@cnamts/synapse 1.0.4 → 1.0.6

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.
Files changed (206) hide show
  1. package/dist/DateFilter-BlOpwEVq.js +98 -0
  2. package/dist/NumberFilter-BPUXE4wY.js +121 -0
  3. package/dist/PeriodFilter-B2yx329_.js +112 -0
  4. package/dist/SelectFilter-CedKn1oV.js +136 -0
  5. package/dist/TextFilter-DkhJjRtR.js +114 -0
  6. package/dist/components/Amelipro/AmeliproAccordion/AmeliproAccordion.d.ts +103 -0
  7. package/dist/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/AmeliproAccordionTemplate.d.ts +105 -0
  8. package/dist/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.d.ts +3 -3
  9. package/dist/components/Amelipro/AmeliproCaptcha/AmeliproCaptcha.d.ts +132 -0
  10. package/dist/components/Amelipro/AmeliproCaptcha/types.d.ts +5 -0
  11. package/dist/components/Amelipro/AmeliproCard/AmeliproCard.d.ts +3 -3
  12. package/dist/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.d.ts +126 -0
  13. package/dist/components/Amelipro/AmeliproCustomSelector/types.d.ts +6 -0
  14. package/dist/components/Amelipro/AmeliproIllustratedDataTile/AmeliproIllustratedDataTile.d.ts +1 -1
  15. package/dist/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.d.ts +1 -1
  16. package/dist/components/Amelipro/AmeliproSelect/AmeliproSelect.d.ts +3 -3
  17. package/dist/components/Amelipro/AmeliproTable/AmeliproTable.d.ts +190 -0
  18. package/dist/components/Amelipro/AmeliproTable/types.d.ts +34 -0
  19. package/dist/components/Amelipro/AmeliproTabs/AmeliproTabs.d.ts +3 -3
  20. package/dist/components/Amelipro/AmeliproTextField/AmeliproTextField.d.ts +1 -1
  21. package/dist/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.d.ts +1 -1
  22. package/dist/components/Amelipro/types.d.ts +6 -0
  23. package/dist/components/CookieBanner/CookieBanner.d.ts +1 -1
  24. package/dist/components/Customs/Selects/SySelect/SySelect.d.ts +11 -2
  25. package/dist/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.d.ts +6 -1
  26. package/dist/components/Customs/SyTextField/SyTextField.d.ts +3 -1
  27. package/dist/components/DataList/DataList.d.ts +9 -0
  28. package/dist/components/DataListGroup/DataListGroup.d.ts +10 -1
  29. package/dist/components/DataListItem/DataListItem.d.ts +1 -1
  30. package/dist/components/DataListItem/config.d.ts +1 -1
  31. package/dist/components/DatePicker/CalendarMode/DatePicker.d.ts +18 -8
  32. package/dist/components/DatePicker/ComplexDatePicker/ComplexDatePicker.d.ts +16 -6
  33. package/dist/components/DatePicker/DateTextInput/DateTextInput.d.ts +6 -1
  34. package/dist/components/DatePicker/composables/useDateInputEditing.d.ts +17 -8
  35. package/dist/components/DatePicker/composables/useKeyboardEvents.d.ts +41 -0
  36. package/dist/components/DatePicker/composables/useManualDateValidation.d.ts +4 -9
  37. package/dist/components/DatePicker/utils/dateFormattingUtils.d.ts +72 -0
  38. package/dist/components/DatePicker/utils/validationUtils.d.ts +38 -0
  39. package/dist/components/HeaderBar/HeaderBurgerMenu/HeaderBurgerMenu.d.ts +9 -3
  40. package/dist/components/HeaderBar/HeaderBurgerMenu/HeaderMenuItem/HeaderMenuItem.d.ts +6 -1
  41. package/dist/components/HeaderBar/HeaderBurgerMenu/HeaderMenuSection/HeaderMenuSection.d.ts +11 -1
  42. package/dist/components/HeaderBar/HeaderBurgerMenu/HeaderSubMenu/HeaderSubMenu.d.ts +11 -1
  43. package/dist/components/HeaderBar/HeaderBurgerMenu/locals.d.ts +2 -0
  44. package/dist/components/HeaderBar/HeaderBurgerMenu/useMenuPosition.d.ts +4 -0
  45. package/dist/components/NirField/NirField.d.ts +14 -4
  46. package/dist/components/PeriodField/PeriodField.d.ts +24 -4
  47. package/dist/components/Tables/common/SyTablePagination.d.ts +10 -0
  48. package/dist/components/index.d.ts +4 -0
  49. package/dist/composables/index.d.ts +1 -0
  50. package/dist/composables/usePagination.d.ts +16 -0
  51. package/dist/design-system-v3.js +165 -160
  52. package/dist/design-system-v3.umd.cjs +120 -138
  53. package/dist/directives/lockFocus.d.ts +17 -0
  54. package/dist/{main-BzyNNvHX.js → main-BXPFSAB4.js} +14664 -13282
  55. package/dist/style.css +1 -0
  56. package/package.json +5 -2
  57. package/src/assets/amelipro/apTheme.scss +149 -0
  58. package/src/assets/amelipro/apTokens.scss +0 -148
  59. package/src/assets/overrides/_btns.scss +15 -0
  60. package/src/assets/overrides/_container.scss +36 -0
  61. package/src/assets/overrides/_forms.scss +7 -0
  62. package/src/assets/{_spacers.scss → overrides/_spacers.scss} +0 -7
  63. package/src/assets/overrides/_tables.scss +18 -0
  64. package/src/assets/overrides/_tooltips.scss +10 -0
  65. package/src/assets/overrides/_typography.scss +196 -0
  66. package/src/assets/settings.scss +11 -51
  67. package/src/assets/themes.scss +10 -0
  68. package/src/assets/tokens.scss +9 -156
  69. package/src/components/Accordion/composables/__tests__/useAccordionGroupCommunication.spec.ts +80 -40
  70. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordion.mdx +15 -0
  71. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordion.stories.ts +83 -0
  72. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordion.vue +86 -0
  73. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/AmeliproAccordionTemplate.vue +242 -0
  74. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/__tests__/AmeliproAccordionTemplate.spec.ts +20 -0
  75. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/__tests__/__snapshots__/AmeliproAccordionTemplate.spec.ts.snap +124 -0
  76. package/src/components/Amelipro/AmeliproAccordion/__tests__/AmeliproAccordion.spec.ts +20 -0
  77. package/src/components/Amelipro/AmeliproAccordion/__tests__/__snapshots__/AmeliproAccordion.spec.ts.snap +124 -0
  78. package/src/components/Amelipro/AmeliproCaptcha/AmeliproCaptcha.mdx +15 -0
  79. package/src/components/Amelipro/AmeliproCaptcha/AmeliproCaptcha.stories.ts +87 -0
  80. package/src/components/Amelipro/AmeliproCaptcha/AmeliproCaptcha.vue +233 -0
  81. package/src/components/Amelipro/AmeliproCaptcha/__tests__/AmeliproCaptcha.spec.ts +24 -0
  82. package/src/components/Amelipro/AmeliproCaptcha/__tests__/__snapshots__/AmeliproCaptcha.spec.ts.snap +384 -0
  83. package/src/components/Amelipro/AmeliproCaptcha/types.d.ts +5 -0
  84. package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.mdx +15 -0
  85. package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.stories.ts +143 -0
  86. package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.vue +351 -0
  87. package/src/components/Amelipro/AmeliproCustomSelector/__tests__/AmeliproCustomSelector.spec.ts +50 -0
  88. package/src/components/Amelipro/AmeliproCustomSelector/__tests__/__snapshots__/AmeliproCustomSelector.spec.ts.snap +186 -0
  89. package/src/components/Amelipro/AmeliproCustomSelector/types.d.ts +6 -0
  90. package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/tests/__snapshots__/AmeliproHeaderBrandSection.spec.ts.snap +1 -1
  91. package/src/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/tests/__snapshots__/AmeliproHeaderBar.spec.ts.snap +1 -1
  92. package/src/components/Amelipro/AmeliproHeader/tests/__snapshots__/AmeliproHeader.spec.ts.snap +1 -708
  93. package/src/components/Amelipro/AmeliproMenu/tests/__snapshots__/AmeliproMenu.spec.ts.snap +1 -1
  94. package/src/components/Amelipro/AmeliproPageLayout/tests/__snapshots__/AmeliproPageLayout.spec.ts.snap +1 -708
  95. package/src/components/Amelipro/AmeliproTable/AmeliproTable.mdx +22 -0
  96. package/src/components/Amelipro/AmeliproTable/AmeliproTable.stories.ts +550 -0
  97. package/src/components/Amelipro/AmeliproTable/AmeliproTable.vue +421 -0
  98. package/src/components/Amelipro/AmeliproTable/__tests__/AmeliproTable.spec.ts +72 -0
  99. package/src/components/Amelipro/AmeliproTable/__tests__/__snapshots__/AmeliproTable.spec.ts.snap +427 -0
  100. package/src/components/Amelipro/AmeliproTable/types.d.ts +34 -0
  101. package/src/components/Amelipro/ServiceMenu/ServiceMenu.vue +12 -1
  102. package/src/components/Amelipro/ServiceMenu/tests/__snapshots__/ServiceMenu.spec.ts.snap +0 -820
  103. package/src/components/Amelipro/types.ts +8 -0
  104. package/src/components/CollapsibleList/CollapsibleList.vue +0 -2
  105. package/src/components/CookieBanner/CookieBanner.vue +1 -3
  106. package/src/components/CopyBtn/CopyBtn.vue +9 -2
  107. package/src/components/CopyBtn/tests/CopyBtn.spec.ts +3 -1
  108. package/src/components/Customs/Selects/SySelect/Accessibilite.mdx +7 -0
  109. package/src/components/Customs/Selects/SySelect/Accessibilite.stories.ts +4 -1
  110. package/src/components/Customs/Selects/SySelect/SySelect.stories.ts +80 -0
  111. package/src/components/Customs/Selects/SySelect/SySelect.vue +280 -34
  112. package/src/components/Customs/Selects/SySelect/composables/tests/useSySelectKeyboard.spec.ts +14 -5
  113. package/src/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.ts +129 -12
  114. package/src/components/Customs/SyIcon/SyIcon.spec.ts +3 -0
  115. package/src/components/Customs/SyTextField/Accessibilite.stories.ts +3 -1
  116. package/src/components/Customs/SyTextField/SyTextField.stories.ts +79 -6
  117. package/src/components/Customs/SyTextField/SyTextField.vue +218 -24
  118. package/src/components/DataList/Accessibilite.stories.ts +4 -0
  119. package/src/components/DataList/DataList.vue +19 -12
  120. package/src/components/DataListGroup/Accessibilite.stories.ts +4 -0
  121. package/src/components/DataListGroup/DataListGroup.vue +32 -15
  122. package/src/components/DataListItem/DataListItem.vue +14 -11
  123. package/src/components/DataListItem/config.ts +1 -1
  124. package/src/components/DataListItem/tests/DataListItem.spec.ts +2 -2
  125. package/src/components/DatePicker/CalendarMode/DatePicker.vue +12 -7
  126. package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.stories.ts +174 -0
  127. package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.vue +27 -5
  128. package/src/components/DatePicker/DatePickerValidationExample/DatePickerValidation.stories.ts +286 -0
  129. package/src/components/DatePicker/DateTextInput/DateRange.stories.ts +1 -1
  130. package/src/components/DatePicker/DateTextInput/DateTextInput.vue +29 -31
  131. package/src/components/DatePicker/composables/tests/useManualDateValidation.spec.ts +11 -3
  132. package/src/components/DatePicker/composables/useDateInputEditing.ts +73 -209
  133. package/src/components/DatePicker/composables/useKeyboardEvents.ts +149 -0
  134. package/src/components/DatePicker/composables/useManualDateValidation.ts +27 -68
  135. package/src/components/DatePicker/utils/dateFormattingUtils.ts +228 -0
  136. package/src/components/DatePicker/utils/validationUtils.ts +90 -0
  137. package/src/components/DialogBox/Accessibilite.stories.ts +4 -0
  138. package/src/components/DialogBox/DialogBox.stories.ts +10 -10
  139. package/src/components/DialogBox/DialogBox.vue +83 -21
  140. package/src/components/DialogBox/tests/__snapshots__/DialogBox.spec.ts.snap +12 -6
  141. package/src/components/FileUpload/tests/FileUpload.spec.ts +3 -0
  142. package/src/components/FooterBar/FooterBar.vue +1 -0
  143. package/src/components/HeaderBar/Accessibilite.stories.ts +4 -0
  144. package/src/components/HeaderBar/HeaderBar.mdx +47 -22
  145. package/src/components/HeaderBar/HeaderBar.stories.ts +54 -13
  146. package/src/components/HeaderBar/HeaderBar.vue +2 -1
  147. package/src/components/HeaderBar/HeaderBurgerMenu/Accessibilite.stories.ts +4 -0
  148. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderBurgerMenu.stories.ts +160 -82
  149. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderBurgerMenu.vue +41 -56
  150. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderMenuItem/HeaderMenuItem.vue +10 -3
  151. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderMenuSection/HeaderMenuSection.vue +41 -18
  152. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderMenuSection/tests/HeaderMenuSection.spec.ts +7 -2
  153. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderSubMenu/HeaderSubMenu.stories.ts +36 -9
  154. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderSubMenu/HeaderSubMenu.vue +41 -9
  155. package/src/components/HeaderBar/HeaderBurgerMenu/locals.ts +2 -0
  156. package/src/components/HeaderBar/HeaderBurgerMenu/tests/HeaderBurgerMenu.spec.ts +1 -1
  157. package/src/components/HeaderBar/HeaderBurgerMenu/tests/__snapshots__/HeaderBurgerMenu.spec.ts.snap +8 -3
  158. package/src/components/HeaderBar/HeaderBurgerMenu/useMenuPosition.ts +50 -0
  159. package/src/components/HeaderBar/HeaderLogo/HeaderLogo.vue +5 -5
  160. package/src/components/HeaderBar/HeaderMenuBtn/HeaderMenuBtn.vue +7 -4
  161. package/src/components/HeaderBar/locales.ts +1 -1
  162. package/src/components/HeaderBar/tests/__snapshots__/HeaderBar.spec.ts.snap +2 -1
  163. package/src/components/HeaderLoading/HeaderLoading.vue +0 -1
  164. package/src/components/HeaderNavigationBar/tests/HeaderNavigationBar.spec.ts +2 -0
  165. package/src/components/LangBtn/LangBtn.vue +0 -3
  166. package/src/components/LogoBrandSection/Accessibilite.stories.ts +4 -1
  167. package/src/components/LogoBrandSection/LogoBrandSection.stories.ts +2 -2
  168. package/src/components/LogoBrandSection/LogoBrandSection.vue +13 -8
  169. package/src/components/LogoBrandSection/locales.ts +1 -1
  170. package/src/components/LogoBrandSection/tests/LogoBrandSection.spec.ts +1 -1
  171. package/src/components/LogoBrandSection/tests/__snapshots__/LogoBrandSection.spec.ts.snap +6 -4
  172. package/src/components/NirField/NirField.vue +5 -5
  173. package/src/components/NirField/tests/NirField.spec.ts +78 -12
  174. package/src/components/Tables/SyServerTable/tests/SyServerTable.spec.ts +104 -6
  175. package/src/components/Tables/common/TableHeader.vue +10 -7
  176. package/src/components/Tables/common/tableAccessibilityUtils.ts +13 -2
  177. package/src/components/Tables/common/useTableAria.ts +17 -1
  178. package/src/components/UserMenuBtn/tests/UserMenuBtn.spec.ts +2 -1
  179. package/src/components/index.ts +4 -0
  180. package/src/composables/date/tests/useDatePickerAccessibility.spec.ts +34 -5
  181. package/src/composables/index.ts +3 -0
  182. package/src/composables/useFilterable/useFilterable.ts +13 -1
  183. package/src/composables/usePagination.ts +103 -0
  184. package/src/directives/lockFocus.ts +48 -0
  185. package/src/main.ts +1 -2
  186. package/src/stories/Accessibilite/Aculturation/SensibilisationAccessibilite.mdx +1 -8
  187. package/src/stories/Accessibilite/{Aculturation/AuditDesignSystem.mdx → AuditDesignSystem.mdx} +1 -1
  188. package/src/stories/Accessibilite/KitDePreAudit/Outils/Tanaguru/FauxPositifs.mdx +102 -0
  189. package/src/stories/Accessibilite/KitDePreAudit/Outils/Tanaguru/FauxPositifs.stories.ts +219 -0
  190. package/src/stories/Accessibilite/KitDePreAudit/Outils/{Tanaguru.mdx → Tanaguru/Utilisation.mdx} +1 -1
  191. package/src/stories/DesignTokens/ColorIntegrationExample.vue +43 -0
  192. package/src/stories/DesignTokens/Colors.mdx +2 -0
  193. package/src/stories/DesignTokens/colors.stories.ts +9 -0
  194. package/src/vuetifyConfig.ts +3 -3
  195. package/dist/DateFilter-yrwJv_2R.js +0 -95
  196. package/dist/NumberFilter-BQXtywZI.js +0 -117
  197. package/dist/PeriodFilter-BYXVSzr5.js +0 -108
  198. package/dist/SelectFilter-CJV_mlN3.js +0 -133
  199. package/dist/TextFilter-DN0ejYIs.js +0 -110
  200. package/dist/design-system-v3.css +0 -1
  201. package/dist/directives/letterSpacing.d.ts +0 -27
  202. package/src/assets/_fonts.scss +0 -6
  203. package/src/assets/_typography.scss +0 -157
  204. package/src/directives/letterSpacing.ts +0 -233
  205. /package/src/assets/{_elevations.scss → overrides/_elevations.scss} +0 -0
  206. /package/src/assets/{_radius.scss → overrides/_radius.scss} +0 -0
@@ -0,0 +1,22 @@
1
+ import { Controls, Canvas, Meta, Source } from '@storybook/blocks';
2
+
3
+ import * as AmeliproTableStories from './AmeliproTable.stories';
4
+
5
+ <Meta of={AmeliproTableStories} />
6
+
7
+ # AmeliproTable
8
+
9
+ L’élément `AmeliproTable` est utilisé pour afficher des tableaux de données dans l’application Amelipro
10
+
11
+ <Canvas of={AmeliproTableStories.Default} />
12
+
13
+ ## API
14
+
15
+ <Controls of={AmeliproTableStories.Default} />
16
+
17
+ ## Usages
18
+
19
+ Ce composant est a utiliser pour afficher des tableaux de données simples dans les services amelipro, lorsqu'il est affiché en mobile le composant se divise en plusieurs petits tableaux affichant chacune les données d'une ligne.
20
+
21
+
22
+
@@ -0,0 +1,550 @@
1
+ import type { Meta, StoryObj } from '@storybook/vue3'
2
+ import AmeliproMessage from '../AmeliproMessage/AmeliproMessage.vue'
3
+ import AmeliproTable from './AmeliproTable.vue'
4
+ const meta = {
5
+ argTypes: {
6
+ '`item-${headers[cellIndex].name}`': { description: 'Slot généré automatiquement pour chaque colonne (`name` nom de la colonne dans headers) vous devez y bind la ligne, pour permettre de renseigner autres chose que des données textuelles si besoin. Le contenu du slot apparaît seulement si la valeur de la cellule concernée est `undefined`.' },
7
+ 'change:pagination-select': {
8
+ table: { category: 'events' },
9
+ description: 'Emit lors d\'un changement sur le select de nombre d\'items par page.',
10
+ },
11
+ 'change:sort-select': {
12
+ table: { category: 'events' },
13
+ description: 'Emit lors d\'un changement sur le select de tri.',
14
+ },
15
+ 'click': {
16
+ table: { category: 'events' },
17
+ description: 'Emit lors d\'un clic sur la pagination.',
18
+ },
19
+ 'counterLabel': { description: 'Label du compteur de résultats en haut du tableau' },
20
+ 'dataList': {
21
+ description: 'Tableau comprenant la liste des données d’une ligne du tableau la clé étant la colonne à afficher devant correspondre au `name` d’un élément de la liste d’entêtes',
22
+ table: {
23
+ type: {
24
+ summary: 'IDataListItem[]',
25
+ detail: `Array<{
26
+ id: number,
27
+ [key: string]: string
28
+ }`,
29
+ },
30
+ },
31
+ },
32
+ 'headers': {
33
+ description: 'Tableau comprenant la liste des entêtes du tableau ainsi que les styles à appliquer aux entêtes et colonnes',
34
+ table: {
35
+ type: {
36
+ summary: 'AmeliproTableHeader[]',
37
+ detail: `Array<{
38
+ name: string;
39
+ title: string;
40
+ align: 'left' | 'right' | 'center';
41
+ headerClasses?: string;
42
+ cellsClasses?: string;
43
+ minWidth: string;
44
+ width: string;
45
+ maxWidth: string;
46
+ descriptionId?: string;
47
+ }>`,
48
+ },
49
+ },
50
+ },
51
+ 'hiddenLabels': { description: 'Masque les labels des champs select' },
52
+ 'itemsToDisplayDesktop': { description: 'Nombre d’éléments affichés par page en desktop par défaut' },
53
+ 'itemsToDisplayMobile': { description: 'Nombre d’éléments affichés par page en mobile par défaut' },
54
+ 'noTableInfos': { description: 'Masques les informations et les filtres au-dessus du tableau' },
55
+ 'paginationSelectLabel': { description: 'Label du select de pagination' },
56
+ 'paginationSelectPlaceholder': { description: 'Placeholder du select de pagination' },
57
+ 'sortSelectItems': { description: 'Items du select dédié aux tris' },
58
+ 'sortSelectLabel': { description: 'Label du select de tri' },
59
+ 'sortSelectPlaceholder': { description: 'Placeholder du select de tri' },
60
+ 'tableMaxWidth': { description: 'Largeur maximale de la div entourant le tableau' },
61
+ 'tableMinWidth': { description: 'Largeur minimale de la div entourant le tableau' },
62
+ 'tableWidth': { description: 'Largeur de la div entourant le tableau' },
63
+ 'title': { description: 'Titre du tableau' },
64
+ 'uniqueId': { description: 'Identifiant unique du tableau' },
65
+ 'verticalBorder': { description: 'Affiche des bordures verticales entre les colonnes' },
66
+
67
+ },
68
+ component: AmeliproTable,
69
+ parameters: { controls: { exclude: ['`item-${headeritem.name}`'] } },
70
+ title: 'Composants/Amelipro/Tableaux/AmeliproTable',
71
+ } as Meta<typeof AmeliproTable>
72
+
73
+ export default meta
74
+
75
+ type Story = StoryObj<typeof AmeliproTable>
76
+
77
+ const headers = [
78
+ {
79
+ align: 'left',
80
+ maxWidth: '25%',
81
+ minWidth: '20%',
82
+ name: 'name',
83
+ title: 'Nom',
84
+ width: '25%',
85
+ },
86
+ {
87
+ align: 'left',
88
+ maxWidth: '25%',
89
+ minWidth: '20%',
90
+ name: 'firstname',
91
+ title: 'Prénom',
92
+ width: '25%',
93
+ },
94
+ {
95
+ align: 'left',
96
+ maxWidth: '25%',
97
+ minWidth: '20%',
98
+ name: 'email',
99
+ title: 'E-mail',
100
+ width: '25%',
101
+ },
102
+ ]
103
+
104
+ const dataList = [
105
+ {
106
+ email: 'jean.bernard@gmail.com',
107
+ firstname: 'Jean',
108
+ id: 0,
109
+ name: 'Bernard',
110
+ },
111
+ {
112
+ email: 'simon.pierre@gmail.com',
113
+ firstname: 'Simon',
114
+ id: 1,
115
+ name: 'Pierre',
116
+ },
117
+ {
118
+ email: 'michel.souris@gmail.com',
119
+ firstname: 'Michel',
120
+ id: 2,
121
+ name: 'Souris',
122
+ },
123
+ {
124
+ email: 'amandine.jabot@gmail.com',
125
+ firstname: 'Amandine',
126
+ id: 3,
127
+ name: 'Jabot',
128
+ },
129
+ ]
130
+
131
+ export const Default: Story = {
132
+ args: {
133
+ dataList,
134
+ headers,
135
+ title: 'Exemple de tableau',
136
+ uniqueId: 'table-example',
137
+ },
138
+ parameters: {
139
+ args: {
140
+ dataList,
141
+ headers,
142
+ title: 'Exemple de tableau',
143
+ uniqueId: 'table-example',
144
+ },
145
+ render: () => ({
146
+ components: { AmeliproTable },
147
+ setup() {
148
+ return {}
149
+ },
150
+ }),
151
+ sourceCode: [
152
+ {
153
+ name: 'Template',
154
+ code: `<template>
155
+ <AmeliproTable
156
+ :data-list="dataList"
157
+ :headers="headers"
158
+ title="Exemple de tableau"
159
+ unique-id="table-example"
160
+ />
161
+ </template>
162
+ `,
163
+ },
164
+ {
165
+ name: 'Script',
166
+ code: `<script setup lang="ts">
167
+ import { AmeliproTable } from '@cnamts/synapse'
168
+
169
+ const headers = [
170
+ {
171
+ align: 'left',
172
+ maxWidth: '25%',
173
+ minWidth: '20%',
174
+ name: 'name',
175
+ title: 'Nom',
176
+ width: '25%',
177
+ },
178
+ {
179
+ align: 'left',
180
+ maxWidth: '25%',
181
+ minWidth: '20%',
182
+ name: 'firstname',
183
+ title: 'Prénom',
184
+ width: '25%',
185
+ },
186
+ {
187
+ align: 'left',
188
+ maxWidth: '25%',
189
+ minWidth: '20%',
190
+ name: 'email',
191
+ title: 'E-mail',
192
+ width: '25%',
193
+ },
194
+ ]
195
+
196
+ const dataList = [
197
+ {
198
+ email: 'jean.bernard@gmail.com',
199
+ firstname: 'Jean',
200
+ id: 0,
201
+ name: 'Bernard',
202
+ },
203
+ {
204
+ email: 'simon.pierre@gmail.com',
205
+ firstname: 'Simon',
206
+ id: 1,
207
+ name: 'Pierre',
208
+ },
209
+ {
210
+ email: 'michel.souris@gmail.com',
211
+ firstname: 'Michel',
212
+ id: 2,
213
+ name: 'Souris',
214
+ },
215
+ {
216
+ email: 'amandine.jabot@gmail.com',
217
+ firstname: 'Amandine',
218
+ id: 3,
219
+ name: 'Jabot',
220
+ },
221
+ ]
222
+ </script>
223
+ `,
224
+ },
225
+ ],
226
+ },
227
+ }
228
+
229
+ // Story n°2
230
+
231
+ const headersAdvanced = [
232
+ {
233
+ align: 'left',
234
+ maxWidth: '25%',
235
+ minWidth: '20%',
236
+ name: 'name',
237
+ title: 'Nom',
238
+ width: '25%',
239
+ },
240
+ {
241
+ align: 'left',
242
+ maxWidth: '25%',
243
+ minWidth: '20%',
244
+ name: 'firstname',
245
+ title: 'Prénom',
246
+ width: '25%',
247
+ },
248
+ {
249
+ align: 'left',
250
+ maxWidth: '25%',
251
+ minWidth: '20%',
252
+ name: 'email',
253
+ title: 'E-mail',
254
+ width: '25%',
255
+ },
256
+ {
257
+ align: 'left',
258
+ maxWidth: '25%',
259
+ minWidth: '20%',
260
+ name: 'actions',
261
+ title: 'Actions',
262
+ width: '25%',
263
+ },
264
+ ]
265
+
266
+ const dataListAdvanced = [
267
+ {
268
+ actions: undefined,
269
+ email: 'jean.bernard@gmail.com',
270
+ firstname: 'Jean',
271
+ id: 0,
272
+ messageText: 'Erreur',
273
+ name: 'Bernard',
274
+ type: 'error',
275
+ },
276
+ {
277
+ email: 'simon.pierre@gmail.com',
278
+ firstname: 'Simon',
279
+ id: 1,
280
+ messageText: 'Attention',
281
+ name: 'Pierre',
282
+ type: 'warning',
283
+ },
284
+ {
285
+ email: 'michel.souris@gmail.com',
286
+ firstname: 'Michel',
287
+ id: 2,
288
+ messageText: 'Information',
289
+ name: 'Souris',
290
+ },
291
+ {
292
+ actions: 'Pas de slot',
293
+ email: 'amandine.jabot@gmail.com',
294
+ firstname: 'Amandine',
295
+ id: 3,
296
+ name: 'Jabot',
297
+ },
298
+ {
299
+ email: 'jean.bernard@gmail.com',
300
+ firstname: 'Jean',
301
+ id: 4,
302
+ messageText: 'Erreur',
303
+ name: 'Bernard',
304
+ type: 'error',
305
+ },
306
+ {
307
+ email: 'simon.pierre@gmail.com',
308
+ firstname: 'Simon',
309
+ id: 5,
310
+ messageText: 'Attention',
311
+ name: 'Pierre',
312
+ type: 'warning',
313
+ },
314
+ {
315
+ email: 'michel.souris@gmail.com',
316
+ firstname: 'Michel',
317
+ id: 6,
318
+ messageText: 'Information',
319
+ name: 'Souris',
320
+ },
321
+ {
322
+ actions: 'Pas de slot',
323
+ email: 'amandine.jabot@gmail.com',
324
+ firstname: 'Amandine',
325
+ id: 7,
326
+ name: 'Jabot',
327
+ },
328
+ {
329
+ email: 'jean.bernard@gmail.com',
330
+ firstname: 'Jean',
331
+ id: 8,
332
+ messageText: 'Erreur',
333
+ name: 'Bernard',
334
+ type: 'error',
335
+ },
336
+ {
337
+ email: 'simon.pierre@gmail.com',
338
+ firstname: 'Simon',
339
+ id: 9,
340
+ messageText: 'Attention',
341
+ name: 'Pierre',
342
+ type: 'warning',
343
+ },
344
+ {
345
+ email: 'michel.souris@gmail.com',
346
+ firstname: 'Michel',
347
+ id: 10,
348
+ messageText: 'Information',
349
+ name: 'Souris',
350
+ },
351
+ {
352
+ actions: 'Pas de slot',
353
+ email: 'amandine.jabot@gmail.com',
354
+ firstname: 'Amandine',
355
+ id: 11,
356
+ name: 'Jabot',
357
+ },
358
+ ]
359
+
360
+ export const Advanced: Story = {
361
+ args: {
362
+ dataList: dataListAdvanced,
363
+ headers: headersAdvanced,
364
+ title: 'Exemple de tableau avancé',
365
+ uniqueId: 'table-example-2',
366
+ },
367
+ parameters: {
368
+ sourceCode: [
369
+ {
370
+ name: 'Template',
371
+ code: `<template>
372
+ <AmeliproTable
373
+ :data-list="dataListAdvanced"
374
+ :headers="headersAdvanced"
375
+ title="Exemple de tableau"
376
+ unique-id="table-example-2"
377
+ >
378
+ <template #item-actions="row">
379
+ <AmeliproMessage
380
+ text
381
+ :type="row.type"
382
+ :unique-id="[\`tableau-slot-message-\${row.id}\`]"
383
+ >
384
+ {{ row.messageText }}
385
+ </AmeliproMessage>
386
+ </template>
387
+ </AmeliproTable>
388
+ </template>
389
+ `,
390
+ },
391
+ {
392
+ name: 'Script',
393
+ code: `<script setup lang="ts">
394
+ import { AmeliproMessage, AmeliproTable } from '@cnamts/synapse'
395
+
396
+ const headersAdvanced = [
397
+ {
398
+ align: 'left',
399
+ maxWidth: '25%',
400
+ minWidth: '20%',
401
+ name: 'name',
402
+ title: 'Nom',
403
+ width: '25%',
404
+ },
405
+ {
406
+ align: 'left',
407
+ maxWidth: '25%',
408
+ minWidth: '20%',
409
+ name: 'firstname',
410
+ title: 'Prénom',
411
+ width: '25%',
412
+ },
413
+ {
414
+ align: 'left',
415
+ maxWidth: '25%',
416
+ minWidth: '20%',
417
+ name: 'email',
418
+ title: 'E-mail',
419
+ width: '25%',
420
+ },
421
+ {
422
+ align: 'left',
423
+ maxWidth: '25%',
424
+ minWidth: '20%',
425
+ name: 'actions',
426
+ title: 'Actions',
427
+ width: '25%',
428
+ },
429
+ ]
430
+
431
+ const dataListAdvanced = [
432
+ {
433
+ actions: undefined,
434
+ email: 'jean.bernard@gmail.com',
435
+ firstname: 'Jean',
436
+ id: 0,
437
+ messageText: 'Erreur',
438
+ name: 'Bernard',
439
+ type: 'error',
440
+ },
441
+ {
442
+ email: 'simon.pierre@gmail.com',
443
+ firstname: 'Simon',
444
+ id: 1,
445
+ messageText: 'Attention',
446
+ name: 'Pierre',
447
+ type: 'warning',
448
+ },
449
+ {
450
+ email: 'michel.souris@gmail.com',
451
+ firstname: 'Michel',
452
+ id: 2,
453
+ messageText: 'Information',
454
+ name: 'Souris',
455
+ },
456
+ {
457
+ actions: 'Pas de slot',
458
+ email: 'amandine.jabot@gmail.com',
459
+ firstname: 'Amandine',
460
+ id: 3,
461
+ name: 'Jabot',
462
+ },
463
+ {
464
+ email: 'jean.bernard@gmail.com',
465
+ firstname: 'Jean',
466
+ id: 4,
467
+ messageText: 'Erreur',
468
+ name: 'Bernard',
469
+ type: 'error',
470
+ },
471
+ {
472
+ email: 'simon.pierre@gmail.com',
473
+ firstname: 'Simon',
474
+ id: 5,
475
+ messageText: 'Attention',
476
+ name: 'Pierre',
477
+ type: 'warning',
478
+ },
479
+ {
480
+ email: 'michel.souris@gmail.com',
481
+ firstname: 'Michel',
482
+ id: 6,
483
+ messageText: 'Information',
484
+ name: 'Souris',
485
+ },
486
+ {
487
+ actions: 'Pas de slot',
488
+ email: 'amandine.jabot@gmail.com',
489
+ firstname: 'Amandine',
490
+ id: 7,
491
+ name: 'Jabot',
492
+ },
493
+ {
494
+ email: 'jean.bernard@gmail.com',
495
+ firstname: 'Jean',
496
+ id: 8,
497
+ messageText: 'Erreur',
498
+ name: 'Bernard',
499
+ type: 'error',
500
+ },
501
+ {
502
+ email: 'simon.pierre@gmail.com',
503
+ firstname: 'Simon',
504
+ id: 9,
505
+ messageText: 'Attention',
506
+ name: 'Pierre',
507
+ type: 'warning',
508
+ },
509
+ {
510
+ email: 'michel.souris@gmail.com',
511
+ firstname: 'Michel',
512
+ id: 10,
513
+ messageText: 'Information',
514
+ name: 'Souris',
515
+ },
516
+ {
517
+ actions: 'Pas de slot',
518
+ email: 'amandine.jabot@gmail.com',
519
+ firstname: 'Amandine',
520
+ id: 11,
521
+ name: 'Jabot',
522
+ },
523
+ ]
524
+ </script>
525
+ `,
526
+ },
527
+ ],
528
+ },
529
+ render: args => ({
530
+ components: { AmeliproTable, AmeliproMessage },
531
+ setup() {
532
+ return { args }
533
+ },
534
+ template: `
535
+ <AmeliproTable
536
+ v-bind="args"
537
+ >
538
+ <template #item-actions="row">
539
+ <AmeliproMessage
540
+ text
541
+ :type="row.type"
542
+ :unique-id="[\`tableau-slot-message-\${row.id}\`]"
543
+ >
544
+ {{ row.messageText }}
545
+ </AmeliproMessage>
546
+ </template>
547
+ </AmeliproTable>
548
+ `,
549
+ }),
550
+ }