@cnamts/synapse 0.0.5-alpha → 0.0.7-alpha

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (229) hide show
  1. package/dist/design-system-v3.d.ts +487 -415
  2. package/dist/design-system-v3.js +2954 -2203
  3. package/dist/design-system-v3.umd.cjs +6 -6
  4. package/dist/style.css +1 -1
  5. package/package.json +17 -17
  6. package/src/assets/settings.scss +3 -0
  7. package/src/assets/tokens.scss +16 -16
  8. package/src/components/BackBtn/AccessibiliteItems.ts +0 -30
  9. package/src/components/BackBtn/BackBtn.mdx +1 -1
  10. package/src/components/BackBtn/BackBtn.stories.ts +12 -9
  11. package/src/components/BackBtn/BackBtn.vue +0 -1
  12. package/src/components/BackToTopBtn/AccessibiliteItems.ts +0 -30
  13. package/src/components/BackToTopBtn/BackToTopBtn.mdx +1 -1
  14. package/src/components/BackToTopBtn/BackToTopBtn.stories.ts +3 -3
  15. package/src/components/CollapsibleList/Accessibilite.stories.ts +4 -0
  16. package/src/components/CollapsibleList/AccessibiliteItems.ts +55 -62
  17. package/src/components/CollapsibleList/CollapsibleList.stories.ts +1 -1
  18. package/src/components/CookieBanner/Accessibilite.stories.ts +219 -0
  19. package/src/components/CookieBanner/AccessibiliteItems.ts +356 -0
  20. package/src/components/CookieBanner/CookieBanner.mdx +219 -0
  21. package/src/components/CookieBanner/CookieBanner.stories.ts +680 -0
  22. package/src/components/CookieBanner/CookieBanner.vue +225 -0
  23. package/src/components/CookieBanner/config.ts +38 -0
  24. package/src/components/CookieBanner/locales.ts +12 -0
  25. package/src/components/CookieBanner/tests/CookieBanner.spec.ts +129 -0
  26. package/src/components/CookieBanner/tests/__snapshots__/CookieBanner.spec.ts.snap +197 -0
  27. package/src/components/CookiesSelection/CookiesInformation/CookiesInformation.vue +123 -0
  28. package/src/components/CookiesSelection/CookiesInformation/locales.ts +21 -0
  29. package/src/components/CookiesSelection/CookiesInformation/tests/CookiesInformation.spec.ts +121 -0
  30. package/src/components/CookiesSelection/CookiesSelection.vue +127 -0
  31. package/src/components/CookiesSelection/CookiesTable/CookiesTable.vue +47 -0
  32. package/src/components/CookiesSelection/CookiesTable/headers.ts +14 -0
  33. package/src/components/CookiesSelection/CookiesTable/tests/CookiesTable.spec.ts +30 -0
  34. package/src/components/CookiesSelection/CookiesTable/tests/__snapshots__/CookiesTable.spec.ts.snap +3 -0
  35. package/src/components/CookiesSelection/locales.ts +10 -0
  36. package/src/components/CookiesSelection/tests/CookiesSelection.spec.ts +184 -0
  37. package/src/components/CookiesSelection/tests/__snapshots__/CookiesSelection.spec.ts.snap +192 -0
  38. package/src/components/CookiesSelection/types.ts +15 -0
  39. package/src/components/CopyBtn/AccessibiliteItems.ts +0 -30
  40. package/src/components/CopyBtn/CopyBtn.mdx +1 -1
  41. package/src/components/CopyBtn/CopyBtn.stories.ts +9 -6
  42. package/src/components/CopyBtn/CopyBtn.vue +0 -1
  43. package/src/components/Customs/SyBtnSelect/Accessibilite.mdx +14 -0
  44. package/src/components/Customs/SyBtnSelect/Accessibilite.stories.ts +193 -0
  45. package/src/components/Customs/SyBtnSelect/AccessibiliteItems.ts +139 -0
  46. package/src/components/Customs/SyBtnSelect/SyBtnSelect.mdx +3 -2
  47. package/src/components/Customs/SyBtnSelect/SyBtnSelect.stories.ts +30 -14
  48. package/src/components/Customs/SyBtnSelect/SyBtnSelect.vue +21 -13
  49. package/src/components/Customs/SyBtnSelect/constants/ExpertiseLevelEnum.ts +4 -0
  50. package/src/components/Customs/SyInputSelect/Accessibilite.mdx +14 -0
  51. package/src/components/Customs/SyInputSelect/Accessibilite.stories.ts +166 -0
  52. package/src/components/Customs/SyInputSelect/AccessibiliteItems.ts +96 -0
  53. package/src/components/Customs/SyInputSelect/SyInputSelect.mdx +7 -3
  54. package/src/components/Customs/SyInputSelect/SyInputSelect.stories.ts +24 -65
  55. package/src/components/Customs/SyInputSelect/SyInputSelect.vue +36 -4
  56. package/src/components/Customs/SyInputSelect/constants/ExpertiseLevelEnum.ts +4 -0
  57. package/src/components/Customs/SySelect/Accessibilite.mdx +14 -0
  58. package/src/components/Customs/SySelect/Accessibilite.stories.ts +217 -0
  59. package/src/components/Customs/SySelect/AccessibiliteItems.ts +173 -0
  60. package/src/components/Customs/SySelect/SySelect.mdx +4 -4
  61. package/src/components/Customs/SySelect/SySelect.stories.ts +4 -60
  62. package/src/components/Customs/SySelect/SySelect.vue +35 -8
  63. package/src/components/Customs/SySelect/constants/ExpertiseLevelEnum.ts +4 -0
  64. package/src/components/Customs/SyTextField/Accessibilite.mdx +14 -0
  65. package/src/components/Customs/SyTextField/Accessibilite.stories.ts +224 -0
  66. package/src/components/Customs/SyTextField/AccessibiliteItems.ts +198 -0
  67. package/src/components/Customs/SyTextField/SyTextField.mdx +1 -1
  68. package/src/components/Customs/SyTextField/SyTextField.stories.ts +118 -7
  69. package/src/components/Customs/SyTextField/SyTextField.vue +27 -7
  70. package/src/components/Customs/SyTextField/constants/ExpertiseLevelEnum.ts +4 -0
  71. package/src/components/Customs/SyTextField/tests/__snapshots__/SyTextField.spec.ts.snap +2 -1
  72. package/src/components/DataList/Accessibilite.mdx +14 -0
  73. package/src/components/DataList/Accessibilite.stories.ts +166 -0
  74. package/src/components/DataList/AccessibiliteItems.ts +47 -0
  75. package/src/components/DataList/DataList.mdx +1 -1
  76. package/src/components/DataList/DataList.stories.ts +10 -10
  77. package/src/components/DataList/constants/ExpertiseLevelEnum.ts +4 -0
  78. package/src/components/DataListGroup/Accessibilite.mdx +14 -0
  79. package/src/components/DataListGroup/Accessibilite.stories.ts +225 -0
  80. package/src/components/DataListGroup/AccessibiliteItems.ts +79 -0
  81. package/src/components/DataListGroup/DataListGroup.mdx +1 -1
  82. package/src/components/DataListGroup/DataListGroup.stories.ts +7 -7
  83. package/src/components/DataListGroup/constants/ExpertiseLevelEnum.ts +4 -0
  84. package/src/components/DialogBox/Accessibilite.mdx +14 -0
  85. package/src/components/DialogBox/Accessibilite.stories.ts +189 -0
  86. package/src/components/DialogBox/AccessibiliteItems.ts +167 -0
  87. package/src/components/DialogBox/constants/ExpertiseLevelEnum.ts +4 -0
  88. package/src/components/DownloadBtn/AccessibiliteItems.ts +1 -31
  89. package/src/components/DownloadBtn/DownloadBtn.mdx +5 -6
  90. package/src/components/DownloadBtn/DownloadBtn.stories.ts +25 -26
  91. package/src/components/ErrorPage/Accessibilite.mdx +14 -0
  92. package/src/components/ErrorPage/Accessibilite.stories.ts +189 -0
  93. package/src/components/ErrorPage/AccessibiliteItems.ts +205 -0
  94. package/src/components/ErrorPage/ErrorPage.vue +1 -1
  95. package/src/components/ErrorPage/constants/ExpertiseLevelEnum.ts +4 -0
  96. package/src/components/ErrorPage/tests/__snapshots__/ErrorPage.spec.ts.snap +4 -4
  97. package/src/components/FooterBar/Accessibilite.mdx +14 -0
  98. package/src/components/FooterBar/Accessibilite.stories.ts +223 -0
  99. package/src/components/FooterBar/AccessibiliteItems.ts +257 -0
  100. package/src/components/FooterBar/FooterBar.mdx +2 -2
  101. package/src/components/FooterBar/FooterBar.stories.ts +14 -14
  102. package/src/components/FooterBar/FooterBar.vue +86 -75
  103. package/src/components/FooterBar/constants/ExpertiseLevelEnum.ts +4 -0
  104. package/src/components/FooterBar/tests/__snapshots__/FooterBar.spec.ts.snap +22 -20
  105. package/src/components/FranceConnectBtn/AccessibiliteItems.ts +0 -30
  106. package/src/components/FranceConnectBtn/FranceConnectBtn.mdx +1 -1
  107. package/src/components/FranceConnectBtn/FranceConnectBtn.stories.ts +5 -4
  108. package/src/components/HeaderBar/Accessibilite.mdx +14 -0
  109. package/src/components/HeaderBar/Accessibilite.stories.ts +223 -0
  110. package/src/components/HeaderBar/AccessibiliteItems.ts +194 -0
  111. package/src/components/HeaderBar/HeaderBar.stories.ts +19 -12
  112. package/src/components/HeaderBar/HeaderBar.vue +9 -12
  113. package/src/components/HeaderBar/HeaderBurgerMenu/Accessibilite.mdx +14 -0
  114. package/src/components/HeaderBar/HeaderBurgerMenu/Accessibilite.stories.ts +223 -0
  115. package/src/components/HeaderBar/HeaderBurgerMenu/AccessibiliteItems.ts +174 -0
  116. package/src/components/HeaderBar/HeaderBurgerMenu/HeaderBurgerMenu.vue +1 -0
  117. package/src/components/HeaderBar/HeaderBurgerMenu/constants/ExpertiseLevelEnum.ts +4 -0
  118. package/src/components/HeaderBar/constants/ExpertiseLevelEnum.ts +4 -0
  119. package/src/components/HeaderBar/tests/__snapshots__/HeaderBar.spec.ts.snap +1 -1
  120. package/src/components/HeaderLoading/Accessibilite.mdx +14 -0
  121. package/src/components/HeaderLoading/Accessibilite.stories.ts +167 -0
  122. package/src/components/HeaderLoading/AccessibiliteItems.ts +29 -0
  123. package/src/components/HeaderLoading/HeaderLoading.mdx +1 -1
  124. package/src/components/HeaderLoading/HeaderLoading.stories.ts +1 -1
  125. package/src/components/HeaderLoading/constants/ExpertiseLevelEnum.ts +4 -0
  126. package/src/components/HeaderNavigationBar/HeaderNavigationBar.stories.ts +104 -32
  127. package/src/components/HeaderNavigationBar/HorizontalNavbar/HorizontalNavbar.vue +35 -33
  128. package/src/components/HeaderToolbar/Accessibilite.mdx +14 -0
  129. package/src/components/HeaderToolbar/Accessibilite.stories.ts +203 -0
  130. package/src/components/HeaderToolbar/AccessibiliteItems.ts +200 -0
  131. package/src/components/HeaderToolbar/HeaderToolbar.mdx +1 -1
  132. package/src/components/HeaderToolbar/HeaderToolbar.stories.ts +2 -2
  133. package/src/components/HeaderToolbar/HeaderToolbar.vue +24 -1
  134. package/src/components/HeaderToolbar/constants/ExpertiseLevelEnum.ts +4 -0
  135. package/src/components/LangBtn/Accessibilite.stories.ts +3 -1
  136. package/src/components/LangBtn/AccessibiliteItems.ts +0 -31
  137. package/src/components/LangBtn/LangBtn.mdx +1 -1
  138. package/src/components/LangBtn/LangBtn.stories.ts +4 -4
  139. package/src/components/LangBtn/LangBtn.vue +3 -2
  140. package/src/components/Logo/Accessibilite.mdx +14 -0
  141. package/src/components/Logo/Accessibilite.stories.ts +223 -0
  142. package/src/components/Logo/AccessibiliteItems.ts +155 -0
  143. package/src/components/Logo/Logo.mdx +1 -1
  144. package/src/components/Logo/Logo.stories.ts +8 -8
  145. package/src/components/Logo/constants/ExpertiseLevelEnum.ts +4 -0
  146. package/src/components/LogoBrandSection/Accessibilite.mdx +14 -0
  147. package/src/components/LogoBrandSection/Accessibilite.stories.ts +223 -0
  148. package/src/components/LogoBrandSection/AccessibiliteItems.ts +194 -0
  149. package/src/components/LogoBrandSection/constants/ExpertiseLevelEnum.ts +4 -0
  150. package/src/components/MaintenancePage/Accessibilite.mdx +14 -0
  151. package/src/components/MaintenancePage/Accessibilite.stories.ts +189 -0
  152. package/src/components/MaintenancePage/AccessibiliteItems.ts +173 -0
  153. package/src/components/MaintenancePage/constants/ExpertiseLevelEnum.ts +4 -0
  154. package/src/components/NirField/Accessibilite.mdx +14 -0
  155. package/src/components/NirField/Accessibilite.stories.ts +214 -0
  156. package/src/components/NirField/AccessibiliteItems.ts +243 -0
  157. package/src/components/NirField/NirField.mdx +213 -0
  158. package/src/components/NirField/NirField.stories.ts +412 -0
  159. package/src/components/NirField/NirField.vue +453 -0
  160. package/src/components/NirField/config.ts +16 -0
  161. package/src/components/NirField/constants/ExpertiseLevelEnum.ts +4 -0
  162. package/src/components/NirField/locales.ts +12 -0
  163. package/src/components/NirField/nirValidation.ts +42 -0
  164. package/src/components/NirField/tests/NirField.spec.ts +120 -0
  165. package/src/components/NotFoundPage/Accessibilite.mdx +14 -0
  166. package/src/components/NotFoundPage/Accessibilite.stories.ts +190 -0
  167. package/src/components/NotFoundPage/AccessibiliteItems.ts +205 -0
  168. package/src/components/NotFoundPage/constants/ExpertiseLevelEnum.ts +4 -0
  169. package/src/components/NotFoundPage/tests/__snapshots__/NotFoundPage.spec.ts.snap +4 -4
  170. package/src/components/NotificationBar/AccessibiliteItems.ts +0 -30
  171. package/src/components/NotificationBar/NotificationBar.mdx +1 -1
  172. package/src/components/PageContainer/PageContainer.mdx +1 -1
  173. package/src/components/PageContainer/PageContainer.stories.ts +9 -9
  174. package/src/components/PageContainer/PageContainer.vue +24 -18
  175. package/src/components/PageContainer/tests/PageContainer.spec.ts +2 -2
  176. package/src/components/PageContainer/tests/__snapshots__/PageContainer.spec.ts.snap +2 -2
  177. package/src/components/PhoneField/Accessibilite.mdx +14 -0
  178. package/src/components/PhoneField/Accessibilite.stories.ts +216 -0
  179. package/src/components/PhoneField/AccessibiliteItems.ts +238 -0
  180. package/src/components/PhoneField/PhoneField.mdx +1 -1
  181. package/src/components/PhoneField/PhoneField.stories.ts +2 -2
  182. package/src/components/PhoneField/PhoneField.vue +0 -1
  183. package/src/components/PhoneField/constants/ExpertiseLevelEnum.ts +4 -0
  184. package/src/components/SkipLink/Accessibilite.stories.ts +1 -1
  185. package/src/components/SkipLink/SkipLink.stories.ts +2 -2
  186. package/src/components/SocialMediaLinks/Accessibilite.mdx +14 -0
  187. package/src/components/SocialMediaLinks/Accessibilite.stories.ts +170 -0
  188. package/src/components/SocialMediaLinks/AccessibiliteItems.ts +160 -0
  189. package/src/components/SocialMediaLinks/SocialMediaLinks.mdx +1 -1
  190. package/src/components/SocialMediaLinks/SocialMediaLinks.stories.ts +1 -1
  191. package/src/components/SocialMediaLinks/SocialMediaLinks.vue +7 -1
  192. package/src/components/SocialMediaLinks/constants/ExpertiseLevelEnum.ts +4 -0
  193. package/src/components/SocialMediaLinks/tests/__snapshots__/SocialMediaLinks.spec.ts.snap +2 -2
  194. package/src/components/SubHeader/Accessibilite.mdx +14 -0
  195. package/src/components/SubHeader/Accessibilite.stories.ts +166 -0
  196. package/src/components/SubHeader/AccessibiliteItems.ts +146 -0
  197. package/src/components/SubHeader/SubHeader.mdx +1 -1
  198. package/src/components/SubHeader/SubHeader.stories.ts +17 -14
  199. package/src/components/SubHeader/constants/ExpertiseLevelEnum.ts +4 -0
  200. package/src/components/SyAlert/Accessibilite.mdx +14 -0
  201. package/src/components/{Alert → SyAlert}/Accessibilite.stories.ts +1 -1
  202. package/src/components/{Alert → SyAlert}/AccessibiliteItems.ts +2 -32
  203. package/src/components/{Alert/Alert.mdx → SyAlert/SyAlert.mdx} +9 -9
  204. package/src/components/{Alert/Alert.stories.ts → SyAlert/SyAlert.stories.ts} +22 -22
  205. package/src/components/{Alert/Alert.vue → SyAlert/SyAlert.vue} +7 -0
  206. package/src/components/SyAlert/constants/ExpertiseLevelEnum.ts +4 -0
  207. package/src/components/{Alert/tests/Alert.spec.ts → SyAlert/tests/SyAlert.spec.ts} +5 -5
  208. package/src/components/{Alert/tests/__snapshots__/Alert.spec.ts.snap → SyAlert/tests/__snapshots__/SyAlert.spec.ts.snap} +2 -2
  209. package/src/components/UserMenuBtn/Accessibilite.mdx +14 -0
  210. package/src/components/UserMenuBtn/Accessibilite.stories.ts +189 -0
  211. package/src/components/UserMenuBtn/AccessibiliteItems.ts +155 -0
  212. package/src/components/UserMenuBtn/UserMenuBtn.mdx +17 -17
  213. package/src/components/UserMenuBtn/UserMenuBtn.stories.ts +121 -19
  214. package/src/components/UserMenuBtn/UserMenuBtn.vue +25 -29
  215. package/src/components/UserMenuBtn/config.ts +1 -1
  216. package/src/components/UserMenuBtn/constants/ExpertiseLevelEnum.ts +4 -0
  217. package/src/components/index.ts +11 -4
  218. package/src/composables/rules/tests/useFieldValidation.spec.ts +60 -58
  219. package/src/composables/rules/useFieldValidation.ts +65 -28
  220. package/src/main.ts +1 -0
  221. package/src/stories/GuideDuDev/CommentUtiliserLesRules.mdx +67 -79
  222. package/src/stories/GuideDuDev/components.stories.ts +5 -5
  223. package/src/stories/GuideDuDev/moduleDeNotification.mdx +1 -1
  224. package/src/stories/Guidelines/Vuetify/Vuetify.mdx +11 -0
  225. package/src/stories/Guidelines/Vuetify/Vuetify.stories.ts +138 -0
  226. package/src/stories/Guidelines/Vuetify/VuetifyItems.ts +350 -0
  227. /package/src/components/{Alert → CookieBanner}/Accessibilite.mdx +0 -0
  228. /package/src/components/{Alert → CookieBanner}/constants/ExpertiseLevelEnum.ts +0 -0
  229. /package/src/components/{Alert → SyAlert}/locales.ts +0 -0
@@ -1,13 +1,13 @@
1
1
  import type { Meta, StoryObj } from '@storybook/vue3'
2
2
 
3
- import HeaderNavbar from './HeaderNavigationBar.vue'
3
+ import HeaderNavigationBar from './HeaderNavigationBar.vue'
4
4
  import { VBtn } from 'vuetify/components'
5
5
  import BackBtn from '../BackBtn/BackBtn.vue'
6
6
  import { fn } from '@storybook/test'
7
7
 
8
8
  const meta = {
9
9
  title: 'Composants/Structure/HeaderBar/HeaderNavigationBar',
10
- component: HeaderNavbar,
10
+ component: HeaderNavigationBar,
11
11
  parameters: {
12
12
  layout: 'fullscreen',
13
13
  },
@@ -248,7 +248,7 @@ const meta = {
248
248
  },
249
249
  },
250
250
  },
251
- } satisfies Meta<typeof HeaderNavbar>
251
+ } satisfies Meta<typeof HeaderNavigationBar>
252
252
 
253
253
  export default meta
254
254
 
@@ -272,7 +272,7 @@ export const Default: Story = {
272
272
  {
273
273
  name: 'Template',
274
274
  code: `
275
- <HeaderNavbar
275
+ <HeaderNavigationBar
276
276
  :items="[
277
277
  { label: 'Home', href: '' },
278
278
  { label: 'About', href: '' },
@@ -280,6 +280,14 @@ export const Default: Story = {
280
280
  />
281
281
  `,
282
282
  },
283
+ {
284
+ name: 'Script',
285
+ code: `
286
+ <script setup lang="ts">
287
+ import { HeaderNavigationBar } from '@cnamts/synapse'
288
+ </script>
289
+ `,
290
+ },
283
291
  ],
284
292
  },
285
293
  }
@@ -313,7 +321,7 @@ export const WithScroll: Story = {
313
321
  {
314
322
  name: 'Template',
315
323
  code: `<template>
316
- <HeaderNavbar
324
+ <HeaderNavigationBar
317
325
  :items="[
318
326
  { label: 'Home', href: '' },
319
327
  { label: 'About', href: '' },
@@ -325,6 +333,14 @@ export const WithScroll: Story = {
325
333
  </template>
326
334
  `,
327
335
  },
336
+ {
337
+ name: 'Script',
338
+ code: `
339
+ <script setup lang="ts">
340
+ import { HeaderNavigationBar } from '@cnamts/synapse'
341
+ </script>
342
+ `,
343
+ },
328
344
  ],
329
345
  },
330
346
  }
@@ -371,7 +387,7 @@ export const WithManyItems: Story = {
371
387
  {
372
388
  name: 'Template',
373
389
  code: `
374
- <HeaderNavbar
390
+ <HeaderNavigationBar
375
391
  :items="[
376
392
  {
377
393
  label: 'Home',
@@ -409,6 +425,14 @@ export const WithManyItems: Story = {
409
425
  />
410
426
  `,
411
427
  },
428
+ {
429
+ name: 'Script',
430
+ code: `
431
+ <script setup lang="ts">
432
+ import { HeaderNavigationBar } from '@cnamts/synapse'
433
+ </script>
434
+ `,
435
+ },
412
436
  ],
413
437
  },
414
438
  }
@@ -419,12 +443,12 @@ export const WithSlots: Story = {
419
443
  },
420
444
  render: (args) => {
421
445
  return {
422
- components: { HeaderNavbar, VBtn, BackBtn },
446
+ components: { HeaderNavigationBar, VBtn, BackBtn },
423
447
  setup() {
424
448
  return { args }
425
449
  },
426
450
  template: `
427
- <HeaderNavbar v-bind="args">
451
+ <HeaderNavigationBar v-bind="args">
428
452
  <template #logo-brand-content>
429
453
  <svg
430
454
  width="22"
@@ -468,7 +492,7 @@ export const WithSlots: Story = {
468
492
  Besoin d’aide ?
469
493
  </VBtn>
470
494
  </template>
471
- </HeaderNavbar>
495
+ </HeaderNavigationBar>
472
496
  `,
473
497
  }
474
498
  },
@@ -477,7 +501,7 @@ export const WithSlots: Story = {
477
501
  {
478
502
  name: 'Template',
479
503
  code: `<template>
480
- <HeaderNavbar>
504
+ <HeaderNavigationBar>
481
505
  <template #logo-brand-content>
482
506
  <svg
483
507
  width="22"
@@ -521,10 +545,18 @@ export const WithSlots: Story = {
521
545
  Besoin d’aide ?
522
546
  </VBtn>
523
547
  </template>
524
- </HeaderNavbar>
548
+ </HeaderNavigationBar>
525
549
  </template>
526
550
  `,
527
551
  },
552
+ {
553
+ name: 'Script',
554
+ code: `
555
+ <script setup lang="ts">
556
+ import { HeaderNavigationBar } from '@cnamts/synapse'
557
+ </script>
558
+ `,
559
+ },
528
560
  ],
529
561
  },
530
562
  }
@@ -535,12 +567,12 @@ export const WithLogoSlot: Story = {
535
567
  },
536
568
  render: (args) => {
537
569
  return {
538
- components: { HeaderNavbar, VBtn, BackBtn },
570
+ components: { HeaderNavigationBar, VBtn, BackBtn },
539
571
  setup() {
540
572
  return { args }
541
573
  },
542
574
  template: `
543
- <HeaderNavbar v-bind="args">
575
+ <HeaderNavigationBar v-bind="args">
544
576
  <template #logo-brand-content>
545
577
  <svg
546
578
  width="22"
@@ -561,7 +593,7 @@ export const WithLogoSlot: Story = {
561
593
  height="52px"
562
594
  />
563
595
  </template>
564
- </HeaderNavbar>
596
+ </HeaderNavigationBar>
565
597
  `,
566
598
  }
567
599
  },
@@ -570,7 +602,7 @@ export const WithLogoSlot: Story = {
570
602
  {
571
603
  name: 'Template',
572
604
  code: `
573
- <HeaderNavbar>
605
+ <HeaderNavigationBar>
574
606
  <template #logo-brand-content>
575
607
  <svg
576
608
  width="22"
@@ -591,7 +623,15 @@ export const WithLogoSlot: Story = {
591
623
  height="52px"
592
624
  />
593
625
  </template>
594
- </HeaderNavbar>
626
+ </HeaderNavigationBar>
627
+ `,
628
+ },
629
+ {
630
+ name: 'Script',
631
+ code: `
632
+ <script setup lang="ts">
633
+ import { HeaderNavigationBar } from '@cnamts/synapse'
634
+ </script>
595
635
  `,
596
636
  },
597
637
  ],
@@ -605,19 +645,19 @@ export const WithNavigationBarPrependSlot: Story = {
605
645
  },
606
646
  render: (args) => {
607
647
  return {
608
- components: { HeaderNavbar, VBtn, BackBtn },
648
+ components: { HeaderNavigationBar, VBtn, BackBtn },
609
649
  setup() {
610
650
  return { args }
611
651
  },
612
652
  template: `
613
- <HeaderNavbar v-bind="args" v-model="args.burgerMenu">
653
+ <HeaderNavigationBar v-bind="args" v-model="args.burgerMenu">
614
654
  <template #navigation-bar-prepend>
615
655
  <BackBtn
616
656
  :dark="true"
617
657
  class="mr-4"
618
658
  />
619
659
  </template>
620
- </HeaderNavbar>
660
+ </HeaderNavigationBar>
621
661
  `,
622
662
  }
623
663
  },
@@ -626,14 +666,22 @@ export const WithNavigationBarPrependSlot: Story = {
626
666
  {
627
667
  name: 'Template',
628
668
  code: `
629
- <HeaderNavbar>
669
+ <HeaderNavigationBar>
630
670
  <template #navigation-bar-prepend>
631
671
  <BackBtn
632
672
  :dark="true"
633
673
  class="mr-4"
634
674
  />
635
675
  </template>
636
- </HeaderNavbar>
676
+ </HeaderNavigationBar>
677
+ `,
678
+ },
679
+ {
680
+ name: 'Script',
681
+ code: `
682
+ <script setup lang="ts">
683
+ import { HeaderNavigationBar } from '@cnamts/synapse'
684
+ </script>
637
685
  `,
638
686
  },
639
687
  ],
@@ -646,12 +694,12 @@ export const WithNavigationBarAppendSlot: Story = {
646
694
  },
647
695
  render: (args) => {
648
696
  return {
649
- components: { HeaderNavbar, VBtn, BackBtn },
697
+ components: { HeaderNavigationBar, VBtn, BackBtn },
650
698
  setup() {
651
699
  return { args }
652
700
  },
653
701
  template: `
654
- <HeaderNavbar v-bind="args">
702
+ <HeaderNavigationBar v-bind="args">
655
703
  <template #navigation-bar-append>
656
704
  <VBtn
657
705
  variant="tonal"
@@ -660,7 +708,7 @@ export const WithNavigationBarAppendSlot: Story = {
660
708
  Besoin d’aide ?
661
709
  </VBtn>
662
710
  </template>
663
- </HeaderNavbar>
711
+ </HeaderNavigationBar>
664
712
  `,
665
713
  }
666
714
  },
@@ -670,7 +718,7 @@ export const WithNavigationBarAppendSlot: Story = {
670
718
  name: 'Template',
671
719
  code: `
672
720
  <template>
673
- <HeaderNavbar>
721
+ <HeaderNavigationBar>
674
722
  <template #navigation-bar-append>
675
723
  <VBtn
676
724
  variant="tonal"
@@ -679,10 +727,18 @@ export const WithNavigationBarAppendSlot: Story = {
679
727
  Besoin d’aide ?
680
728
  </VBtn>
681
729
  </template>
682
- </HeaderNavbar>
730
+ </HeaderNavigationBar>
683
731
  </template>
684
732
  `,
685
733
  },
734
+ {
735
+ name: 'Script',
736
+ code: `
737
+ <script setup lang="ts">
738
+ import { HeaderNavigationBar } from '@cnamts/synapse'
739
+ </script>
740
+ `,
741
+ },
686
742
  ],
687
743
  },
688
744
  }
@@ -695,12 +751,12 @@ export const WithNavigationMenuAppendSlot: Story = {
695
751
  },
696
752
  render: (args) => {
697
753
  return {
698
- components: { HeaderNavbar, VBtn, BackBtn },
754
+ components: { HeaderNavigationBar, VBtn, BackBtn },
699
755
  setup() {
700
756
  return { args }
701
757
  },
702
758
  template: `
703
- <HeaderNavbar
759
+ <HeaderNavigationBar
704
760
  v-bind="args"
705
761
  v-model="args.burgerMenu"
706
762
  @update:burgerMenu="()=>{
@@ -717,7 +773,7 @@ export const WithNavigationMenuAppendSlot: Story = {
717
773
  Besoin d’aide ?
718
774
  </VBtn>
719
775
  </template>
720
- </HeaderNavbar>
776
+ </HeaderNavigationBar>
721
777
  <div style="height: 200px;"></div>
722
778
  `,
723
779
  }
@@ -728,7 +784,7 @@ export const WithNavigationMenuAppendSlot: Story = {
728
784
  name: 'Template',
729
785
  code: `
730
786
  <template>
731
- <HeaderNavbar
787
+ <HeaderNavigationBar
732
788
  maxHorizontalMenuItems="0"
733
789
  :items="[
734
790
  { label: 'Home', href: '' },
@@ -744,10 +800,18 @@ export const WithNavigationMenuAppendSlot: Story = {
744
800
  Besoin d’aide ?
745
801
  </VBtn>
746
802
  </template>
747
- </HeaderNavbar>
803
+ </HeaderNavigationBar>
748
804
  </template>
749
805
  `,
750
806
  },
807
+ {
808
+ name: 'Script',
809
+ code: `
810
+ <script setup lang="ts">
811
+ import { HeaderNavigationBar } from '@cnamts/synapse'
812
+ </script>
813
+ `,
814
+ },
751
815
  ],
752
816
  },
753
817
  }
@@ -766,7 +830,7 @@ export const WithVuetifyOptions: Story = {
766
830
  {
767
831
  name: 'Template',
768
832
  code: `
769
- <HeaderNavbar
833
+ <HeaderNavigationBar
770
834
  :items="[
771
835
  { label: 'Home', href: '' },
772
836
  { label: 'About', href: '' },
@@ -779,6 +843,14 @@ export const WithVuetifyOptions: Story = {
779
843
  />
780
844
  `,
781
845
  },
846
+ {
847
+ name: 'Script',
848
+ code: `
849
+ <script setup lang="ts">
850
+ import { HeaderNavigationBar } from '@cnamts/synapse'
851
+ </script>
852
+ `,
853
+ },
782
854
  ],
783
855
  },
784
856
  }
@@ -1,5 +1,4 @@
1
1
  <script setup lang="ts">
2
- import { VTabs } from 'vuetify/components'
3
2
  import type { NavigationItem } from '../types'
4
3
  import useCustomizableOptions, { type CustomizableOptions } from '@/composables/useCustomizableOptions'
5
4
  import { config } from './config'
@@ -19,56 +18,59 @@
19
18
  </script>
20
19
 
21
20
  <template>
22
- <VSheet
23
- class="horizontal-menu px-12"
24
- v-bind="options.sheet"
25
- >
26
- <slot name="navigation-bar-prepend" />
27
- <slot>
28
- <VTabs
29
- class="horizontal-menu__tabs"
30
- v-bind="options.tabs"
31
- >
32
- <VTab
33
- v-for="(item, index) in items"
34
- :key="index"
35
- :href="item.href"
36
- :to="item.to"
37
- v-bind="options.tab"
38
- tabindex="0"
39
- class="horizontal-menu__item"
21
+ <VSheet v-bind="options.sheet">
22
+ <div class="horizontal-menu px-xl-0 px-14">
23
+ <slot name="navigation-bar-prepend" />
24
+ <slot>
25
+ <VTabs
26
+ class="horizontal-menu__tabs"
27
+ v-bind="options.tabs"
40
28
  >
41
- <span class="horizontal-menu__item-link">
42
- {{ item.label }}
43
- </span>
44
- </VTab>
45
- </VTabs>
46
- </slot>
47
- <slot name="navigation-bar-append" />
29
+ <VTab
30
+ v-for="(item, index) in items"
31
+ :key="index"
32
+ :href="item.href"
33
+ :to="item.to"
34
+ v-bind="options.tab"
35
+ tabindex="0"
36
+ class="horizontal-menu__item"
37
+ >
38
+ <span class="horizontal-menu__item-link">
39
+ {{ item.label }}
40
+ </span>
41
+ </VTab>
42
+ </VTabs>
43
+ </slot>
44
+ <slot name="navigation-bar-append" />
45
+ </div>
48
46
  </VSheet>
49
47
  </template>
50
48
 
51
49
  <style lang="scss" scoped>
50
+ @use '@/assets/tokens.scss' as *;
51
+ @use '@/components/HeaderBar/consts' as *;
52
52
 
53
53
  .horizontal-menu {
54
- display: flex;
55
- align-items: center;
54
+ display: flex;
55
+ align-items: center;
56
+ max-width: $header-max-width;
57
+ margin: 0 auto;
56
58
  }
57
59
 
58
60
  .horizontal-menu__tabs {
59
- flex: 1 1 0;
61
+ flex: 1 1 0;
60
62
  }
61
63
 
62
64
  .horizontal-menu__item {
63
- cursor: pointer;
65
+ cursor: pointer;
64
66
  }
65
67
 
66
68
  .horizontal-menu__item-link {
67
- font-size: 0.875rem;
68
- font-weight: 700;
69
+ font-size: 0.875rem;
70
+ font-weight: 700;
69
71
  }
70
72
 
71
73
  .v-tab-item--selected span {
72
- color: #fff;
74
+ color: #fff;
73
75
  }
74
76
  </style>
@@ -0,0 +1,14 @@
1
+ import { Meta, Story } from '@storybook/addon-docs';
2
+ import * as AccessStories from './Accessibilite.stories.ts';
3
+
4
+ <Meta of={AccessStories} />
5
+
6
+ Accessibilité
7
+ =============
8
+ <Story of={AccessStories.Legende} />
9
+ <br />
10
+
11
+ --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
12
+
13
+ <Story of={AccessStories.AccessibilitePanel} />
14
+ <br />
@@ -0,0 +1,203 @@
1
+ import { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VDataTable, VIcon } from 'vuetify/components'
2
+ import type { StoryObj } from '@storybook/vue3'
3
+ import { AccessibiliteItemsIndeterminate, AccessibiliteItemsValidated } from './AccessibiliteItems'
4
+ import { mdiCheckboxMarkedCircle, mdiLink, mdiEye } from '@mdi/js'
5
+
6
+ const checkIcon = mdiCheckboxMarkedCircle
7
+ const iconEye = mdiEye
8
+ const linkICon = mdiLink
9
+
10
+ export default {
11
+ title: 'Composants/Structure/HeaderToolbar/Accessibilité',
12
+ }
13
+
14
+ export const AccessibilitePanel: StoryObj = {
15
+
16
+ render: () => {
17
+ return {
18
+ components: { VExpansionPanels, VExpansionPanel, VExpansionPanelTitle, VExpansionPanelText, VDataTable, VIcon },
19
+
20
+ setup() {
21
+ const icon = checkIcon
22
+
23
+ return { AccessibiliteItemsIndeterminate, AccessibiliteItemsValidated, icon, linkICon, iconEye }
24
+ },
25
+ template: `
26
+ <div class="accessibiliteItems" style="display:flex; max-width: none !important;">
27
+ <v-col cols="6">
28
+ <div style="display:flex; margin-bottom: 10px; justify-content: space-between; align-items: center;">
29
+ <h5>{{ AccessibiliteItemsIndeterminate.length }} critères à prendre en charge par le projet</h5>
30
+ <div style="display: flex; align-items: center;">
31
+ <v-btn variant="tonal" color="red" size="x-small" style="margin: 4px;font-size: 8px;"
32
+ rounded>Tanaguru
33
+ </v-btn>
34
+ </div>
35
+ </div>
36
+
37
+ <v-expansion-panels value="opened" multiple>
38
+ <v-expansion-panel v-for="(item, index) in AccessibiliteItemsIndeterminate" :key="index" style="background-color: rgba(42, 96, 158, 0.1); margin-bottom: 10px;">
39
+ <v-expansion-panel-title>
40
+ <VIcon :icon="iconEye" style="margin-right: 5px; color:#5778b7;"/>
41
+ {{ item.title }}
42
+ </v-expansion-panel-title>
43
+ <v-expansion-panel-text>
44
+ <v-expansion-panels>
45
+ <v-expansion-panel>
46
+ <v-expansion-panel-title
47
+ style="font-weight: bold; font-size: 13px; line-height: 16px;">
48
+ {{ item.subtitle }}
49
+ </v-expansion-panel-title>
50
+ <v-expansion-panel-text>
51
+ <div v-for="(value, i) in item.items" :key="i">
52
+ <p style="font-size: 13px;line-height: 16px;">
53
+ {{ value.precision }}
54
+ </p>
55
+ <div v-for="element in value.solution"
56
+ style="margin-top:15px; font-size: 13px;line-height: 16px;">
57
+ <p style="font-weight: bold;">Méthodologie du test : <a
58
+ href="value.link" target="blank">
59
+ <VIcon :icon="linkICon"/>
60
+ </a></p>
61
+
62
+ <p>{{ element.info1 }}</p>
63
+ <p>{{ element.info2 }}</p>
64
+ <p>{{ element.info3 }}</p>
65
+ <p>{{ element.info4 }}</p>
66
+ <p>{{ element.info5 }}</p>
67
+ <p>{{ element.info6 }}</p>
68
+ <p>{{ element.info7 }}</p>
69
+
70
+ </div>
71
+ <span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
72
+ </div>
73
+ </v-expansion-panel-text>
74
+ </v-expansion-panel>
75
+ </v-expansion-panels>
76
+ </v-expansion-panel-text>
77
+ </v-expansion-panel>
78
+ </v-expansion-panels>
79
+ </v-col>
80
+ <v-col cols="6">
81
+ <div style="display:flex; margin-bottom: 10px; justify-content: space-between; align-items: center;">
82
+ <h5>{{ AccessibiliteItemsValidated.length }} critères pris en charge par l'équipe Design System</h5>
83
+ <div style="display: flex; align-items: center;">
84
+ <v-btn variant="tonal" color="red" size="x-small" style="margin: 4px;font-size: 8px;"
85
+ rounded>Tanaguru
86
+ </v-btn>
87
+ </div>
88
+ </div>
89
+ <v-expansion-panels v-if="AccessibiliteItemsValidated.length > 0" value="opened" multiple>
90
+ <v-expansion-panel
91
+ v-for="(item, index) in AccessibiliteItemsValidated"
92
+ :key="index" style="background-color: rgba(53,135,0,0.1); margin-bottom: 10px;">
93
+ <v-expansion-panel-title>
94
+ <VIcon color="green" :icon="icon" style="margin-right: 5px;"/>
95
+ {{ item.title }}
96
+ </v-expansion-panel-title>
97
+ <v-expansion-panel-text>
98
+ <v-expansion-panels>
99
+
100
+ <v-expansion-panel v-for="(i, index) in item.items2" :key="i" style="margin-bottom: 10px;">
101
+ <v-expansion-panel-title
102
+ style="font-weight: bold; font-size: 13px; line-height: 16px;">
103
+ {{ i.subtitle}}
104
+ </v-expansion-panel-title>
105
+ <v-expansion-panel-text>
106
+ <div>
107
+ <p style="font-size: 13px;line-height: 16px;">
108
+ {{ i.precision }}
109
+ </p>
110
+ <div v-for="(value, index) in i.solution"
111
+ style="margin-top:15px; font-size: 13px;line-height: 16px;">
112
+ <p style="font-weight: bold;">Méthodologie du test : <a
113
+ href="{{i.link}}" target="blank">
114
+ <VIcon :icon="linkICon"/>
115
+ </a></p>
116
+
117
+ <p>{{ value.info1 }}</p>
118
+ <p>{{ value.info2 }}</p>
119
+ <p>{{ value.info3 }}</p>
120
+
121
+ </div>
122
+ <span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
123
+ </div>
124
+ </v-expansion-panel-text>
125
+ </v-expansion-panel>
126
+
127
+ <v-expansion-panel>
128
+ <v-expansion-panel-title style="font-weight: bold;font-size: 13px; line-height: 16px;">
129
+ {{ item.subtitle }}
130
+ </v-expansion-panel-title>
131
+ <v-expansion-panel-text>
132
+ <div v-for="(value, i) in item.items" :key="i">
133
+ <p style="font-size: 13px;line-height: 16px;">
134
+ {{ value.precision }}
135
+ </p>
136
+ <div v-for="element in value.solution"
137
+ style="margin-top:15px; font-size: 13px;line-height: 16px;">
138
+ <p style="font-weight: bold;">Méthodologie du test : <a
139
+ href="value.link" target="blank">
140
+ <VIcon :icon="linkICon"/>
141
+ </a></p>
142
+ <p>{{ element.info1 }}</p>
143
+ <p>{{ element.info2 }}</p>
144
+ <p>{{ element.info3 }}</p>
145
+ <p>{{ element.info4 }}</p>
146
+ <p>{{ element.info5 }}</p>
147
+ <p>{{ element.info6 }}</p>
148
+ <p>{{ element.info7 }}</p>
149
+ </div>
150
+ <span style="display:flex; justify-content:center; margin-bottom:5px;">______</span>
151
+ </div>
152
+ </v-expansion-panel-text>
153
+ </v-expansion-panel>
154
+ </v-expansion-panels>
155
+ </v-expansion-panel-text>
156
+ </v-expansion-panel>
157
+ </v-expansion-panels>
158
+ <div v-else style="display: flex;justify-content: center;"><span style="text-align:center;" >Pas de critère d'accessibilité bloquant</span></div>
159
+ </v-col>
160
+ </div>
161
+ `,
162
+ }
163
+ },
164
+ tags: ['!dev'],
165
+ }
166
+
167
+ export const Legende: StoryObj = {
168
+ args: {
169
+ icon: checkIcon,
170
+ },
171
+ render: (args) => {
172
+ return {
173
+ components: { VIcon },
174
+ setup() {
175
+ return { args }
176
+ },
177
+ template: `
178
+ <p style="color: grey;font-size: 11px; margin-bottom: 12px;">Date de conception: 20/11/2024</p>
179
+ <div>
180
+ <p>Le tableau ci-dessous liste nos recommandations suivant les <a target="blank" style="color:#0C41BD;" href="https://www.numerique.gouv.fr/publications/rgaa-accessibilite/#contenu">catégories du RGAA</a>.</p>
181
+ <p style="margin-bottom: 12px;font-weight:bold;">Pour rappel le composant seul ne garantie pas
182
+ l'accessibilité du site.</p>
183
+ <div style="font-size: 14px">
184
+ <p>Nous avons deux façons de relever les problèmes d'accessibilité des composants :</p>
185
+ <div>
186
+ <v-btn variant="tonal" color="grey" size="x-small" style="margin: 2px;font-size: 8px;" rounded>
187
+ Audit
188
+ </v-btn>
189
+ Problèmes relevés par le projet
190
+ </div>
191
+ <div>
192
+ <v-btn variant="tonal" color="red" size="x-small" style="margin: 2px;font-size: 8px;" rounded>
193
+ Tanaguru
194
+ </v-btn>
195
+ Problèmes relevés par Tanaguru
196
+ </div>
197
+ </div>
198
+ </div>
199
+ `,
200
+ }
201
+ },
202
+ tags: ['!dev'],
203
+ }