Table des matières

Principes généraux

Pour concevoir l'architecture graphique de ce site, je me suis inspiré des principes de l'Atomic Design développé par Brad Frost. Cette méthode propose de distinguer cinq niveaux d'organisation graphique :

Page
Le plus « haut » niveau d'organisation graphique est celui de la « page », qui correspond à la composition de tous les autres éléments d'organisation afin de former une unité complète sur laquelle l'expérience d'usage peut être mesurée.

Exemple : Dans le cas de ce site, une « page » correspond à un document HTML associé à une route particulière.

Note :

À un niveau d'organisation « supérieur » à celui de « page », on pourait par exemple, considérer le niveau d'organisation du « site » lui-même. De la même manière, on pourrait concevoir l'organisation des pages à l'intérieur d'un livre. Cependant, je considère que ces niveaux d'organisation « supérieurs » au concept de « page » ne relèvent plus d'un cadre « graphique », mais mobilisent d'autres cadres analytiques.

Patron
Le « patron » (template) prescrit la manière de composer les différents éléments au sein des différentes pages.

Exemple : Dans le cas présent, il s'agit de définir des principes comme la présence du menu de navigation fixe en haut de la zone d'affichage sur toutes les pages, la présence des liens dans le pied-de-page, etc. Techniquement, le concept de blocs dans le langage Twig me permet de construire ces « patrons » grâce à l'instruction {extends}

Organisme
Un « organisme » correspond à une unité graphique de l'interface d'utilisation, qui articule plusieurs éléments fonctionnels dans un ensemble cohérent.

Exemple : le menu de navigation en haut de la page, le menu de pied-de-page, ou les « cartes ».

Molécule
Une « molécule » correspond à une unité fonctionnelle de l'interface graphique, qui répond à un cas d'utilisation particulier.

Exemple : une ligne d'un formulaire, un bouton, etc.

Atome
Enfin, les « atomes » correspondent à des unités élémentaires du langage (ie. constitués d'un élément HTML sans enfant, ou ne contenant que des nœuds de texte), qui peuvent être articulés ensemble pour former les « molécules »

Exemple : un champ de formulaire <input>, qui forme une molécule lorsqu'il est combiné avec son étiquette <label>.

Patrons

Tous les différents patrons des pages de ce site se composent de 4 parties principales :

Navigation générale
La barre de navigation principale est fixée en haut de la zone d'affichage, de manière à être toujours accessible (excepté pour les clients comme les imprimantes, qui ne nécessitent pas de navigation).
En-tête
Le haut de la page comprend trois organismes graphiques :
  1. un fil d'Ariane permettant de situer la page par rapport à l'architecture plus globale du site ;
  2. une bannière avec le titre de la page et une courte description ;
  3. un sommaire qui résume le contenu de la page, avec des liens pour accéder aux différentes sections principales.
Contenu principal
Le corps de la page se compose d'un ou plusieurs éléments <article>, lesquels doivent être identifiés par un élément <h2>-<h6>, ou bien d'éléments <section>. Le patron de chaque page adapte le contenu et la forme de ces éléments en fonction des besoins.
Pied de page
Le pied de page contient différents liens utiles et informations légales obligatoires.

Ces différents éléments forment une base, à partir de laquelle les patrons des différentes pages peuvent être construits, en ajustant la composition de la banière et le contenu du corps de la page. Les titres de chaque article qui composent la page sont automatiquement ajoutés au sommaire via JavaScript.

Organismes

Navigation générale

Le menu de navigation principal se divise en deux sous-parties principales :

Marque
Le logo du site avec un lien vers la page d'accueil
Menu
Le menu à proprement parler, qui contient la liste des liens principaux, mais aussi des menus d'actions pour accéder aux différentes traductions du contenu.

Le menu de navigation exhibe deux comportements différents en fonction de la taille de la zone d'affichage :

  • Sur petits écrans, le contenu du menu est caché, et ne s'affiche qu'en appuyant sur un bouton dédié. Le menu occupe alors l'ensemble de l'espace de l'écran, avec le menu d'actions en bas.
  • Sur les écrans plus larges, le contenu du menu s'affiche en ligne, avec des menus déroulables qui s'étendent en dessous, et le menu d'action aligné à droite.

Exemple :

Fil d'Ariane

Le fil d'Ariane permet d'afficher les liens vers les différentes sections liées à la page courante. Il se compose d'une succession de liens sur lesquels des pseudo-éléments sont ajoutés automatiquement pour indiquer les relations de dépendence entre un lien et le suivant.

Exemple :

Bannière

Une bannière permet d'afficher une image en arrière-plan d'un contenu, avec un fond qui permet d'assurer un contraste suffisant pour garantir la lisibilité du contenu.

Exemple :

Sommaire

Le sommaire regroupe automatiquement des liens vers les différentes sections principales de la page (c'est-à-dire les différents éléments <article> qui contiennent un titre de niveau <h2>).

Exemple :

Cartes

Une carte est un élément qui comporte une en-tête, un contenu principal, et éventuellement une section dédiée à une liste d'actions, et qui prennent la forme de petites cartes qui peuvent être placées les unes à côté des autres.

Exemple :

Debitis eligendi corporis qui ratione et expedita quam. Aliquam qui fugit hic est. Fugiat iusto mollitia minima aut pariatur. Distinctio ipsa fuga incidunt magni non eaque et. Rerum nihil odit et.

Alias deserunt dicta error voluptatem corporis sit

Quam qui et aspernatur vel.

Aliquam rerum dolorum laborum eveniet quia sed consequatur. Ut autem distinctio quis.

Dicta quo quia aut. Eos nihil nisi magnam temporibus. Deleniti impedit vel explicabo similique deserunt qui. Quis dolorum est cupiditate. Eius qui voluptatem et molestiae impedit enim.

Ligne de temps

Affichage d'une séquence de sections organisées selon une ligne temporelle.

Exemple :
2026—2027

Accusamus commodi similique

Adipisci incidunt

Quas adipisci quidem et itaque sed sit. Nesciunt nam totam nihil sit cupiditate et harum corporis. Sequi unde molestiae aut dolor voluptas nemo iusto.

Temporibus vel consequatur atque qui. Aspernatur in deleniti corporis quo labore architecto. Quo alias pariatur et. Quod fugiat quasi maiores laudantium a consequatur illo.

Eius omnis sed aut expedita reiciendis. Natus dolore reprehenderit inventore voluptatibus dicta et. Ullam blanditiis cumque delectus et ipsa voluptas.

Et delectus vel distinctio iusto maiores. Et ipsa velit modi in aut. Repudiandae veniam molestiae voluptas voluptas voluptate quidem ea.

2025—2026

consequatur ut ea

Veritatis esse qui sint voluptate aliquid

Est inventore vero fuga. Rerum consequatur voluptas quos consequatur quasi. Vitae et et quo rerum deleniti temporibus recusandae. Cupiditate vel earum est explicabo.

Voluptatibus et qui est quae rerum corporis corrupti. Illum voluptatem illum iste quia illum. Iure necessitatibus aut ea iusto necessitatibus quae quaerat. Quibusdam quia doloribus hic aut beatae impedit.

Ea doloremque exercitationem accusamus ab officia. Et aut reprehenderit quod accusantium numquam. Aut culpa similique soluta corrupti illo. Debitis aut voluptas deleniti sit.

Ducimus aperiam omnis rem autem. Incidunt dignissimos quae quo consequatur ea molestiae perspiciatis. Culpa dolor culpa quod nostrum dicta. Explicabo cum omnis et in porro veniam minus.

2024—2025

Eius voluptatibus voluptatem et et. Expedita animi iste eveniet voluptatibus quas explicabo dolorem.

Odit placeat aspernatur iste. Maxime fugit voluptatem tempora et voluptas nesciunt nesciunt. Sed recusandae quis illum molestiae et deleniti perferendis aliquid.

Nemo dolorem minus et quaerat consequatur. Illo sed alias enim cum repudiandae. Necessitatibus perferendis tenetur vitae possimus ab. Ut et in repudiandae adipisci et.

Quaerat reiciendis odit vel aut. Eos velit sunt et. Aliquam nostrum minima qui et fugit. Eos magnam beatae modi cupiditate dolores molestiae et vel.

Quasi perferendis dolor rerum nam molestias recusandae. Ut enim qui ab exercitationem facere. Aut ex impedit aut accusamus distinctio.

Molécules

Formulaires

.form-row

Une ligne de formulaire, qui comprend à la fois le champ du formulaire ainsi que les éléments d'aide (<label> etc.), et qui occupe toute la largeur du conteneur.

Exemple :
.btn

Un élément qui prend la forme d'un bouton (qu'il s'agisse d'un objet de type <button> ou d'un lien <a>, tant qu'il s'agit d'un élément interactif).

Exemple : impedit voluptas voluptatum dolorem
.btn.form-row
Exemple : non beatae qui amet

Atomes