Obsidian as Recipe Manager and Shopping list (Tutorial)

Intro

(Skip this if you want to go straight to the good part)

I have a confession to make:

I’ve never figured out the whole Zettlekasten thing. I know Obsidian is suppose to be God’s gift to second brains, but my ‘zettle’ notes have never gone beyond the following:

“The key to fixing the problem is knowing what it is.”

(Seriously, that’s the entire content of a note I just pulled from my Zettle folder. A real profound world-changer.)

Since I have little desire to share my philosophizing with anyone else, I haven’t seen the point in writing down these soundbites for myself. Perhaps that will change one day, but for now, my main use case for Obsidian is as a life-management tool, not an idea management tool.

A particular area Obsidian shines is as a recipe manager and shopping list. This tutorial/showcase is about setting it up for yourself.

Even though Dataview is used, don’t let that scare you off: you can copy and paste the needed Dataview snippets directly, and no coding skills are needed.

Goals:

Show how to use Obsidian as friction-less shopping list.
Show how to use Obsidian as a recipe manager/digital cookbook.


The Good Part (Tutorial starts here)

Plugins:

Checklist (Required for Shopping list functionality)
And/Or
Dataview (Required for Cookbook functionality)

Themes:

A theme or CSS snippet with a checkmark that doesn’t apply strikethrough to text when checked.
The pictured theme is the Minimal theme.


Part 1: Shopping List

Frictionless, integrated.

Step 1

Download and install the Checklist plugin.

Step 2

Configure the Checklist plugin as follows:

Step 3.

Setup your recipes with the ingredients as checkmark items with the tag #ingredients directly above the list.

NOTE: Make sure no line-breaks exist between the items in your ingredients list. After a line break, you will need to add another #ingredients tag in order for the list to show up correctly.

Each week prior to grocery shopping, I go through the recipes I plan to make that week, review the pantry, and simply uncheck the checkbox next any of the ingredients that I don’t have in each recipe file.

They are automatically populated into the Checklist ‘Shopping list’ sidebar, which I can refer to at the store.

As I shop in the grocery store, I check off the items in the Checklist sidebar, and this checks the checkbox in the individual recipe file. This means I don’t need to open each recipe file to check off items I’ve purchased.

Another way to use this: As you are cooking a recipe and you use up a staple ingredient (like flour or sugar), you simply uncheck the box next to it so that it populates into your shopping list for the next time you go to the store.

It really sucks to use up your Coriander, and then forget you ran out of it the next time you cook Indian food. This way you continually track and replenish your staple pantry items as they are depleted.

In addition to each recipe having it’s own ingredients, I have a separate ‘Shopping List’ file with pantry staples, and other shopping items which would never be found in a recipe, like dish soap and paper towels.

It looks like this:

Because of the #ingredients hashtag at the top, the items on this list are pulled into the Checklist shopping list just like items in the recipes.

Part 2: Cookbook

Plaintext, Auto-Populating, Interlinked.

Download and install the Dataview plugin for the following to work.

I don’t import a ton of recipes from places. In fact, I only put a recipe into Obsidian after I’ve tried it and know that I want to make it again. This tutorial is not about easily grabbing and dumping tons of recipes into your vault. There may be other plugins or guides for that. Instead, this is about organizing recipes that you use regularly; recipes which is worth keeping and evolving over time as needed.

Inputting a recipe usually takes a me few minutes. If it’s digital, then copy-pasting is fairly easy. If it’s from a physical cookbook, I may use an OCR app on my phone to get text, or type it in by hand.

Regardless of the source, I manually format each recipe to fit into my template. Since I may only add three or four recipes a month, this is not a burden for me, and ensures that I only have the highest quality recipes in Obsidian.

Here’s a normal recipe for the Instant Pot, with a breakdown explaining it.

  1. The file name is ‘IP Refried Black Beans’, so that it’s obvious it’s an Instant pot recipe. This is so that if Obsidian goes away, I can still use this text file and know that it only works with an Instant Pot. I have an alias for this which removes the IP prefix, which looks for nicer internal linking.
  2. Tags. My rule for tags is us the absolute minimum possible, and each tag performs a specific, clear task. These are used for Dataview reference.
  3. Notes: This is one of the hidden gems of Obsidian as a cookbook. I often write cooking notes and edit the recipes as I go. In this case, I tweaked the spices and blending method from what the original recipe called for. Then wrote in the note what I changed and why it was successful. Sometimes I will use a footnote [^1] to to show what the original recipe called for.

One reason I dislike Paprika and other recipe managers is that editing recipes usually involves multiple clicks and different screens. With Obsidian, I edit things on the fly, which means my recipes steadily improve and evolve over time. This is also one huge benefit of Digital recipes over paper. With a paper recipe, you can only fit so many scrawled notes into the margins.

  1. Ingredients can be linked! This recipe is based on the Simple Black Beans recipe seen in the images above. A simple link takes me there, while not breaking the Shopping list functionality.

Here is the recipe template file I use. Feel free copy and paste this as a template file, and modify it to suit your own needs. The only YAML required for this tutorial to work is “tags:”. The Recipe sorting in this tutorial is done via Dataview with tags. The rest can be changed to suit your needs.

---
alias:
source:
tags: recipe
---
### Recipe Name 

 >Notes: 

### Ingredients
#ingredients 
- [x] 

---
#### Intro:


---
#### Directions


#### FINISH:

Part 3: Putting it all together

When I create a new recipe, I add tags to it. These tags allow the recipe to automatically categorize and be added into my ‘Cookbook’ file, based on how I have that file setup. No manual adding required.

For example, if I add a new Vegetarian meal that also makes enough left-overs to use for lunches, I add the following tags to the YAML of the recipe: #recipe #vegetarian #meal #lunches

Then the Dataview query looks like this:

LIST FROM #recipe AND #lunches AND #meal AND #vegetarian 
sort desc

Here is a screenshot of my ‘Cookbook’ file.

You can create any kind of list or categorization you want - all you need to do is change which tags you call out in the Dataview snippet.

For instance, I have a set of Thanksgiving recipes. Near the end of my Cookbook file, I used this Dataview snippet to create a small list with ONLY those Thanksgiving recipes for easy reference come November.

LIST FROM #recipe AND #thanksgiving
sort desc

Notice how there are only 2 tags used to create this particular list: #recipe and #thanksgiving Simple. Efficient.

NOTE: In the Cookbook screenshot above, I have several commonly used files with permanent links at the top of my Cookbook file. This is for ease of navigation. I want access to these files without having to use the Folder structure, so these links live there.

Speaking of which, the [[02 Meals This Week]] file is a very short MOC-type file (map of content) which I change every week. It’s extremely basic, but allows me to navigate quickly to the recipes I’m making this week.

Here’s a screenshot:

That’s it.

I hope this is helpful, and that it opens up a new use for Obsidian for you.

46 Likes

Brilliant! Thank you. This is very helpful.

This is great. I like your ideas to incorporate the shopping list.
I assume this all works on mobile too?

I use Obsidian to manage my recipes & publish them for easy access and I’ll probably incorporate some of your ideas.

Yes, it all works on mobile, including the dataview Cookbook file. For a while there was an error where the Checklist plugin wouldn’t load on Android mobile for some users (during which time I reverted to an earlier version of the plugin, which did work), but several days ago a new version of Checklist was released which fixed that issue.

I really appreciate the work the Checklist guys put in - that’s what makes this workflow possible.

Life changingly helpful :white_heart:
Thank you so much for sharing in such detail!

1 Like

Great tutorial. I am very tempted to move from Paprika, but it has a very handy option I use often: scale and convert. Sometimes I want 1/2 portion, sometimes 2 portions. Sometimes I have US recipes (and I’m in Europe), and I can’t be bothered with cups and sticks. This is really the only thing I’m missing.

2 Likes

That’s true, this is a the one real deficiency in this Obsidian setup.

Perhaps I’ll find a way to manage scaling and converting at some point via another plugin.

3 Likes

Shout out if you do :slight_smile:

1 Like

I was looking for this made a account to say thanks!

1 Like

This is fantastic, thank you so much! I’m trying to revamp my recipe system in Obsidian today: I also found the Cooklang plugin which is cool for automatically creating grocery lists and (theoretically - I can’t get it working) converting/scaling measurements (cc @Yanina) - but as far as I can tell it doesn’t work with Dataview etc so makes it of limited use for queries

1 Like

This is brilliant. I especially love the concept of using the ingredients as wikilinks as it will allow me to see what recipes I can make based on my currently available set of ingredients - thanks for sharing!

1 Like

Wondering if this thread could shed some insight?

Hi, can I found more about your recipes management somewhere? Especially how do you publish them or obsidian source codes for the cookbook? Thanks

I think this is such a cool approach to automating your shopping list! Thank you for sharing!!

I was wondering if anyone knows how to pull the checklist from the toolbar into an existing note?

I am trying to integrate this into my existing system. I essentially have a “home page” with recipes for the week, the grocery list, and all meals “on rotation” (that I frequently make) for reference. What I’d like to figure out is if there’s a way to pull the automatic list generated by the checklist plugin into that home note, so I have everything on a single sheet on my phone when I’m out and about.

Thank you!

Great idea @Llew , man, you inspired me to do something similar. There was only one disadvantage to this approach (I found) and it’s that when you have similar recipes, you would have copies of ingredients in the checklist view on the side.

So, I played around a little, and I am sharing the approach without the checklist plugin, using transclusions.

Essentially, it looks almost identical, but thanks to transclusions, I am able to use one ingredient as a global ingredient in my “digital pantry” where, if I am cooking something and I use up an ingredient from this recipe, it automatically shows this ingredient as “missing” in all other recipes, if there are any similar ones.
For reference, I’m posting a few images at the end of the post, but here’s a simple breakdown:
I created a file called “pantry” where I store all ingredients we hold at home (plus those I use in recipes, in categories, which will be explained later).
Then I created a another file called “shopping list” which includes a dataview filter of just the incomplete tasks from the “pantry”.
In the pantry, I changed the list into tasks and assigned unique IDs to each ingredient (with “^” after the ingredient task) and defined it so it’s a global task.

Then, I changed the ingredients part in all the recipes with transclusions (![[pantry^apples]]) of individual ingredients from the pantry, so it’s all automated when I run out of something while cooking.

And then, I added the shopping list (dataview-filtered pantry) to the left pane which shows only the missing ingredients from the pantry, categorized by type. I put them into categories, because I use this filtered view during shopping, to see what I’ve got to buy, and it’s handy to have it categorized as I don’t have to run around the shop looking for ingredients but just scroll to find the group based on where I am in a shop and buy what I need based on the list I find in Obsidian.

The only negative of this approach is that transclusions take up the whole line and so if the ingredient needs to be specified further in the recipe (4 eggs) I have to write this directly into the recipe, either above, or under the transclusion for the given ingredient, which doesn’t look pretty, but I don’t bother.

So in my opinion, this has all the advantages of the approach with checklist, but for those who are like me and hate duplicates of ingredients, it could be a better approach.

split view, for reference:

the whole pantry snapshot with IDs:

the shopping list:

In this example, a recipe that needs “cukor (hnedý)” (sugar (brown)), runs out as I’m cooking, it is updated when the global task in the shopping list changes status, along with all the other recipes that need this ingredient in them and the pantry:
digital pantry

Great explanation and idea!