@helixui/library 1.1.1 → 1.1.2-next.10

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 (639) hide show
  1. package/custom-elements.json +3336 -2337
  2. package/dist/base/helix-element.d.ts +134 -0
  3. package/dist/base/helix-element.d.ts.map +1 -0
  4. package/dist/base/id-counter.d.ts +32 -0
  5. package/dist/base/id-counter.d.ts.map +1 -0
  6. package/dist/base/index.d.ts +4 -0
  7. package/dist/base/index.d.ts.map +1 -0
  8. package/dist/base/styles.d.ts +19 -0
  9. package/dist/base/styles.d.ts.map +1 -0
  10. package/dist/components/hx-accordion/hx-accordion-item.d.ts +3 -0
  11. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  12. package/dist/components/hx-accordion/hx-accordion.d.ts +4 -1
  13. package/dist/components/hx-accordion/hx-accordion.d.ts.map +1 -1
  14. package/dist/components/hx-accordion/index.js +1 -1
  15. package/dist/components/hx-action-bar/hx-action-bar.d.ts +1 -1
  16. package/dist/components/hx-action-bar/hx-action-bar.d.ts.map +1 -1
  17. package/dist/components/hx-action-bar/index.js +1 -1
  18. package/dist/components/hx-alert/hx-alert.d.ts +18 -10
  19. package/dist/components/hx-alert/hx-alert.d.ts.map +1 -1
  20. package/dist/components/hx-alert/hx-alert.styles.d.ts.map +1 -1
  21. package/dist/components/hx-alert/index.js +1 -1
  22. package/dist/components/hx-avatar/hx-avatar.styles.d.ts.map +1 -1
  23. package/dist/components/hx-avatar/index.js +1 -1
  24. package/dist/components/hx-badge/hx-badge.d.ts.map +1 -1
  25. package/dist/components/hx-badge/hx-badge.styles.d.ts.map +1 -1
  26. package/dist/components/hx-badge/index.js +1 -1
  27. package/dist/components/hx-banner/hx-banner.d.ts +15 -5
  28. package/dist/components/hx-banner/hx-banner.d.ts.map +1 -1
  29. package/dist/components/hx-banner/hx-banner.styles.d.ts.map +1 -1
  30. package/dist/components/hx-banner/index.js +1 -1
  31. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts +1 -0
  32. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts.map +1 -1
  33. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +42 -11
  34. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  35. package/dist/components/hx-breadcrumb/index.js +1 -1
  36. package/dist/components/hx-button/hx-button.d.ts +22 -13
  37. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  38. package/dist/components/hx-button/hx-button.styles.d.ts.map +1 -1
  39. package/dist/components/hx-button/index.js +1 -1
  40. package/dist/components/hx-button-group/hx-button-group.d.ts +3 -6
  41. package/dist/components/hx-button-group/hx-button-group.d.ts.map +1 -1
  42. package/dist/components/hx-button-group/index.js +1 -1
  43. package/dist/components/hx-card/hx-card.d.ts +7 -7
  44. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  45. package/dist/components/hx-card/index.js +1 -1
  46. package/dist/components/hx-carousel/hx-carousel.d.ts +2 -2
  47. package/dist/components/hx-carousel/index.js +1 -1
  48. package/dist/components/hx-checkbox/hx-checkbox.d.ts +18 -18
  49. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  50. package/dist/components/hx-checkbox/hx-checkbox.styles.d.ts.map +1 -1
  51. package/dist/components/hx-checkbox/index.js +1 -1
  52. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +8 -3
  53. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  54. package/dist/components/hx-checkbox-group/index.js +1 -1
  55. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts +134 -0
  56. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts.map +1 -0
  57. package/dist/components/hx-clinical-status/hx-clinical-status.styles.d.ts +2 -0
  58. package/dist/components/hx-clinical-status/hx-clinical-status.styles.d.ts.map +1 -0
  59. package/dist/components/hx-clinical-status/index.d.ts +3 -0
  60. package/dist/components/hx-clinical-status/index.d.ts.map +1 -0
  61. package/dist/components/hx-clinical-status/index.js +5 -0
  62. package/dist/components/hx-clinical-status/index.js.map +1 -0
  63. package/dist/components/hx-code-snippet/hx-code-snippet.styles.d.ts.map +1 -1
  64. package/dist/components/hx-code-snippet/index.js +1 -1
  65. package/dist/components/hx-color-picker/color-utils.d.ts +27 -0
  66. package/dist/components/hx-color-picker/color-utils.d.ts.map +1 -0
  67. package/dist/components/hx-color-picker/hx-color-picker.d.ts +16 -4
  68. package/dist/components/hx-color-picker/hx-color-picker.d.ts.map +1 -1
  69. package/dist/components/hx-color-picker/index.js +1 -1
  70. package/dist/components/hx-combobox/hx-combobox.d.ts +9 -4
  71. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  72. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  73. package/dist/components/hx-combobox/index.js +1 -1
  74. package/dist/components/hx-container/index.js +1 -1
  75. package/dist/components/hx-copy-button/hx-copy-button.d.ts +6 -1
  76. package/dist/components/hx-copy-button/hx-copy-button.d.ts.map +1 -1
  77. package/dist/components/hx-copy-button/index.js +1 -1
  78. package/dist/components/hx-counter/hx-counter.d.ts +20 -3
  79. package/dist/components/hx-counter/hx-counter.d.ts.map +1 -1
  80. package/dist/components/hx-counter/hx-counter.styles.d.ts.map +1 -1
  81. package/dist/components/hx-counter/index.js +1 -1
  82. package/dist/components/hx-data-table/hx-data-table.d.ts +13 -13
  83. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  84. package/dist/components/hx-data-table/hx-data-table.styles.d.ts.map +1 -1
  85. package/dist/components/hx-data-table/index.js +1 -1
  86. package/dist/components/hx-date-picker/hx-date-picker.d.ts +70 -13
  87. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  88. package/dist/components/hx-date-picker/hx-date-picker.styles.d.ts.map +1 -1
  89. package/dist/components/hx-date-picker/index.js +1 -1
  90. package/dist/components/hx-dialog/hx-dialog.d.ts +4 -1
  91. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  92. package/dist/components/hx-dialog/index.js +1 -1
  93. package/dist/components/hx-divider/hx-divider.d.ts.map +1 -1
  94. package/dist/components/hx-divider/index.js +1 -1
  95. package/dist/components/hx-drawer/hx-drawer.d.ts +5 -8
  96. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  97. package/dist/components/hx-drawer/hx-drawer.styles.d.ts.map +1 -1
  98. package/dist/components/hx-drawer/index.js +1 -1
  99. package/dist/components/hx-dropdown/hx-dropdown.d.ts +14 -1
  100. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  101. package/dist/components/hx-dropdown/index.js +1 -1
  102. package/dist/components/hx-field/hx-field.d.ts +1 -1
  103. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  104. package/dist/components/hx-field/index.js +1 -1
  105. package/dist/components/hx-field-label/hx-field-label.styles.d.ts.map +1 -1
  106. package/dist/components/hx-field-label/index.js +1 -1
  107. package/dist/components/hx-file-upload/hx-file-upload.d.ts +8 -9
  108. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  109. package/dist/components/hx-file-upload/index.js +1 -1
  110. package/dist/components/hx-form/hx-form.d.ts.map +1 -1
  111. package/dist/components/hx-form/index.js +1 -1
  112. package/dist/components/hx-format-date/hx-format-date.d.ts.map +1 -1
  113. package/dist/components/hx-format-date/index.js +1 -1
  114. package/dist/components/hx-grid/hx-grid.d.ts +5 -9
  115. package/dist/components/hx-grid/hx-grid.d.ts.map +1 -1
  116. package/dist/components/hx-grid/index.js +1 -1
  117. package/dist/components/hx-icon/hx-icon.d.ts.map +1 -1
  118. package/dist/components/hx-icon/index.js +1 -1
  119. package/dist/components/hx-icon-button/hx-icon-button.d.ts +4 -3
  120. package/dist/components/hx-icon-button/hx-icon-button.d.ts.map +1 -1
  121. package/dist/components/hx-icon-button/index.js +1 -1
  122. package/dist/components/hx-image/hx-image.d.ts.map +1 -1
  123. package/dist/components/hx-image/index.js +1 -1
  124. package/dist/components/hx-link/hx-link.d.ts +1 -1
  125. package/dist/components/hx-link/hx-link.d.ts.map +1 -1
  126. package/dist/components/hx-link/hx-link.styles.d.ts.map +1 -1
  127. package/dist/components/hx-link/index.js +1 -1
  128. package/dist/components/hx-menu/hx-menu-item.d.ts +5 -0
  129. package/dist/components/hx-menu/hx-menu-item.d.ts.map +1 -1
  130. package/dist/components/hx-menu/hx-menu.d.ts +1 -0
  131. package/dist/components/hx-menu/hx-menu.d.ts.map +1 -1
  132. package/dist/components/hx-menu/hx-menu.styles.d.ts.map +1 -1
  133. package/dist/components/hx-menu/index.js +1 -1
  134. package/dist/components/hx-meter/hx-meter.d.ts +2 -2
  135. package/dist/components/hx-meter/hx-meter.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 +10 -0
  138. package/dist/components/hx-nav/hx-nav.d.ts.map +1 -1
  139. package/dist/components/hx-nav/index.js +1 -1
  140. package/dist/components/hx-number-input/hx-number-input.d.ts +19 -7
  141. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  142. package/dist/components/hx-number-input/index.js +1 -1
  143. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts +3 -3
  144. package/dist/components/hx-overflow-menu/hx-overflow-menu.styles.d.ts.map +1 -1
  145. package/dist/components/hx-overflow-menu/index.js +1 -1
  146. package/dist/components/hx-pagination/hx-pagination.d.ts +26 -12
  147. package/dist/components/hx-pagination/hx-pagination.d.ts.map +1 -1
  148. package/dist/components/hx-pagination/hx-pagination.styles.d.ts.map +1 -1
  149. package/dist/components/hx-pagination/index.js +1 -1
  150. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts +113 -0
  151. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts.map +1 -0
  152. package/dist/components/hx-patient-banner/hx-patient-banner.styles.d.ts +2 -0
  153. package/dist/components/hx-patient-banner/hx-patient-banner.styles.d.ts.map +1 -0
  154. package/dist/components/hx-patient-banner/index.d.ts +3 -0
  155. package/dist/components/hx-patient-banner/index.d.ts.map +1 -0
  156. package/dist/components/hx-patient-banner/index.js +5 -0
  157. package/dist/components/hx-patient-banner/index.js.map +1 -0
  158. package/dist/components/hx-phi-field/hx-phi-field.d.ts +97 -0
  159. package/dist/components/hx-phi-field/hx-phi-field.d.ts.map +1 -0
  160. package/dist/components/hx-phi-field/hx-phi-field.styles.d.ts +2 -0
  161. package/dist/components/hx-phi-field/hx-phi-field.styles.d.ts.map +1 -0
  162. package/dist/components/hx-phi-field/index.d.ts +3 -0
  163. package/dist/components/hx-phi-field/index.d.ts.map +1 -0
  164. package/dist/components/hx-phi-field/index.js +5 -0
  165. package/dist/components/hx-phi-field/index.js.map +1 -0
  166. package/dist/components/hx-popover/hx-popover.d.ts +25 -9
  167. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  168. package/dist/components/hx-popover/index.js +1 -1
  169. package/dist/components/hx-popup/hx-popup.d.ts +5 -8
  170. package/dist/components/hx-popup/hx-popup.d.ts.map +1 -1
  171. package/dist/components/hx-popup/index.js +1 -1
  172. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +2 -0
  173. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  174. package/dist/components/hx-progress-bar/hx-progress-bar.styles.d.ts.map +1 -1
  175. package/dist/components/hx-progress-bar/index.js +1 -1
  176. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts.map +1 -1
  177. package/dist/components/hx-progress-ring/index.js +1 -1
  178. package/dist/components/hx-prose/hx-prose.d.ts +1 -0
  179. package/dist/components/hx-prose/hx-prose.d.ts.map +1 -1
  180. package/dist/components/hx-radio-group/hx-radio-group.d.ts +3 -7
  181. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  182. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  183. package/dist/components/hx-radio-group/hx-radio.styles.d.ts.map +1 -1
  184. package/dist/components/hx-radio-group/index.js +1 -1
  185. package/dist/components/hx-rating/hx-rating.d.ts +3 -3
  186. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  187. package/dist/components/hx-rating/hx-rating.styles.d.ts.map +1 -1
  188. package/dist/components/hx-rating/index.js +1 -1
  189. package/dist/components/hx-select/hx-select.d.ts +17 -11
  190. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  191. package/dist/components/hx-select/hx-select.styles.d.ts.map +1 -1
  192. package/dist/components/hx-select/index.js +1 -1
  193. package/dist/components/hx-side-nav/hx-nav-item.d.ts +12 -0
  194. package/dist/components/hx-side-nav/hx-nav-item.d.ts.map +1 -1
  195. package/dist/components/hx-side-nav/hx-nav-item.styles.d.ts.map +1 -1
  196. package/dist/components/hx-side-nav/hx-side-nav.d.ts.map +1 -1
  197. package/dist/components/hx-side-nav/hx-side-nav.styles.d.ts.map +1 -1
  198. package/dist/components/hx-side-nav/index.js +1 -1
  199. package/dist/components/hx-skeleton/hx-skeleton.d.ts +2 -2
  200. package/dist/components/hx-skeleton/hx-skeleton.d.ts.map +1 -1
  201. package/dist/components/hx-slider/hx-slider.d.ts +5 -8
  202. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  203. package/dist/components/hx-slider/hx-slider.styles.d.ts.map +1 -1
  204. package/dist/components/hx-slider/index.js +1 -1
  205. package/dist/components/hx-spinner/hx-spinner.d.ts +14 -1
  206. package/dist/components/hx-spinner/hx-spinner.d.ts.map +1 -1
  207. package/dist/components/hx-spinner/hx-spinner.styles.d.ts.map +1 -1
  208. package/dist/components/hx-spinner/index.js +1 -1
  209. package/dist/components/hx-split-button/hx-split-button.d.ts +10 -4
  210. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  211. package/dist/components/hx-split-button/hx-split-button.styles.d.ts.map +1 -1
  212. package/dist/components/hx-split-button/index.js +1 -1
  213. package/dist/components/hx-split-panel/hx-split-panel.d.ts +13 -9
  214. package/dist/components/hx-split-panel/hx-split-panel.d.ts.map +1 -1
  215. package/dist/components/hx-split-panel/hx-split-panel.styles.d.ts.map +1 -1
  216. package/dist/components/hx-split-panel/index.js +1 -1
  217. package/dist/components/hx-stat/hx-stat.d.ts +7 -2
  218. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -1
  219. package/dist/components/hx-stat/index.js +1 -1
  220. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts +19 -3
  221. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts.map +1 -1
  222. package/dist/components/hx-status-indicator/hx-status-indicator.styles.d.ts.map +1 -1
  223. package/dist/components/hx-status-indicator/index.js +1 -1
  224. package/dist/components/hx-steps/hx-step.d.ts +7 -0
  225. package/dist/components/hx-steps/hx-step.d.ts.map +1 -1
  226. package/dist/components/hx-steps/hx-step.styles.d.ts.map +1 -1
  227. package/dist/components/hx-steps/hx-steps.d.ts.map +1 -1
  228. package/dist/components/hx-steps/index.js +1 -1
  229. package/dist/components/hx-structured-list/hx-structured-list.d.ts +10 -3
  230. package/dist/components/hx-structured-list/hx-structured-list.d.ts.map +1 -1
  231. package/dist/components/hx-structured-list/index.js +1 -1
  232. package/dist/components/hx-style-scope/hx-style-scope.d.ts +71 -0
  233. package/dist/components/hx-style-scope/hx-style-scope.d.ts.map +1 -0
  234. package/dist/components/hx-style-scope/hx-style-scope.styles.d.ts +10 -0
  235. package/dist/components/hx-style-scope/hx-style-scope.styles.d.ts.map +1 -0
  236. package/dist/components/hx-style-scope/index.d.ts +2 -0
  237. package/dist/components/hx-style-scope/index.d.ts.map +1 -0
  238. package/dist/components/hx-style-scope/index.js +5 -0
  239. package/dist/components/hx-style-scope/index.js.map +1 -0
  240. package/dist/components/hx-switch/hx-switch.d.ts +4 -4
  241. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  242. package/dist/components/hx-switch/hx-switch.styles.d.ts.map +1 -1
  243. package/dist/components/hx-switch/index.js +1 -1
  244. package/dist/components/hx-table/hx-table.d.ts +1 -0
  245. package/dist/components/hx-table/hx-table.d.ts.map +1 -1
  246. package/dist/components/hx-table/index.js +1 -1
  247. package/dist/components/hx-tabs/hx-tab-panel.styles.d.ts.map +1 -1
  248. package/dist/components/hx-tabs/hx-tab.d.ts +1 -0
  249. package/dist/components/hx-tabs/hx-tab.d.ts.map +1 -1
  250. package/dist/components/hx-tabs/hx-tab.styles.d.ts.map +1 -1
  251. package/dist/components/hx-tabs/hx-tabs.d.ts +12 -2
  252. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  253. package/dist/components/hx-tabs/index.js +1 -1
  254. package/dist/components/hx-tag/hx-tag.styles.d.ts.map +1 -1
  255. package/dist/components/hx-tag/index.js +1 -1
  256. package/dist/components/hx-text/index.js +1 -1
  257. package/dist/components/hx-text-input/hx-text-input.d.ts +16 -15
  258. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  259. package/dist/components/hx-text-input/hx-text-input.styles.d.ts.map +1 -1
  260. package/dist/components/hx-text-input/index.js +1 -1
  261. package/dist/components/hx-textarea/hx-textarea.d.ts +4 -4
  262. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  263. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  264. package/dist/components/hx-textarea/index.js +1 -1
  265. package/dist/components/hx-theme/hx-theme.d.ts +82 -3
  266. package/dist/components/hx-theme/hx-theme.d.ts.map +1 -1
  267. package/dist/components/hx-theme/index.js +1 -1
  268. package/dist/components/hx-time-picker/hx-time-picker.d.ts +6 -1
  269. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  270. package/dist/components/hx-time-picker/index.js +1 -1
  271. package/dist/components/hx-toast/hx-toast-stack.d.ts +1 -1
  272. package/dist/components/hx-toast/hx-toast-stack.d.ts.map +1 -1
  273. package/dist/components/hx-toast/hx-toast.d.ts +9 -5
  274. package/dist/components/hx-toast/hx-toast.d.ts.map +1 -1
  275. package/dist/components/hx-toast/hx-toast.styles.d.ts.map +1 -1
  276. package/dist/components/hx-toast/index.js +1 -1
  277. package/dist/components/hx-toast/toast-factory.d.ts.map +1 -1
  278. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +4 -3
  279. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  280. package/dist/components/hx-toggle-button/hx-toggle-button.styles.d.ts.map +1 -1
  281. package/dist/components/hx-toggle-button/index.js +1 -1
  282. package/dist/components/hx-tooltip/hx-tooltip.d.ts +1 -2
  283. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  284. package/dist/components/hx-tooltip/index.js +1 -1
  285. package/dist/components/hx-tree-view/hx-tree-item.d.ts +12 -0
  286. package/dist/components/hx-tree-view/hx-tree-item.d.ts.map +1 -1
  287. package/dist/components/hx-tree-view/hx-tree-view.d.ts +27 -2
  288. package/dist/components/hx-tree-view/hx-tree-view.d.ts.map +1 -1
  289. package/dist/components/hx-tree-view/hx-tree-view.styles.d.ts.map +1 -1
  290. package/dist/components/hx-tree-view/index.js +1 -1
  291. package/dist/controllers/helix-audit-controller.d.ts +71 -0
  292. package/dist/controllers/helix-audit-controller.d.ts.map +1 -0
  293. package/dist/css/helix-all.css +9743 -0
  294. package/dist/css/helix-core.css +1839 -0
  295. package/dist/css/helix-data.css +639 -0
  296. package/dist/css/helix-feedback.css +1268 -0
  297. package/dist/css/helix-forms.css +2525 -0
  298. package/dist/css/helix-layout.css +380 -0
  299. package/dist/css/helix-media.css +213 -0
  300. package/dist/css/helix-navigation.css +1131 -0
  301. package/dist/css/helix-overlay.css +643 -0
  302. package/dist/css/helix-tokens.css +432 -0
  303. package/dist/css/helix-utility.css +633 -0
  304. package/dist/css/hx-accordion.css +10 -0
  305. package/dist/css/hx-action-bar.css +117 -0
  306. package/dist/css/hx-alert.css +213 -0
  307. package/dist/css/hx-avatar.css +134 -0
  308. package/dist/css/hx-badge.css +178 -0
  309. package/dist/css/hx-banner.css +203 -0
  310. package/dist/css/hx-breadcrumb.css +36 -0
  311. package/dist/css/hx-button-group.css +91 -0
  312. package/dist/css/hx-button.css +296 -0
  313. package/dist/css/hx-card.css +161 -0
  314. package/dist/css/hx-carousel.css +211 -0
  315. package/dist/css/hx-checkbox-group.css +77 -0
  316. package/dist/css/hx-checkbox.css +219 -0
  317. package/dist/css/hx-clinical-status.css +248 -0
  318. package/dist/css/hx-code-snippet.css +179 -0
  319. package/dist/css/hx-color-picker.css +2 -0
  320. package/dist/css/hx-combobox.css +2 -0
  321. package/dist/css/hx-container.css +82 -0
  322. package/dist/css/hx-copy-button.css +121 -0
  323. package/dist/css/hx-counter.css +51 -0
  324. package/dist/css/hx-data-table.css +207 -0
  325. package/dist/css/hx-date-picker.css +2 -0
  326. package/dist/css/hx-dialog.css +190 -0
  327. package/dist/css/hx-divider.css +87 -0
  328. package/dist/css/hx-drawer.css +262 -0
  329. package/dist/css/hx-dropdown.css +46 -0
  330. package/dist/css/hx-field-label.css +38 -0
  331. package/dist/css/hx-field.css +119 -0
  332. package/dist/css/hx-file-upload.css +241 -0
  333. package/dist/css/hx-form.css +2 -0
  334. package/dist/css/hx-format-date.css +10 -0
  335. package/dist/css/hx-grid.css +14 -0
  336. package/dist/css/hx-help-text.css +50 -0
  337. package/dist/css/hx-icon-button.css +152 -0
  338. package/dist/css/hx-icon.css +73 -0
  339. package/dist/css/hx-image.css +41 -0
  340. package/dist/css/hx-link.css +105 -0
  341. package/dist/css/hx-list.css +48 -0
  342. package/dist/css/hx-menu.css +23 -0
  343. package/dist/css/hx-meter.css +113 -0
  344. package/dist/css/hx-nav.css +242 -0
  345. package/dist/css/hx-number-input.css +246 -0
  346. package/dist/css/hx-overflow-menu.css +133 -0
  347. package/dist/css/hx-pagination.css +193 -0
  348. package/dist/css/hx-patient-banner.css +139 -0
  349. package/dist/css/hx-phi-field.css +97 -0
  350. package/dist/css/hx-popover.css +61 -0
  351. package/dist/css/hx-popup.css +31 -0
  352. package/dist/css/hx-progress-bar.css +133 -0
  353. package/dist/css/hx-progress-ring.css +142 -0
  354. package/dist/css/hx-prose.css +2 -0
  355. package/dist/css/hx-radio-group.css +77 -0
  356. package/dist/css/hx-rating.css +96 -0
  357. package/dist/css/hx-select.css +295 -0
  358. package/dist/css/hx-side-nav.css +149 -0
  359. package/dist/css/hx-skeleton.css +82 -0
  360. package/dist/css/hx-slider.css +287 -0
  361. package/dist/css/hx-spinner.css +116 -0
  362. package/dist/css/hx-split-button.css +309 -0
  363. package/dist/css/hx-split-panel.css +168 -0
  364. package/dist/css/hx-stack.css +104 -0
  365. package/dist/css/hx-stat.css +106 -0
  366. package/dist/css/hx-status-indicator.css +126 -0
  367. package/dist/css/hx-steps.css +52 -0
  368. package/dist/css/hx-structured-list.css +75 -0
  369. package/dist/css/hx-style-scope.css +4 -0
  370. package/dist/css/hx-switch.css +169 -0
  371. package/dist/css/hx-table.css +128 -0
  372. package/dist/css/hx-tabs.css +76 -0
  373. package/dist/css/hx-tag.css +146 -0
  374. package/dist/css/hx-text-input.css +214 -0
  375. package/dist/css/hx-text.css +149 -0
  376. package/dist/css/hx-textarea.css +180 -0
  377. package/dist/css/hx-theme.css +23 -0
  378. package/dist/css/hx-time-picker.css +2 -0
  379. package/dist/css/hx-toast.css +230 -0
  380. package/dist/css/hx-toggle-button.css +207 -0
  381. package/dist/css/hx-tooltip.css +51 -0
  382. package/dist/css/hx-top-nav.css +203 -0
  383. package/dist/css/hx-tree-view.css +22 -0
  384. package/dist/css/hx-visually-hidden.css +26 -0
  385. package/dist/css/index.css +84 -0
  386. package/dist/css/manifest.json +2704 -0
  387. package/dist/index.d.ts +14 -0
  388. package/dist/index.d.ts.map +1 -1
  389. package/dist/index.js +266 -176
  390. package/dist/index.js.map +1 -1
  391. package/dist/mixins/FocusMixin.d.ts +49 -0
  392. package/dist/mixins/FocusMixin.d.ts.map +1 -0
  393. package/dist/mixins/FormMixin.d.ts +69 -0
  394. package/dist/mixins/FormMixin.d.ts.map +1 -0
  395. package/dist/mixins/aria-delegation.d.ts +97 -0
  396. package/dist/mixins/aria-delegation.d.ts.map +1 -0
  397. package/dist/mixins/index.d.ts +5 -0
  398. package/dist/mixins/index.d.ts.map +1 -0
  399. package/dist/shared/FormMixin-Bjvw20G5.js +88 -0
  400. package/dist/shared/FormMixin-Bjvw20G5.js.map +1 -0
  401. package/dist/shared/aria-delegation-CBP9eQ0M.js +107 -0
  402. package/dist/shared/aria-delegation-CBP9eQ0M.js.map +1 -0
  403. package/dist/shared/{hx-accordion-D1kFhdeQ.js → hx-accordion-_KeulaQR.js} +83 -55
  404. package/dist/shared/hx-accordion-_KeulaQR.js.map +1 -0
  405. package/dist/shared/{hx-action-bar-D4bulGQP.js → hx-action-bar-vGFnNwNY.js} +33 -34
  406. package/dist/shared/hx-action-bar-vGFnNwNY.js.map +1 -0
  407. package/dist/shared/{hx-alert-K5F8KeqI.js → hx-alert-DRZYP0Oo.js} +32 -23
  408. package/dist/shared/hx-alert-DRZYP0Oo.js.map +1 -0
  409. package/dist/shared/{hx-avatar-Cun-O99h.js → hx-avatar-CZfA9KEl.js} +28 -11
  410. package/dist/shared/hx-avatar-CZfA9KEl.js.map +1 -0
  411. package/dist/shared/{hx-badge-CsFd2xtw.js → hx-badge-Xg7zoh4Q.js} +46 -37
  412. package/dist/shared/hx-badge-Xg7zoh4Q.js.map +1 -0
  413. package/dist/shared/{hx-banner-BTV-X2xF.js → hx-banner-2RS7Nux4.js} +93 -58
  414. package/dist/shared/hx-banner-2RS7Nux4.js.map +1 -0
  415. package/dist/shared/{hx-breadcrumb-item-4IwaLgaO.js → hx-breadcrumb-item-CObc-WJl.js} +86 -83
  416. package/dist/shared/hx-breadcrumb-item-CObc-WJl.js.map +1 -0
  417. package/dist/shared/{hx-button-7k-KeCYU.js → hx-button-CC1YH9RZ.js} +127 -62
  418. package/dist/shared/hx-button-CC1YH9RZ.js.map +1 -0
  419. package/dist/shared/{hx-button-group-CWjWv-wS.js → hx-button-group-ChTQsnQj.js} +10 -10
  420. package/dist/shared/hx-button-group-ChTQsnQj.js.map +1 -0
  421. package/dist/shared/{hx-card-0hT3G5hi.js → hx-card-dIKdcMhr.js} +32 -32
  422. package/dist/shared/hx-card-dIKdcMhr.js.map +1 -0
  423. package/dist/shared/{hx-carousel-item-DgeYyYZJ.js → hx-carousel-item-Cm8a1nAi.js} +3 -3
  424. package/dist/shared/hx-carousel-item-Cm8a1nAi.js.map +1 -0
  425. package/dist/shared/{hx-checkbox-BvjO-O41.js → hx-checkbox-_WUiuTo9.js} +68 -71
  426. package/dist/shared/hx-checkbox-_WUiuTo9.js.map +1 -0
  427. package/dist/shared/{hx-checkbox-group-Z5VvWzcj.js → hx-checkbox-group-B-ci-dxp.js} +37 -31
  428. package/dist/shared/hx-checkbox-group-B-ci-dxp.js.map +1 -0
  429. package/dist/shared/hx-clinical-status-D6eaplvs.js +469 -0
  430. package/dist/shared/hx-clinical-status-D6eaplvs.js.map +1 -0
  431. package/dist/shared/{hx-code-snippet-DqzPkH4K.js → hx-code-snippet-CQsyvthi.js} +56 -47
  432. package/dist/shared/hx-code-snippet-CQsyvthi.js.map +1 -0
  433. package/dist/shared/{hx-color-picker-Da8z6AlQ.js → hx-color-picker-Dk2Myvaf.js} +153 -137
  434. package/dist/shared/hx-color-picker-Dk2Myvaf.js.map +1 -0
  435. package/dist/shared/{hx-combobox-CivfelTS.js → hx-combobox-CNAJXIxo.js} +10 -10
  436. package/dist/shared/hx-combobox-CNAJXIxo.js.map +1 -0
  437. package/dist/shared/{hx-container-DLUKnTi9.js → hx-container-7j16VuQE.js} +16 -16
  438. package/dist/shared/hx-container-7j16VuQE.js.map +1 -0
  439. package/dist/shared/{hx-copy-button--0dymSvw.js → hx-copy-button-B_ZHYO7_.js} +47 -40
  440. package/dist/shared/hx-copy-button-B_ZHYO7_.js.map +1 -0
  441. package/dist/shared/hx-counter-D_B7L9Pi.js +185 -0
  442. package/dist/shared/hx-counter-D_B7L9Pi.js.map +1 -0
  443. package/dist/shared/{hx-data-table-DujB9hSE.js → hx-data-table-B1j4n4bm.js} +134 -107
  444. package/dist/shared/hx-data-table-B1j4n4bm.js.map +1 -0
  445. package/dist/shared/{hx-date-picker-C8d2HtRV.js → hx-date-picker-R-0kWFwr.js} +146 -130
  446. package/dist/shared/hx-date-picker-R-0kWFwr.js.map +1 -0
  447. package/dist/shared/{hx-dialog-DkUSnVgw.js → hx-dialog-U5d3s0Ps.js} +98 -89
  448. package/dist/shared/hx-dialog-U5d3s0Ps.js.map +1 -0
  449. package/dist/shared/{hx-divider-DNNs4e8q.js → hx-divider-DdAN-_jB.js} +5 -5
  450. package/dist/shared/hx-divider-DdAN-_jB.js.map +1 -0
  451. package/dist/shared/{hx-drawer-CJcRZcns.js → hx-drawer-e0qeGxAD.js} +117 -77
  452. package/dist/shared/hx-drawer-e0qeGxAD.js.map +1 -0
  453. package/dist/shared/{hx-dropdown-Bo0KTM1A.js → hx-dropdown-DP_DNpEb.js} +56 -41
  454. package/dist/shared/hx-dropdown-DP_DNpEb.js.map +1 -0
  455. package/dist/shared/{hx-field-3MmzJ4kZ.js → hx-field-COM4KvMQ.js} +9 -9
  456. package/dist/shared/hx-field-COM4KvMQ.js.map +1 -0
  457. package/dist/shared/{hx-field-label-Bg-EWvqF.js → hx-field-label-BtZ9H9Yy.js} +8 -11
  458. package/dist/shared/hx-field-label-BtZ9H9Yy.js.map +1 -0
  459. package/dist/shared/{hx-file-upload-ByjAgfNy.js → hx-file-upload-DbECypLe.js} +78 -87
  460. package/dist/shared/hx-file-upload-DbECypLe.js.map +1 -0
  461. package/dist/shared/{hx-form-BpS6v3Iu.js → hx-form-fJE-FJQV.js} +36 -32
  462. package/dist/shared/{hx-form-BpS6v3Iu.js.map → hx-form-fJE-FJQV.js.map} +1 -1
  463. package/dist/shared/{hx-format-date-BdnWV2kX.js → hx-format-date-C030ThSm.js} +14 -12
  464. package/dist/shared/hx-format-date-C030ThSm.js.map +1 -0
  465. package/dist/shared/{hx-grid-gEjuF0cR.js → hx-grid-DE8KM5Gf.js} +7 -7
  466. package/dist/shared/hx-grid-DE8KM5Gf.js.map +1 -0
  467. package/dist/shared/{hx-icon-button-DzH_bRtC.js → hx-icon-button-Et9wq79n.js} +4 -4
  468. package/dist/shared/{hx-icon-button-DzH_bRtC.js.map → hx-icon-button-Et9wq79n.js.map} +1 -1
  469. package/dist/shared/{hx-icon-CP6OnLoM.js → hx-icon-dYvrzvsO.js} +7 -7
  470. package/dist/shared/hx-icon-dYvrzvsO.js.map +1 -0
  471. package/dist/shared/{hx-image-C6pGiI6c.js → hx-image-DUsEi-oN.js} +15 -15
  472. package/dist/shared/hx-image-DUsEi-oN.js.map +1 -0
  473. package/dist/shared/{hx-link-Tmk_YPvW.js → hx-link-Peg2LzOD.js} +43 -41
  474. package/dist/shared/hx-link-Peg2LzOD.js.map +1 -0
  475. package/dist/shared/{hx-menu-divider-DR4G_rqw.js → hx-menu-divider-puPmRAdN.js} +40 -20
  476. package/dist/shared/hx-menu-divider-puPmRAdN.js.map +1 -0
  477. package/dist/shared/{hx-meter-uXkTZq-W.js → hx-meter-CVs4A649.js} +13 -13
  478. package/dist/shared/hx-meter-CVs4A649.js.map +1 -0
  479. package/dist/shared/{hx-nav-3JsN2Oak.js → hx-nav-CiyqaW2I.js} +119 -107
  480. package/dist/shared/hx-nav-CiyqaW2I.js.map +1 -0
  481. package/dist/shared/{hx-nav-item-D3EJatzc.js → hx-nav-item-tM_6bolB.js} +181 -115
  482. package/dist/shared/hx-nav-item-tM_6bolB.js.map +1 -0
  483. package/dist/shared/{hx-number-input-CAAibZ8X.js → hx-number-input-BPgrlMLN.js} +70 -66
  484. package/dist/shared/hx-number-input-BPgrlMLN.js.map +1 -0
  485. package/dist/shared/{hx-overflow-menu-2kgOJ_ht.js → hx-overflow-menu-Bz02LPPk.js} +15 -11
  486. package/dist/shared/hx-overflow-menu-Bz02LPPk.js.map +1 -0
  487. package/dist/shared/{hx-pagination-DBs-vmSv.js → hx-pagination-Cb9UEWXz.js} +84 -71
  488. package/dist/shared/hx-pagination-Cb9UEWXz.js.map +1 -0
  489. package/dist/shared/hx-patient-banner-wk4qWmsH.js +297 -0
  490. package/dist/shared/hx-patient-banner-wk4qWmsH.js.map +1 -0
  491. package/dist/shared/hx-phi-field-DX9z3nu0.js +295 -0
  492. package/dist/shared/hx-phi-field-DX9z3nu0.js.map +1 -0
  493. package/dist/shared/{hx-popover-DxE67miP.js → hx-popover-D6kYQkt3.js} +96 -69
  494. package/dist/shared/hx-popover-D6kYQkt3.js.map +1 -0
  495. package/dist/shared/{hx-popup-Dg6n_PbY.js → hx-popup-RQb6HUXc.js} +2 -2
  496. package/dist/shared/hx-popup-RQb6HUXc.js.map +1 -0
  497. package/dist/shared/{hx-progress-bar-Dm_EHyng.js → hx-progress-bar-ByEmxq1V.js} +42 -40
  498. package/dist/shared/hx-progress-bar-ByEmxq1V.js.map +1 -0
  499. package/dist/shared/{hx-progress-ring-DpxBDD5d.js → hx-progress-ring-CtVnNRQx.js} +2 -2
  500. package/dist/shared/{hx-progress-ring-DpxBDD5d.js.map → hx-progress-ring-CtVnNRQx.js.map} +1 -1
  501. package/dist/shared/hx-prose-Ml_L2zje.js.map +1 -1
  502. package/dist/shared/{hx-radio-BywgVSEu.js → hx-radio-jgeW92SV.js} +28 -27
  503. package/dist/shared/hx-radio-jgeW92SV.js.map +1 -0
  504. package/dist/shared/{hx-rating-CUWBQ0fZ.js → hx-rating-g_iy-DW_.js} +92 -96
  505. package/dist/shared/hx-rating-g_iy-DW_.js.map +1 -0
  506. package/dist/shared/{hx-select-BwDwxk-M.js → hx-select-BWzxWZs_.js} +139 -100
  507. package/dist/shared/hx-select-BWzxWZs_.js.map +1 -0
  508. package/dist/shared/hx-skeleton-BHvALyd7.js.map +1 -1
  509. package/dist/shared/{hx-slider-D_0EKJyk.js → hx-slider-7Q-e0_pc.js} +27 -22
  510. package/dist/shared/hx-slider-7Q-e0_pc.js.map +1 -0
  511. package/dist/shared/{hx-spinner-DMn4SChS.js → hx-spinner-DEgrKsUo.js} +3 -2
  512. package/dist/shared/hx-spinner-DEgrKsUo.js.map +1 -0
  513. package/dist/shared/{hx-split-button-CypgLXw1.js → hx-split-button-BA7P_ly5.js} +40 -31
  514. package/dist/shared/hx-split-button-BA7P_ly5.js.map +1 -0
  515. package/dist/shared/{hx-split-panel-BPMWKPGu.js → hx-split-panel-Bss54UN8.js} +28 -28
  516. package/dist/shared/hx-split-panel-Bss54UN8.js.map +1 -0
  517. package/dist/shared/{hx-stat-CHntLHJM.js → hx-stat-CmkCUI8v.js} +40 -32
  518. package/dist/shared/{hx-stat-CHntLHJM.js.map → hx-stat-CmkCUI8v.js.map} +1 -1
  519. package/dist/shared/{hx-status-indicator-C1BwEvUw.js → hx-status-indicator-Dl3Y34mc.js} +81 -40
  520. package/dist/shared/hx-status-indicator-Dl3Y34mc.js.map +1 -0
  521. package/dist/shared/{hx-step-BIVWSPxd.js → hx-step-CmNwfcJx.js} +49 -85
  522. package/dist/shared/hx-step-CmNwfcJx.js.map +1 -0
  523. package/dist/shared/{hx-structured-list-CMWllxGg.js → hx-structured-list-Db9rwLI_.js} +26 -23
  524. package/dist/shared/hx-structured-list-Db9rwLI_.js.map +1 -0
  525. package/dist/shared/hx-style-scope-BroUu83L.js +125 -0
  526. package/dist/shared/hx-style-scope-BroUu83L.js.map +1 -0
  527. package/dist/shared/{hx-switch-BgX8kuWt.js → hx-switch-C0Lp5RGy.js} +8 -5
  528. package/dist/shared/hx-switch-C0Lp5RGy.js.map +1 -0
  529. package/dist/shared/{hx-tab-panel-DhOq67jj.js → hx-tab-panel-Dnt8aA74.js} +161 -122
  530. package/dist/shared/hx-tab-panel-Dnt8aA74.js.map +1 -0
  531. package/dist/shared/{hx-tag-CzOTDcXI.js → hx-tag-K5fCjfqQ.js} +15 -14
  532. package/dist/shared/hx-tag-K5fCjfqQ.js.map +1 -0
  533. package/dist/shared/{hx-td-h6oeW6YC.js → hx-td-DZuILY3s.js} +43 -40
  534. package/dist/shared/hx-td-DZuILY3s.js.map +1 -0
  535. package/dist/shared/{hx-text-DTXjiviE.js → hx-text-DoEVOf47.js} +29 -29
  536. package/dist/shared/hx-text-DoEVOf47.js.map +1 -0
  537. package/dist/shared/hx-text-input-DTKWPVdy.js +576 -0
  538. package/dist/shared/hx-text-input-DTKWPVdy.js.map +1 -0
  539. package/dist/shared/{hx-textarea-BgX7rxyo.js → hx-textarea-BkSiU8oM.js} +15 -15
  540. package/dist/shared/hx-textarea-BkSiU8oM.js.map +1 -0
  541. package/dist/shared/hx-theme-Aag8QJvT.js +299 -0
  542. package/dist/shared/hx-theme-Aag8QJvT.js.map +1 -0
  543. package/dist/shared/{hx-time-picker-DmLu7WUC.js → hx-time-picker-BpCRsh_z.js} +54 -53
  544. package/dist/shared/hx-time-picker-BpCRsh_z.js.map +1 -0
  545. package/dist/shared/{hx-toggle-button-D1jpDvSA.js → hx-toggle-button-CPFqs3eQ.js} +8 -5
  546. package/dist/shared/hx-toggle-button-CPFqs3eQ.js.map +1 -0
  547. package/dist/shared/{hx-tooltip-kh7QFPKu.js → hx-tooltip-CrO4vzeX.js} +15 -10
  548. package/dist/shared/hx-tooltip-CrO4vzeX.js.map +1 -0
  549. package/dist/shared/{hx-tree-item-BP6UF_H1.js → hx-tree-item-C1PhX-HE.js} +163 -99
  550. package/dist/shared/hx-tree-item-C1PhX-HE.js.map +1 -0
  551. package/dist/shared/id-counter-JhvVCnjh.js +143 -0
  552. package/dist/shared/id-counter-JhvVCnjh.js.map +1 -0
  553. package/dist/shared/{toast-factory-DTy-qN8r.js → toast-factory-f184Gi70.js} +57 -45
  554. package/dist/shared/toast-factory-f184Gi70.js.map +1 -0
  555. package/dist/utilities/adoptedStylesheetRegistry.d.ts +47 -0
  556. package/dist/utilities/adoptedStylesheetRegistry.d.ts.map +1 -0
  557. package/dist/utilities/generateScopedSelectors.d.ts +30 -0
  558. package/dist/utilities/generateScopedSelectors.d.ts.map +1 -0
  559. package/dist/utilities/injectLightStyles.d.ts +37 -0
  560. package/dist/utilities/injectLightStyles.d.ts.map +1 -0
  561. package/dist/utilities/lightStyleRegistry.d.ts +41 -0
  562. package/dist/utilities/lightStyleRegistry.d.ts.map +1 -0
  563. package/dist/utilities/sheetManager.d.ts +62 -0
  564. package/dist/utilities/sheetManager.d.ts.map +1 -0
  565. package/dist/utils/contrast-checker.d.ts +86 -0
  566. package/dist/utils/contrast-checker.d.ts.map +1 -0
  567. package/dist/utils/token-merger.d.ts +24 -0
  568. package/dist/utils/token-merger.d.ts.map +1 -0
  569. package/fouc.css +37 -0
  570. package/package.json +26 -6
  571. package/dist/shared/hx-accordion-D1kFhdeQ.js.map +0 -1
  572. package/dist/shared/hx-action-bar-D4bulGQP.js.map +0 -1
  573. package/dist/shared/hx-alert-K5F8KeqI.js.map +0 -1
  574. package/dist/shared/hx-avatar-Cun-O99h.js.map +0 -1
  575. package/dist/shared/hx-badge-CsFd2xtw.js.map +0 -1
  576. package/dist/shared/hx-banner-BTV-X2xF.js.map +0 -1
  577. package/dist/shared/hx-breadcrumb-item-4IwaLgaO.js.map +0 -1
  578. package/dist/shared/hx-button-7k-KeCYU.js.map +0 -1
  579. package/dist/shared/hx-button-group-CWjWv-wS.js.map +0 -1
  580. package/dist/shared/hx-card-0hT3G5hi.js.map +0 -1
  581. package/dist/shared/hx-carousel-item-DgeYyYZJ.js.map +0 -1
  582. package/dist/shared/hx-checkbox-BvjO-O41.js.map +0 -1
  583. package/dist/shared/hx-checkbox-group-Z5VvWzcj.js.map +0 -1
  584. package/dist/shared/hx-code-snippet-DqzPkH4K.js.map +0 -1
  585. package/dist/shared/hx-color-picker-Da8z6AlQ.js.map +0 -1
  586. package/dist/shared/hx-combobox-CivfelTS.js.map +0 -1
  587. package/dist/shared/hx-container-DLUKnTi9.js.map +0 -1
  588. package/dist/shared/hx-copy-button--0dymSvw.js.map +0 -1
  589. package/dist/shared/hx-counter-Duf00H7p.js +0 -147
  590. package/dist/shared/hx-counter-Duf00H7p.js.map +0 -1
  591. package/dist/shared/hx-data-table-DujB9hSE.js.map +0 -1
  592. package/dist/shared/hx-date-picker-C8d2HtRV.js.map +0 -1
  593. package/dist/shared/hx-dialog-DkUSnVgw.js.map +0 -1
  594. package/dist/shared/hx-divider-DNNs4e8q.js.map +0 -1
  595. package/dist/shared/hx-drawer-CJcRZcns.js.map +0 -1
  596. package/dist/shared/hx-dropdown-Bo0KTM1A.js.map +0 -1
  597. package/dist/shared/hx-field-3MmzJ4kZ.js.map +0 -1
  598. package/dist/shared/hx-field-label-Bg-EWvqF.js.map +0 -1
  599. package/dist/shared/hx-file-upload-ByjAgfNy.js.map +0 -1
  600. package/dist/shared/hx-format-date-BdnWV2kX.js.map +0 -1
  601. package/dist/shared/hx-grid-gEjuF0cR.js.map +0 -1
  602. package/dist/shared/hx-icon-CP6OnLoM.js.map +0 -1
  603. package/dist/shared/hx-image-C6pGiI6c.js.map +0 -1
  604. package/dist/shared/hx-link-Tmk_YPvW.js.map +0 -1
  605. package/dist/shared/hx-menu-divider-DR4G_rqw.js.map +0 -1
  606. package/dist/shared/hx-meter-uXkTZq-W.js.map +0 -1
  607. package/dist/shared/hx-nav-3JsN2Oak.js.map +0 -1
  608. package/dist/shared/hx-nav-item-D3EJatzc.js.map +0 -1
  609. package/dist/shared/hx-number-input-CAAibZ8X.js.map +0 -1
  610. package/dist/shared/hx-overflow-menu-2kgOJ_ht.js.map +0 -1
  611. package/dist/shared/hx-pagination-DBs-vmSv.js.map +0 -1
  612. package/dist/shared/hx-popover-DxE67miP.js.map +0 -1
  613. package/dist/shared/hx-popup-Dg6n_PbY.js.map +0 -1
  614. package/dist/shared/hx-progress-bar-Dm_EHyng.js.map +0 -1
  615. package/dist/shared/hx-radio-BywgVSEu.js.map +0 -1
  616. package/dist/shared/hx-rating-CUWBQ0fZ.js.map +0 -1
  617. package/dist/shared/hx-select-BwDwxk-M.js.map +0 -1
  618. package/dist/shared/hx-slider-D_0EKJyk.js.map +0 -1
  619. package/dist/shared/hx-spinner-DMn4SChS.js.map +0 -1
  620. package/dist/shared/hx-split-button-CypgLXw1.js.map +0 -1
  621. package/dist/shared/hx-split-panel-BPMWKPGu.js.map +0 -1
  622. package/dist/shared/hx-status-indicator-C1BwEvUw.js.map +0 -1
  623. package/dist/shared/hx-step-BIVWSPxd.js.map +0 -1
  624. package/dist/shared/hx-structured-list-CMWllxGg.js.map +0 -1
  625. package/dist/shared/hx-switch-BgX8kuWt.js.map +0 -1
  626. package/dist/shared/hx-tab-panel-DhOq67jj.js.map +0 -1
  627. package/dist/shared/hx-tag-CzOTDcXI.js.map +0 -1
  628. package/dist/shared/hx-td-h6oeW6YC.js.map +0 -1
  629. package/dist/shared/hx-text-DTXjiviE.js.map +0 -1
  630. package/dist/shared/hx-text-input-CqEdDHMU.js +0 -461
  631. package/dist/shared/hx-text-input-CqEdDHMU.js.map +0 -1
  632. package/dist/shared/hx-textarea-BgX7rxyo.js.map +0 -1
  633. package/dist/shared/hx-theme-6GDoUG8j.js +0 -176
  634. package/dist/shared/hx-theme-6GDoUG8j.js.map +0 -1
  635. package/dist/shared/hx-time-picker-DmLu7WUC.js.map +0 -1
  636. package/dist/shared/hx-toggle-button-D1jpDvSA.js.map +0 -1
  637. package/dist/shared/hx-tooltip-kh7QFPKu.js.map +0 -1
  638. package/dist/shared/hx-tree-item-BP6UF_H1.js.map +0 -1
  639. package/dist/shared/toast-factory-DTy-qN8r.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-style-scope-BroUu83L.js","sources":["../../src/components/hx-style-scope/hx-style-scope.styles.ts","../../src/utilities/lightStyleRegistry.ts","../../src/utilities/generateScopedSelectors.ts","../../src/utilities/injectLightStyles.ts","../../src/components/hx-style-scope/hx-style-scope.ts"],"sourcesContent":["import { css } from 'lit';\n\n/**\n * Styles for hx-style-scope.\n *\n * The element acts as a transparent wrapper — `display: contents` removes it\n * from the layout box model so slotted children lay out as if the wrapper\n * were absent. This prevents hx-style-scope from introducing unexpected\n * layout shifts or block-formatting-context changes.\n */\nexport const hxStyleScopeStyles = css`\n :host {\n display: contents;\n }\n`;\n","/**\n * @module lightStyleRegistry\n *\n * A Map-based registry that tracks which component stylesheets have been\n * injected into the document's light DOM. Used by injectLightStyles to\n * deduplicate style injection — each component type is injected at most once\n * per page load.\n *\n * @example\n * ```ts\n * import { isStyleRegistered, registerStyle } from './lightStyleRegistry.js';\n *\n * if (!isStyleRegistered('hx-card')) {\n * const el = document.createElement('style');\n * el.textContent = css;\n * document.head.appendChild(el);\n * registerStyle('hx-card', el);\n * }\n * ```\n */\n\n/**\n * Primary registry mapping component names to their injected HTMLStyleElement.\n * Keyed by component tag name (e.g. `'hx-card'`).\n */\nexport const lightStyleRegistry: Map<string, HTMLStyleElement> = new Map();\n\n/**\n * Returns true if a stylesheet for the given component has already been\n * injected into the document.\n *\n * @param componentName - The component tag name (e.g. `'hx-card'`).\n */\nexport function isStyleRegistered(componentName: string): boolean {\n return lightStyleRegistry.has(componentName);\n}\n\n/**\n * Records a stylesheet element in the registry for the given component.\n * Called after the element has been appended to the document.\n *\n * @param componentName - The component tag name (e.g. `'hx-card'`).\n * @param el - The HTMLStyleElement that was injected.\n */\nexport function registerStyle(componentName: string, el: HTMLStyleElement): void {\n lightStyleRegistry.set(componentName, el);\n}\n","/**\n * @module generateScopedSelectors\n *\n * Generates CSS with all selectors scoped under a `[data-hx-styled=\"componentName\"]`\n * attribute selector. This ensures injected light DOM styles only apply to content\n * wrapped in `<hx-style-scope component=\"...\">` and do not leak to the rest of the page.\n *\n * @example\n * ```ts\n * import { generateScopedSelectors } from './generateScopedSelectors.js';\n *\n * const scoped = generateScopedSelectors('hx-card', 'p { color: red; }');\n * // '[data-hx-styled=\"hx-card\"] p { color: red; }'\n * ```\n */\n\n/**\n * Wraps all CSS selectors to be scoped under `[data-hx-styled=\"componentName\"]`.\n *\n * Handles:\n * - Standard selectors: `p { ... }` → `[data-hx-styled=\"hx-card\"] p { ... }`\n * - `::slotted(*)` patterns: `::slotted(p) { ... }` → `[data-hx-styled=\"hx-card\"] p { ... }`\n * - At-rules (`@media`, `@supports`, etc.) are preserved with their inner rules scoped\n * - `:host` selectors are replaced with the scope attribute selector\n *\n * @param componentName - The component tag name used as the scope identifier.\n * @param css - The CSS string to transform.\n * @returns The transformed CSS with all selectors scoped.\n */\nexport function generateScopedSelectors(componentName: string, css: string): string {\n const scopeAttr = `[data-hx-styled=\"${componentName}\"]`;\n return transformCss(css, scopeAttr);\n}\n\n/**\n * Returns the character at position `i` in `str`, or an empty string if out of bounds.\n * Avoids the `string | undefined` issue from `noUncheckedIndexedAccess`.\n */\nfunction charAt(str: string, i: number): string {\n return str[i] ?? '';\n}\n\n/**\n * Recursively transforms CSS text, scoping all selectors under the given\n * attribute selector prefix.\n *\n * @param css - The CSS text to transform.\n * @param scopeAttr - The attribute selector to prepend (e.g. `[data-hx-styled=\"hx-card\"]`).\n * @returns The scoped CSS string.\n */\nfunction transformCss(css: string, scopeAttr: string): string {\n const result: string[] = [];\n let i = 0;\n const len = css.length;\n\n while (i < len) {\n // Skip whitespace\n while (i < len && /\\s/.test(charAt(css, i))) {\n result.push(charAt(css, i));\n i++;\n }\n\n if (i >= len) break;\n\n // Check for at-rule (e.g. @media, @supports, @keyframes)\n if (charAt(css, i) === '@') {\n const atBlock = extractAtRule(css, i);\n result.push(transformAtRule(atBlock.text, scopeAttr));\n i = atBlock.end;\n continue;\n }\n\n // Extract a selector block up to the opening brace\n const selectorEnd = css.indexOf('{', i);\n if (selectorEnd === -1) break;\n\n const selectorRaw = css.slice(i, selectorEnd);\n const bodyStart = selectorEnd + 1;\n const bodyEnd = findMatchingBrace(css, selectorEnd);\n\n if (bodyEnd === -1) break;\n\n const body = css.slice(bodyStart, bodyEnd);\n const scopedSelector = scopeSelector(selectorRaw, scopeAttr);\n result.push(`${scopedSelector}{${body}}`);\n i = bodyEnd + 1;\n }\n\n return result.join('');\n}\n\n/**\n * Scopes a raw selector string under the given attribute selector.\n * Handles comma-separated selectors, `::slotted()`, and `:host`.\n *\n * @param selectorRaw - The raw selector string (may be comma-separated).\n * @param scopeAttr - The attribute selector prefix.\n * @returns The scoped selector string.\n */\nfunction scopeSelector(selectorRaw: string, scopeAttr: string): string {\n return selectorRaw\n .split(',')\n .map((part) => {\n const trimmed = part.trim();\n\n // Replace ::slotted(*) with a direct descendant selector\n if (trimmed.startsWith('::slotted(') && trimmed.endsWith(')')) {\n const inner = trimmed.slice('::slotted('.length, -1).trim();\n return `${scopeAttr} ${inner}`;\n }\n\n // Replace :host with the scope attribute selector\n if (trimmed === ':host' || trimmed.startsWith(':host(') || trimmed.startsWith(':host ')) {\n return trimmed.replace(/^:host(\\([^)]*\\))?/, scopeAttr);\n }\n\n // Standard selector — prepend scope\n return `${scopeAttr} ${trimmed}`;\n })\n .join(', ');\n}\n\n/**\n * Handles transformation of an at-rule block. For container at-rules\n * (`@media`, `@supports`, `@layer`, `@container`) the inner rules are scoped.\n * Non-container at-rules (e.g. `@keyframes`, `@charset`) are passed through unchanged.\n *\n * @param atRuleText - The full at-rule text including its block.\n * @param scopeAttr - The attribute selector prefix.\n * @returns The transformed at-rule text.\n */\nfunction transformAtRule(atRuleText: string, scopeAttr: string): string {\n const containerAtRules = /^@(media|supports|layer|container|document)\\b/;\n const braceIndex = atRuleText.indexOf('{');\n\n if (braceIndex === -1 || !containerAtRules.test(atRuleText.trim())) {\n return atRuleText;\n }\n\n const head = atRuleText.slice(0, braceIndex + 1);\n const innerEnd = atRuleText.lastIndexOf('}');\n const inner = atRuleText.slice(braceIndex + 1, innerEnd);\n const tail = atRuleText.slice(innerEnd);\n\n return `${head}${transformCss(inner, scopeAttr)}${tail}`;\n}\n\n/**\n * Extracts a complete at-rule (potentially with a block) starting at index `start`.\n * Returns the text and the end index.\n */\nfunction extractAtRule(css: string, start: number): { text: string; end: number } {\n // Find either ';' (simple at-rule) or the matching '{...}' (block at-rule)\n let i = start;\n while (i < css.length && charAt(css, i) !== '{' && charAt(css, i) !== ';') {\n i++;\n }\n\n if (i >= css.length) {\n return { text: css.slice(start), end: css.length };\n }\n\n if (charAt(css, i) === ';') {\n return { text: css.slice(start, i + 1), end: i + 1 };\n }\n\n // Block at-rule — find matching closing brace\n const end = findMatchingBrace(css, i);\n if (end === -1) {\n return { text: css.slice(start), end: css.length };\n }\n\n return { text: css.slice(start, end + 1), end: end + 1 };\n}\n\n/**\n * Finds the index of the closing `}` that matches the `{` at `openIndex`.\n * Returns -1 if no matching brace is found.\n */\nfunction findMatchingBrace(css: string, openIndex: number): number {\n let depth = 0;\n for (let i = openIndex; i < css.length; i++) {\n const ch = charAt(css, i);\n if (ch === '{') depth++;\n else if (ch === '}') {\n depth--;\n if (depth === 0) return i;\n }\n }\n return -1;\n}\n","/**\n * @module injectLightStyles\n *\n * Core utility for injecting scoped `<style>` elements into `document.head`\n * to style light DOM slotted content in HELiX components. Uses the\n * `lightStyleRegistry` to deduplicate — each component type is injected at\n * most once per page lifetime.\n *\n * This is the primary mechanism for ensuring Drupal-slotted content inherits\n * proper typography and spacing when rendered into HELiX components.\n *\n * @example\n * ```ts\n * import { injectLightStyles } from '../../utilities/injectLightStyles.js';\n *\n * // In connectedCallback:\n * injectLightStyles('hx-card', 'p { font-size: var(--hx-font-size-md); }');\n * ```\n */\n\nimport { isStyleRegistered, registerStyle } from './lightStyleRegistry.js';\nimport { generateScopedSelectors } from './generateScopedSelectors.js';\n\n/**\n * Injects a scoped `<style>` element into `document.head` for light DOM content\n * belonging to `componentName`. The CSS is automatically scoped via\n * `generateScopedSelectors` so styles only apply inside\n * `[data-hx-styled=\"componentName\"]` wrappers.\n *\n * Safe to call multiple times — subsequent calls for the same `componentName`\n * are no-ops (deduplication via `lightStyleRegistry`).\n *\n * No-op in SSR environments where `document` is not defined.\n *\n * @param componentName - The component tag name used as the scope identifier\n * (e.g. `'hx-card'`). Must be unique per component type.\n * @param css - The raw CSS to scope and inject. Selectors will be prefixed with\n * `[data-hx-styled=\"componentName\"]`.\n */\nexport function injectLightStyles(componentName: string, css: string): void {\n if (typeof document === 'undefined') return;\n\n if (isStyleRegistered(componentName)) return;\n\n const scopedCss = generateScopedSelectors(componentName, css);\n\n const styleEl = document.createElement('style');\n styleEl.setAttribute('data-hx-light-styles', componentName);\n styleEl.textContent = scopedCss;\n\n document.head.appendChild(styleEl);\n registerStyle(componentName, styleEl);\n}\n","import { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { hxStyleScopeStyles } from './hx-style-scope.styles.js';\nimport { injectLightStyles } from '../../utilities/injectLightStyles.js';\n\n/**\n * A transparent wrapper component that injects scoped light DOM styles for its\n * slotted children. Designed for use in Drupal Twig templates where slotted\n * content lives in the light DOM and cannot inherit Shadow DOM styles.\n *\n * On connection, the component:\n * 1. Sets `data-hx-styled` on itself so scoped CSS selectors resolve correctly.\n * 2. Calls `injectLightStyles` to inject a `<style>` into `document.head` — once\n * per component type, deduplicated via `lightStyleRegistry`.\n *\n * The element renders as `display: contents` so it does not affect layout.\n *\n * @summary Scoped light DOM style injection wrapper for Drupal-slotted content.\n *\n * @tag hx-style-scope\n *\n * @slot - Default slot for any light DOM content that should receive scoped styles.\n *\n * @example\n * ```html\n * <hx-style-scope component=\"hx-card\">\n * <p>This paragraph will receive hx-card light DOM styles.</p>\n * </hx-style-scope>\n * ```\n *\n * @example Drupal Twig usage via macro\n * ```twig\n * {% import '@helix/hx-style-scope.macro.twig' as hx %}\n * {{ hx.scope('hx-card', content) }}\n * ```\n */\n@customElement('hx-style-scope')\nexport class HxStyleScope extends LitElement {\n static override styles = [hxStyleScopeStyles];\n\n /**\n * The component tag name whose light DOM styles should be injected.\n * Must match a registered component name (e.g. `'hx-card'`).\n *\n * When set, the element also applies `data-hx-styled` to itself so that\n * scoped CSS selectors generated by `generateScopedSelectors` resolve\n * correctly against slotted child elements.\n *\n * @attr component\n */\n @property({ type: String, reflect: true })\n component: string = '';\n\n /**\n * The CSS to inject as scoped light DOM styles. When provided alongside\n * `component`, this CSS will be scoped under `[data-hx-styled=\"component\"]`\n * and injected into `document.head` (once per component type).\n *\n * If omitted, `injectLightStyles` is still called but with an empty string,\n * which is a no-op for actual style injection.\n *\n * @attr light-css\n */\n @property({ type: String, attribute: 'light-css' })\n lightCss: string = '';\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._applyScope();\n }\n\n override updated(changed: Map<string, unknown>): void {\n if (changed.has('component') || changed.has('lightCss')) {\n this._applyScope();\n }\n }\n\n /**\n * Applies the `data-hx-styled` attribute and triggers style injection.\n * Called on connect and whenever `component` or `lightCss` changes.\n */\n private _applyScope(): void {\n if (!this.component) return;\n\n // Set the scoping attribute so CSS selectors from generateScopedSelectors work.\n this.setAttribute('data-hx-styled', this.component);\n\n if (this.lightCss) {\n injectLightStyles(this.component, this.lightCss);\n }\n }\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-style-scope': HxStyleScope;\n }\n}\n"],"names":["hxStyleScopeStyles","css","lightStyleRegistry","isStyleRegistered","componentName","registerStyle","el","generateScopedSelectors","scopeAttr","transformCss","charAt","str","i","result","len","atBlock","extractAtRule","transformAtRule","selectorEnd","selectorRaw","bodyStart","bodyEnd","findMatchingBrace","body","scopedSelector","scopeSelector","part","trimmed","inner","atRuleText","containerAtRules","braceIndex","head","innerEnd","tail","start","end","openIndex","depth","ch","injectLightStyles","scopedCss","styleEl","HxStyleScope","LitElement","changed","html","__decorateClass","property","customElement"],"mappings":"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"}
@@ -52,7 +52,10 @@ const b = p`
52
52
 
53
53
  .switch__track:focus-visible {
54
54
  outline: var(--hx-focus-ring-width, 2px) solid
55
- var(--hx-switch-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
55
+ var(
56
+ --hx-switch-focus-ring-color,
57
+ var(--hx-focus-ring-color, var(--hx-color-primary-400, #60a5fa))
58
+ );
56
59
  outline-offset: var(--hx-focus-ring-offset, 2px);
57
60
  }
58
61
 
@@ -213,15 +216,15 @@ let e = class extends x {
213
216
  this._trackEl ?? void 0
214
217
  ) : this._internals.setValidity({});
215
218
  }
216
- /** Called by the form when it resets. */
219
+ /** @internal */
217
220
  formResetCallback() {
218
221
  this.checked = !1, this._internals.setFormValue(null);
219
222
  }
220
- /** Called when the form restores state (e.g., back/forward navigation). */
223
+ /** @internal */
221
224
  formStateRestoreCallback(t, r) {
222
225
  typeof t == "string" && (this.checked = t === this.value);
223
226
  }
224
- /** Called when a parent fieldset is disabled/enabled. */
227
+ /** @internal */
225
228
  formDisabledCallback(t) {
226
229
  this.disabled = t;
227
230
  }
@@ -367,4 +370,4 @@ e = i([
367
370
  export {
368
371
  e as H
369
372
  };
370
- //# sourceMappingURL=hx-switch-BgX8kuWt.js.map
373
+ //# sourceMappingURL=hx-switch-C0Lp5RGy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-switch-C0Lp5RGy.js","sources":["../../src/components/hx-switch/hx-switch.styles.ts","../../src/components/hx-switch/hx-switch.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixSwitchStyles = css`\n :host {\n display: block;\n }\n\n :host([disabled]) {\n opacity: var(--hx-opacity-disabled, 0.5);\n pointer-events: none;\n }\n\n * {\n box-sizing: border-box;\n }\n\n /* --- Layout --- */\n\n .switch {\n display: flex;\n flex-direction: column;\n gap: var(--hx-space-1, 0.25rem);\n font-family: var(--hx-font-family-sans, sans-serif);\n }\n\n .switch__control-row {\n display: flex;\n align-items: center;\n gap: var(--hx-space-2, 0.5rem);\n }\n\n /* --- Track --- */\n\n .switch__track {\n position: relative;\n display: inline-flex;\n align-items: center;\n flex-shrink: 0;\n border: none;\n padding: 0;\n border-radius: var(--hx-border-radius-full, 9999px);\n background-color: var(--hx-switch-track-bg, var(--hx-color-neutral-300, #ced4da));\n cursor: pointer;\n transition: background-color var(--hx-transition-fast, 150ms ease);\n outline: none;\n -webkit-appearance: none;\n appearance: none;\n }\n\n .switch__track:focus-visible {\n outline: var(--hx-focus-ring-width, 2px) solid\n var(\n --hx-switch-focus-ring-color,\n var(--hx-focus-ring-color, var(--hx-color-primary-400, #60a5fa))\n );\n outline-offset: var(--hx-focus-ring-offset, 2px);\n }\n\n .switch--checked .switch__track {\n background-color: var(--hx-switch-track-checked-bg, var(--hx-color-primary-500, #2563eb));\n }\n\n /* --- Thumb --- */\n\n .switch__thumb {\n position: absolute;\n border-radius: var(--hx-border-radius-full, 9999px);\n background-color: var(--hx-switch-thumb-bg, var(--hx-color-neutral-0, #ffffff));\n box-shadow: var(--hx-switch-thumb-shadow, var(--hx-shadow-sm, 0 1px 2px 0 rgb(0 0 0 / 0.05)));\n transition: transform var(--hx-transition-fast, 150ms ease);\n }\n\n /* --- Size: sm (track 32x18, thumb 14px) --- */\n\n .switch--sm .switch__track {\n width: var(--hx-switch-track-width-sm, var(--hx-size-8, 2rem));\n height: var(--hx-switch-track-height-sm, var(--hx-size-4-5, 1.125rem));\n }\n\n .switch--sm .switch__thumb {\n width: var(--hx-switch-thumb-size-sm, var(--hx-size-3-5, 0.875rem));\n height: var(--hx-switch-thumb-size-sm, var(--hx-size-3-5, 0.875rem));\n top: 50%;\n left: var(--hx-switch-thumb-offset, var(--hx-space-0-5, 0.125rem));\n transform: translateY(-50%);\n }\n\n .switch--sm.switch--checked .switch__thumb {\n transform: translateY(-50%)\n translateX(var(--hx-switch-thumb-size-sm, var(--hx-size-3-5, 0.875rem)));\n }\n\n /* --- Size: md (track 40x22, thumb 18px) --- */\n\n .switch--md .switch__track {\n width: var(--hx-switch-track-width-md, var(--hx-size-10, 2.5rem));\n height: var(--hx-switch-track-height-md, var(--hx-size-5-5, 1.375rem));\n }\n\n .switch--md .switch__thumb {\n width: var(--hx-switch-thumb-size-md, var(--hx-size-4-5, 1.125rem));\n height: var(--hx-switch-thumb-size-md, var(--hx-size-4-5, 1.125rem));\n top: 50%;\n left: var(--hx-switch-thumb-offset, var(--hx-space-0-5, 0.125rem));\n transform: translateY(-50%);\n }\n\n .switch--md.switch--checked .switch__thumb {\n transform: translateY(-50%)\n translateX(var(--hx-switch-thumb-size-md, var(--hx-size-4-5, 1.125rem)));\n }\n\n /* --- Size: lg (track 48x26, thumb 22px) --- */\n\n .switch--lg .switch__track {\n width: var(--hx-switch-track-width-lg, var(--hx-size-12, 3rem));\n height: var(--hx-switch-track-height-lg, var(--hx-size-6-5, 1.625rem));\n }\n\n .switch--lg .switch__thumb {\n width: var(--hx-switch-thumb-size-lg, var(--hx-size-5-5, 1.375rem));\n height: var(--hx-switch-thumb-size-lg, var(--hx-size-5-5, 1.375rem));\n top: 50%;\n left: var(--hx-switch-thumb-offset, var(--hx-space-0-5, 0.125rem));\n transform: translateY(-50%);\n }\n\n .switch--lg.switch--checked .switch__thumb {\n transform: translateY(-50%)\n translateX(var(--hx-switch-thumb-size-lg, var(--hx-size-5-5, 1.375rem)));\n }\n\n /* --- Label --- */\n\n .switch__label {\n font-size: var(--hx-font-size-sm, 0.875rem);\n font-weight: var(--hx-font-weight-medium, 500);\n color: var(--hx-switch-label-color, var(--hx-color-neutral-700, #343a40));\n line-height: var(--hx-line-height-normal, 1.5);\n cursor: pointer;\n user-select: none;\n -webkit-user-select: none;\n }\n\n .switch__required-marker {\n color: var(--hx-switch-error-color, var(--hx-color-error-text, #b91c1c));\n font-weight: var(--hx-font-weight-bold, 700);\n }\n\n /* --- Help Text & Error --- */\n\n .switch__help-text {\n font-size: var(--hx-font-size-xs, 0.75rem);\n color: var(--hx-switch-help-text-color, var(--hx-color-neutral-500, #6c757d));\n line-height: var(--hx-line-height-normal, 1.5);\n }\n\n .switch__error {\n font-size: var(--hx-font-size-xs, 0.75rem);\n color: var(--hx-switch-error-color, var(--hx-color-error-text, #b91c1c));\n line-height: var(--hx-line-height-normal, 1.5);\n }\n\n /* --- Reduced Motion --- */\n\n @media (prefers-reduced-motion: reduce) {\n .switch__track,\n .switch__thumb {\n transition: none;\n }\n }\n`;\n","import { LitElement, html, nothing, type PropertyValues } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { tokenStyles } from '@helixui/tokens/lit';\nimport { helixSwitchStyles } from './hx-switch.styles.js';\n\n/**\n * A toggle switch component for on/off states.\n *\n * Uses `role=\"switch\"` with `aria-checked` to convey toggle state.\n * Supports keyboard activation via Space key (per ARIA APG switch pattern).\n * Label association is handled through `aria-labelledby`, and\n * error/help text are linked via `aria-describedby`.\n *\n * @summary Form-associated toggle switch with label, error, and help text.\n *\n * @tag hx-switch\n *\n * @slot - Custom label content (overrides the label property).\n * @slot error - Custom error content (overrides the error property).\n * @slot help-text - Custom help text content (overrides the helpText property).\n *\n * @fires {CustomEvent<{checked: boolean, value: string}>} hx-change - Dispatched when the switch is toggled.\n *\n * @csspart switch - The switch container (track + thumb wrapper).\n * @csspart track - The track background element.\n * @csspart thumb - The sliding thumb element.\n * @csspart label - The label text element.\n * @csspart help-text - The help text container.\n * @csspart error - The error message container.\n *\n * @cssprop [--hx-switch-track-bg=var(--hx-color-neutral-300)] - Track background color.\n * @cssprop [--hx-switch-track-checked-bg=var(--hx-color-primary-500)] - Track background when checked.\n * @cssprop [--hx-switch-thumb-bg=var(--hx-color-neutral-0)] - Thumb background color.\n * @cssprop [--hx-switch-thumb-shadow=var(--hx-shadow-sm)] - Thumb box shadow.\n * @cssprop [--hx-switch-focus-ring-color=var(--hx-focus-ring-color)] - Focus ring color.\n * @cssprop [--hx-switch-label-color=var(--hx-color-neutral-700)] - Label text color.\n * @cssprop [--hx-switch-error-color=var(--hx-color-error-500)] - Error message color.\n * @cssprop [--hx-switch-help-text-color=var(--hx-color-neutral-500)] - Help text color.\n */\n@customElement('hx-switch')\nexport class HelixSwitch extends LitElement {\n static override styles = [tokenStyles, helixSwitchStyles];\n\n /** Monotonic counter for deterministic, unique IDs across instances. */\n /** @internal */\n private static _instanceCounter = 0;\n\n // ─── Form Association ───\n\n /** @internal */\n static formAssociated = true;\n\n /** ElementInternals instance for form association, validation, and ARIA. */\n /** @internal */\n private _internals: ElementInternals;\n\n constructor() {\n super();\n /** @internal */\n this._internals = this.attachInternals();\n }\n\n // ─── Properties ───\n\n /**\n * Whether the switch is toggled on.\n * @attr checked\n */\n @property({ type: Boolean, reflect: true })\n checked = false;\n\n /**\n * Whether the switch is disabled.\n * @attr disabled\n */\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n /**\n * Whether the switch is required for form submission.\n * @attr required\n */\n @property({ type: Boolean, reflect: true })\n required = false;\n\n /**\n * The name of the switch, used for form submission.\n * @attr name\n */\n @property({ type: String })\n name = '';\n\n /**\n * The value submitted when the switch is checked.\n * @attr value\n */\n @property({ type: String })\n value = 'on';\n\n /**\n * The visible label text for the switch.\n * @attr label\n */\n @property({ type: String })\n label = '';\n\n /**\n * Size variant of the switch.\n * @attr hx-size\n */\n @property({ type: String, reflect: true, attribute: 'hx-size' })\n size: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Error message to display. When set, the switch enters an error state.\n * @attr error\n */\n @property({ type: String })\n error = '';\n\n /**\n * Help text displayed below the switch for guidance.\n * @attr help-text\n */\n @property({ type: String, attribute: 'help-text' })\n helpText = '';\n\n /**\n * Validation message shown when the field is required but empty.\n * @attr required-message\n */\n @property({ attribute: 'required-message' })\n requiredMessage = 'This field is required.';\n\n // ─── Lifecycle ───\n\n override updated(changedProperties: PropertyValues<this>): void {\n super.updated(changedProperties);\n if (changedProperties.has('checked') || changedProperties.has('value')) {\n this._internals.setFormValue(this.checked ? this.value : null);\n this._updateValidity();\n }\n if (changedProperties.has('required')) {\n this._updateValidity();\n }\n }\n\n // ─── Form Integration ───\n\n /** Returns the associated form element, if any. */\n get form(): HTMLFormElement | null {\n return this._internals.form;\n }\n\n /** Returns the validation message. */\n get validationMessage(): string {\n return this._internals.validationMessage;\n }\n\n /** Returns the ValidityState object. */\n get validity(): ValidityState {\n return this._internals.validity;\n }\n\n /** Checks whether the switch satisfies its constraints. */\n checkValidity(): boolean {\n return this._internals.checkValidity();\n }\n\n /** Reports validity and shows the browser's constraint validation UI. */\n reportValidity(): boolean {\n return this._internals.reportValidity();\n }\n\n /** Recalculates and sets the validity state based on required and checked. */\n /** @internal */\n private _updateValidity(): void {\n if (this.required && !this.checked) {\n this._internals.setValidity(\n { valueMissing: true },\n this.error || this.requiredMessage,\n this._trackEl ?? undefined,\n );\n } else {\n this._internals.setValidity({});\n }\n }\n\n /** @internal */\n formResetCallback(): void {\n this.checked = false;\n this._internals.setFormValue(null);\n }\n\n /** @internal */\n formStateRestoreCallback(state: File | string | null, _mode: 'restore' | 'autocomplete'): void {\n if (typeof state === 'string') {\n this.checked = state === this.value;\n }\n }\n\n /** @internal */\n formDisabledCallback(disabled: boolean): void {\n this.disabled = disabled;\n }\n\n /** Reference to the native button element acting as the switch track. * @internal\n */\n @query('.switch__track')\n private _trackEl: HTMLButtonElement | null | undefined;\n\n /** Whether the error slot has assigned content. */\n /** @internal */\n @state() private _hasErrorSlot = false;\n\n /** Whether the default slot has assigned content (slotted label). */\n /** @internal */\n @state() private _hasDefaultSlot = false;\n\n // ─── Slot Handlers ───\n\n /** Updates _hasErrorSlot when error slot content changes. */\n /** @internal */\n private _handleErrorSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasErrorSlot = slot.assignedNodes({ flatten: true }).length > 0;\n }\n\n /** Updates _hasDefaultSlot when default slot content changes. */\n /** @internal */\n private _handleDefaultSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasDefaultSlot = slot.assignedNodes({ flatten: true }).length > 0;\n }\n\n // ─── Event Handling ───\n\n /** Toggles checked state and dispatches hx-change event. */\n /** @internal */\n private _toggle(): void {\n if (this.disabled) return;\n this.checked = !this.checked;\n\n this.dispatchEvent(\n new CustomEvent<{ checked: boolean; value: string }>('hx-change', {\n bubbles: true,\n composed: true,\n detail: { checked: this.checked, value: this.value },\n }),\n );\n }\n\n /** Handles click events on the track. */\n /** @internal */\n private _handleClick(): void {\n this._toggle();\n }\n\n /** Handles keydown events — Space toggles the switch per ARIA APG. */\n /** @internal */\n private _handleKeyDown(e: KeyboardEvent): void {\n if (e.key === ' ') {\n e.preventDefault();\n this._toggle();\n }\n }\n\n // ─── Public Methods ───\n\n /** Moves focus to the switch track element. */\n override focus(options?: FocusOptions): void {\n this._trackEl?.focus(options);\n }\n\n // ─── Render ───\n\n /** Unique ID for this switch instance, used for ARIA associations. */\n /** @internal */\n private _switchId = `hx-switch-${++HelixSwitch._instanceCounter}`;\n /** ID for the label element, referenced by aria-labelledby. */\n /** @internal */\n private _labelId = `${this._switchId}-label`;\n /** ID for the help text element, referenced by aria-describedby. */\n /** @internal */\n private _helpTextId = `${this._switchId}-help`;\n /** ID for the error element, referenced by aria-describedby. */\n /** @internal */\n private _errorId = `${this._switchId}-error`;\n\n override render() {\n const hasError = !!this.error;\n const hasLabel = !!this.label || this._hasDefaultSlot;\n\n const containerClasses = {\n switch: true,\n 'switch--checked': this.checked,\n 'switch--disabled': this.disabled,\n 'switch--required': this.required,\n 'switch--error': hasError,\n [`switch--${this.size}`]: true,\n };\n\n const describedBy =\n [\n hasError || this._hasErrorSlot ? this._errorId : null,\n this.helpText && !hasError ? this._helpTextId : null,\n ]\n .filter(Boolean)\n .join(' ') || undefined;\n\n return html`\n <div part=\"switch\" class=${classMap(containerClasses)}>\n <div class=\"switch__control-row\">\n <button\n part=\"track\"\n class=\"switch__track\"\n id=${this._switchId}\n type=\"button\"\n role=\"switch\"\n aria-checked=${this.checked ? 'true' : 'false'}\n aria-labelledby=${ifDefined(hasLabel ? this._labelId : undefined)}\n aria-describedby=${ifDefined(describedBy)}\n aria-invalid=${hasError ? 'true' : nothing}\n aria-required=${this.required ? 'true' : nothing}\n ?disabled=${this.disabled}\n @click=${this._handleClick}\n @keydown=${this._handleKeyDown}\n >\n <span part=\"thumb\" class=\"switch__thumb\"></span>\n </button>\n\n <label part=\"label\" class=\"switch__label\" id=${this._labelId} for=${this._switchId}>\n <slot @slotchange=${this._handleDefaultSlotChange}>${this.label}</slot>${this.required\n ? html`<span class=\"switch__required-marker\" aria-hidden=\"true\">*</span>`\n : nothing}\n </label>\n </div>\n\n <slot name=\"error\" @slotchange=${this._handleErrorSlotChange}>\n ${hasError\n ? html`<div part=\"error\" class=\"switch__error\" id=${this._errorId} role=\"alert\">\n ${this.error}\n </div>`\n : nothing}\n </slot>\n\n ${this.helpText && !hasError\n ? html`\n <div part=\"help-text\" class=\"switch__help-text\" id=${this._helpTextId}>\n <slot name=\"help-text\">${this.helpText}</slot>\n </div>\n `\n : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-switch': HelixSwitch;\n }\n}\n\n/** @deprecated Use HxSwitch instead. */\nexport type WcSwitch = HelixSwitch;\nexport type HxSwitch = HelixSwitch;\n"],"names":["helixSwitchStyles","css","HelixSwitch","LitElement","changedProperties","state","_mode","disabled","e","slot","options","_a","hasError","hasLabel","containerClasses","describedBy","html","classMap","ifDefined","nothing","tokenStyles","__decorateClass","property","query","customElement"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
- import { css as x, LitElement as _, nothing as $, html as m } from "lit";
1
+ import { css as v, LitElement as _, html as m, nothing as N } from "lit";
2
2
  import { property as h, state as g, customElement as y } from "lit/decorators.js";
3
3
  import { tokenStyles as w } from "@helixui/tokens/lit";
4
4
  import { d as E } from "./dev-warn-YlwPHjtX.js";
5
- const L = x`
5
+ const O = v`
6
6
  :host {
7
7
  display: block;
8
8
  font-family: var(--hx-font-family-sans, sans-serif);
@@ -79,138 +79,163 @@ const L = x`
79
79
  }
80
80
  }
81
81
  `;
82
- var k = Object.defineProperty, z = Object.getOwnPropertyDescriptor, p = (t, e, a, i) => {
83
- for (var s = i > 1 ? void 0 : i ? z(e, a) : e, o = t.length - 1, r; o >= 0; o--)
84
- (r = t[o]) && (s = (i ? r(e, a, s) : r(s)) || s);
85
- return i && s && k(e, a, s), s;
82
+ var I = Object.defineProperty, k = Object.getOwnPropertyDescriptor, p = (e, t, a, i) => {
83
+ for (var s = i > 1 ? void 0 : i ? k(t, a) : t, r = e.length - 1, n; r >= 0; r--)
84
+ (n = e[r]) && (s = (i ? n(t, a, s) : n(s)) || s);
85
+ return i && s && I(t, a, s), s;
86
86
  };
87
- let I = 0, d = class extends _ {
87
+ let L = 0, b = class extends _ {
88
88
  constructor() {
89
- super(...arguments), this._id = `hx-tabs-${++I}`, this.orientation = "horizontal", this.activation = "automatic", this.label = "", this._activePanel = "", this._cachedTabs = null, this._cachedPanels = null, this._observer = null, this._handleTabSelect = (t) => {
90
- if (!(t instanceof CustomEvent)) return;
91
- t.stopPropagation();
92
- const e = t.composedPath().find((a) => a instanceof Element && a.tagName.toLowerCase() === "hx-tab");
93
- e && this._activateTab(e);
89
+ super(...arguments), this._id = `hx-tabs-${++L}`, this.orientation = "horizontal", this.activation = "automatic", this.label = "", this._activePanel = "", this._cachedTabs = null, this._cachedPanels = null, this._observer = null, this._pendingIndex = null, this._handleTabSelect = (e) => {
90
+ if (!(e instanceof CustomEvent)) return;
91
+ e.stopPropagation();
92
+ const t = e.composedPath().find((a) => a instanceof Element && a.tagName.toLowerCase() === "hx-tab");
93
+ t && this._activateTab(t);
94
94
  }, this._handleSlotChange = () => {
95
95
  if (this._warnInvalidSlotContent(), this._cachedTabs = null, this._cachedPanels = null, this._syncTabsAndPanels(), !this._getPanels().some((a) => a.name === this._activePanel)) {
96
96
  const a = this._getEnabledTabs()[0];
97
97
  a ? this._activateTab(a, !1) : this._activePanel = "";
98
98
  }
99
- }, this._handleKeydown = (t) => {
100
- var P, S, T, C;
101
- const e = this._getEnabledTabs();
102
- if (e.length === 0)
99
+ }, this._handleKeydown = (e) => {
100
+ var T, P, S, C;
101
+ const t = this._getTabs();
102
+ if (t.length === 0)
103
103
  return;
104
104
  const a = this.orientation === "horizontal", i = a ? "ArrowLeft" : "ArrowUp", s = a ? "ArrowRight" : "ArrowDown";
105
- if (![i, s, "Home", "End", " ", "Enter"].includes(t.key))
105
+ if (![i, s, "Home", "End", " ", "Enter"].includes(e.key))
106
106
  return;
107
- const r = e.find((u) => u === document.activeElement);
108
- if (t.key === " " || t.key === "Enter") {
109
- r && (t.preventDefault(), this._activateTab(r), (S = (P = r.shadowRoot) == null ? void 0 : P.querySelector("button")) == null || S.focus());
107
+ const n = t.find((u) => u === document.activeElement);
108
+ if (e.key === " " || e.key === "Enter") {
109
+ n && !n.disabled && (e.preventDefault(), this._activateTab(n), (P = (T = n.shadowRoot) == null ? void 0 : T.querySelector("button")) == null || P.focus());
110
110
  return;
111
111
  }
112
- t.preventDefault();
113
- let c = r ? e.indexOf(r) : -1;
114
- if (c === -1) {
115
- const u = e.find((O) => O.panel === this._activePanel);
116
- c = u ? e.indexOf(u) : 0;
112
+ e.preventDefault();
113
+ let o = n ? t.indexOf(n) : -1;
114
+ if (o === -1) {
115
+ const u = t.find(($) => $.panel === this._activePanel);
116
+ o = u ? t.indexOf(u) : 0;
117
117
  }
118
- let n;
119
- t.key === "Home" ? n = 0 : t.key === "End" ? n = e.length - 1 : t.key === s ? n = (c + 1) % e.length : n = c <= 0 ? e.length - 1 : c - 1;
120
- const f = e[n];
121
- f && ((C = (T = f.shadowRoot) == null ? void 0 : T.querySelector("button")) == null || C.focus(), this.activation === "automatic" && this._activateTab(f));
118
+ let d;
119
+ e.key === "Home" ? d = 0 : e.key === "End" ? d = t.length - 1 : e.key === s ? d = (o + 1) % t.length : d = o <= 0 ? t.length - 1 : o - 1;
120
+ const l = t[d];
121
+ l && ((C = (S = l.shadowRoot) == null ? void 0 : S.querySelector("button")) == null || C.focus(), this.activation === "automatic" && !l.disabled && this._activateTab(l));
122
122
  };
123
123
  }
124
+ // ─── Attribute Observation ───
125
+ static get observedAttributes() {
126
+ return [...super.observedAttributes ?? [], "selected-index"];
127
+ }
128
+ attributeChangedCallback(e, t, a) {
129
+ if (super.attributeChangedCallback(e, t, a), e === "selected-index" && a !== null && t !== a) {
130
+ const i = parseInt(a, 10);
131
+ if (!isNaN(i) && i >= 0)
132
+ if (this.hasUpdated) {
133
+ const s = this._getTabs()[i];
134
+ s && !s.disabled && this._activateTab(s, !1);
135
+ } else
136
+ this._pendingIndex = i;
137
+ }
138
+ }
124
139
  // ─── Public API ───
125
140
  /**
126
141
  * Gets or sets the zero-based index of the currently selected tab.
127
142
  * Setting this programmatically activates the tab at the given index.
143
+ * Can also be set via the `selected-index` HTML attribute for server-side
144
+ * pre-selection (e.g. Drupal Twig templates).
128
145
  */
129
146
  get selectedIndex() {
130
- return this._getTabs().findIndex((t) => t.panel === this._activePanel);
147
+ return this._getTabs().findIndex((e) => e.panel === this._activePanel);
131
148
  }
132
- set selectedIndex(t) {
133
- const e = this._getTabs()[t];
134
- e && !e.disabled && this._activateTab(e, !0);
149
+ set selectedIndex(e) {
150
+ const t = this._getTabs()[e];
151
+ t && !t.disabled && this._activateTab(t, !0);
135
152
  }
136
153
  /** @internal */
137
154
  _getTabs() {
138
155
  return this._cachedTabs || (this._cachedTabs = Array.from(this.querySelectorAll(":scope > hx-tab")).filter(
139
- (t) => t.tagName.toLowerCase() === "hx-tab"
156
+ (e) => e.tagName.toLowerCase() === "hx-tab"
140
157
  )), this._cachedTabs;
141
158
  }
142
159
  /** @internal */
143
160
  _getPanels() {
144
161
  return this._cachedPanels || (this._cachedPanels = Array.from(this.querySelectorAll(":scope > hx-tab-panel")).filter(
145
- (t) => t.tagName.toLowerCase() === "hx-tab-panel"
162
+ (e) => e.tagName.toLowerCase() === "hx-tab-panel"
146
163
  )), this._cachedPanels;
147
164
  }
148
165
  /** @internal */
149
166
  _getEnabledTabs() {
150
- return this._getTabs().filter((t) => !t.disabled);
167
+ return this._getTabs().filter((e) => !e.disabled);
151
168
  }
152
169
  // ─── Lifecycle ───
153
170
  connectedCallback() {
154
- super.connectedCallback(), this.addEventListener("hx-tab-select", this._handleTabSelect), this.addEventListener("keydown", this._handleKeydown), this._observer = new MutationObserver(() => {
171
+ super.connectedCallback(), this.addEventListener("hx-tab-select", this._handleTabSelect), this.addEventListener("keydown", this._handleKeydown), typeof MutationObserver < "u" && (this._observer = new MutationObserver(() => {
155
172
  this._cachedTabs = null, this._cachedPanels = null, this._syncTabsAndPanels();
156
173
  }), this._observer.observe(this, {
157
174
  subtree: !1,
158
175
  attributeFilter: ["panel", "name"]
159
- });
176
+ }));
160
177
  }
161
178
  disconnectedCallback() {
162
- var t;
163
- super.disconnectedCallback(), this.removeEventListener("hx-tab-select", this._handleTabSelect), this.removeEventListener("keydown", this._handleKeydown), (t = this._observer) == null || t.disconnect(), this._observer = null;
179
+ var e;
180
+ super.disconnectedCallback(), this.removeEventListener("hx-tab-select", this._handleTabSelect), this.removeEventListener("keydown", this._handleKeydown), (e = this._observer) == null || e.disconnect(), this._observer = null;
164
181
  }
165
182
  firstUpdated() {
166
- if (this.label, this._syncTabsAndPanels(), !this._activePanel) {
167
- const t = this._getEnabledTabs()[0];
168
- t && this._activateTab(t, !1);
183
+ if (this.label, this._syncTabsAndPanels(), this._pendingIndex !== null) {
184
+ const e = this._getTabs()[this._pendingIndex];
185
+ if (this._pendingIndex = null, e && !e.disabled) {
186
+ this._activateTab(e, !1);
187
+ return;
188
+ }
189
+ }
190
+ if (!this._activePanel) {
191
+ const e = this._getEnabledTabs()[0];
192
+ e && this._activateTab(e, !1);
169
193
  }
170
194
  }
171
- updated(t) {
172
- super.updated(t), t.has("_activePanel") && this._updateTabsAndPanels();
195
+ updated(e) {
196
+ super.updated(e), e.has("_activePanel") && this._updateTabsAndPanels();
173
197
  }
174
198
  // ─── Tab / Panel Sync ───
175
199
  /** @internal */
176
200
  _syncTabsAndPanels() {
177
- const t = this._getTabs(), e = this._getPanels();
178
- t.forEach((a, i) => {
179
- var c;
201
+ const e = this._getTabs(), t = this._getPanels();
202
+ e.forEach((a, i) => {
180
203
  const s = a.id || `hx-tab-${this._id}-${i}`;
181
204
  a.id = s;
182
- const o = a.panel, r = e.find((n) => n.name === o) ?? e[i];
183
- if (r) {
184
- const n = r.id || `hx-panel-${this._id}-${i}`;
185
- r.id = n, a.controls = n;
186
- const f = ((c = a.textContent) == null ? void 0 : c.trim()) ?? "";
187
- f ? (r.setAttribute("aria-label", f), r.removeAttribute("aria-labelledby")) : r.setAttribute("aria-labelledby", s);
205
+ const r = a.panel, n = t.find((o) => o.name === r) ?? t[i];
206
+ if (n) {
207
+ const o = n.id || `hx-panel-${this._id}-${i}`;
208
+ n.id = o, a.controls = o;
209
+ const d = Array.from(a.childNodes).filter(
210
+ (l) => l.nodeType === Node.TEXT_NODE || l.nodeType === Node.ELEMENT_NODE && !l.hasAttribute("slot")
211
+ ).map((l) => l.textContent ?? "").join("").trim();
212
+ d ? (n.setAttribute("aria-label", d), n.removeAttribute("aria-labelledby")) : n.setAttribute("aria-labelledby", s);
188
213
  }
189
214
  }), this._updateTabsAndPanels();
190
215
  }
191
216
  /** @internal */
192
217
  _updateTabsAndPanels() {
193
- const t = this._getTabs(), e = this._getPanels();
194
- t.forEach((a) => {
218
+ const e = this._getTabs(), t = this._getPanels();
219
+ e.forEach((a) => {
195
220
  const i = a.panel === this._activePanel;
196
221
  a.selected = i, a.tabIndex = i ? 0 : -1;
197
- }), e.forEach((a) => {
222
+ }), t.forEach((a) => {
198
223
  a.name === this._activePanel ? (a.removeAttribute("hidden"), a.setAttribute("tabindex", "0")) : (a.setAttribute("hidden", ""), a.setAttribute("tabindex", "-1"));
199
224
  });
200
225
  }
201
226
  // ─── Tab Activation ───
202
227
  /** @internal */
203
- _activateTab(t, e = !0) {
204
- if (t.disabled)
228
+ _activateTab(e, t = !0) {
229
+ if (e.disabled)
205
230
  return;
206
231
  const a = this._getTabs(), i = this._activePanel;
207
- if (this._activePanel = t.panel, e && i !== this._activePanel) {
208
- const s = a.indexOf(t);
232
+ if (this._activePanel = e.panel, t && i !== this._activePanel) {
233
+ const s = a.indexOf(e);
209
234
  this.dispatchEvent(
210
235
  new CustomEvent("hx-tab-change", {
211
236
  bubbles: !0,
212
237
  composed: !0,
213
- detail: { tabId: t.id, index: s }
238
+ detail: { tabId: e.id, index: s }
214
239
  })
215
240
  );
216
241
  }
@@ -218,19 +243,19 @@ let I = 0, d = class extends _ {
218
243
  /** @internal */
219
244
  _warnInvalidSlotContent() {
220
245
  var a, i;
221
- const t = (a = this.shadowRoot) == null ? void 0 : a.querySelector('slot[name="tab"]'), e = (i = this.shadowRoot) == null ? void 0 : i.querySelector("slot:not([name])");
222
- if (t) {
223
- const s = t.assignedElements().filter((o) => o.tagName.toLowerCase() !== "hx-tab");
246
+ const e = (a = this.shadowRoot) == null ? void 0 : a.querySelector('slot[name="tab"]'), t = (i = this.shadowRoot) == null ? void 0 : i.querySelector("slot:not([name])");
247
+ if (e) {
248
+ const s = e.assignedElements().filter((r) => r.tagName.toLowerCase() !== "hx-tab");
224
249
  s.length > 0 && E(
225
250
  "hx-tabs",
226
- `Slot "tab" expects <hx-tab> elements. Found unexpected: ${s.map((o) => `<${o.tagName.toLowerCase()}>`).join(", ")}`
251
+ `Slot "tab" expects <hx-tab> elements. Found unexpected: ${s.map((r) => `<${r.tagName.toLowerCase()}>`).join(", ")}`
227
252
  );
228
253
  }
229
- if (e) {
230
- const s = e.assignedElements().filter((o) => o.tagName.toLowerCase() !== "hx-tab-panel");
254
+ if (t) {
255
+ const s = t.assignedElements().filter((r) => r.tagName.toLowerCase() !== "hx-tab-panel");
231
256
  s.length > 0 && E(
232
257
  "hx-tabs",
233
- `Default slot expects <hx-tab-panel> elements. Found unexpected: ${s.map((o) => `<${o.tagName.toLowerCase()}>`).join(", ")}`
258
+ `Default slot expects <hx-tab-panel> elements. Found unexpected: ${s.map((r) => `<${r.tagName.toLowerCase()}>`).join(", ")}`
234
259
  );
235
260
  }
236
261
  }
@@ -243,7 +268,7 @@ let I = 0, d = class extends _ {
243
268
  class="tablist"
244
269
  role="tablist"
245
270
  aria-orientation=${this.orientation}
246
- aria-label=${this.label || $}
271
+ aria-label=${this.label || "Tabs"}
247
272
  >
248
273
  <slot name="tab" @slotchange=${this._handleSlotChange}></slot>
249
274
  </div>
@@ -254,23 +279,23 @@ let I = 0, d = class extends _ {
254
279
  `;
255
280
  }
256
281
  };
257
- d.styles = [w, L];
282
+ b.styles = [w, O];
258
283
  p([
259
284
  h({ type: String, reflect: !0 })
260
- ], d.prototype, "orientation", 2);
285
+ ], b.prototype, "orientation", 2);
261
286
  p([
262
287
  h({ type: String, attribute: "activation", reflect: !0 })
263
- ], d.prototype, "activation", 2);
288
+ ], b.prototype, "activation", 2);
264
289
  p([
265
290
  h({ type: String, reflect: !0 })
266
- ], d.prototype, "label", 2);
291
+ ], b.prototype, "label", 2);
267
292
  p([
268
293
  g()
269
- ], d.prototype, "_activePanel", 2);
270
- d = p([
294
+ ], b.prototype, "_activePanel", 2);
295
+ b = p([
271
296
  y("hx-tabs")
272
- ], d);
273
- const N = x`
297
+ ], b);
298
+ const z = v`
274
299
  :host {
275
300
  display: inline-block;
276
301
  }
@@ -334,15 +359,22 @@ const N = x`
334
359
 
335
360
  .tab:focus-visible {
336
361
  outline: var(--hx-focus-ring-width, 2px) solid
337
- var(--hx-tabs-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
362
+ var(
363
+ --hx-tabs-focus-ring-color,
364
+ var(--hx-focus-ring-color, var(--hx-color-primary-400, #60a5fa))
365
+ );
338
366
  outline-offset: var(--hx-focus-ring-offset, 2px);
339
367
  border-radius: var(--hx-border-radius-sm, 0.125rem);
340
368
  }
341
369
 
342
370
  /* ─── Disabled State ─── */
343
371
 
344
- .tab[aria-disabled='true'] {
372
+ :host([disabled]) {
345
373
  cursor: not-allowed;
374
+ }
375
+
376
+ .tab[aria-disabled='true'] {
377
+ pointer-events: none;
346
378
  color: var(--hx-color-neutral-400, #adb5bd);
347
379
  }
348
380
 
@@ -363,15 +395,19 @@ const N = x`
363
395
  }
364
396
  }
365
397
  `;
366
- var D = Object.defineProperty, j = Object.getOwnPropertyDescriptor, b = (t, e, a, i) => {
367
- for (var s = i > 1 ? void 0 : i ? j(e, a) : e, o = t.length - 1, r; o >= 0; o--)
368
- (r = t[o]) && (s = (i ? r(e, a, s) : r(s)) || s);
369
- return i && s && D(e, a, s), s;
398
+ var D = Object.defineProperty, j = Object.getOwnPropertyDescriptor, f = (e, t, a, i) => {
399
+ for (var s = i > 1 ? void 0 : i ? j(t, a) : t, r = e.length - 1, n; r >= 0; r--)
400
+ (n = e[r]) && (s = (i ? n(t, a, s) : n(s)) || s);
401
+ return i && s && D(t, a, s), s;
370
402
  };
371
- let l = class extends _ {
403
+ let c = class extends _ {
372
404
  constructor() {
373
405
  super(...arguments), this.panel = "", this.selected = !1, this.disabled = !1, this.controls = "", this._hasPrefixSlot = !1, this._hasSuffixSlot = !1;
374
406
  }
407
+ // ─── Lifecycle ───
408
+ connectedCallback() {
409
+ super.connectedCallback(), this.closest("hx-tabs");
410
+ }
375
411
  // ─── Event Handling ───
376
412
  /** @internal */
377
413
  _handleClick() {
@@ -384,14 +420,14 @@ let l = class extends _ {
384
420
  );
385
421
  }
386
422
  /** @internal */
387
- _handlePrefixSlotChange(t) {
388
- const e = t.target;
389
- this._hasPrefixSlot = e.assignedNodes({ flatten: !0 }).length > 0;
423
+ _handlePrefixSlotChange(e) {
424
+ const t = e.target;
425
+ this._hasPrefixSlot = t.assignedNodes({ flatten: !0 }).length > 0;
390
426
  }
391
427
  /** @internal */
392
- _handleSuffixSlotChange(t) {
393
- const e = t.target;
394
- this._hasSuffixSlot = e.assignedNodes({ flatten: !0 }).length > 0;
428
+ _handleSuffixSlotChange(e) {
429
+ const t = e.target;
430
+ this._hasSuffixSlot = t.assignedNodes({ flatten: !0 }).length > 0;
395
431
  }
396
432
  // ─── Render ───
397
433
  render() {
@@ -402,7 +438,7 @@ let l = class extends _ {
402
438
  role="tab"
403
439
  aria-selected=${this.selected ? "true" : "false"}
404
440
  aria-disabled=${this.disabled ? "true" : "false"}
405
- aria-controls=${this.controls || $}
441
+ aria-controls=${this.controls || N}
406
442
  tabindex=${this.selected ? "0" : "-1"}
407
443
  @click=${this._handleClick}
408
444
  >
@@ -417,29 +453,29 @@ let l = class extends _ {
417
453
  `;
418
454
  }
419
455
  };
420
- l.styles = [w, N];
421
- b([
456
+ c.styles = [w, z];
457
+ f([
422
458
  h({ type: String, reflect: !0 })
423
- ], l.prototype, "panel", 2);
424
- b([
459
+ ], c.prototype, "panel", 2);
460
+ f([
425
461
  h({ type: Boolean, reflect: !0 })
426
- ], l.prototype, "selected", 2);
427
- b([
462
+ ], c.prototype, "selected", 2);
463
+ f([
428
464
  h({ type: Boolean, reflect: !0 })
429
- ], l.prototype, "disabled", 2);
430
- b([
465
+ ], c.prototype, "disabled", 2);
466
+ f([
431
467
  h({ type: String, attribute: !1 })
432
- ], l.prototype, "controls", 2);
433
- b([
468
+ ], c.prototype, "controls", 2);
469
+ f([
434
470
  g()
435
- ], l.prototype, "_hasPrefixSlot", 2);
436
- b([
471
+ ], c.prototype, "_hasPrefixSlot", 2);
472
+ f([
437
473
  g()
438
- ], l.prototype, "_hasSuffixSlot", 2);
439
- l = b([
474
+ ], c.prototype, "_hasSuffixSlot", 2);
475
+ c = f([
440
476
  y("hx-tab")
441
- ], l);
442
- const H = x`
477
+ ], c);
478
+ const H = v`
443
479
  :host {
444
480
  display: block;
445
481
  }
@@ -454,7 +490,10 @@ const H = x`
454
490
 
455
491
  :host(:focus-visible) {
456
492
  outline: var(--hx-focus-ring-width, 2px) solid
457
- var(--hx-tabs-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
493
+ var(
494
+ --hx-tabs-focus-ring-color,
495
+ var(--hx-focus-ring-color, var(--hx-color-primary-400, #60a5fa))
496
+ );
458
497
  outline-offset: var(--hx-focus-ring-offset, 2px);
459
498
  border-radius: var(--hx-border-radius-sm, 0.125rem);
460
499
  }
@@ -468,12 +507,12 @@ const H = x`
468
507
  outline: none;
469
508
  }
470
509
  `;
471
- var K = Object.defineProperty, R = Object.getOwnPropertyDescriptor, A = (t, e, a, i) => {
472
- for (var s = i > 1 ? void 0 : i ? R(e, a) : e, o = t.length - 1, r; o >= 0; o--)
473
- (r = t[o]) && (s = (i ? r(e, a, s) : r(s)) || s);
474
- return i && s && K(e, a, s), s;
510
+ var K = Object.defineProperty, R = Object.getOwnPropertyDescriptor, A = (e, t, a, i) => {
511
+ for (var s = i > 1 ? void 0 : i ? R(t, a) : t, r = e.length - 1, n; r >= 0; r--)
512
+ (n = e[r]) && (s = (i ? n(t, a, s) : n(s)) || s);
513
+ return i && s && K(t, a, s), s;
475
514
  };
476
- let v = class extends _ {
515
+ let x = class extends _ {
477
516
  constructor() {
478
517
  super(...arguments), this.name = "";
479
518
  }
@@ -490,16 +529,16 @@ let v = class extends _ {
490
529
  `;
491
530
  }
492
531
  };
493
- v.styles = [w, H];
532
+ x.styles = [w, H];
494
533
  A([
495
534
  h({ type: String, reflect: !0 })
496
- ], v.prototype, "name", 2);
497
- v = A([
535
+ ], x.prototype, "name", 2);
536
+ x = A([
498
537
  y("hx-tab-panel")
499
- ], v);
538
+ ], x);
500
539
  export {
501
- l as H,
502
- v as a,
503
- d as b
540
+ c as H,
541
+ x as a,
542
+ b
504
543
  };
505
- //# sourceMappingURL=hx-tab-panel-DhOq67jj.js.map
544
+ //# sourceMappingURL=hx-tab-panel-Dnt8aA74.js.map