@helixui/library 0.3.3 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (441) hide show
  1. package/LICENSE +21 -0
  2. package/custom-elements.json +13178 -12195
  3. package/dist/components/hx-accordion/hx-accordion-item.d.ts +3 -1
  4. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  5. package/dist/components/hx-accordion/hx-accordion.d.ts +9 -1
  6. package/dist/components/hx-accordion/hx-accordion.d.ts.map +1 -1
  7. package/dist/components/hx-accordion/index.js +1 -1
  8. package/dist/components/hx-action-bar/hx-action-bar.d.ts +1 -1
  9. package/dist/components/hx-action-bar/hx-action-bar.d.ts.map +1 -1
  10. package/dist/components/hx-action-bar/index.js +1 -1
  11. package/dist/components/hx-alert/hx-alert.d.ts +3 -6
  12. package/dist/components/hx-alert/hx-alert.d.ts.map +1 -1
  13. package/dist/components/hx-alert/index.js +1 -1
  14. package/dist/components/hx-avatar/hx-avatar.d.ts +1 -1
  15. package/dist/components/hx-avatar/hx-avatar.d.ts.map +1 -1
  16. package/dist/components/hx-avatar/index.js +1 -1
  17. package/dist/components/hx-badge/hx-badge.d.ts +1 -1
  18. package/dist/components/hx-banner/hx-banner.d.ts +99 -0
  19. package/dist/components/hx-banner/hx-banner.d.ts.map +1 -0
  20. package/dist/components/hx-banner/hx-banner.styles.d.ts +2 -0
  21. package/dist/components/hx-banner/hx-banner.styles.d.ts.map +1 -0
  22. package/dist/components/hx-banner/index.d.ts +3 -0
  23. package/dist/components/hx-banner/index.d.ts.map +1 -0
  24. package/dist/components/hx-banner/index.js +5 -0
  25. package/dist/components/hx-banner/index.js.map +1 -0
  26. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts +1 -1
  27. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +6 -1
  28. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  29. package/dist/components/hx-breadcrumb/index.js +1 -1
  30. package/dist/components/hx-button/hx-button.d.ts +17 -0
  31. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  32. package/dist/components/hx-button/hx-button.styles.d.ts.map +1 -1
  33. package/dist/components/hx-button/index.js +1 -1
  34. package/dist/components/hx-button-group/hx-button-group.d.ts +9 -1
  35. package/dist/components/hx-button-group/hx-button-group.d.ts.map +1 -1
  36. package/dist/components/hx-button-group/index.js +1 -1
  37. package/dist/components/hx-card/hx-card.d.ts +17 -1
  38. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  39. package/dist/components/hx-card/hx-card.styles.d.ts.map +1 -1
  40. package/dist/components/hx-card/index.js +1 -1
  41. package/dist/components/hx-carousel/hx-carousel-item.d.ts +1 -1
  42. package/dist/components/hx-carousel/hx-carousel.d.ts +123 -1
  43. package/dist/components/hx-carousel/hx-carousel.d.ts.map +1 -1
  44. package/dist/components/hx-carousel/index.js +1 -1
  45. package/dist/components/hx-checkbox/hx-checkbox.d.ts +4 -2
  46. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  47. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +6 -2
  48. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  49. package/dist/components/hx-checkbox-group/index.js +1 -1
  50. package/dist/components/hx-code-snippet/hx-code-snippet.d.ts +21 -6
  51. package/dist/components/hx-code-snippet/hx-code-snippet.d.ts.map +1 -1
  52. package/dist/components/hx-code-snippet/index.js +1 -1
  53. package/dist/components/hx-color-picker/hx-color-picker.d.ts +14 -1
  54. package/dist/components/hx-color-picker/hx-color-picker.d.ts.map +1 -1
  55. package/dist/components/hx-color-picker/hx-color-picker.styles.d.ts.map +1 -1
  56. package/dist/components/hx-color-picker/index.js +1 -1
  57. package/dist/components/hx-combobox/hx-combobox.d.ts +25 -1
  58. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  59. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  60. package/dist/components/hx-combobox/index.js +1 -1
  61. package/dist/components/hx-container/hx-container.d.ts +4 -2
  62. package/dist/components/hx-container/hx-container.d.ts.map +1 -1
  63. package/dist/components/hx-copy-button/hx-copy-button.d.ts +7 -1
  64. package/dist/components/hx-copy-button/hx-copy-button.d.ts.map +1 -1
  65. package/dist/components/hx-copy-button/index.js +1 -1
  66. package/dist/components/hx-counter/hx-counter.d.ts +79 -0
  67. package/dist/components/hx-counter/hx-counter.d.ts.map +1 -0
  68. package/dist/components/hx-counter/hx-counter.styles.d.ts +2 -0
  69. package/dist/components/hx-counter/hx-counter.styles.d.ts.map +1 -0
  70. package/dist/components/hx-counter/index.d.ts +3 -0
  71. package/dist/components/hx-counter/index.d.ts.map +1 -0
  72. package/dist/components/hx-counter/index.js +5 -0
  73. package/dist/components/hx-counter/index.js.map +1 -0
  74. package/dist/components/hx-data-table/hx-data-table.d.ts +7 -1
  75. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  76. package/dist/components/hx-data-table/hx-data-table.styles.d.ts.map +1 -1
  77. package/dist/components/hx-data-table/index.js +1 -1
  78. package/dist/components/hx-date-picker/hx-date-picker.d.ts +125 -1
  79. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  80. package/dist/components/hx-date-picker/index.js +1 -1
  81. package/dist/components/hx-dialog/hx-dialog.d.ts +1 -1
  82. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  83. package/dist/components/hx-dialog/index.js +1 -1
  84. package/dist/components/hx-divider/hx-divider.d.ts +4 -1
  85. package/dist/components/hx-divider/hx-divider.d.ts.map +1 -1
  86. package/dist/components/hx-drawer/hx-drawer.d.ts +55 -2
  87. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  88. package/dist/components/hx-drawer/index.js +1 -1
  89. package/dist/components/hx-dropdown/hx-dropdown.d.ts +6 -1
  90. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  91. package/dist/components/hx-field/hx-field.d.ts +32 -2
  92. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  93. package/dist/components/hx-field/index.js +1 -1
  94. package/dist/components/hx-field-label/hx-field-label.d.ts +1 -1
  95. package/dist/components/hx-file-upload/hx-file-upload.d.ts +13 -1
  96. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  97. package/dist/components/hx-file-upload/index.js +1 -1
  98. package/dist/components/hx-form/hx-form.d.ts +25 -1
  99. package/dist/components/hx-form/hx-form.d.ts.map +1 -1
  100. package/dist/components/hx-form/index.js +1 -1
  101. package/dist/components/hx-format-date/hx-format-date.d.ts +1 -1
  102. package/dist/components/hx-grid/hx-grid.d.ts +2 -2
  103. package/dist/components/hx-help-text/hx-help-text.d.ts +4 -1
  104. package/dist/components/hx-help-text/hx-help-text.d.ts.map +1 -1
  105. package/dist/components/hx-icon/hx-icon.d.ts +1 -1
  106. package/dist/components/hx-icon-button/hx-icon-button.d.ts +1 -1
  107. package/dist/components/hx-icon-button/hx-icon-button.d.ts.map +1 -1
  108. package/dist/components/hx-icon-button/index.js +1 -1
  109. package/dist/components/hx-image/hx-image.d.ts +1 -1
  110. package/dist/components/hx-link/hx-link.d.ts +1 -1
  111. package/dist/components/hx-list/hx-list-item.d.ts +1 -1
  112. package/dist/components/hx-list/hx-list.d.ts +1 -1
  113. package/dist/components/hx-list/hx-list.d.ts.map +1 -1
  114. package/dist/components/hx-list/index.js +1 -1
  115. package/dist/components/hx-menu/hx-menu-divider.d.ts +1 -1
  116. package/dist/components/hx-menu/hx-menu-item.d.ts +1 -1
  117. package/dist/components/hx-menu/hx-menu.d.ts +13 -1
  118. package/dist/components/hx-menu/hx-menu.d.ts.map +1 -1
  119. package/dist/components/hx-menu/index.js +1 -1
  120. package/dist/components/hx-meter/hx-meter.d.ts +3 -1
  121. package/dist/components/hx-meter/hx-meter.d.ts.map +1 -1
  122. package/dist/components/hx-meter/index.js +1 -1
  123. package/dist/components/hx-nav/hx-nav.d.ts +16 -2
  124. package/dist/components/hx-nav/hx-nav.d.ts.map +1 -1
  125. package/dist/components/hx-nav/index.js +1 -1
  126. package/dist/components/hx-number-input/hx-number-input.d.ts +3 -1
  127. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  128. package/dist/components/hx-number-input/index.js +1 -1
  129. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts +15 -1
  130. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts.map +1 -1
  131. package/dist/components/hx-overflow-menu/index.js +1 -1
  132. package/dist/components/hx-pagination/hx-pagination.d.ts +6 -1
  133. package/dist/components/hx-pagination/hx-pagination.d.ts.map +1 -1
  134. package/dist/components/hx-pagination/index.js +1 -1
  135. package/dist/components/hx-popover/hx-popover.d.ts +11 -39
  136. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  137. package/dist/components/hx-popover/index.js +1 -1
  138. package/dist/components/hx-popup/hx-popup.d.ts +1 -1
  139. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +11 -1
  140. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  141. package/dist/components/hx-progress-bar/index.js +1 -1
  142. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts.map +1 -1
  143. package/dist/components/hx-progress-ring/index.js +1 -1
  144. package/dist/components/hx-prose/hx-prose.d.ts +1 -1
  145. package/dist/components/hx-radio-group/hx-radio-group.d.ts +76 -4
  146. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  147. package/dist/components/hx-radio-group/hx-radio.d.ts +4 -2
  148. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  149. package/dist/components/hx-radio-group/index.js +1 -1
  150. package/dist/components/hx-rating/hx-rating.d.ts +19 -4
  151. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  152. package/dist/components/hx-rating/index.js +1 -1
  153. package/dist/components/hx-select/hx-select.d.ts +10 -1
  154. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  155. package/dist/components/hx-select/index.js +1 -1
  156. package/dist/components/hx-side-nav/hx-nav-item.d.ts +1 -1
  157. package/dist/components/hx-side-nav/hx-side-nav.d.ts +1 -1
  158. package/dist/components/hx-side-nav/hx-side-nav.d.ts.map +1 -1
  159. package/dist/components/hx-side-nav/index.js +1 -1
  160. package/dist/components/hx-skeleton/hx-skeleton.d.ts +1 -1
  161. package/dist/components/hx-slider/hx-slider.d.ts +2 -0
  162. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  163. package/dist/components/hx-slider/index.js +1 -1
  164. package/dist/components/hx-spinner/hx-spinner.d.ts +1 -1
  165. package/dist/components/hx-split-button/hx-split-button.d.ts +17 -1
  166. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  167. package/dist/components/hx-split-button/index.js +1 -1
  168. package/dist/components/hx-split-panel/hx-split-panel.d.ts +12 -1
  169. package/dist/components/hx-split-panel/hx-split-panel.d.ts.map +1 -1
  170. package/dist/components/hx-stack/hx-stack.d.ts +1 -1
  171. package/dist/components/hx-stat/hx-stat.d.ts +71 -0
  172. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -0
  173. package/dist/components/hx-stat/hx-stat.styles.d.ts +2 -0
  174. package/dist/components/hx-stat/hx-stat.styles.d.ts.map +1 -0
  175. package/dist/components/hx-stat/index.d.ts +3 -0
  176. package/dist/components/hx-stat/index.d.ts.map +1 -0
  177. package/dist/components/hx-stat/index.js +5 -0
  178. package/dist/components/hx-stat/index.js.map +1 -0
  179. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts +1 -1
  180. package/dist/components/hx-steps/hx-step.d.ts +1 -1
  181. package/dist/components/hx-steps/hx-steps.d.ts +6 -1
  182. package/dist/components/hx-steps/hx-steps.d.ts.map +1 -1
  183. package/dist/components/hx-steps/index.js +1 -1
  184. package/dist/components/hx-structured-list/hx-structured-list.d.ts +4 -2
  185. package/dist/components/hx-structured-list/hx-structured-list.d.ts.map +1 -1
  186. package/dist/components/hx-structured-list/index.js +1 -1
  187. package/dist/components/hx-switch/hx-switch.d.ts +3 -1
  188. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  189. package/dist/components/hx-switch/index.js +1 -1
  190. package/dist/components/hx-table/hx-table.d.ts +60 -0
  191. package/dist/components/hx-table/hx-table.d.ts.map +1 -0
  192. package/dist/components/hx-table/hx-table.styles.d.ts +9 -0
  193. package/dist/components/hx-table/hx-table.styles.d.ts.map +1 -0
  194. package/dist/components/hx-table/hx-tbody.d.ts +23 -0
  195. package/dist/components/hx-table/hx-tbody.d.ts.map +1 -0
  196. package/dist/components/hx-table/hx-td.d.ts +46 -0
  197. package/dist/components/hx-table/hx-td.d.ts.map +1 -0
  198. package/dist/components/hx-table/hx-tfoot.d.ts +23 -0
  199. package/dist/components/hx-table/hx-tfoot.d.ts.map +1 -0
  200. package/dist/components/hx-table/hx-th.d.ts +61 -0
  201. package/dist/components/hx-table/hx-th.d.ts.map +1 -0
  202. package/dist/components/hx-table/hx-thead.d.ts +23 -0
  203. package/dist/components/hx-table/hx-thead.d.ts.map +1 -0
  204. package/dist/components/hx-table/hx-tr.d.ts +33 -0
  205. package/dist/components/hx-table/hx-tr.d.ts.map +1 -0
  206. package/dist/components/hx-table/index.d.ts +9 -0
  207. package/dist/components/hx-table/index.d.ts.map +1 -0
  208. package/dist/components/hx-table/index.js +11 -0
  209. package/dist/components/hx-table/index.js.map +1 -0
  210. package/dist/components/hx-tabs/hx-tab-panel.d.ts +1 -1
  211. package/dist/components/hx-tabs/hx-tab.d.ts +1 -1
  212. package/dist/components/hx-tabs/hx-tabs.d.ts +1 -1
  213. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  214. package/dist/components/hx-tabs/index.js +1 -1
  215. package/dist/components/hx-tag/hx-tag.d.ts +1 -1
  216. package/dist/components/hx-text/hx-text.d.ts +1 -1
  217. package/dist/components/hx-text-input/hx-text-input.d.ts +2 -1
  218. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  219. package/dist/components/hx-text-input/index.js +1 -1
  220. package/dist/components/hx-textarea/hx-textarea.d.ts +15 -1
  221. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  222. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  223. package/dist/components/hx-textarea/index.js +1 -1
  224. package/dist/components/hx-theme/hx-theme.d.ts +1 -1
  225. package/dist/components/hx-time-picker/hx-time-picker.d.ts +23 -2
  226. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  227. package/dist/components/hx-time-picker/index.js +1 -1
  228. package/dist/components/hx-toast/hx-toast-stack.d.ts +36 -0
  229. package/dist/components/hx-toast/hx-toast-stack.d.ts.map +1 -0
  230. package/dist/components/hx-toast/hx-toast.d.ts +1 -53
  231. package/dist/components/hx-toast/hx-toast.d.ts.map +1 -1
  232. package/dist/components/hx-toast/index.d.ts +6 -2
  233. package/dist/components/hx-toast/index.d.ts.map +1 -1
  234. package/dist/components/hx-toast/index.js +1 -1
  235. package/dist/components/hx-toast/toast-factory.d.ts +25 -0
  236. package/dist/components/hx-toast/toast-factory.d.ts.map +1 -0
  237. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +2 -1
  238. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  239. package/dist/components/hx-toggle-button/index.js +1 -1
  240. package/dist/components/hx-tooltip/hx-tooltip.d.ts +2 -46
  241. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  242. package/dist/components/hx-tooltip/index.js +1 -1
  243. package/dist/components/hx-top-nav/hx-top-nav.d.ts +1 -1
  244. package/dist/components/hx-top-nav/hx-top-nav.d.ts.map +1 -1
  245. package/dist/components/hx-top-nav/index.js +1 -1
  246. package/dist/components/hx-tree-view/hx-tree-item.d.ts +51 -1
  247. package/dist/components/hx-tree-view/hx-tree-item.d.ts.map +1 -1
  248. package/dist/components/hx-tree-view/hx-tree-view.d.ts +16 -1
  249. package/dist/components/hx-tree-view/hx-tree-view.d.ts.map +1 -1
  250. package/dist/components/hx-tree-view/index.js +1 -1
  251. package/dist/components/hx-visually-hidden/hx-visually-hidden.d.ts +1 -1
  252. package/dist/index.d.ts +20 -2
  253. package/dist/index.d.ts.map +1 -1
  254. package/dist/index.js +168 -154
  255. package/dist/index.js.map +1 -1
  256. package/dist/shared/body-scroll-lock-VBa5TFP-.js +12 -0
  257. package/dist/shared/body-scroll-lock-VBa5TFP-.js.map +1 -0
  258. package/dist/shared/dev-warn-YlwPHjtX.js +6 -0
  259. package/dist/shared/dev-warn-YlwPHjtX.js.map +1 -0
  260. package/dist/shared/{hx-accordion-D95XSAft.js → hx-accordion-Cyswa6J3.js} +46 -43
  261. package/dist/shared/hx-accordion-Cyswa6J3.js.map +1 -0
  262. package/dist/shared/{hx-action-bar-B4i9tBCP.js → hx-action-bar-we_WJety.js} +41 -40
  263. package/dist/shared/hx-action-bar-we_WJety.js.map +1 -0
  264. package/dist/shared/{hx-alert-BQpT4gL3.js → hx-alert-Cg-zxRiU.js} +2 -2
  265. package/dist/shared/hx-alert-Cg-zxRiU.js.map +1 -0
  266. package/dist/shared/{hx-avatar-yHjmNdtf.js → hx-avatar-Cep6Urm3.js} +62 -65
  267. package/dist/shared/hx-avatar-Cep6Urm3.js.map +1 -0
  268. package/dist/shared/hx-banner-lxAIJ2kR.js +349 -0
  269. package/dist/shared/hx-banner-lxAIJ2kR.js.map +1 -0
  270. package/dist/shared/{hx-breadcrumb-item-DtSxRZ_W.js → hx-breadcrumb-item-C0rz0fzV.js} +46 -44
  271. package/dist/shared/hx-breadcrumb-item-C0rz0fzV.js.map +1 -0
  272. package/dist/shared/{hx-button-CtiJsmOg.js → hx-button-Cbhqpm5i.js} +111 -28
  273. package/dist/shared/hx-button-Cbhqpm5i.js.map +1 -0
  274. package/dist/shared/{hx-button-group-BMV5qFs4.js → hx-button-group-CWjWv-wS.js} +10 -10
  275. package/dist/shared/hx-button-group-CWjWv-wS.js.map +1 -0
  276. package/dist/shared/{hx-card-DAkEfpJd.js → hx-card-Bg4W4uXC.js} +16 -16
  277. package/dist/shared/hx-card-Bg4W4uXC.js.map +1 -0
  278. package/dist/shared/{hx-carousel-item-C2yBnM0r.js → hx-carousel-item-BKpmFbUT.js} +101 -63
  279. package/dist/shared/hx-carousel-item-BKpmFbUT.js.map +1 -0
  280. package/dist/shared/hx-checkbox-BMayOpAM.js.map +1 -1
  281. package/dist/shared/{hx-checkbox-group-DTS9iT4b.js → hx-checkbox-group-ydUdV9Sx.js} +7 -7
  282. package/dist/shared/hx-checkbox-group-ydUdV9Sx.js.map +1 -0
  283. package/dist/shared/{hx-code-snippet-DdEqy-1B.js → hx-code-snippet-B4hV7rWG.js} +65 -53
  284. package/dist/shared/hx-code-snippet-B4hV7rWG.js.map +1 -0
  285. package/dist/shared/{hx-color-picker-K2x_dyeG.js → hx-color-picker-BvfJ_h16.js} +100 -90
  286. package/dist/shared/hx-color-picker-BvfJ_h16.js.map +1 -0
  287. package/dist/shared/{hx-combobox-DjMigccw.js → hx-combobox-BBi3izKJ.js} +80 -44
  288. package/dist/shared/hx-combobox-BBi3izKJ.js.map +1 -0
  289. package/dist/shared/hx-container-DLUKnTi9.js.map +1 -1
  290. package/dist/shared/{hx-copy-button-BXL1xkxb.js → hx-copy-button-CLBA31to.js} +45 -50
  291. package/dist/shared/hx-copy-button-CLBA31to.js.map +1 -0
  292. package/dist/shared/hx-counter-D-1NXzGs.js +138 -0
  293. package/dist/shared/hx-counter-D-1NXzGs.js.map +1 -0
  294. package/dist/shared/{hx-data-table-D3NZvc3P.js → hx-data-table-DNiDVWR2.js} +100 -95
  295. package/dist/shared/hx-data-table-DNiDVWR2.js.map +1 -0
  296. package/dist/shared/{hx-date-picker-CIHwx9b3.js → hx-date-picker-D7yCK0nk.js} +17 -12
  297. package/dist/shared/hx-date-picker-D7yCK0nk.js.map +1 -0
  298. package/dist/shared/{hx-dialog-e4CSD8xX.js → hx-dialog-Z7Ou_AZ9.js} +37 -36
  299. package/dist/shared/hx-dialog-Z7Ou_AZ9.js.map +1 -0
  300. package/dist/shared/hx-divider-XgWIz4Mr.js.map +1 -1
  301. package/dist/shared/{hx-drawer-bTF0nbrg.js → hx-drawer-Dk-_xzy0.js} +59 -58
  302. package/dist/shared/hx-drawer-Dk-_xzy0.js.map +1 -0
  303. package/dist/shared/hx-dropdown-DnjLnkTj.js.map +1 -1
  304. package/dist/shared/{hx-field-Dz-7M_SC.js → hx-field-CDP8EXuj.js} +22 -19
  305. package/dist/shared/hx-field-CDP8EXuj.js.map +1 -0
  306. package/dist/shared/{hx-file-upload-DnYiIhyN.js → hx-file-upload-CUORgnKc.js} +17 -14
  307. package/dist/shared/hx-file-upload-CUORgnKc.js.map +1 -0
  308. package/dist/shared/{hx-form-BJeLK34m.js → hx-form-BFv_N1dm.js} +9 -1
  309. package/dist/shared/{hx-form-BJeLK34m.js.map → hx-form-BFv_N1dm.js.map} +1 -1
  310. package/dist/shared/hx-help-text-DaOPN1iB.js.map +1 -1
  311. package/dist/shared/{hx-icon-button-C_fsUJW4.js → hx-icon-button-C83bCR0K.js} +2 -4
  312. package/dist/shared/hx-icon-button-C83bCR0K.js.map +1 -0
  313. package/dist/shared/{hx-list-CF-AAnp-.js → hx-list-CdRNgeoP.js} +7 -9
  314. package/dist/shared/{hx-list-CF-AAnp-.js.map → hx-list-CdRNgeoP.js.map} +1 -1
  315. package/dist/shared/{hx-menu-divider-Buc5XA9E.js → hx-menu-divider-11Dp2VfM.js} +50 -48
  316. package/dist/shared/hx-menu-divider-11Dp2VfM.js.map +1 -0
  317. package/dist/shared/{hx-meter-qcXl0zCL.js → hx-meter-UinDQjl6.js} +43 -37
  318. package/dist/shared/hx-meter-UinDQjl6.js.map +1 -0
  319. package/dist/shared/{hx-nav-CWwByFdq.js → hx-nav-DSpwWYUX.js} +81 -81
  320. package/dist/shared/hx-nav-DSpwWYUX.js.map +1 -0
  321. package/dist/shared/{hx-nav-item-DItaMWl0.js → hx-nav-item-D54-5eUM.js} +12 -12
  322. package/dist/shared/hx-nav-item-D54-5eUM.js.map +1 -0
  323. package/dist/shared/{hx-number-input-CS6_w1lT.js → hx-number-input-BP6TIA92.js} +5 -1
  324. package/dist/shared/hx-number-input-BP6TIA92.js.map +1 -0
  325. package/dist/shared/{hx-overflow-menu-CAS1Mlus.js → hx-overflow-menu-C7k5wlZy.js} +39 -34
  326. package/dist/shared/hx-overflow-menu-C7k5wlZy.js.map +1 -0
  327. package/dist/shared/{hx-pagination-DNFgXQm3.js → hx-pagination-BQ0cLTuB.js} +65 -62
  328. package/dist/shared/hx-pagination-BQ0cLTuB.js.map +1 -0
  329. package/dist/shared/{hx-popover-BjAyLbzp.js → hx-popover-BQsgrJCW.js} +7 -7
  330. package/dist/shared/hx-popover-BQsgrJCW.js.map +1 -0
  331. package/dist/shared/{hx-progress-bar-b3_m1hna.js → hx-progress-bar-C_mdPVF-.js} +61 -52
  332. package/dist/shared/hx-progress-bar-C_mdPVF-.js.map +1 -0
  333. package/dist/shared/{hx-progress-ring-wOSv2y_I.js → hx-progress-ring-BHJBaXNk.js} +2 -4
  334. package/dist/shared/hx-progress-ring-BHJBaXNk.js.map +1 -0
  335. package/dist/shared/{hx-radio-CGtFKls2.js → hx-radio-Bqyi8re3.js} +44 -12
  336. package/dist/shared/hx-radio-Bqyi8re3.js.map +1 -0
  337. package/dist/shared/{hx-rating-C4kTOyHF.js → hx-rating-Y_t7Z4qb.js} +104 -67
  338. package/dist/shared/hx-rating-Y_t7Z4qb.js.map +1 -0
  339. package/dist/shared/{hx-select-D9bYJcDv.js → hx-select-BBae2LqN.js} +16 -10
  340. package/dist/shared/hx-select-BBae2LqN.js.map +1 -0
  341. package/dist/shared/{hx-slider-Duzmuid9.js → hx-slider-CpnxH2UP.js} +9 -5
  342. package/dist/shared/{hx-slider-Duzmuid9.js.map → hx-slider-CpnxH2UP.js.map} +1 -1
  343. package/dist/shared/{hx-split-button-DhncgAtZ.js → hx-split-button-BvwoG8h2.js} +14 -13
  344. package/dist/shared/hx-split-button-BvwoG8h2.js.map +1 -0
  345. package/dist/shared/hx-split-panel-Cxkeauwe.js.map +1 -1
  346. package/dist/shared/hx-stat-C2wfph8W.js +212 -0
  347. package/dist/shared/hx-stat-C2wfph8W.js.map +1 -0
  348. package/dist/shared/{hx-step-nMT0fHEn.js → hx-step-DYoIumpR.js} +29 -29
  349. package/dist/shared/hx-step-DYoIumpR.js.map +1 -0
  350. package/dist/shared/{hx-structured-list-CMja1VXz.js → hx-structured-list-CMWllxGg.js} +23 -17
  351. package/dist/shared/{hx-structured-list-CMja1VXz.js.map → hx-structured-list-CMWllxGg.js.map} +1 -1
  352. package/dist/shared/{hx-switch-BPvIcDpM.js → hx-switch-DkKchcuP.js} +8 -3
  353. package/dist/shared/{hx-switch-BPvIcDpM.js.map → hx-switch-DkKchcuP.js.map} +1 -1
  354. package/dist/shared/{hx-tab-panel-C7h5lRpw.js → hx-tab-panel-CHB0u1zF.js} +91 -85
  355. package/dist/shared/hx-tab-panel-CHB0u1zF.js.map +1 -0
  356. package/dist/shared/hx-td-CVwCGBYf.js +604 -0
  357. package/dist/shared/hx-td-CVwCGBYf.js.map +1 -0
  358. package/dist/shared/{hx-text-input-BUMgOQHX.js → hx-text-input-BrCjo4fJ.js} +5 -1
  359. package/dist/shared/hx-text-input-BrCjo4fJ.js.map +1 -0
  360. package/dist/shared/{hx-textarea-B_nmxzhC.js → hx-textarea-BsQdB1Rk.js} +51 -18
  361. package/dist/shared/hx-textarea-BsQdB1Rk.js.map +1 -0
  362. package/dist/shared/{hx-time-picker-a-BCkecJ.js → hx-time-picker-DRRAFuVd.js} +62 -54
  363. package/dist/shared/hx-time-picker-DRRAFuVd.js.map +1 -0
  364. package/dist/shared/{hx-toggle-button--xCXWRJW.js → hx-toggle-button-D4F1soEM.js} +34 -22
  365. package/dist/shared/{hx-toggle-button--xCXWRJW.js.map → hx-toggle-button-D4F1soEM.js.map} +1 -1
  366. package/dist/shared/{hx-tooltip-DN6lMlP5.js → hx-tooltip-Bk1iQRHs.js} +23 -23
  367. package/dist/shared/hx-tooltip-Bk1iQRHs.js.map +1 -0
  368. package/dist/shared/{hx-top-nav-8lDKNZUj.js → hx-top-nav-DzW7XLv-.js} +42 -29
  369. package/dist/shared/{hx-top-nav-8lDKNZUj.js.map → hx-top-nav-DzW7XLv-.js.map} +1 -1
  370. package/dist/shared/{hx-tree-item-Cesh_du5.js → hx-tree-item-DdH6RbMs.js} +170 -111
  371. package/dist/shared/hx-tree-item-DdH6RbMs.js.map +1 -0
  372. package/dist/shared/{hx-toast-ikwh9Y03.js → toast-factory-B8jicczW.js} +69 -66
  373. package/dist/shared/toast-factory-B8jicczW.js.map +1 -0
  374. package/dist/tools/cem-a11y-analyzer/analyzers/aria-analyzer.d.ts +12 -0
  375. package/dist/tools/cem-a11y-analyzer/analyzers/aria-analyzer.d.ts.map +1 -0
  376. package/dist/tools/cem-a11y-analyzer/analyzers/focus-analyzer.d.ts +13 -0
  377. package/dist/tools/cem-a11y-analyzer/analyzers/focus-analyzer.d.ts.map +1 -0
  378. package/dist/tools/cem-a11y-analyzer/analyzers/form-analyzer.d.ts +13 -0
  379. package/dist/tools/cem-a11y-analyzer/analyzers/form-analyzer.d.ts.map +1 -0
  380. package/dist/tools/cem-a11y-analyzer/analyzers/keyboard-analyzer.d.ts +12 -0
  381. package/dist/tools/cem-a11y-analyzer/analyzers/keyboard-analyzer.d.ts.map +1 -0
  382. package/dist/tools/cem-a11y-analyzer/analyzers/label-analyzer.d.ts +13 -0
  383. package/dist/tools/cem-a11y-analyzer/analyzers/label-analyzer.d.ts.map +1 -0
  384. package/dist/tools/cem-a11y-analyzer/analyzers/motion-analyzer.d.ts +12 -0
  385. package/dist/tools/cem-a11y-analyzer/analyzers/motion-analyzer.d.ts.map +1 -0
  386. package/dist/tools/cem-a11y-analyzer/index.d.ts +14 -0
  387. package/dist/tools/cem-a11y-analyzer/index.d.ts.map +1 -0
  388. package/dist/tools/cem-a11y-analyzer/reporter.d.ts +6 -0
  389. package/dist/tools/cem-a11y-analyzer/reporter.d.ts.map +1 -0
  390. package/dist/tools/cem-a11y-analyzer/scorer.d.ts +22 -0
  391. package/dist/tools/cem-a11y-analyzer/scorer.d.ts.map +1 -0
  392. package/dist/tools/cem-a11y-analyzer/types.d.ts +171 -0
  393. package/dist/tools/cem-a11y-analyzer/types.d.ts.map +1 -0
  394. package/dist/utils/body-scroll-lock.d.ts +34 -0
  395. package/dist/utils/body-scroll-lock.d.ts.map +1 -0
  396. package/dist/utils/dev-warn.d.ts +19 -0
  397. package/dist/utils/dev-warn.d.ts.map +1 -0
  398. package/package.json +33 -27
  399. package/dist/shared/hx-accordion-D95XSAft.js.map +0 -1
  400. package/dist/shared/hx-action-bar-B4i9tBCP.js.map +0 -1
  401. package/dist/shared/hx-alert-BQpT4gL3.js.map +0 -1
  402. package/dist/shared/hx-avatar-yHjmNdtf.js.map +0 -1
  403. package/dist/shared/hx-breadcrumb-item-DtSxRZ_W.js.map +0 -1
  404. package/dist/shared/hx-button-CtiJsmOg.js.map +0 -1
  405. package/dist/shared/hx-button-group-BMV5qFs4.js.map +0 -1
  406. package/dist/shared/hx-card-DAkEfpJd.js.map +0 -1
  407. package/dist/shared/hx-carousel-item-C2yBnM0r.js.map +0 -1
  408. package/dist/shared/hx-checkbox-group-DTS9iT4b.js.map +0 -1
  409. package/dist/shared/hx-code-snippet-DdEqy-1B.js.map +0 -1
  410. package/dist/shared/hx-color-picker-K2x_dyeG.js.map +0 -1
  411. package/dist/shared/hx-combobox-DjMigccw.js.map +0 -1
  412. package/dist/shared/hx-copy-button-BXL1xkxb.js.map +0 -1
  413. package/dist/shared/hx-data-table-D3NZvc3P.js.map +0 -1
  414. package/dist/shared/hx-date-picker-CIHwx9b3.js.map +0 -1
  415. package/dist/shared/hx-dialog-e4CSD8xX.js.map +0 -1
  416. package/dist/shared/hx-drawer-bTF0nbrg.js.map +0 -1
  417. package/dist/shared/hx-field-Dz-7M_SC.js.map +0 -1
  418. package/dist/shared/hx-file-upload-DnYiIhyN.js.map +0 -1
  419. package/dist/shared/hx-icon-button-C_fsUJW4.js.map +0 -1
  420. package/dist/shared/hx-menu-divider-Buc5XA9E.js.map +0 -1
  421. package/dist/shared/hx-meter-qcXl0zCL.js.map +0 -1
  422. package/dist/shared/hx-nav-CWwByFdq.js.map +0 -1
  423. package/dist/shared/hx-nav-item-DItaMWl0.js.map +0 -1
  424. package/dist/shared/hx-number-input-CS6_w1lT.js.map +0 -1
  425. package/dist/shared/hx-overflow-menu-CAS1Mlus.js.map +0 -1
  426. package/dist/shared/hx-pagination-DNFgXQm3.js.map +0 -1
  427. package/dist/shared/hx-popover-BjAyLbzp.js.map +0 -1
  428. package/dist/shared/hx-progress-bar-b3_m1hna.js.map +0 -1
  429. package/dist/shared/hx-progress-ring-wOSv2y_I.js.map +0 -1
  430. package/dist/shared/hx-radio-CGtFKls2.js.map +0 -1
  431. package/dist/shared/hx-rating-C4kTOyHF.js.map +0 -1
  432. package/dist/shared/hx-select-D9bYJcDv.js.map +0 -1
  433. package/dist/shared/hx-split-button-DhncgAtZ.js.map +0 -1
  434. package/dist/shared/hx-step-nMT0fHEn.js.map +0 -1
  435. package/dist/shared/hx-tab-panel-C7h5lRpw.js.map +0 -1
  436. package/dist/shared/hx-text-input-BUMgOQHX.js.map +0 -1
  437. package/dist/shared/hx-textarea-B_nmxzhC.js.map +0 -1
  438. package/dist/shared/hx-time-picker-a-BCkecJ.js.map +0 -1
  439. package/dist/shared/hx-toast-ikwh9Y03.js.map +0 -1
  440. package/dist/shared/hx-tooltip-DN6lMlP5.js.map +0 -1
  441. package/dist/shared/hx-tree-item-Cesh_du5.js.map +0 -1
@@ -1,8 +1,9 @@
1
- import { css as b, svg as S, LitElement as w, nothing as D, html as _ } from "lit";
1
+ import { css as b, svg as C, LitElement as w, nothing as S, html as _ } from "lit";
2
2
  import { property as m, customElement as E } from "lit/decorators.js";
3
3
  import { tokenStyles as k } from "@helixui/tokens/lit";
4
- import { classMap as $ } from "lit/directives/class-map.js";
5
- const A = b`
4
+ import { classMap as D } from "lit/directives/class-map.js";
5
+ import { d as A } from "./dev-warn-YlwPHjtX.js";
6
+ const I = b`
6
7
  :host {
7
8
  display: block;
8
9
  font-family: var(--hx-font-family-sans, sans-serif);
@@ -12,7 +13,7 @@ const A = b`
12
13
  border-radius: var(--hx-accordion-border-radius, var(--hx-border-radius-md, 0.375rem));
13
14
  overflow: hidden;
14
15
  }
15
- `, I = b`
16
+ `, O = b`
16
17
  :host {
17
18
  display: block;
18
19
  }
@@ -133,12 +134,12 @@ const A = b`
133
134
  }
134
135
  }
135
136
  `;
136
- var O = Object.defineProperty, P = Object.getOwnPropertyDescriptor, g = (e, r, o, t) => {
137
- for (var n = t > 1 ? void 0 : t ? P(r, o) : r, i = e.length - 1, a; i >= 0; i--)
137
+ var P = Object.defineProperty, j = Object.getOwnPropertyDescriptor, g = (e, r, o, t) => {
138
+ for (var n = t > 1 ? void 0 : t ? j(r, o) : r, i = e.length - 1, a; i >= 0; i--)
138
139
  (a = e[i]) && (n = (t ? a(r, o, n) : a(n)) || n);
139
- return t && n && O(r, o, n), n;
140
+ return t && n && P(r, o, n), n;
140
141
  };
141
- const j = S`
142
+ const L = C`
142
143
  <svg
143
144
  xmlns="http://www.w3.org/2000/svg"
144
145
  width="16"
@@ -154,9 +155,9 @@ const j = S`
154
155
  <polyline points="6 9 12 15 18 9"></polyline>
155
156
  </svg>
156
157
  `;
157
- let l = class extends w {
158
+ let s = class extends w {
158
159
  constructor() {
159
- super(...arguments), this.expanded = !1, this.disabled = !1;
160
+ super(...arguments), this._uid = `hx-accordion-item-${++s._counter}`, this.expanded = !1, this.disabled = !1;
160
161
  }
161
162
  // ─── Toggle Logic ───
162
163
  _toggle() {
@@ -183,30 +184,30 @@ let l = class extends w {
183
184
  "item--disabled": this.disabled
184
185
  };
185
186
  return _`
186
- <details part="item" class=${$(e)} ?open=${this.expanded}>
187
+ <details part="item" class=${D(e)} ?open=${this.expanded}>
187
188
  <summary
188
- id="trigger"
189
+ id=${`${this._uid}-trigger`}
189
190
  part="trigger"
190
191
  class="trigger"
191
192
  tabindex=${this.disabled ? "-1" : "0"}
192
193
  aria-expanded=${this.expanded ? "true" : "false"}
193
194
  aria-disabled=${this.disabled ? "true" : "false"}
194
- aria-controls="content"
195
+ aria-controls=${`${this._uid}-content`}
195
196
  @click=${this._handleSummaryClick}
196
197
  @keydown=${this._handleKeyDown}
197
198
  >
198
199
  <slot name="trigger"></slot>
199
- <span part="icon" class="icon">${j}</span>
200
+ <span part="icon" class="icon">${L}</span>
200
201
  </summary>
201
202
  <div class="content-wrapper">
202
203
  <div class="content-inner">
203
204
  <div
204
- id="content"
205
+ id=${`${this._uid}-content`}
205
206
  part="content"
206
207
  class="content"
207
208
  role="region"
208
- aria-labelledby="trigger"
209
- aria-hidden=${this.expanded ? D : "true"}
209
+ aria-labelledby=${`${this._uid}-trigger`}
210
+ aria-hidden=${this.expanded ? S : "true"}
210
211
  >
211
212
  <slot></slot>
212
213
  </div>
@@ -216,20 +217,21 @@ let l = class extends w {
216
217
  `;
217
218
  }
218
219
  };
219
- l.styles = [k, I];
220
+ s.styles = [k, O];
221
+ s._counter = 0;
220
222
  g([
221
223
  m({ type: Boolean, reflect: !0 })
222
- ], l.prototype, "expanded", 2);
224
+ ], s.prototype, "expanded", 2);
223
225
  g([
224
226
  m({ type: Boolean, reflect: !0 })
225
- ], l.prototype, "disabled", 2);
226
- l = g([
227
+ ], s.prototype, "disabled", 2);
228
+ s = g([
227
229
  E("hx-accordion-item")
228
- ], l);
229
- var L = Object.defineProperty, q = Object.getOwnPropertyDescriptor, C = (e, r, o, t) => {
230
- for (var n = t > 1 ? void 0 : t ? q(r, o) : r, i = e.length - 1, a; i >= 0; i--)
230
+ ], s);
231
+ var q = Object.defineProperty, R = Object.getOwnPropertyDescriptor, $ = (e, r, o, t) => {
232
+ for (var n = t > 1 ? void 0 : t ? R(r, o) : r, i = e.length - 1, a; i >= 0; i--)
231
233
  (a = e[i]) && (n = (t ? a(r, o, n) : a(n)) || n);
232
- return t && n && L(r, o, n), n;
234
+ return t && n && q(r, o, n), n;
233
235
  };
234
236
  let c = class extends w {
235
237
  constructor() {
@@ -245,35 +247,35 @@ let c = class extends w {
245
247
  const o = ((f = this.shadowRoot) == null ? void 0 : f.activeElement) ?? document.activeElement;
246
248
  let t = null;
247
249
  const n = Array.from(this.querySelectorAll("hx-accordion-item"));
248
- for (const d of n) {
249
- const y = (u = d.shadowRoot) == null ? void 0 : u.querySelector("summary");
250
- if (y === o || ((x = d.shadowRoot) == null ? void 0 : x.activeElement) === y) {
251
- t = d;
250
+ for (const l of n) {
251
+ const y = (u = l.shadowRoot) == null ? void 0 : u.querySelector("summary");
252
+ if (y === o || ((x = l.shadowRoot) == null ? void 0 : x.activeElement) === y) {
253
+ t = l;
252
254
  break;
253
255
  }
254
256
  }
255
257
  if (!t) return;
256
- const i = n.filter((d) => !d.disabled), a = i.indexOf(t);
258
+ const i = n.filter((l) => !l.disabled), a = i.indexOf(t);
257
259
  if (a === -1) return;
258
- let s = -1;
260
+ let d = -1;
259
261
  switch (e.key) {
260
262
  case "ArrowDown":
261
- s = (a + 1) % i.length;
263
+ d = (a + 1) % i.length;
262
264
  break;
263
265
  case "ArrowUp":
264
- s = (a - 1 + i.length) % i.length;
266
+ d = (a - 1 + i.length) % i.length;
265
267
  break;
266
268
  case "Home":
267
- s = 0;
269
+ d = 0;
268
270
  break;
269
271
  case "End":
270
- s = i.length - 1;
272
+ d = i.length - 1;
271
273
  break;
272
274
  default:
273
275
  return;
274
276
  }
275
277
  e.preventDefault();
276
- const h = i[s], p = (v = h == null ? void 0 : h.shadowRoot) == null ? void 0 : v.querySelector("summary");
278
+ const h = i[d], p = (v = h == null ? void 0 : h.shadowRoot) == null ? void 0 : v.querySelector("summary");
277
279
  p == null || p.focus();
278
280
  };
279
281
  }
@@ -309,8 +311,9 @@ let c = class extends w {
309
311
  const r = e.target;
310
312
  if (!(r instanceof HTMLSlotElement)) return;
311
313
  const o = r.assignedElements().filter((t) => t.tagName.toLowerCase() !== "hx-accordion-item");
312
- o.length > 0 && console.warn(
313
- `[hx-accordion] Default slot expects <hx-accordion-item> elements. Found unexpected: ${o.map((t) => `<${t.tagName.toLowerCase()}>`).join(", ")}`
314
+ o.length > 0 && A(
315
+ "hx-accordion",
316
+ `Default slot expects <hx-accordion-item> elements. Found unexpected: ${o.map((t) => `<${t.tagName.toLowerCase()}>`).join(", ")}`
314
317
  );
315
318
  }
316
319
  // ─── Render ───
@@ -322,15 +325,15 @@ let c = class extends w {
322
325
  `;
323
326
  }
324
327
  };
325
- c.styles = [k, A];
326
- C([
328
+ c.styles = [k, I];
329
+ $([
327
330
  m({ type: String, reflect: !0 })
328
331
  ], c.prototype, "mode", 2);
329
- c = C([
332
+ c = $([
330
333
  E("hx-accordion")
331
334
  ], c);
332
335
  export {
333
336
  c as H,
334
- l as a
337
+ s as a
335
338
  };
336
- //# sourceMappingURL=hx-accordion-D95XSAft.js.map
339
+ //# sourceMappingURL=hx-accordion-Cyswa6J3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-accordion-Cyswa6J3.js","sources":["../../src/components/hx-accordion/hx-accordion.styles.ts","../../src/components/hx-accordion/hx-accordion-item.styles.ts","../../src/components/hx-accordion/hx-accordion-item.ts","../../src/components/hx-accordion/hx-accordion.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixAccordionStyles = css`\n :host {\n display: block;\n font-family: var(--hx-font-family-sans, sans-serif);\n }\n\n .accordion {\n border-radius: var(--hx-accordion-border-radius, var(--hx-border-radius-md, 0.375rem));\n overflow: hidden;\n }\n`;\n","import { css } from 'lit';\n\nexport const helixAccordionItemStyles = css`\n :host {\n display: block;\n }\n\n .item {\n border-bottom: var(--hx-border-width-thin, 1px) solid\n var(--hx-accordion-border-color, var(--hx-color-neutral-200, #dee2e6));\n font-family: var(--hx-font-family-sans, sans-serif);\n }\n\n :host(:first-child) .item {\n border-top: var(--hx-border-width-thin, 1px) solid\n var(--hx-accordion-border-color, var(--hx-color-neutral-200, #dee2e6));\n }\n\n /* Remove native details marker */\n .trigger {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: var(--hx-space-3, 0.75rem);\n padding: var(--hx-accordion-trigger-padding, var(--hx-space-4, 1rem));\n cursor: pointer;\n list-style: none;\n font-size: var(--hx-font-size-md, 1rem);\n font-weight: var(--hx-font-weight-semibold, 600);\n color: var(--hx-accordion-trigger-color, var(--hx-color-neutral-800, #212529));\n background-color: var(--hx-accordion-trigger-bg, transparent);\n user-select: none;\n transition: background-color var(--hx-transition-fast, 150ms ease);\n }\n\n /* Hide the native details disclosure triangle */\n .trigger::-webkit-details-marker {\n display: none;\n }\n\n .trigger::marker {\n display: none;\n }\n\n .item--disabled .trigger {\n cursor: not-allowed;\n }\n\n :host(:not([disabled])) .trigger:hover {\n background-color: var(--hx-accordion-trigger-hover-bg, var(--hx-color-neutral-50, #f8f9fa));\n }\n\n .trigger:focus-visible {\n outline: var(--hx-focus-ring-width, 2px) solid\n var(--hx-focus-ring-color, var(--hx-color-primary-500, #2563eb));\n outline-offset: var(--hx-focus-ring-offset, -2px);\n }\n\n /* ─── Icon ─── */\n\n .icon {\n flex-shrink: 0;\n width: 1.25rem;\n height: 1.25rem;\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--hx-accordion-icon-color, var(--hx-color-neutral-500, #6c757d));\n transition: transform var(--hx-transition-normal, 250ms ease);\n }\n\n .item--expanded .icon {\n transform: rotate(180deg);\n }\n\n /* ─── Content animation via CSS grid trick ─── */\n\n .content-wrapper {\n display: grid;\n grid-template-rows: 0fr;\n transition: grid-template-rows var(--hx-transition-normal, 250ms ease);\n overflow: hidden;\n }\n\n .item--expanded .content-wrapper,\n details[open]:not(.item--expanded) .content-wrapper {\n grid-template-rows: 1fr;\n }\n\n .content-inner {\n overflow: hidden;\n }\n\n .content {\n padding: var(--hx-accordion-content-padding, 0 var(--hx-space-4, 1rem) var(--hx-space-4, 1rem));\n font-size: var(--hx-font-size-md, 1rem);\n line-height: var(--hx-line-height-normal, 1.5);\n color: var(--hx-accordion-content-color, var(--hx-color-neutral-600, #495057));\n }\n\n /* ─── Disabled host ─── */\n\n :host([disabled]) {\n pointer-events: none;\n opacity: 0.5;\n }\n\n /* ─── Reduced motion ─── */\n\n @media (prefers-reduced-motion: reduce) {\n .trigger {\n transition: none;\n }\n\n .icon {\n transition: none;\n }\n\n .content-wrapper {\n transition: none;\n }\n }\n`;\n","import { LitElement, html, svg, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { tokenStyles } from '@helixui/tokens/lit';\nimport { helixAccordionItemStyles } from './hx-accordion-item.styles.js';\n\nconst chevronIcon = svg`\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n aria-hidden=\"true\"\n >\n <polyline points=\"6 9 12 15 18 9\"></polyline>\n </svg>\n`;\n\n/**\n * An individual accordion item with collapsible content.\n *\n * @summary Collapsible panel that can be expanded or collapsed.\n *\n * @tag hx-accordion-item\n *\n * @slot trigger - The heading/trigger content for this item.\n * @slot - Default slot for the collapsible body content.\n *\n * @fires {CustomEvent<{expanded: boolean, itemId: string}>} hx-expand - Dispatched when the item is expanded.\n * @fires {CustomEvent<{expanded: boolean, itemId: string}>} hx-collapse - Dispatched when the item is collapsed.\n *\n * @csspart item - The outer details element container.\n * @csspart trigger - The summary/trigger element.\n * @csspart content - The collapsible content area.\n * @csspart icon - The expand/collapse icon.\n *\n * @cssprop [--hx-accordion-border-color=var(--hx-color-neutral-200)] - Border color between items.\n * @cssprop [--hx-accordion-trigger-padding=var(--hx-space-4)] - Trigger padding.\n * @cssprop [--hx-accordion-trigger-color=var(--hx-color-neutral-800)] - Trigger text color.\n * @cssprop [--hx-accordion-trigger-bg=transparent] - Trigger background color.\n * @cssprop [--hx-accordion-trigger-hover-bg=var(--hx-color-neutral-50)] - Trigger hover background.\n * @cssprop [--hx-accordion-icon-color=var(--hx-color-neutral-500)] - Icon color.\n * @cssprop [--hx-accordion-content-padding=0 var(--hx-space-4) var(--hx-space-4)] - Content padding.\n * @cssprop [--hx-accordion-content-color=var(--hx-color-neutral-600)] - Content text color.\n */\n@customElement('hx-accordion-item')\nexport class HelixAccordionItem extends LitElement {\n static override styles = [tokenStyles, helixAccordionItemStyles];\n\n private static _counter = 0;\n private _uid = `hx-accordion-item-${++HelixAccordionItem._counter}`;\n\n /**\n * Whether this item is expanded.\n * @attr expanded\n */\n @property({ type: Boolean, reflect: true })\n expanded = false;\n\n /**\n * Whether this item is disabled (cannot be toggled).\n * @attr disabled\n */\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n // ─── Toggle Logic ───\n\n private _toggle(): void {\n if (this.disabled) return;\n\n const willExpand = !this.expanded;\n this.expanded = willExpand;\n\n this._dispatchToggleEvent(willExpand);\n }\n\n _dispatchToggleEvent(expanded: boolean): void {\n const detail = { expanded, itemId: this.id || '' };\n const options = { bubbles: true, composed: true, detail };\n\n if (expanded) {\n this.dispatchEvent(new CustomEvent('hx-expand', options));\n } else {\n this.dispatchEvent(new CustomEvent('hx-collapse', options));\n }\n }\n\n // ─── Event Handlers ───\n\n private _handleSummaryClick(e: MouseEvent): void {\n e.preventDefault();\n this._toggle();\n }\n\n private _handleKeyDown(e: KeyboardEvent): void {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n this._toggle();\n }\n }\n\n // ─── Render ───\n\n override render() {\n const itemClasses = {\n item: true,\n 'item--expanded': this.expanded,\n 'item--disabled': this.disabled,\n };\n\n return html`\n <details part=\"item\" class=${classMap(itemClasses)} ?open=${this.expanded}>\n <summary\n id=${`${this._uid}-trigger`}\n part=\"trigger\"\n class=\"trigger\"\n tabindex=${this.disabled ? '-1' : '0'}\n aria-expanded=${this.expanded ? 'true' : 'false'}\n aria-disabled=${this.disabled ? 'true' : 'false'}\n aria-controls=${`${this._uid}-content`}\n @click=${this._handleSummaryClick}\n @keydown=${this._handleKeyDown}\n >\n <slot name=\"trigger\"></slot>\n <span part=\"icon\" class=\"icon\">${chevronIcon}</span>\n </summary>\n <div class=\"content-wrapper\">\n <div class=\"content-inner\">\n <div\n id=${`${this._uid}-content`}\n part=\"content\"\n class=\"content\"\n role=\"region\"\n aria-labelledby=${`${this._uid}-trigger`}\n aria-hidden=${this.expanded ? nothing : 'true'}\n >\n <slot></slot>\n </div>\n </div>\n </div>\n </details>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-accordion-item': HelixAccordionItem;\n }\n}\n","import { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { tokenStyles } from '@helixui/tokens/lit';\nimport { helixAccordionStyles } from './hx-accordion.styles.js';\nimport './hx-accordion-item.js';\nimport type { HelixAccordionItem } from './hx-accordion-item.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\n/**\n * An accordion container that manages collapsible content sections.\n *\n * @summary Collapsible content sections with single or multi-expand modes.\n *\n * @tag hx-accordion\n *\n * @slot - Default slot for hx-accordion-item elements.\n *\n * @csspart accordion - The outer container wrapping all accordion items.\n *\n * @cssprop [--hx-accordion-border-radius=var(--hx-border-radius-md)] - Outer border radius.\n *\n * @example\n * ```html\n * <hx-accordion mode=\"single\">\n * <hx-accordion-item>\n * <span slot=\"trigger\">What is this?</span>\n * <p>Answer content here.</p>\n * </hx-accordion-item>\n * </hx-accordion>\n * ```\n */\n@customElement('hx-accordion')\nexport class HelixAccordion extends LitElement {\n static override styles = [tokenStyles, helixAccordionStyles];\n\n /**\n * Expansion mode: 'single' collapses all other items when one expands.\n * 'multi' allows multiple items open simultaneously.\n * @attr mode\n */\n @property({ type: String, reflect: true })\n mode: 'single' | 'multi' = 'single';\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('hx-expand', this._handleChildExpand);\n this.addEventListener('keydown', this._handleKeyDown);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.removeEventListener('hx-expand', this._handleChildExpand);\n this.removeEventListener('keydown', this._handleKeyDown);\n }\n\n protected override firstUpdated(): void {\n this._enforceSingleMode();\n }\n\n // ─── Single-expand coordination ───\n\n private _enforceSingleMode(): void {\n if (this.mode !== 'single') return;\n\n const items = this.querySelectorAll<HelixAccordionItem>('hx-accordion-item');\n let foundExpanded = false;\n\n items.forEach((item) => {\n if (item.expanded) {\n if (foundExpanded) {\n item.expanded = false;\n } else {\n foundExpanded = true;\n }\n }\n });\n }\n\n /**\n * Handles expand events from child accordion items to enforce single-expand mode.\n * @internal\n */\n private _handleChildExpand = (e: Event): void => {\n if (this.mode !== 'single') return;\n\n const expandedItem = e.composedPath()[0] as HelixAccordionItem;\n const items = this.querySelectorAll<HelixAccordionItem>('hx-accordion-item');\n\n items.forEach((item) => {\n if (item !== expandedItem && item.expanded) {\n item.expanded = false;\n item._dispatchToggleEvent(false);\n }\n });\n };\n\n // ─── Arrow key navigation (ARIA APG Accordion pattern) ───\n\n /**\n * Handles keyboard navigation between accordion triggers using arrow, Home, and End keys.\n * @internal\n */\n private _handleKeyDown = (e: KeyboardEvent): void => {\n const triggers = this._getTriggers();\n if (triggers.length === 0) return;\n\n const activeEl = this.shadowRoot?.activeElement ?? document.activeElement;\n let currentItem: HelixAccordionItem | null = null;\n\n const items = Array.from(this.querySelectorAll<HelixAccordionItem>('hx-accordion-item'));\n for (const item of items) {\n const summary = item.shadowRoot?.querySelector('summary');\n if (summary === activeEl || item.shadowRoot?.activeElement === summary) {\n currentItem = item;\n break;\n }\n }\n\n if (!currentItem) return;\n\n const enabledItems = items.filter((item) => !item.disabled);\n const currentIndex = enabledItems.indexOf(currentItem);\n if (currentIndex === -1) return;\n\n let targetIndex = -1;\n\n switch (e.key) {\n case 'ArrowDown':\n targetIndex = (currentIndex + 1) % enabledItems.length;\n break;\n case 'ArrowUp':\n targetIndex = (currentIndex - 1 + enabledItems.length) % enabledItems.length;\n break;\n case 'Home':\n targetIndex = 0;\n break;\n case 'End':\n targetIndex = enabledItems.length - 1;\n break;\n default:\n return;\n }\n\n e.preventDefault();\n const targetItem = enabledItems[targetIndex];\n const targetSummary = targetItem?.shadowRoot?.querySelector('summary');\n targetSummary?.focus();\n };\n\n private _getTriggers(): HTMLElement[] {\n const items = this.querySelectorAll<HelixAccordionItem>('hx-accordion-item');\n const triggers: HTMLElement[] = [];\n items.forEach((item) => {\n const summary = item.shadowRoot?.querySelector<HTMLElement>('summary');\n if (summary) triggers.push(summary);\n });\n return triggers;\n }\n\n // ─── Slot validation ───\n\n private _handleSlotChange(e: Event): void {\n const slot = e.target;\n if (!(slot instanceof HTMLSlotElement)) return;\n const invalid = slot\n .assignedElements()\n .filter((el) => el.tagName.toLowerCase() !== 'hx-accordion-item');\n if (invalid.length > 0) {\n devWarn(\n 'hx-accordion',\n `Default slot expects <hx-accordion-item> elements. Found unexpected: ${invalid.map((el) => `<${el.tagName.toLowerCase()}>`).join(', ')}`,\n );\n }\n }\n\n // ─── Render ───\n\n override render() {\n return html`\n <div part=\"accordion\" class=\"accordion\">\n <slot @slotchange=${this._handleSlotChange}></slot>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-accordion': HelixAccordion;\n }\n}\n"],"names":["helixAccordionStyles","css","helixAccordionItemStyles","chevronIcon","svg","HelixAccordionItem","LitElement","willExpand","expanded","options","itemClasses","html","classMap","nothing","tokenStyles","__decorateClass","property","customElement","HelixAccordion","expandedItem","item","activeEl","_a","currentItem","items","summary","_b","_c","enabledItems","currentIndex","targetIndex","targetItem","targetSummary","_d","foundExpanded","triggers","slot","invalid","el","devWarn"],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import { css as d, LitElement as b, html as f } from "lit";
2
- import { property as l, state as p, customElement as u } from "lit/decorators.js";
2
+ import { property as c, state as p, customElement as u } from "lit/decorators.js";
3
3
  import { tokenStyles as v } from "@helixui/tokens/lit";
4
+ import { d as m } from "./dev-warn-YlwPHjtX.js";
4
5
  const x = d`
5
6
  :host {
6
7
  display: block;
@@ -119,27 +120,27 @@ const x = d`
119
120
  flex-shrink: 0;
120
121
  }
121
122
  `;
122
- var m = Object.defineProperty, g = Object.getOwnPropertyDescriptor, c = (t, e, s, a) => {
123
- for (var i = a > 1 ? void 0 : a ? g(e, s) : e, o = t.length - 1, r; o >= 0; o--)
124
- (r = t[o]) && (i = (a ? r(e, s, i) : r(i)) || i);
125
- return a && i && m(e, s, i), i;
123
+ var g = Object.defineProperty, y = Object.getOwnPropertyDescriptor, l = (t, e, a, s) => {
124
+ for (var i = s > 1 ? void 0 : s ? y(e, a) : e, o = t.length - 1, r; o >= 0; o--)
125
+ (r = t[o]) && (i = (s ? r(e, a, i) : r(i)) || i);
126
+ return s && i && g(e, a, i), i;
126
127
  };
127
128
  let n = class extends b {
128
129
  constructor() {
129
130
  super(...arguments), this.size = "md", this.variant = "default", this.position = "top", this._sticky = !1, this.ariaLabel = "Actions", this._focusableCache = null, this._hasOverflow = !1, this._handleKeydown = (t) => {
130
- var e, s;
131
+ var e, a;
131
132
  if (t.key === "ArrowRight")
132
133
  t.preventDefault(), this._moveFocus("next");
133
134
  else if (t.key === "ArrowLeft")
134
135
  t.preventDefault(), this._moveFocus("prev");
135
136
  else if (t.key === "Home") {
136
137
  t.preventDefault();
137
- const a = this._getFocusableItems();
138
- a.length && (a.forEach((i, o) => i.setAttribute("tabindex", o === 0 ? "0" : "-1")), (e = a[0]) == null || e.focus());
138
+ const s = this._getFocusableItems();
139
+ s.length && (s.forEach((i, o) => i.setAttribute("tabindex", o === 0 ? "0" : "-1")), (e = s[0]) == null || e.focus());
139
140
  } else if (t.key === "End") {
140
141
  t.preventDefault();
141
- const a = this._getFocusableItems(), i = a.length - 1;
142
- a.length && (a.forEach((o, r) => o.setAttribute("tabindex", r === i ? "0" : "-1")), (s = a[i]) == null || s.focus());
142
+ const s = this._getFocusableItems(), i = s.length - 1;
143
+ s.length && (s.forEach((o, r) => o.setAttribute("tabindex", r === i ? "0" : "-1")), (a = s[i]) == null || a.focus());
143
144
  }
144
145
  };
145
146
  }
@@ -147,14 +148,14 @@ let n = class extends b {
147
148
  return this._sticky;
148
149
  }
149
150
  set sticky(t) {
150
- t && console.warn(
151
- '[hx-action-bar] The `sticky` property is deprecated. Use `position="sticky"` instead.'
152
- );
153
151
  const e = this._sticky;
154
152
  this._sticky = t, this.requestUpdate("sticky", e);
155
153
  }
156
154
  connectedCallback() {
157
- super.connectedCallback(), this.hasAttribute("role") || this.setAttribute("role", "none"), this.addEventListener("keydown", this._handleKeydown);
155
+ super.connectedCallback(), this.hasAttribute("role") ? this.getAttribute("role") !== "none" && m(
156
+ "hx-action-bar",
157
+ `Setting role="${this.getAttribute("role")}" on the host creates a duplicate toolbar announcement. The shadow DOM already contains role="toolbar". Set role="none" on the host to suppress it.`
158
+ ) : this.setAttribute("role", "none"), this.addEventListener("keydown", this._handleKeydown);
158
159
  }
159
160
  firstUpdated() {
160
161
  this._initRovingTabindex();
@@ -166,15 +167,15 @@ let n = class extends b {
166
167
  _isFocusable(t) {
167
168
  if (t.hasAttribute("disabled") || t.disabled === !0) return !1;
168
169
  if (t.tabIndex >= 0) return !0;
169
- const s = t.tagName.toLowerCase();
170
- return s === "button" || s === "input" || s === "select" || s === "textarea";
170
+ const a = t.tagName.toLowerCase();
171
+ return a === "button" || a === "input" || a === "select" || a === "textarea";
171
172
  }
172
173
  _getFocusableItems() {
173
- var s;
174
+ var a;
174
175
  if (this._focusableCache) return this._focusableCache;
175
- const t = ((s = this.shadowRoot) == null ? void 0 : s.querySelectorAll("slot")) ?? [], e = [];
176
- for (const a of Array.from(t)) {
177
- const i = a.assignedElements({ flatten: !0 });
176
+ const t = ((a = this.shadowRoot) == null ? void 0 : a.querySelectorAll("slot")) ?? [], e = [];
177
+ for (const s of Array.from(t)) {
178
+ const i = s.assignedElements({ flatten: !0 });
178
179
  for (const o of i)
179
180
  if (o instanceof HTMLElement)
180
181
  if (this._isFocusable(o))
@@ -192,17 +193,17 @@ let n = class extends b {
192
193
  this._focusableCache = null;
193
194
  const t = this._getFocusableItems();
194
195
  if (!t.length) return;
195
- t.some((s) => s.getAttribute("tabindex") === "0") ? t.forEach((s) => {
196
- s.getAttribute("tabindex") === null && s.setAttribute("tabindex", "-1");
197
- }) : t.forEach((s, a) => s.setAttribute("tabindex", a === 0 ? "0" : "-1"));
196
+ t.some((a) => a.getAttribute("tabindex") === "0") ? t.forEach((a) => {
197
+ a.getAttribute("tabindex") === null && a.setAttribute("tabindex", "-1");
198
+ }) : t.forEach((a, s) => a.setAttribute("tabindex", s === 0 ? "0" : "-1"));
198
199
  }
199
200
  _moveFocus(t) {
200
201
  var o;
201
202
  const e = this._getFocusableItems();
202
203
  if (!e.length) return;
203
- const s = document.activeElement, a = e.indexOf(s);
204
+ const a = document.activeElement, s = e.indexOf(a);
204
205
  let i;
205
- t === "next" ? i = a < e.length - 1 ? a + 1 : 0 : i = a > 0 ? a - 1 : e.length - 1, e.forEach((r, h) => {
206
+ t === "next" ? i = s < e.length - 1 ? s + 1 : 0 : i = s > 0 ? s - 1 : e.length - 1, e.forEach((r, h) => {
206
207
  r.setAttribute("tabindex", h === i ? "0" : "-1");
207
208
  }), (o = e[i]) == null || o.focus();
208
209
  }
@@ -213,14 +214,14 @@ let n = class extends b {
213
214
  }
214
215
  // ─── Render ───
215
216
  render() {
216
- const t = this.position === "sticky" || this.sticky, e = this.position === "bottom", s = t ? " base--sticky" : e ? " base--bottom" : "";
217
+ const t = this.position === "sticky" || this.sticky, e = this.position === "bottom", a = t ? " base--sticky" : e ? " base--bottom" : "";
217
218
  return f`
218
219
  <div
219
220
  part="base"
220
221
  role="toolbar"
221
222
  aria-label=${this.ariaLabel}
222
223
  aria-orientation="horizontal"
223
- class="base base--${this.size} base--${this.variant}${s}"
224
+ class="base base--${this.size} base--${this.variant}${a}"
224
225
  >
225
226
  <div part="start" class="section section--start">
226
227
  <slot name="start" @slotchange=${this._handleSlotChange}></slot>
@@ -239,28 +240,28 @@ let n = class extends b {
239
240
  }
240
241
  };
241
242
  n.styles = [v, x];
242
- c([
243
- l({ type: String, reflect: !0 })
243
+ l([
244
+ c({ type: String, reflect: !0 })
244
245
  ], n.prototype, "size", 2);
245
- c([
246
- l({ type: String, reflect: !0 })
246
+ l([
247
+ c({ type: String, reflect: !0 })
247
248
  ], n.prototype, "variant", 2);
248
- c([
249
- l({ type: String, reflect: !0 })
249
+ l([
250
+ c({ type: String, reflect: !0 })
250
251
  ], n.prototype, "position", 2);
251
- c([
252
- l({ type: Boolean, reflect: !0 })
252
+ l([
253
+ c({ type: Boolean, reflect: !0 })
253
254
  ], n.prototype, "sticky", 1);
254
- c([
255
- l({ attribute: "aria-label" })
255
+ l([
256
+ c({ attribute: "aria-label" })
256
257
  ], n.prototype, "ariaLabel", 2);
257
- c([
258
+ l([
258
259
  p()
259
260
  ], n.prototype, "_hasOverflow", 2);
260
- n = c([
261
+ n = l([
261
262
  u("hx-action-bar")
262
263
  ], n);
263
264
  export {
264
265
  n as H
265
266
  };
266
- //# sourceMappingURL=hx-action-bar-B4i9tBCP.js.map
267
+ //# sourceMappingURL=hx-action-bar-we_WJety.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-action-bar-we_WJety.js","sources":["../../src/components/hx-action-bar/hx-action-bar.styles.ts","../../src/components/hx-action-bar/hx-action-bar.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixActionBarStyles = css`\n :host {\n display: block;\n }\n\n /* ─── Base ─── */\n\n .base {\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: var(--hx-action-bar-gap, var(--hx-space-2, 0.5rem));\n padding: var(--hx-action-bar-padding, var(--hx-space-2, 0.5rem) var(--hx-space-3, 0.75rem));\n background: var(--hx-action-bar-bg, transparent);\n border: var(--hx-action-bar-border, none);\n box-sizing: border-box;\n width: 100%;\n }\n\n /* ─── Sticky (top) ─── */\n\n .base--sticky {\n position: sticky;\n top: 0;\n padding-top: max(var(--hx-action-bar-padding-block-start, 0px), env(safe-area-inset-top, 0px));\n z-index: var(--hx-action-bar-z-index, 10);\n /*\n * Consumers: when this bar is sticky, add scroll-padding-top to the scroll container\n * equal to the bar's rendered height so anchor targets are not hidden behind the bar.\n * Example: .scroll-container { scroll-padding-top: 2.5rem; }\n */\n }\n\n /* ─── Bottom sticky ─── */\n\n .base--bottom {\n position: sticky;\n bottom: 0;\n /*\n * Respect iOS home-indicator safe area on devices with notch/home bar.\n * Falls back to 0px on devices that do not support env().\n */\n padding-bottom: max(\n var(--hx-action-bar-padding-block-end, 0px),\n env(safe-area-inset-bottom, 0px)\n );\n z-index: var(--hx-action-bar-z-index, 10);\n }\n\n /* ─── Variant: outlined ─── */\n\n .base--outlined {\n background: var(--hx-action-bar-bg, var(--hx-color-neutral-0, #fff));\n border: var(\n --hx-action-bar-border,\n var(--hx-border-width-thin, 1px) solid var(--hx-color-neutral-200, #e5e7eb)\n );\n border-radius: var(--hx-border-radius-md, 0.375rem);\n }\n\n /* ─── Variant: filled ─── */\n\n .base--filled {\n background: var(--hx-action-bar-bg, var(--hx-color-neutral-50, #f9fafb));\n border-radius: var(--hx-border-radius-md, 0.375rem);\n }\n\n /* ─── Size modifiers ─── */\n\n .base--sm {\n padding: var(--hx-action-bar-padding, var(--hx-space-1, 0.25rem) var(--hx-space-2, 0.5rem));\n gap: var(--hx-action-bar-gap, var(--hx-space-1, 0.25rem));\n min-height: var(--hx-size-8, 2rem);\n }\n\n .base--md {\n min-height: var(--hx-size-10, 2.5rem);\n }\n\n .base--lg {\n padding: var(--hx-action-bar-padding, var(--hx-space-3, 0.75rem) var(--hx-space-4, 1rem));\n gap: var(--hx-action-bar-gap, var(--hx-space-3, 0.75rem));\n min-height: var(--hx-size-12, 3rem);\n }\n\n /* ─── Sections ─── */\n\n .section {\n display: flex;\n align-items: center;\n gap: inherit;\n }\n\n /*\n * Equal flex-basis on start and end guarantees the center section is visually centered\n * within the full bar width, regardless of how wide start and end content are.\n */\n .section--start {\n flex: 1 1 0;\n justify-content: flex-start;\n }\n\n .section--center {\n flex: 0 0 auto;\n justify-content: center;\n }\n\n .section--end {\n flex: 1 1 0;\n justify-content: flex-end;\n }\n\n /* ─── Slotted content ─── */\n\n ::slotted(*) {\n flex-shrink: 0;\n }\n`;\n","import { LitElement, html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { tokenStyles } from '@helixui/tokens/lit';\nimport { helixActionBarStyles } from './hx-action-bar.styles.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\n/**\n * A horizontal toolbar container for grouping related action buttons and controls.\n * Implements the ARIA toolbar pattern with roving tabindex keyboard navigation.\n *\n * @summary Horizontal action bar for grouping related controls.\n *\n * @tag hx-action-bar\n *\n * @slot start - Left-aligned actions.\n * @slot - Center content (default slot).\n * @slot end - Right-aligned actions.\n * @slot overflow - Actions revealed when the bar is constrained for space.\n *\n * @csspart base - The root toolbar container element.\n * @csspart start - The start (left) slot wrapper.\n * @csspart center - The center (default) slot wrapper.\n * @csspart end - The end (right) slot wrapper.\n * @csspart overflow - The overflow slot wrapper (hidden when no overflow content).\n *\n * @cssprop [--hx-action-bar-bg=transparent] - Bar background color (default variant).\n * @cssprop [--hx-action-bar-border=none] - Bar border (default variant).\n * @cssprop [--hx-action-bar-padding=var(--hx-space-2,0.5rem) var(--hx-space-3,0.75rem)] - Inner padding.\n * @cssprop [--hx-action-bar-gap=var(--hx-space-2,0.5rem)] - Gap between slotted items.\n * @cssprop [--hx-action-bar-z-index=10] - Z-index when sticky or bottom position.\n *\n * @attr {string} aria-label - Required. Identifies the toolbar to assistive technology.\n * When multiple toolbars appear on the same page, each must have a unique, descriptive label.\n *\n * @example\n * ```html\n * <hx-action-bar aria-label=\"Patient actions\">\n * <hx-button slot=\"start\">Save</hx-button>\n * <hx-button slot=\"end\" variant=\"ghost\">Cancel</hx-button>\n * </hx-action-bar>\n * ```\n */\n@customElement('hx-action-bar')\nexport class HelixActionBar extends LitElement {\n static override styles = [tokenStyles, helixActionBarStyles];\n\n /**\n * Size of the action bar — propagated as a data attribute to slotted children.\n * @attr size\n */\n @property({ type: String, reflect: true })\n size: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Visual variant controlling the bar background.\n * @attr variant\n */\n @property({ type: String, reflect: true })\n variant: 'default' | 'outlined' | 'filled' = 'default';\n\n /**\n * Position and sticky behavior of the action bar.\n * - `top` — normal flow (default)\n * - `sticky` — sticks to the top of the scroll container; add `scroll-padding-top` to the\n * scroll container equal to the bar height to prevent anchor targets from scrolling behind it\n * - `bottom` — sticks to the bottom of the scroll container with iOS safe-area-inset support\n * @attr position\n */\n @property({ type: String, reflect: true })\n position: 'top' | 'bottom' | 'sticky' = 'top';\n\n /**\n * @deprecated Use `position=\"sticky\"` instead.\n * When true, the bar sticks to the top of its scroll container.\n * @attr sticky\n */\n @property({ type: Boolean, reflect: true })\n get sticky(): boolean {\n return this._sticky;\n }\n set sticky(value: boolean) {\n if (value) {\n devWarn(\n 'hx-action-bar',\n 'The `sticky` property is deprecated. Use `position=\"sticky\"` instead.',\n );\n }\n const old = this._sticky;\n this._sticky = value;\n this.requestUpdate('sticky', old);\n }\n private _sticky = false;\n\n /**\n * Accessible label for the toolbar.\n * Required when multiple toolbars appear on the same page.\n * @attr aria-label\n */\n @property({ attribute: 'aria-label' })\n ariaLabel: string = 'Actions';\n\n /** Cached list of focusable items — invalidated on slot change. */\n private _focusableCache: HTMLElement[] | null = null;\n\n /** Whether the overflow slot has assigned content. */\n @state()\n private _hasOverflow = false;\n\n // ─── Lifecycle ───\n\n /** Arrow function field — stable reference for add/removeEventListener. */\n private _handleKeydown = (e: KeyboardEvent): void => {\n if (e.key === 'ArrowRight') {\n e.preventDefault();\n this._moveFocus('next');\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n this._moveFocus('prev');\n } else if (e.key === 'Home') {\n e.preventDefault();\n // Move directly to first item — do NOT call _moveFocus which would visit other items first.\n const items = this._getFocusableItems();\n if (items.length) {\n items.forEach((el, i) => el.setAttribute('tabindex', i === 0 ? '0' : '-1'));\n items[0]?.focus();\n }\n } else if (e.key === 'End') {\n e.preventDefault();\n const items = this._getFocusableItems();\n const last = items.length - 1;\n if (items.length) {\n items.forEach((el, i) => el.setAttribute('tabindex', i === last ? '0' : '-1'));\n items[last]?.focus();\n }\n }\n };\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Prevent dual aria-label announcement: the host carries the consumer's\n // aria-label attribute while the inner div[role=\"toolbar\"] receives the\n // same value. Setting role=\"none\" on the host hides it from the\n // accessibility tree so only the toolbar is announced.\n if (!this.hasAttribute('role')) {\n this.setAttribute('role', 'none');\n } else if (this.getAttribute('role') !== 'none') {\n devWarn(\n 'hx-action-bar',\n `Setting role=\"${this.getAttribute('role')}\" on the host creates a duplicate toolbar announcement. ` +\n 'The shadow DOM already contains role=\"toolbar\". Set role=\"none\" on the host to suppress it.',\n );\n }\n this.addEventListener('keydown', this._handleKeydown);\n }\n\n override firstUpdated(): void {\n // Slot assignments are complete by firstUpdated; initialize roving tabindex\n // immediately rather than waiting for the async slotchange event.\n this._initRovingTabindex();\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.removeEventListener('keydown', this._handleKeydown);\n }\n\n // ─── Focusable item discovery ───\n\n private _isFocusable(el: HTMLElement): boolean {\n // Check disabled via DOM attribute (native elements) or property (custom elements)\n if (el.hasAttribute('disabled')) return false;\n const elWithDisabled = el as HTMLElement & { disabled?: boolean };\n if (elWithDisabled.disabled === true) return false;\n\n // Use the IDL tabIndex property — covers both DOM attribute and ElementInternals settings.\n // Custom elements (e.g. hx-button) that set tabIndex via ElementInternals are discoverable.\n if (el.tabIndex >= 0) return true;\n\n const tag = el.tagName.toLowerCase();\n return tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea';\n }\n\n private _getFocusableItems(): HTMLElement[] {\n if (this._focusableCache) return this._focusableCache;\n\n const slots = this.shadowRoot?.querySelectorAll('slot') ?? [];\n const items: HTMLElement[] = [];\n\n for (const slot of Array.from(slots)) {\n const assigned = (slot as HTMLSlotElement).assignedElements({ flatten: true });\n for (const el of assigned) {\n if (!(el instanceof HTMLElement)) continue;\n if (this._isFocusable(el)) {\n // Element is itself focusable — include it and do NOT also recurse into its children\n // to prevent double-counting compound components (e.g. <a><button>).\n items.push(el);\n } else {\n // Element is a non-focusable wrapper (e.g. <div>, <span>) — find focusable children.\n const descendants = el.querySelectorAll<HTMLElement>('*');\n for (const d of Array.from(descendants)) {\n if (this._isFocusable(d)) {\n items.push(d);\n }\n }\n }\n }\n }\n\n this._focusableCache = items;\n return items;\n }\n\n // ─── Roving tabindex helpers ───\n\n private _initRovingTabindex(): void {\n this._focusableCache = null; // invalidate cache on slot change\n const items = this._getFocusableItems();\n if (!items.length) return;\n const hasActive = items.some((el) => el.getAttribute('tabindex') === '0');\n if (!hasActive) {\n // No item is active yet — make the first item tabbable.\n items.forEach((el, i) => el.setAttribute('tabindex', i === 0 ? '0' : '-1'));\n } else {\n // An item is already active — ensure new items get tabindex=\"-1\"\n // without disturbing the currently active item.\n items.forEach((el) => {\n if (el.getAttribute('tabindex') === null) el.setAttribute('tabindex', '-1');\n });\n }\n }\n\n private _moveFocus(direction: 'next' | 'prev'): void {\n const items = this._getFocusableItems();\n if (!items.length) return;\n\n const focused = document.activeElement as HTMLElement | null;\n const currentIndex = items.indexOf(focused as HTMLElement);\n\n let nextIndex: number;\n if (direction === 'next') {\n nextIndex = currentIndex < items.length - 1 ? currentIndex + 1 : 0;\n } else {\n nextIndex = currentIndex > 0 ? currentIndex - 1 : items.length - 1;\n }\n\n items.forEach((el, i) => {\n el.setAttribute('tabindex', i === nextIndex ? '0' : '-1');\n });\n\n items[nextIndex]?.focus();\n }\n\n // ─── Event Handlers ───\n\n private _handleSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n if (slot.name === 'overflow') {\n this._hasOverflow = slot.assignedElements({ flatten: true }).length > 0;\n }\n this._initRovingTabindex();\n }\n\n // ─── Render ───\n\n override render() {\n const isSticky = this.position === 'sticky' || this.sticky;\n const isBottom = this.position === 'bottom';\n const positionClass = isSticky ? ' base--sticky' : isBottom ? ' base--bottom' : '';\n\n return html`\n <div\n part=\"base\"\n role=\"toolbar\"\n aria-label=${this.ariaLabel}\n aria-orientation=\"horizontal\"\n class=\"base base--${this.size} base--${this.variant}${positionClass}\"\n >\n <div part=\"start\" class=\"section section--start\">\n <slot name=\"start\" @slotchange=${this._handleSlotChange}></slot>\n </div>\n <div part=\"center\" class=\"section section--center\">\n <slot @slotchange=${this._handleSlotChange}></slot>\n </div>\n <div part=\"end\" class=\"section section--end\">\n <slot name=\"end\" @slotchange=${this._handleSlotChange}></slot>\n </div>\n <div part=\"overflow\" class=\"section section--overflow\" ?hidden=${!this._hasOverflow}>\n <slot name=\"overflow\" @slotchange=${this._handleSlotChange}></slot>\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-action-bar': HelixActionBar;\n }\n}\n"],"names":["helixActionBarStyles","css","HelixActionBar","LitElement","e","items","el","i","_a","last","_b","value","old","devWarn","tag","slots","slot","assigned","descendants","d","direction","focused","currentIndex","nextIndex","isSticky","isBottom","positionClass","html","tokenStyles","__decorateClass","property","state","customElement"],"mappings":";;;;AAEO,MAAMA,IAAuBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;;;;ACyC7B,IAAMC,IAAN,cAA6BC,EAAW;AAAA,EAAxC,cAAA;AAAA,UAAA,GAAA,SAAA,GAQL,KAAA,OAA2B,MAO3B,KAAA,UAA6C,WAW7C,KAAA,WAAwC,OAsBxC,KAAQ,UAAU,IAQlB,KAAA,YAAoB,WAGpB,KAAQ,kBAAwC,MAIhD,KAAQ,eAAe,IAKvB,KAAQ,iBAAiB,CAACC,MAA2B;;AACnD,UAAIA,EAAE,QAAQ;AACZ,QAAAA,EAAE,eAAA,GACF,KAAK,WAAW,MAAM;AAAA,eACbA,EAAE,QAAQ;AACnB,QAAAA,EAAE,eAAA,GACF,KAAK,WAAW,MAAM;AAAA,eACbA,EAAE,QAAQ,QAAQ;AAC3B,QAAAA,EAAE,eAAA;AAEF,cAAMC,IAAQ,KAAK,mBAAA;AACnB,QAAIA,EAAM,WACRA,EAAM,QAAQ,CAACC,GAAIC,MAAMD,EAAG,aAAa,YAAYC,MAAM,IAAI,MAAM,IAAI,CAAC,IAC1EC,IAAAH,EAAM,CAAC,MAAP,QAAAG,EAAU;AAAA,MAEd,WAAWJ,EAAE,QAAQ,OAAO;AAC1B,QAAAA,EAAE,eAAA;AACF,cAAMC,IAAQ,KAAK,mBAAA,GACbI,IAAOJ,EAAM,SAAS;AAC5B,QAAIA,EAAM,WACRA,EAAM,QAAQ,CAACC,GAAIC,MAAMD,EAAG,aAAa,YAAYC,MAAME,IAAO,MAAM,IAAI,CAAC,IAC7EC,IAAAL,EAAMI,CAAI,MAAV,QAAAC,EAAa;AAAA,MAEjB;AAAA,IACF;AAAA,EAAA;AAAA,EA1DA,IAAI,SAAkB;AACpB,WAAO,KAAK;AAAA,EACd;AAAA,EACA,IAAI,OAAOC,GAAgB;AAOzB,UAAMC,IAAM,KAAK;AACjB,SAAK,UAAUD,GACf,KAAK,cAAc,UAAUC,CAAG;AAAA,EAClC;AAAA,EA+CS,oBAA0B;AACjC,UAAM,kBAAA,GAKD,KAAK,aAAa,MAAM,IAElB,KAAK,aAAa,MAAM,MAAM,UACvCC;AAAA,MACE;AAAA,MACA,iBAAiB,KAAK,aAAa,MAAM,CAAC;AAAA,IAAA,IAJ5C,KAAK,aAAa,QAAQ,MAAM,GAQlC,KAAK,iBAAiB,WAAW,KAAK,cAAc;AAAA,EACtD;AAAA,EAES,eAAqB;AAG5B,SAAK,oBAAA;AAAA,EACP;AAAA,EAES,uBAA6B;AACpC,UAAM,qBAAA,GACN,KAAK,oBAAoB,WAAW,KAAK,cAAc;AAAA,EACzD;AAAA;AAAA,EAIQ,aAAaP,GAA0B;AAI7C,QAFIA,EAAG,aAAa,UAAU,KACPA,EACJ,aAAa,GAAM,QAAO;AAI7C,QAAIA,EAAG,YAAY,EAAG,QAAO;AAE7B,UAAMQ,IAAMR,EAAG,QAAQ,YAAA;AACvB,WAAOQ,MAAQ,YAAYA,MAAQ,WAAWA,MAAQ,YAAYA,MAAQ;AAAA,EAC5E;AAAA,EAEQ,qBAAoC;;AAC1C,QAAI,KAAK,gBAAiB,QAAO,KAAK;AAEtC,UAAMC,MAAQP,IAAA,KAAK,eAAL,gBAAAA,EAAiB,iBAAiB,YAAW,CAAA,GACrDH,IAAuB,CAAA;AAE7B,eAAWW,KAAQ,MAAM,KAAKD,CAAK,GAAG;AACpC,YAAME,IAAYD,EAAyB,iBAAiB,EAAE,SAAS,IAAM;AAC7E,iBAAWV,KAAMW;AACf,YAAMX,aAAc;AACpB,cAAI,KAAK,aAAaA,CAAE;AAGtB,YAAAD,EAAM,KAAKC,CAAE;AAAA,eACR;AAEL,kBAAMY,IAAcZ,EAAG,iBAA8B,GAAG;AACxD,uBAAWa,KAAK,MAAM,KAAKD,CAAW;AACpC,cAAI,KAAK,aAAaC,CAAC,KACrBd,EAAM,KAAKc,CAAC;AAAA,UAGlB;AAAA,IAEJ;AAEA,gBAAK,kBAAkBd,GAChBA;AAAA,EACT;AAAA;AAAA,EAIQ,sBAA4B;AAClC,SAAK,kBAAkB;AACvB,UAAMA,IAAQ,KAAK,mBAAA;AACnB,QAAI,CAACA,EAAM,OAAQ;AAEnB,IADkBA,EAAM,KAAK,CAACC,MAAOA,EAAG,aAAa,UAAU,MAAM,GAAG,IAOtED,EAAM,QAAQ,CAACC,MAAO;AACpB,MAAIA,EAAG,aAAa,UAAU,MAAM,QAAMA,EAAG,aAAa,YAAY,IAAI;AAAA,IAC5E,CAAC,IANDD,EAAM,QAAQ,CAACC,GAAIC,MAAMD,EAAG,aAAa,YAAYC,MAAM,IAAI,MAAM,IAAI,CAAC;AAAA,EAQ9E;AAAA,EAEQ,WAAWa,GAAkC;;AACnD,UAAMf,IAAQ,KAAK,mBAAA;AACnB,QAAI,CAACA,EAAM,OAAQ;AAEnB,UAAMgB,IAAU,SAAS,eACnBC,IAAejB,EAAM,QAAQgB,CAAsB;AAEzD,QAAIE;AACJ,IAAIH,MAAc,SAChBG,IAAYD,IAAejB,EAAM,SAAS,IAAIiB,IAAe,IAAI,IAEjEC,IAAYD,IAAe,IAAIA,IAAe,IAAIjB,EAAM,SAAS,GAGnEA,EAAM,QAAQ,CAACC,GAAIC,MAAM;AACvB,MAAAD,EAAG,aAAa,YAAYC,MAAMgB,IAAY,MAAM,IAAI;AAAA,IAC1D,CAAC,IAEDf,IAAAH,EAAMkB,CAAS,MAAf,QAAAf,EAAkB;AAAA,EACpB;AAAA;AAAA,EAIQ,kBAAkBJ,GAAgB;AACxC,UAAMY,IAAOZ,EAAE;AACf,IAAIY,EAAK,SAAS,eAChB,KAAK,eAAeA,EAAK,iBAAiB,EAAE,SAAS,GAAA,CAAM,EAAE,SAAS,IAExE,KAAK,oBAAA;AAAA,EACP;AAAA;AAAA,EAIS,SAAS;AAChB,UAAMQ,IAAW,KAAK,aAAa,YAAY,KAAK,QAC9CC,IAAW,KAAK,aAAa,UAC7BC,IAAgBF,IAAW,kBAAkBC,IAAW,kBAAkB;AAEhF,WAAOE;AAAA;AAAA;AAAA;AAAA,qBAIU,KAAK,SAAS;AAAA;AAAA,4BAEP,KAAK,IAAI,UAAU,KAAK,OAAO,GAAGD,CAAa;AAAA;AAAA;AAAA,2CAGhC,KAAK,iBAAiB;AAAA;AAAA;AAAA,8BAGnC,KAAK,iBAAiB;AAAA;AAAA;AAAA,yCAGX,KAAK,iBAAiB;AAAA;AAAA,yEAEU,CAAC,KAAK,YAAY;AAAA,8CAC7C,KAAK,iBAAiB;AAAA;AAAA;AAAA;AAAA,EAIlE;AACF;AAzPaxB,EACK,SAAS,CAAC0B,GAAa5B,CAAoB;AAO3D6B,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAP9B5B,EAQX,WAAA,QAAA,CAAA;AAOA2B,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAd9B5B,EAeX,WAAA,WAAA,CAAA;AAWA2B,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAzB9B5B,EA0BX,WAAA,YAAA,CAAA;AAQI2B,EAAA;AAAA,EADHC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAjC/B5B,EAkCP,WAAA,UAAA,CAAA;AAsBJ2B,EAAA;AAAA,EADCC,EAAS,EAAE,WAAW,aAAA,CAAc;AAAA,GAvD1B5B,EAwDX,WAAA,aAAA,CAAA;AAOQ2B,EAAA;AAAA,EADPE,EAAA;AAAM,GA9DI7B,EA+DH,WAAA,gBAAA,CAAA;AA/DGA,IAAN2B,EAAA;AAAA,EADNG,EAAc,eAAe;AAAA,GACjB9B,CAAA;"}
@@ -182,7 +182,7 @@ var m = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, a = (e, t, l
182
182
  };
183
183
  let r = class extends f {
184
184
  constructor() {
185
- super(...arguments), this.variant = "info", this.dismissible = !1, this.open = !0, this.showIcon = !0, this.accent = !1, this.returnFocusTo = null, this._hasActions = !1, this._hasTitle = !1, this._actionsSlotChangeHandler = null, this._titleSlotChangeHandler = null;
185
+ super(...arguments), this.variant = "info", this.dismissible = !1, this.open = !1, this.showIcon = !1, this.accent = !1, this.returnFocusTo = null, this._hasActions = !1, this._hasTitle = !1, this._actionsSlotChangeHandler = null, this._titleSlotChangeHandler = null;
186
186
  }
187
187
  // ─── Private Helpers ───
188
188
  /** Returns true when the variant requires assertive announcement. */
@@ -361,4 +361,4 @@ r = a([
361
361
  export {
362
362
  r as H
363
363
  };
364
- //# sourceMappingURL=hx-alert-BQpT4gL3.js.map
364
+ //# sourceMappingURL=hx-alert-Cg-zxRiU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-alert-Cg-zxRiU.js","sources":["../../src/components/hx-alert/hx-alert.styles.ts","../../src/components/hx-alert/hx-alert.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixAlertStyles = css`\n :host {\n display: block;\n }\n\n :host(:not([open])) {\n display: none;\n }\n\n * {\n box-sizing: border-box;\n }\n\n /* ─── Alert Container ─── */\n\n .alert {\n display: flex;\n align-items: flex-start;\n gap: var(--hx-alert-gap, var(--hx-space-3, 0.75rem));\n padding: var(--hx-alert-padding, var(--hx-space-4, 1rem));\n border: var(--hx-alert-border-width, var(--hx-border-width-thin, 1px)) solid\n var(--hx-alert-border-color, var(--hx-color-info-200, #b3d9ef));\n border-radius: var(--hx-alert-border-radius, var(--hx-border-radius-md, 0.375rem));\n background-color: var(--hx-alert-bg, var(--hx-color-info-50, #e8f4fd));\n color: var(--hx-alert-color, var(--hx-color-info-800, #1a3a4a));\n font-family: var(--hx-alert-font-family, var(--hx-font-family-sans, sans-serif));\n font-size: var(--hx-font-size-sm, 0.875rem);\n line-height: var(--hx-line-height-normal, 1.5);\n }\n\n /* ─── Accent Variant (left border stripe) ─── */\n /* Removes full border and replaces with a left-side accent stripe. */\n /* Common healthcare/enterprise dashboard pattern for dense information UIs. */\n\n .alert--accent {\n border-width: 0;\n border-left: var(--hx-alert-accent-width, 4px) solid\n var(--hx-alert-border-color, var(--hx-color-info-200, #b3d9ef));\n border-radius: 0;\n }\n\n /* ─── Icon ─── */\n\n .alert__icon {\n display: flex;\n align-items: center;\n flex-shrink: 0;\n color: var(--hx-alert-icon-color, var(--hx-color-info-500, #3b82f6));\n }\n\n .alert__icon svg {\n width: var(--hx-space-5, 1.25rem);\n height: var(--hx-space-5, 1.25rem);\n fill: currentColor;\n }\n\n /* ─── Title ─── */\n\n .alert__title {\n display: none;\n font-weight: var(--hx-font-weight-semibold, 600);\n margin-bottom: var(--hx-space-1, 0.25rem);\n }\n\n .alert__title--visible {\n display: block;\n }\n\n /* ─── Message ─── */\n\n .alert__message {\n flex: 1;\n min-width: 0;\n }\n\n /* ─── Actions ─── */\n /* Hidden by default; shown via JS slotchange detection to avoid invisible */\n /* margin-top spacing when no actions are slotted. */\n\n .alert__actions {\n display: none;\n align-items: center;\n gap: var(--hx-space-2, 0.5rem);\n margin-top: var(--hx-space-2, 0.5rem);\n }\n\n .alert__actions--visible {\n display: flex;\n }\n\n /* ─── Close Button ─── */\n /* Minimum 44px touch target per WCAG 2.5.8 (Target Size Minimum, AA) and */\n /* Apple HIG / Google Material guidelines. Uses absolute px units to ensure */\n /* the target size is independent of the consumer's base font size. */\n\n .alert__close-button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n min-width: var(--hx-touch-target-size, 44px);\n min-height: var(--hx-touch-target-size, 44px);\n margin-left: auto;\n padding: 0;\n border: none;\n border-radius: var(--hx-border-radius-sm, 0.25rem);\n background: transparent;\n color: var(--hx-alert-color, var(--hx-color-info-800, #1a3a4a));\n cursor: pointer;\n font-size: var(--hx-font-size-md, 1rem);\n line-height: 1;\n transition:\n background-color var(--hx-transition-fast, 150ms ease),\n opacity var(--hx-transition-fast, 150ms ease);\n opacity: 0.7;\n }\n\n .alert__close-button:hover {\n opacity: 1;\n /* color-mix() is supported in Chrome 111+, Firefox 113+, Safari 16.2+. */\n /* Falls back to transparent (no hover background) in older environments. */\n background-color: color-mix(in srgb, currentColor 10%, transparent);\n }\n\n .alert__close-button:focus-visible {\n outline: var(--hx-focus-ring-width, 2px) solid var(--hx-focus-ring-color, #2563eb);\n outline-offset: var(--hx-focus-ring-offset, 2px);\n opacity: 1;\n }\n\n .alert__close-button svg {\n width: var(--hx-space-4, 1rem);\n height: var(--hx-space-4, 1rem);\n fill: currentColor;\n }\n\n /* ─── Variant: info ─── */\n\n :host([variant='info']) .alert,\n :host(:not([variant])) .alert {\n --hx-alert-bg: var(--hx-color-info-50, #e8f4fd);\n --hx-alert-border-color: var(--hx-color-info-200, #b3d9ef);\n --hx-alert-color: var(--hx-color-info-800, #1a3a4a);\n --hx-alert-icon-color: var(--hx-color-info-500, #3b82f6);\n }\n\n /* ─── Variant: success ─── */\n\n :host([variant='success']) .alert {\n --hx-alert-bg: var(--hx-color-success-50, #ecfdf5);\n --hx-alert-border-color: var(--hx-color-success-200, #a7f3d0);\n --hx-alert-color: var(--hx-color-success-800, #065f46);\n --hx-alert-icon-color: var(--hx-color-success-500, #10b981);\n }\n\n /* ─── Variant: warning ─── */\n\n :host([variant='warning']) .alert {\n --hx-alert-bg: var(--hx-color-warning-50, #fffbeb);\n --hx-alert-border-color: var(--hx-color-warning-200, #fde68a);\n --hx-alert-color: var(--hx-color-warning-800, #92400e);\n --hx-alert-icon-color: var(--hx-color-warning-500, #f59e0b);\n }\n\n /* ─── Variant: error ─── */\n\n :host([variant='error']) .alert {\n --hx-alert-bg: var(--hx-color-error-50, #fef2f2);\n --hx-alert-border-color: var(--hx-color-error-200, #fecaca);\n --hx-alert-color: var(--hx-color-error-800, #991b1b);\n --hx-alert-icon-color: var(--hx-color-error-500, #ef4444);\n }\n`;\n","import { LitElement, html, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { tokenStyles } from '@helixui/tokens/lit';\nimport { helixAlertStyles } from './hx-alert.styles.js';\n\n/** Alert variant determines visual styling and ARIA semantics. */\nexport type AlertVariant = 'info' | 'success' | 'warning' | 'error';\n\n/**\n * A feedback component for communicating status messages, warnings, and errors.\n * Critical for healthcare patient safety alerts.\n *\n * @summary Feedback alert for status messages with variant-based styling and ARIA live regions.\n *\n * @tag hx-alert\n *\n * @slot - Default slot for alert message content.\n * @slot title - Optional title/headline for the alert.\n * @slot icon - Custom icon to override the default variant icon.\n * @slot actions - Action buttons rendered within the alert.\n *\n * @fires {CustomEvent<{reason: string}>} hx-close - Dispatched when the user dismisses the alert.\n * @fires {CustomEvent} hx-after-close - Dispatched after the alert is dismissed.\n *\n * @csspart alert - The outer alert container.\n * @csspart title - The title/headline container.\n * @csspart icon - The icon container.\n * @csspart message - The message content area.\n * @csspart close-button - The dismiss button (only rendered when dismissible).\n * @csspart actions - The actions container.\n *\n * @cssprop [--hx-alert-bg=var(--hx-color-info-50)] - Alert background color.\n * @cssprop [--hx-alert-color=var(--hx-color-info-800)] - Alert text color.\n * @cssprop [--hx-alert-border-color=var(--hx-color-info-200)] - Alert border color.\n * @cssprop [--hx-alert-border-radius=var(--hx-border-radius-md)] - Alert border radius.\n * @cssprop [--hx-alert-border-width=var(--hx-border-width-thin)] - Alert border width.\n * @cssprop [--hx-alert-padding=var(--hx-space-4)] - Alert padding.\n * @cssprop [--hx-alert-gap=var(--hx-space-3)] - Gap between alert elements.\n * @cssprop [--hx-alert-icon-color=var(--hx-color-info-500)] - Alert icon color.\n * @cssprop [--hx-alert-font-family=var(--hx-font-family-sans)] - Alert font family.\n * @cssprop [--hx-touch-target-size=44px] - Minimum touch target size for the close button.\n * @cssprop [--hx-alert-accent-width=4px] - Width of the left border accent stripe.\n */\n@customElement('hx-alert')\nexport class HelixAlert extends LitElement {\n static override styles = [tokenStyles, helixAlertStyles];\n\n // ─── Properties ───\n\n /**\n * Visual variant of the alert that determines colors and ARIA semantics.\n * @attr variant\n */\n @property({ type: String, reflect: true })\n variant: AlertVariant = 'info';\n\n /**\n * Whether the alert can be dismissed by the user.\n * @attr dismissible\n */\n @property({ type: Boolean, reflect: true })\n dismissible = false;\n\n /**\n * Whether the alert is visible. Add the `open` attribute to show the alert.\n * @attr open\n */\n @property({ type: Boolean, reflect: true })\n open = false;\n\n /**\n * Whether to show the default variant icon. Add `show-icon` attribute to display the icon.\n * @attr show-icon\n */\n @property({ type: Boolean, reflect: true, attribute: 'show-icon' })\n showIcon = false;\n\n /**\n * When true, applies a left border accent stripe instead of a full border.\n * Common healthcare/enterprise dashboard pattern for visual distinction of alert types.\n * @attr accent\n */\n @property({ type: Boolean, reflect: true })\n accent = false;\n\n /**\n * CSS selector for the element to return focus to after the alert is dismissed.\n * When set, the component will find and focus the matching element after dismissal.\n * If not set, focus management is the caller's responsibility via the hx-after-close event.\n * @attr return-focus-to\n */\n @property({ type: String, attribute: 'return-focus-to' })\n returnFocusTo: string | null = null;\n\n // ─── State ───\n\n @state()\n private _hasActions = false;\n\n @state()\n private _hasTitle = false;\n\n // ─── Private Handler References ───\n\n private _actionsSlotChangeHandler: (() => void) | null = null;\n private _titleSlotChangeHandler: (() => void) | null = null;\n\n // ─── Private Helpers ───\n\n /** Returns true when the variant requires assertive announcement. */\n private get _isAssertive(): boolean {\n return this.variant === 'error' || this.variant === 'warning';\n }\n\n /**\n * Returns the appropriate ARIA role based on variant.\n * role=\"alert\" implies aria-live=\"assertive\"; role=\"status\" implies aria-live=\"polite\".\n * We do NOT set aria-live explicitly to avoid double-announcements in JAWS.\n */\n private get _role(): string {\n return this._isAssertive ? 'alert' : 'status';\n }\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Apply ARIA role to the host element for reliable screen reader support across\n // Shadow DOM boundaries. Placing role on a shadow-internal element has inconsistent\n // AT support in JAWS+Chrome and VoiceOver+Safari combinations (particularly pre-2024).\n this.setAttribute('role', this._role);\n if (!this.open) {\n this.setAttribute('aria-hidden', 'true');\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n const actionsSlot = this.renderRoot.querySelector<HTMLSlotElement>('slot[name=\"actions\"]');\n if (actionsSlot && this._actionsSlotChangeHandler) {\n actionsSlot.removeEventListener('slotchange', this._actionsSlotChangeHandler);\n }\n const titleSlot = this.renderRoot.querySelector<HTMLSlotElement>('slot[name=\"title\"]');\n if (titleSlot && this._titleSlotChangeHandler) {\n titleSlot.removeEventListener('slotchange', this._titleSlotChangeHandler);\n }\n }\n\n override firstUpdated(): void {\n // Track actions slot content to avoid invisible spacing when no actions are slotted.\n const actionsSlot = this.renderRoot.querySelector<HTMLSlotElement>('slot[name=\"actions\"]');\n if (actionsSlot) {\n this._actionsSlotChangeHandler = () => {\n this._hasActions = actionsSlot.assignedNodes({ flatten: true }).length > 0;\n };\n actionsSlot.addEventListener('slotchange', this._actionsSlotChangeHandler);\n }\n\n // Track title slot content so the title container doesn't create dead space when empty.\n const titleSlot = this.renderRoot.querySelector<HTMLSlotElement>('slot[name=\"title\"]');\n if (titleSlot) {\n this._titleSlotChangeHandler = () => {\n this._hasTitle = titleSlot.assignedNodes({ flatten: true }).length > 0;\n };\n titleSlot.addEventListener('slotchange', this._titleSlotChangeHandler);\n }\n }\n\n protected override updated(changedProperties: Map<PropertyKey, unknown>): void {\n super.updated(changedProperties);\n if (changedProperties.has('variant')) {\n // Keep host ARIA role in sync with variant (assertive vs. polite).\n this.setAttribute('role', this._role);\n }\n if (changedProperties.has('open')) {\n // Manage aria-hidden in addition to display:none for reliable AT exclusion.\n // When open transitions from false→true, removing aria-hidden signals to AT\n // that the live region content should be announced.\n if (this.open) {\n this.removeAttribute('aria-hidden');\n } else {\n this.setAttribute('aria-hidden', 'true');\n }\n }\n }\n\n // ─── Default Icons ───\n\n private _renderInfoIcon() {\n return html`<svg viewBox=\"0 0 20 20\" aria-hidden=\"true\">\n <path\n d=\"M10 2a8 8 0 100 16 8 8 0 000-16zm.75 4.75a.75.75 0 11-1.5 0 .75.75 0 011.5 0zM9.25 9a.75.75 0 011.5 0v4a.75.75 0 01-1.5 0V9z\"\n />\n </svg>`;\n }\n\n private _renderSuccessIcon() {\n return html`<svg viewBox=\"0 0 20 20\" aria-hidden=\"true\">\n <path\n d=\"M10 2a8 8 0 100 16 8 8 0 000-16zm3.03 6.28a.75.75 0 00-1.06-1.06L9 10.19 7.78 8.97a.75.75 0 00-1.06 1.06l1.75 1.75a.75.75 0 001.06 0l3.5-3.5z\"\n />\n </svg>`;\n }\n\n private _renderWarningIcon() {\n return html`<svg viewBox=\"0 0 20 20\" aria-hidden=\"true\">\n <path\n d=\"M8.49 2.92a1.75 1.75 0 013.02 0l6.25 10.83A1.75 1.75 0 0116.25 16H3.75a1.75 1.75 0 01-1.51-2.25L8.49 2.92zM10 7a.75.75 0 01.75.75v3a.75.75 0 01-1.5 0v-3A.75.75 0 0110 7zm0 7.5a.75.75 0 100-1.5.75.75 0 000 1.5z\"\n />\n </svg>`;\n }\n\n private _renderErrorIcon() {\n return html`<svg viewBox=\"0 0 20 20\" aria-hidden=\"true\">\n <path\n d=\"M10 2a8 8 0 100 16 8 8 0 000-16zm-1.72 5.22a.75.75 0 011.06 0L10 7.94l.66-.72a.75.75 0 111.06 1.06L11.06 9l.66.72a.75.75 0 11-1.06 1.06L10 10.06l-.66.72a.75.75 0 01-1.06-1.06L8.94 9l-.66-.72a.75.75 0 010-1.06z\"\n />\n </svg>`;\n }\n\n private _renderDefaultIcon() {\n switch (this.variant) {\n case 'success':\n return this._renderSuccessIcon();\n case 'warning':\n return this._renderWarningIcon();\n case 'error':\n return this._renderErrorIcon();\n case 'info':\n default:\n return this._renderInfoIcon();\n }\n }\n\n private _renderCloseIcon() {\n return html`<svg viewBox=\"0 0 20 20\" aria-hidden=\"true\">\n <path\n d=\"M6.28 5.22a.75.75 0 00-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 101.06 1.06L10 11.06l3.72 3.72a.75.75 0 101.06-1.06L11.06 10l3.72-3.72a.75.75 0 00-1.06-1.06L10 8.94 6.28 5.22z\"\n />\n </svg>`;\n }\n\n // ─── Event Handling ───\n\n private _handleDismiss(): void {\n this.open = false;\n\n /**\n * Dispatched when the user dismisses the alert.\n * @event hx-close\n */\n this.dispatchEvent(\n new CustomEvent('hx-close', {\n bubbles: true,\n composed: true,\n detail: { reason: 'user' },\n }),\n );\n\n /**\n * Dispatched after the alert is dismissed.\n * @event hx-after-close\n */\n this.dispatchEvent(\n new CustomEvent('hx-after-close', {\n bubbles: true,\n composed: true,\n }),\n );\n\n // Return focus to a designated element if specified via returnFocusTo.\n if (this.returnFocusTo) {\n const target = document.querySelector(this.returnFocusTo);\n if (target instanceof HTMLElement) {\n target.focus();\n }\n }\n }\n\n // ─── Render ───\n\n override render() {\n const classes = {\n alert: true,\n [`alert--${this.variant}`]: true,\n 'alert--accent': this.accent,\n };\n\n return html`\n <div part=\"alert\" class=${classMap(classes)}>\n ${this.showIcon\n ? html`\n <div part=\"icon\" class=\"alert__icon\">\n <slot name=\"icon\">${this._renderDefaultIcon()}</slot>\n </div>\n `\n : nothing}\n\n <div part=\"message\" class=\"alert__message\">\n <div part=\"title\" class=\"alert__title ${this._hasTitle ? 'alert__title--visible' : ''}\">\n <slot name=\"title\"></slot>\n </div>\n <slot></slot>\n <div\n part=\"actions\"\n class=\"alert__actions ${this._hasActions ? 'alert__actions--visible' : ''}\"\n >\n <slot name=\"actions\"></slot>\n </div>\n </div>\n\n ${this.dismissible\n ? html`\n <button\n part=\"close-button\"\n class=\"alert__close-button\"\n aria-label=\"Close\"\n @click=${this._handleDismiss}\n >\n ${this._renderCloseIcon()}\n </button>\n `\n : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-alert': HelixAlert;\n }\n}\n\nexport type { HelixAlert as HxAlert };\n"],"names":["helixAlertStyles","css","HelixAlert","LitElement","actionsSlot","titleSlot","changedProperties","html","target","classes","classMap","nothing","tokenStyles","__decorateClass","property","state","customElement"],"mappings":"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"}