@pine-ds/core 3.6.0 → 3.7.0

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 (612) hide show
  1. package/components/index.d.ts +4 -0
  2. package/components/index.js +2 -0
  3. package/components/index.js.map +1 -1
  4. package/components/index2.js +3 -1
  5. package/components/index2.js.map +1 -1
  6. package/components/mock-pds-modal.js +1 -1
  7. package/components/pds-avatar.js +1 -1
  8. package/components/pds-button2.js +7 -4
  9. package/components/pds-button2.js.map +1 -1
  10. package/components/pds-checkbox2.js +1 -1
  11. package/components/pds-combobox.js +349 -39
  12. package/components/pds-combobox.js.map +1 -1
  13. package/components/pds-copytext.js +1 -1
  14. package/components/pds-dropdown-menu-separator.js +1 -1
  15. package/components/pds-dropdown-menu-separator.js.map +1 -1
  16. package/components/pds-filter.d.ts +11 -0
  17. package/components/pds-filter.js +518 -0
  18. package/components/pds-filter.js.map +1 -0
  19. package/components/pds-filters.d.ts +11 -0
  20. package/components/pds-filters.js +38 -0
  21. package/components/pds-filters.js.map +1 -0
  22. package/components/pds-image.js +2 -2
  23. package/components/pds-input.js +2 -2
  24. package/components/pds-link2.js +2 -2
  25. package/components/pds-loader2.js +1 -1
  26. package/components/pds-modal-content.js +2 -2
  27. package/components/pds-modal-footer.js +1 -1
  28. package/components/pds-modal-header.js +1 -1
  29. package/components/pds-modal.js +3 -3
  30. package/components/pds-popover.js +1 -1
  31. package/components/pds-progress.js +1 -1
  32. package/components/pds-property.js +1 -1
  33. package/components/pds-radio.js +4 -4
  34. package/components/pds-row.js +1 -1
  35. package/components/pds-select.js +2 -2
  36. package/components/pds-sortable-item.js +1 -1
  37. package/components/pds-sortable.js +1 -1
  38. package/components/pds-switch.js +4 -4
  39. package/components/pds-tab.js +4 -4
  40. package/components/pds-tab.js.map +1 -1
  41. package/components/pds-table-body.js +1 -1
  42. package/components/pds-table-cell2.js +2 -2
  43. package/components/pds-table-head-cell2.js +2 -2
  44. package/components/pds-table-head.js +1 -1
  45. package/components/pds-table-row.js +1 -1
  46. package/components/pds-tabpanel.js +1 -1
  47. package/components/pds-tabs.js +1 -1
  48. package/components/pds-tabs.js.map +1 -1
  49. package/components/pds-text2.js +1 -1
  50. package/components/pds-textarea.js +5 -5
  51. package/components/pds-toast.js +3 -3
  52. package/components/pds-tooltip.js +2 -2
  53. package/dist/cjs/{index-DVaLegMK.js → index-CTirFLR-.js} +6 -2
  54. package/dist/cjs/{index-DVaLegMK.js.map → index-CTirFLR-.js.map} +1 -1
  55. package/dist/cjs/{index-g-uSeICs.js → index-DDTyvZD7.js} +5 -2
  56. package/dist/cjs/index-DDTyvZD7.js.map +1 -0
  57. package/dist/cjs/index.cjs.js +1 -1
  58. package/dist/cjs/loader.cjs.js +2 -2
  59. package/dist/cjs/mock-pds-modal.cjs.entry.js +2 -2
  60. package/dist/cjs/pds-accordion.cjs.entry.js +2 -2
  61. package/dist/cjs/pds-alert.cjs.entry.js +1 -1
  62. package/dist/cjs/pds-avatar.cjs.entry.js +2 -2
  63. package/dist/cjs/pds-box.cjs.entry.js +1 -1
  64. package/dist/cjs/pds-button.cjs.entry.js +8 -5
  65. package/dist/cjs/pds-button.cjs.entry.js.map +1 -1
  66. package/dist/cjs/pds-button.entry.cjs.js.map +1 -1
  67. package/dist/cjs/pds-checkbox.cjs.entry.js +2 -2
  68. package/dist/cjs/pds-chip.cjs.entry.js +2 -2
  69. package/dist/cjs/pds-combobox.cjs.entry.js +349 -39
  70. package/dist/cjs/pds-combobox.cjs.entry.js.map +1 -1
  71. package/dist/cjs/pds-combobox.entry.cjs.js.map +1 -1
  72. package/dist/cjs/pds-copytext.cjs.entry.js +2 -2
  73. package/dist/cjs/pds-divider.cjs.entry.js +1 -1
  74. package/dist/cjs/pds-dropdown-menu-item.cjs.entry.js +1 -1
  75. package/dist/cjs/pds-dropdown-menu-separator.cjs.entry.js +2 -2
  76. package/dist/cjs/pds-dropdown-menu-separator.cjs.entry.js.map +1 -1
  77. package/dist/cjs/pds-dropdown-menu-separator.entry.cjs.js.map +1 -1
  78. package/dist/cjs/pds-dropdown-menu.cjs.entry.js +1 -1
  79. package/dist/cjs/pds-filter.cjs.entry.js +488 -0
  80. package/dist/cjs/pds-filter.cjs.entry.js.map +1 -0
  81. package/dist/cjs/pds-filter.entry.cjs.js.map +1 -0
  82. package/dist/cjs/pds-filters.cjs.entry.js +20 -0
  83. package/dist/cjs/pds-filters.cjs.entry.js.map +1 -0
  84. package/dist/cjs/pds-filters.entry.cjs.js.map +1 -0
  85. package/dist/cjs/pds-icon.cjs.entry.js +1 -1
  86. package/dist/cjs/pds-image.cjs.entry.js +3 -3
  87. package/dist/cjs/pds-input.cjs.entry.js +3 -3
  88. package/dist/cjs/pds-link.cjs.entry.js +4 -4
  89. package/dist/cjs/pds-loader.cjs.entry.js +2 -2
  90. package/dist/cjs/pds-modal-content.cjs.entry.js +3 -3
  91. package/dist/cjs/pds-modal-footer.cjs.entry.js +2 -2
  92. package/dist/cjs/pds-modal-header.cjs.entry.js +2 -2
  93. package/dist/cjs/pds-modal.cjs.entry.js +4 -4
  94. package/dist/cjs/pds-popover.cjs.entry.js +2 -2
  95. package/dist/cjs/pds-progress.cjs.entry.js +2 -2
  96. package/dist/cjs/pds-property.cjs.entry.js +2 -2
  97. package/dist/cjs/pds-radio.cjs.entry.js +5 -5
  98. package/dist/cjs/pds-row.cjs.entry.js +2 -2
  99. package/dist/cjs/pds-select.cjs.entry.js +3 -3
  100. package/dist/cjs/pds-sortable-item.cjs.entry.js +3 -3
  101. package/dist/cjs/pds-sortable.cjs.entry.js +2 -2
  102. package/dist/cjs/pds-switch.cjs.entry.js +5 -5
  103. package/dist/cjs/pds-tab.cjs.entry.js +5 -5
  104. package/dist/cjs/pds-tab.cjs.entry.js.map +1 -1
  105. package/dist/cjs/pds-tab.entry.cjs.js.map +1 -1
  106. package/dist/cjs/pds-table-body.cjs.entry.js +2 -2
  107. package/dist/cjs/pds-table-cell.cjs.entry.js +3 -3
  108. package/dist/cjs/pds-table-head-cell.cjs.entry.js +4 -4
  109. package/dist/cjs/pds-table-head.cjs.entry.js +2 -2
  110. package/dist/cjs/pds-table-row.cjs.entry.js +2 -2
  111. package/dist/cjs/pds-table.cjs.entry.js +1 -1
  112. package/dist/cjs/pds-tabpanel.cjs.entry.js +2 -2
  113. package/dist/cjs/pds-tabs.cjs.entry.js +2 -2
  114. package/dist/cjs/pds-tabs.cjs.entry.js.map +1 -1
  115. package/dist/cjs/pds-tabs.entry.cjs.js.map +1 -1
  116. package/dist/cjs/pds-text.cjs.entry.js +2 -2
  117. package/dist/cjs/pds-textarea.cjs.entry.js +6 -6
  118. package/dist/cjs/pds-toast.cjs.entry.js +4 -4
  119. package/dist/cjs/pds-tooltip.cjs.entry.js +3 -3
  120. package/dist/cjs/pine-core.cjs.js +2 -2
  121. package/dist/collection/collection-manifest.json +2 -0
  122. package/dist/collection/components/pds-button/pds-button.css +23 -0
  123. package/dist/collection/components/pds-button/pds-button.js +8 -5
  124. package/dist/collection/components/pds-button/pds-button.js.map +1 -1
  125. package/dist/collection/components/pds-button/stories/pds-button.stories.js +28 -1
  126. package/dist/collection/components/pds-combobox/pds-combobox.css +39 -1
  127. package/dist/collection/components/pds-combobox/pds-combobox.js +348 -38
  128. package/dist/collection/components/pds-combobox/pds-combobox.js.map +1 -1
  129. package/dist/collection/components/pds-combobox/stories/pds-combobox.stories.js +103 -0
  130. package/dist/collection/components/pds-dropdown-menu/pds-dropdown-menu-separator/pds-dropdown-menu-separator.css +4 -1
  131. package/dist/collection/components/pds-filters/pds-filter/filter-interface.js +2 -0
  132. package/dist/collection/components/pds-filters/pds-filter/filter-interface.js.map +1 -0
  133. package/dist/collection/components/pds-filters/pds-filter/pds-filter.css +193 -0
  134. package/dist/collection/components/pds-filters/pds-filter/pds-filter.js +732 -0
  135. package/dist/collection/components/pds-filters/pds-filter/pds-filter.js.map +1 -0
  136. package/dist/collection/components/pds-filters/pds-filter/stories/pds-filter.stories.js +93 -0
  137. package/dist/collection/components/pds-filters/pds-filters.css +10 -0
  138. package/dist/collection/components/pds-filters/pds-filters.js +45 -0
  139. package/dist/collection/components/pds-filters/pds-filters.js.map +1 -0
  140. package/dist/collection/components/pds-filters/stories/pds-filters.stories.js +40 -0
  141. package/dist/collection/components/pds-image/pds-image.js +2 -2
  142. package/dist/collection/components/pds-input/pds-input.js +1 -1
  143. package/dist/collection/components/pds-link/pds-link.js +2 -2
  144. package/dist/collection/components/pds-loader/pds-loader.js +1 -1
  145. package/dist/collection/components/pds-modal/pds-modal-content/pds-modal-content.js +2 -2
  146. package/dist/collection/components/pds-modal/pds-modal-footer/pds-modal-footer.js +1 -1
  147. package/dist/collection/components/pds-modal/pds-modal-header/pds-modal-header.js +1 -1
  148. package/dist/collection/components/pds-modal/pds-modal.js +3 -3
  149. package/dist/collection/components/pds-modal/test/mock-pds-modal.js +1 -1
  150. package/dist/collection/components/pds-popover/pds-popover.js +1 -1
  151. package/dist/collection/components/pds-progress/pds-progress.js +1 -1
  152. package/dist/collection/components/pds-property/pds-property.js +1 -1
  153. package/dist/collection/components/pds-radio/pds-radio.js +3 -3
  154. package/dist/collection/components/pds-row/pds-row.js +1 -1
  155. package/dist/collection/components/pds-select/pds-select.js +1 -1
  156. package/dist/collection/components/pds-sortable/pds-sortable-item/pds-sortable-item.js +1 -1
  157. package/dist/collection/components/pds-sortable/pds-sortable.js +1 -1
  158. package/dist/collection/components/pds-switch/pds-switch.js +3 -3
  159. package/dist/collection/components/pds-table/pds-table-body/pds-table-body.js +1 -1
  160. package/dist/collection/components/pds-table/pds-table-cell/pds-table-cell.js +2 -2
  161. package/dist/collection/components/pds-table/pds-table-head/pds-table-head.js +1 -1
  162. package/dist/collection/components/pds-table/pds-table-head-cell/pds-table-head-cell.js +2 -2
  163. package/dist/collection/components/pds-table/pds-table-row/pds-table-row.js +1 -1
  164. package/dist/collection/components/pds-tabs/pds-tab/pds-tab.css +3 -0
  165. package/dist/collection/components/pds-tabs/pds-tab/pds-tab.js +3 -3
  166. package/dist/collection/components/pds-tabs/pds-tabpanel/pds-tabpanel.js +1 -1
  167. package/dist/collection/components/pds-tabs/pds-tabs.js +2 -1
  168. package/dist/collection/components/pds-tabs/pds-tabs.js.map +1 -1
  169. package/dist/collection/components/pds-text/pds-text.js +1 -1
  170. package/dist/collection/components/pds-textarea/pds-textarea.js +4 -4
  171. package/dist/collection/components/pds-toast/pds-toast.js +3 -3
  172. package/dist/collection/components/pds-tooltip/pds-tooltip.js +2 -2
  173. package/dist/docs.json +422 -5
  174. package/dist/esm/{index-BVCWKPy3.js → index-Bf1dou5H.js} +5 -2
  175. package/dist/esm/index-Bf1dou5H.js.map +1 -0
  176. package/dist/esm/{index-DrJ5r5Pu.js → index-D4MkIUXU.js} +5 -3
  177. package/dist/{esm-es5/index-DrJ5r5Pu.js.map → esm/index-D4MkIUXU.js.map} +1 -1
  178. package/dist/esm/index.js +1 -1
  179. package/dist/esm/loader.js +3 -3
  180. package/dist/esm/mock-pds-modal.entry.js +2 -2
  181. package/dist/esm/pds-accordion.entry.js +2 -2
  182. package/dist/esm/pds-alert.entry.js +1 -1
  183. package/dist/esm/pds-avatar.entry.js +2 -2
  184. package/dist/esm/pds-box.entry.js +1 -1
  185. package/dist/esm/pds-button.entry.js +8 -5
  186. package/dist/esm/pds-button.entry.js.map +1 -1
  187. package/dist/esm/pds-checkbox.entry.js +2 -2
  188. package/dist/esm/pds-chip.entry.js +2 -2
  189. package/dist/esm/pds-combobox.entry.js +349 -39
  190. package/dist/esm/pds-combobox.entry.js.map +1 -1
  191. package/dist/esm/pds-copytext.entry.js +2 -2
  192. package/dist/esm/pds-divider.entry.js +1 -1
  193. package/dist/esm/pds-dropdown-menu-item.entry.js +1 -1
  194. package/dist/esm/pds-dropdown-menu-separator.entry.js +2 -2
  195. package/dist/esm/pds-dropdown-menu-separator.entry.js.map +1 -1
  196. package/dist/esm/pds-dropdown-menu.entry.js +1 -1
  197. package/dist/esm/pds-filter.entry.js +486 -0
  198. package/dist/esm/pds-filter.entry.js.map +1 -0
  199. package/dist/esm/pds-filters.entry.js +18 -0
  200. package/dist/esm/pds-filters.entry.js.map +1 -0
  201. package/dist/esm/pds-icon.entry.js +1 -1
  202. package/dist/esm/pds-image.entry.js +3 -3
  203. package/dist/esm/pds-input.entry.js +3 -3
  204. package/dist/esm/pds-link.entry.js +4 -4
  205. package/dist/esm/pds-loader.entry.js +2 -2
  206. package/dist/esm/pds-modal-content.entry.js +3 -3
  207. package/dist/esm/pds-modal-footer.entry.js +2 -2
  208. package/dist/esm/pds-modal-header.entry.js +2 -2
  209. package/dist/esm/pds-modal.entry.js +4 -4
  210. package/dist/esm/pds-popover.entry.js +2 -2
  211. package/dist/esm/pds-progress.entry.js +2 -2
  212. package/dist/esm/pds-property.entry.js +2 -2
  213. package/dist/esm/pds-radio.entry.js +5 -5
  214. package/dist/esm/pds-row.entry.js +2 -2
  215. package/dist/esm/pds-select.entry.js +3 -3
  216. package/dist/esm/pds-sortable-item.entry.js +3 -3
  217. package/dist/esm/pds-sortable.entry.js +2 -2
  218. package/dist/esm/pds-switch.entry.js +5 -5
  219. package/dist/esm/pds-tab.entry.js +5 -5
  220. package/dist/esm/pds-tab.entry.js.map +1 -1
  221. package/dist/esm/pds-table-body.entry.js +2 -2
  222. package/dist/esm/pds-table-cell.entry.js +3 -3
  223. package/dist/esm/pds-table-head-cell.entry.js +4 -4
  224. package/dist/esm/pds-table-head.entry.js +2 -2
  225. package/dist/esm/pds-table-row.entry.js +2 -2
  226. package/dist/esm/pds-table.entry.js +1 -1
  227. package/dist/esm/pds-tabpanel.entry.js +2 -2
  228. package/dist/esm/pds-tabs.entry.js +2 -2
  229. package/dist/esm/pds-tabs.entry.js.map +1 -1
  230. package/dist/esm/pds-text.entry.js +2 -2
  231. package/dist/esm/pds-textarea.entry.js +6 -6
  232. package/dist/esm/pds-toast.entry.js +4 -4
  233. package/dist/esm/pds-tooltip.entry.js +3 -3
  234. package/dist/esm/pine-core.js +3 -3
  235. package/dist/esm-es5/{index-BVCWKPy3.js → index-Bf1dou5H.js} +2 -2
  236. package/dist/esm-es5/index-Bf1dou5H.js.map +1 -0
  237. package/dist/esm-es5/index-D4MkIUXU.js +2 -0
  238. package/dist/{esm/index-DrJ5r5Pu.js.map → esm-es5/index-D4MkIUXU.js.map} +1 -1
  239. package/dist/esm-es5/index.js +1 -1
  240. package/dist/esm-es5/loader.js +1 -1
  241. package/dist/esm-es5/mock-pds-modal.entry.js +1 -1
  242. package/dist/esm-es5/pds-accordion.entry.js +1 -1
  243. package/dist/esm-es5/pds-alert.entry.js +1 -1
  244. package/dist/esm-es5/pds-avatar.entry.js +1 -1
  245. package/dist/esm-es5/pds-box.entry.js +1 -1
  246. package/dist/esm-es5/pds-button.entry.js +1 -1
  247. package/dist/esm-es5/pds-button.entry.js.map +1 -1
  248. package/dist/esm-es5/pds-checkbox.entry.js +1 -1
  249. package/dist/esm-es5/pds-chip.entry.js +1 -1
  250. package/dist/esm-es5/pds-combobox.entry.js +2 -2
  251. package/dist/esm-es5/pds-combobox.entry.js.map +1 -1
  252. package/dist/esm-es5/pds-copytext.entry.js +1 -1
  253. package/dist/esm-es5/pds-divider.entry.js +1 -1
  254. package/dist/esm-es5/pds-dropdown-menu-item.entry.js +1 -1
  255. package/dist/esm-es5/pds-dropdown-menu-separator.entry.js +1 -1
  256. package/dist/esm-es5/pds-dropdown-menu-separator.entry.js.map +1 -1
  257. package/dist/esm-es5/pds-dropdown-menu.entry.js +1 -1
  258. package/dist/esm-es5/pds-filter.entry.js +2 -0
  259. package/dist/esm-es5/pds-filter.entry.js.map +1 -0
  260. package/dist/esm-es5/pds-filters.entry.js +2 -0
  261. package/dist/esm-es5/pds-filters.entry.js.map +1 -0
  262. package/dist/esm-es5/pds-icon.entry.js +1 -1
  263. package/dist/esm-es5/pds-image.entry.js +1 -1
  264. package/dist/esm-es5/pds-input.entry.js +1 -1
  265. package/dist/esm-es5/pds-link.entry.js +1 -1
  266. package/dist/esm-es5/pds-loader.entry.js +1 -1
  267. package/dist/esm-es5/pds-modal-content.entry.js +1 -1
  268. package/dist/esm-es5/pds-modal-footer.entry.js +1 -1
  269. package/dist/esm-es5/pds-modal-header.entry.js +1 -1
  270. package/dist/esm-es5/pds-modal.entry.js +1 -1
  271. package/dist/esm-es5/pds-popover.entry.js +1 -1
  272. package/dist/esm-es5/pds-progress.entry.js +1 -1
  273. package/dist/esm-es5/pds-property.entry.js +1 -1
  274. package/dist/esm-es5/pds-radio.entry.js +1 -1
  275. package/dist/esm-es5/pds-row.entry.js +1 -1
  276. package/dist/esm-es5/pds-select.entry.js +1 -1
  277. package/dist/esm-es5/pds-sortable-item.entry.js +1 -1
  278. package/dist/esm-es5/pds-sortable.entry.js +2 -2
  279. package/dist/esm-es5/pds-switch.entry.js +1 -1
  280. package/dist/esm-es5/pds-tab.entry.js +1 -1
  281. package/dist/esm-es5/pds-tab.entry.js.map +1 -1
  282. package/dist/esm-es5/pds-table-body.entry.js +1 -1
  283. package/dist/esm-es5/pds-table-cell.entry.js +1 -1
  284. package/dist/esm-es5/pds-table-head-cell.entry.js +1 -1
  285. package/dist/esm-es5/pds-table-head.entry.js +1 -1
  286. package/dist/esm-es5/pds-table-row.entry.js +1 -1
  287. package/dist/esm-es5/pds-table.entry.js +1 -1
  288. package/dist/esm-es5/pds-tabpanel.entry.js +1 -1
  289. package/dist/esm-es5/pds-tabs.entry.js +1 -1
  290. package/dist/esm-es5/pds-tabs.entry.js.map +1 -1
  291. package/dist/esm-es5/pds-text.entry.js +1 -1
  292. package/dist/esm-es5/pds-textarea.entry.js +1 -1
  293. package/dist/esm-es5/pds-toast.entry.js +1 -1
  294. package/dist/esm-es5/pds-tooltip.entry.js +1 -1
  295. package/dist/esm-es5/pine-core.js +1 -1
  296. package/dist/pine-core/index.esm.js +1 -1
  297. package/dist/pine-core/{p-fd091234.system.entry.js → p-0075bbbe.system.entry.js} +2 -2
  298. package/dist/pine-core/p-07e129db.entry.js +2 -0
  299. package/dist/pine-core/{p-8999b63d.system.entry.js → p-0975b749.system.entry.js} +2 -2
  300. package/dist/pine-core/{p-4c81420c.entry.js → p-0befa8f0.entry.js} +2 -2
  301. package/dist/pine-core/p-0d18171c.system.entry.js +2 -0
  302. package/dist/pine-core/p-0d18171c.system.entry.js.map +1 -0
  303. package/dist/pine-core/{p-540cfd70.entry.js → p-1009009c.entry.js} +2 -2
  304. package/dist/pine-core/{p-8722865f.system.entry.js → p-1773aeac.system.entry.js} +2 -2
  305. package/dist/pine-core/{p-e2887e78.entry.js → p-1b9d4482.entry.js} +2 -2
  306. package/dist/pine-core/p-1c32ffb3.entry.js +2 -0
  307. package/dist/pine-core/p-1c32ffb3.entry.js.map +1 -0
  308. package/dist/pine-core/{p-8726c99d.system.entry.js → p-2597bc59.system.entry.js} +2 -2
  309. package/dist/pine-core/{p-5a709348.entry.js → p-25cb810d.entry.js} +2 -2
  310. package/dist/pine-core/{p-a1b51557.system.entry.js → p-25cf2860.system.entry.js} +2 -2
  311. package/dist/pine-core/{p-6f4a6d0b.entry.js → p-265372d3.entry.js} +2 -2
  312. package/dist/pine-core/p-29b2af94.entry.js +2 -0
  313. package/dist/pine-core/{p-44087d1c.entry.js.map → p-29b2af94.entry.js.map} +1 -1
  314. package/dist/pine-core/p-2b102034.system.entry.js +2 -0
  315. package/dist/pine-core/p-2b102034.system.entry.js.map +1 -0
  316. package/dist/pine-core/p-2b12bc55.system.entry.js +2 -0
  317. package/dist/pine-core/{p-297afc49.system.entry.js → p-2b452883.system.entry.js} +2 -2
  318. package/dist/pine-core/p-2efc646c.system.entry.js +2 -0
  319. package/dist/pine-core/{p-ecb9edf8.entry.js → p-2fb6f9d5.entry.js} +2 -2
  320. package/dist/pine-core/p-2fd7f74e.entry.js +2 -0
  321. package/dist/pine-core/{p-39488f2c.system.entry.js → p-302849cf.system.entry.js} +2 -2
  322. package/dist/pine-core/{p-51d83489.system.entry.js → p-307f415a.system.entry.js} +2 -2
  323. package/dist/pine-core/{p-651861ff.entry.js → p-30e8c3ea.entry.js} +2 -2
  324. package/dist/pine-core/p-30e8c3ea.entry.js.map +1 -0
  325. package/dist/pine-core/{p-318fd0cf.entry.js → p-31f6fcc1.entry.js} +2 -2
  326. package/dist/pine-core/p-378df5eb.system.entry.js +2 -0
  327. package/dist/pine-core/{p-e08f492a.entry.js → p-39648ce2.entry.js} +2 -2
  328. package/dist/pine-core/p-3b20aa93.system.entry.js +2 -0
  329. package/dist/pine-core/p-3b20aa93.system.entry.js.map +1 -0
  330. package/dist/pine-core/{p-50c9e865.entry.js → p-3e7933bf.entry.js} +2 -2
  331. package/dist/pine-core/{p-5f5b19f4.entry.js → p-41e2fe3a.entry.js} +2 -2
  332. package/dist/pine-core/p-449ebe39.system.entry.js +2 -0
  333. package/dist/pine-core/{p-023d8b71.system.entry.js → p-4534e8cc.system.entry.js} +2 -2
  334. package/dist/pine-core/{p-52d37cc1.entry.js → p-46820152.entry.js} +2 -2
  335. package/dist/pine-core/{p-ba187a35.entry.js → p-4b3a8cab.entry.js} +2 -2
  336. package/dist/pine-core/{p-da367b5e.system.entry.js → p-4c8bebd8.system.entry.js} +2 -2
  337. package/dist/pine-core/{p-503cab1f.entry.js → p-4dda1edf.entry.js} +2 -2
  338. package/dist/pine-core/p-4e55730d.entry.js +2 -0
  339. package/dist/pine-core/p-4e55730d.entry.js.map +1 -0
  340. package/dist/pine-core/{p-5e8badb9.entry.js → p-559b4ebc.entry.js} +2 -2
  341. package/dist/pine-core/{p-c13ef6a7.system.entry.js → p-55d06d0a.system.entry.js} +3 -3
  342. package/dist/pine-core/{p-25190921.entry.js → p-56f6f106.entry.js} +2 -2
  343. package/dist/pine-core/{p-075eecf9.entry.js → p-5ac7af9e.entry.js} +2 -2
  344. package/dist/pine-core/{p-6d4d4705.system.entry.js → p-5cc0244d.system.entry.js} +2 -2
  345. package/dist/pine-core/{p-dfc5ab34.system.entry.js → p-72d87dc6.system.entry.js} +2 -2
  346. package/dist/pine-core/{p-b2b1b7a9.system.entry.js → p-73a2e028.system.entry.js} +2 -2
  347. package/dist/pine-core/{p-4bbf3e31.entry.js → p-74f03e75.entry.js} +2 -2
  348. package/dist/pine-core/p-786967e8.entry.js +2 -0
  349. package/dist/pine-core/{p-0de9f8da.system.entry.js → p-7b0517e5.system.entry.js} +2 -2
  350. package/dist/pine-core/p-7b66bc50.entry.js +3 -0
  351. package/dist/pine-core/p-7b66bc50.entry.js.map +1 -0
  352. package/dist/pine-core/{p-41d1b164.entry.js → p-7eb22880.entry.js} +2 -2
  353. package/dist/pine-core/{p-464dd476.entry.js → p-8501429f.entry.js} +2 -2
  354. package/dist/pine-core/p-875d5d5a.system.entry.js +2 -0
  355. package/dist/pine-core/{p-4deb7b8c.entry.js → p-896e2f1b.entry.js} +2 -2
  356. package/dist/pine-core/{p-72b05928.system.entry.js → p-8ded79aa.system.entry.js} +2 -2
  357. package/dist/pine-core/{p-e89cb1f2.system.entry.js → p-8f69dd71.system.entry.js} +2 -2
  358. package/dist/pine-core/{p-2e19f167.system.entry.js → p-94fe15b0.system.entry.js} +2 -2
  359. package/dist/pine-core/p-95aee0b1.entry.js +2 -0
  360. package/dist/pine-core/p-95aee0b1.entry.js.map +1 -0
  361. package/dist/pine-core/p-96c27dba.entry.js +2 -0
  362. package/dist/pine-core/p-96c27dba.entry.js.map +1 -0
  363. package/dist/pine-core/p-B02VgXkx.system.js.map +1 -0
  364. package/dist/pine-core/{p-Kj_j7PHx.system.js.map → p-B57Bybw-.system.js.map} +1 -1
  365. package/dist/pine-core/{p-B1fiSdbt.system.js.map → p-BEgEi4w5.system.js.map} +1 -1
  366. package/dist/pine-core/{p-CJT--ZXC.system.js.map → p-BFiM1S8V.system.js.map} +1 -1
  367. package/dist/pine-core/{p-_E9ZEzfO.system.js.map → p-BIjeWHX_.system.js.map} +1 -1
  368. package/dist/pine-core/{p-BVKCNX0X.system.js.map → p-BJhtHwq5.system.js.map} +1 -1
  369. package/dist/pine-core/{p-EYhpJx2s.system.js.map → p-BJjdD3yf.system.js.map} +1 -1
  370. package/dist/pine-core/p-BPjnTOEL.system.js +2 -0
  371. package/dist/pine-core/{p-De9tROL-.system.js.map → p-BPjnTOEL.system.js.map} +1 -1
  372. package/dist/pine-core/{p-CCQUgOoR.system.js.map → p-BQFgzIQT.system.js.map} +1 -1
  373. package/dist/pine-core/p-BSkbMuB5.system.js +2 -0
  374. package/dist/pine-core/{p-BEn3hirk.system.js.map → p-BSkbMuB5.system.js.map} +1 -1
  375. package/dist/pine-core/{p-BVCWKPy3.js → p-Bf1dou5H.js} +2 -2
  376. package/dist/pine-core/p-Bf1dou5H.js.map +1 -0
  377. package/dist/pine-core/p-BigOVPun.system.js.map +1 -0
  378. package/dist/pine-core/{p-CcXaBX2A.system.js.map → p-BmFGXXkm.system.js.map} +1 -1
  379. package/dist/pine-core/p-ByzULH8m.system.js.map +1 -0
  380. package/dist/pine-core/{p-CE6b_LzB.system.js.map → p-C3iAHQC6.system.js.map} +1 -1
  381. package/dist/pine-core/{p-ACQU83St.system.js.map → p-CCQd5PVN.system.js.map} +1 -1
  382. package/dist/pine-core/{p-ChslVme6.system.js.map → p-CG2PKUWT.system.js.map} +1 -1
  383. package/dist/pine-core/{p-CQ8f8GnD.system.js.map → p-CHVzHNgU.system.js.map} +1 -1
  384. package/dist/pine-core/{p-Dh7jcLgJ.system.js.map → p-COwpA8ab.system.js.map} +1 -1
  385. package/dist/pine-core/{p-Co5XZmTN.system.js.map → p-CV0Lw9gs.system.js.map} +1 -1
  386. package/dist/pine-core/{p-C0zqu7Gr.system.js.map → p-CZqgW7e3.system.js.map} +1 -1
  387. package/dist/pine-core/{p-pQqXEKPh.system.js.map → p-Cc1q-FuD.system.js.map} +1 -1
  388. package/dist/pine-core/{p-CWdEolqa.system.js.map → p-Cl47ROcT.system.js.map} +1 -1
  389. package/dist/pine-core/{p-0KTU2Jt-.system.js.map → p-CnPN6prI.system.js.map} +1 -1
  390. package/dist/pine-core/{p-B1FQkx7R.system.js.map → p-Ctdx1tCG.system.js.map} +1 -1
  391. package/dist/pine-core/{p-3gYSFJIn.system.js.map → p-CwNRZQss.system.js.map} +1 -1
  392. package/dist/pine-core/{p-B_C-mRjx.system.js → p-Cxvdulqq.system.js} +2 -2
  393. package/dist/pine-core/p-Cxvdulqq.system.js.map +1 -0
  394. package/dist/pine-core/p-D3SrjYeb.system.js.map +1 -0
  395. package/dist/pine-core/p-D4MkIUXU.js +2 -0
  396. package/dist/pine-core/{p-DrJ5r5Pu.js.map → p-D4MkIUXU.js.map} +1 -1
  397. package/dist/pine-core/{p-MBv7PsKc.system.js.map → p-D52TGCLt.system.js.map} +1 -1
  398. package/dist/pine-core/{p-CHJgq_z7.system.js.map → p-D7B3vOdC.system.js.map} +1 -1
  399. package/dist/pine-core/{p-0TIvNV5c.system.js.map → p-D9veIL-g.system.js.map} +1 -1
  400. package/dist/pine-core/{p-D9_z2w3q.system.js.map → p-DGFR-x7P.system.js.map} +1 -1
  401. package/dist/pine-core/p-DeR0sSWy.system.js.map +1 -0
  402. package/dist/pine-core/{p-BRygGju8.system.js.map → p-Df597YUK.system.js.map} +1 -1
  403. package/dist/pine-core/{p-Df_3qA_L.system.js.map → p-DgE9ds9o.system.js.map} +1 -1
  404. package/dist/pine-core/{p-CLoi4eKt.system.js.map → p-DmWU0f_O.system.js.map} +1 -1
  405. package/dist/pine-core/{p-DYb5Y47j.system.js.map → p-Dq7Wu9rr.system.js.map} +1 -1
  406. package/dist/pine-core/p-Dw7zXw_6.system.js.map +1 -0
  407. package/dist/pine-core/{p-CpdNWpfd.system.js.map → p-Ek6vvXfI.system.js.map} +1 -1
  408. package/dist/pine-core/{p-C5Y492i0.system.js.map → p-M-zMP2QX.system.js.map} +1 -1
  409. package/dist/pine-core/{p-IhWWc2L_.system.js.map → p-WO5h6NYA.system.js.map} +1 -1
  410. package/dist/pine-core/p-WWWd_vEd.system.js +2 -0
  411. package/dist/pine-core/p-WWWd_vEd.system.js.map +1 -0
  412. package/dist/pine-core/{p-D05FrqXr.system.js.map → p-X5M4eshC.system.js.map} +1 -1
  413. package/dist/pine-core/{p-m6UZWRsP.system.js.map → p-Z5rOSkoA.system.js.map} +1 -1
  414. package/dist/pine-core/{p-72053224.entry.js → p-a2cb65df.entry.js} +3 -3
  415. package/dist/pine-core/{p-c8122bea.entry.js → p-a54d6a53.entry.js} +2 -2
  416. package/dist/pine-core/{p-a04556e4.system.entry.js → p-a5cf0088.system.entry.js} +2 -2
  417. package/dist/pine-core/p-a645818a.entry.js +2 -0
  418. package/dist/pine-core/{p-f583e5d4.entry.js → p-a9cfaa1f.entry.js} +2 -2
  419. package/dist/pine-core/{p-14a52961.system.entry.js → p-aa2782b9.system.entry.js} +2 -2
  420. package/dist/pine-core/{p-f55b9f90.system.entry.js → p-ab4307c7.system.entry.js} +2 -2
  421. package/dist/pine-core/{p-349a8869.entry.js → p-af56cb57.entry.js} +2 -2
  422. package/dist/pine-core/{p-8d7abc83.entry.js → p-b32d34d0.entry.js} +2 -2
  423. package/dist/pine-core/{p-00616fc9.entry.js → p-b378ca03.entry.js} +2 -2
  424. package/dist/pine-core/p-b669e1d9.entry.js +2 -0
  425. package/dist/pine-core/p-b699a14f.system.entry.js +2 -0
  426. package/dist/pine-core/p-b699a14f.system.entry.js.map +1 -0
  427. package/dist/pine-core/{p-52cb152b.system.entry.js → p-bc2fecd4.system.entry.js} +2 -2
  428. package/dist/pine-core/{p-e3fb0bc2.system.entry.js → p-bc637bed.system.entry.js} +2 -2
  429. package/dist/pine-core/{p-b6ea3332.entry.js → p-be5ef841.entry.js} +2 -2
  430. package/dist/pine-core/{p-54183d70.system.entry.js → p-c0601420.system.entry.js} +2 -2
  431. package/dist/pine-core/p-c2d2fe64.system.entry.js +2 -0
  432. package/dist/pine-core/{p-fcb39155.system.entry.js → p-c3f84df8.system.entry.js} +2 -2
  433. package/dist/pine-core/p-c44d3551.entry.js +2 -0
  434. package/dist/pine-core/{p-e8d76117.entry.js → p-c55fc47e.entry.js} +2 -2
  435. package/dist/pine-core/{p-5da82e8c.system.entry.js → p-c63e7909.system.entry.js} +2 -2
  436. package/dist/pine-core/{p-c0df3222.entry.js → p-d325287b.entry.js} +2 -2
  437. package/dist/pine-core/p-d52d96b5.system.entry.js +4 -0
  438. package/dist/pine-core/p-d52d96b5.system.entry.js.map +1 -0
  439. package/dist/pine-core/{p-d8d8fe07.system.entry.js → p-d5c63517.system.entry.js} +2 -2
  440. package/dist/pine-core/p-d65d252d.entry.js +2 -0
  441. package/dist/pine-core/p-d65d252d.entry.js.map +1 -0
  442. package/dist/pine-core/p-db12273e.system.entry.js +2 -0
  443. package/dist/pine-core/{p-92c52409.system.entry.js → p-dbe41087.system.entry.js} +2 -2
  444. package/dist/pine-core/{p-deb8a499.system.entry.js → p-e03b7f4a.system.entry.js} +2 -2
  445. package/dist/pine-core/{p-6db1e029.system.entry.js → p-ee583234.system.entry.js} +2 -2
  446. package/dist/pine-core/{p-0066d249.entry.js → p-f5d78141.entry.js} +2 -2
  447. package/dist/pine-core/p-f61ee383.system.entry.js +2 -0
  448. package/dist/pine-core/p-f61ee383.system.entry.js.map +1 -0
  449. package/dist/pine-core/{p-98fe56d9.entry.js → p-f6b269ac.entry.js} +2 -2
  450. package/dist/pine-core/p-f70aef6e.system.entry.js +2 -0
  451. package/dist/pine-core/p-f70aef6e.system.entry.js.map +1 -0
  452. package/dist/pine-core/{p-52af1890.system.entry.js → p-f911dde3.system.entry.js} +2 -2
  453. package/dist/pine-core/{p-7cb4f0de.entry.js → p-fd3d548f.entry.js} +2 -2
  454. package/dist/pine-core/{p-ac37cf0d.entry.js → p-fddf82f8.entry.js} +2 -2
  455. package/dist/pine-core/{p-dc19ce6c.system.entry.js → p-fdf22be1.system.entry.js} +2 -2
  456. package/dist/pine-core/{p-a9895385.system.entry.js → p-fe7ece91.system.entry.js} +2 -2
  457. package/dist/pine-core/{p-DHmJZxQk.system.js.map → p-iM8w34Dq.system.js.map} +1 -1
  458. package/dist/pine-core/{p-BZoPY2dP.system.js.map → p-iazk4jjL.system.js.map} +1 -1
  459. package/dist/pine-core/{p-CqzGa2j0.system.js.map → p-k9JOparb.system.js.map} +1 -1
  460. package/dist/pine-core/{p-CgyVIfOY.system.js.map → p-kbAzjMDU.system.js.map} +1 -1
  461. package/dist/pine-core/{p-B7S-9dbT.system.js.map → p-kcOuXqWo.system.js.map} +1 -1
  462. package/dist/pine-core/{p-3pEJO0vO.system.js.map → p-nawkAoxk.system.js.map} +1 -1
  463. package/dist/pine-core/p-oDk-2Jyq.system.js.map +1 -0
  464. package/dist/pine-core/{p-WkrM7Vv0.system.js.map → p-wlxYjeBe.system.js.map} +1 -1
  465. package/dist/pine-core/{p-CqK-uhv8.system.js.map → p-yaM1kuaC.system.js.map} +1 -1
  466. package/dist/pine-core/pds-button.entry.esm.js.map +1 -1
  467. package/dist/pine-core/pds-combobox.entry.esm.js.map +1 -1
  468. package/dist/pine-core/pds-dropdown-menu-separator.entry.esm.js.map +1 -1
  469. package/dist/pine-core/pds-filter.entry.esm.js.map +1 -0
  470. package/dist/pine-core/pds-filters.entry.esm.js.map +1 -0
  471. package/dist/pine-core/pds-tab.entry.esm.js.map +1 -1
  472. package/dist/pine-core/pds-tabs.entry.esm.js.map +1 -1
  473. package/dist/pine-core/pine-core.esm.js +1 -1
  474. package/dist/pine-core/pine-core.js +1 -1
  475. package/dist/types/components/pds-button/pds-button.d.ts +1 -1
  476. package/dist/types/components/pds-combobox/pds-combobox.d.ts +28 -3
  477. package/dist/types/components/pds-filters/pds-filter/filter-interface.d.ts +19 -0
  478. package/dist/types/components/pds-filters/pds-filter/pds-filter.d.ts +133 -0
  479. package/dist/types/components/pds-filters/pds-filters.d.ts +11 -0
  480. package/dist/types/components/pds-tabs/pds-tabs.d.ts +1 -0
  481. package/dist/types/components.d.ts +133 -2
  482. package/hydrate/index.js +948 -93
  483. package/hydrate/index.mjs +948 -93
  484. package/package.json +2 -2
  485. package/dist/cjs/index-g-uSeICs.js.map +0 -1
  486. package/dist/esm/index-BVCWKPy3.js.map +0 -1
  487. package/dist/esm-es5/index-BVCWKPy3.js.map +0 -1
  488. package/dist/esm-es5/index-DrJ5r5Pu.js +0 -2
  489. package/dist/pine-core/p-051ff780.system.entry.js +0 -2
  490. package/dist/pine-core/p-051ff780.system.entry.js.map +0 -1
  491. package/dist/pine-core/p-232a2043.entry.js +0 -2
  492. package/dist/pine-core/p-346561a6.system.entry.js +0 -2
  493. package/dist/pine-core/p-346561a6.system.entry.js.map +0 -1
  494. package/dist/pine-core/p-44087d1c.entry.js +0 -2
  495. package/dist/pine-core/p-47670150.entry.js +0 -3
  496. package/dist/pine-core/p-47670150.entry.js.map +0 -1
  497. package/dist/pine-core/p-5708f95a.entry.js +0 -2
  498. package/dist/pine-core/p-651861ff.entry.js.map +0 -1
  499. package/dist/pine-core/p-66b10d29.entry.js +0 -2
  500. package/dist/pine-core/p-7004d1ea.system.entry.js +0 -2
  501. package/dist/pine-core/p-71169b66.system.entry.js +0 -2
  502. package/dist/pine-core/p-71169b66.system.entry.js.map +0 -1
  503. package/dist/pine-core/p-73158adf.system.entry.js +0 -2
  504. package/dist/pine-core/p-77336705.entry.js +0 -2
  505. package/dist/pine-core/p-77336705.entry.js.map +0 -1
  506. package/dist/pine-core/p-84949a12.entry.js +0 -2
  507. package/dist/pine-core/p-84949a12.entry.js.map +0 -1
  508. package/dist/pine-core/p-8ab7f0d7.system.entry.js +0 -4
  509. package/dist/pine-core/p-8ab7f0d7.system.entry.js.map +0 -1
  510. package/dist/pine-core/p-BEn3hirk.system.js +0 -2
  511. package/dist/pine-core/p-BGbUqsWH.system.js +0 -2
  512. package/dist/pine-core/p-BGbUqsWH.system.js.map +0 -1
  513. package/dist/pine-core/p-BKFboaI5.system.js.map +0 -1
  514. package/dist/pine-core/p-BVCWKPy3.js.map +0 -1
  515. package/dist/pine-core/p-B_C-mRjx.system.js.map +0 -1
  516. package/dist/pine-core/p-Cmzqpibo.system.js.map +0 -1
  517. package/dist/pine-core/p-Czoq9yJM.system.js.map +0 -1
  518. package/dist/pine-core/p-DXuK7cEc.system.js.map +0 -1
  519. package/dist/pine-core/p-De9tROL-.system.js +0 -2
  520. package/dist/pine-core/p-DrJ5r5Pu.js +0 -2
  521. package/dist/pine-core/p-UsEwlBJ0.system.js.map +0 -1
  522. package/dist/pine-core/p-a54f1d9e.entry.js +0 -2
  523. package/dist/pine-core/p-a54f1d9e.entry.js.map +0 -1
  524. package/dist/pine-core/p-aa645f28.system.entry.js +0 -2
  525. package/dist/pine-core/p-aa645f28.system.entry.js.map +0 -1
  526. package/dist/pine-core/p-bb8ef74a.system.entry.js +0 -2
  527. package/dist/pine-core/p-be939cb0.entry.js +0 -2
  528. package/dist/pine-core/p-c1099665.system.entry.js +0 -2
  529. package/dist/pine-core/p-c2ffb466.system.entry.js +0 -2
  530. package/dist/pine-core/p-cd785026.system.entry.js +0 -2
  531. package/dist/pine-core/p-e65a7d1c.system.entry.js +0 -2
  532. package/dist/pine-core/p-efa788ea.entry.js +0 -2
  533. package/dist/pine-core/p-f880adaa.entry.js +0 -2
  534. /package/dist/pine-core/{p-fd091234.system.entry.js.map → p-0075bbbe.system.entry.js.map} +0 -0
  535. /package/dist/pine-core/{p-66b10d29.entry.js.map → p-07e129db.entry.js.map} +0 -0
  536. /package/dist/pine-core/{p-8999b63d.system.entry.js.map → p-0975b749.system.entry.js.map} +0 -0
  537. /package/dist/pine-core/{p-4c81420c.entry.js.map → p-0befa8f0.entry.js.map} +0 -0
  538. /package/dist/pine-core/{p-540cfd70.entry.js.map → p-1009009c.entry.js.map} +0 -0
  539. /package/dist/pine-core/{p-8722865f.system.entry.js.map → p-1773aeac.system.entry.js.map} +0 -0
  540. /package/dist/pine-core/{p-e2887e78.entry.js.map → p-1b9d4482.entry.js.map} +0 -0
  541. /package/dist/pine-core/{p-8726c99d.system.entry.js.map → p-2597bc59.system.entry.js.map} +0 -0
  542. /package/dist/pine-core/{p-5a709348.entry.js.map → p-25cb810d.entry.js.map} +0 -0
  543. /package/dist/pine-core/{p-a1b51557.system.entry.js.map → p-25cf2860.system.entry.js.map} +0 -0
  544. /package/dist/pine-core/{p-6f4a6d0b.entry.js.map → p-265372d3.entry.js.map} +0 -0
  545. /package/dist/pine-core/{p-c2ffb466.system.entry.js.map → p-2b12bc55.system.entry.js.map} +0 -0
  546. /package/dist/pine-core/{p-297afc49.system.entry.js.map → p-2b452883.system.entry.js.map} +0 -0
  547. /package/dist/pine-core/{p-cd785026.system.entry.js.map → p-2efc646c.system.entry.js.map} +0 -0
  548. /package/dist/pine-core/{p-ecb9edf8.entry.js.map → p-2fb6f9d5.entry.js.map} +0 -0
  549. /package/dist/pine-core/{p-efa788ea.entry.js.map → p-2fd7f74e.entry.js.map} +0 -0
  550. /package/dist/pine-core/{p-39488f2c.system.entry.js.map → p-302849cf.system.entry.js.map} +0 -0
  551. /package/dist/pine-core/{p-51d83489.system.entry.js.map → p-307f415a.system.entry.js.map} +0 -0
  552. /package/dist/pine-core/{p-318fd0cf.entry.js.map → p-31f6fcc1.entry.js.map} +0 -0
  553. /package/dist/pine-core/{p-bb8ef74a.system.entry.js.map → p-378df5eb.system.entry.js.map} +0 -0
  554. /package/dist/pine-core/{p-e08f492a.entry.js.map → p-39648ce2.entry.js.map} +0 -0
  555. /package/dist/pine-core/{p-50c9e865.entry.js.map → p-3e7933bf.entry.js.map} +0 -0
  556. /package/dist/pine-core/{p-5f5b19f4.entry.js.map → p-41e2fe3a.entry.js.map} +0 -0
  557. /package/dist/pine-core/{p-7004d1ea.system.entry.js.map → p-449ebe39.system.entry.js.map} +0 -0
  558. /package/dist/pine-core/{p-023d8b71.system.entry.js.map → p-4534e8cc.system.entry.js.map} +0 -0
  559. /package/dist/pine-core/{p-52d37cc1.entry.js.map → p-46820152.entry.js.map} +0 -0
  560. /package/dist/pine-core/{p-ba187a35.entry.js.map → p-4b3a8cab.entry.js.map} +0 -0
  561. /package/dist/pine-core/{p-da367b5e.system.entry.js.map → p-4c8bebd8.system.entry.js.map} +0 -0
  562. /package/dist/pine-core/{p-503cab1f.entry.js.map → p-4dda1edf.entry.js.map} +0 -0
  563. /package/dist/pine-core/{p-5e8badb9.entry.js.map → p-559b4ebc.entry.js.map} +0 -0
  564. /package/dist/pine-core/{p-c13ef6a7.system.entry.js.map → p-55d06d0a.system.entry.js.map} +0 -0
  565. /package/dist/pine-core/{p-25190921.entry.js.map → p-56f6f106.entry.js.map} +0 -0
  566. /package/dist/pine-core/{p-075eecf9.entry.js.map → p-5ac7af9e.entry.js.map} +0 -0
  567. /package/dist/pine-core/{p-6d4d4705.system.entry.js.map → p-5cc0244d.system.entry.js.map} +0 -0
  568. /package/dist/pine-core/{p-dfc5ab34.system.entry.js.map → p-72d87dc6.system.entry.js.map} +0 -0
  569. /package/dist/pine-core/{p-b2b1b7a9.system.entry.js.map → p-73a2e028.system.entry.js.map} +0 -0
  570. /package/dist/pine-core/{p-4bbf3e31.entry.js.map → p-74f03e75.entry.js.map} +0 -0
  571. /package/dist/pine-core/{p-be939cb0.entry.js.map → p-786967e8.entry.js.map} +0 -0
  572. /package/dist/pine-core/{p-0de9f8da.system.entry.js.map → p-7b0517e5.system.entry.js.map} +0 -0
  573. /package/dist/pine-core/{p-41d1b164.entry.js.map → p-7eb22880.entry.js.map} +0 -0
  574. /package/dist/pine-core/{p-464dd476.entry.js.map → p-8501429f.entry.js.map} +0 -0
  575. /package/dist/pine-core/{p-e65a7d1c.system.entry.js.map → p-875d5d5a.system.entry.js.map} +0 -0
  576. /package/dist/pine-core/{p-4deb7b8c.entry.js.map → p-896e2f1b.entry.js.map} +0 -0
  577. /package/dist/pine-core/{p-72b05928.system.entry.js.map → p-8ded79aa.system.entry.js.map} +0 -0
  578. /package/dist/pine-core/{p-e89cb1f2.system.entry.js.map → p-8f69dd71.system.entry.js.map} +0 -0
  579. /package/dist/pine-core/{p-2e19f167.system.entry.js.map → p-94fe15b0.system.entry.js.map} +0 -0
  580. /package/dist/pine-core/{p-72053224.entry.js.map → p-a2cb65df.entry.js.map} +0 -0
  581. /package/dist/pine-core/{p-c8122bea.entry.js.map → p-a54d6a53.entry.js.map} +0 -0
  582. /package/dist/pine-core/{p-a04556e4.system.entry.js.map → p-a5cf0088.system.entry.js.map} +0 -0
  583. /package/dist/pine-core/{p-f880adaa.entry.js.map → p-a645818a.entry.js.map} +0 -0
  584. /package/dist/pine-core/{p-f583e5d4.entry.js.map → p-a9cfaa1f.entry.js.map} +0 -0
  585. /package/dist/pine-core/{p-14a52961.system.entry.js.map → p-aa2782b9.system.entry.js.map} +0 -0
  586. /package/dist/pine-core/{p-f55b9f90.system.entry.js.map → p-ab4307c7.system.entry.js.map} +0 -0
  587. /package/dist/pine-core/{p-349a8869.entry.js.map → p-af56cb57.entry.js.map} +0 -0
  588. /package/dist/pine-core/{p-8d7abc83.entry.js.map → p-b32d34d0.entry.js.map} +0 -0
  589. /package/dist/pine-core/{p-00616fc9.entry.js.map → p-b378ca03.entry.js.map} +0 -0
  590. /package/dist/pine-core/{p-5708f95a.entry.js.map → p-b669e1d9.entry.js.map} +0 -0
  591. /package/dist/pine-core/{p-52cb152b.system.entry.js.map → p-bc2fecd4.system.entry.js.map} +0 -0
  592. /package/dist/pine-core/{p-e3fb0bc2.system.entry.js.map → p-bc637bed.system.entry.js.map} +0 -0
  593. /package/dist/pine-core/{p-b6ea3332.entry.js.map → p-be5ef841.entry.js.map} +0 -0
  594. /package/dist/pine-core/{p-54183d70.system.entry.js.map → p-c0601420.system.entry.js.map} +0 -0
  595. /package/dist/pine-core/{p-73158adf.system.entry.js.map → p-c2d2fe64.system.entry.js.map} +0 -0
  596. /package/dist/pine-core/{p-fcb39155.system.entry.js.map → p-c3f84df8.system.entry.js.map} +0 -0
  597. /package/dist/pine-core/{p-232a2043.entry.js.map → p-c44d3551.entry.js.map} +0 -0
  598. /package/dist/pine-core/{p-e8d76117.entry.js.map → p-c55fc47e.entry.js.map} +0 -0
  599. /package/dist/pine-core/{p-5da82e8c.system.entry.js.map → p-c63e7909.system.entry.js.map} +0 -0
  600. /package/dist/pine-core/{p-c0df3222.entry.js.map → p-d325287b.entry.js.map} +0 -0
  601. /package/dist/pine-core/{p-d8d8fe07.system.entry.js.map → p-d5c63517.system.entry.js.map} +0 -0
  602. /package/dist/pine-core/{p-c1099665.system.entry.js.map → p-db12273e.system.entry.js.map} +0 -0
  603. /package/dist/pine-core/{p-92c52409.system.entry.js.map → p-dbe41087.system.entry.js.map} +0 -0
  604. /package/dist/pine-core/{p-deb8a499.system.entry.js.map → p-e03b7f4a.system.entry.js.map} +0 -0
  605. /package/dist/pine-core/{p-6db1e029.system.entry.js.map → p-ee583234.system.entry.js.map} +0 -0
  606. /package/dist/pine-core/{p-0066d249.entry.js.map → p-f5d78141.entry.js.map} +0 -0
  607. /package/dist/pine-core/{p-98fe56d9.entry.js.map → p-f6b269ac.entry.js.map} +0 -0
  608. /package/dist/pine-core/{p-52af1890.system.entry.js.map → p-f911dde3.system.entry.js.map} +0 -0
  609. /package/dist/pine-core/{p-7cb4f0de.entry.js.map → p-fd3d548f.entry.js.map} +0 -0
  610. /package/dist/pine-core/{p-ac37cf0d.entry.js.map → p-fddf82f8.entry.js.map} +0 -0
  611. /package/dist/pine-core/{p-dc19ce6c.system.entry.js.map → p-fdf22be1.system.entry.js.map} +0 -0
  612. /package/dist/pine-core/{p-a9895385.system.entry.js.map → p-fe7ece91.system.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"pds-combobox.js","sourceRoot":"","sources":["../../../src/components/pds-combobox/pds-combobox.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Host, Prop, State, Watch, Method } from '@stencil/core';\nimport type { BasePdsProps } from '@utils/interfaces';\nimport { computePosition, flip, offset, shift } from '@floating-ui/dom';\nimport DOMPurify from 'dompurify';\n\n/**\n * @slot option - Option elements for the combobox dropdown\n * @slot trigger-content - Custom content for the button trigger when customTriggerContent is true\n */\n@Component({\n tag: 'pds-combobox',\n styleUrl: 'pds-combobox.scss',\n shadow: true,\n})\nexport class PdsCombobox implements BasePdsProps {\n /** Reference to the host element */\n @Element() el!: HTMLPdsComboboxElement;\n\n /**\n * A unique identifier used for the underlying component `id` attribute.\n */\n @Prop() componentId!: string;\n\n /**\n * Enable custom layout content for options. Options with data-layout attribute will render their HTML content.\n * ⚠️ Security Warning: Only use with trusted content. Basic XSS protection is applied, but avoid user-generated content.\n * @default false\n */\n @Prop() customOptionLayouts: boolean = false;\n\n /**\n * Enable custom layout content for the button trigger via the trigger-content slot.\n * When true, uses slot content for initial state but updates dynamically with selected option layout.\n * ⚠️ Security Warning: Only use with trusted content. Basic XSS protection is applied, but avoid user-generated content.\n * @default false\n */\n @Prop() customTriggerContent: boolean = false;\n\n /**\n * If true, the combobox is disabled.\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Placement of the dropdown relative to the trigger.\n * @default 'bottom-start'\n */\n @Prop() dropdownPlacement: 'bottom-start' | 'bottom-end' | 'top-start' | 'top-end' = 'bottom-start';\n\n /**\n * Width of the dropdown. Any valid CSS width value.\n * @default '236px'\n */\n @Prop() dropdownWidth: string = '236px';\n\n /**\n * Visually hides the label text for instances where only the combobox should be displayed.\n * Label remains accessible to assistive technology such as screen readers.\n */\n @Prop() hideLabel: boolean = false;\n\n /**\n * Text to be displayed as the combobox label.\n */\n @Prop() label?: string;\n\n /**\n * Maximum height of the dropdown. Can be any valid CSS height value (e.g., '200px', '10rem').\n * When content exceeds this height, the dropdown will scroll.\n */\n @Prop() maxHeight?: string;\n\n /**\n * Determines the combobox mode: 'filter' (filter options as you type) or 'select-only' (show all options).\n * @default 'filter'\n */\n @Prop() mode: 'filter' | 'select-only' = 'filter';\n\n /**\n * Placeholder text for the input field.\n */\n @Prop() placeholder?: string;\n\n /**\n * Determines the combobox trigger: 'input' (editable input) or 'button' (button-like, non-editable).\n * @default 'input'\n */\n @Prop() trigger: 'input' | 'button' = 'input';\n\n /**\n * Width of the trigger (button or input). Any valid CSS width value.\n * @default 'fit-content'\n */\n @Prop() triggerWidth: string = 'fit-content';\n\n /**\n * The visual variant for the button trigger. Matches Pine button variants.\n * @default 'secondary'\n */\n @Prop() triggerVariant: 'secondary' | 'primary' | 'accent' | 'destructive' = 'secondary';\n\n /**\n * The value of the combobox input.\n */\n @Prop({ mutable: true }) value: string = '';\n\n /**\n * Emitted when the value changes.\n */\n @Event() pdsComboboxChange!: EventEmitter<{ value: string }>;\n\n /**\n * Internal state for filtered options\n */\n @State() filteredOptions: HTMLOptionElement[] = [];\n\n /**\n * Internal state for the currently highlighted option index\n */\n @State() highlightedIndex: number = -1;\n\n /**\n * Internal state for dropdown open/close\n */\n @State() isOpen: boolean = false;\n\n /**\n * Internal state for the currently selected option\n */\n @State() selectedOption: HTMLOptionElement | null = null;\n\n /**\n * Internal state for the sanitized layout content of the selected option\n */\n @State() selectedOptionLayoutContent: string = '';\n\n private inputEl?: HTMLInputElement;\n private optionEls: HTMLOptionElement[] = [];\n private triggerEl?: HTMLElement;\n private listboxEl?: HTMLElement;\n\n componentWillLoad() {\n this.updateOptions();\n }\n\n @Watch('value')\n handleValueChange() {\n this.filterOptions();\n }\n\n @Watch('selectedOption')\n handleSelectedOptionChange() {\n // Update the layout content when selected option changes\n this.selectedOptionLayoutContent = this.selectedOption && this.isOptionLayout(this.selectedOption)\n ? this.getOptionLayoutContent(this.selectedOption)\n : '';\n }\n\n private updateOptions() {\n // Get all <option> elements from the slot\n const slot = this.el.shadowRoot?.querySelector('slot[name=\"option\"], slot:not([name])');\n if (slot) {\n this.optionEls = (slot as HTMLSlotElement).assignedElements({ flatten: true })\n .filter(el => el.tagName === 'OPTION') as HTMLOptionElement[];\n\n // Set initial selected option if one exists (only check DOM on initialization)\n if (!this.selectedOption) {\n const initialSelected = this.optionEls.find(opt => opt.hasAttribute('selected')) || null;\n this.setSelectedOption(initialSelected);\n }\n\n this.filterOptions();\n }\n }\n\n // Helper method to get option label, falling back to text content if no label attribute\n private getOptionLabel(option: HTMLOptionElement): string {\n return option.label || option.textContent || '';\n }\n\n // Helper method to get option layout content\n private getOptionLayoutContent(option: HTMLOptionElement): string {\n return this.sanitizeHtml(option.innerHTML || '');\n }\n\n // HTML sanitization using DOMPurify library to prevent XSS attacks\n private sanitizeHtml(html: string): string {\n // Configure DOMPurify to allow Pine Design System components while removing dangerous content\n const config = {\n // Allow all custom elements (including pds-* components)\n CUSTOM_ELEMENT_HANDLING: {\n tagNameCheck: (tagName: string) => {\n // Allow all pds-* tags and standard safe HTML tags\n return tagName.startsWith('pds-') || /^[a-z]+$/i.test(tagName);\n },\n attributeNameCheck: (attr: string) => {\n // Allow standard HTML attributes, data-* attributes, and Pine component attributes\n return /^[a-zA-Z][a-zA-Z0-9-]*$/.test(attr) || attr.startsWith('data-') || attr.startsWith('aria-');\n },\n allowCustomizedBuiltInElements: false,\n },\n // Allow standard safe attributes\n ALLOW_DATA_ATTR: true,\n ALLOW_ARIA_ATTR: true,\n // Specifically forbid dangerous tags\n FORBID_TAGS: ['script', 'iframe', 'object', 'embed', 'form', 'input', 'textarea', 'select', 'button', 'style'],\n // Forbid all event handler attributes\n FORBID_ATTR: [\n 'onerror', 'onload', 'onclick', 'onmouseover', 'onmouseout', 'onmousemove',\n 'onfocus', 'onblur', 'onchange', 'onsubmit', 'onkeydown', 'onkeyup', 'onkeypress',\n 'onmousedown', 'onmouseup', 'ondblclick', 'oncontextmenu', 'onscroll'\n ],\n // Safe protocol whitelist\n ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp|data):|[^a-z]|[a-z+.\\-]+(?:[^a-z+.\\-:]|$))/i,\n };\n\n return DOMPurify.sanitize(html, config);\n }\n\n\n\n // Helper method to check if option should render as layout\n private isOptionLayout(option: HTMLOptionElement): boolean {\n return this.customOptionLayouts && option.hasAttribute('data-layout');\n }\n\n // Helper method to check if option is selected (single source of truth)\n private isOptionSelected(option: HTMLOptionElement): boolean {\n return this.selectedOption === option;\n }\n\n // Helper method to set selected option (centralized state management)\n private setSelectedOption(option: HTMLOptionElement | null): void {\n this.selectedOption = option;\n }\n\n private filterOptions() {\n if (this.mode === 'select-only') {\n this.filteredOptions = this.optionEls;\n } else {\n const val = this.value.toLowerCase();\n this.filteredOptions = this.optionEls.filter(option => {\n // For layout options, search both text content and data-search-text attribute\n if (this.isOptionLayout(option)) {\n const searchText = option.getAttribute('data-search-text') || option.textContent || '';\n return searchText.toLowerCase().includes(val);\n }\n return this.getOptionLabel(option).toLowerCase().includes(val);\n });\n }\n this.highlightedIndex = -1;\n }\n\n private openDropdownPositioning() {\n if (this.triggerEl && this.listboxEl) {\n // Apply width and max-height BEFORE positioning calculations\n this.listboxEl.style.width = this.dropdownWidth;\n\n if (this.maxHeight) {\n this.listboxEl.style.maxHeight = this.maxHeight;\n this.listboxEl.style.overflowY = 'auto';\n }\n\n // Force a reflow to ensure dimensions are calculated\n this.listboxEl.offsetHeight;\n\n computePosition(this.triggerEl, this.listboxEl, {\n placement: this.dropdownPlacement,\n strategy: 'absolute',\n middleware: [offset(12), flip(), shift({ padding: 5 })],\n }).then(({ x, y }) => {\n Object.assign(this.listboxEl.style, {\n left: `${x}px`,\n top: `${y}px`,\n position: 'absolute',\n zIndex: 1000,\n });\n });\n }\n }\n\n private handleInput = (e: Event) => {\n const target = e.target as HTMLInputElement;\n this.value = target.value;\n this.isOpen = true;\n this.filterOptions();\n setTimeout(() => this.openDropdownPositioning(), 0);\n };\n\n private handleFocus = () => {\n this.isOpen = true;\n this.filterOptions();\n setTimeout(() => this.openDropdownPositioning(), 0);\n };\n\n private handleKeyDown = (e: KeyboardEvent) => {\n if (!this.isOpen && (e.key === 'ArrowDown' || e.key === 'ArrowUp')) {\n this.isOpen = true;\n return;\n }\n switch (e.key) {\n case 'ArrowDown':\n this.highlightedIndex = Math.min(this.highlightedIndex + 1, this.filteredOptions.length - 1);\n break;\n case 'ArrowUp':\n this.highlightedIndex = Math.max(this.highlightedIndex - 1, 0);\n break;\n case 'Enter':\n if (this.isOpen && this.highlightedIndex >= 0 && this.highlightedIndex < this.filteredOptions.length) {\n this.handleOptionClick(this.filteredOptions[this.highlightedIndex]);\n }\n break;\n case 'Escape':\n this.isOpen = false;\n break;\n }\n };\n\n /**\n * Sets focus on the native input element.\n */\n @Method()\n async setFocus() {\n this.inputEl?.focus();\n }\n\n /**\n * Gets the value of the currently selected option.\n */\n @Method()\n async getSelectedValue(): Promise<string | null> {\n return this.selectedOption ? this.selectedOption.value : null;\n }\n\n // Event handler for option click\n private onOptionClick = (event: Event) => {\n const idx = Number((event.currentTarget as HTMLElement).getAttribute('data-option-index'));\n const option = this.filteredOptions[idx];\n this.handleOptionClick(option);\n };\n\n // Event handler for mouse enter on option\n private onOptionMouseEnter = (event: Event) => {\n const idx = Number((event.currentTarget as HTMLElement).getAttribute('data-option-index'));\n this.highlightedIndex = idx;\n };\n\n // Prevent blur on mousedown\n private onOptionMouseDown = (event: Event) => {\n event.preventDefault();\n };\n\n // Get the label of the selected option\n private get selectedLabel(): string {\n return this.selectedOption ? this.getOptionLabel(this.selectedOption) : '';\n }\n\n // Get the layout content of the selected option for button trigger\n private get selectedLayoutContent(): string {\n return this.selectedOptionLayoutContent;\n }\n\n // Check if selected option has layout\n private get selectedHasLayout(): boolean {\n return this.selectedOption ? this.isOptionLayout(this.selectedOption) : false;\n }\n\n // Handler for button trigger click\n private onButtonTriggerClick = () => {\n this.isOpen = !this.isOpen;\n if (this.isOpen) setTimeout(() => this.openDropdownPositioning(), 0);\n };\n\n // Handler for button trigger keyboard events\n private onButtonTriggerKeyDown = (e: KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault();\n this.isOpen = true;\n this.highlightedIndex = 0;\n setTimeout(() => this.openDropdownPositioning(), 0);\n } else if (e.key === 'Escape') {\n this.isOpen = false;\n }\n };\n\n // Close dropdown when focus leaves the combobox\n private onComboboxFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n if (!this.el.contains(relatedTarget)) {\n this.isOpen = false;\n\n // If there's a selected option but the input value doesn't match, restore the selected option's value\n if (this.selectedOption && this.value !== this.getOptionLabel(this.selectedOption)) {\n this.value = this.getOptionLabel(this.selectedOption);\n }\n }\n };\n\n private handleOptionClick(option: HTMLOptionElement) {\n // Update reactive state - single source of truth\n this.setSelectedOption(option);\n\n this.value = this.getOptionLabel(option);\n this.isOpen = false;\n this.pdsComboboxChange.emit({ value: option.value });\n }\n\n private renderDropdown() {\n if (!this.isOpen || this.filteredOptions.length === 0) return null;\n return (\n <ul\n class=\"pds-combobox__listbox\"\n role=\"listbox\"\n id=\"pds-combobox-listbox\"\n ref={el => (this.listboxEl = el as HTMLElement)}\n >\n {this.filteredOptions.map((option, idx) => {\n const isSelected = this.isOptionSelected(option);\n const isHighlighted = this.highlightedIndex === idx;\n const isLayout = this.isOptionLayout(option);\n\n return (\n <li\n key={option.value}\n id={`pds-combobox-option-${idx}`}\n role=\"option\"\n aria-selected={isSelected ? 'true' : 'false'}\n class={{\n 'pds-combobox__option': true,\n 'pds-combobox__option--highlighted': isHighlighted,\n 'pds-combobox__option--layout': isLayout,\n }}\n data-option-index={idx}\n onMouseDown={this.onOptionMouseDown}\n onClick={this.onOptionClick}\n onMouseEnter={this.onOptionMouseEnter}\n >\n {isLayout ? (\n <pds-box class=\"pds-combobox__option-layout-wrapper\" innerHTML={this.getOptionLayoutContent(option)} />\n ) : (\n this.getOptionLabel(option)\n )}\n {isSelected && <pds-icon icon=\"check\" size=\"regular\" class=\"pds-combobox__option-check\" />}\n </li>\n );\n })}\n </ul>\n );\n }\n\n // Helper method to render the caret icon\n private renderCaretIcon() {\n return <pds-icon icon=\"caret-down\" aria-hidden=\"true\" aria-label=\"dropdown indicator\" class=\"pds-combobox__button-trigger-chevron\" />;\n }\n\n // Helper method to render layout content\n private renderLayoutContent() {\n return (\n <div class=\"pds-combobox__button-trigger-layout-wrapper\" innerHTML={this.selectedLayoutContent} />\n );\n }\n\n // Helper method to render default text content\n private renderDefaultContent() {\n return (\n <span class=\"pds-combobox__button-trigger-label\">\n {this.selectedLabel || this.placeholder}\n </span>\n );\n }\n\n // Helper method to check if we should show layout content\n private shouldShowLayoutContent(): boolean {\n return this.selectedHasLayout && !!this.selectedLayoutContent;\n }\n\n private renderButtonTriggerContent() {\n // Case 1: Custom trigger content with layout priority\n if (this.customTriggerContent) {\n if (this.shouldShowLayoutContent()) {\n return [this.renderLayoutContent(), this.renderCaretIcon()];\n }\n // Fall back to slot content when no layout is available\n return <slot name=\"trigger-content\" />;\n }\n\n // Case 2: Standard mode with layout content\n if (this.shouldShowLayoutContent()) {\n return [this.renderLayoutContent(), this.renderCaretIcon()];\n }\n\n // Case 3: Standard mode with default text content\n return [this.renderDefaultContent(), this.renderCaretIcon()];\n }\n\n\n\n render() {\n const triggerClass = `pds-combobox__button-trigger pds-combobox__button-trigger--${this.triggerVariant}`;\n return (\n <Host>\n <div class=\"pds-combobox\" tabIndex={-1} onFocusout={this.onComboboxFocusOut}>\n {this.label && (\n <label htmlFor={this.componentId} class=\"pds-combobox__label\">\n <span class={this.hideLabel ? 'visually-hidden' : ''}>{this.label}</span>\n </label>\n )}\n {this.trigger === 'input' ? (\n <input\n ref={el => {\n this.inputEl = el as HTMLInputElement;\n this.triggerEl = el as HTMLElement;\n }}\n class=\"pds-combobox__input\"\n style={{ width: this.triggerWidth }}\n type=\"text\"\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-controls=\"pds-combobox-listbox\"\n aria-activedescendant={this.highlightedIndex >= 0 ? `pds-combobox-option-${this.highlightedIndex}` : undefined}\n aria-expanded={this.isOpen ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-label={this.hideLabel ? this.label : undefined}\n id={this.componentId}\n value={this.value}\n placeholder={this.placeholder}\n disabled={this.disabled}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n onKeyDown={this.handleKeyDown}\n autocomplete=\"off\"\n part=\"input\"\n />\n ) : (\n <div\n class={triggerClass}\n style={{ width: this.triggerWidth }}\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"pds-combobox-listbox\"\n aria-expanded={this.isOpen ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-label={this.hideLabel ? this.label : undefined}\n id={this.componentId}\n tabIndex={0}\n onClick={this.onButtonTriggerClick}\n data-layout={this.customTriggerContent}\n onKeyDown={this.onButtonTriggerKeyDown}\n ref={el => (this.triggerEl = el as HTMLElement)}\n part=\"button-trigger\"\n >\n {this.renderButtonTriggerContent()}\n </div>\n )}\n {/* Hide the slot so options are not visible */}\n <div style={{ display: 'none' }}>\n <slot onSlotchange={() => this.updateOptions()}></slot>\n </div>\n {this.renderDropdown()}\n </div>\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"pds-combobox.js","sourceRoot":"","sources":["../../../src/components/pds-combobox/pds-combobox.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, Event, EventEmitter, h, Host, Prop, State, Watch, Method } from '@stencil/core';\nimport type { BasePdsProps } from '@utils/interfaces';\nimport { computePosition, flip, offset, shift } from '@floating-ui/dom';\nimport DOMPurify from 'dompurify';\n\n/**\n * @slot option - Option elements for the combobox dropdown\n * @slot trigger-content - Custom content for the button trigger when customTriggerContent is true\n */\n@Component({\n tag: 'pds-combobox',\n styleUrl: 'pds-combobox.scss',\n shadow: true,\n})\nexport class PdsCombobox implements BasePdsProps {\n /** Reference to the host element */\n @Element() el!: HTMLPdsComboboxElement;\n\n /**\n * A unique identifier used for the underlying component `id` attribute.\n */\n @Prop() componentId!: string;\n\n /**\n * Enable custom layout content for options. Options with data-layout attribute will render their HTML content.\n * ⚠️ Security Warning: Only use with trusted content. Basic XSS protection is applied, but avoid user-generated content.\n * @default false\n */\n @Prop() customOptionLayouts: boolean = false;\n\n /**\n * Enable custom layout content for the button trigger via the trigger-content slot.\n * When true, uses slot content for initial state but updates dynamically with selected option layout.\n * ⚠️ Security Warning: Only use with trusted content. Basic XSS protection is applied, but avoid user-generated content.\n * @default false\n */\n @Prop() customTriggerContent: boolean = false;\n\n /**\n * If true, the combobox is disabled.\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Placement of the dropdown relative to the trigger.\n * @default 'bottom-start'\n */\n @Prop() dropdownPlacement: 'bottom-start' | 'bottom-end' | 'top-start' | 'top-end' = 'bottom-start';\n\n /**\n * Width of the dropdown. Any valid CSS width value.\n * @default '236px'\n */\n @Prop() dropdownWidth: string = '236px';\n\n /**\n * Visually hides the label text for instances where only the combobox should be displayed.\n * Label remains accessible to assistive technology such as screen readers.\n */\n @Prop() hideLabel: boolean = false;\n\n /**\n * Text to be displayed as the combobox label.\n */\n @Prop() label?: string;\n\n /**\n * Maximum height of the dropdown. Can be any valid CSS height value (e.g., '200px', '10rem').\n * When content exceeds this height, the dropdown will scroll.\n */\n @Prop() maxHeight?: string;\n\n /**\n * Determines the combobox mode: 'filter' (filter options as you type) or 'select-only' (show all options).\n * @default 'filter'\n */\n @Prop() mode: 'filter' | 'select-only' = 'filter';\n\n /**\n * Placeholder text for the input field.\n */\n @Prop() placeholder?: string;\n\n /**\n * Determines the combobox trigger: 'input' (editable input) or 'button' (button-like, non-editable).\n * @default 'input'\n */\n @Prop() trigger: 'input' | 'button' = 'input';\n\n /**\n * Width of the trigger (button or input). Any valid CSS width value.\n * @default 'fit-content'\n */\n @Prop() triggerWidth: string = 'fit-content';\n\n /**\n * The visual variant for the button trigger. Matches Pine button variants.\n * @default 'secondary'\n */\n @Prop() triggerVariant: 'secondary' | 'primary' | 'accent' | 'destructive' = 'secondary';\n\n /**\n * The value of the combobox input.\n */\n @Prop({ mutable: true }) value: string = '';\n\n /**\n * Emitted when the value changes.\n */\n @Event() pdsComboboxChange!: EventEmitter<{ value: string }>;\n\n /**\n * Internal state for filtered options and group labels\n */\n @State() filteredItems: (HTMLOptionElement | HTMLOptGroupElement | HTMLPdsTextElement)[] = [];\n\n /**\n * Internal state for the currently highlighted option index\n */\n @State() highlightedIndex: number = -1;\n\n /**\n * Internal state for dropdown open/close\n */\n @State() isOpen: boolean = false;\n\n /**\n * Internal state for the currently selected option\n */\n @State() selectedOption: HTMLOptionElement | null = null;\n\n /**\n * Internal state for the sanitized layout content of the selected option\n */\n @State() selectedOptionLayoutContent: string = '';\n\n private inputEl?: HTMLInputElement;\n private optionEls: HTMLOptionElement[] = [];\n private allItems: (HTMLOptionElement | HTMLOptGroupElement | HTMLPdsTextElement)[] = [];\n private triggerEl?: HTMLElement;\n private listboxEl?: HTMLElement;\n\n componentWillLoad() {\n this.updateOptions();\n }\n\n @Watch('value')\n handleValueChange() {\n this.filterOptions();\n }\n\n @Watch('selectedOption')\n handleSelectedOptionChange() {\n // Update the layout content when selected option changes\n this.selectedOptionLayoutContent = this.selectedOption && this.isOptionLayout(this.selectedOption)\n ? this.getOptionLayoutContent(this.selectedOption)\n : '';\n }\n\n private updateOptions() {\n // Get all elements from the slot\n const slot = this.el.shadowRoot?.querySelector('slot[name=\"option\"], slot:not([name])');\n if (slot) {\n const allElements = (slot as HTMLSlotElement).assignedElements({ flatten: true });\n\n // Separate options from group labels and flatten optgroups\n this.allItems = [];\n this.optionEls = [];\n\n allElements.forEach(el => {\n if (el.tagName === 'OPTION') {\n this.optionEls.push(el as HTMLOptionElement);\n this.allItems.push(el as HTMLOptionElement);\n } else if (el.tagName === 'OPTGROUP') {\n const optgroup = el as HTMLOptGroupElement;\n this.allItems.push(optgroup);\n // Add optgroup children (options)\n Array.from(optgroup.children).forEach(child => {\n if (child.tagName === 'OPTION') {\n this.optionEls.push(child as HTMLOptionElement);\n this.allItems.push(child as HTMLOptionElement);\n }\n });\n } else if (el.tagName === 'PDS-TEXT') {\n this.allItems.push(el as HTMLPdsTextElement);\n }\n });\n\n // Set initial selected option if one exists (only check DOM on initialization)\n if (!this.selectedOption) {\n const initialSelected = this.optionEls.find(opt => opt.hasAttribute('selected')) || null;\n this.setSelectedOption(initialSelected);\n }\n\n this.filterOptions();\n }\n }\n\n // Helper method to get option label, falling back to text content if no label attribute\n private getOptionLabel(option: HTMLOptionElement): string {\n return option.label || option.textContent || '';\n }\n\n // Helper method to get option layout content\n private getOptionLayoutContent(option: HTMLOptionElement): string {\n return this.sanitizeHtml(option.innerHTML || '');\n }\n\n // HTML sanitization using DOMPurify library to prevent XSS attacks\n private sanitizeHtml(html: string): string {\n // Configure DOMPurify to allow Pine Design System components while removing dangerous content\n const config = {\n // Allow all custom elements (including pds-* components)\n CUSTOM_ELEMENT_HANDLING: {\n tagNameCheck: (tagName: string) => {\n // Allow all pds-* tags and standard safe HTML tags\n return tagName.startsWith('pds-') || /^[a-z]+$/i.test(tagName);\n },\n attributeNameCheck: (attr: string) => {\n // Allow standard HTML attributes, data-* attributes, and Pine component attributes\n return /^[a-zA-Z][a-zA-Z0-9-]*$/.test(attr) || attr.startsWith('data-') || attr.startsWith('aria-');\n },\n allowCustomizedBuiltInElements: false,\n },\n // Allow standard safe attributes\n ALLOW_DATA_ATTR: true,\n ALLOW_ARIA_ATTR: true,\n // Specifically forbid dangerous tags\n FORBID_TAGS: ['script', 'iframe', 'object', 'embed', 'form', 'input', 'textarea', 'select', 'button', 'style'],\n // Forbid all event handler attributes\n FORBID_ATTR: [\n 'onerror', 'onload', 'onclick', 'onmouseover', 'onmouseout', 'onmousemove',\n 'onfocus', 'onblur', 'onchange', 'onsubmit', 'onkeydown', 'onkeyup', 'onkeypress',\n 'onmousedown', 'onmouseup', 'ondblclick', 'oncontextmenu', 'onscroll'\n ],\n // Safe protocol whitelist\n ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp|data):|[^a-z]|[a-z+.\\-]+(?:[^a-z+.\\-:]|$))/i,\n };\n\n return DOMPurify.sanitize(html, config);\n }\n\n // Helper method to check if option should render as layout\n private isOptionLayout(option: HTMLOptionElement): boolean {\n return this.customOptionLayouts && option.hasAttribute('data-layout');\n }\n\n // Helper method to check if option is selected (single source of truth)\n private isOptionSelected(option: HTMLOptionElement): boolean {\n return this.selectedOption === option;\n }\n\n // Helper method to set selected option (centralized state management)\n private setSelectedOption(option: HTMLOptionElement | null): void {\n this.selectedOption = option;\n }\n\n private filterOptions() {\n // Ensure allItems includes optionEls if not already populated (for edge cases)\n if (this.allItems.length === 0 && this.optionEls.length > 0) {\n this.allItems = [...this.optionEls];\n }\n\n if (this.mode === 'select-only') {\n this.filteredItems = [...this.allItems];\n } else {\n const val = this.value.toLowerCase();\n const filteredOptions = this.optionEls.filter(option => {\n // For layout options, search both text content and data-search-text attribute\n if (this.isOptionLayout(option)) {\n const searchText = option.getAttribute('data-search-text') || option.textContent || '';\n return searchText.toLowerCase().includes(val);\n }\n return this.getOptionLabel(option).toLowerCase().includes(val);\n });\n\n // Rebuild filtered items maintaining group structure - simplified approach\n this.filteredItems = [];\n let currentGroupLabel: HTMLOptGroupElement | HTMLPdsTextElement | null = null;\n\n this.allItems.forEach(item => {\n if (item.tagName === 'OPTGROUP' || item.tagName === 'PDS-TEXT') {\n currentGroupLabel = item as HTMLOptGroupElement | HTMLPdsTextElement;\n } else if (item.tagName === 'OPTION' && filteredOptions.includes(item as HTMLOptionElement)) {\n const optionEl = item as HTMLOptionElement;\n const parent = optionEl.parentElement;\n let labelToUse: HTMLOptGroupElement | HTMLPdsTextElement | null = null;\n if (parent && parent.tagName === 'OPTGROUP') {\n // Only use the actual parent optgroup as label\n labelToUse = parent as HTMLOptGroupElement;\n } else if (currentGroupLabel && currentGroupLabel.tagName === 'PDS-TEXT') {\n // Allow pds-text to label subsequent top-level options until another label appears\n labelToUse = currentGroupLabel as HTMLPdsTextElement;\n }\n if (labelToUse && !this.filteredItems.includes(labelToUse)) {\n this.filteredItems.push(labelToUse);\n }\n this.filteredItems.push(optionEl);\n }\n });\n }\n this.highlightedIndex = -1;\n }\n\n private openDropdownPositioning() {\n if (this.triggerEl && this.listboxEl) {\n // Apply width and max-height BEFORE positioning calculations\n this.listboxEl.style.width = this.dropdownWidth;\n\n if (this.maxHeight) {\n this.listboxEl.style.maxHeight = this.maxHeight;\n this.listboxEl.style.overflowY = 'auto';\n }\n\n // Force a reflow to ensure dimensions are calculated\n this.listboxEl.offsetHeight;\n\n computePosition(this.triggerEl, this.listboxEl, {\n placement: this.dropdownPlacement,\n strategy: 'absolute',\n middleware: [offset(12), flip(), shift({ padding: 5 })],\n }).then(({ x, y }) => {\n Object.assign(this.listboxEl.style, {\n left: `${x}px`,\n top: `${y}px`,\n position: 'absolute',\n zIndex: 1000,\n });\n });\n }\n }\n\n private handleInput = (e: Event) => {\n const target = e.target as HTMLInputElement;\n this.value = target.value;\n this.isOpen = true;\n this.filterOptions();\n setTimeout(() => this.openDropdownPositioning(), 0);\n };\n\n private handleInputClick = () => {\n // Open dropdown when input is clicked (but not when tabbed into)\n if (!this.isOpen) {\n this.isOpen = true;\n this.filterOptions();\n setTimeout(() => this.openDropdownPositioning(), 0);\n }\n };\n\n private handleKeyDown = (e: KeyboardEvent) => {\n if (!this.isOpen && (e.key === 'ArrowDown' || e.key === 'ArrowUp' || (e.altKey && e.key === 'ArrowDown'))) {\n e.preventDefault();\n this.isOpen = true;\n this.filterOptions();\n // Set highlighted index immediately for testing\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION');\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n }\n setTimeout(() => {\n this.openDropdownPositioning();\n // For input trigger, keep focus on input and use aria-activedescendant\n // For button trigger, move focus to first option for keyboard navigation\n if (this.trigger === 'input') {\n this.focusFirstOption();\n } else {\n this.focusFirstOptionForArrowKeys();\n }\n }, 0);\n return;\n }\n\n if (!this.isOpen) {\n return;\n }\n\n // Get only the option elements (skip group labels) for navigation\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION') as HTMLOptionElement[];\n\n switch (e.key) {\n case 'ArrowDown':\n e.preventDefault();\n // If no option is highlighted and we have options, start at 0\n if (this.highlightedIndex < 0 && selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n } else {\n this.highlightedIndex = Math.min(this.highlightedIndex + 1, selectableOptions.length - 1);\n }\n this.updateOptionFocus();\n break;\n case 'ArrowUp':\n e.preventDefault();\n // If no option is highlighted and we have options, start at last option\n if (this.highlightedIndex < 0 && selectableOptions.length > 0) {\n this.highlightedIndex = selectableOptions.length - 1;\n } else {\n this.highlightedIndex = Math.max(this.highlightedIndex - 1, 0);\n }\n this.updateOptionFocus();\n break;\n case 'Home':\n e.preventDefault();\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n this.updateOptionFocus();\n }\n break;\n case 'End':\n e.preventDefault();\n if (selectableOptions.length > 0) {\n this.highlightedIndex = selectableOptions.length - 1;\n this.updateOptionFocus();\n }\n break;\n case 'PageDown':\n e.preventDefault();\n if (selectableOptions.length > 0) {\n const nextIndex = Math.min(this.highlightedIndex + 10, selectableOptions.length - 1);\n this.highlightedIndex = nextIndex;\n this.updateOptionFocus();\n }\n break;\n case 'PageUp':\n e.preventDefault();\n if (selectableOptions.length > 0) {\n const prevIndex = Math.max(this.highlightedIndex - 10, 0);\n this.highlightedIndex = prevIndex;\n this.updateOptionFocus();\n }\n break;\n case 'Enter':\n e.preventDefault();\n if (this.highlightedIndex >= 0 && this.highlightedIndex < selectableOptions.length) {\n this.handleOptionClick(selectableOptions[this.highlightedIndex]);\n this.restoreFocusToTrigger();\n }\n break;\n case 'Escape':\n e.preventDefault();\n this.isOpen = false;\n this.highlightedIndex = -1;\n this.isArrowKeyNavigationMode = false; // Reset arrow-key navigation mode\n this.restoreFocusToTrigger();\n break;\n case 'Tab':\n // Allow normal tab behavior to close dropdown and move focus\n this.isOpen = false;\n this.highlightedIndex = -1;\n this.isArrowKeyNavigationMode = false; // Reset arrow-key navigation mode\n break;\n }\n };\n\n /**\n * Sets focus on the native input element.\n */\n @Method()\n async setFocus() {\n if (this.inputEl) {\n this.inputEl.focus();\n } else {\n this.triggerEl?.focus();\n }\n }\n\n /**\n * Focus management helper - moves focus to the first option when dropdown opens\n */\n private focusFirstOption() {\n if (this.isOpen) {\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION');\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n // DON'T focus the option elements - keep focus on trigger and use aria-activedescendant\n // This prevents the focusout event that was closing the dropdown\n // But still call updateOptionFocus for scrolling\n if (this.listboxEl) {\n this.updateOptionFocus();\n }\n }\n }\n }\n\n /**\n * Focus management helper - actually focuses the first option when opened via arrow keys\n */\n private focusFirstOptionForArrowKeys() {\n if (this.isOpen) {\n // Set arrow-key navigation mode\n this.isArrowKeyNavigationMode = true;\n\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION');\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n // For arrow key navigation, actually focus the first option\n if (this.listboxEl) {\n const optionElements = this.listboxEl.querySelectorAll('[role=\"option\"]');\n const firstOption = optionElements[0] as HTMLElement;\n if (firstOption) {\n // Remove tabindex from all options first\n optionElements.forEach(option => {\n (option as HTMLElement).setAttribute('tabindex', '-1');\n });\n // Set tabindex and focus on first option\n firstOption.setAttribute('tabindex', '0');\n firstOption.focus();\n firstOption.scrollIntoView({ block: 'nearest', behavior: 'smooth' });\n }\n }\n // Update aria-activedescendant on trigger\n this.updateAriaActiveDescendant();\n }\n }\n }\n\n // Track if we're in arrow-key navigation mode (focus should move between options)\n private isArrowKeyNavigationMode: boolean = false;\n\n /**\n * Focus management helper - updates visual state and scrolling for the currently highlighted option\n * Note: We don't actually focus the option to prevent focusout events that close the dropdown\n */\n private updateOptionFocus() {\n if (!this.listboxEl || this.highlightedIndex < 0) return;\n\n const optionElements = this.listboxEl.querySelectorAll('[role=\"option\"]');\n const currentOption = optionElements[this.highlightedIndex] as HTMLElement;\n\n if (currentOption) {\n // Check if any option currently has focus OR if we're in arrow-key navigation mode\n const hasOptionFocus = Array.from(optionElements).some(el => el === document.activeElement);\n\n if (hasOptionFocus || this.isArrowKeyNavigationMode) {\n // We're in arrow-key navigation mode, so actually move focus between options\n optionElements.forEach(option => {\n (option as HTMLElement).setAttribute('tabindex', '-1');\n });\n currentOption.setAttribute('tabindex', '0');\n currentOption.focus();\n }\n\n // Always scroll the option into view\n currentOption.scrollIntoView({ block: 'nearest', behavior: 'smooth' });\n }\n\n // Always update aria-activedescendant on the trigger element\n this.updateAriaActiveDescendant();\n }\n\n /**\n * Updates aria-activedescendant on the trigger element\n */\n private updateAriaActiveDescendant() {\n if (this.triggerEl && this.highlightedIndex >= 0) {\n this.triggerEl.setAttribute('aria-activedescendant', `pds-combobox-option-${this.highlightedIndex}`);\n } else if (this.triggerEl) {\n this.triggerEl.removeAttribute('aria-activedescendant');\n }\n }\n\n /**\n * Focus management helper - restores focus to the trigger element\n */\n private restoreFocusToTrigger() {\n setTimeout(() => {\n if (this.inputEl) {\n this.inputEl.focus();\n } else if (this.triggerEl) {\n this.triggerEl.focus();\n }\n }, 0);\n }\n\n /**\n * Gets the value of the currently selected option.\n */\n @Method()\n async getSelectedValue(): Promise<string | null> {\n return this.selectedOption ? this.selectedOption.value : null;\n }\n\n // Event handler for option click\n private onOptionClick = (event: Event) => {\n const idx = Number((event.currentTarget as HTMLElement).getAttribute('data-option-index'));\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION') as HTMLOptionElement[];\n const option = selectableOptions[idx];\n this.handleOptionClick(option);\n };\n\n // Event handler for mouse enter on option\n private onOptionMouseEnter = (event: Event) => {\n const idx = Number((event.currentTarget as HTMLElement).getAttribute('data-option-index'));\n this.highlightedIndex = idx;\n };\n\n // Prevent blur on mousedown\n private onOptionMouseDown = (event: Event) => {\n event.preventDefault();\n };\n\n // Event handler for option keyboard events\n private onOptionKeyDown = (event: KeyboardEvent) => {\n // Delegate to main keyboard handler\n this.handleKeyDown(event);\n };\n\n // Get the label of the selected option\n private get selectedLabel(): string {\n return this.selectedOption ? this.getOptionLabel(this.selectedOption) : '';\n }\n\n // Get the layout content of the selected option for button trigger\n private get selectedLayoutContent(): string {\n return this.selectedOptionLayoutContent;\n }\n\n // Check if selected option has layout\n private get selectedHasLayout(): boolean {\n return this.selectedOption ? this.isOptionLayout(this.selectedOption) : false;\n }\n\n // Handler for button trigger click\n private onButtonTriggerClick = () => {\n this.isOpen = !this.isOpen;\n if (this.isOpen) {\n this.filterOptions();\n // Set highlighted index and prepare for keyboard navigation\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION');\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n // For button trigger, prepare for arrow-key navigation mode\n this.isArrowKeyNavigationMode = true;\n }\n setTimeout(() => this.openDropdownPositioning(), 0);\n } else {\n // Reset navigation mode when closing\n this.isArrowKeyNavigationMode = false;\n }\n };\n\n // Handler for button trigger keyboard events\n private onButtonTriggerKeyDown = (e: KeyboardEvent) => {\n if ((e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown' || e.key === 'ArrowUp') && !this.isOpen) {\n e.preventDefault();\n e.stopPropagation(); // Prevent the event from bubbling and triggering click\n\n this.isOpen = true;\n this.filterOptions();\n // Set highlighted index immediately\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION');\n if (selectableOptions.length > 0) {\n this.highlightedIndex = 0;\n }\n setTimeout(() => {\n this.openDropdownPositioning();\n // For all button trigger keyboard opening, focus the first option so subsequent navigation works\n this.focusFirstOptionForArrowKeys();\n }, 0);\n } else if (e.key === 'Escape') {\n e.preventDefault();\n if (this.isOpen) {\n this.isOpen = false;\n this.highlightedIndex = -1;\n this.updateAriaActiveDescendant(); // Clear aria-activedescendant\n this.restoreFocusToTrigger();\n }\n } else if (this.isOpen) {\n // Delegate other keys to main keyboard handler when dropdown is open\n this.handleKeyDown(e);\n }\n };\n\n // Handler for button trigger keyup events - prevents space key from triggering synthetic click\n private onButtonTriggerKeyUp = (e: KeyboardEvent) => {\n if (e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n }\n };\n\n // Close dropdown when focus leaves the combobox\n private onComboboxFocusOut = (event: FocusEvent) => {\n const relatedTarget = event.relatedTarget as Node | null;\n\n // Check if the related target is within our shadow DOM (listbox options)\n const isRelatedTargetInListbox = relatedTarget && this.listboxEl?.contains(relatedTarget);\n const isRelatedTargetInCombobox = this.el.contains(relatedTarget);\n\n // Don't close if focus is moving to an option in the listbox or staying within the combobox\n if (!isRelatedTargetInCombobox && !isRelatedTargetInListbox) {\n this.isOpen = false;\n this.highlightedIndex = -1;\n this.isArrowKeyNavigationMode = false; // Reset arrow-key navigation mode\n this.updateAriaActiveDescendant(); // Clear aria-activedescendant\n\n // If there's a selected option but the input value doesn't match, restore the selected option's value\n if (this.selectedOption && this.value !== this.getOptionLabel(this.selectedOption)) {\n this.value = this.getOptionLabel(this.selectedOption);\n }\n }\n };\n\n private handleOptionClick(option: HTMLOptionElement) {\n // Update reactive state - single source of truth\n this.setSelectedOption(option);\n\n this.value = this.getOptionLabel(option);\n this.isOpen = false;\n this.pdsComboboxChange.emit({ value: option.value });\n }\n\n private renderDropdown() {\n if (!this.isOpen || this.filteredItems.length === 0) {\n return null;\n }\n\n let optionIndex = 0;\n const selectableOptions = this.filteredItems.filter(item => item.tagName === 'OPTION') as HTMLOptionElement[];\n\n return (\n <ul\n class=\"pds-combobox__listbox\"\n role=\"listbox\"\n id=\"pds-combobox-listbox\"\n aria-label={this.label || 'Options'}\n aria-multiselectable=\"false\"\n ref={el => (this.listboxEl = el as HTMLElement)}\n >\n {this.filteredItems.map((item, itemIdx) => {\n if (item.tagName === 'OPTGROUP') {\n const optgroup = item as HTMLOptGroupElement;\n return (\n <li\n key={`optgroup-${itemIdx}`}\n class=\"pds-combobox__group-label\"\n role=\"presentation\"\n aria-label={optgroup.label}\n >\n {optgroup.label}\n </li>\n );\n } else if (item.tagName === 'PDS-TEXT') {\n const pdsText = item as HTMLPdsTextElement;\n return (\n <li\n key={`pds-text-${itemIdx}`}\n class=\"pds-combobox__group-label\"\n role=\"presentation\"\n >\n {pdsText.textContent}\n </li>\n );\n } else if (item.tagName === 'OPTION') {\n const option = item as HTMLOptionElement;\n const isSelected = this.isOptionSelected(option);\n const isHighlighted = this.highlightedIndex === optionIndex;\n const isLayout = this.isOptionLayout(option);\n const currentOptionIndex = optionIndex++;\n\n return (\n <li\n key={option.value}\n id={`pds-combobox-option-${currentOptionIndex}`}\n role=\"option\"\n aria-selected={isSelected ? 'true' : 'false'}\n aria-setsize={selectableOptions.length}\n aria-posinset={currentOptionIndex + 1}\n aria-label={isLayout ? option.getAttribute('aria-label') || this.getOptionLabel(option) : undefined}\n tabindex={isHighlighted ? '0' : '-1'}\n class={{\n 'pds-combobox__option': true,\n 'pds-combobox__option--highlighted': isHighlighted,\n 'pds-combobox__option--layout': isLayout,\n }}\n data-option-index={currentOptionIndex}\n onMouseDown={this.onOptionMouseDown}\n onClick={this.onOptionClick}\n onMouseEnter={this.onOptionMouseEnter}\n onKeyDown={this.onOptionKeyDown}\n >\n {isLayout ? (\n <pds-box class=\"pds-combobox__option-layout-wrapper\" innerHTML={this.getOptionLayoutContent(option)} />\n ) : (\n this.getOptionLabel(option)\n )}\n {isSelected && <pds-icon icon=\"check\" size=\"regular\" class=\"pds-combobox__option-check\" />}\n </li>\n );\n }\n return null;\n })}\n </ul>\n );\n }\n\n // Helper method to render the caret icon\n private renderCaretIcon() {\n return <pds-icon icon=\"caret-down\" aria-hidden=\"true\" class=\"pds-combobox__button-trigger-chevron\" />;\n }\n\n // Helper method to render layout content\n private renderLayoutContent() {\n return (\n <div class=\"pds-combobox__button-trigger-layout-wrapper\" innerHTML={this.selectedLayoutContent} />\n );\n }\n\n // Helper method to render default text content\n private renderDefaultContent() {\n return (\n <span class=\"pds-combobox__button-trigger-label\">\n {this.selectedLabel || this.placeholder}\n </span>\n );\n }\n\n // Helper method to check if we should show layout content\n private shouldShowLayoutContent(): boolean {\n return this.selectedHasLayout && !!this.selectedLayoutContent;\n }\n\n private renderButtonTriggerContent() {\n // Case 1: Custom trigger content with layout priority\n if (this.customTriggerContent) {\n if (this.shouldShowLayoutContent()) {\n return [this.renderLayoutContent(), this.renderCaretIcon()];\n }\n // Fall back to slot content when no layout is available\n return <slot name=\"trigger-content\" />;\n }\n\n // Case 2: Standard mode with layout content\n if (this.shouldShowLayoutContent()) {\n return [this.renderLayoutContent(), this.renderCaretIcon()];\n }\n\n // Case 3: Standard mode with default text content\n return [this.renderDefaultContent(), this.renderCaretIcon()];\n }\n\n\n\n render() {\n const triggerClass = `pds-combobox__button-trigger pds-combobox__button-trigger--${this.triggerVariant}`;\n return (\n <Host>\n <div class=\"pds-combobox\" tabIndex={-1} onFocusout={this.onComboboxFocusOut}>\n {this.label && (\n <label htmlFor={this.componentId} class=\"pds-combobox__label\">\n <span class={this.hideLabel ? 'visually-hidden' : ''}>{this.label}</span>\n </label>\n )}\n {this.trigger === 'input' ? (\n <div class=\"pds-combobox__input-wrapper\" style={{ width: this.triggerWidth }}>\n <input\n ref={el => {\n this.inputEl = el as HTMLInputElement;\n this.triggerEl = el as HTMLElement;\n }}\n class=\"pds-combobox__input\"\n type=\"text\"\n role=\"combobox\"\n aria-autocomplete=\"list\"\n aria-controls=\"pds-combobox-listbox\"\n aria-activedescendant={this.isOpen && this.highlightedIndex >= 0 ? `pds-combobox-option-${this.highlightedIndex}` : undefined}\n aria-expanded={this.isOpen ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-label={this.hideLabel ? this.label : undefined}\n id={this.componentId}\n value={this.value}\n placeholder={this.placeholder}\n disabled={this.disabled}\n onInput={this.handleInput}\n onClick={this.handleInputClick}\n onKeyDown={this.handleKeyDown}\n autocomplete=\"off\"\n part=\"input\"\n />\n <pds-icon icon=\"enlarge\" aria-hidden=\"true\" class=\"pds-combobox__input-icon\" />\n </div>\n ) : (\n <div\n class={triggerClass}\n style={{ width: this.triggerWidth }}\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"pds-combobox-listbox\"\n aria-activedescendant={this.isOpen && this.highlightedIndex >= 0 ? `pds-combobox-option-${this.highlightedIndex}` : undefined}\n aria-expanded={this.isOpen ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n aria-label={this.hideLabel ? this.label : undefined}\n id={this.componentId}\n tabIndex={this.disabled ? -1 : 0}\n onClick={this.onButtonTriggerClick}\n data-layout={this.customTriggerContent}\n onKeyDown={this.onButtonTriggerKeyDown}\n onKeyUp={this.onButtonTriggerKeyUp}\n ref={el => (this.triggerEl = el as HTMLElement)}\n part=\"button-trigger\"\n >\n {this.renderButtonTriggerContent()}\n </div>\n )}\n {/* Hide the slot so options are not visible */}\n <div style={{ display: 'none' }}>\n <slot onSlotchange={() => this.updateOptions()}></slot>\n </div>\n {this.renderDropdown()}\n </div>\n </Host>\n );\n }\n}\n"]}
@@ -191,4 +191,107 @@ Custom.args = {
191
191
  dropdownWidth: '500px',
192
192
  customTriggerContent: true,
193
193
  customOptionLayouts: true,
194
+ };
195
+
196
+ export const OptionGroupsOptgroup = (args) => html`
197
+ <pds-combobox
198
+ component-id="combobox-optgroups"
199
+ label=${args.label}
200
+ placeholder=${args.placeholder}
201
+ trigger=${args.trigger}
202
+ trigger-variant=${args.triggerVariant}
203
+ mode=${args.mode}
204
+ trigger-width=${args.triggerWidth}
205
+ dropdown-width=${args.dropdownWidth}
206
+ max-height=${args.maxHeight}
207
+ >
208
+ <optgroup label="Mammals">
209
+ <option value="cat">Cat</option>
210
+ <option value="dog">Dog</option>
211
+ <option value="elephant">Elephant</option>
212
+ <option value="whale">Whale</option>
213
+ <option value="dolphin">Dolphin</option>
214
+ <option value="tiger">Tiger</option>
215
+ </optgroup>
216
+ <optgroup label="Birds">
217
+ <option value="eagle">Eagle</option>
218
+ <option value="parrot">Parrot</option>
219
+ <option value="penguin">Penguin</option>
220
+ <option value="owl">Owl</option>
221
+ <option value="falcon">Falcon</option>
222
+ </optgroup>
223
+ <optgroup label="Fish">
224
+ <option value="salmon">Salmon</option>
225
+ <option value="shark">Shark</option>
226
+ <option value="tuna">Tuna</option>
227
+ <option value="goldfish">Goldfish</option>
228
+ </optgroup>
229
+ <optgroup label="Reptiles">
230
+ <option value="snake">Snake</option>
231
+ <option value="lizard">Lizard</option>
232
+ <option value="turtle">Turtle</option>
233
+ <option value="crocodile">Crocodile</option>
234
+ </optgroup>
235
+ </pds-combobox>`;
236
+
237
+ OptionGroupsOptgroup.args = {
238
+ componentId: 'combobox-optgroups',
239
+ label: 'Select Animal',
240
+ placeholder: 'Choose an animal',
241
+ trigger: 'button',
242
+ triggerVariant: 'secondary',
243
+ mode: 'select-only',
244
+ triggerWidth: '280px',
245
+ dropdownWidth: '280px',
246
+ maxHeight: '280px',
247
+ };
248
+
249
+ export const OptionGroupsPdsText = (args) => html`
250
+ <pds-combobox
251
+ component-id="combobox-pds-text-groups"
252
+ label=${args.label}
253
+ placeholder=${args.placeholder}
254
+ trigger=${args.trigger}
255
+ trigger-variant=${args.triggerVariant}
256
+ mode=${args.mode}
257
+ trigger-width=${args.triggerWidth}
258
+ dropdown-width=${args.dropdownWidth}
259
+ max-height=${args.maxHeight}
260
+ >
261
+ <pds-text color="secondary">Frontend Technologies</pds-text>
262
+ <option value="react">React</option>
263
+ <option value="vue">Vue.js</option>
264
+ <option value="angular">Angular</option>
265
+ <option value="svelte">Svelte</option>
266
+ <option value="nextjs">Next.js</option>
267
+
268
+ <pds-text color="secondary">Backend Technologies</pds-text>
269
+ <option value="nodejs">Node.js</option>
270
+ <option value="python">Python</option>
271
+ <option value="java">Java</option>
272
+ <option value="golang">Go</option>
273
+ <option value="rust">Rust</option>
274
+
275
+ <pds-text color="secondary">Databases</pds-text>
276
+ <option value="postgresql">PostgreSQL</option>
277
+ <option value="mongodb">MongoDB</option>
278
+ <option value="mysql">MySQL</option>
279
+ <option value="redis">Redis</option>
280
+
281
+ <pds-text color="secondary">Cloud Services</pds-text>
282
+ <option value="aws">AWS</option>
283
+ <option value="azure">Azure</option>
284
+ <option value="gcp">Google Cloud</option>
285
+ <option value="vercel">Vercel</option>
286
+ </pds-combobox>`;
287
+
288
+ OptionGroupsPdsText.args = {
289
+ componentId: 'combobox-pds-text-groups',
290
+ label: 'Select Technology',
291
+ placeholder: 'Choose a technology',
292
+ trigger: 'input',
293
+ mode: 'filter',
294
+ triggerWidth: '300px',
295
+ dropdownWidth: '300px',
296
+ maxHeight: '280px',
194
297
  };
@@ -1,4 +1,7 @@
1
1
  :host hr {
2
- border: 1px solid var(--pine-color-border);
2
+ border: 0;
3
+ border-top: 1px solid var(--pine-color-border);
4
+ height: 0;
3
5
  margin-block: var(--pine-dimension-xs);
6
+ margin-inline: calc(var(--pine-dimension-xs) * -1);
4
7
  }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=filter-interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-interface.js","sourceRoot":"","sources":["../../../../src/components/pds-filters/pds-filter/filter-interface.ts"],"names":[],"mappings":"","sourcesContent":["export type PdsFilterVariant = 'default' | 'selected' | 'more' | 'clear';\n\nexport interface PdsFilterOpenEventDetail {\n componentId: string;\n variant: PdsFilterVariant;\n text?: string;\n}\n\nexport interface PdsFilterCloseEventDetail {\n componentId: string;\n variant: PdsFilterVariant;\n text?: string;\n}\n\nexport interface PdsFilterClearEventDetail {\n componentId: string;\n text?: string;\n}\n\nexport interface PdsFilterEvent<T> extends CustomEvent<T> {\n readonly detail: T;\n readonly target: HTMLPdsFilterElement | null;\n}\n"]}
@@ -0,0 +1,193 @@
1
+ :host {
2
+ --box-shadow-focus: 0 0 0 1px var(--pine-color-white), 0 0 0 3px var(--pine-color-focus-ring);
3
+ display: inline-block;
4
+ position: relative;
5
+ }
6
+
7
+ .pds-filter__trigger {
8
+ align-items: center;
9
+ /* stylelint-disable-next-line property-no-unknown */
10
+ anchor-name: --filter-trigger;
11
+ background: var(--pine-color-background-container);
12
+ border: var(--pine-border-width-thin) solid var(--pine-color-border);
13
+ border-radius: var(--pine-dimension-100);
14
+ box-shadow: var(--pine-box-shadow-050);
15
+ box-sizing: border-box;
16
+ color: var(--pine-color-text-placeholder);
17
+ cursor: pointer;
18
+ display: inline-flex;
19
+ font-family: var(--pine-font-family-inter);
20
+ font-size: var(--pine-font-size-100);
21
+ font-weight: var(--pine-font-weight-400);
22
+ gap: var(--pine-dimension-050);
23
+ letter-spacing: var(--pine-letter-spacing-114);
24
+ line-height: var(--pine-line-height-150);
25
+ padding: var(--pine-dimension-025) var(--pine-dimension-125);
26
+ position: relative;
27
+ transition: all 0.2s ease;
28
+ }
29
+ .pds-filter__trigger pds-icon {
30
+ block-size: var(--pine-font-size-100);
31
+ color: var(--pine-color-grey-800);
32
+ flex-shrink: 0;
33
+ inline-size: var(--pine-font-size-100);
34
+ }
35
+ .pds-filter__trigger:hover, .pds-filter__trigger.pds-filter__trigger--open {
36
+ background-color: var(--pine-color-grey-100);
37
+ border-color: var(--pine-color-grey-400);
38
+ color: var(--pine-color-text-hover);
39
+ }
40
+ .pds-filter__trigger:hover pds-icon, .pds-filter__trigger.pds-filter__trigger--open pds-icon {
41
+ color: var(--pine-color-grey-800);
42
+ }
43
+ .pds-filter__trigger:focus-visible {
44
+ box-shadow: var(--box-shadow-focus);
45
+ outline: none;
46
+ }
47
+ .pds-filter__trigger:disabled {
48
+ cursor: not-allowed;
49
+ opacity: 0.5;
50
+ }
51
+
52
+ .pds-filter__trigger--selected {
53
+ background-color: var(--pine-color-purple-050);
54
+ border-color: var(--pine-color-purple-500);
55
+ color: var(--pine-color-purple-600);
56
+ }
57
+ .pds-filter__trigger--selected pds-icon {
58
+ color: var(--pine-color-purple-600);
59
+ }
60
+ .pds-filter__trigger--selected:hover, .pds-filter__trigger--selected.pds-filter__trigger--open {
61
+ background-color: var(--pine-color-purple-100);
62
+ border-color: var(--pine-color-purple-500);
63
+ color: var(--pine-color-purple-600);
64
+ }
65
+ .pds-filter__trigger--selected:hover pds-icon, .pds-filter__trigger--selected.pds-filter__trigger--open pds-icon {
66
+ color: var(--pine-color-purple-600);
67
+ }
68
+ .pds-filter__trigger--selected:focus-visible {
69
+ box-shadow: var(--box-shadow-focus);
70
+ outline: none;
71
+ }
72
+
73
+ .pds-filter__trigger--more {
74
+ background-color: var(--pine-color-grey-050);
75
+ border: var(--pine-border-width-thin) dashed var(--pine-color-grey-300);
76
+ color: var(--pine-color-text-placeholder);
77
+ }
78
+ .pds-filter__trigger--more pds-icon {
79
+ color: var(--pine-color-grey-800);
80
+ }
81
+ .pds-filter__trigger--more:hover, .pds-filter__trigger--more.pds-filter__trigger--open {
82
+ background-color: var(--pine-color-grey-100);
83
+ border-color: var(--pine-color-grey-400);
84
+ color: var(--pine-color-text-hover);
85
+ }
86
+ .pds-filter__trigger--more:hover pds-icon, .pds-filter__trigger--more.pds-filter__trigger--open pds-icon {
87
+ color: var(--pine-color-grey-800);
88
+ }
89
+ .pds-filter__trigger--more:focus-visible {
90
+ box-shadow: var(--box-shadow-focus);
91
+ outline: none;
92
+ }
93
+
94
+ .pds-filter__trigger--clear {
95
+ background: transparent;
96
+ border: var(--pine-border-width-thin) solid transparent;
97
+ border-radius: var(--pine-dimension-100);
98
+ box-shadow: none;
99
+ color: var(--pine-color-purple-600);
100
+ }
101
+ .pds-filter__trigger--clear pds-icon {
102
+ color: var(--pine-color-purple-600);
103
+ }
104
+ .pds-filter__trigger--clear:hover {
105
+ background-color: var(--pine-color-purple-100);
106
+ border-color: var(--pine-color-purple-100);
107
+ color: var(--pine-color-purple-600);
108
+ }
109
+ .pds-filter__trigger--clear:hover pds-icon {
110
+ color: var(--pine-color-purple-600);
111
+ }
112
+ .pds-filter__trigger--clear:focus-visible {
113
+ box-shadow: var(--box-shadow-focus);
114
+ outline: none;
115
+ }
116
+
117
+ .pds-filter__button-content {
118
+ align-items: center;
119
+ display: inline-flex;
120
+ gap: var(--pine-dimension-050);
121
+ max-inline-size: 148px;
122
+ overflow: hidden;
123
+ text-overflow: ellipsis;
124
+ white-space: nowrap;
125
+ }
126
+
127
+ .pds-filter__button-text {
128
+ line-height: var(--pine-line-height-150);
129
+ overflow: hidden;
130
+ text-overflow: ellipsis;
131
+ white-space: nowrap;
132
+ }
133
+
134
+ .pds-filter__dropdown-icon {
135
+ block-size: var(--pine-dimension-200);
136
+ flex-shrink: 0;
137
+ inline-size: var(--pine-dimension-200);
138
+ }
139
+
140
+ .pds-filter__popover {
141
+ background-color: var(--pine-color-background-container);
142
+ border: 0;
143
+ border-radius: var(--pine-dimension-100);
144
+ box-shadow: var(--pine-box-shadow-100);
145
+ display: none;
146
+ inline-size: 228px;
147
+ inset: unset;
148
+ padding: var(--pine-dimension-100);
149
+ z-index: 1000;
150
+ /* stylelint-disable-next-line selector-pseudo-class-no-unknown */
151
+ /* Modern browsers: CSS anchor positioning with JavaScript-controlled flipping */
152
+ }
153
+ .pds-filter__popover:popover-open, .pds-filter__popover.is-open {
154
+ display: block;
155
+ }
156
+ @supports (anchor-name: --test) {
157
+ .pds-filter__popover {
158
+ inset-block-start: calc(anchor(--filter-trigger bottom) + var(--pine-dimension-100));
159
+ inset-inline-start: anchor(--filter-trigger left);
160
+ position: fixed; /* Anchor positioning requires fixed positioning */
161
+ /* stylelint-disable-next-line property-no-unknown */
162
+ position-anchor: --filter-trigger;
163
+ /* CSS position-try disabled for precise JavaScript-controlled flipping */
164
+ /* Flipping classes applied by JavaScript for precise control */
165
+ /* Ensure fallback class works with flipping in modern browsers */
166
+ }
167
+ .pds-filter__popover.popover-flip-horizontal {
168
+ inset-inline-start: anchor(--filter-trigger right);
169
+ transform: translateX(-100%);
170
+ }
171
+ .pds-filter__popover.popover-flip-vertical {
172
+ inset-block-start: anchor(--filter-trigger top);
173
+ transform: translateY(calc(-100% - var(--pine-dimension-100)));
174
+ }
175
+ .pds-filter__popover.popover-flip-horizontal.popover-flip-vertical {
176
+ inset-block-start: anchor(--filter-trigger top);
177
+ inset-inline-start: anchor(--filter-trigger right);
178
+ transform: translate(-100%, calc(-100% - var(--pine-dimension-100)));
179
+ }
180
+ .pds-filter__popover.is-open.popover-flip-horizontal {
181
+ inset-inline-start: anchor(--filter-trigger right);
182
+ transform: translateX(-100%);
183
+ }
184
+ .pds-filter__popover.is-open.popover-flip-vertical {
185
+ inset-block-start: anchor(--filter-trigger top);
186
+ transform: translateY(calc(-100% - var(--pine-dimension-100)));
187
+ }
188
+ .pds-filter__popover.is-open.popover-flip-horizontal.popover-flip-vertical {
189
+ inset-block-start: anchor(--filter-trigger top);
190
+ inset-inline-start: anchor(--filter-trigger right);
191
+ transform: translate(-100%, calc(-100% - var(--pine-dimension-100)));
192
+ }
193
+ }