@cnamts/synapse 1.0.21 → 1.0.22
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/{DateFilter-uN8OURoP.js → DateFilter-B5n-ZkLi.js} +29 -24
- package/dist/{NumberFilter-sm1dQNQi.js → NumberFilter-CtiZ9uj8.js} +1 -1
- package/dist/{PeriodFilter-Cklsxnh9.js → PeriodFilter-DzqiMb-b.js} +1 -1
- package/dist/{SelectFilter-CWefj27Z.js → SelectFilter-BOYlF7rX.js} +1 -1
- package/dist/{TextFilter-Ddyj885L.js → TextFilter-BOFRNfcX.js} +1 -1
- package/dist/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.d.ts +7399 -5967
- package/dist/components/Amelipro/AmeliproBtn/AmeliproBtn.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproCallback/AmeliproCallback.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproCarousel/AmeliproCarousel.d.ts +10 -14
- package/dist/components/Amelipro/AmeliproCarousel/AmeliproCarouselItem/AmeliproCarouselItem.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproClickableTile/AmeliproClickableTile.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproFirstLogin/AmeliproFirstLogin.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproFooter/AmeliproFooter.d.ts +8 -8
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeader.d.ts +3 -3
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBar.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/AmeliproHeaderBrandSection.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproIcon/AmeliproIcon.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.d.ts +16 -20
- package/dist/components/Amelipro/AmeliproMenu/AmeliproMenu.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/AmeliproPaginationBtn.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/AmeliproPostalAddressCityRow.d.ts +1610 -1354
- package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.d.ts +2411 -2027
- package/dist/components/Amelipro/AmeliproSelect/AmeliproSelect.d.ts +8889 -7327
- package/dist/components/Amelipro/AmeliproStateTile/AmeliproStateTile.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproStepper/AmeliproStepper.d.ts +2 -6
- package/dist/components/Amelipro/AmeliproTabs/AmeliproTabs.d.ts +8888 -7334
- package/dist/components/Amelipro/AmeliproTextArea/AmeliproTextArea.d.ts +951 -839
- package/dist/components/Amelipro/AmeliproTextField/AmeliproTextField.d.ts +1613 -1357
- package/dist/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.d.ts +223 -203
- package/dist/components/Amelipro/AmeliproTransmission/AmeliproTransmission.d.ts +3 -3
- package/dist/components/Amelipro/StructureMenu/StructureTabs/StructureTabs.d.ts +3 -7
- package/dist/components/CollapsibleList/CollapsibleList.d.ts +4 -1
- package/dist/components/CookieBanner/CookieBanner.d.ts +303 -273
- package/dist/components/CookiesSelection/CookiesInformation/CookiesInformation.d.ts +1297 -1156
- package/dist/components/CookiesSelection/CookiesSelection.d.ts +404 -377
- package/dist/components/Customs/Selects/SelectBtnField/SelectBtnField.d.ts +1 -1
- package/dist/components/Customs/Selects/SyAutocomplete/SyAutocomplete.d.ts +1088 -847
- package/dist/components/Customs/Selects/SyInputSelect/SyInputSelect.d.ts +1 -1
- package/dist/components/Customs/Selects/SySelect/SySelect.d.ts +515 -321
- package/dist/components/Customs/SyCheckBoxGroup/SyCheckBoxGroup.d.ts +41 -39
- package/dist/components/Customs/SyCheckbox/SyCheckbox.d.ts +921 -801
- package/dist/components/Customs/SyForm/SyForm.d.ts +356 -348
- package/dist/components/Customs/SyPagination/SyPagination.d.ts +11 -1
- package/dist/components/Customs/SyRadioGroup/SyRadioGroup.d.ts +907 -795
- package/dist/components/Customs/SyTextField/SyTextField.d.ts +1629 -1365
- package/dist/components/DataList/DataList.d.ts +1 -1
- package/dist/components/DatePicker/CalendarMode/DatePicker.d.ts +3868 -3123
- package/dist/components/DatePicker/ComplexDatePicker/ComplexDatePicker.d.ts +1946 -1562
- package/dist/components/DatePicker/DateTextInput/DateTextInput.d.ts +833 -687
- package/dist/components/DialogBox/DialogBox.d.ts +482 -416
- package/dist/components/DownloadBtn/config.d.ts +1 -1
- package/dist/components/ErrorPage/ErrorPage.d.ts +4 -0
- package/dist/components/FileList/UploadItem/locales.d.ts +4 -0
- package/dist/components/FileUpload/FileUpload.d.ts +4 -4
- package/dist/components/FileUpload/locales.d.ts +1 -0
- package/dist/components/FilterSideBar/FilterSideBar.d.ts +418 -366
- package/dist/components/FooterBar/FooterBar.d.ts +13 -1
- package/dist/components/FooterBar/locales.d.ts +1 -0
- package/dist/components/FooterBar/types.d.ts +1 -0
- package/dist/components/HeaderBar/HeaderBar.d.ts +1 -0
- package/dist/components/HeaderBar/HeaderLogo/HeaderLogo.d.ts +1 -0
- package/dist/components/HeaderNavigationBar/HeaderNavigationBar.d.ts +3 -6
- package/dist/components/HeaderToolbar/HeaderToolbar.d.ts +1031 -643
- package/dist/components/LangBtn/LangBtn.d.ts +277 -239
- package/dist/components/LogoBrandSection/LogoBrandSection.d.ts +4 -0
- package/dist/components/MaintenancePage/MaintenancePage.d.ts +16 -1
- package/dist/components/NirField/NirField.d.ts +1659 -1371
- package/dist/components/NotFoundPage/NotFoundPage.d.ts +9 -3
- package/dist/components/PageContainer/PageContainer.d.ts +3 -1
- package/dist/components/PasswordField/PasswordField.d.ts +1 -1
- package/dist/components/PeriodField/PeriodField.d.ts +7712 -6216
- package/dist/components/PhoneField/PhoneField.d.ts +831 -687
- package/dist/components/RangeField/RangeSlider/RangeSlider.d.ts +4 -12
- package/dist/components/StatusPage/StatusPage.d.ts +12 -1
- package/dist/components/SubHeader/SubHeader.d.ts +2 -0
- package/dist/components/SyAlert/SyAlert.d.ts +74 -70
- package/dist/components/SyBtnMenu/SyBtnMenu.d.ts +10 -1
- package/dist/components/SyHeading/SyHeading.d.ts +20 -0
- package/dist/components/SyTextArea/SyTextArea.d.ts +476 -420
- package/dist/components/Tables/SyServerTable/SyServerTable.d.ts +759 -468
- package/dist/components/Tables/SyTable/SyTable.d.ts +761 -470
- package/dist/components/Tables/common/SyTableFilter.d.ts +1 -1
- package/dist/components/Tables/common/SyTablePagination.d.ts +269 -170
- package/dist/components/Tables/common/filters/DateFilter.d.ts +10 -1
- package/dist/components/Tables/common/filters/NumberFilter.d.ts +1 -1
- package/dist/components/Tables/common/filters/PeriodFilter.d.ts +1 -1
- package/dist/components/Tables/common/filters/SelectFilter.d.ts +1 -1
- package/dist/components/Tables/common/filters/TextFilter.d.ts +1 -1
- package/dist/components/Tables/common/organizeColumns/OrganizeColumns.d.ts +166 -138
- package/dist/components/Tables/common/types.d.ts +2 -0
- package/dist/components/UploadWorkflow/UploadWorkflow.d.ts +24 -1211
- package/dist/components/UserMenuBtn/UserMenuBtn.d.ts +1 -0
- package/dist/components/index.d.ts +1 -0
- package/dist/components/types.d.ts +2 -0
- package/dist/design-system-v3.js +70 -69
- package/dist/design-system-v3.umd.cjs +265 -265
- package/dist/designTokens/tokens/amelipro/apLightTheme.d.ts +26 -14
- package/dist/designTokens/tokens/amelipro/apSemantic.d.ts +19 -13
- package/dist/designTokens/tokens/cnam/cnamLightTheme.d.ts +28 -15
- package/dist/designTokens/tokens/cnam/cnamSemantic.d.ts +20 -13
- package/dist/designTokens/tokens/pa/paLightTheme.d.ts +26 -15
- package/dist/designTokens/tokens/pa/paSemantic.d.ts +19 -13
- package/dist/main-CEl4J8_T.js +37241 -0
- package/dist/style.css +1 -1
- package/dist/vuetifyConfig.d.ts +14 -14
- package/package.json +13 -7
- package/src/assets/amelipro/img/logo-amelipro.svg +9 -0
- package/src/assets/apTokens.scss +53 -17
- package/src/assets/overrides/_icons.scss +12 -2
- package/src/assets/overrides/_tooltips.scss +5 -6
- package/src/assets/overrides/_typography.scss +17 -2
- package/src/assets/overrides/_utilities.scss +49 -3
- package/src/assets/tokens.scss +53 -17
- package/src/components/Accordion/accessibilite/Accessibility.mdx +5 -4
- package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/AmeliproAccordionTemplate.vue +2 -2
- package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/__tests__/__snapshots__/AmeliproAccordionTemplate.spec.ts.snap +0 -2
- package/src/components/Amelipro/AmeliproAccordionFrieze/AmeliproAccordionFrieze.vue +2 -2
- package/src/components/Amelipro/AmeliproAccordionFrieze/__tests__/__snapshots__/AmeliproAccordionFrieze.spec.ts.snap +14 -56
- package/src/components/Amelipro/AmeliproAccordionList/AmeliproAccordionList.vue +1 -1
- package/src/components/Amelipro/AmeliproAccordionList/__tests__/__snapshots__/AmeliproAccordionList.spec.ts.snap +15 -23
- package/src/components/Amelipro/AmeliproAccordionResultList/AmeliproAccordionResultList.vue +1 -1
- package/src/components/Amelipro/AmeliproAccordionResultList/__tests__/__snapshots__/AmeliproAccordionResultList.spec.ts.snap +15 -3
- package/src/components/Amelipro/AmeliproCarousel/__tests__/__snapshots__/AmeliproCarousel.spec.ts.snap +0 -2
- package/src/components/Amelipro/AmeliproClickableTile/tests/__snapshots__/AmeliproClickableTile.spec.ts.snap +0 -98
- package/src/components/Amelipro/AmeliproContentLayout/AmeliproContentLayout.mdx +1 -1
- package/src/components/Amelipro/AmeliproContentLayout/AmeliproContentLayout.stories.ts +5 -16
- package/src/components/Amelipro/AmeliproCopyBtn/AmeliproCopyBtn.mdx +3 -1
- package/src/components/Amelipro/AmeliproCopyBtn/AmeliproCopyBtn.stories.ts +7 -0
- package/src/components/Amelipro/AmeliproDentalChart/AmeliproTooth/AmeliproTooth.vue +0 -1
- package/src/components/Amelipro/AmeliproDentalChart/AmeliproTooth/tests/__snapshots__/AmeliproTooth.spec.ts.snap +0 -1
- package/src/components/Amelipro/AmeliproDentalChart/tests/__snapshots__/AmeliproDentalChart.spec.ts.snap +0 -52
- package/src/components/Amelipro/AmeliproDialog/__tests__/__snapshots__/AmeliproDialog.spec.ts.snap +6 -0
- package/src/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.mdx +3 -1
- package/src/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.stories.ts +19 -0
- package/src/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.vue +2 -2
- package/src/components/Amelipro/AmeliproFirstLogin/AmeliproFirstLogin.vue +3 -4
- package/src/components/Amelipro/AmeliproFirstLogin/__tests__/__snapshots__/AmeliproFirstLogin.spec.ts.snap +2 -13
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.mdx +3 -1
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.stories.ts +7 -0
- package/src/components/Amelipro/AmeliproMenu/__tests__/__snapshots__/AmeliproMenu.spec.ts.snap +8 -0
- package/src/components/Amelipro/AmeliproPatientLogged/__tests__/__snapshots__/AmeliproPatientLogged.spec.ts.snap +9 -2
- package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/__tests__/__snapshots__/AmeliproPostalAddressCityRow.spec.ts.snap +28 -10
- package/src/components/Amelipro/AmeliproPostalAddressField/__tests__/__snapshots__/AmeliproPostalAddressField.spec.ts.snap +44 -8
- package/src/components/Amelipro/AmeliproResultList/AmeliproResultList.vue +1 -1
- package/src/components/Amelipro/AmeliproResultList/__tests__/__snapshots__/AmeliproResultList.spec.ts.snap +15 -3
- package/src/components/Amelipro/AmeliproTable/AmeliproTable.vue +1 -1
- package/src/components/Amelipro/AmeliproTable/__tests__/__snapshots__/AmeliproTable.spec.ts.snap +0 -1
- package/src/components/Amelipro/AmeliproTooltips/__tests__/__snapshots__/AmeliproTooltips.spec.ts.snap +6 -0
- package/src/components/Amelipro/AmeliproUpload/__tests__/__snapshots__/AmeliproUpload.spec.ts.snap +2 -4
- package/src/components/Amelipro/StructureMenu/StructureList/__tests__/__snapshots__/StructureList.spec.ts.snap +0 -2
- package/src/components/Amelipro/UserMenu/__tests__/__snapshots__/UserMenu.spec.ts.snap +8 -0
- package/src/components/BackBtn/BackBtn.vue +1 -1
- package/src/components/Captcha/tests/__snapshots__/Captcha.spec.ts.snap +36 -18
- package/src/components/ChipList/ChipList.vue +4 -2
- package/src/components/CollapsibleList/CollapsibleList.stories.ts +8 -3
- package/src/components/CollapsibleList/CollapsibleList.vue +14 -6
- package/src/components/CollapsibleList/accessibilite/Accessibility.mdx +19 -6
- package/src/components/CollapsibleList/tests/CollapsibleList.a11y.spec.ts +1 -0
- package/src/components/CollapsibleList/tests/CollapsibleList.spec.ts +2 -0
- package/src/components/CookieBanner/CookieBanner.stories.ts +10 -0
- package/src/components/CookieBanner/CookieBanner.vue +15 -5
- package/src/components/CookieBanner/accessibilite/Accessibility.mdx +9 -0
- package/src/components/CookieBanner/tests/CookieBanner.spec.ts +10 -2
- package/src/components/CookieBanner/tests/__snapshots__/CookieBanner.spec.ts.snap +21 -15
- package/src/components/CookiesSelection/CookiesInformation/CookiesInformation.vue +17 -8
- package/src/components/CookiesSelection/CookiesInformation/tests/CookiesInformation.a11y.spec.ts +1 -0
- package/src/components/CookiesSelection/CookiesInformation/tests/CookiesInformation.spec.ts +5 -0
- package/src/components/CookiesSelection/CookiesSelection.vue +7 -2
- package/src/components/CookiesSelection/tests/CookiesSelection.a11y.spec.ts +1 -0
- package/src/components/CookiesSelection/tests/CookiesSelection.spec.ts +5 -0
- package/src/components/CookiesSelection/tests/__snapshots__/CookiesSelection.spec.ts.snap +21 -15
- package/src/components/CopyBtn/CopyBtn.vue +6 -4
- package/src/components/CopyBtn/accessibilite/Accessibility.mdx +82 -11
- package/src/components/CopyBtn/tests/__snapshots__/CopyBtn.spec.ts.snap +5 -1
- package/src/components/Customs/Selects/SyInputSelect/SyInputSelect.stories.ts +4 -10
- package/src/components/Customs/Selects/SySelect/SySelect.mdx +0 -1
- package/src/components/Customs/Selects/SySelect/SySelect.stories.ts +10 -10
- package/src/components/Customs/Selects/SySelect/SySelect.vue +17 -0
- package/src/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.ts +1 -1
- package/src/components/Customs/Selects/SySelect/tests/SySelect.a11y.spec.ts +1 -3
- package/src/components/Customs/Selects/SySelect/tests/SySelect.spec.ts +72 -0
- package/src/components/Customs/SyCheckbox/SyCheckbox.vue +1 -1
- package/src/components/Customs/SyIcon/SyIcon.a11y.spec.ts +31 -2
- package/src/components/Customs/SyIcon/SyIcon.vue +9 -5
- package/src/components/Customs/SyPagination/SyPagination.stories.ts +14 -2
- package/src/components/Customs/SyPagination/SyPagination.vue +20 -5
- package/src/components/Customs/SyPagination/accessibilite/Accessibility.mdx +79 -8
- package/src/components/Customs/SyPagination/tests/SyPagination.a11y.spec.ts +53 -0
- package/src/components/Customs/SyPagination/tests/SyPagination.spec.ts +12 -0
- package/src/components/Customs/SyTextField/SyTextField.stories.ts +4 -0
- package/src/components/Customs/SyTextField/SyTextField.vue +39 -5
- package/src/components/DatePicker/CalendarMode/DatePicker.stories.ts +28 -3
- package/src/components/DatePicker/CalendarMode/DatePicker.vue +20 -8
- package/src/components/DatePicker/CalendarMode/tests/DatePicker.spec.ts +9 -3
- package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.stories.ts +1 -1
- package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.vue +70 -47
- package/src/components/DatePicker/ComplexDatePicker/tests/ComplexDatePicker.a11y.spec.ts +34 -0
- package/src/components/DatePicker/DateTextInput/tests/DateTextInput.a11y.spec.ts +27 -0
- package/src/components/DatePicker/docExamples/BidirectionalComplexValidation.vue +23 -9
- package/src/components/DatePicker/docExamples/DatePickerBidirectionalValidation.vue +21 -8
- package/src/components/DatePicker/docExamples/DatePickerValidationExamples.vue +50 -22
- package/src/components/DatePicker/playground/ComplexDatePickerPlayground.vue +48 -10
- package/src/components/DatePicker/playground/DatePickerHolidayRule.vue +16 -3
- package/src/components/DialogBox/DialogBox.stories.ts +13 -0
- package/src/components/DialogBox/DialogBox.vue +12 -5
- package/src/components/DialogBox/accessibilite/Accessibility.mdx +27 -7
- package/src/components/DialogBox/tests/DialogBox.a11y.spec.ts +1 -0
- package/src/components/DialogBox/tests/DialogBox.spec.ts +40 -6
- package/src/components/DownloadBtn/accessibilite/Accessibility.mdx +73 -11
- package/src/components/DownloadBtn/config.ts +1 -1
- package/src/components/ErrorPage/ErrorPage.stories.ts +82 -47
- package/src/components/ErrorPage/ErrorPage.vue +6 -0
- package/src/components/ErrorPage/accessibilite/Accessibility.mdx +15 -0
- package/src/components/ErrorPage/tests/__snapshots__/ErrorPage.spec.ts.snap +2 -0
- package/src/components/ExternalLinks/tests/__snapshots__/ExternalLinks.spec.ts.snap +13 -2
- package/src/components/FileList/FileList.stories.ts +4 -0
- package/src/components/FileList/UploadItem/UploadItem.vue +8 -3
- package/src/components/FileList/UploadItem/locales.ts +10 -0
- package/src/components/FileList/accessibilite/Accessibility.mdx +55 -7
- package/src/components/FileUpload/FileUpload.vue +60 -37
- package/src/components/FileUpload/FileUploadContent.vue +1 -1
- package/src/components/FileUpload/accessibilite/Accessibility.mdx +48 -5
- package/src/components/FileUpload/locales.ts +1 -0
- package/src/components/FileUpload/tests/FileUpload.spec.ts +14 -14
- package/src/components/FilterInline/FilterInline.stories.ts +0 -15
- package/src/components/FilterInline/FilterInline.vue +1 -0
- package/src/components/FilterInline/accessibilite/Accessibility.mdx +70 -7
- package/src/components/FilterInline/tests/__snapshots__/FilterInline.spec.ts.snap +3 -3
- package/src/components/FilterSideBar/FilterSideBar.stories.ts +0 -3
- package/src/components/FilterSideBar/FilterSideBar.vue +2 -1
- package/src/components/FilterSideBar/accessibilite/Accessibility.mdx +70 -9
- package/src/components/FooterBar/FooterBar.stories.ts +298 -34
- package/src/components/FooterBar/FooterBar.vue +67 -9
- package/src/components/FooterBar/config.ts +2 -2
- package/src/components/FooterBar/locales.ts +1 -0
- package/src/components/FooterBar/tests/FooterBarConfig.spec.ts +1 -1
- package/src/components/FooterBar/tests/__snapshots__/FooterBar.spec.ts.snap +6 -25
- package/src/components/FooterBar/types.d.ts +1 -0
- package/src/components/HeaderBar/HeaderBar.stories.ts +23 -1
- package/src/components/HeaderBar/HeaderBar.vue +4 -0
- package/src/components/HeaderBar/HeaderLogo/HeaderLogo.vue +7 -2
- package/src/components/HeaderBar/HeaderLogo/tests/HeaderLogo.spec.ts +5 -0
- package/src/components/HeaderBar/accessibilite/Accessibility.mdx +24 -5
- package/src/components/HeaderBar/tests/HeaderBar.a11y.spec.ts +1 -0
- package/src/components/HeaderBar/tests/HeaderBar.spec.ts +3 -0
- package/src/components/HeaderNavigationBar/HeaderNavigationBar.stories.ts +4 -0
- package/src/components/HeaderNavigationBar/HeaderNavigationBar.vue +2 -0
- package/src/components/HeaderNavigationBar/tests/HeaderNavigationBar.spec.ts +3 -0
- package/src/components/LogoBrandSection/LogoBrandSection.stories.ts +22 -0
- package/src/components/LogoBrandSection/LogoBrandSection.vue +13 -5
- package/src/components/LogoBrandSection/tests/LogoBrandSection.a11y.spec.ts +2 -0
- package/src/components/LogoBrandSection/tests/LogoBrandSection.spec.ts +44 -0
- package/src/components/LogoBrandSection/tests/__snapshots__/LogoBrandSection.spec.ts.snap +2 -0
- package/src/components/MaintenancePage/MaintenancePage.vue +33 -6
- package/src/components/MaintenancePage/accessibilite/Accessibility.mdx +3 -1
- package/src/components/MaintenancePage/tests/MaintenancePage.a11y.spec.ts +3 -2
- package/src/components/MaintenancePage/tests/MaintenancePage.spec.ts +18 -0
- package/src/components/MaintenancePage/tests/__snapshots__/MaintenancePage.spec.ts.snap +2 -0
- package/src/components/NotFoundPage/NotFoundPage.stories.ts +1 -1
- package/src/components/NotFoundPage/NotFoundPage.vue +16 -5
- package/src/components/NotFoundPage/accessibilite/Accessibility.mdx +2 -0
- package/src/components/NotFoundPage/tests/NotFoundPage.a11y.spec.ts +49 -0
- package/src/components/NotFoundPage/tests/NotFoundPage.spec.ts +25 -2
- package/src/components/NotFoundPage/tests/__snapshots__/NotFoundPage.spec.ts.snap +2 -0
- package/src/components/PageContainer/PageContainer.stories.ts +47 -0
- package/src/components/PageContainer/PageContainer.vue +4 -2
- package/src/components/PageContainer/accessibilite/Accessibility.mdx +31 -17
- package/src/components/PaginatedTable/PaginatedTable.mdx +3 -3
- package/src/components/PaginatedTable/PaginatedTable.stories.ts +9 -1
- package/src/components/PeriodField/PeriodField.vue +4 -0
- package/src/components/PeriodField/tests/PeriodField.a11y.spec.ts +10 -1
- package/src/components/PhoneField/PhoneField.stories.ts +73 -35
- package/src/components/PhoneField/PhoneField.vue +152 -83
- package/src/components/PhoneField/accessibilite/Accessibility.mdx +306 -9
- package/src/components/PhoneField/indicatifs.ts +2 -2
- package/src/components/PhoneField/tests/PhoneField.a11y.spec.ts +47 -0
- package/src/components/PhoneField/tests/PhoneField.spec.ts +82 -5
- package/src/components/SearchListField/SearchListField.vue +1 -1
- package/src/components/SearchListField/accessibilite/Accessibility.mdx +69 -9
- package/src/components/SearchListField/tests/SearchListField.a11y.spec.ts +37 -0
- package/src/components/SocialMediaLinks/SocialMediaLinks.vue +1 -1
- package/src/components/StatusPage/StatusPage.mdx +10 -1
- package/src/components/StatusPage/StatusPage.stories.ts +43 -0
- package/src/components/StatusPage/StatusPage.vue +26 -4
- package/src/components/StatusPage/accessibilite/Accessibility.mdx +24 -5
- package/src/components/StatusPage/tests/StatusPage.a11y.spec.ts +1 -0
- package/src/components/StatusPage/tests/StatusPage.spec.ts +3 -0
- package/src/components/StatusPage/tests/__snapshots__/StatusPage.spec.ts.snap +2 -0
- package/src/components/SubHeader/SubHeader.stories.ts +16 -0
- package/src/components/SubHeader/SubHeader.vue +6 -3
- package/src/components/SubHeader/accessibilite/Accessibility.mdx +27 -6
- package/src/components/SyAlert/SyAlert.vue +21 -20
- package/src/components/SyBtnMenu/SyBtnMenu.vue +33 -17
- package/src/components/SyBtnMenu/tests/SyBtnMenu.a11y.spec.ts +38 -0
- package/src/components/SyBtnMenu/tests/SyBtnMenu.spec.ts +41 -0
- package/src/components/SyHeading/SyHeading.vue +18 -0
- package/src/components/TableToolbar/tests/__snapshots__/TableToolbar.spec.ts.snap +96 -30
- package/src/components/Tables/SyServerTable/SyServerTable.vue +2 -0
- package/src/components/Tables/SyTable/SyTable.vue +2 -0
- package/src/components/Tables/common/SyTablePagination.vue +16 -10
- package/src/components/Tables/common/filters/DateFilter.vue +5 -0
- package/src/components/Tables/common/tests/SyTablePagination.spec.ts +40 -24
- package/src/components/Tables/common/types.ts +3 -0
- package/src/components/UploadWorkflow/UploadWorkflow.stories.ts +11 -11
- package/src/components/UploadWorkflow/UploadWorkflow.vue +30 -13
- package/src/components/UploadWorkflow/accessibilite/Accessibility.mdx +56 -5
- package/src/components/UploadWorkflow/accessibilite/UploadWorkflow.a11y.spec.ts +110 -0
- package/src/components/UploadWorkflow/tests/UploadWorkflow.spec.ts +7 -25
- package/src/components/UploadWorkflow/tests/__snapshots__/UploadWorkflow.spec.ts.snap +144 -121
- package/src/components/UserMenuBtn/UserMenuBtn.stories.ts +53 -31
- package/src/components/UserMenuBtn/UserMenuBtn.vue +4 -1
- package/src/components/UserMenuBtn/accessibilite/Accessibility.mdx +72 -8
- package/src/components/index.ts +1 -0
- package/src/components/types.ts +4 -0
- package/src/composables/date/tests/useDateInitialization.spec.ts +22 -1
- package/src/composables/date/useDateInitializationDayjs.ts +4 -7
- package/src/composables/date/useDatePickerAccessibility.ts +2 -3
- package/src/composables/useFilterable/useFilterable.spec.ts +52 -2
- package/src/composables/useFilterable/useFilterable.ts +7 -1
- package/src/designTokens/tokens/amelipro/apLightTheme.ts +27 -15
- package/src/designTokens/tokens/amelipro/apSemantic.ts +21 -15
- package/src/designTokens/tokens/cnam/cnamLightTheme.ts +28 -15
- package/src/designTokens/tokens/cnam/cnamSemantic.ts +21 -14
- package/src/designTokens/tokens/pa/paLightTheme.ts +27 -16
- package/src/designTokens/tokens/pa/paSemantic.ts +19 -13
- package/src/directives/rgaaSvgFix.ts +2 -7
- package/src/stories/Accessibilite/{Audit → AuditEtContreAudit}/Exemptions-derogations.mdx +1 -1
- package/src/stories/Accessibilite/AuditEtContreAudit/Introduction.mdx +188 -0
- package/src/stories/Accessibilite/{Audit → AuditEtContreAudit}/RGAA.mdx +1 -1
- package/src/stories/Accessibilite/Introduction.mdx +22 -3
- package/src/stories/Accessibilite/KitDePreAudit/Introduction.mdx +21 -22
- package/src/stories/DeprecationNotice/DeprecationNotice.ts +41 -0
- package/src/stories/DesignTokens/ColorDisplay.vue +12 -5
- package/src/stories/DesignTokens/Colors.mdx +8 -59
- package/src/stories/DesignTokens/colors.stories.ts +1862 -1071
- package/src/stories/EcoConception/EcoGuideComponent.vue +10 -4
- package/dist/main-CWniLr0s.js +0 -36919
|
@@ -6,7 +6,7 @@ import UploadWorkflow from '../UploadWorkflow.vue'
|
|
|
6
6
|
import { locales as fileListLocales } from '@/components/FileList/UploadItem/locales'
|
|
7
7
|
import { locales as FileUploadLocales } from '@/components/FileUpload/locales'
|
|
8
8
|
import { afterEach } from 'node:test'
|
|
9
|
-
import {
|
|
9
|
+
import { SySelect } from '@/components'
|
|
10
10
|
|
|
11
11
|
describe('UploadWorkflow', () => {
|
|
12
12
|
afterEach(() => {
|
|
@@ -35,24 +35,6 @@ describe('UploadWorkflow', () => {
|
|
|
35
35
|
expect(wrapper.find('.sy-file-upload').isVisible()).toBeTruthy()
|
|
36
36
|
})
|
|
37
37
|
|
|
38
|
-
it('renders default title with role heading and configured aria-level', () => {
|
|
39
|
-
const wrapper = mount(UploadWorkflow, {
|
|
40
|
-
props: {
|
|
41
|
-
uploadList: [
|
|
42
|
-
{
|
|
43
|
-
id: 'ID',
|
|
44
|
-
title: 'Carte d\'identité',
|
|
45
|
-
},
|
|
46
|
-
],
|
|
47
|
-
headingLevel: 2,
|
|
48
|
-
},
|
|
49
|
-
})
|
|
50
|
-
|
|
51
|
-
const title = wrapper.find('[role="heading"]')
|
|
52
|
-
expect(title.exists()).toBe(true)
|
|
53
|
-
expect(title.attributes('aria-level')).toBe('2')
|
|
54
|
-
})
|
|
55
|
-
|
|
56
38
|
it('shows the file in the list when set with the list button', async () => {
|
|
57
39
|
const wrapper = mount(UploadWorkflow, {
|
|
58
40
|
props: {
|
|
@@ -75,7 +57,7 @@ describe('UploadWorkflow', () => {
|
|
|
75
57
|
type: 'application/pdf',
|
|
76
58
|
})
|
|
77
59
|
|
|
78
|
-
await wrapper.find('
|
|
60
|
+
await wrapper.find('.sy-file-upload').trigger('drop', {
|
|
79
61
|
dataTransfer: {
|
|
80
62
|
files: [file],
|
|
81
63
|
},
|
|
@@ -155,14 +137,14 @@ describe('UploadWorkflow', () => {
|
|
|
155
137
|
type: 'application/pdf',
|
|
156
138
|
})
|
|
157
139
|
|
|
158
|
-
await wrapper.find('
|
|
140
|
+
await wrapper.find('.sy-file-upload').trigger('drop', {
|
|
159
141
|
dataTransfer: {
|
|
160
142
|
files: [file],
|
|
161
143
|
},
|
|
162
144
|
})
|
|
163
145
|
|
|
164
|
-
wrapper.find('.
|
|
165
|
-
wrapper.findComponent(
|
|
146
|
+
wrapper.find('.sy-select input').setValue('bill')
|
|
147
|
+
wrapper.findComponent(SySelect).vm.$emit('update:modelValue', 'bill')
|
|
166
148
|
|
|
167
149
|
await wrapper.find('[data-test-id="confirm-btn"]').trigger('click')
|
|
168
150
|
|
|
@@ -204,7 +186,7 @@ describe('UploadWorkflow', () => {
|
|
|
204
186
|
type: 'application/pdf',
|
|
205
187
|
})
|
|
206
188
|
|
|
207
|
-
await wrapper.find('
|
|
189
|
+
await wrapper.find('.sy-file-upload').trigger('drop', {
|
|
208
190
|
dataTransfer: {
|
|
209
191
|
files: [file],
|
|
210
192
|
},
|
|
@@ -248,7 +230,7 @@ describe('UploadWorkflow', () => {
|
|
|
248
230
|
|
|
249
231
|
await wrapper.find('.file-item button').trigger('click')
|
|
250
232
|
|
|
251
|
-
await wrapper.find('
|
|
233
|
+
await wrapper.find('.sy-file-upload').trigger('drop', {
|
|
252
234
|
dataTransfer: {
|
|
253
235
|
files: [image],
|
|
254
236
|
},
|
|
@@ -8,16 +8,13 @@ exports[`UploadWorkflow > render the upload list 1`] = `
|
|
|
8
8
|
"
|
|
9
9
|
style="width: 100%;"
|
|
10
10
|
>
|
|
11
|
-
<
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
"
|
|
17
|
-
role="heading"
|
|
18
|
-
>
|
|
11
|
+
<h4 class="
|
|
12
|
+
mb-2
|
|
13
|
+
sy-heading
|
|
14
|
+
text-h6
|
|
15
|
+
">
|
|
19
16
|
Documents à nous transmettre
|
|
20
|
-
</
|
|
17
|
+
</h4>
|
|
21
18
|
<ul
|
|
22
19
|
class="upload-list"
|
|
23
20
|
style="width: 100%;"
|
|
@@ -61,11 +58,20 @@ exports[`UploadWorkflow > render the upload list 1`] = `
|
|
|
61
58
|
text-base
|
|
62
59
|
"></div>
|
|
63
60
|
<!-- v-if -->
|
|
64
|
-
|
|
61
|
+
<div
|
|
62
|
+
class="
|
|
63
|
+
file-item__error-message
|
|
64
|
+
text-error
|
|
65
|
+
"
|
|
66
|
+
role="status"
|
|
67
|
+
>
|
|
68
|
+
<!-- v-if -->
|
|
69
|
+
</div>
|
|
65
70
|
</div>
|
|
66
71
|
</div>
|
|
67
72
|
<div class="file-item__actions">
|
|
68
73
|
<button
|
|
74
|
+
aria-label="Importer le fichier Carte d'identité"
|
|
69
75
|
class="
|
|
70
76
|
file-item__action
|
|
71
77
|
file-item__action-upload
|
|
@@ -168,11 +174,20 @@ exports[`UploadWorkflow > render the upload list 1`] = `
|
|
|
168
174
|
text-base
|
|
169
175
|
"></div>
|
|
170
176
|
<!-- v-if -->
|
|
171
|
-
|
|
177
|
+
<div
|
|
178
|
+
class="
|
|
179
|
+
file-item__error-message
|
|
180
|
+
text-error
|
|
181
|
+
"
|
|
182
|
+
role="status"
|
|
183
|
+
>
|
|
184
|
+
<!-- v-if -->
|
|
185
|
+
</div>
|
|
172
186
|
</div>
|
|
173
187
|
</div>
|
|
174
188
|
<div class="file-item__actions">
|
|
175
189
|
<button
|
|
190
|
+
aria-label="Importer le fichier Facture de soin"
|
|
176
191
|
class="
|
|
177
192
|
file-item__action
|
|
178
193
|
file-item__action-upload
|
|
@@ -242,124 +257,132 @@ exports[`UploadWorkflow > render the upload list 1`] = `
|
|
|
242
257
|
css="true"
|
|
243
258
|
persisted="false"
|
|
244
259
|
>
|
|
245
|
-
<
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
pa-4
|
|
250
|
-
sy-file-upload
|
|
251
|
-
"
|
|
252
|
-
for="file-upload-v-2"
|
|
253
|
-
style="width: 100%;"
|
|
254
|
-
>
|
|
260
|
+
<div class="
|
|
261
|
+
mt-6
|
|
262
|
+
sy-file-upload-wrapper
|
|
263
|
+
">
|
|
255
264
|
<input
|
|
256
265
|
accept=".pdf, .jpg, .jpeg, .png"
|
|
266
|
+
aria-hidden="true"
|
|
257
267
|
class="sy-file-upload-input"
|
|
258
268
|
id="file-upload-v-2"
|
|
269
|
+
tabindex="-1"
|
|
259
270
|
type="file"
|
|
260
271
|
/>
|
|
261
|
-
<
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
272
|
+
<div
|
|
273
|
+
class="
|
|
274
|
+
d-block
|
|
275
|
+
mt-6
|
|
276
|
+
pa-4
|
|
277
|
+
sy-file-upload
|
|
278
|
+
"
|
|
279
|
+
role="button"
|
|
280
|
+
style="width: 100%;"
|
|
281
|
+
tabindex="0"
|
|
282
|
+
title="Téléverser un fichier"
|
|
283
|
+
>
|
|
284
|
+
<span class="sy-file-upload-placeholder">
|
|
285
|
+
<i
|
|
286
|
+
aria-hidden="true"
|
|
287
|
+
class="
|
|
288
|
+
1
|
|
289
|
+
1
|
|
290
|
+
1
|
|
291
|
+
11
|
|
292
|
+
11.1
|
|
293
|
+
11.2
|
|
294
|
+
12
|
|
295
|
+
12.5
|
|
296
|
+
12.63
|
|
297
|
+
12.85Z
|
|
298
|
+
13.78
|
|
299
|
+
13L12
|
|
300
|
+
13L9.4
|
|
301
|
+
14.4L11
|
|
302
|
+
14.4L16
|
|
303
|
+
14.58
|
|
304
|
+
14.93
|
|
305
|
+
15.5
|
|
306
|
+
16.85
|
|
307
|
+
16.96
|
|
308
|
+
17.38
|
|
309
|
+
18.43
|
|
310
|
+
18.5
|
|
311
|
+
18.69
|
|
312
|
+
19
|
|
313
|
+
19
|
|
314
|
+
2.17
|
|
315
|
+
2.61
|
|
316
|
+
20
|
|
317
|
+
20
|
|
318
|
+
20.38
|
|
319
|
+
20.73
|
|
320
|
+
20H13V12.85L14.6
|
|
321
|
+
20H6.5Q4.22
|
|
322
|
+
21.69
|
|
323
|
+
21.86
|
|
324
|
+
23
|
|
325
|
+
23
|
|
326
|
+
23
|
|
327
|
+
3.35
|
|
328
|
+
4
|
|
329
|
+
4
|
|
330
|
+
4
|
|
331
|
+
5.25
|
|
332
|
+
5.43
|
|
333
|
+
5.88
|
|
334
|
+
6.04
|
|
335
|
+
6.85
|
|
336
|
+
7.75
|
|
337
|
+
8.07
|
|
338
|
+
9.15
|
|
339
|
+
9.57
|
|
340
|
+
9.63
|
|
341
|
+
9L8
|
|
342
|
+
M11
|
|
343
|
+
mdi
|
|
344
|
+
notranslate
|
|
345
|
+
text-primary
|
|
346
|
+
v-icon
|
|
347
|
+
v-theme--light
|
|
348
|
+
"
|
|
349
|
+
style="
|
|
350
|
+
font-size: 40px;
|
|
351
|
+
height: 40px;
|
|
352
|
+
width: 40px;
|
|
353
|
+
"
|
|
354
|
+
></i>
|
|
355
|
+
<span class="
|
|
356
|
+
font-weight-medium
|
|
357
|
+
mt-1
|
|
358
|
+
text-black
|
|
359
|
+
">
|
|
360
|
+
<span>
|
|
361
|
+
Déposer votre fichier ici
|
|
362
|
+
</span>
|
|
363
|
+
</span>
|
|
364
|
+
<span class="
|
|
365
|
+
mb-2
|
|
366
|
+
sy-file-upload-caption
|
|
367
|
+
">
|
|
368
|
+
Ou
|
|
369
|
+
</span>
|
|
370
|
+
<span class="
|
|
371
|
+
bg-primary
|
|
372
|
+
sy-file-upload-btn
|
|
373
|
+
text-white
|
|
374
|
+
">
|
|
375
|
+
Choisir un fichier
|
|
376
|
+
</span>
|
|
377
|
+
<span class="
|
|
378
|
+
mt-4
|
|
379
|
+
sy-file-upload-caption
|
|
380
|
+
">
|
|
381
|
+
Taille max. : 10 Mo. Formats acceptés : pdf, jpg, jpeg, png
|
|
339
382
|
</span>
|
|
340
383
|
</span>
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
sy-file-upload-caption
|
|
344
|
-
">
|
|
345
|
-
Ou
|
|
346
|
-
</span>
|
|
347
|
-
<span class="
|
|
348
|
-
bg-primary
|
|
349
|
-
elevation-2
|
|
350
|
-
sy-file-upload-btn
|
|
351
|
-
text-white
|
|
352
|
-
">
|
|
353
|
-
Choisir un fichier
|
|
354
|
-
</span>
|
|
355
|
-
<span class="
|
|
356
|
-
mt-4
|
|
357
|
-
sy-file-upload-caption
|
|
358
|
-
">
|
|
359
|
-
Taille max. : 10 Mo. Formats acceptés : pdf, jpg, jpeg, png
|
|
360
|
-
</span>
|
|
361
|
-
</span>
|
|
362
|
-
</label>
|
|
384
|
+
</div>
|
|
385
|
+
</div>
|
|
363
386
|
</transition-stub>
|
|
364
387
|
<!---->
|
|
365
388
|
<!---->
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
+
import { mdiAccount, mdiCog, mdiShieldAccount } from '@mdi/js'
|
|
2
3
|
import UserMenuBtn from './UserMenuBtn.vue'
|
|
3
4
|
|
|
4
5
|
const meta = {
|
|
@@ -63,7 +64,7 @@ const meta = {
|
|
|
63
64
|
description: 'Liste des éléments du menu utilisateur',
|
|
64
65
|
table: {
|
|
65
66
|
type: {
|
|
66
|
-
summary: '{ text: string, value: string, link?: string, to?: RouteLocationRaw }[]',
|
|
67
|
+
summary: '{ text: string, value: string, link?: string, to?: RouteLocationRaw, icon?: string }[]',
|
|
67
68
|
},
|
|
68
69
|
},
|
|
69
70
|
},
|
|
@@ -143,9 +144,6 @@ type Story = StoryObj<typeof meta>
|
|
|
143
144
|
|
|
144
145
|
export const Default: Story = {
|
|
145
146
|
parameters: {
|
|
146
|
-
a11y: {
|
|
147
|
-
disable: true,
|
|
148
|
-
},
|
|
149
147
|
sourceCode: [
|
|
150
148
|
{
|
|
151
149
|
name: 'Template',
|
|
@@ -197,11 +195,59 @@ export const Default: Story = {
|
|
|
197
195
|
}
|
|
198
196
|
},
|
|
199
197
|
}
|
|
198
|
+
|
|
199
|
+
export const WithIcons: Story = {
|
|
200
|
+
parameters: {
|
|
201
|
+
sourceCode: [
|
|
202
|
+
{
|
|
203
|
+
name: 'Template',
|
|
204
|
+
code: `<template>
|
|
205
|
+
<UserMenuBtn
|
|
206
|
+
v-model="selected"
|
|
207
|
+
:menu-items="menuItems"
|
|
208
|
+
/>
|
|
209
|
+
</template>`,
|
|
210
|
+
},
|
|
211
|
+
{
|
|
212
|
+
name: 'Script',
|
|
213
|
+
code: `<script setup lang="ts">
|
|
214
|
+
import { ref } from 'vue'
|
|
215
|
+
import { mdiAccount, mdiCog, mdiShieldAccount } from '@mdi/js'
|
|
216
|
+
import { UserMenuBtn } from '@cnamts/synapse'
|
|
217
|
+
|
|
218
|
+
const selected = ref(null)
|
|
219
|
+
const menuItems = ref([
|
|
220
|
+
{ text: 'Administration', value: 'Administration', icon: mdiShieldAccount },
|
|
221
|
+
{ text: 'Profil', value: 'Profil', icon: mdiAccount },
|
|
222
|
+
{ text: 'Paramètres', value: 'Paramètres', icon: mdiCog },
|
|
223
|
+
])
|
|
224
|
+
</script>`,
|
|
225
|
+
},
|
|
226
|
+
],
|
|
227
|
+
},
|
|
228
|
+
args: {
|
|
229
|
+
...Default.args,
|
|
230
|
+
menuItems: [
|
|
231
|
+
{ text: 'Administration', value: 'Administration', icon: mdiShieldAccount },
|
|
232
|
+
{ text: 'Profil', value: 'Profil', icon: mdiAccount },
|
|
233
|
+
{ text: 'Paramètres', value: 'Paramètres', icon: mdiCog },
|
|
234
|
+
],
|
|
235
|
+
},
|
|
236
|
+
render: (args) => {
|
|
237
|
+
return {
|
|
238
|
+
components: { UserMenuBtn },
|
|
239
|
+
setup() {
|
|
240
|
+
return { args }
|
|
241
|
+
},
|
|
242
|
+
template: `
|
|
243
|
+
<div class="pa-4">
|
|
244
|
+
<UserMenuBtn v-bind="args"/>
|
|
245
|
+
</div>`,
|
|
246
|
+
}
|
|
247
|
+
},
|
|
248
|
+
}
|
|
200
249
|
export const HideLogoutButton: Story = {
|
|
201
250
|
parameters: {
|
|
202
|
-
a11y: {
|
|
203
|
-
disable: true,
|
|
204
|
-
},
|
|
205
251
|
sourceCode: [
|
|
206
252
|
{
|
|
207
253
|
name: 'Template',
|
|
@@ -251,9 +297,6 @@ export const HideLogoutButton: Story = {
|
|
|
251
297
|
|
|
252
298
|
export const HideUserIcon: Story = {
|
|
253
299
|
parameters: {
|
|
254
|
-
a11y: {
|
|
255
|
-
disable: true,
|
|
256
|
-
},
|
|
257
300
|
sourceCode: [
|
|
258
301
|
{
|
|
259
302
|
name: 'Template',
|
|
@@ -303,9 +346,6 @@ export const HideUserIcon: Story = {
|
|
|
303
346
|
|
|
304
347
|
export const MobileVersion: Story = {
|
|
305
348
|
parameters: {
|
|
306
|
-
a11y: {
|
|
307
|
-
disable: true,
|
|
308
|
-
},
|
|
309
349
|
sourceCode: [
|
|
310
350
|
{
|
|
311
351
|
name: 'Template',
|
|
@@ -355,9 +395,6 @@ export const MobileVersion: Story = {
|
|
|
355
395
|
|
|
356
396
|
export const CustomFullName: Story = {
|
|
357
397
|
parameters: {
|
|
358
|
-
a11y: {
|
|
359
|
-
disable: true,
|
|
360
|
-
},
|
|
361
398
|
sourceCode: [
|
|
362
399
|
{
|
|
363
400
|
name: 'Template',
|
|
@@ -407,9 +444,6 @@ export const CustomFullName: Story = {
|
|
|
407
444
|
|
|
408
445
|
export const CustomLogoutText: Story = {
|
|
409
446
|
parameters: {
|
|
410
|
-
a11y: {
|
|
411
|
-
disable: true,
|
|
412
|
-
},
|
|
413
447
|
sourceCode: [
|
|
414
448
|
{
|
|
415
449
|
name: 'Template',
|
|
@@ -459,9 +493,6 @@ export const CustomLogoutText: Story = {
|
|
|
459
493
|
|
|
460
494
|
export const CustomAdditionalInformation: Story = {
|
|
461
495
|
parameters: {
|
|
462
|
-
a11y: {
|
|
463
|
-
disable: true,
|
|
464
|
-
},
|
|
465
496
|
sourceCode: [
|
|
466
497
|
{
|
|
467
498
|
name: 'Template',
|
|
@@ -511,9 +542,6 @@ export const CustomAdditionalInformation: Story = {
|
|
|
511
542
|
|
|
512
543
|
export const WithVuetifyOptions: Story = {
|
|
513
544
|
parameters: {
|
|
514
|
-
a11y: {
|
|
515
|
-
disable: true,
|
|
516
|
-
},
|
|
517
545
|
sourceCode: [
|
|
518
546
|
{
|
|
519
547
|
name: 'Template',
|
|
@@ -575,9 +603,6 @@ export const WithVuetifyOptions: Story = {
|
|
|
575
603
|
|
|
576
604
|
export const LogoutEvent: Story = {
|
|
577
605
|
parameters: {
|
|
578
|
-
a11y: {
|
|
579
|
-
disable: true,
|
|
580
|
-
},
|
|
581
606
|
sourceCode: [
|
|
582
607
|
{
|
|
583
608
|
name: 'Template',
|
|
@@ -631,9 +656,6 @@ export const LogoutEvent: Story = {
|
|
|
631
656
|
|
|
632
657
|
export const Slot: Story = {
|
|
633
658
|
parameters: {
|
|
634
|
-
a11y: {
|
|
635
|
-
disable: true,
|
|
636
|
-
},
|
|
637
659
|
sourceCode: [
|
|
638
660
|
{
|
|
639
661
|
name: 'Template',
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
import { defaultOptions } from './config'
|
|
9
9
|
import SyIcon from '@/components/Customs/SyIcon/SyIcon.vue'
|
|
10
10
|
|
|
11
|
-
type MenuItem = { text: string, value: string, link?: string, to?: RouteLocationRaw }
|
|
11
|
+
type MenuItem = { text: string, value: string, link?: string, to?: RouteLocationRaw, icon?: string }
|
|
12
12
|
|
|
13
13
|
const props = withDefaults(defineProps<CustomizableOptions & {
|
|
14
14
|
menuItems?: MenuItem[]
|
|
@@ -70,6 +70,9 @@
|
|
|
70
70
|
<VListItem
|
|
71
71
|
v-if="!hideLogoutBtn"
|
|
72
72
|
class="logout"
|
|
73
|
+
tag="li"
|
|
74
|
+
role="menuitem"
|
|
75
|
+
tabindex="0"
|
|
73
76
|
v-bind="options['logoutListItem']"
|
|
74
77
|
@click="$emit('logout')"
|
|
75
78
|
>
|
|
@@ -1,12 +1,76 @@
|
|
|
1
|
-
import { Meta,
|
|
2
|
-
import * as
|
|
1
|
+
import { Meta, Primary } from '@storybook/blocks';
|
|
2
|
+
import * as UserMenuBtnStories from '../UserMenuBtn.stories.ts';
|
|
3
|
+
import AccessibilityIcon from '@/common/imgs/accessibility-svgrepo-com.svg';
|
|
3
4
|
import '@/stories/styles/shared.css';
|
|
5
|
+
import {
|
|
6
|
+
AccessibilityGuideLayout,
|
|
7
|
+
CriteriaSection,
|
|
8
|
+
CriteriaCard,
|
|
9
|
+
DemoSection,
|
|
10
|
+
BestPracticesSection,
|
|
11
|
+
ResourcesSection,
|
|
12
|
+
} from '@/stories/accessibility/AccessibilityGuideLayout.mdx';
|
|
4
13
|
|
|
5
|
-
<Meta of={
|
|
14
|
+
<Meta of={UserMenuBtnStories} />
|
|
6
15
|
|
|
7
|
-
<
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
16
|
+
<AccessibilityGuideLayout
|
|
17
|
+
componentName="UserMenuBtn"
|
|
18
|
+
iconSrc={AccessibilityIcon}
|
|
19
|
+
apgHref="https://www.w3.org/WAI/ARIA/apg/patterns/menu-button/"
|
|
20
|
+
>
|
|
21
|
+
<CriteriaSection>
|
|
22
|
+
<CriteriaCard icon="🔍" title="Structure sémantique">
|
|
23
|
+
<ul>
|
|
24
|
+
<li><strong>Rôles ARIA</strong> : <code>role="menu"</code> pour la liste et <code>role="menuitem"</code> pour chaque option (y compris le bouton de déconnexion).</li>
|
|
25
|
+
<li><strong>Attributs d'association</strong> : <code>aria-labelledby</code> relie le menu au bouton généré, <code>aria-haspopup</code>/<code>aria-expanded</code>/<code>aria-controls</code> sont gérés par <code>VMenu</code>.</li>
|
|
26
|
+
<li><strong>Étiquette accessible</strong> : un texte masqué (<code>label</code>, par défaut « Menu utilisateur ») assure le nom du bouton, même en mode icône seule.</li>
|
|
27
|
+
<li><strong>Suivi de l'item actif</strong> : <code>aria-activedescendant</code> pointe vers l'option active via un identifiant slugifié.</li>
|
|
28
|
+
</ul>
|
|
29
|
+
</CriteriaCard>
|
|
11
30
|
|
|
12
|
-
<
|
|
31
|
+
<CriteriaCard icon="⌨️" title="Navigation clavier complète">
|
|
32
|
+
<ul>
|
|
33
|
+
<li><strong>Tabulation</strong> : accès au bouton puis parcours des options.</li>
|
|
34
|
+
<li><strong>Entrée/Espace</strong> : ouverture du menu et activation d'une option.</li>
|
|
35
|
+
<li><strong>Flèches</strong> : navigation verticale entre les éléments du menu.</li>
|
|
36
|
+
<li><strong>Échap</strong> : fermeture du menu et restitution du focus sur le bouton.</li>
|
|
37
|
+
</ul>
|
|
38
|
+
</CriteriaCard>
|
|
39
|
+
|
|
40
|
+
<CriteriaCard icon="🎯" title="Gestion du focus & retours">
|
|
41
|
+
<ul>
|
|
42
|
+
<li>Focus placé sur la première option à l'ouverture, puis renvoyé vers le bouton à la fermeture.</li>
|
|
43
|
+
<li><code>aria-expanded</code> reflète l'état d'ouverture ; <code>aria-current="page"</code> sur l'élément sélectionné.</li>
|
|
44
|
+
<li>Styles <code>:focus-visible</code> renforcés sur le bouton et les éléments du menu pour une indication claire.</li>
|
|
45
|
+
</ul>
|
|
46
|
+
</CriteriaCard>
|
|
47
|
+
|
|
48
|
+
<CriteriaCard icon="📱" title="Compatibilité mobile & personnalisation">
|
|
49
|
+
<ul>
|
|
50
|
+
<li>Modes <code>isMobileView</code> et <code>iconOnly</code> compactent l'affichage tout en conservant un libellé pour les lecteurs d'écran.</li>
|
|
51
|
+
<li>Options <code>menu</code> / <code>btn</code> / <code>list</code> personnalisables sans dégrader les attributs ARIA.</li>
|
|
52
|
+
<li>Le bouton de déconnexion optionnel (<code>hideLogoutBtn</code>) reste exposé comme élément de menu clavier/navigateur.</li>
|
|
53
|
+
</ul>
|
|
54
|
+
</CriteriaCard>
|
|
55
|
+
</CriteriaSection>
|
|
56
|
+
|
|
57
|
+
<DemoSection componentName="UserMenuBtn">
|
|
58
|
+
<Primary />
|
|
59
|
+
</DemoSection>
|
|
60
|
+
|
|
61
|
+
<BestPracticesSection>
|
|
62
|
+
<ul>
|
|
63
|
+
<li>Fournir un libellé clair pour <code>label</code> (ex. « Menu utilisateur », « Compte de Marie »), surtout en mode icône seule.</li>
|
|
64
|
+
<li>Limiter le nombre d'options et placer les actions destructives ou sensibles (ex. déconnexion) en fin de liste.</li>
|
|
65
|
+
<li>Utiliser des intitulés explicites pour les éléments du menu ; éviter les abréviations ou les seules icônes.</li>
|
|
66
|
+
<li>Vérifier le focus visible et le contraste des états actifs/sélectionnés, notamment sur fond personnalisé.</li>
|
|
67
|
+
</ul>
|
|
68
|
+
</BestPracticesSection>
|
|
69
|
+
|
|
70
|
+
<ResourcesSection>
|
|
71
|
+
<ul>
|
|
72
|
+
<li><a href="https://www.w3.org/WAI/ARIA/apg/patterns/menu-button/" target="_blank" rel="noopener noreferrer">WAI-ARIA Authoring Practices : Menu button</a></li>
|
|
73
|
+
<li><a href="https://inclusive-components.design/menus-menu-buttons/" target="_blank" rel="noopener noreferrer">Inclusive Components : Menus & Menu Buttons</a></li>
|
|
74
|
+
</ul>
|
|
75
|
+
</ResourcesSection>
|
|
76
|
+
</AccessibilityGuideLayout>
|
package/src/components/index.ts
CHANGED
|
@@ -12,6 +12,7 @@ export { default as HeaderMenuBtn } from './HeaderBar/HeaderMenuBtn/HeaderMenuBt
|
|
|
12
12
|
export { default as HeaderLoading } from './HeaderLoading/HeaderLoading.vue'
|
|
13
13
|
export { default as HeaderToolbar } from './HeaderToolbar/HeaderToolbar.vue'
|
|
14
14
|
export { default as SubHeader } from './SubHeader/SubHeader.vue'
|
|
15
|
+
export { default as SyHeading } from './SyHeading/SyHeading.vue'
|
|
15
16
|
|
|
16
17
|
// ===========================
|
|
17
18
|
// Layout
|
package/src/components/types.ts
CHANGED
|
@@ -8,3 +8,7 @@ export type NavigationProps =
|
|
|
8
8
|
| { href: string, to?: never }
|
|
9
9
|
| { to: RouteLocationRaw, href?: never }
|
|
10
10
|
| { href?: never, to?: never }
|
|
11
|
+
|
|
12
|
+
// Type pour les rôles ARIA utilisés dans les composants
|
|
13
|
+
export type AriaRole = 'main' | 'region' | 'navigation' | 'contentinfo' | 'banner'
|
|
14
|
+
export type PageAriaRole = 'main' | 'region'
|