From ef47b4c72a135eb7babbb699cdac53ec300b0489 Mon Sep 17 00:00:00 2001 From: Sylvain Lafay Date: Fri, 26 Jan 2024 15:20:01 +0100 Subject: [PATCH 1/8] composant alerte --- _includes/components/alert.njk | 7 ++++ content/fr/blog/posts/alert.md | 59 ++++++++++++++++++++++++++++++++++ 2 files changed, 66 insertions(+) create mode 100644 _includes/components/alert.njk create mode 100644 content/fr/blog/posts/alert.md diff --git a/_includes/components/alert.njk b/_includes/components/alert.njk new file mode 100644 index 00000000..fd1b3dab --- /dev/null +++ b/_includes/components/alert.njk @@ -0,0 +1,7 @@ +{% if not alert %}{% set alert = params %}{% endif %} +
+ {% if alert.title %} +

{{ alert.title | safe }}

+ {% endif %} + {% if alert.description %}{{ alert.description | safe }}{% endif %} +
\ No newline at end of file diff --git a/content/fr/blog/posts/alert.md b/content/fr/blog/posts/alert.md new file mode 100644 index 00000000..23ef96e9 --- /dev/null +++ b/content/fr/blog/posts/alert.md @@ -0,0 +1,59 @@ +--- +title: Alerte +description: Comment intégrer une alerte dans une page du site ? +date: git Last Modified +tags: + - DSFR + - composant +--- + +Ce composant peut être inclus dans un fichier Nunjucks `.njk` ou Markdown `.md`. + +## Exemple d'utilisation + +```njk +{% raw %} +{% from "components/component.njk" import component with context %} +{{ component("alert", { + type: "info", + title: "Test d'alerte", + description: "

Le contenu de l'alerte

" +}) }} +{% endraw %} +``` + +**Notes :** + +Le composant alerte n'inclut pas de bouton de fermeture. + +Le bloc ne porte pas l'attribut `role="alert"` car il n’apparait pas dynamiquement en cours de navigation. + +Les types possibles sont `info`, `warning`, `error`, `success`. Si le type est omis, le type `info` sera appliqué. + +## Rendu + +{% from "components/component.njk" import component with context %} +{{ component("alert", { + type: "info", + title: "Titre de l'information", + description: "

Le contenu de l'alerte

" +}) }} + +{% from "components/component.njk" import component with context %} +{{ component("alert", { + type: "warning", + title: "Titre de l'avertissement", + description: "

Le contenu de l'alerte

" +}) }} + +{% from "components/component.njk" import component with context %} +{{ component("alert", { + type: "success", + description: "

Contenu de l'alerte seul

" +}) }} + +{% from "components/component.njk" import component with context %} +{{ component("alert", { + type: "error", + title: "Titre d'une erreur simple" +}) }} From 9574b5f5e166f0a3317392f7afd236e7dccf72ba Mon Sep 17 00:00:00 2001 From: Helene MJ <20780121+hjonin@users.noreply.github.com> Date: Mon, 5 Feb 2024 13:07:35 +0100 Subject: [PATCH 2/8] Update README.md Signed-off-by: Helene MJ <20780121+hjonin@users.noreply.github.com> --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 0a1d7fce..15c1fffb 100644 --- a/README.md +++ b/README.md @@ -113,7 +113,7 @@ La suite de la documentation (composants, fonctionnalités) est disponible dans ## Démonstration et réutilisations - Pour une démonstration, voir la [GitHub Pages](https://codegouvfr.github.io/eleventy-dsfr/fr/) correspondante. -- `eleventy-dsfr` est utilisé pour le site [code.gouv.fr](https://code.gouv.fr). +- `eleventy-dsfr` est utilisé pour le site [code.gouv.fr](https://code.gouv.fr) (code source : https://github.com/codegouvfr/codegouvfr-website). ## Licence From 8c1f51b086b95d75382db8f154525c98752aa549 Mon Sep 17 00:00:00 2001 From: Helene MJ <20780121+hjonin@users.noreply.github.com> Date: Tue, 6 Feb 2024 10:11:46 +0100 Subject: [PATCH 3/8] Update README to add reuse Signed-off-by: Helene MJ <20780121+hjonin@users.noreply.github.com> --- README.md | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 15c1fffb..b842be18 100644 --- a/README.md +++ b/README.md @@ -3,7 +3,8 @@ # eleventy-dsfr Un dépôt pour démarrer un site statique au [DSFR](https://www.systeme-de-design.gouv.fr/) avec le -générateur [Eleventy](https://www.11ty.dev/). +générateur [Eleventy](https://www.11ty.dev/), déployé pour démonstration sur [GitHub Pages](https://codegouvfr.github.io/eleventy-dsfr/fr/). +Pour d'autres exemples de réutilisation, cf. [Démonstration et réutilisations](#démonstration-et-réutilisations). ![Screenshot of the website front page.](eleventy-dsfr.png) @@ -112,8 +113,11 @@ La suite de la documentation (composants, fonctionnalités) est disponible dans ## Démonstration et réutilisations -- Pour une démonstration, voir la [GitHub Pages](https://codegouvfr.github.io/eleventy-dsfr/fr/) correspondante. -- `eleventy-dsfr` est utilisé pour le site [code.gouv.fr](https://code.gouv.fr) (code source : https://github.com/codegouvfr/codegouvfr-website). +Pour une démonstration, voir la [GitHub Pages](https://codegouvfr.github.io/eleventy-dsfr/fr/) correspondante. + +- [Site de la mission logiciels libres de la DINUM](https://code.gouv.fr) (code source : https://github.com/codegouvfr/codegouvfr-website). +- [Site du cadre de cohérence technique du MI](https://dnum-mi.github.io/cct-mi/) (code source : https://github.com/dnum-mi/cct-mi) +- [Site de documentation pour cartes.gouv.fr](https://ignf.github.io/cartes.gouv.fr-documentation/) (code source : https://github.com/IGNF/cartes.gouv.fr-documentation) ## Licence From c144746bfa35dc7f463e1436185325499f46d4a0 Mon Sep 17 00:00:00 2001 From: Sylvain Lafay Date: Tue, 6 Feb 2024 17:15:26 +0100 Subject: [PATCH 4/8] container markdown pour composant alerte --- content/fr/blog/posts/alert.md | 25 +++++++++++++------------ eleventy.config.js | 4 ++++ markdown-custom-containers.js | 31 +++++++++++++++++++++++++++++++ 3 files changed, 48 insertions(+), 12 deletions(-) diff --git a/content/fr/blog/posts/alert.md b/content/fr/blog/posts/alert.md index 23ef96e9..d6215930 100644 --- a/content/fr/blog/posts/alert.md +++ b/content/fr/blog/posts/alert.md @@ -22,22 +22,25 @@ Ce composant peut être inclus dans un fichier Nunjucks `.njk` ou Markdown `.md` {% endraw %} ``` +```md +:::info Test d'alerte +Contenu **Mardown** +::: +``` + **Notes :** Le composant alerte n'inclut pas de bouton de fermeture. Le bloc ne porte pas l'attribut `role="alert"` car il n’apparait pas dynamiquement en cours de navigation. -Les types possibles sont `info`, `warning`, `error`, `success`. Si le type est omis, le type `info` sera appliqué. +Les types possibles sont `info`, `warning`, `error`, `success`. En `njk` si le type est omis, le type `info` sera appliqué. ## Rendu -{% from "components/component.njk" import component with context %} -{{ component("alert", { - type: "info", - title: "Titre de l'information", - description: "

Le contenu de l'alerte

" -}) }} +:::info Titre de l'information +Contenu de l'alerte +::: {% from "components/component.njk" import component with context %} {{ component("alert", { @@ -46,11 +49,9 @@ Les types possibles sont `info`, `warning`, `error`, `success`. Si le type est o description: "

Le contenu de l'alerte

" }) }} -{% from "components/component.njk" import component with context %} -{{ component("alert", { - type: "success", - description: "

Contenu de l'alerte seul

" -}) }} +:::success +Contenu de l'alerte seule +::: {% from "components/component.njk" import component with context %} {{ component("alert", { diff --git a/eleventy.config.js b/eleventy.config.js index ea48342b..31b2b1c9 100644 --- a/eleventy.config.js +++ b/eleventy.config.js @@ -165,6 +165,10 @@ module.exports = function (eleventyConfig) { mdLib.use(markdownItContainer, 'quote', customMarkdownContainers.quote(mdLib)); }); + eleventyConfig.amendLibrary("md", mdLib => { + mdLib.use(markdownItContainer, 'alert', customMarkdownContainers.alert(mdLib)); + }); + // Automatically strip all leading or trailing whitespace // to prevent Markdown lib from rendering with wrapping into paragraphs // instead of using Nunjucks special syntax. Learn more: diff --git a/markdown-custom-containers.js b/markdown-custom-containers.js index 87cf7642..7d3fcc18 100644 --- a/markdown-custom-containers.js +++ b/markdown-custom-containers.js @@ -57,5 +57,36 @@ module.exports = { } } } + }, + alert: md => { + const re = /^(info|warning|error|success)(\s+.*)?$/; + return { + validate: (params) => { + return params.trim().match(re); + }, + + render: (tokens, idx) => { + const params = tokens[idx].info.trim().match(re); + const type = params?.[1]; + const title = md.utils.escapeHtml(params?.[2]) || ''; + + if (tokens[idx].nesting === 1) { + title_elem = ''; + small_class = 'fr-alert--sm'; + if (title !== '') { + title_elem = `

${title}

`; + small_class = ""; + } + // opening tag + return ` +
+ ${title_elem} +`; + } else { + // closing tag + return '
\n'; + } + } + } } } \ No newline at end of file From 153f845fa899b071f8fd806bff8e162c584730a2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A9l=C3=A8ne=20Jonin?= Date: Wed, 7 Feb 2024 15:11:27 +0100 Subject: [PATCH 5/8] gh-18 Mention sponsoring agencies on awesome page --- _includes/components/card.njk | 5 +++++ content/fr/awesome/index.njk | 8 ++++++-- eleventy.config.js | 4 ++++ 3 files changed, 15 insertions(+), 2 deletions(-) diff --git a/_includes/components/card.njk b/_includes/components/card.njk index 1bbf5265..32142326 100644 --- a/_includes/components/card.njk +++ b/_includes/components/card.njk @@ -27,6 +27,11 @@

{{ card.detail }}

{% endif %} + {% if card.detailEnd %} +
+

{{ card.detailEnd }}

+
+ {% endif %}