@spw-ds/spw-stencil-library 1.3.0 → 1.3.2

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 (782) hide show
  1. package/dist/cjs/loader.cjs.js +1 -1
  2. package/dist/cjs/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.cjs.js.map +1 -1
  3. package/dist/cjs/spw-accordion_4.cjs.entry.js +28 -5
  4. package/dist/cjs/spw-accordion_4.cjs.entry.js.map +1 -1
  5. package/dist/cjs/spw-breadcrumb-item.cjs.entry.js +5 -2
  6. package/dist/cjs/spw-breadcrumb-item.cjs.entry.js.map +1 -1
  7. package/dist/cjs/spw-breadcrumb-item.entry.cjs.js.map +1 -1
  8. package/dist/cjs/spw-breadcrumb.cjs.entry.js +2 -2
  9. package/dist/cjs/spw-breadcrumb.cjs.entry.js.map +1 -1
  10. package/dist/cjs/spw-breadcrumb.entry.cjs.js.map +1 -1
  11. package/dist/cjs/spw-button_2.cjs.entry.js +2 -2
  12. package/dist/cjs/spw-card-content.cjs.entry.js +1 -1
  13. package/dist/cjs/spw-card-excerpt.cjs.entry.js +1 -1
  14. package/dist/cjs/spw-card-image.cjs.entry.js +1 -1
  15. package/dist/cjs/spw-card-subtag-item.cjs.entry.js +1 -1
  16. package/dist/cjs/spw-card-subtags.cjs.entry.js +1 -1
  17. package/dist/cjs/spw-card-title.cjs.entry.js +1 -1
  18. package/dist/cjs/spw-card.cjs.entry.js +1 -1
  19. package/dist/cjs/spw-checkbox.cjs.entry.js +1 -1
  20. package/dist/cjs/spw-custom-select.cjs.entry.js +3 -3
  21. package/dist/cjs/spw-date-picker.cjs.entry.js +5 -3
  22. package/dist/cjs/spw-date-picker.cjs.entry.js.map +1 -1
  23. package/dist/cjs/spw-date-picker.entry.cjs.js.map +1 -1
  24. package/dist/cjs/spw-dropdown-container.cjs.entry.js +1 -1
  25. package/dist/cjs/spw-dropdown-item.cjs.entry.js +1 -1
  26. package/dist/cjs/spw-dropdown.cjs.entry.js +1 -1
  27. package/dist/cjs/spw-field-label_6.cjs.entry.js +6 -6
  28. package/dist/cjs/spw-field-message.cjs.entry.js +1 -1
  29. package/dist/cjs/spw-file-upload.cjs.entry.js +2 -2
  30. package/dist/cjs/spw-footer-bottom.cjs.entry.js +1 -1
  31. package/dist/cjs/spw-footer-content-col.cjs.entry.js +1 -1
  32. package/dist/cjs/spw-footer-content.cjs.entry.js +1 -1
  33. package/dist/cjs/spw-footer-link.cjs.entry.js +1 -1
  34. package/dist/cjs/spw-footer.cjs.entry.js +1 -1
  35. package/dist/cjs/spw-grid-item.cjs.entry.js +2 -2
  36. package/dist/cjs/spw-grid.cjs.entry.js +2 -2
  37. package/dist/cjs/spw-header-lang-item.cjs.entry.js +1 -1
  38. package/dist/cjs/spw-header-lang.cjs.entry.js +1 -1
  39. package/dist/cjs/spw-header-navigation-dropdown.cjs.entry.js +1 -1
  40. package/dist/cjs/spw-header-navigation-item.cjs.entry.js +1 -1
  41. package/dist/cjs/spw-header-navigation.cjs.entry.js +1 -1
  42. package/dist/cjs/spw-header-persona-item.cjs.entry.js +1 -1
  43. package/dist/cjs/spw-header-persona.cjs.entry.js +1 -1
  44. package/dist/cjs/spw-header.cjs.entry.js +1 -1
  45. package/dist/cjs/spw-hero.cjs.entry.js +10 -3
  46. package/dist/cjs/spw-hero.cjs.entry.js.map +1 -1
  47. package/dist/cjs/spw-hero.entry.cjs.js.map +1 -1
  48. package/dist/cjs/spw-illustration.cjs.entry.js +488 -1
  49. package/dist/cjs/spw-illustration.cjs.entry.js.map +1 -1
  50. package/dist/cjs/spw-illustration.entry.cjs.js.map +1 -1
  51. package/dist/cjs/spw-iodda.cjs.entry.js +1 -1
  52. package/dist/cjs/spw-list-description.cjs.entry.js +1 -1
  53. package/dist/cjs/spw-list-item.cjs.entry.js +1 -1
  54. package/dist/cjs/spw-list-title.cjs.entry.js +1 -1
  55. package/dist/cjs/spw-list.cjs.entry.js +1 -1
  56. package/dist/cjs/spw-modal.cjs.entry.js +1 -1
  57. package/dist/cjs/spw-mosaic-item.cjs.entry.js +1 -1
  58. package/dist/cjs/spw-mosaic.cjs.entry.js +1 -1
  59. package/dist/cjs/spw-pagination.cjs.entry.js +10 -10
  60. package/dist/cjs/spw-pagination.cjs.entry.js.map +1 -1
  61. package/dist/cjs/spw-pagination.entry.cjs.js.map +1 -1
  62. package/dist/cjs/spw-radio.cjs.entry.js +1 -1
  63. package/dist/cjs/spw-search-field.cjs.entry.js +2 -2
  64. package/dist/cjs/spw-sidebar-navigation-dropdown.cjs.entry.js +1 -1
  65. package/dist/cjs/spw-sidebar-navigation-item.cjs.entry.js +3 -3
  66. package/dist/cjs/spw-sidebar-navigation-separator.cjs.entry.js +1 -1
  67. package/dist/cjs/spw-sidebar.cjs.entry.js +1 -1
  68. package/dist/cjs/spw-skeleton.cjs.entry.js +1 -1
  69. package/dist/cjs/spw-slider-item.cjs.entry.js +1 -1
  70. package/dist/cjs/spw-slider.cjs.entry.js +11 -4
  71. package/dist/cjs/spw-slider.cjs.entry.js.map +1 -1
  72. package/dist/cjs/spw-slider.entry.cjs.js.map +1 -1
  73. package/dist/cjs/spw-socials.cjs.entry.js +1 -1
  74. package/dist/cjs/spw-stencil-library.cjs.js +1 -1
  75. package/dist/cjs/spw-table-body.cjs.entry.js +1 -1
  76. package/dist/cjs/spw-table-cell.cjs.entry.js +1 -1
  77. package/dist/cjs/spw-table-container.cjs.entry.js +20 -0
  78. package/dist/cjs/spw-table-container.cjs.entry.js.map +1 -0
  79. package/dist/cjs/spw-table-container.entry.cjs.js.map +1 -0
  80. package/dist/cjs/spw-table-footer.cjs.entry.js +2 -2
  81. package/dist/cjs/spw-table-footer.cjs.entry.js.map +1 -1
  82. package/dist/cjs/spw-table-footer.entry.cjs.js.map +1 -1
  83. package/dist/cjs/spw-table-head.cjs.entry.js +1 -1
  84. package/dist/cjs/spw-table-header.cjs.entry.js +3 -3
  85. package/dist/cjs/spw-table-header.cjs.entry.js.map +1 -1
  86. package/dist/cjs/spw-table-header.entry.cjs.js.map +1 -1
  87. package/dist/cjs/spw-table-row.cjs.entry.js +1 -1
  88. package/dist/cjs/spw-table-sidebar.cjs.entry.js +142 -0
  89. package/dist/cjs/spw-table-sidebar.cjs.entry.js.map +1 -0
  90. package/dist/cjs/spw-table-sidebar.entry.cjs.js.map +1 -0
  91. package/dist/cjs/spw-table.cjs.entry.js +34 -17
  92. package/dist/cjs/spw-table.cjs.entry.js.map +1 -1
  93. package/dist/cjs/spw-table.entry.cjs.js.map +1 -1
  94. package/dist/cjs/spw-tabs-navigation-item.cjs.entry.js +1 -1
  95. package/dist/cjs/spw-tabs-navigation.cjs.entry.js +1 -1
  96. package/dist/cjs/spw-tabs.cjs.entry.js +1 -1
  97. package/dist/cjs/spw-tag.cjs.entry.js +1 -1
  98. package/dist/cjs/spw-text-field.cjs.entry.js +1 -1
  99. package/dist/cjs/spw-textarea.cjs.entry.js +2 -2
  100. package/dist/cjs/spw-textarea.cjs.entry.js.map +1 -1
  101. package/dist/cjs/spw-textarea.entry.cjs.js.map +1 -1
  102. package/dist/cjs/spw-tile-description.cjs.entry.js +1 -1
  103. package/dist/cjs/spw-tile-title.cjs.entry.js +1 -1
  104. package/dist/cjs/spw-tile.cjs.entry.js +1 -1
  105. package/dist/cjs/spw-toc-container.cjs.entry.js +73 -0
  106. package/dist/cjs/spw-toc-container.cjs.entry.js.map +1 -0
  107. package/dist/cjs/spw-toc-container.entry.cjs.js.map +1 -0
  108. package/dist/cjs/spw-toc-navigation.cjs.entry.js +283 -0
  109. package/dist/cjs/spw-toc-navigation.cjs.entry.js.map +1 -0
  110. package/dist/cjs/spw-toc-navigation.entry.cjs.js.map +1 -0
  111. package/dist/cjs/spw-toc.cjs.entry.js +20 -0
  112. package/dist/cjs/spw-toc.cjs.entry.js.map +1 -0
  113. package/dist/cjs/spw-toc.entry.cjs.js.map +1 -0
  114. package/dist/cjs/spw-tooltip.cjs.entry.js +1 -1
  115. package/dist/cjs/spw-topbar.cjs.entry.js +1 -1
  116. package/dist/cjs/spw-wizard-item.cjs.entry.js +1 -1
  117. package/dist/cjs/spw-wizard.cjs.entry.js +1 -1
  118. package/dist/collection/collection-manifest.json +5 -0
  119. package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.js +1 -1
  120. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.css +1 -1
  121. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.js +1 -1
  122. package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.js +1 -1
  123. package/dist/collection/components/spw-accordion/spw-accordion.js +53 -1
  124. package/dist/collection/components/spw-accordion/spw-accordion.js.map +1 -1
  125. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.css +1 -1
  126. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js +4 -1
  127. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js.map +1 -1
  128. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.css +1 -1
  129. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.js +1 -1
  130. package/dist/collection/components/spw-button/spw-button.js +1 -1
  131. package/dist/collection/components/spw-card/spw-card-content/spw-card-content.js +1 -1
  132. package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.js +1 -1
  133. package/dist/collection/components/spw-card/spw-card-image/spw-card-image.js +1 -1
  134. package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.js +1 -1
  135. package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.js +1 -1
  136. package/dist/collection/components/spw-card/spw-card-title/spw-card-title.js +1 -1
  137. package/dist/collection/components/spw-card/spw-card.js +1 -1
  138. package/dist/collection/components/spw-checkbox/spw-checkbox.js +1 -1
  139. package/dist/collection/components/spw-custom-select/spw-custom-select.js +3 -3
  140. package/dist/collection/components/spw-date-picker/spw-date-picker.js +5 -3
  141. package/dist/collection/components/spw-date-picker/spw-date-picker.js.map +1 -1
  142. package/dist/collection/components/spw-dropdown/spw-dropdown-container/spw-dropdown-container.js +1 -1
  143. package/dist/collection/components/spw-dropdown/spw-dropdown-item/spw-dropdown-item.js +1 -1
  144. package/dist/collection/components/spw-dropdown/spw-dropdown.js +1 -1
  145. package/dist/collection/components/spw-field-label/spw-field-label.js +1 -1
  146. package/dist/collection/components/spw-field-message/spw-field-message.js +1 -1
  147. package/dist/collection/components/spw-file-upload/spw-file-upload.js +2 -2
  148. package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js +1 -1
  149. package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js +1 -1
  150. package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js +1 -1
  151. package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js +1 -1
  152. package/dist/collection/components/spw-footer/spw-footer.js +1 -1
  153. package/dist/collection/components/spw-grid/spw-grid-item/spw-grid-item.js +2 -2
  154. package/dist/collection/components/spw-grid/spw-grid.js +2 -2
  155. package/dist/collection/components/spw-group/spw-group.js +1 -1
  156. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js +1 -1
  157. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js +1 -1
  158. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js +1 -1
  159. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js +1 -1
  160. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js +1 -1
  161. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js +1 -1
  162. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js +1 -1
  163. package/dist/collection/components/spw-header/spw-header.js +1 -1
  164. package/dist/collection/components/spw-hero/spw-hero.css +1 -1
  165. package/dist/collection/components/spw-hero/spw-hero.js +51 -4
  166. package/dist/collection/components/spw-hero/spw-hero.js.map +1 -1
  167. package/dist/collection/components/spw-icon/spw-icon.js +1 -1
  168. package/dist/collection/components/spw-illustration/spw-illustration.css +1 -1
  169. package/dist/collection/components/spw-illustration/spw-illustration.js +488 -1
  170. package/dist/collection/components/spw-illustration/spw-illustration.js.map +1 -1
  171. package/dist/collection/components/spw-iodda/spw-iodda.js +1 -1
  172. package/dist/collection/components/spw-link/spw-link.js +1 -1
  173. package/dist/collection/components/spw-list/spw-list-description/spw-list-description.js +1 -1
  174. package/dist/collection/components/spw-list/spw-list-item/spw-list-item.js +1 -1
  175. package/dist/collection/components/spw-list/spw-list-title/spw-list-title.js +1 -1
  176. package/dist/collection/components/spw-list/spw-list.js +1 -1
  177. package/dist/collection/components/spw-loading/spw-loading.js +1 -1
  178. package/dist/collection/components/spw-modal/spw-modal.js +1 -1
  179. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js +1 -1
  180. package/dist/collection/components/spw-mosaic/spw-mosaic.js +1 -1
  181. package/dist/collection/components/spw-pagination/spw-pagination.js +12 -9
  182. package/dist/collection/components/spw-pagination/spw-pagination.js.map +1 -1
  183. package/dist/collection/components/spw-radio/spw-radio.js +1 -1
  184. package/dist/collection/components/spw-search-field/spw-search-field.js +2 -2
  185. package/dist/collection/components/spw-separator/spw-separator.js +1 -1
  186. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-dropdown/spw-sidebar-navigation-dropdown.js +1 -1
  187. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.js +3 -3
  188. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-separator/spw-sidebar-navigation-separator.js +1 -1
  189. package/dist/collection/components/spw-sidebar/spw-sidebar.js +1 -1
  190. package/dist/collection/components/spw-skeleton/spw-skeleton.js +1 -1
  191. package/dist/collection/components/spw-slider/spw-slider-item/spw-slider-item.js +1 -1
  192. package/dist/collection/components/spw-slider/spw-slider.css +1 -1
  193. package/dist/collection/components/spw-slider/spw-slider.js +30 -3
  194. package/dist/collection/components/spw-slider/spw-slider.js.map +1 -1
  195. package/dist/collection/components/spw-socials/spw-socials.js +1 -1
  196. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js +1 -1
  197. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js +1 -1
  198. package/dist/collection/components/spw-table/spw-table-container/spw-table-container.css +2 -0
  199. package/dist/collection/components/spw-table/spw-table-container/spw-table-container.js +19 -0
  200. package/dist/collection/components/spw-table/spw-table-container/spw-table-container.js.map +1 -0
  201. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.css +1 -1
  202. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.js +1 -1
  203. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.js.map +1 -1
  204. package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js +1 -1
  205. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.css +1 -1
  206. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js +2 -2
  207. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js.map +1 -1
  208. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js +1 -1
  209. package/dist/collection/components/spw-table/spw-table-sidebar/spw-table-sidebar.css +2 -0
  210. package/dist/collection/components/spw-table/spw-table-sidebar/spw-table-sidebar.js +290 -0
  211. package/dist/collection/components/spw-table/spw-table-sidebar/spw-table-sidebar.js.map +1 -0
  212. package/dist/collection/components/spw-table/spw-table.css +1 -1
  213. package/dist/collection/components/spw-table/spw-table.js +33 -16
  214. package/dist/collection/components/spw-table/spw-table.js.map +1 -1
  215. package/dist/collection/components/spw-tabs/spw-tabs-navigation/spw-tabs-navigation.js +1 -1
  216. package/dist/collection/components/spw-tabs/spw-tabs-navigation-item/spw-tabs-navigation-item.js +1 -1
  217. package/dist/collection/components/spw-tabs/spw-tabs.js +1 -1
  218. package/dist/collection/components/spw-tag/spw-tag.js +1 -1
  219. package/dist/collection/components/spw-text-field/spw-text-field.js +1 -1
  220. package/dist/collection/components/spw-textarea/spw-textarea.js +3 -3
  221. package/dist/collection/components/spw-textarea/spw-textarea.js.map +1 -1
  222. package/dist/collection/components/spw-theme-provider/spw-theme-provider.js +1 -1
  223. package/dist/collection/components/spw-tile/spw-tile-description/spw-tile-description.js +1 -1
  224. package/dist/collection/components/spw-tile/spw-tile-title/spw-tile-title.js +1 -1
  225. package/dist/collection/components/spw-tile/spw-tile.js +1 -1
  226. package/dist/collection/components/spw-toc/spw-toc-container/spw-toc-container.css +2 -0
  227. package/dist/collection/components/spw-toc/spw-toc-container/spw-toc-container.js +120 -0
  228. package/dist/collection/components/spw-toc/spw-toc-container/spw-toc-container.js.map +1 -0
  229. package/dist/collection/components/spw-toc/spw-toc-navigation/spw-toc-navigation.css +2 -0
  230. package/dist/collection/components/spw-toc/spw-toc-navigation/spw-toc-navigation.js +301 -0
  231. package/dist/collection/components/spw-toc/spw-toc-navigation/spw-toc-navigation.js.map +1 -0
  232. package/dist/collection/components/spw-toc/spw-toc.css +2 -0
  233. package/dist/collection/components/spw-toc/spw-toc.js +18 -0
  234. package/dist/collection/components/spw-toc/spw-toc.js.map +1 -0
  235. package/dist/collection/components/spw-tooltip/spw-tooltip.js +1 -1
  236. package/dist/collection/components/spw-topbar/spw-topbar.js +1 -1
  237. package/dist/collection/components/spw-wizard/spw-wizard-item/spw-wizard-item.js +1 -1
  238. package/dist/collection/components/spw-wizard/spw-wizard.js +1 -1
  239. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js +32 -1
  240. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js.map +1 -1
  241. package/dist/collection/stories/components/spw-button/spw-button.stories.js +59 -1
  242. package/dist/collection/stories/components/spw-button/spw-button.stories.js.map +1 -1
  243. package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js +37 -1
  244. package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js.map +1 -1
  245. package/dist/collection/stories/components/spw-custom-select/spw-custom-select.stories.js +60 -1
  246. package/dist/collection/stories/components/spw-custom-select/spw-custom-select.stories.js.map +1 -1
  247. package/dist/collection/stories/components/spw-date-picker/spw-date-picker.stories.js +60 -1
  248. package/dist/collection/stories/components/spw-date-picker/spw-date-picker.stories.js.map +1 -1
  249. package/dist/collection/stories/components/spw-dropdown/spw-dropdown.stories.js +19 -1
  250. package/dist/collection/stories/components/spw-dropdown/spw-dropdown.stories.js.map +1 -1
  251. package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js +52 -1
  252. package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js.map +1 -1
  253. package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js +20 -1
  254. package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js.map +1 -1
  255. package/dist/collection/stories/components/spw-icon/spw-icon.stories.js +21 -1
  256. package/dist/collection/stories/components/spw-icon/spw-icon.stories.js.map +1 -1
  257. package/dist/collection/stories/components/spw-link/spw-link.stories.js +31 -1
  258. package/dist/collection/stories/components/spw-link/spw-link.stories.js.map +1 -1
  259. package/dist/collection/stories/components/spw-loading/spw-loading.stories.js +29 -1
  260. package/dist/collection/stories/components/spw-loading/spw-loading.stories.js.map +1 -1
  261. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js +37 -1
  262. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js.map +1 -1
  263. package/dist/collection/stories/components/spw-radio/spw-radio.stories.js +17 -1
  264. package/dist/collection/stories/components/spw-radio/spw-radio.stories.js.map +1 -1
  265. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js +33 -1
  266. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js.map +1 -1
  267. package/dist/collection/stories/components/spw-select/spw-select.stories.js +19 -1
  268. package/dist/collection/stories/components/spw-select/spw-select.stories.js.map +1 -1
  269. package/dist/collection/stories/components/spw-separator/spw-separator.stories.js +33 -1
  270. package/dist/collection/stories/components/spw-separator/spw-separator.stories.js.map +1 -1
  271. package/dist/collection/stories/components/spw-skeleton/spw-skeleton.stories.js +51 -2
  272. package/dist/collection/stories/components/spw-skeleton/spw-skeleton.stories.js.map +1 -1
  273. package/dist/collection/stories/components/spw-tag/spw-tag.stories.js +72 -1
  274. package/dist/collection/stories/components/spw-tag/spw-tag.stories.js.map +1 -1
  275. package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js +34 -1
  276. package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js.map +1 -1
  277. package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js +16 -1
  278. package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js.map +1 -1
  279. package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js +17 -1
  280. package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js.map +1 -1
  281. package/dist/collection/stories/organisms/spw-accordion/spw-accordion.stories.js +17 -4
  282. package/dist/collection/stories/organisms/spw-accordion/spw-accordion.stories.js.map +1 -1
  283. package/dist/collection/stories/organisms/spw-card/spw-card.stories.js +96 -1
  284. package/dist/collection/stories/organisms/spw-card/spw-card.stories.js.map +1 -1
  285. package/dist/collection/stories/organisms/spw-footer/spw-footer.stories.js +38 -1
  286. package/dist/collection/stories/organisms/spw-footer/spw-footer.stories.js.map +1 -1
  287. package/dist/collection/stories/organisms/spw-grid/spw-grid.stories.js +25 -1
  288. package/dist/collection/stories/organisms/spw-grid/spw-grid.stories.js.map +1 -1
  289. package/dist/collection/stories/organisms/spw-group/spw-group.stories.js +46 -7
  290. package/dist/collection/stories/organisms/spw-group/spw-group.stories.js.map +1 -1
  291. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js +58 -7
  292. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js.map +1 -1
  293. package/dist/collection/stories/organisms/spw-hero/spw-hero.stories.js +87 -1
  294. package/dist/collection/stories/organisms/spw-hero/spw-hero.stories.js.map +1 -1
  295. package/dist/collection/stories/organisms/spw-list/spw-list.stories.js +57 -1
  296. package/dist/collection/stories/organisms/spw-list/spw-list.stories.js.map +1 -1
  297. package/dist/collection/stories/organisms/spw-message/spw-message.stories.js +71 -1
  298. package/dist/collection/stories/organisms/spw-message/spw-message.stories.js.map +1 -1
  299. package/dist/collection/stories/organisms/spw-modal/spw-modal.stories.js +62 -1
  300. package/dist/collection/stories/organisms/spw-modal/spw-modal.stories.js.map +1 -1
  301. package/dist/collection/stories/organisms/spw-mosaic/spw-mosaic.stories.js +74 -1
  302. package/dist/collection/stories/organisms/spw-mosaic/spw-mosaic.stories.js.map +1 -1
  303. package/dist/collection/stories/organisms/spw-sidebar/spw-sidebar.stories.js +31 -1
  304. package/dist/collection/stories/organisms/spw-sidebar/spw-sidebar.stories.js.map +1 -1
  305. package/dist/collection/stories/organisms/spw-slider/spw-slider.stories.js +21 -1
  306. package/dist/collection/stories/organisms/spw-slider/spw-slider.stories.js.map +1 -1
  307. package/dist/collection/stories/organisms/spw-socials/spw-socials.stories.js +25 -1
  308. package/dist/collection/stories/organisms/spw-socials/spw-socials.stories.js.map +1 -1
  309. package/dist/collection/stories/organisms/spw-table/spw-table.stories.js +69 -1
  310. package/dist/collection/stories/organisms/spw-table/spw-table.stories.js.map +1 -1
  311. package/dist/collection/stories/organisms/spw-tabs/spw-tabs.stories.js +57 -1
  312. package/dist/collection/stories/organisms/spw-tabs/spw-tabs.stories.js.map +1 -1
  313. package/dist/collection/stories/organisms/spw-tile/spw-tile.stories.js +83 -1
  314. package/dist/collection/stories/organisms/spw-tile/spw-tile.stories.js.map +1 -1
  315. package/dist/collection/stories/organisms/spw-toc/spw-toc.stories.js +256 -0
  316. package/dist/collection/stories/organisms/spw-toc/spw-toc.stories.js.map +1 -0
  317. package/dist/collection/stories/organisms/spw-topbar/spw-topbar.stories.js +52 -1
  318. package/dist/collection/stories/organisms/spw-topbar/spw-topbar.stories.js.map +1 -1
  319. package/dist/components/{p-QqgPCBuq.js → p-BCWtq89_.js} +3 -3
  320. package/dist/components/{p-QqgPCBuq.js.map → p-BCWtq89_.js.map} +1 -1
  321. package/dist/components/{p-DzdAUdJU.js → p-BTvGjWzW.js} +3 -3
  322. package/dist/components/{p-DzdAUdJU.js.map → p-BTvGjWzW.js.map} +1 -1
  323. package/dist/components/{p-DtyDCGAt.js → p-BZeR2u__.js} +3 -3
  324. package/dist/components/{p-DtyDCGAt.js.map → p-BZeR2u__.js.map} +1 -1
  325. package/dist/components/{p-BJuYSBNu.js → p-Bu2NP1Hz.js} +4 -4
  326. package/dist/components/{p-BJuYSBNu.js.map → p-Bu2NP1Hz.js.map} +1 -1
  327. package/dist/components/{p-CFQbmE2_.js → p-C0RRW46w.js} +4 -4
  328. package/dist/components/p-C0RRW46w.js.map +1 -0
  329. package/dist/components/{p-BYWyi-Sg.js → p-Cwnv6xZs.js} +4 -4
  330. package/dist/components/{p-BYWyi-Sg.js.map → p-Cwnv6xZs.js.map} +1 -1
  331. package/dist/components/{p-YZZxQbyU.js → p-CyyuvuPG.js} +5 -5
  332. package/dist/components/{p-YZZxQbyU.js.map → p-CyyuvuPG.js.map} +1 -1
  333. package/dist/components/{p-CQpGzRKu.js → p-D4uTODSD.js} +31 -4
  334. package/dist/components/p-D4uTODSD.js.map +1 -0
  335. package/dist/components/{p-CN-VU2O8.js → p-DPJAZYpY.js} +3 -3
  336. package/dist/components/{p-CN-VU2O8.js.map → p-DPJAZYpY.js.map} +1 -1
  337. package/dist/components/{p-Otqq8W18.js → p-DYC6u5kd.js} +3 -3
  338. package/dist/components/{p-Otqq8W18.js.map → p-DYC6u5kd.js.map} +1 -1
  339. package/dist/components/{p-CIwDs15y.js → p-DrAfEAz-.js} +3 -3
  340. package/dist/components/{p-CIwDs15y.js.map → p-DrAfEAz-.js.map} +1 -1
  341. package/dist/components/{p-BPeRFxsF.js → p-DvSE7JLV.js} +4 -4
  342. package/dist/components/{p-BPeRFxsF.js.map → p-DvSE7JLV.js.map} +1 -1
  343. package/dist/components/{p-C47wKUeG.js → p-L8eHcqaq.js} +17 -17
  344. package/dist/components/p-L8eHcqaq.js.map +1 -0
  345. package/dist/components/{p-DTm94uQW.js → p-d3hqDeA0.js} +4 -4
  346. package/dist/components/{p-DTm94uQW.js.map → p-d3hqDeA0.js.map} +1 -1
  347. package/dist/components/{p-Cdk2nQ84.js → p-kJsRMeYL.js} +6 -6
  348. package/dist/components/{p-Cdk2nQ84.js.map → p-kJsRMeYL.js.map} +1 -1
  349. package/dist/components/spw-accordion-content.js +1 -1
  350. package/dist/components/spw-accordion-item.js +1 -1
  351. package/dist/components/spw-accordion-title.js +1 -1
  352. package/dist/components/spw-accordion.js +1 -1
  353. package/dist/components/spw-breadcrumb-item.js +7 -4
  354. package/dist/components/spw-breadcrumb-item.js.map +1 -1
  355. package/dist/components/spw-breadcrumb.js +2 -2
  356. package/dist/components/spw-breadcrumb.js.map +1 -1
  357. package/dist/components/spw-button.js +1 -1
  358. package/dist/components/spw-card-content.js +1 -1
  359. package/dist/components/spw-card-excerpt.js +1 -1
  360. package/dist/components/spw-card-image.js +2 -2
  361. package/dist/components/spw-card-subtag-item.js +1 -1
  362. package/dist/components/spw-card-subtags.js +1 -1
  363. package/dist/components/spw-card-title.js +1 -1
  364. package/dist/components/spw-card.js +1 -1
  365. package/dist/components/spw-checkbox.js +1 -1
  366. package/dist/components/spw-cookies.js +8 -8
  367. package/dist/components/spw-custom-select.js +7 -7
  368. package/dist/components/spw-date-picker.js +8 -6
  369. package/dist/components/spw-date-picker.js.map +1 -1
  370. package/dist/components/spw-dropdown-container.js +1 -1
  371. package/dist/components/spw-dropdown-item.js +2 -2
  372. package/dist/components/spw-dropdown.js +1 -1
  373. package/dist/components/spw-field-label.js +1 -1
  374. package/dist/components/spw-field-message.js +1 -1
  375. package/dist/components/spw-file-upload.js +5 -5
  376. package/dist/components/spw-footer-bottom.js +1 -1
  377. package/dist/components/spw-footer-content-col.js +1 -1
  378. package/dist/components/spw-footer-content.js +1 -1
  379. package/dist/components/spw-footer-link.js +1 -1
  380. package/dist/components/spw-footer.js +1 -1
  381. package/dist/components/spw-grid-item.js +2 -2
  382. package/dist/components/spw-grid.js +2 -2
  383. package/dist/components/spw-group.js +2 -2
  384. package/dist/components/spw-header-lang-item.js +1 -1
  385. package/dist/components/spw-header-lang.js +4 -4
  386. package/dist/components/spw-header-navigation-dropdown.js +1 -1
  387. package/dist/components/spw-header-navigation-item.js +2 -2
  388. package/dist/components/spw-header-navigation.js +4 -4
  389. package/dist/components/spw-header-persona-item.js +1 -1
  390. package/dist/components/spw-header-persona.js +2 -2
  391. package/dist/components/spw-header.js +4 -4
  392. package/dist/components/spw-hero.js +14 -5
  393. package/dist/components/spw-hero.js.map +1 -1
  394. package/dist/components/spw-icon.js +1 -1
  395. package/dist/components/spw-illustration.js +488 -1
  396. package/dist/components/spw-illustration.js.map +1 -1
  397. package/dist/components/spw-iodda.js +7 -7
  398. package/dist/components/spw-link.js +1 -1
  399. package/dist/components/spw-list-description.js +1 -1
  400. package/dist/components/spw-list-item.js +2 -2
  401. package/dist/components/spw-list-title.js +2 -2
  402. package/dist/components/spw-list.js +1 -1
  403. package/dist/components/spw-loading.js +1 -1
  404. package/dist/components/spw-message.js +2 -2
  405. package/dist/components/spw-modal.js +2 -2
  406. package/dist/components/spw-mosaic-item.js +1 -1
  407. package/dist/components/spw-mosaic.js +1 -1
  408. package/dist/components/spw-pagination.js +1 -1
  409. package/dist/components/spw-radio.js +1 -1
  410. package/dist/components/spw-search-field.js +6 -6
  411. package/dist/components/spw-select.js +3 -3
  412. package/dist/components/spw-separator.js +1 -1
  413. package/dist/components/spw-sidebar-navigation-dropdown.js +1 -1
  414. package/dist/components/spw-sidebar-navigation-item.js +5 -5
  415. package/dist/components/spw-sidebar-navigation-separator.js +2 -2
  416. package/dist/components/spw-sidebar.js +2 -2
  417. package/dist/components/spw-skeleton.js +1 -1
  418. package/dist/components/spw-slider-item.js +1 -1
  419. package/dist/components/spw-slider.js +14 -6
  420. package/dist/components/spw-slider.js.map +1 -1
  421. package/dist/components/spw-socials.js +1 -1
  422. package/dist/components/spw-table-body.js +1 -1
  423. package/dist/components/spw-table-cell.js +1 -1
  424. package/dist/components/spw-table-container.d.ts +11 -0
  425. package/dist/components/spw-table-container.js +36 -0
  426. package/dist/components/spw-table-container.js.map +1 -0
  427. package/dist/components/spw-table-footer.js +2 -2
  428. package/dist/components/spw-table-footer.js.map +1 -1
  429. package/dist/components/spw-table-head.js +1 -1
  430. package/dist/components/spw-table-header.js +5 -5
  431. package/dist/components/spw-table-header.js.map +1 -1
  432. package/dist/components/spw-table-row.js +1 -1
  433. package/dist/components/spw-table-sidebar.d.ts +11 -0
  434. package/dist/components/spw-table-sidebar.js +185 -0
  435. package/dist/components/spw-table-sidebar.js.map +1 -0
  436. package/dist/components/spw-table.js +34 -17
  437. package/dist/components/spw-table.js.map +1 -1
  438. package/dist/components/spw-tabs-navigation-item.js +3 -3
  439. package/dist/components/spw-tabs-navigation.js +2 -2
  440. package/dist/components/spw-tabs.js +1 -1
  441. package/dist/components/spw-tag.js +2 -2
  442. package/dist/components/spw-text-field.js +1 -1
  443. package/dist/components/spw-textarea.js +5 -5
  444. package/dist/components/spw-textarea.js.map +1 -1
  445. package/dist/components/spw-theme-provider.js +1 -1
  446. package/dist/components/spw-tile-description.js +1 -1
  447. package/dist/components/spw-tile-title.js +1 -1
  448. package/dist/components/spw-tile.js +2 -2
  449. package/dist/components/spw-toc-container.d.ts +11 -0
  450. package/dist/components/spw-toc-container.js +90 -0
  451. package/dist/components/spw-toc-container.js.map +1 -0
  452. package/dist/components/spw-toc-navigation.d.ts +11 -0
  453. package/dist/components/spw-toc-navigation.js +304 -0
  454. package/dist/components/spw-toc-navigation.js.map +1 -0
  455. package/dist/components/spw-toc.d.ts +11 -0
  456. package/dist/components/spw-toc.js +35 -0
  457. package/dist/components/spw-toc.js.map +1 -0
  458. package/dist/components/spw-tooltip.js +1 -1
  459. package/dist/components/spw-topbar.js +1 -1
  460. package/dist/components/spw-wizard-item.js +2 -2
  461. package/dist/components/spw-wizard.js +1 -1
  462. package/dist/components_json.json +461 -16
  463. package/dist/components_vscode.json +3409 -0
  464. package/dist/esm/loader.js +1 -1
  465. package/dist/esm/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.js.map +1 -1
  466. package/dist/esm/spw-accordion_4.entry.js +28 -5
  467. package/dist/esm/spw-accordion_4.entry.js.map +1 -1
  468. package/dist/esm/spw-breadcrumb-item.entry.js +5 -2
  469. package/dist/esm/spw-breadcrumb-item.entry.js.map +1 -1
  470. package/dist/esm/spw-breadcrumb.entry.js +2 -2
  471. package/dist/esm/spw-breadcrumb.entry.js.map +1 -1
  472. package/dist/esm/spw-button_2.entry.js +2 -2
  473. package/dist/esm/spw-card-content.entry.js +1 -1
  474. package/dist/esm/spw-card-excerpt.entry.js +1 -1
  475. package/dist/esm/spw-card-image.entry.js +1 -1
  476. package/dist/esm/spw-card-subtag-item.entry.js +1 -1
  477. package/dist/esm/spw-card-subtags.entry.js +1 -1
  478. package/dist/esm/spw-card-title.entry.js +1 -1
  479. package/dist/esm/spw-card.entry.js +1 -1
  480. package/dist/esm/spw-checkbox.entry.js +1 -1
  481. package/dist/esm/spw-custom-select.entry.js +3 -3
  482. package/dist/esm/spw-date-picker.entry.js +5 -3
  483. package/dist/esm/spw-date-picker.entry.js.map +1 -1
  484. package/dist/esm/spw-dropdown-container.entry.js +1 -1
  485. package/dist/esm/spw-dropdown-item.entry.js +1 -1
  486. package/dist/esm/spw-dropdown.entry.js +1 -1
  487. package/dist/esm/spw-field-label_6.entry.js +6 -6
  488. package/dist/esm/spw-field-message.entry.js +1 -1
  489. package/dist/esm/spw-file-upload.entry.js +2 -2
  490. package/dist/esm/spw-footer-bottom.entry.js +1 -1
  491. package/dist/esm/spw-footer-content-col.entry.js +1 -1
  492. package/dist/esm/spw-footer-content.entry.js +1 -1
  493. package/dist/esm/spw-footer-link.entry.js +1 -1
  494. package/dist/esm/spw-footer.entry.js +1 -1
  495. package/dist/esm/spw-grid-item.entry.js +2 -2
  496. package/dist/esm/spw-grid.entry.js +2 -2
  497. package/dist/esm/spw-header-lang-item.entry.js +1 -1
  498. package/dist/esm/spw-header-lang.entry.js +1 -1
  499. package/dist/esm/spw-header-navigation-dropdown.entry.js +1 -1
  500. package/dist/esm/spw-header-navigation-item.entry.js +1 -1
  501. package/dist/esm/spw-header-navigation.entry.js +1 -1
  502. package/dist/esm/spw-header-persona-item.entry.js +1 -1
  503. package/dist/esm/spw-header-persona.entry.js +1 -1
  504. package/dist/esm/spw-header.entry.js +1 -1
  505. package/dist/esm/spw-hero.entry.js +10 -3
  506. package/dist/esm/spw-hero.entry.js.map +1 -1
  507. package/dist/esm/spw-illustration.entry.js +488 -1
  508. package/dist/esm/spw-illustration.entry.js.map +1 -1
  509. package/dist/esm/spw-iodda.entry.js +1 -1
  510. package/dist/esm/spw-list-description.entry.js +1 -1
  511. package/dist/esm/spw-list-item.entry.js +1 -1
  512. package/dist/esm/spw-list-title.entry.js +1 -1
  513. package/dist/esm/spw-list.entry.js +1 -1
  514. package/dist/esm/spw-modal.entry.js +1 -1
  515. package/dist/esm/spw-mosaic-item.entry.js +1 -1
  516. package/dist/esm/spw-mosaic.entry.js +1 -1
  517. package/dist/esm/spw-pagination.entry.js +10 -10
  518. package/dist/esm/spw-pagination.entry.js.map +1 -1
  519. package/dist/esm/spw-radio.entry.js +1 -1
  520. package/dist/esm/spw-search-field.entry.js +2 -2
  521. package/dist/esm/spw-sidebar-navigation-dropdown.entry.js +1 -1
  522. package/dist/esm/spw-sidebar-navigation-item.entry.js +3 -3
  523. package/dist/esm/spw-sidebar-navigation-separator.entry.js +1 -1
  524. package/dist/esm/spw-sidebar.entry.js +1 -1
  525. package/dist/esm/spw-skeleton.entry.js +1 -1
  526. package/dist/esm/spw-slider-item.entry.js +1 -1
  527. package/dist/esm/spw-slider.entry.js +11 -4
  528. package/dist/esm/spw-slider.entry.js.map +1 -1
  529. package/dist/esm/spw-socials.entry.js +1 -1
  530. package/dist/esm/spw-stencil-library.js +1 -1
  531. package/dist/esm/spw-table-body.entry.js +1 -1
  532. package/dist/esm/spw-table-cell.entry.js +1 -1
  533. package/dist/esm/spw-table-container.entry.js +18 -0
  534. package/dist/esm/spw-table-container.entry.js.map +1 -0
  535. package/dist/esm/spw-table-footer.entry.js +2 -2
  536. package/dist/esm/spw-table-footer.entry.js.map +1 -1
  537. package/dist/esm/spw-table-head.entry.js +1 -1
  538. package/dist/esm/spw-table-header.entry.js +3 -3
  539. package/dist/esm/spw-table-header.entry.js.map +1 -1
  540. package/dist/esm/spw-table-row.entry.js +1 -1
  541. package/dist/esm/spw-table-sidebar.entry.js +140 -0
  542. package/dist/esm/spw-table-sidebar.entry.js.map +1 -0
  543. package/dist/esm/spw-table.entry.js +34 -17
  544. package/dist/esm/spw-table.entry.js.map +1 -1
  545. package/dist/esm/spw-tabs-navigation-item.entry.js +1 -1
  546. package/dist/esm/spw-tabs-navigation.entry.js +1 -1
  547. package/dist/esm/spw-tabs.entry.js +1 -1
  548. package/dist/esm/spw-tag.entry.js +1 -1
  549. package/dist/esm/spw-text-field.entry.js +1 -1
  550. package/dist/esm/spw-textarea.entry.js +2 -2
  551. package/dist/esm/spw-textarea.entry.js.map +1 -1
  552. package/dist/esm/spw-tile-description.entry.js +1 -1
  553. package/dist/esm/spw-tile-title.entry.js +1 -1
  554. package/dist/esm/spw-tile.entry.js +1 -1
  555. package/dist/esm/spw-toc-container.entry.js +71 -0
  556. package/dist/esm/spw-toc-container.entry.js.map +1 -0
  557. package/dist/esm/spw-toc-navigation.entry.js +281 -0
  558. package/dist/esm/spw-toc-navigation.entry.js.map +1 -0
  559. package/dist/esm/spw-toc.entry.js +18 -0
  560. package/dist/esm/spw-toc.entry.js.map +1 -0
  561. package/dist/esm/spw-tooltip.entry.js +1 -1
  562. package/dist/esm/spw-topbar.entry.js +1 -1
  563. package/dist/esm/spw-wizard-item.entry.js +1 -1
  564. package/dist/esm/spw-wizard.entry.js +1 -1
  565. package/dist/spw-stencil-library/{p-4bc3d2ef.entry.js → p-04aa5d86.entry.js} +2 -2
  566. package/dist/spw-stencil-library/{p-a2fd09f8.entry.js → p-0839efb1.entry.js} +2 -2
  567. package/dist/spw-stencil-library/p-0a69cead.entry.js +2 -0
  568. package/dist/spw-stencil-library/p-0a69cead.entry.js.map +1 -0
  569. package/dist/spw-stencil-library/{p-84645c94.entry.js → p-0bc1209e.entry.js} +2 -2
  570. package/dist/spw-stencil-library/{p-1644bf7d.entry.js → p-0e7f2c1a.entry.js} +2 -2
  571. package/dist/spw-stencil-library/{p-6e37db2d.entry.js → p-0f728bbd.entry.js} +2 -2
  572. package/dist/spw-stencil-library/{p-6e37db2d.entry.js.map → p-0f728bbd.entry.js.map} +1 -1
  573. package/dist/spw-stencil-library/{p-670f0edc.entry.js → p-1306c0ff.entry.js} +2 -2
  574. package/dist/spw-stencil-library/{p-ed61e2a8.entry.js → p-137f2856.entry.js} +2 -2
  575. package/dist/spw-stencil-library/{p-d02b077c.entry.js → p-1416942e.entry.js} +2 -2
  576. package/dist/spw-stencil-library/p-1416942e.entry.js.map +1 -0
  577. package/dist/spw-stencil-library/{p-5e0b04c0.entry.js → p-1bb4a071.entry.js} +2 -2
  578. package/dist/spw-stencil-library/{p-eb26b450.entry.js → p-1c728c37.entry.js} +2 -2
  579. package/dist/spw-stencil-library/{p-44bb3ec0.entry.js → p-20fa2637.entry.js} +2 -2
  580. package/dist/spw-stencil-library/{p-2b70c24a.entry.js → p-2965d7ca.entry.js} +2 -2
  581. package/dist/spw-stencil-library/{p-82ed2f9b.entry.js → p-29fb06a6.entry.js} +2 -2
  582. package/dist/spw-stencil-library/p-2d6f393e.entry.js +2 -0
  583. package/dist/spw-stencil-library/p-2d6f393e.entry.js.map +1 -0
  584. package/dist/spw-stencil-library/{p-2760ef2b.entry.js → p-2d7492af.entry.js} +2 -2
  585. package/dist/spw-stencil-library/p-2dea4478.entry.js +2 -0
  586. package/dist/spw-stencil-library/p-2dea4478.entry.js.map +1 -0
  587. package/dist/spw-stencil-library/{p-6c88a82d.entry.js → p-3067d3dd.entry.js} +2 -2
  588. package/dist/spw-stencil-library/{p-e5f141b6.entry.js → p-31980405.entry.js} +2 -2
  589. package/dist/spw-stencil-library/{p-9d0e8d02.entry.js → p-3553e1f1.entry.js} +2 -2
  590. package/dist/spw-stencil-library/p-3753277e.entry.js +2 -0
  591. package/dist/spw-stencil-library/p-3753277e.entry.js.map +1 -0
  592. package/dist/spw-stencil-library/{p-cbf4ef91.entry.js → p-3c524edb.entry.js} +2 -2
  593. package/dist/spw-stencil-library/{p-93dc746d.entry.js → p-40b238cb.entry.js} +2 -2
  594. package/dist/spw-stencil-library/{p-93dc746d.entry.js.map → p-40b238cb.entry.js.map} +1 -1
  595. package/dist/spw-stencil-library/{p-d37963e0.entry.js → p-420fd27d.entry.js} +2 -2
  596. package/dist/spw-stencil-library/{p-87249c32.entry.js → p-460b4ede.entry.js} +2 -2
  597. package/dist/spw-stencil-library/{p-c3f21e33.entry.js → p-47f6b942.entry.js} +2 -2
  598. package/dist/spw-stencil-library/p-48f1e67a.entry.js +2 -0
  599. package/dist/spw-stencil-library/p-48f1e67a.entry.js.map +1 -0
  600. package/dist/spw-stencil-library/{p-f26fd3b1.entry.js → p-49227f48.entry.js} +2 -2
  601. package/dist/spw-stencil-library/{p-a065a834.entry.js → p-4ab97219.entry.js} +2 -2
  602. package/dist/spw-stencil-library/{p-3545f888.entry.js → p-5ba3deea.entry.js} +2 -2
  603. package/dist/spw-stencil-library/{p-5e1aae61.entry.js → p-6c0993d6.entry.js} +2 -2
  604. package/dist/spw-stencil-library/{p-95749696.entry.js → p-70ccb73f.entry.js} +2 -2
  605. package/dist/spw-stencil-library/{p-6f084e62.entry.js → p-70f46bf2.entry.js} +2 -2
  606. package/dist/spw-stencil-library/{p-b3e76f4c.entry.js → p-7214cc7b.entry.js} +2 -2
  607. package/dist/spw-stencil-library/{p-0c3e8d91.entry.js → p-798bac47.entry.js} +2 -2
  608. package/dist/spw-stencil-library/{p-a4111a43.entry.js → p-8483cd8b.entry.js} +2 -2
  609. package/dist/spw-stencil-library/{p-931bea3a.entry.js → p-8c2f0377.entry.js} +2 -2
  610. package/dist/spw-stencil-library/{p-e4e2cb61.entry.js → p-93bd4d23.entry.js} +2 -2
  611. package/dist/spw-stencil-library/{p-25204236.entry.js → p-95ec862e.entry.js} +2 -2
  612. package/dist/spw-stencil-library/{p-5adfcd7e.entry.js → p-9a3dcf80.entry.js} +2 -2
  613. package/dist/spw-stencil-library/{p-6cdf16ac.entry.js → p-9d5deba6.entry.js} +2 -2
  614. package/dist/spw-stencil-library/{p-d28a7068.entry.js → p-a264b181.entry.js} +2 -2
  615. package/dist/spw-stencil-library/{p-95fa97a9.entry.js → p-aa4ddfa1.entry.js} +2 -2
  616. package/dist/spw-stencil-library/{p-9dea2f39.entry.js → p-ad964a8e.entry.js} +2 -2
  617. package/dist/spw-stencil-library/{p-08000970.entry.js → p-ada217d5.entry.js} +2 -2
  618. package/dist/spw-stencil-library/{p-197a694e.entry.js → p-aed34c29.entry.js} +2 -2
  619. package/dist/spw-stencil-library/{p-94069aff.entry.js → p-b4805c08.entry.js} +2 -2
  620. package/dist/spw-stencil-library/{p-277bb102.entry.js → p-bb4c4e16.entry.js} +2 -2
  621. package/dist/spw-stencil-library/{p-a5004a01.entry.js → p-bb7f1387.entry.js} +2 -2
  622. package/dist/spw-stencil-library/{p-b4c2fdf2.entry.js → p-bcceb61b.entry.js} +2 -2
  623. package/dist/spw-stencil-library/{p-68f93962.entry.js → p-bf070798.entry.js} +2 -2
  624. package/dist/spw-stencil-library/{p-110ca863.entry.js → p-c02b7133.entry.js} +2 -2
  625. package/dist/spw-stencil-library/{p-ca98ee5d.entry.js → p-c278daa3.entry.js} +2 -2
  626. package/dist/spw-stencil-library/{p-428aa721.entry.js → p-c398550f.entry.js} +2 -2
  627. package/dist/spw-stencil-library/{p-803b2bb5.entry.js → p-c77adac8.entry.js} +2 -2
  628. package/dist/spw-stencil-library/{p-aeec7eeb.entry.js → p-c7b2c5d7.entry.js} +2 -2
  629. package/dist/spw-stencil-library/p-c7b2c5d7.entry.js.map +1 -0
  630. package/dist/spw-stencil-library/p-c85f2f9a.entry.js +2 -0
  631. package/dist/spw-stencil-library/p-c85f2f9a.entry.js.map +1 -0
  632. package/dist/spw-stencil-library/{p-ea0cfe62.entry.js → p-cc3a84a1.entry.js} +2 -2
  633. package/dist/spw-stencil-library/{p-91b264d1.entry.js → p-cc869e6f.entry.js} +2 -2
  634. package/dist/spw-stencil-library/{p-a1d06611.entry.js → p-ccbc7c44.entry.js} +2 -2
  635. package/dist/spw-stencil-library/p-d0cb71d3.entry.js +2 -0
  636. package/dist/spw-stencil-library/p-d0cb71d3.entry.js.map +1 -0
  637. package/dist/spw-stencil-library/{p-3ac699ae.entry.js → p-d18146ca.entry.js} +2 -2
  638. package/dist/spw-stencil-library/p-d2b6aae7.entry.js +2 -0
  639. package/dist/spw-stencil-library/p-d2b6aae7.entry.js.map +1 -0
  640. package/dist/spw-stencil-library/{p-65aec904.entry.js → p-d2f5d210.entry.js} +2 -2
  641. package/dist/spw-stencil-library/p-d672e985.entry.js +2 -0
  642. package/dist/spw-stencil-library/p-d672e985.entry.js.map +1 -0
  643. package/dist/spw-stencil-library/{p-bb2421dc.entry.js → p-d8cae37d.entry.js} +2 -2
  644. package/dist/spw-stencil-library/{p-e2bac6be.entry.js → p-db817793.entry.js} +2 -2
  645. package/dist/spw-stencil-library/{p-c3246505.entry.js → p-dbb7e719.entry.js} +2 -2
  646. package/dist/spw-stencil-library/{p-df4d1f42.entry.js → p-de771d14.entry.js} +2 -2
  647. package/dist/spw-stencil-library/p-dedeaccc.entry.js +2 -0
  648. package/dist/spw-stencil-library/p-dedeaccc.entry.js.map +1 -0
  649. package/dist/spw-stencil-library/{p-187d02cb.entry.js → p-e369abbb.entry.js} +2 -2
  650. package/dist/spw-stencil-library/{p-67b7b947.entry.js → p-e44b8ebb.entry.js} +2 -2
  651. package/dist/spw-stencil-library/p-e55b0c4b.entry.js +2 -0
  652. package/dist/spw-stencil-library/p-e55b0c4b.entry.js.map +1 -0
  653. package/dist/spw-stencil-library/{p-1271e178.entry.js → p-e6b25971.entry.js} +2 -2
  654. package/dist/spw-stencil-library/p-e6b25971.entry.js.map +1 -0
  655. package/dist/spw-stencil-library/p-e6c8a3e4.entry.js +2 -0
  656. package/dist/spw-stencil-library/p-e6c8a3e4.entry.js.map +1 -0
  657. package/dist/spw-stencil-library/{p-6461fb4b.entry.js → p-e78304f0.entry.js} +2 -2
  658. package/dist/spw-stencil-library/{p-25aaf6a6.entry.js → p-ea5f2427.entry.js} +2 -2
  659. package/dist/spw-stencil-library/{p-95891f3a.entry.js → p-ea952c66.entry.js} +2 -2
  660. package/dist/spw-stencil-library/{p-22f022ca.entry.js → p-eaa1025a.entry.js} +2 -2
  661. package/dist/spw-stencil-library/{p-ef8f15e9.entry.js → p-f05cd056.entry.js} +2 -2
  662. package/dist/spw-stencil-library/{p-2ef45489.entry.js → p-fad06d00.entry.js} +2 -2
  663. package/dist/spw-stencil-library/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.esm.js.map +1 -1
  664. package/dist/spw-stencil-library/spw-breadcrumb-item.entry.esm.js.map +1 -1
  665. package/dist/spw-stencil-library/spw-breadcrumb.entry.esm.js.map +1 -1
  666. package/dist/spw-stencil-library/spw-date-picker.entry.esm.js.map +1 -1
  667. package/dist/spw-stencil-library/spw-hero.entry.esm.js.map +1 -1
  668. package/dist/spw-stencil-library/spw-illustration.entry.esm.js.map +1 -1
  669. package/dist/spw-stencil-library/spw-pagination.entry.esm.js.map +1 -1
  670. package/dist/spw-stencil-library/spw-slider.entry.esm.js.map +1 -1
  671. package/dist/spw-stencil-library/spw-stencil-library.css +1 -1
  672. package/dist/spw-stencil-library/spw-stencil-library.esm.js +1 -1
  673. package/dist/spw-stencil-library/spw-table-container.entry.esm.js.map +1 -0
  674. package/dist/spw-stencil-library/spw-table-footer.entry.esm.js.map +1 -1
  675. package/dist/spw-stencil-library/spw-table-header.entry.esm.js.map +1 -1
  676. package/dist/spw-stencil-library/spw-table-sidebar.entry.esm.js.map +1 -0
  677. package/dist/spw-stencil-library/spw-table.entry.esm.js.map +1 -1
  678. package/dist/spw-stencil-library/spw-textarea.entry.esm.js.map +1 -1
  679. package/dist/spw-stencil-library/spw-toc-container.entry.esm.js.map +1 -0
  680. package/dist/spw-stencil-library/spw-toc-navigation.entry.esm.js.map +1 -0
  681. package/dist/spw-stencil-library/spw-toc.entry.esm.js.map +1 -0
  682. package/dist/stats.json +2225 -592
  683. package/dist/types/components/spw-accordion/spw-accordion.d.ts +6 -0
  684. package/dist/types/components/spw-hero/spw-hero.d.ts +5 -1
  685. package/dist/types/components/spw-illustration/spw-illustration.d.ts +2 -0
  686. package/dist/types/components/spw-pagination/spw-pagination.d.ts +1 -0
  687. package/dist/types/components/spw-slider/spw-slider.d.ts +3 -0
  688. package/dist/types/components/spw-table/spw-table-container/spw-table-container.d.ts +3 -0
  689. package/dist/types/components/spw-table/spw-table-sidebar/spw-table-sidebar.d.ts +34 -0
  690. package/dist/types/components/spw-table/spw-table.d.ts +2 -0
  691. package/dist/types/components/spw-toc/spw-toc-container/spw-toc-container.d.ts +18 -0
  692. package/dist/types/components/spw-toc/spw-toc-navigation/spw-toc-navigation.d.ts +24 -0
  693. package/dist/types/components/spw-toc/spw-toc.d.ts +3 -0
  694. package/dist/types/components.d.ts +185 -2
  695. package/dist/types/stories/organisms/spw-toc/spw-toc.stories.d.ts +5 -0
  696. package/hydrate/index.js +1245 -134
  697. package/hydrate/index.mjs +1245 -134
  698. package/package.json +4 -4
  699. package/dist/components/p-C47wKUeG.js.map +0 -1
  700. package/dist/components/p-CFQbmE2_.js.map +0 -1
  701. package/dist/components/p-CQpGzRKu.js.map +0 -1
  702. package/dist/spw-stencil-library/p-1271e178.entry.js.map +0 -1
  703. package/dist/spw-stencil-library/p-33f33d6d.entry.js +0 -2
  704. package/dist/spw-stencil-library/p-33f33d6d.entry.js.map +0 -1
  705. package/dist/spw-stencil-library/p-5c745e85.entry.js +0 -2
  706. package/dist/spw-stencil-library/p-5c745e85.entry.js.map +0 -1
  707. package/dist/spw-stencil-library/p-71519d62.entry.js +0 -2
  708. package/dist/spw-stencil-library/p-71519d62.entry.js.map +0 -1
  709. package/dist/spw-stencil-library/p-98bddf34.entry.js +0 -2
  710. package/dist/spw-stencil-library/p-98bddf34.entry.js.map +0 -1
  711. package/dist/spw-stencil-library/p-aeec7eeb.entry.js.map +0 -1
  712. package/dist/spw-stencil-library/p-b8645217.entry.js +0 -2
  713. package/dist/spw-stencil-library/p-b8645217.entry.js.map +0 -1
  714. package/dist/spw-stencil-library/p-bf7cd8c9.entry.js +0 -2
  715. package/dist/spw-stencil-library/p-bf7cd8c9.entry.js.map +0 -1
  716. package/dist/spw-stencil-library/p-c43d3406.entry.js +0 -2
  717. package/dist/spw-stencil-library/p-c43d3406.entry.js.map +0 -1
  718. package/dist/spw-stencil-library/p-d02b077c.entry.js.map +0 -1
  719. /package/dist/spw-stencil-library/{p-4bc3d2ef.entry.js.map → p-04aa5d86.entry.js.map} +0 -0
  720. /package/dist/spw-stencil-library/{p-a2fd09f8.entry.js.map → p-0839efb1.entry.js.map} +0 -0
  721. /package/dist/spw-stencil-library/{p-84645c94.entry.js.map → p-0bc1209e.entry.js.map} +0 -0
  722. /package/dist/spw-stencil-library/{p-1644bf7d.entry.js.map → p-0e7f2c1a.entry.js.map} +0 -0
  723. /package/dist/spw-stencil-library/{p-670f0edc.entry.js.map → p-1306c0ff.entry.js.map} +0 -0
  724. /package/dist/spw-stencil-library/{p-ed61e2a8.entry.js.map → p-137f2856.entry.js.map} +0 -0
  725. /package/dist/spw-stencil-library/{p-5e0b04c0.entry.js.map → p-1bb4a071.entry.js.map} +0 -0
  726. /package/dist/spw-stencil-library/{p-eb26b450.entry.js.map → p-1c728c37.entry.js.map} +0 -0
  727. /package/dist/spw-stencil-library/{p-44bb3ec0.entry.js.map → p-20fa2637.entry.js.map} +0 -0
  728. /package/dist/spw-stencil-library/{p-2b70c24a.entry.js.map → p-2965d7ca.entry.js.map} +0 -0
  729. /package/dist/spw-stencil-library/{p-82ed2f9b.entry.js.map → p-29fb06a6.entry.js.map} +0 -0
  730. /package/dist/spw-stencil-library/{p-2760ef2b.entry.js.map → p-2d7492af.entry.js.map} +0 -0
  731. /package/dist/spw-stencil-library/{p-6c88a82d.entry.js.map → p-3067d3dd.entry.js.map} +0 -0
  732. /package/dist/spw-stencil-library/{p-e5f141b6.entry.js.map → p-31980405.entry.js.map} +0 -0
  733. /package/dist/spw-stencil-library/{p-9d0e8d02.entry.js.map → p-3553e1f1.entry.js.map} +0 -0
  734. /package/dist/spw-stencil-library/{p-cbf4ef91.entry.js.map → p-3c524edb.entry.js.map} +0 -0
  735. /package/dist/spw-stencil-library/{p-d37963e0.entry.js.map → p-420fd27d.entry.js.map} +0 -0
  736. /package/dist/spw-stencil-library/{p-87249c32.entry.js.map → p-460b4ede.entry.js.map} +0 -0
  737. /package/dist/spw-stencil-library/{p-c3f21e33.entry.js.map → p-47f6b942.entry.js.map} +0 -0
  738. /package/dist/spw-stencil-library/{p-f26fd3b1.entry.js.map → p-49227f48.entry.js.map} +0 -0
  739. /package/dist/spw-stencil-library/{p-a065a834.entry.js.map → p-4ab97219.entry.js.map} +0 -0
  740. /package/dist/spw-stencil-library/{p-3545f888.entry.js.map → p-5ba3deea.entry.js.map} +0 -0
  741. /package/dist/spw-stencil-library/{p-5e1aae61.entry.js.map → p-6c0993d6.entry.js.map} +0 -0
  742. /package/dist/spw-stencil-library/{p-95749696.entry.js.map → p-70ccb73f.entry.js.map} +0 -0
  743. /package/dist/spw-stencil-library/{p-6f084e62.entry.js.map → p-70f46bf2.entry.js.map} +0 -0
  744. /package/dist/spw-stencil-library/{p-b3e76f4c.entry.js.map → p-7214cc7b.entry.js.map} +0 -0
  745. /package/dist/spw-stencil-library/{p-0c3e8d91.entry.js.map → p-798bac47.entry.js.map} +0 -0
  746. /package/dist/spw-stencil-library/{p-a4111a43.entry.js.map → p-8483cd8b.entry.js.map} +0 -0
  747. /package/dist/spw-stencil-library/{p-931bea3a.entry.js.map → p-8c2f0377.entry.js.map} +0 -0
  748. /package/dist/spw-stencil-library/{p-e4e2cb61.entry.js.map → p-93bd4d23.entry.js.map} +0 -0
  749. /package/dist/spw-stencil-library/{p-25204236.entry.js.map → p-95ec862e.entry.js.map} +0 -0
  750. /package/dist/spw-stencil-library/{p-5adfcd7e.entry.js.map → p-9a3dcf80.entry.js.map} +0 -0
  751. /package/dist/spw-stencil-library/{p-6cdf16ac.entry.js.map → p-9d5deba6.entry.js.map} +0 -0
  752. /package/dist/spw-stencil-library/{p-d28a7068.entry.js.map → p-a264b181.entry.js.map} +0 -0
  753. /package/dist/spw-stencil-library/{p-95fa97a9.entry.js.map → p-aa4ddfa1.entry.js.map} +0 -0
  754. /package/dist/spw-stencil-library/{p-9dea2f39.entry.js.map → p-ad964a8e.entry.js.map} +0 -0
  755. /package/dist/spw-stencil-library/{p-08000970.entry.js.map → p-ada217d5.entry.js.map} +0 -0
  756. /package/dist/spw-stencil-library/{p-197a694e.entry.js.map → p-aed34c29.entry.js.map} +0 -0
  757. /package/dist/spw-stencil-library/{p-94069aff.entry.js.map → p-b4805c08.entry.js.map} +0 -0
  758. /package/dist/spw-stencil-library/{p-277bb102.entry.js.map → p-bb4c4e16.entry.js.map} +0 -0
  759. /package/dist/spw-stencil-library/{p-a5004a01.entry.js.map → p-bb7f1387.entry.js.map} +0 -0
  760. /package/dist/spw-stencil-library/{p-b4c2fdf2.entry.js.map → p-bcceb61b.entry.js.map} +0 -0
  761. /package/dist/spw-stencil-library/{p-68f93962.entry.js.map → p-bf070798.entry.js.map} +0 -0
  762. /package/dist/spw-stencil-library/{p-110ca863.entry.js.map → p-c02b7133.entry.js.map} +0 -0
  763. /package/dist/spw-stencil-library/{p-ca98ee5d.entry.js.map → p-c278daa3.entry.js.map} +0 -0
  764. /package/dist/spw-stencil-library/{p-428aa721.entry.js.map → p-c398550f.entry.js.map} +0 -0
  765. /package/dist/spw-stencil-library/{p-803b2bb5.entry.js.map → p-c77adac8.entry.js.map} +0 -0
  766. /package/dist/spw-stencil-library/{p-ea0cfe62.entry.js.map → p-cc3a84a1.entry.js.map} +0 -0
  767. /package/dist/spw-stencil-library/{p-91b264d1.entry.js.map → p-cc869e6f.entry.js.map} +0 -0
  768. /package/dist/spw-stencil-library/{p-a1d06611.entry.js.map → p-ccbc7c44.entry.js.map} +0 -0
  769. /package/dist/spw-stencil-library/{p-3ac699ae.entry.js.map → p-d18146ca.entry.js.map} +0 -0
  770. /package/dist/spw-stencil-library/{p-65aec904.entry.js.map → p-d2f5d210.entry.js.map} +0 -0
  771. /package/dist/spw-stencil-library/{p-bb2421dc.entry.js.map → p-d8cae37d.entry.js.map} +0 -0
  772. /package/dist/spw-stencil-library/{p-e2bac6be.entry.js.map → p-db817793.entry.js.map} +0 -0
  773. /package/dist/spw-stencil-library/{p-c3246505.entry.js.map → p-dbb7e719.entry.js.map} +0 -0
  774. /package/dist/spw-stencil-library/{p-df4d1f42.entry.js.map → p-de771d14.entry.js.map} +0 -0
  775. /package/dist/spw-stencil-library/{p-187d02cb.entry.js.map → p-e369abbb.entry.js.map} +0 -0
  776. /package/dist/spw-stencil-library/{p-67b7b947.entry.js.map → p-e44b8ebb.entry.js.map} +0 -0
  777. /package/dist/spw-stencil-library/{p-6461fb4b.entry.js.map → p-e78304f0.entry.js.map} +0 -0
  778. /package/dist/spw-stencil-library/{p-25aaf6a6.entry.js.map → p-ea5f2427.entry.js.map} +0 -0
  779. /package/dist/spw-stencil-library/{p-95891f3a.entry.js.map → p-ea952c66.entry.js.map} +0 -0
  780. /package/dist/spw-stencil-library/{p-22f022ca.entry.js.map → p-eaa1025a.entry.js.map} +0 -0
  781. /package/dist/spw-stencil-library/{p-ef8f15e9.entry.js.map → p-f05cd056.entry.js.map} +0 -0
  782. /package/dist/spw-stencil-library/{p-2ef45489.entry.js.map → p-fad06d00.entry.js.map} +0 -0
@@ -20,7 +20,28 @@ const meta = {
20
20
  component: `
21
21
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
22
22
 
23
- Affiche un aperçu de votre contenu avant le chargement des données pour réduire la frustration liée au temps de chargement.
23
+ Le composant Skeleton affiche un aperçu animé du contenu avant son chargement complet. Il améliore l'expérience utilisateur en réduisant la frustration liée aux temps d'attente et donne une indication visuelle de la structure à venir.
24
+
25
+ ## Variantes disponibles
26
+
27
+ - **text** : Lignes de texte avec variations de largeur
28
+ - **article** : Bloc article avec titre et paragraphes
29
+ - **layout** : Structure de page complète avec zones définies
30
+
31
+ ## Fonctionnalités
32
+
33
+ - Animation de pulsation (shimmer effect)
34
+ - Nombre de blocs configurable
35
+ - Hauteur personnalisable
36
+ - Intégrable dans cartes, listes et grilles
37
+ - Adaptation automatique à la largeur du conteneur
38
+
39
+ ## Cas d'usage
40
+
41
+ - Chargement de listes d'articles ou actualités
42
+ - Aperçu de cartes avant rendu du contenu
43
+ - Placeholder pour images en cours de chargement
44
+ - États de chargement de pages entières
24
45
 
25
46
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/54b742-squelette)
26
47
  `,
@@ -106,10 +127,38 @@ VarianteLayout.args = {
106
127
  };
107
128
  // Story pour toutes les variantes ensemble
108
129
  export const VarianteMosaique = VariantsTemplate.bind({});
130
+ Default.parameters = {
131
+ docs: {
132
+ description: {
133
+ story: `Skeleton par défaut avec 3 blocs. Version générique adaptable à différents types de contenu. Cas d'usage : placeholder simple, chargement de contenu court.`,
134
+ },
135
+ },
136
+ };
137
+ VarianteTexte.parameters = {
138
+ docs: {
139
+ description: {
140
+ story: `Skeleton variant text avec 5 lignes de texte. Largeurs variables pour simuler du texte naturel. Cas d'usage : chargement de paragraphes, aperçu de contenu textuel, descriptions.`,
141
+ },
142
+ },
143
+ };
144
+ VarianteArticle.parameters = {
145
+ docs: {
146
+ description: {
147
+ story: `Skeleton variant article avec structure titre + contenu. Simule un bloc article complet. Cas d'usage : chargement d'articles de blog, actualités, contenus éditoriaux.`,
148
+ },
149
+ },
150
+ };
151
+ VarianteLayout.parameters = {
152
+ docs: {
153
+ description: {
154
+ story: `Skeleton variant layout avec structure de page complète. Blocs multiples simulant header, sidebar et content. Cas d'usage : chargement de pages entières, dashboards, interfaces complexes.`,
155
+ },
156
+ },
157
+ };
109
158
  VarianteMosaique.parameters = {
110
159
  docs: {
111
160
  description: {
112
- story: "Il est également possible d'intégrer le composant dans une mosaïque pour afficher plusieurs squelettes sous forme de cartes.",
161
+ story: `Skeleton intégré dans une mosaïque de cartes. Démontre l'utilisation dans un contexte réel avec spw-mosaic et spw-card. Cas d'usage : galeries d'actualités, listes de produits, grilles de contenus à charger.`,
113
162
  },
114
163
  },
115
164
  };
@@ -1 +1 @@
1
- {"version":3,"file":"spw-skeleton.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-skeleton/spw-skeleton.stories.ts"],"names":[],"mappings":"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","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-skeleton';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Squelette (skeleton)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nAffiche un aperçu de votre contenu avant le chargement des données pour réduire la frustration liée au temps de chargement.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/54b742-squelette)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'label';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\n// Template pour les variantes complexes\nconst VariantsTemplate: StoryFn = () => {\n const container = document.createElement('div');\n container.innerHTML = /* HTML */ `\n <spw-mosaic is-masonry=\"true\" cols-desktop=\"3\" cols-tablet=\"2\" cols-mobile=\"1\">\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n </spw-mosaic>\n `;\n return container;\n};\n\n// Story par défaut\nexport const Default = Template.bind({});\nDefault.args = {\n blocks: 3,\n};\n\n// Story pour la variante texte\nexport const VarianteTexte = Template.bind({});\nVarianteTexte.args = {\n blocks: 5,\n variant: 'text',\n};\n\n// Story pour la variante article\nexport const VarianteArticle = Template.bind({});\nVarianteArticle.args = {\n blocks: 6,\n variant: 'article',\n};\n\n// Story pour la variante layout\nexport const VarianteLayout = Template.bind({});\nVarianteLayout.args = {\n blocks: 8,\n variant: 'layout',\n};\n\n// Story pour toutes les variantes ensemble\nexport const VarianteMosaique = VariantsTemplate.bind({});\nVarianteMosaique.parameters = {\n docs: {\n description: {\n story: \"Il est également possible d'intégrer le composant dans une mosaïque pour afficher plusieurs squelettes sous forme de cartes.\",\n },\n },\n};\n"]}
1
+ {"version":3,"file":"spw-skeleton.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-skeleton/spw-skeleton.stories.ts"],"names":[],"mappings":"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","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-skeleton';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Squelette (skeleton)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLe composant Skeleton affiche un aperçu animé du contenu avant son chargement complet. Il améliore l'expérience utilisateur en réduisant la frustration liée aux temps d'attente et donne une indication visuelle de la structure à venir.\n\n## Variantes disponibles\n\n- **text** : Lignes de texte avec variations de largeur\n- **article** : Bloc article avec titre et paragraphes\n- **layout** : Structure de page complète avec zones définies\n\n## Fonctionnalités\n\n- Animation de pulsation (shimmer effect)\n- Nombre de blocs configurable\n- Hauteur personnalisable\n- Intégrable dans cartes, listes et grilles\n- Adaptation automatique à la largeur du conteneur\n\n## Cas d'usage\n\n- Chargement de listes d'articles ou actualités\n- Aperçu de cartes avant rendu du contenu\n- Placeholder pour images en cours de chargement\n- États de chargement de pages entières\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/54b742-squelette)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'label';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\n// Template pour les variantes complexes\nconst VariantsTemplate: StoryFn = () => {\n const container = document.createElement('div');\n container.innerHTML = /* HTML */ `\n <spw-mosaic is-masonry=\"true\" cols-desktop=\"3\" cols-tablet=\"2\" cols-mobile=\"1\">\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n <spw-mosaic-item>\n <spw-card full-height=\"true\">\n <spw-card-content>\n <spw-skeleton blocks=\"8\" variant=\"article\"></spw-skeleton>\n </spw-card-content>\n </spw-card>\n </spw-mosaic-item>\n </spw-mosaic>\n `;\n return container;\n};\n\n// Story par défaut\nexport const Default = Template.bind({});\nDefault.args = {\n blocks: 3,\n};\n\n// Story pour la variante texte\nexport const VarianteTexte = Template.bind({});\nVarianteTexte.args = {\n blocks: 5,\n variant: 'text',\n};\n\n// Story pour la variante article\nexport const VarianteArticle = Template.bind({});\nVarianteArticle.args = {\n blocks: 6,\n variant: 'article',\n};\n\n// Story pour la variante layout\nexport const VarianteLayout = Template.bind({});\nVarianteLayout.args = {\n blocks: 8,\n variant: 'layout',\n};\n\n// Story pour toutes les variantes ensemble\nexport const VarianteMosaique = VariantsTemplate.bind({});\n\nDefault.parameters = {\n docs: {\n description: {\n story: `Skeleton par défaut avec 3 blocs. Version générique adaptable à différents types de contenu. Cas d'usage : placeholder simple, chargement de contenu court.`,\n },\n },\n};\n\nVarianteTexte.parameters = {\n docs: {\n description: {\n story: `Skeleton variant text avec 5 lignes de texte. Largeurs variables pour simuler du texte naturel. Cas d'usage : chargement de paragraphes, aperçu de contenu textuel, descriptions.`,\n },\n },\n};\n\nVarianteArticle.parameters = {\n docs: {\n description: {\n story: `Skeleton variant article avec structure titre + contenu. Simule un bloc article complet. Cas d'usage : chargement d'articles de blog, actualités, contenus éditoriaux.`,\n },\n },\n};\n\nVarianteLayout.parameters = {\n docs: {\n description: {\n story: `Skeleton variant layout avec structure de page complète. Blocs multiples simulant header, sidebar et content. Cas d'usage : chargement de pages entières, dashboards, interfaces complexes.`,\n },\n },\n};\n\nVarianteMosaique.parameters = {\n docs: {\n description: {\n story: `Skeleton intégré dans une mosaïque de cartes. Démontre l'utilisation dans un contexte réel avec spw-mosaic et spw-card. Cas d'usage : galeries d'actualités, listes de produits, grilles de contenus à charger.`,\n },\n },\n};\n"]}
@@ -20,7 +20,29 @@ const meta = {
20
20
  component: `
21
21
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
22
22
 
23
- Affiche discrètement des informations supplémentaires.
23
+ Le composant Tag permet d'afficher des étiquettes visuelles pour catégoriser, labelliser ou indiquer le statut d'un élément. Compact et discret, il attire l'attention sur des informations clés sans surcharger l'interface.
24
+
25
+ ## Variantes disponibles
26
+
27
+ - **default** : Tag par défaut avec fond gris clair
28
+ - **grey** : Variante grise neutre
29
+ - **blue** : Tag bleu pour informations générales
30
+ - **green** : Tag vert pour statuts positifs ou succès
31
+ - **orange** : Tag orange pour avertissements ou actions en attente
32
+ - **red** : Tag rouge pour erreurs ou statuts critiques
33
+ - **purple** : Tag violet pour catégories spécifiques
34
+
35
+ ## Fonctionnalités
36
+
37
+ - Plusieurs variantes de couleur pour différents contextes
38
+ - Deux tailles disponibles (small, medium)
39
+
40
+ ## Cas d'usage
41
+
42
+ - Affichage de statuts (en cours, validé, rejeté)
43
+ - Catégorisation de contenu (type de document, thématique)
44
+ - Labels informatifs dans cartes et listes
45
+ - Badges de notification ou compteurs
24
46
 
25
47
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/621ede-tag)
26
48
  `,
@@ -93,4 +115,53 @@ Purple.args = {
93
115
  size: 'small',
94
116
  content: 'Mon tag',
95
117
  };
118
+ Default.parameters = {
119
+ docs: {
120
+ description: {
121
+ story: `Tag par défaut avec fond gris clair. Utilisé pour des labels neutres ou génériques qui ne nécessitent pas de code couleur particulier.`,
122
+ },
123
+ },
124
+ };
125
+ Grey.parameters = {
126
+ docs: {
127
+ description: {
128
+ story: `Tag gris neutre. Alternative au variant default, utilisé pour des informations secondaires ou contextuelles.`,
129
+ },
130
+ },
131
+ };
132
+ Blue.parameters = {
133
+ docs: {
134
+ description: {
135
+ story: `Tag bleu pour informations générales. Cas d'usage : notifications informatives, catégories standards, labels d'aide.`,
136
+ },
137
+ },
138
+ };
139
+ Green.parameters = {
140
+ docs: {
141
+ description: {
142
+ story: `Tag vert pour statuts positifs. Cas d'usage : validé, actif, succès, disponible, en ligne.`,
143
+ },
144
+ },
145
+ };
146
+ Orange.parameters = {
147
+ docs: {
148
+ description: {
149
+ story: `Tag orange pour avertissements. Cas d'usage : en attente, à vérifier, attention requise, modéré.`,
150
+ },
151
+ },
152
+ };
153
+ Red.parameters = {
154
+ docs: {
155
+ description: {
156
+ story: `Tag rouge pour erreurs ou statuts critiques. Cas d'usage : rejeté, erreur, inactif, urgent, expiré.`,
157
+ },
158
+ },
159
+ };
160
+ Purple.parameters = {
161
+ docs: {
162
+ description: {
163
+ story: `Tag violet pour catégories spécifiques. Cas d'usage : nouveauté, premium, featured, catégorie spéciale.`,
164
+ },
165
+ },
166
+ };
96
167
  //# sourceMappingURL=spw-tag.stories.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"spw-tag.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-tag/spw-tag.stories.ts"],"names":[],"mappings":"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","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-tag';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Tag',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nAffiche discrètement des informations supplémentaires.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/621ede-tag)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = true;\n const slottedLabel = 'content';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n variant: 'default',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Grey = Template.bind({});\nGrey.args = {\n variant: 'grey',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Blue = Template.bind({});\nBlue.args = {\n variant: 'blue',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Green = Template.bind({});\nGreen.args = {\n variant: 'green',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Orange = Template.bind({});\nOrange.args = {\n variant: 'orange',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Red = Template.bind({});\nRed.args = {\n variant: 'red',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Purple = Template.bind({});\nPurple.args = {\n variant: 'purple',\n size: 'small',\n content: 'Mon tag',\n};\n"]}
1
+ {"version":3,"file":"spw-tag.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-tag/spw-tag.stories.ts"],"names":[],"mappings":"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","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-tag';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Tag',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLe composant Tag permet d'afficher des étiquettes visuelles pour catégoriser, labelliser ou indiquer le statut d'un élément. Compact et discret, il attire l'attention sur des informations clés sans surcharger l'interface.\n\n## Variantes disponibles\n\n- **default** : Tag par défaut avec fond gris clair\n- **grey** : Variante grise neutre\n- **blue** : Tag bleu pour informations générales\n- **green** : Tag vert pour statuts positifs ou succès\n- **orange** : Tag orange pour avertissements ou actions en attente\n- **red** : Tag rouge pour erreurs ou statuts critiques\n- **purple** : Tag violet pour catégories spécifiques\n\n## Fonctionnalités\n\n- Plusieurs variantes de couleur pour différents contextes\n- Deux tailles disponibles (small, medium)\n\n## Cas d'usage\n\n- Affichage de statuts (en cours, validé, rejeté)\n- Catégorisation de contenu (type de document, thématique)\n- Labels informatifs dans cartes et listes\n- Badges de notification ou compteurs\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/621ede-tag)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = true;\n const slottedLabel = 'content';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n variant: 'default',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Grey = Template.bind({});\nGrey.args = {\n variant: 'grey',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Blue = Template.bind({});\nBlue.args = {\n variant: 'blue',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Green = Template.bind({});\nGreen.args = {\n variant: 'green',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Orange = Template.bind({});\nOrange.args = {\n variant: 'orange',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Red = Template.bind({});\nRed.args = {\n variant: 'red',\n size: 'small',\n content: 'Mon tag',\n};\n\nexport const Purple = Template.bind({});\nPurple.args = {\n variant: 'purple',\n size: 'small',\n content: 'Mon tag',\n};\n\nDefault.parameters = {\n docs: {\n description: {\n story: `Tag par défaut avec fond gris clair. Utilisé pour des labels neutres ou génériques qui ne nécessitent pas de code couleur particulier.`,\n },\n },\n};\n\nGrey.parameters = {\n docs: {\n description: {\n story: `Tag gris neutre. Alternative au variant default, utilisé pour des informations secondaires ou contextuelles.`,\n },\n },\n};\n\nBlue.parameters = {\n docs: {\n description: {\n story: `Tag bleu pour informations générales. Cas d'usage : notifications informatives, catégories standards, labels d'aide.`,\n },\n },\n};\n\nGreen.parameters = {\n docs: {\n description: {\n story: `Tag vert pour statuts positifs. Cas d'usage : validé, actif, succès, disponible, en ligne.`,\n },\n },\n};\n\nOrange.parameters = {\n docs: {\n description: {\n story: `Tag orange pour avertissements. Cas d'usage : en attente, à vérifier, attention requise, modéré.`,\n },\n },\n};\n\nRed.parameters = {\n docs: {\n description: {\n story: `Tag rouge pour erreurs ou statuts critiques. Cas d'usage : rejeté, erreur, inactif, urgent, expiré.`,\n },\n },\n};\n\nPurple.parameters = {\n docs: {\n description: {\n story: `Tag violet pour catégories spécifiques. Cas d'usage : nouveauté, premium, featured, catégorie spéciale.`,\n },\n },\n};\n"]}
@@ -20,7 +20,33 @@ const meta = {
20
20
  component: `
21
21
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
22
22
 
23
- Permet aux utilisateurs dentrer du texte ou une valeur.
23
+ Le composant Text Field permet aux utilisateurs d'entrer du texte court sur une seule ligne. Élément fondamental des formulaires, il intègre label, placeholder, validation et messages d'aide.
24
+
25
+ ## Variantes disponibles
26
+
27
+ - **text** : Texte standard (par défaut)
28
+ - **email** : Validation d'adresse email
29
+ - **password** : Masquage du texte saisi
30
+ - **tel** : Numéro de téléphone
31
+ - **url** : Adresse web
32
+ - **number** : Valeur numérique
33
+
34
+ ## Fonctionnalités
35
+
36
+ - Label et placeholder configurables
37
+ - Texte d'assistance avec icône optionnelle
38
+ - États de validation (erreur, succès)
39
+ - Champ requis avec indicateur visuel
40
+ - Support de l'autocomplétion
41
+ - Largeur adaptative
42
+
43
+ ## Cas d'usage
44
+
45
+ - Saisie de nom, prénom, email
46
+ - Formulaires de contact et d'inscription
47
+ - Recherche et filtres
48
+ - Champs de connexion
49
+ - Saisie d'adresses et coordonnées
24
50
 
25
51
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/859851-champ-de-saisie-input-field)
26
52
  `,
@@ -60,4 +86,11 @@ Default.args = {
60
86
  required: true,
61
87
  showHintIcon: false,
62
88
  };
89
+ Default.parameters = {
90
+ docs: {
91
+ description: {
92
+ story: `Champ de saisie par défaut avec label, placeholder et texte d'assistance. Le champ est marqué comme requis avec l'astérisque. Cas d'usage : formulaires de contact, saisie de données personnelles, champs de recherche simples.`,
93
+ },
94
+ },
95
+ };
63
96
  //# sourceMappingURL=spw-text-field.stories.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"spw-text-field.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-text-field/spw-text-field.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,gBAAgB,CAAC;AAEpC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,yCAAyC;IAChD,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;SAMV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC;IACtB,MAAM,YAAY,GAAG,SAAS,CAAC;IAE/B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC;IAClF,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAElE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;QACxD,CAAC;aAAM,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,WAAW,EAAE,iBAAiB;IAC9B,KAAK,EAAE,WAAW;IAClB,IAAI,EAAE,OAAO;IACb,IAAI,EAAE,wBAAwB;IAC9B,QAAQ,EAAE,IAAI;IACd,YAAY,EAAE,KAAK;CACpB,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-text-field';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Champ de saisie (input text)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nPermet aux utilisateurs dentrer du texte ou une valeur.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/859851-champ-de-saisie-input-field)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'content';\n\n const controls = withComponentControls(componentsData, { tag: elementTag }) || {};\n const masterProps = controls.__realProps || Object.keys(controls);\n\n Object.entries(args).forEach(([key, val]) => {\n if (masterProps.includes(key)) {\n element.setAttribute(toKebabCase(key), val as string);\n } else if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n placeholder: 'Mon placeholder',\n label: 'Mon label',\n name: 'input',\n hint: \"Mon texte d'assistance\",\n required: true,\n showHintIcon: false,\n};\n"]}
1
+ {"version":3,"file":"spw-text-field.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-text-field/spw-text-field.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,gBAAgB,CAAC;AAEpC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,yCAAyC;IAChD,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAgCV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC;IACtB,MAAM,YAAY,GAAG,SAAS,CAAC;IAE/B,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC;IAClF,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAElE,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;QACxD,CAAC;aAAM,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,WAAW,EAAE,iBAAiB;IAC9B,KAAK,EAAE,WAAW;IAClB,IAAI,EAAE,OAAO;IACb,IAAI,EAAE,wBAAwB;IAC9B,QAAQ,EAAE,IAAI;IACd,YAAY,EAAE,KAAK;CACpB,CAAC;AAEF,OAAO,CAAC,UAAU,GAAG;IACnB,IAAI,EAAE;QACJ,WAAW,EAAE;YACX,KAAK,EAAE,kOAAkO;SAC1O;KACF;CACF,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-text-field';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Champ de saisie (input text)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLe composant Text Field permet aux utilisateurs d'entrer du texte court sur une seule ligne. Élément fondamental des formulaires, il intègre label, placeholder, validation et messages d'aide.\n\n## Variantes disponibles\n\n- **text** : Texte standard (par défaut)\n- **email** : Validation d'adresse email\n- **password** : Masquage du texte saisi\n- **tel** : Numéro de téléphone\n- **url** : Adresse web\n- **number** : Valeur numérique\n\n## Fonctionnalités\n\n- Label et placeholder configurables\n- Texte d'assistance avec icône optionnelle\n- États de validation (erreur, succès)\n- Champ requis avec indicateur visuel\n- Support de l'autocomplétion\n- Largeur adaptative\n\n## Cas d'usage\n\n- Saisie de nom, prénom, email\n- Formulaires de contact et d'inscription\n- Recherche et filtres\n- Champs de connexion\n- Saisie d'adresses et coordonnées\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/859851-champ-de-saisie-input-field)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'content';\n\n const controls = withComponentControls(componentsData, { tag: elementTag }) || {};\n const masterProps = controls.__realProps || Object.keys(controls);\n\n Object.entries(args).forEach(([key, val]) => {\n if (masterProps.includes(key)) {\n element.setAttribute(toKebabCase(key), val as string);\n } else if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n placeholder: 'Mon placeholder',\n label: 'Mon label',\n name: 'input',\n hint: \"Mon texte d'assistance\",\n required: true,\n showHintIcon: false,\n};\n\nDefault.parameters = {\n docs: {\n description: {\n story: `Champ de saisie par défaut avec label, placeholder et texte d'assistance. Le champ est marqué comme requis avec l'astérisque. Cas d'usage : formulaires de contact, saisie de données personnelles, champs de recherche simples.`,\n },\n },\n};\n"]}
@@ -20,7 +20,22 @@ const meta = {
20
20
  component: `
21
21
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
22
22
 
23
- Permet à l’utilisateur de taper du contenu plus long.
23
+ Le composant Textarea permet aux utilisateurs de saisir du texte long sur plusieurs lignes. Idéal pour les commentaires, descriptions et contenus étendus dans les formulaires.
24
+
25
+ ## Fonctionnalités
26
+
27
+ - Hauteur configurable (nombre de lignes)
28
+ - Label et placeholder
29
+ - Texte d'assistance avec icône
30
+ - États de validation (erreur, succès)
31
+
32
+ ## Cas d'usage
33
+
34
+ - Commentaires et remarques
35
+ - Messages dans formulaires de contact
36
+ - Contenu éditorial ou rédactionnel
37
+ - Feedback utilisateur et témoignages
38
+ - Notes et observations
24
39
 
25
40
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/6692b4-champ-texte-textarea)
26
41
  `,
@@ -1 +1 @@
1
- {"version":3,"file":"spw-textarea.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-textarea/spw-textarea.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,cAAc,CAAC;AAElC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,sCAAsC;IAC7C,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;SAMV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC;IACtB,MAAM,YAAY,GAAG,SAAS,CAAC;IAE/B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;gBACzB,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,WAAW,EAAE,iBAAiB;IAC9B,KAAK,EAAE,WAAW;IAClB,IAAI,EAAE,UAAU;IAChB,IAAI,EAAE,wBAAwB;IAC9B,QAAQ,EAAE,IAAI;IACd,YAAY,EAAE,KAAK;CACpB,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-textarea';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Champ de texte (textarea)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nPermet à l’utilisateur de taper du contenu plus long.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/6692b4-champ-texte-textarea)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'content';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n placeholder: 'Mon placeholder',\n label: 'Mon label',\n name: 'textarea',\n hint: \"Mon texte d'assistance\",\n required: true,\n showHintIcon: false,\n};\n"]}
1
+ {"version":3,"file":"spw-textarea.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-textarea/spw-textarea.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,cAAc,CAAC;AAElC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,sCAAsC;IAC7C,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;;;;;;;;;;;;;;;;SAqBV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC;IACtB,MAAM,YAAY,GAAG,SAAS,CAAC;IAE/B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;gBACzB,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,WAAW,EAAE,iBAAiB;IAC9B,KAAK,EAAE,WAAW;IAClB,IAAI,EAAE,UAAU;IAChB,IAAI,EAAE,wBAAwB;IAC9B,QAAQ,EAAE,IAAI;IACd,YAAY,EAAE,KAAK;CACpB,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-textarea';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Champ de texte (textarea)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLe composant Textarea permet aux utilisateurs de saisir du texte long sur plusieurs lignes. Idéal pour les commentaires, descriptions et contenus étendus dans les formulaires.\n\n## Fonctionnalités\n\n- Hauteur configurable (nombre de lignes)\n- Label et placeholder\n- Texte d'assistance avec icône\n- États de validation (erreur, succès)\n\n## Cas d'usage\n\n- Commentaires et remarques\n- Messages dans formulaires de contact\n- Contenu éditorial ou rédactionnel\n- Feedback utilisateur et témoignages\n- Notes et observations\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/6692b4-champ-texte-textarea)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = false;\n const slottedLabel = 'content';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n placeholder: 'Mon placeholder',\n label: 'Mon label',\n name: 'textarea',\n hint: \"Mon texte d'assistance\",\n required: true,\n showHintIcon: false,\n};\n"]}
@@ -20,7 +20,23 @@ const meta = {
20
20
  component: `
21
21
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
22
22
 
23
- Affiche des informations supplémentaires lorsque l'utilisateur survole un élément.
23
+ Le composant Tooltip affiche des informations contextuelles supplémentaires au survol d'un élément. Il permet de fournir des explications, des aides ou des précisions sans surcharger l'interface.
24
+
25
+ ## Fonctionnalités
26
+
27
+ - Affichage au survol
28
+ - Titre et contenu configurables
29
+ - Positionnement automatique
30
+ - Support de contenu HTML
31
+ - Accessibilité avec ARIA
32
+
33
+ ## Cas d'usage
34
+
35
+ - Aide contextuelle sur les champs de formulaire
36
+ - Explication de termes techniques ou d'abréviations
37
+ - Informations supplémentaires sur les icônes ou boutons
38
+ - Descriptions détaillées sans encombrer l'interface
39
+ - Aide à la complétion de formulaires complexes
24
40
 
25
41
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/748e85-infobulle-tooltip)
26
42
  `,
@@ -1 +1 @@
1
- {"version":3,"file":"spw-tooltip.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-tooltip/spw-tooltip.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,aAAa,CAAC;AAEjC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,gCAAgC;IACvC,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;SAMV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,IAAI,CAAC;IACrB,MAAM,YAAY,GAAG,OAAO,CAAC;IAE7B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;gBACzB,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,YAAY,EAAE,WAAW;IACzB,WAAW,EAAE,WAAW;IACxB,KAAK,EAAE,yBAAyB;CACjC,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-tooltip';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Infobulle (tooltip)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nAffiche des informations supplémentaires lorsque l'utilisateur survole un élément.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/748e85-infobulle-tooltip)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = true;\n const slottedLabel = 'label';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n tooltipTitle: 'Mon titre',\n tooltipText: 'Mon texte',\n label: 'Mon élément déclencheur',\n};\n"]}
1
+ {"version":3,"file":"spw-tooltip.stories.js","sourceRoot":"","sources":["../../../../src/stories/components/spw-tooltip/spw-tooltip.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAElE,MAAM,UAAU,GAAG,aAAa,CAAC;AAEjC,MAAM,QAAQ,GAAG,qBAAqB,CAAC,cAAc,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,CAAC;AAE5E,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,gCAAgC;IACvC,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;;;;;;;;;;;;;;;;;SAsBV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,IAAI;IACvB,OAAO,UAAU,CAAC,GAAG,IAAI,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,IAAI,CAAC;IACrB,MAAM,YAAY,GAAG,OAAO,CAAC;IAE7B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,KAAK,YAAY,EAAE,CAAC;gBACzB,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,GAAa,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,YAAY,EAAE,WAAW;IACzB,WAAW,EAAE,WAAW;IACxB,KAAK,EAAE,yBAAyB;CACjC,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, toKebabCase } from '@utils/utils';\n\nconst elementTag = 'spw-tooltip';\n\nconst argTypes = withComponentControls(componentsData, { tag: elementTag });\n\nconst meta: Meta = {\n title: 'Composants/Infobulle (tooltip)',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLe composant Tooltip affiche des informations contextuelles supplémentaires au survol d'un élément. Il permet de fournir des explications, des aides ou des précisions sans surcharger l'interface.\n\n## Fonctionnalités\n\n- Affichage au survol\n- Titre et contenu configurables\n- Positionnement automatique\n- Support de contenu HTML\n- Accessibilité avec ARIA\n\n## Cas d'usage\n\n- Aide contextuelle sur les champs de formulaire\n- Explication de termes techniques ou d'abréviations\n- Informations supplémentaires sur les icônes ou boutons\n- Descriptions détaillées sans encombrer l'interface\n- Aide à la complétion de formulaires complexes\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/748e85-infobulle-tooltip)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slot) {\n return /* HTML */ `${slot}`;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n const hasSlot = true;\n const slottedLabel = 'label';\n\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n } else {\n if (key !== slottedLabel) {\n element.setAttribute(toKebabCase(key), val as string);\n }\n }\n });\n\n if (hasSlot) {\n element.innerHTML = htmlContent(args[slottedLabel]);\n }\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n tooltipTitle: 'Mon titre',\n tooltipText: 'Mon texte',\n label: 'Mon élément déclencheur',\n};\n"]}
@@ -30,15 +30,28 @@ const meta = {
30
30
  argTypes,
31
31
  tags: ['autodocs'],
32
32
  parameters: {
33
- // status: {
34
- // type: 'aVenir',
35
- // },
36
33
  docs: {
37
34
  description: {
38
35
  component: `
39
36
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
40
37
 
41
- Les accordéons permettent aux utilisateurs d'afficher et de masquer des sections de contenu présentés dans une page.
38
+ Les accordéons permettent aux utilisateurs d'afficher et de masquer des sections de contenu présentés dans une page. Ils sont particulièrement utiles pour organiser de grandes quantités d'informations de manière compacte et améliorer la lisibilité du contenu.
39
+
40
+ ## Structure
41
+
42
+ Le composant se compose de trois parties :
43
+ - **spw-accordion** : Le conteneur principal qui englobe tous les items
44
+ - **spw-accordion-item** : Chaque élément pliable individuel
45
+ - **spw-accordion-title** : Le titre cliquable de chaque item
46
+ - **spw-accordion-content** : Le contenu qui s'affiche/se masque
47
+
48
+ ## Fonctionnalités
49
+
50
+ - Ouverture/fermeture animée des sections
51
+ - Possibilité d'avoir plusieurs items ouverts simultanément
52
+ - Support des icônes personnalisées pour chaque titre
53
+ - Accessibilité avec gestion du clavier et attributs ARIA
54
+ - Personnalisation du niveau de titre pour le SEO
42
55
 
43
56
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/054567-accordeon)
44
57
  `,
@@ -1 +1 @@
1
- {"version":3,"file":"spw-accordion.stories.js","sourceRoot":"","sources":["../../../../src/stories/organisms/spw-accordion/spw-accordion.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAEtE,MAAM,UAAU,GAAG,eAAe,CAAC;AAEnC,MAAM,gBAAgB,GAAG,CAAC,uBAAuB,EAAE,oBAAoB,EAAE,qBAAqB,CAAC,CAAC;AAEhG,MAAM,QAAQ,mCACT,qBAAqB,CAAC,cAAc,EAAE;IACvC,GAAG,EAAE,UAAU;IACf,kBAAkB;IAClB,MAAM;IACN,uCAAuC;IACvC,+DAA+D;IAC/D,4BAA4B;IAC5B,OAAO;IACP,MAAM;IACN,4CAA4C;IAC5C,4DAA4D;IAC5D,4BAA4B;IAC5B,OAAO;IACP,KAAK;CACN,CAAC,GACC,eAAe,CAAC,cAAc,EAAE,gBAAgB,CAAC,CACrD,CAAC;AAEF,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,sBAAsB;IAC7B,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,YAAY;QACZ,oBAAoB;QACpB,KAAK;QACL,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;SAMV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,QAAQ;IAC3B,OAAO,UAAU,CAAC;wCACoB,QAAQ,CAAC,WAAW;kCAC1B,QAAQ,CAAC,GAAG,WAAW,QAAQ,CAAC,IAAI;;;;;;;;;;kCAUpC,QAAQ,CAAC,GAAG,WAAW,QAAQ,CAAC,IAAI;;;;;;;;;GASnE,CAAC;AACJ,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAEnD,uCAAuC;IACvC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,yBAAyB;IACzB,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAEtC,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,IAAI,EAAE,SAAS;IACf,GAAG,EAAE,IAAI;IACT,WAAW,EAAE,IAAI;CAClB,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, extractArgTypes } from '@utils/utils';\n\nconst elementTag = 'spw-accordion';\n\nconst subComponentTags = ['spw-accordion-content', 'spw-accordion-item', 'spw-accordion-title'];\n\nconst argTypes = {\n ...withComponentControls(componentsData, {\n tag: elementTag,\n // customTokens: [\n // {\n // name: '--spw-accordion-padding',\n // description: 'Padding interne des items de l’accordéon',\n // defaultValue: '16px',\n // },\n // {\n // name: '--spw-accordion-border-color',\n // description: 'Couleur de la bordure entre les items',\n // defaultValue: '#ccc',\n // },\n // ],\n }),\n ...extractArgTypes(componentsData, subComponentTags),\n};\n\nconst meta: Meta = {\n title: 'Organismes/Accordéon',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n // status: {\n // type: 'aVenir',\n // },\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLes accordéons permettent aux utilisateurs d'afficher et de masquer des sections de contenu présentés dans une page.\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/054567-accordeon)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slotArgs) {\n return /* HTML */ `\n <spw-accordion-item default-open=\"${slotArgs.defaultOpen}\">\n <spw-accordion-title tag=\"${slotArgs.tag}\" icon=\"${slotArgs.icon}\" slot=\"title\">Titre avec icône</spw-accordion-title>\n <spw-accordion-content slot=\"content\">\n Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut vel imperdiet diam. Aliquam in quam nulla. Duis mi erat, tempus vitae tincidunt in, pretium ut diam. Ut\n malesuada ante et scelerisque eleifend. Curabitur luctus faucibus pretium. Praesent lacinia laoreet ipsum, at mattis magna cursus non. Pellentesque suscipit magna tellus,\n eu ullamcorper risus efficitur at. Donec eu tincidunt dolor. Suspendisse imperdiet, velit non tristique dignissim, sem est viverra arcu, eget malesuada felis massa eget\n sem. Nam sed felis eu sem suscipit sollicitudin volutpat vitae turpis. Sed quis facilisis magna, sed condimentum enim. Sed gravida est eget est dapibus rutrum. Suspendisse\n lacus leo, imperdiet et leo at, ultrices porta libero.\n </spw-accordion-content>\n </spw-accordion-item>\n <spw-accordion-item>\n <spw-accordion-title tag=\"${slotArgs.tag}\" icon=\"${slotArgs.icon}\" slot=\"title\">Titre avec icône</spw-accordion-title>\n <spw-accordion-content slot=\"content\">\n Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut vel imperdiet diam. Aliquam in quam nulla. Duis mi erat, tempus vitae tincidunt in, pretium ut diam. Ut\n malesuada ante et scelerisque eleifend. Curabitur luctus faucibus pretium. Praesent lacinia laoreet ipsum, at mattis magna cursus non. Pellentesque suscipit magna tellus,\n eu ullamcorper risus efficitur at. Donec eu tincidunt dolor. Suspendisse imperdiet, velit non tristique dignissim, sem est viverra arcu, eget malesuada felis massa eget\n sem. Nam sed felis eu sem suscipit sollicitudin volutpat vitae turpis. Sed quis facilisis magna, sed condimentum enim. Sed gravida est eget est dapibus rutrum. Suspendisse\n lacus leo, imperdiet et leo at, ultrices porta libero.\n </spw-accordion-content>\n </spw-accordion-item>\n `;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n\n // Apply properties to the main element\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n }\n });\n\n // Set inner HTML content\n element.innerHTML = htmlContent(args);\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n icon: 'fa-book',\n tag: 'h3',\n defaultOpen: true,\n};\n"]}
1
+ {"version":3,"file":"spw-accordion.stories.js","sourceRoot":"","sources":["../../../../src/stories/organisms/spw-accordion/spw-accordion.stories.ts"],"names":[],"mappings":"AAAA,IAAI,cAAmB,CAAC;AAExB,IAAI,CAAC;IACH,cAAc,GAAG,OAAO,CAAC,uCAAuC,CAAC,CAAC;AACpE,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IACpF,cAAc,GAAG,EAAE,CAAC;AACtB,CAAC;AAGD,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAEtE,MAAM,UAAU,GAAG,eAAe,CAAC;AAEnC,MAAM,gBAAgB,GAAG,CAAC,uBAAuB,EAAE,oBAAoB,EAAE,qBAAqB,CAAC,CAAC;AAEhG,MAAM,QAAQ,mCACT,qBAAqB,CAAC,cAAc,EAAE;IACvC,GAAG,EAAE,UAAU;IACf,kBAAkB;IAClB,MAAM;IACN,uCAAuC;IACvC,+DAA+D;IAC/D,4BAA4B;IAC5B,OAAO;IACP,MAAM;IACN,4CAA4C;IAC5C,4DAA4D;IAC5D,4BAA4B;IAC5B,OAAO;IACP,KAAK;CACN,CAAC,GACC,eAAe,CAAC,cAAc,EAAE,gBAAgB,CAAC,CACrD,CAAC;AAEF,MAAM,IAAI,GAAS;IACjB,KAAK,EAAE,sBAAsB;IAC7B,SAAS,EAAE,UAAU;IACrB,QAAQ;IACR,IAAI,EAAE,CAAC,UAAU,CAAC;IAClB,UAAU,EAAE;QACV,IAAI,EAAE;YACJ,WAAW,EAAE;gBACX,SAAS,EAAE;;;;;;;;;;;;;;;;;;;;;;SAsBV;aACF;SACF;KACF;CACF,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,SAAS,WAAW,CAAC,QAAQ;IAC3B,OAAO,UAAU,CAAC;wCACoB,QAAQ,CAAC,WAAW;kCAC1B,QAAQ,CAAC,GAAG,WAAW,QAAQ,CAAC,IAAI;;;;;;;;;;kCAUpC,QAAQ,CAAC,GAAG,WAAW,QAAQ,CAAC,IAAI;;;;;;;;;GASnE,CAAC;AACJ,CAAC;AAED,MAAM,QAAQ,GAAY,IAAI,CAAC,EAAE;IAC/B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAEnD,uCAAuC;IACvC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;QAC1C,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAChE,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,yBAAyB;IACzB,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;IAEtC,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AACzC,OAAO,CAAC,IAAI,GAAG;IACb,IAAI,EAAE,SAAS;IACf,GAAG,EAAE,IAAI;IACT,WAAW,EAAE,IAAI;CAClB,CAAC","sourcesContent":["let componentsData: any;\n\ntry {\n componentsData = require('../../../../dist/components_json.json');\n} catch (error) {\n console.warn('components_json.json non trouvé. Utilisation de valeurs par défaut.');\n componentsData = {};\n}\n\nimport { Meta, StoryFn } from '@storybook/web-components';\nimport { withComponentControls, extractArgTypes } from '@utils/utils';\n\nconst elementTag = 'spw-accordion';\n\nconst subComponentTags = ['spw-accordion-content', 'spw-accordion-item', 'spw-accordion-title'];\n\nconst argTypes = {\n ...withComponentControls(componentsData, {\n tag: elementTag,\n // customTokens: [\n // {\n // name: '--spw-accordion-padding',\n // description: 'Padding interne des items de l’accordéon',\n // defaultValue: '16px',\n // },\n // {\n // name: '--spw-accordion-border-color',\n // description: 'Couleur de la bordure entre les items',\n // defaultValue: '#ccc',\n // },\n // ],\n }),\n ...extractArgTypes(componentsData, subComponentTags),\n};\n\nconst meta: Meta = {\n title: 'Organismes/Accordéon',\n component: elementTag,\n argTypes,\n tags: ['autodocs'],\n parameters: {\n docs: {\n description: {\n component: `\n<strong class=\"mr-2\">Statut du composant :</strong> <spw-tag size=\"small\" variant=\"green\">Prêt</spw-tag>\n\nLes accordéons permettent aux utilisateurs d'afficher et de masquer des sections de contenu présentés dans une page. Ils sont particulièrement utiles pour organiser de grandes quantités d'informations de manière compacte et améliorer la lisibilité du contenu.\n\n## Structure\n\nLe composant se compose de trois parties :\n- **spw-accordion** : Le conteneur principal qui englobe tous les items\n- **spw-accordion-item** : Chaque élément pliable individuel\n- **spw-accordion-title** : Le titre cliquable de chaque item\n- **spw-accordion-content** : Le contenu qui s'affiche/se masque\n\n## Fonctionnalités\n\n- Ouverture/fermeture animée des sections\n- Possibilité d'avoir plusieurs items ouverts simultanément\n- Support des icônes personnalisées pour chaque titre\n- Accessibilité avec gestion du clavier et attributs ARIA\n- Personnalisation du niveau de titre pour le SEO\n\n[<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/054567-accordeon)\n `,\n },\n },\n },\n};\n\nexport default meta;\n\nfunction htmlContent(slotArgs) {\n return /* HTML */ `\n <spw-accordion-item default-open=\"${slotArgs.defaultOpen}\">\n <spw-accordion-title tag=\"${slotArgs.tag}\" icon=\"${slotArgs.icon}\" slot=\"title\">Titre avec icône</spw-accordion-title>\n <spw-accordion-content slot=\"content\">\n Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut vel imperdiet diam. Aliquam in quam nulla. Duis mi erat, tempus vitae tincidunt in, pretium ut diam. Ut\n malesuada ante et scelerisque eleifend. Curabitur luctus faucibus pretium. Praesent lacinia laoreet ipsum, at mattis magna cursus non. Pellentesque suscipit magna tellus,\n eu ullamcorper risus efficitur at. Donec eu tincidunt dolor. Suspendisse imperdiet, velit non tristique dignissim, sem est viverra arcu, eget malesuada felis massa eget\n sem. Nam sed felis eu sem suscipit sollicitudin volutpat vitae turpis. Sed quis facilisis magna, sed condimentum enim. Sed gravida est eget est dapibus rutrum. Suspendisse\n lacus leo, imperdiet et leo at, ultrices porta libero.\n </spw-accordion-content>\n </spw-accordion-item>\n <spw-accordion-item>\n <spw-accordion-title tag=\"${slotArgs.tag}\" icon=\"${slotArgs.icon}\" slot=\"title\">Titre avec icône</spw-accordion-title>\n <spw-accordion-content slot=\"content\">\n Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut vel imperdiet diam. Aliquam in quam nulla. Duis mi erat, tempus vitae tincidunt in, pretium ut diam. Ut\n malesuada ante et scelerisque eleifend. Curabitur luctus faucibus pretium. Praesent lacinia laoreet ipsum, at mattis magna cursus non. Pellentesque suscipit magna tellus,\n eu ullamcorper risus efficitur at. Donec eu tincidunt dolor. Suspendisse imperdiet, velit non tristique dignissim, sem est viverra arcu, eget malesuada felis massa eget\n sem. Nam sed felis eu sem suscipit sollicitudin volutpat vitae turpis. Sed quis facilisis magna, sed condimentum enim. Sed gravida est eget est dapibus rutrum. Suspendisse\n lacus leo, imperdiet et leo at, ultrices porta libero.\n </spw-accordion-content>\n </spw-accordion-item>\n `;\n}\n\nconst Template: StoryFn = args => {\n const element = document.createElement(elementTag);\n\n // Apply properties to the main element\n Object.entries(args).forEach(([key, val]) => {\n if (key.startsWith('on')) {\n element.addEventListener(key.substring(2).toLowerCase(), val);\n }\n });\n\n // Set inner HTML content\n element.innerHTML = htmlContent(args);\n\n return element;\n};\n\nexport const Default = Template.bind({});\nDefault.args = {\n icon: 'fa-book',\n tag: 'h3',\n defaultOpen: true,\n};\n"]}
@@ -24,7 +24,39 @@ const meta = {
24
24
  component: `
25
25
  <strong class="mr-2">Statut du composant :</strong> <spw-tag size="small" variant="green">Prêt</spw-tag>
26
26
 
27
- La carte est un lien vers une page éditoriale dont elle donne un aperçu. Elle fait généralement partie d'une liste d'aperçus de contenus similaires.
27
+ Le composant Carte est un conteneur cliquable qui affiche un aperçu visuel de contenu (article, événement, personne, vidéo). Il permet de présenter des informations de manière attrayante et structurée, souvent utilisé dans des listes ou grilles de contenus similaires.
28
+
29
+ ## Variants disponibles
30
+
31
+ - **Default / Horizontal** : Carte classique avec image à gauche, contenu à droite
32
+ - **Vertical** : Image en haut, contenu en dessous
33
+ - **Event** : Carte événement avec date et tags
34
+ - **Video** : Carte vidéo avec icône de lecture
35
+ - **Light** : Version allégée sans image, texte seul
36
+ - **Mini** : Version compacte pour sidebars
37
+ - **People** : Carte profil avec avatar rond
38
+ - **Sidebar** : Version pour barre latérale
39
+
40
+ ## Structure
41
+
42
+ Le composant se compose de plusieurs parties :
43
+ - **spw-card** : Conteneur principal avec la propriété href
44
+ - **spw-card-image** : Bloc image avec label optionnel
45
+ - **spw-card-content** : Conteneur du contenu textuel
46
+ - **spw-card-title** : Titre de la carte
47
+ - **spw-card-excerpt** : Description/extrait
48
+ - **spw-card-subtags** : Liste de sous-tags (liens ou tags)
49
+ - **spw-card-subtag-item** : Item de sous-tag individuel
50
+
51
+ ## Fonctionnalités
52
+
53
+ - Cartes entièrement cliquables
54
+ - Support des images avec labels
55
+ - Tags et catégories personnalisables
56
+ - Versions compactes pour sidebars
57
+ - Cartes profil avec affiliations
58
+ - Responsive design adaptatif
59
+ - Hover states et transitions fluides
28
60
 
29
61
  [<spw-link>Consulter la documentation</spw-link>](https://zeroheight.com/2310c7a1e/p/71f31e-carte-card)
30
62
  `,
@@ -280,4 +312,67 @@ PeopleWithAffiliates.args = {
280
312
  imgAlt: 'Image',
281
313
  imgSrc: 'https://images.unsplash.com/photo-1518020382113-a7e8fc38eac9?q=80&w=717&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D',
282
314
  };
315
+ Default.parameters = {
316
+ docs: {
317
+ description: {
318
+ story: `Carte horizontale par défaut avec image à gauche et contenu à droite. Affiche un tag, une date, un titre, un extrait et des sous-tags cliquables. Format idéal pour listes d'articles ou actualités.`,
319
+ },
320
+ },
321
+ };
322
+ WithoutImage.parameters = {
323
+ docs: {
324
+ description: {
325
+ story: `Carte sans image, contenu textuel uniquement. Utile lorsqu'aucune image pertinente n'est disponible ou pour varier la présentation dans une liste.`,
326
+ },
327
+ },
328
+ };
329
+ Light.parameters = {
330
+ docs: {
331
+ description: {
332
+ story: `Version allégée avec titre seul, sans image ni métadonnées. Parfaite pour des listes simples de liens ou menus de navigation secondaire.`,
333
+ },
334
+ },
335
+ };
336
+ Vertical.parameters = {
337
+ docs: {
338
+ description: {
339
+ story: `Carte verticale avec image en haut et contenu en dessous. Format populaire pour grilles d'articles, articles connexes ou publications. Idéale pour présentation en colonnes.`,
340
+ },
341
+ },
342
+ };
343
+ Event.parameters = {
344
+ docs: {
345
+ description: {
346
+ story: `Carte événement avec dates de début/fin visibles. Optimisée pour afficher des événements avec période définie.`,
347
+ },
348
+ },
349
+ };
350
+ Video.parameters = {
351
+ docs: {
352
+ description: {
353
+ story: `Carte vidéo avec icône de lecture superposée sur l'image. Signale clairement un contenu vidéo et invite au clic pour visionner.`,
354
+ },
355
+ },
356
+ };
357
+ Mini.parameters = {
358
+ docs: {
359
+ description: {
360
+ story: `Version compacte pour sidebar ou colonne latérale. Image réduite à gauche avec titre à droite, format économe en espace.`,
361
+ },
362
+ },
363
+ };
364
+ People.parameters = {
365
+ docs: {
366
+ description: {
367
+ story: `Carte profil avec avatar rond, nom, fonction, et coordonnées. Idéale pour annuaires, équipes, organigrammes ou pages de contact.`,
368
+ },
369
+ },
370
+ };
371
+ PeopleWithAffiliates.parameters = {
372
+ docs: {
373
+ description: {
374
+ story: `Carte profil enrichie avec affiliations/organisations associées. Permet de montrer les relations et appartenances d'une personne.`,
375
+ },
376
+ },
377
+ };
283
378
  //# sourceMappingURL=spw-card.stories.js.map