Bakerydemo
Next generation Wagtail demo, born in Reykjavík
Install / Use
/learn @wagtail/BakerydemoREADME
Wagtail demo project
This is a demonstration project for the amazing Wagtail CMS.
The demo site is designed to provide examples of common features and recipes to introduce you to Wagtail development. Beyond the code, it will also let you explore the admin/editorial interface of the CMS.
Note we do not recommend using this project to start your own site - the demo is intended to be a springboard to get you started. Feel free to copy code from the demo into your own project.
Wagtail Features Demonstrated in This Demo
This demo is aimed primarily at developers wanting to learn more about the internals of Wagtail, and assumes you'll be reading its source code. After browsing the features, pay special attention to code we've used for:
- Dividing a project up into multiple apps
- Custom content models and "contexts" in the "breads" and "locations" apps
- A typical weblog in the "blog" app
- Example of using a "base" app to contain misc additional functionality (e.g. Contact Form, About, etc.)
- "StandardPage" model using mixins borrowed from other apps
- Example of customizing the Wagtail Admin via wagtail_hooks
- Example of using the Wagtail "snippets" system to represent bread categories, countries, and ingredients
- Example of a custom "Galleries" feature that pulls in images used in other content types in the system
- Example of creating ManyToMany relationships via the Ingredients feature on BreadPage
- Lots more
Document contents
Installation
If you want to see what Wagtail is all about, we suggest trying it out locally in a virtual environment: Setup with venv.
If you're new to Python and/or Django, we suggest you run this project on a Virtual Machine using Docker or Vagrant (whichever you're most comfortable with). Both Vagrant and Docker will help resolve common software dependency issues.
Setup with Vagrant
Dependencies
Installation
Once you've installed the necessary dependencies run the following commands:
git clone https://github.com/wagtail/bakerydemo.git
cd bakerydemo
vagrant up
vagrant ssh
# then, within the SSH session:
./manage.py runserver 0.0.0.0:8000
The demo site will now be accessible at http://localhost:8000/ and the Wagtail admin interface at http://localhost:8000/admin/.
Log into the admin with the credentials admin / changeme.
Use Ctrl+c to stop the local server. To stop the Vagrant environment, run exit then vagrant halt.
Setup with Docker
Dependencies
Installation
Run the following commands:
git clone https://github.com/wagtail/bakerydemo.git --config core.autocrlf=input
cd bakerydemo
docker compose up --build -d
After this command completes and returns to the command prompt, wait 10 more seconds for the database setup to complete. Then run:
docker compose run app /venv/bin/python manage.py migrate
docker compose run app /venv/bin/python manage.py load_initial_data
If this fails with a database error, wait 10 more seconds and re-try. Finally, run:
docker compose up
The demo site will now be accessible at http://localhost:8000/ and the Wagtail admin interface at http://localhost:8000/admin/.
Log into the admin with the credentials admin / changeme.
Important: This docker-compose.yml is configured for local testing only, and is not intended for production use.
Debugging
To tail the logs from the Docker containers in realtime, run:
docker compose logs -f
Setup with venv
You can run the Wagtail demo locally without setting up Vagrant or Docker and simply use venv, which is the recommended installation approach for Django itself.
Dependencies
- Python 3.10+
- venv
Installation
On GNU/Linux or macOS (bash):
python -m venv .venv
source .venv/bin/activate
On Windows, activate the virtual environment using the appropriate command for your shell:
# PowerShell
.venv\Scripts\Activate.ps1
# Command Prompt (cmd.exe)
.venv\Scripts\activate.bat
Note (PowerShell Execution Policy) If activating with
Activate.ps1fails with an error like “running scripts is disabled on this system”, you can either:
- use
.venv\Scripts\activate.batin Command Prompt, or- allow scripts in PowerShell for your user account:
Set-ExecutionPolicy -Scope CurrentUser RemoteSigned
Now we're ready to set up the bakery demo project itself:
cd ~/dev [or your preferred dev directory]
git clone https://github.com/wagtail/bakerydemo.git
cd bakerydemo
pip install -r requirements/development.txt
Next, we need to create the files .env and bakerydemo/settings/local.py, which provide a place for local configuration settings that need to be kept outside of version control. No such settings are required for a standard installation, but warnings will be displayed if these files are not present:
cp bakerydemo/settings/local.py.example bakerydemo/settings/local.py
cp .env.example .env
# `cp` is used for bash. Windows Command Prompt uses `copy`
To set up your database and load initial data, run the following commands:
./manage.py migrate
./manage.py load_initial_data
./manage.py runserver
Log into the admin with the credentials admin / changeme.
Next steps
Hopefully after you've experimented with the demo you'll want to create your own site. To do that you'll want to run the wagtail start command in your environment of choice. You can find more information in the getting started Wagtail CMS docs.
Contributing
Check out our contributing documentation for our contributing guidelines and docs for common tasks.
Other notes
Local configuration files
The bakerydemo/settings/local.py file can be used to store local Django settings such as database connection details that need to be kept outside of version control.
Additionally, various settings can be controlled through environment variables. The python-dotenv package is used to load these variables from a .env file in the project root.
Note on demo search
Because we can't (easily) use ElasticSearch for this demo, we use wagtail's native DB search.
However, native DB search can't search specific fields in our models on a generalized Page query.
So for demo purposes ONLY, we hard-code the model names we want to search into search.views, which is
not ideal. In production, use ElasticSearch and a simplified search query, per
https://docs.wagtail.org/en/stable/topics/search/searching.html.
Sending email from the contact form
The following setting in base.py and production.py ensures that live email is not sent by the demo contact form.
EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
In production on your own site, you'll need to change this to:
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
and configure SMTP settings appropriate for your email provider.
Users included in demo data
The demo data includes users with different roles and preferences. You can use these users to quickly test the permission system in Wagtail or how localization is handled in the admin interface.
| Username | Password | Superuser | Groups | Preferred language | Timezone | Active |
| ----------- | ---------- | --------- | ---------- | ------------------ | ------------- | ------ |
| admin | changeme | Yes | None | undefined | undefined | Yes |
| editor | changeme | No | Editors | undefined | undefined | Yes |
| moderator | changeme | No | Moderators | undefined | undefined | Yes |
| inactive | changeme | yes | None | undefined | undefined | No |
| german | changeme | yes | None | German | Europe/Berlin | Yes |
| arabic | changeme | yes | None | Arabic | Asia/Beirut | Yes |
Ownership of demo content
All content in the demo is public domain. Textual content in this project is either sourced from Wikimedia (Wikipedia for blog posts, Wikibooks for recipes) or is lorem ipsum. All images are from either Wikimedia Commons or other copyright-free sources.
