@spw-ds/spw-stencil-library 0.0.1

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 (652) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +16 -0
  3. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  4. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  5. package/dist/cjs/index-55fbdb28.js +1956 -0
  6. package/dist/cjs/index-55fbdb28.js.map +1 -0
  7. package/dist/cjs/index.cjs.js +4 -0
  8. package/dist/cjs/index.cjs.js.map +1 -0
  9. package/dist/cjs/loader.cjs.js +17 -0
  10. package/dist/cjs/loader.cjs.js.map +1 -0
  11. package/dist/cjs/spw-accordion_58.cjs.entry.js +5955 -0
  12. package/dist/cjs/spw-accordion_58.cjs.entry.js.map +1 -0
  13. package/dist/cjs/spw-stencil-library.cjs.js +27 -0
  14. package/dist/cjs/spw-stencil-library.cjs.js.map +1 -0
  15. package/dist/collection/assets/images/logo.svg +3 -0
  16. package/dist/collection/collection-manifest.json +69 -0
  17. package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.css +2 -0
  18. package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.js +91 -0
  19. package/dist/collection/components/spw-accordion/spw-accordion-content/spw-accordion-content.js.map +1 -0
  20. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.css +2 -0
  21. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.js +146 -0
  22. package/dist/collection/components/spw-accordion/spw-accordion-item/spw-accordion-item.js.map +1 -0
  23. package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.css +2 -0
  24. package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.js +64 -0
  25. package/dist/collection/components/spw-accordion/spw-accordion-title/spw-accordion-title.js.map +1 -0
  26. package/dist/collection/components/spw-accordion/spw-accordion.css +2 -0
  27. package/dist/collection/components/spw-accordion/spw-accordion.js +19 -0
  28. package/dist/collection/components/spw-accordion/spw-accordion.js.map +1 -0
  29. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.css +2 -0
  30. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js +83 -0
  31. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.js.map +1 -0
  32. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.css +2 -0
  33. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.js +97 -0
  34. package/dist/collection/components/spw-breadcrumb/spw-breadcrumb.js.map +1 -0
  35. package/dist/collection/components/spw-button/spw-button.css +2 -0
  36. package/dist/collection/components/spw-button/spw-button.js +444 -0
  37. package/dist/collection/components/spw-button/spw-button.js.map +1 -0
  38. package/dist/collection/components/spw-card/spw-card-content/spw-card-content.css +2 -0
  39. package/dist/collection/components/spw-card/spw-card-content/spw-card-content.js +69 -0
  40. package/dist/collection/components/spw-card/spw-card-content/spw-card-content.js.map +1 -0
  41. package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.css +2 -0
  42. package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.js +52 -0
  43. package/dist/collection/components/spw-card/spw-card-excerpt/spw-card-excerpt.js.map +1 -0
  44. package/dist/collection/components/spw-card/spw-card-image/spw-card-image.css +2 -0
  45. package/dist/collection/components/spw-card/spw-card-image/spw-card-image.js +62 -0
  46. package/dist/collection/components/spw-card/spw-card-image/spw-card-image.js.map +1 -0
  47. package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.css +2 -0
  48. package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.js +54 -0
  49. package/dist/collection/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.js.map +1 -0
  50. package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.css +2 -0
  51. package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.js +62 -0
  52. package/dist/collection/components/spw-card/spw-card-subtags/spw-card-subtags.js.map +1 -0
  53. package/dist/collection/components/spw-card/spw-card-title/spw-card-title.css +2 -0
  54. package/dist/collection/components/spw-card/spw-card-title/spw-card-title.js +19 -0
  55. package/dist/collection/components/spw-card/spw-card-title/spw-card-title.js.map +1 -0
  56. package/dist/collection/components/spw-card/spw-card.css +2 -0
  57. package/dist/collection/components/spw-card/spw-card.js +314 -0
  58. package/dist/collection/components/spw-card/spw-card.js.map +1 -0
  59. package/dist/collection/components/spw-checkbox/spw-checkbox.css +2 -0
  60. package/dist/collection/components/spw-checkbox/spw-checkbox.js +238 -0
  61. package/dist/collection/components/spw-checkbox/spw-checkbox.js.map +1 -0
  62. package/dist/collection/components/spw-cookies/spw-cookies.css +2 -0
  63. package/dist/collection/components/spw-cookies/spw-cookies.js +166 -0
  64. package/dist/collection/components/spw-cookies/spw-cookies.js.map +1 -0
  65. package/dist/collection/components/spw-custom-select/spw-custom-select.css +2 -0
  66. package/dist/collection/components/spw-custom-select/spw-custom-select.js +680 -0
  67. package/dist/collection/components/spw-custom-select/spw-custom-select.js.map +1 -0
  68. package/dist/collection/components/spw-field-label/spw-field-label.css +2 -0
  69. package/dist/collection/components/spw-field-label/spw-field-label.js +89 -0
  70. package/dist/collection/components/spw-field-label/spw-field-label.js.map +1 -0
  71. package/dist/collection/components/spw-field-message/spw-field-message.css +2 -0
  72. package/dist/collection/components/spw-field-message/spw-field-message.js +80 -0
  73. package/dist/collection/components/spw-field-message/spw-field-message.js.map +1 -0
  74. package/dist/collection/components/spw-file-upload/spw-file-upload.css +2 -0
  75. package/dist/collection/components/spw-file-upload/spw-file-upload.js +411 -0
  76. package/dist/collection/components/spw-file-upload/spw-file-upload.js.map +1 -0
  77. package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.css +2 -0
  78. package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js +44 -0
  79. package/dist/collection/components/spw-footer/spw-footer-bottom/spw-footer-bottom.js.map +1 -0
  80. package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.css +2 -0
  81. package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js +32 -0
  82. package/dist/collection/components/spw-footer/spw-footer-content/spw-footer-content.js.map +1 -0
  83. package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.css +2 -0
  84. package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js +43 -0
  85. package/dist/collection/components/spw-footer/spw-footer-content-col/spw-footer-content-col.js.map +1 -0
  86. package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.css +2 -0
  87. package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js +62 -0
  88. package/dist/collection/components/spw-footer/spw-footer-link/spw-footer-link.js.map +1 -0
  89. package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.css +2 -0
  90. package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.js +19 -0
  91. package/dist/collection/components/spw-footer/spw-footer-socials/spw-footer-socials.js.map +1 -0
  92. package/dist/collection/components/spw-footer/spw-footer.css +2 -0
  93. package/dist/collection/components/spw-footer/spw-footer.js +113 -0
  94. package/dist/collection/components/spw-footer/spw-footer.js.map +1 -0
  95. package/dist/collection/components/spw-group/spw-group.css +2 -0
  96. package/dist/collection/components/spw-group/spw-group.js +181 -0
  97. package/dist/collection/components/spw-group/spw-group.js.map +1 -0
  98. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.css +2 -0
  99. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js +46 -0
  100. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js.map +1 -0
  101. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.css +2 -0
  102. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js +44 -0
  103. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js.map +1 -0
  104. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.css +2 -0
  105. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js +70 -0
  106. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js.map +1 -0
  107. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.css +2 -0
  108. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js +19 -0
  109. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js.map +1 -0
  110. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.css +2 -0
  111. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js +193 -0
  112. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js.map +1 -0
  113. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.css +2 -0
  114. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js +51 -0
  115. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js.map +1 -0
  116. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.css +2 -0
  117. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js +44 -0
  118. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js.map +1 -0
  119. package/dist/collection/components/spw-header/spw-header.css +2 -0
  120. package/dist/collection/components/spw-header/spw-header.js +36 -0
  121. package/dist/collection/components/spw-header/spw-header.js.map +1 -0
  122. package/dist/collection/components/spw-icon/assets/LICENSE.txt +165 -0
  123. package/dist/collection/components/spw-icon/assets/all.css +7913 -0
  124. package/dist/collection/components/spw-icon/assets/all.min.css +9 -0
  125. package/dist/collection/components/spw-icon/assets/brands.css +1609 -0
  126. package/dist/collection/components/spw-icon/assets/brands.min.css +6 -0
  127. package/dist/collection/components/spw-icon/assets/fa-brands-400.ttf +0 -0
  128. package/dist/collection/components/spw-icon/assets/fa-brands-400.woff2 +0 -0
  129. package/dist/collection/components/spw-icon/assets/fa-regular-400.ttf +0 -0
  130. package/dist/collection/components/spw-icon/assets/fa-regular-400.woff2 +0 -0
  131. package/dist/collection/components/spw-icon/assets/fa-solid-900.ttf +0 -0
  132. package/dist/collection/components/spw-icon/assets/fa-solid-900.woff2 +0 -0
  133. package/dist/collection/components/spw-icon/assets/fa-v4compatibility.ttf +0 -0
  134. package/dist/collection/components/spw-icon/assets/fa-v4compatibility.woff2 +0 -0
  135. package/dist/collection/components/spw-icon/assets/fontawesome.css +6243 -0
  136. package/dist/collection/components/spw-icon/assets/fontawesome.min.css +9 -0
  137. package/dist/collection/components/spw-icon/assets/regular.css +19 -0
  138. package/dist/collection/components/spw-icon/assets/regular.min.css +6 -0
  139. package/dist/collection/components/spw-icon/assets/solid.css +19 -0
  140. package/dist/collection/components/spw-icon/assets/solid.min.css +6 -0
  141. package/dist/collection/components/spw-icon/assets/svg-with-js.css +461 -0
  142. package/dist/collection/components/spw-icon/assets/svg-with-js.min.css +6 -0
  143. package/dist/collection/components/spw-icon/assets/v4-font-face.css +26 -0
  144. package/dist/collection/components/spw-icon/assets/v4-font-face.min.css +6 -0
  145. package/dist/collection/components/spw-icon/assets/v4-shims.css +2194 -0
  146. package/dist/collection/components/spw-icon/assets/v4-shims.min.css +6 -0
  147. package/dist/collection/components/spw-icon/assets/v5-font-face.css +22 -0
  148. package/dist/collection/components/spw-icon/assets/v5-font-face.min.css +6 -0
  149. package/dist/collection/components/spw-icon/spw-icon.css +10 -0
  150. package/dist/collection/components/spw-icon/spw-icon.js +64 -0
  151. package/dist/collection/components/spw-icon/spw-icon.js.map +1 -0
  152. package/dist/collection/components/spw-iodda/spw-iodda.css +2 -0
  153. package/dist/collection/components/spw-iodda/spw-iodda.js +113 -0
  154. package/dist/collection/components/spw-iodda/spw-iodda.js.map +1 -0
  155. package/dist/collection/components/spw-iodda/spw-iodda.service.js +19 -0
  156. package/dist/collection/components/spw-iodda/spw-iodda.service.js.map +1 -0
  157. package/dist/collection/components/spw-link/spw-link.css +2 -0
  158. package/dist/collection/components/spw-link/spw-link.js +220 -0
  159. package/dist/collection/components/spw-link/spw-link.js.map +1 -0
  160. package/dist/collection/components/spw-loading/spw-loading.css +2 -0
  161. package/dist/collection/components/spw-loading/spw-loading.js +44 -0
  162. package/dist/collection/components/spw-loading/spw-loading.js.map +1 -0
  163. package/dist/collection/components/spw-message/spw-message.css +2 -0
  164. package/dist/collection/components/spw-message/spw-message.js +141 -0
  165. package/dist/collection/components/spw-message/spw-message.js.map +1 -0
  166. package/dist/collection/components/spw-message/utils.js +27 -0
  167. package/dist/collection/components/spw-modal/spw-modal.css +2 -0
  168. package/dist/collection/components/spw-modal/spw-modal.js +361 -0
  169. package/dist/collection/components/spw-modal/spw-modal.js.map +1 -0
  170. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.css +2 -0
  171. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js +40 -0
  172. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js.map +1 -0
  173. package/dist/collection/components/spw-mosaic/spw-mosaic.css +2 -0
  174. package/dist/collection/components/spw-mosaic/spw-mosaic.js +301 -0
  175. package/dist/collection/components/spw-mosaic/spw-mosaic.js.map +1 -0
  176. package/dist/collection/components/spw-pagination/spw-pagination.css +2 -0
  177. package/dist/collection/components/spw-pagination/spw-pagination.js +305 -0
  178. package/dist/collection/components/spw-pagination/spw-pagination.js.map +1 -0
  179. package/dist/collection/components/spw-radio/spw-radio.css +2 -0
  180. package/dist/collection/components/spw-radio/spw-radio.js +248 -0
  181. package/dist/collection/components/spw-radio/spw-radio.js.map +1 -0
  182. package/dist/collection/components/spw-search-field/spw-search-field.css +2 -0
  183. package/dist/collection/components/spw-search-field/spw-search-field.js +287 -0
  184. package/dist/collection/components/spw-search-field/spw-search-field.js.map +1 -0
  185. package/dist/collection/components/spw-select/spw-select.css +2 -0
  186. package/dist/collection/components/spw-select/spw-select.js +374 -0
  187. package/dist/collection/components/spw-select/spw-select.js.map +1 -0
  188. package/dist/collection/components/spw-separator/spw-separator.css +2 -0
  189. package/dist/collection/components/spw-separator/spw-separator.js +134 -0
  190. package/dist/collection/components/spw-separator/spw-separator.js.map +1 -0
  191. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.css +2 -0
  192. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js +19 -0
  193. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js.map +1 -0
  194. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.css +2 -0
  195. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js +159 -0
  196. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js.map +1 -0
  197. package/dist/collection/components/spw-table/spw-table-head/spw-table-head.css +2 -0
  198. package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js +19 -0
  199. package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js.map +1 -0
  200. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.css +2 -0
  201. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js +158 -0
  202. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js.map +1 -0
  203. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.css +2 -0
  204. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js +19 -0
  205. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js.map +1 -0
  206. package/dist/collection/components/spw-table/spw-table.css +2 -0
  207. package/dist/collection/components/spw-table/spw-table.js +115 -0
  208. package/dist/collection/components/spw-table/spw-table.js.map +1 -0
  209. package/dist/collection/components/spw-text-field/spw-text-field.css +2 -0
  210. package/dist/collection/components/spw-text-field/spw-text-field.js +480 -0
  211. package/dist/collection/components/spw-text-field/spw-text-field.js.map +1 -0
  212. package/dist/collection/components/spw-textarea/spw-textarea.css +2 -0
  213. package/dist/collection/components/spw-textarea/spw-textarea.js +450 -0
  214. package/dist/collection/components/spw-textarea/spw-textarea.js.map +1 -0
  215. package/dist/collection/components/spw-theme-provider/spw-theme-provider.js +59 -0
  216. package/dist/collection/components/spw-theme-provider/spw-theme-provider.js.map +1 -0
  217. package/dist/collection/components/spw-tooltip/spw-tooltip.css +2 -0
  218. package/dist/collection/components/spw-tooltip/spw-tooltip.js +100 -0
  219. package/dist/collection/components/spw-tooltip/spw-tooltip.js.map +1 -0
  220. package/dist/collection/index.js +2 -0
  221. package/dist/collection/index.js.map +1 -0
  222. package/dist/collection/stories/assets/accessibility.svg +5 -0
  223. package/dist/collection/stories/assets/discord.svg +15 -0
  224. package/dist/collection/stories/assets/github.svg +3 -0
  225. package/dist/collection/stories/assets/logo.svg +18 -0
  226. package/dist/collection/stories/assets/tutorials.svg +12 -0
  227. package/dist/collection/stories/assets/youtube.svg +4 -0
  228. package/dist/collection/stories/components/spw-accordion/spw-accordion.stories.js +72 -0
  229. package/dist/collection/stories/components/spw-accordion/spw-accordion.stories.js.map +1 -0
  230. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js +66 -0
  231. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js.map +1 -0
  232. package/dist/collection/stories/components/spw-button/spw-button.stories.js +74 -0
  233. package/dist/collection/stories/components/spw-button/spw-button.stories.js.map +1 -0
  234. package/dist/collection/stories/components/spw-card/spw-card.stories.js +183 -0
  235. package/dist/collection/stories/components/spw-card/spw-card.stories.js.map +1 -0
  236. package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js +61 -0
  237. package/dist/collection/stories/components/spw-checkbox/spw-checkbox.stories.js.map +1 -0
  238. package/dist/collection/stories/components/spw-cookies/spw-cookies.stories.js +56 -0
  239. package/dist/collection/stories/components/spw-cookies/spw-cookies.stories.js.map +1 -0
  240. package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js +67 -0
  241. package/dist/collection/stories/components/spw-field-message/spw-field-message.stories.js.map +1 -0
  242. package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js +53 -0
  243. package/dist/collection/stories/components/spw-file-upload/spw-file-upload.stories.js.map +1 -0
  244. package/dist/collection/stories/components/spw-footer/spw-footer.stories.js +126 -0
  245. package/dist/collection/stories/components/spw-footer/spw-footer.stories.js.map +1 -0
  246. package/dist/collection/stories/components/spw-group/spw-group.stories.js +81 -0
  247. package/dist/collection/stories/components/spw-group/spw-group.stories.js.map +1 -0
  248. package/dist/collection/stories/components/spw-header/spw-header.stories.js +135 -0
  249. package/dist/collection/stories/components/spw-header/spw-header.stories.js.map +1 -0
  250. package/dist/collection/stories/components/spw-icon/spw-icon.stories.js +54 -0
  251. package/dist/collection/stories/components/spw-icon/spw-icon.stories.js.map +1 -0
  252. package/dist/collection/stories/components/spw-link/spw-link.stories.js +66 -0
  253. package/dist/collection/stories/components/spw-link/spw-link.stories.js.map +1 -0
  254. package/dist/collection/stories/components/spw-loading/spw-loading.stories.js +58 -0
  255. package/dist/collection/stories/components/spw-loading/spw-loading.stories.js.map +1 -0
  256. package/dist/collection/stories/components/spw-message/spw-message.stories.js +67 -0
  257. package/dist/collection/stories/components/spw-message/spw-message.stories.js.map +1 -0
  258. package/dist/collection/stories/components/spw-modal/spw-modal.stories.js +111 -0
  259. package/dist/collection/stories/components/spw-modal/spw-modal.stories.js.map +1 -0
  260. package/dist/collection/stories/components/spw-mosaic/spw-mosaic.stories.js +146 -0
  261. package/dist/collection/stories/components/spw-mosaic/spw-mosaic.stories.js.map +1 -0
  262. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js +93 -0
  263. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js.map +1 -0
  264. package/dist/collection/stories/components/spw-radio/spw-radio.stories.js +62 -0
  265. package/dist/collection/stories/components/spw-radio/spw-radio.stories.js.map +1 -0
  266. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js +60 -0
  267. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js.map +1 -0
  268. package/dist/collection/stories/components/spw-select/spw-select.stories.js +65 -0
  269. package/dist/collection/stories/components/spw-select/spw-select.stories.js.map +1 -0
  270. package/dist/collection/stories/components/spw-separator/spw-separator.stories.js +63 -0
  271. package/dist/collection/stories/components/spw-separator/spw-separator.stories.js.map +1 -0
  272. package/dist/collection/stories/components/spw-table/spw-table.stories.js +103 -0
  273. package/dist/collection/stories/components/spw-table/spw-table.stories.js.map +1 -0
  274. package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js +61 -0
  275. package/dist/collection/stories/components/spw-text-field/spw-text-field.stories.js.map +1 -0
  276. package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js +61 -0
  277. package/dist/collection/stories/components/spw-textarea/spw-textarea.stories.js.map +1 -0
  278. package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js +58 -0
  279. package/dist/collection/stories/components/spw-tooltip/spw-tooltip.stories.js.map +1 -0
  280. package/dist/collection/themes/themes.js +23 -0
  281. package/dist/collection/themes/themes.js.map +1 -0
  282. package/dist/collection/utils/animation.js +23 -0
  283. package/dist/collection/utils/animation.js.map +1 -0
  284. package/dist/collection/utils/focus-trap.js +113 -0
  285. package/dist/collection/utils/focus-trap.js.map +1 -0
  286. package/dist/collection/utils/utils.js +224 -0
  287. package/dist/collection/utils/utils.js.map +1 -0
  288. package/dist/components/index.d.ts +33 -0
  289. package/dist/components/index.js +3 -0
  290. package/dist/components/index.js.map +1 -0
  291. package/dist/components/p-0e197bb5.js +231 -0
  292. package/dist/components/p-0e197bb5.js.map +1 -0
  293. package/dist/components/p-1808c8c6.js +81 -0
  294. package/dist/components/p-1808c8c6.js.map +1 -0
  295. package/dist/components/p-3706b88e.js +1816 -0
  296. package/dist/components/p-3706b88e.js.map +1 -0
  297. package/dist/components/p-70d767cd.js +19 -0
  298. package/dist/components/p-70d767cd.js.map +1 -0
  299. package/dist/components/p-72ca702e.js +40 -0
  300. package/dist/components/p-72ca702e.js.map +1 -0
  301. package/dist/components/p-89cf5afe.js +138 -0
  302. package/dist/components/p-89cf5afe.js.map +1 -0
  303. package/dist/components/p-987e354f.js +123 -0
  304. package/dist/components/p-987e354f.js.map +1 -0
  305. package/dist/components/p-a9181b0a.js +46 -0
  306. package/dist/components/p-a9181b0a.js.map +1 -0
  307. package/dist/components/p-b3b66a09.js +48 -0
  308. package/dist/components/p-b3b66a09.js.map +1 -0
  309. package/dist/components/p-cb0eb249.js +36 -0
  310. package/dist/components/p-cb0eb249.js.map +1 -0
  311. package/dist/components/p-cb99b731.js +153 -0
  312. package/dist/components/p-cb99b731.js.map +1 -0
  313. package/dist/components/p-def4fee9.js +33 -0
  314. package/dist/components/p-def4fee9.js.map +1 -0
  315. package/dist/components/p-e37034cf.js +143 -0
  316. package/dist/components/p-e37034cf.js.map +1 -0
  317. package/dist/components/p-e70f2b83.js +62 -0
  318. package/dist/components/p-e70f2b83.js.map +1 -0
  319. package/dist/components/p-f48f06ae.js +91 -0
  320. package/dist/components/p-f48f06ae.js.map +1 -0
  321. package/dist/components/spw-accordion-content.d.ts +11 -0
  322. package/dist/components/spw-accordion-content.js +8 -0
  323. package/dist/components/spw-accordion-content.js.map +1 -0
  324. package/dist/components/spw-accordion-item.d.ts +11 -0
  325. package/dist/components/spw-accordion-item.js +8 -0
  326. package/dist/components/spw-accordion-item.js.map +1 -0
  327. package/dist/components/spw-accordion-title.d.ts +11 -0
  328. package/dist/components/spw-accordion-title.js +8 -0
  329. package/dist/components/spw-accordion-title.js.map +1 -0
  330. package/dist/components/spw-accordion.d.ts +11 -0
  331. package/dist/components/spw-accordion.js +8 -0
  332. package/dist/components/spw-accordion.js.map +1 -0
  333. package/dist/components/spw-breadcrumb-item.d.ts +11 -0
  334. package/dist/components/spw-breadcrumb-item.js +85 -0
  335. package/dist/components/spw-breadcrumb-item.js.map +1 -0
  336. package/dist/components/spw-breadcrumb.d.ts +11 -0
  337. package/dist/components/spw-breadcrumb.js +75 -0
  338. package/dist/components/spw-breadcrumb.js.map +1 -0
  339. package/dist/components/spw-button.d.ts +11 -0
  340. package/dist/components/spw-button.js +8 -0
  341. package/dist/components/spw-button.js.map +1 -0
  342. package/dist/components/spw-card-content.d.ts +11 -0
  343. package/dist/components/spw-card-content.js +45 -0
  344. package/dist/components/spw-card-content.js.map +1 -0
  345. package/dist/components/spw-card-excerpt.d.ts +11 -0
  346. package/dist/components/spw-card-excerpt.js +47 -0
  347. package/dist/components/spw-card-excerpt.js.map +1 -0
  348. package/dist/components/spw-card-image.d.ts +11 -0
  349. package/dist/components/spw-card-image.js +64 -0
  350. package/dist/components/spw-card-image.js.map +1 -0
  351. package/dist/components/spw-card-subtag-item.d.ts +11 -0
  352. package/dist/components/spw-card-subtag-item.js +50 -0
  353. package/dist/components/spw-card-subtag-item.js.map +1 -0
  354. package/dist/components/spw-card-subtags.d.ts +11 -0
  355. package/dist/components/spw-card-subtags.js +57 -0
  356. package/dist/components/spw-card-subtags.js.map +1 -0
  357. package/dist/components/spw-card-title.d.ts +11 -0
  358. package/dist/components/spw-card-title.js +36 -0
  359. package/dist/components/spw-card-title.js.map +1 -0
  360. package/dist/components/spw-card.d.ts +11 -0
  361. package/dist/components/spw-card.js +136 -0
  362. package/dist/components/spw-card.js.map +1 -0
  363. package/dist/components/spw-checkbox.d.ts +11 -0
  364. package/dist/components/spw-checkbox.js +8 -0
  365. package/dist/components/spw-checkbox.js.map +1 -0
  366. package/dist/components/spw-cookies.d.ts +11 -0
  367. package/dist/components/spw-cookies.js +148 -0
  368. package/dist/components/spw-cookies.js.map +1 -0
  369. package/dist/components/spw-custom-select.d.ts +11 -0
  370. package/dist/components/spw-custom-select.js +407 -0
  371. package/dist/components/spw-custom-select.js.map +1 -0
  372. package/dist/components/spw-field-label.d.ts +11 -0
  373. package/dist/components/spw-field-label.js +8 -0
  374. package/dist/components/spw-field-label.js.map +1 -0
  375. package/dist/components/spw-field-message.d.ts +11 -0
  376. package/dist/components/spw-field-message.js +8 -0
  377. package/dist/components/spw-field-message.js.map +1 -0
  378. package/dist/components/spw-file-upload.d.ts +11 -0
  379. package/dist/components/spw-file-upload.js +238 -0
  380. package/dist/components/spw-file-upload.js.map +1 -0
  381. package/dist/components/spw-footer-bottom.d.ts +11 -0
  382. package/dist/components/spw-footer-bottom.js +39 -0
  383. package/dist/components/spw-footer-bottom.js.map +1 -0
  384. package/dist/components/spw-footer-content-col.d.ts +11 -0
  385. package/dist/components/spw-footer-content-col.js +39 -0
  386. package/dist/components/spw-footer-content-col.js.map +1 -0
  387. package/dist/components/spw-footer-content.d.ts +11 -0
  388. package/dist/components/spw-footer-content.js +49 -0
  389. package/dist/components/spw-footer-content.js.map +1 -0
  390. package/dist/components/spw-footer-link.d.ts +11 -0
  391. package/dist/components/spw-footer-link.js +41 -0
  392. package/dist/components/spw-footer-link.js.map +1 -0
  393. package/dist/components/spw-footer-socials.d.ts +11 -0
  394. package/dist/components/spw-footer-socials.js +36 -0
  395. package/dist/components/spw-footer-socials.js.map +1 -0
  396. package/dist/components/spw-footer.d.ts +11 -0
  397. package/dist/components/spw-footer.js +71 -0
  398. package/dist/components/spw-footer.js.map +1 -0
  399. package/dist/components/spw-group.d.ts +11 -0
  400. package/dist/components/spw-group.js +82 -0
  401. package/dist/components/spw-group.js.map +1 -0
  402. package/dist/components/spw-header-lang-item.d.ts +11 -0
  403. package/dist/components/spw-header-lang-item.js +39 -0
  404. package/dist/components/spw-header-lang-item.js.map +1 -0
  405. package/dist/components/spw-header-lang.d.ts +11 -0
  406. package/dist/components/spw-header-lang.js +70 -0
  407. package/dist/components/spw-header-lang.js.map +1 -0
  408. package/dist/components/spw-header-navigation-dropdown.d.ts +11 -0
  409. package/dist/components/spw-header-navigation-dropdown.js +36 -0
  410. package/dist/components/spw-header-navigation-dropdown.js.map +1 -0
  411. package/dist/components/spw-header-navigation-item.d.ts +11 -0
  412. package/dist/components/spw-header-navigation-item.js +168 -0
  413. package/dist/components/spw-header-navigation-item.js.map +1 -0
  414. package/dist/components/spw-header-navigation.d.ts +11 -0
  415. package/dist/components/spw-header-navigation.js +79 -0
  416. package/dist/components/spw-header-navigation.js.map +1 -0
  417. package/dist/components/spw-header-persona-item.d.ts +11 -0
  418. package/dist/components/spw-header-persona-item.js +39 -0
  419. package/dist/components/spw-header-persona-item.js.map +1 -0
  420. package/dist/components/spw-header-persona.d.ts +11 -0
  421. package/dist/components/spw-header-persona.js +69 -0
  422. package/dist/components/spw-header-persona.js.map +1 -0
  423. package/dist/components/spw-header.d.ts +11 -0
  424. package/dist/components/spw-header.js +60 -0
  425. package/dist/components/spw-header.js.map +1 -0
  426. package/dist/components/spw-icon.d.ts +11 -0
  427. package/dist/components/spw-icon.js +8 -0
  428. package/dist/components/spw-icon.js.map +1 -0
  429. package/dist/components/spw-iodda.d.ts +11 -0
  430. package/dist/components/spw-iodda.js +179 -0
  431. package/dist/components/spw-iodda.js.map +1 -0
  432. package/dist/components/spw-link.d.ts +11 -0
  433. package/dist/components/spw-link.js +8 -0
  434. package/dist/components/spw-link.js.map +1 -0
  435. package/dist/components/spw-loading.d.ts +11 -0
  436. package/dist/components/spw-loading.js +8 -0
  437. package/dist/components/spw-loading.js.map +1 -0
  438. package/dist/components/spw-message.d.ts +11 -0
  439. package/dist/components/spw-message.js +104 -0
  440. package/dist/components/spw-message.js.map +1 -0
  441. package/dist/components/spw-modal.d.ts +11 -0
  442. package/dist/components/spw-modal.js +324 -0
  443. package/dist/components/spw-modal.js.map +1 -0
  444. package/dist/components/spw-mosaic-item.d.ts +11 -0
  445. package/dist/components/spw-mosaic-item.js +52 -0
  446. package/dist/components/spw-mosaic-item.js.map +1 -0
  447. package/dist/components/spw-mosaic.d.ts +11 -0
  448. package/dist/components/spw-mosaic.js +2507 -0
  449. package/dist/components/spw-mosaic.js.map +1 -0
  450. package/dist/components/spw-pagination.d.ts +11 -0
  451. package/dist/components/spw-pagination.js +8 -0
  452. package/dist/components/spw-pagination.js.map +1 -0
  453. package/dist/components/spw-radio.d.ts +11 -0
  454. package/dist/components/spw-radio.js +131 -0
  455. package/dist/components/spw-radio.js.map +1 -0
  456. package/dist/components/spw-search-field.d.ts +11 -0
  457. package/dist/components/spw-search-field.js +203 -0
  458. package/dist/components/spw-search-field.js.map +1 -0
  459. package/dist/components/spw-select.d.ts +11 -0
  460. package/dist/components/spw-select.js +149 -0
  461. package/dist/components/spw-select.js.map +1 -0
  462. package/dist/components/spw-separator.d.ts +11 -0
  463. package/dist/components/spw-separator.js +61 -0
  464. package/dist/components/spw-separator.js.map +1 -0
  465. package/dist/components/spw-table-body.d.ts +11 -0
  466. package/dist/components/spw-table-body.js +36 -0
  467. package/dist/components/spw-table-body.js.map +1 -0
  468. package/dist/components/spw-table-cell.d.ts +11 -0
  469. package/dist/components/spw-table-cell.js +57 -0
  470. package/dist/components/spw-table-cell.js.map +1 -0
  471. package/dist/components/spw-table-head.d.ts +11 -0
  472. package/dist/components/spw-table-head.js +36 -0
  473. package/dist/components/spw-table-head.js.map +1 -0
  474. package/dist/components/spw-table-header.d.ts +11 -0
  475. package/dist/components/spw-table-header.js +56 -0
  476. package/dist/components/spw-table-header.js.map +1 -0
  477. package/dist/components/spw-table-row.d.ts +11 -0
  478. package/dist/components/spw-table-row.js +36 -0
  479. package/dist/components/spw-table-row.js.map +1 -0
  480. package/dist/components/spw-table.d.ts +11 -0
  481. package/dist/components/spw-table.js +61 -0
  482. package/dist/components/spw-table.js.map +1 -0
  483. package/dist/components/spw-text-field.d.ts +11 -0
  484. package/dist/components/spw-text-field.js +8 -0
  485. package/dist/components/spw-text-field.js.map +1 -0
  486. package/dist/components/spw-textarea.d.ts +11 -0
  487. package/dist/components/spw-textarea.js +143 -0
  488. package/dist/components/spw-textarea.js.map +1 -0
  489. package/dist/components/spw-theme-provider.d.ts +11 -0
  490. package/dist/components/spw-theme-provider.js +96 -0
  491. package/dist/components/spw-theme-provider.js.map +1 -0
  492. package/dist/components/spw-tooltip.d.ts +11 -0
  493. package/dist/components/spw-tooltip.js +57 -0
  494. package/dist/components/spw-tooltip.js.map +1 -0
  495. package/dist/components_json.d.ts +435 -0
  496. package/dist/components_json.json +7153 -0
  497. package/dist/esm/app-globals-0f993ce5.js +5 -0
  498. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  499. package/dist/esm/index-080912e4.js +1926 -0
  500. package/dist/esm/index-080912e4.js.map +1 -0
  501. package/dist/esm/index.js +3 -0
  502. package/dist/esm/index.js.map +1 -0
  503. package/dist/esm/loader.js +13 -0
  504. package/dist/esm/loader.js.map +1 -0
  505. package/dist/esm/spw-accordion_58.entry.js +5894 -0
  506. package/dist/esm/spw-accordion_58.entry.js.map +1 -0
  507. package/dist/esm/spw-stencil-library.js +22 -0
  508. package/dist/esm/spw-stencil-library.js.map +1 -0
  509. package/dist/index.cjs.js +1 -0
  510. package/dist/index.js +1 -0
  511. package/dist/spw-stencil-library/assets/LICENSE.txt +165 -0
  512. package/dist/spw-stencil-library/assets/all.css +7913 -0
  513. package/dist/spw-stencil-library/assets/all.min.css +9 -0
  514. package/dist/spw-stencil-library/assets/brands.css +1609 -0
  515. package/dist/spw-stencil-library/assets/brands.min.css +6 -0
  516. package/dist/spw-stencil-library/assets/fa-brands-400.ttf +0 -0
  517. package/dist/spw-stencil-library/assets/fa-brands-400.woff2 +0 -0
  518. package/dist/spw-stencil-library/assets/fa-regular-400.ttf +0 -0
  519. package/dist/spw-stencil-library/assets/fa-regular-400.woff2 +0 -0
  520. package/dist/spw-stencil-library/assets/fa-solid-900.ttf +0 -0
  521. package/dist/spw-stencil-library/assets/fa-solid-900.woff2 +0 -0
  522. package/dist/spw-stencil-library/assets/fa-v4compatibility.ttf +0 -0
  523. package/dist/spw-stencil-library/assets/fa-v4compatibility.woff2 +0 -0
  524. package/dist/spw-stencil-library/assets/fontawesome.css +6243 -0
  525. package/dist/spw-stencil-library/assets/fontawesome.min.css +9 -0
  526. package/dist/spw-stencil-library/assets/regular.css +19 -0
  527. package/dist/spw-stencil-library/assets/regular.min.css +6 -0
  528. package/dist/spw-stencil-library/assets/solid.css +19 -0
  529. package/dist/spw-stencil-library/assets/solid.min.css +6 -0
  530. package/dist/spw-stencil-library/assets/svg-with-js.css +461 -0
  531. package/dist/spw-stencil-library/assets/svg-with-js.min.css +6 -0
  532. package/dist/spw-stencil-library/assets/v4-font-face.css +26 -0
  533. package/dist/spw-stencil-library/assets/v4-font-face.min.css +6 -0
  534. package/dist/spw-stencil-library/assets/v4-shims.css +2194 -0
  535. package/dist/spw-stencil-library/assets/v4-shims.min.css +6 -0
  536. package/dist/spw-stencil-library/assets/v5-font-face.css +22 -0
  537. package/dist/spw-stencil-library/assets/v5-font-face.min.css +6 -0
  538. package/dist/spw-stencil-library/index.esm.js +2 -0
  539. package/dist/spw-stencil-library/index.esm.js.map +1 -0
  540. package/dist/spw-stencil-library/p-205fd6a4.js +3 -0
  541. package/dist/spw-stencil-library/p-205fd6a4.js.map +1 -0
  542. package/dist/spw-stencil-library/p-d3d3de91.entry.js +19 -0
  543. package/dist/spw-stencil-library/p-d3d3de91.entry.js.map +1 -0
  544. package/dist/spw-stencil-library/p-e1255160.js +2 -0
  545. package/dist/spw-stencil-library/p-e1255160.js.map +1 -0
  546. package/dist/spw-stencil-library/spw-stencil-library.css +1 -0
  547. package/dist/spw-stencil-library/spw-stencil-library.esm.js +2 -0
  548. package/dist/spw-stencil-library/spw-stencil-library.esm.js.map +1 -0
  549. package/dist/stats.json +19725 -0
  550. package/dist/types/components/spw-accordion/spw-accordion-content/spw-accordion-content.d.ts +16 -0
  551. package/dist/types/components/spw-accordion/spw-accordion-item/spw-accordion-item.d.ts +25 -0
  552. package/dist/types/components/spw-accordion/spw-accordion-title/spw-accordion-title.d.ts +7 -0
  553. package/dist/types/components/spw-accordion/spw-accordion.d.ts +3 -0
  554. package/dist/types/components/spw-breadcrumb/spw-breadcrumb-item/spw-breadcrumb-item.d.ts +11 -0
  555. package/dist/types/components/spw-breadcrumb/spw-breadcrumb.d.ts +13 -0
  556. package/dist/types/components/spw-button/spw-button.d.ts +48 -0
  557. package/dist/types/components/spw-card/spw-card-content/spw-card-content.d.ts +9 -0
  558. package/dist/types/components/spw-card/spw-card-excerpt/spw-card-excerpt.d.ts +6 -0
  559. package/dist/types/components/spw-card/spw-card-image/spw-card-image.d.ts +8 -0
  560. package/dist/types/components/spw-card/spw-card-subtag-item/spw-card-subtag-item.d.ts +7 -0
  561. package/dist/types/components/spw-card/spw-card-subtags/spw-card-subtags.d.ts +9 -0
  562. package/dist/types/components/spw-card/spw-card-title/spw-card-title.d.ts +3 -0
  563. package/dist/types/components/spw-card/spw-card.d.ts +34 -0
  564. package/dist/types/components/spw-checkbox/spw-checkbox.d.ts +30 -0
  565. package/dist/types/components/spw-cookies/spw-cookies.d.ts +21 -0
  566. package/dist/types/components/spw-custom-select/spw-custom-select.d.ts +79 -0
  567. package/dist/types/components/spw-field-label/spw-field-label.d.ts +11 -0
  568. package/dist/types/components/spw-field-message/spw-field-message.d.ts +9 -0
  569. package/dist/types/components/spw-file-upload/spw-file-upload.d.ts +53 -0
  570. package/dist/types/components/spw-footer/spw-footer-bottom/spw-footer-bottom.d.ts +5 -0
  571. package/dist/types/components/spw-footer/spw-footer-content/spw-footer-content.d.ts +7 -0
  572. package/dist/types/components/spw-footer/spw-footer-content-col/spw-footer-content-col.d.ts +5 -0
  573. package/dist/types/components/spw-footer/spw-footer-link/spw-footer-link.d.ts +7 -0
  574. package/dist/types/components/spw-footer/spw-footer-socials/spw-footer-socials.d.ts +3 -0
  575. package/dist/types/components/spw-footer/spw-footer.d.ts +13 -0
  576. package/dist/types/components/spw-group/spw-group.d.ts +22 -0
  577. package/dist/types/components/spw-header/spw-header-lang/spw-header-lang.d.ts +8 -0
  578. package/dist/types/components/spw-header/spw-header-lang-item/spw-header-lang-item.d.ts +4 -0
  579. package/dist/types/components/spw-header/spw-header-navigation/spw-header-navigation.d.ts +12 -0
  580. package/dist/types/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.d.ts +3 -0
  581. package/dist/types/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.d.ts +26 -0
  582. package/dist/types/components/spw-header/spw-header-persona/spw-header-persona.d.ts +10 -0
  583. package/dist/types/components/spw-header/spw-header-persona-item/spw-header-persona-item.d.ts +4 -0
  584. package/dist/types/components/spw-header/spw-header.d.ts +6 -0
  585. package/dist/types/components/spw-icon/spw-icon.d.ts +7 -0
  586. package/dist/types/components/spw-iodda/spw-iodda.d.ts +19 -0
  587. package/dist/types/components/spw-iodda/spw-iodda.service.d.ts +1 -0
  588. package/dist/types/components/spw-link/spw-link.d.ts +25 -0
  589. package/dist/types/components/spw-loading/spw-loading.d.ts +5 -0
  590. package/dist/types/components/spw-message/spw-message.d.ts +18 -0
  591. package/dist/types/components/spw-modal/spw-modal.d.ts +53 -0
  592. package/dist/types/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.d.ts +8 -0
  593. package/dist/types/components/spw-mosaic/spw-mosaic.d.ts +31 -0
  594. package/dist/types/components/spw-pagination/spw-pagination.d.ts +30 -0
  595. package/dist/types/components/spw-radio/spw-radio.d.ts +35 -0
  596. package/dist/types/components/spw-search-field/spw-search-field.d.ts +39 -0
  597. package/dist/types/components/spw-select/spw-select.d.ts +48 -0
  598. package/dist/types/components/spw-separator/spw-separator.d.ts +15 -0
  599. package/dist/types/components/spw-table/spw-table-body/spw-table-body.d.ts +3 -0
  600. package/dist/types/components/spw-table/spw-table-cell/spw-table-cell.d.ts +16 -0
  601. package/dist/types/components/spw-table/spw-table-head/spw-table-head.d.ts +3 -0
  602. package/dist/types/components/spw-table/spw-table-header/spw-table-header.d.ts +16 -0
  603. package/dist/types/components/spw-table/spw-table-row/spw-table-row.d.ts +3 -0
  604. package/dist/types/components/spw-table/spw-table.d.ts +23 -0
  605. package/dist/types/components/spw-text-field/spw-text-field.d.ts +57 -0
  606. package/dist/types/components/spw-textarea/spw-textarea.d.ts +53 -0
  607. package/dist/types/components/spw-theme-provider/spw-theme-provider.d.ts +10 -0
  608. package/dist/types/components/spw-tooltip/spw-tooltip.d.ts +13 -0
  609. package/dist/types/components.d.ts +2793 -0
  610. package/dist/types/index.d.ts +1 -0
  611. package/dist/types/stencil-public-runtime.d.ts +1678 -0
  612. package/dist/types/stories/components/spw-accordion/spw-accordion.stories.d.ts +4 -0
  613. package/dist/types/stories/components/spw-breadcrumb/spw-breadcrumb.stories.d.ts +5 -0
  614. package/dist/types/stories/components/spw-button/spw-button.stories.d.ts +7 -0
  615. package/dist/types/stories/components/spw-card/spw-card.stories.d.ts +10 -0
  616. package/dist/types/stories/components/spw-checkbox/spw-checkbox.stories.d.ts +4 -0
  617. package/dist/types/stories/components/spw-cookies/spw-cookies.stories.d.ts +4 -0
  618. package/dist/types/stories/components/spw-field-message/spw-field-message.stories.d.ts +6 -0
  619. package/dist/types/stories/components/spw-file-upload/spw-file-upload.stories.d.ts +4 -0
  620. package/dist/types/stories/components/spw-footer/spw-footer.stories.d.ts +5 -0
  621. package/dist/types/stories/components/spw-group/spw-group.stories.d.ts +6 -0
  622. package/dist/types/stories/components/spw-header/spw-header.stories.d.ts +4 -0
  623. package/dist/types/stories/components/spw-icon/spw-icon.stories.d.ts +4 -0
  624. package/dist/types/stories/components/spw-link/spw-link.stories.d.ts +5 -0
  625. package/dist/types/stories/components/spw-loading/spw-loading.stories.d.ts +5 -0
  626. package/dist/types/stories/components/spw-message/spw-message.stories.d.ts +8 -0
  627. package/dist/types/stories/components/spw-modal/spw-modal.stories.d.ts +8 -0
  628. package/dist/types/stories/components/spw-mosaic/spw-mosaic.stories.d.ts +4 -0
  629. package/dist/types/stories/components/spw-pagination/spw-pagination.stories.d.ts +22 -0
  630. package/dist/types/stories/components/spw-radio/spw-radio.stories.d.ts +4 -0
  631. package/dist/types/stories/components/spw-search-field/spw-search-field.stories.d.ts +4 -0
  632. package/dist/types/stories/components/spw-select/spw-select.stories.d.ts +4 -0
  633. package/dist/types/stories/components/spw-separator/spw-separator.stories.d.ts +5 -0
  634. package/dist/types/stories/components/spw-table/spw-table.stories.d.ts +4 -0
  635. package/dist/types/stories/components/spw-text-field/spw-text-field.stories.d.ts +4 -0
  636. package/dist/types/stories/components/spw-textarea/spw-textarea.stories.d.ts +4 -0
  637. package/dist/types/stories/components/spw-tooltip/spw-tooltip.stories.d.ts +4 -0
  638. package/dist/types/themes/themes.d.ts +13 -0
  639. package/dist/types/utils/animation.d.ts +13 -0
  640. package/dist/types/utils/focus-trap.d.ts +33 -0
  641. package/dist/types/utils/utils.d.ts +11 -0
  642. package/hydrate/index.d.ts +242 -0
  643. package/hydrate/index.js +24773 -0
  644. package/hydrate/index.mjs +24765 -0
  645. package/hydrate/package.json +12 -0
  646. package/loader/cdn.js +1 -0
  647. package/loader/index.cjs.js +1 -0
  648. package/loader/index.d.ts +24 -0
  649. package/loader/index.es2017.js +1 -0
  650. package/loader/index.js +2 -0
  651. package/loader/package.json +11 -0
  652. package/package.json +88 -0
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SpwMessage extends Components.SpwMessage, HTMLElement {}
4
+ export const SpwMessage: {
5
+ prototype: SpwMessage;
6
+ new (): SpwMessage;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,104 @@
1
+ import { p as proxyCustomElement, H, h, c as Host } from './p-3706b88e.js';
2
+ import { d as defineCustomElement$3 } from './p-72ca702e.js';
3
+ import { d as defineCustomElement$2 } from './p-1808c8c6.js';
4
+
5
+ const getIcon = variant => {
6
+ const icons = {
7
+ default: 'fa-lightbulb',
8
+ success: 'fa-check',
9
+ info: 'fa-info-circle',
10
+ warning: 'fa-exclamation-triangle',
11
+ alert: 'fa-exclamation-triangle',
12
+ };
13
+
14
+ return icons[variant] || icons['default'];
15
+ };
16
+
17
+ const getElementClass = variant => {
18
+ return {
19
+ 'spw-message': true,
20
+ [`spw-message--${variant}`]: true,
21
+ };
22
+ };
23
+
24
+ const shouldHideMessage = messageId => {
25
+ return !!localStorage.getItem(`spw-message-${messageId}`);
26
+ };
27
+
28
+ const dismissMessage = (messageId, hideCallback) => {
29
+ localStorage.setItem(`spw-message-${messageId}`, 'true');
30
+ hideCallback();
31
+ };
32
+
33
+ const spwMessageCss = "/*! 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:block;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:1220px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{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-message{border-radius:16px;color:var(--spw-colors-support-grey-grey-900);font-size:16px;padding:24px}.spw-message__title-container{display:flex;flex-direction:column;flex-wrap:nowrap;gap:24px;justify-content:space-between}@media (min-width:1024px){.spw-message__title-container{flex-direction:row}}.spw-message__close{order:-1}@media (min-width:1024px){.spw-message__close{order:0}}.spw-message__title{display:block;flex:1;font-size:18px}.spw-message__title .spw-icon,.spw-message__title spw-icon{margin-right:6px;position:relative;top:1px}.spw-message__text{margin-top:12px}.spw-message--default{background:var(--spw-colors-support-grey-grey-100)}.spw-message--success{background:var(--spw-colors-multi-branding-green-green-50)}.spw-message--success .spw-icon,.spw-message--success spw-icon{color:var(--spw-colors-multi-branding-green-green-600)}.spw-message--alert{background:var(--spw-colors-multi-branding-red-red-50)}.spw-message--alert .spw-icon,.spw-message--alert spw-icon{color:var(--spw-colors-multi-branding-red-red-accent-3)}.spw-message--info{background:var(--spw-colors-multi-branding-blue-blue-50)}.spw-message--info .spw-icon,.spw-message--info spw-icon{color:var(--spw-colors-multi-branding-blue-blue-accent-3)}.spw-message--warning{background:#fffdeb}.spw-message--warning .spw-icon,.spw-message--warning spw-icon{color:#e6b800}.spw-message spw-link{--spw-link-color:var(--spw-colors-support-grey-grey-900);--spw-link-hover-color:var(--spw-colors-support-grey-grey-900);--spw-link-active-color:var(--spw-colors-support-grey-grey-800);--spw-link-padding:12px}.spw-message spw-link:focus-visible{outline:2px solid var(--spw-ds-focus);outline-offset:1px}";
34
+ const SpwMessageStyle0 = spwMessageCss;
35
+
36
+ const SpwMessage$1 = /*@__PURE__*/ proxyCustomElement(class SpwMessage extends H {
37
+ constructor() {
38
+ super();
39
+ this.__registerHost();
40
+ this.__attachShadow();
41
+ this.handleKeyDown = (ev) => {
42
+ if (ev.key === 'Enter') {
43
+ ev.preventDefault();
44
+ this.handleDismiss();
45
+ }
46
+ };
47
+ this.handleDismiss = () => {
48
+ dismissMessage(this.messageId, () => {
49
+ this.isVisible = false;
50
+ });
51
+ };
52
+ this.variant = 'default';
53
+ this.messageId = undefined;
54
+ this.isDismissable = true;
55
+ this.dismissableText = 'Masquer';
56
+ this.messageTitle = 'Notification';
57
+ this.isVisible = true;
58
+ }
59
+ componentWillLoad() {
60
+ this.isVisible = !shouldHideMessage(this.messageId);
61
+ }
62
+ render() {
63
+ return this.isVisible ? (h(Host, null, h("div", { class: getElementClass(this.variant), role: "alert", "aria-live": "polite", "aria-label": this.messageTitle }, h("div", { class: "spw-message__title-container" }, h("strong", { class: "spw-message__title" }, h("spw-icon", { icon: getIcon(this.variant) }), " ", this.messageTitle), this.isDismissable && (h("spw-link", { tabindex: "0", icon: "fa-close", class: "spw-message__close", "aria-label": this.dismissableText, onClick: this.handleDismiss, onKeyDown: this.handleKeyDown }, this.dismissableText))), h("div", { class: "spw-message__text" }, h("slot", null))))) : null;
64
+ }
65
+ get el() { return this; }
66
+ static get style() { return SpwMessageStyle0; }
67
+ }, [1, "spw-message", {
68
+ "variant": [1],
69
+ "messageId": [1, "message-id"],
70
+ "isDismissable": [4, "is-dismissable"],
71
+ "dismissableText": [1, "dismissable-text"],
72
+ "messageTitle": [1, "message-title"],
73
+ "isVisible": [32]
74
+ }]);
75
+ function defineCustomElement$1() {
76
+ if (typeof customElements === "undefined") {
77
+ return;
78
+ }
79
+ const components = ["spw-message", "spw-icon", "spw-link"];
80
+ components.forEach(tagName => { switch (tagName) {
81
+ case "spw-message":
82
+ if (!customElements.get(tagName)) {
83
+ customElements.define(tagName, SpwMessage$1);
84
+ }
85
+ break;
86
+ case "spw-icon":
87
+ if (!customElements.get(tagName)) {
88
+ defineCustomElement$3();
89
+ }
90
+ break;
91
+ case "spw-link":
92
+ if (!customElements.get(tagName)) {
93
+ defineCustomElement$2();
94
+ }
95
+ break;
96
+ } });
97
+ }
98
+
99
+ const SpwMessage = SpwMessage$1;
100
+ const defineCustomElement = defineCustomElement$1;
101
+
102
+ export { SpwMessage, defineCustomElement };
103
+
104
+ //# sourceMappingURL=spw-message.js.map
@@ -0,0 +1 @@
1
+ {"file":"spw-message.js","mappings":";;;;AAAO,MAAM,OAAO,GAAG,OAAO,IAAI;AAClC,EAAE,MAAM,KAAK,GAAG;AAChB,IAAI,OAAO,EAAE,cAAc;AAC3B,IAAI,OAAO,EAAE,UAAU;AACvB,IAAI,IAAI,EAAE,gBAAgB;AAC1B,IAAI,OAAO,EAAE,yBAAyB;AACtC,IAAI,KAAK,EAAE,yBAAyB;AACpC,GAAG,CAAC;AACJ;AACA,EAAE,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC;AAC5C,CAAC,CAAC;AACF;AACO,MAAM,eAAe,GAAG,OAAO,IAAI;AAC1C,EAAE,OAAO;AACT,IAAI,aAAa,EAAE,IAAI;AACvB,IAAI,CAAC,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,GAAG,IAAI;AACrC,GAAG,CAAC;AACJ,CAAC,CAAC;AACF;AACO,MAAM,iBAAiB,GAAG,SAAS,IAAI;AAC9C,EAAE,OAAO,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;AAC5D,CAAC,CAAC;AACF;AACO,MAAM,cAAc,GAAG,CAAC,SAAS,EAAE,YAAY,KAAK;AAC3D,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;AAC3D,EAAE,YAAY,EAAE,CAAC;AACjB,CAAC;;AC1BD,MAAM,aAAa,GAAG,8oIAA8oI,CAAC;AACrqI,yBAAe,aAAa;;MCOfA,YAAU;;;;;QAoBb,kBAAa,GAAG,CAAC,EAAiB;YACxC,IAAI,EAAE,CAAC,GAAG,KAAK,OAAO,EAAE;gBACtB,EAAE,CAAC,cAAc,EAAE,CAAC;gBACpB,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;SACF,CAAC;QAEM,kBAAa,GAAG;YACtB,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE;gBAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;aACxB,CAAC,CAAC;SACJ,CAAC;uBA3BsE,SAAS;;6BAIhD,IAAI;+BAEH,SAAS;4BAEZ,cAAc;yBAEf,IAAI;;IAElC,iBAAiB;QACf,IAAI,CAAC,SAAS,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;KACrD;IAeD,MAAM;QACJ,OAAO,IAAI,CAAC,SAAS,IACnB,EAAC,IAAI,QACH,WAAK,KAAK,EAAE,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,EAAC,OAAO,eAAW,QAAQ,gBAAa,IAAI,CAAC,YAAY,IACtG,WAAK,KAAK,EAAC,8BAA8B,IACvC,cAAQ,KAAK,EAAC,oBAAoB,IAChC,gBAAU,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAa,OAAE,IAAI,CAAC,YAAY,CAC9D,EACR,IAAI,CAAC,aAAa,KACjB,gBAAU,QAAQ,EAAC,GAAG,EAAC,IAAI,EAAC,UAAU,EAAC,KAAK,EAAC,oBAAoB,gBAAa,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,IAAI,CAAC,aAAa,IAC3J,IAAI,CAAC,eAAe,CACZ,CACZ,CACG,EACN,WAAK,KAAK,EAAC,mBAAmB,IAC5B,eAAa,CACT,CACF,CACD,IACL,IAAI,CAAC;KACV;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["SpwMessage"],"sources":["src/components/spw-message/utils.js","src/components/spw-message/spw-message.scss?tag=spw-message&encapsulation=shadow","src/components/spw-message/spw-message.tsx"],"sourcesContent":["export const getIcon = variant => {\n const icons = {\n default: 'fa-lightbulb',\n success: 'fa-check',\n info: 'fa-info-circle',\n warning: 'fa-exclamation-triangle',\n alert: 'fa-exclamation-triangle',\n };\n\n return icons[variant] || icons['default'];\n};\n\nexport const getElementClass = variant => {\n return {\n 'spw-message': true,\n [`spw-message--${variant}`]: true,\n };\n};\n\nexport const shouldHideMessage = messageId => {\n return !!localStorage.getItem(`spw-message-${messageId}`);\n};\n\nexport const dismissMessage = (messageId, hideCallback) => {\n localStorage.setItem(`spw-message-${messageId}`, 'true');\n hideCallback();\n};\n","@import '../../scss/mixins';\n\n:host {\n display: block;\n}\n\n.spw-message {\n padding: 24px;\n border-radius: 16px;\n color: var(--spw-colors-support-grey-grey-900);\n font-size: 16px;\n\n &__title-container {\n display: flex;\n gap: 24px;\n flex-wrap: nowrap;\n justify-content: space-between;\n flex-direction: column;\n @include breakpoint(lg) {\n flex-direction: row;\n }\n }\n\n &__close {\n order: -1;\n @include breakpoint(lg) {\n order: initial;\n }\n }\n\n &__title {\n font-size: 18px;\n flex: 1;\n display: block;\n spw-icon,\n .spw-icon {\n position: relative;\n margin-right: 6px;\n top: 1px;\n }\n }\n\n &__text {\n margin-top: 12px;\n }\n\n &--default {\n background: var(--spw-colors-support-grey-grey-100);\n }\n\n &--success {\n background: var(--spw-colors-multi-branding-green-green-50);\n spw-icon,\n .spw-icon {\n color: var(--spw-colors-multi-branding-green-green-600);\n }\n }\n\n &--alert {\n background: var(--spw-colors-multi-branding-red-red-50);\n spw-icon,\n .spw-icon {\n color: var(--spw-colors-multi-branding-red-red-accent-3);\n }\n }\n\n &--info {\n background: var(--spw-colors-multi-branding-blue-blue-50);\n spw-icon,\n .spw-icon {\n color: var(--spw-colors-multi-branding-blue-blue-accent-3);\n }\n }\n\n &--warning {\n background: #fffdeb;\n spw-icon,\n .spw-icon {\n color: #e6b800;\n }\n }\n\n spw-link {\n --spw-link-color: var(--spw-colors-support-grey-grey-900);\n --spw-link-hover-color: var(--spw-colors-support-grey-grey-900);\n --spw-link-active-color: var(--spw-colors-support-grey-grey-800);\n --spw-link-padding: 12px;\n &:focus-visible {\n outline-offset: 1px;\n outline: 2px solid var(--spw-ds-focus);\n }\n }\n}\n","import { Component, Host, h, Prop, State, Element } from '@stencil/core';\nimport { getIcon, getElementClass, shouldHideMessage, dismissMessage } from './utils.js';\n\n@Component({\n tag: 'spw-message',\n styleUrl: 'spw-message.scss',\n shadow: true,\n})\nexport class SpwMessage {\n @Element() el: HTMLSpwMessageElement;\n\n /** Le type de variante */\n @Prop() variant: 'default' | 'success' | 'info' | 'alert' | 'warning' = 'default';\n /** Identifiant unique pour le message */\n @Prop() messageId: string;\n /** Si la notification est masquable */\n @Prop() isDismissable: boolean = true;\n /** Texte du bouton pour masquer la notification */\n @Prop() dismissableText: string = 'Masquer';\n /** Titre de la notification */\n @Prop() messageTitle: string = 'Notification';\n\n @State() isVisible: boolean = true;\n\n componentWillLoad() {\n this.isVisible = !shouldHideMessage(this.messageId);\n }\n\n private handleKeyDown = (ev: KeyboardEvent) => {\n if (ev.key === 'Enter') {\n ev.preventDefault();\n this.handleDismiss();\n }\n };\n\n private handleDismiss = () => {\n dismissMessage(this.messageId, () => {\n this.isVisible = false;\n });\n };\n\n render() {\n return this.isVisible ? (\n <Host>\n <div class={getElementClass(this.variant)} role=\"alert\" aria-live=\"polite\" aria-label={this.messageTitle}>\n <div class=\"spw-message__title-container\">\n <strong class=\"spw-message__title\">\n <spw-icon icon={getIcon(this.variant)}></spw-icon> {this.messageTitle}\n </strong>\n {this.isDismissable && (\n <spw-link tabindex=\"0\" icon=\"fa-close\" class=\"spw-message__close\" aria-label={this.dismissableText} onClick={this.handleDismiss} onKeyDown={this.handleKeyDown}>\n {this.dismissableText}\n </spw-link>\n )}\n </div>\n <div class=\"spw-message__text\">\n <slot></slot>\n </div>\n </div>\n </Host>\n ) : null;\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SpwModal extends Components.SpwModal, HTMLElement {}
4
+ export const SpwModal: {
5
+ prototype: SpwModal;
6
+ new (): SpwModal;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,324 @@
1
+ import { p as proxyCustomElement, H, d as createEvent, h, c as Host } from './p-3706b88e.js';
2
+ import { d as defineCustomElement$2 } from './p-72ca702e.js';
3
+
4
+ /**
5
+ * Copy/pasted from https://github.com/andreasbm/focus-trap
6
+ */
7
+ /**
8
+ * Traverses the slots of the open shadowroots and returns all children matching the query.
9
+ * We need to traverse each child-depth one at a time because if an element should be skipped
10
+ * (for example because it is hidden) we need to skip all of it's children. If we use querySelectorAll("*")
11
+ * the information of whether the children is within a hidden parent is lost.
12
+ * @param {ShadowRoot | HTMLElement} root
13
+ * @param skipNode
14
+ * @param isMatch
15
+ * @param {number} maxDepth
16
+ * @param {number} depth
17
+ * @returns {HTMLElement[]}
18
+ */
19
+ function queryShadowRoot(root, skipNode, isMatch, maxDepth = 20, depth = 0) {
20
+ const matches = [];
21
+ // If the depth is above the max depth, abort the searching here.
22
+ if (depth >= maxDepth) {
23
+ return matches;
24
+ }
25
+ // Traverses a slot element
26
+ const traverseSlot = ($slot) => {
27
+ // Only check nodes that are of the type Node.ELEMENT_NODE
28
+ // Read more here https://developer.mozilla.org/en-US/docs/Web/API/Node/nodeType
29
+ const assignedNodes = $slot.assignedNodes().filter(node => node.nodeType === 1);
30
+ if (assignedNodes.length > 0) {
31
+ const $slotParent = assignedNodes[0].parentElement;
32
+ return queryShadowRoot($slotParent, skipNode, isMatch, maxDepth, depth + 1);
33
+ }
34
+ return [];
35
+ };
36
+ // Go through each child and continue the traversing if necessary
37
+ // Even though the typing says that children can't be undefined, Edge 15 sometimes gives an undefined value.
38
+ // Therefore we fallback to an empty array if it is undefined.
39
+ const children = Array.from(root.children || []);
40
+ for (const $child of children) {
41
+ // Check if the element and its descendants should be skipped
42
+ if (skipNode($child)) {
43
+ // console.log('-- SKIP', $child);
44
+ continue;
45
+ }
46
+ // console.log('$child', $child);
47
+ // If the element matches we always add it
48
+ if (isMatch($child)) {
49
+ matches.push($child);
50
+ }
51
+ if ($child.shadowRoot != null) {
52
+ // If the element has a shadow root we need to traverse it
53
+ matches.push(...queryShadowRoot($child.shadowRoot, skipNode, isMatch, maxDepth, depth + 1));
54
+ }
55
+ else if ($child.tagName === 'SLOT') {
56
+ // If the child is a slot we need to traverse each assigned node
57
+ matches.push(...traverseSlot($child));
58
+ }
59
+ else {
60
+ // Traverse the children of the element
61
+ matches.push(...queryShadowRoot($child, skipNode, isMatch, maxDepth, depth + 1));
62
+ }
63
+ }
64
+ return matches;
65
+ }
66
+ /**
67
+ * Returns whether the element is hidden.
68
+ * @param $elem
69
+ */
70
+ function isHidden($elem) {
71
+ return ($elem.hasAttribute('hidden') ||
72
+ ($elem.hasAttribute('aria-hidden') && $elem.getAttribute('aria-hidden') !== 'false') ||
73
+ // A quick and dirty way to check whether the element is hidden.
74
+ // For a more fine-grained check we could use "window.getComputedStyle" but we don't because of bad performance.
75
+ // If the element has visibility set to "hidden" or "collapse", display set to "none" or opacity set to "0" through CSS
76
+ // we won't be able to catch it here. We accept it due to the huge performance benefits.
77
+ $elem.style.display === `none` ||
78
+ $elem.style.opacity === `0` ||
79
+ $elem.style.visibility === `hidden` ||
80
+ $elem.style.visibility === `collapse`);
81
+ // If offsetParent is null we can assume that the element is hidden
82
+ // https://stackoverflow.com/questions/306305/what-would-make-offsetparent-null
83
+ // || $elem.offsetParent == null;
84
+ }
85
+ /**
86
+ * Returns whether the element is disabled.
87
+ * @param $elem
88
+ */
89
+ function isDisabled($elem) {
90
+ return $elem.hasAttribute('disabled') || ($elem.hasAttribute('aria-disabled') && $elem.getAttribute('aria-disabled') !== 'false');
91
+ }
92
+ /**
93
+ * Determines whether an element is focusable.
94
+ * Read more here: https://stackoverflow.com/questions/1599660/which-html-elements-can-receive-focus/1600194#1600194
95
+ * Or here: https://stackoverflow.com/questions/18261595/how-to-check-if-a-dom-element-is-focusable
96
+ * @param $elem
97
+ */
98
+ function isFocusable($elem) {
99
+ // Discard elements that are removed from the tab order.
100
+ if ($elem.getAttribute('tabindex') === '-1' || isHidden($elem) || isDisabled($elem)) {
101
+ return false;
102
+ }
103
+ return (
104
+ // At this point we know that the element can have focus (eg. won't be -1) if the tabindex attribute exists
105
+ $elem.hasAttribute('tabindex') ||
106
+ // Anchor tags or area tags with a href set
107
+ (($elem instanceof HTMLAnchorElement || $elem instanceof HTMLAreaElement) && $elem.hasAttribute('href')) ||
108
+ // Form elements which are not disabled
109
+ $elem instanceof HTMLButtonElement ||
110
+ $elem instanceof HTMLInputElement ||
111
+ $elem instanceof HTMLTextAreaElement ||
112
+ $elem instanceof HTMLSelectElement ||
113
+ // IFrames
114
+ $elem instanceof HTMLIFrameElement);
115
+ }
116
+
117
+ function animationTo(element, keyframes, options) {
118
+ const animated = element.animate(keyframes, Object.assign(Object.assign({}, options), { fill: 'both' }));
119
+ animated.addEventListener('finish', () => {
120
+ // @ts-ignore
121
+ animated.commitStyles();
122
+ animated.cancel();
123
+ });
124
+ return animated;
125
+ }
126
+ const keyframeDefaults = {
127
+ easing: 'cubic-bezier(0.390, 0.575, 0.565, 1.000)',
128
+ };
129
+ const KEYFRAMES = {
130
+ fadeIn: [
131
+ Object.assign(Object.assign({ offset: 0 }, keyframeDefaults), { opacity: 0 }),
132
+ Object.assign(Object.assign({ offset: 1 }, keyframeDefaults), { opacity: 1 }),
133
+ ],
134
+ fadeOut: [
135
+ Object.assign(Object.assign({ offset: 0 }, keyframeDefaults), { opacity: 1 }),
136
+ Object.assign(Object.assign({ offset: 1 }, keyframeDefaults), { opacity: 0 }),
137
+ ],
138
+ };
139
+
140
+ const spwModalCss = "/*! 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:block;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:1220px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{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-modal{align-items:center;display:none;height:100%;justify-content:center;left:0;overflow-y:auto;position:fixed;top:0;width:100%;z-index:1060}.spw-modal--opened{display:flex}.spw-modal__overlay{background:#000;height:100%;left:0;opacity:.7;position:absolute;top:0;width:100%;z-index:0}.spw-modal__content-container{align-items:stretch;background-color:#fff;border-radius:var(--spw-spacings-border-radius-lg);box-shadow:var(--spw-effect-elevation-6);box-sizing:border-box;display:flex;justify-content:center;overflow:hidden;position:absolute;width:90%}.spw-modal__content-container--small{max-width:480px}.spw-modal__content-container--medium{max-width:600px}.spw-modal__content-container--large{max-width:768px}.spw-modal__content-container--fluid{max-width:100%}.spw-modal__content{border:1px solid var(--spw-color-themes-grey-grey-300);display:flex;flex-direction:column;max-height:90vh;overflow-y:auto;width:100%}.spw-modal--sticky-buttons .spw-modal__content{overflow-y:visible}.spw-modal__icon-container{align-items:center;align-self:stretch;background-color:#fff;display:flex;justify-content:center;width:32px}.spw-modal__header{align-items:center;border-radius:1px 1px 0 0;box-sizing:border-box;color:var(--spw-colors-support-grey-grey-900);display:flex;justify-content:space-between;margin-bottom:12px;margin-top:6px;padding:24px 24px 0}.spw-modal__caption{word-wrap:break-word;overflow:hidden;white-space:pre-wrap}.spw-modal__header h2{color:var(--spw-colors-support-grey-grey-900);font-size:18px;margin:0}.spw-modal__header button{background:none;border:none;cursor:pointer;font-size:1.5em;padding:0}.spw-modal__close-button{cursor:pointer;font-size:21px;position:absolute;right:12px;top:12px}.spw-modal__close-button:hover{opacity:.7}.spw-modal__body{box-sizing:border-box;color:var(--spw-colors-support-grey-grey-700);flex:1;font-size:16px;margin-bottom:12px;padding:0 24px}.spw-modal--sticky-buttons .spw-modal__body{overflow-y:auto}.spw-modal__buttons ::slotted([slot=buttons]){padding:12px 24px 24px}.spw-modal__footer--buttons-present ::slotted(*){display:flex;gap:12px;justify-content:flex-end;padding:8px 24px 24px}.spw-modal__content-container--small .spw-modal__footer--buttons-present ::slotted(*){flex-direction:column;gap:8px}.spw-modal__content-container--medium .spw-modal__footer--buttons-present ::slotted(*){display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.spw-modal__border{align-items:center;display:flex;flex-grow:1;font-size:1.5em;justify-content:center;width:100%}";
141
+ const SpwModalStyle0 = spwModalCss;
142
+
143
+ const SpwModal$1 = /*@__PURE__*/ proxyCustomElement(class SpwModal extends H {
144
+ constructor() {
145
+ super();
146
+ this.__registerHost();
147
+ this.__attachShadow();
148
+ this.spwModalOpen = createEvent(this, "spwModalOpen", 7);
149
+ this.spwModalClose = createEvent(this, "spwModalClose", 7);
150
+ this.focusableElements = [];
151
+ this.handleClick = (event) => {
152
+ const trigger = event.target.closest('[data-modal-trigger]');
153
+ if (trigger) {
154
+ const modalId = trigger.getAttribute('data-modal-trigger');
155
+ if (modalId === this.hostElement.id) {
156
+ this.opened = true;
157
+ }
158
+ }
159
+ };
160
+ this.handleClose = (event) => {
161
+ const trigger = event.target.closest('[data-modal-close]');
162
+ if (trigger) {
163
+ const modalId = trigger.getAttribute('data-modal-close');
164
+ if (modalId === this.hostElement.id) {
165
+ this.opened = false;
166
+ }
167
+ }
168
+ };
169
+ this.handleTopFocus = () => {
170
+ this.attemptFocus(this.getLastFocusableElement());
171
+ };
172
+ this.handleBottomFocus = () => {
173
+ this.attemptFocus(this.getFirstFocusableElement());
174
+ };
175
+ this.handleKeypress = (event) => {
176
+ if (this.showModal && event.key === 'Escape') {
177
+ this.doBeforeClose('ESCAPE_KEY');
178
+ }
179
+ };
180
+ this.opened = false;
181
+ this.showModal = this.opened || false;
182
+ this.caption = 'Titre de la modal';
183
+ this.closeOnOverlayClick = true;
184
+ this.stickyButtons = false;
185
+ this.size = 'small';
186
+ this.alertIcon = '';
187
+ this.okButtonLabel = 'Confirmer';
188
+ this.cancelButtonLabel = 'Annuler';
189
+ this.slotButtonsPresent = false;
190
+ this.showCloseButton = true;
191
+ }
192
+ componentDidLoad() {
193
+ this.focusableElements = queryShadowRoot(this.hostElement.shadowRoot, el => isHidden(el) || el.matches('[data-focus-trap-edge]'), isFocusable);
194
+ document.addEventListener('click', this.handleClick);
195
+ document.addEventListener('click', this.handleClose);
196
+ document.addEventListener('keydown', this.handleKeypress);
197
+ }
198
+ disconnectedCallback() {
199
+ document.removeEventListener('click', this.handleClick);
200
+ document.removeEventListener('click', this.handleClose);
201
+ document.removeEventListener('keydown', this.handleKeypress);
202
+ }
203
+ getFirstFocusableElement() {
204
+ return this.focusableElements[0];
205
+ }
206
+ getLastFocusableElement() {
207
+ return this.focusableElements[this.focusableElements.length - 1];
208
+ }
209
+ attemptFocus(element) {
210
+ if (element == null) {
211
+ setTimeout(() => {
212
+ this.closeButton.focus();
213
+ });
214
+ return;
215
+ }
216
+ setTimeout(() => {
217
+ element.focus();
218
+ }, 0);
219
+ }
220
+ open() {
221
+ this.showModal = true;
222
+ try {
223
+ const anim = animationTo(this.modalContainer, KEYFRAMES.fadeIn, {
224
+ duration: 200,
225
+ });
226
+ anim.addEventListener('finish', () => {
227
+ setTimeout(() => {
228
+ var _a, _b;
229
+ (_a = this.getLastFocusableElement()) === null || _a === void 0 ? void 0 : _a.focus();
230
+ (_b = this.getLastFocusableElement()) === null || _b === void 0 ? void 0 : _b.blur();
231
+ }, 0);
232
+ this.spwModalOpen.emit();
233
+ });
234
+ }
235
+ catch (err) {
236
+ this.spwModalOpen.emit();
237
+ }
238
+ }
239
+ close() {
240
+ try {
241
+ const anim = animationTo(this.modalContainer, KEYFRAMES.fadeOut, {
242
+ duration: 200,
243
+ });
244
+ anim.addEventListener('finish', () => {
245
+ this.showModal = false;
246
+ this.spwModalClose.emit();
247
+ });
248
+ }
249
+ catch (err) {
250
+ this.showModal = false;
251
+ this.spwModalClose.emit();
252
+ }
253
+ }
254
+ doBeforeClose(trigger) {
255
+ const triggers = [];
256
+ triggers.push(trigger);
257
+ const prevented = triggers.some(event => event.defaultPrevented);
258
+ if (!prevented) {
259
+ this.opened = false;
260
+ }
261
+ }
262
+ openedChanged(newValue) {
263
+ newValue === true ? this.open() : this.close();
264
+ }
265
+ handleOverlayClick() {
266
+ if (this.closeOnOverlayClick) {
267
+ this.doBeforeClose('BACKDROP');
268
+ }
269
+ }
270
+ get elementClass() {
271
+ return {
272
+ 'spw-modal': true,
273
+ 'spw-modal--opened': this.showModal,
274
+ 'spw-modal--sticky-buttons': this.stickyButtons,
275
+ };
276
+ }
277
+ render() {
278
+ return (h(Host, { key: '4fd8ce50409d48a8348542e0b8de43e93992e707' }, h("div", { key: 'e7d0beefb5b9fd255cf2d4728850189d8ef7f779', ref: el => (this.modalContainer = el), class: this.elementClass }, h("div", { key: '884d4f6e571b86a7c4956305e0d56c8612ac44a4', class: "spw-modal__overlay", onClick: () => this.handleOverlayClick() }), h("div", { key: 'c244eda2abf043741bd9478b68180b6ac58887b1', "data-focus-trap-edge": true, onFocus: this.handleTopFocus, tabindex: "0" }), h("div", { key: 'f134fba630f9ab4929ca0104e37f352aa23d187c', class: `spw-modal__content-container spw-modal__content-container--${this.size}`, role: "dialog", "aria-modal": "true", "aria-label": this.caption }, h("div", { key: '08f2f50cdc0073bd739d653bfe652d84889582de', class: "spw-modal__content" }, h("div", { key: '81581611eb5d7b384694de9fd56819696d169a9d', class: "spw-modal__header" }, h("h2", { key: 'cebf2dcdb0d0bf5b84dec83815f95d2bd04be4ff', class: "spw-modal__caption" }, this.caption), this.showCloseButton && (h("spw-icon", { key: '7fc41c76aebb18a8cba76eb6e76df0bd30735945', class: "spw-modal__close-button", ref: el => (this.closeButton = el), icon: "fa-xmark", onClick: () => this.doBeforeClose('CLOSE_BUTTON') }))), h("div", { key: '47c627e9b302629fe48110cd5696afc62f5f07a4', class: "spw-modal__body" }, h("slot", { key: 'b447f58d68463e2a038b2730cb92fe65cd89733b', name: "content" })), h("div", { key: 'f03e2d95cf416a4aeb7c64083568b050956515e0', class: "spw-modal__buttons" }, h("slot", { key: '8959b3535b64398ed8754aa736d6276daf462fb4', name: "buttons" })))), h("div", { key: '9842e77f6c9f504cc41fd04795a42dfaf27dd475', "data-focus-trap-edge": true, onFocus: this.handleBottomFocus, tabindex: "0" }))));
279
+ }
280
+ get hostElement() { return this; }
281
+ static get watchers() { return {
282
+ "opened": ["openedChanged"]
283
+ }; }
284
+ static get style() { return SpwModalStyle0; }
285
+ }, [1, "spw-modal", {
286
+ "opened": [1540],
287
+ "caption": [1],
288
+ "closeOnOverlayClick": [4, "close-on-overlay-click"],
289
+ "stickyButtons": [4, "sticky-buttons"],
290
+ "size": [1],
291
+ "alertIcon": [1, "alert-icon"],
292
+ "okButtonLabel": [1, "ok-button-label"],
293
+ "cancelButtonLabel": [1, "cancel-button-label"],
294
+ "showCloseButton": [4, "show-close-button"],
295
+ "showModal": [32],
296
+ "slotButtonsPresent": [32]
297
+ }, undefined, {
298
+ "opened": ["openedChanged"]
299
+ }]);
300
+ function defineCustomElement$1() {
301
+ if (typeof customElements === "undefined") {
302
+ return;
303
+ }
304
+ const components = ["spw-modal", "spw-icon"];
305
+ components.forEach(tagName => { switch (tagName) {
306
+ case "spw-modal":
307
+ if (!customElements.get(tagName)) {
308
+ customElements.define(tagName, SpwModal$1);
309
+ }
310
+ break;
311
+ case "spw-icon":
312
+ if (!customElements.get(tagName)) {
313
+ defineCustomElement$2();
314
+ }
315
+ break;
316
+ } });
317
+ }
318
+
319
+ const SpwModal = SpwModal$1;
320
+ const defineCustomElement = defineCustomElement$1;
321
+
322
+ export { SpwModal, defineCustomElement };
323
+
324
+ //# sourceMappingURL=spw-modal.js.map
@@ -0,0 +1 @@
1
+ {"file":"spw-modal.js","mappings":"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","names":["SpwModal"],"sources":["src/utils/focus-trap.ts","src/utils/animation.ts","src/components/spw-modal/spw-modal.scss?tag=spw-modal&encapsulation=shadow","src/components/spw-modal/spw-modal.tsx"],"sourcesContent":["/**\n * Copy/pasted from https://github.com/andreasbm/focus-trap\n */\n\n/**\n * Traverses the slots of the open shadowroots and returns all children matching the query.\n * We need to traverse each child-depth one at a time because if an element should be skipped\n * (for example because it is hidden) we need to skip all of it's children. If we use querySelectorAll(\"*\")\n * the information of whether the children is within a hidden parent is lost.\n * @param {ShadowRoot | HTMLElement} root\n * @param skipNode\n * @param isMatch\n * @param {number} maxDepth\n * @param {number} depth\n * @returns {HTMLElement[]}\n */\nexport function queryShadowRoot(\n root: ShadowRoot | HTMLElement,\n skipNode: ($elem: HTMLElement) => boolean,\n isMatch: ($elem: HTMLElement) => boolean,\n maxDepth: number = 20,\n depth: number = 0,\n): HTMLElement[] {\n const matches: HTMLElement[] = [];\n\n // If the depth is above the max depth, abort the searching here.\n if (depth >= maxDepth) {\n return matches;\n }\n\n // Traverses a slot element\n const traverseSlot = ($slot: HTMLSlotElement) => {\n // Only check nodes that are of the type Node.ELEMENT_NODE\n // Read more here https://developer.mozilla.org/en-US/docs/Web/API/Node/nodeType\n const assignedNodes = $slot.assignedNodes().filter(node => node.nodeType === 1);\n if (assignedNodes.length > 0) {\n const $slotParent = assignedNodes[0].parentElement!;\n return queryShadowRoot($slotParent, skipNode, isMatch, maxDepth, depth + 1);\n }\n\n return [];\n };\n\n // Go through each child and continue the traversing if necessary\n // Even though the typing says that children can't be undefined, Edge 15 sometimes gives an undefined value.\n // Therefore we fallback to an empty array if it is undefined.\n const children = Array.from(root.children || []) as HTMLElement[];\n for (const $child of children) {\n // Check if the element and its descendants should be skipped\n if (skipNode($child)) {\n // console.log('-- SKIP', $child);\n continue;\n }\n\n // console.log('$child', $child);\n\n // If the element matches we always add it\n if (isMatch($child)) {\n matches.push($child);\n }\n\n if ($child.shadowRoot != null) {\n // If the element has a shadow root we need to traverse it\n matches.push(...queryShadowRoot($child.shadowRoot, skipNode, isMatch, maxDepth, depth + 1));\n } else if ($child.tagName === 'SLOT') {\n // If the child is a slot we need to traverse each assigned node\n matches.push(...traverseSlot($child as HTMLSlotElement));\n } else {\n // Traverse the children of the element\n matches.push(...queryShadowRoot($child, skipNode, isMatch, maxDepth, depth + 1));\n }\n }\n\n return matches;\n}\n\n/**\n * Returns whether the element is hidden.\n * @param $elem\n */\nexport function isHidden($elem: HTMLElement): boolean {\n return (\n $elem.hasAttribute('hidden') ||\n ($elem.hasAttribute('aria-hidden') && $elem.getAttribute('aria-hidden') !== 'false') ||\n // A quick and dirty way to check whether the element is hidden.\n // For a more fine-grained check we could use \"window.getComputedStyle\" but we don't because of bad performance.\n // If the element has visibility set to \"hidden\" or \"collapse\", display set to \"none\" or opacity set to \"0\" through CSS\n // we won't be able to catch it here. We accept it due to the huge performance benefits.\n $elem.style.display === `none` ||\n $elem.style.opacity === `0` ||\n $elem.style.visibility === `hidden` ||\n $elem.style.visibility === `collapse`\n );\n\n // If offsetParent is null we can assume that the element is hidden\n // https://stackoverflow.com/questions/306305/what-would-make-offsetparent-null\n // || $elem.offsetParent == null;\n}\n\n/**\n * Returns whether the element is disabled.\n * @param $elem\n */\nexport function isDisabled($elem: HTMLElement): boolean {\n return $elem.hasAttribute('disabled') || ($elem.hasAttribute('aria-disabled') && $elem.getAttribute('aria-disabled') !== 'false');\n}\n\n/**\n * Determines whether an element is focusable.\n * Read more here: https://stackoverflow.com/questions/1599660/which-html-elements-can-receive-focus/1600194#1600194\n * Or here: https://stackoverflow.com/questions/18261595/how-to-check-if-a-dom-element-is-focusable\n * @param $elem\n */\nexport function isFocusable($elem: HTMLElement): boolean {\n // Discard elements that are removed from the tab order.\n if ($elem.getAttribute('tabindex') === '-1' || isHidden($elem) || isDisabled($elem)) {\n return false;\n }\n\n return (\n // At this point we know that the element can have focus (eg. won't be -1) if the tabindex attribute exists\n $elem.hasAttribute('tabindex') ||\n // Anchor tags or area tags with a href set\n (($elem instanceof HTMLAnchorElement || $elem instanceof HTMLAreaElement) && $elem.hasAttribute('href')) ||\n // Form elements which are not disabled\n $elem instanceof HTMLButtonElement ||\n $elem instanceof HTMLInputElement ||\n $elem instanceof HTMLTextAreaElement ||\n $elem instanceof HTMLSelectElement ||\n // IFrames\n $elem instanceof HTMLIFrameElement\n );\n}\n","export function animationTo(element: HTMLElement, keyframes: Keyframe | Keyframe[], options?: KeyframeAnimationOptions) {\n const animated = element.animate(keyframes, { ...options, fill: 'both' });\n animated.addEventListener('finish', () => {\n // @ts-ignore\n animated.commitStyles();\n animated.cancel();\n });\n\n return animated;\n}\n\nconst keyframeDefaults = {\n easing: 'cubic-bezier(0.390, 0.575, 0.565, 1.000)',\n};\n\nexport const KEYFRAMES = {\n fadeIn: [\n {\n offset: 0,\n ...keyframeDefaults,\n opacity: 0,\n },\n {\n offset: 1,\n ...keyframeDefaults,\n opacity: 1,\n },\n ],\n fadeOut: [\n {\n offset: 0,\n ...keyframeDefaults,\n opacity: 1,\n },\n {\n offset: 1,\n ...keyframeDefaults,\n opacity: 0,\n },\n ],\n};\n",":host {\n display: block;\n}\n\n.spw-modal {\n display: none;\n justify-content: center;\n align-items: center;\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1060;\n overflow-y: auto;\n\n &--opened {\n display: flex;\n }\n}\n\n.spw-modal__overlay {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background: black;\n opacity: 0.7;\n z-index: 0;\n}\n\n.spw-modal__content-container {\n position: absolute;\n display: flex;\n justify-content: center;\n width: 90%;\n background-color: #fff;\n box-shadow: var(--spw-effect-elevation-6);\n overflow: hidden;\n box-sizing: border-box;\n align-items: stretch;\n border-radius: var(--spw-spacings-border-radius-lg);\n\n &--small {\n max-width: 480px;\n }\n\n &--medium {\n max-width: 600px;\n }\n\n &--large {\n max-width: 768px;\n }\n\n &--fluid {\n max-width: 100%;\n }\n}\n\n.spw-modal__content {\n display: flex;\n flex-direction: column;\n border: 1px solid var(--spw-color-themes-grey-grey-300);\n width: 100%;\n max-height: 90vh;\n overflow-y: auto;\n\n .spw-modal--sticky-buttons & {\n overflow-y: visible;\n }\n}\n\n.spw-modal__icon-container {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 32px;\n background-color: #fff;\n align-self: stretch;\n}\n\n.spw-modal__header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 24px;\n padding-bottom: 0;\n margin-top: 6px;\n margin-bottom: 12px;\n box-sizing: border-box;\n border-radius: 1px 1px 0px 0px;\n color: var(--spw-colors-support-grey-grey-900);\n}\n\n.spw-modal__caption {\n overflow: hidden;\n white-space: pre-wrap;\n word-wrap: break-word;\n}\n\n.spw-modal__header h2 {\n margin: 0;\n font-size: 18px;\n color: var(--spw-colors-support-grey-grey-900);\n}\n\n.spw-modal__header button {\n background: none;\n border: none;\n font-size: 1.5em;\n padding: 0;\n cursor: pointer;\n}\n\n.spw-modal__close-button {\n position: absolute;\n top: 12px;\n right: 12px;\n cursor: pointer;\n font-size: 21px;\n &:hover {\n opacity: 0.7;\n }\n}\n\n.spw-modal__body {\n padding: 0 24px;\n margin-bottom: 12px;\n box-sizing: border-box;\n flex: 1;\n font-size: 16px;\n color: var(--spw-colors-support-grey-grey-700);\n\n .spw-modal--sticky-buttons & {\n overflow-y: auto;\n }\n}\n\n.spw-modal__buttons {\n ::slotted([slot='buttons']) {\n padding: 24px;\n padding-top: 12px;\n }\n}\n\n.spw-modal__footer--buttons-present ::slotted(*) {\n display: flex;\n justify-content: flex-end;\n gap: 12px;\n padding: 24px;\n padding-top: 8px;\n\n .spw-modal__content-container--small & {\n flex-direction: column;\n gap: 8px;\n }\n\n .spw-modal__content-container--medium & {\n display: grid;\n grid-template-columns: repeat(2, minmax(0, 1fr));\n }\n}\n\n.spw-modal__border {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n font-size: 1.5em;\n flex-grow: 1;\n}\n","import { Component, Prop, Element, State, Event, Host, EventEmitter, h, Watch } from '@stencil/core';\nimport { queryShadowRoot, isHidden, isFocusable } from '@utils/focus-trap';\nimport { animationTo, KEYFRAMES } from '@utils/animation';\n\ntype CloseEventTrigger = 'CLOSE_BUTTON' | 'ESCAPE_KEY' | 'BACKDROP';\n\nexport interface BeforeCloseEventDetail {\n trigger: CloseEventTrigger;\n}\n\n@Component({\n tag: 'spw-modal',\n styleUrl: 'spw-modal.scss',\n shadow: true,\n})\nexport class SpwModal {\n /** Indique si la modal est ouverte ou fermée, mutable et reflétée dans le DOM */\n @Prop({ reflect: true, mutable: true }) opened?: boolean = false;\n\n @State() showModal: boolean = this.opened || false;\n\n /** Titre de la modal */\n @Prop() caption: string = 'Titre de la modal';\n /** Indique si la fermeture de la modal est possible en cliquant sur l'overlay */\n @Prop() closeOnOverlayClick: boolean = true;\n /** Rend les boutons en bas de la modal \"collants\" (toujours visibles) si vrai */\n @Prop() stickyButtons: boolean = false;\n /** Événement déclenché lors de l'ouverture de la modal */\n @Event() spwModalOpen: EventEmitter;\n /** Événement déclenché lors de la fermeture de la modal */\n @Event() spwModalClose: EventEmitter;\n /** Définit la taille de la modal : 'small', 'medium', 'large' ou 'fluid' */\n @Prop() size: 'small' | 'medium' | 'large' | 'fluid' = 'small';\n /** Icône d'alerte à afficher dans la modal */\n @Prop() alertIcon: string = '';\n /** Texte du bouton de confirmation */\n @Prop() okButtonLabel: string = 'Confirmer';\n /** Texte du bouton d'annulation */\n @Prop() cancelButtonLabel: string = 'Annuler';\n\n @Element() hostElement: HTMLSpwModalElement;\n\n @State() slotButtonsPresent: boolean = false;\n\n /** Indique si le bouton de fermeture est visible */\n @Prop() showCloseButton: boolean = true;\n\n private modalContainer: HTMLElement;\n private focusableElements: HTMLElement[] = [];\n private closeButton: HTMLSpwIconElement;\n\n componentDidLoad() {\n this.focusableElements = queryShadowRoot(this.hostElement.shadowRoot, el => isHidden(el) || el.matches('[data-focus-trap-edge]'), isFocusable);\n document.addEventListener('click', this.handleClick);\n document.addEventListener('click', this.handleClose);\n document.addEventListener('keydown', this.handleKeypress);\n }\n\n disconnectedCallback() {\n document.removeEventListener('click', this.handleClick);\n document.removeEventListener('click', this.handleClose);\n document.removeEventListener('keydown', this.handleKeypress);\n }\n\n private handleClick = (event: MouseEvent) => {\n const trigger = (event.target as HTMLElement).closest('[data-modal-trigger]');\n if (trigger) {\n const modalId = trigger.getAttribute('data-modal-trigger');\n if (modalId === this.hostElement.id) {\n this.opened = true;\n }\n }\n };\n\n private handleClose = (event: MouseEvent) => {\n const trigger = (event.target as HTMLElement).closest('[data-modal-close]');\n if (trigger) {\n const modalId = trigger.getAttribute('data-modal-close');\n if (modalId === this.hostElement.id) {\n this.opened = false;\n }\n }\n };\n\n private getFirstFocusableElement(): HTMLElement | null {\n return this.focusableElements[0];\n }\n\n private getLastFocusableElement(): HTMLElement | null {\n return this.focusableElements[this.focusableElements.length - 1];\n }\n\n private handleTopFocus = () => {\n this.attemptFocus(this.getLastFocusableElement());\n };\n\n private handleBottomFocus = () => {\n this.attemptFocus(this.getFirstFocusableElement());\n };\n\n private attemptFocus(element: HTMLElement | null) {\n if (element == null) {\n setTimeout(() => {\n this.closeButton.focus();\n });\n return;\n }\n\n setTimeout(() => {\n element.focus();\n }, 0);\n }\n\n private open() {\n this.showModal = true;\n try {\n const anim = animationTo(this.modalContainer, KEYFRAMES.fadeIn, {\n duration: 200,\n });\n anim.addEventListener('finish', () => {\n setTimeout(() => {\n this.getLastFocusableElement()?.focus();\n this.getLastFocusableElement()?.blur();\n }, 0);\n\n this.spwModalOpen.emit();\n });\n } catch (err) {\n this.spwModalOpen.emit();\n }\n }\n\n private close() {\n try {\n const anim = animationTo(this.modalContainer, KEYFRAMES.fadeOut, {\n duration: 200,\n });\n anim.addEventListener('finish', () => {\n this.showModal = false;\n this.spwModalClose.emit();\n });\n } catch (err) {\n this.showModal = false;\n this.spwModalClose.emit();\n }\n }\n\n private handleKeypress = (event: KeyboardEvent) => {\n if (this.showModal && event.key === 'Escape') {\n this.doBeforeClose('ESCAPE_KEY');\n }\n };\n\n private doBeforeClose(trigger: CloseEventTrigger) {\n const triggers = [];\n triggers.push(trigger);\n const prevented = triggers.some(event => event.defaultPrevented);\n if (!prevented) {\n this.opened = false;\n }\n }\n\n @Watch('opened')\n openedChanged(newValue: boolean) {\n newValue === true ? this.open() : this.close();\n }\n\n private handleOverlayClick() {\n if (this.closeOnOverlayClick) {\n this.doBeforeClose('BACKDROP');\n }\n }\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-modal': true,\n 'spw-modal--opened': this.showModal,\n 'spw-modal--sticky-buttons': this.stickyButtons,\n };\n }\n\n render() {\n return (\n <Host>\n <div ref={el => (this.modalContainer = el)} class={this.elementClass}>\n <div class=\"spw-modal__overlay\" onClick={() => this.handleOverlayClick()}></div>\n <div data-focus-trap-edge onFocus={this.handleTopFocus} tabindex=\"0\"></div>\n <div class={`spw-modal__content-container spw-modal__content-container--${this.size}`} role=\"dialog\" aria-modal=\"true\" aria-label={this.caption}>\n <div class=\"spw-modal__content\">\n <div class=\"spw-modal__header\">\n <h2 class=\"spw-modal__caption\">{this.caption}</h2>\n {this.showCloseButton && (\n <spw-icon class=\"spw-modal__close-button\" ref={el => (this.closeButton = el)} icon=\"fa-xmark\" onClick={() => this.doBeforeClose('CLOSE_BUTTON')}></spw-icon>\n )}\n </div>\n <div class=\"spw-modal__body\">\n <slot name=\"content\" />\n </div>\n <div class=\"spw-modal__buttons\">\n <slot name=\"buttons\"></slot>\n </div>\n </div>\n </div>\n <div data-focus-trap-edge onFocus={this.handleBottomFocus} tabindex=\"0\"></div>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SpwMosaicItem extends Components.SpwMosaicItem, HTMLElement {}
4
+ export const SpwMosaicItem: {
5
+ prototype: SpwMosaicItem;
6
+ new (): SpwMosaicItem;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,52 @@
1
+ import { p as proxyCustomElement, H, h, c as Host } from './p-3706b88e.js';
2
+
3
+ const spwMosaicItemCss = ".spw-tw-px-3{padding-left:.75rem;padding-right:.75rem}/*! 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%;--spw-mosaic-item-width-mobile:100%;--spw-mosaic-item-width-tablet:100%;--spw-mosaic-item-width-desktop:100%;box-sizing:border-box;font-size:100%;line-height:1.3;margin-bottom:1.5rem;padding-left:.75rem;padding-right:.75rem;width:var(--spw-mosaic-item-width-mobile)}: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:1220px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{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)}}@media (min-width:768px){:host{width:var(--spw-mosaic-item-width-tablet)}}@media (min-width:1024px){:host{width:var(--spw-mosaic-item-width-desktop)}}.spw-mobile-1{--spw-mosaic-item-width-mobile:100%}.spw-tablet-1{--spw-mosaic-item-width-tablet:100%}.spw-desktop-1{--spw-mosaic-item-width-desktop:100%}.spw-mobile-2{--spw-mosaic-item-width-mobile:50%}.spw-tablet-2{--spw-mosaic-item-width-tablet:50%}.spw-desktop-2{--spw-mosaic-item-width-desktop:50%}.spw-mobile-3{--spw-mosaic-item-width-mobile:33.33333%}.spw-tablet-3{--spw-mosaic-item-width-tablet:33.33333%}.spw-desktop-3{--spw-mosaic-item-width-desktop:33.33333%}.spw-mobile-4{--spw-mosaic-item-width-mobile:25%}.spw-tablet-4{--spw-mosaic-item-width-tablet:25%}.spw-desktop-4{--spw-mosaic-item-width-desktop:25%}.spw-mobile-5{--spw-mosaic-item-width-mobile:20%}.spw-tablet-5{--spw-mosaic-item-width-tablet:20%}.spw-desktop-5{--spw-mosaic-item-width-desktop:20%}.spw-mobile-6{--spw-mosaic-item-width-mobile:16.66667%}.spw-tablet-6{--spw-mosaic-item-width-tablet:16.66667%}.spw-desktop-6{--spw-mosaic-item-width-desktop:16.66667%}.spw-mobile-7{--spw-mosaic-item-width-mobile:14.28571%}.spw-tablet-7{--spw-mosaic-item-width-tablet:14.28571%}.spw-desktop-7{--spw-mosaic-item-width-desktop:14.28571%}.spw-mobile-8{--spw-mosaic-item-width-mobile:12.5%}.spw-tablet-8{--spw-mosaic-item-width-tablet:12.5%}.spw-desktop-8{--spw-mosaic-item-width-desktop:12.5%}.spw-mobile-9{--spw-mosaic-item-width-mobile:11.11111%}.spw-tablet-9{--spw-mosaic-item-width-tablet:11.11111%}.spw-desktop-9{--spw-mosaic-item-width-desktop:11.11111%}.spw-mobile-10{--spw-mosaic-item-width-mobile:10%}.spw-tablet-10{--spw-mosaic-item-width-tablet:10%}.spw-desktop-10{--spw-mosaic-item-width-desktop:10%}.spw-mobile-11{--spw-mosaic-item-width-mobile:9.09091%}.spw-tablet-11{--spw-mosaic-item-width-tablet:9.09091%}.spw-desktop-11{--spw-mosaic-item-width-desktop:9.09091%}.spw-mobile-12{--spw-mosaic-item-width-mobile:8.33333%}.spw-tablet-12{--spw-mosaic-item-width-tablet:8.33333%}.spw-desktop-12{--spw-mosaic-item-width-desktop:8.33333%}.spw-tw-mb-6{margin-bottom:1.5rem}";
4
+ const SpwMosaicItemStyle0 = spwMosaicItemCss;
5
+
6
+ const SpwMosaicItem$1 = /*@__PURE__*/ proxyCustomElement(class SpwMosaicItem extends H {
7
+ constructor() {
8
+ super();
9
+ this.__registerHost();
10
+ this.__attachShadow();
11
+ this.classString = 'spw-tw-px-3 spw-tw-mb-6';
12
+ }
13
+ componentDidLoad() {
14
+ this.el.closest('spw-mosaic').addEventListener('mosaicConfigurationChanged', this.handleConfigurationChange.bind(this));
15
+ }
16
+ disconnectedCallback() {
17
+ this.el.closest('spw-mosaic').removeEventListener('mosaicConfigurationChanged', this.handleConfigurationChange.bind(this));
18
+ }
19
+ handleConfigurationChange(event) {
20
+ const { colsMobile, colsTablet, colsDesktop } = event.detail;
21
+ this.el.style.setProperty('--spw-mosaic-item-width-mobile', `calc(100% / ${colsMobile})`);
22
+ this.el.style.setProperty('--spw-mosaic-item-width-tablet', `calc(100% / ${colsTablet})`);
23
+ this.el.style.setProperty('--spw-mosaic-item-width-desktop', `calc(100% / ${colsDesktop})`);
24
+ }
25
+ render() {
26
+ return (h(Host, { key: 'c2f0d85eed9a6c3a05b155f3adc340e788b40213' }, h("slot", { key: 'ea74766894f7a06dc67a991a4e13949cb3144b38' })));
27
+ }
28
+ get el() { return this; }
29
+ static get style() { return SpwMosaicItemStyle0; }
30
+ }, [1, "spw-mosaic-item", {
31
+ "classString": [32]
32
+ }]);
33
+ function defineCustomElement$1() {
34
+ if (typeof customElements === "undefined") {
35
+ return;
36
+ }
37
+ const components = ["spw-mosaic-item"];
38
+ components.forEach(tagName => { switch (tagName) {
39
+ case "spw-mosaic-item":
40
+ if (!customElements.get(tagName)) {
41
+ customElements.define(tagName, SpwMosaicItem$1);
42
+ }
43
+ break;
44
+ } });
45
+ }
46
+
47
+ const SpwMosaicItem = SpwMosaicItem$1;
48
+ const defineCustomElement = defineCustomElement$1;
49
+
50
+ export { SpwMosaicItem, defineCustomElement };
51
+
52
+ //# sourceMappingURL=spw-mosaic-item.js.map
@@ -0,0 +1 @@
1
+ {"file":"spw-mosaic-item.js","mappings":";;AAAA,MAAM,gBAAgB,GAAG,6yJAA6yJ,CAAC;AACv0J,4BAAe,gBAAgB;;MCMlBA,eAAa;;;;;2BAGO,yBAAyB;;IAExD,gBAAgB;QACd,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,gBAAgB,CAAC,4BAA4B,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KACzH;IAED,oBAAoB;QAClB,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,mBAAmB,CAAC,4BAA4B,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KAC5H;IAEO,yBAAyB,CAAC,KAAK;QACrC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;QAC7D,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,eAAe,UAAU,GAAG,CAAC,CAAC;QAC1F,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,gCAAgC,EAAE,eAAe,UAAU,GAAG,CAAC,CAAC;QAC1F,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,iCAAiC,EAAE,eAAe,WAAW,GAAG,CAAC,CAAC;KAC7F;IAED,MAAM;QACJ,QACE,EAAC,IAAI,uDACH,8DAAa,CACR,EACP;KACH;;;;;;;;;;;;;;;;;;;;;;;;;","names":["SpwMosaicItem"],"sources":["src/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.scss?tag=spw-mosaic-item&encapsulation=shadow","src/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.tsx"],"sourcesContent":[":host {\n --spw-mosaic-item-width-mobile: 100%;\n --spw-mosaic-item-width-tablet: 100%;\n --spw-mosaic-item-width-desktop: 100%;\n\n width: var(--spw-mosaic-item-width-mobile);\n @apply spw-tw-px-3 spw-tw-mb-6;\n}\n\n@media (min-width: 768px) {\n :host {\n width: var(--spw-mosaic-item-width-tablet);\n }\n}\n\n@media (min-width: 1024px) {\n :host {\n width: var(--spw-mosaic-item-width-desktop);\n }\n}\n\n@for $i from 1 through 12 {\n .spw-mobile-#{$i} {\n --spw-mosaic-item-width-mobile: calc(100% / #{$i});\n }\n\n .spw-tablet-#{$i} {\n --spw-mosaic-item-width-tablet: calc(100% / #{$i});\n }\n\n .spw-desktop-#{$i} {\n --spw-mosaic-item-width-desktop: calc(100% / #{$i});\n }\n}\n","import { Element, Component, Host, h, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-mosaic-item',\n styleUrl: 'spw-mosaic-item.scss',\n shadow: true,\n})\nexport class SpwMosaicItem {\n @Element() el: HTMLSpwMosaicItemElement;\n\n @State() classString: string = 'spw-tw-px-3 spw-tw-mb-6';\n\n componentDidLoad() {\n this.el.closest('spw-mosaic').addEventListener('mosaicConfigurationChanged', this.handleConfigurationChange.bind(this));\n }\n\n disconnectedCallback() {\n this.el.closest('spw-mosaic').removeEventListener('mosaicConfigurationChanged', this.handleConfigurationChange.bind(this));\n }\n\n private handleConfigurationChange(event) {\n const { colsMobile, colsTablet, colsDesktop } = event.detail;\n this.el.style.setProperty('--spw-mosaic-item-width-mobile', `calc(100% / ${colsMobile})`);\n this.el.style.setProperty('--spw-mosaic-item-width-tablet', `calc(100% / ${colsTablet})`);\n this.el.style.setProperty('--spw-mosaic-item-width-desktop', `calc(100% / ${colsDesktop})`);\n }\n\n render() {\n return (\n <Host>\n <slot></slot>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SpwMosaic extends Components.SpwMosaic, HTMLElement {}
4
+ export const SpwMosaic: {
5
+ prototype: SpwMosaic;
6
+ new (): SpwMosaic;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;