@cnamts/synapse 1.0.2 → 1.0.3
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-YWOTbfeL.js → DateFilter-DFKfon7L.js} +1 -1
- package/dist/{NumberFilter-DMmMgALM.js → NumberFilter-DmhIL2Pr.js} +1 -1
- package/dist/{PeriodFilter-Bok5BHcn.js → PeriodFilter-C46V6bYN.js} +1 -1
- package/dist/{SelectFilter-BKud2WhN.js → SelectFilter-B8dtHtHo.js} +2 -2
- package/dist/{TextFilter-DvMf2thH.js → TextFilter-COKGday2.js} +1 -1
- package/dist/assets/amelipro/icons.d.ts +5 -0
- package/dist/components/Accordion/Accordion.d.ts +1 -1
- package/dist/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.d.ts +6554 -0
- package/dist/components/Amelipro/AmeliproAutoCompleteField/types.d.ts +12 -0
- package/dist/components/Amelipro/AmeliproBreadcrumb/AmeliproBreadcrumb.d.ts +28 -0
- package/dist/components/Amelipro/AmeliproBreadcrumb/types.d.ts +7 -0
- package/dist/components/Amelipro/AmeliproBtn/AmeliproBtn.d.ts +258 -0
- package/dist/components/Amelipro/AmeliproCallback/AmeliproCallback.d.ts +128 -0
- package/dist/components/Amelipro/AmeliproCard/AmeliproCard.d.ts +151 -0
- package/dist/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.d.ts +98 -0
- package/dist/components/Amelipro/AmeliproCheckbox/types.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.d.ts +149 -0
- package/dist/components/Amelipro/AmeliproCheckboxGroup/types.d.ts +7 -0
- package/dist/components/Amelipro/AmeliproChips/AmeliproChips.d.ts +24 -0
- package/dist/components/Amelipro/AmeliproDialog/AmeliproDialog.d.ts +164 -0
- package/dist/components/Amelipro/AmeliproDisclosure/AmeliproDisclosure.d.ts +37 -0
- package/dist/components/Amelipro/AmeliproFooter/A11yComplianceEnum.d.ts +6 -0
- package/dist/components/Amelipro/AmeliproFooter/AmeliproFooter.d.ts +313 -0
- package/dist/components/Amelipro/AmeliproFooter/locales.d.ts +13 -0
- package/dist/components/Amelipro/AmeliproFooter/types.d.ts +33 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeader.d.ts +191 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBar.d.ts +77 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/AmeliproHeaderBrandSection.d.ts +76 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/dividerDimensionsMapping.d.ts +2 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/locales.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/types.d.ts +4 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/AmeliproLogoAm.d.ts +35 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/LogoSizeEnum.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/locales.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/logoDimensionsMapping.d.ts +2 -0
- package/dist/components/Amelipro/AmeliproHeader/types.d.ts +24 -0
- package/dist/components/Amelipro/AmeliproIcon/AmeliproIcon.d.ts +137 -0
- package/dist/components/Amelipro/AmeliproIcon/iconList.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.d.ts +449 -0
- package/dist/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.d.ts +104 -0
- package/dist/components/Amelipro/AmeliproIllustratedDataTile/types.d.ts +4 -0
- package/dist/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.d.ts +80 -0
- package/dist/components/Amelipro/AmeliproIllustratedRadioGroup/locales.d.ts +3 -0
- package/dist/components/Amelipro/AmeliproIllustratedRadioGroup/types.d.ts +8 -0
- package/dist/components/Amelipro/AmeliproMailTile/AmeliproMailTile.d.ts +38 -0
- package/dist/components/Amelipro/AmeliproMailTile/types.d.ts +13 -0
- package/dist/components/Amelipro/AmeliproMenu/AmeliproMenu.d.ts +57 -0
- package/dist/components/Amelipro/AmeliproMenu/types.d.ts +9 -0
- package/dist/components/Amelipro/AmeliproMessage/AmeliproMessage.d.ts +172 -0
- package/dist/components/Amelipro/AmeliproMessage/AmeliproMessageTypes.d.ts +2 -0
- package/dist/components/Amelipro/AmeliproMessage/types.d.ts +7 -0
- package/dist/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/types.d.ts +7 -0
- package/dist/components/Amelipro/AmeliproMessagingLayout/types.d.ts +9 -0
- package/dist/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.d.ts +123 -0
- package/dist/components/Amelipro/AmeliproMultipleFoldingCard/types.d.ts +6 -0
- package/dist/components/Amelipro/AmeliproNumberedCard/AmeliproNumberedCard.d.ts +79 -0
- package/dist/components/Amelipro/AmeliproNumberedCard/types.d.ts +4 -0
- package/dist/components/Amelipro/AmeliproOnboarding/AmeliproOnboarding.d.ts +125 -0
- package/dist/components/Amelipro/AmeliproOnboarding/types.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproPageLayout/AmeliproPageLayout.d.ts +63 -0
- package/dist/components/Amelipro/AmeliproPageLayout/locales.d.ts +3 -0
- package/dist/components/Amelipro/AmeliproPageLayout/types.d.ts +14 -0
- package/dist/components/Amelipro/AmeliproPagination/AmeliproPagination.d.ts +37 -0
- package/dist/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/AmeliproPaginationBtn.d.ts +63 -0
- package/dist/components/Amelipro/AmeliproPagination/types.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.d.ts +127 -0
- package/dist/components/Amelipro/AmeliproPatientBanner/locales.d.ts +6 -0
- package/dist/components/Amelipro/AmeliproPatientBanner/types.d.ts +15 -0
- package/dist/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.d.ts +139 -0
- package/dist/components/Amelipro/AmeliproRadioGroup/locales.d.ts +3 -0
- package/dist/components/Amelipro/AmeliproRadioGroup/types.d.ts +6 -0
- package/dist/components/Amelipro/AmeliproSelect/AmeliproSelect.d.ts +6513 -0
- package/dist/components/Amelipro/AmeliproSelect/types.d.ts +10 -0
- package/dist/components/Amelipro/AmeliproStateTile/AmeliproStateTile.d.ts +138 -0
- package/dist/components/Amelipro/AmeliproStateTile/AmeliproStateTileTypes.d.ts +2 -0
- package/dist/components/Amelipro/AmeliproStateTile/types.d.ts +11 -0
- package/dist/components/Amelipro/AmeliproStatus/AmeliproStatus.d.ts +62 -0
- package/dist/components/Amelipro/AmeliproStatus/AmeliproStatusTypes.d.ts +2 -0
- package/dist/components/Amelipro/AmeliproStatus/types.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproStepper/AmeliproStepBtn/AmeliproStepBtn.d.ts +43 -0
- package/dist/components/Amelipro/AmeliproStepper/AmeliproStepper.d.ts +213 -0
- package/dist/components/Amelipro/AmeliproStepper/types.d.ts +5 -0
- package/dist/components/Amelipro/AmeliproTabs/AmeliproTabBtn/AmeliproTabBtn.d.ts +76 -0
- package/dist/components/Amelipro/AmeliproTabs/AmeliproTabs.d.ts +6839 -0
- package/dist/components/Amelipro/AmeliproTabs/types.d.ts +10 -0
- package/dist/components/Amelipro/AmeliproTextArea/AmeliproTextArea.d.ts +1063 -0
- package/dist/components/Amelipro/AmeliproTextArea/types.d.ts +4 -0
- package/dist/components/Amelipro/AmeliproTextField/AmeliproTextField.d.ts +1681 -0
- package/dist/components/Amelipro/AmeliproTextField/types.d.ts +4 -0
- package/dist/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.d.ts +199 -0
- package/dist/components/Amelipro/AmeliproTooltips/AmeliproTooltips.d.ts +115 -0
- package/dist/components/Amelipro/AmeliproTransmission/AmeliproTransmission.d.ts +121 -0
- package/dist/components/Amelipro/ServiceMenu/ServiceBtn/ServiceBtn.d.ts +44 -0
- package/dist/components/Amelipro/ServiceMenu/ServiceBtn/types.d.ts +8 -0
- package/dist/components/Amelipro/ServiceMenu/ServiceList/ServiceList.d.ts +41 -0
- package/dist/components/Amelipro/ServiceMenu/ServiceMenu.d.ts +84 -0
- package/dist/components/Amelipro/ServiceMenu/ServiceMenuContent/ServiceMenuContent.d.ts +57 -0
- package/dist/components/Amelipro/ServiceMenu/types.d.ts +12 -0
- package/dist/components/Amelipro/StructureMenu/StructureBtn/StructureBtn.d.ts +49 -0
- package/dist/components/Amelipro/StructureMenu/StructureItem/StructureItem.d.ts +53 -0
- package/dist/components/Amelipro/StructureMenu/StructureItem/locales.d.ts +4 -0
- package/dist/components/Amelipro/StructureMenu/StructureItem/types.d.ts +6 -0
- package/dist/components/Amelipro/StructureMenu/StructureList/StructureList.d.ts +62 -0
- package/dist/components/Amelipro/StructureMenu/StructureList/locales.d.ts +4 -0
- package/dist/components/Amelipro/StructureMenu/StructureMenu.d.ts +105 -0
- package/dist/components/Amelipro/StructureMenu/StructureTabs/StructureTabs.d.ts +176 -0
- package/dist/components/Amelipro/StructureMenu/StructureTabs/locales.d.ts +4 -0
- package/dist/components/Amelipro/StructureMenu/StructureTabs/types.d.ts +11 -0
- package/dist/components/Amelipro/StructureMenu/locales.d.ts +10 -0
- package/dist/components/Amelipro/StructureMenu/types.d.ts +34 -0
- package/dist/components/Amelipro/UserInformationSummary/UserInformationSummary.d.ts +25 -0
- package/dist/components/Amelipro/UserInformationSummary/types.d.ts +9 -0
- package/dist/components/Amelipro/UserMenu/UserMenu.d.ts +57 -0
- package/dist/components/Amelipro/UserMenu/UserMenuDetails/UserMenuDetails.d.ts +25 -0
- package/dist/components/Amelipro/UserMenu/UserMenuDetails/types.d.ts +20 -0
- package/dist/components/Amelipro/UserMenu/types.d.ts +8 -0
- package/dist/components/Amelipro/types.d.ts +4 -0
- package/dist/components/BackToTopBtn/BackToTopBtn.d.ts +1 -1
- package/dist/components/ChipList/ChipList.d.ts +1 -1
- package/dist/components/ContextualMenu/ContextualMenu.d.ts +2 -1
- package/dist/components/ContextualMenu/DeepMenu.d.ts +12 -0
- package/dist/components/ContextualMenu/types.d.ts +7 -0
- package/dist/components/CookieBanner/CookieBanner.d.ts +1 -1
- package/dist/components/CookiesSelection/CookiesSelection.d.ts +8 -4
- package/dist/components/{SelectBtnField → Customs/Selects/SelectBtnField}/AccessibiliteItems.d.ts +1 -1
- package/dist/components/{SelectBtnField → Customs/Selects/SelectBtnField}/SelectBtnField.d.ts +5 -5
- package/dist/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/AccessibiliteItems.d.ts +1 -1
- package/dist/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/SyBtnSelect.d.ts +5 -5
- package/dist/components/Customs/{SyInputSelect → Selects/SyInputSelect}/AccessibiliteItems.d.ts +1 -1
- package/dist/components/Customs/{SyInputSelect → Selects/SyInputSelect}/SyInputSelect.d.ts +9 -9
- package/dist/components/Customs/{SySelect → Selects/SySelect}/AccessibiliteItems.d.ts +1 -1
- package/dist/components/Customs/{SySelect → Selects/SySelect}/SySelect.d.ts +106 -86
- package/dist/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.d.ts +29 -0
- package/dist/components/Customs/SyCheckbox/SyCheckbox.d.ts +19 -13
- package/dist/components/Customs/SyCheckbox/locales.d.ts +3 -0
- package/dist/components/Customs/SyIcon/SyIcon.d.ts +11 -0
- package/dist/components/Customs/SyIcon/utils/iconUtils.d.ts +24 -0
- package/dist/components/Customs/SyPagination/SyPagination.d.ts +49 -0
- package/dist/components/Customs/SyTextField/SyTextField.d.ts +120 -100
- package/dist/components/DataList/DataList.d.ts +2 -2
- package/dist/components/DataList/DataListLoading/DataListLoading.d.ts +1 -1
- package/dist/components/DataListItem/DataListItem.d.ts +2 -2
- package/dist/components/DatePicker/ComplexDatePicker/ComplexDatePicker.d.ts +421 -296
- package/dist/components/DatePicker/DatePicker/DatePicker.d.ts +412 -287
- package/dist/components/DatePicker/DateTextInput/DateTextInput.d.ts +154 -134
- package/dist/components/DatePicker/composables/useIconState.d.ts +2 -2
- package/dist/components/DialogBox/DialogBox.d.ts +24 -16
- package/dist/components/DownloadBtn/DownloadBtn.d.ts +1 -1
- package/dist/components/ErrorPage/ErrorPage.d.ts +1 -1
- package/dist/components/ExternalLinks/ExternalLinks.d.ts +3 -3
- package/dist/components/FileList/FileList.d.ts +1 -1
- package/dist/components/FileList/UploadItem/UploadItem.d.ts +1 -1
- package/dist/components/FilePreview/FilePreview.d.ts +4 -4
- package/dist/components/FileUpload/FileUpload.d.ts +1 -1
- package/dist/components/FilterInline/FilterInline.d.ts +1 -1
- package/dist/components/FilterSideBar/FilterSideBar.d.ts +31 -19
- package/dist/components/FooterBar/FooterBar.d.ts +2 -2
- package/dist/components/LangBtn/LangBtn.d.ts +47 -27
- package/dist/components/Logo/Logo.d.ts +6 -6
- package/dist/components/Logo/LogoSize.d.ts +1 -1
- package/dist/components/NirField/NirField.d.ts +314 -274
- package/dist/components/NotificationBar/NotificationBar.d.ts +1 -1
- package/dist/components/PageContainer/PageContainer.d.ts +1 -1
- package/dist/components/PaginatedTable/PaginatedTable.d.ts +19 -1
- package/dist/components/PasswordField/PasswordField.d.ts +9 -9
- package/dist/components/PeriodField/PeriodField.d.ts +846 -596
- package/dist/components/PhoneField/PhoneField.d.ts +5 -5
- package/dist/components/RangeField/RangeField.d.ts +2 -2
- package/dist/components/RangeField/RangeSlider/RangeSlider.d.ts +2 -2
- package/dist/components/RatingPicker/EmotionPicker/EmotionPicker.d.ts +1 -1
- package/dist/components/RatingPicker/NumberPicker/NumberPicker.d.ts +1 -1
- package/dist/components/RatingPicker/RatingPicker.d.ts +1 -1
- package/dist/components/RatingPicker/StarsPicker/StarsPicker.d.ts +1 -1
- package/dist/components/SearchListField/SearchListField.d.ts +414 -2
- package/dist/components/SocialMediaLinks/SocialMediaLinks.d.ts +20 -0
- package/dist/components/SyAlert/SyAlert.d.ts +6 -2
- package/dist/components/SyTextArea/SyTextArea.d.ts +62 -51
- package/dist/components/TableToolbar/TableToolbar.d.ts +1 -1
- package/dist/components/Tables/SyServerTable/SyServerTable.d.ts +20 -29
- package/dist/components/Tables/SyTable/SyTable.d.ts +20 -29
- package/dist/components/Tables/common/SyTableFilter.d.ts +2 -2
- package/dist/components/Tables/common/SyTablePagination.d.ts +122 -102
- package/dist/components/Tables/common/filters/DateFilter.d.ts +2 -2
- package/dist/components/Tables/common/filters/NumberFilter.d.ts +2 -2
- package/dist/components/Tables/common/filters/PeriodFilter.d.ts +2 -2
- package/dist/components/Tables/common/filters/SelectFilter.d.ts +2 -2
- package/dist/components/Tables/common/filters/TextFilter.d.ts +2 -2
- package/dist/components/Tables/common/organizeColumns/OrganizeColumns.d.ts +24 -12
- package/dist/components/Tables/common/types.d.ts +4 -0
- package/dist/components/UploadWorkflow/UploadWorkflow.d.ts +12 -8
- package/dist/components/index.d.ts +100 -57
- package/dist/composables/date/useDatePickerAccessibility.d.ts +1 -0
- package/dist/composables/useError.d.ts +4 -0
- package/dist/design-system-v3.js +160 -100
- package/dist/design-system-v3.umd.cjs +1003 -11
- package/dist/designTokens/index.d.ts +6 -1
- package/dist/designTokens/tokens/amelipro/apColors.d.ts +73 -0
- package/dist/designTokens/tokens/amelipro/apContextual.d.ts +58 -0
- package/dist/designTokens/tokens/amelipro/apDarkTheme.d.ts +1 -0
- package/dist/designTokens/tokens/amelipro/apLightTheme.d.ts +8 -0
- package/dist/designTokens/tokens/amelipro/apSemantic.d.ts +87 -0
- package/dist/directives/rgaaSvgFix.d.ts +5 -0
- package/dist/main-DoYCrS2Q.js +26573 -0
- package/dist/main.d.ts +1 -0
- package/dist/services/NotificationService.d.ts +2 -2
- package/dist/style.css +1 -1
- package/dist/utils/amelipro/dateHelper/dateHelper.d.ts +48 -0
- package/dist/utils/amelipro/numberHelper/numberHelper.d.ts +8 -0
- package/dist/utils/amelipro/rules/maxNumber/index.d.ts +3 -0
- package/dist/utils/amelipro/rules/minNumber/index.d.ts +3 -0
- package/dist/utils/amelipro/rules/notAfterDate/index.d.ts +3 -0
- package/dist/utils/amelipro/rules/notBeforeDate/index.d.ts +3 -0
- package/dist/utils/functions/ameliproColors/ameliproColors.d.ts +2 -0
- package/dist/utils/functions/ameliproColors/types.d.ts +5 -0
- package/dist/utils/functions/classToHex.d.ts +1 -0
- package/dist/utils/functions/convertToHex.d.ts +1 -0
- package/dist/utils/functions/isCssColor.d.ts +1 -0
- package/dist/utils/index.d.ts +19 -0
- package/dist/vuetifyConfig.d.ts +4 -3
- package/package.json +1 -1
- package/src/assets/_elevations.scss +30 -0
- package/src/assets/_radius.scss +17 -0
- package/src/assets/_spacers.scss +61 -4
- package/src/assets/amelipro/apTokens.scss +315 -0
- package/src/assets/amelipro/icons/btn_structures.svg +19 -0
- package/src/assets/amelipro/icons/ga.svg +23 -0
- package/src/assets/amelipro/icons/icone_dsg.svg +29 -0
- package/src/assets/amelipro/icons/icone_hr.svg +30 -0
- package/src/assets/amelipro/icons/icone_infosPatient_actif.svg +30 -0
- package/src/assets/amelipro/icons/icone_mes_commandes.svg +31 -0
- package/src/assets/amelipro/icons/icone_pse.svg +34 -0
- package/src/assets/amelipro/icons/info.svg +16 -0
- package/src/assets/amelipro/icons/releve_activites_fb.svg +22 -0
- package/src/assets/amelipro/icons/retourHaut_fb.svg +11 -0
- package/src/assets/amelipro/icons/shc.svg +19 -0
- package/src/assets/amelipro/icons.ts +1141 -0
- package/src/assets/amelipro/img/amelipro.svg +1 -0
- package/src/assets/amelipro/img/cartouche_nouveauTEL.svg +47 -0
- package/src/assets/amelipro/img/logo-menu.svg +52 -0
- package/src/assets/settings.scss +6 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.mdx +15 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.stories.ts +170 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.vue +393 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/__tests__/AmeliproAutoCompleteField.spec.ts +62 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/__tests__/__snapshots__/AmeliproAutoCompleteField.spec.ts.snap +245 -0
- package/src/components/Amelipro/AmeliproAutoCompleteField/types.d.ts +12 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/AmeliproBreadcrumb.mdx +15 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/AmeliproBreadcrumb.stories.ts +92 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/AmeliproBreadcrumb.vue +89 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/__tests__/AmeliproBreadcrumb.spec.ts +37 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/__tests__/__snapshots__/AmeliproBreadcrumb.spec.ts.snap +192 -0
- package/src/components/Amelipro/AmeliproBreadcrumb/types.d.ts +8 -0
- package/src/components/Amelipro/AmeliproBtn/AmeliproBtn.mdx +24 -0
- package/src/components/Amelipro/AmeliproBtn/AmeliproBtn.stories.ts +182 -0
- package/src/components/Amelipro/AmeliproBtn/AmeliproBtn.vue +382 -0
- package/src/components/Amelipro/AmeliproBtn/tests/AmeliproBtn.spec.ts +22 -0
- package/src/components/Amelipro/AmeliproBtn/tests/__snapshots__/AmeliproBtn.spec.ts.snap +42 -0
- package/src/components/Amelipro/AmeliproCallback/AmeliproCallback.mdx +21 -0
- package/src/components/Amelipro/AmeliproCallback/AmeliproCallback.stories.ts +69 -0
- package/src/components/Amelipro/AmeliproCallback/AmeliproCallback.vue +170 -0
- package/src/components/Amelipro/AmeliproCallback/tests/AmeliproCallback.spec.ts +21 -0
- package/src/components/Amelipro/AmeliproCallback/tests/__snapshots__/AmeliproCallback.spec.ts.snap +154 -0
- package/src/components/Amelipro/AmeliproCard/AmeliproCard.mdx +15 -0
- package/src/components/Amelipro/AmeliproCard/AmeliproCard.stories.ts +95 -0
- package/src/components/Amelipro/AmeliproCard/AmeliproCard.vue +312 -0
- package/src/components/Amelipro/AmeliproCard/tests/AmeliproCard.spec.ts +23 -0
- package/src/components/Amelipro/AmeliproCard/tests/__snapshots__/AmeliproCard.spec.ts.snap +71 -0
- package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.mdx +15 -0
- package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.stories.ts +104 -0
- package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.vue +276 -0
- package/src/components/Amelipro/AmeliproCheckbox/tests/AmeliproCheckbox.spec.ts +23 -0
- package/src/components/Amelipro/AmeliproCheckbox/tests/__snapshots__/AmeliproCheckbox.spec.ts.snap +40 -0
- package/src/components/Amelipro/AmeliproCheckbox/types.d.ts +5 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.mdx +15 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.stories.ts +176 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.vue +396 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/tests/AmeliproCheckboxGroup.spec.ts +50 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/tests/__snapshots__/AmeliproCheckboxGroup.spec.ts.snap +249 -0
- package/src/components/Amelipro/AmeliproCheckboxGroup/types.d.ts +7 -0
- package/src/components/Amelipro/AmeliproChips/AmeliproChips.mdx +15 -0
- package/src/components/Amelipro/AmeliproChips/AmeliproChips.stories.ts +54 -0
- package/src/components/Amelipro/AmeliproChips/AmeliproChips.vue +51 -0
- package/src/components/Amelipro/AmeliproChips/tests/AmeliproChips.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproChips/tests/__snapshots__/AmeliproChips.spec.ts.snap +94 -0
- package/src/components/Amelipro/AmeliproDialog/AmeliproDialog.mdx +30 -0
- package/src/components/Amelipro/AmeliproDialog/AmeliproDialog.stories.ts +130 -0
- package/src/components/Amelipro/AmeliproDialog/AmeliproDialog.vue +326 -0
- package/src/components/Amelipro/AmeliproDialog/tests/AmeliproDialog.spec.ts +26 -0
- package/src/components/Amelipro/AmeliproDialog/tests/__snapshots__/AmeliproDialog.spec.ts.snap +126 -0
- package/src/components/Amelipro/AmeliproDisclosure/AmeliproDisclosure.mdx +15 -0
- package/src/components/Amelipro/AmeliproDisclosure/AmeliproDisclosure.stories.ts +58 -0
- package/src/components/Amelipro/AmeliproDisclosure/AmeliproDisclosure.vue +78 -0
- package/src/components/Amelipro/AmeliproDisclosure/tests/AmeliproDisclosure.spec.ts +23 -0
- package/src/components/Amelipro/AmeliproDisclosure/tests/__snapshots__/AmeliproDisclosure.spec.ts.snap +88 -0
- package/src/components/Amelipro/AmeliproFooter/A11yComplianceEnum.ts +7 -0
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.mdx +15 -0
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.stories.ts +105 -0
- package/src/components/Amelipro/AmeliproFooter/AmeliproFooter.vue +415 -0
- package/src/components/Amelipro/AmeliproFooter/locales.ts +16 -0
- package/src/components/Amelipro/AmeliproFooter/tests/AmeliproFooter.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproFooter/tests/__snapshots__/AmeliproFooter.spec.ts.snap +404 -0
- package/src/components/Amelipro/AmeliproFooter/types.d.ts +34 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeader.mdx +15 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeader.stories.ts +746 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeader.vue +487 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBar.vue +131 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/AmeliproHeaderBrandSection.vue +239 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/dividerDimensionsMapping.ts +16 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/locales.ts +7 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/tests/AmeliproHeaderBrandSection.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/tests/__snapshots__/AmeliproHeaderBrandSection.spec.ts.snap +132 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/types.d.ts +4 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/AmeliproLogoAm.vue +133 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/LogoSizeEnum.ts +5 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/locales.ts +5 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/logoDimensionsMapping.ts +17 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/tests/AmeliproLogoAm.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproLogoAm/tests/__snapshots__/AmeliproLogoAm.spec.ts.snap +92 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/tests/AmeliproHeaderBar.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/tests/__snapshots__/AmeliproHeaderBar.spec.ts.snap +170 -0
- package/src/components/Amelipro/AmeliproHeader/tests/AmeliproHeader.spec.ts +163 -0
- package/src/components/Amelipro/AmeliproHeader/tests/__snapshots__/AmeliproHeader.spec.ts.snap +1448 -0
- package/src/components/Amelipro/AmeliproHeader/types.d.ts +25 -0
- package/src/components/Amelipro/AmeliproIcon/AmeliproIcon.mdx +17 -0
- package/src/components/Amelipro/AmeliproIcon/AmeliproIcon.stories.ts +101 -0
- package/src/components/Amelipro/AmeliproIcon/AmeliproIcon.vue +248 -0
- package/src/components/Amelipro/AmeliproIcon/iconList.ts +230 -0
- package/src/components/Amelipro/AmeliproIcon/tests/AmeliproIcon.spec.ts +23 -0
- package/src/components/Amelipro/AmeliproIcon/tests/__snapshots__/AmeliproIcon.spec.ts.snap +46 -0
- package/src/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.mdx +17 -0
- package/src/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.stories.ts +81 -0
- package/src/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.vue +318 -0
- package/src/components/Amelipro/AmeliproIconBtn/tests/AmeliproIconBtn.spec.ts +26 -0
- package/src/components/Amelipro/AmeliproIconBtn/tests/__snapshots__/AmeliproIconBtn.spec.ts.snap +84 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.mdx +15 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.stories.ts +67 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.vue +174 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/tests/AmeliproIllustratedDataTile.spec.ts +24 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/tests/__snapshots__/AmeliproIllustratedDataTile.spec.ts.snap +66 -0
- package/src/components/Amelipro/AmeliproIllustratedDataTile/types.d.ts +4 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.mdx +15 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.stories.ts +162 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.vue +252 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/locales.ts +1 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/tests/AmeliproIllustratedRadioGroup.spec.ts +57 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/tests/__snapshots__/AmeliproIllustratedRadioGroup.spec.ts.snap +524 -0
- package/src/components/Amelipro/AmeliproIllustratedRadioGroup/types.d.ts +8 -0
- package/src/components/Amelipro/AmeliproMailTile/AmeliproMailTile.mdx +15 -0
- package/src/components/Amelipro/AmeliproMailTile/AmeliproMailTile.stories.ts +151 -0
- package/src/components/Amelipro/AmeliproMailTile/AmeliproMailTile.vue +408 -0
- package/src/components/Amelipro/AmeliproMailTile/tests/AmeliproMailTile.spec.ts +29 -0
- package/src/components/Amelipro/AmeliproMailTile/tests/__snapshots__/AmeliproMailTile.spec.ts.snap +160 -0
- package/src/components/Amelipro/AmeliproMailTile/types.d.ts +14 -0
- package/src/components/Amelipro/AmeliproMenu/AmeliproMenu.mdx +15 -0
- package/src/components/Amelipro/AmeliproMenu/AmeliproMenu.stories.ts +205 -0
- package/src/components/Amelipro/AmeliproMenu/AmeliproMenu.vue +390 -0
- package/src/components/Amelipro/AmeliproMenu/tests/AmeliproMenu.spec.ts +87 -0
- package/src/components/Amelipro/AmeliproMenu/tests/__snapshots__/AmeliproMenu.spec.ts.snap +475 -0
- package/src/components/Amelipro/AmeliproMenu/types.d.ts +10 -0
- package/src/components/Amelipro/AmeliproMessage/AmeliproMessage.mdx +17 -0
- package/src/components/Amelipro/AmeliproMessage/AmeliproMessage.stories.ts +127 -0
- package/src/components/Amelipro/AmeliproMessage/AmeliproMessage.vue +253 -0
- package/src/components/Amelipro/AmeliproMessage/AmeliproMessageTypes.ts +26 -0
- package/src/components/Amelipro/AmeliproMessage/tests/AmeliproMessage.spec.ts +22 -0
- package/src/components/Amelipro/AmeliproMessage/tests/__snapshots__/AmeliproMessage.spec.ts.snap +85 -0
- package/src/components/Amelipro/AmeliproMessage/types.d.ts +7 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/AmeliproDropdownMenu.vue +225 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/AmeliproDropdownMenuBtn/AmeliproDropdownMenuBtn.vue +85 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/AmeliproDropdownMenuBtn/tests/AmeliproDropdownMenuBtn.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/AmeliproDropdownMenuBtn/tests/__snapshots__/AmeliproDropdownMenuBtn.spec.ts.snap +52 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/tests/AmeliproDropdownMenu.spec.ts +32 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/tests/__snapshots__/AmeliproDropdownMenu.spec.ts.snap +280 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproDropdownMenu/types.d.ts +8 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingLayout.mdx +15 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingLayout.stories.ts +149 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingLayout.vue +191 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingMenuBtn/AmeliproMessagingMenuBtn.vue +98 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingMenuBtn/tests/AmeliproMessagingMenuBtn.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/AmeliproMessagingMenuBtn/tests/__snapshots__/AmeliproMessagingMenuBtn.spec.ts.snap +81 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/tests/AmeliproMessagingLayout.spec.ts +34 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/tests/__snapshots__/AmeliproMessagingLayout.spec.ts.snap +405 -0
- package/src/components/Amelipro/AmeliproMessagingLayout/types.d.ts +10 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.mdx +15 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.stories.ts +146 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.vue +378 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/tests/AmeliproMultipleFoldingCard.spec.ts +44 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/tests/__snapshots__/AmeliproMultipleFoldingCard.spec.ts.snap +359 -0
- package/src/components/Amelipro/AmeliproMultipleFoldingCard/types.d.ts +6 -0
- package/src/components/Amelipro/AmeliproNumberedCard/AmeliproNumberedCard.mdx +22 -0
- package/src/components/Amelipro/AmeliproNumberedCard/AmeliproNumberedCard.stories.ts +178 -0
- package/src/components/Amelipro/AmeliproNumberedCard/AmeliproNumberedCard.vue +270 -0
- package/src/components/Amelipro/AmeliproNumberedCard/tests/AmeliproNumberedCard.spec.ts +27 -0
- package/src/components/Amelipro/AmeliproNumberedCard/tests/__snapshots__/AmeliproNumberedCard.spec.ts.snap +160 -0
- package/src/components/Amelipro/AmeliproNumberedCard/types.d.ts +4 -0
- package/src/components/Amelipro/AmeliproOnboarding/AmeliproOnboarding.mdx +15 -0
- package/src/components/Amelipro/AmeliproOnboarding/AmeliproOnboarding.stories.ts +160 -0
- package/src/components/Amelipro/AmeliproOnboarding/AmeliproOnboarding.vue +242 -0
- package/src/components/Amelipro/AmeliproOnboarding/tests/AmeliproOnboarding.spec.ts +45 -0
- package/src/components/Amelipro/AmeliproOnboarding/tests/__snapshots__/AmeliproOnboarding.spec.ts.snap +3 -0
- package/src/components/Amelipro/AmeliproOnboarding/types.d.ts +5 -0
- package/src/components/Amelipro/AmeliproPageLayout/AmeliproPageLayout.mdx +15 -0
- package/src/components/Amelipro/AmeliproPageLayout/AmeliproPageLayout.stories.ts +746 -0
- package/src/components/Amelipro/AmeliproPageLayout/AmeliproPageLayout.vue +252 -0
- package/src/components/Amelipro/AmeliproPageLayout/locales.ts +1 -0
- package/src/components/Amelipro/AmeliproPageLayout/tests/AmeliproPageLayout.spec.ts +187 -0
- package/src/components/Amelipro/AmeliproPageLayout/tests/__snapshots__/AmeliproPageLayout.spec.ts.snap +2144 -0
- package/src/components/Amelipro/AmeliproPageLayout/types.d.ts +15 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPagination.mdx +15 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPagination.stories.ts +96 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPagination.vue +161 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/AmeliproPaginationBtn.vue +84 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/tests/AmeliproPaginationBtn.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/tests/__snapshots__/AmeliproPaginationBtn.spec.ts.snap +42 -0
- package/src/components/Amelipro/AmeliproPagination/tests/AmeliproPagination.spec.ts +19 -0
- package/src/components/Amelipro/AmeliproPagination/tests/__snapshots__/AmeliproPagination.spec.ts.snap +108 -0
- package/src/components/Amelipro/AmeliproPagination/types.d.ts +5 -0
- package/src/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.mdx +57 -0
- package/src/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.stories.ts +78 -0
- package/src/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.vue +219 -0
- package/src/components/Amelipro/AmeliproPatientBanner/locales.ts +6 -0
- package/src/components/Amelipro/AmeliproPatientBanner/tests/AmeliproPatientBanner.spec.ts +28 -0
- package/src/components/Amelipro/AmeliproPatientBanner/tests/__snapshots__/AmeliproPatientBanner.spec.ts.snap +246 -0
- package/src/components/Amelipro/AmeliproPatientBanner/types.d.ts +16 -0
- package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.mdx +15 -0
- package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.stories.ts +148 -0
- package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.vue +391 -0
- package/src/components/Amelipro/AmeliproRadioGroup/locales.ts +1 -0
- package/src/components/Amelipro/AmeliproRadioGroup/tests/AmeliproRadioGroup.spec.ts +47 -0
- package/src/components/Amelipro/AmeliproRadioGroup/tests/__snapshots__/AmeliproRadioGroup.spec.ts.snap +262 -0
- package/src/components/Amelipro/AmeliproRadioGroup/types.d.ts +6 -0
- package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.mdx +15 -0
- package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.stories.ts +160 -0
- package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.vue +373 -0
- package/src/components/Amelipro/AmeliproSelect/tests/AmeliproSelect.spec.ts +42 -0
- package/src/components/Amelipro/AmeliproSelect/tests/__snapshots__/AmeliproSelect.spec.ts.snap +186 -0
- package/src/components/Amelipro/AmeliproSelect/types.d.ts +10 -0
- package/src/components/Amelipro/AmeliproStateTile/AmeliproStateTile.mdx +15 -0
- package/src/components/Amelipro/AmeliproStateTile/AmeliproStateTile.stories.ts +86 -0
- package/src/components/Amelipro/AmeliproStateTile/AmeliproStateTile.vue +362 -0
- package/src/components/Amelipro/AmeliproStateTile/AmeliproStateTileTypes.ts +51 -0
- package/src/components/Amelipro/AmeliproStateTile/tests/AmeliproStateTile.spec.ts +24 -0
- package/src/components/Amelipro/AmeliproStateTile/tests/__snapshots__/AmeliproStateTile.spec.ts.snap +79 -0
- package/src/components/Amelipro/AmeliproStateTile/types.d.ts +11 -0
- package/src/components/Amelipro/AmeliproStatus/AmeliproStatus.mdx +15 -0
- package/src/components/Amelipro/AmeliproStatus/AmeliproStatus.stories.ts +56 -0
- package/src/components/Amelipro/AmeliproStatus/AmeliproStatus.vue +63 -0
- package/src/components/Amelipro/AmeliproStatus/AmeliproStatusTypes.ts +36 -0
- package/src/components/Amelipro/AmeliproStatus/tests/AmeliproStatus.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproStatus/tests/__snapshots__/AmeliproStatus.spec.ts.snap +17 -0
- package/src/components/Amelipro/AmeliproStatus/types.d.ts +5 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepBtn/AmeliproStepBtn.vue +70 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepBtn/tests/AmeliproStepBtn.spec.ts +22 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepBtn/tests/__snapshots__/AmeliproStepBtn.spec.ts.snap +28 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepper.mdx +15 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepper.stories.ts +145 -0
- package/src/components/Amelipro/AmeliproStepper/AmeliproStepper.vue +416 -0
- package/src/components/Amelipro/AmeliproStepper/tests/AmeliproStepper.spec.ts +40 -0
- package/src/components/Amelipro/AmeliproStepper/tests/__snapshots__/AmeliproStepper.spec.ts.snap +312 -0
- package/src/components/Amelipro/AmeliproStepper/types.d.ts +5 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabBtn/AmeliproTabBtn.vue +196 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabBtn/tests/AmeliproTabBtn.spec.ts +24 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabBtn/tests/__snapshots__/AmeliproTabBtn.spec.ts.snap +30 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabs.mdx +23 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabs.stories.ts +204 -0
- package/src/components/Amelipro/AmeliproTabs/AmeliproTabs.vue +333 -0
- package/src/components/Amelipro/AmeliproTabs/tests/AmeliproTabs.spec.ts +43 -0
- package/src/components/Amelipro/AmeliproTabs/tests/__snapshots__/AmeliproTabs.spec.ts.snap +200 -0
- package/src/components/Amelipro/AmeliproTabs/types.d.ts +11 -0
- package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.mdx +18 -0
- package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.stories.ts +90 -0
- package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.vue +321 -0
- package/src/components/Amelipro/AmeliproTextArea/__tests__/AmeliproTextArea.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproTextArea/__tests__/__snapshots__/AmeliproTextArea.spec.ts.snap +174 -0
- package/src/components/Amelipro/AmeliproTextArea/types.d.ts +4 -0
- package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.mdx +35 -0
- package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.stories.ts +238 -0
- package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.vue +390 -0
- package/src/components/Amelipro/AmeliproTextField/tests/AmeliproTextField.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproTextField/tests/__snapshots__/AmeliproTextField.spec.ts.snap +155 -0
- package/src/components/Amelipro/AmeliproTextField/types.d.ts +4 -0
- package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.mdx +18 -0
- package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.stories.ts +135 -0
- package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.vue +360 -0
- package/src/components/Amelipro/AmeliproTileBtn/tests/AmeliproTileBtn.spec.ts +21 -0
- package/src/components/Amelipro/AmeliproTileBtn/tests/__snapshots__/AmeliproTileBtn.spec.ts.snap +58 -0
- package/src/components/Amelipro/AmeliproTooltips/AmeliproTooltips.mdx +15 -0
- package/src/components/Amelipro/AmeliproTooltips/AmeliproTooltips.stories.ts +60 -0
- package/src/components/Amelipro/AmeliproTooltips/AmeliproTooltips.vue +114 -0
- package/src/components/Amelipro/AmeliproTooltips/tests/AmeliproTooltips.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproTooltips/tests/__snapshots__/AmeliproTooltips.spec.ts.snap +100 -0
- package/src/components/Amelipro/AmeliproTransmission/AmeliproTransmission.mdx +24 -0
- package/src/components/Amelipro/AmeliproTransmission/AmeliproTransmission.stories.ts +67 -0
- package/src/components/Amelipro/AmeliproTransmission/AmeliproTransmission.vue +139 -0
- package/src/components/Amelipro/AmeliproTransmission/tests/AmeliproTransmission.spec.ts +20 -0
- package/src/components/Amelipro/AmeliproTransmission/tests/__snapshots__/AmeliproTransmission.spec.ts.snap +225 -0
- package/src/components/Amelipro/ServiceMenu/ServiceBtn/ServiceBtn.vue +113 -0
- package/src/components/Amelipro/ServiceMenu/ServiceBtn/tests/ServiceBtn.spec.ts +25 -0
- package/src/components/Amelipro/ServiceMenu/ServiceBtn/tests/__snapshots__/ServiceBtn.spec.ts.snap +93 -0
- package/src/components/Amelipro/ServiceMenu/ServiceBtn/types.d.ts +8 -0
- package/src/components/Amelipro/ServiceMenu/ServiceList/ServiceList.vue +96 -0
- package/src/components/Amelipro/ServiceMenu/ServiceList/tests/ServiceList.spec.ts +29 -0
- package/src/components/Amelipro/ServiceMenu/ServiceList/tests/__snapshots__/ServiceList.spec.ts.snap +231 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenu.mdx +15 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenu.stories.ts +338 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenu.vue +183 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/ServiceMenuContent.vue +135 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/tests/ServiceMenuContent.spec.ts +49 -0
- package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/tests/__snapshots__/ServiceMenuContent.spec.ts.snap +733 -0
- package/src/components/Amelipro/ServiceMenu/tests/ServiceMenu.spec.ts +50 -0
- package/src/components/Amelipro/ServiceMenu/tests/__snapshots__/ServiceMenu.spec.ts.snap +863 -0
- package/src/components/Amelipro/ServiceMenu/types.d.ts +13 -0
- package/src/components/Amelipro/StructureMenu/StructureBtn/StructureBtn.vue +76 -0
- package/src/components/Amelipro/StructureMenu/StructureBtn/tests/StructureBtn.spec.ts +21 -0
- package/src/components/Amelipro/StructureMenu/StructureBtn/tests/__snapshots__/StructureBtn.spec.ts.snap +34 -0
- package/src/components/Amelipro/StructureMenu/StructureItem/StructureItem.vue +129 -0
- package/src/components/Amelipro/StructureMenu/StructureItem/locales.ts +4 -0
- package/src/components/Amelipro/StructureMenu/StructureItem/tests/StructureItem.spec.ts +25 -0
- package/src/components/Amelipro/StructureMenu/StructureItem/tests/__snapshots__/StructureItem.spec.ts.snap +102 -0
- package/src/components/Amelipro/StructureMenu/StructureItem/types.d.ts +6 -0
- package/src/components/Amelipro/StructureMenu/StructureList/StructureList.vue +130 -0
- package/src/components/Amelipro/StructureMenu/StructureList/locales.ts +4 -0
- package/src/components/Amelipro/StructureMenu/StructureList/tests/StructureList.spec.ts +37 -0
- package/src/components/Amelipro/StructureMenu/StructureList/tests/__snapshots__/StructureList.spec.ts.snap +342 -0
- package/src/components/Amelipro/StructureMenu/StructureMenu.mdx +15 -0
- package/src/components/Amelipro/StructureMenu/StructureMenu.stories.ts +268 -0
- package/src/components/Amelipro/StructureMenu/StructureMenu.vue +240 -0
- package/src/components/Amelipro/StructureMenu/StructureTabs/StructureTabs.vue +167 -0
- package/src/components/Amelipro/StructureMenu/StructureTabs/locales.ts +4 -0
- package/src/components/Amelipro/StructureMenu/StructureTabs/tests/StructureTabs.spec.ts +64 -0
- package/src/components/Amelipro/StructureMenu/StructureTabs/tests/__snapshots__/StructureTabs.spec.ts.snap +801 -0
- package/src/components/Amelipro/StructureMenu/StructureTabs/types.d.ts +12 -0
- package/src/components/Amelipro/StructureMenu/locales.ts +10 -0
- package/src/components/Amelipro/StructureMenu/tests/StructureMenu.spec.ts +71 -0
- package/src/components/Amelipro/StructureMenu/tests/__snapshots__/StructureMenu.spec.ts.snap +1321 -0
- package/src/components/Amelipro/StructureMenu/types.d.ts +35 -0
- package/src/components/Amelipro/UserInformationSummary/UserInformationSummary.vue +73 -0
- package/src/components/Amelipro/UserInformationSummary/tests/UserInformationSummary.spec.ts +28 -0
- package/src/components/Amelipro/UserInformationSummary/tests/__snapshots__/UserInformationSummary.spec.ts.snap +80 -0
- package/src/components/Amelipro/UserInformationSummary/types.d.ts +9 -0
- package/src/components/Amelipro/UserMenu/UserMenu.mdx +15 -0
- package/src/components/Amelipro/UserMenu/UserMenu.stories.ts +133 -0
- package/src/components/Amelipro/UserMenu/UserMenu.vue +169 -0
- package/src/components/Amelipro/UserMenu/UserMenuDetails/UserMenuDetails.vue +99 -0
- package/src/components/Amelipro/UserMenu/UserMenuDetails/tests/UserMenuDetails.spec.ts +37 -0
- package/src/components/Amelipro/UserMenu/UserMenuDetails/tests/__snapshots__/UserMenuDetails.spec.ts.snap +3 -0
- package/src/components/Amelipro/UserMenu/UserMenuDetails/types.d.ts +20 -0
- package/src/components/Amelipro/UserMenu/tests/UserMenu.spec.ts +38 -0
- package/src/components/Amelipro/UserMenu/tests/__snapshots__/UserMenu.spec.ts.snap +91 -0
- package/src/components/Amelipro/UserMenu/types.d.ts +9 -0
- package/src/components/Amelipro/types.ts +5 -0
- package/src/components/CollapsibleList/Accessibilite.stories.ts +4 -0
- package/src/components/CollapsibleList/CollapsibleList.vue +23 -8
- package/src/components/ContextualMenu/Accessibilite.stories.ts +4 -0
- package/src/components/ContextualMenu/ContextualMenu.stories.ts +58 -28
- package/src/components/ContextualMenu/ContextualMenu.vue +87 -54
- package/src/components/ContextualMenu/DeepMenu.vue +82 -0
- package/src/components/ContextualMenu/tests/ContextualMenu.spec.ts +154 -0
- package/src/components/ContextualMenu/tests/__snapshots__/ContextualMenu.spec.ts.snap +436 -31
- package/src/components/ContextualMenu/types.ts +8 -0
- package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/Accessibilite.stories.ts +1 -1
- package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/SelectBtnField.mdx +1 -1
- package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/SelectBtnField.stories.ts +2 -2
- package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/Usages.stories.ts +1 -1
- package/src/components/Customs/Selects/SelectOverview.mdx +350 -0
- package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/Accessibilite.stories.ts +1 -1
- package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/SyBtnSelect.mdx +1 -1
- package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/SyBtnSelect.stories.ts +1 -1
- package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/Accessibilite.stories.ts +1 -1
- package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/SyInputSelect.mdx +1 -1
- package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/SyInputSelect.stories.ts +2 -2
- package/src/components/Customs/Selects/SySelect/Accessibilite.mdx +204 -0
- package/src/components/Customs/{SySelect → Selects/SySelect}/Accessibilite.stories.ts +73 -3
- package/src/components/Customs/{SySelect → Selects/SySelect}/SySelect.mdx +1 -1
- package/src/components/Customs/{SySelect → Selects/SySelect}/SySelect.stories.ts +43 -15
- package/src/components/Customs/{SySelect → Selects/SySelect}/SySelect.vue +191 -44
- package/src/components/Customs/{SySelect → Selects/SySelect}/Usages.stories.ts +1 -1
- package/src/components/Customs/Selects/SySelect/composables/tests/useSySelectKeyboard.spec.ts +272 -0
- package/src/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.ts +272 -0
- package/src/components/Customs/SyCheckbox/SyCheckbox.vue +72 -47
- package/src/components/Customs/SyCheckbox/locales.ts +3 -0
- package/src/components/Customs/SyIcon/Accessibilite.mdx +103 -0
- package/src/components/Customs/SyIcon/Accessibilite.stories.ts +27 -0
- package/src/components/Customs/SyIcon/SyIcon.mdx +72 -0
- package/src/components/Customs/SyIcon/SyIcon.spec.ts +127 -0
- package/src/components/Customs/SyIcon/SyIcon.stories.ts +310 -0
- package/src/components/Customs/SyIcon/SyIcon.vue +72 -0
- package/src/components/Customs/SyIcon/SyIconAccessibility.vue +306 -0
- package/src/components/Customs/SyIcon/utils/iconUtils.ts +52 -0
- package/src/components/Customs/SyPagination/SyPagination.mdx +150 -0
- package/src/components/Customs/SyPagination/SyPagination.stories.ts +213 -0
- package/src/components/Customs/SyPagination/SyPagination.vue +437 -0
- package/src/components/Customs/SyPagination/tests/SyPagination.spec.ts +179 -0
- package/src/components/DatePicker/DatePicker/DatePicker.vue +6 -5
- package/src/components/DatePicker/DateTextInput/DateTextInput.vue +3 -1
- package/src/components/DatePicker/composables/useMonthButtonCustomization.ts +4 -4
- package/src/components/FilterSideBar/FilterSideBar.vue +3 -2
- package/src/components/FilterSideBar/tests/FilterSideBar.spec.ts +1 -1
- package/src/components/MaintenancePage/Accessibilite.stories.ts +8 -0
- package/src/components/MaintenancePage/MaintenancePage.vue +3 -2
- package/src/components/MaintenancePage/tests/__snapshots__/MaintenancePage.spec.ts.snap +1 -2
- package/src/components/PaginatedTable/PaginatedTable.stories.ts +22 -0
- package/src/components/PaginatedTable/PaginatedTable.vue +10 -2
- package/src/components/PhoneField/PhoneField.vue +1 -1
- package/src/components/RatingPicker/NumberPicker/NumberPicker.vue +2 -2
- package/src/components/RatingPicker/RatingPicker.stories.ts +1 -1
- package/src/components/SearchListField/SearchListField.mdx +1 -1
- package/src/components/SearchListField/SearchListField.stories.ts +7 -1
- package/src/components/SearchListField/SearchListField.vue +33 -49
- package/src/components/SocialMediaLinks/Accessibilite.stories.ts +8 -0
- package/src/components/SocialMediaLinks/SocialMediaLinks.stories.ts +34 -2
- package/src/components/SocialMediaLinks/SocialMediaLinks.vue +43 -8
- package/src/components/SocialMediaLinks/tests/SocialMediaLinks.spec.ts +98 -2
- package/src/components/SocialMediaLinks/tests/__snapshots__/SocialMediaLinks.spec.ts.snap +76 -8
- package/src/components/TableToolbar/TableToolbar.stories.ts +1 -1
- package/src/components/Tables/SyServerTable/SyServerTable.mdx +11 -1
- package/src/components/Tables/SyServerTable/SyServerTable.stories.ts +1007 -140
- package/src/components/Tables/SyServerTable/SyServerTable.vue +16 -2
- package/src/components/Tables/SyTable/SyTable.mdx +11 -1
- package/src/components/Tables/SyTable/SyTable.stories.ts +607 -0
- package/src/components/Tables/SyTable/SyTable.vue +15 -0
- package/src/components/Tables/common/SyTablePagination.vue +19 -191
- package/src/components/Tables/common/TableHeader.vue +37 -8
- package/src/components/Tables/common/filters/SelectFilter.vue +1 -1
- package/src/components/Tables/common/filters/tests/SelectFilter.spec.ts +1 -1
- package/src/components/Tables/common/tests/SyTablePagination.spec.ts +5 -2
- package/src/components/Tables/common/tests/TableHeader.spec.ts +272 -0
- package/src/components/Tables/common/types.ts +4 -0
- package/src/components/UserMenuBtn/UserMenuBtn.vue +1 -1
- package/src/components/index.ts +151 -57
- package/src/composables/date/useDatePickerAccessibility.ts +163 -14
- package/src/composables/useError.ts +9 -0
- package/src/designTokens/apColors.md +66 -0
- package/src/designTokens/index.ts +10 -0
- package/src/designTokens/tokens/amelipro/apColors.ts +81 -0
- package/src/designTokens/tokens/amelipro/apContextual.ts +58 -0
- package/src/designTokens/tokens/amelipro/apDarkTheme.ts +5 -0
- package/src/designTokens/tokens/amelipro/apLightTheme.ts +13 -0
- package/src/designTokens/tokens/amelipro/apSemantic.ts +87 -0
- package/src/directives/rgaaSvgFix.ts +279 -0
- package/src/main.ts +1 -0
- package/src/stories/Accessibilite/Avancement/Avancement.mdx +2 -2
- package/src/stories/Accessibilite/Avancement/Avancement.stories.ts +10 -9
- package/src/stories/Accessibilite/Vuetify/Vuetify.mdx +39 -0
- package/src/stories/Accessibilite/Vuetify/VuetifyItems.ts +20 -3
- package/src/stories/Demarrer/Accueil.mdx +1 -1
- package/src/stories/Demarrer/Accueil.stories.ts +75 -51
- package/src/stories/Demarrer/Releases.stories.ts +3 -0
- package/src/stories/DesignTokens/ColorDisplay.vue +117 -28
- package/src/stories/DesignTokens/Colors.mdx +9 -27
- package/src/stories/DesignTokens/colors.stories.ts +507 -23
- package/src/stories/Directives/SvgDirective.mdx +432 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/DataUtilities.mdx +318 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/DomBrowserUtilities.mdx +344 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/FormattingUtilities.mdx +287 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/StorageUtilities.mdx +145 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/ValidationRules.mdx +437 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/ValidationUtilities.mdx +364 -0
- package/src/stories/GuideDuDev/ClassesUtilitaires/index.mdx +292 -0
- package/src/stories/GuideDuDev/PortailAgent.stories.ts +45 -25
- package/src/stories/GuideDuDev/Theme.mdx +2 -1
- package/src/utils/amelipro/dateHelper/dateHelper.ts +97 -0
- package/src/utils/amelipro/dateHelper/tests/dateHelper.spec.ts +49 -0
- package/src/utils/amelipro/numberHelper/numberHelper.ts +20 -0
- package/src/utils/amelipro/numberHelper/tests/numberHelper.spec.ts +24 -0
- package/src/utils/amelipro/rules/maxNumber/index.ts +24 -0
- package/src/utils/amelipro/rules/maxNumber/tests/maxNumber.spec.ts +22 -0
- package/src/utils/amelipro/rules/minNumber/index.ts +24 -0
- package/src/utils/amelipro/rules/minNumber/tests/minNumber.spec.ts +22 -0
- package/src/utils/amelipro/rules/notAfterDate/index.ts +33 -0
- package/src/utils/amelipro/rules/notAfterDate/tests/notAfterDate.spec.ts +32 -0
- package/src/utils/amelipro/rules/notBeforeDate/index.ts +33 -0
- package/src/utils/amelipro/rules/notBeforeDate/tests/notBeforeDate.spec.ts +32 -0
- package/src/utils/functions/ameliproColors/ameliproColors.ts +57 -0
- package/src/utils/functions/ameliproColors/types.d.ts +5 -0
- package/src/utils/functions/classToHex.ts +38 -0
- package/src/utils/functions/convertToHex.ts +23 -0
- package/src/utils/functions/isCssColor.ts +3 -0
- package/src/utils/index.ts +45 -0
- package/src/vuetifyConfig.ts +15 -0
- package/dist/main-Cx8qG7YR.js +0 -16344
- package/src/components/SelectBtnField/Accessibilite.mdx +0 -14
- /package/dist/components/{SelectBtnField → Customs/Selects/SelectBtnField}/config.d.ts +0 -0
- /package/dist/components/{SelectBtnField → Customs/Selects/SelectBtnField}/types.d.ts +0 -0
- /package/dist/components/Customs/{SyInputSelect → Selects/SyInputSelect}/config.d.ts +0 -0
- /package/dist/components/Customs/{SySelect → Selects/SySelect}/locales.d.ts +0 -0
- /package/src/components/Customs/{SyBtnSelect → Selects/SelectBtnField}/Accessibilite.mdx +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/AccessibiliteItems.ts +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/SelectBtnField.vue +0 -0
- /package/src/components/Customs/{SySelect → Selects/SelectBtnField}/Usages.mdx +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/config.ts +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/tests/SelectBtnField.spec.ts +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/tests/__snapshots__/SelectBtnField.spec.ts.snap +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SelectBtnField}/types.d.ts +0 -0
- /package/src/components/Customs/{SyInputSelect → Selects/SyBtnSelect}/Accessibilite.mdx +0 -0
- /package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/AccessibiliteItems.ts +0 -0
- /package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/SyBtnSelect.vue +0 -0
- /package/src/components/Customs/{SyBtnSelect → Selects/SyBtnSelect}/tests/SyBtnSelect.spec.ts +0 -0
- /package/src/components/Customs/{SySelect → Selects/SyInputSelect}/Accessibilite.mdx +0 -0
- /package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/AccessibiliteItems.ts +0 -0
- /package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/SyInputSelect.vue +0 -0
- /package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/config.ts +0 -0
- /package/src/components/Customs/{SyInputSelect → Selects/SyInputSelect}/tests/SyInputSelect.spec.ts +0 -0
- /package/src/components/Customs/{SySelect → Selects/SySelect}/AccessibiliteItems.ts +0 -0
- /package/src/components/{SelectBtnField → Customs/Selects/SySelect}/Usages.mdx +0 -0
- /package/src/components/Customs/{SySelect → Selects/SySelect}/locales.ts +0 -0
- /package/src/components/Customs/{SySelect → Selects/SySelect}/tests/SySelect.spec.ts +0 -0
|
@@ -93,6 +93,33 @@ const meta = {
|
|
|
93
93
|
},
|
|
94
94
|
resizableColumns: {
|
|
95
95
|
description: 'Permet de redimensionner les colonnes du tableau',
|
|
96
|
+
control: { type: 'boolean' },
|
|
97
|
+
table: {
|
|
98
|
+
category: 'props',
|
|
99
|
+
type: { summary: 'boolean' },
|
|
100
|
+
},
|
|
101
|
+
},
|
|
102
|
+
multiSort: {
|
|
103
|
+
description: 'Permet de trier sur plusieurs colonnes simultanément. Lorsque activé, des indicateurs numériques apparaissent à côté des icônes de tri pour montrer l\'ordre de priorité.',
|
|
104
|
+
control: { type: 'boolean' },
|
|
105
|
+
table: {
|
|
106
|
+
category: 'props',
|
|
107
|
+
type: { summary: 'boolean' },
|
|
108
|
+
defaultValue: {
|
|
109
|
+
summary: 'false',
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
},
|
|
113
|
+
mustSort: {
|
|
114
|
+
description: 'Force au moins une colonne à être toujours triée. Si désactivé, toutes les colonnes peuvent être non triées.',
|
|
115
|
+
control: { type: 'boolean' },
|
|
116
|
+
table: {
|
|
117
|
+
category: 'props',
|
|
118
|
+
type: { summary: 'boolean' },
|
|
119
|
+
defaultValue: {
|
|
120
|
+
summary: 'false',
|
|
121
|
+
},
|
|
122
|
+
},
|
|
96
123
|
},
|
|
97
124
|
enableColumnControls: {
|
|
98
125
|
description: 'Allow the users to re-organize the columns',
|
|
@@ -580,6 +607,320 @@ export const ServerSortBy: Story = {
|
|
|
580
607
|
},
|
|
581
608
|
}
|
|
582
609
|
|
|
610
|
+
export const ServerMultiSort: Story = {
|
|
611
|
+
parameters: {
|
|
612
|
+
sourceCode: [
|
|
613
|
+
{
|
|
614
|
+
name: 'Template',
|
|
615
|
+
code: `
|
|
616
|
+
<template>
|
|
617
|
+
<div>
|
|
618
|
+
<p class="mb-4">
|
|
619
|
+
Cet exemple montre le tri multiple côté serveur avec des indicateurs d'ordre de priorité.
|
|
620
|
+
Les chiffres à côté des icônes de tri indiquent l'ordre de priorité du tri.
|
|
621
|
+
</p>
|
|
622
|
+
<SyServerTable
|
|
623
|
+
v-model:options="options"
|
|
624
|
+
:items="users"
|
|
625
|
+
:headers="headers"
|
|
626
|
+
:server-items-length="totalUsers"
|
|
627
|
+
:loading="state === StateEnum.PENDING"
|
|
628
|
+
suffix="server-multi-sort"
|
|
629
|
+
@update:options="fetchData"
|
|
630
|
+
/>
|
|
631
|
+
</div>
|
|
632
|
+
</template>
|
|
633
|
+
`,
|
|
634
|
+
},
|
|
635
|
+
{
|
|
636
|
+
name: 'Script',
|
|
637
|
+
code: `
|
|
638
|
+
<script setup lang="ts">
|
|
639
|
+
import { ref } from 'vue'
|
|
640
|
+
import { SyServerTable } from '@cnamts/synapse'
|
|
641
|
+
import { StateEnum } from '@cnamts/synapse/src/components/Tables/common/constants/StateEnum'
|
|
642
|
+
import type { DataOptions } from '@cnamts/synapse/src/components/Tables/common/types'
|
|
643
|
+
|
|
644
|
+
interface User {
|
|
645
|
+
[key: string]: string
|
|
646
|
+
firstname: string
|
|
647
|
+
lastname: string
|
|
648
|
+
email: string
|
|
649
|
+
}
|
|
650
|
+
|
|
651
|
+
interface DataObj {
|
|
652
|
+
items: User[]
|
|
653
|
+
total: number
|
|
654
|
+
}
|
|
655
|
+
|
|
656
|
+
const totalUsers = ref(0)
|
|
657
|
+
const users = ref<User[]>([])
|
|
658
|
+
const state = ref(StateEnum.IDLE)
|
|
659
|
+
|
|
660
|
+
const options = ref<DataOptions>({
|
|
661
|
+
itemsPerPage: 5,
|
|
662
|
+
multiSort: true,
|
|
663
|
+
sortBy: [
|
|
664
|
+
{
|
|
665
|
+
key: 'lastname',
|
|
666
|
+
order: 'desc',
|
|
667
|
+
},
|
|
668
|
+
{
|
|
669
|
+
key: 'firstname',
|
|
670
|
+
order: 'asc',
|
|
671
|
+
},
|
|
672
|
+
],
|
|
673
|
+
page: 1,
|
|
674
|
+
})
|
|
675
|
+
|
|
676
|
+
const headers = [
|
|
677
|
+
{ title: 'Nom', key: 'lastname' },
|
|
678
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
679
|
+
{ title: 'Email', key: 'email' },
|
|
680
|
+
]
|
|
681
|
+
|
|
682
|
+
const fetchData = async (): Promise<void> => {
|
|
683
|
+
const { items, total } = await getDataFromApi(options.value)
|
|
684
|
+
users.value = items
|
|
685
|
+
totalUsers.value = total
|
|
686
|
+
}
|
|
687
|
+
|
|
688
|
+
const wait = async (ms: number) => {
|
|
689
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
690
|
+
}
|
|
691
|
+
|
|
692
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage }: DataOptions): Promise<DataObj> => {
|
|
693
|
+
state.value = StateEnum.PENDING
|
|
694
|
+
await wait(1000)
|
|
695
|
+
|
|
696
|
+
return new Promise((resolve) => {
|
|
697
|
+
let items: User[] = getUsers()
|
|
698
|
+
const total = items.length
|
|
699
|
+
|
|
700
|
+
if (sortBy && sortBy.length > 0) {
|
|
701
|
+
items.sort((a, b) => {
|
|
702
|
+
for (const sort of sortBy) {
|
|
703
|
+
const key = sort.key
|
|
704
|
+
const r = String(a[key]).localeCompare(String(b[key]))
|
|
705
|
+
|
|
706
|
+
const order = sort.order === 'asc' ? 1 : -1
|
|
707
|
+
if (r !== 0) {
|
|
708
|
+
return r * order
|
|
709
|
+
}
|
|
710
|
+
}
|
|
711
|
+
return 0
|
|
712
|
+
})
|
|
713
|
+
}
|
|
714
|
+
|
|
715
|
+
if (itemsPerPage > 0) {
|
|
716
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
resolve({ items, total })
|
|
720
|
+
state.value = StateEnum.RESOLVED
|
|
721
|
+
})
|
|
722
|
+
}
|
|
723
|
+
|
|
724
|
+
const getUsers = (): User[] => {
|
|
725
|
+
return [
|
|
726
|
+
{
|
|
727
|
+
firstname: 'Virginie',
|
|
728
|
+
lastname: 'Beauchesne',
|
|
729
|
+
email: 'virginie.beauchesne@example.com',
|
|
730
|
+
},
|
|
731
|
+
{
|
|
732
|
+
firstname: 'Simone',
|
|
733
|
+
lastname: 'Bellefeuille',
|
|
734
|
+
email: 'simone.bellefeuille@example.com',
|
|
735
|
+
},
|
|
736
|
+
{
|
|
737
|
+
firstname: 'Étienne',
|
|
738
|
+
lastname: 'Salois',
|
|
739
|
+
email: 'etienne.salois@example.com',
|
|
740
|
+
},
|
|
741
|
+
{
|
|
742
|
+
firstname: 'Thierry',
|
|
743
|
+
lastname: 'Bobu',
|
|
744
|
+
email: 'thierry.bobu@example.com',
|
|
745
|
+
},
|
|
746
|
+
{
|
|
747
|
+
firstname: 'Bernadette',
|
|
748
|
+
lastname: 'Langelier',
|
|
749
|
+
email: 'bernadette.langelier@exemple.com'
|
|
750
|
+
},
|
|
751
|
+
{
|
|
752
|
+
firstname: 'Agate',
|
|
753
|
+
lastname: 'Roy',
|
|
754
|
+
email: 'agate.roy@exemple.com'
|
|
755
|
+
},
|
|
756
|
+
{
|
|
757
|
+
firstname: 'Agate',
|
|
758
|
+
lastname: 'Beauchesne',
|
|
759
|
+
email: 'agate.beauchesne@exemple.com'
|
|
760
|
+
}
|
|
761
|
+
]
|
|
762
|
+
}
|
|
763
|
+
|
|
764
|
+
// Initialize data
|
|
765
|
+
fetchData()
|
|
766
|
+
</script>
|
|
767
|
+
`,
|
|
768
|
+
},
|
|
769
|
+
],
|
|
770
|
+
},
|
|
771
|
+
args: {
|
|
772
|
+
'options': {
|
|
773
|
+
itemsPerPage: 5,
|
|
774
|
+
multiSort: true,
|
|
775
|
+
sortBy: [
|
|
776
|
+
{
|
|
777
|
+
key: 'lastname',
|
|
778
|
+
order: 'desc',
|
|
779
|
+
},
|
|
780
|
+
{
|
|
781
|
+
key: 'firstname',
|
|
782
|
+
order: 'asc',
|
|
783
|
+
},
|
|
784
|
+
],
|
|
785
|
+
page: 1,
|
|
786
|
+
},
|
|
787
|
+
'headers': [
|
|
788
|
+
{ title: 'Nom', key: 'lastname' },
|
|
789
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
790
|
+
{ title: 'Email', key: 'email' },
|
|
791
|
+
],
|
|
792
|
+
'caption': '',
|
|
793
|
+
'suffix': 'server-sort',
|
|
794
|
+
'density': 'default',
|
|
795
|
+
'striped': false,
|
|
796
|
+
'multiSort': true,
|
|
797
|
+
'serverItemsLength': 7,
|
|
798
|
+
'onUpdate:options': fn(),
|
|
799
|
+
},
|
|
800
|
+
render: (args) => {
|
|
801
|
+
return {
|
|
802
|
+
components: { SyServerTable },
|
|
803
|
+
setup() {
|
|
804
|
+
const totalUsers = ref(0)
|
|
805
|
+
const users = ref<User[]>([])
|
|
806
|
+
const state = ref(StateEnum.IDLE)
|
|
807
|
+
|
|
808
|
+
const options = ref({ ...args.options })
|
|
809
|
+
|
|
810
|
+
watch(options, (newVal) => {
|
|
811
|
+
if (args.options) {
|
|
812
|
+
Object.assign(args.options, JSON.parse(JSON.stringify(newVal)))
|
|
813
|
+
}
|
|
814
|
+
}, { deep: true })
|
|
815
|
+
|
|
816
|
+
const fetchData = async (): Promise<void> => {
|
|
817
|
+
const { items, total } = await getDataFromApi(options.value as DataOptions)
|
|
818
|
+
users.value = items
|
|
819
|
+
totalUsers.value = total
|
|
820
|
+
}
|
|
821
|
+
|
|
822
|
+
const wait = async (ms: number) => {
|
|
823
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
824
|
+
}
|
|
825
|
+
|
|
826
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage }: DataOptions): Promise<DataObj> => {
|
|
827
|
+
state.value = StateEnum.PENDING
|
|
828
|
+
await wait(1000)
|
|
829
|
+
|
|
830
|
+
return new Promise((resolve) => {
|
|
831
|
+
let items: User[] = getUsers()
|
|
832
|
+
const total = items.length
|
|
833
|
+
|
|
834
|
+
if (sortBy && sortBy.length > 0) {
|
|
835
|
+
items.sort((a, b) => {
|
|
836
|
+
for (const sort of sortBy) {
|
|
837
|
+
const key = sort.key
|
|
838
|
+
const r = String(a[key]).localeCompare(String(b[key]))
|
|
839
|
+
|
|
840
|
+
const order = sort.order === 'asc' ? 1 : -1
|
|
841
|
+
if (r !== 0) {
|
|
842
|
+
return r * order
|
|
843
|
+
}
|
|
844
|
+
}
|
|
845
|
+
return 0
|
|
846
|
+
})
|
|
847
|
+
}
|
|
848
|
+
|
|
849
|
+
if (itemsPerPage > 0) {
|
|
850
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
851
|
+
}
|
|
852
|
+
|
|
853
|
+
resolve({ items, total })
|
|
854
|
+
state.value = StateEnum.RESOLVED
|
|
855
|
+
})
|
|
856
|
+
}
|
|
857
|
+
|
|
858
|
+
const getUsers = (): User[] => {
|
|
859
|
+
return [
|
|
860
|
+
{
|
|
861
|
+
firstname: 'Virginie',
|
|
862
|
+
lastname: 'Beauchesne',
|
|
863
|
+
email: 'virginie.beauchesne@example.com',
|
|
864
|
+
},
|
|
865
|
+
{
|
|
866
|
+
firstname: 'Simone',
|
|
867
|
+
lastname: 'Bellefeuille',
|
|
868
|
+
email: 'simone.bellefeuille@example.com',
|
|
869
|
+
},
|
|
870
|
+
{
|
|
871
|
+
firstname: 'Étienne',
|
|
872
|
+
lastname: 'Salois',
|
|
873
|
+
email: 'etienne.salois@example.com',
|
|
874
|
+
},
|
|
875
|
+
{
|
|
876
|
+
firstname: 'Thierry',
|
|
877
|
+
lastname: 'Bobu',
|
|
878
|
+
email: 'thierry.bobu@example.com',
|
|
879
|
+
},
|
|
880
|
+
{
|
|
881
|
+
firstname: 'Bernadette',
|
|
882
|
+
lastname: 'Langelier',
|
|
883
|
+
email: 'bernadette.langelier@exemple.com',
|
|
884
|
+
},
|
|
885
|
+
{
|
|
886
|
+
firstname: 'Agate',
|
|
887
|
+
lastname: 'Roy',
|
|
888
|
+
email: 'agate.roy@exemple.com',
|
|
889
|
+
},
|
|
890
|
+
{
|
|
891
|
+
firstname: 'Agate',
|
|
892
|
+
lastname: 'Beauchesne',
|
|
893
|
+
email: 'agate.beauchesne@exemple.com',
|
|
894
|
+
},
|
|
895
|
+
]
|
|
896
|
+
}
|
|
897
|
+
|
|
898
|
+
// Initialize data
|
|
899
|
+
fetchData()
|
|
900
|
+
|
|
901
|
+
return { args, users, state, fetchData, options, totalUsers, StateEnum }
|
|
902
|
+
},
|
|
903
|
+
template: `
|
|
904
|
+
<div>
|
|
905
|
+
<p class="mb-4">
|
|
906
|
+
Cet exemple montre le tri multiple côté serveur avec des indicateurs d'ordre de priorité.
|
|
907
|
+
Les chiffres à côté des icônes de tri indiquent l'ordre de priorité du tri.
|
|
908
|
+
</p>
|
|
909
|
+
<SyServerTable
|
|
910
|
+
v-model:options="options"
|
|
911
|
+
:items="users"
|
|
912
|
+
:server-items-length="totalUsers"
|
|
913
|
+
:loading="state === StateEnum.PENDING"
|
|
914
|
+
v-bind="args"
|
|
915
|
+
suffix="server-multi-sort"
|
|
916
|
+
@update:options="fetchData"
|
|
917
|
+
/>
|
|
918
|
+
</div>
|
|
919
|
+
`,
|
|
920
|
+
}
|
|
921
|
+
},
|
|
922
|
+
}
|
|
923
|
+
|
|
583
924
|
export const ServerFilterByText: Story = {
|
|
584
925
|
parameters: {
|
|
585
926
|
sourceCode: [
|
|
@@ -1477,16 +1818,16 @@ export const ServerFilterBySelectMultiple: Story = {
|
|
|
1477
1818
|
name: 'Template',
|
|
1478
1819
|
code: `
|
|
1479
1820
|
<template>
|
|
1480
|
-
|
|
1481
|
-
|
|
1482
|
-
|
|
1483
|
-
|
|
1484
|
-
|
|
1485
|
-
|
|
1486
|
-
|
|
1487
|
-
|
|
1488
|
-
|
|
1489
|
-
|
|
1821
|
+
<SyServerTable
|
|
1822
|
+
v-model:options="options"
|
|
1823
|
+
:items="filteredUsers"
|
|
1824
|
+
:headers="headers"
|
|
1825
|
+
:server-items-length="totalFilteredUsers"
|
|
1826
|
+
:loading="state === StateEnum.PENDING"
|
|
1827
|
+
suffix="server-filter-select"
|
|
1828
|
+
:show-filters="true"
|
|
1829
|
+
@update:options="fetchData"
|
|
1830
|
+
/>
|
|
1490
1831
|
</template>
|
|
1491
1832
|
`,
|
|
1492
1833
|
},
|
|
@@ -1494,150 +1835,158 @@ export const ServerFilterBySelectMultiple: Story = {
|
|
|
1494
1835
|
name: 'Script',
|
|
1495
1836
|
code: `
|
|
1496
1837
|
<script setup lang="ts">
|
|
1497
|
-
|
|
1498
|
-
|
|
1499
|
-
|
|
1500
|
-
|
|
1838
|
+
import { ref } from 'vue'
|
|
1839
|
+
import { SyServerTable } from '@cnamts/synapse'
|
|
1840
|
+
import { StateEnum } from '@cnamts/synapse/components/Tables/common/constants/StateEnum'
|
|
1841
|
+
import type { DataOptions, FilterOption } from '@cnamts/synapse/components/Tables/common/types'
|
|
1842
|
+
|
|
1843
|
+
interface User {
|
|
1844
|
+
name: string
|
|
1845
|
+
department: string
|
|
1846
|
+
status: string
|
|
1847
|
+
}
|
|
1501
1848
|
|
|
1502
|
-
|
|
1503
|
-
|
|
1504
|
-
|
|
1505
|
-
|
|
1506
|
-
}
|
|
1849
|
+
interface DataObj {
|
|
1850
|
+
items: User[]
|
|
1851
|
+
total: number
|
|
1852
|
+
}
|
|
1507
1853
|
|
|
1508
|
-
|
|
1509
|
-
|
|
1510
|
-
|
|
1511
|
-
}
|
|
1854
|
+
const totalFilteredUsers = ref(0)
|
|
1855
|
+
const filteredUsers = ref<User[]>([])
|
|
1856
|
+
const state = ref(StateEnum.IDLE)
|
|
1512
1857
|
|
|
1513
|
-
|
|
1514
|
-
|
|
1515
|
-
|
|
1858
|
+
const options = ref<DataOptions>({
|
|
1859
|
+
itemsPerPage: 5,
|
|
1860
|
+
page: 1,
|
|
1861
|
+
filters: [],
|
|
1862
|
+
})
|
|
1516
1863
|
|
|
1517
|
-
|
|
1518
|
-
|
|
1519
|
-
|
|
1520
|
-
|
|
1521
|
-
|
|
1864
|
+
const headers = [
|
|
1865
|
+
{
|
|
1866
|
+
title: 'Nom',
|
|
1867
|
+
key: 'name',
|
|
1868
|
+
filterable: true,
|
|
1869
|
+
filterType: 'text' as const
|
|
1870
|
+
},
|
|
1871
|
+
{
|
|
1872
|
+
title: 'Département',
|
|
1873
|
+
key: 'department',
|
|
1874
|
+
filterable: true,
|
|
1875
|
+
filterType: 'select' as const,
|
|
1876
|
+
multiple: true,
|
|
1877
|
+
chips: true,
|
|
1878
|
+
hideMessages: true,
|
|
1879
|
+
filterOptions: [
|
|
1880
|
+
{ text: 'RH', value: 'RH' },
|
|
1881
|
+
{ text: 'IT', value: 'IT' },
|
|
1882
|
+
{ text: 'Finance', value: 'Finance' },
|
|
1883
|
+
{ text: 'Marketing', value: 'Marketing' },
|
|
1884
|
+
]
|
|
1885
|
+
},
|
|
1886
|
+
{
|
|
1887
|
+
title: 'Statut',
|
|
1888
|
+
key: 'status',
|
|
1889
|
+
filterable: true,
|
|
1890
|
+
filterType: 'select' as const,
|
|
1891
|
+
multiple: true,
|
|
1892
|
+
chips: true,
|
|
1893
|
+
hideMessages: true,
|
|
1894
|
+
filterOptions: [
|
|
1895
|
+
{ text: 'Actif', value: 'Actif' },
|
|
1896
|
+
{ text: 'En congé', value: 'En congé' },
|
|
1897
|
+
{ text: 'Inactif', value: 'Inactif' },
|
|
1898
|
+
]
|
|
1899
|
+
}
|
|
1900
|
+
]
|
|
1522
1901
|
|
|
1523
|
-
|
|
1524
|
-
|
|
1525
|
-
|
|
1526
|
-
|
|
1527
|
-
filterable: true,
|
|
1528
|
-
filterType: 'text'
|
|
1529
|
-
},
|
|
1530
|
-
{
|
|
1531
|
-
title: 'Département',
|
|
1532
|
-
key: 'department',
|
|
1533
|
-
filterable: true,
|
|
1534
|
-
filterType: 'select',
|
|
1535
|
-
multiple: true,
|
|
1536
|
-
chips: true,
|
|
1537
|
-
hideMessages: true,
|
|
1538
|
-
filterOptions: [
|
|
1539
|
-
{ text: 'RH', value: 'RH' },
|
|
1540
|
-
{ text: 'IT', value: 'IT' },
|
|
1541
|
-
{ text: 'Finance', value: 'Finance' },
|
|
1542
|
-
{ text: 'Marketing', value: 'Marketing' },
|
|
1543
|
-
]
|
|
1544
|
-
},
|
|
1545
|
-
{
|
|
1546
|
-
title: 'Statut',
|
|
1547
|
-
key: 'status',
|
|
1548
|
-
filterable: true,
|
|
1549
|
-
filterType: 'select',
|
|
1550
|
-
multiple: true,
|
|
1551
|
-
chips: true,
|
|
1552
|
-
hideMessages: true,
|
|
1553
|
-
filterOptions: [
|
|
1554
|
-
{ text: 'Actif', value: 'Actif' },
|
|
1555
|
-
{ text: 'En congé', value: 'En congé' },
|
|
1556
|
-
{ text: 'Inactif', value: 'Inactif' },
|
|
1557
|
-
]
|
|
1902
|
+
const fetchData = async (): Promise<void> => {
|
|
1903
|
+
const { items, total } = await getDataFromApi(options.value)
|
|
1904
|
+
filteredUsers.value = items
|
|
1905
|
+
totalFilteredUsers.value = total
|
|
1558
1906
|
}
|
|
1559
|
-
]
|
|
1560
|
-
|
|
1561
|
-
const fetchData = async (): Promise<void> => {
|
|
1562
|
-
const { items, total } = await getDataFromApi(options.value)
|
|
1563
|
-
filteredUsers.value = items
|
|
1564
|
-
totalFilteredUsers.value = total
|
|
1565
|
-
}
|
|
1566
1907
|
|
|
1567
|
-
|
|
1568
|
-
|
|
1569
|
-
|
|
1908
|
+
const wait = async (ms: number) => {
|
|
1909
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
1910
|
+
}
|
|
1570
1911
|
|
|
1571
|
-
|
|
1572
|
-
|
|
1573
|
-
|
|
1912
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage, filters }: DataOptions): Promise<DataObj> => {
|
|
1913
|
+
state.value = StateEnum.PENDING
|
|
1914
|
+
await wait(1000)
|
|
1574
1915
|
|
|
1575
|
-
|
|
1576
|
-
|
|
1577
|
-
|
|
1578
|
-
|
|
1579
|
-
|
|
1580
|
-
|
|
1581
|
-
|
|
1582
|
-
|
|
1583
|
-
|
|
1584
|
-
items = items.filter(item => {
|
|
1585
|
-
const itemValue = item[key as keyof User]
|
|
1916
|
+
return new Promise((resolve) => {
|
|
1917
|
+
// Get all users
|
|
1918
|
+
let items: User[] = getUsers()
|
|
1919
|
+
|
|
1920
|
+
// Apply filters on server side
|
|
1921
|
+
if (filters && filters.length > 0) {
|
|
1922
|
+
filters.forEach((filter: FilterOption) => {
|
|
1923
|
+
const { key, value, type } = filter
|
|
1586
1924
|
|
|
1587
|
-
|
|
1588
|
-
|
|
1589
|
-
|
|
1590
|
-
|
|
1591
|
-
|
|
1592
|
-
|
|
1593
|
-
|
|
1594
|
-
|
|
1595
|
-
|
|
1596
|
-
|
|
1925
|
+
items = items.filter(item => {
|
|
1926
|
+
const itemValue = item[key as keyof User]
|
|
1927
|
+
|
|
1928
|
+
if (type === 'select') {
|
|
1929
|
+
if (Array.isArray(value)) {
|
|
1930
|
+
// Empty array means no filter applied
|
|
1931
|
+
if (value.length === 0) return true
|
|
1932
|
+
// Check if item value is in the selected values
|
|
1933
|
+
return value.includes(itemValue)
|
|
1934
|
+
}
|
|
1935
|
+
else {
|
|
1936
|
+
return itemValue === value
|
|
1937
|
+
}
|
|
1938
|
+
} else {
|
|
1939
|
+
return String(itemValue).toLowerCase().includes(String(value).toLowerCase())
|
|
1940
|
+
}
|
|
1941
|
+
})
|
|
1942
|
+
})
|
|
1943
|
+
}
|
|
1944
|
+
|
|
1945
|
+
const total = items.length
|
|
1597
1946
|
|
|
1598
|
-
|
|
1599
|
-
|
|
1600
|
-
|
|
1601
|
-
|
|
1602
|
-
|
|
1603
|
-
|
|
1604
|
-
|
|
1605
|
-
|
|
1606
|
-
|
|
1947
|
+
// Apply sorting
|
|
1948
|
+
if (sortBy && sortBy.length > 0) {
|
|
1949
|
+
items = items.sort((a, b) => {
|
|
1950
|
+
const key = sortBy[0].key as keyof User
|
|
1951
|
+
const order = sortBy[0].order === 'asc' ? 1 : -1
|
|
1952
|
+
|
|
1953
|
+
return String(a[key]) > String(b[key]) ? order : -order
|
|
1954
|
+
})
|
|
1955
|
+
}
|
|
1607
1956
|
|
|
1608
|
-
|
|
1609
|
-
|
|
1610
|
-
|
|
1611
|
-
|
|
1957
|
+
// Apply pagination
|
|
1958
|
+
if (itemsPerPage > 0) {
|
|
1959
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
1960
|
+
}
|
|
1612
1961
|
|
|
1613
|
-
|
|
1614
|
-
|
|
1615
|
-
|
|
1616
|
-
|
|
1962
|
+
resolve({ items, total })
|
|
1963
|
+
state.value = StateEnum.RESOLVED
|
|
1964
|
+
})
|
|
1965
|
+
}
|
|
1617
1966
|
|
|
1618
|
-
|
|
1619
|
-
|
|
1620
|
-
|
|
1621
|
-
|
|
1622
|
-
|
|
1623
|
-
|
|
1624
|
-
|
|
1625
|
-
|
|
1626
|
-
|
|
1627
|
-
|
|
1628
|
-
|
|
1629
|
-
|
|
1630
|
-
|
|
1631
|
-
|
|
1632
|
-
|
|
1633
|
-
|
|
1634
|
-
|
|
1635
|
-
|
|
1636
|
-
|
|
1637
|
-
|
|
1638
|
-
|
|
1639
|
-
|
|
1640
|
-
|
|
1967
|
+
const getUsers = (): User[] => {
|
|
1968
|
+
return [
|
|
1969
|
+
{ name: 'Jean Dupont', department: 'RH', status: 'Actif' },
|
|
1970
|
+
{ name: 'Marie Martin', department: 'IT', status: 'En congé' },
|
|
1971
|
+
{ name: 'Pierre Durand', department: 'Finance', status: 'Actif' },
|
|
1972
|
+
{ name: 'Sophie Petit', department: 'Marketing', status: 'Actif' },
|
|
1973
|
+
{ name: 'Thomas Leroy', department: 'IT', status: 'Inactif' },
|
|
1974
|
+
{ name: 'Julie Bernard', department: 'RH', status: 'Actif' },
|
|
1975
|
+
{ name: 'Nicolas Moreau', department: 'Finance', status: 'En congé' },
|
|
1976
|
+
{ name: 'Camille Dubois', department: 'Marketing', status: 'Inactif' },
|
|
1977
|
+
{ name: 'Alexandre Lefebvre', department: 'IT', status: 'Actif' },
|
|
1978
|
+
{ name: 'Émilie Girard', department: 'RH', status: 'En congé' },
|
|
1979
|
+
{ name: 'Lucas Roux', department: 'Finance', status: 'Actif' },
|
|
1980
|
+
{ name: 'Chloé Lambert', department: 'Marketing', status: 'Actif' },
|
|
1981
|
+
{ name: 'Maxime Simon', department: 'IT', status: 'Inactif' },
|
|
1982
|
+
{ name: 'Laura Fournier', department: 'RH', status: 'Actif' },
|
|
1983
|
+
{ name: 'Antoine Mercier', department: 'Finance', status: 'En congé' },
|
|
1984
|
+
]
|
|
1985
|
+
}
|
|
1986
|
+
|
|
1987
|
+
// Initialize data
|
|
1988
|
+
fetchData()
|
|
1989
|
+
</script>
|
|
1641
1990
|
`,
|
|
1642
1991
|
},
|
|
1643
1992
|
],
|
|
@@ -4352,3 +4701,521 @@ export const ColumnControls: StoryObj<typeof SyServerTable> = {
|
|
|
4352
4701
|
}
|
|
4353
4702
|
},
|
|
4354
4703
|
}
|
|
4704
|
+
|
|
4705
|
+
export const SlotItem: Story = {
|
|
4706
|
+
parameters: {
|
|
4707
|
+
sourceCode: [
|
|
4708
|
+
{
|
|
4709
|
+
name: 'Template',
|
|
4710
|
+
code: `
|
|
4711
|
+
<template>
|
|
4712
|
+
<SyServerTable
|
|
4713
|
+
v-model:options="options"
|
|
4714
|
+
:items="users"
|
|
4715
|
+
:headers="headers"
|
|
4716
|
+
:server-items-length="totalUsers"
|
|
4717
|
+
:loading="state === StateEnum.PENDING"
|
|
4718
|
+
suffix="server-default"
|
|
4719
|
+
@update:options="fetchData"
|
|
4720
|
+
>
|
|
4721
|
+
<template #item="{ item }">
|
|
4722
|
+
<tr>
|
|
4723
|
+
<td>{{ item.lastname }}</td>
|
|
4724
|
+
<td>
|
|
4725
|
+
<a
|
|
4726
|
+
href="#"
|
|
4727
|
+
class="text-primary"
|
|
4728
|
+
>
|
|
4729
|
+
{{ item.firstname }}
|
|
4730
|
+
</a>
|
|
4731
|
+
</td>
|
|
4732
|
+
<td>{{ item.email }}</td>
|
|
4733
|
+
</tr>
|
|
4734
|
+
</template>
|
|
4735
|
+
</SyServerTable>
|
|
4736
|
+
</template>
|
|
4737
|
+
`,
|
|
4738
|
+
},
|
|
4739
|
+
{
|
|
4740
|
+
name: 'Script',
|
|
4741
|
+
code: `
|
|
4742
|
+
<script setup lang="ts">
|
|
4743
|
+
import { ref, watch } from 'vue'
|
|
4744
|
+
import { SyServerTable } from '@cnamts/synapse'
|
|
4745
|
+
import { StateEnum } from '@cnamts/synapse/src/components/Tables/common/constants/StateEnum'
|
|
4746
|
+
import type { DataOptions } from '@cnamts/synapse/src/components/Tables/common/types'
|
|
4747
|
+
|
|
4748
|
+
interface User {
|
|
4749
|
+
[key: string]: string
|
|
4750
|
+
firstname: string
|
|
4751
|
+
lastname: string
|
|
4752
|
+
email: string
|
|
4753
|
+
}
|
|
4754
|
+
|
|
4755
|
+
interface DataObj {
|
|
4756
|
+
items: User[]
|
|
4757
|
+
total: number
|
|
4758
|
+
}
|
|
4759
|
+
|
|
4760
|
+
const totalUsers = ref(0)
|
|
4761
|
+
const users = ref<User[]>([])
|
|
4762
|
+
const state = ref(StateEnum.IDLE)
|
|
4763
|
+
|
|
4764
|
+
const options = ref({
|
|
4765
|
+
itemsPerPage: 5,
|
|
4766
|
+
sortBy: [{ key: 'lastname', order: 'asc' }],
|
|
4767
|
+
page: 1,
|
|
4768
|
+
})
|
|
4769
|
+
|
|
4770
|
+
const headers = [
|
|
4771
|
+
{ title: 'Nom', key: 'lastname' },
|
|
4772
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
4773
|
+
{ title: 'Email', key: 'email' },
|
|
4774
|
+
]
|
|
4775
|
+
|
|
4776
|
+
const fetchData = async (): Promise<void> => {
|
|
4777
|
+
const { items, total } = await getDataFromApi(options.value)
|
|
4778
|
+
users.value = items
|
|
4779
|
+
totalUsers.value = total
|
|
4780
|
+
}
|
|
4781
|
+
|
|
4782
|
+
const wait = async (ms: number) => {
|
|
4783
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
4784
|
+
}
|
|
4785
|
+
|
|
4786
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage, filters }: DataOptions): Promise<DataObj> => {
|
|
4787
|
+
state.value = StateEnum.PENDING
|
|
4788
|
+
await wait(1000)
|
|
4789
|
+
|
|
4790
|
+
return new Promise((resolve) => {
|
|
4791
|
+
let items: User[] = getUsers()
|
|
4792
|
+
const total = items.length
|
|
4793
|
+
|
|
4794
|
+
if (sortBy && sortBy.length > 0) {
|
|
4795
|
+
items = items.sort((a, b) => {
|
|
4796
|
+
const key = sortBy[0].key
|
|
4797
|
+
const order = sortBy[0].order === 'asc' ? 1 : -1
|
|
4798
|
+
|
|
4799
|
+
return a[key] > b[key] ? order : -order
|
|
4800
|
+
})
|
|
4801
|
+
}
|
|
4802
|
+
|
|
4803
|
+
if (itemsPerPage > 0) {
|
|
4804
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
4805
|
+
}
|
|
4806
|
+
|
|
4807
|
+
resolve({ items, total })
|
|
4808
|
+
state.value = StateEnum.RESOLVED
|
|
4809
|
+
})
|
|
4810
|
+
}
|
|
4811
|
+
|
|
4812
|
+
const getUsers = (): User[] => {
|
|
4813
|
+
return [
|
|
4814
|
+
{ firstname: 'Virginie', lastname: 'Beauchesne', email: 'virginie.beauchesne@example.com' },
|
|
4815
|
+
{ firstname: 'Simone', lastname: 'Bellefeuille', email: 'simone.bellefeuille@example.com' },
|
|
4816
|
+
{ firstname: 'Étienne', lastname: 'Salois', email: 'etienne.salois@example.com' },
|
|
4817
|
+
{ firstname: 'Bernadette', lastname: 'Langelier', email: 'bernadette.langelier@example.com' },
|
|
4818
|
+
{ firstname: 'Agate', lastname: 'Roy', email: 'agate.roy@example.com' },
|
|
4819
|
+
{ firstname: 'Louis', lastname: 'Denis', email: 'louis.denis@example.com' },
|
|
4820
|
+
{ firstname: 'Édith', lastname: 'Cartier', email: 'edith.cartier@example.com' },
|
|
4821
|
+
{ firstname: 'Alphonse', lastname: 'Bouvier', email: 'alphonse.bouvier@example.com' },
|
|
4822
|
+
{ firstname: 'Eustache', lastname: 'Dubois', email: 'eustache.dubois@example.com' },
|
|
4823
|
+
{ firstname: 'Rosemarie', lastname: 'Quessy', email: 'rosemarie.quessy@example.com' },
|
|
4824
|
+
{ firstname: 'Serge', lastname: 'Rivard', email: 'serge.rivard@example.com' },
|
|
4825
|
+
{ firstname: 'Jacques', lastname: 'Demers', email: 'jacques.demers@example.com' },
|
|
4826
|
+
{ firstname: 'Aimée', lastname: 'Josseaume', email: 'aimee.josseaume@example.com' },
|
|
4827
|
+
{ firstname: 'Delphine', lastname: 'Robillard', email: 'delphine.robillard@example.com' },
|
|
4828
|
+
{ firstname: 'Alexandre', lastname: 'Lazure', email: 'alexandre.lazure@example.com' },
|
|
4829
|
+
]
|
|
4830
|
+
}
|
|
4831
|
+
|
|
4832
|
+
// Initialize data
|
|
4833
|
+
fetchData()
|
|
4834
|
+
</script>
|
|
4835
|
+
`,
|
|
4836
|
+
},
|
|
4837
|
+
],
|
|
4838
|
+
},
|
|
4839
|
+
args: {
|
|
4840
|
+
'options': {
|
|
4841
|
+
itemsPerPage: 5,
|
|
4842
|
+
sortBy: [{ key: 'lastname', order: 'asc' }],
|
|
4843
|
+
page: 1,
|
|
4844
|
+
},
|
|
4845
|
+
'headers': [
|
|
4846
|
+
{ title: 'Nom', key: 'lastname' },
|
|
4847
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
4848
|
+
{ title: 'Email', key: 'email' },
|
|
4849
|
+
],
|
|
4850
|
+
'caption': '',
|
|
4851
|
+
'serverItemsLength': 15,
|
|
4852
|
+
'suffix': 'server-default',
|
|
4853
|
+
'density': 'default',
|
|
4854
|
+
'striped': false,
|
|
4855
|
+
'onUpdate:options': fn(),
|
|
4856
|
+
},
|
|
4857
|
+
render: (args) => {
|
|
4858
|
+
return {
|
|
4859
|
+
components: { SyServerTable },
|
|
4860
|
+
setup() {
|
|
4861
|
+
const totalUsers = ref(0)
|
|
4862
|
+
const users = ref<User[]>([])
|
|
4863
|
+
const state = ref(StateEnum.IDLE)
|
|
4864
|
+
|
|
4865
|
+
const options = ref({ ...args.options })
|
|
4866
|
+
|
|
4867
|
+
watch(options, (newVal) => {
|
|
4868
|
+
if (args.options) {
|
|
4869
|
+
Object.assign(args.options, JSON.parse(JSON.stringify(newVal)))
|
|
4870
|
+
}
|
|
4871
|
+
}, { deep: true })
|
|
4872
|
+
|
|
4873
|
+
const fetchData = async (): Promise<void> => {
|
|
4874
|
+
const { items, total } = await getDataFromApi(options.value as DataOptions)
|
|
4875
|
+
users.value = items
|
|
4876
|
+
totalUsers.value = total
|
|
4877
|
+
}
|
|
4878
|
+
|
|
4879
|
+
const wait = async (ms: number) => {
|
|
4880
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
4881
|
+
}
|
|
4882
|
+
|
|
4883
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage }: DataOptions): Promise<DataObj> => {
|
|
4884
|
+
state.value = StateEnum.PENDING
|
|
4885
|
+
await wait(1000)
|
|
4886
|
+
|
|
4887
|
+
return new Promise((resolve) => {
|
|
4888
|
+
let items: User[] = getUsers()
|
|
4889
|
+
const total = items.length
|
|
4890
|
+
|
|
4891
|
+
if (sortBy && sortBy.length > 0) {
|
|
4892
|
+
items = items.sort((a, b) => {
|
|
4893
|
+
const key = sortBy[0].key
|
|
4894
|
+
const order = sortBy[0].order === 'asc' ? 1 : -1
|
|
4895
|
+
|
|
4896
|
+
return a[key] > b[key] ? order : -order
|
|
4897
|
+
})
|
|
4898
|
+
}
|
|
4899
|
+
|
|
4900
|
+
if (itemsPerPage > 0) {
|
|
4901
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
4902
|
+
}
|
|
4903
|
+
|
|
4904
|
+
resolve({ items, total })
|
|
4905
|
+
state.value = StateEnum.RESOLVED
|
|
4906
|
+
})
|
|
4907
|
+
}
|
|
4908
|
+
|
|
4909
|
+
const getUsers = (): User[] => {
|
|
4910
|
+
return [
|
|
4911
|
+
{ firstname: 'Virginie', lastname: 'Beauchesne', email: 'virginie.beauchesne@example.com' },
|
|
4912
|
+
{ firstname: 'Simone', lastname: 'Bellefeuille', email: 'simone.bellefeuille@example.com' },
|
|
4913
|
+
{ firstname: 'Étienne', lastname: 'Salois', email: 'etienne.salois@example.com' },
|
|
4914
|
+
{ firstname: 'Bernadette', lastname: 'Langelier', email: 'bernadette.langelier@example.com' },
|
|
4915
|
+
{ firstname: 'Agate', lastname: 'Roy', email: 'agate.roy@example.com' },
|
|
4916
|
+
{ firstname: 'Louis', lastname: 'Denis', email: 'louis.denis@example.com' },
|
|
4917
|
+
{ firstname: 'Édith', lastname: 'Cartier', email: 'edith.cartier@example.com' },
|
|
4918
|
+
{ firstname: 'Alphonse', lastname: 'Bouvier', email: 'alphonse.bouvier@example.com' },
|
|
4919
|
+
{ firstname: 'Eustache', lastname: 'Dubois', email: 'eustache.dubois@example.com' },
|
|
4920
|
+
{ firstname: 'Rosemarie', lastname: 'Quessy', email: 'rosemarie.quessy@example.com' },
|
|
4921
|
+
{ firstname: 'Serge', lastname: 'Rivard', email: 'serge.rivard@example.com' },
|
|
4922
|
+
{ firstname: 'Jacques', lastname: 'Demers', email: 'jacques.demers@example.com' },
|
|
4923
|
+
{ firstname: 'Aimée', lastname: 'Josseaume', email: 'aimee.josseaume@example.com' },
|
|
4924
|
+
{ firstname: 'Delphine', lastname: 'Robillard', email: 'delphine.robillard@example.com' },
|
|
4925
|
+
{ firstname: 'Alexandre', lastname: 'Lazure', email: 'alexandre.lazure@example.com' },
|
|
4926
|
+
]
|
|
4927
|
+
}
|
|
4928
|
+
|
|
4929
|
+
// Initialize data
|
|
4930
|
+
fetchData()
|
|
4931
|
+
|
|
4932
|
+
return { args, users, state, fetchData, options, totalUsers, StateEnum }
|
|
4933
|
+
},
|
|
4934
|
+
template: `
|
|
4935
|
+
<div>
|
|
4936
|
+
<SyServerTable
|
|
4937
|
+
v-model:options="options"
|
|
4938
|
+
:items="users"
|
|
4939
|
+
:server-items-length="totalUsers"
|
|
4940
|
+
:loading="state === StateEnum.PENDING"
|
|
4941
|
+
v-bind="args"
|
|
4942
|
+
suffix="server-slot-item"
|
|
4943
|
+
@update:options="fetchData"
|
|
4944
|
+
>
|
|
4945
|
+
<template #item="{ item }">
|
|
4946
|
+
<tr>
|
|
4947
|
+
<td>{{ item.lastname }}</td>
|
|
4948
|
+
<td>
|
|
4949
|
+
<a
|
|
4950
|
+
href="#"
|
|
4951
|
+
class="text-primary"
|
|
4952
|
+
>
|
|
4953
|
+
{{ item.firstname }}
|
|
4954
|
+
</a>
|
|
4955
|
+
</td>
|
|
4956
|
+
<td>{{ item.email }}</td>
|
|
4957
|
+
</tr>
|
|
4958
|
+
</template>
|
|
4959
|
+
</SyServerTable>
|
|
4960
|
+
</div>
|
|
4961
|
+
`,
|
|
4962
|
+
}
|
|
4963
|
+
},
|
|
4964
|
+
}
|
|
4965
|
+
|
|
4966
|
+
export const SlotHeaders: Story = {
|
|
4967
|
+
parameters: {
|
|
4968
|
+
sourceCode: [
|
|
4969
|
+
{
|
|
4970
|
+
name: 'Template',
|
|
4971
|
+
code: `
|
|
4972
|
+
<template>
|
|
4973
|
+
<SyServerTable
|
|
4974
|
+
v-model:options="options"
|
|
4975
|
+
:items="users"
|
|
4976
|
+
:headers="headers"
|
|
4977
|
+
:server-items-length="totalUsers"
|
|
4978
|
+
:loading="state === StateEnum.PENDING"
|
|
4979
|
+
suffix="server-default"
|
|
4980
|
+
@update:options="fetchData"
|
|
4981
|
+
>
|
|
4982
|
+
<template #headers="{ columns }">
|
|
4983
|
+
<tr>
|
|
4984
|
+
<th
|
|
4985
|
+
v-for="column in columns"
|
|
4986
|
+
:key="column.key"
|
|
4987
|
+
>
|
|
4988
|
+
<span class="font-weight-bold text-primary">
|
|
4989
|
+
{{ column.title }}
|
|
4990
|
+
</span>
|
|
4991
|
+
</th>
|
|
4992
|
+
</tr>
|
|
4993
|
+
</template>
|
|
4994
|
+
</SyServerTable>
|
|
4995
|
+
</template>
|
|
4996
|
+
`,
|
|
4997
|
+
},
|
|
4998
|
+
{
|
|
4999
|
+
name: 'Script',
|
|
5000
|
+
code: `
|
|
5001
|
+
<script setup lang="ts">
|
|
5002
|
+
import { ref, watch } from 'vue'
|
|
5003
|
+
import { SyServerTable } from '@cnamts/synapse'
|
|
5004
|
+
import { StateEnum } from '@cnamts/synapse/src/components/Tables/common/constants/StateEnum'
|
|
5005
|
+
import type { DataOptions } from '@cnamts/synapse/src/components/Tables/common/types'
|
|
5006
|
+
|
|
5007
|
+
interface User {
|
|
5008
|
+
[key: string]: string
|
|
5009
|
+
firstname: string
|
|
5010
|
+
lastname: string
|
|
5011
|
+
email: string
|
|
5012
|
+
}
|
|
5013
|
+
|
|
5014
|
+
interface DataObj {
|
|
5015
|
+
items: User[]
|
|
5016
|
+
total: number
|
|
5017
|
+
}
|
|
5018
|
+
|
|
5019
|
+
const totalUsers = ref(0)
|
|
5020
|
+
const users = ref<User[]>([])
|
|
5021
|
+
const state = ref(StateEnum.IDLE)
|
|
5022
|
+
|
|
5023
|
+
const options = ref({
|
|
5024
|
+
itemsPerPage: 5,
|
|
5025
|
+
sortBy: [{ key: 'lastname', order: 'asc' }],
|
|
5026
|
+
page: 1,
|
|
5027
|
+
})
|
|
5028
|
+
|
|
5029
|
+
const headers = [
|
|
5030
|
+
{ title: 'Nom', key: 'lastname' },
|
|
5031
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
5032
|
+
{ title: 'Email', key: 'email' },
|
|
5033
|
+
]
|
|
5034
|
+
|
|
5035
|
+
const fetchData = async (): Promise<void> => {
|
|
5036
|
+
const { items, total } = await getDataFromApi(options.value)
|
|
5037
|
+
users.value = items
|
|
5038
|
+
totalUsers.value = total
|
|
5039
|
+
}
|
|
5040
|
+
|
|
5041
|
+
const wait = async (ms: number) => {
|
|
5042
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
5043
|
+
}
|
|
5044
|
+
|
|
5045
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage, filters }: DataOptions): Promise<DataObj> => {
|
|
5046
|
+
state.value = StateEnum.PENDING
|
|
5047
|
+
await wait(1000)
|
|
5048
|
+
|
|
5049
|
+
return new Promise((resolve) => {
|
|
5050
|
+
let items: User[] = getUsers()
|
|
5051
|
+
const total = items.length
|
|
5052
|
+
|
|
5053
|
+
if (sortBy && sortBy.length > 0) {
|
|
5054
|
+
items = items.sort((a, b) => {
|
|
5055
|
+
const key = sortBy[0].key
|
|
5056
|
+
const order = sortBy[0].order === 'asc' ? 1 : -1
|
|
5057
|
+
|
|
5058
|
+
return a[key] > b[key] ? order : -order
|
|
5059
|
+
})
|
|
5060
|
+
}
|
|
5061
|
+
|
|
5062
|
+
if (itemsPerPage > 0) {
|
|
5063
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
5064
|
+
}
|
|
5065
|
+
|
|
5066
|
+
resolve({ items, total })
|
|
5067
|
+
state.value = StateEnum.RESOLVED
|
|
5068
|
+
})
|
|
5069
|
+
}
|
|
5070
|
+
|
|
5071
|
+
const getUsers = (): User[] => {
|
|
5072
|
+
return [
|
|
5073
|
+
{ firstname: 'Virginie', lastname: 'Beauchesne', email: 'virginie.beauchesne@example.com' },
|
|
5074
|
+
{ firstname: 'Simone', lastname: 'Bellefeuille', email: 'simone.bellefeuille@example.com' },
|
|
5075
|
+
{ firstname: 'Étienne', lastname: 'Salois', email: 'etienne.salois@example.com' },
|
|
5076
|
+
{ firstname: 'Bernadette', lastname: 'Langelier', email: 'bernadette.langelier@example.com' },
|
|
5077
|
+
{ firstname: 'Agate', lastname: 'Roy', email: 'agate.roy@example.com' },
|
|
5078
|
+
{ firstname: 'Louis', lastname: 'Denis', email: 'louis.denis@example.com' },
|
|
5079
|
+
{ firstname: 'Édith', lastname: 'Cartier', email: 'edith.cartier@example.com' },
|
|
5080
|
+
{ firstname: 'Alphonse', lastname: 'Bouvier', email: 'alphonse.bouvier@example.com' },
|
|
5081
|
+
{ firstname: 'Eustache', lastname: 'Dubois', email: 'eustache.dubois@example.com' },
|
|
5082
|
+
{ firstname: 'Rosemarie', lastname: 'Quessy', email: 'rosemarie.quessy@example.com' },
|
|
5083
|
+
{ firstname: 'Serge', lastname: 'Rivard', email: 'serge.rivard@example.com' },
|
|
5084
|
+
{ firstname: 'Jacques', lastname: 'Demers', email: 'jacques.demers@example.com' },
|
|
5085
|
+
{ firstname: 'Aimée', lastname: 'Josseaume', email: 'aimee.josseaume@example.com' },
|
|
5086
|
+
{ firstname: 'Delphine', lastname: 'Robillard', email: 'delphine.robillard@example.com' },
|
|
5087
|
+
{ firstname: 'Alexandre', lastname: 'Lazure', email: 'alexandre.lazure@example.com' },
|
|
5088
|
+
]
|
|
5089
|
+
}
|
|
5090
|
+
|
|
5091
|
+
// Initialize data
|
|
5092
|
+
fetchData()
|
|
5093
|
+
</script>
|
|
5094
|
+
`,
|
|
5095
|
+
},
|
|
5096
|
+
],
|
|
5097
|
+
},
|
|
5098
|
+
args: {
|
|
5099
|
+
'options': {
|
|
5100
|
+
itemsPerPage: 5,
|
|
5101
|
+
sortBy: [{ key: 'lastname', order: 'asc' }],
|
|
5102
|
+
page: 1,
|
|
5103
|
+
},
|
|
5104
|
+
'headers': [
|
|
5105
|
+
{ title: 'Nom', key: 'lastname' },
|
|
5106
|
+
{ title: 'Prénom', key: 'firstname' },
|
|
5107
|
+
{ title: 'Email', key: 'email' },
|
|
5108
|
+
],
|
|
5109
|
+
'caption': '',
|
|
5110
|
+
'serverItemsLength': 15,
|
|
5111
|
+
'suffix': 'server-default',
|
|
5112
|
+
'density': 'default',
|
|
5113
|
+
'striped': false,
|
|
5114
|
+
'onUpdate:options': fn(),
|
|
5115
|
+
},
|
|
5116
|
+
render: (args) => {
|
|
5117
|
+
return {
|
|
5118
|
+
components: { SyServerTable },
|
|
5119
|
+
setup() {
|
|
5120
|
+
const totalUsers = ref(0)
|
|
5121
|
+
const users = ref<User[]>([])
|
|
5122
|
+
const state = ref(StateEnum.IDLE)
|
|
5123
|
+
|
|
5124
|
+
const options = ref({ ...args.options })
|
|
5125
|
+
|
|
5126
|
+
watch(options, (newVal) => {
|
|
5127
|
+
if (args.options) {
|
|
5128
|
+
Object.assign(args.options, JSON.parse(JSON.stringify(newVal)))
|
|
5129
|
+
}
|
|
5130
|
+
}, { deep: true })
|
|
5131
|
+
|
|
5132
|
+
const fetchData = async (): Promise<void> => {
|
|
5133
|
+
const { items, total } = await getDataFromApi(options.value as DataOptions)
|
|
5134
|
+
users.value = items
|
|
5135
|
+
totalUsers.value = total
|
|
5136
|
+
}
|
|
5137
|
+
|
|
5138
|
+
const wait = async (ms: number) => {
|
|
5139
|
+
return new Promise(resolve => setTimeout(resolve, ms))
|
|
5140
|
+
}
|
|
5141
|
+
|
|
5142
|
+
const getDataFromApi = async ({ sortBy, page, itemsPerPage }: DataOptions): Promise<DataObj> => {
|
|
5143
|
+
state.value = StateEnum.PENDING
|
|
5144
|
+
await wait(1000)
|
|
5145
|
+
|
|
5146
|
+
return new Promise((resolve) => {
|
|
5147
|
+
let items: User[] = getUsers()
|
|
5148
|
+
const total = items.length
|
|
5149
|
+
|
|
5150
|
+
if (sortBy && sortBy.length > 0) {
|
|
5151
|
+
items = items.sort((a, b) => {
|
|
5152
|
+
const key = sortBy[0].key
|
|
5153
|
+
const order = sortBy[0].order === 'asc' ? 1 : -1
|
|
5154
|
+
|
|
5155
|
+
return a[key] > b[key] ? order : -order
|
|
5156
|
+
})
|
|
5157
|
+
}
|
|
5158
|
+
|
|
5159
|
+
if (itemsPerPage > 0) {
|
|
5160
|
+
items = items.slice((page - 1) * itemsPerPage, page * itemsPerPage)
|
|
5161
|
+
}
|
|
5162
|
+
|
|
5163
|
+
resolve({ items, total })
|
|
5164
|
+
state.value = StateEnum.RESOLVED
|
|
5165
|
+
})
|
|
5166
|
+
}
|
|
5167
|
+
|
|
5168
|
+
const getUsers = (): User[] => {
|
|
5169
|
+
return [
|
|
5170
|
+
{ firstname: 'Virginie', lastname: 'Beauchesne', email: 'virginie.beauchesne@example.com' },
|
|
5171
|
+
{ firstname: 'Simone', lastname: 'Bellefeuille', email: 'simone.bellefeuille@example.com' },
|
|
5172
|
+
{ firstname: 'Étienne', lastname: 'Salois', email: 'etienne.salois@example.com' },
|
|
5173
|
+
{ firstname: 'Bernadette', lastname: 'Langelier', email: 'bernadette.langelier@example.com' },
|
|
5174
|
+
{ firstname: 'Agate', lastname: 'Roy', email: 'agate.roy@example.com' },
|
|
5175
|
+
{ firstname: 'Louis', lastname: 'Denis', email: 'louis.denis@example.com' },
|
|
5176
|
+
{ firstname: 'Édith', lastname: 'Cartier', email: 'edith.cartier@example.com' },
|
|
5177
|
+
{ firstname: 'Alphonse', lastname: 'Bouvier', email: 'alphonse.bouvier@example.com' },
|
|
5178
|
+
{ firstname: 'Eustache', lastname: 'Dubois', email: 'eustache.dubois@example.com' },
|
|
5179
|
+
{ firstname: 'Rosemarie', lastname: 'Quessy', email: 'rosemarie.quessy@example.com' },
|
|
5180
|
+
{ firstname: 'Serge', lastname: 'Rivard', email: 'serge.rivard@example.com' },
|
|
5181
|
+
{ firstname: 'Jacques', lastname: 'Demers', email: 'jacques.demers@example.com' },
|
|
5182
|
+
{ firstname: 'Aimée', lastname: 'Josseaume', email: 'aimee.josseaume@example.com' },
|
|
5183
|
+
{ firstname: 'Delphine', lastname: 'Robillard', email: 'delphine.robillard@example.com' },
|
|
5184
|
+
{ firstname: 'Alexandre', lastname: 'Lazure', email: 'alexandre.lazure@example.com' },
|
|
5185
|
+
]
|
|
5186
|
+
}
|
|
5187
|
+
|
|
5188
|
+
// Initialize data
|
|
5189
|
+
fetchData()
|
|
5190
|
+
|
|
5191
|
+
return { args, users, state, fetchData, options, totalUsers, StateEnum }
|
|
5192
|
+
},
|
|
5193
|
+
template: `
|
|
5194
|
+
<div>
|
|
5195
|
+
<SyServerTable
|
|
5196
|
+
v-model:options="options"
|
|
5197
|
+
:items="users"
|
|
5198
|
+
:server-items-length="totalUsers"
|
|
5199
|
+
:loading="state === StateEnum.PENDING"
|
|
5200
|
+
v-bind="args"
|
|
5201
|
+
suffix="server-slot-item"
|
|
5202
|
+
@update:options="fetchData"
|
|
5203
|
+
>
|
|
5204
|
+
<template #headers="{ columns }">
|
|
5205
|
+
<tr>
|
|
5206
|
+
<th
|
|
5207
|
+
v-for="column in columns"
|
|
5208
|
+
:key="column.key"
|
|
5209
|
+
>
|
|
5210
|
+
<span class="font-weight-bold text-primary">
|
|
5211
|
+
{{ column.title }}
|
|
5212
|
+
</span>
|
|
5213
|
+
</th>
|
|
5214
|
+
</tr>
|
|
5215
|
+
</template>
|
|
5216
|
+
</SyServerTable>
|
|
5217
|
+
</div>
|
|
5218
|
+
`,
|
|
5219
|
+
}
|
|
5220
|
+
},
|
|
5221
|
+
}
|