Wagtail Tag Manager is an admin interface for managing tag usage across your Wagtail site:
- View and manage all objects (Page, Image, Document, etc.) using a given tag
- Works across Pages, Documents, Images, and other tagged models that use
django-taggit - Add or remove tags from multiple object types
- Bulk merge and delete tags
- Add multiple pages to a given tag
- Edit tag names and slugs
- Compatible with custom tag models and page models
- Python 3.8, 3.9, 3.10, 3.11, 3.12, 3.13
- Django 4.2, 5.0, 5.1, 5.2
- Wagtail 5.2, 6.1, 6.2, 6.3, 6.4
While these are the officially supported versions, wagtail-tagmanager may work on older versions of Python, Django, or Wagtail as it avoids reliance on newer features. Please note that issues on unsupported versions might not be prioritized.
-
Install via pip:
pip install wagtail-tags -
Add to your
INSTALLED_APPS:INSTALLED_APPS = [ ... "wagtail_tagmanager", ]
-
Configure your settings:
-
Specify the model you use that inherits from
TaggedItemBase. If you use tags for pages, you would have set this up already. More information here. You must define this setting to use this tag manager :WAGTAIL_TAGMANAGER_PAGE_TAG_MODEL = "yourapp.BlogPageTag"
-
If you want to be able add pages to a specific tag in bulk, specify the page model you want to add tags to. If you want to add tags to all pages, set it to your first concrete model that inherits Page (if the model is abstract, this will not work). You must define this setting to add pages to a tag
WAGTAIL_TAGMANAGER_BASE_PAGE_MODEL = "yourapp.BlogPage"
-
Once installed, go to the "Tags" section in the Wagtail admin.
There are four main views:
- View all tags in the project and how many objects are tagged with each tag
- Add and Delete tags
- Merge multiple tags into one
- Click each tag to go to Tag Edit View
- Edit tag
NameandSlug - Button to view all objects tagged with that tag
- View and search all objects tagged with the selected tag
- Remove the tag from multiple objects
- Button to add pages to this tag (Note: This button only appears if
WAGTAIL_TAGMANAGER_BASE_PAGE_MODELis defined)
- Add pages in bulk to the specified tag
- Search for a specific page by title
- The object count for each tag will count objects even if their model was deleted (since deleting a model does not delete it's corresponding
ContentType). This can lead to incorrect object counts on the Tag Index Page. Thismodelis defined in theContentTypemodel
If you would like to contribute, feel free to create a pull request. All changes to main must go through a pull request and be reviewed. Direct pushes, merges without review, or force pushes are blocked by branch protection rules.
Clone this repository:
git clone https://github.com/mikhail-robinson/wagtail-tagmanager.git
cd wagtail-tagmanagerFrom inside your preferred virtual environment:
cd wagtail-tagmanager
pip install -r requirements.txtNote that this project uses pre-commit to enforce ruff formatting. This will check that you have run ruff format and ruff check before committing. If you forget, pre-commit will throw the error Git: [WARNING] Unstaged files detected when committing to remind you. To setup locally:
cd wagtail-tagmanager
pre-commit installcd wagtail-tagmanager
python3 runtests.pyPlease make sure all tests pass before committing



