Add your description here
Project description
Wagtail Exact Crop
Exact image cropping for Wagtail.
Installation
Assuming you have a Wagtail project set up.
Add wagtail_exact_crop to installed apps:
INSTALLED_APPS = [
"wagtail_exact_crop",
...
]
Configure a custom image model with the exact_crops field:
# images/models.py
from django.db import models
from wagtail.images.models import AbstractImage, AbstractRendition
from wagtail_exact_crop.models import ExactCropImageMixin
class CustomImage(ExactCropImageMixin, AbstractImage):
admin_form_fields = (
"title",
"file",
"description",
"collection",
"tags",
"focal_point_x",
"focal_point_y",
"focal_point_width",
"focal_point_height",
"exact_crops",
)
class CustomRendition(AbstractRendition):
image = models.ForeignKey(
CustomImage,
on_delete=models.CASCADE,
related_name="renditions",
)
# settings.py
WAGTAILIMAGES_IMAGE_MODEL = "images.CustomImage"
After adding the model, create and run migrations for your image app.
Define crop sizes:
WAGTAIL_EXACT_IMAGE_CROP_PRESETS = {
"avatar": {"width": 300, "height": 300},
"medium_shot": {"width": 400, "height": 800},
"list_image_small": {"width": 400, "height": 300},
"list_image_medium": {"width": 800, "height": 600},
"hero_image": {"width": 1600, "height": 600},
}
Define widgets (admin interface). Note that images with the same aspect ratio can share presets:
WAGTAIL_EXACT_IMAGE_CROP_WIDGETS = {
"avatar": {
"title": _("Avatar image"),
"description": _("Used in listings and teasers"),
"presets": ["avatar"],
},
"medium_shot": {
"title": _("Medium shot image"),
"description": _("Used in listings and teasers"),
"presets": ["medium_shot"],
},
"list_image": {
"title": _("List image"),
"description": _("Used in listings and teasers"),
"presets": ["list_image_small", "list_image_medium"],
},
"hero_image": {
"title": _("Hero image"),
"description": _("Large banner at top of page"),
"presets": ["hero_image"],
},
}
Exact crop is registered as a custom image filter, so you can use it in your templates like any other filter. https://docs.wagtail.org/en/latest/extending/custom_image_filters.html
Just use the exact- prefix followed by the crop preset name to apply the crop:
{% load wagtailimages_tags %}
{% image some_image exact-avatar %}
{% image some_image exact-medium_shot %}
{% image some_image exact-list_image_small %}
{% image some_image exact-list_image_medium %}
{% image some_image exact-hero_image %}
Testing
Install the package with test dependencies:
python -m venv .venv
source .venv/bin/activate
pip install -e ".[test]"
Run the automated tests:
pytest
Manual test project
The tests/test_project Django/Wagtail project can be used to test the admin UI manually:
python tests/test_project/manage.py migrate
python tests/test_project/manage.py createsuperuser
python tests/test_project/manage.py runserver
Then open http://127.0.0.1:8000/admin/, upload an image, edit it, adjust the exact crop widgets, and save. The exact crop demo at http://127.0.0.1:8000/exact-crop/ renders the latest uploaded image using the documented exact-* filters. The focal point comparison page at http://127.0.0.1:8000/focal-point/ renders the same target sizes with Wagtail's fill-* filters.
Releasing
Releases are published to PyPI by GitHub Actions when a v* tag is pushed.
uv version 0.1.1
git add pyproject.toml
git commit -m "Release 0.1.1"
git tag -a v0.1.1 -m v0.1.1
git push
git push origin v0.1.1
The Git tag should be the package version with a v prefix. For example, version = "0.1.1" in pyproject.toml is released with tag v0.1.1.
You can also create the GitHub Release in the web UI after pushing the tag. If you create the tag through the GitHub Release UI, make sure the version bump commit is already on the target branch.
To build and inspect the package locally:
uv build
This writes the release artifacts to dist/. Before publishing, inspect the generated files and verify the package data is included:
tar -tf dist/wagtail_exact_crop-*.tar.gz
unzip -l dist/wagtail_exact_crop-*.whl
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file wagtail_exact_crop-0.1.0.tar.gz.
File metadata
- Download URL: wagtail_exact_crop-0.1.0.tar.gz
- Upload date:
- Size: 56.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
418284de70528978036a9fd6ae74a4321de8bc7d30048560b5ab8e832aa2e1bf
|
|
| MD5 |
969057bc4f0b482a1997e57db0e60b40
|
|
| BLAKE2b-256 |
33743f2b0824fa533a5b9f680fa2f1ecae16162ed8ec77b2d8e62759ae7cd71c
|
File details
Details for the file wagtail_exact_crop-0.1.0-py3-none-any.whl.
File metadata
- Download URL: wagtail_exact_crop-0.1.0-py3-none-any.whl
- Upload date:
- Size: 13.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.21 {"installer":{"name":"uv","version":"0.11.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8f39b0ecafcabfbf7ece31ec4a830260c0b564cfcc0abe482ebe99ee08cfeb3
|
|
| MD5 |
b5e19ee8f0ee395b005f7dcaaca194ca
|
|
| BLAKE2b-256 |
75052a156c9add5019a91ad5d6e885eb6955c4a939a7532841e9bf2dfc39e4fa
|