En-tête
L’en-tête est géré grâce à une balise include
dans le fichier base.html
. Si vous n’avez pas besoin de le personnaliser, vous n’avez rien à faire.
Il est alors possible de personnaliser le titre, le sous-titre, ainsi que le bloc-marque, via la configuration du site dans l’administration de Django.
- Voir la page de documentation du composant sur le Système de Design de l’État Ouvre une nouvelle fenêtre
- Voir la page d’exemple du Système de Design de l’État Ouvre une nouvelle fenêtre
Composants liés
Le gabarit d’en-tête est également l’endroit où inclure les composants suivants :
- Navigation principale (navigation) (Documentation — Exemple), à insérer dans le bloc
main_menu
. - Sélecteur de langue (translate) : (Documentation — Exemple), à insérer dans le bloc
header_tools
. L’application d’exemple donne un exemple d’implémentation ne traduisant que l’interface, et ne changeant pas l’URL, mais il est plutôt recommandé de définir un préfixe de langue dans l’URL, cf. la documentation de Django.
Personnaliser
Il est possible de l’étendre pour le personnaliser, par exemple pour ajouter la barre de recherche :
<!-- <votre_app>/templates/<votre_app>/base.html -->
{% extends "django_village/base.html" %}
<!-- [...] -->
{% block header %}
{% include "<votre_app>/blocks/header.html" %}
{% endblock header %}
<!-- <votre_app>/templates/<votre_app>/blocks/header.html -->
{% extends "django_village/header.html" %}
{% block header_search %}
<div class="village-header__search village-modal" id="modal-search">
<div class="village-container village-container-lg--fluid">
<button class="village-btn--close village-btn"
aria-controls="modal-search"
title="Fermer">
Fermer
</button>
<form action="{% url 'page_search' %}" method="get">
<div class="village-search-bar" id="search-bar" role="search">
<label class="village-label" for="search-bar-input">
Rechercher
</label>
<input class="village-input"
placeholder="Rechercher"
type="search"
id="query"
name="q">
<button class="village-btn" title="Rechercher">
Rechercher
</button>
</div>
</form>
</div>
</div>
{% endblock header_search %}
Opengraph
Un bloc opengraph
, vide par défaut, est fourni pour permettre d’entrer des données de partage sur les réseaux sociaux.
<!-- <votre_app>/templates/<votre_app>/base.html -->
{% extends "django_village/base.html" %}
<!-- [...] -->
{% block opengraph }
<meta name="twitter:card" content="summary_large_image">
<meta name="twitter:site" content="[À MODIFIER - @usernameTwitter]">
<meta property="og:title" content="[À MODIFIER - Système de Design de l'État]">
<meta property="og:description" content="[À MODIFIER - Développer vos sites et applications en utilisant des composants prêts à l'emploi, accessibles et ergonomiques]">
<meta property="og:image" content="[À MODIFIER - https://systeme-de-design.gouv.fr/src/img/systeme-de-design.gouv.fr.jpg]">
<meta property="og:type" content="website">
<meta property="og:url" content="[À MODIFIER - https://systeme-de-design.gouv.fr/]">
<meta property="og:site_name" content="[À MODIFIER - Site officiel du Système de Design de l'État]">
<meta property="og:image:alt" content="[À MODIFIER - République Française - Système de Design de l'État]">
<meta name="twitter:image:alt" content="[À MODIFIER - République Française - Système de Design de l'État]">
{% endblock opengraph }