@cnamts/synapse 1.0.23 → 1.0.25
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/README.md +27 -5
- package/dist/AutocompleteFilter-D7qBuCAP.js +114 -0
- package/dist/AutocompleteFilter-Df9i5mAl.cjs +1 -0
- package/dist/DateFilter-BJD6FMev.cjs +1 -0
- package/dist/{DateFilter-Dc-gSGwk.js → DateFilter-BitMWrMU.js} +1 -1
- package/dist/{NumberFilter-vP38Wp6j.js → NumberFilter-BTLUxw0a.js} +3 -3
- package/dist/NumberFilter-DGCzCXzI.cjs +1 -0
- package/dist/{PeriodFilter-Ba1uYUnT.js → PeriodFilter-B5rUIPAC.js} +1 -1
- package/dist/PeriodFilter-DO_ecTZW.cjs +1 -0
- package/dist/SelectFilter-CGwcKWLm.cjs +1 -0
- package/dist/SelectFilter-l4QnRcuk.js +135 -0
- package/dist/TextFilter-B8nf7xoK.cjs +1 -0
- package/dist/{TextFilter-B84dpnoq.js → TextFilter-C9hj6Qrp.js} +7 -7
- package/dist/apLightTheme-CEK4iY3f.cjs +1 -0
- package/dist/apLightTheme-DnIM24Lv.js +950 -0
- package/dist/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.d.ts +7022 -9616
- package/dist/components/Amelipro/AmeliproCarousel/AmeliproCarousel.d.ts +2 -2
- package/dist/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.d.ts +2 -2
- package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/AmeliproPostalAddressCityRow.d.ts +40 -40
- package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.d.ts +60 -60
- package/dist/components/Amelipro/AmeliproSelect/AmeliproSelect.d.ts +7168 -9762
- package/dist/components/Amelipro/AmeliproStepper/AmeliproStepper.d.ts +2 -2
- package/dist/components/Amelipro/AmeliproTabs/AmeliproTabs.d.ts +7501 -10095
- package/dist/components/Amelipro/AmeliproTextArea/AmeliproTextArea.d.ts +21 -21
- package/dist/components/Amelipro/AmeliproTextField/AmeliproTextField.d.ts +41 -41
- package/dist/components/Amelipro/StructureMenu/StructureTabs/StructureTabs.d.ts +2 -2
- package/dist/components/CookiesSelection/CookiesInformation/CookiesInformation.d.ts +20 -498
- package/dist/components/Customs/Selects/SyAutocomplete/SyAutocomplete.d.ts +117 -151
- package/dist/components/Customs/Selects/SyInputSelect/SyInputSelect.d.ts +5 -5
- package/dist/components/Customs/Selects/SySelect/SySelect.d.ts +12 -16
- package/dist/components/Customs/SyCheckBoxGroup/SyCheckBoxGroup.d.ts +8 -8
- package/dist/components/Customs/SyCheckbox/SyCheckbox.d.ts +31 -506
- package/dist/components/Customs/SyRadioGroup/SyRadioGroup.d.ts +28 -506
- package/dist/components/Customs/SyTabs/SyTabs.d.ts +13 -11
- package/dist/components/Customs/SyTextField/SyTextField.d.ts +69 -89
- package/dist/components/DatePicker/CalendarMode/DatePicker.d.ts +627 -791
- package/dist/components/DatePicker/ComplexDatePicker/ComplexDatePicker.d.ts +315 -412
- package/dist/components/DatePicker/DateTextInput/DateTextInput.d.ts +112 -160
- package/dist/components/DatePicker/composables/index.d.ts +1 -0
- package/dist/components/DatePicker/composables/useDatePickerFocusTrap.d.ts +11 -0
- package/dist/components/DatePicker/composables/useDatePickerState.d.ts +1 -0
- package/dist/components/DatePicker/composables/useDateTextField.d.ts +4 -4
- package/dist/components/DatePicker/composables/useDateValidation.d.ts +3 -3
- package/dist/components/DatePicker/composables/useInputBlurHandler.d.ts +2 -2
- package/dist/components/DatePicker/composables/useManualDateValidation.d.ts +2 -2
- package/dist/components/FileList/FileList.d.ts +6 -0
- package/dist/components/FilterSideBar/FilterSideBar.d.ts +2 -0
- package/dist/components/HeaderNavigationBar/HeaderNavigationBar.d.ts +17 -17
- package/dist/components/HeaderNavigationBar/HorizontalNavbar/HorizontalNavbar.d.ts +3 -3
- package/dist/components/HeaderToolbar/HeaderToolbar.d.ts +20 -28
- package/dist/components/LunarCalendar/useLunarCalendarValidation.d.ts +3 -3
- package/dist/components/MonthPicker/MonthPicker.d.ts +86 -127
- package/dist/components/MonthPicker/MonthPickerText/MonthPickerInput.d.ts +85 -126
- package/dist/components/NirField/NirField.d.ts +202 -278
- package/dist/components/NirField/locales.d.ts +10 -10
- package/dist/components/NirField/useNirValidation.d.ts +64 -0
- package/dist/components/PasswordField/PasswordField.d.ts +8 -9
- package/dist/components/PeriodField/PeriodField.d.ts +1352 -1680
- package/dist/components/PhoneField/PhoneField.d.ts +88 -129
- package/dist/components/RangeField/RangeSlider/RangeSlider.d.ts +12 -12
- package/dist/components/SyTextArea/SyTextArea.d.ts +34 -14
- package/dist/components/SyTextArea/useDefaultValidationRules.d.ts +11 -0
- package/dist/components/Tables/SyServerTable/SyServerTable.d.ts +10 -6
- package/dist/components/Tables/SyTable/SyTable.d.ts +10 -6
- package/dist/components/Tables/common/SyTableFilter.d.ts +2 -3
- package/dist/components/Tables/common/SyTablePagination.d.ts +19 -19
- package/dist/components/Tables/common/TableHeader.d.ts +5 -0
- package/dist/components/Tables/common/filters/AutocompleteFilter.d.ts +120 -0
- package/dist/components/Tables/common/filters/locales.d.ts +0 -1
- package/dist/components/Tables/common/locales.d.ts +3 -0
- package/dist/components/Tables/common/types.d.ts +21 -3
- package/dist/components/Tables/common/useClickableTableRow.d.ts +17 -0
- package/dist/components/Tables/common/usePagination.d.ts +3 -1
- package/dist/components/Tables/common/usePinnedColumns.d.ts +31 -0
- package/dist/components/Tables/common/useTableHeaders.d.ts +2 -0
- package/dist/components/Tables/common/useTableRowCheckboxAccessibility.d.ts +5 -0
- package/dist/components/UploadWorkflow/UploadWorkflow.d.ts +7 -6
- package/dist/composables/date/useDatePickerAccessibility.d.ts +1 -1
- package/dist/composables/rules/useFieldValidation.d.ts +4 -4
- package/dist/composables/unifyValidation/documentationValidationProps.d.ts +230 -0
- package/dist/composables/unifyValidation/useCustomValidation.d.ts +8 -0
- package/dist/composables/unifyValidation/useValidation.d.ts +102 -0
- package/dist/composables/unifyValidation/useVuetifyValidation.d.ts +18 -0
- package/dist/composables/useFormFieldErrorHandling.d.ts +2 -2
- package/dist/composables/validation/useFormValidation.d.ts +11 -2
- package/dist/composables/validation/useValidation.d.ts +19 -9
- package/dist/design-system-v3.d.ts +2 -0
- package/dist/design-system-v3.js +186 -187
- package/dist/design-system-v3.umd.cjs +1 -1066
- package/dist/designTokens/tokens/amelipro/apColors.d.ts +10 -10
- package/dist/designTokens/tokens/amelipro/apColors2026.d.ts +1 -2
- package/dist/designTokens/tokens/amelipro/apContextual.d.ts +44 -0
- package/dist/designTokens/tokens/amelipro/apSemantic.d.ts +1 -1
- package/dist/designTokens/tokens/baseColors.d.ts +127 -0
- package/dist/designTokens/tokens/baseContextualTokens.d.ts +50 -0
- package/dist/designTokens/tokens/cnam/cnamColors.d.ts +10 -10
- package/dist/designTokens/tokens/cnam/cnamSemantic.d.ts +1 -1
- package/dist/designTokens/tokens/pa/paColors.d.ts +1 -166
- package/dist/designTokens/tokens/pa/paSemantic.d.ts +1 -1
- package/dist/designTokens/utils/buildColorClassMap.d.ts +12 -0
- package/dist/designTokens/utils/createFlattenTheme.d.ts +1 -3
- package/dist/designTokens/utils/index.d.ts +2 -2
- package/dist/main-ByDPHpae.cjs +1067 -0
- package/dist/main-Cpx8Co6H.js +38869 -0
- package/dist/main.d.ts +0 -1
- package/dist/synapse.css +1 -0
- package/dist/tooth-11-D3sLWv2n.cjs +1 -0
- package/dist/tooth-12-CXrLuH03.cjs +1 -0
- package/dist/tooth-13-BSfo5fpT.cjs +1 -0
- package/dist/tooth-14-DMzulx0h.cjs +1 -0
- package/dist/tooth-15-BKRFVi-9.cjs +1 -0
- package/dist/tooth-16-CpuxAbuM.cjs +1 -0
- package/dist/tooth-17-BPoahUdg.cjs +1 -0
- package/dist/tooth-18-DhHJz8sy.cjs +1 -0
- package/dist/tooth-21-Dgd5hn_X.cjs +1 -0
- package/dist/tooth-22-C2Tn19sB.cjs +1 -0
- package/dist/tooth-23-C9uaaSGb.cjs +1 -0
- package/dist/tooth-24-BrK9UGpf.cjs +1 -0
- package/dist/tooth-25-CE_EfGNp.cjs +1 -0
- package/dist/tooth-26-Ctv4i9Fy.cjs +1 -0
- package/dist/tooth-27-C5J7JkWM.cjs +1 -0
- package/dist/tooth-28-Z9oWqjo0.cjs +1 -0
- package/dist/tooth-31-BrYqmkTi.cjs +1 -0
- package/dist/tooth-32-BNNR0oCZ.cjs +1 -0
- package/dist/tooth-33-DuxvqO2J.cjs +1 -0
- package/dist/tooth-34-BCSCXMB6.cjs +1 -0
- package/dist/tooth-35-BLUXkX88.cjs +1 -0
- package/dist/tooth-36-IrKHYqlA.cjs +1 -0
- package/dist/tooth-37-BYqpdMwo.cjs +1 -0
- package/dist/tooth-38-B_eNXXdu.cjs +1 -0
- package/dist/tooth-41-Ddva4Ot8.cjs +1 -0
- package/dist/tooth-42-szcDqlM0.cjs +1 -0
- package/dist/tooth-43-B3ka6rQm.cjs +1 -0
- package/dist/tooth-44-CazyQucj.cjs +1 -0
- package/dist/tooth-45-B4HQtc8n.cjs +1 -0
- package/dist/tooth-46-BPM40gbG.cjs +1 -0
- package/dist/tooth-47-Dvr20dlh.cjs +1 -0
- package/dist/tooth-48-Bd8ljGsF.cjs +1 -0
- package/dist/tooth-51-OBpwCOF3.cjs +1 -0
- package/dist/tooth-52-aKxyHcmq.cjs +1 -0
- package/dist/tooth-53-vCwJjTOc.cjs +1 -0
- package/dist/tooth-54-DsWu2iFy.cjs +1 -0
- package/dist/tooth-55-BxC1X2Dn.cjs +1 -0
- package/dist/tooth-61-BbLvxMQi.cjs +1 -0
- package/dist/tooth-62-CmTkWczP.cjs +1 -0
- package/dist/tooth-63-DI7l_2qI.cjs +1 -0
- package/dist/tooth-64-B21sOsJh.cjs +1 -0
- package/dist/tooth-65-D2ZC2VEr.cjs +1 -0
- package/dist/tooth-71-D473PPO5.cjs +1 -0
- package/dist/tooth-72-Drh1wnNu.cjs +1 -0
- package/dist/tooth-73-DzlwYI23.cjs +1 -0
- package/dist/tooth-74-8aGvcZPg.cjs +1 -0
- package/dist/tooth-75-BFK7At_r.cjs +1 -0
- package/dist/tooth-81-BZmR-I0M.cjs +1 -0
- package/dist/tooth-82-euVfUUZV.cjs +1 -0
- package/dist/tooth-83-KV010j64.cjs +1 -0
- package/dist/tooth-84-BBg1RjhZ.cjs +1 -0
- package/dist/tooth-85-Cr-kc1wM.cjs +1 -0
- package/dist/utils/functions/classToHex.d.ts +1 -1
- package/dist/utils/functions/createHexResolver.d.ts +16 -0
- package/dist/vuetifyConfig.js +522 -0
- package/dist/vuetifyConfig.umd.cjs +1 -0
- package/package.json +37 -20
- package/src/assets/amelipro/apTokens2026.scss +5 -5
- package/src/assets/overrides/_breakpoints.scss +25 -0
- package/src/assets/overrides/_btns.scss +0 -8
- package/src/assets/overrides/_forms.scss +1 -3
- package/src/assets/overrides/_icons.scss +14 -10
- package/src/assets/overrides/_otp.scss +41 -0
- package/src/assets/overrides/_tables.scss +11 -20
- package/src/assets/overrides/_tooltips.scss +17 -7
- package/src/assets/overrides/_typography.scss +35 -47
- package/src/assets/overrides/_utilities.scss +43 -47
- package/src/assets/themes.scss +1 -0
- package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/AmeliproAccordionTemplate.vue +20 -20
- package/src/components/Amelipro/AmeliproAccordionFrieze/AmeliproAccordionFrieze.vue +12 -14
- package/src/components/Amelipro/AmeliproAccordionList/AmeliproAccordionList.vue +4 -6
- package/src/components/Amelipro/AmeliproAccordionResult/AmeliproAccordionResultTemplate/AmeliproAccordionResultTemplate.vue +5 -5
- package/src/components/Amelipro/AmeliproAccordionResultList/AmeliproAccordionResultList.vue +4 -6
- package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.vue +4 -6
- package/src/components/Amelipro/AmeliproAutoCompleteField/__tests__/__snapshots__/AmeliproAutoCompleteField.spec.ts.snap +2 -2
- package/src/components/Amelipro/AmeliproBadge/AmeliproBadge.vue +4 -6
- package/src/components/Amelipro/AmeliproBreadcrumb/AmeliproBreadcrumb.vue +1 -3
- package/src/components/Amelipro/AmeliproBtn/AmeliproBtn.vue +4 -6
- package/src/components/Amelipro/AmeliproCallback/AmeliproCallback.vue +2 -2
- package/src/components/Amelipro/AmeliproCard/AmeliproCard.vue +31 -31
- package/src/components/Amelipro/AmeliproCarousel/AmeliproCarousel.vue +5 -7
- package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.vue +13 -15
- package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.vue +23 -23
- package/src/components/Amelipro/AmeliproChips/AmeliproChips.vue +1 -3
- package/src/components/Amelipro/AmeliproClickableTile/AmeliproClickableTile.vue +17 -12
- package/src/components/Amelipro/AmeliproClickableTile/tests/__snapshots__/AmeliproClickableTile.spec.ts.snap +2 -2
- package/src/components/Amelipro/AmeliproCopyBtn/AmeliproCopyBtn.vue +4 -6
- package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.vue +13 -13
- package/src/components/Amelipro/AmeliproDentalChart/AmeliproDentalChart.vue +4 -2
- package/src/components/Amelipro/AmeliproDentalChart/AmeliproTooth/AmeliproTooth.vue +4 -4
- package/src/components/Amelipro/AmeliproDialog/AmeliproDialog.vue +5 -7
- package/src/components/Amelipro/AmeliproDisclosure/AmeliproDisclosure.vue +1 -3
- package/src/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.vue +2 -4
- package/src/components/Amelipro/AmeliproFilePreview/AmeliproFilePreview.vue +4 -6
- package/src/components/Amelipro/AmeliproFilters/AmeliproFilters.vue +13 -13
- package/src/components/Amelipro/AmeliproFirstLogin/AmeliproFirstLogin.vue +3 -5
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.vue +1 -3
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeader.vue +2 -4
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBar.vue +1 -3
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/AmeliproHeaderBrandSection.vue +20 -16
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/__tests__/__snapshots__/AmeliproHeaderBrandSection.spec.ts.snap +2 -2
- package/src/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.vue +2 -4
- package/src/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.vue +5 -7
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.vue +6 -8
- package/src/components/Amelipro/AmeliproMailTile/AmeliproMailTile.vue +14 -14
- package/src/components/Amelipro/AmeliproMenu/AmeliproMenu.vue +11 -13
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/AmeliproDropdownMenu.vue +2 -4
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingLayout.vue +8 -8
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.vue +40 -40
- package/src/components/Amelipro/AmeliproNumberedCard/AmeliproNumberedCard.vue +27 -27
- package/src/components/Amelipro/AmeliproOnboarding/AmeliproOnboarding.vue +3 -5
- package/src/components/Amelipro/AmeliproPageLayout/AmeliproPageLayout.vue +2 -4
- package/src/components/Amelipro/AmeliproPagination/AmeliproPagination.vue +2 -4
- package/src/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/AmeliproPaginationBtn.vue +3 -5
- package/src/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.vue +1 -3
- package/src/components/Amelipro/AmeliproPatientLogged/AmeliproPatientLogged.vue +2 -4
- package/src/components/Amelipro/AmeliproPatientLogin/AmeliproPatientLogin.vue +4 -4
- package/src/components/Amelipro/AmeliproPatientLogin/AmeliproPatientLoginForm/AmeliproPatientLoginForm.vue +1 -3
- package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/AmeliproPostalAddressCityRow.vue +3 -5
- package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.vue +3 -5
- package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.vue +23 -23
- package/src/components/Amelipro/AmeliproResultList/AmeliproResultList.vue +4 -6
- package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.vue +12 -22
- package/src/components/Amelipro/AmeliproStateTile/AmeliproStateTile.vue +10 -12
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepper.vue +17 -17
- package/src/components/Amelipro/AmeliproTable/AmeliproTable.vue +8 -10
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabBtn/AmeliproTabBtn.vue +6 -8
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabs.vue +4 -4
- package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.vue +4 -6
- package/src/components/Amelipro/AmeliproTextArea/__tests__/__snapshots__/AmeliproTextArea.spec.ts.snap +2 -2
- package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.vue +7 -9
- package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.vue +3 -5
- package/src/components/Amelipro/AmeliproTooltips/AmeliproTooltips.vue +0 -2
- package/src/components/Amelipro/AmeliproUpload/AmeliproUpload.vue +6 -6
- package/src/components/Amelipro/ServiceMenu/ServiceMenu.vue +2 -2
- package/src/components/Amelipro/StructureMenu/StructureBtn/StructureBtn.vue +4 -4
- package/src/components/Amelipro/StructureMenu/StructureItem/StructureItem.vue +4 -6
- package/src/components/Amelipro/StructureMenu/StructureMenu.vue +2 -2
- package/src/components/Amelipro/StructureMenu/StructureTabs/StructureTabs.vue +2 -2
- package/src/components/Amelipro/UserMenu/UserMenu.vue +1 -3
- package/src/components/BackBtn/tests/BackBtn.visual.cy.ts +43 -0
- package/src/components/BackBtn/tests/__snapshots__/back-btn-custom-bg.snap.png +0 -0
- package/src/components/BackBtn/tests/__snapshots__/back-btn-dark-mode.snap.png +0 -0
- package/src/components/BackBtn/tests/__snapshots__/back-btn-default.snap.png +0 -0
- package/src/components/BackBtn/tests/__snapshots__/back-btn-no-icon.snap.png +0 -0
- package/src/components/Captcha/Captcha.vue +1 -3
- package/src/components/Captcha/accessibilite/Accessibility.mdx +86 -8
- package/src/components/Captcha/tests/__snapshots__/Captcha.spec.ts.snap +12 -12
- package/src/components/ChipList/ChipList.stories.ts +0 -15
- package/src/components/ChipList/ChipList.vue +19 -17
- package/src/components/ChipList/accessibilite/Accessibility.mdx +83 -10
- package/src/components/ChipList/tests/ChipList.a11y.spec.ts +41 -0
- package/src/components/CookiesSelection/CookiesInformation/CookiesInformation.vue +0 -2
- package/src/components/CopyBtn/CopyBtn.vue +1 -3
- package/src/components/Customs/Selects/SelectBtnField/SelectBtnField.vue +17 -17
- package/src/components/Customs/Selects/SelectBtnField/accessibilite/Accessibility.mdx +0 -9
- package/src/components/Customs/Selects/SelectBtnField/tests/SelectBtnField.spec.ts +31 -0
- package/src/components/Customs/Selects/SyAutocomplete/SyAutocomplete.stories.ts +66 -0
- package/src/components/Customs/Selects/SyAutocomplete/SyAutocomplete.vue +28 -7
- package/src/components/Customs/Selects/SyAutocomplete/tests/SyAutocomplete.a11y.spec.ts +18 -0
- package/src/components/Customs/Selects/SyAutocomplete/tests/SyAutocomplete.spec.ts +209 -0
- package/src/components/Customs/Selects/SyAutocomplete/utils/ariaManager.ts +14 -10
- package/src/components/Customs/Selects/SyInputSelect/SyInputSelect.stories.ts +4 -4
- package/src/components/Customs/Selects/SyInputSelect/SyInputSelect.vue +12 -15
- package/src/components/Customs/Selects/SyInputSelect/tests/SyInputSelect.spec.ts +10 -10
- package/src/components/Customs/Selects/SySelect/SySelect.stories.ts +1 -39
- package/src/components/Customs/Selects/SySelect/SySelect.vue +274 -71
- package/src/components/Customs/Selects/SySelect/accessibilite/Accessibility.mdx +199 -269
- package/src/components/Customs/Selects/SySelect/tests/SySelect.spec.ts +89 -0
- package/src/components/Customs/SyCheckBoxGroup/SyCheckBoxGroup.vue +6 -9
- package/src/components/Customs/SyCheckbox/SyCheckbox.mdx +5 -0
- package/src/components/Customs/SyCheckbox/SyCheckbox.stories.ts +10 -16
- package/src/components/Customs/SyCheckbox/SyCheckbox.vue +45 -11
- package/src/components/Customs/SyCheckbox/accessibilite/Accessibility.mdx +53 -3
- package/src/components/Customs/SyCheckbox/tests/SyCheckbox.a11y.spec.ts +134 -2
- package/src/components/Customs/SyForm/SyForm.stories.ts +31 -5
- package/src/components/Customs/SyPagination/SyPagination.vue +0 -2
- package/src/components/Customs/SyRadioGroup/SyRadioGroup.vue +4 -7
- package/src/components/Customs/SyTabs/SyTabs.mdx +0 -58
- package/src/components/Customs/SyTabs/SyTabs.stories.ts +32 -33
- package/src/components/Customs/SyTabs/SyTabs.vue +87 -67
- package/src/components/Customs/SyTabs/accessibilite/Accessibility.mdx +83 -23
- package/src/components/Customs/SyTabs/tests/SyTabs.a11y.spec.ts +88 -0
- package/src/components/Customs/SyTabs/tests/SyTabs.spec.ts +46 -1
- package/src/components/Customs/SyTextField/SyTextField.mdx +1 -1
- package/src/components/Customs/SyTextField/SyTextField.stories.ts +50 -68
- package/src/components/Customs/SyTextField/SyTextField.vue +156 -161
- package/src/components/Customs/SyTextField/tests/SyTextField.a11y.spec.ts +32 -0
- package/src/components/Customs/SyTextField/tests/SyTextField.spec.ts +120 -11
- package/src/components/DatePicker/CalendarMode/DatePicker.stories.ts +62 -58
- package/src/components/DatePicker/CalendarMode/DatePicker.vue +342 -237
- package/src/components/DatePicker/CalendarMode/accessibilite/Accessibility.mdx +82 -0
- package/src/components/DatePicker/CalendarMode/tests/DatePicker.a11y.spec.ts +141 -0
- package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.stories.ts +2 -56
- package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.vue +215 -175
- package/src/components/DatePicker/ComplexDatePicker/accessibilite/Accessibility.mdx +76 -0
- package/src/components/DatePicker/ComplexDatePicker/tests/ComplexDatePicker.spec.ts +33 -10
- package/src/components/DatePicker/DatePickerValidationExample/CalendarMode.stories.ts +8 -8
- package/src/components/DatePicker/DatePickerValidationExample/ComplexDatePicker.stories.ts +106 -8
- package/src/components/DatePicker/DatePickerValidationExample/DateTextInput.stories.ts +12 -11
- package/src/components/DatePicker/DatePickerValidationExample/MultiMode.stories.ts +12 -12
- package/src/components/DatePicker/DateTextInput/DateRange.stories.ts +0 -12
- package/src/components/DatePicker/DateTextInput/DateTextInput.vue +71 -67
- package/src/components/DatePicker/DateTextInput/NoCalendar.stories.ts +3 -0
- package/src/components/DatePicker/DateTextInput/accessibilite/Accessibility.mdx +66 -0
- package/src/components/DatePicker/DateTextInput/tests/DateTextInput.spec.ts +52 -1
- package/src/components/DatePicker/composables/index.ts +1 -0
- package/src/components/DatePicker/composables/tests/useCalendarKeyboardNavigation.spec.ts +109 -65
- package/src/components/DatePicker/composables/tests/useDatePickerFocusTrap.spec.ts +138 -0
- package/src/components/DatePicker/composables/tests/useDatePickerState.spec.ts +53 -0
- package/src/components/DatePicker/composables/tests/useDateValidation.spec.ts +74 -18
- package/src/components/DatePicker/composables/tests/useInputBlurHandler.spec.ts +39 -0
- package/src/components/DatePicker/composables/tests/useManualDateValidation.spec.ts +91 -0
- package/src/components/DatePicker/composables/useCalendarKeyboardNavigation.ts +442 -36
- package/src/components/DatePicker/composables/useDatePickerFocusTrap.ts +92 -0
- package/src/components/DatePicker/composables/useDatePickerState.ts +24 -0
- package/src/components/DatePicker/composables/useDateTextField.ts +6 -6
- package/src/components/DatePicker/composables/useDateValidation.ts +36 -35
- package/src/components/DatePicker/composables/useInputBlurHandler.ts +3 -3
- package/src/components/DatePicker/composables/useManualDateValidation.ts +6 -2
- package/src/components/DatePicker/composables/useMonthButtonCustomization.ts +9 -8
- package/src/components/DatePicker/playground/DatePickerHolidayRule.vue +1 -1
- package/src/components/DiacriticPicker/accessibilite/Accessibility.mdx +76 -8
- package/src/components/DialogBox/DialogBox.vue +3 -5
- package/src/components/DialogBox/tests/DialogBox.visual.cy.ts +76 -0
- package/src/components/DialogBox/tests/__snapshots__/dialog-box-custom-texts.snap.png +0 -0
- package/src/components/DialogBox/tests/__snapshots__/dialog-box-default.snap.png +0 -0
- package/src/components/DialogBox/tests/__snapshots__/dialog-box-no-actions.snap.png +0 -0
- package/src/components/FileList/FileList.vue +9 -2
- package/src/components/FileList/UploadItem/UploadItem.vue +11 -13
- package/src/components/FileList/tests/FileList.spec.ts +47 -0
- package/src/components/FileUpload/FileUpload.vue +3 -5
- package/src/components/FileUpload/FileUploadContent.vue +3 -5
- package/src/components/FilterInline/FilterInline.vue +1 -3
- package/src/components/FilterSideBar/FilterSideBar.mdx +44 -1
- package/src/components/FilterSideBar/FilterSideBar.stories.ts +105 -1
- package/src/components/FilterSideBar/FilterSideBar.vue +7 -0
- package/src/components/FilterSideBar/tests/FilterSideBar.a11y.spec.ts +54 -1
- package/src/components/FilterSideBar/tests/FilterSideBar.spec.ts +42 -0
- package/src/components/FooterBar/FooterBar.vue +9 -13
- package/src/components/FranceConnectBtn/FranceConnectBtn.vue +1 -1
- package/src/components/HeaderBar/HeaderBar.stories.ts +14 -2
- package/src/components/HeaderBar/HeaderBar.vue +2 -3
- package/src/components/HeaderBar/HeaderBurgerMenu/HeaderBurgerMenu.vue +2 -3
- package/src/components/HeaderBar/HeaderBurgerMenu/HeaderMenuItem/HeaderMenuItem.vue +2 -3
- package/src/components/HeaderBar/HeaderBurgerMenu/HeaderMenuSection/HeaderMenuSection.vue +0 -1
- package/src/components/HeaderBar/HeaderBurgerMenu/HeaderSubMenu/HeaderSubMenu.vue +8 -9
- package/src/components/HeaderBar/HeaderBurgerMenu/menu.scss +0 -8
- package/src/components/HeaderBar/HeaderBurgerMenu/tests/HeaderBurgerMenu.visual.cy.ts +196 -0
- package/src/components/HeaderBar/HeaderBurgerMenu/tests/__snapshots__/header-burger-menu-generated-submenu-open.snap.png +0 -0
- package/src/components/HeaderBar/HeaderBurgerMenu/tests/__snapshots__/header-burger-menu-generated.snap.png +0 -0
- package/src/components/HeaderBar/HeaderLogo/HeaderLogo.vue +0 -1
- package/src/components/HeaderBar/HeaderMenuBtn/HeaderMenuBtn.vue +6 -7
- package/src/components/HeaderBar/tests/HeaderBar.visual.cy.ts +81 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-custom-width.snap.png +0 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-default.snap.png +0 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-no-sticky.snap.png +0 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-with-prepend.snap.png +0 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-with-side.snap.png +0 -0
- package/src/components/HeaderBar/tests/__snapshots__/header-bar-with-subtitle.snap.png +0 -0
- package/src/components/HeaderNavigationBar/HeaderNavigationBar.vue +12 -3
- package/src/components/HeaderNavigationBar/HorizontalNavbar/HorizontalNavbar.vue +15 -8
- package/src/components/HeaderToolbar/HeaderToolbar.vue +6 -7
- package/src/components/LangBtn/LangBtn.vue +2 -4
- package/src/components/Logo/accessibilite/Accessibility.mdx +73 -11
- package/src/components/Logo/tests/Logo.visual.cy.ts +57 -0
- package/src/components/Logo/tests/__snapshots__/logo-avatar.snap.png +0 -0
- package/src/components/Logo/tests/__snapshots__/logo-dark.snap.png +0 -0
- package/src/components/Logo/tests/__snapshots__/logo-default.snap.png +0 -0
- package/src/components/Logo/tests/__snapshots__/logo-no-organism.snap.png +0 -0
- package/src/components/Logo/tests/__snapshots__/logo-no-signature.snap.png +0 -0
- package/src/components/Logo/tests/__snapshots__/logo-risque-pro.snap.png +0 -0
- package/src/components/LogoBrandSection/LogoBrandSection.vue +2 -2
- package/src/components/LogoBrandSection/accessibilite/Accessibility.mdx +85 -9
- package/src/components/LunarCalendar/tests/LunarCalendar.spec.ts +3 -1
- package/src/components/LunarCalendar/useLunarCalendarValidation.ts +4 -5
- package/src/components/MonthPicker/MonthPickerVisual/VisualPickerHeader.vue +1 -1
- package/src/components/MonthPicker/tests/MonthPicker.spec.ts +2 -1
- package/src/components/MonthPicker/tests/__snapshots__/MonthPicker.spec.ts.snap +7 -7
- package/src/components/NirField/NirField.stories.ts +6 -2
- package/src/components/NirField/NirField.vue +67 -265
- package/src/components/NirField/accessibilite/Accessibility.mdx +102 -7
- package/src/components/NirField/locales.ts +1 -1
- package/src/components/NirField/tests/NirField.spec.ts +124 -0
- package/src/components/NirField/tests/useNirValidation.spec.ts +449 -0
- package/src/components/NirField/useNirValidation.ts +277 -0
- package/src/components/NotificationBar/Notification/Notification.vue +5 -7
- package/src/components/NotificationBar/NotificationBar.vue +1 -3
- package/src/components/PaginatedTable/PaginatedTable.vue +2 -3
- package/src/components/PaginatedTable/Pagination.vue +3 -5
- package/src/components/PasswordField/PasswordField.stories.ts +4 -4
- package/src/components/PasswordField/PasswordField.vue +26 -34
- package/src/components/PasswordField/tests/PasswordField.spec.ts +6 -3
- package/src/components/PeriodField/PeriodField.stories.ts +4 -4
- package/src/components/PeriodField/PeriodField.vue +57 -57
- package/src/components/PeriodField/__tests__/PeriodField.async.spec.ts +32 -0
- package/src/components/PeriodField/accessibilite/Accessibility.mdx +68 -8
- package/src/components/PeriodField/tests/PeriodField.spec.ts +28 -2
- package/src/components/PhoneField/PhoneField.vue +8 -9
- package/src/components/PhoneField/tests/PhoneField.spec.ts +1 -0
- package/src/components/RangeField/RangeField.vue +6 -0
- package/src/components/RangeField/RangeSlider/RangeSlider.vue +0 -2
- package/src/components/RangeField/RangeSlider/Tooltip/Tooltip.vue +1 -1
- package/src/components/RangeField/tests/RangeField.visual.cy.ts +65 -0
- package/src/components/RangeField/tests/__snapshots__/range-field-custom-bg.snap.png +0 -0
- package/src/components/RangeField/tests/__snapshots__/range-field-custom-range.snap.png +0 -0
- package/src/components/RangeField/tests/__snapshots__/range-field-default.snap.png +0 -0
- package/src/components/RangeField/tests/__snapshots__/range-field-step.snap.png +0 -0
- package/src/components/RangeField/tests/__snapshots__/range-field-with-label.snap.png +0 -0
- package/src/components/RatingPicker/EmotionPicker/EmotionPicker.vue +6 -8
- package/src/components/RatingPicker/StarsPicker/StarsPicker.vue +3 -5
- package/src/components/SearchListField/SearchListField.vue +0 -2
- package/src/components/SkipLink/SkipLink.vue +2 -4
- package/src/components/SocialMediaLinks/SocialMediaLinks.vue +6 -6
- package/src/components/SubHeader/SubHeader.vue +1 -1
- package/src/components/SyAlert/SyAlert.vue +7 -9
- package/src/components/SyAlert/tests/SyAlert.visual.cy.ts +46 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-closable.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-error.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-info.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-success.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-variant-outlined.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-variant-tonal.snap.png +0 -0
- package/src/components/SyAlert/tests/__snapshots__/sy-alert-warning.snap.png +0 -0
- package/src/components/SyBtnMenu/SyBtnMenu.vue +2 -4
- package/src/components/SyTextArea/SyTextArea.stories.ts +138 -2
- package/src/components/SyTextArea/SyTextArea.vue +53 -23
- package/src/components/SyTextArea/tests/SyTextArea.spec.ts +126 -3
- package/src/components/SyTextArea/useDefaultValidationRules.ts +74 -0
- package/src/components/TableToolbar/TableToolbar.vue +6 -8
- package/src/components/Tables/SyServerTable/SyServerTable.mdx +25 -0
- package/src/components/Tables/SyServerTable/SyServerTable.stories.ts +839 -1
- package/src/components/Tables/SyServerTable/SyServerTable.vue +154 -95
- package/src/components/Tables/SyServerTable/tests/SyServerTable.a11y.spec.ts +81 -0
- package/src/components/Tables/SyServerTable/tests/SyServerTable.spec.ts +390 -0
- package/src/components/Tables/SyTable/SyTable.mdx +25 -0
- package/src/components/Tables/SyTable/SyTable.stories.ts +556 -1
- package/src/components/Tables/SyTable/SyTable.vue +136 -60
- package/src/components/Tables/SyTable/tests/SyTable.a11y.spec.ts +79 -0
- package/src/components/Tables/SyTable/tests/SyTable.spec.ts +382 -0
- package/src/components/Tables/common/SyTableFilter.vue +49 -4
- package/src/components/Tables/common/SyTablePagination.vue +142 -19
- package/src/components/Tables/common/TableHeader.vue +45 -4
- package/src/components/Tables/common/filters/AutocompleteFilter.vue +160 -0
- package/src/components/Tables/common/filters/NumberFilter.vue +1 -1
- package/src/components/Tables/common/filters/SelectFilter.vue +11 -12
- package/src/components/Tables/common/filters/TextFilter.vue +1 -1
- package/src/components/Tables/common/filters/getFilterComponent.ts +8 -1
- package/src/components/Tables/common/filters/locales.ts +0 -1
- package/src/components/Tables/common/filters/tests/AutocompleteFilter.a11y.spec.ts +110 -0
- package/src/components/Tables/common/filters/tests/AutocompleteFilter.spec.ts +203 -0
- package/src/components/Tables/common/filters/tests/SelectFilter.a11y.spec.ts +104 -0
- package/src/components/Tables/common/filters/tests/SelectFilter.spec.ts +152 -16
- package/src/components/Tables/common/locales.ts +3 -0
- package/src/components/Tables/common/tableFilterUtils.ts +3 -0
- package/src/components/Tables/common/tableStyles.scss +60 -19
- package/src/components/Tables/common/tests/SyTablePagination.spec.ts +18 -0
- package/src/components/Tables/common/tests/TableHeader.spec.ts +39 -0
- package/src/components/Tables/common/tests/filterByRange.spec.ts +2 -1
- package/src/components/Tables/common/types.ts +15 -4
- package/src/components/Tables/common/useClickableTableRow.ts +103 -0
- package/src/components/Tables/common/usePagination.ts +13 -0
- package/src/components/Tables/common/usePinnedColumns.ts +237 -0
- package/src/components/Tables/common/useTableHeaders.ts +52 -30
- package/src/components/Tables/common/useTableRowCheckboxAccessibility.ts +41 -0
- package/src/components/UploadWorkflow/UploadWorkflow.vue +1 -0
- package/src/components/UploadWorkflow/tests/UploadWorkflow.spec.ts +23 -0
- package/src/components/UploadWorkflow/tests/__snapshots__/UploadWorkflow.spec.ts.snap +66 -0
- package/src/components/UploadWorkflow/useFileList.ts +3 -0
- package/src/components/UserMenuBtn/UserMenuBtn.vue +1 -3
- package/src/composables/date/tests/useDatePickerAccessibility.spec.ts +2 -6
- package/src/composables/date/useDatePickerAccessibility.ts +42 -207
- package/src/composables/rules/tests/useFieldValidation.spec.ts +120 -120
- package/src/composables/rules/useFieldValidation.ts +34 -17
- package/src/composables/unifyValidation/documentationValidationProps.ts +235 -0
- package/src/composables/unifyValidation/tests/useCustomValidation.spec.ts +601 -0
- package/src/composables/unifyValidation/tests/useValidation.spec.ts +2048 -0
- package/src/composables/unifyValidation/tests/useVuetifyValidation.spec.ts +184 -0
- package/src/composables/unifyValidation/useCustomValidation.ts +95 -0
- package/src/composables/unifyValidation/useValidation.ts +190 -0
- package/src/composables/unifyValidation/useVuetifyValidation.ts +54 -0
- package/src/composables/useFormFieldErrorHandling.ts +4 -7
- package/src/composables/validation/tests/useFormValidation.spec.ts +14 -0
- package/src/composables/validation/tests/useValidation.spec.ts +116 -21
- package/src/composables/validation/useFormValidation.ts +20 -13
- package/src/composables/validation/useValidatable.ts +8 -1
- package/src/composables/validation/useValidation.ts +151 -99
- package/src/composantsVuetify/Introduction.mdx +48 -0
- package/src/composantsVuetify/VBreadcrumbs/VBreadcrumbs.mdx +28 -0
- package/src/composantsVuetify/VBreadcrumbs/v-breadcrumbs.stories.ts +108 -0
- package/src/composantsVuetify/VBtn/VBtn.mdx +72 -0
- package/src/composantsVuetify/VBtn/v-btn.stories.ts +121 -0
- package/src/composantsVuetify/VOtpInput/VOtpInput.mdx +39 -0
- package/src/composantsVuetify/VOtpInput/v-otp-input.stories.ts +56 -0
- package/src/composantsVuetify/VSkeletonLoader/VSkeletonLoader.mdx +42 -0
- package/src/composantsVuetify/VSkeletonLoader/v-skeleton-loader.stories.ts +77 -0
- package/src/composantsVuetify/VSwitch/VSwitch.mdx +47 -0
- package/src/composantsVuetify/VSwitch/v-switch.stories.ts +166 -0
- package/src/composantsVuetify/VTooltip/VTooltip.mdx +32 -0
- package/src/composantsVuetify/VTooltip/v-tooltip.stories.ts +95 -0
- package/src/designTokens/tests/buildColorClassMap.spec.ts +31 -0
- package/src/designTokens/tests/generateScssTokens.spec.ts +12 -0
- package/src/designTokens/tests/themeUtils.spec.ts +53 -0
- package/src/designTokens/tokens/amelipro/apColors.ts +8 -130
- package/src/designTokens/tokens/amelipro/apColors2026.ts +3 -15
- package/src/designTokens/tokens/amelipro/apContextual.ts +55 -47
- package/src/designTokens/tokens/amelipro/apLightTheme.ts +1 -1
- package/src/designTokens/tokens/amelipro/apSemantic.ts +1 -1
- package/src/designTokens/tokens/baseColors.ts +129 -0
- package/src/designTokens/tokens/baseContextualTokens.ts +52 -0
- package/src/designTokens/tokens/cnam/cnamColors.ts +3 -125
- package/src/designTokens/tokens/cnam/cnamContextual.ts +4 -48
- package/src/designTokens/tokens/cnam/cnamLightTheme.ts +1 -1
- package/src/designTokens/tokens/cnam/cnamSemantic.ts +3 -3
- package/src/designTokens/tokens/pa/paColors.ts +2 -166
- package/src/designTokens/tokens/pa/paContextual.ts +3 -48
- package/src/designTokens/tokens/pa/paLightTheme.ts +1 -1
- package/src/designTokens/tokens/pa/paSemantic.ts +2 -2
- package/src/designTokens/utils/buildColorClassMap.ts +34 -0
- package/src/designTokens/utils/convertSemanticsToken.ts +8 -11
- package/src/designTokens/utils/createFlattenTheme.ts +15 -7
- package/src/designTokens/utils/index.ts +2 -2
- package/src/main.ts +0 -2
- package/src/stories/Accessibilite/AuditDesignSystem.mdx +0 -11
- package/src/stories/Accessibilite/DesignSystem/Avancement.mdx +433 -0
- package/src/stories/Accessibilite/DesignSystem/a11y-status.json +692 -0
- package/src/stories/Accessibilite/KitDePreAudit/Echantillonnage.mdx +8 -1
- package/src/stories/Accessibilite/KitDePreAudit/Introduction.mdx +51 -10
- package/src/stories/Accessibilite/KitDePreAudit/Outils/Introduction.mdx +16 -9
- package/src/stories/Accessibilite/KitDePreAudit/Preaudit.mdx +48 -58
- package/src/stories/Components/Components.stories.ts +113 -9
- package/src/stories/Demarrer/Accueil.stories.ts +3 -3
- package/src/stories/Demarrer/EnrichirLeDesignSystem.mdx +4 -9
- package/src/stories/Demarrer/EnrichirLeDesignSystem.stories.ts +28 -0
- package/src/stories/Demarrer/Releases.stories.ts +48 -5
- package/src/stories/DesignTokens/ColorDisplay.vue +6 -5
- package/src/stories/DesignTokens/ColorIntegrationExample.vue +2 -4
- package/src/stories/DesignTokens/colors.stories.ts +5 -6
- package/src/stories/GuideDuDev/Amelipro.mdx +15 -0
- package/src/stories/GuideDuDev/Amelipro.stories.ts +209 -0
- package/src/stories/GuideDuDev/CreateVuetifyInstance.mdx +95 -0
- package/src/stories/GuideDuDev/Theme.mdx +36 -26
- package/src/stories/GuideDuDev/moduleDeNotification.mdx +3 -2
- package/src/stories/GuideDuDev/vuetifyOptions.mdx +3 -3
- package/src/stories/styles/accessibility-guide.css +3 -3
- package/src/utils/functions/classToHex.ts +6 -34
- package/src/utils/functions/createHexResolver.ts +45 -0
- package/src/utils/functions/tests/classToHex.spec.ts +36 -0
- package/src/utils/functions/tests/convertToHex.spec.ts +31 -0
- package/src/utils/functions/tests/createHexResolver.spec.ts +66 -0
- package/src/utils/functions/tests/isCssColor.spec.ts +48 -0
- package/dist/SelectFilter-BioGT6Nn.js +0 -136
- package/dist/designTokens/utils/convertGaps.d.ts +0 -5
- package/dist/main-aLKwdMi1.js +0 -37886
- package/dist/style.css +0 -1
- package/src/assets/apTokens.scss +0 -343
- package/src/assets/overrides/_container.scss +0 -36
- package/src/assets/tokens.scss +0 -388
- package/src/components/DatePicker/Accessibilite.mdx +0 -14
- package/src/designTokens/apColors.md +0 -66
- package/src/designTokens/cnamColors.md +0 -193
- package/src/designTokens/paColors.md +0 -66
- package/src/designTokens/tokens/json/contextual-tokens.json +0 -156
- package/src/designTokens/tokens/json/primitives.json +0 -209
- package/src/designTokens/tokens/json/semantic.json +0 -120
- package/src/designTokens/utils/convertGaps.ts +0 -11
- package/src/stories/Accessibilite/Avancement/Avancement.mdx +0 -533
- package/src/stories/Accessibilite/Avancement/Avancement.stories.ts +0 -306
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { VCard, VCardText, VCardTitle, VRow, VCol, VIcon } from 'vuetify/components'
|
|
2
2
|
import type { StoryObj } from '@storybook/vue3'
|
|
3
|
+
import { useTheme } from 'vuetify'
|
|
3
4
|
|
|
4
5
|
export default {
|
|
5
6
|
title: 'Composants/Vue d\'ensemble',
|
|
@@ -24,12 +25,14 @@ export const ComponentsList: StoryObj = {
|
|
|
24
25
|
return {
|
|
25
26
|
components: { VCard, VCardText, VCardTitle, VRow, VCol, VIcon },
|
|
26
27
|
setup() {
|
|
28
|
+
const theme = useTheme()
|
|
29
|
+
const isAp = theme.global.name.value === 'ap'
|
|
27
30
|
const components = [
|
|
28
31
|
{
|
|
29
32
|
title: 'HeaderBar',
|
|
30
33
|
description: 'Utilisé pour afficher l’en-tête d’une page ainsi qu’une barre de navigation.',
|
|
31
34
|
link: '/?path=/docs/composants-structure-headerbar--docs',
|
|
32
|
-
img:
|
|
35
|
+
img: `/components/header-bar${isAp ? '-ap' : ''}.svg`,
|
|
33
36
|
category: 'Structure',
|
|
34
37
|
},
|
|
35
38
|
{
|
|
@@ -53,11 +56,18 @@ export const ComponentsList: StoryObj = {
|
|
|
53
56
|
img: '/components/sub-header.svg',
|
|
54
57
|
category: 'Structure',
|
|
55
58
|
},
|
|
59
|
+
{
|
|
60
|
+
title: 'SkeletonLoader',
|
|
61
|
+
description: 'Utilisé pour améliorer l’expérience utilisateur pendant le chargement des données, affiche une structure visuelle temporaire qui ressemble au contenu final.',
|
|
62
|
+
link: '/?path=/docs/composants-composants-vuetify-vskeletonloader--docs',
|
|
63
|
+
img: '/components/v-skeleton-loader.svg',
|
|
64
|
+
category: 'Structure',
|
|
65
|
+
},
|
|
56
66
|
{
|
|
57
67
|
title: 'FooterBar',
|
|
58
68
|
description: 'Utilisé pour afficher une barre de pied de page avec des liens et des informations supplémentaires.',
|
|
59
69
|
link: '/?path=/docs/composants-structure-footerbar--docs',
|
|
60
|
-
img:
|
|
70
|
+
img: `/components/footer-bar${isAp ? '-ap' : ''}.svg`,
|
|
61
71
|
category: 'Structure',
|
|
62
72
|
},
|
|
63
73
|
{
|
|
@@ -74,6 +84,13 @@ export const ComponentsList: StoryObj = {
|
|
|
74
84
|
img: '/components/contextual-menu.svg',
|
|
75
85
|
category: 'Navigation',
|
|
76
86
|
},
|
|
87
|
+
{
|
|
88
|
+
title: 'Breadcrumbs',
|
|
89
|
+
description: 'Utilisé comme un outil d’aide à la navigation et comme une structure hiérarchique pour les pages.',
|
|
90
|
+
link: '/?path=/docs/composants-composants-vuetify-vbreadcrumbs--docs',
|
|
91
|
+
img: '/components/breadcrumbs.svg',
|
|
92
|
+
category: 'Navigation',
|
|
93
|
+
},
|
|
77
94
|
{
|
|
78
95
|
title: 'ExternalLinks',
|
|
79
96
|
description: 'Utilisé pour afficher un menu avec une liste vers des liens externes.',
|
|
@@ -92,7 +109,14 @@ export const ComponentsList: StoryObj = {
|
|
|
92
109
|
title: 'SkipLink',
|
|
93
110
|
description: 'Utilisé pour permettre à l\'utilisateur utilisant la navigation au clavier de passer directement à une section de contenu.',
|
|
94
111
|
link: '/?path=/docs/composants-navigation-skiplink--docs',
|
|
95
|
-
img:
|
|
112
|
+
img: `/components/skip-link${isAp ? '-ap' : ''}.svg`,
|
|
113
|
+
category: 'Navigation',
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
title: 'SyPagination',
|
|
117
|
+
description: 'Utilisé pour permettre la navigation entre plusieurs pages de contenu.',
|
|
118
|
+
link: '/?path=/docs/composants-navigation-sypagination--docs',
|
|
119
|
+
img: `/components/pagination${isAp ? '-ap' : ''}.svg`,
|
|
96
120
|
category: 'Navigation',
|
|
97
121
|
},
|
|
98
122
|
{
|
|
@@ -102,6 +126,13 @@ export const ComponentsList: StoryObj = {
|
|
|
102
126
|
img: '/components/back-btn.svg',
|
|
103
127
|
category: 'Boutons',
|
|
104
128
|
},
|
|
129
|
+
{
|
|
130
|
+
title: 'SyIconBtn',
|
|
131
|
+
description: 'Utilisé lorsque on a besoin d’un bouton qui sert principalement à afficher une icône.',
|
|
132
|
+
link: '/?path=/docs/composants-boutons-syiconbutton--docs',
|
|
133
|
+
img: `/components/sy-icon-button${isAp ? '-ap' : ''}.svg`,
|
|
134
|
+
category: 'Boutons',
|
|
135
|
+
},
|
|
105
136
|
{
|
|
106
137
|
title: 'BackToTopBtn',
|
|
107
138
|
description: 'Utilisé pour afficher un bouton permettant à l’utilisateur de remonter en haut de la page.',
|
|
@@ -113,7 +144,7 @@ export const ComponentsList: StoryObj = {
|
|
|
113
144
|
title: 'CopyBtn',
|
|
114
145
|
description: 'Utilisé pour afficher un bouton permettant à l’utilisateur de copier du texte.',
|
|
115
146
|
link: '/?path=/docs/composants-boutons-copybtn--docs',
|
|
116
|
-
img:
|
|
147
|
+
img: `/components/copy-btn${isAp ? '-ap' : ''}.svg`,
|
|
117
148
|
category: 'Boutons',
|
|
118
149
|
},
|
|
119
150
|
{
|
|
@@ -127,7 +158,7 @@ export const ComponentsList: StoryObj = {
|
|
|
127
158
|
title: 'DownloadBtn',
|
|
128
159
|
description: 'Utilisé pour permettre à l’utilisateur de télécharger un document provenant d’une API.',
|
|
129
160
|
link: '/?path=/docs/composants-boutons-downloadbtn--docs',
|
|
130
|
-
img:
|
|
161
|
+
img: `/components/download-btn${isAp ? '-ap' : ''}.svg`,
|
|
131
162
|
category: 'Boutons',
|
|
132
163
|
},
|
|
133
164
|
{
|
|
@@ -151,11 +182,25 @@ export const ComponentsList: StoryObj = {
|
|
|
151
182
|
img: '/components/sy-text-field.svg',
|
|
152
183
|
category: 'Formulaires',
|
|
153
184
|
},
|
|
185
|
+
{
|
|
186
|
+
title: 'SyAutocomplete',
|
|
187
|
+
description: 'Utilisé pour permettre à l’utilisateur de rechercher et sélectionner une valeur dans une liste d\'options (alternative au v-autocomplete de Vuetify).',
|
|
188
|
+
link: '/?path=/docs/composants-formulaires-selects-syautocomplete--docs',
|
|
189
|
+
img: `/components/sy-select${isAp ? '-ap' : ''}.svg`,
|
|
190
|
+
category: 'Formulaires',
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
title: 'Switch',
|
|
194
|
+
description: 'Utilisé pour permettre à l’utilisateur de choisir entre deux valeurs distinctes. Il est très similaire à un bouton bascule (toggle) ou à un interrupteur marche/arrêt.',
|
|
195
|
+
link: '/?path=/docs/composants-composants-vuetify-vswitch--docs',
|
|
196
|
+
img: `/components/switch${isAp ? '-ap' : ''}.svg`,
|
|
197
|
+
category: 'Boutons',
|
|
198
|
+
},
|
|
154
199
|
{
|
|
155
200
|
title: 'SySelect',
|
|
156
201
|
description: 'Utilisé pour proposer une alternative au v-select de Vuetify qui ne respecte pas les règles d\'accessibilité RGAA. Il est basé sur un v-textfield.',
|
|
157
202
|
link: '/?path=/docs/composants-formulaires-syselect--docs',
|
|
158
|
-
img:
|
|
203
|
+
img: `/components/sy-select${isAp ? '-ap' : ''}.svg`,
|
|
159
204
|
category: 'Formulaires',
|
|
160
205
|
},
|
|
161
206
|
{
|
|
@@ -172,9 +217,16 @@ export const ComponentsList: StoryObj = {
|
|
|
172
217
|
img: '/components/sy-btn-select.svg',
|
|
173
218
|
category: 'Formulaires',
|
|
174
219
|
},
|
|
220
|
+
{
|
|
221
|
+
title: 'OTPInput',
|
|
222
|
+
description: 'Utilisé pour une procédure MFA d’authentification des utilisateurs via un mot de passe à usage unique.',
|
|
223
|
+
link: '/?path=/docs/composants-composants-vuetify-votpinput--docs',
|
|
224
|
+
img: `/components/otp${isAp ? '-ap' : ''}.svg`,
|
|
225
|
+
category: 'Formulaires',
|
|
226
|
+
},
|
|
175
227
|
{
|
|
176
228
|
title: 'DatePicker',
|
|
177
|
-
description: '
|
|
229
|
+
description: 'Utilisé pour permettre à l’utilisateur de sélectionner ou de saisir une date.',
|
|
178
230
|
link: '/?path=/docs/composants-formulaires-datepicker--docs',
|
|
179
231
|
img: '/components/date-picker.svg',
|
|
180
232
|
category: 'Formulaires',
|
|
@@ -235,6 +287,27 @@ export const ComponentsList: StoryObj = {
|
|
|
235
287
|
img: '/components/select-btn-field.svg',
|
|
236
288
|
category: 'Formulaires',
|
|
237
289
|
},
|
|
290
|
+
{
|
|
291
|
+
title: 'SyCheckBox',
|
|
292
|
+
description: 'Utilisé pour permettre à l’utilisateur de selectionner une option.',
|
|
293
|
+
link: '/?path=/docs/composants-formulaires-sycheckbox--docs',
|
|
294
|
+
img: `/components/sy-checkbox${isAp ? '-ap' : ''}.svg`,
|
|
295
|
+
category: 'Formulaires',
|
|
296
|
+
},
|
|
297
|
+
{
|
|
298
|
+
title: 'SyCheckBoxGroup',
|
|
299
|
+
description: 'Utilisé pour permettre à l’utilisateur de selectionner plusieurs options.',
|
|
300
|
+
link: '/?path=/docs/composants-formulaires-sycheckboxgroup--docs',
|
|
301
|
+
img: `/components/sy-checkbox-group${isAp ? '-ap' : ''}.svg`,
|
|
302
|
+
category: 'Formulaires',
|
|
303
|
+
},
|
|
304
|
+
{
|
|
305
|
+
title: 'SyRadioGroup',
|
|
306
|
+
description: 'Utilisé pour permettre à l\'utilisateur de choisir une option parmi plusieurs.',
|
|
307
|
+
link: '/?path=/docs/composants-formulaires-syradiogroup--docs',
|
|
308
|
+
img: `/components/sy-radiogroup${isAp ? '-ap' : ''}.svg`,
|
|
309
|
+
category: 'Formulaires',
|
|
310
|
+
},
|
|
238
311
|
{
|
|
239
312
|
title: 'PaginatedTable',
|
|
240
313
|
description: 'Utilisé pour afficher une VDataTable de Vuetify avec une pagination persistante.',
|
|
@@ -353,10 +426,41 @@ export const ComponentsList: StoryObj = {
|
|
|
353
426
|
'Feedback',
|
|
354
427
|
]
|
|
355
428
|
|
|
429
|
+
const apComponents = [
|
|
430
|
+
'FooterBar',
|
|
431
|
+
'HeaderBar',
|
|
432
|
+
'HeaderLoading',
|
|
433
|
+
'PageContainer',
|
|
434
|
+
'CopyBtn',
|
|
435
|
+
'DownloadBtn',
|
|
436
|
+
'SyPagination',
|
|
437
|
+
'SkipLink',
|
|
438
|
+
'SyCheckBox',
|
|
439
|
+
'SyCheckBoxGroup',
|
|
440
|
+
'SyAutocomplete',
|
|
441
|
+
'SySelect',
|
|
442
|
+
'SyRadioGroup',
|
|
443
|
+
'SyIconBtn',
|
|
444
|
+
'NirField',
|
|
445
|
+
]
|
|
446
|
+
|
|
447
|
+
const shouldDisplayComponent = (component: { category: string, title: string }, category: string) => {
|
|
448
|
+
if (isAp) {
|
|
449
|
+
return (
|
|
450
|
+
component.category === category
|
|
451
|
+
&& apComponents.some(apComponent => component.title.includes(apComponent))
|
|
452
|
+
)
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
return component.category === category
|
|
456
|
+
}
|
|
457
|
+
|
|
356
458
|
const groupedComponents = categoryOrder.map(category => ({
|
|
357
459
|
category,
|
|
358
|
-
components: components
|
|
359
|
-
|
|
460
|
+
components: components
|
|
461
|
+
.filter(component => shouldDisplayComponent(component, category))
|
|
462
|
+
.sort((a, b) => a.title.localeCompare(b.title)),
|
|
463
|
+
})).filter(group => group.components.length > 0)
|
|
360
464
|
|
|
361
465
|
return {
|
|
362
466
|
groupedComponents,
|
|
@@ -43,8 +43,8 @@ export const Header: StoryObj = {
|
|
|
43
43
|
<img alt="line" src="/home-line.svg" width="120" height="5" class="mb-5" />
|
|
44
44
|
<h2 style="font-family: Arial !important; font-size: 1.5rem !important; font-weight: 400 !important; line-height: 1.30 !important; letter-spacing: normal !important;" class="mb-5">Synapse :
|
|
45
45
|
<span v-if="theme === 'pa'" class="text-h5">thème Portail Agent</span>
|
|
46
|
-
<span v-if="theme === 'ap'">thème Amelipro
|
|
47
|
-
<span v-if="theme === 'ap2026'">thème Amelipro</span>
|
|
46
|
+
<span v-if="theme === 'ap'">thème Amelipro</span>
|
|
47
|
+
<span v-if="theme === 'ap2026'">thème Amelipro 2026</span>
|
|
48
48
|
<span v-if="theme === 'cnam'" class="text-h5">thème CNAM</span></h2>
|
|
49
49
|
<p style="font-family: Arial !important; font-size: 1rem !important;" class="mb-5">Veuillez sélectionner dans la barre d’outil en haut de l’écran le thème graphique de votre produit avant de consulter la documentation, elle s’actualisera en conséquence avec les tokens et composants disponibles.
|
|
50
50
|
<br/>Si vous ne connaissez pas le thème auquel votre produit est soumis veuillez consulter le dossier d’architecture du produit.
|
|
@@ -153,7 +153,7 @@ export const DesignSystem: StoryObj = {
|
|
|
153
153
|
</VCard>
|
|
154
154
|
</VCol>
|
|
155
155
|
<VCol cols="12" md="4">
|
|
156
|
-
<VCard class="pa-0 h-100 card-hover" elevation="0" href="/?path=/docs/guide-du-dev-
|
|
156
|
+
<VCard class="pa-0 h-100 card-hover" elevation="0" href="/?path=/docs/guide-du-dev-installation--docs">
|
|
157
157
|
<img src="/home-card-dev.svg" alt="Guide du dev" class="w-100" />
|
|
158
158
|
<VCardTitle><b>Guides du dev</b></VCardTitle>
|
|
159
159
|
<VCardText>Les Guides du Dev accompagnent les équipes techniques dans l'implémentation du Design System en garantissant une intégration fluide et efficace.</VCardText>
|
|
@@ -14,7 +14,8 @@ Le Design System de l'Assurance Maladie est un projet vivant qui évolue constam
|
|
|
14
14
|
Votre contribution est essentielle pour garantir que le Design System reste pertinent, accessible et efficace.<br/>
|
|
15
15
|
Toute demande ne sera pas nécessairement intégrée, mais chaque suggestion est examinée avec attention par l'équipe du Studio Design.
|
|
16
16
|
|
|
17
|
-
|
|
17
|
+
#
|
|
18
|
+
<Story of={ComponentStories.WarningIntro}/>
|
|
18
19
|
|
|
19
20
|
<a id="exigences" />
|
|
20
21
|
## Exigences requises pour acceptation d'un nouveau composant ou d'une nouvelle fonctionnalité
|
|
@@ -31,13 +32,7 @@ Toute demande ne sera pas nécessairement intégrée, mais chaque suggestion est
|
|
|
31
32
|
10. Doit se conformer aux **exigences techniques** du Design System et à son bon fonctionnement sur le Starter Kit (VueJS 3, version des plugins...).
|
|
32
33
|
|
|
33
34
|
## Créer une nouvelle demande
|
|
34
|
-
|
|
35
|
-
<Story of={ComponentStories.Optimisation}/>
|
|
36
|
-
|
|
35
|
+
#
|
|
37
36
|
<Story of={ComponentStories.AjoutFonctionnalite}/>
|
|
38
37
|
|
|
39
|
-
<Story of={ComponentStories.
|
|
40
|
-
|
|
41
|
-
<Story of={ComponentStories.CreationComposant}/>
|
|
42
|
-
|
|
43
|
-
<Story of={ComponentStories.IntegrationComposant}/>
|
|
38
|
+
<Story of={ComponentStories.CreationComposant}/>
|
|
@@ -26,6 +26,34 @@ export const InfoIntro = {
|
|
|
26
26
|
tags: ['!dev'],
|
|
27
27
|
}
|
|
28
28
|
|
|
29
|
+
export const WarningIntro = {
|
|
30
|
+
render: () => {
|
|
31
|
+
return {
|
|
32
|
+
components: { SyAlert },
|
|
33
|
+
setup() {
|
|
34
|
+
return {}
|
|
35
|
+
},
|
|
36
|
+
template: `
|
|
37
|
+
<SyAlert type="error" variant="tonal" :closable="false">
|
|
38
|
+
<template #default>
|
|
39
|
+
<b>Pour limiter les risques de régression et d'anomalie nous mettons temporairement en pause les demandes de nouvelles fonctionnalités. Nous invitons les projets à mettre en place des solutions de contournement.</b>
|
|
40
|
+
<br/><br/>
|
|
41
|
+
Une fois les chantiers ci-après complétés au 1er juillet 2026 nous pourrons reprendre l'analyse et l'intégration de vos features au fil de l'eau selon la disponibilité de l'équipe.
|
|
42
|
+
<br/><br/>
|
|
43
|
+
Chantiers en cours :
|
|
44
|
+
<ul><li>- Disponibilité des composants Amelipro</li>
|
|
45
|
+
<li>- Optimisation de la validation des composants de formulaire</li>
|
|
46
|
+
<li>- Optimisation des tokens pour la convergence des 3 thèmes (Amelipro, Cnam, Portail Agent)</li>
|
|
47
|
+
<li>- Optimisation de l'accessibilité numérique</li>
|
|
48
|
+
</ul>
|
|
49
|
+
</template>
|
|
50
|
+
</SyAlert>
|
|
51
|
+
`,
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
tags: ['!dev'],
|
|
55
|
+
}
|
|
56
|
+
|
|
29
57
|
export const Optimisation = {
|
|
30
58
|
render: () => {
|
|
31
59
|
return {
|
|
@@ -1,8 +1,34 @@
|
|
|
1
1
|
import axios from 'axios'
|
|
2
|
-
import { onMounted,
|
|
2
|
+
import { onMounted, shallowRef } from 'vue'
|
|
3
3
|
import * as marked from 'marked'
|
|
4
4
|
import SyAlert from '../../components/SyAlert/SyAlert.vue'
|
|
5
5
|
|
|
6
|
+
type GitHubRelease = {
|
|
7
|
+
id: number
|
|
8
|
+
name?: string | null
|
|
9
|
+
tag_name?: string | null
|
|
10
|
+
published_at: string
|
|
11
|
+
body?: string | null
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
type ReleaseAlert = {
|
|
15
|
+
id: string
|
|
16
|
+
releaseVersion: string
|
|
17
|
+
message: string
|
|
18
|
+
type: 'success' | 'info' | 'warning' | 'error'
|
|
19
|
+
variant: 'tonal' | 'outlined'
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const releaseAlerts: ReleaseAlert[] = [
|
|
23
|
+
{
|
|
24
|
+
id: 'starter-kit-2-0-32',
|
|
25
|
+
releaseVersion: 'v1.0.24',
|
|
26
|
+
message: 'Il est conseillé de faire une montée de version du Starter Kit en 2.0.32',
|
|
27
|
+
type: 'warning',
|
|
28
|
+
variant: 'tonal',
|
|
29
|
+
},
|
|
30
|
+
]
|
|
31
|
+
|
|
6
32
|
export default {
|
|
7
33
|
title: 'Démarrer/Releases',
|
|
8
34
|
component: SyAlert,
|
|
@@ -12,8 +38,8 @@ export const List = {
|
|
|
12
38
|
return {
|
|
13
39
|
components: { SyAlert },
|
|
14
40
|
setup() {
|
|
15
|
-
const releases =
|
|
16
|
-
const errorMessage =
|
|
41
|
+
const releases = shallowRef<GitHubRelease[]>([])
|
|
42
|
+
const errorMessage = shallowRef('')
|
|
17
43
|
|
|
18
44
|
const fetchReleases = async () => {
|
|
19
45
|
try {
|
|
@@ -30,8 +56,14 @@ export const List = {
|
|
|
30
56
|
return new Date(date).toLocaleDateString()
|
|
31
57
|
}
|
|
32
58
|
|
|
33
|
-
const formatMarkdown = (markdown
|
|
34
|
-
return marked.parse(markdown)
|
|
59
|
+
const formatMarkdown = (markdown?: string | null) => {
|
|
60
|
+
return marked.parse(markdown ?? '')
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const getReleaseAlerts = (release: GitHubRelease) => {
|
|
64
|
+
return releaseAlerts.filter(alert =>
|
|
65
|
+
[release.name, release.tag_name].some(value => value?.includes(alert.releaseVersion)),
|
|
66
|
+
)
|
|
35
67
|
}
|
|
36
68
|
|
|
37
69
|
onMounted(() => {
|
|
@@ -43,6 +75,7 @@ export const List = {
|
|
|
43
75
|
errorMessage,
|
|
44
76
|
formatDate,
|
|
45
77
|
formatMarkdown,
|
|
78
|
+
getReleaseAlerts,
|
|
46
79
|
}
|
|
47
80
|
},
|
|
48
81
|
template: `
|
|
@@ -60,6 +93,16 @@ export const List = {
|
|
|
60
93
|
<div v-else>
|
|
61
94
|
<div v-for="release in releases" :key="release.id">
|
|
62
95
|
<h2>{{ release.name }} ({{ formatDate(release.published_at) }})</h2>
|
|
96
|
+
<SyAlert
|
|
97
|
+
v-for="alert in getReleaseAlerts(release)"
|
|
98
|
+
:key="alert.id"
|
|
99
|
+
:type="alert.type"
|
|
100
|
+
:variant="alert.variant"
|
|
101
|
+
:closable="false"
|
|
102
|
+
class="mt-2 mb-4"
|
|
103
|
+
>
|
|
104
|
+
<template #default>{{ alert.message }}</template>
|
|
105
|
+
</SyAlert>
|
|
63
106
|
<div v-html="formatMarkdown(release.body)"></div>
|
|
64
107
|
<hr>
|
|
65
108
|
</div>
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
/* eslint-disabled vuejs-accessibility/anchor-has-content */
|
|
3
3
|
import SyHeading from '@/components/SyHeading/SyHeading.vue'
|
|
4
4
|
import { computed } from 'vue'
|
|
5
|
+
import { useTheme } from 'vuetify'
|
|
5
6
|
import { VContainer, VRow, VCol, VCard, VCardTitle, VCardSubtitle } from 'vuetify/components'
|
|
6
7
|
|
|
7
8
|
interface Props {
|
|
@@ -17,16 +18,16 @@
|
|
|
17
18
|
}
|
|
18
19
|
|
|
19
20
|
const props = defineProps<Props>()
|
|
21
|
+
const theme = useTheme()
|
|
20
22
|
|
|
21
|
-
const theme = computed(() => typeof window !== 'undefined' ? localStorage.getItem('storybook-theme') : 'cnam')
|
|
22
23
|
const displayColors = computed(() => {
|
|
23
|
-
if (theme.value === 'pa') {
|
|
24
|
+
if (theme.global.name.value === 'pa') {
|
|
24
25
|
return props.paColors
|
|
25
26
|
}
|
|
26
|
-
if (theme.value === 'ap') {
|
|
27
|
+
if (theme.global.name.value === 'ap') {
|
|
27
28
|
return props.apColors
|
|
28
29
|
}
|
|
29
|
-
if (theme.value === 'ap2026') {
|
|
30
|
+
if (theme.global.name.value === 'ap2026') {
|
|
30
31
|
return props.apColors2026
|
|
31
32
|
}
|
|
32
33
|
return props.cnamColors
|
|
@@ -42,7 +43,7 @@
|
|
|
42
43
|
<div
|
|
43
44
|
v-if="!isEmptyObject(displayColors) ||
|
|
44
45
|
(isEmptyObject(displayColors) && displayEmptyColors &&
|
|
45
|
-
!['ap2026', 'ap', 'cnam', 'pa'].includes(theme
|
|
46
|
+
!['ap2026', 'ap', 'cnam', 'pa'].includes(theme.global.name.value))"
|
|
46
47
|
class="mb-5"
|
|
47
48
|
>
|
|
48
49
|
<SyHeading
|
|
@@ -26,7 +26,7 @@
|
|
|
26
26
|
<pre style="margin: 0; font-size: 12px; color: #333;"><code>@use '@cnamts/synapse/assets/tokens' as tokens;
|
|
27
27
|
|
|
28
28
|
.my-color {
|
|
29
|
-
color:
|
|
29
|
+
color: rgb(var(--v-theme-yellow-lighten40)) !important;
|
|
30
30
|
}</code></pre>
|
|
31
31
|
</div>
|
|
32
32
|
</div>
|
|
@@ -35,9 +35,7 @@
|
|
|
35
35
|
</template>
|
|
36
36
|
|
|
37
37
|
<style lang="scss" scoped>
|
|
38
|
-
@use '@/assets/tokens' as tokens;
|
|
39
|
-
|
|
40
38
|
.my-color {
|
|
41
|
-
color:
|
|
39
|
+
color: rgb(var(--v-theme-yellow-lighten40)) !important;
|
|
42
40
|
}
|
|
43
41
|
</style>
|
|
@@ -61,11 +61,7 @@ export const Theme: StoryObj = {
|
|
|
61
61
|
render: () => {
|
|
62
62
|
return {
|
|
63
63
|
setup() {
|
|
64
|
-
const theme =
|
|
65
|
-
const value
|
|
66
|
-
= typeof window !== 'undefined' ? localStorage.getItem('storybook-theme') : 'cnam'
|
|
67
|
-
return (value as ThemeKey) ?? 'cnam'
|
|
68
|
-
})
|
|
64
|
+
const theme = useTheme()
|
|
69
65
|
|
|
70
66
|
const themeLabels: Record<ThemeKey, string> = {
|
|
71
67
|
cnam: 'Assurance Maladie',
|
|
@@ -74,7 +70,10 @@ export const Theme: StoryObj = {
|
|
|
74
70
|
ap2026: 'AmeliPro',
|
|
75
71
|
}
|
|
76
72
|
|
|
77
|
-
const themeLabel = computed(() =>
|
|
73
|
+
const themeLabel = computed(() => {
|
|
74
|
+
const currentTheme = theme.global.name.value as ThemeKey
|
|
75
|
+
return themeLabels[currentTheme] ?? themeLabels.cnam
|
|
76
|
+
})
|
|
78
77
|
|
|
79
78
|
return {
|
|
80
79
|
themeLabel,
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Meta, Story } from '@storybook/blocks';
|
|
2
|
+
import * as AmeliproStories from './Amelipro.stories';
|
|
3
|
+
import '../styles/shared.css';
|
|
4
|
+
|
|
5
|
+
<Meta of={AmeliproStories}/>
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
<div className="header">
|
|
10
|
+
<h1>Equivalence des composants Amelipro avec la stack front VueJs 3</h1>
|
|
11
|
+
</div>
|
|
12
|
+
|
|
13
|
+
Suite au besoin de migration de l'ensemble des applications du parc de Amelipro vers Vue.js 3, les composants graphiques ont été unifiés. Voici les composants Amelipro et leur équivalence dans la stack front Vue.js 3.
|
|
14
|
+
|
|
15
|
+
<Story of={AmeliproStories.ApComponents}/>
|