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

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 (507) hide show
  1. package/dist/cjs/loader.cjs.js +1 -1
  2. package/dist/cjs/spw-button.spw-loading.entry.cjs.js.map +1 -1
  3. package/dist/cjs/spw-button_2.cjs.entry.js +2 -2
  4. package/dist/cjs/spw-button_2.cjs.entry.js.map +1 -1
  5. package/dist/cjs/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.cjs.js.map +1 -1
  6. package/dist/cjs/spw-field-label_6.cjs.entry.js +5 -5
  7. package/dist/cjs/spw-field-label_6.cjs.entry.js.map +1 -1
  8. package/dist/cjs/spw-grid-item.cjs.entry.js +29 -0
  9. package/dist/cjs/spw-grid-item.cjs.entry.js.map +1 -0
  10. package/dist/cjs/spw-grid-item.entry.cjs.js.map +1 -0
  11. package/dist/cjs/spw-grid.cjs.entry.js +54 -0
  12. package/dist/cjs/spw-grid.cjs.entry.js.map +1 -0
  13. package/dist/cjs/spw-grid.entry.cjs.js.map +1 -0
  14. package/dist/cjs/spw-header-lang-item.cjs.entry.js +1 -1
  15. package/dist/cjs/spw-header-lang.cjs.entry.js +1 -1
  16. package/dist/cjs/spw-header-navigation-dropdown.cjs.entry.js +1 -1
  17. package/dist/cjs/spw-header-navigation-item.cjs.entry.js +2 -2
  18. package/dist/cjs/spw-header-navigation-item.cjs.entry.js.map +1 -1
  19. package/dist/cjs/spw-header-navigation-item.entry.cjs.js.map +1 -1
  20. package/dist/cjs/spw-header-navigation.cjs.entry.js +10 -2
  21. package/dist/cjs/spw-header-navigation.cjs.entry.js.map +1 -1
  22. package/dist/cjs/spw-header-navigation.entry.cjs.js.map +1 -1
  23. package/dist/cjs/spw-header-persona-item.cjs.entry.js +1 -1
  24. package/dist/cjs/spw-header-persona.cjs.entry.js +1 -1
  25. package/dist/cjs/spw-header.cjs.entry.js +2 -2
  26. package/dist/cjs/spw-header.cjs.entry.js.map +1 -1
  27. package/dist/cjs/spw-header.entry.cjs.js.map +1 -1
  28. package/dist/cjs/spw-hero.cjs.entry.js +1 -1
  29. package/dist/cjs/spw-iodda.cjs.entry.js +1 -1
  30. package/dist/cjs/spw-list-description.cjs.entry.js +1 -1
  31. package/dist/cjs/spw-list-item.cjs.entry.js +1 -1
  32. package/dist/cjs/spw-list-title.cjs.entry.js +1 -1
  33. package/dist/cjs/spw-list.cjs.entry.js +1 -1
  34. package/dist/cjs/spw-modal.cjs.entry.js +1 -1
  35. package/dist/cjs/spw-mosaic-item.cjs.entry.js +1 -1
  36. package/dist/cjs/spw-mosaic.cjs.entry.js +1 -1
  37. package/dist/cjs/spw-pagination.cjs.entry.js +6 -6
  38. package/dist/cjs/spw-radio.cjs.entry.js +1 -1
  39. package/dist/cjs/spw-search-field.cjs.entry.js +65 -11
  40. package/dist/cjs/spw-search-field.cjs.entry.js.map +1 -1
  41. package/dist/cjs/spw-search-field.entry.cjs.js.map +1 -1
  42. package/dist/cjs/spw-sidebar-navigation-dropdown.cjs.entry.js +1 -1
  43. package/dist/cjs/spw-sidebar-navigation-item.cjs.entry.js +3 -3
  44. package/dist/cjs/spw-sidebar-navigation-separator.cjs.entry.js +1 -1
  45. package/dist/cjs/spw-sidebar.cjs.entry.js +1 -1
  46. package/dist/cjs/spw-skeleton.cjs.entry.js +1 -1
  47. package/dist/cjs/spw-slider-item.cjs.entry.js +20 -0
  48. package/dist/cjs/spw-slider-item.cjs.entry.js.map +1 -0
  49. package/dist/cjs/spw-slider-item.entry.cjs.js.map +1 -0
  50. package/dist/cjs/spw-slider.cjs.entry.js +246 -0
  51. package/dist/cjs/spw-slider.cjs.entry.js.map +1 -0
  52. package/dist/cjs/spw-slider.entry.cjs.js.map +1 -0
  53. package/dist/cjs/spw-socials.cjs.entry.js +2 -2
  54. package/dist/cjs/spw-socials.cjs.entry.js.map +1 -1
  55. package/dist/cjs/spw-socials.entry.cjs.js.map +1 -1
  56. package/dist/cjs/spw-stencil-library.cjs.js +1 -1
  57. package/dist/cjs/spw-table-body.cjs.entry.js +1 -1
  58. package/dist/cjs/spw-table-cell.cjs.entry.js +1 -1
  59. package/dist/cjs/spw-table-footer.cjs.entry.js +1 -1
  60. package/dist/cjs/spw-table-head.cjs.entry.js +1 -1
  61. package/dist/cjs/spw-table-header.cjs.entry.js +2 -2
  62. package/dist/cjs/spw-table-row.cjs.entry.js +1 -1
  63. package/dist/cjs/spw-tabs-navigation-item.cjs.entry.js +1 -1
  64. package/dist/cjs/spw-tabs-navigation.cjs.entry.js +1 -1
  65. package/dist/cjs/spw-tabs.cjs.entry.js +1 -1
  66. package/dist/cjs/spw-tag.cjs.entry.js +1 -1
  67. package/dist/cjs/spw-text-field.cjs.entry.js +1 -1
  68. package/dist/cjs/spw-textarea.cjs.entry.js +1 -1
  69. package/dist/cjs/spw-tile-description.cjs.entry.js +2 -2
  70. package/dist/cjs/spw-tile-description.cjs.entry.js.map +1 -1
  71. package/dist/cjs/spw-tile-description.entry.cjs.js.map +1 -1
  72. package/dist/cjs/spw-tile-title.cjs.entry.js +2 -2
  73. package/dist/cjs/spw-tile-title.cjs.entry.js.map +1 -1
  74. package/dist/cjs/spw-tile-title.entry.cjs.js.map +1 -1
  75. package/dist/cjs/spw-tile.cjs.entry.js +5 -2
  76. package/dist/cjs/spw-tile.cjs.entry.js.map +1 -1
  77. package/dist/cjs/spw-tile.entry.cjs.js.map +1 -1
  78. package/dist/cjs/spw-tooltip.cjs.entry.js +1 -1
  79. package/dist/cjs/spw-topbar.cjs.entry.js +1 -1
  80. package/dist/cjs/spw-wizard-item.cjs.entry.js +1 -1
  81. package/dist/cjs/spw-wizard.cjs.entry.js +1 -1
  82. package/dist/cjs/utils-D_vNTY6w.js.map +1 -1
  83. package/dist/collection/collection-manifest.json +4 -0
  84. package/dist/collection/components/spw-button/spw-button.css +1 -1
  85. package/dist/collection/components/spw-grid/spw-grid-item/spw-grid-item.css +2 -0
  86. package/dist/collection/components/spw-grid/spw-grid-item/spw-grid-item.js +146 -0
  87. package/dist/collection/components/spw-grid/spw-grid-item/spw-grid-item.js.map +1 -0
  88. package/dist/collection/components/spw-grid/spw-grid.css +2 -0
  89. package/dist/collection/components/spw-grid/spw-grid.js +126 -0
  90. package/dist/collection/components/spw-grid/spw-grid.js.map +1 -0
  91. package/dist/collection/components/spw-group/spw-group.js +1 -1
  92. package/dist/collection/components/spw-header/spw-header-lang/spw-header-lang.js +1 -1
  93. package/dist/collection/components/spw-header/spw-header-lang-item/spw-header-lang-item.js +1 -1
  94. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.css +1 -1
  95. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js +33 -1
  96. package/dist/collection/components/spw-header/spw-header-navigation/spw-header-navigation.js.map +1 -1
  97. package/dist/collection/components/spw-header/spw-header-navigation-dropdown/spw-header-navigation-dropdown.js +1 -1
  98. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.css +1 -1
  99. package/dist/collection/components/spw-header/spw-header-navigation-item/spw-header-navigation-item.js +1 -1
  100. package/dist/collection/components/spw-header/spw-header-persona/spw-header-persona.js +1 -1
  101. package/dist/collection/components/spw-header/spw-header-persona-item/spw-header-persona-item.js +1 -1
  102. package/dist/collection/components/spw-header/spw-header.css +1 -1
  103. package/dist/collection/components/spw-header/spw-header.js +1 -1
  104. package/dist/collection/components/spw-header/spw-header.js.map +1 -1
  105. package/dist/collection/components/spw-hero/spw-hero.js +1 -1
  106. package/dist/collection/components/spw-icon/assets/fontawesome/webfonts/fa-light-300.woff2 +0 -0
  107. package/dist/collection/components/spw-icon/spw-icon.js +3 -3
  108. package/dist/collection/components/spw-icon/spw-icon.js.map +1 -1
  109. package/dist/collection/components/spw-iodda/spw-iodda.js +1 -1
  110. package/dist/collection/components/spw-link/spw-link.js +1 -1
  111. package/dist/collection/components/spw-list/spw-list-description/spw-list-description.js +1 -1
  112. package/dist/collection/components/spw-list/spw-list-item/spw-list-item.js +1 -1
  113. package/dist/collection/components/spw-list/spw-list-title/spw-list-title.js +1 -1
  114. package/dist/collection/components/spw-list/spw-list.js +1 -1
  115. package/dist/collection/components/spw-loading/spw-loading.js +1 -1
  116. package/dist/collection/components/spw-modal/spw-modal.js +1 -1
  117. package/dist/collection/components/spw-mosaic/spw-mosaic-item/spw-mosaic-item.js +1 -1
  118. package/dist/collection/components/spw-mosaic/spw-mosaic.js +1 -1
  119. package/dist/collection/components/spw-pagination/spw-pagination.js +6 -6
  120. package/dist/collection/components/spw-radio/spw-radio.js +1 -1
  121. package/dist/collection/components/spw-search-field/spw-search-field.css +1 -1
  122. package/dist/collection/components/spw-search-field/spw-search-field.js +200 -10
  123. package/dist/collection/components/spw-search-field/spw-search-field.js.map +1 -1
  124. package/dist/collection/components/spw-separator/spw-separator.js +1 -1
  125. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-dropdown/spw-sidebar-navigation-dropdown.js +1 -1
  126. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-item/spw-sidebar-navigation-item.js +3 -3
  127. package/dist/collection/components/spw-sidebar/spw-sidebar-navigation-separator/spw-sidebar-navigation-separator.js +1 -1
  128. package/dist/collection/components/spw-sidebar/spw-sidebar.js +1 -1
  129. package/dist/collection/components/spw-skeleton/spw-skeleton.js +1 -1
  130. package/dist/collection/components/spw-slider/spw-slider-item/spw-slider-item.css +2 -0
  131. package/dist/collection/components/spw-slider/spw-slider-item/spw-slider-item.js +19 -0
  132. package/dist/collection/components/spw-slider/spw-slider-item/spw-slider-item.js.map +1 -0
  133. package/dist/collection/components/spw-slider/spw-slider.css +2 -0
  134. package/dist/collection/components/spw-slider/spw-slider.js +319 -0
  135. package/dist/collection/components/spw-slider/spw-slider.js.map +1 -0
  136. package/dist/collection/components/spw-socials/spw-socials.css +1 -1
  137. package/dist/collection/components/spw-socials/spw-socials.js +1 -1
  138. package/dist/collection/components/spw-table/spw-table-body/spw-table-body.js +1 -1
  139. package/dist/collection/components/spw-table/spw-table-cell/spw-table-cell.js +1 -1
  140. package/dist/collection/components/spw-table/spw-table-footer/spw-table-footer.js +1 -1
  141. package/dist/collection/components/spw-table/spw-table-head/spw-table-head.js +1 -1
  142. package/dist/collection/components/spw-table/spw-table-header/spw-table-header.js +2 -2
  143. package/dist/collection/components/spw-table/spw-table-row/spw-table-row.js +1 -1
  144. package/dist/collection/components/spw-tabs/spw-tabs-navigation/spw-tabs-navigation.js +1 -1
  145. package/dist/collection/components/spw-tabs/spw-tabs-navigation-item/spw-tabs-navigation-item.js +1 -1
  146. package/dist/collection/components/spw-tabs/spw-tabs.js +1 -1
  147. package/dist/collection/components/spw-tag/spw-tag.js +1 -1
  148. package/dist/collection/components/spw-text-field/spw-text-field.js +1 -1
  149. package/dist/collection/components/spw-textarea/spw-textarea.js +1 -1
  150. package/dist/collection/components/spw-theme-provider/spw-theme-provider.js +1 -1
  151. package/dist/collection/components/spw-tile/spw-tile-description/spw-tile-description.css +1 -1
  152. package/dist/collection/components/spw-tile/spw-tile-description/spw-tile-description.js +1 -1
  153. package/dist/collection/components/spw-tile/spw-tile-title/spw-tile-title.css +1 -1
  154. package/dist/collection/components/spw-tile/spw-tile-title/spw-tile-title.js +1 -1
  155. package/dist/collection/components/spw-tile/spw-tile.css +1 -1
  156. package/dist/collection/components/spw-tile/spw-tile.js +24 -1
  157. package/dist/collection/components/spw-tile/spw-tile.js.map +1 -1
  158. package/dist/collection/components/spw-tooltip/spw-tooltip.js +1 -1
  159. package/dist/collection/components/spw-topbar/spw-topbar.js +1 -1
  160. package/dist/collection/components/spw-wizard/spw-wizard-item/spw-wizard-item.js +1 -1
  161. package/dist/collection/components/spw-wizard/spw-wizard.js +1 -1
  162. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js +3 -2
  163. package/dist/collection/stories/components/spw-breadcrumb/spw-breadcrumb.stories.js.map +1 -1
  164. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js +11 -31
  165. package/dist/collection/stories/components/spw-pagination/spw-pagination.stories.js.map +1 -1
  166. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js +106 -11
  167. package/dist/collection/stories/components/spw-search-field/spw-search-field.stories.js.map +1 -1
  168. package/dist/collection/stories/organisms/spw-card/spw-card.stories.js +5 -2
  169. package/dist/collection/stories/organisms/spw-card/spw-card.stories.js.map +1 -1
  170. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js +1 -1
  171. package/dist/collection/stories/organisms/spw-header/spw-header.stories.js.map +1 -1
  172. package/dist/collection/stories/organisms/spw-list/spw-list.stories.js +1 -1
  173. package/dist/collection/stories/organisms/spw-list/spw-list.stories.js.map +1 -1
  174. package/dist/collection/stories/organisms/spw-tile/spw-tile.stories.js +1 -1
  175. package/dist/collection/stories/organisms/spw-tile/spw-tile.stories.js.map +1 -1
  176. package/dist/collection/utils/utils.js +5 -4
  177. package/dist/collection/utils/utils.js.map +1 -1
  178. package/dist/components/p-B59-Q28_.js +162 -0
  179. package/dist/components/p-B59-Q28_.js.map +1 -0
  180. package/dist/components/{p-DHBpMBYT.js → p-B62I-VV0.js} +3 -3
  181. package/dist/components/{p-DHBpMBYT.js.map → p-B62I-VV0.js.map} +1 -1
  182. package/dist/components/p-BBi01mKM.js.map +1 -1
  183. package/dist/components/{p-Bvpi6byK.js → p-BSrgKxt5.js} +3 -3
  184. package/dist/components/{p-Bvpi6byK.js.map → p-BSrgKxt5.js.map} +1 -1
  185. package/dist/components/{p-_sdYD0eS.js → p-BlSOja6j.js} +5 -5
  186. package/dist/components/{p-_sdYD0eS.js.map → p-BlSOja6j.js.map} +1 -1
  187. package/dist/components/{p-CVuBJlFL.js → p-BvEKH3n2.js} +3 -3
  188. package/dist/components/{p-CVuBJlFL.js.map → p-BvEKH3n2.js.map} +1 -1
  189. package/dist/components/{p-J5AA2xQI.js → p-DJZBdUDB.js} +3 -3
  190. package/dist/components/{p-J5AA2xQI.js.map → p-DJZBdUDB.js.map} +1 -1
  191. package/dist/components/{p-qgvllwX6.js → p-DKCYb8Pa.js} +3 -3
  192. package/dist/components/{p-qgvllwX6.js.map → p-DKCYb8Pa.js.map} +1 -1
  193. package/dist/components/{p-c0hJPgjJ.js → p-DN5puq3N.js} +3 -3
  194. package/dist/components/{p-c0hJPgjJ.js.map → p-DN5puq3N.js.map} +1 -1
  195. package/dist/components/{p-B2toBmC2.js → p-Dg1wxTqL.js} +11 -11
  196. package/dist/components/{p-B2toBmC2.js.map → p-Dg1wxTqL.js.map} +1 -1
  197. package/dist/components/{p-qROlK2WR.js → p-iQsDa7FA.js} +4 -4
  198. package/dist/components/{p-qROlK2WR.js.map → p-iQsDa7FA.js.map} +1 -1
  199. package/dist/components/{p-_q4w18VU.js → p-jHpxbAsa.js} +3 -3
  200. package/dist/components/{p-_q4w18VU.js.map → p-jHpxbAsa.js.map} +1 -1
  201. package/dist/components/spw-accordion-title.js +1 -1
  202. package/dist/components/spw-breadcrumb-item.js +2 -2
  203. package/dist/components/spw-button.js +1 -1
  204. package/dist/components/spw-card-image.js +1 -1
  205. package/dist/components/spw-checkbox.js +1 -1
  206. package/dist/components/spw-cookies.js +5 -5
  207. package/dist/components/spw-custom-select.js +3 -3
  208. package/dist/components/spw-date-picker.js +2 -2
  209. package/dist/components/spw-dropdown-item.js +1 -1
  210. package/dist/components/spw-field-message.js +1 -1
  211. package/dist/components/spw-file-upload.js +3 -3
  212. package/dist/components/spw-grid-item.d.ts +11 -0
  213. package/dist/components/spw-grid-item.js +52 -0
  214. package/dist/components/spw-grid-item.js.map +1 -0
  215. package/dist/components/spw-grid.d.ts +11 -0
  216. package/dist/components/spw-grid.js +78 -0
  217. package/dist/components/spw-grid.js.map +1 -0
  218. package/dist/components/spw-group.js +1 -1
  219. package/dist/components/spw-header-lang-item.js +1 -1
  220. package/dist/components/spw-header-lang.js +4 -4
  221. package/dist/components/spw-header-navigation-dropdown.js +1 -1
  222. package/dist/components/spw-header-navigation-item.js +3 -3
  223. package/dist/components/spw-header-navigation-item.js.map +1 -1
  224. package/dist/components/spw-header-navigation.js +12 -3
  225. package/dist/components/spw-header-navigation.js.map +1 -1
  226. package/dist/components/spw-header-persona-item.js +1 -1
  227. package/dist/components/spw-header-persona.js +2 -2
  228. package/dist/components/spw-header.js +5 -5
  229. package/dist/components/spw-header.js.map +1 -1
  230. package/dist/components/spw-hero.js +2 -2
  231. package/dist/components/spw-icon.js +1 -1
  232. package/dist/components/spw-iodda.js +6 -6
  233. package/dist/components/spw-link.js +1 -1
  234. package/dist/components/spw-list-description.js +1 -1
  235. package/dist/components/spw-list-item.js +2 -2
  236. package/dist/components/spw-list-title.js +2 -2
  237. package/dist/components/spw-list.js +1 -1
  238. package/dist/components/spw-loading.js +1 -1
  239. package/dist/components/spw-message.js +2 -2
  240. package/dist/components/spw-modal.js +2 -2
  241. package/dist/components/spw-mosaic-item.js +1 -1
  242. package/dist/components/spw-mosaic.js +1 -1
  243. package/dist/components/spw-pagination.js +1 -1
  244. package/dist/components/spw-radio.js +1 -1
  245. package/dist/components/spw-search-field.js +76 -15
  246. package/dist/components/spw-search-field.js.map +1 -1
  247. package/dist/components/spw-select.js +2 -2
  248. package/dist/components/spw-separator.js +1 -1
  249. package/dist/components/spw-sidebar-navigation-dropdown.js +1 -1
  250. package/dist/components/spw-sidebar-navigation-item.js +5 -5
  251. package/dist/components/spw-sidebar-navigation-separator.js +2 -2
  252. package/dist/components/spw-sidebar.js +2 -2
  253. package/dist/components/spw-skeleton.js +1 -1
  254. package/dist/components/spw-slider-item.d.ts +11 -0
  255. package/dist/components/spw-slider-item.js +36 -0
  256. package/dist/components/spw-slider-item.js.map +1 -0
  257. package/dist/components/spw-slider.d.ts +11 -0
  258. package/dist/components/spw-slider.js +274 -0
  259. package/dist/components/spw-slider.js.map +1 -0
  260. package/dist/components/spw-socials.js +2 -2
  261. package/dist/components/spw-socials.js.map +1 -1
  262. package/dist/components/spw-table-body.js +1 -1
  263. package/dist/components/spw-table-cell.js +1 -1
  264. package/dist/components/spw-table-footer.js +1 -1
  265. package/dist/components/spw-table-head.js +1 -1
  266. package/dist/components/spw-table-header.js +4 -4
  267. package/dist/components/spw-table-row.js +1 -1
  268. package/dist/components/spw-tabs-navigation-item.js +3 -3
  269. package/dist/components/spw-tabs-navigation.js +2 -2
  270. package/dist/components/spw-tabs.js +1 -1
  271. package/dist/components/spw-tag.js +2 -2
  272. package/dist/components/spw-text-field.js +1 -1
  273. package/dist/components/spw-textarea.js +3 -3
  274. package/dist/components/spw-theme-provider.js +1 -1
  275. package/dist/components/spw-tile-description.js +2 -2
  276. package/dist/components/spw-tile-description.js.map +1 -1
  277. package/dist/components/spw-tile-title.js +2 -2
  278. package/dist/components/spw-tile-title.js.map +1 -1
  279. package/dist/components/spw-tile.js +7 -3
  280. package/dist/components/spw-tile.js.map +1 -1
  281. package/dist/components/spw-tooltip.js +1 -1
  282. package/dist/components/spw-topbar.js +1 -1
  283. package/dist/components/spw-wizard-item.js +2 -2
  284. package/dist/components/spw-wizard.js +1 -1
  285. package/dist/components_json.json +627 -17
  286. package/dist/esm/loader.js +1 -1
  287. package/dist/esm/spw-button.spw-loading.entry.js.map +1 -1
  288. package/dist/esm/spw-button_2.entry.js +2 -2
  289. package/dist/esm/spw-button_2.entry.js.map +1 -1
  290. package/dist/esm/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.js.map +1 -1
  291. package/dist/esm/spw-field-label_6.entry.js +5 -5
  292. package/dist/esm/spw-field-label_6.entry.js.map +1 -1
  293. package/dist/esm/spw-grid-item.entry.js +27 -0
  294. package/dist/esm/spw-grid-item.entry.js.map +1 -0
  295. package/dist/esm/spw-grid.entry.js +52 -0
  296. package/dist/esm/spw-grid.entry.js.map +1 -0
  297. package/dist/esm/spw-header-lang-item.entry.js +1 -1
  298. package/dist/esm/spw-header-lang.entry.js +1 -1
  299. package/dist/esm/spw-header-navigation-dropdown.entry.js +1 -1
  300. package/dist/esm/spw-header-navigation-item.entry.js +2 -2
  301. package/dist/esm/spw-header-navigation-item.entry.js.map +1 -1
  302. package/dist/esm/spw-header-navigation.entry.js +10 -2
  303. package/dist/esm/spw-header-navigation.entry.js.map +1 -1
  304. package/dist/esm/spw-header-persona-item.entry.js +1 -1
  305. package/dist/esm/spw-header-persona.entry.js +1 -1
  306. package/dist/esm/spw-header.entry.js +2 -2
  307. package/dist/esm/spw-header.entry.js.map +1 -1
  308. package/dist/esm/spw-hero.entry.js +1 -1
  309. package/dist/esm/spw-iodda.entry.js +1 -1
  310. package/dist/esm/spw-list-description.entry.js +1 -1
  311. package/dist/esm/spw-list-item.entry.js +1 -1
  312. package/dist/esm/spw-list-title.entry.js +1 -1
  313. package/dist/esm/spw-list.entry.js +1 -1
  314. package/dist/esm/spw-modal.entry.js +1 -1
  315. package/dist/esm/spw-mosaic-item.entry.js +1 -1
  316. package/dist/esm/spw-mosaic.entry.js +1 -1
  317. package/dist/esm/spw-pagination.entry.js +6 -6
  318. package/dist/esm/spw-radio.entry.js +1 -1
  319. package/dist/esm/spw-search-field.entry.js +66 -12
  320. package/dist/esm/spw-search-field.entry.js.map +1 -1
  321. package/dist/esm/spw-sidebar-navigation-dropdown.entry.js +1 -1
  322. package/dist/esm/spw-sidebar-navigation-item.entry.js +3 -3
  323. package/dist/esm/spw-sidebar-navigation-separator.entry.js +1 -1
  324. package/dist/esm/spw-sidebar.entry.js +1 -1
  325. package/dist/esm/spw-skeleton.entry.js +1 -1
  326. package/dist/esm/spw-slider-item.entry.js +18 -0
  327. package/dist/esm/spw-slider-item.entry.js.map +1 -0
  328. package/dist/esm/spw-slider.entry.js +244 -0
  329. package/dist/esm/spw-slider.entry.js.map +1 -0
  330. package/dist/esm/spw-socials.entry.js +2 -2
  331. package/dist/esm/spw-socials.entry.js.map +1 -1
  332. package/dist/esm/spw-stencil-library.js +1 -1
  333. package/dist/esm/spw-table-body.entry.js +1 -1
  334. package/dist/esm/spw-table-cell.entry.js +1 -1
  335. package/dist/esm/spw-table-footer.entry.js +1 -1
  336. package/dist/esm/spw-table-head.entry.js +1 -1
  337. package/dist/esm/spw-table-header.entry.js +2 -2
  338. package/dist/esm/spw-table-row.entry.js +1 -1
  339. package/dist/esm/spw-tabs-navigation-item.entry.js +1 -1
  340. package/dist/esm/spw-tabs-navigation.entry.js +1 -1
  341. package/dist/esm/spw-tabs.entry.js +1 -1
  342. package/dist/esm/spw-tag.entry.js +1 -1
  343. package/dist/esm/spw-text-field.entry.js +1 -1
  344. package/dist/esm/spw-textarea.entry.js +1 -1
  345. package/dist/esm/spw-tile-description.entry.js +2 -2
  346. package/dist/esm/spw-tile-description.entry.js.map +1 -1
  347. package/dist/esm/spw-tile-title.entry.js +2 -2
  348. package/dist/esm/spw-tile-title.entry.js.map +1 -1
  349. package/dist/esm/spw-tile.entry.js +5 -2
  350. package/dist/esm/spw-tile.entry.js.map +1 -1
  351. package/dist/esm/spw-tooltip.entry.js +1 -1
  352. package/dist/esm/spw-topbar.entry.js +1 -1
  353. package/dist/esm/spw-wizard-item.entry.js +1 -1
  354. package/dist/esm/spw-wizard.entry.js +1 -1
  355. package/dist/esm/utils-BBi01mKM.js.map +1 -1
  356. package/dist/spw-stencil-library/assets/fontawesome/webfonts/fa-light-300.woff2 +0 -0
  357. package/dist/spw-stencil-library/{p-fc6af4d8.entry.js → p-04e6eb78.entry.js} +2 -2
  358. package/dist/spw-stencil-library/{p-06cb6865.entry.js → p-0d4be6b6.entry.js} +2 -2
  359. package/dist/spw-stencil-library/p-14966ecb.entry.js +2 -0
  360. package/dist/spw-stencil-library/p-14966ecb.entry.js.map +1 -0
  361. package/dist/spw-stencil-library/{p-8cfb4646.entry.js → p-1ac496bc.entry.js} +2 -2
  362. package/dist/spw-stencil-library/p-1df14251.entry.js +2 -0
  363. package/dist/spw-stencil-library/p-1df14251.entry.js.map +1 -0
  364. package/dist/spw-stencil-library/{p-5632f307.entry.js → p-1f9aeaa2.entry.js} +2 -2
  365. package/dist/spw-stencil-library/{p-45d99a2b.entry.js → p-257f7869.entry.js} +2 -2
  366. package/dist/spw-stencil-library/{p-86bdf571.entry.js → p-2c724ab6.entry.js} +2 -2
  367. package/dist/spw-stencil-library/{p-2abc48ed.entry.js → p-2e612e2c.entry.js} +2 -2
  368. package/dist/spw-stencil-library/p-2e612e2c.entry.js.map +1 -0
  369. package/dist/spw-stencil-library/p-2e6612dd.entry.js +2 -0
  370. package/dist/spw-stencil-library/p-2e6612dd.entry.js.map +1 -0
  371. package/dist/spw-stencil-library/{p-6ea811f3.entry.js → p-393aff63.entry.js} +2 -2
  372. package/dist/spw-stencil-library/{p-2d974226.entry.js → p-3a485895.entry.js} +2 -2
  373. package/dist/spw-stencil-library/{p-cbf8aea1.entry.js → p-3b10cd69.entry.js} +2 -2
  374. package/dist/spw-stencil-library/{p-512a2787.entry.js → p-3cfd662b.entry.js} +2 -2
  375. package/dist/spw-stencil-library/{p-5e43e2ed.entry.js → p-40b6234e.entry.js} +2 -2
  376. package/dist/spw-stencil-library/p-48ec199f.entry.js +2 -0
  377. package/dist/spw-stencil-library/p-48ec199f.entry.js.map +1 -0
  378. package/dist/spw-stencil-library/{p-438f1793.entry.js → p-49a8e363.entry.js} +2 -2
  379. package/dist/spw-stencil-library/{p-a840f2ca.entry.js → p-4bf78ea1.entry.js} +2 -2
  380. package/dist/spw-stencil-library/{p-63d1c97f.entry.js → p-4ca8274d.entry.js} +2 -2
  381. package/dist/spw-stencil-library/{p-b0e3875a.entry.js → p-503c4a4c.entry.js} +2 -2
  382. package/dist/spw-stencil-library/{p-e3485695.entry.js → p-54e0ff7e.entry.js} +2 -2
  383. package/dist/spw-stencil-library/{p-a25ad9f2.entry.js → p-55adad0b.entry.js} +2 -2
  384. package/dist/spw-stencil-library/{p-a25ad9f2.entry.js.map → p-55adad0b.entry.js.map} +1 -1
  385. package/dist/spw-stencil-library/{p-a31a30f3.entry.js → p-582c5b43.entry.js} +2 -2
  386. package/dist/spw-stencil-library/{p-b6a56ec7.entry.js → p-64455700.entry.js} +2 -2
  387. package/dist/spw-stencil-library/{p-0baeea00.entry.js → p-69220685.entry.js} +2 -2
  388. package/dist/spw-stencil-library/{p-c3985590.entry.js → p-76366414.entry.js} +2 -2
  389. package/dist/spw-stencil-library/p-79719bbc.entry.js +2 -0
  390. package/dist/spw-stencil-library/p-79719bbc.entry.js.map +1 -0
  391. package/dist/spw-stencil-library/{p-d8ba3e5c.entry.js → p-7bfe4ee5.entry.js} +2 -2
  392. package/dist/spw-stencil-library/{p-2c79bd06.entry.js → p-804bb957.entry.js} +2 -2
  393. package/dist/spw-stencil-library/{p-32fd509b.entry.js → p-8e42dc26.entry.js} +2 -2
  394. package/dist/spw-stencil-library/{p-4a273848.entry.js → p-8eeda66f.entry.js} +2 -2
  395. package/dist/spw-stencil-library/{p-2113f2f6.entry.js → p-90a73e8a.entry.js} +2 -2
  396. package/dist/spw-stencil-library/{p-e0c31c21.entry.js → p-9a794a86.entry.js} +2 -2
  397. package/dist/spw-stencil-library/p-BBi01mKM.js.map +1 -1
  398. package/dist/spw-stencil-library/{p-fcc5884a.entry.js → p-a3d3ce93.entry.js} +2 -2
  399. package/dist/spw-stencil-library/p-a3d3ce93.entry.js.map +1 -0
  400. package/dist/spw-stencil-library/{p-488c2d88.entry.js → p-a496fed2.entry.js} +2 -2
  401. package/dist/spw-stencil-library/{p-5a1b3ad1.entry.js → p-a7816d9b.entry.js} +5 -5
  402. package/dist/spw-stencil-library/{p-9d984204.entry.js → p-ab417959.entry.js} +2 -2
  403. package/dist/spw-stencil-library/p-abee710b.entry.js +2 -0
  404. package/dist/spw-stencil-library/p-abee710b.entry.js.map +1 -0
  405. package/dist/spw-stencil-library/{p-48417d99.entry.js → p-b027d336.entry.js} +2 -2
  406. package/dist/spw-stencil-library/p-b027d336.entry.js.map +1 -0
  407. package/dist/spw-stencil-library/p-b0493a84.entry.js +2 -0
  408. package/dist/spw-stencil-library/p-b0493a84.entry.js.map +1 -0
  409. package/dist/spw-stencil-library/p-b68a4a1c.entry.js +2 -0
  410. package/dist/spw-stencil-library/p-b68a4a1c.entry.js.map +1 -0
  411. package/dist/spw-stencil-library/{p-f28bf2be.entry.js → p-b7af7c70.entry.js} +2 -2
  412. package/dist/spw-stencil-library/{p-9d760073.entry.js → p-c8c62aaa.entry.js} +2 -2
  413. package/dist/spw-stencil-library/p-c9c26889.entry.js +2 -0
  414. package/dist/spw-stencil-library/p-c9c26889.entry.js.map +1 -0
  415. package/dist/spw-stencil-library/{p-0e1ec1e6.entry.js → p-d3242535.entry.js} +2 -2
  416. package/dist/spw-stencil-library/{p-9e12973d.entry.js → p-e4dc2bcb.entry.js} +2 -2
  417. package/dist/spw-stencil-library/p-e4dc2bcb.entry.js.map +1 -0
  418. package/dist/spw-stencil-library/{p-46567994.entry.js → p-ec380e53.entry.js} +2 -2
  419. package/dist/spw-stencil-library/{p-ce72bca4.entry.js → p-f5d6641d.entry.js} +2 -2
  420. package/dist/spw-stencil-library/{p-f70ed5c3.entry.js → p-f7fdda79.entry.js} +2 -2
  421. package/dist/spw-stencil-library/{p-2ad00dfc.entry.js → p-f96ee8a6.entry.js} +2 -2
  422. package/dist/spw-stencil-library/{p-000f04a1.entry.js → p-fa308eb6.entry.js} +2 -2
  423. package/dist/spw-stencil-library/spw-button.spw-loading.entry.esm.js.map +1 -1
  424. package/dist/spw-stencil-library/spw-field-label.spw-group.spw-icon.spw-link.spw-separator.spw-theme-provider.entry.esm.js.map +1 -1
  425. package/dist/spw-stencil-library/spw-grid-item.entry.esm.js.map +1 -0
  426. package/dist/spw-stencil-library/spw-grid.entry.esm.js.map +1 -0
  427. package/dist/spw-stencil-library/spw-header-navigation-item.entry.esm.js.map +1 -1
  428. package/dist/spw-stencil-library/spw-header-navigation.entry.esm.js.map +1 -1
  429. package/dist/spw-stencil-library/spw-header.entry.esm.js.map +1 -1
  430. package/dist/spw-stencil-library/spw-search-field.entry.esm.js.map +1 -1
  431. package/dist/spw-stencil-library/spw-slider-item.entry.esm.js.map +1 -0
  432. package/dist/spw-stencil-library/spw-slider.entry.esm.js.map +1 -0
  433. package/dist/spw-stencil-library/spw-socials.entry.esm.js.map +1 -1
  434. package/dist/spw-stencil-library/spw-stencil-library.css +1 -1
  435. package/dist/spw-stencil-library/spw-stencil-library.esm.js +1 -1
  436. package/dist/spw-stencil-library/spw-tile-description.entry.esm.js.map +1 -1
  437. package/dist/spw-stencil-library/spw-tile-title.entry.esm.js.map +1 -1
  438. package/dist/spw-stencil-library/spw-tile.entry.esm.js.map +1 -1
  439. package/dist/stats.json +2087 -354
  440. package/dist/types/components/spw-grid/spw-grid-item/spw-grid-item.d.ts +16 -0
  441. package/dist/types/components/spw-grid/spw-grid.d.ts +13 -0
  442. package/dist/types/components/spw-header/spw-header-navigation/spw-header-navigation.d.ts +3 -0
  443. package/dist/types/components/spw-icon/spw-icon.d.ts +1 -1
  444. package/dist/types/components/spw-search-field/spw-search-field.d.ts +20 -1
  445. package/dist/types/components/spw-slider/spw-slider-item/spw-slider-item.d.ts +3 -0
  446. package/dist/types/components/spw-slider/spw-slider.d.ts +43 -0
  447. package/dist/types/components/spw-tile/spw-tile.d.ts +2 -0
  448. package/dist/types/components.d.ts +206 -2
  449. package/dist/types/stories/components/spw-pagination/spw-pagination.stories.d.ts +0 -17
  450. package/dist/types/stories/components/spw-search-field/spw-search-field.stories.d.ts +5 -0
  451. package/hydrate/index.js +522 -78
  452. package/hydrate/index.mjs +522 -78
  453. package/package.json +1 -1
  454. package/dist/components/p-DjyPtAVX.js +0 -162
  455. package/dist/components/p-DjyPtAVX.js.map +0 -1
  456. package/dist/components_vscode.json +0 -3088
  457. package/dist/spw-stencil-library/p-0f69442e.entry.js +0 -2
  458. package/dist/spw-stencil-library/p-0f69442e.entry.js.map +0 -1
  459. package/dist/spw-stencil-library/p-2abc48ed.entry.js.map +0 -1
  460. package/dist/spw-stencil-library/p-300b4bdb.entry.js +0 -2
  461. package/dist/spw-stencil-library/p-300b4bdb.entry.js.map +0 -1
  462. package/dist/spw-stencil-library/p-451a9785.entry.js +0 -2
  463. package/dist/spw-stencil-library/p-451a9785.entry.js.map +0 -1
  464. package/dist/spw-stencil-library/p-48417d99.entry.js.map +0 -1
  465. package/dist/spw-stencil-library/p-9b63ccca.entry.js +0 -2
  466. package/dist/spw-stencil-library/p-9b63ccca.entry.js.map +0 -1
  467. package/dist/spw-stencil-library/p-9e12973d.entry.js.map +0 -1
  468. package/dist/spw-stencil-library/p-c4e4cfd4.entry.js +0 -2
  469. package/dist/spw-stencil-library/p-c4e4cfd4.entry.js.map +0 -1
  470. package/dist/spw-stencil-library/p-fcc5884a.entry.js.map +0 -1
  471. /package/dist/spw-stencil-library/{p-fc6af4d8.entry.js.map → p-04e6eb78.entry.js.map} +0 -0
  472. /package/dist/spw-stencil-library/{p-06cb6865.entry.js.map → p-0d4be6b6.entry.js.map} +0 -0
  473. /package/dist/spw-stencil-library/{p-8cfb4646.entry.js.map → p-1ac496bc.entry.js.map} +0 -0
  474. /package/dist/spw-stencil-library/{p-5632f307.entry.js.map → p-1f9aeaa2.entry.js.map} +0 -0
  475. /package/dist/spw-stencil-library/{p-45d99a2b.entry.js.map → p-257f7869.entry.js.map} +0 -0
  476. /package/dist/spw-stencil-library/{p-86bdf571.entry.js.map → p-2c724ab6.entry.js.map} +0 -0
  477. /package/dist/spw-stencil-library/{p-6ea811f3.entry.js.map → p-393aff63.entry.js.map} +0 -0
  478. /package/dist/spw-stencil-library/{p-2d974226.entry.js.map → p-3a485895.entry.js.map} +0 -0
  479. /package/dist/spw-stencil-library/{p-cbf8aea1.entry.js.map → p-3b10cd69.entry.js.map} +0 -0
  480. /package/dist/spw-stencil-library/{p-512a2787.entry.js.map → p-3cfd662b.entry.js.map} +0 -0
  481. /package/dist/spw-stencil-library/{p-5e43e2ed.entry.js.map → p-40b6234e.entry.js.map} +0 -0
  482. /package/dist/spw-stencil-library/{p-438f1793.entry.js.map → p-49a8e363.entry.js.map} +0 -0
  483. /package/dist/spw-stencil-library/{p-a840f2ca.entry.js.map → p-4bf78ea1.entry.js.map} +0 -0
  484. /package/dist/spw-stencil-library/{p-63d1c97f.entry.js.map → p-4ca8274d.entry.js.map} +0 -0
  485. /package/dist/spw-stencil-library/{p-b0e3875a.entry.js.map → p-503c4a4c.entry.js.map} +0 -0
  486. /package/dist/spw-stencil-library/{p-e3485695.entry.js.map → p-54e0ff7e.entry.js.map} +0 -0
  487. /package/dist/spw-stencil-library/{p-a31a30f3.entry.js.map → p-582c5b43.entry.js.map} +0 -0
  488. /package/dist/spw-stencil-library/{p-b6a56ec7.entry.js.map → p-64455700.entry.js.map} +0 -0
  489. /package/dist/spw-stencil-library/{p-0baeea00.entry.js.map → p-69220685.entry.js.map} +0 -0
  490. /package/dist/spw-stencil-library/{p-c3985590.entry.js.map → p-76366414.entry.js.map} +0 -0
  491. /package/dist/spw-stencil-library/{p-d8ba3e5c.entry.js.map → p-7bfe4ee5.entry.js.map} +0 -0
  492. /package/dist/spw-stencil-library/{p-2c79bd06.entry.js.map → p-804bb957.entry.js.map} +0 -0
  493. /package/dist/spw-stencil-library/{p-32fd509b.entry.js.map → p-8e42dc26.entry.js.map} +0 -0
  494. /package/dist/spw-stencil-library/{p-4a273848.entry.js.map → p-8eeda66f.entry.js.map} +0 -0
  495. /package/dist/spw-stencil-library/{p-2113f2f6.entry.js.map → p-90a73e8a.entry.js.map} +0 -0
  496. /package/dist/spw-stencil-library/{p-e0c31c21.entry.js.map → p-9a794a86.entry.js.map} +0 -0
  497. /package/dist/spw-stencil-library/{p-488c2d88.entry.js.map → p-a496fed2.entry.js.map} +0 -0
  498. /package/dist/spw-stencil-library/{p-5a1b3ad1.entry.js.map → p-a7816d9b.entry.js.map} +0 -0
  499. /package/dist/spw-stencil-library/{p-9d984204.entry.js.map → p-ab417959.entry.js.map} +0 -0
  500. /package/dist/spw-stencil-library/{p-f28bf2be.entry.js.map → p-b7af7c70.entry.js.map} +0 -0
  501. /package/dist/spw-stencil-library/{p-9d760073.entry.js.map → p-c8c62aaa.entry.js.map} +0 -0
  502. /package/dist/spw-stencil-library/{p-0e1ec1e6.entry.js.map → p-d3242535.entry.js.map} +0 -0
  503. /package/dist/spw-stencil-library/{p-46567994.entry.js.map → p-ec380e53.entry.js.map} +0 -0
  504. /package/dist/spw-stencil-library/{p-ce72bca4.entry.js.map → p-f5d6641d.entry.js.map} +0 -0
  505. /package/dist/spw-stencil-library/{p-f70ed5c3.entry.js.map → p-f7fdda79.entry.js.map} +0 -0
  506. /package/dist/spw-stencil-library/{p-2ad00dfc.entry.js.map → p-f96ee8a6.entry.js.map} +0 -0
  507. /package/dist/spw-stencil-library/{p-000f04a1.entry.js.map → p-fa308eb6.entry.js.map} +0 -0
@@ -2,7 +2,7 @@
2
2
 
3
3
  var index = require('./index-ivINMH9O.js');
4
4
 
5
- const spwSearchFieldCss = "/*! 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:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-search-field{position:relative}.spw-search-field--large spw-text-field{--spw-input-height:54px;--spw-input-padding:16px 24px;--spw-input-radius:60px;--spw-input-border:transparent;--spw-input-icon-search-color:var(--spw-ds-primary)}.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);color:var(--spw-color-themes-grey-grey-900);cursor:pointer;padding:12px;text-align:left;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;text-align:left}.spw-tw-italic{font-style:italic}.-spw-tw-mt-1{margin-top:-.25rem}.spw-tw-mb-2{margin-bottom:.5rem}";
5
+ const spwSearchFieldCss = "/*! 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:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-search-field{position:relative}.spw-search-field--large spw-text-field{--spw-input-height:54px;--spw-input-padding:16px 24px;--spw-input-radius:60px;--spw-input-border:transparent;--spw-input-icon-search-color:var(--spw-ds-primary)}.spw-search-field--has-submit-button spw-text-field{--spw-input-padding-right:56px}.spw-search-field__submit{align-items:center;background:transparent;border:none;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:0;top:50%;transform:translateY(-50%);transition:all .2s ease;width:40px;z-index:10}.spw-search-field--large .spw-search-field__submit{height:46px;right:16px;width:46px}.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--is-rounded .spw-search-field__options{border-radius:24px;margin-top:12px}.spw-search-field--is-rounded .spw-search-field__options ul{padding:12px}.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);color:var(--spw-color-themes-grey-grey-900);cursor:pointer;padding:12px;text-align:left;transition:background-color .2s ease}.spw-search-field--is-rounded .spw-search-field__option{border-bottom:none;border-radius:12px;padding:12px}.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;text-align:left}.spw-search-field--is-rounded .spw-search-field__no-results{padding:24px}.spw-search-field__view-all{bottom:0;cursor:pointer;font-weight:700;position:sticky}.spw-search-field--is-rounded .spw-search-field__view-all{border-radius:12px;border-top:none}.spw-search-field__view-all a{background:#fff;border-top:1px solid var(--spw-color-themes-grey-grey-900);color:#000;display:block;display:inline-flex;justify-content:space-between;padding:12px;text-decoration:underline;width:100%}.spw-search-field--is-rounded .spw-search-field__view-all a{border-top:none;color:var(--spw-ds-primary);padding:12px 24px 24px}.spw-search-field__view-all a:hover{text-decoration:none}.spw-tw-italic{font-style:italic}.-spw-tw-mt-1{margin-top:-.25rem}.spw-tw-mb-2{margin-bottom:.5rem}";
6
6
 
7
7
  const SpwSearchField = class {
8
8
  constructor(hostRef) {
@@ -16,6 +16,12 @@ const SpwSearchField = class {
16
16
  this.label = '';
17
17
  /** Indique si le champ est requis */
18
18
  this.required = false;
19
+ /** Texte du lien pour voir tous les résultats */
20
+ this.viewAllResults = 'Voir plus de résultats';
21
+ /** Texte à afficher si pas de résultats */
22
+ this.noResults = 'Pas de résultats.';
23
+ /** Affiche un bouton submit (loupe) qui déclenche le submit du formulaire parent */
24
+ this.hasSubmitButton = false;
19
25
  this.filteredItems = [];
20
26
  this.searchText = '';
21
27
  this.isOpen = false;
@@ -30,6 +36,28 @@ const SpwSearchField = class {
30
36
  }
31
37
  }
32
38
  };
39
+ this.handleValueChanged = (event) => {
40
+ const newValue = String(event.detail);
41
+ this.searchText = newValue;
42
+ this.updateHiddenInput();
43
+ this.filterItems();
44
+ this.determineDropdownDirection();
45
+ if (!this.searchText) {
46
+ this.isOpen = false;
47
+ }
48
+ else {
49
+ this.isOpen = true;
50
+ }
51
+ this.valueChanged.emit(this.searchText);
52
+ };
53
+ this.handleSubmit = (event) => {
54
+ event.preventDefault();
55
+ this.updateHiddenInput();
56
+ const form = this.el.closest('form');
57
+ if (form) {
58
+ form.submit();
59
+ }
60
+ };
33
61
  }
34
62
  componentWillLoad() {
35
63
  if (this.items) {
@@ -41,17 +69,47 @@ const SpwSearchField = class {
41
69
  }
42
70
  componentDidLoad() {
43
71
  document.addEventListener('click', this.handleClickOutside);
72
+ this.createHiddenInput();
44
73
  }
45
74
  disconnectedCallback() {
46
75
  document.removeEventListener('click', this.handleClickOutside);
76
+ if (this.hiddenInput && this.hiddenInput.parentNode) {
77
+ this.hiddenInput.parentNode.removeChild(this.hiddenInput);
78
+ }
79
+ }
80
+ createHiddenInput() {
81
+ if (this.name) {
82
+ this.hiddenInput = document.createElement('input');
83
+ this.hiddenInput.type = 'hidden';
84
+ this.hiddenInput.name = this.name;
85
+ this.hiddenInput.value = this.searchText;
86
+ this.el.appendChild(this.hiddenInput);
87
+ }
88
+ }
89
+ updateHiddenInput() {
90
+ if (this.hiddenInput) {
91
+ this.hiddenInput.value = this.searchText;
92
+ }
47
93
  }
48
94
  /** Réinitialise le champ de recherche */
49
95
  async resetInput() {
50
96
  this.searchText = '';
97
+ this.updateHiddenInput();
51
98
  this.isOpen = false;
52
99
  this.focusedItemIndex = null;
53
100
  this.valueChanged.emit(this.searchText);
54
101
  }
102
+ /** Définit la valeur du champ de recherche */
103
+ async setValue(value) {
104
+ this.searchText = value;
105
+ this.updateHiddenInput();
106
+ this.filterItems();
107
+ this.valueChanged.emit(this.searchText);
108
+ }
109
+ /** Récupère la valeur actuelle du champ de recherche */
110
+ async getValue() {
111
+ return this.searchText;
112
+ }
55
113
  parseItems(newValue) {
56
114
  if (!newValue) {
57
115
  this.filteredItems = [];
@@ -65,14 +123,6 @@ const SpwSearchField = class {
65
123
  this.filteredItems = [];
66
124
  }
67
125
  }
68
- handleSearchInput(event) {
69
- const input = event.target;
70
- this.searchText = input.value;
71
- this.filterItems();
72
- this.determineDropdownDirection();
73
- this.isOpen = true;
74
- this.valueChanged.emit(this.searchText);
75
- }
76
126
  filterItems() {
77
127
  if (!this.items) {
78
128
  this.filteredItems = [];
@@ -89,6 +139,7 @@ const SpwSearchField = class {
89
139
  }
90
140
  selectItem(item) {
91
141
  this.searchText = item.label;
142
+ this.updateHiddenInput();
92
143
  this.isOpen = false;
93
144
  this.valueChanged.emit(this.searchText);
94
145
  if (item.url) {
@@ -144,15 +195,18 @@ const SpwSearchField = class {
144
195
  get elementClass() {
145
196
  return {
146
197
  'spw-search-field': true,
198
+ 'spw-search-field--is-rounded': this.isRounded,
199
+ 'spw-search-field--has-submit-button': this.hasSubmitButton,
147
200
  [`spw-search-field--${this.size}`]: true,
148
201
  };
149
202
  }
150
203
  render() {
151
- return (index.h("div", { key: '177ea345dde83be8b00034dabd261cd4ae921b53', ref: el => (this.hostElement = el), class: this.elementClass }, index.h("spw-text-field", { key: 'ff33047f1a04a89e239ab0bd3a8af4337c8f235b', placeholder: this.placeholder, name: this.name, label: this.label, size: this.size, "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 && (index.h("div", { key: '11c758b336d8590e082eaa7773fa6cd45709074d', class: `spw-search-field__options spw-search-field__options--${this.dropdownDirection}` }, !!this.filteredItems.length && (index.h("ul", { key: '745a24351b6818bedd402ecd19c5ad06d7eab8d9' }, this.filteredItems.map((item, index$1) => (index.h("li", { class: {
204
+ return (index.h("div", { key: 'd0a1b10aa7cdf992e36f90c215a38d4138e0dbbd', ref: el => (this.hostElement = el), class: this.elementClass }, index.h("spw-text-field", { key: '1fdbace2681a85644f082916b6d43a82e784ba2b', placeholder: this.placeholder, name: this.name, label: this.label, size: this.size, "is-search": true, "is-clear": true, required: this.required, disabled: this.disabled, assistiveText: this.assistiveText, value: this.searchText, onValueChanged: this.handleValueChanged, onKeyDown: event => this.handleKeyDown(event) }), this.hasSubmitButton && index.h("button", { key: 'a88e7c9fc3f0ec38a04a96c0199148c8739c1216', type: "button", class: "spw-search-field__submit", onClick: this.handleSubmit, "aria-label": "Rechercher" }), this.isOpen && !!this.items && (index.h("div", { key: 'befb8b10930f0ae8ee659325993995dc73278b84', class: `spw-search-field__options spw-search-field__options--${this.dropdownDirection}` }, !!this.filteredItems.length && (index.h("ul", { key: '96007fab50b2de0a58a36c01f05dc1915549e218' }, this.filteredItems.map((item, index$1) => (index.h("li", { class: {
152
205
  'spw-search-field__option': true,
153
206
  'spw-search-field__option--focused': index$1 === this.focusedItemIndex,
154
- }, onClick: () => this.selectItem(item) }, this.highlightMatch(item.label), " ", item.category && index.h("span", { class: "spw-tw-italic" }, " - ", item.category)))))), !this.filteredItems.length && index.h("p", { key: '53f82d90522e707aef8f3a4de87875d44ad1fbea', class: "spw-search-field__no-results" }, "Pas de r\u00E9sultats.")))));
207
+ }, onClick: () => this.selectItem(item) }, this.highlightMatch(item.label), " ", item.category && index.h("span", { class: "spw-tw-italic" }, " - ", item.category)))))), !this.filteredItems.length && index.h("p", { key: 'da6968da819382f15ab30478d7b3d93962848adf', class: "spw-search-field__no-results" }, this.noResults), !!this.filteredItems.length && this.viewAllResults && this.viewAllResultsLink && (index.h("p", { key: '62f022f97e5755b0ea79db2db80e92e2e161996e', class: "spw-search-field__view-all" }, index.h("a", { key: '4765319c861bd9427f7871588b95dd52e28fa917', href: this.viewAllResultsLink }, this.viewAllResults, " ", index.h("spw-icon", { key: 'fd59b817d4576cfaefcd2d5c7a2a8c6f9eef9a94', icon: "fa-arrow-right" }))))))));
155
208
  }
209
+ get el() { return index.getElement(this); }
156
210
  static get watchers() { return {
157
211
  "items": ["parseItems"]
158
212
  }; }
@@ -1 +1 @@
1
- {"file":"spw-search-field.entry.cjs.js","mappings":";;;;AAAA,MAAM,iBAAiB,GAAG,m3HAAm3H;;MCOh4H,cAAc,GAAA,MAAA;AAL3B,IAAA,WAAA,CAAA,OAAA,EAAA;;;;AAcU,QAAA,IAAW,CAAA,WAAA,GAAW,cAAc;;AAEpC,QAAA,IAAI,CAAA,IAAA,GAAwB,QAAQ;;AAEpC,QAAA,IAAK,CAAA,KAAA,GAAY,EAAE;;AAMnB,QAAA,IAAQ,CAAA,QAAA,GAAa,KAAK;AAIzB,QAAA,IAAa,CAAA,aAAA,GAA8D,EAAE;AAC7E,QAAA,IAAU,CAAA,UAAA,GAAW,EAAE;AACvB,QAAA,IAAM,CAAA,MAAA,GAAY,KAAK;AACvB,QAAA,IAAgB,CAAA,gBAAA,GAAkB,IAAI;AACtC,QAAA,IAAiB,CAAA,iBAAA,GAAkB,MAAM;AA0C1C,QAAA,IAAA,CAAA,kBAAkB,GAAG,CAAC,KAAiB,KAAI;AACjD,YAAA,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,MAAM,MAAM,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC,CAAC,CAAS;gBAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAEtD,IAAI,CAAC,YAAY,EAAE;AACjB,oBAAA,IAAI,CAAC,MAAM,GAAG,KAAK;;;AAGzB,SAAC;AAiJF;IAlMC,iBAAiB,GAAA;AACf,QAAA,IAAI,IAAI,CAAC,KAAK,EAAE;AACd,YAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC;;aACtB;AACL,YAAA,IAAI,CAAC,aAAa,GAAG,EAAE;;;IAI3B,gBAAgB,GAAA;QACd,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC;;IAG7D,oBAAoB,GAAA;QAClB,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC;;;AAKhE,IAAA,MAAM,UAAU,GAAA;AACd,QAAA,IAAI,CAAC,UAAU,GAAG,EAAE;AACpB,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK;AACnB,QAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI;QAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;;AAIzC,IAAA,UAAU,CAAC,QAAgB,EAAA;QACzB,IAAI,CAAC,QAAQ,EAAE;AACb,YAAA,IAAI,CAAC,aAAa,GAAG,EAAE;YACvB;;AAGF,QAAA,IAAI;YACF,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;;QACzC,OAAO,CAAC,EAAE;AACV,YAAA,OAAO,CAAC,KAAK,CAAC,gCAAgC,EAAE,QAAQ,CAAC;AACzD,YAAA,IAAI,CAAC,aAAa,GAAG,EAAE;;;AAenB,IAAA,iBAAiB,CAAC,KAAY,EAAA;AACpC,QAAA,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B;AAC9C,QAAA,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,KAAK;QAC7B,IAAI,CAAC,WAAW,EAAE;QAClB,IAAI,CAAC,0BAA0B,EAAE;AACjC,QAAA,IAAI,CAAC,MAAM,GAAG,IAAI;QAClB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;;IAGjC,WAAW,GAAA;AACjB,QAAA,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;AACf,YAAA,IAAI,CAAC,aAAa,GAAG,EAAE;YACvB;;QAGF,MAAM,oBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;AAElE,QAAA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;;AAGrH,IAAA,eAAe,CAAC,GAAW,EAAA;AACjC,QAAA,OAAO;aACJ,SAAS,CAAC,KAAK;AACf,aAAA,OAAO,CAAC,kBAAkB,EAAE,EAAE;AAC9B,aAAA,WAAW,EAAE;;AAGV,IAAA,UAAU,CAAC,IAAqC,EAAA;AACtD,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK;AAC5B,QAAA,IAAI,CAAC,MAAM,GAAG,KAAK;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;AAEvC,QAAA,IAAI,IAAI,CAAC,GAAG,EAAE;YACZ,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG;;;IAI3B,0BAA0B,GAAA;QAChC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,EAAE;AACrD,QAAA,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW;AAEzC,QAAA,IAAI,IAAI,CAAC,MAAM,GAAG,GAAG,GAAG,cAAc,IAAI,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE;AACxD,YAAA,IAAI,CAAC,iBAAiB,GAAG,IAAI;;aACxB;AACL,YAAA,IAAI,CAAC,iBAAiB,GAAG,MAAM;;;AAI3B,IAAA,aAAa,CAAC,KAAoB,EAAA;AACxC,QAAA,QAAQ,KAAK,CAAC,GAAG;AACf,YAAA,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE;AACtB,gBAAA,IAAI,IAAI,CAAC,MAAM,EAAE;AACf,oBAAA,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,KAAK,IAAI,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM;;gBAEtH;AACF,YAAA,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE;AACtB,gBAAA,IAAI,IAAI,CAAC,MAAM,EAAE;AACf,oBAAA,IAAI,CAAC,gBAAgB;AACnB,wBAAA,IAAI,CAAC,gBAAgB,KAAK,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM;;gBAExJ;AACF,YAAA,KAAK,OAAO;gBACV,KAAK,CAAC,cAAc,EAAE;gBACtB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI,EAAE;AACjD,oBAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;;gBAE5D;AACF,YAAA,KAAK,QAAQ;AACX,gBAAA,IAAI,CAAC,MAAM,GAAG,KAAK;gBACnB;;;AAIE,IAAA,cAAc,CAAC,IAAY,EAAA;QACjC,MAAM,oBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC;QAClE,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;QAEjD,MAAM,UAAU,GAAG,cAAc,CAAC,OAAO,CAAC,oBAAoB,CAAC;QAE/D,IAAI,UAAU,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;AACzC,YAAA,OAAO,IAAI;;AAGb,QAAA,MAAM,QAAQ,GAAG,UAAU,GAAG,oBAAoB,CAAC,MAAM;AAEzD,QAAA,QACEA,OAAA,CAAA,MAAA,EAAA,IAAA,EACG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,EAC1BA,OAAS,CAAA,QAAA,EAAA,IAAA,EAAA,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAU,EAClD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAChB;;AAIX,IAAA,IAAY,YAAY,GAAA;QACtB,OAAO;AACL,YAAA,kBAAkB,EAAE,IAAI;AACxB,YAAA,CAAC,qBAAqB,IAAI,CAAC,IAAI,CAAE,CAAA,GAAG,IAAI;SACzC;;IAGH,MAAM,GAAA;QACJ,QACEA,kEAAK,GAAG,EAAE,EAAE,KAAK,IAAI,CAAC,WAAW,GAAG,EAAiB,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,YAAY,EAAA,EAC9EA,OAAA,CAAA,gBAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,WAAW,EAAE,IAAI,CAAC,WAAW,EAC7B,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,IAAI,EAAE,IAAI,CAAC,IAAI,EACJ,WAAA,EAAA,IAAI,cACL,IAAI,EACd,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,aAAa,EAAE,IAAI,CAAC,aAAa,EACjC,KAAK,EAAE,IAAI,CAAC,UAAU,EACtB,OAAO,EAAE,KAAK,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAC/C,SAAS,EAAE,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAC7B,CAAA,EACjB,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAC1BA,kEAAK,KAAK,EAAE,CAAwD,qDAAA,EAAA,IAAI,CAAC,iBAAiB,CAAA,CAAE,EAAA,EACzF,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,KAC1BA,OACG,CAAA,IAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EAAA,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAEC,OAAK,MAClCD,OACE,CAAA,IAAA,EAAA,EAAA,KAAK,EAAE;AACL,gBAAA,0BAA0B,EAAE,IAAI;AAChC,gBAAA,mCAAmC,EAAEC,OAAK,KAAK,IAAI,CAAC,gBAAgB;AACrE,aAAA,EACD,OAAO,EAAE,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAA,EAEnC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,OAAG,IAAI,CAAC,QAAQ,IAAID,OAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,eAAe,EAAA,SAAK,IAAI,CAAC,QAAQ,CAAQ,CACtG,CACN,CAAC,CACC,CACN,EACA,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,IAAIA,OAAA,CAAA,GAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAG,KAAK,EAAC,8BAA8B,EAAsB,EAAA,wBAAA,CAAA,CACxF,CACP,CACG;;;;;;;;;;","names":["h","index"],"sources":["src/components/spw-search-field/spw-search-field.scss?tag=spw-search-field&encapsulation=shadow","src/components/spw-search-field/spw-search-field.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.spw-search-field {\n position: relative;\n &--large {\n spw-text-field {\n --spw-input-height: 54px;\n --spw-input-padding: 16px 24px;\n --spw-input-radius: 60px;\n --spw-input-border: transparent;\n --spw-input-icon-search-color: var(--spw-ds-primary);\n }\n }\n}\n\n.spw-search-field__options {\n position: absolute;\n width: 100%;\n background-color: #fff;\n border: 1px solid var(--spw-color-themes-grey-grey-800);\n border-radius: 0 0 4px 4px;\n max-height: 200px;\n overflow-y: auto;\n z-index: 44;\n margin-top: -2px;\n transition:\n transform 0.3s ease,\n opacity 0.3s ease;\n}\n\n.spw-search-field__options--down {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__options--up {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__option {\n padding: 12px;\n color: var(--spw-color-themes-grey-grey-900);\n text-align: left;\n border-bottom: 1px solid var(--spw-color-themes-grey-grey-900);\n cursor: pointer;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: var(--spw-color-themes-grey-grey-200);\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n &--focused {\n background-color: var(--spw-color-themes-grey-grey-300);\n }\n\n &--selected {\n font-weight: 700;\n }\n}\n\n.spw-search-field__no-results {\n padding: 12px;\n cursor: not-allowed;\n text-align: left;\n color: var(--spw-color-themes-grey-grey-600);\n}\n","import { Component, Prop, State, Event, EventEmitter, Method, 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 /** Événement émis lorsque la valeur du champ de recherche change */\n @Event() valueChanged: EventEmitter<string>;\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 /** Taille du champ de recherche */\n @Prop() size?: 'large' | 'medium' = 'medium';\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 /** Réinitialise le champ de recherche */\n @Method()\n async resetInput() {\n this.searchText = '';\n this.isOpen = false;\n this.focusedItemIndex = null;\n this.valueChanged.emit(this.searchText);\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 this.valueChanged.emit(this.searchText);\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 this.valueChanged.emit(this.searchText);\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 private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-search-field': true,\n [`spw-search-field--${this.size}`]: true,\n };\n }\n\n render() {\n return (\n <div ref={el => (this.hostElement = el as HTMLElement)} class={this.elementClass}>\n <spw-text-field\n placeholder={this.placeholder}\n name={this.name}\n label={this.label}\n size={this.size}\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"],"version":3}
1
+ {"file":"spw-search-field.entry.cjs.js","mappings":"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","names":["h","index"],"sources":["src/components/spw-search-field/spw-search-field.scss?tag=spw-search-field&encapsulation=shadow","src/components/spw-search-field/spw-search-field.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.spw-search-field {\n position: relative;\n &--large {\n spw-text-field {\n --spw-input-height: 54px;\n --spw-input-padding: 16px 24px;\n --spw-input-radius: 60px;\n --spw-input-border: transparent;\n --spw-input-icon-search-color: var(--spw-ds-primary);\n }\n }\n\n &--has-submit-button {\n spw-text-field {\n --spw-input-padding-right: 56px;\n }\n }\n}\n\n.spw-search-field__submit {\n position: absolute;\n right: 0;\n top: 50%;\n transform: translateY(-50%);\n width: 40px;\n height: 40px;\n border: none;\n border-radius: 50%;\n background: transparent;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n transition: all 0.2s ease;\n z-index: 10;\n\n .spw-search-field--large & {\n width: 46px;\n height: 46px;\n right: 16px;\n }\n}\n\n.spw-search-field__options {\n position: absolute;\n width: 100%;\n background-color: #fff;\n border: 1px solid var(--spw-color-themes-grey-grey-800);\n border-radius: 0 0 4px 4px;\n max-height: 200px;\n overflow-y: auto;\n z-index: 44;\n margin-top: -2px;\n transition:\n transform 0.3s ease,\n opacity 0.3s ease;\n .spw-search-field--is-rounded & {\n border-radius: 24px;\n margin-top: 12px;\n ul {\n padding: 12px;\n }\n }\n}\n\n.spw-search-field__options--down {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__options--up {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__option {\n padding: 12px;\n color: var(--spw-color-themes-grey-grey-900);\n text-align: left;\n border-bottom: 1px solid var(--spw-color-themes-grey-grey-900);\n cursor: pointer;\n transition: background-color 0.2s ease;\n\n .spw-search-field--is-rounded & {\n border-radius: 12px;\n padding: 12px;\n border-bottom: none;\n }\n\n &:hover {\n background-color: var(--spw-color-themes-grey-grey-200);\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n &--focused {\n background-color: var(--spw-color-themes-grey-grey-300);\n }\n\n &--selected {\n font-weight: 700;\n }\n}\n\n.spw-search-field__no-results {\n padding: 12px;\n cursor: not-allowed;\n text-align: left;\n color: var(--spw-color-themes-grey-grey-600);\n .spw-search-field--is-rounded & {\n padding: 24px;\n }\n}\n\n.spw-search-field__view-all {\n position: sticky;\n bottom: 0;\n cursor: pointer;\n font-weight: 700;\n\n .spw-search-field--is-rounded & {\n border-radius: 12px;\n border-top: none;\n }\n\n a {\n color: black;\n background: white;\n border-top: 1px solid var(--spw-color-themes-grey-grey-900);\n .spw-search-field--is-rounded & {\n color: var(--spw-ds-primary);\n padding: 12px 24px 24px 24px;\n border-top: none;\n }\n text-decoration: underline;\n display: block;\n width: 100%;\n padding: 12px;\n display: inline-flex;\n justify-content: space-between;\n\n &:hover {\n text-decoration: none;\n }\n }\n}\n","import { Component, Prop, State, Event, EventEmitter, Method, h, Watch, Element } 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 @Element() el: HTMLElement;\n private hostElement: HTMLElement;\n private hiddenInput: HTMLInputElement;\n\n /** Événement émis lorsque la valeur du champ de recherche change */\n @Event() valueChanged: EventEmitter<string>;\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 /** Taille du champ de recherche */\n @Prop() size?: 'large' | 'medium' = 'medium';\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 /** Indique si le champ de recherche est arrondi ou pas (communément utilisé dans un hero banner) */\n @Prop() isRounded?: 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 /** Texte du lien pour voir tous les résultats */\n @Prop() viewAllResults?: string = 'Voir plus de résultats';\n /** URL vers laquelle renvoie le lien \"voir tous les résultats\" */\n @Prop() viewAllResultsLink?: string;\n /** Texte à afficher si pas de résultats */\n @Prop() noResults?: string = 'Pas de résultats.';\n /** Affiche un bouton submit (loupe) qui déclenche le submit du formulaire parent */\n @Prop() hasSubmitButton?: boolean = false;\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 this.createHiddenInput();\n }\n\n disconnectedCallback() {\n document.removeEventListener('click', this.handleClickOutside);\n if (this.hiddenInput && this.hiddenInput.parentNode) {\n this.hiddenInput.parentNode.removeChild(this.hiddenInput);\n }\n }\n\n private createHiddenInput() {\n if (this.name) {\n this.hiddenInput = document.createElement('input');\n this.hiddenInput.type = 'hidden';\n this.hiddenInput.name = this.name;\n this.hiddenInput.value = this.searchText;\n this.el.appendChild(this.hiddenInput);\n }\n }\n\n private updateHiddenInput() {\n if (this.hiddenInput) {\n this.hiddenInput.value = this.searchText;\n }\n }\n\n /** Réinitialise le champ de recherche */\n @Method()\n async resetInput() {\n this.searchText = '';\n this.updateHiddenInput();\n this.isOpen = false;\n this.focusedItemIndex = null;\n this.valueChanged.emit(this.searchText);\n }\n\n /** Définit la valeur du champ de recherche */\n @Method()\n async setValue(value: string) {\n this.searchText = value;\n this.updateHiddenInput();\n this.filterItems();\n this.valueChanged.emit(this.searchText);\n }\n\n /** Récupère la valeur actuelle du champ de recherche */\n @Method()\n async getValue(): Promise<string> {\n return this.searchText;\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 handleValueChanged = (event: CustomEvent<string | number>) => {\n const newValue = String(event.detail);\n this.searchText = newValue;\n this.updateHiddenInput();\n this.filterItems();\n this.determineDropdownDirection();\n\n if (!this.searchText) {\n this.isOpen = false;\n } else {\n this.isOpen = true;\n }\n\n this.valueChanged.emit(this.searchText);\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.updateHiddenInput();\n this.isOpen = false;\n this.valueChanged.emit(this.searchText);\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 private handleSubmit = (event: Event) => {\n event.preventDefault();\n\n this.updateHiddenInput();\n\n const form = this.el.closest('form');\n if (form) {\n form.submit();\n }\n };\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-search-field': true,\n 'spw-search-field--is-rounded': this.isRounded,\n 'spw-search-field--has-submit-button': this.hasSubmitButton,\n [`spw-search-field--${this.size}`]: true,\n };\n }\n\n render() {\n return (\n <div ref={el => (this.hostElement = el as HTMLElement)} class={this.elementClass}>\n <spw-text-field\n placeholder={this.placeholder}\n name={this.name}\n label={this.label}\n size={this.size}\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 onValueChanged={this.handleValueChanged}\n onKeyDown={event => this.handleKeyDown(event)}\n ></spw-text-field>\n {this.hasSubmitButton && <button type=\"button\" class=\"spw-search-field__submit\" onClick={this.handleSubmit} aria-label=\"Rechercher\"></button>}\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\">{this.noResults}</p>}\n {!!this.filteredItems.length && this.viewAllResults && this.viewAllResultsLink && (\n <p class=\"spw-search-field__view-all\">\n <a href={this.viewAllResultsLink}>\n {this.viewAllResults} <spw-icon icon=\"fa-arrow-right\"></spw-icon>\n </a>\n </p>\n )}\n </div>\n )}\n </div>\n );\n }\n}\n"],"version":3}
@@ -1 +1 @@
1
- {"version":3,"file":"spw-search-field.entry.cjs.js","sources":["src/components/spw-search-field/spw-search-field.scss?tag=spw-search-field&encapsulation=shadow","src/components/spw-search-field/spw-search-field.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.spw-search-field {\n position: relative;\n &--large {\n spw-text-field {\n --spw-input-height: 54px;\n --spw-input-padding: 16px 24px;\n --spw-input-radius: 60px;\n --spw-input-border: transparent;\n --spw-input-icon-search-color: var(--spw-ds-primary);\n }\n }\n}\n\n.spw-search-field__options {\n position: absolute;\n width: 100%;\n background-color: #fff;\n border: 1px solid var(--spw-color-themes-grey-grey-800);\n border-radius: 0 0 4px 4px;\n max-height: 200px;\n overflow-y: auto;\n z-index: 44;\n margin-top: -2px;\n transition:\n transform 0.3s ease,\n opacity 0.3s ease;\n}\n\n.spw-search-field__options--down {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__options--up {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__option {\n padding: 12px;\n color: var(--spw-color-themes-grey-grey-900);\n text-align: left;\n border-bottom: 1px solid var(--spw-color-themes-grey-grey-900);\n cursor: pointer;\n transition: background-color 0.2s ease;\n\n &:hover {\n background-color: var(--spw-color-themes-grey-grey-200);\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n &--focused {\n background-color: var(--spw-color-themes-grey-grey-300);\n }\n\n &--selected {\n font-weight: 700;\n }\n}\n\n.spw-search-field__no-results {\n padding: 12px;\n cursor: not-allowed;\n text-align: left;\n color: var(--spw-color-themes-grey-grey-600);\n}\n","import { Component, Prop, State, Event, EventEmitter, Method, 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 /** Événement émis lorsque la valeur du champ de recherche change */\n @Event() valueChanged: EventEmitter<string>;\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 /** Taille du champ de recherche */\n @Prop() size?: 'large' | 'medium' = 'medium';\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 /** Réinitialise le champ de recherche */\n @Method()\n async resetInput() {\n this.searchText = '';\n this.isOpen = false;\n this.focusedItemIndex = null;\n this.valueChanged.emit(this.searchText);\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 this.valueChanged.emit(this.searchText);\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 this.valueChanged.emit(this.searchText);\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 private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-search-field': true,\n [`spw-search-field--${this.size}`]: true,\n };\n }\n\n render() {\n return (\n <div ref={el => (this.hostElement = el as HTMLElement)} class={this.elementClass}>\n <spw-text-field\n placeholder={this.placeholder}\n name={this.name}\n label={this.label}\n size={this.size}\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"],"names":["h","index"],"mappings":"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"}
1
+ {"version":3,"file":"spw-search-field.entry.cjs.js","sources":["src/components/spw-search-field/spw-search-field.scss?tag=spw-search-field&encapsulation=shadow","src/components/spw-search-field/spw-search-field.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.spw-search-field {\n position: relative;\n &--large {\n spw-text-field {\n --spw-input-height: 54px;\n --spw-input-padding: 16px 24px;\n --spw-input-radius: 60px;\n --spw-input-border: transparent;\n --spw-input-icon-search-color: var(--spw-ds-primary);\n }\n }\n\n &--has-submit-button {\n spw-text-field {\n --spw-input-padding-right: 56px;\n }\n }\n}\n\n.spw-search-field__submit {\n position: absolute;\n right: 0;\n top: 50%;\n transform: translateY(-50%);\n width: 40px;\n height: 40px;\n border: none;\n border-radius: 50%;\n background: transparent;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n transition: all 0.2s ease;\n z-index: 10;\n\n .spw-search-field--large & {\n width: 46px;\n height: 46px;\n right: 16px;\n }\n}\n\n.spw-search-field__options {\n position: absolute;\n width: 100%;\n background-color: #fff;\n border: 1px solid var(--spw-color-themes-grey-grey-800);\n border-radius: 0 0 4px 4px;\n max-height: 200px;\n overflow-y: auto;\n z-index: 44;\n margin-top: -2px;\n transition:\n transform 0.3s ease,\n opacity 0.3s ease;\n .spw-search-field--is-rounded & {\n border-radius: 24px;\n margin-top: 12px;\n ul {\n padding: 12px;\n }\n }\n}\n\n.spw-search-field__options--down {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__options--up {\n top: 100%;\n transform: translateY(0);\n}\n\n.spw-search-field__option {\n padding: 12px;\n color: var(--spw-color-themes-grey-grey-900);\n text-align: left;\n border-bottom: 1px solid var(--spw-color-themes-grey-grey-900);\n cursor: pointer;\n transition: background-color 0.2s ease;\n\n .spw-search-field--is-rounded & {\n border-radius: 12px;\n padding: 12px;\n border-bottom: none;\n }\n\n &:hover {\n background-color: var(--spw-color-themes-grey-grey-200);\n }\n\n &:last-child {\n border-bottom: none;\n }\n\n &--focused {\n background-color: var(--spw-color-themes-grey-grey-300);\n }\n\n &--selected {\n font-weight: 700;\n }\n}\n\n.spw-search-field__no-results {\n padding: 12px;\n cursor: not-allowed;\n text-align: left;\n color: var(--spw-color-themes-grey-grey-600);\n .spw-search-field--is-rounded & {\n padding: 24px;\n }\n}\n\n.spw-search-field__view-all {\n position: sticky;\n bottom: 0;\n cursor: pointer;\n font-weight: 700;\n\n .spw-search-field--is-rounded & {\n border-radius: 12px;\n border-top: none;\n }\n\n a {\n color: black;\n background: white;\n border-top: 1px solid var(--spw-color-themes-grey-grey-900);\n .spw-search-field--is-rounded & {\n color: var(--spw-ds-primary);\n padding: 12px 24px 24px 24px;\n border-top: none;\n }\n text-decoration: underline;\n display: block;\n width: 100%;\n padding: 12px;\n display: inline-flex;\n justify-content: space-between;\n\n &:hover {\n text-decoration: none;\n }\n }\n}\n","import { Component, Prop, State, Event, EventEmitter, Method, h, Watch, Element } 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 @Element() el: HTMLElement;\n private hostElement: HTMLElement;\n private hiddenInput: HTMLInputElement;\n\n /** Événement émis lorsque la valeur du champ de recherche change */\n @Event() valueChanged: EventEmitter<string>;\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 /** Taille du champ de recherche */\n @Prop() size?: 'large' | 'medium' = 'medium';\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 /** Indique si le champ de recherche est arrondi ou pas (communément utilisé dans un hero banner) */\n @Prop() isRounded?: 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 /** Texte du lien pour voir tous les résultats */\n @Prop() viewAllResults?: string = 'Voir plus de résultats';\n /** URL vers laquelle renvoie le lien \"voir tous les résultats\" */\n @Prop() viewAllResultsLink?: string;\n /** Texte à afficher si pas de résultats */\n @Prop() noResults?: string = 'Pas de résultats.';\n /** Affiche un bouton submit (loupe) qui déclenche le submit du formulaire parent */\n @Prop() hasSubmitButton?: boolean = false;\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 this.createHiddenInput();\n }\n\n disconnectedCallback() {\n document.removeEventListener('click', this.handleClickOutside);\n if (this.hiddenInput && this.hiddenInput.parentNode) {\n this.hiddenInput.parentNode.removeChild(this.hiddenInput);\n }\n }\n\n private createHiddenInput() {\n if (this.name) {\n this.hiddenInput = document.createElement('input');\n this.hiddenInput.type = 'hidden';\n this.hiddenInput.name = this.name;\n this.hiddenInput.value = this.searchText;\n this.el.appendChild(this.hiddenInput);\n }\n }\n\n private updateHiddenInput() {\n if (this.hiddenInput) {\n this.hiddenInput.value = this.searchText;\n }\n }\n\n /** Réinitialise le champ de recherche */\n @Method()\n async resetInput() {\n this.searchText = '';\n this.updateHiddenInput();\n this.isOpen = false;\n this.focusedItemIndex = null;\n this.valueChanged.emit(this.searchText);\n }\n\n /** Définit la valeur du champ de recherche */\n @Method()\n async setValue(value: string) {\n this.searchText = value;\n this.updateHiddenInput();\n this.filterItems();\n this.valueChanged.emit(this.searchText);\n }\n\n /** Récupère la valeur actuelle du champ de recherche */\n @Method()\n async getValue(): Promise<string> {\n return this.searchText;\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 handleValueChanged = (event: CustomEvent<string | number>) => {\n const newValue = String(event.detail);\n this.searchText = newValue;\n this.updateHiddenInput();\n this.filterItems();\n this.determineDropdownDirection();\n\n if (!this.searchText) {\n this.isOpen = false;\n } else {\n this.isOpen = true;\n }\n\n this.valueChanged.emit(this.searchText);\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.updateHiddenInput();\n this.isOpen = false;\n this.valueChanged.emit(this.searchText);\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 private handleSubmit = (event: Event) => {\n event.preventDefault();\n\n this.updateHiddenInput();\n\n const form = this.el.closest('form');\n if (form) {\n form.submit();\n }\n };\n\n private get elementClass(): { [className: string]: boolean } {\n return {\n 'spw-search-field': true,\n 'spw-search-field--is-rounded': this.isRounded,\n 'spw-search-field--has-submit-button': this.hasSubmitButton,\n [`spw-search-field--${this.size}`]: true,\n };\n }\n\n render() {\n return (\n <div ref={el => (this.hostElement = el as HTMLElement)} class={this.elementClass}>\n <spw-text-field\n placeholder={this.placeholder}\n name={this.name}\n label={this.label}\n size={this.size}\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 onValueChanged={this.handleValueChanged}\n onKeyDown={event => this.handleKeyDown(event)}\n ></spw-text-field>\n {this.hasSubmitButton && <button type=\"button\" class=\"spw-search-field__submit\" onClick={this.handleSubmit} aria-label=\"Rechercher\"></button>}\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\">{this.noResults}</p>}\n {!!this.filteredItems.length && this.viewAllResults && this.viewAllResultsLink && (\n <p class=\"spw-search-field__view-all\">\n <a href={this.viewAllResultsLink}>\n {this.viewAllResults} <spw-icon icon=\"fa-arrow-right\"></spw-icon>\n </a>\n </p>\n )}\n </div>\n )}\n </div>\n );\n }\n}\n"],"names":["h","index"],"mappings":"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"}
@@ -17,7 +17,7 @@ const SpwSidebarNavigationDropdown = class {
17
17
  };
18
18
  }
19
19
  render() {
20
- return (index.h(index.Host, { key: '02e55fcb6e035e1c2c89c378f6c12e5142b93456', class: this.classes }, index.h("div", { key: '6938fe3452c3d5b0f7076648d8df01520aad9a04', class: "spw-sidebar-navigation-dropdown__content", style: { display: this.open ? 'block' : 'none' } }, index.h("slot", { key: '925365f2fb7cec831414a24a45cf292d4080d452' }))));
20
+ return (index.h(index.Host, { key: '75bbcafbc7cd6f25836cf9055e9d3aa55a09e349', class: this.classes }, index.h("div", { key: '0a7ac6f071a601cd8b51e88f605ebb442586c684', class: "spw-sidebar-navigation-dropdown__content", style: { display: this.open ? 'block' : 'none' } }, index.h("slot", { key: 'aca20597e121a92626cd644967895ea4e8eb3bc4' }))));
21
21
  }
22
22
  };
23
23
  SpwSidebarNavigationDropdown.style = spwSidebarNavigationDropdownCss;
@@ -175,14 +175,14 @@ const SpwSidebarNavigationItem = class {
175
175
  }
176
176
  render() {
177
177
  const Tag = this.href && !this.disabled && !this.openOnClick ? 'a' : 'div';
178
- const iconContent = index.h("spw-icon", { key: '551dd344206c2a0a747505c215bbdcb8630e70af', variant: this.iconVariant, icon: this.icon });
179
- const iconDiv = (index.h("div", { key: '033a5245bad2cb52ac940e798e2ac50696134c90', class: "spw-sidebar-navigation-item__icon" }, this.bubble && index.h("span", { key: '00b15c2081a53f8175390da5c15d5fd015497698', class: "spw-sidebar-navigation-item__bubble" }, this.bubble), iconContent));
178
+ const iconContent = index.h("spw-icon", { key: 'ba50a62e37fab6538d131f631f367b1b4b7e05fd', variant: this.iconVariant, icon: this.icon });
179
+ const iconDiv = (index.h("div", { key: 'c8277652cfe11466a70d0c4913e2165f91aafdb9', class: "spw-sidebar-navigation-item__icon" }, this.bubble && index.h("span", { key: 'a7a59273be4832fca25e44cae2e13cf17e3fd21b', class: "spw-sidebar-navigation-item__bubble" }, this.bubble), iconContent));
180
180
  const iconWithBubble = this.tooltipTitle ? (index.h("spw-tooltip", { cursor: this.disabled ? 'disabled' : 'pointer', "tooltip-title": this.tooltipTitle, direction: "right", visible: !this.navExpanded }, iconDiv)) : (iconDiv);
181
181
  const toggleClasses = {
182
182
  'spw-sidebar-navigation-item__dropdown-toggle': true,
183
183
  'spw-sidebar-navigation-item__dropdown-toggle--open': this.dropdownOpen,
184
184
  };
185
- return (index.h(Tag, { key: 'b67e6b8a6918b209fd5f589bc63c2ea141c23ecd', class: this.classes, href: this.openOnClick ? undefined : this.href, "aria-disabled": this.disabled ? 'true' : undefined, tabIndex: this.disabled ? -1 : 0, onClick: this.openOnClick ? this.handleItemClick : undefined }, this.icon && iconWithBubble, index.h("div", { key: '321ea3fb1f0142f08eb8e9181e946b40603df3b7', class: "spw-sidebar-navigation-item__content" }, index.h("div", { key: '5aa95a61305bfe337cfdae0e7709a1f4a7280e94', class: "spw-sidebar-navigation-item__content-label" }, index.h("slot", { key: 'a73d04cbda3c6dbdfec620dacd6a9e93080f8892' })), this.hasDropdown && (index.h("div", { key: 'b8ea2990ace408c4896bf9c494b7083cd5fcd6f3', class: toggleClasses, onClick: this.handleDropdownToggle, tabIndex: this.disabled ? -1 : 0 }, index.h("spw-icon", { key: '94d525e89c6a052311a493419404c2d5a3f3e2c5', icon: "fa-chevron-down" }))), index.h("slot", { key: 'd418e150102a23a27e3e473888ecbe832a9f4f78', name: "dropdown" }))));
185
+ return (index.h(Tag, { key: '18f2239e3f5d1e6aad8b5f1f6bf84661da99451f', class: this.classes, href: this.openOnClick ? undefined : this.href, "aria-disabled": this.disabled ? 'true' : undefined, tabIndex: this.disabled ? -1 : 0, onClick: this.openOnClick ? this.handleItemClick : undefined }, this.icon && iconWithBubble, index.h("div", { key: '275bd07ba59e2ae162f35eb1bcf6d293421fb973', class: "spw-sidebar-navigation-item__content" }, index.h("div", { key: '2c5e449eada05bcc53b28507c4179d06a8f682fa', class: "spw-sidebar-navigation-item__content-label" }, index.h("slot", { key: '6f1c226293c0d634f65f58c580edd1cc299b5e63' })), this.hasDropdown && (index.h("div", { key: '17cf51a4a2f6c360d2da0b1b8b4c18ce9ebab090', class: toggleClasses, onClick: this.handleDropdownToggle, tabIndex: this.disabled ? -1 : 0 }, index.h("spw-icon", { key: 'a609d938758000563523770616f23d3833b1155a', icon: "fa-chevron-down" }))), index.h("slot", { key: '2bc0029ee6fb2f46b0e64f6b738a1c1acfe215de', name: "dropdown" }))));
186
186
  }
187
187
  get el() { return index.getElement(this); }
188
188
  };
@@ -9,7 +9,7 @@ const SpwSidebarNavigationSeparator = class {
9
9
  index.registerInstance(this, hostRef);
10
10
  }
11
11
  render() {
12
- return (index.h(index.Host, { key: '93da5418115a91bd8a45a0b8de207d4d91a9c706' }, index.h("spw-separator", { key: '7c5cc350ddaf479ed0af22be5f2014b4183c98f2', class: "spw-sidebar-navigation-separator" })));
12
+ return (index.h(index.Host, { key: 'e5c8dfac230556b68d89ce549ccd938d3cdf8b52' }, index.h("spw-separator", { key: '7589540cc55775aee77ae9abad8464b420104cd3', class: "spw-sidebar-navigation-separator" })));
13
13
  }
14
14
  };
15
15
  SpwSidebarNavigationSeparator.style = spwSidebarNavigationSeparatorCss;
@@ -64,7 +64,7 @@ const SpwSidebar = class {
64
64
  };
65
65
  }
66
66
  render() {
67
- return (index.h(index.Host, { key: 'ddffbd455cbc2710867a69ee8b7591b2f73b6599', class: this.hostClass }, index.h("div", { key: 'ee150c9244aa861c978c5008efd28c04b8e8c868', class: this.elementClass }, index.h("span", { key: '873736c218af40bb9a3c2aadb5891420d8b8f674', class: "spw-sidebar__toggle", onClick: this.toggleSidebar, "aria-expanded": this.expanded.toString() }, index.h("spw-icon", { key: '6c47d4c931c5e1932b06824e2809e77147229eb0', icon: "fa-chevron-right" })), index.h("div", { key: 'c2894503c4ab71bc570209c9fac1963e13b3ca06', class: "spw-sidebar__content" }, index.h("slot", { key: 'fb3d4146487654157da34e715c382194dcb4dc5c', name: "navigation-top" }), index.h("slot", { key: 'bcd036895810de895cfe78e654a3bb584f9d0480', name: "navigation-bottom" })), index.h("div", { key: 'b0ffe9b397e6a9535acbabd319fc8a37eabeef54', class: "spw-sidebar__resize-border", onClick: this.toggleSidebar }))));
67
+ return (index.h(index.Host, { key: 'e44c02dbf98f9b8e75cae4585b3536a19c623653', class: this.hostClass }, index.h("div", { key: '09542748f222ad44385bcfdca6db051602679134', class: this.elementClass }, index.h("span", { key: 'd99a52c3451d963d9319941315333c719514415f', class: "spw-sidebar__toggle", onClick: this.toggleSidebar, "aria-expanded": this.expanded.toString() }, index.h("spw-icon", { key: '7fa47c34ae17225ba5937fd166e360968a2697b2', icon: "fa-chevron-right" })), index.h("div", { key: '7f8d3bd7b53a2a1cde0dba3c7f5fa1597d05d5b8', class: "spw-sidebar__content" }, index.h("slot", { key: 'ef20255ed1389b00f10e4abc8d2ac5558194c625', name: "navigation-top" }), index.h("slot", { key: '07087b883297deade379d672e4a13223241b94b2', name: "navigation-bottom" })), index.h("div", { key: 'f0dda2faa61465601fd568d0339cc603ad652340', class: "spw-sidebar__resize-border", onClick: this.toggleSidebar }))));
68
68
  }
69
69
  get el() { return index.getElement(this); }
70
70
  };
@@ -50,7 +50,7 @@ const SpwSkeleton = class {
50
50
  }
51
51
  }
52
52
  render() {
53
- return (index.h(index.Host, { key: 'e7062026d9545a347b6fbcf89d1d34f703e0c283' }, index.h("div", { key: '1d663e0cd802f50a72186239fcade5e6a808ac76', class: "spw-skeleton" }, this.renderVariant(), index.h("slot", { key: '8cbd37e477730c2dd41acba2ac56ec66522379eb' }))));
53
+ return (index.h(index.Host, { key: '84bb1db4447ad88e67e12a0db999955ea282479a' }, index.h("div", { key: 'fee62735ea0a995804172621cf0583a2c07f8e50', class: "spw-skeleton" }, this.renderVariant(), index.h("slot", { key: '1cd7227b66a6e791660e46aa2bf657cb2fbeec95' }))));
54
54
  }
55
55
  };
56
56
  SpwSkeleton.style = spwSkeletonCss;
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ var index = require('./index-ivINMH9O.js');
4
+
5
+ const spwSliderItemCss = "/*! 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%;left:0;line-height:1.3;position:absolute;top:0;width:100%}:host *,:host :after,:host :before{box-sizing:inherit;font-family:Nunito Sans}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}:root{--spw-ds-container-xl:1200px;--spw-ds-container-lg:1024px;--spw-ds-container-md:768px;--spw-ds-container-sm:640px}.spw-ds-container{margin-left:auto;margin-right:auto;padding-left:16px;padding-right:16px;width:100%}@media (min-width:460px){.spw-ds-container{max-width:var(--spw-ds-container-sm)}}@media (min-width:768px){.spw-ds-container{max-width:var(--spw-ds-container-md)}}@media (min-width:1024px){.spw-ds-container{max-width:var(--spw-ds-container-lg)}}@media (min-width:1350px){.spw-ds-container{max-width:var(--spw-ds-container-xl)}}.spw-slider-item{display:block;width:100%}";
6
+
7
+ const SpwSliderItem = class {
8
+ constructor(hostRef) {
9
+ index.registerInstance(this, hostRef);
10
+ }
11
+ render() {
12
+ return (index.h(index.Host, { key: 'f57cd993f37c73d67d7bb76314698342f9eeb85f' }, index.h("div", { key: 'ce03289164dd0e3f94119e6e3ace34a07505f684', class: "spw-slider-item" }, index.h("slot", { key: 'b3d727e9a0f316eb9200ccf357e88390caa11151' }))));
13
+ }
14
+ };
15
+ SpwSliderItem.style = spwSliderItemCss;
16
+
17
+ exports.spw_slider_item = SpwSliderItem;
18
+ //# sourceMappingURL=spw-slider-item.entry.cjs.js.map
19
+
20
+ //# sourceMappingURL=spw-slider-item.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"spw-slider-item.entry.cjs.js","mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,gqFAAgqF;;MCO5qF,aAAa,GAAA,MAAA;;;;IACxB,MAAM,GAAA;AACJ,QAAA,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,iBAAiB,EAAA,EAC1BA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;","names":["h","Host"],"sources":["src/components/spw-slider/spw-slider-item/spw-slider-item.scss?tag=spw-slider-item&encapsulation=shadow","src/components/spw-slider/spw-slider-item/spw-slider-item.tsx"],"sourcesContent":[":host {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n display: block;\n}\n\n.spw-slider-item {\n width: 100%;\n display: block;\n}\n","import { Component, Host, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-slider-item',\n styleUrl: 'spw-slider-item.scss',\n shadow: true,\n})\nexport class SpwSliderItem {\n render() {\n return (\n <Host>\n <div class=\"spw-slider-item\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spw-slider-item.entry.cjs.js","sources":["src/components/spw-slider/spw-slider-item/spw-slider-item.scss?tag=spw-slider-item&encapsulation=shadow","src/components/spw-slider/spw-slider-item/spw-slider-item.tsx"],"sourcesContent":[":host {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n display: block;\n}\n\n.spw-slider-item {\n width: 100%;\n display: block;\n}\n","import { Component, Host, h } from '@stencil/core';\n\n@Component({\n tag: 'spw-slider-item',\n styleUrl: 'spw-slider-item.scss',\n shadow: true,\n})\nexport class SpwSliderItem {\n render() {\n return (\n <Host>\n <div class=\"spw-slider-item\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"],"names":["h","Host"],"mappings":";;;;AAAA,MAAM,gBAAgB,GAAG,gqFAAgqF;;MCO5qF,aAAa,GAAA,MAAA;;;;IACxB,MAAM,GAAA;AACJ,QAAA,QACEA,QAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACHD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,iBAAiB,EAAA,EAC1BA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACT,CACD;;;;;;;"}