@helixui/library 1.1.2 → 2.0.0-next.31

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 (691) hide show
  1. package/custom-elements.json +3221 -2224
  2. package/dist/base/helix-element.d.ts +134 -0
  3. package/dist/base/helix-element.d.ts.map +1 -0
  4. package/dist/base/id-counter.d.ts +32 -0
  5. package/dist/base/id-counter.d.ts.map +1 -0
  6. package/dist/base/index.d.ts +4 -0
  7. package/dist/base/index.d.ts.map +1 -0
  8. package/dist/base/styles.d.ts +29 -0
  9. package/dist/base/styles.d.ts.map +1 -0
  10. package/dist/components/hx-accordion/hx-accordion-item.d.ts +3 -0
  11. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  12. package/dist/components/hx-accordion/hx-accordion.d.ts +4 -1
  13. package/dist/components/hx-accordion/hx-accordion.d.ts.map +1 -1
  14. package/dist/components/hx-accordion/index.js +1 -1
  15. package/dist/components/hx-action-bar/hx-action-bar.d.ts +1 -1
  16. package/dist/components/hx-action-bar/hx-action-bar.d.ts.map +1 -1
  17. package/dist/components/hx-action-bar/index.js +1 -1
  18. package/dist/components/hx-alert/hx-alert.d.ts +10 -5
  19. package/dist/components/hx-alert/hx-alert.d.ts.map +1 -1
  20. package/dist/components/hx-alert/hx-alert.styles.d.ts.map +1 -1
  21. package/dist/components/hx-alert/index.js +1 -1
  22. package/dist/components/hx-avatar/hx-avatar.d.ts.map +1 -1
  23. package/dist/components/hx-avatar/hx-avatar.styles.d.ts.map +1 -1
  24. package/dist/components/hx-avatar/index.js +1 -1
  25. package/dist/components/hx-badge/hx-badge.d.ts.map +1 -1
  26. package/dist/components/hx-badge/hx-badge.styles.d.ts.map +1 -1
  27. package/dist/components/hx-badge/index.js +1 -1
  28. package/dist/components/hx-banner/hx-banner.d.ts +15 -5
  29. package/dist/components/hx-banner/hx-banner.d.ts.map +1 -1
  30. package/dist/components/hx-banner/hx-banner.styles.d.ts.map +1 -1
  31. package/dist/components/hx-banner/index.js +1 -1
  32. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts +1 -0
  33. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts.map +1 -1
  34. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +42 -11
  35. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  36. package/dist/components/hx-breadcrumb/index.js +1 -1
  37. package/dist/components/hx-button/hx-button.d.ts +22 -13
  38. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  39. package/dist/components/hx-button/hx-button.styles.d.ts.map +1 -1
  40. package/dist/components/hx-button/index.js +1 -1
  41. package/dist/components/hx-button-group/hx-button-group.d.ts +3 -6
  42. package/dist/components/hx-button-group/hx-button-group.d.ts.map +1 -1
  43. package/dist/components/hx-button-group/index.js +1 -1
  44. package/dist/components/hx-card/hx-card.d.ts +7 -7
  45. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  46. package/dist/components/hx-card/index.js +1 -1
  47. package/dist/components/hx-carousel/hx-carousel-item.d.ts.map +1 -1
  48. package/dist/components/hx-carousel/hx-carousel.d.ts +2 -2
  49. package/dist/components/hx-carousel/hx-carousel.d.ts.map +1 -1
  50. package/dist/components/hx-carousel/index.js +1 -1
  51. package/dist/components/hx-checkbox/hx-checkbox.d.ts +18 -18
  52. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  53. package/dist/components/hx-checkbox/hx-checkbox.styles.d.ts.map +1 -1
  54. package/dist/components/hx-checkbox/index.js +1 -1
  55. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +8 -3
  56. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  57. package/dist/components/hx-checkbox-group/index.js +1 -1
  58. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts +134 -0
  59. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts.map +1 -0
  60. package/dist/components/hx-clinical-status/hx-clinical-status.styles.d.ts +2 -0
  61. package/dist/components/hx-clinical-status/hx-clinical-status.styles.d.ts.map +1 -0
  62. package/dist/components/hx-clinical-status/index.d.ts +3 -0
  63. package/dist/components/hx-clinical-status/index.d.ts.map +1 -0
  64. package/dist/components/hx-clinical-status/index.js +5 -0
  65. package/dist/components/hx-clinical-status/index.js.map +1 -0
  66. package/dist/components/hx-code-snippet/hx-code-snippet.d.ts.map +1 -1
  67. package/dist/components/hx-code-snippet/hx-code-snippet.styles.d.ts.map +1 -1
  68. package/dist/components/hx-code-snippet/index.js +1 -1
  69. package/dist/components/hx-color-picker/color-utils.d.ts +27 -0
  70. package/dist/components/hx-color-picker/color-utils.d.ts.map +1 -0
  71. package/dist/components/hx-color-picker/hx-color-picker.d.ts +16 -4
  72. package/dist/components/hx-color-picker/hx-color-picker.d.ts.map +1 -1
  73. package/dist/components/hx-color-picker/index.js +1 -1
  74. package/dist/components/hx-combobox/hx-combobox.d.ts +9 -4
  75. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  76. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  77. package/dist/components/hx-combobox/index.js +1 -1
  78. package/dist/components/hx-container/hx-container.d.ts.map +1 -1
  79. package/dist/components/hx-container/index.js +1 -1
  80. package/dist/components/hx-copy-button/hx-copy-button.d.ts +6 -1
  81. package/dist/components/hx-copy-button/hx-copy-button.d.ts.map +1 -1
  82. package/dist/components/hx-copy-button/index.js +1 -1
  83. package/dist/components/hx-counter/hx-counter.d.ts +20 -3
  84. package/dist/components/hx-counter/hx-counter.d.ts.map +1 -1
  85. package/dist/components/hx-counter/hx-counter.styles.d.ts.map +1 -1
  86. package/dist/components/hx-counter/index.js +1 -1
  87. package/dist/components/hx-data-table/hx-data-table.d.ts +8 -0
  88. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  89. package/dist/components/hx-data-table/hx-data-table.styles.d.ts.map +1 -1
  90. package/dist/components/hx-data-table/index.js +1 -1
  91. package/dist/components/hx-date-picker/hx-date-picker.d.ts +40 -3
  92. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  93. package/dist/components/hx-date-picker/hx-date-picker.styles.d.ts.map +1 -1
  94. package/dist/components/hx-date-picker/index.js +1 -1
  95. package/dist/components/hx-dialog/hx-dialog.d.ts +4 -1
  96. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  97. package/dist/components/hx-dialog/index.js +1 -1
  98. package/dist/components/hx-divider/hx-divider.d.ts.map +1 -1
  99. package/dist/components/hx-divider/index.js +1 -1
  100. package/dist/components/hx-drawer/hx-drawer.d.ts +5 -8
  101. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  102. package/dist/components/hx-drawer/hx-drawer.styles.d.ts.map +1 -1
  103. package/dist/components/hx-drawer/index.js +1 -1
  104. package/dist/components/hx-dropdown/hx-dropdown.d.ts +14 -1
  105. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  106. package/dist/components/hx-dropdown/index.js +1 -1
  107. package/dist/components/hx-field/hx-field.d.ts +1 -1
  108. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  109. package/dist/components/hx-field/index.js +1 -1
  110. package/dist/components/hx-field-label/hx-field-label.d.ts.map +1 -1
  111. package/dist/components/hx-field-label/hx-field-label.styles.d.ts.map +1 -1
  112. package/dist/components/hx-field-label/index.js +1 -1
  113. package/dist/components/hx-file-upload/hx-file-upload.d.ts +8 -9
  114. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  115. package/dist/components/hx-file-upload/index.js +1 -1
  116. package/dist/components/hx-form/hx-form.d.ts.map +1 -1
  117. package/dist/components/hx-form/index.js +1 -1
  118. package/dist/components/hx-format-date/hx-format-date.d.ts.map +1 -1
  119. package/dist/components/hx-format-date/index.js +1 -1
  120. package/dist/components/hx-grid/hx-grid.d.ts +5 -9
  121. package/dist/components/hx-grid/hx-grid.d.ts.map +1 -1
  122. package/dist/components/hx-grid/index.js +1 -1
  123. package/dist/components/hx-help-text/hx-help-text.d.ts.map +1 -1
  124. package/dist/components/hx-help-text/index.js +1 -1
  125. package/dist/components/hx-icon/hx-icon.d.ts.map +1 -1
  126. package/dist/components/hx-icon/index.js +1 -1
  127. package/dist/components/hx-icon-button/hx-icon-button.d.ts +4 -3
  128. package/dist/components/hx-icon-button/hx-icon-button.d.ts.map +1 -1
  129. package/dist/components/hx-icon-button/index.js +1 -1
  130. package/dist/components/hx-image/hx-image.d.ts.map +1 -1
  131. package/dist/components/hx-image/index.js +1 -1
  132. package/dist/components/hx-link/hx-link.d.ts +1 -1
  133. package/dist/components/hx-link/hx-link.d.ts.map +1 -1
  134. package/dist/components/hx-link/hx-link.styles.d.ts.map +1 -1
  135. package/dist/components/hx-link/index.js +1 -1
  136. package/dist/components/hx-list/hx-list-item.d.ts.map +1 -1
  137. package/dist/components/hx-list/hx-list.d.ts.map +1 -1
  138. package/dist/components/hx-list/index.js +1 -1
  139. package/dist/components/hx-menu/hx-menu-divider.d.ts.map +1 -1
  140. package/dist/components/hx-menu/hx-menu-item.d.ts +5 -0
  141. package/dist/components/hx-menu/hx-menu-item.d.ts.map +1 -1
  142. package/dist/components/hx-menu/hx-menu.d.ts +1 -0
  143. package/dist/components/hx-menu/hx-menu.d.ts.map +1 -1
  144. package/dist/components/hx-menu/hx-menu.styles.d.ts.map +1 -1
  145. package/dist/components/hx-menu/index.js +1 -1
  146. package/dist/components/hx-meter/hx-meter.d.ts +2 -2
  147. package/dist/components/hx-meter/hx-meter.d.ts.map +1 -1
  148. package/dist/components/hx-meter/index.js +1 -1
  149. package/dist/components/hx-nav/hx-nav.d.ts +10 -0
  150. package/dist/components/hx-nav/hx-nav.d.ts.map +1 -1
  151. package/dist/components/hx-nav/index.js +1 -1
  152. package/dist/components/hx-number-input/hx-number-input.d.ts +4 -3
  153. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  154. package/dist/components/hx-number-input/index.js +1 -1
  155. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts +3 -3
  156. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts.map +1 -1
  157. package/dist/components/hx-overflow-menu/hx-overflow-menu.styles.d.ts.map +1 -1
  158. package/dist/components/hx-overflow-menu/index.js +1 -1
  159. package/dist/components/hx-pagination/hx-pagination.d.ts +8 -0
  160. package/dist/components/hx-pagination/hx-pagination.d.ts.map +1 -1
  161. package/dist/components/hx-pagination/hx-pagination.styles.d.ts.map +1 -1
  162. package/dist/components/hx-pagination/index.js +1 -1
  163. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts +113 -0
  164. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts.map +1 -0
  165. package/dist/components/hx-patient-banner/hx-patient-banner.styles.d.ts +2 -0
  166. package/dist/components/hx-patient-banner/hx-patient-banner.styles.d.ts.map +1 -0
  167. package/dist/components/hx-patient-banner/index.d.ts +3 -0
  168. package/dist/components/hx-patient-banner/index.d.ts.map +1 -0
  169. package/dist/components/hx-patient-banner/index.js +5 -0
  170. package/dist/components/hx-patient-banner/index.js.map +1 -0
  171. package/dist/components/hx-phi-field/hx-phi-field.d.ts +97 -0
  172. package/dist/components/hx-phi-field/hx-phi-field.d.ts.map +1 -0
  173. package/dist/components/hx-phi-field/hx-phi-field.styles.d.ts +2 -0
  174. package/dist/components/hx-phi-field/hx-phi-field.styles.d.ts.map +1 -0
  175. package/dist/components/hx-phi-field/index.d.ts +3 -0
  176. package/dist/components/hx-phi-field/index.d.ts.map +1 -0
  177. package/dist/components/hx-phi-field/index.js +5 -0
  178. package/dist/components/hx-phi-field/index.js.map +1 -0
  179. package/dist/components/hx-popover/hx-popover.d.ts +25 -9
  180. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  181. package/dist/components/hx-popover/index.js +1 -1
  182. package/dist/components/hx-popup/hx-popup.d.ts +5 -8
  183. package/dist/components/hx-popup/hx-popup.d.ts.map +1 -1
  184. package/dist/components/hx-popup/index.js +1 -1
  185. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +2 -0
  186. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  187. package/dist/components/hx-progress-bar/hx-progress-bar.styles.d.ts.map +1 -1
  188. package/dist/components/hx-progress-bar/index.js +1 -1
  189. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts.map +1 -1
  190. package/dist/components/hx-progress-ring/index.js +1 -1
  191. package/dist/components/hx-prose/hx-prose.d.ts +1 -0
  192. package/dist/components/hx-prose/hx-prose.d.ts.map +1 -1
  193. package/dist/components/hx-radio-group/hx-radio-group.d.ts +3 -7
  194. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  195. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  196. package/dist/components/hx-radio-group/hx-radio.styles.d.ts.map +1 -1
  197. package/dist/components/hx-radio-group/index.js +1 -1
  198. package/dist/components/hx-rating/hx-rating.d.ts +3 -3
  199. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  200. package/dist/components/hx-rating/hx-rating.styles.d.ts.map +1 -1
  201. package/dist/components/hx-rating/index.js +1 -1
  202. package/dist/components/hx-select/hx-select.d.ts +17 -11
  203. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  204. package/dist/components/hx-select/hx-select.styles.d.ts.map +1 -1
  205. package/dist/components/hx-select/index.js +1 -1
  206. package/dist/components/hx-side-nav/hx-nav-item.d.ts +12 -0
  207. package/dist/components/hx-side-nav/hx-nav-item.d.ts.map +1 -1
  208. package/dist/components/hx-side-nav/hx-nav-item.styles.d.ts.map +1 -1
  209. package/dist/components/hx-side-nav/hx-side-nav.d.ts.map +1 -1
  210. package/dist/components/hx-side-nav/hx-side-nav.styles.d.ts.map +1 -1
  211. package/dist/components/hx-side-nav/index.js +1 -1
  212. package/dist/components/hx-skeleton/hx-skeleton.d.ts +2 -2
  213. package/dist/components/hx-skeleton/hx-skeleton.d.ts.map +1 -1
  214. package/dist/components/hx-skeleton/index.js +1 -1
  215. package/dist/components/hx-slider/hx-slider.d.ts +5 -8
  216. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  217. package/dist/components/hx-slider/hx-slider.styles.d.ts.map +1 -1
  218. package/dist/components/hx-slider/index.js +1 -1
  219. package/dist/components/hx-spinner/hx-spinner.d.ts +14 -1
  220. package/dist/components/hx-spinner/hx-spinner.d.ts.map +1 -1
  221. package/dist/components/hx-spinner/hx-spinner.styles.d.ts.map +1 -1
  222. package/dist/components/hx-spinner/index.js +1 -1
  223. package/dist/components/hx-split-button/hx-split-button.d.ts +10 -4
  224. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  225. package/dist/components/hx-split-button/hx-split-button.styles.d.ts.map +1 -1
  226. package/dist/components/hx-split-button/index.js +1 -1
  227. package/dist/components/hx-split-panel/hx-split-panel.d.ts.map +1 -1
  228. package/dist/components/hx-split-panel/hx-split-panel.styles.d.ts.map +1 -1
  229. package/dist/components/hx-split-panel/index.js +1 -1
  230. package/dist/components/hx-stack/hx-stack.d.ts.map +1 -1
  231. package/dist/components/hx-stack/index.js +1 -1
  232. package/dist/components/hx-stat/hx-stat.d.ts +7 -2
  233. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -1
  234. package/dist/components/hx-stat/index.js +1 -1
  235. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts +19 -3
  236. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts.map +1 -1
  237. package/dist/components/hx-status-indicator/hx-status-indicator.styles.d.ts.map +1 -1
  238. package/dist/components/hx-status-indicator/index.js +1 -1
  239. package/dist/components/hx-steps/hx-step.d.ts +7 -0
  240. package/dist/components/hx-steps/hx-step.d.ts.map +1 -1
  241. package/dist/components/hx-steps/hx-step.styles.d.ts.map +1 -1
  242. package/dist/components/hx-steps/hx-steps.d.ts.map +1 -1
  243. package/dist/components/hx-steps/index.js +1 -1
  244. package/dist/components/hx-structured-list/hx-structured-list.d.ts +10 -3
  245. package/dist/components/hx-structured-list/hx-structured-list.d.ts.map +1 -1
  246. package/dist/components/hx-structured-list/index.js +1 -1
  247. package/dist/components/hx-style-scope/hx-style-scope.d.ts +71 -0
  248. package/dist/components/hx-style-scope/hx-style-scope.d.ts.map +1 -0
  249. package/dist/components/hx-style-scope/hx-style-scope.styles.d.ts +10 -0
  250. package/dist/components/hx-style-scope/hx-style-scope.styles.d.ts.map +1 -0
  251. package/dist/components/hx-style-scope/index.d.ts +2 -0
  252. package/dist/components/hx-style-scope/index.d.ts.map +1 -0
  253. package/dist/components/hx-style-scope/index.js +5 -0
  254. package/dist/components/hx-style-scope/index.js.map +1 -0
  255. package/dist/components/hx-switch/hx-switch.d.ts +4 -4
  256. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  257. package/dist/components/hx-switch/hx-switch.styles.d.ts.map +1 -1
  258. package/dist/components/hx-switch/index.js +1 -1
  259. package/dist/components/hx-table/hx-table.d.ts +1 -0
  260. package/dist/components/hx-table/hx-table.d.ts.map +1 -1
  261. package/dist/components/hx-table/hx-tbody.d.ts.map +1 -1
  262. package/dist/components/hx-table/hx-td.d.ts.map +1 -1
  263. package/dist/components/hx-table/hx-tfoot.d.ts.map +1 -1
  264. package/dist/components/hx-table/hx-th.d.ts.map +1 -1
  265. package/dist/components/hx-table/hx-thead.d.ts.map +1 -1
  266. package/dist/components/hx-table/hx-tr.d.ts.map +1 -1
  267. package/dist/components/hx-table/index.js +1 -1
  268. package/dist/components/hx-tabs/hx-tab-panel.d.ts.map +1 -1
  269. package/dist/components/hx-tabs/hx-tab-panel.styles.d.ts.map +1 -1
  270. package/dist/components/hx-tabs/hx-tab.d.ts +1 -0
  271. package/dist/components/hx-tabs/hx-tab.d.ts.map +1 -1
  272. package/dist/components/hx-tabs/hx-tab.styles.d.ts.map +1 -1
  273. package/dist/components/hx-tabs/hx-tabs.d.ts +12 -2
  274. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  275. package/dist/components/hx-tabs/index.js +1 -1
  276. package/dist/components/hx-tag/hx-tag.d.ts.map +1 -1
  277. package/dist/components/hx-tag/hx-tag.styles.d.ts.map +1 -1
  278. package/dist/components/hx-tag/index.js +1 -1
  279. package/dist/components/hx-text/hx-text.d.ts.map +1 -1
  280. package/dist/components/hx-text/index.js +1 -1
  281. package/dist/components/hx-text-input/hx-text-input.d.ts +16 -15
  282. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  283. package/dist/components/hx-text-input/hx-text-input.styles.d.ts.map +1 -1
  284. package/dist/components/hx-text-input/index.js +1 -1
  285. package/dist/components/hx-textarea/hx-textarea.d.ts +4 -4
  286. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  287. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  288. package/dist/components/hx-textarea/index.js +1 -1
  289. package/dist/components/hx-theme/hx-theme.d.ts +82 -3
  290. package/dist/components/hx-theme/hx-theme.d.ts.map +1 -1
  291. package/dist/components/hx-theme/index.js +1 -1
  292. package/dist/components/hx-time-picker/hx-time-picker.d.ts +6 -1
  293. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  294. package/dist/components/hx-time-picker/index.js +1 -1
  295. package/dist/components/hx-toast/hx-toast-stack.d.ts +1 -1
  296. package/dist/components/hx-toast/hx-toast-stack.d.ts.map +1 -1
  297. package/dist/components/hx-toast/hx-toast.d.ts +9 -5
  298. package/dist/components/hx-toast/hx-toast.d.ts.map +1 -1
  299. package/dist/components/hx-toast/hx-toast.styles.d.ts.map +1 -1
  300. package/dist/components/hx-toast/index.js +1 -1
  301. package/dist/components/hx-toast/toast-factory.d.ts.map +1 -1
  302. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +4 -3
  303. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  304. package/dist/components/hx-toggle-button/hx-toggle-button.styles.d.ts.map +1 -1
  305. package/dist/components/hx-toggle-button/index.js +1 -1
  306. package/dist/components/hx-tooltip/hx-tooltip.d.ts +1 -2
  307. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  308. package/dist/components/hx-tooltip/index.js +1 -1
  309. package/dist/components/hx-top-nav/hx-top-nav.d.ts.map +1 -1
  310. package/dist/components/hx-top-nav/index.js +1 -1
  311. package/dist/components/hx-tree-view/hx-tree-item.d.ts +12 -0
  312. package/dist/components/hx-tree-view/hx-tree-item.d.ts.map +1 -1
  313. package/dist/components/hx-tree-view/hx-tree-view.d.ts +27 -2
  314. package/dist/components/hx-tree-view/hx-tree-view.d.ts.map +1 -1
  315. package/dist/components/hx-tree-view/hx-tree-view.styles.d.ts.map +1 -1
  316. package/dist/components/hx-tree-view/index.js +1 -1
  317. package/dist/components/hx-visually-hidden/hx-visually-hidden.d.ts.map +1 -1
  318. package/dist/components/hx-visually-hidden/index.js +1 -1
  319. package/dist/controllers/helix-audit-controller.d.ts +71 -0
  320. package/dist/controllers/helix-audit-controller.d.ts.map +1 -0
  321. package/dist/css/helix-all.css +9743 -0
  322. package/dist/css/helix-core.css +1839 -0
  323. package/dist/css/helix-data.css +639 -0
  324. package/dist/css/helix-feedback.css +1268 -0
  325. package/dist/css/helix-forms.css +2525 -0
  326. package/dist/css/helix-layout.css +380 -0
  327. package/dist/css/helix-media.css +213 -0
  328. package/dist/css/helix-navigation.css +1131 -0
  329. package/dist/css/helix-overlay.css +643 -0
  330. package/dist/css/helix-tokens.css +432 -0
  331. package/dist/css/helix-utility.css +633 -0
  332. package/dist/css/hx-accordion.css +10 -0
  333. package/dist/css/hx-action-bar.css +117 -0
  334. package/dist/css/hx-alert.css +213 -0
  335. package/dist/css/hx-avatar.css +134 -0
  336. package/dist/css/hx-badge.css +178 -0
  337. package/dist/css/hx-banner.css +203 -0
  338. package/dist/css/hx-breadcrumb.css +36 -0
  339. package/dist/css/hx-button-group.css +91 -0
  340. package/dist/css/hx-button.css +296 -0
  341. package/dist/css/hx-card.css +161 -0
  342. package/dist/css/hx-carousel.css +211 -0
  343. package/dist/css/hx-checkbox-group.css +77 -0
  344. package/dist/css/hx-checkbox.css +219 -0
  345. package/dist/css/hx-clinical-status.css +248 -0
  346. package/dist/css/hx-code-snippet.css +179 -0
  347. package/dist/css/hx-color-picker.css +2 -0
  348. package/dist/css/hx-combobox.css +2 -0
  349. package/dist/css/hx-container.css +82 -0
  350. package/dist/css/hx-copy-button.css +121 -0
  351. package/dist/css/hx-counter.css +51 -0
  352. package/dist/css/hx-data-table.css +207 -0
  353. package/dist/css/hx-date-picker.css +2 -0
  354. package/dist/css/hx-dialog.css +190 -0
  355. package/dist/css/hx-divider.css +87 -0
  356. package/dist/css/hx-drawer.css +262 -0
  357. package/dist/css/hx-dropdown.css +46 -0
  358. package/dist/css/hx-field-label.css +38 -0
  359. package/dist/css/hx-field.css +119 -0
  360. package/dist/css/hx-file-upload.css +241 -0
  361. package/dist/css/hx-form.css +2 -0
  362. package/dist/css/hx-format-date.css +10 -0
  363. package/dist/css/hx-grid.css +14 -0
  364. package/dist/css/hx-help-text.css +50 -0
  365. package/dist/css/hx-icon-button.css +152 -0
  366. package/dist/css/hx-icon.css +73 -0
  367. package/dist/css/hx-image.css +41 -0
  368. package/dist/css/hx-link.css +105 -0
  369. package/dist/css/hx-list.css +48 -0
  370. package/dist/css/hx-menu.css +23 -0
  371. package/dist/css/hx-meter.css +113 -0
  372. package/dist/css/hx-nav.css +242 -0
  373. package/dist/css/hx-number-input.css +246 -0
  374. package/dist/css/hx-overflow-menu.css +133 -0
  375. package/dist/css/hx-pagination.css +193 -0
  376. package/dist/css/hx-patient-banner.css +139 -0
  377. package/dist/css/hx-phi-field.css +97 -0
  378. package/dist/css/hx-popover.css +61 -0
  379. package/dist/css/hx-popup.css +31 -0
  380. package/dist/css/hx-progress-bar.css +133 -0
  381. package/dist/css/hx-progress-ring.css +142 -0
  382. package/dist/css/hx-prose.css +2 -0
  383. package/dist/css/hx-radio-group.css +77 -0
  384. package/dist/css/hx-rating.css +96 -0
  385. package/dist/css/hx-select.css +295 -0
  386. package/dist/css/hx-side-nav.css +149 -0
  387. package/dist/css/hx-skeleton.css +82 -0
  388. package/dist/css/hx-slider.css +287 -0
  389. package/dist/css/hx-spinner.css +116 -0
  390. package/dist/css/hx-split-button.css +309 -0
  391. package/dist/css/hx-split-panel.css +168 -0
  392. package/dist/css/hx-stack.css +104 -0
  393. package/dist/css/hx-stat.css +106 -0
  394. package/dist/css/hx-status-indicator.css +126 -0
  395. package/dist/css/hx-steps.css +52 -0
  396. package/dist/css/hx-structured-list.css +75 -0
  397. package/dist/css/hx-style-scope.css +4 -0
  398. package/dist/css/hx-switch.css +169 -0
  399. package/dist/css/hx-table.css +128 -0
  400. package/dist/css/hx-tabs.css +76 -0
  401. package/dist/css/hx-tag.css +146 -0
  402. package/dist/css/hx-text-input.css +214 -0
  403. package/dist/css/hx-text.css +149 -0
  404. package/dist/css/hx-textarea.css +180 -0
  405. package/dist/css/hx-theme.css +23 -0
  406. package/dist/css/hx-time-picker.css +2 -0
  407. package/dist/css/hx-toast.css +230 -0
  408. package/dist/css/hx-toggle-button.css +207 -0
  409. package/dist/css/hx-tooltip.css +51 -0
  410. package/dist/css/hx-top-nav.css +203 -0
  411. package/dist/css/hx-tree-view.css +22 -0
  412. package/dist/css/hx-visually-hidden.css +26 -0
  413. package/dist/css/index.css +84 -0
  414. package/dist/css/manifest.json +2704 -0
  415. package/dist/index.d.ts +15 -9
  416. package/dist/index.d.ts.map +1 -1
  417. package/dist/index.js +268 -176
  418. package/dist/index.js.map +1 -1
  419. package/dist/mixins/FocusMixin.d.ts +49 -0
  420. package/dist/mixins/FocusMixin.d.ts.map +1 -0
  421. package/dist/mixins/FormMixin.d.ts +69 -0
  422. package/dist/mixins/FormMixin.d.ts.map +1 -0
  423. package/dist/mixins/aria-delegation.d.ts +97 -0
  424. package/dist/mixins/aria-delegation.d.ts.map +1 -0
  425. package/dist/mixins/index.d.ts +5 -0
  426. package/dist/mixins/index.d.ts.map +1 -0
  427. package/dist/shared/FormMixin-Bjvw20G5.js +88 -0
  428. package/dist/shared/FormMixin-Bjvw20G5.js.map +1 -0
  429. package/dist/shared/aria-delegation-CBP9eQ0M.js +107 -0
  430. package/dist/shared/aria-delegation-CBP9eQ0M.js.map +1 -0
  431. package/dist/shared/document-token-adoption-DuYNKd4k.js +21 -0
  432. package/dist/shared/document-token-adoption-DuYNKd4k.js.map +1 -0
  433. package/dist/shared/{hx-accordion-D1kFhdeQ.js → hx-accordion-CpfO0YQo.js} +86 -58
  434. package/dist/shared/hx-accordion-CpfO0YQo.js.map +1 -0
  435. package/dist/shared/{hx-action-bar-D4bulGQP.js → hx-action-bar-BpY1Z1UV.js} +34 -35
  436. package/dist/shared/hx-action-bar-BpY1Z1UV.js.map +1 -0
  437. package/dist/shared/{hx-alert-CSxCF2rr.js → hx-alert-CHOjTBds.js} +38 -34
  438. package/dist/shared/hx-alert-CHOjTBds.js.map +1 -0
  439. package/dist/shared/{hx-avatar-Cun-O99h.js → hx-avatar-an-WsuLl.js} +32 -15
  440. package/dist/shared/hx-avatar-an-WsuLl.js.map +1 -0
  441. package/dist/shared/{hx-badge-CsFd2xtw.js → hx-badge-DDXTLoWi.js} +49 -40
  442. package/dist/shared/hx-badge-DDXTLoWi.js.map +1 -0
  443. package/dist/shared/{hx-banner-BTV-X2xF.js → hx-banner-B-WEDiq7.js} +95 -60
  444. package/dist/shared/hx-banner-B-WEDiq7.js.map +1 -0
  445. package/dist/shared/{hx-breadcrumb-item-4IwaLgaO.js → hx-breadcrumb-item-DzLyeL5Z.js} +92 -89
  446. package/dist/shared/hx-breadcrumb-item-DzLyeL5Z.js.map +1 -0
  447. package/dist/shared/{hx-button-7k-KeCYU.js → hx-button-DoN8jjQT.js} +128 -63
  448. package/dist/shared/hx-button-DoN8jjQT.js.map +1 -0
  449. package/dist/shared/{hx-button-group-CWjWv-wS.js → hx-button-group-BXlMQTt_.js} +9 -9
  450. package/dist/shared/hx-button-group-BXlMQTt_.js.map +1 -0
  451. package/dist/shared/{hx-card-0hT3G5hi.js → hx-card-BgXZXDuc.js} +34 -34
  452. package/dist/shared/hx-card-BgXZXDuc.js.map +1 -0
  453. package/dist/shared/{hx-carousel-item-DgeYyYZJ.js → hx-carousel-item-Dwt9Pphz.js} +25 -25
  454. package/dist/shared/hx-carousel-item-Dwt9Pphz.js.map +1 -0
  455. package/dist/shared/{hx-checkbox-BvjO-O41.js → hx-checkbox-CTEZ9IFq.js} +67 -70
  456. package/dist/shared/hx-checkbox-CTEZ9IFq.js.map +1 -0
  457. package/dist/shared/{hx-checkbox-group-Z5VvWzcj.js → hx-checkbox-group-DThZeN5d.js} +48 -42
  458. package/dist/shared/hx-checkbox-group-DThZeN5d.js.map +1 -0
  459. package/dist/shared/hx-clinical-status-m4soOOwg.js +469 -0
  460. package/dist/shared/hx-clinical-status-m4soOOwg.js.map +1 -0
  461. package/dist/shared/{hx-code-snippet-DqzPkH4K.js → hx-code-snippet-CoLYvX1Z.js} +57 -48
  462. package/dist/shared/hx-code-snippet-CoLYvX1Z.js.map +1 -0
  463. package/dist/shared/{hx-color-picker-Da8z6AlQ.js → hx-color-picker-DhOaNe6-.js} +153 -137
  464. package/dist/shared/hx-color-picker-DhOaNe6-.js.map +1 -0
  465. package/dist/shared/{hx-combobox-CivfelTS.js → hx-combobox-BJ4lQocO.js} +17 -17
  466. package/dist/shared/hx-combobox-BJ4lQocO.js.map +1 -0
  467. package/dist/shared/{hx-container-DLUKnTi9.js → hx-container-31QT9KV_.js} +15 -15
  468. package/dist/shared/hx-container-31QT9KV_.js.map +1 -0
  469. package/dist/shared/{hx-copy-button--0dymSvw.js → hx-copy-button-BoM0WsMd.js} +52 -45
  470. package/dist/shared/hx-copy-button-BoM0WsMd.js.map +1 -0
  471. package/dist/shared/hx-counter-CP42cSVK.js +185 -0
  472. package/dist/shared/hx-counter-CP42cSVK.js.map +1 -0
  473. package/dist/shared/{hx-data-table-BWvd5NNx.js → hx-data-table-D5Ne-goy.js} +89 -53
  474. package/dist/shared/hx-data-table-D5Ne-goy.js.map +1 -0
  475. package/dist/shared/{hx-date-picker-6voxxxNE.js → hx-date-picker-Cd3I3WkX.js} +105 -92
  476. package/dist/shared/hx-date-picker-Cd3I3WkX.js.map +1 -0
  477. package/dist/shared/{hx-dialog-DkUSnVgw.js → hx-dialog-D4ubstxx.js} +98 -89
  478. package/dist/shared/hx-dialog-D4ubstxx.js.map +1 -0
  479. package/dist/shared/{hx-divider-DNNs4e8q.js → hx-divider-BBtOLHRP.js} +15 -15
  480. package/dist/shared/hx-divider-BBtOLHRP.js.map +1 -0
  481. package/dist/shared/{hx-drawer-CJcRZcns.js → hx-drawer--WDLuWtS.js} +87 -47
  482. package/dist/shared/hx-drawer--WDLuWtS.js.map +1 -0
  483. package/dist/shared/{hx-dropdown-Bo0KTM1A.js → hx-dropdown-n5-XSmiV.js} +56 -41
  484. package/dist/shared/hx-dropdown-n5-XSmiV.js.map +1 -0
  485. package/dist/shared/{hx-field-3MmzJ4kZ.js → hx-field-CwT9tki1.js} +21 -21
  486. package/dist/shared/hx-field-CwT9tki1.js.map +1 -0
  487. package/dist/shared/{hx-field-label-Bg-EWvqF.js → hx-field-label-CcOK9VU3.js} +11 -14
  488. package/dist/shared/hx-field-label-CcOK9VU3.js.map +1 -0
  489. package/dist/shared/{hx-file-upload-ByjAgfNy.js → hx-file-upload-Dwtu3WcB.js} +79 -88
  490. package/dist/shared/hx-file-upload-Dwtu3WcB.js.map +1 -0
  491. package/dist/shared/{hx-form-BpS6v3Iu.js → hx-form-fJE-FJQV.js} +36 -32
  492. package/dist/shared/{hx-form-BpS6v3Iu.js.map → hx-form-fJE-FJQV.js.map} +1 -1
  493. package/dist/shared/{hx-format-date-BdnWV2kX.js → hx-format-date-B7L9odbA.js} +19 -17
  494. package/dist/shared/hx-format-date-B7L9odbA.js.map +1 -0
  495. package/dist/shared/{hx-grid-gEjuF0cR.js → hx-grid-BIAR5h9m.js} +12 -12
  496. package/dist/shared/hx-grid-BIAR5h9m.js.map +1 -0
  497. package/dist/shared/{hx-help-text-BAcEGRUE.js → hx-help-text-Bmb80bP4.js} +13 -13
  498. package/dist/shared/hx-help-text-Bmb80bP4.js.map +1 -0
  499. package/dist/shared/{hx-icon-CP6OnLoM.js → hx-icon-BKHs3OLu.js} +15 -15
  500. package/dist/shared/hx-icon-BKHs3OLu.js.map +1 -0
  501. package/dist/shared/{hx-icon-button-DzH_bRtC.js → hx-icon-button-CJuy9xbw.js} +10 -10
  502. package/dist/shared/hx-icon-button-CJuy9xbw.js.map +1 -0
  503. package/dist/shared/{hx-image-C6pGiI6c.js → hx-image-ztiXumZB.js} +21 -21
  504. package/dist/shared/hx-image-ztiXumZB.js.map +1 -0
  505. package/dist/shared/{hx-link-Tmk_YPvW.js → hx-link-IVsXmsKx.js} +27 -25
  506. package/dist/shared/hx-link-IVsXmsKx.js.map +1 -0
  507. package/dist/shared/{hx-list-DwInEX2H.js → hx-list-CoTDMp19.js} +12 -12
  508. package/dist/shared/hx-list-CoTDMp19.js.map +1 -0
  509. package/dist/shared/{hx-menu-divider-DR4G_rqw.js → hx-menu-divider-DRT8yHRZ.js} +50 -30
  510. package/dist/shared/hx-menu-divider-DRT8yHRZ.js.map +1 -0
  511. package/dist/shared/{hx-meter-uXkTZq-W.js → hx-meter-BvSJoqDp.js} +18 -18
  512. package/dist/shared/hx-meter-BvSJoqDp.js.map +1 -0
  513. package/dist/shared/{hx-nav-item-D3EJatzc.js → hx-nav-item-CJN4VDrf.js} +181 -115
  514. package/dist/shared/hx-nav-item-CJN4VDrf.js.map +1 -0
  515. package/dist/shared/{hx-nav-3JsN2Oak.js → hx-nav-l0Rp7WPW.js} +119 -107
  516. package/dist/shared/hx-nav-l0Rp7WPW.js.map +1 -0
  517. package/dist/shared/{hx-number-input-CIpL2BEh.js → hx-number-input-0Waw7Z7u.js} +42 -41
  518. package/dist/shared/hx-number-input-0Waw7Z7u.js.map +1 -0
  519. package/dist/shared/{hx-overflow-menu-2kgOJ_ht.js → hx-overflow-menu-DElwFSCd.js} +20 -16
  520. package/dist/shared/hx-overflow-menu-DElwFSCd.js.map +1 -0
  521. package/dist/shared/{hx-pagination-Blt-fFqV.js → hx-pagination-BNtx-LG6.js} +91 -75
  522. package/dist/shared/hx-pagination-BNtx-LG6.js.map +1 -0
  523. package/dist/shared/hx-patient-banner-BKiN7nIE.js +297 -0
  524. package/dist/shared/hx-patient-banner-BKiN7nIE.js.map +1 -0
  525. package/dist/shared/hx-phi-field-BiJH3V-k.js +295 -0
  526. package/dist/shared/hx-phi-field-BiJH3V-k.js.map +1 -0
  527. package/dist/shared/{hx-popover-DxE67miP.js → hx-popover-D63RXn5H.js} +96 -69
  528. package/dist/shared/hx-popover-D63RXn5H.js.map +1 -0
  529. package/dist/shared/{hx-popup-Dg6n_PbY.js → hx-popup-BQWMhvMO.js} +15 -15
  530. package/dist/shared/hx-popup-BQWMhvMO.js.map +1 -0
  531. package/dist/shared/{hx-progress-bar-Dm_EHyng.js → hx-progress-bar-Cm0VihTN.js} +44 -42
  532. package/dist/shared/hx-progress-bar-Cm0VihTN.js.map +1 -0
  533. package/dist/shared/{hx-progress-ring-DpxBDD5d.js → hx-progress-ring-BJeiDr3q.js} +8 -8
  534. package/dist/shared/hx-progress-ring-BJeiDr3q.js.map +1 -0
  535. package/dist/shared/hx-prose-Ml_L2zje.js.map +1 -1
  536. package/dist/shared/{hx-radio-BywgVSEu.js → hx-radio-f8c5ggHG.js} +40 -39
  537. package/dist/shared/hx-radio-f8c5ggHG.js.map +1 -0
  538. package/dist/shared/{hx-rating-CUWBQ0fZ.js → hx-rating-qRJZXskm.js} +92 -96
  539. package/dist/shared/hx-rating-qRJZXskm.js.map +1 -0
  540. package/dist/shared/{hx-select-BwDwxk-M.js → hx-select-B5wq9Swh.js} +137 -98
  541. package/dist/shared/hx-select-B5wq9Swh.js.map +1 -0
  542. package/dist/shared/{hx-skeleton-BHvALyd7.js → hx-skeleton-e5K9Qaxq.js} +6 -6
  543. package/dist/shared/hx-skeleton-e5K9Qaxq.js.map +1 -0
  544. package/dist/shared/{hx-slider-D_0EKJyk.js → hx-slider-BvXtvxmN.js} +31 -26
  545. package/dist/shared/hx-slider-BvXtvxmN.js.map +1 -0
  546. package/dist/shared/{hx-spinner-DMn4SChS.js → hx-spinner-Dyese1Tb.js} +15 -14
  547. package/dist/shared/hx-spinner-Dyese1Tb.js.map +1 -0
  548. package/dist/shared/{hx-split-button-CypgLXw1.js → hx-split-button-CPndTJlC.js} +44 -35
  549. package/dist/shared/hx-split-button-CPndTJlC.js.map +1 -0
  550. package/dist/shared/{hx-split-panel-CV_Kr4EK.js → hx-split-panel-Dx72NaET.js} +18 -15
  551. package/dist/shared/hx-split-panel-Dx72NaET.js.map +1 -0
  552. package/dist/shared/{hx-stack-BStY1RmV.js → hx-stack-B76_1O6g.js} +9 -9
  553. package/dist/shared/hx-stack-B76_1O6g.js.map +1 -0
  554. package/dist/shared/{hx-stat-CHntLHJM.js → hx-stat-DKD2E7An.js} +43 -35
  555. package/dist/shared/hx-stat-DKD2E7An.js.map +1 -0
  556. package/dist/shared/{hx-status-indicator-C1BwEvUw.js → hx-status-indicator-ClWpK6zz.js} +81 -40
  557. package/dist/shared/hx-status-indicator-ClWpK6zz.js.map +1 -0
  558. package/dist/shared/{hx-step-BIVWSPxd.js → hx-step-C2Jk4mHa.js} +48 -84
  559. package/dist/shared/hx-step-C2Jk4mHa.js.map +1 -0
  560. package/dist/shared/{hx-structured-list-CMWllxGg.js → hx-structured-list-DKlrv7kS.js} +25 -22
  561. package/dist/shared/hx-structured-list-DKlrv7kS.js.map +1 -0
  562. package/dist/shared/hx-style-scope-CsQ2Phf_.js +126 -0
  563. package/dist/shared/hx-style-scope-CsQ2Phf_.js.map +1 -0
  564. package/dist/shared/{hx-switch-BgX8kuWt.js → hx-switch-BzMN37PV.js} +14 -11
  565. package/dist/shared/hx-switch-BzMN37PV.js.map +1 -0
  566. package/dist/shared/{hx-tab-panel-DhOq67jj.js → hx-tab-panel-J58zOSjq.js} +165 -126
  567. package/dist/shared/hx-tab-panel-J58zOSjq.js.map +1 -0
  568. package/dist/shared/{hx-tag-CzOTDcXI.js → hx-tag-F0ZcYj9b.js} +20 -19
  569. package/dist/shared/hx-tag-F0ZcYj9b.js.map +1 -0
  570. package/dist/shared/{hx-td-h6oeW6YC.js → hx-td-CNCvzBwY.js} +49 -46
  571. package/dist/shared/hx-td-CNCvzBwY.js.map +1 -0
  572. package/dist/shared/{hx-text-DTXjiviE.js → hx-text-DcWBqZwx.js} +27 -27
  573. package/dist/shared/hx-text-DcWBqZwx.js.map +1 -0
  574. package/dist/shared/hx-text-input-Scyeefec.js +576 -0
  575. package/dist/shared/hx-text-input-Scyeefec.js.map +1 -0
  576. package/dist/shared/{hx-textarea-BgX7rxyo.js → hx-textarea-BfSJJtA1.js} +23 -23
  577. package/dist/shared/hx-textarea-BfSJJtA1.js.map +1 -0
  578. package/dist/shared/hx-theme-pc1V7dyL.js +300 -0
  579. package/dist/shared/hx-theme-pc1V7dyL.js.map +1 -0
  580. package/dist/shared/{hx-time-picker-DmLu7WUC.js → hx-time-picker-CZvmihHD.js} +89 -88
  581. package/dist/shared/hx-time-picker-CZvmihHD.js.map +1 -0
  582. package/dist/shared/{hx-toggle-button-D1jpDvSA.js → hx-toggle-button-BZUQUULm.js} +14 -11
  583. package/dist/shared/hx-toggle-button-BZUQUULm.js.map +1 -0
  584. package/dist/shared/{hx-tooltip-kh7QFPKu.js → hx-tooltip-Ny4i1Idj.js} +26 -21
  585. package/dist/shared/hx-tooltip-Ny4i1Idj.js.map +1 -0
  586. package/dist/shared/{hx-top-nav-DYlnzDaU.js → hx-top-nav-CC4FW2Hp.js} +7 -7
  587. package/dist/shared/hx-top-nav-CC4FW2Hp.js.map +1 -0
  588. package/dist/shared/{hx-tree-item-BP6UF_H1.js → hx-tree-item-CPQ9dJiK.js} +170 -106
  589. package/dist/shared/hx-tree-item-CPQ9dJiK.js.map +1 -0
  590. package/dist/shared/{hx-visually-hidden-CCTQTjbR.js → hx-visually-hidden-vKX8QjeX.js} +13 -13
  591. package/dist/shared/hx-visually-hidden-vKX8QjeX.js.map +1 -0
  592. package/dist/shared/id-counter-JhvVCnjh.js +143 -0
  593. package/dist/shared/id-counter-JhvVCnjh.js.map +1 -0
  594. package/dist/shared/{toast-factory-DTy-qN8r.js → toast-factory-CEMNOt1T.js} +58 -46
  595. package/dist/shared/toast-factory-CEMNOt1T.js.map +1 -0
  596. package/dist/utilities/adoptedStylesheetRegistry.d.ts +47 -0
  597. package/dist/utilities/adoptedStylesheetRegistry.d.ts.map +1 -0
  598. package/dist/utilities/document-token-adoption.d.ts +10 -0
  599. package/dist/utilities/document-token-adoption.d.ts.map +1 -0
  600. package/dist/utilities/generateScopedSelectors.d.ts +30 -0
  601. package/dist/utilities/generateScopedSelectors.d.ts.map +1 -0
  602. package/dist/utilities/injectLightStyles.d.ts +37 -0
  603. package/dist/utilities/injectLightStyles.d.ts.map +1 -0
  604. package/dist/utilities/lightStyleRegistry.d.ts +41 -0
  605. package/dist/utilities/lightStyleRegistry.d.ts.map +1 -0
  606. package/dist/utilities/sheetManager.d.ts +62 -0
  607. package/dist/utilities/sheetManager.d.ts.map +1 -0
  608. package/dist/utils/contrast-checker.d.ts +86 -0
  609. package/dist/utils/contrast-checker.d.ts.map +1 -0
  610. package/dist/utils/token-merger.d.ts +24 -0
  611. package/dist/utils/token-merger.d.ts.map +1 -0
  612. package/fouc.css +37 -0
  613. package/package.json +28 -6
  614. package/dist/shared/hx-accordion-D1kFhdeQ.js.map +0 -1
  615. package/dist/shared/hx-action-bar-D4bulGQP.js.map +0 -1
  616. package/dist/shared/hx-alert-CSxCF2rr.js.map +0 -1
  617. package/dist/shared/hx-avatar-Cun-O99h.js.map +0 -1
  618. package/dist/shared/hx-badge-CsFd2xtw.js.map +0 -1
  619. package/dist/shared/hx-banner-BTV-X2xF.js.map +0 -1
  620. package/dist/shared/hx-breadcrumb-item-4IwaLgaO.js.map +0 -1
  621. package/dist/shared/hx-button-7k-KeCYU.js.map +0 -1
  622. package/dist/shared/hx-button-group-CWjWv-wS.js.map +0 -1
  623. package/dist/shared/hx-card-0hT3G5hi.js.map +0 -1
  624. package/dist/shared/hx-carousel-item-DgeYyYZJ.js.map +0 -1
  625. package/dist/shared/hx-checkbox-BvjO-O41.js.map +0 -1
  626. package/dist/shared/hx-checkbox-group-Z5VvWzcj.js.map +0 -1
  627. package/dist/shared/hx-code-snippet-DqzPkH4K.js.map +0 -1
  628. package/dist/shared/hx-color-picker-Da8z6AlQ.js.map +0 -1
  629. package/dist/shared/hx-combobox-CivfelTS.js.map +0 -1
  630. package/dist/shared/hx-container-DLUKnTi9.js.map +0 -1
  631. package/dist/shared/hx-copy-button--0dymSvw.js.map +0 -1
  632. package/dist/shared/hx-counter-Duf00H7p.js +0 -147
  633. package/dist/shared/hx-counter-Duf00H7p.js.map +0 -1
  634. package/dist/shared/hx-data-table-BWvd5NNx.js.map +0 -1
  635. package/dist/shared/hx-date-picker-6voxxxNE.js.map +0 -1
  636. package/dist/shared/hx-dialog-DkUSnVgw.js.map +0 -1
  637. package/dist/shared/hx-divider-DNNs4e8q.js.map +0 -1
  638. package/dist/shared/hx-drawer-CJcRZcns.js.map +0 -1
  639. package/dist/shared/hx-dropdown-Bo0KTM1A.js.map +0 -1
  640. package/dist/shared/hx-field-3MmzJ4kZ.js.map +0 -1
  641. package/dist/shared/hx-field-label-Bg-EWvqF.js.map +0 -1
  642. package/dist/shared/hx-file-upload-ByjAgfNy.js.map +0 -1
  643. package/dist/shared/hx-format-date-BdnWV2kX.js.map +0 -1
  644. package/dist/shared/hx-grid-gEjuF0cR.js.map +0 -1
  645. package/dist/shared/hx-help-text-BAcEGRUE.js.map +0 -1
  646. package/dist/shared/hx-icon-CP6OnLoM.js.map +0 -1
  647. package/dist/shared/hx-icon-button-DzH_bRtC.js.map +0 -1
  648. package/dist/shared/hx-image-C6pGiI6c.js.map +0 -1
  649. package/dist/shared/hx-link-Tmk_YPvW.js.map +0 -1
  650. package/dist/shared/hx-list-DwInEX2H.js.map +0 -1
  651. package/dist/shared/hx-menu-divider-DR4G_rqw.js.map +0 -1
  652. package/dist/shared/hx-meter-uXkTZq-W.js.map +0 -1
  653. package/dist/shared/hx-nav-3JsN2Oak.js.map +0 -1
  654. package/dist/shared/hx-nav-item-D3EJatzc.js.map +0 -1
  655. package/dist/shared/hx-number-input-CIpL2BEh.js.map +0 -1
  656. package/dist/shared/hx-overflow-menu-2kgOJ_ht.js.map +0 -1
  657. package/dist/shared/hx-pagination-Blt-fFqV.js.map +0 -1
  658. package/dist/shared/hx-popover-DxE67miP.js.map +0 -1
  659. package/dist/shared/hx-popup-Dg6n_PbY.js.map +0 -1
  660. package/dist/shared/hx-progress-bar-Dm_EHyng.js.map +0 -1
  661. package/dist/shared/hx-progress-ring-DpxBDD5d.js.map +0 -1
  662. package/dist/shared/hx-radio-BywgVSEu.js.map +0 -1
  663. package/dist/shared/hx-rating-CUWBQ0fZ.js.map +0 -1
  664. package/dist/shared/hx-select-BwDwxk-M.js.map +0 -1
  665. package/dist/shared/hx-skeleton-BHvALyd7.js.map +0 -1
  666. package/dist/shared/hx-slider-D_0EKJyk.js.map +0 -1
  667. package/dist/shared/hx-spinner-DMn4SChS.js.map +0 -1
  668. package/dist/shared/hx-split-button-CypgLXw1.js.map +0 -1
  669. package/dist/shared/hx-split-panel-CV_Kr4EK.js.map +0 -1
  670. package/dist/shared/hx-stack-BStY1RmV.js.map +0 -1
  671. package/dist/shared/hx-stat-CHntLHJM.js.map +0 -1
  672. package/dist/shared/hx-status-indicator-C1BwEvUw.js.map +0 -1
  673. package/dist/shared/hx-step-BIVWSPxd.js.map +0 -1
  674. package/dist/shared/hx-structured-list-CMWllxGg.js.map +0 -1
  675. package/dist/shared/hx-switch-BgX8kuWt.js.map +0 -1
  676. package/dist/shared/hx-tab-panel-DhOq67jj.js.map +0 -1
  677. package/dist/shared/hx-tag-CzOTDcXI.js.map +0 -1
  678. package/dist/shared/hx-td-h6oeW6YC.js.map +0 -1
  679. package/dist/shared/hx-text-DTXjiviE.js.map +0 -1
  680. package/dist/shared/hx-text-input-CqEdDHMU.js +0 -461
  681. package/dist/shared/hx-text-input-CqEdDHMU.js.map +0 -1
  682. package/dist/shared/hx-textarea-BgX7rxyo.js.map +0 -1
  683. package/dist/shared/hx-theme-6GDoUG8j.js +0 -176
  684. package/dist/shared/hx-theme-6GDoUG8j.js.map +0 -1
  685. package/dist/shared/hx-time-picker-DmLu7WUC.js.map +0 -1
  686. package/dist/shared/hx-toggle-button-D1jpDvSA.js.map +0 -1
  687. package/dist/shared/hx-tooltip-kh7QFPKu.js.map +0 -1
  688. package/dist/shared/hx-top-nav-DYlnzDaU.js.map +0 -1
  689. package/dist/shared/hx-tree-item-BP6UF_H1.js.map +0 -1
  690. package/dist/shared/hx-visually-hidden-CCTQTjbR.js.map +0 -1
  691. package/dist/shared/toast-factory-DTy-qN8r.js.map +0 -1
@@ -1,9 +1,9 @@
1
- import { css as d, LitElement as u, nothing as c, html as p } from "lit";
2
- import { property as o, state as b, customElement as _ } from "lit/decorators.js";
3
- import { classMap as v } from "lit/directives/class-map.js";
4
- import { ifDefined as g } from "lit/directives/if-defined.js";
5
- import { tokenStyles as f } from "@helixui/tokens/lit";
6
- const x = d`
1
+ import { css as m, LitElement as u, nothing as c, html as p } from "lit";
2
+ import "./document-token-adoption-DuYNKd4k.js";
3
+ import { property as o, state as g, customElement as v } from "lit/decorators.js";
4
+ import { classMap as _ } from "lit/directives/class-map.js";
5
+ import { ifDefined as b } from "lit/directives/if-defined.js";
6
+ const f = m`
7
7
  :host {
8
8
  display: block;
9
9
  }
@@ -45,15 +45,15 @@ const x = d`
45
45
  /* ─── Size Variants ─── */
46
46
 
47
47
  .progress-bar--sm .progress-bar__track {
48
- height: var(--hx-progress-bar-height-sm, var(--hx-size-1, 0.25rem));
48
+ height: var(--hx-progress-bar-height-sm, var(--hx-space-1, 0.25rem));
49
49
  }
50
50
 
51
51
  .progress-bar--md .progress-bar__track {
52
- height: var(--hx-progress-bar-height-md, var(--hx-size-2, 0.5rem));
52
+ height: var(--hx-progress-bar-height-md, var(--hx-space-2, 0.5rem));
53
53
  }
54
54
 
55
55
  .progress-bar--lg .progress-bar__track {
56
- height: var(--hx-progress-bar-height-lg, var(--hx-size-3, 0.75rem));
56
+ height: var(--hx-progress-bar-height-lg, var(--hx-space-3, 0.75rem));
57
57
  }
58
58
 
59
59
  .progress-bar__fill {
@@ -107,7 +107,8 @@ const x = d`
107
107
  .progress-bar--indeterminate .progress-bar__fill {
108
108
  transform: translateX(-100%) scaleX(0.4);
109
109
  transform-origin: left center;
110
- animation: hx-progress-indeterminate 1.5s ease-in-out infinite;
110
+ animation: hx-progress-indeterminate var(--hx-progress-bar-indeterminate-duration, 1.5s)
111
+ ease-in-out infinite;
111
112
  }
112
113
 
113
114
  @media (prefers-reduced-motion: reduce) {
@@ -118,7 +119,7 @@ const x = d`
118
119
  .progress-bar--indeterminate .progress-bar__fill {
119
120
  animation: none;
120
121
  transform: scaleX(1);
121
- opacity: 0.4;
122
+ opacity: var(--hx-opacity-disabled, 0.5); /* reduced from animation; no exact token for 0.4 */
122
123
  }
123
124
  }
124
125
 
@@ -136,14 +137,14 @@ const x = d`
136
137
  }
137
138
  }
138
139
  `;
139
- var y = Object.defineProperty, $ = Object.getOwnPropertyDescriptor, s = (r, t, n, l) => {
140
- for (var a = l > 1 ? void 0 : l ? $(t, n) : t, i = r.length - 1, h; i >= 0; i--)
141
- (h = r[i]) && (a = (l ? h(t, n, a) : h(a)) || a);
142
- return l && a && y(t, n, a), a;
140
+ var x = Object.defineProperty, y = Object.getOwnPropertyDescriptor, a = (r, t, n, l) => {
141
+ for (var s = l > 1 ? void 0 : l ? y(t, n) : t, i = r.length - 1, h; i >= 0; i--)
142
+ (h = r[i]) && (s = (l ? h(t, n, s) : h(s)) || s);
143
+ return l && s && x(t, n, s), s;
143
144
  };
144
145
  let e = class extends u {
145
146
  constructor() {
146
- super(...arguments), this.value = null, this.min = 0, this.max = 100, this.indeterminate = !1, this.label = "", this.description = "", this.size = "md", this.variant = "default", this._liveMessage = "", this._hasLabelSlotContent = !1, this._uid = `hx-pb-${++e._counter}`;
147
+ super(...arguments), this.value = null, this.min = 0, this.max = 100, this.indeterminate = !1, this.label = "", this.description = "", this.size = "md", this.variant = "default", this._liveMessage = "", this._hasLabelSlotContent = !1, this._warnedAboutLabel = !1, this._uid = `hx-pb-${++e._counter}`;
147
148
  }
148
149
  /** @internal */
149
150
  get _isIndeterminate() {
@@ -151,7 +152,8 @@ let e = class extends u {
151
152
  }
152
153
  /** @internal */
153
154
  get _percentage() {
154
- if (this._isIndeterminate) return 0;
155
+ if (this._isIndeterminate || this.value !== null && isNaN(this.value))
156
+ return 0;
155
157
  const r = this.max - this.min;
156
158
  return r <= 0 ? 0 : (Math.max(this.min, Math.min(this.value ?? this.min, this.max)) - this.min) / r * 100;
157
159
  }
@@ -160,11 +162,11 @@ let e = class extends u {
160
162
  return !this._isIndeterminate && this.value !== null && this.value >= this.max;
161
163
  }
162
164
  updated(r) {
163
- if ((r.has("value") || r.has("max")) && this._isComplete ? (this._liveMessage = "Complete", this.dispatchEvent(new CustomEvent("hx-complete", { bubbles: !0, composed: !0 }))) : r.has("value") && !this._isComplete && (this._liveMessage = ""), r.has("value") || r.has("min") || r.has("max") || r.has("indeterminate")) {
165
+ if (super.updated(r), (r.has("value") || r.has("max")) && this._isComplete ? (this._liveMessage = "Complete", this.dispatchEvent(new CustomEvent("hx-complete", { bubbles: !0, composed: !0 }))) : r.has("value") && !this._isComplete && (this._liveMessage = ""), r.has("value") || r.has("min") || r.has("max") || r.has("indeterminate")) {
164
166
  const t = this._isIndeterminate ? 0 : this._percentage / 100;
165
167
  this.style.setProperty("--_value-ratio", String(Math.max(0, Math.min(1, t))));
166
168
  }
167
- this.label;
169
+ !this.label && !this._warnedAboutLabel && (this._warnedAboutLabel = !0);
168
170
  }
169
171
  /** @internal */
170
172
  _onLabelSlotChange(r) {
@@ -181,9 +183,9 @@ let e = class extends u {
181
183
  [`progress-bar--${this.size}`]: !0,
182
184
  [`progress-bar--${this.variant}`]: !0,
183
185
  "progress-bar--indeterminate": this._isIndeterminate
184
- }, a = this._isIndeterminate ? void 0 : this.value ?? this.min, i = this._variantLabel, h = this._isIndeterminate ? "In progress" : `${Math.round(this._percentage)}%`, m = i ? `${h} — ${i}` : h;
186
+ }, s = this._isIndeterminate ? void 0 : this.value ?? this.min, i = this._variantLabel, h = this._isIndeterminate ? "In progress" : `${Math.round(this._percentage)}%`, d = i ? `${h} — ${i}` : h;
185
187
  return p`
186
- <div class=${v(l)}>
188
+ <div class=${_(l)}>
187
189
  ${n || this.label ? p`<span id=${r} part="label" class="progress-bar__label">
188
190
  <slot name="label" @slotchange=${this._onLabelSlotChange}></slot>
189
191
  </span>` : p`<slot name="label" @slotchange=${this._onLabelSlotChange} hidden></slot>`}
@@ -192,13 +194,13 @@ let e = class extends u {
192
194
  part="track"
193
195
  class="progress-bar__track"
194
196
  role="progressbar"
195
- aria-valuenow=${g(a)}
197
+ aria-valuenow=${b(s)}
196
198
  aria-valuemin=${this.min}
197
199
  aria-valuemax=${this.max}
198
- aria-valuetext=${m}
199
- aria-label=${g(!n && this.label ? this.label : void 0)}
200
- aria-labelledby=${g(n ? r : void 0)}
201
- aria-describedby=${g(t)}
200
+ aria-valuetext=${d}
201
+ aria-label=${b(!n && this.label ? this.label : void 0)}
202
+ aria-labelledby=${b(n ? r : void 0)}
203
+ aria-describedby=${b(t)}
202
204
  >
203
205
  <div part="fill" class="progress-bar__fill"></div>
204
206
  </div>
@@ -208,47 +210,47 @@ let e = class extends u {
208
210
  `;
209
211
  }
210
212
  };
211
- e.styles = [f, x];
213
+ e.styles = [f];
212
214
  e._counter = 0;
213
215
  e._VARIANT_LABELS = {
214
216
  success: "Success",
215
217
  warning: "Warning",
216
218
  danger: "Danger"
217
219
  };
218
- s([
220
+ a([
219
221
  o({ type: Number, reflect: !0 })
220
222
  ], e.prototype, "value", 2);
221
- s([
223
+ a([
222
224
  o({ type: Number, reflect: !0 })
223
225
  ], e.prototype, "min", 2);
224
- s([
226
+ a([
225
227
  o({ type: Number, reflect: !0 })
226
228
  ], e.prototype, "max", 2);
227
- s([
229
+ a([
228
230
  o({ type: Boolean, reflect: !0 })
229
231
  ], e.prototype, "indeterminate", 2);
230
- s([
232
+ a([
231
233
  o({ type: String, reflect: !0 })
232
234
  ], e.prototype, "label", 2);
233
- s([
235
+ a([
234
236
  o({ type: String, reflect: !0 })
235
237
  ], e.prototype, "description", 2);
236
- s([
238
+ a([
237
239
  o({ type: String, reflect: !0, attribute: "hx-size" })
238
240
  ], e.prototype, "size", 2);
239
- s([
241
+ a([
240
242
  o({ type: String, reflect: !0 })
241
243
  ], e.prototype, "variant", 2);
242
- s([
243
- b()
244
+ a([
245
+ g()
244
246
  ], e.prototype, "_liveMessage", 2);
245
- s([
246
- b()
247
+ a([
248
+ g()
247
249
  ], e.prototype, "_hasLabelSlotContent", 2);
248
- e = s([
249
- _("hx-progress-bar")
250
+ e = a([
251
+ v("hx-progress-bar")
250
252
  ], e);
251
253
  export {
252
254
  e as H
253
255
  };
254
- //# sourceMappingURL=hx-progress-bar-Dm_EHyng.js.map
256
+ //# sourceMappingURL=hx-progress-bar-Cm0VihTN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-progress-bar-Cm0VihTN.js","sources":["../../src/components/hx-progress-bar/hx-progress-bar.styles.ts","../../src/components/hx-progress-bar/hx-progress-bar.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixProgressBarStyles = css`\n :host {\n display: block;\n }\n\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n\n .progress-bar {\n display: flex;\n flex-direction: column;\n gap: var(--hx-space-1, 0.25rem);\n }\n\n .progress-bar__label {\n font-family: var(--hx-progress-bar-label-font-family, var(--hx-font-family-sans, sans-serif));\n font-size: var(--hx-progress-bar-label-font-size, var(--hx-font-size-sm, 0.875rem));\n font-weight: var(--hx-progress-bar-label-font-weight, var(--hx-font-weight-medium, 500));\n color: var(--hx-progress-bar-label-color, var(--hx-color-neutral-700));\n line-height: var(--hx-line-height-tight, 1.25);\n }\n\n .progress-bar__track {\n position: relative;\n overflow: hidden;\n border-radius: var(--hx-progress-bar-border-radius, var(--hx-border-radius-full, 9999px));\n background-color: var(--hx-progress-bar-track-bg, var(--hx-color-neutral-100));\n width: 100%;\n }\n\n /* ─── Size Variants ─── */\n\n .progress-bar--sm .progress-bar__track {\n height: var(--hx-progress-bar-height-sm, var(--hx-space-1, 0.25rem));\n }\n\n .progress-bar--md .progress-bar__track {\n height: var(--hx-progress-bar-height-md, var(--hx-space-2, 0.5rem));\n }\n\n .progress-bar--lg .progress-bar__track {\n height: var(--hx-progress-bar-height-lg, var(--hx-space-3, 0.75rem));\n }\n\n .progress-bar__fill {\n height: 100%;\n width: 100%;\n border-radius: inherit;\n background-color: var(--hx-progress-bar-indicator-bg, var(--hx-color-primary-500));\n transform-origin: left center;\n transform: scaleX(var(--_value-ratio, 0));\n transition: transform var(--hx-transition-fast, 150ms ease);\n }\n\n @media (prefers-reduced-motion: reduce) {\n .progress-bar__fill {\n transition: none;\n }\n }\n\n /* ─── Variant Colors ─── */\n\n .progress-bar--default .progress-bar__fill {\n --hx-progress-bar-indicator-bg: var(--hx-color-primary-500);\n }\n\n .progress-bar--success .progress-bar__fill {\n --hx-progress-bar-indicator-bg: var(--hx-color-success-700);\n }\n\n .progress-bar--warning .progress-bar__fill {\n --hx-progress-bar-indicator-bg: var(--hx-color-warning-500);\n }\n\n .progress-bar--danger .progress-bar__fill {\n --hx-progress-bar-indicator-bg: var(--hx-color-error-500);\n }\n\n /* ─── Indeterminate Animation ─── */\n\n @keyframes hx-progress-indeterminate {\n 0% {\n transform: translateX(-100%) scaleX(0.4);\n }\n 50% {\n transform: translateX(50%) scaleX(0.6);\n }\n 100% {\n transform: translateX(250%) scaleX(0.4);\n }\n }\n\n .progress-bar--indeterminate .progress-bar__fill {\n transform: translateX(-100%) scaleX(0.4);\n transform-origin: left center;\n animation: hx-progress-indeterminate var(--hx-progress-bar-indeterminate-duration, 1.5s)\n ease-in-out infinite;\n }\n\n @media (prefers-reduced-motion: reduce) {\n .progress-bar__fill {\n transition: none;\n }\n\n .progress-bar--indeterminate .progress-bar__fill {\n animation: none;\n transform: scaleX(1);\n opacity: var(--hx-opacity-disabled, 0.5); /* reduced from animation; no exact token for 0.4 */\n }\n }\n\n /* ─── High Contrast Mode ─── */\n\n @media (forced-colors: active) {\n .progress-bar__track {\n border: 1px solid ButtonText;\n background-color: Canvas;\n }\n\n .progress-bar__fill {\n background-color: Highlight;\n forced-color-adjust: none;\n }\n }\n`;\n","import { LitElement, html, nothing, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { helixProgressBarStyles } from './hx-progress-bar.styles.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\n/**\n * A linear progress indicator for determinate and indeterminate states.\n *\n * @summary Displays task completion progress or an indeterminate loading state.\n *\n * @tag hx-progress-bar\n *\n * @slot label - Visible label text rendered above the progress bar track.\n *\n * @csspart track - The outer track container element.\n * @csspart fill - The filled portion indicating progress.\n * @csspart label - The label slot wrapper element.\n *\n * @cssprop [--hx-progress-bar-track-bg=var(--hx-color-neutral-100)] - Track background color.\n * @cssprop [--hx-progress-bar-indicator-bg=var(--hx-color-primary-500)] - Indicator fill color.\n * @cssprop [--hx-progress-bar-border-radius=var(--hx-border-radius-full)] - Track border radius.\n * @cssprop [--hx-progress-bar-height-sm=var(--hx-size-1)] - Track height for size=\"sm\".\n * @cssprop [--hx-progress-bar-height-md=var(--hx-size-2)] - Track height for size=\"md\".\n * @cssprop [--hx-progress-bar-height-lg=var(--hx-size-3)] - Track height for size=\"lg\".\n * @cssprop [--hx-progress-bar-label-font-family=var(--hx-font-family-sans)] - Label font family.\n * @cssprop [--hx-progress-bar-label-font-size=var(--hx-font-size-sm)] - Label font size.\n * @cssprop [--hx-progress-bar-label-font-weight=var(--hx-font-weight-medium)] - Label font weight.\n * @cssprop [--hx-progress-bar-label-color=var(--hx-color-neutral-700)] - Label text color.\n *\n * @fires {CustomEvent} hx-complete - Emitted when progress reaches 100%.\n */\n@customElement('hx-progress-bar')\nexport class HelixProgressBar extends LitElement {\n static override styles = [helixProgressBarStyles];\n\n /**\n * Current progress value (min–max). Set to null for indeterminate state.\n * @attr value\n */\n @property({ type: Number, reflect: true })\n value: number | null = null;\n\n /**\n * Minimum value for the progress bar.\n * @attr min\n */\n @property({ type: Number, reflect: true })\n min = 0;\n\n /**\n * Maximum value for the progress bar.\n * @attr max\n */\n @property({ type: Number, reflect: true })\n max = 100;\n\n /**\n * When true, displays an animated indeterminate loading state regardless of value.\n * @attr indeterminate\n */\n @property({ type: Boolean, reflect: true })\n indeterminate = false;\n\n /**\n * Accessible label for the progress bar (maps to aria-label when no label slot content is used).\n * @attr label\n */\n @property({ type: String, reflect: true })\n label = '';\n\n /**\n * Additional description for the progress operation, linked via aria-describedby.\n * @attr description\n */\n @property({ type: String, reflect: true })\n description = '';\n\n /**\n * Size of the progress bar track.\n * @attr hx-size\n */\n @property({ type: String, reflect: true, attribute: 'hx-size' })\n size: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Visual variant controlling the indicator color.\n * @attr variant\n */\n @property({ type: String, reflect: true })\n variant: 'default' | 'success' | 'warning' | 'danger' = 'default';\n\n /** @internal */\n @state() private _liveMessage = '';\n /** @internal */\n @state() private _hasLabelSlotContent = false;\n /** @internal */\n private _warnedAboutLabel = false;\n\n /** @internal */\n private static _counter = 0;\n /** @internal */\n private _uid = `hx-pb-${++HelixProgressBar._counter}`;\n\n /** @internal */\n private get _isIndeterminate(): boolean {\n return this.indeterminate || this.value === null;\n }\n\n /** @internal */\n private get _percentage(): number {\n if (this._isIndeterminate) return 0;\n if (this.value !== null && isNaN(this.value)) {\n devWarn('hx-progress-bar', 'Invalid value: NaN. Defaulting to 0.');\n return 0;\n }\n const range = this.max - this.min;\n if (range <= 0) return 0;\n const clamped = Math.max(this.min, Math.min(this.value ?? this.min, this.max));\n return ((clamped - this.min) / range) * 100;\n }\n\n /** @internal */\n private get _isComplete(): boolean {\n return !this._isIndeterminate && this.value !== null && this.value >= this.max;\n }\n\n override updated(changedProps: PropertyValues<this>): void {\n super.updated(changedProps);\n if ((changedProps.has('value') || changedProps.has('max')) && this._isComplete) {\n this._liveMessage = 'Complete';\n this.dispatchEvent(new CustomEvent<void>('hx-complete', { bubbles: true, composed: true }));\n } else if (changedProps.has('value') && !this._isComplete) {\n this._liveMessage = '';\n }\n\n if (\n changedProps.has('value') ||\n changedProps.has('min') ||\n changedProps.has('max') ||\n changedProps.has('indeterminate')\n ) {\n const ratio = this._isIndeterminate ? 0 : this._percentage / 100;\n this.style.setProperty('--_value-ratio', String(Math.max(0, Math.min(1, ratio))));\n }\n\n if (!this.label && !this._warnedAboutLabel) {\n this._warnedAboutLabel = true;\n devWarn(\n 'hx-progress-bar',\n 'No accessible label provided. Set the `label` attribute or use the label slot. An unlabeled progressbar violates WCAG 2.1 AA (4.1.2 Name, Role, Value).',\n );\n }\n }\n\n /** @internal */\n private _onLabelSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasLabelSlotContent = slot.assignedNodes({ flatten: true }).length > 0;\n }\n\n // ─── WCAG 1.4.1: Variant label map ───\n // Semantic variants (success/warning/danger) must not rely on color alone.\n // The variant label is included in aria-valuetext for AT users and rendered\n // as visually-hidden text for users in high contrast or color-blind contexts.\n\n /** @internal */\n private static readonly _VARIANT_LABELS: Partial<Record<HelixProgressBar['variant'], string>> = {\n success: 'Success',\n warning: 'Warning',\n danger: 'Danger',\n };\n\n /** @internal */\n private get _variantLabel(): string {\n return HelixProgressBar._VARIANT_LABELS[this.variant] ?? '';\n }\n\n override render() {\n const labelId = `${this._uid}-label`;\n const descId = this.description ? `${this._uid}-desc` : undefined;\n const hasVisibleLabel = this._hasLabelSlotContent;\n\n const classes = {\n 'progress-bar': true,\n [`progress-bar--${this.size}`]: true,\n [`progress-bar--${this.variant}`]: true,\n 'progress-bar--indeterminate': this._isIndeterminate,\n };\n\n const ariaValueNow = this._isIndeterminate ? undefined : (this.value ?? this.min);\n const variantLabel = this._variantLabel;\n\n // WCAG 1.4.1: Include variant label in aria-valuetext so AT users receive\n // the semantic state (success/warning/danger) without relying on fill color.\n const percentageText = this._isIndeterminate\n ? 'In progress'\n : `${Math.round(this._percentage)}%`;\n const ariaValuetext = variantLabel ? `${percentageText} — ${variantLabel}` : percentageText;\n\n return html`\n <div class=${classMap(classes)}>\n ${hasVisibleLabel || this.label\n ? html`<span id=${labelId} part=\"label\" class=\"progress-bar__label\">\n <slot name=\"label\" @slotchange=${this._onLabelSlotChange}></slot>\n </span>`\n : html`<slot name=\"label\" @slotchange=${this._onLabelSlotChange} hidden></slot>`}\n ${this.description\n ? html`<span id=${descId} class=\"sr-only\">${this.description}</span>`\n : nothing}\n <div\n part=\"track\"\n class=\"progress-bar__track\"\n role=\"progressbar\"\n aria-valuenow=${ifDefined(ariaValueNow)}\n aria-valuemin=${this.min}\n aria-valuemax=${this.max}\n aria-valuetext=${ariaValuetext}\n aria-label=${ifDefined(!hasVisibleLabel && this.label ? this.label : undefined)}\n aria-labelledby=${ifDefined(hasVisibleLabel ? labelId : undefined)}\n aria-describedby=${ifDefined(descId)}\n >\n <div part=\"fill\" class=\"progress-bar__fill\"></div>\n </div>\n ${variantLabel\n ? html`<span class=\"sr-only progress-bar__variant-label\">${variantLabel}</span>`\n : nothing}\n <div aria-live=\"polite\" aria-atomic=\"true\" class=\"sr-only\">${this._liveMessage}</div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-progress-bar': HelixProgressBar;\n }\n}\n"],"names":["helixProgressBarStyles","css","HelixProgressBar","LitElement","range","changedProps","ratio","e","slot","labelId","descId","hasVisibleLabel","classes","ariaValueNow","variantLabel","percentageText","ariaValuetext","html","classMap","nothing","ifDefined","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { css as c, LitElement as g, svg as d, html as u } from "lit";
2
+ import "./document-token-adoption-DuYNKd4k.js";
2
3
  import { property as n, customElement as p } from "lit/decorators.js";
3
- import { tokenStyles as m } from "@helixui/tokens/lit";
4
- const f = c`
4
+ const m = c`
5
5
  :host {
6
6
  display: inline-flex;
7
7
  align-items: center;
@@ -144,10 +144,10 @@ const f = c`
144
144
  pointer-events: none;
145
145
  }
146
146
  `;
147
- var v = Object.defineProperty, _ = Object.getOwnPropertyDescriptor, i = (r, o, a, t) => {
148
- for (var s = t > 1 ? void 0 : t ? _(o, a) : o, l = r.length - 1, h; l >= 0; l--)
147
+ var f = Object.defineProperty, v = Object.getOwnPropertyDescriptor, i = (r, o, a, t) => {
148
+ for (var s = t > 1 ? void 0 : t ? v(o, a) : o, l = r.length - 1, h; l >= 0; l--)
149
149
  (h = r[l]) && (s = (t ? h(o, a, s) : h(s)) || s);
150
- return t && s && v(o, a, s), s;
150
+ return t && s && f(o, a, s), s;
151
151
  };
152
152
  let e = class extends g {
153
153
  constructor() {
@@ -184,7 +184,7 @@ let e = class extends g {
184
184
  r !== null && !this.hasAttribute("hx-size") && (this.size = r), this.setAttribute("role", "progressbar"), this.setAttribute("aria-valuemin", "0");
185
185
  }
186
186
  willUpdate(r) {
187
- this.setAttribute("aria-valuemax", String(this.max)), this._isIndeterminate ? (this.setAttribute("indeterminate", ""), this.setAttribute("aria-busy", "true"), this.removeAttribute("aria-valuenow")) : (this.removeAttribute("indeterminate"), this.removeAttribute("aria-busy"), this.setAttribute("aria-valuenow", String(this._clampedValue))), this.label ? this.setAttribute("aria-label", this.label) : (this.removeAttribute("aria-label"), this._labelWarned || (this._labelWarned = !0));
187
+ this.setAttribute("aria-valuemax", String(this.max)), this._isIndeterminate ? (this.setAttribute("indeterminate", ""), this.setAttribute("aria-busy", "true"), this.removeAttribute("aria-valuenow"), this.removeAttribute("aria-valuetext")) : (this.removeAttribute("indeterminate"), this.removeAttribute("aria-busy"), this.setAttribute("aria-valuenow", String(this._clampedValue)), this.setAttribute("aria-valuetext", `${this._clampedValue}% complete`)), this.label ? this.setAttribute("aria-label", this.label) : (this.removeAttribute("aria-label"), this._labelWarned || (this._labelWarned = !0));
188
188
  }
189
189
  // ─── Render ───
190
190
  render() {
@@ -226,7 +226,7 @@ let e = class extends g {
226
226
  `;
227
227
  }
228
228
  };
229
- e.styles = [m, f];
229
+ e.styles = [m];
230
230
  i([
231
231
  n({ type: Number, reflect: !0 })
232
232
  ], e.prototype, "value", 2);
@@ -251,4 +251,4 @@ e = i([
251
251
  export {
252
252
  e as H
253
253
  };
254
- //# sourceMappingURL=hx-progress-ring-DpxBDD5d.js.map
254
+ //# sourceMappingURL=hx-progress-ring-BJeiDr3q.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-progress-ring-BJeiDr3q.js","sources":["../../src/components/hx-progress-ring/hx-progress-ring.styles.ts","../../src/components/hx-progress-ring/hx-progress-ring.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixProgressRingStyles = css`\n :host {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n }\n\n /* ─── Base Container ─── */\n\n .progress-ring {\n position: relative;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n }\n\n /* ─── SVG ─── */\n\n .progress-ring__svg {\n transform: rotate(-90deg);\n overflow: visible;\n }\n\n /* ─── Track ─── */\n\n .progress-ring__track {\n fill: none;\n stroke: var(--hx-progress-ring-track-color, var(--hx-color-neutral-200, #e2e8f0));\n }\n\n /* ─── Indicator ─── */\n\n .progress-ring__indicator {\n fill: none;\n stroke: var(--hx-progress-ring-indicator-color, var(--hx-color-primary-500, #2563eb));\n stroke-linecap: round;\n transition: stroke-dashoffset var(--hx-transition-base, 300ms ease);\n }\n\n /* ─── Variant Colors ─── */\n\n :host([variant='success']) .progress-ring__indicator {\n stroke: var(--hx-progress-ring-indicator-color, var(--hx-color-success-500, #16a34a));\n }\n\n :host([variant='warning']) .progress-ring__indicator {\n stroke: var(--hx-progress-ring-indicator-color, var(--hx-color-warning-500, #d97706));\n }\n\n :host([variant='danger']) .progress-ring__indicator {\n stroke: var(--hx-progress-ring-indicator-color, var(--hx-color-error-500, #dc2626));\n }\n\n /* ─── Indeterminate Animation ─── */\n\n :host([indeterminate]) .progress-ring__svg {\n animation: hx-progress-ring-rotate var(--hx-duration-spinner, 1400ms) linear infinite;\n }\n\n :host([indeterminate]) .progress-ring__indicator {\n animation: hx-progress-ring-dash var(--hx-duration-spinner, 1400ms) ease-in-out infinite;\n transition: none;\n stroke-dasharray: 1, 200;\n stroke-dashoffset: 0;\n }\n\n @keyframes hx-progress-ring-rotate {\n to {\n transform: rotate(270deg);\n }\n }\n\n /*\n * Indeterminate spinner keyframes — values are tuned for default strokeWidth=4\n * (radius ≈ 48, circumference ≈ 301). The gap value 200 is intentionally smaller\n * than the full circumference; the repeating pattern is a standard CSS spinner\n * technique that produces an arc of ~35% coverage. At non-default strokeWidths\n * the arc coverage will vary slightly but remains visually acceptable.\n */\n @keyframes hx-progress-ring-dash {\n 0% {\n stroke-dasharray: 1, 200;\n stroke-dashoffset: 0;\n }\n 50% {\n stroke-dasharray: 89, 200;\n stroke-dashoffset: -35;\n }\n 100% {\n stroke-dasharray: 89, 200;\n stroke-dashoffset: -124;\n }\n }\n\n @media (prefers-reduced-motion: reduce) {\n :host([indeterminate]) .progress-ring__svg {\n animation: none;\n }\n\n :host([indeterminate]) .progress-ring__indicator {\n animation: none;\n stroke-dasharray: 89, 200;\n stroke-dashoffset: -35;\n }\n\n .progress-ring__indicator {\n transition: none;\n }\n }\n\n /* ─── Size Variants ─── */\n\n :host([size='sm']) .progress-ring {\n width: var(--hx-size-8, 2rem);\n height: var(--hx-size-8, 2rem);\n }\n\n :host([size='md']) .progress-ring,\n .progress-ring {\n width: var(--hx-size-12, 3rem);\n height: var(--hx-size-12, 3rem);\n }\n\n :host([size='lg']) .progress-ring {\n width: var(--hx-size-16, 4rem);\n height: var(--hx-size-16, 4rem);\n }\n\n /* ─── Label (center slot wrapper) ─── */\n\n .progress-ring__label {\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n inset: 0;\n font-size: var(--hx-font-size-xs, 0.75rem);\n font-family: var(--hx-font-family-sans, sans-serif);\n font-weight: var(--hx-font-weight-semibold, 600);\n color: var(--hx-progress-ring-label-color, var(--hx-color-neutral-900, #0f172a));\n pointer-events: none;\n }\n`;\n","import { LitElement, html, svg, TemplateResult, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property } from 'lit/decorators.js';\nimport { helixProgressRingStyles } from './hx-progress-ring.styles.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\n/**\n * SVG-based circular progress indicator. Supports determinate and indeterminate modes,\n * multiple size variants, semantic color variants, and a center content slot.\n *\n * @summary Circular progress ring for indicating operation progress or loading state.\n *\n * @tag hx-progress-ring\n *\n * @slot - Default slot for center content (percentage text, icon, etc.).\n *\n * @csspart base - The SVG element.\n * @csspart track - The background circle track.\n * @csspart indicator - The progress arc indicator.\n * @csspart label - The center slot wrapper div.\n *\n * @cssprop [--hx-progress-ring-track-color=var(--hx-color-neutral-200)] - Track stroke color.\n * @cssprop [--hx-progress-ring-indicator-color=var(--hx-color-primary-500)] - Indicator stroke color.\n * @cssprop [--hx-progress-ring-label-color=var(--hx-color-neutral-900)] - Center label text color.\n */\n@customElement('hx-progress-ring')\nexport class HelixProgressRing extends LitElement {\n static override styles = [helixProgressRingStyles];\n\n // ─── Public Properties ───\n\n /**\n * Current progress value (0–max). When null, renders in indeterminate mode.\n * @attr value\n */\n @property({ type: Number, reflect: true })\n value: number | null = null;\n\n /**\n * Maximum value for the progress range. Defaults to 100. Used for aria-valuemax.\n * @attr max\n */\n @property({ type: Number, reflect: true })\n max = 100;\n\n /**\n * Size of the ring. Controls SVG diameter.\n * @attr hx-size\n */\n @property({ type: String, reflect: true, attribute: 'hx-size' })\n size: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Stroke width of the ring circles in SVG user units.\n * @attr stroke-width\n */\n @property({ type: Number, attribute: 'stroke-width', reflect: true })\n strokeWidth = 4;\n\n /**\n * Semantic color variant.\n * @attr variant\n */\n @property({ type: String, reflect: true })\n variant: 'default' | 'success' | 'warning' | 'danger' = 'default';\n\n /**\n * Accessible label for the progressbar. Exposed as aria-label.\n * Set this attribute to satisfy WCAG 4.1.2. When absent, aria-busy reflects\n * indeterminate state and a console warning is emitted.\n * @attr label\n */\n @property({ type: String })\n label = '';\n\n // ─── Private Helpers ───\n\n /** @internal */\n private get _isIndeterminate(): boolean {\n return this.value === null;\n }\n\n /** @internal */\n private get _clampedValue(): number {\n if (this.value === null) return 0;\n return Math.min(this.max, Math.max(0, this.value));\n }\n\n /**\n * SVG viewBox is 100x100. Radius leaves room for the stroke.\n */\n /** @internal */\n private get _radius(): number {\n return (100 - this.strokeWidth) / 2;\n }\n\n /** @internal */\n private get _circumference(): number {\n return 2 * Math.PI * this._radius;\n }\n\n /** @internal */\n private get _strokeDashoffset(): number {\n return this._circumference * (1 - this._clampedValue / this.max);\n }\n\n /** @internal */\n private _labelWarned = false;\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Backward compat: accept legacy `size` attribute. When present and `hx-size`\n // is not set, map the value and emit a deprecation warning.\n const legacySize = this.getAttribute('size');\n if (legacySize !== null && !this.hasAttribute('hx-size')) {\n devWarn('hx-progress-ring', 'The \"size\" attribute is deprecated. Use \"hx-size\" instead.');\n this.size = legacySize as 'sm' | 'md' | 'lg';\n }\n this.setAttribute('role', 'progressbar');\n this.setAttribute('aria-valuemin', '0');\n }\n\n protected override willUpdate(_changed: PropertyValues<this>): void {\n // Sync all dynamic ARIA attributes before render\n this.setAttribute('aria-valuemax', String(this.max));\n\n if (this._isIndeterminate) {\n this.setAttribute('indeterminate', '');\n this.setAttribute('aria-busy', 'true');\n this.removeAttribute('aria-valuenow');\n this.removeAttribute('aria-valuetext');\n } else {\n this.removeAttribute('indeterminate');\n this.removeAttribute('aria-busy');\n this.setAttribute('aria-valuenow', String(this._clampedValue));\n this.setAttribute('aria-valuetext', `${this._clampedValue}% complete`);\n }\n\n if (this.label) {\n this.setAttribute('aria-label', this.label);\n } else {\n this.removeAttribute('aria-label');\n if (!this._labelWarned) {\n this._labelWarned = true;\n devWarn(\n 'hx-progress-ring',\n 'Missing accessible label. Set the `label` attribute for WCAG 4.1.2 compliance.',\n );\n }\n }\n }\n\n // ─── Render ───\n\n override render(): TemplateResult {\n const cx = 50;\n const cy = 50;\n const r = this._radius;\n const circumference = this._circumference;\n\n return html`\n <div class=\"progress-ring\">\n <svg\n class=\"progress-ring__svg\"\n part=\"base\"\n viewBox=\"0 0 100 100\"\n aria-hidden=\"true\"\n focusable=\"false\"\n >\n ${svg`\n <circle\n class=\"progress-ring__track\"\n part=\"track\"\n cx=${cx}\n cy=${cy}\n r=${r}\n stroke-width=${this.strokeWidth}\n />\n <circle\n class=\"progress-ring__indicator\"\n part=\"indicator\"\n cx=${cx}\n cy=${cy}\n r=${r}\n stroke-width=${this.strokeWidth}\n stroke-dasharray=${\n this._isIndeterminate ? '1 200' : `${circumference} ${circumference}`\n }\n stroke-dashoffset=${this._isIndeterminate ? '0' : this._strokeDashoffset}\n />\n `}\n </svg>\n <div class=\"progress-ring__label\" part=\"label\">\n <slot></slot>\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-progress-ring': HelixProgressRing;\n }\n}\n"],"names":["helixProgressRingStyles","css","HelixProgressRing","LitElement","legacySize","_changed","r","circumference","html","svg","__decorateClass","property","customElement"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"hx-prose-Ml_L2zje.js","sources":["../../src/styles/prose/prose.scoped.css?raw","../../src/components/hx-prose/hx-prose.styles.ts","../../src/components/hx-prose/hx-prose.ts"],"sourcesContent":["export default \"hx-prose{display:block;font-family:var(--hx-font-family-sans, sans-serif)}hx-prose :is(h1,h2,h3,h4,h5,h6){font-family:var( --hx-prose-heading-font-family, var(--hx-heading-font-family, var(--hx-font-family-sans, sans-serif)) );font-weight:var( --hx-prose-heading-font-weight, var(--hx-heading-font-weight, var(--hx-font-weight-bold, 700)) );line-height:var( --hx-prose-heading-line-height, var(--hx-heading-line-height, var(--hx-line-height-tight, 1.25)) );letter-spacing:var( --hx-prose-heading-letter-spacing, var(--hx-heading-letter-spacing, var(--hx-letter-spacing-tight, -.025em)) );color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));margin-top:0;scroll-margin-top:var(--hx-space-8, 2rem)}hx-prose h1{font-size:var(--hx-prose-h1-font-size, var(--hx-font-size-4xl, 2.25rem));margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose h2{font-size:var(--hx-prose-h2-font-size, var(--hx-font-size-3xl, 1.875rem));margin-bottom:var(--hx-space-5, 1.25rem);padding-bottom:var(--hx-space-3, .75rem);border-bottom:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-subtle, var(--hx-color-neutral-100, #e9ecef))}hx-prose h3{font-size:var(--hx-prose-h3-font-size, var(--hx-font-size-2xl, 1.5rem));margin-bottom:var(--hx-space-4, 1rem)}hx-prose h4{font-size:var(--hx-prose-h4-font-size, var(--hx-font-size-xl, 1.25rem));margin-bottom:var(--hx-space-3, .75rem)}hx-prose h5{font-size:var(--hx-prose-h5-font-size, var(--hx-font-size-lg, 1.125rem));margin-bottom:var(--hx-space-3, .75rem)}hx-prose h6{font-size:var(--hx-prose-h6-font-size, var(--hx-font-size-md, 1rem));font-weight:var(--hx-font-weight-semibold, 600);text-transform:uppercase;letter-spacing:var(--hx-letter-spacing-wide, .025em);margin-bottom:var(--hx-space-3, .75rem);color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057))}hx-prose :is(h1+h2,h2+h3,h3+h4,h4+h5,h5+h6){margin-top:var(--hx-space-2, .5rem)}hx-prose *+h1{margin-top:var(--hx-space-12, 3rem)}hx-prose *+h2{margin-top:var(--hx-space-10, 2.5rem)}hx-prose *+h3{margin-top:var(--hx-space-8, 2rem)}hx-prose :is(*+h4,*+h5,*+h6){margin-top:var(--hx-space-6, 1.5rem)}hx-prose p{margin-top:0;margin-bottom:var(--hx-space-4, 1rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-prose-line-height, var(--hx-line-height-relaxed, 1.75));color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose p.lead{font-size:var(--hx-prose-lead-font-size, var(--hx-font-size-lg, 1.125rem));color:var(--hx-prose-lead-color, var(--hx-color-neutral-600, #495057))}hx-prose blockquote{margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);margin-left:0;margin-right:0;padding:var(--hx-space-4, 1rem) var(--hx-space-6, 1.5rem);border-left:var(--hx-border-width-thick, 3px) solid var(--hx-color-primary-500, #2563eb);background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa));border-radius:0 var(--hx-border-radius-sm, .25rem) var(--hx-border-radius-sm, .25rem) 0;font-style:italic;color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057))}hx-prose blockquote p{color:inherit}hx-prose blockquote p:last-child{margin-bottom:0}hx-prose blockquote cite{display:block;margin-top:var(--hx-space-2, .5rem);font-size:var(--hx-font-size-sm, .875rem);font-style:normal;font-weight:var(--hx-font-weight-medium, 500);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose blockquote cite:before{content:\\\"\\\\2014\\\\a0\\\"}hx-prose hr{border:0;border-top:var(--hx-divider-width, var(--hx-border-width-thin, 1px)) solid var(--hx-divider-color, var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6)));margin-top:var(--hx-space-8, 2rem);margin-bottom:var(--hx-space-8, 2rem)}hx-prose :is(strong,b){font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827))}hx-prose :is(em,i){font-style:italic}hx-prose small{font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose mark{background-color:var(--hx-color-warning-100, #fff3cd);color:var(--hx-color-neutral-900, #0d1117);padding:var(--hx-space-0, 0) var(--hx-space-1, .25rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(del,s){text-decoration:line-through;color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose ins{text-decoration:underline;text-decoration-color:var(--hx-color-success-300, #75b798)}hx-prose abbr[title]{text-decoration:underline dotted;text-decoration-color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));cursor:help;text-underline-offset:.15em}hx-prose :is(sub,sup){font-size:var(--hx-font-size-xs, .75rem);line-height:0;position:relative;vertical-align:baseline}hx-prose sup{top:-.5em}hx-prose sub{bottom:-.25em}hx-prose a{color:var( --hx-prose-link-color, var(--hx-color-text-link, var(--hx-color-primary-600, #006868)) );text-decoration:underline;text-decoration-color:var(--hx-color-primary-200, #80c2c2);text-underline-offset:.15em;transition:color var(--hx-transition-fast, .15s ease),text-decoration-color var(--hx-transition-fast, .15s ease)}hx-prose a:hover{color:var(--hx-color-text-link-hover, var(--hx-color-primary-700, #005252));text-decoration-color:currentColor}hx-prose a:visited{color:var(--hx-color-text-link-visited, var(--hx-color-secondary-600, #4f46e5))}hx-prose a:active{color:var(--hx-color-text-link-active, var(--hx-color-primary-800, #003c3c))}hx-prose a:focus-visible{outline:var(--hx-focus-ring-width, 2px) solid var(--hx-focus-ring-color, var(--hx-color-primary-500, #2563eb));outline-offset:var(--hx-focus-ring-offset, 2px);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(ul,ol){margin-top:0;margin-bottom:var(--hx-space-4, 1rem);padding-left:var(--hx-space-6, 1.5rem);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose ul{list-style-type:disc}hx-prose ol{list-style-type:decimal}hx-prose li{margin-bottom:var(--hx-space-2, .5rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-prose-line-height, var(--hx-line-height-relaxed, 1.75))}hx-prose li:last-child{margin-bottom:0}hx-prose li>p{margin-bottom:var(--hx-space-2, .5rem)}hx-prose li>p:last-child{margin-bottom:0}hx-prose :is(ul ul,ol ul){list-style-type:circle;margin-top:var(--hx-space-2, .5rem);margin-bottom:var(--hx-space-2, .5rem)}hx-prose :is(ul ul ul,ol ul ul,ul ol ul,ol ol ul){list-style-type:square}hx-prose :is(ol ol,ul ol){list-style-type:lower-alpha;margin-top:var(--hx-space-2, .5rem);margin-bottom:var(--hx-space-2, .5rem)}hx-prose :is(ol ol ol,ul ol ol,ol ul ol,ul ul ol){list-style-type:lower-roman}hx-prose :is(ul,ol) ::marker{color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose dl{margin-top:0;margin-bottom:var(--hx-space-4, 1rem)}hx-prose dt{font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));margin-bottom:var(--hx-space-1, .25rem)}hx-prose dt+dt{margin-top:var(--hx-space-4, 1rem)}hx-prose dd{margin-left:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose dd:last-child{margin-bottom:0}hx-prose table{width:100%;border-collapse:collapse;border-spacing:0;margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-line-height-normal, 1.5);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40));overflow-x:auto;display:block}@media(min-width:640px){hx-prose table{display:table}}hx-prose caption{padding-top:var(--hx-space-3, .75rem);padding-bottom:var(--hx-space-3, .75rem);font-size:var(--hx-font-size-sm, .875rem);font-weight:var(--hx-font-weight-medium, 500);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));text-align:left;caption-side:top}hx-prose thead{border-bottom:var(--hx-border-width-medium, 2px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6))}hx-prose tfoot{border-top:var(--hx-border-width-medium, 2px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6))}hx-prose th{padding:var(--hx-space-3, .75rem) var(--hx-space-4, 1rem);font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));text-align:left;background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa))}hx-prose td{padding:var(--hx-space-3, .75rem) var(--hx-space-4, 1rem);border-bottom:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));vertical-align:top}hx-prose tbody tr:nth-child(2n){background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa))}hx-prose tbody tr:hover{background-color:var(--hx-color-primary-50, #e6f3f3)}hx-prose :is(th,td)[align=center]{text-align:center}hx-prose :is(th,td)[align=right]{text-align:right}hx-prose :is(code,pre,kbd,samp){font-family:var( --hx-font-family-mono, \\\"JetBrains Mono\\\", ui-monospace, \\\"Cascadia Code\\\", monospace )}hx-prose code{font-size:var(--hx-font-size-sm, .875em);font-weight:var(--hx-font-weight-normal, 400);background-color:var(--hx-color-surface-sunken, var(--hx-color-neutral-100, #e9ecef));color:var(--hx-color-error-600, #b02a37);padding:var(--hx-prose-code-padding-v, .125em) var(--hx-space-1, .25rem);border-radius:var(--hx-border-radius-sm, .25rem);word-break:break-word}hx-prose pre{margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);padding:var(--hx-space-4, 1rem) var(--hx-space-5, 1.25rem);overflow-x:auto;font-size:var(--hx-font-size-sm, .875rem);line-height:var(--hx-line-height-relaxed, 1.75);color:var(--hx-color-neutral-800, #212529);background-color:var(--hx-color-surface-sunken, var(--hx-color-neutral-100, #e9ecef));border:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));border-radius:var(--hx-border-radius-md, .375rem);-webkit-overflow-scrolling:touch;tab-size:2}hx-prose pre code{background-color:transparent;color:inherit;padding:0;border-radius:0;font-size:inherit;font-weight:inherit;word-break:normal}hx-prose samp{font-size:var(--hx-font-size-sm, .875em)}hx-prose kbd{padding:var(--hx-prose-code-padding-v, .125em) var(--hx-space-2, .5rem);background-color:var(--hx-color-neutral-800, #212529);color:var(--hx-color-neutral-0, #ffffff);border-radius:var(--hx-border-radius-sm, .25rem);box-shadow:var(--hx-shadow-inset-sm, inset 0 -1px 0 rgba(0, 0, 0, .25))}hx-prose var{font-style:italic;color:var(--hx-color-secondary-600, #4f46e5)}hx-prose :is(img,figure>a img){border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose img{max-width:100%;height:auto;display:block}hx-prose figure{margin:0;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose figure img{margin-bottom:0}hx-prose figure>a{display:block}hx-prose figcaption{margin-top:var(--hx-space-2, .5rem);font-size:var(--hx-font-size-sm, .875rem);line-height:var(--hx-line-height-normal, 1.5);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));font-style:italic}hx-prose :is(video,iframe){max-width:100%;display:block;margin-bottom:var(--hx-space-6, 1.5rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose video{height:auto}hx-prose iframe{border:0}hx-prose :is(.embed-responsive,.video-embed,.media-oembed){position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;margin-bottom:var(--hx-space-6, 1.5rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(.embed-responsive,.video-embed,.media-oembed) :is(iframe,video){position:absolute;top:0;left:0;width:100%;height:100%;margin-bottom:0;border-radius:0}hx-prose audio{width:100%;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose :is(object,embed){max-width:100%}hx-prose .field{margin-bottom:var(--hx-space-4, 1rem)}hx-prose .field:last-child{margin-bottom:0}hx-prose .field__label{font-weight:var(--hx-font-weight-semibold, 600);font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057));margin-bottom:var(--hx-space-1, .25rem);text-transform:uppercase;letter-spacing:var(--hx-letter-spacing-wide, .025em)}hx-prose .field__item{margin-bottom:var(--hx-space-2, .5rem)}hx-prose .field__item:last-child{margin-bottom:0}hx-prose .field__items{list-style:none;padding-left:0;margin:0}hx-prose .text-formatted>*:last-child{margin-bottom:0}hx-prose :is(.media-embed,.embedded-entity,.media--type-image,.media--type-remote-video){margin-top:var(--hx-space-4, 1rem);margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose :is(.media-embed,.embedded-entity) img{max-width:100%;height:auto;display:block}hx-prose .align-left{float:left;margin-right:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);max-width:50%}hx-prose .align-right{float:right;margin-left:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);max-width:50%}hx-prose .align-center{display:block;margin-left:auto;margin-right:auto;margin-bottom:var(--hx-space-6, 1.5rem);text-align:center}hx-prose :is(.align-left,.align-right) img{display:block}hx-prose :is(.align-left,.align-right)+*{clear:both}hx-prose .caption{margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose .caption :is(figcaption,.caption-text){font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));font-style:italic;margin-top:var(--hx-space-2, .5rem)}hx-prose .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose .table-responsive table{margin-bottom:0}hx-prose :is(.messages,.callout){padding:var(--hx-space-4, 1rem) var(--hx-space-5, 1.25rem);margin-bottom:var(--hx-space-4, 1rem);border:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));border-radius:var(--hx-border-radius-md, .375rem);border-left-width:var(--hx-border-width-thick, 3px)}hx-prose .messages--status{border-left-color:var(--hx-color-success-500, #198754);background-color:var(--hx-color-success-50, #f0fdf4)}hx-prose .messages--warning{border-left-color:var(--hx-color-warning-500, #ffc107);background-color:var(--hx-color-warning-50, #fffbeb)}hx-prose .messages--error{border-left-color:var(--hx-color-error-500, #dc3545);background-color:var(--hx-color-error-50, #fef2f2)}hx-prose .page-break{border:0;border-top:var(--hx-border-width-thin, 1px) dashed var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));margin-top:var(--hx-space-8, 2rem);margin-bottom:var(--hx-space-8, 2rem)}hx-prose .clearfix:after{content:\\\"\\\";display:table;clear:both}\\n\"","import proseScopedCss from '../../styles/prose/prose.scoped.css?raw';\n\nexport const helixProseScopedCss = proseScopedCss;\n","import { LitElement, html, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { AdoptedStylesheetsController } from '../../controllers/adopted-stylesheets.js';\nimport { devWarn } from '../../utils/dev-warn.js';\nimport { helixProseScopedCss } from './hx-prose.styles.js';\n\n/**\n * A Light DOM prose container that applies typographic styles to rich text\n * content such as CKEditor output, Markdown-rendered HTML, or any structured\n * body copy.\n *\n * Renders in the Light DOM (no Shadow DOM) so that global and scoped styles\n * can target child elements directly. Uses the AdoptedStylesheetsController\n * to inject scoped prose CSS into the document without duplication.\n *\n * @summary Light DOM typography wrapper for rich text and CMS content.\n *\n * @tag hx-prose\n *\n * @slot - Default slot for rich text content (headings, paragraphs, lists, tables, etc.).\n *\n * @cssprop [--hx-prose-max-width=720px] - Maximum content width.\n * @cssprop [--hx-prose-font-size=var(--hx-font-size-base)] - Base font size.\n * @cssprop [--hx-prose-line-height=var(--hx-line-height-relaxed)] - Base line height.\n * @cssprop [--hx-prose-color=var(--hx-color-text)] - Body text color.\n * @cssprop [--hx-prose-heading-color=var(--hx-color-text-strong)] - Heading color.\n * @cssprop [--hx-prose-link-color=var(--hx-color-primary)] - Link color.\n */\n@customElement('hx-prose')\nexport class HelixProse extends LitElement {\n // ─── Light DOM ───\n\n override createRenderRoot(): this {\n return this;\n }\n\n // ─── Adopted Stylesheets ───\n\n private adoptedStyles = new AdoptedStylesheetsController(this, helixProseScopedCss, document);\n\n // ─── Properties ───\n\n /**\n * Typography scale for the prose content.\n * @attr hx-size\n */\n @property({ type: String, reflect: true, attribute: 'hx-size' })\n size: 'sm' | 'base' | 'lg' = 'base';\n\n /**\n * Maximum content width. When set, overrides the --hx-prose-max-width token.\n * Accepts any valid CSS width value (e.g., '640px', '80ch', '100%').\n * @attr max-width\n */\n @property({ type: String, reflect: true, attribute: 'max-width' })\n maxWidth = '';\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Backward compat: accept legacy `size` attribute. When present and `hx-size`\n // is not set, map the value and emit a deprecation warning.\n const legacySize = this.getAttribute('size');\n if (legacySize !== null && !this.hasAttribute('hx-size')) {\n devWarn('hx-prose', 'The \"size\" attribute is deprecated. Use \"hx-size\" instead.');\n this.size = legacySize as 'sm' | 'base' | 'lg';\n }\n this.style.display = 'block';\n this._applyMaxWidth();\n this._applySize();\n }\n\n override updated(changedProperties: PropertyValues<this>): void {\n if (changedProperties.has('maxWidth')) {\n this._applyMaxWidth();\n }\n if (changedProperties.has('size')) {\n this._applySize();\n }\n }\n\n // ─── Private ───\n\n /** @internal */\n private _applyMaxWidth(): void {\n if (this.maxWidth) {\n this.style.setProperty('--hx-prose-max-width', this.maxWidth);\n } else {\n this.style.removeProperty('--hx-prose-max-width');\n }\n }\n\n /** @internal */\n private _applySize(): void {\n const sizeMap: Record<string, string> = {\n sm: 'var(--hx-font-size-sm, 0.875rem)',\n base: '',\n lg: 'var(--hx-font-size-lg, 1.125rem)',\n };\n\n const fontSize = sizeMap[this.size];\n if (fontSize) {\n this.style.setProperty('--hx-prose-font-size', fontSize);\n } else {\n this.style.removeProperty('--hx-prose-font-size');\n }\n }\n\n // ─── Render ───\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-prose': HelixProse;\n }\n}\n"],"names":["proseScopedCss","helixProseScopedCss","HelixProse","LitElement","AdoptedStylesheetsController","legacySize","changedProperties","fontSize","html","__decorateClass","property","customElement"],"mappings":";;;AAAA,MAAAA,IAAe;AAAA,GCEFC,IAAsBD;;;;;;AC2B5B,IAAME,IAAN,cAAyBC,EAAW;AAAA,EAApC,cAAA;AAAA,UAAA,GAAA,SAAA,GASL,KAAQ,gBAAgB,IAAIC,EAA6B,MAAMH,GAAqB,QAAQ,GAS5F,KAAA,OAA6B,QAQ7B,KAAA,WAAW;AAAA,EAAA;AAAA;AAAA,EAvBF,mBAAyB;AAChC,WAAO;AAAA,EACT;AAAA;AAAA,EAyBS,oBAA0B;AACjC,UAAM,kBAAA;AAGN,UAAMI,IAAa,KAAK,aAAa,MAAM;AAC3C,IAAIA,MAAe,QAAQ,CAAC,KAAK,aAAa,SAAS,MAErD,KAAK,OAAOA,IAEd,KAAK,MAAM,UAAU,SACrB,KAAK,eAAA,GACL,KAAK,WAAA;AAAA,EACP;AAAA,EAES,QAAQC,GAA+C;AAC9D,IAAIA,EAAkB,IAAI,UAAU,KAClC,KAAK,eAAA,GAEHA,EAAkB,IAAI,MAAM,KAC9B,KAAK,WAAA;AAAA,EAET;AAAA;AAAA;AAAA,EAKQ,iBAAuB;AAC7B,IAAI,KAAK,WACP,KAAK,MAAM,YAAY,wBAAwB,KAAK,QAAQ,IAE5D,KAAK,MAAM,eAAe,sBAAsB;AAAA,EAEpD;AAAA;AAAA,EAGQ,aAAmB;AAOzB,UAAMC,IANkC;AAAA,MACtC,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,IAAA,EAGmB,KAAK,IAAI;AAClC,IAAIA,IACF,KAAK,MAAM,YAAY,wBAAwBA,CAAQ,IAEvD,KAAK,MAAM,eAAe,sBAAsB;AAAA,EAEpD;AAAA;AAAA,EAIS,SAAS;AAChB,WAAOC;AAAA,EACT;AACF;AAnEEC,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM,WAAW,WAAW;AAAA,GAjBpDR,EAkBX,WAAA,QAAA,CAAA;AAQAO,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM,WAAW,aAAa;AAAA,GAzBtDR,EA0BX,WAAA,YAAA,CAAA;AA1BWA,IAANO,EAAA;AAAA,EADNE,EAAc,UAAU;AAAA,GACZT,CAAA;"}
1
+ {"version":3,"file":"hx-prose-Ml_L2zje.js","sources":["../../src/styles/prose/prose.scoped.css?raw","../../src/components/hx-prose/hx-prose.styles.ts","../../src/components/hx-prose/hx-prose.ts"],"sourcesContent":["export default \"hx-prose{display:block;font-family:var(--hx-font-family-sans, sans-serif)}hx-prose :is(h1,h2,h3,h4,h5,h6){font-family:var( --hx-prose-heading-font-family, var(--hx-heading-font-family, var(--hx-font-family-sans, sans-serif)) );font-weight:var( --hx-prose-heading-font-weight, var(--hx-heading-font-weight, var(--hx-font-weight-bold, 700)) );line-height:var( --hx-prose-heading-line-height, var(--hx-heading-line-height, var(--hx-line-height-tight, 1.25)) );letter-spacing:var( --hx-prose-heading-letter-spacing, var(--hx-heading-letter-spacing, var(--hx-letter-spacing-tight, -.025em)) );color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));margin-top:0;scroll-margin-top:var(--hx-space-8, 2rem)}hx-prose h1{font-size:var(--hx-prose-h1-font-size, var(--hx-font-size-4xl, 2.25rem));margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose h2{font-size:var(--hx-prose-h2-font-size, var(--hx-font-size-3xl, 1.875rem));margin-bottom:var(--hx-space-5, 1.25rem);padding-bottom:var(--hx-space-3, .75rem);border-bottom:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-subtle, var(--hx-color-neutral-100, #e9ecef))}hx-prose h3{font-size:var(--hx-prose-h3-font-size, var(--hx-font-size-2xl, 1.5rem));margin-bottom:var(--hx-space-4, 1rem)}hx-prose h4{font-size:var(--hx-prose-h4-font-size, var(--hx-font-size-xl, 1.25rem));margin-bottom:var(--hx-space-3, .75rem)}hx-prose h5{font-size:var(--hx-prose-h5-font-size, var(--hx-font-size-lg, 1.125rem));margin-bottom:var(--hx-space-3, .75rem)}hx-prose h6{font-size:var(--hx-prose-h6-font-size, var(--hx-font-size-md, 1rem));font-weight:var(--hx-font-weight-semibold, 600);text-transform:uppercase;letter-spacing:var(--hx-letter-spacing-wide, .025em);margin-bottom:var(--hx-space-3, .75rem);color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057))}hx-prose :is(h1+h2,h2+h3,h3+h4,h4+h5,h5+h6){margin-top:var(--hx-space-2, .5rem)}hx-prose *+h1{margin-top:var(--hx-space-12, 3rem)}hx-prose *+h2{margin-top:var(--hx-space-10, 2.5rem)}hx-prose *+h3{margin-top:var(--hx-space-8, 2rem)}hx-prose :is(*+h4,*+h5,*+h6){margin-top:var(--hx-space-6, 1.5rem)}hx-prose p{margin-top:0;margin-bottom:var(--hx-space-4, 1rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-prose-line-height, var(--hx-line-height-relaxed, 1.75));color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose p.lead{font-size:var(--hx-prose-lead-font-size, var(--hx-font-size-lg, 1.125rem));color:var(--hx-prose-lead-color, var(--hx-color-neutral-600, #495057))}hx-prose blockquote{margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);margin-left:0;margin-right:0;padding:var(--hx-space-4, 1rem) var(--hx-space-6, 1.5rem);border-left:var(--hx-border-width-thick, 3px) solid var(--hx-color-primary-500, #2563eb);background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa));border-radius:0 var(--hx-border-radius-sm, .25rem) var(--hx-border-radius-sm, .25rem) 0;font-style:italic;color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057))}hx-prose blockquote p{color:inherit}hx-prose blockquote p:last-child{margin-bottom:0}hx-prose blockquote cite{display:block;margin-top:var(--hx-space-2, .5rem);font-size:var(--hx-font-size-sm, .875rem);font-style:normal;font-weight:var(--hx-font-weight-medium, 500);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose blockquote cite:before{content:\\\"\\\\2014\\\\a0\\\"}hx-prose hr{border:0;border-top:var(--hx-divider-width, var(--hx-border-width-thin, 1px)) solid var(--hx-divider-color, var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6)));margin-top:var(--hx-space-8, 2rem);margin-bottom:var(--hx-space-8, 2rem)}hx-prose :is(strong,b){font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827))}hx-prose :is(em,i){font-style:italic}hx-prose small{font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose mark{background-color:var(--hx-color-warning-100, #fff3cd);color:var(--hx-color-neutral-900, #0d1117);padding:var(--hx-space-0, 0) var(--hx-space-1, .25rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(del,s){text-decoration:line-through;color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose ins{text-decoration:underline;text-decoration-color:var(--hx-color-success-300, #75b798)}hx-prose abbr[title]{text-decoration:underline dotted;text-decoration-color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));cursor:help;text-underline-offset:.15em}hx-prose :is(sub,sup){font-size:var(--hx-font-size-xs, .75rem);line-height:0;position:relative;vertical-align:baseline}hx-prose sup{top:-.5em}hx-prose sub{bottom:-.25em}hx-prose a{color:var( --hx-prose-link-color, var(--hx-color-text-link, var(--hx-color-primary-600, #006868)) );text-decoration:underline;text-decoration-color:var(--hx-color-primary-200, #80c2c2);text-underline-offset:.15em;transition:color var(--hx-transition-fast, .15s ease),text-decoration-color var(--hx-transition-fast, .15s ease)}hx-prose a:hover{color:var(--hx-color-text-link-hover, var(--hx-color-primary-700, #005252));text-decoration-color:currentColor}hx-prose a:visited{color:var(--hx-color-text-link-visited, var(--hx-color-secondary-600, #4f46e5))}hx-prose a:active{color:var(--hx-color-text-link-active, var(--hx-color-primary-800, #003c3c))}hx-prose a:focus-visible{outline:var(--hx-focus-ring-width, 2px) solid var(--hx-focus-ring-color, var(--hx-color-primary-500, #2563eb));outline-offset:var(--hx-focus-ring-offset, 2px);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(ul,ol){margin-top:0;margin-bottom:var(--hx-space-4, 1rem);padding-left:var(--hx-space-6, 1.5rem);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose ul{list-style-type:disc}hx-prose ol{list-style-type:decimal}hx-prose li{margin-bottom:var(--hx-space-2, .5rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-prose-line-height, var(--hx-line-height-relaxed, 1.75))}hx-prose li:last-child{margin-bottom:0}hx-prose li>p{margin-bottom:var(--hx-space-2, .5rem)}hx-prose li>p:last-child{margin-bottom:0}hx-prose :is(ul ul,ol ul){list-style-type:circle;margin-top:var(--hx-space-2, .5rem);margin-bottom:var(--hx-space-2, .5rem)}hx-prose :is(ul ul ul,ol ul ul,ul ol ul,ol ol ul){list-style-type:square}hx-prose :is(ol ol,ul ol){list-style-type:lower-alpha;margin-top:var(--hx-space-2, .5rem);margin-bottom:var(--hx-space-2, .5rem)}hx-prose :is(ol ol ol,ul ol ol,ol ul ol,ul ul ol){list-style-type:lower-roman}hx-prose :is(ul,ol) ::marker{color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d))}hx-prose dl{margin-top:0;margin-bottom:var(--hx-space-4, 1rem)}hx-prose dt{font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));margin-bottom:var(--hx-space-1, .25rem)}hx-prose dt+dt{margin-top:var(--hx-space-4, 1rem)}hx-prose dd{margin-left:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40))}hx-prose dd:last-child{margin-bottom:0}hx-prose table{width:100%;border-collapse:collapse;border-spacing:0;margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);font-size:var(--hx-prose-font-size, var(--hx-font-size-md, 1rem));line-height:var(--hx-line-height-normal, 1.5);color:var(--hx-prose-color, var(--hx-color-neutral-700, #343a40));overflow-x:auto;display:block}@media(min-width:640px){hx-prose table{display:table}}hx-prose caption{padding-top:var(--hx-space-3, .75rem);padding-bottom:var(--hx-space-3, .75rem);font-size:var(--hx-font-size-sm, .875rem);font-weight:var(--hx-font-weight-medium, 500);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));text-align:left;caption-side:top}hx-prose thead{border-bottom:var(--hx-border-width-medium, 2px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6))}hx-prose tfoot{border-top:var(--hx-border-width-medium, 2px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6))}hx-prose th{padding:var(--hx-space-3, .75rem) var(--hx-space-4, 1rem);font-weight:var(--hx-font-weight-semibold, 600);color:var(--hx-prose-heading-color, var(--hx-color-neutral-900, #111827));text-align:left;background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa))}hx-prose td{padding:var(--hx-space-3, .75rem) var(--hx-space-4, 1rem);border-bottom:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));vertical-align:top}hx-prose tbody tr:nth-child(2n){background-color:var(--hx-color-surface-raised, var(--hx-color-neutral-50, #f8f9fa))}hx-prose tbody tr:hover{background-color:var(--hx-color-primary-50, #e6f3f3)}hx-prose :is(th,td)[align=center]{text-align:center}hx-prose :is(th,td)[align=right]{text-align:right}hx-prose :is(code,pre,kbd,samp){font-family:var( --hx-font-family-mono, \\\"JetBrains Mono\\\", ui-monospace, \\\"Cascadia Code\\\", monospace )}hx-prose code{font-size:var(--hx-font-size-sm, .875em);font-weight:var(--hx-font-weight-normal, 400);background-color:var(--hx-color-surface-sunken, var(--hx-color-neutral-100, #e9ecef));color:var(--hx-color-error-600, #b02a37);padding:var(--hx-prose-code-padding-v, .125em) var(--hx-space-1, .25rem);border-radius:var(--hx-border-radius-sm, .25rem);word-break:break-word}hx-prose pre{margin-top:0;margin-bottom:var(--hx-space-6, 1.5rem);padding:var(--hx-space-4, 1rem) var(--hx-space-5, 1.25rem);overflow-x:auto;font-size:var(--hx-font-size-sm, .875rem);line-height:var(--hx-line-height-relaxed, 1.75);color:var(--hx-color-neutral-800, #212529);background-color:var(--hx-color-surface-sunken, var(--hx-color-neutral-100, #e9ecef));border:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));border-radius:var(--hx-border-radius-md, .375rem);-webkit-overflow-scrolling:touch;tab-size:2}hx-prose pre code{background-color:transparent;color:inherit;padding:0;border-radius:0;font-size:inherit;font-weight:inherit;word-break:normal}hx-prose samp{font-size:var(--hx-font-size-sm, .875em)}hx-prose kbd{padding:var(--hx-prose-code-padding-v, .125em) var(--hx-space-2, .5rem);background-color:var(--hx-color-neutral-800, #212529);color:var(--hx-color-neutral-0, #ffffff);border-radius:var(--hx-border-radius-sm, .25rem);box-shadow:var(--hx-shadow-inset-sm, inset 0 -1px 0 rgba(0, 0, 0, .25))}hx-prose var{font-style:italic;color:var(--hx-color-secondary-600, #4f46e5)}hx-prose :is(img,figure>a img){border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose img{max-width:100%;height:auto;display:block}hx-prose figure{margin:0;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose figure img{margin-bottom:0}hx-prose figure>a{display:block}hx-prose figcaption{margin-top:var(--hx-space-2, .5rem);font-size:var(--hx-font-size-sm, .875rem);line-height:var(--hx-line-height-normal, 1.5);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));font-style:italic}hx-prose :is(video,iframe){max-width:100%;display:block;margin-bottom:var(--hx-space-6, 1.5rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose video{height:auto}hx-prose iframe{border:0}hx-prose :is(.embed-responsive,.video-embed,.media-oembed){position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;margin-bottom:var(--hx-space-6, 1.5rem);border-radius:var(--hx-border-radius-sm, .25rem)}hx-prose :is(.embed-responsive,.video-embed,.media-oembed) :is(iframe,video){position:absolute;top:0;left:0;width:100%;height:100%;margin-bottom:0;border-radius:0}hx-prose audio{width:100%;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose :is(object,embed){max-width:100%}hx-prose .field{margin-bottom:var(--hx-space-4, 1rem)}hx-prose .field:last-child{margin-bottom:0}hx-prose .field__label{font-weight:var(--hx-font-weight-semibold, 600);font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-secondary, var(--hx-color-neutral-600, #495057));margin-bottom:var(--hx-space-1, .25rem);text-transform:uppercase;letter-spacing:var(--hx-letter-spacing-wide, .025em)}hx-prose .field__item{margin-bottom:var(--hx-space-2, .5rem)}hx-prose .field__item:last-child{margin-bottom:0}hx-prose .field__items{list-style:none;padding-left:0;margin:0}hx-prose .text-formatted>*:last-child{margin-bottom:0}hx-prose :is(.media-embed,.embedded-entity,.media--type-image,.media--type-remote-video){margin-top:var(--hx-space-4, 1rem);margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose :is(.media-embed,.embedded-entity) img{max-width:100%;height:auto;display:block}hx-prose .align-left{float:left;margin-right:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);max-width:50%}hx-prose .align-right{float:right;margin-left:var(--hx-space-6, 1.5rem);margin-bottom:var(--hx-space-4, 1rem);max-width:50%}hx-prose .align-center{display:block;margin-left:auto;margin-right:auto;margin-bottom:var(--hx-space-6, 1.5rem);text-align:center}hx-prose :is(.align-left,.align-right) img{display:block}hx-prose :is(.align-left,.align-right)+*{clear:both}hx-prose .caption{margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose .caption :is(figcaption,.caption-text){font-size:var(--hx-font-size-sm, .875rem);color:var(--hx-color-text-muted, var(--hx-color-neutral-500, #6c757d));font-style:italic;margin-top:var(--hx-space-2, .5rem)}hx-prose .table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--hx-space-6, 1.5rem)}hx-prose .table-responsive table{margin-bottom:0}hx-prose :is(.messages,.callout){padding:var(--hx-space-4, 1rem) var(--hx-space-5, 1.25rem);margin-bottom:var(--hx-space-4, 1rem);border:var(--hx-border-width-thin, 1px) solid var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));border-radius:var(--hx-border-radius-md, .375rem);border-left-width:var(--hx-border-width-thick, 3px)}hx-prose .messages--status{border-left-color:var(--hx-color-success-500, #198754);background-color:var(--hx-color-success-50, #f0fdf4)}hx-prose .messages--warning{border-left-color:var(--hx-color-warning-500, #ffc107);background-color:var(--hx-color-warning-50, #fffbeb)}hx-prose .messages--error{border-left-color:var(--hx-color-error-500, #dc3545);background-color:var(--hx-color-error-50, #fef2f2)}hx-prose .page-break{border:0;border-top:var(--hx-border-width-thin, 1px) dashed var(--hx-color-border-default, var(--hx-color-neutral-200, #dee2e6));margin-top:var(--hx-space-8, 2rem);margin-bottom:var(--hx-space-8, 2rem)}hx-prose .clearfix:after{content:\\\"\\\";display:table;clear:both}\\n\"","import proseScopedCss from '../../styles/prose/prose.scoped.css?raw';\n\nexport const helixProseScopedCss = proseScopedCss;\n","import { LitElement, html, type PropertyValues } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { AdoptedStylesheetsController } from '../../controllers/adopted-stylesheets.js';\nimport { devWarn } from '../../utils/dev-warn.js';\nimport { helixProseScopedCss } from './hx-prose.styles.js';\n\n/**\n * A Light DOM prose container that applies typographic styles to rich text\n * content such as CKEditor output, Markdown-rendered HTML, or any structured\n * body copy.\n *\n * Renders in the Light DOM (no Shadow DOM) so that global and scoped styles\n * can target child elements directly. Uses the AdoptedStylesheetsController\n * to inject scoped prose CSS into the document without duplication.\n *\n * @summary Light DOM typography wrapper for rich text and CMS content.\n *\n * @tag hx-prose\n *\n * @slot - Default slot for rich text content (headings, paragraphs, lists, tables, etc.).\n *\n * @cssprop [--hx-prose-max-width=720px] - Maximum content width.\n * @cssprop [--hx-prose-font-size=var(--hx-font-size-base)] - Base font size.\n * @cssprop [--hx-prose-line-height=var(--hx-line-height-relaxed)] - Base line height.\n * @cssprop [--hx-prose-color=var(--hx-color-text)] - Body text color.\n * @cssprop [--hx-prose-heading-color=var(--hx-color-text-strong)] - Heading color.\n * @cssprop [--hx-prose-link-color=var(--hx-color-primary)] - Link color.\n */\n@customElement('hx-prose')\nexport class HelixProse extends LitElement {\n // ─── Light DOM ───\n\n override createRenderRoot(): this {\n return this;\n }\n\n // ─── Adopted Stylesheets ───\n\n /** @internal */\n private adoptedStyles = new AdoptedStylesheetsController(this, helixProseScopedCss, document);\n\n // ─── Properties ───\n\n /**\n * Typography scale for the prose content.\n * @attr hx-size\n */\n @property({ type: String, reflect: true, attribute: 'hx-size' })\n size: 'sm' | 'base' | 'lg' = 'base';\n\n /**\n * Maximum content width. When set, overrides the --hx-prose-max-width token.\n * Accepts any valid CSS width value (e.g., '640px', '80ch', '100%').\n * @attr max-width\n */\n @property({ type: String, reflect: true, attribute: 'max-width' })\n maxWidth = '';\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n // Backward compat: accept legacy `size` attribute. When present and `hx-size`\n // is not set, map the value and emit a deprecation warning.\n const legacySize = this.getAttribute('size');\n if (legacySize !== null && !this.hasAttribute('hx-size')) {\n devWarn('hx-prose', 'The \"size\" attribute is deprecated. Use \"hx-size\" instead.');\n this.size = legacySize as 'sm' | 'base' | 'lg';\n }\n this.style.display = 'block';\n this._applyMaxWidth();\n this._applySize();\n }\n\n override updated(changedProperties: PropertyValues<this>): void {\n if (changedProperties.has('maxWidth')) {\n this._applyMaxWidth();\n }\n if (changedProperties.has('size')) {\n this._applySize();\n }\n }\n\n // ─── Private ───\n\n /** @internal */\n private _applyMaxWidth(): void {\n if (this.maxWidth) {\n this.style.setProperty('--hx-prose-max-width', this.maxWidth);\n } else {\n this.style.removeProperty('--hx-prose-max-width');\n }\n }\n\n /** @internal */\n private _applySize(): void {\n const sizeMap: Record<string, string> = {\n sm: 'var(--hx-font-size-sm, 0.875rem)',\n base: '',\n lg: 'var(--hx-font-size-lg, 1.125rem)',\n };\n\n const fontSize = sizeMap[this.size];\n if (fontSize) {\n this.style.setProperty('--hx-prose-font-size', fontSize);\n } else {\n this.style.removeProperty('--hx-prose-font-size');\n }\n }\n\n // ─── Render ───\n\n override render() {\n return html`<slot></slot>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-prose': HelixProse;\n }\n}\n"],"names":["proseScopedCss","helixProseScopedCss","HelixProse","LitElement","AdoptedStylesheetsController","legacySize","changedProperties","fontSize","html","__decorateClass","property","customElement"],"mappings":";;;AAAA,MAAAA,IAAe;AAAA,GCEFC,IAAsBD;;;;;;AC2B5B,IAAME,IAAN,cAAyBC,EAAW;AAAA,EAApC,cAAA;AAAA,UAAA,GAAA,SAAA,GAUL,KAAQ,gBAAgB,IAAIC,EAA6B,MAAMH,GAAqB,QAAQ,GAS5F,KAAA,OAA6B,QAQ7B,KAAA,WAAW;AAAA,EAAA;AAAA;AAAA,EAxBF,mBAAyB;AAChC,WAAO;AAAA,EACT;AAAA;AAAA,EA0BS,oBAA0B;AACjC,UAAM,kBAAA;AAGN,UAAMI,IAAa,KAAK,aAAa,MAAM;AAC3C,IAAIA,MAAe,QAAQ,CAAC,KAAK,aAAa,SAAS,MAErD,KAAK,OAAOA,IAEd,KAAK,MAAM,UAAU,SACrB,KAAK,eAAA,GACL,KAAK,WAAA;AAAA,EACP;AAAA,EAES,QAAQC,GAA+C;AAC9D,IAAIA,EAAkB,IAAI,UAAU,KAClC,KAAK,eAAA,GAEHA,EAAkB,IAAI,MAAM,KAC9B,KAAK,WAAA;AAAA,EAET;AAAA;AAAA;AAAA,EAKQ,iBAAuB;AAC7B,IAAI,KAAK,WACP,KAAK,MAAM,YAAY,wBAAwB,KAAK,QAAQ,IAE5D,KAAK,MAAM,eAAe,sBAAsB;AAAA,EAEpD;AAAA;AAAA,EAGQ,aAAmB;AAOzB,UAAMC,IANkC;AAAA,MACtC,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,IAAA,EAGmB,KAAK,IAAI;AAClC,IAAIA,IACF,KAAK,MAAM,YAAY,wBAAwBA,CAAQ,IAEvD,KAAK,MAAM,eAAe,sBAAsB;AAAA,EAEpD;AAAA;AAAA,EAIS,SAAS;AAChB,WAAOC;AAAA,EACT;AACF;AAnEEC,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM,WAAW,WAAW;AAAA,GAlBpDR,EAmBX,WAAA,QAAA,CAAA;AAQAO,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM,WAAW,aAAa;AAAA,GA1BtDR,EA2BX,WAAA,YAAA,CAAA;AA3BWA,IAANO,EAAA;AAAA,EADNE,EAAc,UAAU;AAAA,GACZT,CAAA;"}
@@ -1,8 +1,8 @@
1
1
  import { css as g, LitElement as m, nothing as h, html as p } from "lit";
2
- import { property as d, state as R, customElement as y } from "lit/decorators.js";
2
+ import "./document-token-adoption-DuYNKd4k.js";
3
+ import { property as d, state as w, customElement as y } from "lit/decorators.js";
3
4
  import { classMap as k } from "lit/directives/class-map.js";
4
- import { tokenStyles as w } from "@helixui/tokens/lit";
5
- const S = g`
5
+ const R = g`
6
6
  :host {
7
7
  display: block;
8
8
  }
@@ -80,14 +80,14 @@ const S = g`
80
80
  line-height: var(--hx-line-height-normal, 1.5);
81
81
  }
82
82
  `;
83
- var E = Object.defineProperty, C = Object.getOwnPropertyDescriptor, n = (e, r, s, t) => {
84
- for (var i = t > 1 ? void 0 : t ? C(r, s) : r, a = e.length - 1, l; a >= 0; a--)
83
+ var S = Object.defineProperty, E = Object.getOwnPropertyDescriptor, n = (e, r, s, t) => {
84
+ for (var i = t > 1 ? void 0 : t ? E(r, s) : r, a = e.length - 1, l; a >= 0; a--)
85
85
  (l = e[a]) && (i = (t ? l(r, s, i) : l(i)) || i);
86
- return t && i && E(r, s, i), i;
86
+ return t && i && S(r, s, i), i;
87
87
  };
88
- let $ = 0, o = class extends m {
88
+ let C = 0, o = class extends m {
89
89
  constructor() {
90
- super(), this.value = "", this.name = "", this.label = "", this.required = !1, this.disabled = !1, this.error = "", this.helpText = "", this.orientation = "vertical", this._hasErrorSlot = !1, this._groupId = `hx-radio-group-${++$}`, this._helpTextId = `${this._groupId}-help`, this._errorId = `${this._groupId}-error`, this._cachedRadios = null, this._individualDisabledStates = /* @__PURE__ */ new WeakMap(), this._handleRadioSelect = (e) => {
90
+ super(), this.value = "", this.name = "", this.label = "", this.required = !1, this.disabled = !1, this.error = "", this.helpText = "", this.orientation = "vertical", this._hasErrorSlot = !1, this._groupId = `hx-radio-group-${++C}`, this._helpTextId = `${this._groupId}-help`, this._errorId = `${this._groupId}-error`, this._cachedRadios = null, this._individualDisabledStates = /* @__PURE__ */ new WeakMap(), this._handleRadioSelect = (e) => {
91
91
  if (!(e instanceof CustomEvent)) return;
92
92
  e.stopPropagation();
93
93
  const r = e.detail.value;
@@ -99,7 +99,7 @@ let $ = 0, o = class extends m {
99
99
  })
100
100
  ));
101
101
  }, this._handleKeydown = (e) => {
102
- var v, b, x, _;
102
+ var b, x, v, _;
103
103
  const r = this._getEnabledRadios();
104
104
  if (r.length === 0 || ![
105
105
  "ArrowUp",
@@ -112,7 +112,7 @@ let $ = 0, o = class extends m {
112
112
  ].includes(e.key))
113
113
  return;
114
114
  if (e.preventDefault(), e.key === " ") {
115
- const u = (b = (v = e.target) == null ? void 0 : v.closest) == null ? void 0 : b.call(v, "hx-radio");
115
+ const u = (x = (b = e.target) == null ? void 0 : b.closest) == null ? void 0 : x.call(b, "hx-radio");
116
116
  u && !u.disabled && u.dispatchEvent(
117
117
  new CustomEvent("hx-radio-select", {
118
118
  bubbles: !0,
@@ -122,7 +122,7 @@ let $ = 0, o = class extends m {
122
122
  );
123
123
  return;
124
124
  }
125
- const t = (_ = (x = e.target) == null ? void 0 : x.closest) == null ? void 0 : _.call(x, "hx-radio"), i = t ? r.indexOf(t) : r.findIndex((u) => u.checked);
125
+ const t = (_ = (v = e.target) == null ? void 0 : v.closest) == null ? void 0 : _.call(v, "hx-radio"), i = t ? r.indexOf(t) : r.findIndex((u) => u.checked);
126
126
  let a;
127
127
  e.key === "Home" ? a = 0 : e.key === "End" ? a = r.length - 1 : e.key === "ArrowDown" || e.key === "ArrowRight" ? a = i === -1 ? 0 : (i + 1) % r.length : a = i <= 0 ? r.length - 1 : i - 1;
128
128
  const l = r[a];
@@ -162,7 +162,7 @@ let $ = 0, o = class extends m {
162
162
  super.updated(e), e.has("value") && (this._internals.setFormValue(this.value || null), this._syncRadios(), this._updateValidity()), e.has("disabled") && this._syncRadios();
163
163
  }
164
164
  firstUpdated(e) {
165
- super.firstUpdated(e), this._syncRadios(), this._updateValidity();
165
+ super.firstUpdated(e), this._syncRadios(), this._updateValidity(), !this.label && this.getAttribute("aria-label");
166
166
  }
167
167
  /**
168
168
  * Returns all child hx-radio elements, using the cache when available.
@@ -257,19 +257,15 @@ let $ = 0, o = class extends m {
257
257
  this._groupEl ?? void 0
258
258
  ) : this._internals.setValidity({});
259
259
  }
260
- /** Called by the form when it resets. */
260
+ /** @internal */
261
261
  formResetCallback() {
262
262
  this.value = "", this._internals.setFormValue(null), this._syncRadios();
263
263
  }
264
- /**
265
- * Called when the form restores state (e.g., back/forward navigation).
266
- * @param state - The saved form state value.
267
- * @param _mode - The restore mode: `'restore'` or `'autocomplete'`.
268
- */
264
+ /** @internal */
269
265
  formStateRestoreCallback(e, r) {
270
266
  typeof e == "string" && (this.value = e);
271
267
  }
272
- /** Called when a parent fieldset is disabled/enabled. */
268
+ /** @internal */
273
269
  formDisabledCallback(e) {
274
270
  this.disabled = e;
275
271
  }
@@ -280,14 +276,14 @@ let $ = 0, o = class extends m {
280
276
  "fieldset--error": e,
281
277
  "fieldset--disabled": this.disabled,
282
278
  "fieldset--required": this.required
283
- }, t = !this._hasErrorSlot && e ? this._errorId : h, i = t !== h ? t : this.helpText ? this._helpTextId : h;
279
+ }, t = !!this.helpText, a = [e ? this._errorId : null, t ? this._helpTextId : null].filter(Boolean).join(" ") || h;
284
280
  return p`
285
281
  <fieldset
286
282
  part="fieldset"
287
283
  class=${k(s)}
288
284
  role="radiogroup"
289
285
  aria-labelledby=${this.label ? r : h}
290
- aria-describedby=${i}
286
+ aria-describedby=${a}
291
287
  aria-required=${this.required ? "true" : h}
292
288
  >
293
289
  ${this.label ? p`
@@ -301,11 +297,13 @@ let $ = 0, o = class extends m {
301
297
  <slot @slotchange=${this._handleSlotChange}></slot>
302
298
  </div>
303
299
 
304
- <slot name="error" @slotchange=${this._handleErrorSlotChange}>
305
- ${e ? p`<div part="error" class="fieldset__error" id=${this._errorId} role="alert">
306
- ${this.error}
307
- </div>` : h}
308
- </slot>
300
+ <!-- WCAG 1.3.1: wrap slot in a persistent container so _errorId stays stable
301
+ regardless of whether error content comes from the slot or the property. -->
302
+ <div id=${this._errorId}>
303
+ <slot name="error" @slotchange=${this._handleErrorSlotChange}>
304
+ ${e ? p`<div part="error" class="fieldset__error" role="alert">${this.error}</div>` : h}
305
+ </slot>
306
+ </div>
309
307
 
310
308
  ${this.helpText && !e ? p`
311
309
  <div part="help-text" class="fieldset__help-text" id=${this._helpTextId}>
@@ -316,7 +314,7 @@ let $ = 0, o = class extends m {
316
314
  `;
317
315
  }
318
316
  };
319
- o.styles = [w, S];
317
+ o.styles = [R];
320
318
  o.formAssociated = !0;
321
319
  n([
322
320
  d({ type: String })
@@ -343,12 +341,12 @@ n([
343
341
  d({ type: String, reflect: !0 })
344
342
  ], o.prototype, "orientation", 2);
345
343
  n([
346
- R()
344
+ w()
347
345
  ], o.prototype, "_hasErrorSlot", 2);
348
346
  o = n([
349
347
  y("hx-radio-group")
350
348
  ], o);
351
- const I = g`
349
+ const $ = g`
352
350
  :host {
353
351
  display: block;
354
352
  }
@@ -436,7 +434,10 @@ const I = g`
436
434
 
437
435
  :host(:focus-visible) .radio__control {
438
436
  outline: var(--hx-focus-ring-width, 2px) solid
439
- var(--hx-radio-focus-ring-color, var(--hx-focus-ring-color, #2563eb));
437
+ var(
438
+ --hx-radio-focus-ring-color,
439
+ var(--hx-focus-ring-color, var(--hx-color-primary-400, #60a5fa))
440
+ );
440
441
  outline-offset: var(--hx-focus-ring-offset, 2px);
441
442
  }
442
443
 
@@ -465,21 +466,21 @@ const I = g`
465
466
  }
466
467
  }
467
468
  `;
468
- var z = Object.defineProperty, D = Object.getOwnPropertyDescriptor, f = (e, r, s, t) => {
469
- for (var i = t > 1 ? void 0 : t ? D(r, s) : r, a = e.length - 1, l; a >= 0; a--)
469
+ var I = Object.defineProperty, A = Object.getOwnPropertyDescriptor, f = (e, r, s, t) => {
470
+ for (var i = t > 1 ? void 0 : t ? A(r, s) : r, a = e.length - 1, l; a >= 0; a--)
470
471
  (l = e[a]) && (i = (t ? l(r, s, i) : l(i)) || i);
471
- return t && i && z(r, s, i), i;
472
+ return t && i && I(r, s, i), i;
472
473
  };
473
- let A = 0, c = class extends m {
474
+ let z = 0, c = class extends m {
474
475
  constructor() {
475
- super(...arguments), this.value = "", this.label = "", this.disabled = !1, this.checked = !1, this._inputId = `hx-radio-${++A}`;
476
+ super(...arguments), this.value = "", this.label = "", this.disabled = !1, this.checked = !1, this._inputId = `hx-radio-${++z}`;
476
477
  }
477
478
  // ─── Lifecycle ───
478
479
  connectedCallback() {
479
- super.connectedCallback(), this.setAttribute("role", "radio"), this.setAttribute("aria-checked", String(this.checked)), this.setAttribute("aria-disabled", String(this.disabled));
480
+ super.connectedCallback(), this.setAttribute("role", "radio"), this.setAttribute("aria-checked", String(this.checked)), this.label && this.setAttribute("aria-label", this.label), this.disabled ? this.setAttribute("aria-disabled", "true") : this.removeAttribute("aria-disabled");
480
481
  }
481
482
  updated(e) {
482
- super.updated(e), e.has("checked") && this.setAttribute("aria-checked", String(this.checked)), e.has("disabled") && this.setAttribute("aria-disabled", String(this.disabled));
483
+ super.updated(e), e.has("checked") && this.setAttribute("aria-checked", String(this.checked)), e.has("label") && (this.label ? this.setAttribute("aria-label", this.label) : this.removeAttribute("aria-label")), e.has("disabled") && (this.disabled ? this.setAttribute("aria-disabled", "true") : this.removeAttribute("aria-disabled"));
483
484
  }
484
485
  // ─── Event Handling ───
485
486
  /** @internal */
@@ -520,7 +521,7 @@ let A = 0, c = class extends m {
520
521
  `;
521
522
  }
522
523
  };
523
- c.styles = [w, I];
524
+ c.styles = [$];
524
525
  f([
525
526
  d({ type: String })
526
527
  ], c.prototype, "value", 2);
@@ -540,4 +541,4 @@ export {
540
541
  c as H,
541
542
  o as a
542
543
  };
543
- //# sourceMappingURL=hx-radio-BywgVSEu.js.map
544
+ //# sourceMappingURL=hx-radio-f8c5ggHG.js.map