3.7 KiB
My Online Cookbook
This repository is based on Maël Brunet's template
My Online Cookbook is a starter kit to create your own website of recipes, using Eleventy and Netlify CMS. It is meant to be both highly accessible (including to non-developers), as well as fully customisable should you want to use it as a starting off point.
Presentation & set-up instructions : https://myonlinecookbook.xyz/
Demo (this is what you get out of the box) : https://myonlinecookbook.netlify.app/
Get started now by forking the project or deploy to Netlify :
Features
📘 Optimised for recipes
Unlike other general-purpose templates and website builders, My Online Cookbook is optimised for writing, reading and easily finding back your recipes. Quickly visualise which ingredients you need, navigate between recipes in the same categories, and automatically adapt quantities based on the number of servings.
💪 Powerful search
The kit includes a powerful live search system offering a UX on-par with third-party services like Algolia, without needing any external dependency or subscription service.
🧰 Lightweight & easily extendable
Easily customise the theme color and other site attributes using the global data files, or dive into the code and change anything. The CSS is authored using Sass and following the BEM naming convention. JavaScript is added where needed using Alpine and following a component-based approach. Images are processed and optimised at build-time using the Eleventy image plugin. Apart from Alpine, there are no run-time dependencies, making the site both extremely lightweight and easy to pick up and modify.
Running the site locally
npm installto install all dependenciesnpm run devto serve the site locallynpm run buildto build the site for production
Access the CMS admin interface
Go to /admin to access the admin interface (this also works locally). You'll need to configure a user with Netlify Identity to log in. For more information on how to use or configure Netlify CMS go to their documentation. In addition to recipes, all site settings (primary color, etc) as well as labels are editable from this interface.
Directory structure
.eleventy.jshas all the custom configuration for Eleventy, including collections, filters and shortcodes.src/_datacontains nav and site settings, also editable from the CMS admin interface.src/_includescontains layouts and reusable components (including SVG icons).src/admincontains the configuration for editable fields in Netlify CMS.src/imgcontains all images. Note that only images placed insrc/img/recipesare editable from the CMS admin interface.src/recipesis your main content, with each recipe saved as a markdown file.- Each other page is located at the root of
src/as its own markdown or nunjucks file.