@spw-ds/spw-stencil-library 1.2.3 → 1.2.5

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 (724) hide show
  1. package/dist/cjs/{index-iVhYitTd.js → index-ivINMH9O.js} +5 -5
  2. package/dist/cjs/{index-iVhYitTd.js.map → index-ivINMH9O.js.map} +1 -1
  3. package/dist/cjs/loader.cjs.js +2 -2
  4. package/dist/cjs/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.cjs.js.map +1 -1
  5. package/dist/cjs/spw-accordion_4.cjs.entry.js +3 -3
  6. package/dist/cjs/spw-accordion_4.cjs.entry.js.map +1 -1
  7. package/dist/cjs/spw-breadcrumb-item.cjs.entry.js +1 -1
  8. package/dist/cjs/spw-breadcrumb.cjs.entry.js +1 -1
  9. package/dist/cjs/spw-button.spw-loading.entry.cjs.js.map +1 -1
  10. package/dist/cjs/spw-button_2.cjs.entry.js +6 -6
  11. package/dist/cjs/spw-button_2.cjs.entry.js.map +1 -1
  12. package/dist/cjs/spw-card-content.cjs.entry.js +2 -2
  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 +3 -3
  20. package/dist/cjs/spw-checkbox.cjs.entry.js.map +1 -1
  21. package/dist/cjs/spw-checkbox.entry.cjs.js.map +1 -1
  22. package/dist/cjs/spw-cookies.cjs.entry.js +1 -1
  23. package/dist/cjs/spw-custom-select.cjs.entry.js +63 -9
  24. package/dist/cjs/spw-custom-select.cjs.entry.js.map +1 -1
  25. package/dist/cjs/spw-custom-select.entry.cjs.js.map +1 -1
  26. package/dist/cjs/spw-date-picker.cjs.entry.js +222 -41
  27. package/dist/cjs/spw-date-picker.cjs.entry.js.map +1 -1
  28. package/dist/cjs/spw-date-picker.entry.cjs.js.map +1 -1
  29. package/dist/cjs/spw-dropdown-container.cjs.entry.js +20 -0
  30. package/dist/cjs/spw-dropdown-container.cjs.entry.js.map +1 -0
  31. package/dist/cjs/spw-dropdown-container.entry.cjs.js.map +1 -0
  32. package/dist/cjs/spw-dropdown-item.cjs.entry.js +87 -0
  33. package/dist/cjs/spw-dropdown-item.cjs.entry.js.map +1 -0
  34. package/dist/cjs/spw-dropdown-item.entry.cjs.js.map +1 -0
  35. package/dist/cjs/spw-dropdown.cjs.entry.js +2 -2
  36. package/dist/cjs/spw-dropdown.cjs.entry.js.map +1 -1
  37. package/dist/cjs/spw-dropdown.entry.cjs.js.map +1 -1
  38. package/dist/cjs/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.cjs.js.map +1 -1
  39. package/dist/cjs/spw-field-label_6.cjs.entry.js +8 -8
  40. package/dist/cjs/spw-field-label_6.cjs.entry.js.map +1 -1
  41. package/dist/cjs/spw-field-message.cjs.entry.js +2 -2
  42. package/dist/cjs/spw-file-upload.cjs.entry.js +6 -5
  43. package/dist/cjs/spw-file-upload.cjs.entry.js.map +1 -1
  44. package/dist/cjs/spw-file-upload.entry.cjs.js.map +1 -1
  45. package/dist/cjs/spw-footer-bottom.cjs.entry.js +2 -2
  46. package/dist/cjs/spw-footer-content-col.cjs.entry.js +2 -2
  47. package/dist/cjs/spw-footer-content.cjs.entry.js +2 -2
  48. package/dist/cjs/spw-footer-link.cjs.entry.js +2 -2
  49. package/dist/cjs/spw-footer.cjs.entry.js +2 -2
  50. package/dist/cjs/spw-header-lang-item.cjs.entry.js +2 -2
  51. package/dist/cjs/spw-header-lang.cjs.entry.js +2 -2
  52. package/dist/cjs/spw-header-navigation-dropdown.cjs.entry.js +2 -2
  53. package/dist/cjs/spw-header-navigation-item.cjs.entry.js +3 -3
  54. package/dist/cjs/spw-header-navigation.cjs.entry.js +2 -2
  55. package/dist/cjs/spw-header-persona-item.cjs.entry.js +2 -2
  56. package/dist/cjs/spw-header-persona.cjs.entry.js +2 -2
  57. package/dist/cjs/spw-header.cjs.entry.js +2 -2
  58. package/dist/cjs/spw-hero.cjs.entry.js +2 -2
  59. package/dist/cjs/spw-illustration.cjs.entry.js +1 -1
  60. package/dist/cjs/spw-iodda.cjs.entry.js +2 -2
  61. package/dist/cjs/spw-list-description.cjs.entry.js +2 -2
  62. package/dist/cjs/spw-list-item.cjs.entry.js +2 -2
  63. package/dist/cjs/spw-list-title.cjs.entry.js +2 -2
  64. package/dist/cjs/spw-list.cjs.entry.js +2 -2
  65. package/dist/cjs/spw-message.cjs.entry.js +1 -1
  66. package/dist/cjs/spw-modal.cjs.entry.js +4 -4
  67. package/dist/cjs/spw-mosaic-item.cjs.entry.js +2 -2
  68. package/dist/cjs/spw-mosaic.cjs.entry.js +2 -2
  69. package/dist/cjs/spw-pagination.cjs.entry.js +28 -18
  70. package/dist/cjs/spw-pagination.cjs.entry.js.map +1 -1
  71. package/dist/cjs/spw-pagination.entry.cjs.js.map +1 -1
  72. package/dist/cjs/spw-radio.cjs.entry.js +3 -3
  73. package/dist/cjs/spw-search-field.cjs.entry.js +13 -3
  74. package/dist/cjs/spw-search-field.cjs.entry.js.map +1 -1
  75. package/dist/cjs/spw-search-field.entry.cjs.js.map +1 -1
  76. package/dist/cjs/spw-select.cjs.entry.js +15 -3
  77. package/dist/cjs/spw-select.cjs.entry.js.map +1 -1
  78. package/dist/cjs/spw-select.entry.cjs.js.map +1 -1
  79. package/dist/cjs/spw-sidebar-navigation-dropdown.cjs.entry.js +2 -2
  80. package/dist/cjs/spw-sidebar-navigation-item.cjs.entry.js +85 -7
  81. package/dist/cjs/spw-sidebar-navigation-item.cjs.entry.js.map +1 -1
  82. package/dist/cjs/spw-sidebar-navigation-item.entry.cjs.js.map +1 -1
  83. package/dist/cjs/spw-sidebar-navigation-separator.cjs.entry.js +2 -2
  84. package/dist/cjs/spw-sidebar.cjs.entry.js +10 -2
  85. package/dist/cjs/spw-sidebar.cjs.entry.js.map +1 -1
  86. package/dist/cjs/spw-sidebar.entry.cjs.js.map +1 -1
  87. package/dist/cjs/spw-skeleton.cjs.entry.js +5 -3
  88. package/dist/cjs/spw-skeleton.cjs.entry.js.map +1 -1
  89. package/dist/cjs/spw-skeleton.entry.cjs.js.map +1 -1
  90. package/dist/cjs/spw-socials.cjs.entry.js +2 -2
  91. package/dist/cjs/spw-stencil-library.cjs.js +2 -2
  92. package/dist/cjs/spw-table-body.cjs.entry.js +2 -2
  93. package/dist/cjs/spw-table-cell.cjs.entry.js +54 -3
  94. package/dist/cjs/spw-table-cell.cjs.entry.js.map +1 -1
  95. package/dist/cjs/spw-table-cell.entry.cjs.js.map +1 -1
  96. package/dist/cjs/spw-table-footer.cjs.entry.js +3 -3
  97. package/dist/cjs/spw-table-footer.cjs.entry.js.map +1 -1
  98. package/dist/cjs/spw-table-footer.entry.cjs.js.map +1 -1
  99. package/dist/cjs/spw-table-head.cjs.entry.js +2 -2
  100. package/dist/cjs/spw-table-header.cjs.entry.js +35 -5
  101. package/dist/cjs/spw-table-header.cjs.entry.js.map +1 -1
  102. package/dist/cjs/spw-table-header.entry.cjs.js.map +1 -1
  103. package/dist/cjs/spw-table-row.cjs.entry.js +35 -3
  104. package/dist/cjs/spw-table-row.cjs.entry.js.map +1 -1
  105. package/dist/cjs/spw-table-row.entry.cjs.js.map +1 -1
  106. package/dist/cjs/spw-table.cjs.entry.js +70 -7
  107. package/dist/cjs/spw-table.cjs.entry.js.map +1 -1
  108. package/dist/cjs/spw-table.entry.cjs.js.map +1 -1
  109. package/dist/cjs/spw-tabs-content.cjs.entry.js +1 -1
  110. package/dist/cjs/spw-tabs-navigation-item.cjs.entry.js +3 -3
  111. package/dist/cjs/spw-tabs-navigation.cjs.entry.js +2 -2
  112. package/dist/cjs/spw-tabs.cjs.entry.js +6 -4
  113. package/dist/cjs/spw-tabs.cjs.entry.js.map +1 -1
  114. package/dist/cjs/spw-tabs.entry.cjs.js.map +1 -1
  115. package/dist/cjs/spw-tag.cjs.entry.js +2 -2
  116. package/dist/cjs/spw-text-field.cjs.entry.js +3 -3
  117. package/dist/cjs/spw-textarea.cjs.entry.js +3 -3
  118. package/dist/cjs/spw-tile-description.cjs.entry.js +2 -2
  119. package/dist/cjs/spw-tile-title.cjs.entry.js +2 -2
  120. package/dist/cjs/spw-tile.cjs.entry.js +2 -2
  121. package/dist/cjs/spw-tooltip.cjs.entry.js +2 -2
  122. package/dist/cjs/spw-topbar.cjs.entry.js +2 -2
  123. package/dist/cjs/spw-wizard-item.cjs.entry.js +64 -0
  124. package/dist/cjs/spw-wizard-item.cjs.entry.js.map +1 -0
  125. package/dist/cjs/spw-wizard-item.entry.cjs.js.map +1 -0
  126. package/dist/cjs/spw-wizard.cjs.entry.js +90 -0
  127. package/dist/cjs/spw-wizard.cjs.entry.js.map +1 -0
  128. package/dist/cjs/spw-wizard.entry.cjs.js.map +1 -0
  129. package/dist/cjs/{utils-CKYAw_Le.js → utils-D_vNTY6w.js} +3 -3
  130. package/dist/cjs/utils-D_vNTY6w.js.map +1 -0
  131. package/dist/collection/collection-manifest.json +5 -1
  132. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.css +1 -1
  133. package/dist/collection/components/spw-button/spw-button.css +1 -1
  134. package/dist/collection/components/spw-checkbox/spw-checkbox.css +1 -1
  135. package/dist/collection/components/spw-custom-select/spw-custom-select.css +1 -1
  136. package/dist/collection/components/spw-custom-select/spw-custom-select.js +81 -6
  137. package/dist/collection/components/spw-custom-select/spw-custom-select.js.map +1 -1
  138. package/dist/collection/components/spw-date-picker/spw-date-picker.css +1 -1
  139. package/dist/collection/components/spw-date-picker/spw-date-picker.js +267 -36
  140. package/dist/collection/components/spw-date-picker/spw-date-picker.js.map +1 -1
  141. package/dist/collection/components/spw-dropdown/spw-dropdown-container/spw-dropdown-container.css +2 -0
  142. package/dist/collection/components/spw-dropdown/spw-dropdown-container/spw-dropdown-container.js +19 -0
  143. package/dist/collection/components/spw-dropdown/spw-dropdown-container/spw-dropdown-container.js.map +1 -0
  144. package/dist/collection/components/spw-dropdown/spw-dropdown-item/spw-dropdown-item.css +2 -0
  145. package/dist/collection/components/spw-dropdown/spw-dropdown-item/spw-dropdown-item.js +175 -0
  146. package/dist/collection/components/spw-dropdown/spw-dropdown-item/spw-dropdown-item.js.map +1 -0
  147. package/dist/collection/components/spw-dropdown/spw-dropdown.js +2 -2
  148. package/dist/collection/components/spw-dropdown/spw-dropdown.js.map +1 -1
  149. package/dist/collection/components/spw-field-label/spw-field-label.js +1 -1
  150. package/dist/collection/components/spw-field-message/spw-field-message.js +1 -1
  151. package/dist/collection/components/spw-file-upload/spw-file-upload.js +3 -2
  152. package/dist/collection/components/spw-file-upload/spw-file-upload.js.map +1 -1
  153. package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js +1 -1
  154. package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js +1 -1
  155. package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js +1 -1
  156. package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js +1 -1
  157. package/dist/collection/components/spw-footer/spw-footer.js +1 -1
  158. package/dist/collection/components/spw-group/spw-group.js +1 -1
  159. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js +1 -1
  160. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js +1 -1
  161. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js +1 -1
  162. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js +1 -1
  163. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js +1 -1
  164. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js +1 -1
  165. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js +1 -1
  166. package/dist/collection/components/spw-header/spw-header.js +1 -1
  167. package/dist/collection/components/spw-hero/spw-hero.js +1 -1
  168. package/dist/collection/components/spw-iodda/spw-iodda.js +1 -1
  169. package/dist/collection/components/spw-link/spw-link.css +1 -1
  170. package/dist/collection/components/spw-link/spw-link.js +1 -1
  171. package/dist/collection/components/spw-list/spw-list-description/spw-list-description.js +1 -1
  172. package/dist/collection/components/spw-list/spw-list-item/spw-list-item.js +1 -1
  173. package/dist/collection/components/spw-list/spw-list-title/spw-list-title.js +1 -1
  174. package/dist/collection/components/spw-list/spw-list.js +1 -1
  175. package/dist/collection/components/spw-loading/spw-loading.js +1 -1
  176. package/dist/collection/components/spw-modal/spw-modal.js +1 -1
  177. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js +1 -1
  178. package/dist/collection/components/spw-mosaic/spw-mosaic.js +1 -1
  179. package/dist/collection/components/spw-pagination/spw-pagination.css +1 -1
  180. package/dist/collection/components/spw-pagination/spw-pagination.js +54 -13
  181. package/dist/collection/components/spw-pagination/spw-pagination.js.map +1 -1
  182. package/dist/collection/components/spw-radio/spw-radio.js +1 -1
  183. package/dist/collection/components/spw-search-field/spw-search-field.js +50 -2
  184. package/dist/collection/components/spw-search-field/spw-search-field.js.map +1 -1
  185. package/dist/collection/components/spw-select/spw-select.js +34 -1
  186. package/dist/collection/components/spw-select/spw-select.js.map +1 -1
  187. package/dist/collection/components/spw-separator/spw-separator.js +1 -1
  188. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-dropdown/spw-sidebar-navigation-dropdown.js +1 -1
  189. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.css +1 -1
  190. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.js +105 -6
  191. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.js.map +1 -1
  192. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-separator/spw-sidebar-navigation-separator.js +1 -1
  193. package/dist/collection/components/spw-sidebar/spw-sidebar.js +9 -1
  194. package/dist/collection/components/spw-sidebar/spw-sidebar.js.map +1 -1
  195. package/dist/collection/components/spw-skeleton/spw-skeleton.js +4 -2
  196. package/dist/collection/components/spw-skeleton/spw-skeleton.js.map +1 -1
  197. package/dist/collection/components/spw-socials/spw-socials.js +1 -1
  198. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js +1 -1
  199. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.css +1 -1
  200. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js +137 -1
  201. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js.map +1 -1
  202. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.css +1 -1
  203. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.js +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 +92 -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.css +1 -1
  209. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js +66 -1
  210. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js.map +1 -1
  211. package/dist/collection/components/spw-table/spw-table.css +1 -1
  212. package/dist/collection/components/spw-table/spw-table.js +135 -9
  213. package/dist/collection/components/spw-table/spw-table.js.map +1 -1
  214. package/dist/collection/components/spw-tabs/spw-tabs-navigation/spw-tabs-navigation.js +1 -1
  215. package/dist/collection/components/spw-tabs/spw-tabs-navigation-item/spw-tabs-navigation-item.js +1 -1
  216. package/dist/collection/components/spw-tabs/spw-tabs.js +6 -4
  217. package/dist/collection/components/spw-tabs/spw-tabs.js.map +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 +1 -1
  221. package/dist/collection/components/spw-theme-provider/spw-theme-provider.js +1 -1
  222. package/dist/collection/components/spw-tile/spw-tile-description/spw-tile-description.js +1 -1
  223. package/dist/collection/components/spw-tile/spw-tile-title/spw-tile-title.js +1 -1
  224. package/dist/collection/components/spw-tile/spw-tile.js +1 -1
  225. package/dist/collection/components/spw-tooltip/spw-tooltip.js +1 -1
  226. package/dist/collection/components/spw-topbar/spw-topbar.js +1 -1
  227. package/dist/collection/components/spw-wizard/spw-wizard-item/spw-wizard-item.css +2 -0
  228. package/dist/collection/components/spw-wizard/spw-wizard-item/spw-wizard-item.js +339 -0
  229. package/dist/collection/components/spw-wizard/spw-wizard-item/spw-wizard-item.js.map +1 -0
  230. package/dist/collection/components/spw-wizard/spw-wizard.css +2 -0
  231. package/dist/collection/components/spw-wizard/spw-wizard.js +192 -0
  232. package/dist/collection/components/spw-wizard/spw-wizard.js.map +1 -0
  233. package/dist/collection/stories/components/spw-date-picker/spw-date-picker.stories.js +46 -1
  234. package/dist/collection/stories/components/spw-date-picker/spw-date-picker.stories.js.map +1 -1
  235. package/dist/collection/stories/organisms/spw-footer/spw-footer.stories.js +1 -1
  236. package/dist/collection/stories/organisms/spw-footer/spw-footer.stories.js.map +1 -1
  237. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js +1 -1
  238. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js.map +1 -1
  239. package/dist/collection/stories/organisms/spw-table/spw-table.stories.js +119 -0
  240. package/dist/collection/stories/organisms/spw-table/spw-table.stories.js.map +1 -1
  241. package/dist/collection/stories/organisms/spw-wizard/spw-wizard.stories.js +208 -0
  242. package/dist/collection/stories/organisms/spw-wizard/spw-wizard.stories.js.map +1 -0
  243. package/dist/collection/utils/utils.js +48 -49
  244. package/dist/collection/utils/utils.js.map +1 -1
  245. package/dist/components/index.js +3 -3
  246. package/dist/components/index.js.map +1 -1
  247. package/dist/components/{p-DaosfSzT.js → p-B2toBmC2.js} +36 -25
  248. package/dist/components/p-B2toBmC2.js.map +1 -0
  249. package/dist/components/{p-zpG0udTn.js → p-BBi01mKM.js} +3 -3
  250. package/dist/components/p-BBi01mKM.js.map +1 -0
  251. package/dist/components/{p-DIhULKFM.js → p-Bvpi6byK.js} +3 -3
  252. package/dist/components/{p-DIhULKFM.js.map → p-Bvpi6byK.js.map} +1 -1
  253. package/dist/components/{p-fNRoK67L.js → p-CVuBJlFL.js} +3 -3
  254. package/dist/components/{p-fNRoK67L.js.map → p-CVuBJlFL.js.map} +1 -1
  255. package/dist/components/{p-B3OQ2nRI.js → p-D4PsQ_SH.js} +4 -4
  256. package/dist/components/p-D4PsQ_SH.js.map +1 -0
  257. package/dist/components/p-DHBpMBYT.js +129 -0
  258. package/dist/components/p-DHBpMBYT.js.map +1 -0
  259. package/dist/components/{p-B-sLKmnT.js → p-DjyPtAVX.js} +7 -7
  260. package/dist/components/p-DjyPtAVX.js.map +1 -0
  261. package/dist/components/{p-BDRCqK1w.js → p-J5AA2xQI.js} +3 -3
  262. package/dist/components/{p-BDRCqK1w.js.map → p-J5AA2xQI.js.map} +1 -1
  263. package/dist/components/{p-Dku0Cksp.js → p-_sdYD0eS.js} +6 -6
  264. package/dist/components/{p-Dku0Cksp.js.map → p-_sdYD0eS.js.map} +1 -1
  265. package/dist/components/{p-GUYao_6w.js → p-qROlK2WR.js} +5 -5
  266. package/dist/components/p-qROlK2WR.js.map +1 -0
  267. package/dist/components/{p-BF73GiQU.js → p-qgvllwX6.js} +3 -3
  268. package/dist/components/{p-BF73GiQU.js.map → p-qgvllwX6.js.map} +1 -1
  269. package/dist/components/{p-BowHA3gk.js → p-t1vZcpqC.js} +3 -3
  270. package/dist/components/{p-BowHA3gk.js.map → p-t1vZcpqC.js.map} +1 -1
  271. package/dist/components/spw-accordion-item.js +1 -1
  272. package/dist/components/spw-breadcrumb-item.js +1 -1
  273. package/dist/components/spw-button.js +1 -1
  274. package/dist/components/spw-card-content.js +1 -1
  275. package/dist/components/spw-checkbox.js +1 -1
  276. package/dist/components/spw-cookies.js +4 -4
  277. package/dist/components/spw-custom-select.js +67 -12
  278. package/dist/components/spw-custom-select.js.map +1 -1
  279. package/dist/components/spw-date-picker.js +230 -45
  280. package/dist/components/spw-date-picker.js.map +1 -1
  281. package/dist/components/spw-dropdown-container.d.ts +11 -0
  282. package/dist/components/spw-dropdown-container.js +36 -0
  283. package/dist/components/spw-dropdown-container.js.map +1 -0
  284. package/dist/components/spw-dropdown-item.d.ts +11 -0
  285. package/dist/components/spw-dropdown-item.js +115 -0
  286. package/dist/components/spw-dropdown-item.js.map +1 -0
  287. package/dist/components/spw-dropdown.js +1 -1
  288. package/dist/components/spw-dropdown.js.map +1 -1
  289. package/dist/components/spw-field-label.js +1 -1
  290. package/dist/components/spw-field-message.js +1 -1
  291. package/dist/components/spw-file-upload.js +7 -6
  292. package/dist/components/spw-file-upload.js.map +1 -1
  293. package/dist/components/spw-footer-bottom.js +1 -1
  294. package/dist/components/spw-footer-content-col.js +1 -1
  295. package/dist/components/spw-footer-content.js +1 -1
  296. package/dist/components/spw-footer-link.js +1 -1
  297. package/dist/components/spw-footer.js +1 -1
  298. package/dist/components/spw-group.js +2 -2
  299. package/dist/components/spw-header-lang-item.js +1 -1
  300. package/dist/components/spw-header-lang.js +3 -3
  301. package/dist/components/spw-header-navigation-dropdown.js +1 -1
  302. package/dist/components/spw-header-navigation-item.js +2 -2
  303. package/dist/components/spw-header-navigation.js +1 -1
  304. package/dist/components/spw-header-persona-item.js +1 -1
  305. package/dist/components/spw-header-persona.js +1 -1
  306. package/dist/components/spw-header.js +3 -3
  307. package/dist/components/spw-hero.js +1 -1
  308. package/dist/components/spw-iodda.js +6 -6
  309. package/dist/components/spw-link.js +1 -1
  310. package/dist/components/spw-list-description.js +1 -1
  311. package/dist/components/spw-list-item.js +1 -1
  312. package/dist/components/spw-list-title.js +1 -1
  313. package/dist/components/spw-list.js +1 -1
  314. package/dist/components/spw-loading.js +1 -1
  315. package/dist/components/spw-message.js +1 -1
  316. package/dist/components/spw-modal.js +3 -3
  317. package/dist/components/spw-mosaic-item.js +1 -1
  318. package/dist/components/spw-mosaic.js +1 -1
  319. package/dist/components/spw-pagination.js +1 -1
  320. package/dist/components/spw-radio.js +2 -2
  321. package/dist/components/spw-search-field.js +18 -7
  322. package/dist/components/spw-search-field.js.map +1 -1
  323. package/dist/components/spw-select.js +18 -5
  324. package/dist/components/spw-select.js.map +1 -1
  325. package/dist/components/spw-separator.js +1 -1
  326. package/dist/components/spw-sidebar-navigation-dropdown.js +1 -1
  327. package/dist/components/spw-sidebar-navigation-item.js +88 -8
  328. package/dist/components/spw-sidebar-navigation-item.js.map +1 -1
  329. package/dist/components/spw-sidebar-navigation-separator.js +2 -2
  330. package/dist/components/spw-sidebar.js +9 -1
  331. package/dist/components/spw-sidebar.js.map +1 -1
  332. package/dist/components/spw-skeleton.js +4 -2
  333. package/dist/components/spw-skeleton.js.map +1 -1
  334. package/dist/components/spw-socials.js +1 -1
  335. package/dist/components/spw-table-body.js +1 -1
  336. package/dist/components/spw-table-cell.js +59 -3
  337. package/dist/components/spw-table-cell.js.map +1 -1
  338. package/dist/components/spw-table-footer.js +2 -2
  339. package/dist/components/spw-table-footer.js.map +1 -1
  340. package/dist/components/spw-table-head.js +1 -1
  341. package/dist/components/spw-table-header.js +39 -6
  342. package/dist/components/spw-table-header.js.map +1 -1
  343. package/dist/components/spw-table-row.js +39 -3
  344. package/dist/components/spw-table-row.js.map +1 -1
  345. package/dist/components/spw-table.js +76 -8
  346. package/dist/components/spw-table.js.map +1 -1
  347. package/dist/components/spw-tabs-navigation-item.js +3 -3
  348. package/dist/components/spw-tabs-navigation.js +1 -1
  349. package/dist/components/spw-tabs.js +5 -3
  350. package/dist/components/spw-tabs.js.map +1 -1
  351. package/dist/components/spw-tag.js +1 -1
  352. package/dist/components/spw-text-field.js +1 -1
  353. package/dist/components/spw-textarea.js +4 -4
  354. package/dist/components/spw-theme-provider.js +1 -1
  355. package/dist/components/spw-tile-description.js +1 -1
  356. package/dist/components/spw-tile-title.js +1 -1
  357. package/dist/components/spw-tile.js +1 -1
  358. package/dist/components/spw-tooltip.js +1 -1
  359. package/dist/components/spw-topbar.js +1 -1
  360. package/dist/components/spw-wizard-item.d.ts +11 -0
  361. package/dist/components/spw-wizard-item.js +100 -0
  362. package/dist/components/spw-wizard-item.js.map +1 -0
  363. package/dist/components/spw-wizard.d.ts +11 -0
  364. package/dist/components/spw-wizard.js +110 -0
  365. package/dist/components/spw-wizard.js.map +1 -0
  366. package/dist/components_json.json +1214 -29
  367. package/dist/components_vscode.json +3088 -0
  368. package/dist/esm/{index-BYM_CUUH.js → index-CvfVJV8a.js} +5 -5
  369. package/dist/esm/{index-BYM_CUUH.js.map → index-CvfVJV8a.js.map} +1 -1
  370. package/dist/esm/loader.js +3 -3
  371. package/dist/esm/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.js.map +1 -1
  372. package/dist/esm/spw-accordion_4.entry.js +3 -3
  373. package/dist/esm/spw-accordion_4.entry.js.map +1 -1
  374. package/dist/esm/spw-breadcrumb-item.entry.js +1 -1
  375. package/dist/esm/spw-breadcrumb.entry.js +1 -1
  376. package/dist/esm/spw-button.spw-loading.entry.js.map +1 -1
  377. package/dist/esm/spw-button_2.entry.js +6 -6
  378. package/dist/esm/spw-button_2.entry.js.map +1 -1
  379. package/dist/esm/spw-card-content.entry.js +2 -2
  380. package/dist/esm/spw-card-excerpt.entry.js +1 -1
  381. package/dist/esm/spw-card-image.entry.js +1 -1
  382. package/dist/esm/spw-card-subtag-item.entry.js +1 -1
  383. package/dist/esm/spw-card-subtags.entry.js +1 -1
  384. package/dist/esm/spw-card-title.entry.js +1 -1
  385. package/dist/esm/spw-card.entry.js +1 -1
  386. package/dist/esm/spw-checkbox.entry.js +3 -3
  387. package/dist/esm/spw-checkbox.entry.js.map +1 -1
  388. package/dist/esm/spw-cookies.entry.js +1 -1
  389. package/dist/esm/spw-custom-select.entry.js +63 -9
  390. package/dist/esm/spw-custom-select.entry.js.map +1 -1
  391. package/dist/esm/spw-date-picker.entry.js +222 -41
  392. package/dist/esm/spw-date-picker.entry.js.map +1 -1
  393. package/dist/esm/spw-dropdown-container.entry.js +18 -0
  394. package/dist/esm/spw-dropdown-container.entry.js.map +1 -0
  395. package/dist/esm/spw-dropdown-item.entry.js +85 -0
  396. package/dist/esm/spw-dropdown-item.entry.js.map +1 -0
  397. package/dist/esm/spw-dropdown.entry.js +2 -2
  398. package/dist/esm/spw-dropdown.entry.js.map +1 -1
  399. package/dist/esm/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.js.map +1 -1
  400. package/dist/esm/spw-field-label_6.entry.js +8 -8
  401. package/dist/esm/spw-field-label_6.entry.js.map +1 -1
  402. package/dist/esm/spw-field-message.entry.js +2 -2
  403. package/dist/esm/spw-file-upload.entry.js +6 -5
  404. package/dist/esm/spw-file-upload.entry.js.map +1 -1
  405. package/dist/esm/spw-footer-bottom.entry.js +2 -2
  406. package/dist/esm/spw-footer-content-col.entry.js +2 -2
  407. package/dist/esm/spw-footer-content.entry.js +2 -2
  408. package/dist/esm/spw-footer-link.entry.js +2 -2
  409. package/dist/esm/spw-footer.entry.js +2 -2
  410. package/dist/esm/spw-header-lang-item.entry.js +2 -2
  411. package/dist/esm/spw-header-lang.entry.js +2 -2
  412. package/dist/esm/spw-header-navigation-dropdown.entry.js +2 -2
  413. package/dist/esm/spw-header-navigation-item.entry.js +3 -3
  414. package/dist/esm/spw-header-navigation.entry.js +2 -2
  415. package/dist/esm/spw-header-persona-item.entry.js +2 -2
  416. package/dist/esm/spw-header-persona.entry.js +2 -2
  417. package/dist/esm/spw-header.entry.js +2 -2
  418. package/dist/esm/spw-hero.entry.js +2 -2
  419. package/dist/esm/spw-illustration.entry.js +1 -1
  420. package/dist/esm/spw-iodda.entry.js +2 -2
  421. package/dist/esm/spw-list-description.entry.js +2 -2
  422. package/dist/esm/spw-list-item.entry.js +2 -2
  423. package/dist/esm/spw-list-title.entry.js +2 -2
  424. package/dist/esm/spw-list.entry.js +2 -2
  425. package/dist/esm/spw-message.entry.js +1 -1
  426. package/dist/esm/spw-modal.entry.js +4 -4
  427. package/dist/esm/spw-mosaic-item.entry.js +2 -2
  428. package/dist/esm/spw-mosaic.entry.js +2 -2
  429. package/dist/esm/spw-pagination.entry.js +28 -18
  430. package/dist/esm/spw-pagination.entry.js.map +1 -1
  431. package/dist/esm/spw-radio.entry.js +3 -3
  432. package/dist/esm/spw-search-field.entry.js +13 -3
  433. package/dist/esm/spw-search-field.entry.js.map +1 -1
  434. package/dist/esm/spw-select.entry.js +15 -3
  435. package/dist/esm/spw-select.entry.js.map +1 -1
  436. package/dist/esm/spw-sidebar-navigation-dropdown.entry.js +2 -2
  437. package/dist/esm/spw-sidebar-navigation-item.entry.js +85 -7
  438. package/dist/esm/spw-sidebar-navigation-item.entry.js.map +1 -1
  439. package/dist/esm/spw-sidebar-navigation-separator.entry.js +2 -2
  440. package/dist/esm/spw-sidebar.entry.js +10 -2
  441. package/dist/esm/spw-sidebar.entry.js.map +1 -1
  442. package/dist/esm/spw-skeleton.entry.js +5 -3
  443. package/dist/esm/spw-skeleton.entry.js.map +1 -1
  444. package/dist/esm/spw-socials.entry.js +2 -2
  445. package/dist/esm/spw-stencil-library.js +3 -3
  446. package/dist/esm/spw-table-body.entry.js +2 -2
  447. package/dist/esm/spw-table-cell.entry.js +54 -3
  448. package/dist/esm/spw-table-cell.entry.js.map +1 -1
  449. package/dist/esm/spw-table-footer.entry.js +3 -3
  450. package/dist/esm/spw-table-footer.entry.js.map +1 -1
  451. package/dist/esm/spw-table-head.entry.js +2 -2
  452. package/dist/esm/spw-table-header.entry.js +35 -5
  453. package/dist/esm/spw-table-header.entry.js.map +1 -1
  454. package/dist/esm/spw-table-row.entry.js +35 -3
  455. package/dist/esm/spw-table-row.entry.js.map +1 -1
  456. package/dist/esm/spw-table.entry.js +70 -7
  457. package/dist/esm/spw-table.entry.js.map +1 -1
  458. package/dist/esm/spw-tabs-content.entry.js +1 -1
  459. package/dist/esm/spw-tabs-navigation-item.entry.js +3 -3
  460. package/dist/esm/spw-tabs-navigation.entry.js +2 -2
  461. package/dist/esm/spw-tabs.entry.js +6 -4
  462. package/dist/esm/spw-tabs.entry.js.map +1 -1
  463. package/dist/esm/spw-tag.entry.js +2 -2
  464. package/dist/esm/spw-text-field.entry.js +3 -3
  465. package/dist/esm/spw-textarea.entry.js +3 -3
  466. package/dist/esm/spw-tile-description.entry.js +2 -2
  467. package/dist/esm/spw-tile-title.entry.js +2 -2
  468. package/dist/esm/spw-tile.entry.js +2 -2
  469. package/dist/esm/spw-tooltip.entry.js +2 -2
  470. package/dist/esm/spw-topbar.entry.js +2 -2
  471. package/dist/esm/spw-wizard-item.entry.js +62 -0
  472. package/dist/esm/spw-wizard-item.entry.js.map +1 -0
  473. package/dist/esm/spw-wizard.entry.js +88 -0
  474. package/dist/esm/spw-wizard.entry.js.map +1 -0
  475. package/dist/esm/{utils-zpG0udTn.js → utils-BBi01mKM.js} +3 -3
  476. package/dist/esm/utils-BBi01mKM.js.map +1 -0
  477. package/dist/spw-stencil-library/{p-e2f03a02.entry.js → p-000f04a1.entry.js} +2 -2
  478. package/dist/spw-stencil-library/{p-e2f03a02.entry.js.map → p-000f04a1.entry.js.map} +1 -1
  479. package/dist/spw-stencil-library/{p-f5de314e.entry.js → p-06cb6865.entry.js} +2 -2
  480. package/dist/spw-stencil-library/{p-52c51ac5.entry.js → p-06ec3521.entry.js} +2 -2
  481. package/dist/spw-stencil-library/{p-0226ad72.entry.js → p-0baeea00.entry.js} +2 -2
  482. package/dist/spw-stencil-library/p-0e1ec1e6.entry.js +2 -0
  483. package/dist/spw-stencil-library/p-0e1ec1e6.entry.js.map +1 -0
  484. package/dist/spw-stencil-library/p-0f69442e.entry.js +2 -0
  485. package/dist/spw-stencil-library/p-0f69442e.entry.js.map +1 -0
  486. package/dist/spw-stencil-library/p-14722019.entry.js +2 -0
  487. package/dist/spw-stencil-library/p-14722019.entry.js.map +1 -0
  488. package/dist/spw-stencil-library/p-152525de.entry.js +2 -0
  489. package/dist/spw-stencil-library/p-152525de.entry.js.map +1 -0
  490. package/dist/spw-stencil-library/{p-fbe468de.entry.js → p-2113f2f6.entry.js} +2 -2
  491. package/dist/spw-stencil-library/{p-181ae002.entry.js → p-25329033.entry.js} +2 -2
  492. package/dist/spw-stencil-library/{p-9219fe7c.entry.js → p-2abc48ed.entry.js} +2 -2
  493. package/dist/spw-stencil-library/p-2ad00dfc.entry.js +2 -0
  494. package/dist/spw-stencil-library/p-2ad00dfc.entry.js.map +1 -0
  495. package/dist/spw-stencil-library/{p-3ab472db.entry.js → p-2b011668.entry.js} +2 -2
  496. package/dist/spw-stencil-library/{p-272dc0ee.entry.js → p-2c79bd06.entry.js} +2 -2
  497. package/dist/spw-stencil-library/{p-272dc0ee.entry.js.map → p-2c79bd06.entry.js.map} +1 -1
  498. package/dist/spw-stencil-library/{p-b0dc1073.entry.js → p-2cfb78fb.entry.js} +2 -2
  499. package/dist/spw-stencil-library/{p-c2de4206.entry.js → p-2d974226.entry.js} +2 -2
  500. package/dist/spw-stencil-library/{p-19a69f36.entry.js → p-300b4bdb.entry.js} +2 -2
  501. package/dist/spw-stencil-library/{p-19a69f36.entry.js.map → p-300b4bdb.entry.js.map} +1 -1
  502. package/dist/spw-stencil-library/{p-cb269271.entry.js → p-32fd509b.entry.js} +2 -2
  503. package/dist/spw-stencil-library/{p-02151d7e.entry.js → p-438f1793.entry.js} +2 -2
  504. package/dist/spw-stencil-library/{p-1f382434.entry.js → p-451a9785.entry.js} +2 -2
  505. package/dist/spw-stencil-library/{p-4d61f200.entry.js → p-45d99a2b.entry.js} +2 -2
  506. package/dist/spw-stencil-library/{p-a93f21f9.entry.js → p-46567994.entry.js} +2 -2
  507. package/dist/spw-stencil-library/{p-2fd3eb76.entry.js → p-48417d99.entry.js} +2 -2
  508. package/dist/spw-stencil-library/{p-dd4bf12d.entry.js → p-488c2d88.entry.js} +2 -2
  509. package/dist/spw-stencil-library/p-4a273848.entry.js +2 -0
  510. package/dist/spw-stencil-library/p-4a273848.entry.js.map +1 -0
  511. package/dist/spw-stencil-library/{p-08d78730.entry.js → p-4e1774df.entry.js} +2 -2
  512. package/dist/spw-stencil-library/{p-a30563ff.entry.js → p-512a2787.entry.js} +2 -2
  513. package/dist/spw-stencil-library/{p-5f82570e.entry.js → p-5632f307.entry.js} +2 -2
  514. package/dist/spw-stencil-library/p-5632f307.entry.js.map +1 -0
  515. package/dist/spw-stencil-library/{p-04274072.entry.js → p-5a1b3ad1.entry.js} +3 -3
  516. package/dist/spw-stencil-library/{p-c838e17b.entry.js → p-5e34ea9d.entry.js} +2 -2
  517. package/dist/spw-stencil-library/{p-64670b2e.entry.js → p-5e43e2ed.entry.js} +2 -2
  518. package/dist/spw-stencil-library/p-5e43e2ed.entry.js.map +1 -0
  519. package/dist/spw-stencil-library/{p-74b4aea0.entry.js → p-5f873b56.entry.js} +2 -2
  520. package/dist/spw-stencil-library/{p-cff5a7e4.entry.js → p-5fde9dae.entry.js} +2 -2
  521. package/dist/spw-stencil-library/{p-09a2d080.entry.js → p-63d1c97f.entry.js} +2 -2
  522. package/dist/spw-stencil-library/{p-2dff657f.entry.js → p-6e74b1b0.entry.js} +2 -2
  523. package/dist/spw-stencil-library/{p-fda153e0.entry.js → p-6ea811f3.entry.js} +2 -2
  524. package/dist/spw-stencil-library/p-6ed76337.entry.js +2 -0
  525. package/dist/spw-stencil-library/p-6ed76337.entry.js.map +1 -0
  526. package/dist/spw-stencil-library/p-76e11724.entry.js +2 -0
  527. package/dist/spw-stencil-library/p-76e11724.entry.js.map +1 -0
  528. package/dist/spw-stencil-library/{p-11805364.entry.js → p-86bdf571.entry.js} +2 -2
  529. package/dist/spw-stencil-library/p-8c287e51.entry.js +2 -0
  530. package/dist/spw-stencil-library/p-8c287e51.entry.js.map +1 -0
  531. package/dist/spw-stencil-library/{p-fabf41a2.entry.js → p-8cfb4646.entry.js} +2 -2
  532. package/dist/spw-stencil-library/p-8cfb4646.entry.js.map +1 -0
  533. package/dist/spw-stencil-library/p-92583499.entry.js +2 -0
  534. package/dist/spw-stencil-library/p-92583499.entry.js.map +1 -0
  535. package/dist/spw-stencil-library/{p-8dca994a.entry.js → p-9b63ccca.entry.js} +2 -2
  536. package/dist/spw-stencil-library/p-9d760073.entry.js +2 -0
  537. package/dist/spw-stencil-library/p-9d760073.entry.js.map +1 -0
  538. package/dist/spw-stencil-library/{p-42658e0a.entry.js → p-9d984204.entry.js} +2 -2
  539. package/dist/spw-stencil-library/p-9d984204.entry.js.map +1 -0
  540. package/dist/spw-stencil-library/{p-5a034423.entry.js → p-9e12973d.entry.js} +2 -2
  541. package/dist/spw-stencil-library/p-9e8a779e.entry.js +2 -0
  542. package/dist/spw-stencil-library/p-9e8a779e.entry.js.map +1 -0
  543. package/dist/spw-stencil-library/{p-zpG0udTn.js → p-BBi01mKM.js} +2 -2
  544. package/dist/spw-stencil-library/p-BBi01mKM.js.map +1 -0
  545. package/dist/spw-stencil-library/p-CvfVJV8a.js +3 -0
  546. package/dist/spw-stencil-library/{p-BYM_CUUH.js.map → p-CvfVJV8a.js.map} +1 -1
  547. package/dist/spw-stencil-library/{p-1d9ef3d5.entry.js → p-a25ad9f2.entry.js} +2 -2
  548. package/dist/spw-stencil-library/{p-376b1e84.entry.js → p-a31a30f3.entry.js} +2 -2
  549. package/dist/spw-stencil-library/p-a31a30f3.entry.js.map +1 -0
  550. package/dist/spw-stencil-library/p-a61253c2.entry.js +2 -0
  551. package/dist/spw-stencil-library/p-a61253c2.entry.js.map +1 -0
  552. package/dist/spw-stencil-library/{p-8c6c9db5.entry.js → p-a840f2ca.entry.js} +2 -2
  553. package/dist/spw-stencil-library/{p-403fe46c.entry.js → p-b0e3875a.entry.js} +2 -2
  554. package/dist/spw-stencil-library/{p-b45534d4.entry.js → p-b1bb413f.entry.js} +2 -2
  555. package/dist/spw-stencil-library/{p-db2354cf.entry.js → p-b6a56ec7.entry.js} +2 -2
  556. package/dist/spw-stencil-library/{p-db2354cf.entry.js.map → p-b6a56ec7.entry.js.map} +1 -1
  557. package/dist/spw-stencil-library/{p-75159246.entry.js → p-bb225503.entry.js} +2 -2
  558. package/dist/spw-stencil-library/{p-1d93e0d8.entry.js → p-bff5424c.entry.js} +2 -2
  559. package/dist/spw-stencil-library/{p-cf508941.entry.js → p-c314e59f.entry.js} +2 -2
  560. package/dist/spw-stencil-library/p-c3985590.entry.js +2 -0
  561. package/dist/spw-stencil-library/p-c3985590.entry.js.map +1 -0
  562. package/dist/spw-stencil-library/p-c4e4cfd4.entry.js +2 -0
  563. package/dist/spw-stencil-library/p-c4e4cfd4.entry.js.map +1 -0
  564. package/dist/spw-stencil-library/{p-e72c6410.entry.js → p-cbf8aea1.entry.js} +2 -2
  565. package/dist/spw-stencil-library/p-ce72bca4.entry.js +2 -0
  566. package/dist/spw-stencil-library/p-ce72bca4.entry.js.map +1 -0
  567. package/dist/spw-stencil-library/{p-b0ca9615.entry.js → p-d03b1644.entry.js} +2 -2
  568. package/dist/spw-stencil-library/{p-817e139e.entry.js → p-d384f832.entry.js} +2 -2
  569. package/dist/spw-stencil-library/{p-532314d2.entry.js → p-d8ba3e5c.entry.js} +2 -2
  570. package/dist/spw-stencil-library/{p-e00468aa.entry.js → p-e0c31c21.entry.js} +2 -2
  571. package/dist/spw-stencil-library/{p-e00468aa.entry.js.map → p-e0c31c21.entry.js.map} +1 -1
  572. package/dist/spw-stencil-library/{p-09d27c4b.entry.js → p-e3485695.entry.js} +2 -2
  573. package/dist/spw-stencil-library/{p-ae905af5.entry.js → p-e4b4f2b3.entry.js} +2 -2
  574. package/dist/spw-stencil-library/{p-93a5f755.entry.js → p-e4d193cd.entry.js} +2 -2
  575. package/dist/spw-stencil-library/{p-158e7952.entry.js → p-e936741c.entry.js} +2 -2
  576. package/dist/spw-stencil-library/{p-98ee79d6.entry.js → p-f154589d.entry.js} +2 -2
  577. package/dist/spw-stencil-library/{p-98ee79d6.entry.js.map → p-f154589d.entry.js.map} +1 -1
  578. package/dist/spw-stencil-library/{p-7d80a44e.entry.js → p-f28bf2be.entry.js} +2 -2
  579. package/dist/spw-stencil-library/{p-7d80a44e.entry.js.map → p-f28bf2be.entry.js.map} +1 -1
  580. package/dist/spw-stencil-library/{p-7cd55113.entry.js → p-f70ed5c3.entry.js} +2 -2
  581. package/dist/spw-stencil-library/p-f8ad31d4.entry.js +2 -0
  582. package/dist/spw-stencil-library/{p-03f1a257.entry.js.map → p-f8ad31d4.entry.js.map} +1 -1
  583. package/dist/spw-stencil-library/{p-3450855b.entry.js → p-fa52aa2c.entry.js} +2 -2
  584. package/dist/spw-stencil-library/{p-554af1e3.entry.js → p-fc6af4d8.entry.js} +2 -2
  585. package/dist/spw-stencil-library/{p-a8311acd.entry.js → p-fcc5884a.entry.js} +2 -2
  586. package/dist/spw-stencil-library/p-fcc5884a.entry.js.map +1 -0
  587. package/dist/spw-stencil-library/spw-accordion.spw-accordion-content.spw-accordion-item.spw-accordion-title.entry.esm.js.map +1 -1
  588. package/dist/spw-stencil-library/spw-button.spw-loading.entry.esm.js.map +1 -1
  589. package/dist/spw-stencil-library/spw-checkbox.entry.esm.js.map +1 -1
  590. package/dist/spw-stencil-library/spw-custom-select.entry.esm.js.map +1 -1
  591. package/dist/spw-stencil-library/spw-date-picker.entry.esm.js.map +1 -1
  592. package/dist/spw-stencil-library/spw-dropdown-container.entry.esm.js.map +1 -0
  593. package/dist/spw-stencil-library/spw-dropdown-item.entry.esm.js.map +1 -0
  594. package/dist/spw-stencil-library/spw-dropdown.entry.esm.js.map +1 -1
  595. package/dist/spw-stencil-library/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.esm.js.map +1 -1
  596. package/dist/spw-stencil-library/spw-file-upload.entry.esm.js.map +1 -1
  597. package/dist/spw-stencil-library/spw-pagination.entry.esm.js.map +1 -1
  598. package/dist/spw-stencil-library/spw-search-field.entry.esm.js.map +1 -1
  599. package/dist/spw-stencil-library/spw-select.entry.esm.js.map +1 -1
  600. package/dist/spw-stencil-library/spw-sidebar-navigation-item.entry.esm.js.map +1 -1
  601. package/dist/spw-stencil-library/spw-sidebar.entry.esm.js.map +1 -1
  602. package/dist/spw-stencil-library/spw-skeleton.entry.esm.js.map +1 -1
  603. package/dist/spw-stencil-library/spw-stencil-library.css +1 -1
  604. package/dist/spw-stencil-library/spw-stencil-library.esm.js +1 -1
  605. package/dist/spw-stencil-library/spw-table-cell.entry.esm.js.map +1 -1
  606. package/dist/spw-stencil-library/spw-table-footer.entry.esm.js.map +1 -1
  607. package/dist/spw-stencil-library/spw-table-header.entry.esm.js.map +1 -1
  608. package/dist/spw-stencil-library/spw-table-row.entry.esm.js.map +1 -1
  609. package/dist/spw-stencil-library/spw-table.entry.esm.js.map +1 -1
  610. package/dist/spw-stencil-library/spw-tabs.entry.esm.js.map +1 -1
  611. package/dist/spw-stencil-library/spw-wizard-item.entry.esm.js.map +1 -0
  612. package/dist/spw-stencil-library/spw-wizard.entry.esm.js.map +1 -0
  613. package/dist/stats.json +3664 -983
  614. package/dist/types/components/spw-custom-select/spw-custom-select.d.ts +5 -0
  615. package/dist/types/components/spw-date-picker/spw-date-picker.d.ts +8 -0
  616. package/dist/types/components/spw-dropdown/spw-dropdown-container/spw-dropdown-container.d.ts +3 -0
  617. package/dist/types/components/spw-dropdown/spw-dropdown-item/spw-dropdown-item.d.ts +23 -0
  618. package/dist/types/components/spw-pagination/spw-pagination.d.ts +4 -1
  619. package/dist/types/components/spw-search-field/spw-search-field.d.ts +5 -0
  620. package/dist/types/components/spw-select/spw-select.d.ts +2 -0
  621. package/dist/types/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.d.ts +8 -0
  622. package/dist/types/components/spw-sidebar/spw-sidebar.d.ts +1 -0
  623. package/dist/types/components/spw-table/spw-table-cell/spw-table-cell.d.ts +15 -0
  624. package/dist/types/components/spw-table/spw-table-header/spw-table-header.d.ts +6 -0
  625. package/dist/types/components/spw-table/spw-table-row/spw-table-row.d.ts +8 -0
  626. package/dist/types/components/spw-table/spw-table.d.ts +13 -1
  627. package/dist/types/components/spw-wizard/spw-wizard-item/spw-wizard-item.d.ts +35 -0
  628. package/dist/types/components/spw-wizard/spw-wizard.d.ts +19 -0
  629. package/dist/types/components.d.ts +379 -0
  630. package/dist/types/stories/components/spw-date-picker/spw-date-picker.stories.d.ts +2 -0
  631. package/dist/types/stories/organisms/spw-table/spw-table.stories.d.ts +1 -0
  632. package/dist/types/stories/organisms/spw-wizard/spw-wizard.stories.d.ts +8 -0
  633. package/dist/types/utils/utils.d.ts +2 -1
  634. package/hydrate/index.js +1023 -180
  635. package/hydrate/index.mjs +1023 -180
  636. package/package.json +1 -1
  637. package/dist/cjs/utils-CKYAw_Le.js.map +0 -1
  638. package/dist/components/p-B-sLKmnT.js.map +0 -1
  639. package/dist/components/p-B3OQ2nRI.js.map +0 -1
  640. package/dist/components/p-Cf-dIWNi.js +0 -129
  641. package/dist/components/p-Cf-dIWNi.js.map +0 -1
  642. package/dist/components/p-DaosfSzT.js.map +0 -1
  643. package/dist/components/p-GUYao_6w.js.map +0 -1
  644. package/dist/components/p-zpG0udTn.js.map +0 -1
  645. package/dist/esm/utils-zpG0udTn.js.map +0 -1
  646. package/dist/spw-stencil-library/p-03f1a257.entry.js +0 -2
  647. package/dist/spw-stencil-library/p-2e9756c4.entry.js +0 -2
  648. package/dist/spw-stencil-library/p-2e9756c4.entry.js.map +0 -1
  649. package/dist/spw-stencil-library/p-34dc26ba.entry.js +0 -2
  650. package/dist/spw-stencil-library/p-34dc26ba.entry.js.map +0 -1
  651. package/dist/spw-stencil-library/p-376b1e84.entry.js.map +0 -1
  652. package/dist/spw-stencil-library/p-42658e0a.entry.js.map +0 -1
  653. package/dist/spw-stencil-library/p-44d87d3f.entry.js +0 -2
  654. package/dist/spw-stencil-library/p-44d87d3f.entry.js.map +0 -1
  655. package/dist/spw-stencil-library/p-5f82570e.entry.js.map +0 -1
  656. package/dist/spw-stencil-library/p-64670b2e.entry.js.map +0 -1
  657. package/dist/spw-stencil-library/p-73db3953.entry.js +0 -2
  658. package/dist/spw-stencil-library/p-73db3953.entry.js.map +0 -1
  659. package/dist/spw-stencil-library/p-7e30e4c2.entry.js +0 -2
  660. package/dist/spw-stencil-library/p-7e30e4c2.entry.js.map +0 -1
  661. package/dist/spw-stencil-library/p-8ef8864e.entry.js +0 -2
  662. package/dist/spw-stencil-library/p-8ef8864e.entry.js.map +0 -1
  663. package/dist/spw-stencil-library/p-9356f8c9.entry.js +0 -2
  664. package/dist/spw-stencil-library/p-9356f8c9.entry.js.map +0 -1
  665. package/dist/spw-stencil-library/p-BYM_CUUH.js +0 -3
  666. package/dist/spw-stencil-library/p-a8311acd.entry.js.map +0 -1
  667. package/dist/spw-stencil-library/p-a950bce8.entry.js +0 -2
  668. package/dist/spw-stencil-library/p-a950bce8.entry.js.map +0 -1
  669. package/dist/spw-stencil-library/p-ba27b9b0.entry.js +0 -2
  670. package/dist/spw-stencil-library/p-ba27b9b0.entry.js.map +0 -1
  671. package/dist/spw-stencil-library/p-bf2d0cf4.entry.js +0 -2
  672. package/dist/spw-stencil-library/p-bf2d0cf4.entry.js.map +0 -1
  673. package/dist/spw-stencil-library/p-c54fee67.entry.js +0 -2
  674. package/dist/spw-stencil-library/p-c54fee67.entry.js.map +0 -1
  675. package/dist/spw-stencil-library/p-d3d4755a.entry.js +0 -2
  676. package/dist/spw-stencil-library/p-d3d4755a.entry.js.map +0 -1
  677. package/dist/spw-stencil-library/p-fabf41a2.entry.js.map +0 -1
  678. package/dist/spw-stencil-library/p-zpG0udTn.js.map +0 -1
  679. /package/dist/spw-stencil-library/{p-f5de314e.entry.js.map → p-06cb6865.entry.js.map} +0 -0
  680. /package/dist/spw-stencil-library/{p-52c51ac5.entry.js.map → p-06ec3521.entry.js.map} +0 -0
  681. /package/dist/spw-stencil-library/{p-0226ad72.entry.js.map → p-0baeea00.entry.js.map} +0 -0
  682. /package/dist/spw-stencil-library/{p-fbe468de.entry.js.map → p-2113f2f6.entry.js.map} +0 -0
  683. /package/dist/spw-stencil-library/{p-181ae002.entry.js.map → p-25329033.entry.js.map} +0 -0
  684. /package/dist/spw-stencil-library/{p-9219fe7c.entry.js.map → p-2abc48ed.entry.js.map} +0 -0
  685. /package/dist/spw-stencil-library/{p-3ab472db.entry.js.map → p-2b011668.entry.js.map} +0 -0
  686. /package/dist/spw-stencil-library/{p-b0dc1073.entry.js.map → p-2cfb78fb.entry.js.map} +0 -0
  687. /package/dist/spw-stencil-library/{p-c2de4206.entry.js.map → p-2d974226.entry.js.map} +0 -0
  688. /package/dist/spw-stencil-library/{p-cb269271.entry.js.map → p-32fd509b.entry.js.map} +0 -0
  689. /package/dist/spw-stencil-library/{p-02151d7e.entry.js.map → p-438f1793.entry.js.map} +0 -0
  690. /package/dist/spw-stencil-library/{p-1f382434.entry.js.map → p-451a9785.entry.js.map} +0 -0
  691. /package/dist/spw-stencil-library/{p-4d61f200.entry.js.map → p-45d99a2b.entry.js.map} +0 -0
  692. /package/dist/spw-stencil-library/{p-a93f21f9.entry.js.map → p-46567994.entry.js.map} +0 -0
  693. /package/dist/spw-stencil-library/{p-2fd3eb76.entry.js.map → p-48417d99.entry.js.map} +0 -0
  694. /package/dist/spw-stencil-library/{p-dd4bf12d.entry.js.map → p-488c2d88.entry.js.map} +0 -0
  695. /package/dist/spw-stencil-library/{p-08d78730.entry.js.map → p-4e1774df.entry.js.map} +0 -0
  696. /package/dist/spw-stencil-library/{p-a30563ff.entry.js.map → p-512a2787.entry.js.map} +0 -0
  697. /package/dist/spw-stencil-library/{p-04274072.entry.js.map → p-5a1b3ad1.entry.js.map} +0 -0
  698. /package/dist/spw-stencil-library/{p-c838e17b.entry.js.map → p-5e34ea9d.entry.js.map} +0 -0
  699. /package/dist/spw-stencil-library/{p-74b4aea0.entry.js.map → p-5f873b56.entry.js.map} +0 -0
  700. /package/dist/spw-stencil-library/{p-cff5a7e4.entry.js.map → p-5fde9dae.entry.js.map} +0 -0
  701. /package/dist/spw-stencil-library/{p-09a2d080.entry.js.map → p-63d1c97f.entry.js.map} +0 -0
  702. /package/dist/spw-stencil-library/{p-2dff657f.entry.js.map → p-6e74b1b0.entry.js.map} +0 -0
  703. /package/dist/spw-stencil-library/{p-fda153e0.entry.js.map → p-6ea811f3.entry.js.map} +0 -0
  704. /package/dist/spw-stencil-library/{p-11805364.entry.js.map → p-86bdf571.entry.js.map} +0 -0
  705. /package/dist/spw-stencil-library/{p-8dca994a.entry.js.map → p-9b63ccca.entry.js.map} +0 -0
  706. /package/dist/spw-stencil-library/{p-5a034423.entry.js.map → p-9e12973d.entry.js.map} +0 -0
  707. /package/dist/spw-stencil-library/{p-1d9ef3d5.entry.js.map → p-a25ad9f2.entry.js.map} +0 -0
  708. /package/dist/spw-stencil-library/{p-8c6c9db5.entry.js.map → p-a840f2ca.entry.js.map} +0 -0
  709. /package/dist/spw-stencil-library/{p-403fe46c.entry.js.map → p-b0e3875a.entry.js.map} +0 -0
  710. /package/dist/spw-stencil-library/{p-b45534d4.entry.js.map → p-b1bb413f.entry.js.map} +0 -0
  711. /package/dist/spw-stencil-library/{p-75159246.entry.js.map → p-bb225503.entry.js.map} +0 -0
  712. /package/dist/spw-stencil-library/{p-1d93e0d8.entry.js.map → p-bff5424c.entry.js.map} +0 -0
  713. /package/dist/spw-stencil-library/{p-cf508941.entry.js.map → p-c314e59f.entry.js.map} +0 -0
  714. /package/dist/spw-stencil-library/{p-e72c6410.entry.js.map → p-cbf8aea1.entry.js.map} +0 -0
  715. /package/dist/spw-stencil-library/{p-b0ca9615.entry.js.map → p-d03b1644.entry.js.map} +0 -0
  716. /package/dist/spw-stencil-library/{p-817e139e.entry.js.map → p-d384f832.entry.js.map} +0 -0
  717. /package/dist/spw-stencil-library/{p-532314d2.entry.js.map → p-d8ba3e5c.entry.js.map} +0 -0
  718. /package/dist/spw-stencil-library/{p-09d27c4b.entry.js.map → p-e3485695.entry.js.map} +0 -0
  719. /package/dist/spw-stencil-library/{p-ae905af5.entry.js.map → p-e4b4f2b3.entry.js.map} +0 -0
  720. /package/dist/spw-stencil-library/{p-93a5f755.entry.js.map → p-e4d193cd.entry.js.map} +0 -0
  721. /package/dist/spw-stencil-library/{p-158e7952.entry.js.map → p-e936741c.entry.js.map} +0 -0
  722. /package/dist/spw-stencil-library/{p-7cd55113.entry.js.map → p-f70ed5c3.entry.js.map} +0 -0
  723. /package/dist/spw-stencil-library/{p-3450855b.entry.js.map → p-fa52aa2c.entry.js.map} +0 -0
  724. /package/dist/spw-stencil-library/{p-554af1e3.entry.js.map → p-fc6af4d8.entry.js.map} +0 -0
@@ -7,9 +7,12 @@ export class SpwSidebarNavigationItem {
7
7
  this.disabled = false;
8
8
  /** A appliquer sur spw-sidebar-navigation-item, permet de choisir la variante d'icônes font-awesome */
9
9
  this.iconVariant = 'fa-regular';
10
+ /** A appliquer sur spw-sidebar-navigation-item, si true, le clic sur l'item entier ouvre le dropdown (utile quand il n'y a pas de page physique) */
11
+ this.openOnClick = false;
10
12
  this.hasDropdown = false;
11
13
  this.dropdownOpen = false;
12
14
  this.navExpanded = false;
15
+ this.hasActiveChild = false;
13
16
  this.checkNavExpanded = () => {
14
17
  this.navExpanded = document.body.classList.contains('spw-sidebar-expanded');
15
18
  };
@@ -31,12 +34,58 @@ export class SpwSidebarNavigationItem {
31
34
  this.dropdownOpen = dropdown.open;
32
35
  }
33
36
  };
37
+ this.handleItemClick = (event) => {
38
+ if (this.disabled)
39
+ return;
40
+ if (this.openOnClick && this.hasDropdown) {
41
+ const clickedElement = event.target;
42
+ const isChildNavigationItem = clickedElement.closest('spw-sidebar-navigation-item') !== this.el;
43
+ if (isChildNavigationItem) {
44
+ return;
45
+ }
46
+ event.preventDefault();
47
+ event.stopPropagation();
48
+ if (!this.navExpanded) {
49
+ document.body.classList.add('spw-sidebar-expanded');
50
+ setTimeout(() => {
51
+ this.openDropdown();
52
+ }, 300);
53
+ }
54
+ else {
55
+ this.toggleDropdown();
56
+ }
57
+ }
58
+ };
59
+ this.openDropdown = () => {
60
+ var _a;
61
+ const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown');
62
+ if (dropdown) {
63
+ dropdown.open = true;
64
+ (_a = dropdown.setAttribute) === null || _a === void 0 ? void 0 : _a.call(dropdown, 'open', '');
65
+ this.dropdownOpen = true;
66
+ }
67
+ };
68
+ this.toggleDropdown = () => {
69
+ var _a, _b;
70
+ const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown');
71
+ if (dropdown) {
72
+ dropdown.open = !dropdown.open;
73
+ if (dropdown.open) {
74
+ (_a = dropdown.setAttribute) === null || _a === void 0 ? void 0 : _a.call(dropdown, 'open', '');
75
+ }
76
+ else {
77
+ (_b = dropdown.removeAttribute) === null || _b === void 0 ? void 0 : _b.call(dropdown, 'open');
78
+ }
79
+ this.dropdownOpen = dropdown.open;
80
+ }
81
+ };
34
82
  }
35
83
  componentDidLoad() {
36
84
  this.checkForDropdown();
37
85
  this.setupMutationObserver();
38
86
  this.checkNavExpanded();
39
87
  this.setupBodyClassObserver();
88
+ this.propagateActiveStateToParents();
40
89
  }
41
90
  componentDidUpdate() {
42
91
  this.checkForDropdown();
@@ -80,25 +129,54 @@ export class SpwSidebarNavigationItem {
80
129
  attributeFilter: ['class'],
81
130
  });
82
131
  }
132
+ propagateActiveStateToParents() {
133
+ if (this.active) {
134
+ this.activateParentItems();
135
+ }
136
+ const childItems = this.el.querySelectorAll('spw-sidebar-navigation-item');
137
+ const hasActiveDescendant = Array.from(childItems).some((child) => child.active === true || child.getAttribute('active') === 'true');
138
+ if (hasActiveDescendant) {
139
+ this.hasActiveChild = true;
140
+ this.openDropdown();
141
+ }
142
+ }
143
+ activateParentItems() {
144
+ let parent = this.el.parentElement;
145
+ while (parent) {
146
+ const parentItem = parent.closest('spw-sidebar-navigation-item');
147
+ if (parentItem && parentItem !== this.el) {
148
+ parentItem.hasActiveChild = true;
149
+ const dropdown = parentItem.querySelector(':scope > spw-sidebar-navigation-dropdown');
150
+ if (dropdown) {
151
+ dropdown.open = true;
152
+ dropdown.setAttribute('open', '');
153
+ }
154
+ parent = parentItem.parentElement;
155
+ }
156
+ else {
157
+ break;
158
+ }
159
+ }
160
+ }
83
161
  get classes() {
84
162
  return {
85
163
  'spw-sidebar-navigation-item': true,
86
- 'spw-sidebar-navigation-item--active': this.active,
164
+ 'spw-sidebar-navigation-item--active': this.active || this.hasActiveChild,
87
165
  'spw-sidebar-navigation-item--disabled': this.disabled,
88
166
  'spw-sidebar-navigation-item--has-dropdown': this.hasDropdown,
89
167
  'spw-sidebar-navigation-item--dropdown-opened': this.dropdownOpen,
90
168
  };
91
169
  }
92
170
  render() {
93
- const Tag = this.href && !this.disabled ? 'a' : 'div';
94
- const iconContent = h("spw-icon", { key: '2f9860be47d53d7bfa9be6e901ce515682aed40c', variant: this.iconVariant, icon: this.icon });
95
- const iconDiv = (h("div", { key: '740859f0b9ef998cfb5a0412347c6cd0b574e930', class: "spw-sidebar-navigation-item__icon" }, this.bubble && h("span", { key: '8ea56c6f135f052bc237df0690ec601f1a5a5744', class: "spw-sidebar-navigation-item__bubble" }, this.bubble), iconContent));
171
+ const Tag = this.href && !this.disabled && !this.openOnClick ? 'a' : 'div';
172
+ const iconContent = h("spw-icon", { key: '551dd344206c2a0a747505c215bbdcb8630e70af', variant: this.iconVariant, icon: this.icon });
173
+ const iconDiv = (h("div", { key: '033a5245bad2cb52ac940e798e2ac50696134c90', class: "spw-sidebar-navigation-item__icon" }, this.bubble && h("span", { key: '00b15c2081a53f8175390da5c15d5fd015497698', class: "spw-sidebar-navigation-item__bubble" }, this.bubble), iconContent));
96
174
  const iconWithBubble = this.tooltipTitle ? (h("spw-tooltip", { cursor: this.disabled ? 'disabled' : 'pointer', "tooltip-title": this.tooltipTitle, direction: "right", visible: !this.navExpanded }, iconDiv)) : (iconDiv);
97
175
  const toggleClasses = {
98
176
  'spw-sidebar-navigation-item__dropdown-toggle': true,
99
177
  'spw-sidebar-navigation-item__dropdown-toggle--open': this.dropdownOpen,
100
178
  };
101
- return (h(Tag, { key: 'fb6661be9c90aeeba52d5dee1e0d42c32d605ae1', class: this.classes, href: this.href, "aria-disabled": this.disabled ? 'true' : undefined, tabIndex: this.disabled ? -1 : 0 }, this.icon && iconWithBubble, h("div", { key: 'a8c78fa983e0a2eef8eb76e0a25e25ec431545dd', class: "spw-sidebar-navigation-item__content" }, h("div", { key: '8296bb1500b0a3832c3afd9e52e83a3f60be91d4', class: "spw-sidebar-navigation-item__content-label" }, h("slot", { key: '1d08db1184d912b80b1fc27e852ad46428fcd1a2' })), this.hasDropdown && (h("div", { key: '676a39dbbb3b1b0a7a3f32df2bf43fe7cc644d99', class: toggleClasses, onClick: this.handleDropdownToggle, tabIndex: this.disabled ? -1 : 0 }, h("spw-icon", { key: 'b8bfa8d5f5355b5f3e876e232f72ae8464a73600', icon: "fa-chevron-down" }))), h("slot", { key: '1a77b8dc78652576d29da9620eae9450ead62a25', name: "dropdown" }))));
179
+ return (h(Tag, { key: 'b67e6b8a6918b209fd5f589bc63c2ea141c23ecd', class: this.classes, href: this.openOnClick ? undefined : this.href, "aria-disabled": this.disabled ? 'true' : undefined, tabIndex: this.disabled ? -1 : 0, onClick: this.openOnClick ? this.handleItemClick : undefined }, this.icon && iconWithBubble, h("div", { key: '321ea3fb1f0142f08eb8e9181e946b40603df3b7', class: "spw-sidebar-navigation-item__content" }, h("div", { key: '5aa95a61305bfe337cfdae0e7709a1f4a7280e94', class: "spw-sidebar-navigation-item__content-label" }, h("slot", { key: 'a73d04cbda3c6dbdfec620dacd6a9e93080f8892' })), this.hasDropdown && (h("div", { key: 'b8ea2990ace408c4896bf9c494b7083cd5fcd6f3', class: toggleClasses, onClick: this.handleDropdownToggle, tabIndex: this.disabled ? -1 : 0 }, h("spw-icon", { key: '94d525e89c6a052311a493419404c2d5a3f3e2c5', icon: "fa-chevron-down" }))), h("slot", { key: 'd418e150102a23a27e3e473888ecbe832a9f4f78', name: "dropdown" }))));
102
180
  }
103
181
  static get is() { return "spw-sidebar-navigation-item"; }
104
182
  static get originalStyleUrls() {
@@ -248,6 +326,26 @@ export class SpwSidebarNavigationItem {
248
326
  "attribute": "icon-variant",
249
327
  "reflect": false,
250
328
  "defaultValue": "'fa-regular'"
329
+ },
330
+ "openOnClick": {
331
+ "type": "boolean",
332
+ "mutable": false,
333
+ "complexType": {
334
+ "original": "boolean",
335
+ "resolved": "boolean",
336
+ "references": {}
337
+ },
338
+ "required": false,
339
+ "optional": false,
340
+ "docs": {
341
+ "tags": [],
342
+ "text": "A appliquer sur spw-sidebar-navigation-item, si true, le clic sur l'item entier ouvre le dropdown (utile quand il n'y a pas de page physique)"
343
+ },
344
+ "getter": false,
345
+ "setter": false,
346
+ "attribute": "open-on-click",
347
+ "reflect": false,
348
+ "defaultValue": "false"
251
349
  }
252
350
  };
253
351
  }
@@ -255,7 +353,8 @@ export class SpwSidebarNavigationItem {
255
353
  return {
256
354
  "hasDropdown": {},
257
355
  "dropdownOpen": {},
258
- "navExpanded": {}
356
+ "navExpanded": {},
357
+ "hasActiveChild": {}
259
358
  };
260
359
  }
261
360
  static get elementRef() { return "el"; }
@@ -1 +1 @@
1
- {"version":3,"file":"spw-sidebar-navigation-item.js","sourceRoot":"","sources":["../../../../src/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, h, Prop, Element, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-sidebar-navigation-item',\n styleUrl: 'spw-sidebar-navigation-item.scss',\n shadow: false,\n})\nexport class SpwSidebarNavigationItem {\n @Element() el: HTMLElement;\n\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir un href sur l'élément */\n @Prop() href?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir une référence font-awesome sur l'élément */\n @Prop() icon?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de mettre en évidence un état actif */\n @Prop() active: boolean = false;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir si l'élément est disabled ou non */\n @Prop() disabled: boolean = false;\n /** A appliquer sur spw-sidebar-navigation-item, permet d'afficher une bulle de notification avec un nombre */\n @Prop() bubble?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir un tooltip au hover */\n @Prop() tooltipTitle?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de choisir la variante d'icônes font-awesome */\n @Prop() iconVariant: 'fa-solid' | 'fa-brands' | 'fa-regular' = 'fa-regular';\n\n @State() hasDropdown: boolean = false;\n @State() dropdownOpen: boolean = false;\n @State() navExpanded: boolean = false;\n\n private mutationObserver?: MutationObserver;\n private bodyClassObserver?: MutationObserver;\n\n componentDidLoad() {\n this.checkForDropdown();\n this.setupMutationObserver();\n this.checkNavExpanded();\n this.setupBodyClassObserver();\n }\n\n componentDidUpdate() {\n this.checkForDropdown();\n }\n\n disconnectedCallback() {\n if (this.mutationObserver) {\n this.mutationObserver.disconnect();\n }\n if (this.bodyClassObserver) {\n this.bodyClassObserver.disconnect();\n }\n }\n\n private setupMutationObserver() {\n this.mutationObserver = new MutationObserver(() => {\n this.checkForDropdown();\n });\n\n this.mutationObserver.observe(this.el, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['open'],\n });\n }\n\n private checkForDropdown() {\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n this.hasDropdown = dropdown !== null;\n\n if (dropdown) {\n this.dropdownOpen = !!dropdown.open || dropdown.hasAttribute?.('open');\n } else {\n this.dropdownOpen = false;\n }\n }\n\n private checkNavExpanded = () => {\n this.navExpanded = document.body.classList.contains('spw-sidebar-expanded');\n };\n\n private setupBodyClassObserver() {\n this.bodyClassObserver = new MutationObserver(() => {\n this.checkNavExpanded();\n });\n this.bodyClassObserver.observe(document.body, {\n attributes: true,\n attributeFilter: ['class'],\n });\n }\n\n private get classes() {\n return {\n 'spw-sidebar-navigation-item': true,\n 'spw-sidebar-navigation-item--active': this.active,\n 'spw-sidebar-navigation-item--disabled': this.disabled,\n 'spw-sidebar-navigation-item--has-dropdown': this.hasDropdown,\n 'spw-sidebar-navigation-item--dropdown-opened': this.dropdownOpen,\n } as Record<string, boolean>;\n }\n\n private handleDropdownToggle = (event: MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n\n if (this.disabled) return;\n\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n\n if (dropdown) {\n dropdown.open = !dropdown.open;\n if (dropdown.open) {\n dropdown.setAttribute?.('open', '');\n } else {\n dropdown.removeAttribute?.('open');\n }\n this.dropdownOpen = dropdown.open;\n }\n };\n\n render() {\n const Tag = this.href && !this.disabled ? 'a' : 'div';\n\n const iconContent = <spw-icon variant={this.iconVariant} icon={this.icon}></spw-icon>;\n\n const iconDiv = (\n <div class=\"spw-sidebar-navigation-item__icon\">\n {this.bubble && <span class=\"spw-sidebar-navigation-item__bubble\">{this.bubble}</span>}\n {iconContent}\n </div>\n );\n\n const iconWithBubble = this.tooltipTitle ? (\n <spw-tooltip cursor={this.disabled ? 'disabled' : 'pointer'} tooltip-title={this.tooltipTitle} direction=\"right\" visible={!this.navExpanded}>\n {iconDiv}\n </spw-tooltip>\n ) : (\n iconDiv\n );\n\n const toggleClasses = {\n 'spw-sidebar-navigation-item__dropdown-toggle': true,\n 'spw-sidebar-navigation-item__dropdown-toggle--open': this.dropdownOpen,\n } as Record<string, boolean>;\n\n return (\n <Tag class={this.classes} href={this.href} aria-disabled={this.disabled ? 'true' : undefined} tabIndex={this.disabled ? -1 : 0}>\n {this.icon && iconWithBubble}\n\n <div class=\"spw-sidebar-navigation-item__content\">\n <div class=\"spw-sidebar-navigation-item__content-label\">\n <slot></slot>\n </div>\n\n {this.hasDropdown && (\n <div class={toggleClasses} onClick={this.handleDropdownToggle} tabIndex={this.disabled ? -1 : 0}>\n <spw-icon icon=\"fa-chevron-down\"></spw-icon>\n </div>\n )}\n\n <slot name=\"dropdown\"></slot>\n </div>\n </Tag>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"spw-sidebar-navigation-item.js","sourceRoot":"","sources":["../../../../src/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAOnE,MAAM,OAAO,wBAAwB;IALrC;QAYE,8FAA8F;QACtF,WAAM,GAAY,KAAK,CAAC;QAChC,sGAAsG;QAC9F,aAAQ,GAAY,KAAK,CAAC;QAKlC,uGAAuG;QAC/F,gBAAW,GAA4C,YAAY,CAAC;QAC5E,oJAAoJ;QAC5I,gBAAW,GAAY,KAAK,CAAC;QAE5B,gBAAW,GAAY,KAAK,CAAC;QAC7B,iBAAY,GAAY,KAAK,CAAC;QAC9B,gBAAW,GAAY,KAAK,CAAC;QAC7B,mBAAc,GAAY,KAAK,CAAC;QAkDjC,qBAAgB,GAAG,GAAG,EAAE;YAC9B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC;QAC9E,CAAC,CAAC;QA0DM,yBAAoB,GAAG,CAAC,KAAiB,EAAE,EAAE;;YACnD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAE1B,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,iCAAiC,CAAQ,CAAC;YAEjF,IAAI,QAAQ,EAAE,CAAC;gBACb,QAAQ,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC;gBAC/B,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;oBAClB,MAAA,QAAQ,CAAC,YAAY,yDAAG,MAAM,EAAE,EAAE,CAAC,CAAC;gBACtC,CAAC;qBAAM,CAAC;oBACN,MAAA,QAAQ,CAAC,eAAe,yDAAG,MAAM,CAAC,CAAC;gBACrC,CAAC;gBACD,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;YACpC,CAAC;QACH,CAAC,CAAC;QAEM,oBAAe,GAAG,CAAC,KAAiB,EAAE,EAAE;YAC9C,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAE1B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACzC,MAAM,cAAc,GAAG,KAAK,CAAC,MAAqB,CAAC;gBACnD,MAAM,qBAAqB,GAAG,cAAc,CAAC,OAAO,CAAC,6BAA6B,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;gBAEhG,IAAI,qBAAqB,EAAE,CAAC;oBAC1B,OAAO;gBACT,CAAC;gBAED,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;gBAExB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;oBACtB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;oBACpD,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,YAAY,EAAE,CAAC;oBACtB,CAAC,EAAE,GAAG,CAAC,CAAC;gBACV,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,cAAc,EAAE,CAAC;gBACxB,CAAC;YACH,CAAC;QACH,CAAC,CAAC;QAEM,iBAAY,GAAG,GAAG,EAAE;;YAC1B,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,iCAAiC,CAAQ,CAAC;YACjF,IAAI,QAAQ,EAAE,CAAC;gBACb,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;gBACrB,MAAA,QAAQ,CAAC,YAAY,yDAAG,MAAM,EAAE,EAAE,CAAC,CAAC;gBACpC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC;QAEM,mBAAc,GAAG,GAAG,EAAE;;YAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,iCAAiC,CAAQ,CAAC;YACjF,IAAI,QAAQ,EAAE,CAAC;gBACb,QAAQ,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC;gBAC/B,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;oBAClB,MAAA,QAAQ,CAAC,YAAY,yDAAG,MAAM,EAAE,EAAE,CAAC,CAAC;gBACtC,CAAC;qBAAM,CAAC;oBACN,MAAA,QAAQ,CAAC,eAAe,yDAAG,MAAM,CAAC,CAAC;gBACrC,CAAC;gBACD,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;YACpC,CAAC;QACH,CAAC,CAAC;KAqDH;IA9NC,gBAAgB;QACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,6BAA6B,EAAE,CAAC;IACvC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;QACrC,CAAC;QACD,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;QACtC,CAAC;IACH,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YAChD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE;YACrC,SAAS,EAAE,IAAI;YACf,OAAO,EAAE,IAAI;YACb,UAAU,EAAE,IAAI;YAChB,eAAe,EAAE,CAAC,MAAM,CAAC;SAC1B,CAAC,CAAC;IACL,CAAC;IAEO,gBAAgB;;QACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,iCAAiC,CAAQ,CAAC;QACjF,IAAI,CAAC,WAAW,GAAG,QAAQ,KAAK,IAAI,CAAC;QAErC,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,KAAI,MAAA,QAAQ,CAAC,YAAY,yDAAG,MAAM,CAAC,CAAA,CAAC;QACzE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC5B,CAAC;IACH,CAAC;IAMO,sBAAsB;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE;YAC5C,UAAU,EAAE,IAAI;YAChB,eAAe,EAAE,CAAC,OAAO,CAAC;SAC3B,CAAC,CAAC;IACL,CAAC;IAEO,6BAA6B;QACnC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,gBAAgB,CAAC,6BAA6B,CAAC,CAAC;QAC3E,MAAM,mBAAmB,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,IAAI,IAAI,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,MAAM,CAAC,CAAC;QAE1I,IAAI,mBAAmB,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAEO,mBAAmB;QACzB,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QAEnC,OAAO,MAAM,EAAE,CAAC;YACd,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,6BAA6B,CAAC,CAAC;YAEjE,IAAI,UAAU,IAAI,UAAU,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;gBACxC,UAAkB,CAAC,cAAc,GAAG,IAAI,CAAC;gBAE1C,MAAM,QAAQ,GAAG,UAAU,CAAC,aAAa,CAAC,0CAA0C,CAAQ,CAAC;gBAC7F,IAAI,QAAQ,EAAE,CAAC;oBACb,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;oBACrB,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;gBACpC,CAAC;gBAED,MAAM,GAAG,UAAU,CAAC,aAAa,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAY,OAAO;QACjB,OAAO;YACL,6BAA6B,EAAE,IAAI;YACnC,qCAAqC,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,cAAc;YACzE,uCAAuC,EAAE,IAAI,CAAC,QAAQ;YACtD,2CAA2C,EAAE,IAAI,CAAC,WAAW;YAC7D,8CAA8C,EAAE,IAAI,CAAC,YAAY;SACvC,CAAC;IAC/B,CAAC;IAoED,MAAM;QACJ,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC;QAE3E,MAAM,WAAW,GAAG,iEAAU,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,GAAa,CAAC;QAEtF,MAAM,OAAO,GAAG,CACd,4DAAK,KAAK,EAAC,mCAAmC;YAC3C,IAAI,CAAC,MAAM,IAAI,6DAAM,KAAK,EAAC,qCAAqC,IAAE,IAAI,CAAC,MAAM,CAAQ;YACrF,WAAW,CACR,CACP,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CACzC,mBAAa,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,mBAAiB,IAAI,CAAC,YAAY,EAAE,SAAS,EAAC,OAAO,EAAC,OAAO,EAAE,CAAC,IAAI,CAAC,WAAW,IACxI,OAAO,CACI,CACf,CAAC,CAAC,CAAC,CACF,OAAO,CACR,CAAC;QAEF,MAAM,aAAa,GAAG;YACpB,8CAA8C,EAAE,IAAI;YACpD,oDAAoD,EAAE,IAAI,CAAC,YAAY;SAC7C,CAAC;QAE7B,OAAO,CACL,EAAC,GAAG,qDACF,KAAK,EAAE,IAAI,CAAC,OAAO,EACnB,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,mBAC/B,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EACjD,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAChC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS;YAE3D,IAAI,CAAC,IAAI,IAAI,cAAc;YAE5B,4DAAK,KAAK,EAAC,sCAAsC;gBAC/C,4DAAK,KAAK,EAAC,4CAA4C;oBACrD,8DAAa,CACT;gBAEL,IAAI,CAAC,WAAW,IAAI,CACnB,4DAAK,KAAK,EAAE,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC7F,iEAAU,IAAI,EAAC,iBAAiB,GAAY,CACxC,CACP;gBAED,6DAAM,IAAI,EAAC,UAAU,GAAQ,CACzB,CACF,CACP,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, h, Prop, Element, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-sidebar-navigation-item',\n styleUrl: 'spw-sidebar-navigation-item.scss',\n shadow: false,\n})\nexport class SpwSidebarNavigationItem {\n @Element() el: HTMLElement;\n\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir un href sur l'élément */\n @Prop() href?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir une référence font-awesome sur l'élément */\n @Prop() icon?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de mettre en évidence un état actif */\n @Prop() active: boolean = false;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir si l'élément est disabled ou non */\n @Prop() disabled: boolean = false;\n /** A appliquer sur spw-sidebar-navigation-item, permet d'afficher une bulle de notification avec un nombre */\n @Prop() bubble?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de définir un tooltip au hover */\n @Prop() tooltipTitle?: string;\n /** A appliquer sur spw-sidebar-navigation-item, permet de choisir la variante d'icônes font-awesome */\n @Prop() iconVariant: 'fa-solid' | 'fa-brands' | 'fa-regular' = 'fa-regular';\n /** A appliquer sur spw-sidebar-navigation-item, si true, le clic sur l'item entier ouvre le dropdown (utile quand il n'y a pas de page physique) */\n @Prop() openOnClick: boolean = false;\n\n @State() hasDropdown: boolean = false;\n @State() dropdownOpen: boolean = false;\n @State() navExpanded: boolean = false;\n @State() hasActiveChild: boolean = false;\n\n private mutationObserver?: MutationObserver;\n private bodyClassObserver?: MutationObserver;\n\n componentDidLoad() {\n this.checkForDropdown();\n this.setupMutationObserver();\n this.checkNavExpanded();\n this.setupBodyClassObserver();\n this.propagateActiveStateToParents();\n }\n\n componentDidUpdate() {\n this.checkForDropdown();\n }\n\n disconnectedCallback() {\n if (this.mutationObserver) {\n this.mutationObserver.disconnect();\n }\n if (this.bodyClassObserver) {\n this.bodyClassObserver.disconnect();\n }\n }\n\n private setupMutationObserver() {\n this.mutationObserver = new MutationObserver(() => {\n this.checkForDropdown();\n });\n\n this.mutationObserver.observe(this.el, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['open'],\n });\n }\n\n private checkForDropdown() {\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n this.hasDropdown = dropdown !== null;\n\n if (dropdown) {\n this.dropdownOpen = !!dropdown.open || dropdown.hasAttribute?.('open');\n } else {\n this.dropdownOpen = false;\n }\n }\n\n private checkNavExpanded = () => {\n this.navExpanded = document.body.classList.contains('spw-sidebar-expanded');\n };\n\n private setupBodyClassObserver() {\n this.bodyClassObserver = new MutationObserver(() => {\n this.checkNavExpanded();\n });\n this.bodyClassObserver.observe(document.body, {\n attributes: true,\n attributeFilter: ['class'],\n });\n }\n\n private propagateActiveStateToParents() {\n if (this.active) {\n this.activateParentItems();\n }\n\n const childItems = this.el.querySelectorAll('spw-sidebar-navigation-item');\n const hasActiveDescendant = Array.from(childItems).some((child: any) => child.active === true || child.getAttribute('active') === 'true');\n\n if (hasActiveDescendant) {\n this.hasActiveChild = true;\n this.openDropdown();\n }\n }\n\n private activateParentItems() {\n let parent = this.el.parentElement;\n\n while (parent) {\n const parentItem = parent.closest('spw-sidebar-navigation-item');\n\n if (parentItem && parentItem !== this.el) {\n (parentItem as any).hasActiveChild = true;\n\n const dropdown = parentItem.querySelector(':scope > spw-sidebar-navigation-dropdown') as any;\n if (dropdown) {\n dropdown.open = true;\n dropdown.setAttribute('open', '');\n }\n\n parent = parentItem.parentElement;\n } else {\n break;\n }\n }\n }\n\n private get classes() {\n return {\n 'spw-sidebar-navigation-item': true,\n 'spw-sidebar-navigation-item--active': this.active || this.hasActiveChild,\n 'spw-sidebar-navigation-item--disabled': this.disabled,\n 'spw-sidebar-navigation-item--has-dropdown': this.hasDropdown,\n 'spw-sidebar-navigation-item--dropdown-opened': this.dropdownOpen,\n } as Record<string, boolean>;\n }\n\n private handleDropdownToggle = (event: MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n\n if (this.disabled) return;\n\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n\n if (dropdown) {\n dropdown.open = !dropdown.open;\n if (dropdown.open) {\n dropdown.setAttribute?.('open', '');\n } else {\n dropdown.removeAttribute?.('open');\n }\n this.dropdownOpen = dropdown.open;\n }\n };\n\n private handleItemClick = (event: MouseEvent) => {\n if (this.disabled) return;\n\n if (this.openOnClick && this.hasDropdown) {\n const clickedElement = event.target as HTMLElement;\n const isChildNavigationItem = clickedElement.closest('spw-sidebar-navigation-item') !== this.el;\n\n if (isChildNavigationItem) {\n return;\n }\n\n event.preventDefault();\n event.stopPropagation();\n\n if (!this.navExpanded) {\n document.body.classList.add('spw-sidebar-expanded');\n setTimeout(() => {\n this.openDropdown();\n }, 300);\n } else {\n this.toggleDropdown();\n }\n }\n };\n\n private openDropdown = () => {\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n if (dropdown) {\n dropdown.open = true;\n dropdown.setAttribute?.('open', '');\n this.dropdownOpen = true;\n }\n };\n\n private toggleDropdown = () => {\n const dropdown = this.el.querySelector('spw-sidebar-navigation-dropdown') as any;\n if (dropdown) {\n dropdown.open = !dropdown.open;\n if (dropdown.open) {\n dropdown.setAttribute?.('open', '');\n } else {\n dropdown.removeAttribute?.('open');\n }\n this.dropdownOpen = dropdown.open;\n }\n };\n\n render() {\n const Tag = this.href && !this.disabled && !this.openOnClick ? 'a' : 'div';\n\n const iconContent = <spw-icon variant={this.iconVariant} icon={this.icon}></spw-icon>;\n\n const iconDiv = (\n <div class=\"spw-sidebar-navigation-item__icon\">\n {this.bubble && <span class=\"spw-sidebar-navigation-item__bubble\">{this.bubble}</span>}\n {iconContent}\n </div>\n );\n\n const iconWithBubble = this.tooltipTitle ? (\n <spw-tooltip cursor={this.disabled ? 'disabled' : 'pointer'} tooltip-title={this.tooltipTitle} direction=\"right\" visible={!this.navExpanded}>\n {iconDiv}\n </spw-tooltip>\n ) : (\n iconDiv\n );\n\n const toggleClasses = {\n 'spw-sidebar-navigation-item__dropdown-toggle': true,\n 'spw-sidebar-navigation-item__dropdown-toggle--open': this.dropdownOpen,\n } as Record<string, boolean>;\n\n return (\n <Tag\n class={this.classes}\n href={this.openOnClick ? undefined : this.href}\n aria-disabled={this.disabled ? 'true' : undefined}\n tabIndex={this.disabled ? -1 : 0}\n onClick={this.openOnClick ? this.handleItemClick : undefined}\n >\n {this.icon && iconWithBubble}\n\n <div class=\"spw-sidebar-navigation-item__content\">\n <div class=\"spw-sidebar-navigation-item__content-label\">\n <slot></slot>\n </div>\n\n {this.hasDropdown && (\n <div class={toggleClasses} onClick={this.handleDropdownToggle} tabIndex={this.disabled ? -1 : 0}>\n <spw-icon icon=\"fa-chevron-down\"></spw-icon>\n </div>\n )}\n\n <slot name=\"dropdown\"></slot>\n </div>\n </Tag>\n );\n }\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Host, h } from "@stencil/core";
2
2
  export class SpwSidebarNavigationSeparator {
3
3
  render() {
4
- return (h(Host, { key: '5931190d536fcfad890d75a47587ed301507542a' }, h("spw-separator", { key: '8b1e73c9f463260683c3c3e5dd60640f0165406f', class: "spw-sidebar-navigation-separator" })));
4
+ return (h(Host, { key: '93da5418115a91bd8a45a0b8de207d4d91a9c706' }, h("spw-separator", { key: '7c5cc350ddaf479ed0af22be5f2014b4183c98f2', class: "spw-sidebar-navigation-separator" })));
5
5
  }
6
6
  static get is() { return "spw-sidebar-navigation-separator"; }
7
7
  static get encapsulation() { return "shadow"; }
@@ -12,6 +12,13 @@ export class SpwSidebar {
12
12
  this.checkTopbarClass = () => {
13
13
  this.hasTopbar = document.body.classList.contains('has-topbar');
14
14
  };
15
+ this.checkExpandedState = () => {
16
+ // Synchronise l'état interne avec la classe body
17
+ const bodyHasExpandedClass = document.body.classList.contains(this.BODY_CLASS);
18
+ if (this.expanded !== bodyHasExpandedClass) {
19
+ this.expanded = bodyHasExpandedClass;
20
+ }
21
+ };
15
22
  }
16
23
  componentWillLoad() {
17
24
  this.expanded = this.defaultExpanded;
@@ -29,6 +36,7 @@ export class SpwSidebar {
29
36
  observeBodyClassChanges() {
30
37
  this.observer = new MutationObserver(() => {
31
38
  this.checkTopbarClass();
39
+ this.checkExpandedState();
32
40
  });
33
41
  this.observer.observe(document.body, {
34
42
  attributes: true,
@@ -50,7 +58,7 @@ export class SpwSidebar {
50
58
  };
51
59
  }
52
60
  render() {
53
- return (h(Host, { key: 'e8b5fe55c0a0bd0bf866cc5cad1da1a8b33ba792', class: this.hostClass }, h("div", { key: 'd9495832225a3008a17de912a79e53602110b5c0', class: this.elementClass }, h("span", { key: 'd5d37ddf70fceee382a5157ac4f468e4923d6a90', class: "spw-sidebar__toggle", onClick: this.toggleSidebar, "aria-expanded": this.expanded.toString() }, h("spw-icon", { key: '5bdd17e49970af56834efd8871c6b5d844189e1e', icon: "fa-chevron-right" })), h("div", { key: 'e372d08ee8ba3d55580bca0a63b554ec01a3719d', class: "spw-sidebar__content" }, h("slot", { key: 'a4d65d4fc323a58c5fa8346d79d8a54e304509fa', name: "navigation-top" }), h("slot", { key: '6484ae2e83756f473c7deab3574e3f747eed744f', name: "navigation-bottom" })), h("div", { key: '495e33ae7faf1aa1116412d876d1352a754c6e9b', class: "spw-sidebar__resize-border", onClick: this.toggleSidebar }))));
61
+ return (h(Host, { key: 'ddffbd455cbc2710867a69ee8b7591b2f73b6599', class: this.hostClass }, h("div", { key: 'ee150c9244aa861c978c5008efd28c04b8e8c868', class: this.elementClass }, h("span", { key: '873736c218af40bb9a3c2aadb5891420d8b8f674', class: "spw-sidebar__toggle", onClick: this.toggleSidebar, "aria-expanded": this.expanded.toString() }, h("spw-icon", { key: '6c47d4c931c5e1932b06824e2809e77147229eb0', icon: "fa-chevron-right" })), h("div", { key: 'c2894503c4ab71bc570209c9fac1963e13b3ca06', class: "spw-sidebar__content" }, h("slot", { key: 'fb3d4146487654157da34e715c382194dcb4dc5c', name: "navigation-top" }), h("slot", { key: 'bcd036895810de895cfe78e654a3bb584f9d0480', name: "navigation-bottom" })), h("div", { key: 'b0ffe9b397e6a9535acbabd319fc8a37eabeef54', class: "spw-sidebar__resize-border", onClick: this.toggleSidebar }))));
54
62
  }
55
63
  static get is() { return "spw-sidebar"; }
56
64
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"spw-sidebar.js","sourceRoot":"","sources":["../../../src/components/spw-sidebar/spw-sidebar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAOzE,MAAM,OAAO,UAAU;IALvB;QAQE,iDAAiD;QACzC,oBAAe,GAAY,KAAK,CAAC;QAGhC,cAAS,GAAY,KAAK,CAAC;QAEnB,eAAU,GAAG,sBAAsB,CAAC;QAkB7C,kBAAa,GAAG,GAAG,EAAE;YAC3B,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC/B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjE,CAAC,CAAC;QAEM,qBAAgB,GAAG,GAAG,EAAE;YAC9B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAClE,CAAC,CAAC;KA6CH;IAnEC,iBAAiB;QACf,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,oBAAoB;;QAClB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,MAAA,IAAI,CAAC,QAAQ,0CAAE,UAAU,EAAE,CAAC;IAC9B,CAAC;IAWO,uBAAuB;QAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE;YACnC,UAAU,EAAE,IAAI;YAChB,eAAe,EAAE,CAAC,OAAO,CAAC;SAC3B,CAAC,CAAC;IACL,CAAC;IAED,IAAY,SAAS;QACnB,OAAO;YACL,YAAY,EAAE,IAAI,CAAC,QAAQ;YAC3B,aAAa,EAAE,CAAC,IAAI,CAAC,QAAQ;SAC9B,CAAC;IACJ,CAAC;IAED,IAAY,YAAY;QACtB,OAAO;YACL,aAAa,EAAE,IAAI;YACnB,uBAAuB,EAAE,IAAI,CAAC,QAAQ;YACtC,wBAAwB,EAAE,CAAC,IAAI,CAAC,QAAQ;YACxC,0BAA0B,EAAE,IAAI,CAAC,SAAS;SAC3C,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI,qDAAC,KAAK,EAAE,IAAI,CAAC,SAAS;YACzB,4DAAK,KAAK,EAAE,IAAI,CAAC,YAAY;gBAC3B,6DAAM,KAAK,EAAC,qBAAqB,EAAC,OAAO,EAAE,IAAI,CAAC,aAAa,mBAAiB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;oBACpG,iEAAU,IAAI,EAAC,kBAAkB,GAAY,CACxC;gBACP,4DAAK,KAAK,EAAC,sBAAsB;oBAC/B,6DAAM,IAAI,EAAC,gBAAgB,GAAQ;oBACnC,6DAAM,IAAI,EAAC,mBAAmB,GAAQ,CAClC;gBACN,4DAAK,KAAK,EAAC,4BAA4B,EAAC,OAAO,EAAE,IAAI,CAAC,aAAa,GAAQ,CACvE,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, h, Host, Element, Prop, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-sidebar',\n styleUrl: 'spw-sidebar.scss',\n shadow: true,\n})\nexport class SpwSidebar {\n @Element() el!: HTMLElement;\n\n /** Si true, la sidebar est dépliée par défaut */\n @Prop() defaultExpanded: boolean = false;\n\n @State() expanded: boolean;\n @State() hasTopbar: boolean = false;\n\n private readonly BODY_CLASS = 'spw-sidebar-expanded';\n private observer: MutationObserver;\n\n componentWillLoad() {\n this.expanded = this.defaultExpanded;\n if (this.expanded) {\n document.body.classList.add(this.BODY_CLASS);\n }\n\n this.checkTopbarClass();\n this.observeBodyClassChanges();\n }\n\n disconnectedCallback() {\n document.body.classList.remove(this.BODY_CLASS);\n this.observer?.disconnect();\n }\n\n private toggleSidebar = () => {\n this.expanded = !this.expanded;\n document.body.classList.toggle(this.BODY_CLASS, this.expanded);\n };\n\n private checkTopbarClass = () => {\n this.hasTopbar = document.body.classList.contains('has-topbar');\n };\n\n private observeBodyClassChanges() {\n this.observer = new MutationObserver(() => {\n this.checkTopbarClass();\n });\n\n this.observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['class'],\n });\n }\n\n private get hostClass() {\n return {\n '--expanded': this.expanded,\n '--collapsed': !this.expanded,\n };\n }\n\n private get elementClass() {\n return {\n 'spw-sidebar': true,\n 'spw-sidebar--expanded': this.expanded,\n 'spw-sidebar--collapsed': !this.expanded,\n 'spw-sidebar--with-topbar': this.hasTopbar,\n };\n }\n\n render() {\n return (\n <Host class={this.hostClass}>\n <div class={this.elementClass}>\n <span class=\"spw-sidebar__toggle\" onClick={this.toggleSidebar} aria-expanded={this.expanded.toString()}>\n <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </span>\n <div class=\"spw-sidebar__content\">\n <slot name=\"navigation-top\"></slot>\n <slot name=\"navigation-bottom\"></slot>\n </div>\n <div class=\"spw-sidebar__resize-border\" onClick={this.toggleSidebar}></div>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"spw-sidebar.js","sourceRoot":"","sources":["../../../src/components/spw-sidebar/spw-sidebar.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, h, Host, Element, Prop, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-sidebar',\n styleUrl: 'spw-sidebar.scss',\n shadow: true,\n})\nexport class SpwSidebar {\n @Element() el!: HTMLElement;\n\n /** Si true, la sidebar est dépliée par défaut */\n @Prop() defaultExpanded: boolean = false;\n\n @State() expanded: boolean;\n @State() hasTopbar: boolean = false;\n\n private readonly BODY_CLASS = 'spw-sidebar-expanded';\n private observer: MutationObserver;\n\n componentWillLoad() {\n this.expanded = this.defaultExpanded;\n if (this.expanded) {\n document.body.classList.add(this.BODY_CLASS);\n }\n\n this.checkTopbarClass();\n this.observeBodyClassChanges();\n }\n\n disconnectedCallback() {\n document.body.classList.remove(this.BODY_CLASS);\n this.observer?.disconnect();\n }\n\n private toggleSidebar = () => {\n this.expanded = !this.expanded;\n document.body.classList.toggle(this.BODY_CLASS, this.expanded);\n };\n\n private checkTopbarClass = () => {\n this.hasTopbar = document.body.classList.contains('has-topbar');\n };\n\n private checkExpandedState = () => {\n // Synchronise l'état interne avec la classe body\n const bodyHasExpandedClass = document.body.classList.contains(this.BODY_CLASS);\n if (this.expanded !== bodyHasExpandedClass) {\n this.expanded = bodyHasExpandedClass;\n }\n };\n\n private observeBodyClassChanges() {\n this.observer = new MutationObserver(() => {\n this.checkTopbarClass();\n this.checkExpandedState();\n });\n\n this.observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['class'],\n });\n }\n\n private get hostClass() {\n return {\n '--expanded': this.expanded,\n '--collapsed': !this.expanded,\n };\n }\n\n private get elementClass() {\n return {\n 'spw-sidebar': true,\n 'spw-sidebar--expanded': this.expanded,\n 'spw-sidebar--collapsed': !this.expanded,\n 'spw-sidebar--with-topbar': this.hasTopbar,\n };\n }\n\n render() {\n return (\n <Host class={this.hostClass}>\n <div class={this.elementClass}>\n <span class=\"spw-sidebar__toggle\" onClick={this.toggleSidebar} aria-expanded={this.expanded.toString()}>\n <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </span>\n <div class=\"spw-sidebar__content\">\n <slot name=\"navigation-top\"></slot>\n <slot name=\"navigation-bottom\"></slot>\n </div>\n <div class=\"spw-sidebar__resize-border\" onClick={this.toggleSidebar}></div>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -11,9 +11,11 @@ export class SpwSkeleton {
11
11
  const isLast = index === this.blocks - 1;
12
12
  const isEven = index % 2 === 1;
13
13
  const isOdd = index % 2 === 0;
14
+ const isOnly = this.blocks === 1;
14
15
  return (h("div", { class: {
15
16
  'spw-skeleton__line': true,
16
- 'spw-skeleton__line--last': isLast,
17
+ 'spw-skeleton__line--only': isOnly,
18
+ 'spw-skeleton__line--last': !isOnly && isLast,
17
19
  'spw-skeleton__line--even': !isLast && isEven,
18
20
  'spw-skeleton__line--odd': !isLast && isOdd,
19
21
  } }));
@@ -42,7 +44,7 @@ export class SpwSkeleton {
42
44
  }
43
45
  }
44
46
  render() {
45
- return (h(Host, { key: 'd09d57159d888a28edca9d579ee00fef11871279' }, h("div", { key: '6220d349418650cfb4dd368e692f85aa1b304b36', class: "spw-skeleton" }, this.renderVariant(), h("slot", { key: 'd830f7f5c7ed120e0aab5f81919947a26357fd5e' }))));
47
+ return (h(Host, { key: 'e7062026d9545a347b6fbcf89d1d34f703e0c283' }, h("div", { key: '1d663e0cd802f50a72186239fcade5e6a808ac76', class: "spw-skeleton" }, this.renderVariant(), h("slot", { key: '8cbd37e477730c2dd41acba2ac56ec66522379eb' }))));
46
48
  }
47
49
  static get is() { return "spw-skeleton"; }
48
50
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"spw-skeleton.js","sourceRoot":"","sources":["../../../src/components/spw-skeleton/spw-skeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAOzD,MAAM,OAAO,WAAW;IALxB;QAME,oFAAoF;QAC5E,WAAM,GAAW,CAAC,CAAC;QAE3B,kCAAkC;QAC1B,YAAO,GAA4C,OAAO,CAAC;KA4EpE;IA1ES,WAAW;QACjB,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;YACtD,MAAM,MAAM,GAAG,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YACzC,MAAM,MAAM,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;YAC/B,MAAM,KAAK,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;YAE9B,OAAO,CACL,WACE,KAAK,EAAE;oBACL,oBAAoB,EAAE,IAAI;oBAC1B,0BAA0B,EAAE,MAAM;oBAClC,0BAA0B,EAAE,CAAC,MAAM,IAAI,MAAM;oBAC7C,yBAAyB,EAAE,CAAC,MAAM,IAAI,KAAK;iBAC5C,GACI,CACR,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,UAAU;QAChB,OAAO,CACL,WAAK,KAAK,EAAC,oBAAoB;YAC7B,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB;YACxD,WAAK,KAAK,EAAC,0BAA0B,GAAO;YAC5C,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB,CACpD,CACP,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,OAAO,CACL,WAAK,KAAK,EAAC,uBAAuB;YAChC,WAAK,KAAK,EAAC,6BAA6B,GAAO;YAC/C,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB,CACpD,CACP,CAAC;IACJ,CAAC;IAEO,iBAAiB;QACvB,OAAO,CACL,WAAK,KAAK,EAAC,4BAA4B;YACrC,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB;YACxD,WAAK,KAAK,EAAC,uBAAuB;gBAChC,WAAK,KAAK,EAAC,sBAAsB,GAAO;gBACxC,WAAK,KAAK,EAAC,sBAAsB,GAAO,CACpC,CACF,CACP,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,QAAQ,IAAI,CAAC,OAAO,EAAE,CAAC;YACrB,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;YAC3B,KAAK,SAAS;gBACZ,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;YAC9B,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAClC,KAAK,OAAO,CAAC;YACb;gBACE,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,4DAAK,KAAK,EAAC,cAAc;gBACtB,IAAI,CAAC,aAAa,EAAE;gBACrB,8DAAa,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, Host, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-skeleton',\n styleUrl: 'spw-skeleton.scss',\n shadow: true,\n})\nexport class SpwSkeleton {\n /** Nombre de répétitions du skeleton (uniquement valable pour la variante lines) */\n @Prop() blocks: number = 1;\n\n /** Type de skeleton à afficher */\n @Prop() variant: 'lines' | 'text' | 'article' | 'layout' = 'lines';\n\n private renderLines() {\n return Array.from({ length: this.blocks }, (_, index) => {\n const isLast = index === this.blocks - 1;\n const isEven = index % 2 === 1;\n const isOdd = index % 2 === 0;\n\n return (\n <div\n class={{\n 'spw-skeleton__line': true,\n 'spw-skeleton__line--last': isLast,\n 'spw-skeleton__line--even': !isLast && isEven,\n 'spw-skeleton__line--odd': !isLast && isOdd,\n }}\n ></div>\n );\n });\n }\n\n private renderText() {\n return (\n <div class=\"spw-skeleton__text\">\n <spw-skeleton variant=\"lines\" blocks={5}></spw-skeleton>\n <div class=\"spw-skeleton__text-block\"></div>\n <spw-skeleton variant=\"lines\" blocks={2}></spw-skeleton>\n </div>\n );\n }\n\n private renderArticle() {\n return (\n <div class=\"spw-skeleton__article\">\n <div class=\"spw-skeleton__article-image\"></div>\n <spw-skeleton variant=\"lines\" blocks={7}></spw-skeleton>\n </div>\n );\n }\n\n private renderTextButtons() {\n return (\n <div class=\"spw-skeleton__text-buttons\">\n <spw-skeleton variant=\"lines\" blocks={3}></spw-skeleton>\n <div class=\"spw-skeleton__buttons\">\n <div class=\"spw-skeleton__button\"></div>\n <div class=\"spw-skeleton__button\"></div>\n </div>\n </div>\n );\n }\n\n private renderVariant() {\n switch (this.variant) {\n case 'text':\n return this.renderText();\n case 'article':\n return this.renderArticle();\n case 'layout':\n return this.renderTextButtons();\n case 'lines':\n default:\n return this.renderLines();\n }\n }\n\n render() {\n return (\n <Host>\n <div class=\"spw-skeleton\">\n {this.renderVariant()}\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"spw-skeleton.js","sourceRoot":"","sources":["../../../src/components/spw-skeleton/spw-skeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAOzD,MAAM,OAAO,WAAW;IALxB;QAME,oFAAoF;QAC5E,WAAM,GAAW,CAAC,CAAC;QAE3B,kCAAkC;QAC1B,YAAO,GAA4C,OAAO,CAAC;KA8EpE;IA5ES,WAAW;QACjB,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;YACtD,MAAM,MAAM,GAAG,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YACzC,MAAM,MAAM,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;YAC/B,MAAM,KAAK,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;YAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC;YAEjC,OAAO,CACL,WACE,KAAK,EAAE;oBACL,oBAAoB,EAAE,IAAI;oBAC1B,0BAA0B,EAAE,MAAM;oBAClC,0BAA0B,EAAE,CAAC,MAAM,IAAI,MAAM;oBAC7C,0BAA0B,EAAE,CAAC,MAAM,IAAI,MAAM;oBAC7C,yBAAyB,EAAE,CAAC,MAAM,IAAI,KAAK;iBAC5C,GACI,CACR,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,UAAU;QAChB,OAAO,CACL,WAAK,KAAK,EAAC,oBAAoB;YAC7B,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB;YACxD,WAAK,KAAK,EAAC,0BAA0B,GAAO;YAC5C,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB,CACpD,CACP,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,OAAO,CACL,WAAK,KAAK,EAAC,uBAAuB;YAChC,WAAK,KAAK,EAAC,6BAA6B,GAAO;YAC/C,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB,CACpD,CACP,CAAC;IACJ,CAAC;IAEO,iBAAiB;QACvB,OAAO,CACL,WAAK,KAAK,EAAC,4BAA4B;YACrC,oBAAc,OAAO,EAAC,OAAO,EAAC,MAAM,EAAE,CAAC,GAAiB;YACxD,WAAK,KAAK,EAAC,uBAAuB;gBAChC,WAAK,KAAK,EAAC,sBAAsB,GAAO;gBACxC,WAAK,KAAK,EAAC,sBAAsB,GAAO,CACpC,CACF,CACP,CAAC;IACJ,CAAC;IAEO,aAAa;QACnB,QAAQ,IAAI,CAAC,OAAO,EAAE,CAAC;YACrB,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;YAC3B,KAAK,SAAS;gBACZ,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;YAC9B,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAClC,KAAK,OAAO,CAAC;YACb;gBACE,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,MAAM;QACJ,OAAO,CACL,EAAC,IAAI;YACH,4DAAK,KAAK,EAAC,cAAc;gBACtB,IAAI,CAAC,aAAa,EAAE;gBACrB,8DAAa,CACT,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, Host, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-skeleton',\n styleUrl: 'spw-skeleton.scss',\n shadow: true,\n})\nexport class SpwSkeleton {\n /** Nombre de répétitions du skeleton (uniquement valable pour la variante lines) */\n @Prop() blocks: number = 1;\n\n /** Type de skeleton à afficher */\n @Prop() variant: 'lines' | 'text' | 'article' | 'layout' = 'lines';\n\n private renderLines() {\n return Array.from({ length: this.blocks }, (_, index) => {\n const isLast = index === this.blocks - 1;\n const isEven = index % 2 === 1;\n const isOdd = index % 2 === 0;\n const isOnly = this.blocks === 1;\n\n return (\n <div\n class={{\n 'spw-skeleton__line': true,\n 'spw-skeleton__line--only': isOnly,\n 'spw-skeleton__line--last': !isOnly && isLast,\n 'spw-skeleton__line--even': !isLast && isEven,\n 'spw-skeleton__line--odd': !isLast && isOdd,\n }}\n ></div>\n );\n });\n }\n\n private renderText() {\n return (\n <div class=\"spw-skeleton__text\">\n <spw-skeleton variant=\"lines\" blocks={5}></spw-skeleton>\n <div class=\"spw-skeleton__text-block\"></div>\n <spw-skeleton variant=\"lines\" blocks={2}></spw-skeleton>\n </div>\n );\n }\n\n private renderArticle() {\n return (\n <div class=\"spw-skeleton__article\">\n <div class=\"spw-skeleton__article-image\"></div>\n <spw-skeleton variant=\"lines\" blocks={7}></spw-skeleton>\n </div>\n );\n }\n\n private renderTextButtons() {\n return (\n <div class=\"spw-skeleton__text-buttons\">\n <spw-skeleton variant=\"lines\" blocks={3}></spw-skeleton>\n <div class=\"spw-skeleton__buttons\">\n <div class=\"spw-skeleton__button\"></div>\n <div class=\"spw-skeleton__button\"></div>\n </div>\n </div>\n );\n }\n\n private renderVariant() {\n switch (this.variant) {\n case 'text':\n return this.renderText();\n case 'article':\n return this.renderArticle();\n case 'layout':\n return this.renderTextButtons();\n case 'lines':\n default:\n return this.renderLines();\n }\n }\n\n render() {\n return (\n <Host>\n <div class=\"spw-skeleton\">\n {this.renderVariant()}\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -5,7 +5,7 @@ export class SpwSocials {
5
5
  this.mainTitle = 'Restez connecté';
6
6
  }
7
7
  render() {
8
- return (h(Host, { key: 'd2c120f651461ddbe1115d8e848b610132d3a287' }, h("div", { key: '200fabf8d9086a1686c5d296f7d456f46622cb27', class: "spw-socials" }, h("div", { key: '5e038715b91cdf5813b3c72d5d1f987ed06a6609', class: "spw-ds-container" }, h("h2", { key: '4d3fc6a5266625ad177c863b49318f89a3d3147f', class: "spw-socials__title" }, this.mainTitle), h("div", { key: '2d86cbd2650709d0d56df013fda5b02fa7e929ef', class: "spw-socials__content" }, h("slot", { key: '1d911bbdf0cd21be24ed7189e7bd0a544032148d' }))))));
8
+ return (h(Host, { key: 'cc2f013bf881c62e70cf8cb91510a5365a633c5c' }, h("div", { key: 'c5f6d4e900ffb335ed9f42ae079faae0a32d19d3', class: "spw-socials" }, h("div", { key: '736f58dbacfceb1e9496649419387f30b004e0ec', class: "spw-ds-container" }, h("h2", { key: 'b0f6cef192dc8bcd3341ec77e175b8c65af212a9', class: "spw-socials__title" }, this.mainTitle), h("div", { key: '50f458edcbd2b916b2af17f44183da7f51b85814', class: "spw-socials__content" }, h("slot", { key: 'bb7295144384b95b711ac790b2d6d4acd6bac1cb' }))))));
9
9
  }
10
10
  static get is() { return "spw-socials"; }
11
11
  static get encapsulation() { return "shadow"; }
@@ -23,7 +23,7 @@ export class SpwTableBody {
23
23
  });
24
24
  }
25
25
  render() {
26
- return (h("tbody", { key: '754040d04173dc5c19de98b2cb403de47eef74d5', part: "tbody" }, h("slot", { key: '03a71f3b518d53314d9e3315b3104be49be0ae01' })));
26
+ return (h("tbody", { key: '330fbfaa3436450e51a3840a1085414c81bba9bc', part: "tbody" }, h("slot", { key: 'd999d2e59c274e494d7d2aaa4ba83bfabda82395' })));
27
27
  }
28
28
  static get is() { return "spw-table-body"; }
29
29
  static get encapsulation() { return "shadow"; }
@@ -1,2 +1,2 @@
1
1
 
2
- /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:contents;font-size:100%;line-height:1.3}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-table-cell{border:1px solid var(--spw-color-themes-grey-grey-300);border-top:0;color:var(--spw-color-themes-grey-grey-800);font-size:14px;text-align:left}.spw-table-cell--is-highlighted{background:var(--spw-color-themes-grey-grey-100);font-weight:700}.spw-table-cell--text-align-left{text-align:left}.spw-table-cell--text-align-center{text-align:center}.spw-table-cell--text-align-right{text-align:right}.spw-table-cell--vertical-align-top{vertical-align:top}.spw-table-cell--vertical-align-bottom{vertical-align:bottom}.spw-table-cell--vertical-align-middle{vertical-align:middle}.spw-table-cell--padding-small{padding:8px}.spw-table-cell--padding-medium{padding:16px}.spw-table-cell ::slotted(spw-checkbox){--spw-ds-checkbox-checked-color:#000}
2
+ /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:contents;font-size:100%;line-height:1.3}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}:host(.--selected) .spw-table-cell{background-color:var(--spw-color-themes-blue-blue-50)}:host(.--selected) .spw-table-cell.spw-table-cell--first-in-row{box-shadow:inset 3px 0 0 var(--spw-color-themes-blue-blue-500)}:host(.--disabled) .spw-table-cell,:host(.--disabled) .spw-table-cell--sticky{position:relative}:host(.--disabled) .spw-table-cell--sticky:before,:host(.--disabled) .spw-table-cell:before{background:var(--spw-ds-white);bottom:1px;content:"";cursor:not-allowed;left:0;opacity:.7;position:absolute;right:0;top:0;z-index:8}.spw-table-cell{border:1px solid var(--spw-color-themes-grey-grey-300);border-top:0;color:var(--spw-color-themes-grey-grey-800);font-size:14px;text-align:left}.spw-table-cell--is-highlighted{background:var(--spw-color-themes-grey-grey-100);font-weight:700}.spw-table-cell--text-align-left{text-align:left}.spw-table-cell--text-align-center{text-align:center}.spw-table-cell--text-align-right{text-align:right}.spw-table-cell--vertical-align-top{vertical-align:top}.spw-table-cell--vertical-align-bottom{vertical-align:bottom}.spw-table-cell--vertical-align-middle{vertical-align:middle}.spw-table-cell--padding-small{padding:8px}.spw-table-cell--padding-medium{padding:16px}.spw-table-cell--disabled{cursor:not-allowed;opacity:.3;pointer-events:none}.spw-table-cell--selected{background-color:var(--spw-color-themes-blue-blue-50)}.spw-table-cell--selected.spw-table-cell--first-in-row{box-shadow:inset 3px 0 0 var(--spw-color-themes-blue-blue-500)}.spw-table-cell ::slotted(spw-checkbox){--spw-ds-checkbox-checked-color:#000}.spw-table-cell--sticky{background-color:var(--spw-color-themes-grey-grey-50);position:sticky}.spw-table-cell--sticky:after{bottom:-1px;content:"";pointer-events:none;position:absolute;top:0;transition:opacity .2s;width:8px}.spw-table-cell--sticky-start:after{box-shadow:inset 8px 0 8px -8px rgba(0,0,0,.15);right:-8px}.spw-table-cell--sticky-end:after{box-shadow:inset -8px 0 8px -8px rgba(0,0,0,.15);left:-8px}.spw-table-cell--sticky.spw-table-cell--selected{background-color:var(--spw-color-themes-blue-blue-50)}.spw-table-cell--sticky.spw-table-cell--is-highlighted{background-color:var(--spw-color-themes-grey-grey-100)}:host(.--selected) .spw-table-cell--sticky{background-color:var(--spw-color-themes-blue-blue-50)}
@@ -11,6 +11,39 @@ export class SpwTableCell {
11
11
  this.width = 'auto';
12
12
  /** Définit le padding pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */
13
13
  this.padding = 'medium';
14
+ /** Permet de changer le state du spw-table-cell */
15
+ this.state = 'default';
16
+ /** Rend la cellule sticky lors du défilement (à appliquer sur spw-table-header ou spw-table-cell) */
17
+ this.sticky = false;
18
+ /** Position du sticky : 'start' (left: 0) ou 'end' (right: 0) (à appliquer sur spw-table-header ou spw-table-cell) */
19
+ this.stickyPosition = 'start';
20
+ /** Décalage en pixels pour le sticky (utile pour empiler plusieurs colonnes sticky) (à appliquer sur spw-table-header ou spw-table-cell) */
21
+ this.stickyOffset = 0;
22
+ this.isFirst = false;
23
+ }
24
+ componentDidLoad() {
25
+ this.checkIfFirst();
26
+ this.observeRowSlot();
27
+ }
28
+ disconnectedCallback() {
29
+ var _a;
30
+ (_a = this.slotObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
31
+ }
32
+ checkIfFirst() {
33
+ const parentRow = this.el.closest('spw-table-row');
34
+ if (!parentRow) {
35
+ this.isFirst = false;
36
+ return;
37
+ }
38
+ const cells = Array.from(parentRow.children).filter((el) => el.tagName === 'SPW-TABLE-CELL' || el.tagName === 'SPW-TABLE-HEADER' || el.tagName === 'TD' || el.tagName === 'TH');
39
+ this.isFirst = cells[0] === this.el;
40
+ }
41
+ observeRowSlot() {
42
+ const parentRow = this.el.closest('spw-table-row');
43
+ if (!parentRow)
44
+ return;
45
+ this.slotObserver = new MutationObserver(() => this.checkIfFirst());
46
+ this.slotObserver.observe(parentRow, { childList: true, subtree: false });
14
47
  }
15
48
  get elementClass() {
16
49
  return {
@@ -19,6 +52,10 @@ export class SpwTableCell {
19
52
  [`spw-table-cell--text-align-${this.textAlign}`]: true,
20
53
  [`spw-table-cell--padding-${this.padding}`]: true,
21
54
  [`spw-table-cell--vertical-align-${this.verticalAlign}`]: true,
55
+ [`spw-table-cell--${this.state}`]: true,
56
+ 'spw-table-cell--first-in-row': this.isFirst,
57
+ 'spw-table-cell--sticky': this.sticky,
58
+ [`spw-table-cell--sticky-${this.stickyPosition}`]: this.sticky,
22
59
  };
23
60
  }
24
61
  render() {
@@ -33,7 +70,20 @@ export class SpwTableCell {
33
70
  attrs.rowSpan = this.rowspan;
34
71
  if (this.headers !== undefined)
35
72
  attrs.headers = this.headers;
36
- return (h("td", Object.assign({ key: '90b5ba037780b40461e2fbfff278fa3e46d4fa79' }, attrs), h("slot", { key: '6e8d211652ff81ec279445597e0d20e9bd783857' })));
73
+ if (this.sticky) {
74
+ const stickyStyles = {
75
+ position: 'sticky',
76
+ zIndex: '10',
77
+ };
78
+ if (this.stickyPosition === 'start') {
79
+ stickyStyles.left = `${this.stickyOffset}px`;
80
+ }
81
+ else {
82
+ stickyStyles.right = `${this.stickyOffset}px`;
83
+ }
84
+ attrs.style = stickyStyles;
85
+ }
86
+ return (h("td", Object.assign({ key: '27bf04742118714d6b54e104929909a392d1995c' }, attrs), h("slot", { key: '8c3ba8fd30c331af629cd030c93047f9931829e3' })));
37
87
  }
38
88
  static get is() { return "spw-table-cell"; }
39
89
  static get encapsulation() { return "shadow"; }
@@ -220,8 +270,94 @@ export class SpwTableCell {
220
270
  "attribute": "padding",
221
271
  "reflect": false,
222
272
  "defaultValue": "'medium'"
273
+ },
274
+ "state": {
275
+ "type": "string",
276
+ "mutable": false,
277
+ "complexType": {
278
+ "original": "'default' | 'selected' | 'disabled'",
279
+ "resolved": "\"default\" | \"disabled\" | \"selected\"",
280
+ "references": {}
281
+ },
282
+ "required": false,
283
+ "optional": true,
284
+ "docs": {
285
+ "tags": [],
286
+ "text": "Permet de changer le state du spw-table-cell"
287
+ },
288
+ "getter": false,
289
+ "setter": false,
290
+ "attribute": "state",
291
+ "reflect": false,
292
+ "defaultValue": "'default'"
293
+ },
294
+ "sticky": {
295
+ "type": "boolean",
296
+ "mutable": false,
297
+ "complexType": {
298
+ "original": "boolean",
299
+ "resolved": "boolean",
300
+ "references": {}
301
+ },
302
+ "required": false,
303
+ "optional": true,
304
+ "docs": {
305
+ "tags": [],
306
+ "text": "Rend la cellule sticky lors du d\u00E9filement (\u00E0 appliquer sur spw-table-header ou spw-table-cell)"
307
+ },
308
+ "getter": false,
309
+ "setter": false,
310
+ "attribute": "sticky",
311
+ "reflect": false,
312
+ "defaultValue": "false"
313
+ },
314
+ "stickyPosition": {
315
+ "type": "string",
316
+ "mutable": false,
317
+ "complexType": {
318
+ "original": "'start' | 'end'",
319
+ "resolved": "\"end\" | \"start\"",
320
+ "references": {}
321
+ },
322
+ "required": false,
323
+ "optional": true,
324
+ "docs": {
325
+ "tags": [],
326
+ "text": "Position du sticky : 'start' (left: 0) ou 'end' (right: 0) (\u00E0 appliquer sur spw-table-header ou spw-table-cell)"
327
+ },
328
+ "getter": false,
329
+ "setter": false,
330
+ "attribute": "sticky-position",
331
+ "reflect": false,
332
+ "defaultValue": "'start'"
333
+ },
334
+ "stickyOffset": {
335
+ "type": "number",
336
+ "mutable": false,
337
+ "complexType": {
338
+ "original": "number",
339
+ "resolved": "number",
340
+ "references": {}
341
+ },
342
+ "required": false,
343
+ "optional": true,
344
+ "docs": {
345
+ "tags": [],
346
+ "text": "D\u00E9calage en pixels pour le sticky (utile pour empiler plusieurs colonnes sticky) (\u00E0 appliquer sur spw-table-header ou spw-table-cell)"
347
+ },
348
+ "getter": false,
349
+ "setter": false,
350
+ "attribute": "sticky-offset",
351
+ "reflect": false,
352
+ "defaultValue": "0"
223
353
  }
224
354
  };
225
355
  }
356
+ static get states() {
357
+ return {
358
+ "isFirst": {}
359
+ };
360
+ }
361
+ static get elementRef() { return "el"; }
226
362
  }
227
363
  //# sourceMappingURL=spw-table-cell.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"spw-table-cell.js","sourceRoot":"","sources":["../../../../src/components/spw-table/spw-table-cell/spw-table-cell.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAOnD,MAAM,OAAO,YAAY;IALzB;QAYE,+GAA+G;QACvG,kBAAa,GAAa,KAAK,CAAC;QACxC,0GAA0G;QAClG,cAAS,GAAiC,MAAM,CAAC;QACzD,0GAA0G;QAClG,kBAAa,GAAiC,QAAQ,CAAC;QAC/D,yEAAyE;QACjE,UAAK,GAAY,MAAM,CAAC;QAChC,8FAA8F;QACtF,YAAO,GAAwB,QAAQ,CAAC;KA6BjD;IA3BC,IAAY,YAAY;QACtB,OAAO;YACL,gBAAgB,EAAE,IAAI;YACtB,gCAAgC,EAAE,IAAI,CAAC,aAAa;YACpD,CAAC,8BAA8B,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,IAAI;YACtD,CAAC,2BAA2B,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI;YACjD,CAAC,kCAAkC,IAAI,CAAC,aAAa,EAAE,CAAC,EAAE,IAAI;SAC/D,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,MAAM,KAAK,GAA2B;YACpC,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,YAAY;YACxB,IAAI,EAAE,MAAM;SACb,CAAC;QAEF,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;YAAE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7D,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;YAAE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7D,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;YAAE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAE7D,OAAO,CACL,2EAAQ,KAAK;YACX,8DAAQ,CACL,CACN,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-table-cell',\n styleUrl: 'spw-table-cell.scss',\n shadow: true,\n})\nexport class SpwTableCell {\n /** Définit un colspan pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() colspan?: HTMLTableCellElement['colSpan'];\n /** Définit un header relationnel pour la cellule, à des fins d'accessibilité (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() headers?: HTMLTableCellElement['headers'];\n /** Définit un rowspan pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() rowspan?: HTMLTableCellElement['rowSpan'];\n /** Définit un style visuel qui met en avant la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() isHighlighted?: boolean = false;\n /** Définit un alignement de texte pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() textAlign?: 'center' | 'left' | 'right' = 'left';\n /** Définit un alignement vertical pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() verticalAlign?: 'top' | 'bottom' | 'middle' = 'middle';\n /** Définit une largeur si nécessaire (à appliquer sur spw-table-cell) */\n @Prop() width?: string = 'auto';\n /** Définit le padding pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() padding?: 'small' | 'medium' = 'medium';\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-table-cell': true,\n 'spw-table-cell--is-highlighted': this.isHighlighted,\n [`spw-table-cell--text-align-${this.textAlign}`]: true,\n [`spw-table-cell--padding-${this.padding}`]: true,\n [`spw-table-cell--vertical-align-${this.verticalAlign}`]: true,\n };\n }\n\n render() {\n const attrs: { [key: string]: any } = {\n width: this.width,\n class: this.elementClass,\n part: 'cell',\n };\n\n if (this.colspan !== undefined) attrs.colSpan = this.colspan;\n if (this.rowspan !== undefined) attrs.rowSpan = this.rowspan;\n if (this.headers !== undefined) attrs.headers = this.headers;\n\n return (\n <td {...attrs}>\n <slot />\n </td>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"spw-table-cell.js","sourceRoot":"","sources":["../../../../src/components/spw-table/spw-table-cell/spw-table-cell.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, State, Prop, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-table-cell',\n styleUrl: 'spw-table-cell.scss',\n shadow: true,\n})\nexport class SpwTableCell {\n @Element() el: HTMLElement;\n /** Définit un colspan pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() colspan?: HTMLTableCellElement['colSpan'];\n /** Définit un header relationnel pour la cellule, à des fins d'accessibilité (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() headers?: HTMLTableCellElement['headers'];\n /** Définit un rowspan pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() rowspan?: HTMLTableCellElement['rowSpan'];\n /** Définit un style visuel qui met en avant la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() isHighlighted?: boolean = false;\n /** Définit un alignement de texte pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() textAlign?: 'center' | 'left' | 'right' = 'left';\n /** Définit un alignement vertical pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() verticalAlign?: 'top' | 'bottom' | 'middle' = 'middle';\n /** Définit une largeur si nécessaire (à appliquer sur spw-table-cell) */\n @Prop() width?: string = 'auto';\n /** Définit le padding pour la cellule (à appliquer sur spw-table-cell ou spw-table-header) */\n @Prop() padding?: 'small' | 'medium' = 'medium';\n /** Permet de changer le state du spw-table-cell */\n @Prop() state?: 'default' | 'selected' | 'disabled' = 'default';\n /** Rend la cellule sticky lors du défilement (à appliquer sur spw-table-header ou spw-table-cell) */\n @Prop() sticky?: boolean = false;\n /** Position du sticky : 'start' (left: 0) ou 'end' (right: 0) (à appliquer sur spw-table-header ou spw-table-cell) */\n @Prop() stickyPosition?: 'start' | 'end' = 'start';\n /** Décalage en pixels pour le sticky (utile pour empiler plusieurs colonnes sticky) (à appliquer sur spw-table-header ou spw-table-cell) */\n @Prop() stickyOffset?: number = 0;\n\n @State() isFirst: boolean = false;\n\n private slotObserver?: MutationObserver;\n\n componentDidLoad() {\n this.checkIfFirst();\n this.observeRowSlot();\n }\n\n disconnectedCallback() {\n this.slotObserver?.disconnect();\n }\n\n private checkIfFirst() {\n const parentRow = this.el.closest('spw-table-row');\n if (!parentRow) {\n this.isFirst = false;\n return;\n }\n const cells = Array.from(parentRow.children).filter(\n (el: Element) => el.tagName === 'SPW-TABLE-CELL' || el.tagName === 'SPW-TABLE-HEADER' || el.tagName === 'TD' || el.tagName === 'TH',\n );\n this.isFirst = cells[0] === this.el;\n }\n\n private observeRowSlot() {\n const parentRow = this.el.closest('spw-table-row');\n if (!parentRow) return;\n this.slotObserver = new MutationObserver(() => this.checkIfFirst());\n this.slotObserver.observe(parentRow, { childList: true, subtree: false });\n }\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-table-cell': true,\n 'spw-table-cell--is-highlighted': this.isHighlighted,\n [`spw-table-cell--text-align-${this.textAlign}`]: true,\n [`spw-table-cell--padding-${this.padding}`]: true,\n [`spw-table-cell--vertical-align-${this.verticalAlign}`]: true,\n [`spw-table-cell--${this.state}`]: true,\n 'spw-table-cell--first-in-row': this.isFirst,\n 'spw-table-cell--sticky': this.sticky,\n [`spw-table-cell--sticky-${this.stickyPosition}`]: this.sticky,\n };\n }\n\n render() {\n const attrs: { [key: string]: any } = {\n width: this.width,\n class: this.elementClass,\n part: 'cell',\n };\n\n if (this.colspan !== undefined) attrs.colSpan = this.colspan;\n if (this.rowspan !== undefined) attrs.rowSpan = this.rowspan;\n if (this.headers !== undefined) attrs.headers = this.headers;\n\n if (this.sticky) {\n const stickyStyles: { [key: string]: string } = {\n position: 'sticky',\n zIndex: '10',\n };\n\n if (this.stickyPosition === 'start') {\n stickyStyles.left = `${this.stickyOffset}px`;\n } else {\n stickyStyles.right = `${this.stickyOffset}px`;\n }\n\n attrs.style = stickyStyles;\n }\n\n return (\n <td {...attrs}>\n <slot />\n </td>\n );\n }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
 
2
- /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:contents;font-size:100%;line-height:1.3}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-table-footer{align-items:center;caption-side:bottom;color:var(--spw-color-themes-grey-grey-900);display:flex;font-size:14px;gap:16px;justify-content:space-between;padding:16px 24px}.spw-table-footer ::slotted([slot=right]){align-items:center;display:inline-flex;gap:8px}
2
+ /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:contents;font-size:100%;line-height:1.3}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}:host(.--is-sticky) caption{bottom:0;position:sticky;z-index:20}caption{background:var(--spw-ds-white);border:1px solid var(--spw-color-themes-grey-grey-300)}.spw-table-footer{align-items:center;caption-side:bottom;color:var(--spw-color-themes-grey-grey-900);display:flex;font-size:14px;gap:16px;justify-content:space-between;padding:16px 24px}.spw-table-footer ::slotted([slot=right]){align-items:center;display:inline-flex;gap:8px}