@cnamts/synapse 1.0.15 → 1.0.16

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 (394) hide show
  1. package/dist/{DateFilter-isr8mXVb.js → DateFilter-DSwJUvBu.js} +12 -12
  2. package/dist/{NumberFilter-BOe7DqWX.js → NumberFilter-CwsbYyz4.js} +1 -1
  3. package/dist/{PeriodFilter-WTprpO40.js → PeriodFilter-csnEZU30.js} +1 -1
  4. package/dist/{SelectFilter-CqlG5dmI.js → SelectFilter-Bd5fndzR.js} +1 -1
  5. package/dist/{TextFilter-fVW5bsRw.js → TextFilter-B6gxzq2a.js} +1 -1
  6. package/dist/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.d.ts +2836 -2845
  7. package/dist/components/Amelipro/AmeliproCallback/AmeliproCallback.d.ts +3 -3
  8. package/dist/components/Amelipro/AmeliproCarousel/AmeliproCarousel.d.ts +7 -7
  9. package/dist/components/Amelipro/AmeliproCarousel/AmeliproCarouselItem/AmeliproCarouselItem.d.ts +3 -3
  10. package/dist/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.d.ts +3 -3
  11. package/dist/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.d.ts +3 -3
  12. package/dist/components/Amelipro/AmeliproClickableTile/AmeliproClickableTile.d.ts +3 -3
  13. package/dist/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.d.ts +3 -3
  14. package/dist/components/Amelipro/AmeliproErrorTemplate/AmeliproErrorTemplate.d.ts +3 -3
  15. package/dist/components/Amelipro/AmeliproFirstLogin/AmeliproFirstLogin.d.ts +3 -3
  16. package/dist/components/Amelipro/AmeliproFooter/AmeliproFooter.d.ts +18 -18
  17. package/dist/components/Amelipro/AmeliproHeader/AmeliproHeader.d.ts +9 -9
  18. package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBar.d.ts +3 -3
  19. package/dist/components/Amelipro/AmeliproHeader/AmeliproHeaderBar/AmeliproHeaderBrandSection/AmeliproHeaderBrandSection.d.ts +3 -3
  20. package/dist/components/Amelipro/AmeliproIcon/AmeliproIcon.d.ts +3 -1
  21. package/dist/components/Amelipro/AmeliproIconBtn/AmeliproIconBtn.d.ts +5 -3
  22. package/dist/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.d.ts +3 -3
  23. package/dist/components/Amelipro/AmeliproMenu/AmeliproMenu.d.ts +3 -3
  24. package/dist/components/Amelipro/AmeliproMultipleFoldingCard/AmeliproMultipleFoldingCard.d.ts +1 -1
  25. package/dist/components/Amelipro/AmeliproPagination/AmeliproPaginationBtn/AmeliproPaginationBtn.d.ts +3 -3
  26. package/dist/components/Amelipro/AmeliproPatientBanner/AmeliproPatientBanner.d.ts +3 -3
  27. package/dist/components/Amelipro/AmeliproPatientLogged/AmeliproPatientLogged.d.ts +9 -0
  28. package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/AmeliproPostalAddressCityRow.d.ts +1288 -1284
  29. package/dist/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.d.ts +1936 -1930
  30. package/dist/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.d.ts +3 -3
  31. package/dist/components/Amelipro/AmeliproSelect/AmeliproSelect.d.ts +2838 -2865
  32. package/dist/components/Amelipro/AmeliproStateTile/AmeliproStateTile.d.ts +3 -3
  33. package/dist/components/Amelipro/AmeliproTabs/AmeliproTabs.d.ts +2843 -2870
  34. package/dist/components/Amelipro/AmeliproTextArea/AmeliproTextArea.d.ts +397 -397
  35. package/dist/components/Amelipro/AmeliproTextField/AmeliproTextField.d.ts +642 -640
  36. package/dist/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.d.ts +233 -5
  37. package/dist/components/Amelipro/AmeliproTransmission/AmeliproTransmission.d.ts +9 -9
  38. package/dist/components/Captcha/CaptchaHelpdesk.d.ts +6 -0
  39. package/dist/components/CookieBanner/CookieBanner.d.ts +117 -119
  40. package/dist/components/CookiesSelection/CookiesInformation/CookiesInformation.d.ts +484 -484
  41. package/dist/components/CookiesSelection/CookiesSelection.d.ts +104 -106
  42. package/dist/components/Customs/Selects/SelectBtnField/SelectBtnField.d.ts +14 -10
  43. package/dist/components/Customs/Selects/SySelect/SySelect.d.ts +118 -129
  44. package/dist/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.d.ts +1 -3
  45. package/dist/components/Customs/SyCheckbox/SyCheckbox.d.ts +1 -1
  46. package/dist/components/Customs/SyForm/SyForm.d.ts +60 -53
  47. package/dist/components/Customs/SyRadioGroup/SyRadioGroup.d.ts +88 -0
  48. package/dist/components/Customs/SyRadioGroup/locales.d.ts +3 -0
  49. package/dist/components/Customs/SyTextField/SyTextField.d.ts +644 -642
  50. package/dist/components/DataList/DataList.d.ts +6 -1
  51. package/dist/components/DataListGroup/DataListGroup.d.ts +14 -2
  52. package/dist/components/DataListItem/DataListItem.d.ts +3 -0
  53. package/dist/components/DatePicker/CalendarMode/DatePicker.d.ts +2988 -3100
  54. package/dist/components/DatePicker/ComplexDatePicker/ComplexDatePicker.d.ts +1458 -1558
  55. package/dist/components/DatePicker/DateTextInput/DateTextInput.d.ts +655 -651
  56. package/dist/components/DatePicker/composables/index.d.ts +4 -0
  57. package/dist/components/DatePicker/composables/useAsteriskDisplay.d.ts +1 -1
  58. package/dist/components/DatePicker/composables/useCalendarKeyboardNavigation.d.ts +11 -0
  59. package/dist/components/DatePicker/composables/useDatePickerState.d.ts +25 -0
  60. package/dist/components/DatePicker/composables/useDateTextField.d.ts +61 -0
  61. package/dist/components/DatePicker/composables/useHolidayHighlighting.d.ts +15 -0
  62. package/dist/components/DatePicker/constants/messages.d.ts +0 -1
  63. package/dist/components/DialogBox/DialogBox.d.ts +175 -177
  64. package/dist/components/FilterSideBar/FilterSideBar.d.ts +161 -171
  65. package/dist/components/FooterBar/FooterBar.d.ts +5 -5
  66. package/dist/components/HeaderBar/HeaderBar.d.ts +2 -2
  67. package/dist/components/HeaderBar/HeaderLogo/HeaderLogo.d.ts +1 -1
  68. package/dist/components/HeaderNavigationBar/HeaderNavigationBar.d.ts +1 -1
  69. package/dist/components/HeaderToolbar/HeaderToolbar.d.ts +234 -258
  70. package/dist/components/LangBtn/LangBtn.d.ts +173 -179
  71. package/dist/components/LogoBrandSection/LogoBrandSection.d.ts +1 -1
  72. package/dist/components/LunarCalendar/LunarCalendar.d.ts +29 -0
  73. package/dist/components/LunarCalendar/useLunarCalendarRules.d.ts +5 -0
  74. package/dist/components/LunarCalendar/useLunarCalendarValidation.d.ts +13 -0
  75. package/dist/components/NirField/NirField.d.ts +1296 -1292
  76. package/dist/components/PaginatedTable/PaginatedTable.d.ts +1 -1
  77. package/dist/components/PeriodField/PeriodField.d.ts +5844 -6068
  78. package/dist/components/PhoneField/PhoneField.d.ts +645 -643
  79. package/dist/components/SyAlert/SyAlert.d.ts +31 -31
  80. package/dist/components/SyTextArea/SyTextArea.d.ts +395 -395
  81. package/dist/components/Tables/SyServerTable/SyServerTable.d.ts +193 -227
  82. package/dist/components/Tables/SyTable/SyTable.d.ts +192 -226
  83. package/dist/components/Tables/common/SyTableFilter.d.ts +1 -1
  84. package/dist/components/Tables/common/SyTablePagination.d.ts +118 -129
  85. package/dist/components/Tables/common/TableHeader.d.ts +52 -2
  86. package/dist/components/Tables/common/filters/DateFilter.d.ts +1 -1
  87. package/dist/components/Tables/common/filters/NumberFilter.d.ts +1 -1
  88. package/dist/components/Tables/common/filters/PeriodFilter.d.ts +1 -1
  89. package/dist/components/Tables/common/filters/SelectFilter.d.ts +1 -1
  90. package/dist/components/Tables/common/filters/TextFilter.d.ts +1 -1
  91. package/dist/components/Tables/common/locales.d.ts +1 -0
  92. package/dist/components/Tables/common/organizeColumns/OrganizeColumns.d.ts +86 -90
  93. package/dist/components/Tables/common/tableFilterUtils.d.ts +2 -2
  94. package/dist/components/Tables/common/types.d.ts +3 -2
  95. package/dist/components/Tables/common/useTableCheckbox.d.ts +3 -2
  96. package/dist/components/Tables/common/useTableFilter.d.ts +1 -1
  97. package/dist/components/Tables/common/useTableItems.d.ts +6 -8
  98. package/dist/components/UploadWorkflow/UploadWorkflow.d.ts +18 -18
  99. package/dist/components/index.d.ts +2 -0
  100. package/dist/design-system-v3.js +101 -98
  101. package/dist/design-system-v3.umd.cjs +25 -33
  102. package/dist/main-DkZZpa3S.js +35197 -0
  103. package/dist/style.css +1 -1
  104. package/dist/utils/formatNir/formatNir.d.ts +2 -0
  105. package/dist/utils/index.d.ts +1 -0
  106. package/dist/utils/insertAt.d.ts +1 -0
  107. package/dist/utils/rules/validateDateValue.d.ts +14 -0
  108. package/dist/vuetifyConfig.d.ts +6 -6
  109. package/package.json +4 -4
  110. package/src/assets/tokens.scss +2 -0
  111. package/src/components/Amelipro/AmeliproAccordion/AmeliproAccordionTemplate/__tests__/__snapshots__/AmeliproAccordionTemplate.spec.ts.snap +1 -18
  112. package/src/components/Amelipro/AmeliproAccordion/__tests__/AmeliproAccordion.spec.ts +178 -9
  113. package/src/components/Amelipro/AmeliproAccordion/__tests__/__snapshots__/AmeliproAccordion.spec.ts.snap +28 -121
  114. package/src/components/Amelipro/AmeliproAccordionFrieze/__tests__/__snapshots__/AmeliproAccordionFrieze.spec.ts.snap +15 -270
  115. package/src/components/Amelipro/AmeliproAccordionList/__tests__/__snapshots__/AmeliproAccordionList.spec.ts.snap +12 -194
  116. package/src/components/Amelipro/AmeliproAccordionResult/AmeliproAccordionResultTemplate/__tests__/__snapshots__/AmeliproAccordionResultTemplate.spec.ts.snap +1 -18
  117. package/src/components/Amelipro/AmeliproAccordionResult/__tests__/__snapshots__/AmeliproAccordionResult.spec.ts.snap +1 -18
  118. package/src/components/Amelipro/AmeliproAccordionResultList/__tests__/__snapshots__/AmeliproAccordionResultList.spec.ts.snap +12 -194
  119. package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.stories.ts +9 -9
  120. package/src/components/Amelipro/AmeliproAutoCompleteField/AmeliproAutoCompleteField.vue +5 -4
  121. package/src/components/Amelipro/AmeliproAutoCompleteField/__tests__/AmeliproAutoCompleteField.spec.ts +6 -6
  122. package/src/components/Amelipro/AmeliproAutoCompleteField/__tests__/__snapshots__/AmeliproAutoCompleteField.spec.ts.snap +2 -0
  123. package/src/components/Amelipro/AmeliproBadge/__tests__/AmeliproBadge.spec.ts +135 -9
  124. package/src/components/Amelipro/AmeliproBadge/__tests__/__snapshots__/AmeliproBadge.spec.ts.snap +20 -5
  125. package/src/components/Amelipro/AmeliproBreadcrumb/__tests__/AmeliproBreadcrumb.spec.ts +195 -28
  126. package/src/components/Amelipro/AmeliproBreadcrumb/__tests__/__snapshots__/AmeliproBreadcrumb.spec.ts.snap +193 -124
  127. package/src/components/Amelipro/AmeliproCaptcha/AmeliproCaptcha.vue +1 -1
  128. package/src/components/Amelipro/AmeliproCaptcha/__tests__/AmeliproCaptcha.spec.ts +364 -12
  129. package/src/components/Amelipro/AmeliproCaptcha/__tests__/__snapshots__/AmeliproCaptcha.spec.ts.snap +30 -390
  130. package/src/components/Amelipro/AmeliproCarousel/__tests__/__snapshots__/AmeliproCarousel.spec.ts.snap +4 -36
  131. package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.stories.ts +10 -10
  132. package/src/components/Amelipro/AmeliproCheckbox/AmeliproCheckbox.vue +7 -7
  133. package/src/components/Amelipro/AmeliproCheckbox/__tests__/AmeliproCheckbox.spec.ts +5 -5
  134. package/src/components/Amelipro/AmeliproCheckbox/__tests__/__snapshots__/AmeliproCheckbox.spec.ts.snap +1 -1
  135. package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.stories.ts +7 -6
  136. package/src/components/Amelipro/AmeliproCheckboxGroup/AmeliproCheckboxGroup.vue +6 -6
  137. package/src/components/Amelipro/AmeliproCheckboxGroup/__tests__/AmeliproCheckboxGroup.spec.ts +6 -6
  138. package/src/components/Amelipro/AmeliproCheckboxGroup/__tests__/__snapshots__/AmeliproCheckboxGroup.spec.ts.snap +2 -2
  139. package/src/components/Amelipro/AmeliproClickableTile/tests/__snapshots__/AmeliproClickableTile.spec.ts.snap +2 -43
  140. package/src/components/Amelipro/AmeliproContentLayout/__tests__/AmeliproContentLayout.spec.ts +80 -9
  141. package/src/components/Amelipro/AmeliproContentLayout/__tests__/__snapshots__/AmeliproContentLayout.spec.ts.snap +25 -4
  142. package/src/components/Amelipro/AmeliproCopyBtn/__tests__/__snapshots__/AmeliproCopyBtn.spec.ts.snap +1 -13
  143. package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.stories.ts +7 -6
  144. package/src/components/Amelipro/AmeliproCustomSelector/AmeliproCustomSelector.vue +5 -5
  145. package/src/components/Amelipro/AmeliproCustomSelector/__tests__/AmeliproCustomSelector.spec.ts +187 -39
  146. package/src/components/Amelipro/AmeliproCustomSelector/__tests__/__snapshots__/AmeliproCustomSelector.spec.ts.snap +147 -147
  147. package/src/components/Amelipro/AmeliproDentalChart/tests/__snapshots__/AmeliproDentalChart.spec.ts.snap +1 -1
  148. package/src/components/Amelipro/AmeliproDialog/__tests__/__snapshots__/AmeliproDialog.spec.ts.snap +0 -2
  149. package/src/components/Amelipro/AmeliproErrorTemplate/__tests__/AmeliproErrorTemplate.spec.ts +160 -20
  150. package/src/components/Amelipro/AmeliproErrorTemplate/__tests__/__snapshots__/AmeliproErrorTemplate.spec.ts.snap +34 -177
  151. package/src/components/Amelipro/AmeliproFilePreview/AmeliproFilePreview.vue +1 -0
  152. package/src/components/Amelipro/AmeliproFilePreview/__tests__/AmeliproFilePreview.spec.ts +248 -19
  153. package/src/components/Amelipro/AmeliproFilePreview/__tests__/__snapshots__/AmeliproFilePreview.spec.ts.snap +34 -203
  154. package/src/components/Amelipro/AmeliproFirstLogin/__tests__/__snapshots__/AmeliproFirstLogin.spec.ts.snap +6 -144
  155. package/src/components/Amelipro/AmeliproIcon/AmeliproIcon.vue +20 -2
  156. package/src/components/Amelipro/AmeliproIcon/__tests__/__snapshots__/AmeliproIcon.spec.ts.snap +1 -25
  157. package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.stories.ts +5 -5
  158. package/src/components/Amelipro/AmeliproIllustratedRadioGroup/AmeliproIllustratedRadioGroup.vue +6 -6
  159. package/src/components/Amelipro/AmeliproIllustratedRadioGroup/__tests__/AmeliproIllustratedRadioGroup.spec.ts +22 -22
  160. package/src/components/Amelipro/AmeliproIllustratedRadioGroup/__tests__/__snapshots__/AmeliproIllustratedRadioGroup.spec.ts.snap +2 -2
  161. package/src/components/Amelipro/AmeliproMultipleFoldingCard/__tests__/AmeliproMultipleFoldingCard.spec.ts +304 -0
  162. package/src/components/Amelipro/AmeliproMultipleFoldingCard/__tests__/__snapshots__/AmeliproMultipleFoldingCard.spec.ts.snap +373 -0
  163. package/src/components/Amelipro/AmeliproPatientLogged/AmeliproPatientLogged.stories.ts +2 -0
  164. package/src/components/Amelipro/AmeliproPatientLogged/AmeliproPatientLogged.vue +28 -2
  165. package/src/components/Amelipro/AmeliproPatientLogged/__tests__/__snapshots__/AmeliproPatientLogged.spec.ts.snap +9 -173
  166. package/src/components/Amelipro/AmeliproPatientLogin/AmeliproPatientLoginForm/AmeliproPatientLoginForm.vue +1 -1
  167. package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/AmeliproPostalAddressCityRow.vue +162 -72
  168. package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/__tests__/AmeliproPostalAddressCityRow.spec.ts +2 -2
  169. package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressCityRow/__tests__/__snapshots__/AmeliproPostalAddressCityRow.spec.ts.snap +6 -39
  170. package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.stories.ts +3 -3
  171. package/src/components/Amelipro/AmeliproPostalAddressField/AmeliproPostalAddressField.vue +8 -8
  172. package/src/components/Amelipro/AmeliproPostalAddressField/{tests → __tests__}/AmeliproPostalAddressField.spec.ts +2 -2
  173. package/src/components/Amelipro/AmeliproPostalAddressField/{tests → __tests__}/__snapshots__/AmeliproPostalAddressField.spec.ts.snap +11 -52
  174. package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.stories.ts +7 -7
  175. package/src/components/Amelipro/AmeliproRadioGroup/AmeliproRadioGroup.vue +8 -8
  176. package/src/components/Amelipro/AmeliproRadioGroup/__tests__/AmeliproRadioGroup.spec.ts +6 -6
  177. package/src/components/Amelipro/AmeliproRadioGroup/__tests__/__snapshots__/AmeliproRadioGroup.spec.ts.snap +2 -2
  178. package/src/components/Amelipro/AmeliproResultList/__tests__/__snapshots__/AmeliproResultList.spec.ts.snap +2 -14
  179. package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.stories.ts +7 -7
  180. package/src/components/Amelipro/AmeliproSelect/AmeliproSelect.vue +4 -4
  181. package/src/components/Amelipro/AmeliproSelect/__tests__/AmeliproSelect.spec.ts +12 -12
  182. package/src/components/Amelipro/AmeliproStepper/AmeliproStepper.vue +2 -2
  183. package/src/components/Amelipro/AmeliproStepper/__tests__/__snapshots__/AmeliproStepper.spec.ts.snap +2 -2
  184. package/src/components/Amelipro/AmeliproTable/AmeliproTable.vue +2 -2
  185. package/src/components/Amelipro/AmeliproTable/__tests__/AmeliproTable.spec.ts +463 -68
  186. package/src/components/Amelipro/AmeliproTable/__tests__/__snapshots__/AmeliproTable.spec.ts.snap +176 -511
  187. package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.stories.ts +6 -6
  188. package/src/components/Amelipro/AmeliproTextArea/AmeliproTextArea.vue +4 -4
  189. package/src/components/Amelipro/AmeliproTextArea/__tests__/AmeliproTextArea.spec.ts +3 -3
  190. package/src/components/Amelipro/AmeliproTextArea/__tests__/__snapshots__/AmeliproTextArea.spec.ts.snap +1 -2
  191. package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.stories.ts +10 -10
  192. package/src/components/Amelipro/AmeliproTextField/AmeliproTextField.vue +4 -4
  193. package/src/components/Amelipro/AmeliproTextField/__tests__/AmeliproTextField.spec.ts +5 -5
  194. package/src/components/Amelipro/AmeliproTextField/tests/__snapshots__/AmeliproTextField.spec.ts.snap +162 -0
  195. package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.stories.ts +44 -0
  196. package/src/components/Amelipro/AmeliproTileBtn/AmeliproTileBtn.vue +79 -1
  197. package/src/components/Amelipro/AmeliproTooltips/__tests__/__snapshots__/AmeliproTooltips.spec.ts.snap +0 -2
  198. package/src/components/Amelipro/AmeliproUpload/AmeliproUpload.stories.ts +2 -2
  199. package/src/components/Amelipro/AmeliproUpload/AmeliproUpload.vue +21 -7
  200. package/src/components/Amelipro/AmeliproUpload/__tests__/AmeliproUpload.spec.ts +252 -44
  201. package/src/components/Amelipro/AmeliproUpload/__tests__/__snapshots__/AmeliproUpload.spec.ts.snap +166 -0
  202. package/src/components/Amelipro/ServiceMenu/ServiceBtn/__tests__/ServiceBtn.spec.ts +137 -0
  203. package/src/components/Amelipro/ServiceMenu/ServiceBtn/__tests__/__snapshots__/ServiceBtn.spec.ts.snap +56 -0
  204. package/src/components/Amelipro/ServiceMenu/ServiceList/__tests__/ServiceList.spec.ts +116 -0
  205. package/src/components/Amelipro/ServiceMenu/ServiceList/__tests__/__snapshots__/ServiceList.spec.ts.snap +58 -0
  206. package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/__tests__/ServiceMenuContent.spec.ts +118 -0
  207. package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/__tests__/__snapshots__/ServiceMenuContent.spec.ts.snap +151 -0
  208. package/src/components/Amelipro/ServiceMenu/__tests__/ServiceMenu.spec.ts +259 -0
  209. package/src/components/Amelipro/ServiceMenu/__tests__/__snapshots__/ServiceMenu.spec.ts.snap +102 -0
  210. package/src/components/Amelipro/StructureMenu/StructureBtn/__tests__/StructureBtn.spec.ts +90 -0
  211. package/src/components/Amelipro/StructureMenu/StructureBtn/__tests__/__snapshots__/StructureBtn.spec.ts.snap +63 -0
  212. package/src/components/Amelipro/StructureMenu/StructureItem/__tests__/StructureItem.spec.ts +133 -0
  213. package/src/components/Amelipro/StructureMenu/StructureItem/__tests__/__snapshots__/StructureItem.spec.ts.snap +143 -0
  214. package/src/components/Amelipro/StructureMenu/StructureList/__tests__/StructureList.spec.ts +190 -0
  215. package/src/components/Amelipro/StructureMenu/StructureList/__tests__/__snapshots__/StructureList.spec.ts.snap +109 -0
  216. package/src/components/Amelipro/StructureMenu/StructureTabs/__tests__/StructureTabs.spec.ts +159 -0
  217. package/src/components/Amelipro/StructureMenu/StructureTabs/__tests__/__snapshots__/StructureTabs.spec.ts.snap +103 -0
  218. package/src/components/Amelipro/StructureMenu/__tests__/StructureMenu.spec.ts +165 -0
  219. package/src/components/Amelipro/StructureMenu/__tests__/__snapshots__/StructureMenu.spec.ts.snap +39 -0
  220. package/src/components/Amelipro/UserInformationSummary/__tests__/UserInformationSummary.spec.ts +140 -0
  221. package/src/components/Amelipro/UserInformationSummary/{tests → __tests__}/__snapshots__/UserInformationSummary.spec.ts.snap +17 -24
  222. package/src/components/Amelipro/UserMenu/UserMenu.stories.ts +3 -3
  223. package/src/components/Amelipro/UserMenu/UserMenu.vue +2 -2
  224. package/src/components/Amelipro/UserMenu/UserMenuDetails/__tests__/UserMenuDetails.spec.ts +150 -0
  225. package/src/components/Amelipro/UserMenu/UserMenuDetails/__tests__/__snapshots__/UserMenuDetails.spec.ts.snap +117 -0
  226. package/src/components/Amelipro/UserMenu/__tests__/UserMenu.spec.ts +141 -0
  227. package/src/components/Amelipro/UserMenu/__tests__/__snapshots__/UserMenu.spec.ts.snap +103 -0
  228. package/src/components/Captcha/Captcha.vue +9 -24
  229. package/src/components/Captcha/CaptchaHelpdesk.vue +42 -0
  230. package/src/components/Captcha/tests/__snapshots__/Captcha.spec.ts.snap +256 -268
  231. package/src/components/CopyBtn/tests/__snapshots__/CopyBtn.spec.ts.snap +0 -1
  232. package/src/components/Customs/Selects/SelectBtnField/Accessibilite.stories.ts +4 -0
  233. package/src/components/Customs/Selects/SelectBtnField/SelectBtnField.stories.ts +154 -82
  234. package/src/components/Customs/Selects/SelectBtnField/SelectBtnField.vue +229 -125
  235. package/src/components/Customs/Selects/SelectBtnField/tests/SelectBtnField.spec.ts +12 -12
  236. package/src/components/Customs/Selects/SelectBtnField/tests/__snapshots__/SelectBtnField.spec.ts.snap +344 -826
  237. package/src/components/Customs/Selects/SySelect/SySelect.vue +215 -169
  238. package/src/components/Customs/Selects/SySelect/composables/tests/useSySelectKeyboard.spec.ts +4 -2
  239. package/src/components/Customs/Selects/SySelect/composables/useSySelectKeyboard.ts +7 -9
  240. package/src/components/Customs/SyForm/SyForm.mdx +47 -7
  241. package/src/components/Customs/SyForm/SyForm.stories.ts +38 -34
  242. package/src/components/Customs/SyForm/SyForm.vue +27 -6
  243. package/src/components/Customs/SyRadioGroup/Accessibilite.mdx +263 -0
  244. package/src/components/Customs/SyRadioGroup/SyRadioGroup.mdx +37 -0
  245. package/src/components/Customs/SyRadioGroup/SyRadioGroup.stories.ts +665 -0
  246. package/src/components/Customs/SyRadioGroup/SyRadioGroup.vue +324 -0
  247. package/src/components/Customs/SyRadioGroup/locales.ts +3 -0
  248. package/src/components/Customs/SyRadioGroup/tests/SyRadioGroup.spec.ts +135 -0
  249. package/src/components/Customs/SyTabs/SyTabs.vue +1 -1
  250. package/src/components/Customs/SyTextField/SyTextField.vue +225 -194
  251. package/src/components/Customs/SyTextField/tests/SyTextField.spec.ts +32 -2
  252. package/src/components/DataList/DataList.mdx +3 -1
  253. package/src/components/DataList/DataList.stories.ts +67 -17
  254. package/src/components/DataList/DataList.vue +13 -1
  255. package/src/components/DataListGroup/DataListGroup.stories.ts +42 -12
  256. package/src/components/DataListGroup/DataListGroup.vue +14 -1
  257. package/src/components/DataListItem/DataListItem.vue +10 -2
  258. package/src/components/DataListItem/tests/DataListItem.spec.ts +1 -1
  259. package/src/components/DatePicker/CalendarMode/DatePicker.vue +157 -178
  260. package/src/components/DatePicker/CalendarMode/tests/DatePicker.events.spec.ts +5 -0
  261. package/src/components/DatePicker/CalendarMode/tests/DatePicker.spec.ts +179 -179
  262. package/src/components/DatePicker/ComplexDatePicker/ComplexDatePicker.vue +261 -258
  263. package/src/components/DatePicker/ComplexDatePicker/tests/ComplexDatePicker.spec.ts +234 -827
  264. package/src/components/DatePicker/DateTextInput/DateTextInput.vue +46 -73
  265. package/src/components/DatePicker/DateTextInput/tests/DateTextInput.spec.ts +350 -0
  266. package/src/components/DatePicker/composables/index.ts +4 -0
  267. package/src/components/DatePicker/composables/tests/useCalendarKeyboardNavigation.spec.ts +270 -0
  268. package/src/components/DatePicker/composables/tests/useDatePickerViewMode.spec.ts +61 -3
  269. package/src/components/DatePicker/composables/tests/useDateRangeInput.spec.ts +198 -0
  270. package/src/components/DatePicker/composables/tests/useDisplayedDateString.spec.ts +36 -2
  271. package/src/components/DatePicker/composables/tests/useInputHandler.spec.ts +755 -0
  272. package/src/components/DatePicker/composables/tests/useKeyboardEvents.spec.ts +168 -0
  273. package/src/components/DatePicker/composables/tests/useMonthButtonCustomization.spec.ts +40 -34
  274. package/src/components/DatePicker/composables/useAsteriskDisplay.ts +1 -2
  275. package/src/components/DatePicker/composables/useCalendarKeyboardNavigation.ts +155 -0
  276. package/src/components/DatePicker/composables/useDatePickerState.ts +163 -0
  277. package/src/components/DatePicker/composables/useDateRangeInput.ts +4 -8
  278. package/src/components/DatePicker/composables/useDateTextField.ts +156 -0
  279. package/src/components/DatePicker/composables/useHolidayHighlighting.ts +64 -0
  280. package/src/components/DatePicker/composables/useInputHandler.ts +25 -19
  281. package/src/components/DatePicker/composables/useMonthButtonCustomization.ts +52 -26
  282. package/src/components/DatePicker/constants/messages.ts +0 -1
  283. package/src/components/DatePicker/docExamples/DatePickerBidirectionalValidation.vue +2 -2
  284. package/src/components/DatePicker/playground/ComplexDatePickerPlayground.vue +16 -8
  285. package/src/components/ErrorPage/ErrorPage.vue +1 -1
  286. package/src/components/ErrorPage/tests/ErrorPage.spec.ts +17 -0
  287. package/src/components/ExternalLinks/tests/__snapshots__/ExternalLinks.spec.ts.snap +0 -1
  288. package/src/components/LunarCalendar/LunarCalendar.mdx +33 -0
  289. package/src/components/LunarCalendar/LunarCalendar.stories.ts +232 -0
  290. package/src/components/LunarCalendar/LunarCalendar.vue +57 -0
  291. package/src/components/LunarCalendar/tests/LunarCalendar.spec.ts +79 -0
  292. package/src/components/LunarCalendar/useLunarCalendarRules.ts +96 -0
  293. package/src/components/LunarCalendar/useLunarCalendarValidation.ts +47 -0
  294. package/src/components/NotificationBar/NotificationBar.vue +2 -2
  295. package/src/components/PaginatedTable/PaginatedTable.stories.ts +15 -10
  296. package/src/components/PaginatedTable/PaginatedTable.vue +24 -35
  297. package/src/components/PhoneField/PhoneField.vue +102 -83
  298. package/src/components/SearchListField/tests/SearchListField.spec.ts +7 -53
  299. package/src/components/SyAlert/SyAlert.vue +5 -2
  300. package/src/components/TableToolbar/tests/__snapshots__/TableToolbar.spec.ts.snap +24 -72
  301. package/src/components/Tables/SyServerTable/SyServerTable.stories.ts +521 -23
  302. package/src/components/Tables/SyServerTable/SyServerTable.vue +19 -13
  303. package/src/components/Tables/SyTable/SyTable.stories.ts +391 -18
  304. package/src/components/Tables/SyTable/SyTable.vue +16 -11
  305. package/src/components/Tables/common/TableHeader.vue +16 -7
  306. package/src/components/Tables/common/filters/DateFilter.vue +1 -1
  307. package/src/components/Tables/common/locales.ts +1 -0
  308. package/src/components/Tables/common/tableFilterUtils.ts +3 -3
  309. package/src/components/Tables/common/types.ts +4 -2
  310. package/src/components/Tables/common/useTableCheckbox.ts +4 -3
  311. package/src/components/Tables/common/useTableFilter.ts +2 -2
  312. package/src/components/Tables/common/useTableItems.ts +4 -19
  313. package/src/components/index.ts +2 -0
  314. package/src/composables/validation/tests/useFormValidation.spec.ts +251 -0
  315. package/src/composables/validation/tests/useValidatable.spec.ts +90 -0
  316. package/src/stories/Accessibilite/Audit/Exemptions-derogations.mdx +241 -0
  317. package/src/stories/Accessibilite/KitDePreAudit/Introduction.mdx +17 -10
  318. package/src/stories/Accessibilite/KitDePreAudit/Outils/Introduction.mdx +16 -0
  319. package/src/stories/Accessibilite/KitDePreAudit/Preaudit.mdx +160 -106
  320. package/src/stories/Accessibilite/Vuetify/VuetifyItems.ts +2 -1
  321. package/src/stories/GuideDuDev/ClassesUtilitaires/FormattingUtilities.mdx +20 -0
  322. package/src/stories/GuideDuDev/ClassesUtilitaires/index.mdx +10 -0
  323. package/src/utils/formatNir/formatNir.ts +15 -0
  324. package/src/utils/index.ts +1 -0
  325. package/src/utils/insertAt.ts +11 -0
  326. package/src/utils/rules/isDateValid/IsDateValid.mdx +2 -2
  327. package/src/utils/rules/isDateValid/IsDateValid.stories.ts +6 -4
  328. package/src/utils/rules/isDateValid/index.ts +23 -8
  329. package/src/utils/rules/isDateValid/tests/isDateValid.spec.ts +9 -0
  330. package/src/utils/rules/isExactLength/IsExactLenght.mdx +1 -1
  331. package/src/utils/rules/isHolidayDay/IsHolidayDay.mdx +19 -7
  332. package/src/utils/rules/isHolidayDay/index.ts +6 -8
  333. package/src/utils/rules/isHolidayDay/tests/isHolidayDay.spec.ts +13 -1
  334. package/src/utils/rules/isNotAfterDate/IsNotAfterDate.mdx +2 -2
  335. package/src/utils/rules/isNotAfterDate/IsNotAfterDate.stories.ts +9 -2
  336. package/src/utils/rules/isNotAfterDate/index.ts +5 -12
  337. package/src/utils/rules/isNotAfterDate/tests/isNotAfterDate.spec.ts +20 -0
  338. package/src/utils/rules/isNotAfterToday/IsNotAfterToday.mdx +2 -2
  339. package/src/utils/rules/isNotAfterToday/IsNotAfterToday.stories.ts +8 -2
  340. package/src/utils/rules/isNotAfterToday/index.ts +6 -6
  341. package/src/utils/rules/isNotAfterToday/tests/isNotAfterToday.spec.ts +20 -0
  342. package/src/utils/rules/isNotBeforeDate/IsNotBeforeDate.mdx +2 -2
  343. package/src/utils/rules/isNotBeforeDate/index.ts +5 -12
  344. package/src/utils/rules/isNotBeforeDate/tests/IsNotBeforeDate.spec.ts +20 -0
  345. package/src/utils/rules/isNotBeforeToday/IsNotBeforeToday.mdx +2 -2
  346. package/src/utils/rules/isNotBeforeToday/IsNotBeforeToday.stories.ts +8 -2
  347. package/src/utils/rules/isNotBeforeToday/index.ts +6 -6
  348. package/src/utils/rules/isNotBeforeToday/tests/notBeforeToday.spec.ts +19 -0
  349. package/src/utils/rules/validateDateValue.ts +37 -0
  350. package/src/vuetifyConfig.ts +6 -2
  351. package/dist/components/Customs/Selects/SelectBtnField/config.d.ts +0 -11
  352. package/dist/components/DatePicker/tests/setup.d.ts +0 -75370
  353. package/dist/components/Tables/common/formatters.d.ts +0 -17
  354. package/dist/main-CbBVJ_le.js +0 -34377
  355. package/dist/stories/Accessibilite/Vuetify/VuetifyItems.d.ts +0 -70
  356. package/dist/stories/DesignTokens/StylesTypographiques.stories.new.d.ts +0 -8
  357. package/dist/stories/DesignTokens/TypographyDisplay.d.ts +0 -28
  358. package/dist/stories/DesignTokens/vue-shims.d.ts +0 -6
  359. package/src/components/Amelipro/AmeliproMultipleFoldingCard/tests/AmeliproMultipleFoldingCard.spec.ts +0 -40
  360. package/src/components/Amelipro/AmeliproMultipleFoldingCard/tests/__snapshots__/AmeliproMultipleFoldingCard.spec.ts.snap +0 -369
  361. package/src/components/Amelipro/ServiceMenu/ServiceBtn/tests/ServiceBtn.spec.ts +0 -21
  362. package/src/components/Amelipro/ServiceMenu/ServiceBtn/tests/__snapshots__/ServiceBtn.spec.ts.snap +0 -100
  363. package/src/components/Amelipro/ServiceMenu/ServiceList/tests/ServiceList.spec.ts +0 -25
  364. package/src/components/Amelipro/ServiceMenu/ServiceList/tests/__snapshots__/ServiceList.spec.ts.snap +0 -245
  365. package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/tests/ServiceMenuContent.spec.ts +0 -45
  366. package/src/components/Amelipro/ServiceMenu/ServiceMenuContent/tests/__snapshots__/ServiceMenuContent.spec.ts.snap +0 -787
  367. package/src/components/Amelipro/ServiceMenu/tests/ServiceMenu.spec.ts +0 -46
  368. package/src/components/Amelipro/ServiceMenu/tests/__snapshots__/ServiceMenu.spec.ts.snap +0 -111
  369. package/src/components/Amelipro/StructureMenu/StructureBtn/tests/StructureBtn.spec.ts +0 -17
  370. package/src/components/Amelipro/StructureMenu/StructureBtn/tests/__snapshots__/StructureBtn.spec.ts.snap +0 -34
  371. package/src/components/Amelipro/StructureMenu/StructureItem/tests/StructureItem.spec.ts +0 -21
  372. package/src/components/Amelipro/StructureMenu/StructureItem/tests/__snapshots__/StructureItem.spec.ts.snap +0 -106
  373. package/src/components/Amelipro/StructureMenu/StructureList/tests/StructureList.spec.ts +0 -33
  374. package/src/components/Amelipro/StructureMenu/StructureList/tests/__snapshots__/StructureList.spec.ts.snap +0 -353
  375. package/src/components/Amelipro/StructureMenu/StructureTabs/tests/StructureTabs.spec.ts +0 -60
  376. package/src/components/Amelipro/StructureMenu/StructureTabs/tests/__snapshots__/StructureTabs.spec.ts.snap +0 -824
  377. package/src/components/Amelipro/StructureMenu/tests/StructureMenu.spec.ts +0 -69
  378. package/src/components/Amelipro/StructureMenu/tests/__snapshots__/StructureMenu.spec.ts.snap +0 -1383
  379. package/src/components/Amelipro/UserInformationSummary/tests/UserInformationSummary.spec.ts +0 -24
  380. package/src/components/Amelipro/UserMenu/UserMenuDetails/tests/UserMenuDetails.spec.ts +0 -33
  381. package/src/components/Amelipro/UserMenu/UserMenuDetails/tests/__snapshots__/UserMenuDetails.spec.ts.snap +0 -3
  382. package/src/components/Amelipro/UserMenu/tests/UserMenu.spec.ts +0 -34
  383. package/src/components/Amelipro/UserMenu/tests/__snapshots__/UserMenu.spec.ts.snap +0 -101
  384. package/src/components/Customs/Selects/SelectBtnField/config.ts +0 -11
  385. package/src/components/DatePicker/ComplexDatePicker/tests/ComplexDatePicker.events.spec.ts +0 -151
  386. package/src/components/DatePicker/DateTextInput/DateTextInput.events.spec.ts +0 -148
  387. package/src/components/DatePicker/DateTextInput/DateTextInput.range.spec.ts +0 -361
  388. package/src/components/DatePicker/DateTextInput/DateTextInput.spec.ts +0 -709
  389. package/src/components/DatePicker/tests/DatePicker.validation.spec.ts +0 -4111
  390. package/src/components/DatePicker/tests/archiTest.md +0 -33
  391. package/src/components/DatePicker/tests/navigation.regression.spec.ts +0 -74
  392. package/src/components/DatePicker/tests/navigation.simple.spec.ts +0 -137
  393. package/src/components/DatePicker/tests/setup.ts +0 -243
  394. package/src/components/Tables/common/formatters.ts +0 -72
@@ -11,7 +11,7 @@
11
11
  mdiAlertCircle,
12
12
  mdiCalendar,
13
13
  } from '@mdi/js'
14
- import { computed, onMounted, ref, watch, nextTick, type ComponentPublicInstance } from 'vue'
14
+ import { computed, onMounted, ref, watch, nextTick, useAttrs, type ComponentPublicInstance } from 'vue'
15
15
  import type { IconType, VariantStyle, ColorType } from './types'
16
16
  import { useValidation, type ValidationRule } from '@/composables/validation/useValidation'
17
17
  import { useValidatable } from '@/composables/validation/useValidatable'
@@ -178,20 +178,37 @@
178
178
  'append-icon-click',
179
179
  ])
180
180
 
181
+ const lastEmittedModelValue = ref(props.modelValue)
182
+
181
183
  const model = computed({
182
184
  get() {
183
185
  return props.modelValue
184
186
  },
185
187
  set(value) {
186
188
  emit('update:modelValue', value)
189
+ lastEmittedModelValue.value = value
187
190
  },
188
191
  })
189
192
 
193
+ const attrs = useAttrs()
194
+
195
+ const forwardedAttrs = computed(() => {
196
+ const filteredAttrs = Object.fromEntries(
197
+ Object.entries(attrs).filter(([key]) => key !== 'display-asterisk'),
198
+ ) as Record<string, unknown>
199
+
200
+ if (!('validate-on' in filteredAttrs) && 'rules' in filteredAttrs && props.isValidateOnBlur) {
201
+ filteredAttrs['validate-on'] = 'blur lazy'
202
+ }
203
+
204
+ return filteredAttrs
205
+ })
206
+
190
207
  const isBlurred = ref(false)
191
208
 
192
209
  const showClear = computed(() => {
193
210
  if (!props.isClearable) return false
194
- if (props.readonly || props.disabled) return false
211
+ if (props.disabled) return false
195
212
  return model.value !== undefined && model.value !== null && String(model.value) !== '' && String(model.value) !== '__/__/____'
196
213
  })
197
214
 
@@ -268,7 +285,10 @@
268
285
  const checkErrorOnBlur = () => {
269
286
  isBlurred.value = true
270
287
  validateField(model.value ?? null)
271
- emit('update:modelValue', model.value)
288
+ if (model.value !== lastEmittedModelValue.value) {
289
+ emit('update:modelValue', model.value)
290
+ lastEmittedModelValue.value = model.value
291
+ }
272
292
  }
273
293
 
274
294
  watch(model, (newValue) => {
@@ -547,199 +567,204 @@
547
567
  </script>
548
568
 
549
569
  <template>
550
- <VTextField
551
- :id="props.id"
552
- ref="syTextFieldRef"
553
- v-model="model"
554
- :autocomplete="props.autocomplete"
555
- :active="props.isActive"
556
- :title="accessibleLabel"
557
- :aria-label="accessibleLabel"
558
- :aria-required="props.required ? 'true' : undefined"
559
- :base-color="props.baseColor"
560
- :bg-color="props.bgColor"
561
- :center-affix="props.centerAffix"
562
- :color="props.color"
563
- :counter-value="props.counterValue"
564
- :density="props.density"
565
- :direction="props.direction"
566
- :dirty="props.isDirty"
567
- :disabled="props.disabled"
568
- :error="hasError"
569
- :error-messages="errors"
570
- :flat="props.isFlat"
571
- :focused="props.isFocused"
572
- :hide-details="props.areDetailsHidden && !showHelpTextAsMessage"
573
- :hint="showHelpTextAsMessage ? props.helpText : props.hint"
574
- :label="labelWithAsterisk"
575
- :loading="props.loading"
576
- :max-errors="props.maxErrors"
577
- :max-width="props.maxWidth"
578
- :messages="hasError ? errors : (hasWarning ? warnings : (hasSuccess && props.showSuccessMessages ? successes : []))"
579
- :min-width="props.minWidth"
580
- :name="props.name"
581
- :persistent-clear="props.displayPersistentClear"
582
- :persistent-counter="props.displayPersistentCounter"
583
- :persistent-hint="props.displayPersistentHint || !!showHelpTextAsMessage"
584
- :persistent-placeholder="props.displayPersistentPlaceholder"
585
- :placeholder="props.placeholder"
586
- :prefix="props.prefix"
587
- :readonly="props.readonly"
588
- :reverse="props.isReversed"
589
- :role="props.role"
590
- :rounded="props.rounded"
591
- :single-line="props.isOnSingleLine"
592
- :suffix="props.suffix"
593
- :theme="props.theme"
594
- :tile="props.isTiled"
595
- :type="props.type"
596
- :variant="props.variantStyle"
597
- :width="props.width"
598
- v-bind="Object.fromEntries(Object.entries($attrs).filter(([key]) => key !== 'display-asterisk'))"
599
- :class="{
600
- 'error-field': hasError,
601
- 'warning-field': hasWarning,
602
- 'success-field': hasSuccess,
603
- 'basic-field': !hasError && !hasWarning && !hasSuccess
604
- }"
605
- @blur="checkErrorOnBlur"
606
- >
607
- <!-- Prepend -->
608
- <template
609
- v-if="props.prependIcon || props.prependTooltip"
610
- #prepend
611
- >
612
- <slot name="prepend">
613
- <template v-if="props.prependTooltip">
614
- <VTooltip
615
- :text="props.prependTooltip"
616
- :location="props.tooltipLocation"
617
- >
618
- <template #activator="{ props: tooltipProps }">
619
- <SyIcon
620
- v-bind="tooltipProps"
621
- :label="props.label ? `${props.label} - info` : 'Info'"
622
- :color="appendInnerIconColor"
623
- :icon="ICONS.info"
624
- role="button"
625
- :decorative="false"
626
- />
627
- </template>
628
- </VTooltip>
629
- </template>
630
- <SyIcon
631
- v-else-if="props.prependIcon && !props.noIcon"
632
- :label="disableClickButton ? undefined : (props.label ? `${props.label} - bouton ${props.prependIcon}` : `Bouton ${props.prependIcon}`)"
633
- :color="appendInnerIconColor"
634
- :icon="ICONS[props.prependIcon]"
635
- :role="disableClickButton ? 'presentation' : 'button'"
636
- :class="disableClickButton ? 'cursor-default' : 'cursor-pointer'"
637
- :decorative="disableClickButton"
638
- :tabindex="disableClickButton ? undefined : '0'"
639
- @click="handlePrependIconClick"
640
- @keydown.enter.prevent="handlePrependIconClick"
641
- @keydown.space.prevent="handlePrependIconClick"
642
- />
643
- </slot>
644
- </template>
645
-
646
- <!-- Append -->
647
- <template
648
- v-if="props.appendIcon || props.appendTooltip"
649
- #append
570
+ <div class="sy-textfield-container">
571
+ <VTextField
572
+ :id="props.id"
573
+ ref="syTextFieldRef"
574
+ v-model="model"
575
+ :autocomplete="props.autocomplete"
576
+ :active="props.isActive"
577
+ :title="accessibleLabel"
578
+ :aria-label="accessibleLabel"
579
+ :aria-required="props.required ? 'true' : undefined"
580
+ :base-color="props.baseColor"
581
+ :bg-color="props.bgColor"
582
+ :center-affix="props.centerAffix"
583
+ :color="props.color"
584
+ :counter-value="props.counterValue"
585
+ :density="props.density"
586
+ :direction="props.direction"
587
+ :dirty="props.isDirty"
588
+ :disabled="props.disabled"
589
+ :error="hasError"
590
+ :error-messages="errors"
591
+ :flat="props.isFlat"
592
+ :focused="props.isFocused"
593
+ :hide-details="props.areDetailsHidden && !showHelpTextAsMessage"
594
+ :hint="showHelpTextAsMessage ? props.helpText : props.hint"
595
+ :label="labelWithAsterisk"
596
+ :loading="props.loading"
597
+ :max-errors="props.maxErrors"
598
+ :max-width="props.maxWidth"
599
+ :messages="hasError ? errors : (hasWarning ? warnings : (hasSuccess && props.showSuccessMessages ? successes : []))"
600
+ :min-width="props.minWidth"
601
+ :name="props.name"
602
+ :persistent-clear="props.displayPersistentClear"
603
+ :persistent-counter="props.displayPersistentCounter"
604
+ :persistent-hint="props.displayPersistentHint || !!showHelpTextAsMessage"
605
+ :persistent-placeholder="props.displayPersistentPlaceholder"
606
+ :placeholder="props.placeholder"
607
+ :prefix="props.prefix"
608
+ :readonly="props.readonly"
609
+ :reverse="props.isReversed"
610
+ :role="props.role"
611
+ :rounded="props.rounded"
612
+ :single-line="props.isOnSingleLine"
613
+ :suffix="props.suffix"
614
+ :theme="props.theme"
615
+ :tile="props.isTiled"
616
+ :type="props.type"
617
+ :variant="props.variantStyle"
618
+ :width="props.width"
619
+ v-bind="forwardedAttrs"
620
+ :class="{
621
+ 'error-field': hasError,
622
+ 'warning-field': hasWarning,
623
+ 'success-field': hasSuccess,
624
+ 'basic-field': !hasError && !hasWarning && !hasSuccess
625
+ }"
626
+ @blur="checkErrorOnBlur"
650
627
  >
651
- <slot name="append">
652
- <template v-if="props.appendTooltip">
653
- <VTooltip
654
- :text="props.appendTooltip"
655
- :location="props.tooltipLocation"
656
- >
657
- <template #activator="{ props: tooltipProps }">
658
- <SyIcon
659
- v-bind="tooltipProps"
660
- :label="props.label ? `${props.label} - info` : 'Info'"
661
- :color="appendInnerIconColor"
662
- :icon="ICONS.info"
663
- role="button"
664
- :decorative="false"
665
- />
666
- </template>
667
- </VTooltip>
668
- </template>
669
- <SyIcon
670
- v-else-if="props.appendIcon && !props.noIcon"
671
- :label="disableClickButton ? undefined : (props.label ? `${props.label} - bouton ${props.appendIcon}` : `Bouton ${props.appendIcon}`)"
672
- :color="appendInnerIconColor"
673
- :icon="ICONS[props.appendIcon]"
674
- :role="disableClickButton ? 'presentation' : 'button'"
675
- :class="disableClickButton ? 'cursor-default' : 'cursor-pointer'"
676
- :decorative="disableClickButton"
677
- :tabindex="disableClickButton ? undefined : '0'"
678
- @click="handleAppendIconClick"
679
- @keydown.enter.prevent="handleAppendIconClick"
680
- @keydown.space.prevent="handleAppendIconClick"
681
- />
682
- </slot>
683
- </template>
684
-
685
- <!-- Prepend inner -->
686
- <template #prepend-inner>
687
- <slot name="prepend-inner">
688
- <SyIcon
689
- v-if="props.prependInnerIcon && !props.noIcon"
690
- :icon="ICONS[props.prependInnerIcon]"
691
- role="presentation"
692
- :decorative="true"
693
- />
694
- <VDivider
695
- v-if="props.showDivider"
696
- class="mt-4 pa-1"
697
- v-bind="dividerProps"
698
- vertical
699
- />
700
- </slot>
701
- </template>
702
-
703
- <!-- Append inner -->
704
- <template #append-inner>
705
- <slot name="append-inner">
706
- <!-- Keyboard-focusable clear button -->
707
- <VBtn
708
- v-if="showClear"
709
- class="v-btn v-btn--density-compact mr-1"
710
- :aria-label="props.label ? `Vider ${props.label}` : 'Vider'"
711
- :title="props.label ? `Vider ${props.label}` : 'Vider'"
712
- :icon="mdiClose"
713
- variant="text"
714
- @click="clearField"
715
- />
716
- <SyIcon
717
- v-if="validationIcon && !props.appendInnerIcon"
718
- :icon="validationIcon"
719
- role="presentation"
720
- :decorative="true"
721
- />
722
- <SyIcon
723
- v-if="props.appendInnerIcon && !props.noIcon"
724
- :color="appendInnerIconColor"
725
- role="presentation"
726
- :icon="ICONS[props.appendInnerIcon]"
727
- :decorative="true"
728
- />
729
- </slot>
730
- </template>
731
-
732
- <template #details>
733
- <slot name="details" />
734
- <div
735
- v-if="showHelpTextBelow"
736
- class="help-text-below px-4 mt-1"
737
- :class="{ 'text-disabled': props.disabled }"
628
+ <!-- Prepend -->
629
+ <template
630
+ v-if="props.prependIcon || props.prependTooltip"
631
+ #prepend
632
+ >
633
+ <slot name="prepend">
634
+ <template v-if="props.prependTooltip">
635
+ <VTooltip
636
+ :text="props.prependTooltip"
637
+ :location="props.tooltipLocation"
638
+ >
639
+ <template #activator="{ props: tooltipProps }">
640
+ <SyIcon
641
+ v-bind="tooltipProps"
642
+ :label="props.label ? `${props.label} - info` : 'Info'"
643
+ :color="appendInnerIconColor"
644
+ :icon="ICONS.info"
645
+ role="button"
646
+ :decorative="false"
647
+ />
648
+ </template>
649
+ </VTooltip>
650
+ </template>
651
+ <SyIcon
652
+ v-else-if="props.prependIcon && !props.noIcon"
653
+ :label="disableClickButton ? undefined : (props.label ? `${props.label} - bouton ${props.prependIcon}` : `Bouton ${props.prependIcon}`)"
654
+ :color="appendInnerIconColor"
655
+ :icon="ICONS[props.prependIcon]"
656
+ :role="disableClickButton ? 'presentation' : 'button'"
657
+ :class="disableClickButton ? 'cursor-default' : 'cursor-pointer'"
658
+ :decorative="disableClickButton"
659
+ :tabindex="disableClickButton ? undefined : '0'"
660
+ @click="handlePrependIconClick"
661
+ @keydown.enter.prevent="handlePrependIconClick"
662
+ @keydown.space.prevent="handlePrependIconClick"
663
+ />
664
+ </slot>
665
+ </template>
666
+
667
+ <!-- Append -->
668
+ <template
669
+ v-if="props.appendIcon || props.appendTooltip"
670
+ #append
738
671
  >
739
- {{ props.helpText }}
740
- </div>
741
- </template>
742
- </VTextField>
672
+ <slot name="append">
673
+ <template v-if="props.appendTooltip">
674
+ <VTooltip
675
+ :text="props.appendTooltip"
676
+ :location="props.tooltipLocation"
677
+ >
678
+ <template #activator="{ props: tooltipProps }">
679
+ <SyIcon
680
+ v-bind="tooltipProps"
681
+ :label="props.label ? `${props.label} - info` : 'Info'"
682
+ :color="appendInnerIconColor"
683
+ :icon="ICONS.info"
684
+ role="button"
685
+ :decorative="false"
686
+ />
687
+ </template>
688
+ </VTooltip>
689
+ </template>
690
+ <SyIcon
691
+ v-else-if="props.appendIcon && !props.noIcon"
692
+ :label="disableClickButton ? undefined : (props.label ? `${props.label} - bouton ${props.appendIcon}` : `Bouton ${props.appendIcon}`)"
693
+ :color="appendInnerIconColor"
694
+ :icon="ICONS[props.appendIcon]"
695
+ :role="disableClickButton ? 'presentation' : 'button'"
696
+ :class="disableClickButton ? 'cursor-default' : 'cursor-pointer'"
697
+ :decorative="disableClickButton"
698
+ :tabindex="disableClickButton ? undefined : '0'"
699
+ @click="handleAppendIconClick"
700
+ @keydown.enter.prevent="handleAppendIconClick"
701
+ @keydown.space.prevent="handleAppendIconClick"
702
+ />
703
+ </slot>
704
+ </template>
705
+
706
+ <!-- Prepend inner -->
707
+ <template #prepend-inner>
708
+ <slot name="prepend-inner">
709
+ <SyIcon
710
+ v-if="props.prependInnerIcon && !props.noIcon"
711
+ :icon="ICONS[props.prependInnerIcon]"
712
+ role="presentation"
713
+ :decorative="true"
714
+ />
715
+ <VDivider
716
+ v-if="props.showDivider"
717
+ class="mt-4 pa-1"
718
+ v-bind="dividerProps"
719
+ vertical
720
+ />
721
+ </slot>
722
+ </template>
723
+
724
+ <!-- Append inner -->
725
+ <template #append-inner>
726
+ <slot name="append-inner">
727
+ <!-- Keyboard-focusable clear button -->
728
+ <VBtn
729
+ v-if="showClear"
730
+ class="v-btn v-btn--density-compact mr-1"
731
+ :aria-label="props.label ? `Vider ${props.label}` : 'Vider'"
732
+ :title="props.label ? `Vider ${props.label}` : 'Vider'"
733
+ :icon="mdiClose"
734
+ variant="text"
735
+ @click.stop="clearField"
736
+ @keydown.enter.stop
737
+ @keydown.space.stop
738
+ />
739
+ <SyIcon
740
+ v-if="validationIcon && !props.appendInnerIcon"
741
+ :icon="validationIcon"
742
+ role="presentation"
743
+ :decorative="true"
744
+ />
745
+ <SyIcon
746
+ v-if="props.appendInnerIcon && !props.noIcon"
747
+ :color="appendInnerIconColor"
748
+ role="presentation"
749
+ :icon="ICONS[props.appendInnerIcon]"
750
+ :decorative="true"
751
+ />
752
+ </slot>
753
+ </template>
754
+
755
+ <template #details>
756
+ <slot name="details" />
757
+ </template>
758
+ </VTextField>
759
+
760
+ <div
761
+ v-if="showHelpTextBelow"
762
+ class="help-text-below px-4 mt-1"
763
+ :class="{ 'text-disabled': props.disabled }"
764
+ >
765
+ {{ props.helpText }}
766
+ </div>
767
+ </div>
743
768
  </template>
744
769
 
745
770
  <style lang="scss" scoped>
@@ -751,6 +776,12 @@
751
776
  // opacity: 0;
752
777
  // }
753
778
 
779
+ .sy-textfield-container {
780
+ display: flex;
781
+ flex-direction: column;
782
+ width: 100%;
783
+ }
784
+
754
785
  .warning-field {
755
786
  :deep(.v-input__details > .v-icon),
756
787
  :deep(.v-input__prepend > .v-icon),
@@ -1,11 +1,11 @@
1
- import { describe, it, expect, beforeEach } from 'vitest'
1
+ import { describe, it, expect, beforeEach, vi } from 'vitest'
2
2
  import { mount } from '@vue/test-utils'
3
3
  import { VIcon } from 'vuetify/components'
4
4
 
5
5
  import SyTextField from '../SyTextField.vue'
6
6
  import type { IconType } from '../types'
7
7
 
8
- describe('SyTextField.vue', () => {
8
+ describe('SyTextField', () => {
9
9
  let wrapper: ReturnType<typeof mount<typeof SyTextField>>
10
10
 
11
11
  beforeEach(() => {
@@ -118,6 +118,36 @@ describe('SyTextField.vue', () => {
118
118
  expect(wrapper.emitted('append-icon-click')).toBeTruthy()
119
119
  })
120
120
 
121
+ it('does not propagate click from clear button to parent container', async () => {
122
+ const onClickParent = vi.fn()
123
+
124
+ const wrapper = mount({
125
+ components: { SyTextField },
126
+ template: `
127
+ <div data-testid="parent" @click="onClickParent">
128
+ <SyTextField
129
+ is-clearable
130
+ label="Test Field"
131
+ model-value="foo"
132
+ />
133
+ </div>
134
+ `,
135
+ setup() {
136
+ return { onClickParent }
137
+ },
138
+ })
139
+
140
+ await wrapper.vm.$nextTick()
141
+
142
+ const clearButton = wrapper.find('button[aria-label="Vider Test Field"]')
143
+ expect(clearButton.exists()).toBe(true)
144
+
145
+ await clearButton.trigger('click')
146
+ await wrapper.vm.$nextTick()
147
+
148
+ expect(onClickParent).not.toHaveBeenCalled()
149
+ })
150
+
121
151
  it('shows validation error message', async () => {
122
152
  const wrapper = mount(SyTextField, {
123
153
  props: {
@@ -1,4 +1,4 @@
1
- import { Controls, Canvas, Meta, Source } from '@storybook/blocks';
1
+ import { Controls, Canvas, Meta, Source, Story } from '@storybook/blocks';
2
2
  import * as DataList from './DataList.stories';
3
3
 
4
4
  <Meta of={DataList} />
@@ -8,6 +8,8 @@ import * as DataList from './DataList.stories';
8
8
  <p>L’élément `DataList` est utilisé pour afficher une liste d’informations.</p>
9
9
  </div>
10
10
 
11
+ <Story of={DataList.InfoIntro}/>
12
+
11
13
  <Canvas of={DataList.Default} />
12
14
 
13
15
  # API