@cnamts/synapse 0.0.4-alpha → 0.0.6-alpha
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/design-system-v3.d.ts +1277 -499
- package/dist/design-system-v3.js +4193 -1573
- package/dist/design-system-v3.umd.cjs +8 -8
- package/dist/style.css +1 -1
- package/package.json +18 -17
- package/src/assets/settings.scss +3 -0
- package/src/assets/tokens.scss +16 -17
- package/src/components/BackBtn/Accessibilite.mdx +14 -0
- package/src/components/BackBtn/Accessibilite.stories.ts +166 -0
- package/src/components/BackBtn/AccessibiliteItems.ts +102 -0
- package/src/components/BackBtn/BackBtn.mdx +1 -1
- package/src/components/BackBtn/BackBtn.stories.ts +8 -8
- package/src/components/BackBtn/BackBtn.vue +0 -1
- package/src/components/BackBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/BackToTopBtn/Accessibilite.mdx +14 -0
- package/src/components/BackToTopBtn/Accessibilite.stories.ts +166 -0
- package/src/components/BackToTopBtn/AccessibiliteItems.ts +52 -0
- package/src/components/BackToTopBtn/BackToTopBtn.mdx +1 -1
- package/src/components/BackToTopBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/CollapsibleList/Accessibilite.mdx +14 -0
- package/src/components/CollapsibleList/Accessibilite.stories.ts +170 -0
- package/src/components/CollapsibleList/AccessibiliteItems.ts +122 -0
- package/src/components/CollapsibleList/CollapsibleList.stories.ts +1 -1
- package/src/components/CollapsibleList/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/CookieBanner/Accessibilite.mdx +14 -0
- package/src/components/CookieBanner/Accessibilite.stories.ts +219 -0
- package/src/components/CookieBanner/AccessibiliteItems.ts +356 -0
- package/src/components/CookieBanner/CookieBanner.mdx +219 -0
- package/src/components/CookieBanner/CookieBanner.stories.ts +678 -0
- package/src/components/CookieBanner/CookieBanner.vue +225 -0
- package/src/components/CookieBanner/config.ts +38 -0
- package/src/components/CookieBanner/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/CookieBanner/locales.ts +12 -0
- package/src/components/CookieBanner/tests/CookieBanner.spec.ts +129 -0
- package/src/components/CookieBanner/tests/__snapshots__/CookieBanner.spec.ts.snap +197 -0
- package/src/components/CookiesSelection/CookiesInformation/CookiesInformation.vue +123 -0
- package/src/components/CookiesSelection/CookiesInformation/locales.ts +21 -0
- package/src/components/CookiesSelection/CookiesInformation/tests/CookiesInformation.spec.ts +121 -0
- package/src/components/CookiesSelection/CookiesSelection.vue +127 -0
- package/src/components/CookiesSelection/CookiesTable/CookiesTable.vue +47 -0
- package/src/components/CookiesSelection/CookiesTable/headers.ts +14 -0
- package/src/components/CookiesSelection/CookiesTable/tests/CookiesTable.spec.ts +30 -0
- package/src/components/CookiesSelection/CookiesTable/tests/__snapshots__/CookiesTable.spec.ts.snap +3 -0
- package/src/components/CookiesSelection/locales.ts +10 -0
- package/src/components/CookiesSelection/tests/CookiesSelection.spec.ts +184 -0
- package/src/components/CookiesSelection/tests/__snapshots__/CookiesSelection.spec.ts.snap +192 -0
- package/src/components/CookiesSelection/types.ts +15 -0
- package/src/components/CopyBtn/Accessibilite.mdx +14 -0
- package/src/components/CopyBtn/Accessibilite.stories.ts +166 -0
- package/src/components/CopyBtn/AccessibiliteItems.ts +105 -0
- package/src/components/CopyBtn/CopyBtn.mdx +1 -1
- package/src/components/CopyBtn/CopyBtn.stories.ts +4 -4
- package/src/components/CopyBtn/CopyBtn.vue +0 -1
- package/src/components/CopyBtn/config.ts +2 -0
- package/src/components/CopyBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/Customs/SyBtnSelect/Accessibilite.mdx +14 -0
- package/src/components/Customs/SyBtnSelect/Accessibilite.stories.ts +193 -0
- package/src/components/Customs/SyBtnSelect/AccessibiliteItems.ts +139 -0
- package/src/components/Customs/SyBtnSelect/SyBtnSelect.mdx +45 -0
- package/src/components/Customs/SyBtnSelect/SyBtnSelect.stories.ts +662 -0
- package/src/components/Customs/SyBtnSelect/SyBtnSelect.vue +254 -0
- package/src/components/Customs/SyBtnSelect/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/Customs/SyBtnSelect/tests/SyBtnSelect.spec.ts +168 -0
- package/src/components/Customs/SyInputSelect/Accessibilite.mdx +14 -0
- package/src/components/Customs/SyInputSelect/Accessibilite.stories.ts +166 -0
- package/src/components/Customs/SyInputSelect/AccessibiliteItems.ts +96 -0
- package/src/components/Customs/SyInputSelect/SyInputSelect.mdx +41 -0
- package/src/components/Customs/{CustomInputSelect/CustomInputSelect.stories.ts → SyInputSelect/SyInputSelect.stories.ts} +30 -83
- package/src/components/Customs/{CustomInputSelect/CustomInputSelect.vue → SyInputSelect/SyInputSelect.vue} +46 -6
- package/src/components/Customs/SyInputSelect/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/Customs/SyInputSelect/tests/SyInputSelect.spec.ts +140 -0
- package/src/components/Customs/SySelect/Accessibilite.mdx +14 -0
- package/src/components/Customs/SySelect/Accessibilite.stories.ts +217 -0
- package/src/components/Customs/SySelect/AccessibiliteItems.ts +173 -0
- package/src/components/Customs/{CustomSelect/CustomSelect.mdx → SySelect/SySelect.mdx} +9 -8
- package/src/components/Customs/{CustomSelect/CustomSelect.stories.ts → SySelect/SySelect.stories.ts} +25 -79
- package/src/components/Customs/{CustomSelect/CustomSelect.vue → SySelect/SySelect.vue} +44 -13
- package/src/components/Customs/SySelect/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/Customs/{CustomInputSelect/tests/CustomInputSelect.spec.ts → SySelect/tests/SySelect.spec.ts} +48 -71
- package/src/components/Customs/SyTextField/Accessibilite.mdx +14 -0
- package/src/components/Customs/SyTextField/Accessibilite.stories.ts +224 -0
- package/src/components/Customs/SyTextField/AccessibiliteItems.ts +198 -0
- package/src/components/Customs/SyTextField/SyTextField.mdx +44 -0
- package/src/components/Customs/{CustomTextField/CustomTextField.stories.ts → SyTextField/SyTextField.stories.ts} +145 -34
- package/src/components/Customs/{CustomTextField/CustomTextField.vue → SyTextField/SyTextField.vue} +27 -7
- package/src/components/Customs/SyTextField/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/Customs/{CustomTextField/tests/CustomTextField.spec.ts → SyTextField/tests/SyTextField.spec.ts} +3 -3
- package/src/components/Customs/{CustomTextField/tests/__snapshots__/CustomTextField.spec.ts.snap → SyTextField/tests/__snapshots__/SyTextField.spec.ts.snap} +5 -6
- package/src/components/DataList/Accessibilite.mdx +14 -0
- package/src/components/DataList/Accessibilite.stories.ts +166 -0
- package/src/components/DataList/AccessibiliteItems.ts +47 -0
- package/src/components/DataList/DataList.mdx +1 -1
- package/src/components/DataList/DataList.stories.ts +10 -10
- package/src/components/DataList/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/DataListGroup/Accessibilite.mdx +14 -0
- package/src/components/DataListGroup/Accessibilite.stories.ts +225 -0
- package/src/components/DataListGroup/AccessibiliteItems.ts +79 -0
- package/src/components/DataListGroup/DataListGroup.mdx +1 -1
- package/src/components/DataListGroup/DataListGroup.stories.ts +7 -7
- package/src/components/DataListGroup/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/DialogBox/Accessibilite.mdx +14 -0
- package/src/components/DialogBox/Accessibilite.stories.ts +189 -0
- package/src/components/DialogBox/AccessibiliteItems.ts +167 -0
- package/src/components/DialogBox/DialogBox.mdx +14 -0
- package/src/components/DialogBox/DialogBox.stories.ts +798 -0
- package/src/components/DialogBox/DialogBox.vue +181 -0
- package/src/components/DialogBox/config.ts +25 -0
- package/src/components/DialogBox/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/DialogBox/locales.ts +5 -0
- package/src/components/DialogBox/tests/DialogBox.spec.ts +329 -0
- package/src/components/DialogBox/tests/__snapshots__/DialogBox.spec.ts.snap +46 -0
- package/src/components/DownloadBtn/AccessibiliteItems.ts +1 -31
- package/src/components/DownloadBtn/DownloadBtn.mdx +3 -3
- package/src/components/DownloadBtn/DownloadBtn.stories.ts +6 -6
- package/src/components/ErrorPage/Accessibilite.mdx +14 -0
- package/src/components/ErrorPage/Accessibilite.stories.ts +189 -0
- package/src/components/ErrorPage/AccessibiliteItems.ts +205 -0
- package/src/components/ErrorPage/ErrorPage.mdx +21 -0
- package/src/components/ErrorPage/ErrorPage.stories.ts +133 -0
- package/src/components/ErrorPage/ErrorPage.vue +93 -0
- package/src/components/ErrorPage/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/ErrorPage/locales.ts +5 -0
- package/src/components/ErrorPage/tests/ErrorPage.spec.ts +40 -0
- package/src/components/ErrorPage/tests/__snapshots__/ErrorPage.spec.ts.snap +78 -0
- package/src/components/FooterBar/Accessibilite.mdx +14 -0
- package/src/components/FooterBar/Accessibilite.stories.ts +223 -0
- package/src/components/FooterBar/AccessibiliteItems.ts +257 -0
- package/src/components/FooterBar/FooterBar.mdx +2 -2
- package/src/components/FooterBar/FooterBar.stories.ts +556 -8
- package/src/components/FooterBar/FooterBar.vue +80 -73
- package/src/components/FooterBar/config.ts +2 -3
- package/src/components/FooterBar/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/FooterBar/tests/FooterBar.spec.ts +1 -1
- package/src/components/FooterBar/tests/FooterBarConfig.spec.ts +1 -1
- package/src/components/FooterBar/tests/__snapshots__/FooterBar.spec.ts.snap +24 -22
- package/src/components/FranceConnectBtn/Accessibilite.mdx +14 -0
- package/src/components/FranceConnectBtn/Accessibilite.stories.ts +194 -0
- package/src/components/FranceConnectBtn/AccessibiliteItems.ts +169 -0
- package/src/components/FranceConnectBtn/FranceConnectBtn.mdx +1 -1
- package/src/components/FranceConnectBtn/FranceConnectBtn.stories.ts +3 -3
- package/src/components/FranceConnectBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/HeaderBar/Accessibilite.mdx +14 -0
- package/src/components/HeaderBar/Accessibilite.stories.ts +223 -0
- package/src/components/HeaderBar/AccessibiliteItems.ts +194 -0
- package/src/components/HeaderBar/HeaderBar.stories.ts +60 -2
- package/src/components/HeaderBar/HeaderBar.vue +1 -9
- package/src/components/HeaderBar/HeaderBurgerMenu/Accessibilite.mdx +14 -0
- package/src/components/HeaderBar/HeaderBurgerMenu/Accessibilite.stories.ts +223 -0
- package/src/components/HeaderBar/HeaderBurgerMenu/AccessibiliteItems.ts +174 -0
- package/src/components/HeaderBar/HeaderBurgerMenu/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/HeaderBar/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/HeaderBar/tests/__snapshots__/HeaderBar.spec.ts.snap +1 -1
- package/src/components/HeaderLoading/Accessibilite.mdx +14 -0
- package/src/components/HeaderLoading/Accessibilite.stories.ts +167 -0
- package/src/components/HeaderLoading/AccessibiliteItems.ts +29 -0
- package/src/components/HeaderLoading/HeaderLoading.mdx +1 -1
- package/src/components/HeaderLoading/HeaderLoading.stories.ts +1 -1
- package/src/components/HeaderLoading/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/HeaderNavigationBar/HeaderNavigationBar.mdx +6 -6
- package/src/components/HeaderNavigationBar/HorizontalNavbar/HorizontalNavbar.vue +35 -33
- package/src/components/HeaderNavigationBar/tests/HeaderNavigationBar.spec.ts +1 -1
- package/src/components/HeaderToolbar/Accessibilite.mdx +14 -0
- package/src/components/HeaderToolbar/Accessibilite.stories.ts +203 -0
- package/src/components/HeaderToolbar/AccessibiliteItems.ts +200 -0
- package/src/components/HeaderToolbar/HeaderToolbar.mdx +1 -1
- package/src/components/HeaderToolbar/HeaderToolbar.stories.ts +2 -2
- package/src/components/HeaderToolbar/HeaderToolbar.vue +3 -2
- package/src/components/HeaderToolbar/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/HeaderToolbar/tests/HeaderToolbar.spec.ts +36 -2
- package/src/components/LangBtn/Accessibilite.mdx +14 -0
- package/src/components/LangBtn/Accessibilite.stories.ts +168 -0
- package/src/components/LangBtn/AccessibiliteItems.ts +101 -0
- package/src/components/LangBtn/LangBtn.mdx +1 -1
- package/src/components/LangBtn/LangBtn.stories.ts +4 -4
- package/src/components/LangBtn/LangBtn.vue +3 -2
- package/src/components/LangBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/LangBtn/tests/LangBtn.spec.ts +1 -1
- package/src/components/LangBtn/tests/__snapshots__/LangBtn.spec.ts.snap +1 -1
- package/src/components/Logo/Accessibilite.mdx +14 -0
- package/src/components/Logo/Accessibilite.stories.ts +223 -0
- package/src/components/Logo/AccessibiliteItems.ts +155 -0
- package/src/components/Logo/Logo.mdx +1 -1
- package/src/components/Logo/Logo.stories.ts +8 -8
- package/src/components/Logo/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/LogoBrandSection/Accessibilite.mdx +14 -0
- package/src/components/LogoBrandSection/Accessibilite.stories.ts +223 -0
- package/src/components/LogoBrandSection/AccessibiliteItems.ts +194 -0
- package/src/components/LogoBrandSection/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/MaintenancePage/Accessibilite.mdx +14 -0
- package/src/components/MaintenancePage/Accessibilite.stories.ts +189 -0
- package/src/components/MaintenancePage/AccessibiliteItems.ts +173 -0
- package/src/components/MaintenancePage/MaintenancePage.mdx +11 -0
- package/src/components/MaintenancePage/MaintenancePage.stories.ts +41 -0
- package/src/components/MaintenancePage/MaintenancePage.vue +25 -0
- package/src/components/MaintenancePage/assets/maintenance.svg +1 -0
- package/src/components/MaintenancePage/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/MaintenancePage/index.ts +3 -0
- package/src/components/MaintenancePage/locales.ts +5 -0
- package/src/components/MaintenancePage/tests/MaintenancePage.spec.ts +12 -0
- package/src/components/MaintenancePage/tests/__snapshots__/MaintenancePage.spec.ts.snap +3 -0
- package/src/components/NirField/Accessibilite.mdx +14 -0
- package/src/components/NirField/Accessibilite.stories.ts +214 -0
- package/src/components/NirField/AccessibiliteItems.ts +243 -0
- package/src/components/NirField/NirField.mdx +216 -0
- package/src/components/NirField/NirField.stories.ts +359 -0
- package/src/components/NirField/NirField.vue +450 -0
- package/src/components/NirField/config.ts +16 -0
- package/src/components/NirField/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/NirField/locales.ts +12 -0
- package/src/components/NirField/nirValidation.ts +42 -0
- package/src/components/NirField/tests/NirField.spec.ts +119 -0
- package/src/components/NotFoundPage/Accessibilite.mdx +14 -0
- package/src/components/NotFoundPage/Accessibilite.stories.ts +190 -0
- package/src/components/NotFoundPage/AccessibiliteItems.ts +205 -0
- package/src/components/NotFoundPage/NotFoundPage.mdx +19 -0
- package/src/components/NotFoundPage/NotFoundPage.stories.ts +76 -0
- package/src/components/NotFoundPage/NotFoundPage.vue +52 -0
- package/src/components/NotFoundPage/assets/not-found.svg +1 -0
- package/src/components/NotFoundPage/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/NotFoundPage/locales.ts +6 -0
- package/src/components/NotFoundPage/tests/NotFoundPage.spec.ts +38 -0
- package/src/components/NotFoundPage/tests/__snapshots__/NotFoundPage.spec.ts.snap +76 -0
- package/src/components/NotificationBar/Accessibilite.mdx +14 -0
- package/src/components/NotificationBar/Accessibilite.stories.ts +166 -0
- package/src/components/NotificationBar/AccessibiliteItems.ts +144 -0
- package/src/components/NotificationBar/NotificationBar.mdx +1 -1
- package/src/components/NotificationBar/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/NotificationBar/options.ts +1 -0
- package/src/components/PageContainer/Accessibilite.mdx +14 -0
- package/src/components/PageContainer/Accessibilite.stories.ts +166 -0
- package/src/components/PageContainer/AccessibiliteItems.ts +52 -0
- package/src/components/PageContainer/PageContainer.mdx +1 -1
- package/src/components/PageContainer/PageContainer.stories.ts +4 -4
- package/src/components/PageContainer/PageContainer.vue +16 -15
- package/src/components/PageContainer/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/PageContainer/tests/PageContainer.spec.ts +1 -1
- package/src/components/PageContainer/tests/__snapshots__/PageContainer.spec.ts.snap +2 -2
- package/src/components/PhoneField/Accessibilite.mdx +14 -0
- package/src/components/PhoneField/Accessibilite.stories.ts +216 -0
- package/src/components/PhoneField/AccessibiliteItems.ts +238 -0
- package/src/components/PhoneField/PhoneField.mdx +1 -1
- package/src/components/PhoneField/PhoneField.stories.ts +2 -2
- package/src/components/PhoneField/PhoneField.vue +5 -6
- package/src/components/PhoneField/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/PhoneField/tests/PhoneField.spec.ts +3 -3
- package/src/components/SkipLink/Accessibilite.mdx +14 -0
- package/src/components/SkipLink/Accessibilite.stories.ts +167 -0
- package/src/components/SkipLink/AccessibiliteItems.ts +77 -0
- package/src/components/SkipLink/SkipLink.stories.ts +2 -2
- package/src/components/SkipLink/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/SocialMediaLinks/Accessibilite.mdx +14 -0
- package/src/components/SocialMediaLinks/Accessibilite.stories.ts +170 -0
- package/src/components/SocialMediaLinks/AccessibiliteItems.ts +160 -0
- package/src/components/SocialMediaLinks/SocialMediaLinks.mdx +18 -14
- package/src/components/SocialMediaLinks/SocialMediaLinks.stories.ts +3 -2
- package/src/components/SocialMediaLinks/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/SocialMediaLinks/tests/SocialMediaLinks.spec.ts +1 -1
- package/src/components/SocialMediaLinks/tests/__snapshots__/SocialMediaLinks.spec.ts.snap +2 -2
- package/src/components/SubHeader/Accessibilite.mdx +14 -0
- package/src/components/SubHeader/Accessibilite.stories.ts +166 -0
- package/src/components/SubHeader/AccessibiliteItems.ts +146 -0
- package/src/components/SubHeader/SubHeader.mdx +1 -1
- package/src/components/SubHeader/SubHeader.stories.ts +11 -11
- package/src/components/SubHeader/SubHeader.vue +1 -1
- package/src/components/SubHeader/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/SyAlert/Accessibilite.mdx +14 -0
- package/src/components/SyAlert/Accessibilite.stories.ts +166 -0
- package/src/components/SyAlert/AccessibiliteItems.ts +122 -0
- package/src/components/{Alert/Alert.mdx → SyAlert/SyAlert.mdx} +9 -9
- package/src/components/{Alert/Alert.stories.ts → SyAlert/SyAlert.stories.ts} +22 -22
- package/src/components/SyAlert/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/{Alert/tests/Alert.spec.ts → SyAlert/tests/SyAlert.spec.ts} +5 -5
- package/src/components/{Alert/tests/__snapshots__/Alert.spec.ts.snap → SyAlert/tests/__snapshots__/SyAlert.spec.ts.snap} +2 -2
- package/src/components/UserMenuBtn/Accessibilite.mdx +14 -0
- package/src/components/UserMenuBtn/Accessibilite.stories.ts +189 -0
- package/src/components/UserMenuBtn/AccessibiliteItems.ts +155 -0
- package/src/components/UserMenuBtn/UserMenuBtn.mdx +35 -0
- package/src/components/UserMenuBtn/UserMenuBtn.stories.ts +540 -0
- package/src/components/UserMenuBtn/UserMenuBtn.vue +101 -0
- package/src/components/UserMenuBtn/config.ts +24 -0
- package/src/components/UserMenuBtn/constants/ExpertiseLevelEnum.ts +4 -0
- package/src/components/UserMenuBtn/tests/UserMenuBtn.spec.ts +125 -0
- package/src/components/index.ts +19 -4
- package/src/composables/index.ts +8 -0
- package/src/composables/rules/tests/useFieldValidation.spec.ts +84 -0
- package/src/composables/rules/useFieldValidation.ts +90 -0
- package/src/designTokens/index.ts +2 -0
- package/src/designTokens/tokens/cnam/cnamDarkTheme.ts +5 -0
- package/src/designTokens/tokens/cnam/cnamLightTheme.ts +1 -0
- package/src/main.ts +3 -0
- package/src/stories/Fondamentaux/Arrondis.mdx +24 -0
- package/src/stories/{Guidelines → Fondamentaux}/Colors.mdx +1 -1
- package/src/stories/Fondamentaux/Conteneurs.mdx +7 -0
- package/src/stories/Fondamentaux/CustomisationEtThemes.mdx +7 -0
- package/src/stories/Fondamentaux/Elevations.mdx +14 -0
- package/src/stories/Fondamentaux/Espacements.mdx +29 -0
- package/src/stories/{Guidelines → Fondamentaux}/Introduction.mdx +1 -1
- package/src/stories/Fondamentaux/StylesTypographiques.mdx +33 -0
- package/src/stories/Fondamentaux/Typographie.mdx +58 -0
- package/src/stories/GuideDuDev/CommentUtiliserLesRules.mdx +120 -0
- package/src/stories/GuideDuDev/components.stories.ts +5 -5
- package/src/stories/GuideDuDev/moduleDeNotification.mdx +1 -1
- package/src/stories/{Fondamentaux → Guidelines}/Accessibilite/Accessibilite.stories.ts +1 -1
- package/src/stories/{Fondamentaux → Guidelines}/EcoConception/Econception.stories.ts +2 -2
- package/src/stories/Guidelines/Vuetify/Vuetify.mdx +11 -0
- package/src/stories/Guidelines/Vuetify/Vuetify.stories.ts +138 -0
- package/src/stories/Guidelines/Vuetify/VuetifyItems.ts +350 -0
- package/src/components/Customs/CustomInputSelect/CustomInputSelect.mdx +0 -40
- package/src/components/Customs/CustomSelect/tests/CustomSelect.spec.ts +0 -236
- package/src/components/Customs/CustomTextField/CustomTextField.mdx +0 -44
- package/src/stories/Guidelines/CustomisationEtThemes.mdx +0 -3
- package/src/stories/Guidelines/Typo.mdx +0 -53
- /package/src/components/Customs/{CustomInputSelect → SyInputSelect}/config.ts +0 -0
- /package/src/components/Customs/{CustomTextField → SyTextField}/types.d.ts +0 -0
- /package/src/components/{Alert/Alert.vue → SyAlert/SyAlert.vue} +0 -0
- /package/src/components/{Alert → SyAlert}/locales.ts +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/Accessibilite/Accessibilite.mdx +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/Accessibilite/AccessibiliteItems.ts +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/Accessibilite/constants/ExpertiseLevelEnum.ts +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/Accessibilite/constants/RGAALevelEnum.ts +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/EcoConception/EcoConception.mdx +0 -0
- /package/src/stories/{Fondamentaux → Guidelines}/EcoConception/ecoDesignItems.ts +0 -0
|
@@ -110,7 +110,7 @@ export const Default: Story = {
|
|
|
110
110
|
{
|
|
111
111
|
name: 'Script',
|
|
112
112
|
code: `<script setup lang="ts">
|
|
113
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
113
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
114
114
|
import axios from 'axios'
|
|
115
115
|
|
|
116
116
|
const download = () => {
|
|
@@ -149,7 +149,7 @@ export const Error: Story = {
|
|
|
149
149
|
{
|
|
150
150
|
name: 'Script',
|
|
151
151
|
code: `<script setup lang="ts">
|
|
152
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
152
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
153
153
|
import axios from 'axios'
|
|
154
154
|
|
|
155
155
|
const download = () => {
|
|
@@ -188,7 +188,7 @@ export const Loading: Story = {
|
|
|
188
188
|
{
|
|
189
189
|
name: 'Script',
|
|
190
190
|
code: `<script setup lang="ts">
|
|
191
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
191
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
192
192
|
import axios from 'axios'
|
|
193
193
|
|
|
194
194
|
const download = () => {
|
|
@@ -234,7 +234,7 @@ export const Dark: Story = {
|
|
|
234
234
|
{
|
|
235
235
|
name: 'Script',
|
|
236
236
|
code: `<script setup lang="ts">
|
|
237
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
237
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
238
238
|
import axios from 'axios'
|
|
239
239
|
|
|
240
240
|
const download = () => {
|
|
@@ -286,7 +286,7 @@ export const Notify: Story = {
|
|
|
286
286
|
{
|
|
287
287
|
name: 'Script',
|
|
288
288
|
code: `<script setup lang="ts">
|
|
289
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
289
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
290
290
|
import NotificationBar from '@cnamts/synapse'
|
|
291
291
|
|
|
292
292
|
import axios from 'axios'
|
|
@@ -373,7 +373,7 @@ export const Customization: Story = {
|
|
|
373
373
|
{
|
|
374
374
|
name: 'Script',
|
|
375
375
|
code: `<script setup lang="ts">
|
|
376
|
-
import DownloadBtn from '@cnamts/synapse'
|
|
376
|
+
import { DownloadBtn } from '@cnamts/synapse'
|
|
377
377
|
import axios from 'axios'
|
|
378
378
|
|
|
379
379
|
const download = () => {
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Meta, Story } from '@storybook/addon-docs';
|
|
2
|
+
import * as AccessStories from './Accessibilite.stories.ts';
|
|
3
|
+
|
|
4
|
+
<Meta of={AccessStories} />
|
|
5
|
+
|
|
6
|
+
Accessibilité
|
|
7
|
+
=============
|
|
8
|
+
<Story of={AccessStories.Legende} />
|
|
9
|
+
<br />
|
|
10
|
+
|
|
11
|
+
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
|
12
|
+
|
|
13
|
+
<Story of={AccessStories.AccessibilitePanel} />
|
|
14
|
+
<br />
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VDataTable, VIcon } from 'vuetify/components'
|
|
2
|
+
import type { StoryObj } from '@storybook/vue3'
|
|
3
|
+
import { AccessibiliteItemsIndeterminate, AccessibiliteItemsValidated } from './AccessibiliteItems'
|
|
4
|
+
import { mdiCheckboxMarkedCircle, mdiLink, mdiEye } from '@mdi/js'
|
|
5
|
+
|
|
6
|
+
const checkIcon = mdiCheckboxMarkedCircle
|
|
7
|
+
const iconEye = mdiEye
|
|
8
|
+
const linkICon = mdiLink
|
|
9
|
+
|
|
10
|
+
export default {
|
|
11
|
+
title: 'Templates/ErrorPage/Accessibilité',
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const AccessibilitePanel: StoryObj = {
|
|
15
|
+
|
|
16
|
+
render: () => {
|
|
17
|
+
return {
|
|
18
|
+
components: { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VDataTable, VIcon },
|
|
19
|
+
|
|
20
|
+
setup() {
|
|
21
|
+
const icon = checkIcon
|
|
22
|
+
|
|
23
|
+
return { AccessibiliteItemsIndeterminate, AccessibiliteItemsValidated, icon, linkICon, iconEye }
|
|
24
|
+
},
|
|
25
|
+
template: `
|
|
26
|
+
<div class="accessibiliteItems" style="display:flex; max-width: none !important;">
|
|
27
|
+
<v-col cols="6">
|
|
28
|
+
<div style="display:flex; margin-bottom: 10px; justify-content: space-between; align-items: center;">
|
|
29
|
+
<h5>{{ AccessibiliteItemsIndeterminate.length }} critères à prendre en charge par le projet</h5>
|
|
30
|
+
<div style="display: flex; align-items: center;">
|
|
31
|
+
<v-btn variant="tonal" color="red" size="x-small" style="margin: 4px;font-size: 8px;"
|
|
32
|
+
rounded>Tanaguru
|
|
33
|
+
</v-btn>
|
|
34
|
+
</div>
|
|
35
|
+
</div>
|
|
36
|
+
|
|
37
|
+
<v-expansion-panels value="opened" multiple>
|
|
38
|
+
<v-expansion-panel v-for="(item, index) in AccessibiliteItemsIndeterminate" :key="index" style="background-color: rgba(42, 96, 158, 0.1); margin-bottom: 10px;">
|
|
39
|
+
<v-expansion-panel-title>
|
|
40
|
+
<VIcon :icon="iconEye" style="margin-right: 5px; color:#5778b7;"/>
|
|
41
|
+
{{ item.title }}
|
|
42
|
+
</v-expansion-panel-title>
|
|
43
|
+
<v-expansion-panel-text>
|
|
44
|
+
<v-expansion-panels>
|
|
45
|
+
<v-expansion-panel v-for="(i, index) in item.items2" :key="i" style="margin-bottom: 10px;">
|
|
46
|
+
<v-expansion-panel-title
|
|
47
|
+
style="font-weight: bold; font-size: 13px; line-height: 16px;">
|
|
48
|
+
{{ i.subtitle}}
|
|
49
|
+
</v-expansion-panel-title>
|
|
50
|
+
<v-expansion-panel-text>
|
|
51
|
+
<div>
|
|
52
|
+
<p style="font-size: 13px;line-height: 16px;">
|
|
53
|
+
{{ i.precision }}
|
|
54
|
+
</p>
|
|
55
|
+
<div v-for="(value, index) in i.solution"
|
|
56
|
+
style="margin-top:15px; font-size: 13px;line-height: 16px;">
|
|
57
|
+
<p style="font-weight: bold;">Méthodologie du test : <a
|
|
58
|
+
href="{{i.link}}" target="blank">
|
|
59
|
+
<VIcon :icon="linkICon"/>
|
|
60
|
+
</a></p>
|
|
61
|
+
<p>{{ value.info1 }}</p>
|
|
62
|
+
<p>{{ value.info2 }}</p>
|
|
63
|
+
<p>{{ value.info3 }}</p>
|
|
64
|
+
</div>
|
|
65
|
+
<span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
|
|
66
|
+
</div>
|
|
67
|
+
</v-expansion-panel-text>
|
|
68
|
+
</v-expansion-panel>
|
|
69
|
+
<v-expansion-panel >
|
|
70
|
+
<v-expansion-panel-title
|
|
71
|
+
style="font-weight: bold; font-size: 13px; line-height: 16px;">
|
|
72
|
+
{{ item.subtitle }}
|
|
73
|
+
</v-expansion-panel-title>
|
|
74
|
+
<v-expansion-panel-text>
|
|
75
|
+
<div v-for="(value, i) in item.items" :key="i">
|
|
76
|
+
<p style="font-size: 13px;line-height: 16px;">
|
|
77
|
+
{{ value.precision }}
|
|
78
|
+
</p>
|
|
79
|
+
<div v-for="element in value.solution"
|
|
80
|
+
style="margin-top:15px; font-size: 13px;line-height: 16px;">
|
|
81
|
+
<p style="font-weight: bold;">Méthodologie du test : <a
|
|
82
|
+
href="value.link" target="blank">
|
|
83
|
+
<VIcon :icon="linkICon"/>
|
|
84
|
+
</a></p>
|
|
85
|
+
<p>{{ element.info1 }}</p>
|
|
86
|
+
<p>{{ element.info2 }}</p>
|
|
87
|
+
<p>{{ element.info3 }}</p>
|
|
88
|
+
</div>
|
|
89
|
+
<span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
|
|
90
|
+
</div>
|
|
91
|
+
</v-expansion-panel-text>
|
|
92
|
+
</v-expansion-panel>
|
|
93
|
+
</v-expansion-panels>
|
|
94
|
+
</v-expansion-panel-text>
|
|
95
|
+
</v-expansion-panel>
|
|
96
|
+
</v-expansion-panels>
|
|
97
|
+
</v-col>
|
|
98
|
+
<v-col cols="6">
|
|
99
|
+
<div style="display:flex; margin-bottom: 10px; justify-content: space-between; align-items: center;">
|
|
100
|
+
<h5>{{ AccessibiliteItemsValidated.length }} critères pris en charge par l'équipe Design System</h5>
|
|
101
|
+
<div style="display: flex; align-items: center;">
|
|
102
|
+
<v-btn variant="tonal" color="red" size="x-small" style="margin: 4px;font-size: 8px;"
|
|
103
|
+
rounded>Tanaguru
|
|
104
|
+
</v-btn>
|
|
105
|
+
</div>
|
|
106
|
+
</div>
|
|
107
|
+
<v-expansion-panels v-if="AccessibiliteItemsValidated.length > 0" value="opened" multiple>
|
|
108
|
+
<v-expansion-panel
|
|
109
|
+
v-for="(item, index) in AccessibiliteItemsValidated"
|
|
110
|
+
:key="index" style="background-color: rgba(53,135,0,0.1); margin-bottom: 10px;">
|
|
111
|
+
<v-expansion-panel-title>
|
|
112
|
+
<VIcon color="green" :icon="icon" style="margin-right: 5px;"/>
|
|
113
|
+
{{ item.title }}
|
|
114
|
+
</v-expansion-panel-title>
|
|
115
|
+
<v-expansion-panel-text>
|
|
116
|
+
<v-expansion-panels>
|
|
117
|
+
<v-expansion-panel>
|
|
118
|
+
<v-expansion-panel-title style="font-weight: bold;font-size: 13px; line-height: 16px;">
|
|
119
|
+
{{ item.subtitle }}
|
|
120
|
+
</v-expansion-panel-title>
|
|
121
|
+
<v-expansion-panel-text>
|
|
122
|
+
<div v-for="(value, i) in item.items" :key="i">
|
|
123
|
+
<p style="font-size: 13px;line-height: 16px;">
|
|
124
|
+
{{ value.precision }}
|
|
125
|
+
</p>
|
|
126
|
+
<div v-for="element in value.solution"
|
|
127
|
+
style="margin-top:15px; font-size: 13px;line-height: 16px;">
|
|
128
|
+
<p style="font-weight: bold;">Méthodologie du test : <a
|
|
129
|
+
href="value.link" target="blank">
|
|
130
|
+
<VIcon :icon="linkICon"/>
|
|
131
|
+
</a></p>
|
|
132
|
+
<p>{{ element.info1 }}</p>
|
|
133
|
+
<p>{{ element.info2 }}</p>
|
|
134
|
+
<p>{{ element.info3 }}</p>
|
|
135
|
+
</div>
|
|
136
|
+
<span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
|
|
137
|
+
</div>
|
|
138
|
+
</v-expansion-panel-text>
|
|
139
|
+
</v-expansion-panel>
|
|
140
|
+
</v-expansion-panels>
|
|
141
|
+
</v-expansion-panel-text>
|
|
142
|
+
</v-expansion-panel>
|
|
143
|
+
</v-expansion-panels>
|
|
144
|
+
<div v-else style="display: flex;justify-content: center;"><span style="text-align:center;" >Pas de critère d'accessibilité bloquant</span></div>
|
|
145
|
+
</v-col>
|
|
146
|
+
</div>
|
|
147
|
+
`,
|
|
148
|
+
}
|
|
149
|
+
},
|
|
150
|
+
tags: ['!dev'],
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
export const Legende: StoryObj = {
|
|
154
|
+
args: {
|
|
155
|
+
icon: checkIcon,
|
|
156
|
+
},
|
|
157
|
+
render: (args) => {
|
|
158
|
+
return {
|
|
159
|
+
components: { VIcon },
|
|
160
|
+
setup() {
|
|
161
|
+
return { args }
|
|
162
|
+
},
|
|
163
|
+
template: `
|
|
164
|
+
<p style="color: grey;font-size: 11px; margin-bottom: 12px;">Date de conception: 20/11/2024</p>
|
|
165
|
+
<div>
|
|
166
|
+
<p>Le tableau ci-dessous liste nos recommandations suivant les <a target="blank" style="color:#0C41BD;" href="https://www.numerique.gouv.fr/publications/rgaa-accessibilite/#contenu">catégories du RGAA</a>.</p>
|
|
167
|
+
<p style="margin-bottom: 12px;font-weight:bold;">Pour rappel le composant seul ne garantie pas
|
|
168
|
+
l'accessibilité du site.</p>
|
|
169
|
+
<div style="font-size: 14px">
|
|
170
|
+
<p>Nous avons deux façons de relever les problèmes d'accessibilité des composants :</p>
|
|
171
|
+
<div>
|
|
172
|
+
<v-btn variant="tonal" color="grey" size="x-small" style="margin: 2px;font-size: 8px;" rounded>
|
|
173
|
+
Audit
|
|
174
|
+
</v-btn>
|
|
175
|
+
Problèmes relevés par le projet
|
|
176
|
+
</div>
|
|
177
|
+
<div>
|
|
178
|
+
<v-btn variant="tonal" color="red" size="x-small" style="margin: 2px;font-size: 8px;" rounded>
|
|
179
|
+
Tanaguru
|
|
180
|
+
</v-btn>
|
|
181
|
+
Problèmes relevés par Tanaguru
|
|
182
|
+
</div>
|
|
183
|
+
</div>
|
|
184
|
+
</div>
|
|
185
|
+
`,
|
|
186
|
+
}
|
|
187
|
+
},
|
|
188
|
+
tags: ['!dev'],
|
|
189
|
+
}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { ExpertiseLevelEnum } from './constants/ExpertiseLevelEnum'
|
|
2
|
+
|
|
3
|
+
export const AccessibiliteItemsIndeterminate = [
|
|
4
|
+
|
|
5
|
+
{
|
|
6
|
+
title: 'Catégorie 1 : Images',
|
|
7
|
+
subtitle: '1.3 Pour chaque image porteuse d’information ayant une alternative textuelle, cette alternative est-elle pertinente (hors cas particuliers) ? ',
|
|
8
|
+
|
|
9
|
+
items2: [
|
|
10
|
+
{
|
|
11
|
+
subtitle: '1.1 Chaque image porteuse d’information a-t-elle une alternative textuelle ? ',
|
|
12
|
+
precision: '1.1.5 Chaque image vectorielle (balise <svg>) porteuse d’information, vérifie-t-elle ces conditions ? '
|
|
13
|
+
+ 'La balise <svg> possède un attribut WAI-ARIA role="img" ; '
|
|
14
|
+
+ 'La balise <svg> a une alternative textuelle.',
|
|
15
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#1.1.5',
|
|
16
|
+
solution: [{
|
|
17
|
+
info1: '1. Retrouver dans le document les éléments <svg> ; Pour chaque élément <svg>, déterminer si l’image est porteuse d’information ; ',
|
|
18
|
+
info2: '2. S’assurer que l’élément <svg> est pourvu d’un attribut WAI-ARIA role="img" ; Si ce n’est pas le cas, le test est invalidé.',
|
|
19
|
+
info3: '3. Le cas échéant, vérifier que l’élément <svg> est pourvu au moins d’une alternative textuelle parmi les suivantes : '
|
|
20
|
+
+ 'Contenu de l’élément <title> ; '
|
|
21
|
+
+ 'Passage de texte associé via l’attribut WAI-ARIA aria-labelledby ; '
|
|
22
|
+
+ 'Contenu de l’attribut WAI-ARIA aria-label ;',
|
|
23
|
+
info4: '4. Si au moins une alternative textuelle est trouvée, le test est validé. ',
|
|
24
|
+
}],
|
|
25
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
26
|
+
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
subtitle: '1.6 Chaque image porteuse d’information a-t-elle, si nécessaire, une description détaillée ?',
|
|
30
|
+
precision: '1.6.1 Chaque image (balise <img>) porteuse d’information, qui nécessite une description détaillée, vérifie-t-elle une de ces conditions ? '
|
|
31
|
+
+ 'Il existe un attribut longdesc qui donne l’adresse (URL) d’une page ou d’un emplacement dans la page contenant la description détaillée ; '
|
|
32
|
+
+ 'Il existe une alternative textuelle contenant la référence à une description détaillée adjacente à l’image ; '
|
|
33
|
+
+ 'Il existe un lien ou un bouton adjacent permettant d’accéder à la description détaillée.',
|
|
34
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#1.6.1',
|
|
35
|
+
solution: [{
|
|
36
|
+
info1: '1. Retrouver dans le document les images structurées au moyen d’un élément <img> (ou d’un élément possédant l’attribut WAI-ARIA role="img") porteuses d’information qui nécessitent une description détaillée ; ',
|
|
37
|
+
info2: '2. Pour chaque image, vérifier qu’il existe : '
|
|
38
|
+
+ 'Soit un attribut longdesc qui donne l’adresse (url) d’une page ou d’un emplacement dans la page contenant la description détaillée ; '
|
|
39
|
+
+ 'Soit une alternative textuelle contenant la référence à une description détaillée adjacente à l’image ; '
|
|
40
|
+
+ 'Soit un lien ou un bouton adjacent permettant d’accéder à la description détaillée.',
|
|
41
|
+
info3: '3. Si c’est le cas pour chaque image, le test est validé',
|
|
42
|
+
}],
|
|
43
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
44
|
+
|
|
45
|
+
},
|
|
46
|
+
|
|
47
|
+
],
|
|
48
|
+
items: [
|
|
49
|
+
{
|
|
50
|
+
precision: '1.3.1 Chaque image (balise <img> ou balise possédant l’attribut WAI-ARIA role="img") porteuse d’information, ayant une alternative textuelle, cette alternative est-elle pertinente (hors cas particuliers) ? '
|
|
51
|
+
+ 'S’il est présent, le contenu de l’attribut title est pertinent ; '
|
|
52
|
+
+ 'S’il est présent, le contenu de l’attribut alt est pertinent ; '
|
|
53
|
+
+ 'S’il est présent, le passage de texte associé via l’attribut WAI-ARIA aria-labelledby est pertinent. '
|
|
54
|
+
+ 'S’il est présent, le contenu de l’attribut WAI-ARIA aria-label est pertinent ;',
|
|
55
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#1.3.1',
|
|
56
|
+
solution: [{
|
|
57
|
+
info1: '1. Retrouver dans le document les images structurées au moyen d’un élément <img> (ou d’un élément possédant l’attribut WAI-ARIA role="img") pourvues d’une alternative textuelle ; ',
|
|
58
|
+
info2: '2. Pour chaque image, vérifier que l’alternative textuelle est pertinente ;',
|
|
59
|
+
info3: '3. Si c’est le cas pour chaque image, le test est validé',
|
|
60
|
+
}],
|
|
61
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
62
|
+
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
precision: '1.3.9 Pour chaque image porteuse d’information et ayant une alternative textuelle, l’alternative textuelle est-elle courte et concise (hors cas particuliers) ? ',
|
|
66
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#1.3.9',
|
|
67
|
+
solution: [{
|
|
68
|
+
info1: '1. Retrouver dans le document les images pourvues d’une alternative textuelle ; ',
|
|
69
|
+
info2: '2. Pour chaque image, vérifier l’alternative textuelle est courte et concise ;',
|
|
70
|
+
info3: '3. Si c’est le cas pour chaque image, le test est validé',
|
|
71
|
+
}],
|
|
72
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
73
|
+
|
|
74
|
+
},
|
|
75
|
+
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
title: 'Catégorie 3 : Couleurs',
|
|
80
|
+
subtitle: '3.1 Dans chaque page web, l’information ne doit pas être donnée uniquement par la couleur. Cette règle est-elle respectée ?',
|
|
81
|
+
items: [
|
|
82
|
+
{
|
|
83
|
+
precision: '3.1.2 Pour chaque indication de couleur donnée par un texte, l’information ne doit pas être donnée uniquement par la couleur. Cette règle est-elle respectée ?',
|
|
84
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#3.1.2',
|
|
85
|
+
solution: [{
|
|
86
|
+
info1: '1. Retrouver dans le document les textes et les textes en image sans effet de graisse d’une taille restituée inférieure à 24px qui pourraient poser des problèmes de contraste ;',
|
|
87
|
+
info2: '2. Pour chacun de ces textes, vérifier que : Soit le rapport de contraste entre le texte et son arrière-plan est de 4.5:1, au moins; Soit un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 4.5:1, au moins.',
|
|
88
|
+
info3: '3. Si c’est le cas pour chaque texte, le test est validé',
|
|
89
|
+
}],
|
|
90
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
91
|
+
|
|
92
|
+
},
|
|
93
|
+
|
|
94
|
+
],
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
title: 'Catégorie 9 : Structuration de l’information',
|
|
98
|
+
subtitle: '9.1 Dans chaque page web, l’information est-elle structurée par l’utilisation appropriée de titres',
|
|
99
|
+
items: [
|
|
100
|
+
{
|
|
101
|
+
|
|
102
|
+
precision: '9.1.1 Dans chaque page web, la hiérarchie entre les titres (balise <hx> ou balise possédant un attribut WAI-ARIA role="heading" associé à un attribut WAI-ARIA aria-level) est-elle pertinente ?',
|
|
103
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#9.1.1',
|
|
104
|
+
solution: [{
|
|
105
|
+
info1: '1. Retrouver dans le document les titres (balise <hx> ou balise possédant un attribut WAI-ARIA role="heading" associé à un attribut WAI-ARIA aria-level) ;',
|
|
106
|
+
info2: '2. Vérifier que la hiérarchie entre les titres est pertinente ;',
|
|
107
|
+
info3: '3. Si c’est le cas, le test est validé',
|
|
108
|
+
}],
|
|
109
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
110
|
+
|
|
111
|
+
},
|
|
112
|
+
|
|
113
|
+
],
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
title: 'Catégorie 10 : Présentation de l’information',
|
|
117
|
+
subtitle: '10.1 Dans le site web, des feuilles de styles sont-elles utilisées pour contrôler la présentation de l’information ? ?',
|
|
118
|
+
items: [
|
|
119
|
+
|
|
120
|
+
{
|
|
121
|
+
precision: '10.1.1 Dans chaque page web, les balises servant à la présentation de l’information ne doivent pas être présentes dans le code source généré des pages. Cette règle est-elle respectée ? ',
|
|
122
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#10.1.1',
|
|
123
|
+
solution: [{
|
|
124
|
+
info1: '1. Vérifier l’absence des éléments de présentation <basefont>, <big>, <blink>, <center>, <font>, <marquee>, <s>, <strike>, <tt> ; ',
|
|
125
|
+
info2: '2. Vérifier l’absence de l’élément <u> uniquement si le DOCTYPE du document ne correspond pas à HTML 5 ; ',
|
|
126
|
+
info3: '3. Si c’est le cas, le test est validé',
|
|
127
|
+
}],
|
|
128
|
+
expertise: ExpertiseLevelEnum.DEV,
|
|
129
|
+
|
|
130
|
+
},
|
|
131
|
+
|
|
132
|
+
],
|
|
133
|
+
},
|
|
134
|
+
|
|
135
|
+
]
|
|
136
|
+
|
|
137
|
+
export const AccessibiliteItemsValidated = [
|
|
138
|
+
{
|
|
139
|
+
title: 'Catégorie 1 : Images',
|
|
140
|
+
subtitle: '1.3 Pour chaque image porteuse d’information ayant une alternative textuelle, cette alternative est-elle pertinente (hors cas particuliers) ? ',
|
|
141
|
+
items: [
|
|
142
|
+
{
|
|
143
|
+
precision: '1.3.1 Chaque image (balise <img> ou balise possédant l’attribut WAI-ARIA role="img") porteuse d’information, ayant une alternative textuelle, cette alternative est-elle pertinente (hors cas particuliers) ? '
|
|
144
|
+
+ 'S’il est présent, le contenu de l’attribut title est pertinent ; '
|
|
145
|
+
+ 'S’il est présent, le contenu de l’attribut alt est pertinent ; '
|
|
146
|
+
+ 'S’il est présent, le passage de texte associé via l’attribut WAI-ARIA aria-labelledby est pertinent. '
|
|
147
|
+
+ 'S’il est présent, le contenu de l’attribut WAI-ARIA aria-label est pertinent ;',
|
|
148
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#1.3.1',
|
|
149
|
+
solution: [{
|
|
150
|
+
info1: '1. Retrouver dans le document les images structurées au moyen d’un élément <img> (ou d’un élément possédant l’attribut WAI-ARIA role="img") pourvues d’une alternative textuelle ; ',
|
|
151
|
+
info2: '2. Pour chaque image, vérifier que l’alternative textuelle est pertinente ;',
|
|
152
|
+
info3: '3. Si c’est le cas pour chaque image, le test est validé',
|
|
153
|
+
}],
|
|
154
|
+
expertise: ExpertiseLevelEnum.DESIGN,
|
|
155
|
+
|
|
156
|
+
},
|
|
157
|
+
|
|
158
|
+
],
|
|
159
|
+
},
|
|
160
|
+
{
|
|
161
|
+
title: 'Catégorie 3 : Couleurs',
|
|
162
|
+
subtitle: '3.2 Dans chaque page web, le contraste entre la couleur du texte et la couleur de son arrière-plan est-il suffisamment élevé?',
|
|
163
|
+
items: [
|
|
164
|
+
{
|
|
165
|
+
precision: '3.2.1 Dans chaque page web, le texte et le texte en image sans effet de graisse d’une taille restituée inférieure à 24px vérifient-ils une de ces conditions? Le rapport de contraste entre le texte et son arrière-plan est de 4.5:1, au moins; Un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 4.5:1, au moins.',
|
|
166
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#3.2.1',
|
|
167
|
+
solution: [{
|
|
168
|
+
info1: '1. Retrouver dans le document les textes et les textes en image sans effet de graisse d’une taille restituée inférieure à 24px qui pourraient poser des problèmes de contraste ;',
|
|
169
|
+
info2: '2. Pour chacun de ces textes, vérifier que : Soit le rapport de contraste entre le texte et son arrière-plan est de 4.5:1, au moins; Soit un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 4.5:1, au moins.',
|
|
170
|
+
info3: '3. Si c’est le cas pour chaque texte, le test est validé',
|
|
171
|
+
}],
|
|
172
|
+
expertise: ExpertiseLevelEnum.DESIGN,
|
|
173
|
+
|
|
174
|
+
},
|
|
175
|
+
{
|
|
176
|
+
precision: ' 3.2.3 Dans chaque page web, le texte et le texte en image sans effet de graisse d’une taille restituée supérieure ou égale à 24px vérifient-ils une de ces conditions (hors cas particuliers) ? '
|
|
177
|
+
+ 'Le rapport de contraste entre le texte et son arrière-plan est de 3:1, au moins ; '
|
|
178
|
+
+ 'Un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 3:1, au moins.',
|
|
179
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#3.2.3',
|
|
180
|
+
solution: [{
|
|
181
|
+
info1: '1. Retrouver dans le document les textes et les textes en image sans effet de graisse d’une taille restituée supérieure ou égale à 24px qui pourraient poser des problèmes de contraste ; ',
|
|
182
|
+
info2: '2. our chacun de ces textes, vérifier que : Soit le rapport de contraste entre le texte et son arrière-plan est de 3:1, au moins ; Soit un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 3:1, au moins. ',
|
|
183
|
+
info3: '3. Si c’est le cas pour chaque texte, le test est validé',
|
|
184
|
+
}],
|
|
185
|
+
expertise: ExpertiseLevelEnum.DESIGN,
|
|
186
|
+
|
|
187
|
+
},
|
|
188
|
+
{
|
|
189
|
+
precision: ' 3.2.4 Dans chaque page web, le texte et le texte en image en gras d’une taille restituée supérieure ou égale à 18,5px vérifient-ils une de ces conditions (hors cas particuliers) ? '
|
|
190
|
+
+ 'Le rapport de contraste entre le texte et son arrière-plan est de 3:1, au moins ; '
|
|
191
|
+
+ 'Un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 3:1, au moins. ',
|
|
192
|
+
link: 'https://accessibilite.numerique.gouv.fr/methode/criteres-et-tests/#3.2.4',
|
|
193
|
+
solution: [{
|
|
194
|
+
info1: '1. Retrouver dans le document les textes et les textes en image en gras d’une taille restituée supérieure ou égale à 18,5px qui pourraient poser des problèmes de contraste ; ',
|
|
195
|
+
info2: '2. Pour chacun de ces textes, vérifier que : Soit le rapport de contraste entre le texte et son arrière-plan est de 3:1, au moins ; Soit un mécanisme permet à l’utilisateur d’afficher le texte avec un rapport de contraste de 3:1, au moins. ',
|
|
196
|
+
info3: '3. Si c’est le cas pour chaque texte, le test est validé',
|
|
197
|
+
}],
|
|
198
|
+
expertise: ExpertiseLevelEnum.DESIGN,
|
|
199
|
+
|
|
200
|
+
},
|
|
201
|
+
|
|
202
|
+
],
|
|
203
|
+
},
|
|
204
|
+
|
|
205
|
+
]
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import {Controls, Canvas, Meta, Source} from '@storybook/blocks';
|
|
2
|
+
|
|
3
|
+
import * as ErrorPageStories from './ErrorPage.stories'
|
|
4
|
+
|
|
5
|
+
<Meta of={ErrorPageStories} />
|
|
6
|
+
|
|
7
|
+
# ErrorPage
|
|
8
|
+
|
|
9
|
+
Le composant `ErrorPage` sert à afficher une page d'erreur ou de maintenance.
|
|
10
|
+
|
|
11
|
+
<Canvas of={ErrorPageStories.Default} />
|
|
12
|
+
|
|
13
|
+
# API
|
|
14
|
+
|
|
15
|
+
<Controls of={ErrorPageStories.Default} />
|
|
16
|
+
|
|
17
|
+
## Lien de retour
|
|
18
|
+
|
|
19
|
+
Vous pouvez mettre un lien vers une autre page avec les props `btn-text` et `btn-link` ou `btn-href`.
|
|
20
|
+
|
|
21
|
+
<Canvas of={ErrorPageStories.WithLink} />
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
+
import ErrorPage from './ErrorPage.vue'
|
|
3
|
+
|
|
4
|
+
const meta = {
|
|
5
|
+
title: 'Templates/ErrorPage',
|
|
6
|
+
component: ErrorPage,
|
|
7
|
+
parameters: {
|
|
8
|
+
layout: 'fullscreen',
|
|
9
|
+
},
|
|
10
|
+
argTypes: {
|
|
11
|
+
'code': {
|
|
12
|
+
description: 'Code d\'erreur affiché en premier plan',
|
|
13
|
+
},
|
|
14
|
+
'codeErrorText': {
|
|
15
|
+
description: 'Text affiché avant le code d\'erreur pour les outils d\'accessibilité',
|
|
16
|
+
table: {
|
|
17
|
+
defaultValue: {
|
|
18
|
+
summary: 'Code d\'erreur\xa0: ',
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
'additional-content': {
|
|
23
|
+
control: {
|
|
24
|
+
type: 'text',
|
|
25
|
+
},
|
|
26
|
+
table: {
|
|
27
|
+
type: {
|
|
28
|
+
summary: '{}',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
'action': {
|
|
33
|
+
control: {
|
|
34
|
+
type: 'text',
|
|
35
|
+
},
|
|
36
|
+
table: {
|
|
37
|
+
type: {
|
|
38
|
+
summary: '{}',
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
'illustration': {
|
|
43
|
+
control: {
|
|
44
|
+
type: 'text',
|
|
45
|
+
},
|
|
46
|
+
table: {
|
|
47
|
+
type: {
|
|
48
|
+
summary: '{}',
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
} satisfies Meta<typeof ErrorPage>
|
|
54
|
+
|
|
55
|
+
export default meta
|
|
56
|
+
|
|
57
|
+
type Story = StoryObj<typeof ErrorPage>
|
|
58
|
+
|
|
59
|
+
export const Default: Story = {
|
|
60
|
+
args: {
|
|
61
|
+
pageTitle: 'une erreur est survenue',
|
|
62
|
+
code: '500',
|
|
63
|
+
message: 'Une erreur est survenue de notre côté, veuillez réessayer plus tard. Si le problème persiste veuillez nous contacter par téléphone au 3646',
|
|
64
|
+
},
|
|
65
|
+
parameters: {
|
|
66
|
+
sourceCode: [
|
|
67
|
+
{
|
|
68
|
+
name: 'Template',
|
|
69
|
+
code: `
|
|
70
|
+
<template>
|
|
71
|
+
<div style="padding: 20px; background: rgb(231, 236, 245)">
|
|
72
|
+
<ErrorPage
|
|
73
|
+
page-title="une erreur est survenue"
|
|
74
|
+
code="500"
|
|
75
|
+
message="Une erreur est survenue de notre côté, veuillez réessayer plus tard. Si le problème persiste veuillez nous contacter par téléphone au 3646"
|
|
76
|
+
>
|
|
77
|
+
</div>
|
|
78
|
+
</template>
|
|
79
|
+
`,
|
|
80
|
+
}, {
|
|
81
|
+
name: 'Script',
|
|
82
|
+
code: `
|
|
83
|
+
<script setup lang="ts">
|
|
84
|
+
import { ErrorPage } from '@cnamts/synapse'
|
|
85
|
+
</script>
|
|
86
|
+
|
|
87
|
+
`,
|
|
88
|
+
},
|
|
89
|
+
],
|
|
90
|
+
},
|
|
91
|
+
decorators: [
|
|
92
|
+
() => ({ template: '<div style="padding: 20px; background: rgb(231, 236, 245)"><story /></div>' }),
|
|
93
|
+
],
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
export const WithLink: Story = {
|
|
97
|
+
args: {
|
|
98
|
+
...Default.args,
|
|
99
|
+
btnHref: '/',
|
|
100
|
+
btnText: 'Retour à l\'accueil',
|
|
101
|
+
},
|
|
102
|
+
parameters: {
|
|
103
|
+
sourceCode: [
|
|
104
|
+
{
|
|
105
|
+
name: 'Template',
|
|
106
|
+
code: `
|
|
107
|
+
<template>
|
|
108
|
+
<div style="padding: 20px; background: rgb(231, 236, 245)">
|
|
109
|
+
<ErrorPage
|
|
110
|
+
page-title="une erreur est survenue"
|
|
111
|
+
code="500"
|
|
112
|
+
message="Une erreur est survenue de notre côté, veuillez réessayer plus tard. Si le problème persiste veuillez nous contacter par téléphone au 3646"
|
|
113
|
+
btn-href=""
|
|
114
|
+
btn-text="Retour à l'accueil"
|
|
115
|
+
>
|
|
116
|
+
</div>
|
|
117
|
+
</template>
|
|
118
|
+
`,
|
|
119
|
+
}, {
|
|
120
|
+
name: 'Script',
|
|
121
|
+
code: `
|
|
122
|
+
<script setup lang="ts">
|
|
123
|
+
import { ErrorPage } from '@cnamts/synapse'
|
|
124
|
+
</script>
|
|
125
|
+
|
|
126
|
+
`,
|
|
127
|
+
},
|
|
128
|
+
],
|
|
129
|
+
},
|
|
130
|
+
decorators: [
|
|
131
|
+
() => ({ template: '<div style="padding: 20px; background: rgb(231, 236, 245)"><story /></div>' }),
|
|
132
|
+
],
|
|
133
|
+
}
|