- Move extending React to new extending client-side page within advanced topics - Add general extending JavaScript / client-side overview - Prepare initial Stimulus usage documentation - Resolves #10197 - Apply suggestions from code review - Co-authored-by: Thibaud Colas <thibaudcolas@gmail.com>
8.5 KiB
Customising admin templates
In your projects with Wagtail, you may wish to replace elements such as the Wagtail logo within the admin interface with your own branding. This can be done through Django's template inheritance mechanism.
You need to create a templates/wagtailadmin/
folder within one of your apps - this may be an existing one, or a new one created for this purpose, for example, dashboard
. This app must be registered in INSTALLED_APPS
before wagtail.admin
:
INSTALLED_APPS = (
# ...
'dashboard',
'wagtail',
'wagtail.admin',
# ...
)
(custom_branding)=
Custom branding
The template blocks that are available to customise the branding in the admin interface are as follows:
branding_logo
To replace the default logo, create a template file dashboard/templates/wagtailadmin/base.html
that overrides the block branding_logo
:
{% extends "wagtailadmin/base.html" %}
{% load static %}
{% block branding_logo %}
<img src="{% static 'images/custom-logo.svg' %}" alt="Custom Project" width="80" />
{% endblock %}
The logo also appears in the following pages and can be replaced with its template file:
- login page - create a template file
dashboard/templates/wagtailadmin/login.html
that overwrites thebranding_logo
block. - 404 error page - create a template file
dashboard/templates/wagtailadmin/404.html
that overrides thebranding_logo
block. - wagtail userbar - create a template file
dashboard/templates/wagtailadmin/userbar/base.html
that overwrites thebranding_logo
block.
branding_favicon
To replace the favicon displayed when viewing admin pages, create a template file dashboard/templates/wagtailadmin/admin_base.html
that overrides the block branding_favicon
:
{% extends "wagtailadmin/admin_base.html" %}
{% load static %}
{% block branding_favicon %}
<link rel="shortcut icon" href="{% static 'images/favicon.ico' %}" />
{% endblock %}
branding_title
To replace the title prefix (which is 'Wagtail' by default), create a template file dashboard/templates/wagtailadmin/admin_base.html
that overrides the block branding_title
:
{% extends "wagtailadmin/admin_base.html" %}
{% block branding_title %}Frank's CMS{% endblock %}
branding_login
To replace the login message, create a template file dashboard/templates/wagtailadmin/login.html
that overrides the block branding_login
:
{% extends "wagtailadmin/login.html" %}
{% block branding_login %}Sign in to Frank's Site{% endblock %}
branding_welcome
To replace the welcome message on the dashboard, create a template file dashboard/templates/wagtailadmin/home.html
that overrides the block branding_welcome
:
{% extends "wagtailadmin/home.html" %}
{% block branding_welcome %}Welcome to Frank's Site{% endblock %}
(custom_user_interface_fonts)=
Custom user interface fonts
To customise the font families used in the admin user interface, inject a CSS file using the hook and override the variables within the :root
selector:
:root {
--w-font-sans: Papyrus;
--w-font-mono: Courier;
}
(custom_user_interface_colours)=
Custom user interface colours
The default Wagtail colours conform to the WCAG2.1 AA level colour contrast requirements. When customising the admin colours you should test the contrast using tools like [Axe](https://www.deque.com/axe/browser-extensions/).
To customise the colours used in the admin user interface, inject a CSS file using the hook and set the desired variables within the :root
selector. Colour variables are reused across both the light and dark themes of the admin interface. To change the colours of a specific theme, use:
:root, .w-theme-light
for the light theme..w-theme-dark
for the dark theme.@media (prefers-color-scheme: light) { .w-theme-system { […] }}
for the light theme via system settings.@media (prefers-color-scheme: dark) { .w-theme-system { […] }}
for the dark theme via system settings.
There are two ways to customise Wagtail’s colour scheme:
- Set static colour variables, which are then reused in both light and dark themes across a wide number of UI components.
- Set semantic colours, which are more numerous but allow customising specific UI components.
For static colours, either set each colour separately (for example --w-color-primary: #2E1F5E;
); or separately set HSL (--w-color-primary-hue
, --w-color-primary-saturation
, --w-color-primary-lightness
) variables so all shades are customised at once. For example, setting --w-color-secondary-hue: 180;
will customise all of the secondary shades at once.
Specifying a site or page in the branding
The admin interface has a number of variables available to the renderer context that can be used to customise the branding in the admin page. These can be useful for customising the dashboard on a multitenanted Wagtail installation:
root_page
Returns the highest explorable page object for the currently logged in user. If the user has no explore rights, this will default to None
.
root_site
Returns the name on the site record for the above root page.
site_name
Returns the value of root_site
, unless it evaluates to None
. In that case, it will return the value of settings.WAGTAIL_SITE_NAME
.
To use these variables, create a template file dashboard/templates/wagtailadmin/home.html
, just as if you were overriding one of the template blocks in the dashboard, and use them as you would any other Django template variable:
{% extends "wagtailadmin/home.html" %}
{% block branding_welcome %}Welcome to the Admin Homepage for {{ root_site }}{% endblock %}
Extending the login form
To add extra controls to the login form, create a template file dashboard/templates/wagtailadmin/login.html
.
above_login
and below_login
To add content above or below the login form, override these blocks:
{% extends "wagtailadmin/login.html" %}
{% block above_login %} If you are not Frank you should not be here! {% endblock %}
fields
To add extra fields to the login form, override the fields
block. You will need to add {{ block.super }}
somewhere in your block to include the username and password fields:
{% extends "wagtailadmin/login.html" %}
{% block fields %}
{{ block.super }}
<li>
<div>
<label for="id_two-factor-auth">Two factor auth token</label>
<input type="text" name="two-factor-auth" id="id_two-factor-auth">
</div>
</li>
{% endblock %}
submit_buttons
To add extra buttons to the login form, override the submit_buttons
block. You will need to add {{ block.super }}
somewhere in your block to include the sign in button:
{% extends "wagtailadmin/login.html" %}
{% block submit_buttons %}
{{ block.super }}
<a href="{% url 'signup' %}"><button type="button" class="button">{% trans 'Sign up' %}</button></a>
{% endblock %}
login_form
To completely customise the login form, override the login_form
block. This block wraps the whole contents of the <form>
element:
{% extends "wagtailadmin/login.html" %}
{% block login_form %}
<p>Some extra form content</p>
{{ block.super }}
{% endblock %}
Extending the password reset request form
To add extra controls to the password reset form, create a template file dashboard/templates/wagtailadmin/account/password_reset/form.html
.
above_form
and below_form
To add content above or below the password reset form, override these blocks:
{% extends "wagtailadmin/account/password_reset/form.html" %}
{% block above_login %} If you have not received your email within 7 days, call us. {% endblock %}
submit_buttons
To add extra buttons to the password reset form, override the submit_buttons
block. You will need to add {{ block.super }}
somewhere in your block if you want to include the original submit button:
{% extends "wagtailadmin/account/password_reset/form.html" %}
{% block submit_buttons %}
<a href="{% url 'helpdesk' %}">Contact the helpdesk</a>
{% endblock %}
Extending client-side JavaScript
Wagtail provides multiple ways to extend client-side JavaScript.