@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 @@
1
+ {"version":3,"file":"spw-pagination.js","sourceRoot":"","sources":["../../../src/components/spw-pagination/spw-pagination.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAgB,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAOtG,MAAM,OAAO,aAAa;;QA8BhB,mBAAc,GAAG,GAAG,EAAE;YAC5B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC;QAC1C,CAAC,CAAC;;;0BA1B4B,KAAK;uBAEI,SAAS;2BAED,CAAC;8BAMd,EAAE;wBACP,MAAM,CAAC,UAAU,GAAG,GAAG;;IAGpD,iBAAiB;QACf,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAClD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IACzD,CAAC;IAED,oBAAoB;QAClB,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5D,CAAC;IASD,mBAAmB;QACjB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;IACnE,CAAC;IAEO,QAAQ,CAAC,IAAY;QAC3B,IAAI,IAAI,KAAK,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAC1F,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;YAClD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAEO,iBAAiB,CAAC,KAAY;QACpC,MAAM,UAAU,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QAC5D,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;QACjC,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACzD,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACjC,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,GAAG,EAAE;gBACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACtB,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC;IACH,CAAC;IAEO,kBAAkB;;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACxC,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,MAAM,CAAC;QACxE,MAAM,gBAAgB,GAAG,aAAa,GAAG,CAAC,IAAI,CAAA,MAAA,KAAK,CAAC,CAAC,CAAC,0CAAE,IAAI,MAAK,KAAK,CAAC;QACvE,MAAM,cAAc,GAAG,aAAa,GAAG,CAAC,IAAI,CAAA,MAAA,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,0CAAE,IAAI,MAAK,KAAK,CAAC;QAEpF,IAAI,eAAe,GAAG,kCAAkC,IAAI,CAAC,WAAW,0BAA0B,IAAI,CAAC,UAAU,EAAE,CAAC;QAEpH,IAAI,aAAa,KAAK,CAAC,EAAE,CAAC;YACxB,eAAe,IAAI,kCAAkC,CAAC;QACxD,CAAC;aAAM,IAAI,gBAAgB,EAAE,CAAC;YAC5B,eAAe,IAAI,iCAAiC,CAAC;QACvD,CAAC;aAAM,IAAI,cAAc,EAAE,CAAC;YAC1B,eAAe,IAAI,+BAA+B,CAAC;QACrD,CAAC;QAED,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,aAAa,CAAC,KAAoB;QACxC,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;YAC/C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;gBACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACtB,CAAC;QACH,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;QAC1C,IAAI,MAAM,IAAI,CAAC,EAAE,CAAC;YAChB,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC;IAC3B,CAAC;IAEO,kBAAkB;QACxB,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;QAEnD,IAAI,QAAQ,EAAE,CAAC;YACb,cAAc;YACd,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;gBACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;oBACrC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,mCAAmC,EAAE,CAAC,CAAC;gBACtE,CAAC;YACH,CAAC;iBAAM,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;gBAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBAC5B,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,mCAAmC,EAAE,CAAC,CAAC;gBACtE,CAAC;gBACD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,2BAA2B,EAAE,CAAC,CAAC;YACvE,CAAC;iBAAM,IAAI,WAAW,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;gBACzC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC;gBAC9D,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,IAAI,CAAC,GAAG,UAAU,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;oBAClD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,iCAAiC,EAAE,CAAC,CAAC;gBACpE,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC;gBAC9D,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,IAAI,CAAC,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBACxD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,oCAAoC,EAAE,CAAC,CAAC;gBACvE,CAAC;gBACD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,2BAA2B,EAAE,CAAC,CAAC;YACvE,CAAC;QACH,CAAC;aAAM,CAAC;YACN,eAAe;YACf,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;gBACpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;oBACrC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,mCAAmC,EAAE,CAAC,CAAC;gBACtE,CAAC;YACH,CAAC;iBAAM,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;gBAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBAC5B,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,mCAAmC,EAAE,CAAC,CAAC;gBACtE,CAAC;gBACD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,2BAA2B,EAAE,CAAC,CAAC;YACvE,CAAC;iBAAM,IAAI,WAAW,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;gBACzC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC;gBAC9D,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,IAAI,CAAC,GAAG,UAAU,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;oBAClD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,iCAAiC,EAAE,CAAC,CAAC;gBACpE,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,6BAA6B,EAAE,CAAC,CAAC;gBAC9D,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,IAAI,CAAC,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBACxD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,oCAAoC,EAAE,CAAC,CAAC;gBACvE,CAAC;gBACD,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,gCAAgC,EAAE,CAAC,CAAC;gBACrE,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,2BAA2B,EAAE,CAAC,CAAC;YACvE,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM;QACJ,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACxC,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QAC3C,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC;QAEzD,MAAM,SAAS,GAAG,aAAa,IAAI,CACjC,2DAAI,KAAK,EAAC,gFAAgF;YACxF,+DAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;gBACxD,iEAAU,IAAI,EAAC,iBAAiB,GAAY;;gBAAC,6DAAM,KAAK,EAAC,iCAAiC,0BAAiB,CACpG,CACN,CACN,CAAC;QAEF,MAAM,SAAS,GAAG,aAAa,IAAI,CACjC,2DAAI,KAAK,EAAC,gFAAgF;YACxF,+DAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;gBACxD,6DAAM,KAAK,EAAC,iCAAiC,cAAe;;gBAAC,iEAAU,IAAI,EAAC,kBAAkB,GAAY,CACnG,CACN,CACN,CAAC;QAEF,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAC9C,2DAAI,KAAK,EAAC,kDAAkD;YAC1D,+DAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;gBACxD,iEAAU,IAAI,EAAC,iBAAiB,GAAY;;gBAAC,qFAAsB,CAC5D,CACN,CACN,CAAC;QAEF,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,IAAI,CAC5D,2DAAI,KAAK,EAAC,kDAAkD;YAC1D,+DAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,UAAU;gBACvG,yEAAoB;;gBAAC,iEAAU,IAAI,EAAC,kBAAkB,GAAY,CAC3D,CACN,CACN,CAAC;QAEF,MAAM,YAAY,GAAG,CACnB,2DAAI,KAAK,EAAC,+BAA+B;YACtC,eAAe;YACf,eAAe,CACb,CACN,CAAC;QAEF,OAAO,CACL,EAAC,IAAI;YACH,4DAAK,KAAK,EAAE,IAAI,CAAC,kBAAkB,EAAE;gBAClC,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,CAC3B,EAAC,QAAQ;oBACP;wBACG,SAAS;wBACV,2DAAI,KAAK,EAAC,uBAAuB;4BAC/B,uEACE,KAAK,EAAE,IAAI,CAAC,cAAc,EAC1B,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAC/C,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAC7C,QAAQ,EAAE,IAAI,CAAC,UAAU,EACzB,KAAK,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,GACvB,CACf;wBACL,2DAAI,KAAK,EAAC,6BAA6B;;4BAAM,IAAI,CAAC,UAAU;qCAAY;wBACvE,SAAS,CACP;oBACJ,YAAY,CACJ,CACZ;gBACA,IAAI,CAAC,OAAO,KAAK,SAAS,IAAI,CAC7B,EAAC,QAAQ;oBACP;wBACG,SAAS;wBAET,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE;4BACxC,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;gCACnB,OAAO,CACL,UAAI,KAAK,EAAE,mDAAmD,SAAS,EAAE;oCACvE,gBAAU,IAAI,EAAC,aAAa,GAAY,CACrC,CACN,CAAC;4BACJ,CAAC;4BAED,OAAO,CACL,UACE,KAAK,EAAE;oCACL,sBAAsB,EAAE,IAAI;oCAC5B,8BAA8B,EAAE,IAAI,KAAK,IAAI,CAAC,WAAW;oCACzD,CAAC,SAAS,CAAC,EAAE,IAAI;iCAClB;gCAED,cAAQ,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAc,CAAC,EAAE,QAAQ,EAAE,IAAI,KAAK,IAAI,CAAC,WAAW,IACtF,IAAI,CACE,CACN,CACN,CAAC;wBACJ,CAAC,CAAC;wBAED,SAAS,CACP;oBACJ,YAAY,CACJ,CACZ,CACG,CACD,CACR,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Fragment, Prop, Host, h, Event, EventEmitter, Watch, State } from '@stencil/core';\n\n@Component({\n tag: 'spw-pagination',\n styleUrl: 'spw-pagination.scss',\n shadow: true,\n})\nexport class SpwPagination {\n /** Nombre total d'éléments à paginer */\n @Prop() totalItems: number;\n /** Nombre d'éléments à afficher par page */\n @Prop() itemsPerPage: number;\n /** Indique si la pagination est désactivée */\n @Prop() isDisabled: boolean = false;\n /** Type de variante de la pagination : 'numbers' ou 'input' */\n @Prop() variant: 'numbers' | 'input' = 'numbers';\n /** Page actuellement sélectionnée, mutable */\n @Prop({ mutable: true }) currentPage: number = 1;\n\n /** Événement émis lorsque la page est changée, renvoie le numéro de la nouvelle page */\n @Event() pageChanged: EventEmitter<number>;\n\n private totalPages: number;\n @State() inputPageValue: string = '';\n @State() isMobile: boolean = window.innerWidth < 800;\n private debounceTimer: any;\n\n componentWillLoad() {\n this.calculateTotalPages();\n this.inputPageValue = this.currentPage.toString();\n window.addEventListener('resize', this.updateIsMobile);\n }\n\n disconnectedCallback() {\n window.removeEventListener('resize', this.updateIsMobile);\n }\n\n private updateIsMobile = () => {\n this.isMobile = window.innerWidth < 800;\n };\n\n @Watch('totalItems')\n @Watch('itemsPerPage')\n @Watch('currentPage')\n calculateTotalPages() {\n this.totalPages = Math.ceil(this.totalItems / this.itemsPerPage);\n }\n\n private goToPage(page: number) {\n if (page !== this.currentPage && !this.isDisabled && page >= 1 && page <= this.totalPages) {\n this.currentPage = page;\n this.inputPageValue = this.currentPage.toString();\n this.pageChanged.emit(this.currentPage);\n }\n }\n\n private handleInputChange(event: Event) {\n const inputValue = (event.target as HTMLInputElement).value;\n this.inputPageValue = inputValue;\n const page = parseInt(inputValue, 10);\n\n if (!isNaN(page) && page >= 1 && page <= this.totalPages) {\n clearTimeout(this.debounceTimer);\n this.debounceTimer = setTimeout(() => {\n this.goToPage(page);\n }, 500);\n }\n }\n\n private getPaginationClass() {\n const pages = this.calculatePageRange();\n const ellipsisCount = pages.filter(({ page }) => page === '...').length;\n const hasEllipsisStart = ellipsisCount > 0 && pages[1]?.page === '...';\n const hasEllipsisEnd = ellipsisCount > 0 && pages[pages.length - 2]?.page === '...';\n\n let paginationClass = `spw-pagination spw-pagination--${this.currentPage} spw-pagination--total-${this.totalPages}`;\n\n if (ellipsisCount === 2) {\n paginationClass += ' spw-pagination--double-ellipsis';\n } else if (hasEllipsisStart) {\n paginationClass += ' spw-pagination--ellipsis-start';\n } else if (hasEllipsisEnd) {\n paginationClass += ' spw-pagination--ellipsis-end';\n }\n\n return paginationClass;\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n if (event.key === 'Enter') {\n const page = parseInt(this.inputPageValue, 10);\n if (!isNaN(page)) {\n this.goToPage(page);\n }\n }\n }\n\n private calculateWidth(): string {\n const length = this.inputPageValue.length;\n if (length <= 1) {\n return '3ch';\n }\n return `${length + 1}ch`;\n }\n\n private calculatePageRange() {\n const pages = [];\n const { currentPage, totalPages, isMobile } = this;\n\n if (isMobile) {\n // Mode mobile\n if (totalPages <= 5) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--small-range' });\n }\n } else if (currentPage <= 3) {\n for (let i = 1; i <= 3; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--start-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n } else if (currentPage >= totalPages - 2) {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = totalPages - 2; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--end-range' });\n }\n } else {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = currentPage - 1; i <= currentPage + 1; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--middle-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n }\n } else {\n // Mode desktop\n if (totalPages <= 7) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--small-range' });\n }\n } else if (currentPage <= 4) {\n for (let i = 1; i <= 4; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--start-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n } else if (currentPage >= totalPages - 3) {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = totalPages - 3; i <= totalPages; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--end-range' });\n }\n } else {\n pages.push({ page: 1, class: 'spw-pagination__item--start' });\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n for (let i = currentPage - 2; i <= currentPage + 2; i++) {\n pages.push({ page: i, class: 'spw-pagination__item--middle-range' });\n }\n pages.push({ page: '...', class: 'spw-pagination__item--ellipsis' });\n pages.push({ page: totalPages, class: 'spw-pagination__item--end' });\n }\n }\n\n return pages;\n }\n\n render() {\n const pages = this.calculatePageRange();\n const showPrevArrow = this.currentPage > 1;\n const showNextArrow = this.currentPage < this.totalPages;\n\n const prevArrow = showPrevArrow && (\n <li class=\"spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage - 1)}>\n <spw-icon icon=\"fa-chevron-left\"></spw-icon> <span class=\"spw-pagination__item-arrow-text\">Précédent</span>\n </button>\n </li>\n );\n\n const nextArrow = showNextArrow && (\n <li class=\"spw-pagination__item spw-pagination__item--desktop spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage + 1)}>\n <span class=\"spw-pagination__item-arrow-text\">Suivant</span> <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </button>\n </li>\n );\n\n const prevArrowMobile = this.currentPage > 1 && (\n <li class=\"spw-pagination__item spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage - 1)}>\n <spw-icon icon=\"fa-chevron-left\"></spw-icon> <span>Précédent</span>\n </button>\n </li>\n );\n\n const nextArrowMobile = this.currentPage < this.totalPages && (\n <li class=\"spw-pagination__item spw-pagination__item--arrow\">\n <button onClick={() => this.goToPage(this.currentPage + 1)} disabled={this.currentPage >= this.totalPages}>\n <span>Suivant</span> <spw-icon icon=\"fa-chevron-right\"></spw-icon>\n </button>\n </li>\n );\n\n const mobileArrows = (\n <ul class=\"spw-pagination__mobile-arrows\">\n {prevArrowMobile}\n {nextArrowMobile}\n </ul>\n );\n\n return (\n <Host>\n <div class={this.getPaginationClass()}>\n {this.variant === 'input' && (\n <Fragment>\n <ul>\n {prevArrow}\n <li class=\"spw-pagination__input\">\n <spw-text-field\n value={this.inputPageValue}\n type=\"number\"\n onInput={event => this.handleInputChange(event)}\n onKeyDown={event => this.handleKeyDown(event)}\n disabled={this.isDisabled}\n style={{ width: this.calculateWidth() }}\n ></spw-text-field>\n </li>\n <li class=\"spw-pagination__total-pages\">sur {this.totalPages} pages</li>\n {nextArrow}\n </ul>\n {mobileArrows}\n </Fragment>\n )}\n {this.variant === 'numbers' && (\n <Fragment>\n <ul>\n {prevArrow}\n\n {pages.map(({ page, class: pageClass }) => {\n if (page === '...') {\n return (\n <li class={`spw-pagination__item spw-pagination__item--dots ${pageClass}`}>\n <spw-icon icon=\"fa-ellipsis\"></spw-icon>\n </li>\n );\n }\n\n return (\n <li\n class={{\n 'spw-pagination__item': true,\n 'spw-pagination__item--active': page === this.currentPage,\n [pageClass]: true,\n }}\n >\n <button onClick={() => this.goToPage(page as number)} disabled={page === this.currentPage}>\n {page}\n </button>\n </li>\n );\n })}\n\n {nextArrow}\n </ul>\n {mobileArrows}\n </Fragment>\n )}\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+
2
+ /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display:inline-flex;font-size:100%;line-height:1.3;vertical-align:top}: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-radio{align-items:flex-start;display:inline-flex;flex-direction:row;gap:var(--spw-spacings-spacing-sm);padding:0}.spw-radio__wrapper{align-items:center;background-color:var(--spw-ds-white);border:2px solid var(--spw-color-themes-grey-grey-900);border-radius:var(--spw-spacings-border-radius-full);display:flex;flex:none;flex-grow:0;font-size:var(--spw-typography-font-size-xs);height:20px;justify-content:center;order:0;position:relative;width:20px}.spw-radio__wrapper--error{border-color:var(--spw-colors-dark-states-error-error-300)}.spw-radio__wrapper:not(.spw-radio__wrapper--disabled):hover{outline:4px solid var(--spw-color-themes-grey-grey-300)}.spw-radio__wrapper:not(.spw-radio__wrapper--disabled):active,.spw-radio__wrapper:not(.spw-radio__wrapper--disabled):focus-visible,.spw-radio__wrapper:not(.spw-radio__wrapper--disabled):focus-within{outline:2px solid var(--spw-ds-focus);outline-offset:2px}.spw-radio__wrapper:not(.spw-radio__wrapper--disabled):active{box-shadow:0 0 4px var(--spw-color-themes-grey-grey-300)}.spw-radio__wrapper--disabled{border-color:var(--spw-color-themes-grey-grey-500)}.spw-radio__wrapper--checked{border-color:var(--spw-ds-primary);color:var(--spw-ds-primary)}.spw-radio__wrapper--checked--disabled{color:var(--spw-color-themes-grey-grey-500)}.spw-radio__circle{background:var(--spw-ds-primary);border-radius:var(--spw-spacings-border-radius-full);display:block;height:10px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:10px}.spw-radio__label{word-wrap:break-word;color:var(--spw-color-themes-grey-grey-900);order:1;padding-top:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.spw-radio__label:hover~.spw-radio__wrapper:not(.spw-radio__wrapper--disabled){outline:4px solid var(--spw-color-themes-grey-grey-300)}.spw-radio__label:active~.spw-radio__wrapper:not(.spw-radio__wrapper--disabled){box-shadow:0 0 4px var(--spw-color-themes-grey-grey-300);outline:2px solid var(--spw-ds-focus);outline-offset:2px}.spw-radio__label--disabled{color:var(--spw-color-themes-grey-grey-500)}.spw-radio__label:hover,.spw-radio__wrapper:hover{cursor:pointer}.spw-radio__label--disabled:hover,.spw-radio__wrapper--disabled:hover{cursor:not-allowed}
@@ -0,0 +1,248 @@
1
+ import { h } from "@stencil/core";
2
+ export class SpwRadio {
3
+ constructor() {
4
+ this.disabled = false;
5
+ this.checked = false;
6
+ this.error = false;
7
+ this.name = undefined;
8
+ this.value = undefined;
9
+ this.internalChecked = undefined;
10
+ }
11
+ handleRadio() {
12
+ if (!this.disabled && !this.internalChecked) {
13
+ this.setCheckedState(true);
14
+ this.spwChange.emit({ checked: this.internalChecked, value: this.value });
15
+ this.uncheckOthers();
16
+ }
17
+ }
18
+ uncheckOthers() {
19
+ const form = this.el.closest('body');
20
+ if (form) {
21
+ const radios = Array.from(form.querySelectorAll(`spw-radio[name="${this.name}"]`));
22
+ radios.forEach(radio => {
23
+ if (radio !== this.el) {
24
+ radio.setChecked(false);
25
+ }
26
+ });
27
+ }
28
+ }
29
+ /** Méthode pour changer l'état de la case à cocher. */
30
+ async setChecked(checked) {
31
+ this.setCheckedState(checked);
32
+ }
33
+ checkedChanged(newValue) {
34
+ this.setCheckedState(newValue);
35
+ }
36
+ setCheckedState(checked) {
37
+ this.internalChecked = checked;
38
+ this.checked = checked;
39
+ if (this.inputElement) {
40
+ this.inputElement.checked = checked;
41
+ }
42
+ this.updateFormValue();
43
+ }
44
+ updateFormValue() {
45
+ if (this.internalChecked) {
46
+ this.internals.setFormValue(this.value);
47
+ }
48
+ else {
49
+ this.internals.setFormValue(null);
50
+ }
51
+ }
52
+ handleKeydown(event) {
53
+ if (event.key === ' ' || event.key === 'Enter') {
54
+ this.handleRadio();
55
+ event.preventDefault();
56
+ }
57
+ }
58
+ componentWillLoad() {
59
+ this.internalChecked = this.checked;
60
+ }
61
+ componentDidLoad() {
62
+ var _a;
63
+ this.setCheckedState(this.internalChecked);
64
+ (_a = this.el.closest('form')) === null || _a === void 0 ? void 0 : _a.addEventListener('formdata', (e) => {
65
+ if (this.internalChecked) {
66
+ e.formData.set(this.name, this.value);
67
+ }
68
+ });
69
+ }
70
+ formResetCallback() {
71
+ this.setCheckedState(this.checked);
72
+ }
73
+ get elementClass() {
74
+ return {
75
+ 'spw-radio__wrapper': true,
76
+ 'spw-radio__wrapper--disabled': this.disabled,
77
+ 'spw-radio__wrapper--checked': this.internalChecked,
78
+ 'spw-radio__wrapper--error': this.error,
79
+ };
80
+ }
81
+ render() {
82
+ const slot = this.el.innerHTML;
83
+ const hasSlot = Boolean(slot);
84
+ return (h("div", { key: 'b7c5bfe6891acd048e668fc4f72de4853b911e99', class: "spw-radio" }, h("input", { key: '2fdadb345faeedc8bb329e57229ed5f096f3a559', type: "radio", ref: el => (this.inputElement = el), checked: this.internalChecked, onChange: this.handleRadio.bind(this), name: this.name, value: this.value, disabled: this.disabled, style: { display: 'none' } }), hasSlot && (h("label", { key: 'd9ee09839ce67f80af3dfdeda97858b07f94657a', class: `spw-radio__label ${this.disabled ? 'spw-radio__label--disabled' : ''}`, onClick: this.handleRadio.bind(this) }, h("slot", { key: 'ec839eeebf46a5178284fd5cb356534f19170062' }))), h("div", { key: '160648566239681dea3af980a8afc3a9272f012a', tabIndex: this.disabled ? -1 : 0, onClick: this.handleRadio.bind(this), onKeyDown: this.handleKeydown.bind(this), role: "radio", "aria-checked": this.internalChecked, "aria-disabled": this.disabled, "aria-labelledby": "label", class: this.elementClass }, this.internalChecked && h("span", { key: 'd61a59b3e153d19397de661c7f4397ed993f81d3', class: "spw-radio__circle" }))));
85
+ }
86
+ static get is() { return "spw-radio"; }
87
+ static get encapsulation() { return "shadow"; }
88
+ static get formAssociated() { return true; }
89
+ static get originalStyleUrls() {
90
+ return {
91
+ "$": ["spw-radio.scss"]
92
+ };
93
+ }
94
+ static get styleUrls() {
95
+ return {
96
+ "$": ["spw-radio.css"]
97
+ };
98
+ }
99
+ static get properties() {
100
+ return {
101
+ "disabled": {
102
+ "type": "boolean",
103
+ "mutable": false,
104
+ "complexType": {
105
+ "original": "boolean",
106
+ "resolved": "boolean",
107
+ "references": {}
108
+ },
109
+ "required": false,
110
+ "optional": false,
111
+ "docs": {
112
+ "tags": [],
113
+ "text": "Indique si le bouton radio est d\u00E9sactiv\u00E9"
114
+ },
115
+ "attribute": "disabled",
116
+ "reflect": false,
117
+ "defaultValue": "false"
118
+ },
119
+ "checked": {
120
+ "type": "boolean",
121
+ "mutable": true,
122
+ "complexType": {
123
+ "original": "boolean",
124
+ "resolved": "boolean",
125
+ "references": {}
126
+ },
127
+ "required": false,
128
+ "optional": false,
129
+ "docs": {
130
+ "tags": [],
131
+ "text": "Indique si le bouton radio est s\u00E9lectionn\u00E9 (coch\u00E9), mutable et refl\u00E9t\u00E9 dans le DOM"
132
+ },
133
+ "attribute": "checked",
134
+ "reflect": true,
135
+ "defaultValue": "false"
136
+ },
137
+ "error": {
138
+ "type": "boolean",
139
+ "mutable": false,
140
+ "complexType": {
141
+ "original": "boolean",
142
+ "resolved": "boolean",
143
+ "references": {}
144
+ },
145
+ "required": false,
146
+ "optional": false,
147
+ "docs": {
148
+ "tags": [],
149
+ "text": "Indique s'il y a une erreur visuelle associ\u00E9e au bouton radio"
150
+ },
151
+ "attribute": "error",
152
+ "reflect": false,
153
+ "defaultValue": "false"
154
+ },
155
+ "name": {
156
+ "type": "string",
157
+ "mutable": false,
158
+ "complexType": {
159
+ "original": "string",
160
+ "resolved": "string",
161
+ "references": {}
162
+ },
163
+ "required": false,
164
+ "optional": false,
165
+ "docs": {
166
+ "tags": [],
167
+ "text": "Nom du bouton radio, utilis\u00E9 pour le grouper avec d'autres boutons radio dans un formulaire"
168
+ },
169
+ "attribute": "name",
170
+ "reflect": false
171
+ },
172
+ "value": {
173
+ "type": "string",
174
+ "mutable": false,
175
+ "complexType": {
176
+ "original": "string",
177
+ "resolved": "string",
178
+ "references": {}
179
+ },
180
+ "required": false,
181
+ "optional": false,
182
+ "docs": {
183
+ "tags": [],
184
+ "text": "Valeur associ\u00E9e au bouton radio"
185
+ },
186
+ "attribute": "value",
187
+ "reflect": false
188
+ }
189
+ };
190
+ }
191
+ static get states() {
192
+ return {
193
+ "internalChecked": {}
194
+ };
195
+ }
196
+ static get events() {
197
+ return [{
198
+ "method": "spwChange",
199
+ "name": "spwChange",
200
+ "bubbles": true,
201
+ "cancelable": true,
202
+ "composed": true,
203
+ "docs": {
204
+ "tags": [],
205
+ "text": "\u00C9v\u00E9nement d\u00E9clench\u00E9 lorsque l'\u00E9tat du bouton radio change (coch\u00E9 ou d\u00E9coch\u00E9)"
206
+ },
207
+ "complexType": {
208
+ "original": "{ checked: boolean; value: string }",
209
+ "resolved": "{ checked: boolean; value: string; }",
210
+ "references": {}
211
+ }
212
+ }];
213
+ }
214
+ static get methods() {
215
+ return {
216
+ "setChecked": {
217
+ "complexType": {
218
+ "signature": "(checked: boolean) => Promise<void>",
219
+ "parameters": [{
220
+ "name": "checked",
221
+ "type": "boolean",
222
+ "docs": ""
223
+ }],
224
+ "references": {
225
+ "Promise": {
226
+ "location": "global",
227
+ "id": "global::Promise"
228
+ }
229
+ },
230
+ "return": "Promise<void>"
231
+ },
232
+ "docs": {
233
+ "text": "M\u00E9thode pour changer l'\u00E9tat de la case \u00E0 cocher.",
234
+ "tags": []
235
+ }
236
+ }
237
+ };
238
+ }
239
+ static get elementRef() { return "el"; }
240
+ static get watchers() {
241
+ return [{
242
+ "propName": "checked",
243
+ "methodName": "checkedChanged"
244
+ }];
245
+ }
246
+ static get attachInternalsMemberName() { return "internals"; }
247
+ }
248
+ //# sourceMappingURL=spw-radio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spw-radio.js","sourceRoot":"","sources":["../../../src/components/spw-radio/spw-radio.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, h, Prop, Element, State, Event, EventEmitter, Watch, Method, AttachInternals } from '@stencil/core';\n\n@Component({\n tag: 'spw-radio',\n styleUrl: 'spw-radio.scss',\n shadow: true,\n formAssociated: true,\n})\nexport class SpwRadio {\n private inputElement: HTMLInputElement;\n\n @Element() el: HTMLSpwRadioElement;\n\n /** Indique si le bouton radio est désactivé */\n @Prop() disabled: boolean = false;\n /** Indique si le bouton radio est sélectionné (coché), mutable et reflété dans le DOM */\n @Prop({ mutable: true, reflect: true }) checked: boolean = false;\n /** Indique s'il y a une erreur visuelle associée au bouton radio */\n @Prop() error: boolean = false;\n /** Nom du bouton radio, utilisé pour le grouper avec d'autres boutons radio dans un formulaire */\n @Prop() name: string;\n /** Valeur associée au bouton radio */\n @Prop() value: string;\n\n @State() internalChecked: boolean;\n\n @AttachInternals() internals: ElementInternals;\n\n /** Événement déclenché lorsque l'état du bouton radio change (coché ou décoché) */\n @Event({ bubbles: true, composed: true }) spwChange: EventEmitter<{ checked: boolean; value: string }>;\n\n private handleRadio() {\n if (!this.disabled && !this.internalChecked) {\n this.setCheckedState(true);\n this.spwChange.emit({ checked: this.internalChecked, value: this.value });\n this.uncheckOthers();\n }\n }\n\n private uncheckOthers() {\n const form = this.el.closest('body');\n if (form) {\n const radios = Array.from(form.querySelectorAll(`spw-radio[name=\"${this.name}\"]`)) as HTMLSpwRadioElement[];\n radios.forEach(radio => {\n if (radio !== this.el) {\n radio.setChecked(false);\n }\n });\n }\n }\n\n /** Méthode pour changer l'état de la case à cocher. */\n @Method()\n async setChecked(checked: boolean) {\n this.setCheckedState(checked);\n }\n\n @Watch('checked')\n checkedChanged(newValue: boolean) {\n this.setCheckedState(newValue);\n }\n\n private setCheckedState(checked: boolean) {\n this.internalChecked = checked;\n this.checked = checked;\n if (this.inputElement) {\n this.inputElement.checked = checked;\n }\n this.updateFormValue();\n }\n\n private updateFormValue() {\n if (this.internalChecked) {\n this.internals.setFormValue(this.value);\n } else {\n this.internals.setFormValue(null);\n }\n }\n\n private handleKeydown(event) {\n if (event.key === ' ' || event.key === 'Enter') {\n this.handleRadio();\n event.preventDefault();\n }\n }\n\n componentWillLoad() {\n this.internalChecked = this.checked;\n }\n\n componentDidLoad() {\n this.setCheckedState(this.internalChecked);\n this.el.closest('form')?.addEventListener('formdata', (e: FormDataEvent) => {\n if (this.internalChecked) {\n e.formData.set(this.name, this.value);\n }\n });\n }\n\n formResetCallback() {\n this.setCheckedState(this.checked);\n }\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-radio__wrapper': true,\n 'spw-radio__wrapper--disabled': this.disabled,\n 'spw-radio__wrapper--checked': this.internalChecked,\n 'spw-radio__wrapper--error': this.error,\n };\n }\n\n render() {\n const slot = this.el.innerHTML;\n const hasSlot = Boolean(slot);\n\n return (\n <div class=\"spw-radio\">\n <input\n type=\"radio\"\n ref={el => (this.inputElement = el)}\n checked={this.internalChecked}\n onChange={this.handleRadio.bind(this)}\n name={this.name}\n value={this.value}\n disabled={this.disabled}\n style={{ display: 'none' }}\n />\n {hasSlot && (\n <label class={`spw-radio__label ${this.disabled ? 'spw-radio__label--disabled' : ''}`} onClick={this.handleRadio.bind(this)}>\n <slot />\n </label>\n )}\n <div\n tabIndex={this.disabled ? -1 : 0}\n onClick={this.handleRadio.bind(this)}\n onKeyDown={this.handleKeydown.bind(this)}\n role=\"radio\"\n aria-checked={this.internalChecked}\n aria-disabled={this.disabled}\n aria-labelledby=\"label\"\n class={this.elementClass}\n >\n {this.internalChecked && <span class=\"spw-radio__circle\"></span>}\n </div>\n </div>\n );\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+
2
+ /*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{-webkit-text-size-adjust:100%;line-height:1.3}h1,h2,h3,h4,h5,h6,li,p,ul{margin:0;padding:0}ul{list-style:none}:host{-webkit-text-size-adjust:100%;box-sizing:border-box;display: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-search-field{position:relative}.spw-search-field__options{background-color:#fff;border:1px solid var(--spw-color-themes-grey-grey-800);border-radius:0 0 4px 4px;margin-top:-2px;max-height:200px;overflow-y:auto;position:absolute;transition:transform .3s ease,opacity .3s ease;width:100%;z-index:44}.spw-search-field__options--down,.spw-search-field__options--up{top:100%;transform:translateY(0)}.spw-search-field__option{border-bottom:1px solid var(--spw-color-themes-grey-grey-900);cursor:pointer;padding:12px;transition:background-color .2s ease}.spw-search-field__option:hover{background-color:var(--spw-color-themes-grey-grey-200)}.spw-search-field__option:last-child{border-bottom:none}.spw-search-field__option--focused{background-color:var(--spw-color-themes-grey-grey-300)}.spw-search-field__option--selected{font-weight:700}.spw-search-field__no-results{color:var(--spw-color-themes-grey-grey-600);cursor:not-allowed;padding:12px}.spw-tw-italic{font-style:italic}.-spw-tw-mt-1{margin-top:-.25rem}.spw-tw-mb-2{margin-bottom:.5rem}
@@ -0,0 +1,287 @@
1
+ import { h } from "@stencil/core";
2
+ export class SpwSearchField {
3
+ constructor() {
4
+ this.handleClickOutside = (event) => {
5
+ if (this.isOpen) {
6
+ const target = event.composedPath()[0];
7
+ const isInsideHost = this.hostElement.contains(target);
8
+ if (!isInsideHost) {
9
+ this.isOpen = false;
10
+ }
11
+ }
12
+ };
13
+ this.items = undefined;
14
+ this.placeholder = 'Recherche...';
15
+ this.label = '';
16
+ this.disabled = undefined;
17
+ this.name = undefined;
18
+ this.required = false;
19
+ this.assistiveText = undefined;
20
+ this.filteredItems = [];
21
+ this.searchText = '';
22
+ this.isOpen = false;
23
+ this.focusedItemIndex = null;
24
+ this.dropdownDirection = 'down';
25
+ }
26
+ componentWillLoad() {
27
+ if (this.items) {
28
+ this.parseItems(this.items);
29
+ }
30
+ else {
31
+ this.filteredItems = [];
32
+ }
33
+ }
34
+ componentDidLoad() {
35
+ document.addEventListener('click', this.handleClickOutside);
36
+ }
37
+ disconnectedCallback() {
38
+ document.removeEventListener('click', this.handleClickOutside);
39
+ }
40
+ parseItems(newValue) {
41
+ if (!newValue) {
42
+ this.filteredItems = [];
43
+ return;
44
+ }
45
+ try {
46
+ this.filteredItems = JSON.parse(newValue);
47
+ }
48
+ catch (e) {
49
+ console.error('Invalid JSON format for items:', newValue);
50
+ this.filteredItems = [];
51
+ }
52
+ }
53
+ handleSearchInput(event) {
54
+ const input = event.target;
55
+ this.searchText = input.value;
56
+ this.filterItems();
57
+ this.determineDropdownDirection();
58
+ this.isOpen = true;
59
+ }
60
+ filterItems() {
61
+ if (!this.items) {
62
+ this.filteredItems = [];
63
+ return;
64
+ }
65
+ const normalizedSearchText = this.normalizeString(this.searchText);
66
+ this.filteredItems = JSON.parse(this.items).filter(item => this.normalizeString(item.label).includes(normalizedSearchText));
67
+ }
68
+ normalizeString(str) {
69
+ return str
70
+ .normalize('NFD')
71
+ .replace(/[\u0300-\u036f]/g, '')
72
+ .toLowerCase();
73
+ }
74
+ selectItem(item) {
75
+ this.searchText = item.label;
76
+ this.isOpen = false;
77
+ if (item.url) {
78
+ window.location.href = item.url;
79
+ }
80
+ }
81
+ determineDropdownDirection() {
82
+ const rect = this.hostElement.getBoundingClientRect();
83
+ const viewportHeight = window.innerHeight;
84
+ if (rect.bottom + 200 > viewportHeight && rect.top > 200) {
85
+ this.dropdownDirection = 'up';
86
+ }
87
+ else {
88
+ this.dropdownDirection = 'down';
89
+ }
90
+ }
91
+ handleKeyDown(event) {
92
+ switch (event.key) {
93
+ case 'ArrowDown':
94
+ event.preventDefault();
95
+ if (this.isOpen) {
96
+ this.focusedItemIndex = this.focusedItemIndex === null ? 0 : (this.focusedItemIndex + 1) % this.filteredItems.length;
97
+ }
98
+ break;
99
+ case 'ArrowUp':
100
+ event.preventDefault();
101
+ if (this.isOpen) {
102
+ this.focusedItemIndex =
103
+ this.focusedItemIndex === null ? this.filteredItems.length - 1 : (this.focusedItemIndex - 1 + this.filteredItems.length) % this.filteredItems.length;
104
+ }
105
+ break;
106
+ case 'Enter':
107
+ event.preventDefault();
108
+ if (this.isOpen && this.focusedItemIndex !== null) {
109
+ this.selectItem(this.filteredItems[this.focusedItemIndex]);
110
+ }
111
+ break;
112
+ case 'Escape':
113
+ this.isOpen = false;
114
+ break;
115
+ }
116
+ }
117
+ highlightMatch(item) {
118
+ const normalizedSearchText = this.normalizeString(this.searchText);
119
+ const normalizedItem = this.normalizeString(item);
120
+ const startIndex = normalizedItem.indexOf(normalizedSearchText);
121
+ if (startIndex === -1 || !this.searchText) {
122
+ return item;
123
+ }
124
+ const endIndex = startIndex + normalizedSearchText.length;
125
+ return (h("span", null, item.slice(0, startIndex), h("strong", null, item.slice(startIndex, endIndex)), item.slice(endIndex)));
126
+ }
127
+ render() {
128
+ return (h("div", { key: '54c4caffc49fe8354751caa94eea54976d2ca00d', ref: el => (this.hostElement = el), class: "spw-search-field" }, h("spw-text-field", { key: 'f6a9cd7d3bbb49325d16d1aa6086bca647416e65', placeholder: this.placeholder, name: this.name, label: this.label, "is-search": true, "is-clear": true, required: this.required, disabled: this.disabled, assistiveText: this.assistiveText, value: this.searchText, onInput: event => this.handleSearchInput(event), onKeyDown: event => this.handleKeyDown(event) }), this.isOpen && !!this.items && (h("div", { key: 'b97c22a397b47348e0863141bf6a8d010e8765bb', class: `spw-search-field__options spw-search-field__options--${this.dropdownDirection}` }, !!this.filteredItems.length && (h("ul", { key: '7b22dbd27a14f4123325770594c9e9900388f47c' }, this.filteredItems.map((item, index) => (h("li", { class: {
129
+ 'spw-search-field__option': true,
130
+ 'spw-search-field__option--focused': index === this.focusedItemIndex,
131
+ }, onClick: () => this.selectItem(item) }, this.highlightMatch(item.label), " ", item.category && h("span", { class: "spw-tw-italic" }, " - ", item.category)))))), !this.filteredItems.length && h("p", { key: 'e2ca5f8f6936eab307618609f8ada8691845a697', class: "spw-search-field__no-results" }, "Pas de r\u00E9sultats.")))));
132
+ }
133
+ static get is() { return "spw-search-field"; }
134
+ static get encapsulation() { return "shadow"; }
135
+ static get originalStyleUrls() {
136
+ return {
137
+ "$": ["spw-search-field.scss"]
138
+ };
139
+ }
140
+ static get styleUrls() {
141
+ return {
142
+ "$": ["spw-search-field.css"]
143
+ };
144
+ }
145
+ static get properties() {
146
+ return {
147
+ "items": {
148
+ "type": "string",
149
+ "mutable": false,
150
+ "complexType": {
151
+ "original": "string",
152
+ "resolved": "string",
153
+ "references": {}
154
+ },
155
+ "required": false,
156
+ "optional": true,
157
+ "docs": {
158
+ "tags": [],
159
+ "text": "Liste des \u00E9l\u00E9ments \u00E0 filtrer, pass\u00E9e sous forme de cha\u00EEne JSON"
160
+ },
161
+ "attribute": "items",
162
+ "reflect": false
163
+ },
164
+ "placeholder": {
165
+ "type": "string",
166
+ "mutable": false,
167
+ "complexType": {
168
+ "original": "string",
169
+ "resolved": "string",
170
+ "references": {}
171
+ },
172
+ "required": false,
173
+ "optional": false,
174
+ "docs": {
175
+ "tags": [],
176
+ "text": "Placeholder \u00E0 afficher dans le champ de recherche"
177
+ },
178
+ "attribute": "placeholder",
179
+ "reflect": false,
180
+ "defaultValue": "'Recherche...'"
181
+ },
182
+ "label": {
183
+ "type": "string",
184
+ "mutable": false,
185
+ "complexType": {
186
+ "original": "string",
187
+ "resolved": "string",
188
+ "references": {}
189
+ },
190
+ "required": false,
191
+ "optional": false,
192
+ "docs": {
193
+ "tags": [],
194
+ "text": "Label associ\u00E9 au champ de recherche"
195
+ },
196
+ "attribute": "label",
197
+ "reflect": false,
198
+ "defaultValue": "''"
199
+ },
200
+ "disabled": {
201
+ "type": "boolean",
202
+ "mutable": false,
203
+ "complexType": {
204
+ "original": "boolean",
205
+ "resolved": "boolean",
206
+ "references": {}
207
+ },
208
+ "required": false,
209
+ "optional": true,
210
+ "docs": {
211
+ "tags": [],
212
+ "text": "Indique si le champ de recherche est d\u00E9sactiv\u00E9"
213
+ },
214
+ "attribute": "disabled",
215
+ "reflect": false
216
+ },
217
+ "name": {
218
+ "type": "string",
219
+ "mutable": false,
220
+ "complexType": {
221
+ "original": "string",
222
+ "resolved": "string",
223
+ "references": {}
224
+ },
225
+ "required": false,
226
+ "optional": false,
227
+ "docs": {
228
+ "tags": [],
229
+ "text": "Nom du champ de recherche, utilis\u00E9 pour les formulaires"
230
+ },
231
+ "attribute": "name",
232
+ "reflect": false
233
+ },
234
+ "required": {
235
+ "type": "boolean",
236
+ "mutable": false,
237
+ "complexType": {
238
+ "original": "boolean",
239
+ "resolved": "boolean",
240
+ "references": {}
241
+ },
242
+ "required": false,
243
+ "optional": true,
244
+ "docs": {
245
+ "tags": [],
246
+ "text": "Indique si le champ est requis"
247
+ },
248
+ "attribute": "required",
249
+ "reflect": false,
250
+ "defaultValue": "false"
251
+ },
252
+ "assistiveText": {
253
+ "type": "string",
254
+ "mutable": false,
255
+ "complexType": {
256
+ "original": "string",
257
+ "resolved": "string",
258
+ "references": {}
259
+ },
260
+ "required": false,
261
+ "optional": true,
262
+ "docs": {
263
+ "tags": [],
264
+ "text": "Texte d'assistance affich\u00E9 sous le champ de recherche"
265
+ },
266
+ "attribute": "assistive-text",
267
+ "reflect": false
268
+ }
269
+ };
270
+ }
271
+ static get states() {
272
+ return {
273
+ "filteredItems": {},
274
+ "searchText": {},
275
+ "isOpen": {},
276
+ "focusedItemIndex": {},
277
+ "dropdownDirection": {}
278
+ };
279
+ }
280
+ static get watchers() {
281
+ return [{
282
+ "propName": "items",
283
+ "methodName": "parseItems"
284
+ }];
285
+ }
286
+ }
287
+ //# sourceMappingURL=spw-search-field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spw-search-field.js","sourceRoot":"","sources":["../../../src/components/spw-search-field/spw-search-field.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, State, h, Watch } from '@stencil/core';\n\n@Component({\n tag: 'spw-search-field',\n styleUrl: 'spw-search-field.scss',\n shadow: true,\n})\nexport class SpwSearchField {\n private hostElement: HTMLElement;\n\n /** Liste des éléments à filtrer, passée sous forme de chaîne JSON */\n @Prop() items?: string;\n /** Placeholder à afficher dans le champ de recherche */\n @Prop() placeholder: string = 'Recherche...';\n /** Label associé au champ de recherche */\n @Prop() label: string = '';\n /** Indique si le champ de recherche est désactivé */\n @Prop() disabled?: boolean;\n /** Nom du champ de recherche, utilisé pour les formulaires */\n @Prop() name: string;\n /** Indique si le champ est requis */\n @Prop() required?: boolean = false;\n /** Texte d'assistance affiché sous le champ de recherche */\n @Prop() assistiveText?: string;\n\n @State() filteredItems: Array<{ url?: string; label: string; category?: string }> = [];\n @State() searchText: string = '';\n @State() isOpen: boolean = false;\n @State() focusedItemIndex: number | null = null;\n @State() dropdownDirection: 'up' | 'down' = 'down';\n\n componentWillLoad() {\n if (this.items) {\n this.parseItems(this.items);\n } else {\n this.filteredItems = [];\n }\n }\n\n componentDidLoad() {\n document.addEventListener('click', this.handleClickOutside);\n }\n\n disconnectedCallback() {\n document.removeEventListener('click', this.handleClickOutside);\n }\n\n @Watch('items')\n parseItems(newValue: string) {\n if (!newValue) {\n this.filteredItems = [];\n return;\n }\n\n try {\n this.filteredItems = JSON.parse(newValue);\n } catch (e) {\n console.error('Invalid JSON format for items:', newValue);\n this.filteredItems = [];\n }\n }\n\n private handleClickOutside = (event: MouseEvent) => {\n if (this.isOpen) {\n const target = event.composedPath()[0] as Node;\n const isInsideHost = this.hostElement.contains(target);\n\n if (!isInsideHost) {\n this.isOpen = false;\n }\n }\n };\n\n private handleSearchInput(event: Event) {\n const input = event.target as HTMLInputElement;\n this.searchText = input.value;\n this.filterItems();\n this.determineDropdownDirection();\n this.isOpen = true;\n }\n\n private filterItems() {\n if (!this.items) {\n this.filteredItems = [];\n return;\n }\n\n const normalizedSearchText = this.normalizeString(this.searchText);\n\n this.filteredItems = JSON.parse(this.items).filter(item => this.normalizeString(item.label).includes(normalizedSearchText));\n }\n\n private normalizeString(str: string): string {\n return str\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .toLowerCase();\n }\n\n private selectItem(item: { url?: string; label: string }) {\n this.searchText = item.label;\n this.isOpen = false;\n\n if (item.url) {\n window.location.href = item.url;\n }\n }\n\n private determineDropdownDirection() {\n const rect = this.hostElement.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n\n if (rect.bottom + 200 > viewportHeight && rect.top > 200) {\n this.dropdownDirection = 'up';\n } else {\n this.dropdownDirection = 'down';\n }\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n switch (event.key) {\n case 'ArrowDown':\n event.preventDefault();\n if (this.isOpen) {\n this.focusedItemIndex = this.focusedItemIndex === null ? 0 : (this.focusedItemIndex + 1) % this.filteredItems.length;\n }\n break;\n case 'ArrowUp':\n event.preventDefault();\n if (this.isOpen) {\n this.focusedItemIndex =\n this.focusedItemIndex === null ? this.filteredItems.length - 1 : (this.focusedItemIndex - 1 + this.filteredItems.length) % this.filteredItems.length;\n }\n break;\n case 'Enter':\n event.preventDefault();\n if (this.isOpen && this.focusedItemIndex !== null) {\n this.selectItem(this.filteredItems[this.focusedItemIndex]);\n }\n break;\n case 'Escape':\n this.isOpen = false;\n break;\n }\n }\n\n private highlightMatch(item: string) {\n const normalizedSearchText = this.normalizeString(this.searchText);\n const normalizedItem = this.normalizeString(item);\n\n const startIndex = normalizedItem.indexOf(normalizedSearchText);\n\n if (startIndex === -1 || !this.searchText) {\n return item;\n }\n\n const endIndex = startIndex + normalizedSearchText.length;\n\n return (\n <span>\n {item.slice(0, startIndex)}\n <strong>{item.slice(startIndex, endIndex)}</strong>\n {item.slice(endIndex)}\n </span>\n );\n }\n\n render() {\n return (\n <div ref={el => (this.hostElement = el as HTMLElement)} class=\"spw-search-field\">\n <spw-text-field\n placeholder={this.placeholder}\n name={this.name}\n label={this.label}\n is-search={true}\n is-clear={true}\n required={this.required}\n disabled={this.disabled}\n assistiveText={this.assistiveText}\n value={this.searchText}\n onInput={event => this.handleSearchInput(event)}\n onKeyDown={event => this.handleKeyDown(event)}\n ></spw-text-field>\n {this.isOpen && !!this.items && (\n <div class={`spw-search-field__options spw-search-field__options--${this.dropdownDirection}`}>\n {!!this.filteredItems.length && (\n <ul>\n {this.filteredItems.map((item, index) => (\n <li\n class={{\n 'spw-search-field__option': true,\n 'spw-search-field__option--focused': index === this.focusedItemIndex,\n }}\n onClick={() => this.selectItem(item)}\n >\n {this.highlightMatch(item.label)} {item.category && <span class=\"spw-tw-italic\"> - {item.category}</span>}\n </li>\n ))}\n </ul>\n )}\n {!this.filteredItems.length && <p class=\"spw-search-field__no-results\">Pas de résultats.</p>}\n </div>\n )}\n </div>\n );\n }\n}\n"]}