🇫🇷 React intégration pour le System de design du gouvernement français (alias DSFR) 🇫🇷
Documentation des composants - guides - essai immédiat
AVERTISSEMENT : Ce système de conception est uniquement destiné à être utilisé pour les sites web officiels des services publics français.
Son objectif principal est de faciliter l'identification des sites gouvernementaux par les citoyens. Voir les conditions.
Ce module est une boîte à outils avancée qui tire parti de @gouvfr/dsfr, l'implémentation en JS/CSS vanilla du DSFR.
Bien que ce module soit écrit en TypeScript, l'utilisation de TypeScript dans votre application est optionnelle (mais recommandée car elle apporte des avantages exceptionnels à la fois pour vous et votre base de code).
- API entièrement TypeSafe, bien documentée.
- Toujours à jour avec les dernières évolutions du DSFR.
Code et Types générés à partir de
@gouvfr/dsfr
/dist/dsfr.css
. - Exactement le même aspect et ressenti qu'avec @gouvfr/dsfr.
- Pas de flash blanc lors du rechargement dans la configuration SSR.
- La plupart des composants sont prêts pour les composants serveur. Les autres sont étiquetés avec
"use client";
- Intégration parfaite avec tous les principaux frameworks React : Next.js (PagesDir et AppDir), Create React App, Vue.
- (Presque) Tous les composants sont implémentés
- Trois distributions modulables, choisissez les composants que vous importez. (Ce n'est pas tout dans un gros bundle .js)
- Intégration optionnelle avec MUI. Si vous utilisez des composants MUI, ils seront automatiquement adaptés pour ressembler aux composants DSFR. Voir documentation.
- Activez CSS in JS en fournissant un hook
useColors()
qui expose les bonnes options de couleurs et décisions pour le schéma de couleurs actuellement activé. - i18n en option, les textes intégrés peuvent être affichés en plusieurs langues et l'utilisateur peut fournir des traductions supplémentaires.
- Support des bibliothèques de routage comme react-router.
💡 Besoin de pages de connexion et d'inscription prêtes à l'emploi et conformes au DSFR ? Consultez keycloak-theme-dsfr.
Ce module est un produit du pôle Logiciel libre et open source d'Etalab.
Ce projet est co-maintenu par des fonctionnaires de diverses administrations françaises :
- Julien Bouquillon - DNUM des ministères sociaux
- Dylan DECRULLE - Insee
- Enguerran Weiss - Plateforme de l'Inclusion
Il est également co-maintenu par Joseph Garrone, l'auteur original.
git clone https://github.com/codegouvfr/react-dsfr
cd react-dsfr
yarn
# Démarrer storybook
yarn storybook
# Démarrer les applications de test
yarn start-cra # Pour tester dans une configuration Create React App
yarn start-vite # Pour tester dans une configuration Vite
yarn start-next-pagesdir # Pour tester dans une configuration Next.js 13 PagesDir (la configuration par défaut)
yarn start-next-appdir # Pour tester dans une configuration Next.js 13 AppDir
# Exécuter tous les tests unitaires (test/runtime):
yarn test
# Exécuter uniquement test/runtime/cssVariable.test.ts (par exemple)
npx vitest -t "Resolution of CSS variables"
Merci ! Voir le guide de contribution.
Ce dépôt a été initialisé à partir de garronej/ts-ci, consultez la documentation de ce starter pour comprendre le cycle de vie de ce dépôt.
Quelques projets qui utilisent @codegouvfr/react-dsfr
.
- https://code.gouv.fr/sill
- https://cartes.gouv.fr
- https://immersion-facile.beta.gouv.fr/
- https://egapro.travail.gouv.fr/
- https://maisondelautisme.gouv.fr/
- https://refugies.info/fr
- https://www.mediateur-public.fr/
- https://signal.conso.gouv.fr/
- https://observatoire.numerique.gouv.fr/
- https://github.com/BaseAdresseNationale/adresse.data.gouv.fr
- https://github.com/DISIC/observatoire.numerique.gouv.fr
- https://github.com/DISIC/monfranceconnect
- https://github.com/InseeFr/Lunatic-DSFR
- https://github.com/EIG6-Geocommuns/lidarviz-front
- https://github.com/EIG6-Geocommuns/geocommuns-core
- https://github.com/SocialGouv/bpco-site
- https://github.com/EIG6-ArtificIA/predictia_front
- https://github.com/BaseAdresseNationale/bal-admin
- https://github.com/etalab/sill-web
- https://github.com/inclusion-numerique/mediature
- https://territoiresentransitions.fr (peut-être)
- https://potentiel.beta.gouv.fr
- https://diagoriente.beta.gouv.fr