GOV.UK Frontend Jinja Macros
Project description
GOV.UK Frontend Jinja Macros
GOV.UK Frontend Jinja is a community tool of the GOV.UK Design System. The Design System team is not responsible for it and cannot support you with using it. Contact the maintainers directly if you need help or you want to request a feature.
This repository provides a complete set of Jinja macros that are kept up-to-date and 100% compliant with the original GOV.UK Frontend Nunjucks macros. Porting is intentionally manual rather than automated to make updates simpler than maintaining an automated conversion routine. A comprehensive test suite ensures compliance against the latest, and every subsequent, GOV.UK Frontend release.
If you are looking to build a fully featured Flask app that integrates with GOV.UK Frontend Jinja and GOV.UK Frontend WTForms please use the GOV.UK Frontend Flask template repository to generate your app.
Compatibility
The following table shows the version of GOV.UK Frontend Jinja that you should use for your targeted version of GOV.UK Frontend:
GOV.UK Frontend Jinja Version | Target GOV.UK Frontend Version |
---|---|
3.4.0 | 5.7.1 |
3.3.0 | 5.6.0 |
3.2.0 | 5.5.0 |
3.1.0 | 5.4.0 |
3.0.0 | 5.1.0 |
2.8.0 | 4.8.0 |
2.7.0 | 4.7.0 |
2.6.0 | 4.6.0 |
2.5.0 | 4.5.0 |
2.4.0 | 4.4.1 |
2.3.0 | 4.2.0 |
2.2.0 | 4.1.0 |
2.1.0 | 4.0.1 |
2.0.0 | 4.0.0 |
1.6.0 | 3.15.0 |
1.5.1 | 3.14.0 |
1.4.0 | 3.13.0 |
1.3.0 | 3.12.0 |
1.2.1 | 3.11.0 |
1.1.0 | 3.10.2 |
1.0.0 | 3.8.1 |
0.2.1 | 3.7.0 |
Any other versions of GOV.UK Frontend not shown above may still be compatible, but have not been specifically tested and verified.
How to use
After running pip install govuk-frontend-jinja
, ensure that you tell Jinja where to load the templates from using the PackageLoader
as follows:
from flask import Flask
from jinja2 import ChoiceLoader, PackageLoader, PrefixLoader
app = Flask(__name__)
app.jinja_loader = ChoiceLoader(
[
PackageLoader("app"),
PrefixLoader({"govuk_frontend_jinja": PackageLoader("govuk_frontend_jinja")}),
]
)
Calling a Macro in your template
To use a component in your project templates you must import and call the component macro and pass the relevant options, for example:
{%- from 'govuk_frontend_jinja/components/button/macro.html' import govukButton -%}
{{ govukButton({ 'text': "Save and continue" }) }}
The options available to each component macro can be found in the original GOV.UK Design System Components documentation. Since this project is a like-for-like port, the only difference between the Nunjucks examples and their Jinja equivalents is having to quote key names, e.g. 'text'
instead of text
.
Running the tests
The tests are run in a GitHub actions pipeline but if you want to run them locally you will need to install govuk-frontend-diff.
There is a test server at tests/utils/app.py
which you will need to run using the following command:
(cd tests/utils && python -m flask run --port 3000)
You can then run the tests using govuk-frontend-diff
as follows:
./govuk-frontend-diff http://localhost:3000 --govuk-frontend-version=v4.8.0
This is all wrapped up in ./test.sh
for simplified running (Requires Docker).
Versioning
We use SemVer for versioning. For the versions available, see the tags on this repository.
How to contribute
We welcome contribution from the community. If you want to contribute to this project, please review the code of conduct and contribution guidelines.
Update methodology
How to update this package following a new release of GOV.UK Frontend:
- On
govuk-frontend
, compare the last compatible tag and the latest tag, e.g. https://github.com/alphagov/govuk-frontend/compare/v4.3.1...v4.4.0 - If there are any changes to templates in
package/govuk/components/<component>/template.njk
read the diff and apply the same changes to the Jinja equivalent templates ingovuk_frontend_jinja/templates/components/<component>/macro.html
- Take into account any idiosyncrasies between how Nunjucks and Jinja would interpret that template. E.g.
None
checking nested attributes, checking array items lengths or logic operators such asis
,not
andin
. - Run the tests as described above
- Resolve any failing tests by comparing the expected HTML output with the actual HTML reported by the test tool
- Add a new row to the compatibility table above to show which version of GOV.UK Frontend the next release of this package will be targeting.
- Once all tests are passing follow the contribution guidelines to raise a pull request.
- After the pull request has been merged, create a new release and tag following SemVer conventions.
- GitHub Actions will run on the new tag to build the package and publish it to PyPI. Verify that the package has been updated with the latest release tag by checking the project page
Contributors
- Matt Shaw (Primary maintainer)
- Andy Mantell (Original author)
See the full list of contributors on GitHub
Support
This software is provided "as-is" without warranty. Support is provided on a "best endeavours" basis by the maintainers and open source community.
If you are a civil servant you can sign up to the UK Government Digital Slack workspace to contact the maintainers listed above and the community of people using this project in the #govuk-design-system channel.
Otherwise, please see the contribution guidelines for how to raise a bug report or feature request.
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
File details
Details for the file govuk_frontend_jinja-3.4.0.tar.gz
.
File metadata
- Download URL: govuk_frontend_jinja-3.4.0.tar.gz
- Upload date:
- Size: 33.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26f34d47a4fe7447078bb6fbe8e9923fa0f5bd9c56230605e5a150e28c1c76d2 |
|
MD5 | fde728d65e53af67f084cd2d2d37ff61 |
|
BLAKE2b-256 | 1ccc258f63af5304fe4ef0352ea6643d8038ece91b76021e2297175f5aaaa066 |
File details
Details for the file govuk_frontend_jinja-3.4.0-py3-none-any.whl
.
File metadata
- Download URL: govuk_frontend_jinja-3.4.0-py3-none-any.whl
- Upload date:
- Size: 46.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d2d3d56db3549e0dbef1b385076ea3a55b0c2279a57205cafc7fd812e0f3943f |
|
MD5 | 98cfc57fbef2b0ba5d119dc7ef2ead34 |
|
BLAKE2b-256 | d7c090cbd104aa0758627e5e7574d2876c762d66cd17c8fe1d9d9c7dbe7ef290 |