Skip to main content

GOV.UK Frontend Jinja Macros

Project description

GOV.UK Frontend Jinja Macros

PyPI - Version PyPI - Downloads PyPI - License Static Badge Python package

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

GOV.UK Frontend Jinja GOV.UK Frontend Status
v4.x.x v6.x.x Supported
v3.x.x v5.x.x Supported
v2.x.x v4.x.x Supported
v1.x.x v3.x.x Unsupported

Any other versions of GOV.UK Frontend not shown above may still be compatible, but have not been specifically tested and verified.

Supported

These versions receive active support alongside upstream GOV.UK Frontend releases.

GOV.UK Frontend Jinja GOV.UK Frontend
4.0.0 6.0.0
3.10.0 5.14.0
3.9.0 5.13.0
3.8.0 5.12.0
3.7.0 5.11.1
3.6.0 5.10.0
3.5.0 5.9.0
3.4.1 5.8.0
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

Unsupported

These versions are no longer supported as upstream GOV.UK Frontend support has ended.

GOV.UK Frontend Jinja GOV.UK Frontend
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

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:

  1. 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
  2. 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 in govuk_frontend_jinja/templates/components/<component>/macro.html
  3. 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 as is, not and in.
  4. Run the tests as described above
  5. Resolve any failing tests by comparing the expected HTML output with the actual HTML reported by the test tool
  6. 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.
  7. Once all tests are passing follow the contribution guidelines to raise a pull request.
  8. After the pull request has been merged, create a new release and tag following SemVer conventions.
  9. 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

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

govuk_frontend_jinja-4.0.0.tar.gz (35.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

govuk_frontend_jinja-4.0.0-py3-none-any.whl (48.0 kB view details)

Uploaded Python 3

File details

Details for the file govuk_frontend_jinja-4.0.0.tar.gz.

File metadata

  • Download URL: govuk_frontend_jinja-4.0.0.tar.gz
  • Upload date:
  • Size: 35.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for govuk_frontend_jinja-4.0.0.tar.gz
Algorithm Hash digest
SHA256 1bcb50779ae4852a0fcb9fb53dab2301a08f1435923900cf5d1be84d8063f31b
MD5 afce1dd634a5c269a6bb2809a1d0e3fb
BLAKE2b-256 9351984b2ebfc5d7aa9bb7426f25d6e188602afa215b087dc68f63fc701d9957

See more details on using hashes here.

File details

Details for the file govuk_frontend_jinja-4.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for govuk_frontend_jinja-4.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8e21fe3c0f3a2499507b021f32f99a3c0107d19cda8c03d9e8572333568e17e9
MD5 6829756caf43a72f132ff2476319978e
BLAKE2b-256 c90afb367109458cc8b8f1de8b23a65e6c54acdf81d237ca7509d915559cffb8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page