@helixui/library 1.0.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (483) hide show
  1. package/custom-elements.json +1901 -8476
  2. package/dist/components/hx-accordion/hx-accordion-item.d.ts +27 -0
  3. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  4. package/dist/components/hx-accordion/hx-accordion.d.ts +3 -0
  5. package/dist/components/hx-accordion/hx-accordion.d.ts.map +1 -1
  6. package/dist/components/hx-accordion/index.js +1 -1
  7. package/dist/components/hx-action-bar/hx-action-bar.d.ts +13 -3
  8. package/dist/components/hx-action-bar/hx-action-bar.d.ts.map +1 -1
  9. package/dist/components/hx-action-bar/index.js +1 -1
  10. package/dist/components/hx-alert/hx-alert.d.ts +30 -0
  11. package/dist/components/hx-alert/hx-alert.d.ts.map +1 -1
  12. package/dist/components/hx-alert/hx-alert.styles.d.ts.map +1 -1
  13. package/dist/components/hx-alert/index.js +1 -1
  14. package/dist/components/hx-avatar/hx-avatar.d.ts +8 -1
  15. package/dist/components/hx-avatar/hx-avatar.d.ts.map +1 -1
  16. package/dist/components/hx-avatar/index.js +1 -1
  17. package/dist/components/hx-badge/hx-badge.d.ts +10 -1
  18. package/dist/components/hx-badge/hx-badge.d.ts.map +1 -1
  19. package/dist/components/hx-badge/hx-badge.styles.d.ts.map +1 -1
  20. package/dist/components/hx-badge/index.js +1 -1
  21. package/dist/components/hx-banner/hx-banner.d.ts +17 -0
  22. package/dist/components/hx-banner/hx-banner.d.ts.map +1 -1
  23. package/dist/components/hx-banner/index.js +1 -1
  24. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.styles.d.ts.map +1 -1
  25. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +17 -2
  26. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  27. package/dist/components/hx-breadcrumb/index.js +1 -1
  28. package/dist/components/hx-button/hx-button.d.ts +6 -0
  29. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  30. package/dist/components/hx-button/hx-button.styles.d.ts.map +1 -1
  31. package/dist/components/hx-button/index.js +1 -1
  32. package/dist/components/hx-card/hx-card.d.ts +8 -0
  33. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  34. package/dist/components/hx-card/hx-card.styles.d.ts.map +1 -1
  35. package/dist/components/hx-card/index.js +1 -1
  36. package/dist/components/hx-carousel/hx-carousel-item.d.ts +2 -0
  37. package/dist/components/hx-carousel/hx-carousel-item.d.ts.map +1 -1
  38. package/dist/components/hx-carousel/hx-carousel-item.styles.d.ts +2 -0
  39. package/dist/components/hx-carousel/hx-carousel-item.styles.d.ts.map +1 -0
  40. package/dist/components/hx-carousel/hx-carousel.d.ts +27 -0
  41. package/dist/components/hx-carousel/hx-carousel.d.ts.map +1 -1
  42. package/dist/components/hx-carousel/hx-carousel.styles.d.ts.map +1 -1
  43. package/dist/components/hx-carousel/index.js +1 -1
  44. package/dist/components/hx-checkbox/hx-checkbox.d.ts +18 -2
  45. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  46. package/dist/components/hx-checkbox/hx-checkbox.styles.d.ts.map +1 -1
  47. package/dist/components/hx-checkbox/index.js +1 -1
  48. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +20 -4
  49. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  50. package/dist/components/hx-checkbox-group/index.js +1 -1
  51. package/dist/components/hx-code-snippet/hx-code-snippet.d.ts +10 -0
  52. package/dist/components/hx-code-snippet/hx-code-snippet.d.ts.map +1 -1
  53. package/dist/components/hx-code-snippet/hx-code-snippet.styles.d.ts.map +1 -1
  54. package/dist/components/hx-code-snippet/index.js +1 -1
  55. package/dist/components/hx-color-picker/hx-color-picker.d.ts +114 -12
  56. package/dist/components/hx-color-picker/hx-color-picker.d.ts.map +1 -1
  57. package/dist/components/hx-color-picker/hx-color-picker.styles.d.ts.map +1 -1
  58. package/dist/components/hx-color-picker/index.js +1 -1
  59. package/dist/components/hx-combobox/hx-combobox.d.ts +37 -2
  60. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  61. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  62. package/dist/components/hx-combobox/index.js +1 -1
  63. package/dist/components/hx-copy-button/hx-copy-button.d.ts +11 -0
  64. package/dist/components/hx-copy-button/hx-copy-button.d.ts.map +1 -1
  65. package/dist/components/hx-copy-button/index.js +1 -1
  66. package/dist/components/hx-counter/hx-counter.d.ts +12 -3
  67. package/dist/components/hx-counter/hx-counter.d.ts.map +1 -1
  68. package/dist/components/hx-counter/index.js +1 -1
  69. package/dist/components/hx-data-table/hx-data-table.d.ts +27 -2
  70. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  71. package/dist/components/hx-data-table/hx-data-table.styles.d.ts.map +1 -1
  72. package/dist/components/hx-data-table/index.js +1 -1
  73. package/dist/components/hx-date-picker/hx-date-picker.d.ts +42 -3
  74. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  75. package/dist/components/hx-date-picker/hx-date-picker.styles.d.ts.map +1 -1
  76. package/dist/components/hx-date-picker/index.js +1 -1
  77. package/dist/components/hx-dialog/hx-dialog.d.ts +31 -4
  78. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  79. package/dist/components/hx-dialog/hx-dialog.styles.d.ts.map +1 -1
  80. package/dist/components/hx-dialog/index.js +1 -1
  81. package/dist/components/hx-divider/hx-divider.d.ts +4 -1
  82. package/dist/components/hx-divider/hx-divider.d.ts.map +1 -1
  83. package/dist/components/hx-divider/index.js +1 -1
  84. package/dist/components/hx-drawer/hx-drawer.d.ts +25 -3
  85. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  86. package/dist/components/hx-drawer/hx-drawer.styles.d.ts.map +1 -1
  87. package/dist/components/hx-drawer/index.js +1 -1
  88. package/dist/components/hx-dropdown/hx-dropdown.d.ts +35 -7
  89. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  90. package/dist/components/hx-dropdown/index.js +1 -1
  91. package/dist/components/hx-field/hx-field.d.ts +10 -2
  92. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  93. package/dist/components/hx-field/index.js +1 -1
  94. package/dist/components/hx-file-upload/hx-file-upload.d.ts +39 -2
  95. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  96. package/dist/components/hx-file-upload/hx-file-upload.styles.d.ts.map +1 -1
  97. package/dist/components/hx-file-upload/index.js +1 -1
  98. package/dist/components/hx-form/hx-form.d.ts.map +1 -1
  99. package/dist/components/hx-form/index.js +1 -1
  100. package/dist/components/hx-format-date/hx-format-date.d.ts +8 -0
  101. package/dist/components/hx-format-date/hx-format-date.d.ts.map +1 -1
  102. package/dist/components/hx-format-date/index.js +1 -1
  103. package/dist/components/hx-grid/hx-grid.d.ts +9 -3
  104. package/dist/components/hx-grid/hx-grid.d.ts.map +1 -1
  105. package/dist/components/hx-grid/index.js +1 -1
  106. package/dist/components/hx-help-text/index.js +1 -1
  107. package/dist/components/hx-icon/hx-icon.d.ts +10 -2
  108. package/dist/components/hx-icon/hx-icon.d.ts.map +1 -1
  109. package/dist/components/hx-icon/index.js +1 -1
  110. package/dist/components/hx-icon-button/hx-icon-button.d.ts +11 -0
  111. package/dist/components/hx-icon-button/hx-icon-button.d.ts.map +1 -1
  112. package/dist/components/hx-icon-button/hx-icon-button.styles.d.ts.map +1 -1
  113. package/dist/components/hx-icon-button/index.js +1 -1
  114. package/dist/components/hx-image/hx-image.d.ts +8 -0
  115. package/dist/components/hx-image/hx-image.d.ts.map +1 -1
  116. package/dist/components/hx-image/index.js +1 -1
  117. package/dist/components/hx-link/hx-link.d.ts +3 -0
  118. package/dist/components/hx-link/hx-link.d.ts.map +1 -1
  119. package/dist/components/hx-link/hx-link.styles.d.ts.map +1 -1
  120. package/dist/components/hx-link/index.js +1 -1
  121. package/dist/components/hx-list/hx-list-item.d.ts +8 -2
  122. package/dist/components/hx-list/hx-list-item.d.ts.map +1 -1
  123. package/dist/components/hx-list/hx-list-item.styles.d.ts.map +1 -1
  124. package/dist/components/hx-list/hx-list.d.ts +6 -2
  125. package/dist/components/hx-list/hx-list.d.ts.map +1 -1
  126. package/dist/components/hx-list/index.js +1 -1
  127. package/dist/components/hx-menu/hx-menu-item.d.ts +12 -0
  128. package/dist/components/hx-menu/hx-menu-item.d.ts.map +1 -1
  129. package/dist/components/hx-menu/hx-menu-item.styles.d.ts.map +1 -1
  130. package/dist/components/hx-menu/hx-menu.d.ts +11 -1
  131. package/dist/components/hx-menu/hx-menu.d.ts.map +1 -1
  132. package/dist/components/hx-menu/index.js +1 -1
  133. package/dist/components/hx-meter/hx-meter.d.ts +9 -0
  134. package/dist/components/hx-meter/hx-meter.d.ts.map +1 -1
  135. package/dist/components/hx-meter/hx-meter.styles.d.ts.map +1 -1
  136. package/dist/components/hx-meter/index.js +1 -1
  137. package/dist/components/hx-nav/hx-nav.d.ts +15 -0
  138. package/dist/components/hx-nav/hx-nav.d.ts.map +1 -1
  139. package/dist/components/hx-nav/hx-nav.styles.d.ts.map +1 -1
  140. package/dist/components/hx-nav/index.js +1 -1
  141. package/dist/components/hx-number-input/hx-number-input.d.ts +36 -1
  142. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  143. package/dist/components/hx-number-input/index.js +1 -1
  144. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts +15 -0
  145. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts.map +1 -1
  146. package/dist/components/hx-overflow-menu/hx-overflow-menu.styles.d.ts.map +1 -1
  147. package/dist/components/hx-overflow-menu/index.js +1 -1
  148. package/dist/components/hx-pagination/hx-pagination.d.ts +24 -0
  149. package/dist/components/hx-pagination/hx-pagination.d.ts.map +1 -1
  150. package/dist/components/hx-pagination/hx-pagination.styles.d.ts.map +1 -1
  151. package/dist/components/hx-pagination/index.js +1 -1
  152. package/dist/components/hx-popover/hx-popover.d.ts +94 -11
  153. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  154. package/dist/components/hx-popover/hx-popover.styles.d.ts.map +1 -1
  155. package/dist/components/hx-popover/index.js +1 -1
  156. package/dist/components/hx-popup/hx-popup.d.ts +8 -0
  157. package/dist/components/hx-popup/hx-popup.d.ts.map +1 -1
  158. package/dist/components/hx-popup/hx-popup.styles.d.ts.map +1 -1
  159. package/dist/components/hx-popup/index.js +1 -1
  160. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +10 -2
  161. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  162. package/dist/components/hx-progress-bar/hx-progress-bar.styles.d.ts.map +1 -1
  163. package/dist/components/hx-progress-bar/index.js +1 -1
  164. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts +8 -2
  165. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts.map +1 -1
  166. package/dist/components/hx-progress-ring/index.js +1 -1
  167. package/dist/components/hx-prose/hx-prose.d.ts +5 -3
  168. package/dist/components/hx-prose/hx-prose.d.ts.map +1 -1
  169. package/dist/components/hx-prose/index.js +1 -1
  170. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  171. package/dist/components/hx-radio-group/hx-radio.d.ts +4 -2
  172. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  173. package/dist/components/hx-radio-group/index.js +1 -1
  174. package/dist/components/hx-rating/hx-rating.d.ts +54 -2
  175. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  176. package/dist/components/hx-rating/index.js +1 -1
  177. package/dist/components/hx-select/hx-select.d.ts +22 -2
  178. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  179. package/dist/components/hx-select/hx-select.styles.d.ts.map +1 -1
  180. package/dist/components/hx-select/index.js +1 -1
  181. package/dist/components/hx-side-nav/hx-nav-item.d.ts +6 -0
  182. package/dist/components/hx-side-nav/hx-nav-item.d.ts.map +1 -1
  183. package/dist/components/hx-side-nav/hx-nav-item.styles.d.ts.map +1 -1
  184. package/dist/components/hx-side-nav/hx-side-nav.d.ts +6 -1
  185. package/dist/components/hx-side-nav/hx-side-nav.d.ts.map +1 -1
  186. package/dist/components/hx-side-nav/hx-side-nav.styles.d.ts.map +1 -1
  187. package/dist/components/hx-side-nav/index.js +1 -1
  188. package/dist/components/hx-slider/hx-slider.d.ts +22 -1
  189. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  190. package/dist/components/hx-slider/hx-slider.styles.d.ts.map +1 -1
  191. package/dist/components/hx-slider/index.js +1 -1
  192. package/dist/components/hx-spinner/hx-spinner.d.ts +3 -1
  193. package/dist/components/hx-spinner/hx-spinner.d.ts.map +1 -1
  194. package/dist/components/hx-spinner/index.js +1 -1
  195. package/dist/components/hx-split-button/hx-split-button.d.ts +12 -0
  196. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  197. package/dist/components/hx-split-button/index.js +1 -1
  198. package/dist/components/hx-split-panel/hx-split-panel.d.ts +72 -13
  199. package/dist/components/hx-split-panel/hx-split-panel.d.ts.map +1 -1
  200. package/dist/components/hx-split-panel/hx-split-panel.styles.d.ts.map +1 -1
  201. package/dist/components/hx-split-panel/index.js +1 -1
  202. package/dist/components/hx-stack/index.js +1 -1
  203. package/dist/components/hx-stat/hx-stat.d.ts +5 -1
  204. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -1
  205. package/dist/components/hx-stat/index.js +1 -1
  206. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts +13 -12
  207. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts.map +1 -1
  208. package/dist/components/hx-status-indicator/index.js +1 -1
  209. package/dist/components/hx-steps/hx-step.d.ts +7 -9
  210. package/dist/components/hx-steps/hx-step.d.ts.map +1 -1
  211. package/dist/components/hx-steps/hx-step.styles.d.ts.map +1 -1
  212. package/dist/components/hx-steps/hx-steps.d.ts +3 -3
  213. package/dist/components/hx-steps/hx-steps.d.ts.map +1 -1
  214. package/dist/components/hx-steps/index.js +1 -1
  215. package/dist/components/hx-switch/hx-switch.d.ts +21 -1
  216. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  217. package/dist/components/hx-switch/index.js +1 -1
  218. package/dist/components/hx-table/hx-table.d.ts +7 -2
  219. package/dist/components/hx-table/hx-table.d.ts.map +1 -1
  220. package/dist/components/hx-table/hx-table.styles.d.ts.map +1 -1
  221. package/dist/components/hx-table/hx-th.d.ts +4 -0
  222. package/dist/components/hx-table/hx-th.d.ts.map +1 -1
  223. package/dist/components/hx-table/index.js +1 -1
  224. package/dist/components/hx-tabs/hx-tab.d.ts +3 -0
  225. package/dist/components/hx-tabs/hx-tab.d.ts.map +1 -1
  226. package/dist/components/hx-tabs/hx-tabs.d.ts +6 -0
  227. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  228. package/dist/components/hx-tabs/index.js +1 -1
  229. package/dist/components/hx-tag/hx-tag.d.ts +4 -0
  230. package/dist/components/hx-tag/hx-tag.d.ts.map +1 -1
  231. package/dist/components/hx-tag/hx-tag.styles.d.ts.map +1 -1
  232. package/dist/components/hx-tag/index.js +1 -1
  233. package/dist/components/hx-text/hx-text.d.ts +1 -0
  234. package/dist/components/hx-text/hx-text.d.ts.map +1 -1
  235. package/dist/components/hx-text/index.js +1 -1
  236. package/dist/components/hx-text-input/hx-text-input.d.ts +9 -4
  237. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  238. package/dist/components/hx-text-input/index.js +1 -1
  239. package/dist/components/hx-textarea/hx-textarea.d.ts +9 -3
  240. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  241. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  242. package/dist/components/hx-textarea/index.js +1 -1
  243. package/dist/components/hx-theme/hx-theme.d.ts +2 -2
  244. package/dist/components/hx-theme/hx-theme.d.ts.map +1 -1
  245. package/dist/components/hx-time-picker/hx-time-picker.d.ts +102 -22
  246. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  247. package/dist/components/hx-time-picker/hx-time-picker.styles.d.ts.map +1 -1
  248. package/dist/components/hx-time-picker/index.js +1 -1
  249. package/dist/components/hx-toast/hx-toast.d.ts +18 -0
  250. package/dist/components/hx-toast/hx-toast.d.ts.map +1 -1
  251. package/dist/components/hx-toast/hx-toast.styles.d.ts.map +1 -1
  252. package/dist/components/hx-toast/index.js +1 -1
  253. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +23 -0
  254. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  255. package/dist/components/hx-toggle-button/index.js +1 -1
  256. package/dist/components/hx-tooltip/hx-tooltip.d.ts +57 -0
  257. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  258. package/dist/components/hx-tooltip/index.js +1 -1
  259. package/dist/components/hx-top-nav/hx-top-nav.d.ts +4 -0
  260. package/dist/components/hx-top-nav/hx-top-nav.d.ts.map +1 -1
  261. package/dist/components/hx-top-nav/index.js +1 -1
  262. package/dist/components/hx-tree-view/hx-tree-item.d.ts +13 -1
  263. package/dist/components/hx-tree-view/hx-tree-item.d.ts.map +1 -1
  264. package/dist/components/hx-tree-view/hx-tree-item.styles.d.ts.map +1 -1
  265. package/dist/components/hx-tree-view/hx-tree-view.d.ts +12 -0
  266. package/dist/components/hx-tree-view/hx-tree-view.d.ts.map +1 -1
  267. package/dist/components/hx-tree-view/index.js +1 -1
  268. package/dist/index.js +70 -70
  269. package/dist/shared/{hx-accordion-Cyswa6J3.js → hx-accordion-D1kFhdeQ.js} +68 -39
  270. package/dist/shared/hx-accordion-D1kFhdeQ.js.map +1 -0
  271. package/dist/shared/{hx-action-bar-we_WJety.js → hx-action-bar-D4bulGQP.js} +38 -31
  272. package/dist/shared/hx-action-bar-D4bulGQP.js.map +1 -0
  273. package/dist/shared/{hx-alert-Cg-zxRiU.js → hx-alert-K5F8KeqI.js} +123 -40
  274. package/dist/shared/hx-alert-K5F8KeqI.js.map +1 -0
  275. package/dist/shared/{hx-avatar-Cep6Urm3.js → hx-avatar-Cun-O99h.js} +5 -1
  276. package/dist/shared/hx-avatar-Cun-O99h.js.map +1 -0
  277. package/dist/shared/{hx-badge-CjT0d8NK.js → hx-badge-CsFd2xtw.js} +83 -47
  278. package/dist/shared/hx-badge-CsFd2xtw.js.map +1 -0
  279. package/dist/shared/{hx-banner-lxAIJ2kR.js → hx-banner-BTV-X2xF.js} +58 -42
  280. package/dist/shared/hx-banner-BTV-X2xF.js.map +1 -0
  281. package/dist/shared/{hx-breadcrumb-item-C0rz0fzV.js → hx-breadcrumb-item-4IwaLgaO.js} +39 -23
  282. package/dist/shared/hx-breadcrumb-item-4IwaLgaO.js.map +1 -0
  283. package/dist/shared/{hx-button-Cbhqpm5i.js → hx-button-7k-KeCYU.js} +29 -15
  284. package/dist/shared/hx-button-7k-KeCYU.js.map +1 -0
  285. package/dist/shared/{hx-card-Bg4W4uXC.js → hx-card-0hT3G5hi.js} +24 -13
  286. package/dist/shared/hx-card-0hT3G5hi.js.map +1 -0
  287. package/dist/shared/{hx-carousel-item-BKpmFbUT.js → hx-carousel-item-DgeYyYZJ.js} +138 -107
  288. package/dist/shared/hx-carousel-item-DgeYyYZJ.js.map +1 -0
  289. package/dist/shared/{hx-checkbox-BMayOpAM.js → hx-checkbox-BvjO-O41.js} +15 -6
  290. package/dist/shared/hx-checkbox-BvjO-O41.js.map +1 -0
  291. package/dist/shared/{hx-checkbox-group-ydUdV9Sx.js → hx-checkbox-group-Z5VvWzcj.js} +50 -37
  292. package/dist/shared/hx-checkbox-group-Z5VvWzcj.js.map +1 -0
  293. package/dist/shared/{hx-code-snippet-B4hV7rWG.js → hx-code-snippet-DqzPkH4K.js} +27 -11
  294. package/dist/shared/hx-code-snippet-DqzPkH4K.js.map +1 -0
  295. package/dist/shared/hx-color-picker-Da8z6AlQ.js +596 -0
  296. package/dist/shared/hx-color-picker-Da8z6AlQ.js.map +1 -0
  297. package/dist/shared/{hx-combobox-BBi3izKJ.js → hx-combobox-CivfelTS.js} +67 -430
  298. package/dist/shared/hx-combobox-CivfelTS.js.map +1 -0
  299. package/dist/shared/{hx-copy-button-CLBA31to.js → hx-copy-button--0dymSvw.js} +9 -1
  300. package/dist/shared/{hx-copy-button-CLBA31to.js.map → hx-copy-button--0dymSvw.js.map} +1 -1
  301. package/dist/shared/{hx-counter-D-1NXzGs.js → hx-counter-Duf00H7p.js} +58 -49
  302. package/dist/shared/hx-counter-Duf00H7p.js.map +1 -0
  303. package/dist/shared/{hx-data-table-DNiDVWR2.js → hx-data-table-DujB9hSE.js} +173 -129
  304. package/dist/shared/hx-data-table-DujB9hSE.js.map +1 -0
  305. package/dist/shared/{hx-date-picker-D7yCK0nk.js → hx-date-picker-C8d2HtRV.js} +142 -505
  306. package/dist/shared/hx-date-picker-C8d2HtRV.js.map +1 -0
  307. package/dist/shared/{hx-dialog-Z7Ou_AZ9.js → hx-dialog-DkUSnVgw.js} +76 -49
  308. package/dist/shared/hx-dialog-DkUSnVgw.js.map +1 -0
  309. package/dist/shared/{hx-divider-XgWIz4Mr.js → hx-divider-DNNs4e8q.js} +2 -1
  310. package/dist/shared/{hx-divider-XgWIz4Mr.js.map → hx-divider-DNNs4e8q.js.map} +1 -1
  311. package/dist/shared/{hx-drawer-Dk-_xzy0.js → hx-drawer-CJcRZcns.js} +102 -66
  312. package/dist/shared/hx-drawer-CJcRZcns.js.map +1 -0
  313. package/dist/shared/{hx-dropdown-DnjLnkTj.js → hx-dropdown-Bo0KTM1A.js} +56 -47
  314. package/dist/shared/hx-dropdown-Bo0KTM1A.js.map +1 -0
  315. package/dist/shared/{hx-field-CDP8EXuj.js → hx-field-3MmzJ4kZ.js} +21 -13
  316. package/dist/shared/hx-field-3MmzJ4kZ.js.map +1 -0
  317. package/dist/shared/{hx-file-upload-CUORgnKc.js → hx-file-upload-ByjAgfNy.js} +131 -86
  318. package/dist/shared/hx-file-upload-ByjAgfNy.js.map +1 -0
  319. package/dist/shared/hx-form-BpS6v3Iu.js +258 -0
  320. package/dist/shared/hx-form-BpS6v3Iu.js.map +1 -0
  321. package/dist/shared/{hx-format-date-BsVr8gpD.js → hx-format-date-BdnWV2kX.js} +7 -1
  322. package/dist/shared/hx-format-date-BdnWV2kX.js.map +1 -0
  323. package/dist/shared/{hx-grid-BsDBCTbt.js → hx-grid-gEjuF0cR.js} +25 -18
  324. package/dist/shared/hx-grid-gEjuF0cR.js.map +1 -0
  325. package/dist/shared/{hx-help-text-DaOPN1iB.js → hx-help-text-BAcEGRUE.js} +2 -2
  326. package/dist/shared/{hx-help-text-DaOPN1iB.js.map → hx-help-text-BAcEGRUE.js.map} +1 -1
  327. package/dist/shared/{hx-icon--xsJztDh.js → hx-icon-CP6OnLoM.js} +6 -1
  328. package/dist/shared/hx-icon-CP6OnLoM.js.map +1 -0
  329. package/dist/shared/{hx-icon-button-C83bCR0K.js → hx-icon-button-DzH_bRtC.js} +53 -29
  330. package/dist/shared/hx-icon-button-DzH_bRtC.js.map +1 -0
  331. package/dist/shared/{hx-image-xyb_tHCR.js → hx-image-C6pGiI6c.js} +6 -1
  332. package/dist/shared/hx-image-C6pGiI6c.js.map +1 -0
  333. package/dist/shared/{hx-link-DfNy_UU8.js → hx-link-Tmk_YPvW.js} +46 -37
  334. package/dist/shared/hx-link-Tmk_YPvW.js.map +1 -0
  335. package/dist/shared/{hx-list-CdRNgeoP.js → hx-list-DwInEX2H.js} +63 -37
  336. package/dist/shared/hx-list-DwInEX2H.js.map +1 -0
  337. package/dist/shared/{hx-menu-divider-11Dp2VfM.js → hx-menu-divider-DR4G_rqw.js} +93 -56
  338. package/dist/shared/hx-menu-divider-DR4G_rqw.js.map +1 -0
  339. package/dist/shared/hx-meter-uXkTZq-W.js +238 -0
  340. package/dist/shared/hx-meter-uXkTZq-W.js.map +1 -0
  341. package/dist/shared/{hx-nav-DSpwWYUX.js → hx-nav-3JsN2Oak.js} +94 -75
  342. package/dist/shared/hx-nav-3JsN2Oak.js.map +1 -0
  343. package/dist/shared/{hx-nav-item-D54-5eUM.js → hx-nav-item-D3EJatzc.js} +40 -16
  344. package/dist/shared/hx-nav-item-D3EJatzc.js.map +1 -0
  345. package/dist/shared/{hx-number-input-BP6TIA92.js → hx-number-input-CAAibZ8X.js} +35 -7
  346. package/dist/shared/hx-number-input-CAAibZ8X.js.map +1 -0
  347. package/dist/shared/{hx-overflow-menu-C7k5wlZy.js → hx-overflow-menu-2kgOJ_ht.js} +86 -66
  348. package/dist/shared/hx-overflow-menu-2kgOJ_ht.js.map +1 -0
  349. package/dist/shared/{hx-pagination-BQ0cLTuB.js → hx-pagination-DBs-vmSv.js} +127 -103
  350. package/dist/shared/hx-pagination-DBs-vmSv.js.map +1 -0
  351. package/dist/shared/hx-popover-DxE67miP.js +274 -0
  352. package/dist/shared/hx-popover-DxE67miP.js.map +1 -0
  353. package/dist/shared/{hx-popup-CYf9Q5sj.js → hx-popup-Dg6n_PbY.js} +13 -1
  354. package/dist/shared/hx-popup-Dg6n_PbY.js.map +1 -0
  355. package/dist/shared/{hx-progress-bar-C_mdPVF-.js → hx-progress-bar-Dm_EHyng.js} +101 -73
  356. package/dist/shared/hx-progress-bar-Dm_EHyng.js.map +1 -0
  357. package/dist/shared/{hx-progress-ring-BHJBaXNk.js → hx-progress-ring-DpxBDD5d.js} +35 -28
  358. package/dist/shared/hx-progress-ring-DpxBDD5d.js.map +1 -0
  359. package/dist/shared/hx-prose-Ml_L2zje.js +59 -0
  360. package/dist/shared/hx-prose-Ml_L2zje.js.map +1 -0
  361. package/dist/shared/{hx-radio-Bqyi8re3.js → hx-radio-BywgVSEu.js} +16 -15
  362. package/dist/shared/hx-radio-BywgVSEu.js.map +1 -0
  363. package/dist/shared/{hx-rating-Y_t7Z4qb.js → hx-rating-CUWBQ0fZ.js} +131 -64
  364. package/dist/shared/hx-rating-CUWBQ0fZ.js.map +1 -0
  365. package/dist/shared/{hx-select-BBae2LqN.js → hx-select-BwDwxk-M.js} +110 -171
  366. package/dist/shared/hx-select-BwDwxk-M.js.map +1 -0
  367. package/dist/shared/hx-skeleton-BHvALyd7.js.map +1 -1
  368. package/dist/shared/{hx-slider-CpnxH2UP.js → hx-slider-D_0EKJyk.js} +25 -8
  369. package/dist/shared/hx-slider-D_0EKJyk.js.map +1 -0
  370. package/dist/shared/{hx-spinner-BOApJ-g9.js → hx-spinner-DMn4SChS.js} +35 -28
  371. package/dist/shared/hx-spinner-DMn4SChS.js.map +1 -0
  372. package/dist/shared/{hx-split-button-BvwoG8h2.js → hx-split-button-CypgLXw1.js} +23 -12
  373. package/dist/shared/{hx-split-button-BvwoG8h2.js.map → hx-split-button-CypgLXw1.js.map} +1 -1
  374. package/dist/shared/{hx-split-panel-Cxkeauwe.js → hx-split-panel-BPMWKPGu.js} +74 -42
  375. package/dist/shared/hx-split-panel-BPMWKPGu.js.map +1 -0
  376. package/dist/shared/{hx-stack-CfoW7jU7.js → hx-stack-BStY1RmV.js} +29 -29
  377. package/dist/shared/hx-stack-BStY1RmV.js.map +1 -0
  378. package/dist/shared/{hx-stat-C2wfph8W.js → hx-stat-CHntLHJM.js} +18 -10
  379. package/dist/shared/hx-stat-CHntLHJM.js.map +1 -0
  380. package/dist/shared/{hx-status-indicator-oYWOkWlD.js → hx-status-indicator-C1BwEvUw.js} +15 -12
  381. package/dist/shared/hx-status-indicator-C1BwEvUw.js.map +1 -0
  382. package/dist/shared/{hx-step-DYoIumpR.js → hx-step-BIVWSPxd.js} +45 -33
  383. package/dist/shared/hx-step-BIVWSPxd.js.map +1 -0
  384. package/dist/shared/{hx-switch-DkKchcuP.js → hx-switch-BgX8kuWt.js} +12 -3
  385. package/dist/shared/hx-switch-BgX8kuWt.js.map +1 -0
  386. package/dist/shared/{hx-tab-panel-CHB0u1zF.js → hx-tab-panel-DhOq67jj.js} +65 -53
  387. package/dist/shared/hx-tab-panel-DhOq67jj.js.map +1 -0
  388. package/dist/shared/{hx-tag-SJJtMlOS.js → hx-tag-CzOTDcXI.js} +81 -55
  389. package/dist/shared/hx-tag-CzOTDcXI.js.map +1 -0
  390. package/dist/shared/{hx-td-CVwCGBYf.js → hx-td-h6oeW6YC.js} +43 -41
  391. package/dist/shared/hx-td-h6oeW6YC.js.map +1 -0
  392. package/dist/shared/{hx-text-NjKoQATI.js → hx-text-DTXjiviE.js} +2 -1
  393. package/dist/shared/{hx-text-NjKoQATI.js.map → hx-text-DTXjiviE.js.map} +1 -1
  394. package/dist/shared/{hx-text-input-BrCjo4fJ.js → hx-text-input-CqEdDHMU.js} +87 -70
  395. package/dist/shared/hx-text-input-CqEdDHMU.js.map +1 -0
  396. package/dist/shared/{hx-textarea-BsQdB1Rk.js → hx-textarea-BgX7rxyo.js} +21 -12
  397. package/dist/shared/hx-textarea-BgX7rxyo.js.map +1 -0
  398. package/dist/shared/hx-theme-6GDoUG8j.js.map +1 -1
  399. package/dist/shared/{hx-time-picker-DRRAFuVd.js → hx-time-picker-DmLu7WUC.js} +77 -274
  400. package/dist/shared/hx-time-picker-DmLu7WUC.js.map +1 -0
  401. package/dist/shared/{hx-toggle-button-D4F1soEM.js → hx-toggle-button-D1jpDvSA.js} +75 -38
  402. package/dist/shared/hx-toggle-button-D1jpDvSA.js.map +1 -0
  403. package/dist/shared/{hx-tooltip-Bk1iQRHs.js → hx-tooltip-kh7QFPKu.js} +66 -49
  404. package/dist/shared/hx-tooltip-kh7QFPKu.js.map +1 -0
  405. package/dist/shared/{hx-top-nav-DzW7XLv-.js → hx-top-nav-DYlnzDaU.js} +4 -2
  406. package/dist/shared/{hx-top-nav-DzW7XLv-.js.map → hx-top-nav-DYlnzDaU.js.map} +1 -1
  407. package/dist/shared/{hx-tree-item-DdH6RbMs.js → hx-tree-item-BP6UF_H1.js} +137 -101
  408. package/dist/shared/hx-tree-item-BP6UF_H1.js.map +1 -0
  409. package/dist/shared/toast-factory-DTy-qN8r.js +521 -0
  410. package/dist/shared/toast-factory-DTy-qN8r.js.map +1 -0
  411. package/dist/styles/shared-field.styles.d.ts +6 -0
  412. package/dist/styles/shared-field.styles.d.ts.map +1 -0
  413. package/package.json +2 -5
  414. package/dist/shared/hx-accordion-Cyswa6J3.js.map +0 -1
  415. package/dist/shared/hx-action-bar-we_WJety.js.map +0 -1
  416. package/dist/shared/hx-alert-Cg-zxRiU.js.map +0 -1
  417. package/dist/shared/hx-avatar-Cep6Urm3.js.map +0 -1
  418. package/dist/shared/hx-badge-CjT0d8NK.js.map +0 -1
  419. package/dist/shared/hx-banner-lxAIJ2kR.js.map +0 -1
  420. package/dist/shared/hx-breadcrumb-item-C0rz0fzV.js.map +0 -1
  421. package/dist/shared/hx-button-Cbhqpm5i.js.map +0 -1
  422. package/dist/shared/hx-card-Bg4W4uXC.js.map +0 -1
  423. package/dist/shared/hx-carousel-item-BKpmFbUT.js.map +0 -1
  424. package/dist/shared/hx-checkbox-BMayOpAM.js.map +0 -1
  425. package/dist/shared/hx-checkbox-group-ydUdV9Sx.js.map +0 -1
  426. package/dist/shared/hx-code-snippet-B4hV7rWG.js.map +0 -1
  427. package/dist/shared/hx-color-picker-BvfJ_h16.js +0 -803
  428. package/dist/shared/hx-color-picker-BvfJ_h16.js.map +0 -1
  429. package/dist/shared/hx-combobox-BBi3izKJ.js.map +0 -1
  430. package/dist/shared/hx-counter-D-1NXzGs.js.map +0 -1
  431. package/dist/shared/hx-data-table-DNiDVWR2.js.map +0 -1
  432. package/dist/shared/hx-date-picker-D7yCK0nk.js.map +0 -1
  433. package/dist/shared/hx-dialog-Z7Ou_AZ9.js.map +0 -1
  434. package/dist/shared/hx-drawer-Dk-_xzy0.js.map +0 -1
  435. package/dist/shared/hx-dropdown-DnjLnkTj.js.map +0 -1
  436. package/dist/shared/hx-field-CDP8EXuj.js.map +0 -1
  437. package/dist/shared/hx-file-upload-CUORgnKc.js.map +0 -1
  438. package/dist/shared/hx-form-BFv_N1dm.js +0 -1272
  439. package/dist/shared/hx-form-BFv_N1dm.js.map +0 -1
  440. package/dist/shared/hx-format-date-BsVr8gpD.js.map +0 -1
  441. package/dist/shared/hx-grid-BsDBCTbt.js.map +0 -1
  442. package/dist/shared/hx-icon--xsJztDh.js.map +0 -1
  443. package/dist/shared/hx-icon-button-C83bCR0K.js.map +0 -1
  444. package/dist/shared/hx-image-xyb_tHCR.js.map +0 -1
  445. package/dist/shared/hx-link-DfNy_UU8.js.map +0 -1
  446. package/dist/shared/hx-list-CdRNgeoP.js.map +0 -1
  447. package/dist/shared/hx-menu-divider-11Dp2VfM.js.map +0 -1
  448. package/dist/shared/hx-meter-UinDQjl6.js +0 -190
  449. package/dist/shared/hx-meter-UinDQjl6.js.map +0 -1
  450. package/dist/shared/hx-nav-DSpwWYUX.js.map +0 -1
  451. package/dist/shared/hx-nav-item-D54-5eUM.js.map +0 -1
  452. package/dist/shared/hx-number-input-BP6TIA92.js.map +0 -1
  453. package/dist/shared/hx-overflow-menu-C7k5wlZy.js.map +0 -1
  454. package/dist/shared/hx-pagination-BQ0cLTuB.js.map +0 -1
  455. package/dist/shared/hx-popover-BQsgrJCW.js +0 -226
  456. package/dist/shared/hx-popover-BQsgrJCW.js.map +0 -1
  457. package/dist/shared/hx-popup-CYf9Q5sj.js.map +0 -1
  458. package/dist/shared/hx-progress-bar-C_mdPVF-.js.map +0 -1
  459. package/dist/shared/hx-progress-ring-BHJBaXNk.js.map +0 -1
  460. package/dist/shared/hx-prose-DZh2KrMb.js +0 -876
  461. package/dist/shared/hx-prose-DZh2KrMb.js.map +0 -1
  462. package/dist/shared/hx-radio-Bqyi8re3.js.map +0 -1
  463. package/dist/shared/hx-rating-Y_t7Z4qb.js.map +0 -1
  464. package/dist/shared/hx-select-BBae2LqN.js.map +0 -1
  465. package/dist/shared/hx-slider-CpnxH2UP.js.map +0 -1
  466. package/dist/shared/hx-spinner-BOApJ-g9.js.map +0 -1
  467. package/dist/shared/hx-split-panel-Cxkeauwe.js.map +0 -1
  468. package/dist/shared/hx-stack-CfoW7jU7.js.map +0 -1
  469. package/dist/shared/hx-stat-C2wfph8W.js.map +0 -1
  470. package/dist/shared/hx-status-indicator-oYWOkWlD.js.map +0 -1
  471. package/dist/shared/hx-step-DYoIumpR.js.map +0 -1
  472. package/dist/shared/hx-switch-DkKchcuP.js.map +0 -1
  473. package/dist/shared/hx-tab-panel-CHB0u1zF.js.map +0 -1
  474. package/dist/shared/hx-tag-SJJtMlOS.js.map +0 -1
  475. package/dist/shared/hx-td-CVwCGBYf.js.map +0 -1
  476. package/dist/shared/hx-text-input-BrCjo4fJ.js.map +0 -1
  477. package/dist/shared/hx-textarea-BsQdB1Rk.js.map +0 -1
  478. package/dist/shared/hx-time-picker-DRRAFuVd.js.map +0 -1
  479. package/dist/shared/hx-toggle-button-D4F1soEM.js.map +0 -1
  480. package/dist/shared/hx-tooltip-Bk1iQRHs.js.map +0 -1
  481. package/dist/shared/hx-tree-item-DdH6RbMs.js.map +0 -1
  482. package/dist/shared/toast-factory-B8jicczW.js +0 -426
  483. package/dist/shared/toast-factory-B8jicczW.js.map +0 -1
@@ -1,10 +1,11 @@
1
- import { css as b, LitElement as m, html as h, nothing as n } from "lit";
2
- import { property as d, state as v, query as _, customElement as y } from "lit/decorators.js";
1
+ import { css as g, LitElement as m, html as h, nothing as n } from "lit";
2
+ import { property as d, state as _, query as x, customElement as y } from "lit/decorators.js";
3
3
  import { classMap as u } from "lit/directives/class-map.js";
4
4
  import { ifDefined as c } from "lit/directives/if-defined.js";
5
- import { tokenStyles as w } from "@helixui/tokens/lit";
6
- import { d as $ } from "./dev-warn-YlwPHjtX.js";
7
- const I = b`
5
+ import { repeat as $ } from "lit/directives/repeat.js";
6
+ import { tokenStyles as I } from "@helixui/tokens/lit";
7
+ import { d as w } from "./dev-warn-YlwPHjtX.js";
8
+ const O = g`
8
9
  :host {
9
10
  display: block;
10
11
  }
@@ -18,8 +19,6 @@ const I = b`
18
19
  box-sizing: border-box;
19
20
  }
20
21
 
21
- /* ─── Field Container ─── */
22
-
23
22
  .field {
24
23
  display: flex;
25
24
  flex-direction: column;
@@ -28,8 +27,6 @@ const I = b`
28
27
  position: relative;
29
28
  }
30
29
 
31
- /* ─── Label ─── */
32
-
33
30
  .field__label {
34
31
  display: flex;
35
32
  align-items: baseline;
@@ -45,21 +42,18 @@ const I = b`
45
42
  font-weight: var(--hx-font-weight-bold, 700);
46
43
  }
47
44
 
48
- /* ─── Select Wrapper ─── */
49
-
50
45
  .field__select-wrapper {
51
46
  position: relative;
52
47
  display: block;
53
48
  }
54
49
 
55
- /* ─── Trigger Button ─── */
56
-
57
50
  .field__trigger {
58
51
  display: flex;
59
52
  align-items: center;
60
53
  justify-content: space-between;
61
54
  gap: var(--hx-space-2, 0.5rem);
62
55
  width: 100%;
56
+ min-height: var(--hx-input-height-md, var(--hx-size-10, 2.5rem));
63
57
  border: var(--hx-border-width-thin, 1px) solid
64
58
  var(--hx-select-border-color, var(--hx-color-neutral-300, #ced4da));
65
59
  border-radius: var(--hx-select-border-radius, var(--hx-border-radius-md, 0.375rem));
@@ -77,58 +71,34 @@ const I = b`
77
71
  outline: none;
78
72
  }
79
73
 
80
- /* Fallback focus ring for environments where :focus-visible is unavailable */
81
- .field__trigger:focus {
82
- border-color: var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
83
- box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
84
- var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
85
- }
86
-
87
- /* Enhanced focus ring with opacity via color-mix when :focus-visible is available */
74
+ .field__trigger:focus,
88
75
  .field__trigger:focus-visible {
89
76
  border-color: var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
90
77
  box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
91
- var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
92
- }
93
-
94
- @supports (color: color-mix(in srgb, red 50%, blue)) {
95
- .field__trigger:focus-visible {
96
- box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
97
- color-mix(
98
- in srgb,
99
- var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb))
100
- calc(var(--hx-focus-ring-opacity, 0.25) * 100%),
101
- transparent
102
- );
103
- }
78
+ color-mix(
79
+ in srgb,
80
+ var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb))
81
+ calc(var(--hx-focus-ring-opacity, 0.25) * 100%),
82
+ transparent
83
+ );
104
84
  }
105
85
 
106
86
  .field__trigger[aria-disabled='true'] {
107
87
  cursor: not-allowed;
108
88
  }
109
89
 
110
- /* ─── Trigger size variants ─── */
111
-
112
90
  .field__trigger--sm {
113
91
  min-height: var(--hx-input-height-sm, var(--hx-size-8, 2rem));
114
92
  font-size: var(--hx-font-size-sm, 0.875rem);
115
93
  padding: var(--hx-space-1, 0.25rem) var(--hx-space-3, 0.75rem);
116
94
  }
117
95
 
118
- .field__trigger--md {
119
- min-height: var(--hx-input-height-md, var(--hx-size-10, 2.5rem));
120
- font-size: var(--hx-font-size-md, 1rem);
121
- padding: var(--hx-space-2, 0.5rem) var(--hx-space-3, 0.75rem);
122
- }
123
-
124
96
  .field__trigger--lg {
125
97
  min-height: var(--hx-input-height-lg, var(--hx-size-12, 3rem));
126
98
  font-size: var(--hx-font-size-lg, 1.125rem);
127
99
  padding: var(--hx-space-3, 0.75rem) var(--hx-space-4, 1rem);
128
100
  }
129
101
 
130
- /* ─── Trigger value ─── */
131
-
132
102
  .field__trigger-value {
133
103
  flex: 1;
134
104
  min-width: 0;
@@ -141,8 +111,6 @@ const I = b`
141
111
  color: var(--hx-select-placeholder-color, var(--hx-color-neutral-400, #adb5bd));
142
112
  }
143
113
 
144
- /* ─── Chevron (CSS-drawn) ─── */
145
-
146
114
  .field__chevron {
147
115
  flex-shrink: 0;
148
116
  width: 12px;
@@ -169,44 +137,22 @@ const I = b`
169
137
  transform: rotate(180deg);
170
138
  }
171
139
 
172
- @media (prefers-reduced-motion: reduce) {
173
- .field__chevron {
174
- transition: none;
175
- }
176
- }
177
-
178
- /* ─── Error State (trigger) ─── */
179
-
180
140
  .field--error .field__trigger {
181
141
  border-color: var(--hx-select-error-color, var(--hx-color-error-500, #dc3545));
182
142
  }
183
143
 
184
- .field--error .field__trigger:focus {
185
- border-color: var(--hx-select-error-color, var(--hx-color-error-500, #dc3545));
186
- box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
187
- var(--hx-select-error-color, var(--hx-color-error-500, #dc3545));
188
- }
189
-
144
+ .field--error .field__trigger:focus,
190
145
  .field--error .field__trigger:focus-visible {
191
146
  border-color: var(--hx-select-error-color, var(--hx-color-error-500, #dc3545));
192
147
  box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
193
- var(--hx-select-error-color, var(--hx-color-error-500, #dc3545));
194
- }
195
-
196
- @supports (color: color-mix(in srgb, red 50%, blue)) {
197
- .field--error .field__trigger:focus-visible {
198
- box-shadow: 0 0 0 var(--hx-focus-ring-width, 2px)
199
- color-mix(
200
- in srgb,
201
- var(--hx-select-error-color, var(--hx-color-error-500, #dc3545))
202
- calc(var(--hx-focus-ring-opacity, 0.25) * 100%),
203
- transparent
204
- );
205
- }
148
+ color-mix(
149
+ in srgb,
150
+ var(--hx-select-error-color, var(--hx-color-error-500, #dc3545))
151
+ calc(var(--hx-focus-ring-opacity, 0.25) * 100%),
152
+ transparent
153
+ );
206
154
  }
207
155
 
208
- /* ─── Listbox Panel ─── */
209
-
210
156
  .field__listbox {
211
157
  position: absolute;
212
158
  top: calc(100% + var(--hx-space-1, 0.25rem));
@@ -231,16 +177,12 @@ const I = b`
231
177
  display: none;
232
178
  }
233
179
 
234
- /* ─── Options Container ─── */
235
-
236
180
  .field__options {
237
181
  overflow-y: auto;
238
182
  flex: 1;
239
183
  padding: var(--hx-space-1, 0.25rem) 0;
240
184
  }
241
185
 
242
- /* ─── Individual Options ─── */
243
-
244
186
  .field__option {
245
187
  display: flex;
246
188
  align-items: center;
@@ -265,8 +207,9 @@ const I = b`
265
207
 
266
208
  .field__option--focused {
267
209
  background-color: var(--hx-select-option-hover-bg, var(--hx-color-primary-50, #eff6ff));
268
- outline: 2px solid var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
269
- outline-offset: -2px;
210
+ outline: var(--hx-focus-ring-width, 2px) solid
211
+ var(--hx-select-focus-ring-color, var(--hx-focus-ring-color, var(--hx-color-primary-500)));
212
+ outline-offset: var(--hx-select-option-focus-ring-offset, -2px);
270
213
  }
271
214
 
272
215
  .field__option--focused.field__option--selected {
@@ -286,8 +229,6 @@ const I = b`
286
229
  text-overflow: ellipsis;
287
230
  }
288
231
 
289
- /* ─── No Options State ─── */
290
-
291
232
  .field__no-options {
292
233
  padding: var(--hx-space-3, 0.75rem);
293
234
  text-align: center;
@@ -295,8 +236,6 @@ const I = b`
295
236
  font-size: var(--hx-font-size-sm, 0.875rem);
296
237
  }
297
238
 
298
- /* ─── Hidden native select (form participation + test compat) ─── */
299
-
300
239
  .field__select {
301
240
  position: absolute;
302
241
  width: 1px;
@@ -307,58 +246,41 @@ const I = b`
307
246
  clip: rect(0, 0, 0, 0);
308
247
  }
309
248
 
310
- /* ─── Size Variants (mirrored on native select for test compat) ─── */
311
-
312
- .field__select--sm {
313
- min-height: var(--hx-input-height-sm, var(--hx-size-8, 2rem));
314
- font-size: var(--hx-font-size-sm, 0.875rem);
315
- }
316
-
317
- .field__select--md {
318
- min-height: var(--hx-input-height-md, var(--hx-size-10, 2.5rem));
319
- font-size: var(--hx-font-size-md, 1rem);
320
- }
321
-
322
- .field__select--lg {
323
- min-height: var(--hx-input-height-lg, var(--hx-size-12, 3rem));
324
- font-size: var(--hx-font-size-lg, 1.125rem);
249
+ .field__help-text,
250
+ .field__error {
251
+ font-size: var(--hx-font-size-xs, 0.75rem);
252
+ line-height: var(--hx-line-height-normal, 1.5);
325
253
  }
326
254
 
327
- /* ─── Help Text & Error Messages ─── */
328
-
329
255
  .field__help-text {
330
- font-size: var(--hx-font-size-xs, 0.75rem);
331
256
  color: var(--hx-color-neutral-500, #6c757d);
332
- line-height: var(--hx-line-height-normal, 1.5);
333
257
  }
334
258
 
335
259
  .field__error {
336
- font-size: var(--hx-font-size-xs, 0.75rem);
337
260
  color: var(--hx-select-error-color, var(--hx-color-error-text, #b91c1c));
338
- line-height: var(--hx-line-height-normal, 1.5);
339
261
  }
340
262
 
341
- /* ─── Reduced Motion ─── */
342
-
343
263
  @media (prefers-reduced-motion: reduce) {
344
264
  .field__trigger,
265
+ .field__chevron,
345
266
  .field__option {
346
267
  transition: none;
347
268
  }
348
269
  }
349
270
  `;
350
- var O = Object.defineProperty, z = Object.getOwnPropertyDescriptor, l = (e, t, a, r) => {
351
- for (var i = r > 1 ? void 0 : r ? z(t, a) : t, s = e.length - 1, f; s >= 0; s--)
352
- (f = e[s]) && (i = (r ? f(t, a, i) : f(i)) || i);
353
- return r && i && O(t, a, i), i;
271
+ var k = Object.defineProperty, C = Object.getOwnPropertyDescriptor, l = (e, t, a, i) => {
272
+ for (var r = i > 1 ? void 0 : i ? C(t, a) : t, s = e.length - 1, f; s >= 0; s--)
273
+ (f = e[s]) && (r = (i ? f(t, a, r) : f(r)) || r);
274
+ return i && r && k(t, a, r), r;
354
275
  };
355
- let k = 0, o = class extends m {
276
+ let z = 0, o = class extends m {
356
277
  constructor() {
357
- super(), this._selectId = `hx-select-${++k}`, this._listboxId = `${this._selectId}-listbox`, this._labelId = `${this._selectId}-label`, this._helpTextId = `${this._selectId}-help`, this._errorId = `${this._selectId}-error`, this.label = "", this.placeholder = "", this.value = "", this.required = !1, this.disabled = !1, this.name = "", this.error = "", this.helpText = "", this.size = "md", this.ariaLabel = null, this.open = !1, this._options = [], this._hasErrorSlot = !1, this._focusedOptionIndex = -1, this._handleOutsideClick = (e) => {
278
+ super(), this._selectId = `hx-select-${++z}`, this._listboxId = `${this._selectId}-listbox`, this._labelId = `${this._selectId}-label`, this._helpTextId = `${this._selectId}-help`, this._errorId = `${this._selectId}-error`, this.label = "", this.placeholder = "", this.value = "", this.required = !1, this.disabled = !1, this.name = "", this.error = "", this.helpText = "", this.size = "md", this.ariaLabel = null, this.open = !1, this._options = [], this._hasErrorSlot = !1, this._focusedOptionIndex = -1, this._handleOutsideClick = (e) => {
358
279
  this.open && !e.composedPath().includes(this) && (this.open = !1);
359
280
  }, this._internals = this.attachInternals();
360
281
  }
361
282
  // ─── Computed helpers ───
283
+ /** @internal */
362
284
  get _displayValue() {
363
285
  if (!this.value) return "";
364
286
  const e = this._options.find((t) => t.value === this.value);
@@ -374,7 +296,7 @@ let k = 0, o = class extends m {
374
296
  updated(e) {
375
297
  if (e.has("value") && (this._syncNativeSelect(), this._updateFormValue(), this._updateValidity()), e.has("size")) {
376
298
  const t = ["sm", "md", "lg"];
377
- t.includes(this.size) || $(
299
+ t.includes(this.size) || w(
378
300
  "hx-select",
379
301
  `Invalid size "${this.size}". Expected one of: ${t.join(", ")}.`
380
302
  );
@@ -401,9 +323,11 @@ let k = 0, o = class extends m {
401
323
  reportValidity() {
402
324
  return this._internals.reportValidity();
403
325
  }
326
+ /** @internal */
404
327
  _updateFormValue() {
405
328
  this._internals.setFormValue(this.value || null);
406
329
  }
330
+ /** @internal */
407
331
  _updateValidity() {
408
332
  this.required && !this.value ? this._internals.setValidity(
409
333
  { valueMissing: !0 },
@@ -424,10 +348,12 @@ let k = 0, o = class extends m {
424
348
  this.disabled = e;
425
349
  }
426
350
  // ─── Native Select Sync ───
351
+ /** @internal */
427
352
  _syncNativeSelect() {
428
353
  this._select && this.value && (this._select.value = this.value);
429
354
  }
430
355
  // ─── Option Syncing from Slot ───
356
+ /** @internal */
431
357
  _parseOption(e) {
432
358
  var t;
433
359
  return { value: e.value, label: ((t = e.textContent) == null ? void 0 : t.trim()) ?? e.value, disabled: e.disabled };
@@ -437,31 +363,34 @@ let k = 0, o = class extends m {
437
363
  * listbox AND clones them into the native <select> for form participation.
438
364
  * Handles both top-level <option> and <optgroup> children.
439
365
  */
366
+ /** @internal */
440
367
  _handleSlotChange() {
441
- var r;
442
- const e = (r = this.shadowRoot) == null ? void 0 : r.querySelector("slot:not([name])");
368
+ var i;
369
+ const e = (i = this.shadowRoot) == null ? void 0 : i.querySelector("slot:not([name])");
443
370
  if (!e) return;
444
371
  const t = [];
445
- this._select && this._select.querySelectorAll("option[data-cloned]").forEach((i) => i.remove());
446
- const a = (i) => {
372
+ this._select && this._select.querySelectorAll("option[data-cloned]").forEach((r) => r.remove());
373
+ const a = (r) => {
447
374
  if (!this._select) return;
448
- const s = i.cloneNode(!0);
375
+ const s = r.cloneNode(!0);
449
376
  s.setAttribute("data-cloned", ""), this._select.appendChild(s);
450
377
  };
451
- for (const i of e.assignedElements({ flatten: !0 }))
452
- if (i instanceof HTMLOptionElement)
453
- t.push(this._parseOption(i)), a(i);
454
- else if (i instanceof HTMLOptGroupElement)
455
- for (const s of Array.from(i.children))
378
+ for (const r of e.assignedElements({ flatten: !0 }))
379
+ if (r instanceof HTMLOptionElement)
380
+ t.push(this._parseOption(r)), a(r);
381
+ else if (r instanceof HTMLOptGroupElement)
382
+ for (const s of Array.from(r.children))
456
383
  s instanceof HTMLOptionElement && (t.push(this._parseOption(s)), a(s));
457
384
  this._options = t, this._select && (this.value ? this._select.value = this.value : !this.placeholder && t.length > 0 && (this.value = this._select.value, this._updateFormValue()));
458
385
  }
459
386
  // ─── Slot Change Handlers ───
387
+ /** @internal */
460
388
  _handleErrorSlotChange(e) {
461
389
  const t = e.target;
462
390
  this._hasErrorSlot = t.assignedNodes({ flatten: !0 }).length > 0;
463
391
  }
464
392
  // ─── Dropdown Control ───
393
+ /** @internal */
465
394
  _toggleDropdown() {
466
395
  if (!this.disabled)
467
396
  if (this.open = !this.open, this.open) {
@@ -471,18 +400,19 @@ let k = 0, o = class extends m {
471
400
  this._focusedOptionIndex = -1;
472
401
  }
473
402
  // ─── Keyboard Navigation ───
403
+ /** @internal */
474
404
  _handleKeydown(e) {
475
405
  var a;
476
406
  if (this.disabled) return;
477
- const t = this._options.map((r, i) => ({ o: r, i })).filter(({ o: r }) => !r.disabled).map(({ i: r }) => r);
407
+ const t = this._options.map((i, r) => ({ o: i, i: r })).filter(({ o: i }) => !i.disabled).map(({ i }) => i);
478
408
  switch (e.key) {
479
409
  case "ArrowDown": {
480
410
  if (e.preventDefault(), !this.open) {
481
411
  this.open = !0, this._focusedOptionIndex = t.length > 0 ? t[0] ?? 0 : 0;
482
412
  break;
483
413
  }
484
- const r = t.find((i) => i > this._focusedOptionIndex);
485
- this._focusedOptionIndex = r !== void 0 ? r : t[0] ?? this._focusedOptionIndex;
414
+ const i = t.find((r) => r > this._focusedOptionIndex);
415
+ this._focusedOptionIndex = i !== void 0 ? i : t[0] ?? this._focusedOptionIndex;
486
416
  break;
487
417
  }
488
418
  case "ArrowUp": {
@@ -492,8 +422,8 @@ let k = 0, o = class extends m {
492
422
  this._focusedOptionIndex = s !== void 0 ? s : 0;
493
423
  break;
494
424
  }
495
- const r = [...t].reverse().find((s) => s < this._focusedOptionIndex), i = t[t.length - 1];
496
- this._focusedOptionIndex = r !== void 0 ? r : i ?? this._focusedOptionIndex;
425
+ const i = [...t].reverse().find((s) => s < this._focusedOptionIndex), r = t[t.length - 1];
426
+ this._focusedOptionIndex = i !== void 0 ? i : r ?? this._focusedOptionIndex;
497
427
  break;
498
428
  }
499
429
  case "Home": {
@@ -502,21 +432,21 @@ let k = 0, o = class extends m {
502
432
  }
503
433
  case "End": {
504
434
  e.preventDefault(), this.open || (this.open = !0);
505
- const r = t[t.length - 1];
506
- this._focusedOptionIndex = r !== void 0 ? r : 0;
435
+ const i = t[t.length - 1];
436
+ this._focusedOptionIndex = i !== void 0 ? i : 0;
507
437
  break;
508
438
  }
509
439
  case "Enter":
510
440
  case " ": {
511
441
  if (e.preventDefault(), !this.open) {
512
442
  this.open = !0;
513
- const r = this._options.findIndex((i) => i.value === this.value);
514
- this._focusedOptionIndex = r >= 0 ? r : t[0] ?? 0;
443
+ const i = this._options.findIndex((r) => r.value === this.value);
444
+ this._focusedOptionIndex = i >= 0 ? i : t[0] ?? 0;
515
445
  break;
516
446
  }
517
447
  if (this._focusedOptionIndex >= 0 && this._focusedOptionIndex < this._options.length) {
518
- const r = this._options[this._focusedOptionIndex];
519
- r && this._selectOption(r);
448
+ const i = this._options[this._focusedOptionIndex];
449
+ i && this._selectOption(i);
520
450
  }
521
451
  break;
522
452
  }
@@ -530,18 +460,20 @@ let k = 0, o = class extends m {
530
460
  }
531
461
  default: {
532
462
  if (!e.ctrlKey && !e.metaKey && !e.altKey && e.key.length === 1) {
533
- const r = e.key.toLowerCase(), i = this.open ? this._focusedOptionIndex + 1 : 0, s = this._options.map((p, g) => ({ o: p, i: g })).filter(({ o: p }) => !p.disabled && p.label.toLowerCase().startsWith(r)), x = s.find(({ i: p }) => p >= i) ?? s[0];
534
- x && (this.open || (this.open = !0), this._focusedOptionIndex = x.i, e.preventDefault());
463
+ const i = e.key.toLowerCase(), r = this.open ? this._focusedOptionIndex + 1 : 0, s = this._options.map((p, b) => ({ o: p, i: b })).filter(({ o: p }) => !p.disabled && p.label.toLowerCase().startsWith(i)), v = s.find(({ i: p }) => p >= r) ?? s[0];
464
+ v && (this.open || (this.open = !0), this._focusedOptionIndex = v.i, e.preventDefault());
535
465
  }
536
466
  break;
537
467
  }
538
468
  }
539
469
  }
540
470
  // ─── Selection ───
471
+ /** @internal */
541
472
  _selectOption(e) {
542
473
  e.disabled || (this.value = e.value, this._dispatchChange(), this.open = !1, this._focusedOptionIndex = -1);
543
474
  }
544
475
  // ─── Event Dispatchers ───
476
+ /** @internal */
545
477
  _dispatchChange() {
546
478
  this.dispatchEvent(
547
479
  new CustomEvent("hx-change", {
@@ -551,6 +483,7 @@ let k = 0, o = class extends m {
551
483
  })
552
484
  );
553
485
  }
486
+ /** @internal */
554
487
  _handleNativeChange(e) {
555
488
  this.value = e.target.value, this._dispatchChange();
556
489
  }
@@ -561,31 +494,37 @@ let k = 0, o = class extends m {
561
494
  (t = this._trigger) == null || t.focus(e);
562
495
  }
563
496
  // ─── Render Helpers ───
497
+ /** @internal */
564
498
  _optionId(e) {
565
499
  return `hx-select-option-${this._selectId}-${e}`;
566
500
  }
501
+ /** @internal */
567
502
  _renderOptions() {
568
- return this._options.length === 0 ? h`<div class="field__no-options">No options found</div>` : this._options.map((e, t) => {
569
- const a = e.value === this.value, r = t === this._focusedOptionIndex;
570
- return h`
571
- <div
572
- id=${this._optionId(t)}
573
- part="option"
574
- role="option"
575
- class=${u({
576
- field__option: !0,
577
- "field__option--selected": a,
578
- "field__option--focused": r,
579
- "field__option--disabled": e.disabled
580
- })}
581
- aria-selected=${a ? "true" : "false"}
582
- aria-disabled=${e.disabled ? "true" : n}
583
- @click=${() => this._selectOption(e)}
584
- >
585
- <span class="field__option-label">${e.label}</span>
586
- </div>
587
- `;
588
- });
503
+ return this._options.length === 0 ? h`<div class="field__no-options">No options found</div>` : $(
504
+ this._options,
505
+ (e) => e.value,
506
+ (e, t) => {
507
+ const a = e.value === this.value, i = t === this._focusedOptionIndex;
508
+ return h`
509
+ <div
510
+ id=${this._optionId(t)}
511
+ part="option"
512
+ role="option"
513
+ class=${u({
514
+ field__option: !0,
515
+ "field__option--selected": a,
516
+ "field__option--focused": i,
517
+ "field__option--disabled": e.disabled
518
+ })}
519
+ aria-selected=${a ? "true" : "false"}
520
+ aria-disabled=${e.disabled ? "true" : n}
521
+ @click=${() => this._selectOption(e)}
522
+ >
523
+ <span class="field__option-label">${e.label}</span>
524
+ </div>
525
+ `;
526
+ }
527
+ );
589
528
  }
590
529
  // ─── Main Render ───
591
530
  render() {
@@ -599,10 +538,10 @@ let k = 0, o = class extends m {
599
538
  field__trigger: !0,
600
539
  [`field__trigger--${this.size}`]: !0,
601
540
  "field__trigger--placeholder": !this.value
602
- }, r = {
541
+ }, i = {
603
542
  field__select: !0,
604
543
  [`field__select--${this.size}`]: !0
605
- }, i = [
544
+ }, r = [
606
545
  e || this._hasErrorSlot ? this._errorId : null,
607
546
  this.helpText ? this._helpTextId : null
608
547
  ].filter(Boolean).join(" ") || void 0;
@@ -635,7 +574,7 @@ let k = 0, o = class extends m {
635
574
  aria-controls=${this._listboxId}
636
575
  aria-activedescendant=${this.open && this._focusedOptionIndex >= 0 ? this._optionId(this._focusedOptionIndex) : n}
637
576
  aria-invalid=${e ? "true" : n}
638
- aria-describedby=${c(i)}
577
+ aria-describedby=${c(r)}
639
578
  aria-required=${this.required ? "true" : n}
640
579
  aria-disabled=${this.disabled ? "true" : n}
641
580
  aria-labelledby=${c(this.label ? this._labelId : void 0)}
@@ -664,7 +603,7 @@ let k = 0, o = class extends m {
664
603
  <!-- Hidden native select (form participation + test compat) -->
665
604
  <select
666
605
  part="select"
667
- class=${u(r)}
606
+ class=${u(i)}
668
607
  tabindex="-1"
669
608
  aria-hidden="true"
670
609
  ?required=${this.required}
@@ -672,7 +611,7 @@ let k = 0, o = class extends m {
672
611
  name=${c(this.name || void 0)}
673
612
  aria-label=${c(this.ariaLabel ?? void 0)}
674
613
  aria-invalid=${e ? "true" : n}
675
- aria-describedby=${c(i)}
614
+ aria-describedby=${c(r)}
676
615
  aria-required=${this.required ? "true" : n}
677
616
  @change=${this._handleNativeChange}
678
617
  >
@@ -700,7 +639,7 @@ let k = 0, o = class extends m {
700
639
  `;
701
640
  }
702
641
  };
703
- o.styles = [w, I];
642
+ o.styles = [I, O];
704
643
  o.formAssociated = !0;
705
644
  l([
706
645
  d({ type: String })
@@ -736,19 +675,19 @@ l([
736
675
  d({ type: Boolean, reflect: !0 })
737
676
  ], o.prototype, "open", 2);
738
677
  l([
739
- v()
678
+ _()
740
679
  ], o.prototype, "_options", 2);
741
680
  l([
742
- v()
681
+ _()
743
682
  ], o.prototype, "_hasErrorSlot", 2);
744
683
  l([
745
- v()
684
+ _()
746
685
  ], o.prototype, "_focusedOptionIndex", 2);
747
686
  l([
748
- _(".field__select")
687
+ x(".field__select")
749
688
  ], o.prototype, "_select", 2);
750
689
  l([
751
- _(".field__trigger")
690
+ x(".field__trigger")
752
691
  ], o.prototype, "_trigger", 2);
753
692
  o = l([
754
693
  y("hx-select")
@@ -756,4 +695,4 @@ o = l([
756
695
  export {
757
696
  o as H
758
697
  };
759
- //# sourceMappingURL=hx-select-BBae2LqN.js.map
698
+ //# sourceMappingURL=hx-select-BwDwxk-M.js.map