@helixui/library 2.1.2-next.53 → 2.1.2-next.57

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 (753) hide show
  1. package/custom-elements.json +847 -1038
  2. package/dist/base/helix-element.d.ts +20 -8
  3. package/dist/base/helix-element.d.ts.map +1 -1
  4. package/dist/components/hx-accordion/hx-accordion-item.d.ts +7 -2
  5. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  6. package/dist/components/hx-accordion/hx-accordion.d.ts +3 -2
  7. package/dist/components/hx-accordion/hx-accordion.d.ts.map +1 -1
  8. package/dist/components/hx-accordion/index.d.ts +1 -0
  9. package/dist/components/hx-accordion/index.d.ts.map +1 -1
  10. package/dist/components/hx-accordion/index.js +1 -1
  11. package/dist/components/hx-action-bar/hx-action-bar.d.ts +2 -11
  12. package/dist/components/hx-action-bar/hx-action-bar.d.ts.map +1 -1
  13. package/dist/components/hx-action-bar/hx-action-bar.styles.d.ts.map +1 -1
  14. package/dist/components/hx-action-bar/index.js +1 -1
  15. package/dist/components/hx-alert/hx-alert.d.ts +7 -2
  16. package/dist/components/hx-alert/hx-alert.d.ts.map +1 -1
  17. package/dist/components/hx-alert/index.d.ts +1 -0
  18. package/dist/components/hx-alert/index.d.ts.map +1 -1
  19. package/dist/components/hx-alert/index.js +1 -1
  20. package/dist/components/hx-avatar/hx-avatar.d.ts +3 -2
  21. package/dist/components/hx-avatar/hx-avatar.d.ts.map +1 -1
  22. package/dist/components/hx-avatar/index.js +1 -1
  23. package/dist/components/hx-badge/hx-badge.d.ts +2 -9
  24. package/dist/components/hx-badge/hx-badge.d.ts.map +1 -1
  25. package/dist/components/hx-badge/index.d.ts +1 -1
  26. package/dist/components/hx-badge/index.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 +3 -2
  29. package/dist/components/hx-banner/hx-banner.d.ts.map +1 -1
  30. package/dist/components/hx-banner/index.js +1 -1
  31. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts +2 -2
  32. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts.map +1 -1
  33. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +9 -12
  34. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  35. package/dist/components/hx-breadcrumb/hx-breadcrumb.styles.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 -0
  38. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  39. package/dist/components/hx-button/index.d.ts +1 -0
  40. package/dist/components/hx-button/index.d.ts.map +1 -1
  41. package/dist/components/hx-button/index.js +1 -1
  42. package/dist/components/hx-button-group/hx-button-group.d.ts +3 -2
  43. package/dist/components/hx-button-group/hx-button-group.d.ts.map +1 -1
  44. package/dist/components/hx-button-group/hx-button-group.styles.d.ts.map +1 -1
  45. package/dist/components/hx-button-group/index.js +1 -1
  46. package/dist/components/hx-card/hx-card.d.ts +3 -2
  47. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  48. package/dist/components/hx-card/index.js +1 -1
  49. package/dist/components/hx-carousel/hx-carousel-item.d.ts +2 -2
  50. package/dist/components/hx-carousel/hx-carousel-item.d.ts.map +1 -1
  51. package/dist/components/hx-carousel/hx-carousel-item.styles.d.ts.map +1 -1
  52. package/dist/components/hx-carousel/hx-carousel.d.ts +2 -2
  53. package/dist/components/hx-carousel/hx-carousel.d.ts.map +1 -1
  54. package/dist/components/hx-carousel/index.js +1 -1
  55. package/dist/components/hx-checkbox/hx-checkbox.d.ts +44 -5
  56. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  57. package/dist/components/hx-checkbox/index.d.ts +1 -0
  58. package/dist/components/hx-checkbox/index.d.ts.map +1 -1
  59. package/dist/components/hx-checkbox/index.js +1 -1
  60. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +9 -13
  61. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  62. package/dist/components/hx-checkbox-group/index.d.ts +1 -0
  63. package/dist/components/hx-checkbox-group/index.d.ts.map +1 -1
  64. package/dist/components/hx-checkbox-group/index.js +1 -1
  65. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts +0 -7
  66. package/dist/components/hx-clinical-status/hx-clinical-status.d.ts.map +1 -1
  67. package/dist/components/hx-clinical-status/index.js +1 -1
  68. package/dist/components/hx-code-snippet/index.js +1 -1
  69. package/dist/components/hx-color-picker/hx-color-picker.d.ts +8 -11
  70. package/dist/components/hx-color-picker/hx-color-picker.d.ts.map +1 -1
  71. package/dist/components/hx-color-picker/hx-color-picker.styles.d.ts.map +1 -1
  72. package/dist/components/hx-color-picker/index.d.ts +1 -0
  73. package/dist/components/hx-color-picker/index.d.ts.map +1 -1
  74. package/dist/components/hx-color-picker/index.js +1 -1
  75. package/dist/components/hx-combobox/hx-combobox.d.ts +32 -15
  76. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  77. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  78. package/dist/components/hx-combobox/index.d.ts +1 -0
  79. package/dist/components/hx-combobox/index.d.ts.map +1 -1
  80. package/dist/components/hx-combobox/index.js +1 -1
  81. package/dist/components/hx-container/hx-container.d.ts +2 -4
  82. package/dist/components/hx-container/hx-container.d.ts.map +1 -1
  83. package/dist/components/hx-container/hx-container.styles.d.ts.map +1 -1
  84. package/dist/components/hx-container/index.d.ts +0 -1
  85. package/dist/components/hx-container/index.d.ts.map +1 -1
  86. package/dist/components/hx-container/index.js +1 -1
  87. package/dist/components/hx-copy-button/hx-copy-button.d.ts +2 -2
  88. package/dist/components/hx-copy-button/hx-copy-button.d.ts.map +1 -1
  89. package/dist/components/hx-copy-button/index.js +1 -1
  90. package/dist/components/hx-counter/hx-counter.d.ts +3 -2
  91. package/dist/components/hx-counter/hx-counter.d.ts.map +1 -1
  92. package/dist/components/hx-counter/hx-counter.styles.d.ts.map +1 -1
  93. package/dist/components/hx-counter/index.js +1 -1
  94. package/dist/components/hx-data-table/hx-data-table.d.ts +26 -2
  95. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  96. package/dist/components/hx-data-table/index.d.ts +1 -0
  97. package/dist/components/hx-data-table/index.d.ts.map +1 -1
  98. package/dist/components/hx-data-table/index.js +1 -1
  99. package/dist/components/hx-date-picker/hx-date-picker.d.ts +30 -19
  100. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  101. package/dist/components/hx-date-picker/hx-date-picker.styles.d.ts.map +1 -1
  102. package/dist/components/hx-date-picker/index.d.ts +1 -0
  103. package/dist/components/hx-date-picker/index.d.ts.map +1 -1
  104. package/dist/components/hx-date-picker/index.js +1 -1
  105. package/dist/components/hx-dialog/hx-dialog.d.ts +37 -5
  106. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  107. package/dist/components/hx-dialog/index.js +1 -1
  108. package/dist/components/hx-divider/hx-divider.d.ts +3 -4
  109. package/dist/components/hx-divider/hx-divider.d.ts.map +1 -1
  110. package/dist/components/hx-divider/index.d.ts +0 -1
  111. package/dist/components/hx-divider/index.d.ts.map +1 -1
  112. package/dist/components/hx-divider/index.js +1 -1
  113. package/dist/components/hx-drawer/hx-drawer.d.ts +32 -2
  114. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  115. package/dist/components/hx-drawer/index.js +1 -1
  116. package/dist/components/hx-dropdown/hx-dropdown.d.ts +3 -2
  117. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  118. package/dist/components/hx-dropdown/index.js +1 -1
  119. package/dist/components/hx-field/hx-field.d.ts +4 -3
  120. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  121. package/dist/components/hx-field/index.js +1 -1
  122. package/dist/components/hx-field-label/hx-field-label.d.ts +2 -2
  123. package/dist/components/hx-field-label/hx-field-label.d.ts.map +1 -1
  124. package/dist/components/hx-field-label/index.js +1 -1
  125. package/dist/components/hx-file-upload/hx-file-upload.d.ts +31 -5
  126. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  127. package/dist/components/hx-file-upload/index.d.ts +1 -0
  128. package/dist/components/hx-file-upload/index.d.ts.map +1 -1
  129. package/dist/components/hx-file-upload/index.js +1 -1
  130. package/dist/components/hx-form/hx-form.d.ts +2 -2
  131. package/dist/components/hx-form/hx-form.d.ts.map +1 -1
  132. package/dist/components/hx-form/hx-form.styles.d.ts +8 -0
  133. package/dist/components/hx-form/hx-form.styles.d.ts.map +1 -1
  134. package/dist/components/hx-form/index.js +1 -1
  135. package/dist/components/hx-format-date/hx-format-date.d.ts +2 -2
  136. package/dist/components/hx-format-date/hx-format-date.d.ts.map +1 -1
  137. package/dist/components/hx-format-date/hx-format-date.styles.d.ts.map +1 -1
  138. package/dist/components/hx-format-date/index.js +1 -1
  139. package/dist/components/hx-grid/hx-grid.d.ts +4 -3
  140. package/dist/components/hx-grid/hx-grid.d.ts.map +1 -1
  141. package/dist/components/hx-grid/hx-grid.styles.d.ts.map +1 -1
  142. package/dist/components/hx-grid/index.js +1 -1
  143. package/dist/components/hx-help-text/hx-help-text.d.ts +2 -4
  144. package/dist/components/hx-help-text/hx-help-text.d.ts.map +1 -1
  145. package/dist/components/hx-help-text/index.js +1 -1
  146. package/dist/components/hx-icon/hx-icon.d.ts +17 -2
  147. package/dist/components/hx-icon/hx-icon.d.ts.map +1 -1
  148. package/dist/components/hx-icon/index.js +1 -1
  149. package/dist/components/hx-icon-button/index.js +1 -1
  150. package/dist/components/hx-image/hx-image.d.ts +2 -2
  151. package/dist/components/hx-image/hx-image.d.ts.map +1 -1
  152. package/dist/components/hx-image/index.js +1 -1
  153. package/dist/components/hx-link/hx-link.d.ts +2 -2
  154. package/dist/components/hx-link/hx-link.d.ts.map +1 -1
  155. package/dist/components/hx-link/index.js +1 -1
  156. package/dist/components/hx-list/hx-list-item.d.ts +3 -2
  157. package/dist/components/hx-list/hx-list-item.d.ts.map +1 -1
  158. package/dist/components/hx-list/hx-list.d.ts +3 -2
  159. package/dist/components/hx-list/hx-list.d.ts.map +1 -1
  160. package/dist/components/hx-list/hx-list.styles.d.ts.map +1 -1
  161. package/dist/components/hx-list/index.js +1 -1
  162. package/dist/components/hx-menu/hx-menu-divider.d.ts +2 -2
  163. package/dist/components/hx-menu/hx-menu-divider.d.ts.map +1 -1
  164. package/dist/components/hx-menu/hx-menu-item.d.ts +2 -2
  165. package/dist/components/hx-menu/hx-menu-item.d.ts.map +1 -1
  166. package/dist/components/hx-menu/hx-menu-item.styles.d.ts.map +1 -1
  167. package/dist/components/hx-menu/hx-menu.d.ts +2 -2
  168. package/dist/components/hx-menu/hx-menu.d.ts.map +1 -1
  169. package/dist/components/hx-menu/hx-menu.styles.d.ts.map +1 -1
  170. package/dist/components/hx-menu/index.js +1 -1
  171. package/dist/components/hx-meter/hx-meter.d.ts +3 -2
  172. package/dist/components/hx-meter/hx-meter.d.ts.map +1 -1
  173. package/dist/components/hx-meter/index.js +1 -1
  174. package/dist/components/hx-nav/hx-nav.d.ts +2 -4
  175. package/dist/components/hx-nav/hx-nav.d.ts.map +1 -1
  176. package/dist/components/hx-nav/hx-nav.styles.d.ts.map +1 -1
  177. package/dist/components/hx-nav/index.d.ts +1 -1
  178. package/dist/components/hx-nav/index.d.ts.map +1 -1
  179. package/dist/components/hx-nav/index.js +1 -1
  180. package/dist/components/hx-number-input/hx-number-input.d.ts +9 -13
  181. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  182. package/dist/components/hx-number-input/index.d.ts +1 -0
  183. package/dist/components/hx-number-input/index.d.ts.map +1 -1
  184. package/dist/components/hx-number-input/index.js +1 -1
  185. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts +2 -2
  186. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts.map +1 -1
  187. package/dist/components/hx-overflow-menu/index.js +1 -1
  188. package/dist/components/hx-pagination/hx-pagination.d.ts +10 -2
  189. package/dist/components/hx-pagination/hx-pagination.d.ts.map +1 -1
  190. package/dist/components/hx-pagination/index.d.ts +1 -0
  191. package/dist/components/hx-pagination/index.d.ts.map +1 -1
  192. package/dist/components/hx-pagination/index.js +1 -1
  193. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts +47 -5
  194. package/dist/components/hx-patient-banner/hx-patient-banner.d.ts.map +1 -1
  195. package/dist/components/hx-patient-banner/index.js +1 -1
  196. package/dist/components/hx-phi-field/hx-phi-field.d.ts +85 -5
  197. package/dist/components/hx-phi-field/hx-phi-field.d.ts.map +1 -1
  198. package/dist/components/hx-phi-field/hx-phi-field.styles.d.ts.map +1 -1
  199. package/dist/components/hx-phi-field/index.js +1 -1
  200. package/dist/components/hx-popover/hx-popover.d.ts +3 -2
  201. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  202. package/dist/components/hx-popover/index.js +1 -1
  203. package/dist/components/hx-popup/hx-popup.d.ts +7 -2
  204. package/dist/components/hx-popup/hx-popup.d.ts.map +1 -1
  205. package/dist/components/hx-popup/index.js +1 -1
  206. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +3 -2
  207. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  208. package/dist/components/hx-progress-bar/index.js +1 -1
  209. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts +3 -2
  210. package/dist/components/hx-progress-ring/hx-progress-ring.d.ts.map +1 -1
  211. package/dist/components/hx-progress-ring/hx-progress-ring.styles.d.ts.map +1 -1
  212. package/dist/components/hx-progress-ring/index.js +1 -1
  213. package/dist/components/hx-prose/hx-prose.d.ts +3 -2
  214. package/dist/components/hx-prose/hx-prose.d.ts.map +1 -1
  215. package/dist/components/hx-prose/hx-prose.styles.d.ts +8 -0
  216. package/dist/components/hx-prose/hx-prose.styles.d.ts.map +1 -1
  217. package/dist/components/hx-prose/index.js +1 -1
  218. package/dist/components/hx-radio-group/hx-radio-group.d.ts +9 -29
  219. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  220. package/dist/components/hx-radio-group/hx-radio.d.ts +19 -4
  221. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  222. package/dist/components/hx-radio-group/index.d.ts +1 -0
  223. package/dist/components/hx-radio-group/index.d.ts.map +1 -1
  224. package/dist/components/hx-radio-group/index.js +1 -1
  225. package/dist/components/hx-rating/hx-rating.d.ts +4 -10
  226. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  227. package/dist/components/hx-rating/hx-rating.styles.d.ts.map +1 -1
  228. package/dist/components/hx-rating/index.d.ts +1 -0
  229. package/dist/components/hx-rating/index.d.ts.map +1 -1
  230. package/dist/components/hx-rating/index.js +1 -1
  231. package/dist/components/hx-select/hx-select.d.ts +26 -25
  232. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  233. package/dist/components/hx-select/index.d.ts +1 -0
  234. package/dist/components/hx-select/index.d.ts.map +1 -1
  235. package/dist/components/hx-select/index.js +1 -1
  236. package/dist/components/hx-side-nav/hx-nav-item.d.ts +2 -2
  237. package/dist/components/hx-side-nav/hx-nav-item.d.ts.map +1 -1
  238. package/dist/components/hx-side-nav/hx-nav-item.styles.d.ts.map +1 -1
  239. package/dist/components/hx-side-nav/hx-side-nav.d.ts +3 -2
  240. package/dist/components/hx-side-nav/hx-side-nav.d.ts.map +1 -1
  241. package/dist/components/hx-side-nav/hx-side-nav.styles.d.ts.map +1 -1
  242. package/dist/components/hx-side-nav/index.js +1 -1
  243. package/dist/components/hx-skeleton/hx-skeleton.d.ts +3 -2
  244. package/dist/components/hx-skeleton/hx-skeleton.d.ts.map +1 -1
  245. package/dist/components/hx-skeleton/index.js +1 -1
  246. package/dist/components/hx-slider/hx-slider.d.ts +7 -11
  247. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  248. package/dist/components/hx-slider/hx-slider.styles.d.ts.map +1 -1
  249. package/dist/components/hx-slider/index.d.ts +1 -0
  250. package/dist/components/hx-slider/index.d.ts.map +1 -1
  251. package/dist/components/hx-slider/index.js +1 -1
  252. package/dist/components/hx-spinner/hx-spinner.d.ts +2 -2
  253. package/dist/components/hx-spinner/hx-spinner.d.ts.map +1 -1
  254. package/dist/components/hx-spinner/index.js +1 -1
  255. package/dist/components/hx-split-button/hx-split-button.d.ts +10 -4
  256. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  257. package/dist/components/hx-split-button/index.js +1 -1
  258. package/dist/components/hx-split-panel/hx-split-panel.d.ts +12 -2
  259. package/dist/components/hx-split-panel/hx-split-panel.d.ts.map +1 -1
  260. package/dist/components/hx-split-panel/index.js +1 -1
  261. package/dist/components/hx-stack/hx-stack.d.ts +2 -2
  262. package/dist/components/hx-stack/hx-stack.d.ts.map +1 -1
  263. package/dist/components/hx-stack/hx-stack.styles.d.ts.map +1 -1
  264. package/dist/components/hx-stack/index.js +1 -1
  265. package/dist/components/hx-stat/hx-stat.d.ts +3 -2
  266. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -1
  267. package/dist/components/hx-stat/index.js +1 -1
  268. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts +3 -2
  269. package/dist/components/hx-status-indicator/hx-status-indicator.d.ts.map +1 -1
  270. package/dist/components/hx-status-indicator/index.js +1 -1
  271. package/dist/components/hx-steps/hx-step.d.ts +3 -2
  272. package/dist/components/hx-steps/hx-step.d.ts.map +1 -1
  273. package/dist/components/hx-steps/hx-step.styles.d.ts.map +1 -1
  274. package/dist/components/hx-steps/hx-steps.d.ts +11 -4
  275. package/dist/components/hx-steps/hx-steps.d.ts.map +1 -1
  276. package/dist/components/hx-steps/hx-steps.styles.d.ts.map +1 -1
  277. package/dist/components/hx-steps/index.js +1 -1
  278. package/dist/components/hx-structured-list/hx-structured-list.d.ts +3 -3
  279. package/dist/components/hx-structured-list/hx-structured-list.d.ts.map +1 -1
  280. package/dist/components/hx-structured-list/index.js +1 -1
  281. package/dist/components/hx-style-scope/hx-style-scope.d.ts +3 -2
  282. package/dist/components/hx-style-scope/hx-style-scope.d.ts.map +1 -1
  283. package/dist/components/hx-style-scope/hx-style-scope.styles.d.ts.map +1 -1
  284. package/dist/components/hx-style-scope/index.js +1 -1
  285. package/dist/components/hx-switch/hx-switch.d.ts +20 -21
  286. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  287. package/dist/components/hx-switch/index.d.ts +2 -1
  288. package/dist/components/hx-switch/index.d.ts.map +1 -1
  289. package/dist/components/hx-switch/index.js +1 -1
  290. package/dist/components/hx-table/hx-table.d.ts +3 -2
  291. package/dist/components/hx-table/hx-table.d.ts.map +1 -1
  292. package/dist/components/hx-table/hx-tbody.d.ts +2 -2
  293. package/dist/components/hx-table/hx-tbody.d.ts.map +1 -1
  294. package/dist/components/hx-table/hx-td.d.ts +2 -2
  295. package/dist/components/hx-table/hx-td.d.ts.map +1 -1
  296. package/dist/components/hx-table/hx-tfoot.d.ts +2 -2
  297. package/dist/components/hx-table/hx-tfoot.d.ts.map +1 -1
  298. package/dist/components/hx-table/hx-th.d.ts +2 -2
  299. package/dist/components/hx-table/hx-th.d.ts.map +1 -1
  300. package/dist/components/hx-table/hx-thead.d.ts +2 -2
  301. package/dist/components/hx-table/hx-thead.d.ts.map +1 -1
  302. package/dist/components/hx-table/hx-tr.d.ts +2 -2
  303. package/dist/components/hx-table/hx-tr.d.ts.map +1 -1
  304. package/dist/components/hx-table/index.js +1 -1
  305. package/dist/components/hx-tabs/hx-tab-panel.d.ts +2 -2
  306. package/dist/components/hx-tabs/hx-tab-panel.d.ts.map +1 -1
  307. package/dist/components/hx-tabs/hx-tab.d.ts +2 -2
  308. package/dist/components/hx-tabs/hx-tab.d.ts.map +1 -1
  309. package/dist/components/hx-tabs/hx-tab.styles.d.ts.map +1 -1
  310. package/dist/components/hx-tabs/hx-tabs.d.ts +8 -2
  311. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  312. package/dist/components/hx-tabs/index.d.ts +1 -0
  313. package/dist/components/hx-tabs/index.d.ts.map +1 -1
  314. package/dist/components/hx-tabs/index.js +1 -1
  315. package/dist/components/hx-tag/hx-tag.d.ts +2 -4
  316. package/dist/components/hx-tag/hx-tag.d.ts.map +1 -1
  317. package/dist/components/hx-tag/index.d.ts +0 -2
  318. package/dist/components/hx-tag/index.d.ts.map +1 -1
  319. package/dist/components/hx-tag/index.js +1 -1
  320. package/dist/components/hx-text/hx-text.d.ts +2 -2
  321. package/dist/components/hx-text/hx-text.d.ts.map +1 -1
  322. package/dist/components/hx-text/hx-text.styles.d.ts.map +1 -1
  323. package/dist/components/hx-text/index.js +1 -1
  324. package/dist/components/hx-text-input/hx-text-input.d.ts +29 -13
  325. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  326. package/dist/components/hx-text-input/index.d.ts +1 -0
  327. package/dist/components/hx-text-input/index.d.ts.map +1 -1
  328. package/dist/components/hx-text-input/index.js +1 -1
  329. package/dist/components/hx-textarea/hx-textarea.d.ts +32 -24
  330. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  331. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  332. package/dist/components/hx-textarea/index.d.ts +1 -0
  333. package/dist/components/hx-textarea/index.d.ts.map +1 -1
  334. package/dist/components/hx-textarea/index.js +1 -1
  335. package/dist/components/hx-theme/hx-theme.d.ts +3 -11
  336. package/dist/components/hx-theme/hx-theme.d.ts.map +1 -1
  337. package/dist/components/hx-theme/hx-theme.styles.d.ts.map +1 -1
  338. package/dist/components/hx-theme/index.d.ts +0 -2
  339. package/dist/components/hx-theme/index.d.ts.map +1 -1
  340. package/dist/components/hx-theme/index.js +1 -1
  341. package/dist/components/hx-time-picker/hx-time-picker.d.ts +8 -15
  342. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  343. package/dist/components/hx-time-picker/hx-time-picker.styles.d.ts.map +1 -1
  344. package/dist/components/hx-time-picker/index.d.ts +1 -0
  345. package/dist/components/hx-time-picker/index.d.ts.map +1 -1
  346. package/dist/components/hx-time-picker/index.js +1 -1
  347. package/dist/components/hx-toast/hx-toast-stack.d.ts +2 -2
  348. package/dist/components/hx-toast/hx-toast-stack.d.ts.map +1 -1
  349. package/dist/components/hx-toast/hx-toast.d.ts +3 -2
  350. package/dist/components/hx-toast/hx-toast.d.ts.map +1 -1
  351. package/dist/components/hx-toast/hx-toast.styles.d.ts.map +1 -1
  352. package/dist/components/hx-toast/index.js +1 -1
  353. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +4 -0
  354. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  355. package/dist/components/hx-toggle-button/index.d.ts +1 -0
  356. package/dist/components/hx-toggle-button/index.d.ts.map +1 -1
  357. package/dist/components/hx-toggle-button/index.js +1 -1
  358. package/dist/components/hx-tooltip/hx-tooltip.d.ts +2 -2
  359. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  360. package/dist/components/hx-tooltip/index.js +1 -1
  361. package/dist/components/hx-top-nav/hx-top-nav.d.ts +2 -2
  362. package/dist/components/hx-top-nav/hx-top-nav.d.ts.map +1 -1
  363. package/dist/components/hx-top-nav/index.js +1 -1
  364. package/dist/components/hx-tree-view/hx-tree-item.d.ts +2 -4
  365. package/dist/components/hx-tree-view/hx-tree-item.d.ts.map +1 -1
  366. package/dist/components/hx-tree-view/hx-tree-item.styles.d.ts.map +1 -1
  367. package/dist/components/hx-tree-view/hx-tree-view.d.ts +2 -4
  368. package/dist/components/hx-tree-view/hx-tree-view.d.ts.map +1 -1
  369. package/dist/components/hx-tree-view/hx-tree-view.styles.d.ts.map +1 -1
  370. package/dist/components/hx-tree-view/index.d.ts +0 -4
  371. package/dist/components/hx-tree-view/index.d.ts.map +1 -1
  372. package/dist/components/hx-tree-view/index.js +1 -1
  373. package/dist/components/hx-visually-hidden/hx-visually-hidden.d.ts +2 -2
  374. package/dist/components/hx-visually-hidden/hx-visually-hidden.d.ts.map +1 -1
  375. package/dist/components/hx-visually-hidden/hx-visually-hidden.styles.d.ts.map +1 -1
  376. package/dist/components/hx-visually-hidden/index.js +1 -1
  377. package/dist/css/helix-all.css +2232 -680
  378. package/dist/css/helix-core.css +107 -49
  379. package/dist/css/helix-data.css +17 -7
  380. package/dist/css/helix-feedback.css +82 -61
  381. package/dist/css/helix-forms.css +1456 -131
  382. package/dist/css/helix-layout.css +31 -1
  383. package/dist/css/helix-media.css +16 -16
  384. package/dist/css/helix-navigation.css +99 -48
  385. package/dist/css/helix-overlay.css +12 -12
  386. package/dist/css/helix-tokens.css +30 -11
  387. package/dist/css/helix-utility.css +53 -10
  388. package/dist/css/hx-accordion.css +1 -1
  389. package/dist/css/hx-action-bar.css +17 -3
  390. package/dist/css/hx-alert.css +18 -18
  391. package/dist/css/hx-avatar.css +1 -1
  392. package/dist/css/hx-badge.css +15 -15
  393. package/dist/css/hx-banner.css +18 -18
  394. package/dist/css/hx-breadcrumb.css +27 -0
  395. package/dist/css/hx-button-group.css +13 -0
  396. package/dist/css/hx-button.css +2 -2
  397. package/dist/css/hx-card.css +6 -6
  398. package/dist/css/hx-carousel.css +16 -16
  399. package/dist/css/hx-checkbox-group.css +4 -4
  400. package/dist/css/hx-checkbox.css +8 -8
  401. package/dist/css/hx-clinical-status.css +23 -23
  402. package/dist/css/hx-code-snippet.css +3 -3
  403. package/dist/css/hx-color-picker.css +276 -1
  404. package/dist/css/hx-combobox.css +391 -1
  405. package/dist/css/hx-container.css +10 -0
  406. package/dist/css/hx-copy-button.css +3 -3
  407. package/dist/css/hx-counter.css +9 -2
  408. package/dist/css/hx-data-table.css +1 -1
  409. package/dist/css/hx-date-picker.css +437 -1
  410. package/dist/css/hx-dialog.css +2 -2
  411. package/dist/css/hx-drawer.css +1 -1
  412. package/dist/css/hx-dropdown.css +1 -1
  413. package/dist/css/hx-field-label.css +2 -2
  414. package/dist/css/hx-field.css +3 -3
  415. package/dist/css/hx-file-upload.css +12 -12
  416. package/dist/css/hx-format-date.css +11 -0
  417. package/dist/css/hx-grid.css +10 -0
  418. package/dist/css/hx-help-text.css +5 -5
  419. package/dist/css/hx-image.css +3 -3
  420. package/dist/css/hx-link.css +5 -5
  421. package/dist/css/hx-list.css +10 -0
  422. package/dist/css/hx-menu.css +1 -2
  423. package/dist/css/hx-meter.css +9 -9
  424. package/dist/css/hx-nav.css +11 -12
  425. package/dist/css/hx-overflow-menu.css +10 -10
  426. package/dist/css/hx-pagination.css +13 -13
  427. package/dist/css/hx-patient-banner.css +10 -10
  428. package/dist/css/hx-phi-field.css +5 -2
  429. package/dist/css/hx-popover.css +4 -4
  430. package/dist/css/hx-progress-bar.css +1 -1
  431. package/dist/css/hx-progress-ring.css +23 -1
  432. package/dist/css/hx-radio-group.css +3 -3
  433. package/dist/css/hx-rating.css +6 -4
  434. package/dist/css/hx-select.css +7 -7
  435. package/dist/css/hx-side-nav.css +5 -0
  436. package/dist/css/hx-slider.css +16 -11
  437. package/dist/css/hx-split-button.css +2 -2
  438. package/dist/css/hx-stack.css +10 -0
  439. package/dist/css/hx-stat.css +5 -5
  440. package/dist/css/hx-status-indicator.css +2 -2
  441. package/dist/css/hx-steps.css +12 -0
  442. package/dist/css/hx-structured-list.css +2 -2
  443. package/dist/css/hx-style-scope.css +11 -0
  444. package/dist/css/hx-switch.css +4 -4
  445. package/dist/css/hx-table.css +1 -1
  446. package/dist/css/hx-tabs.css +3 -3
  447. package/dist/css/hx-tag.css +12 -12
  448. package/dist/css/hx-text-input.css +9 -9
  449. package/dist/css/hx-text.css +38 -5
  450. package/dist/css/hx-textarea.css +9 -15
  451. package/dist/css/hx-theme.css +11 -0
  452. package/dist/css/hx-time-picker.css +224 -1
  453. package/dist/css/hx-toast.css +6 -7
  454. package/dist/css/hx-toggle-button.css +3 -3
  455. package/dist/css/hx-tooltip.css +4 -4
  456. package/dist/css/hx-top-nav.css +8 -8
  457. package/dist/css/hx-tree-view.css +9 -0
  458. package/dist/css/hx-visually-hidden.css +12 -0
  459. package/dist/css/index.css +1 -1
  460. package/dist/css/manifest.json +39 -7
  461. package/dist/form-test-utils.d.ts +45 -0
  462. package/dist/form-test-utils.d.ts.map +1 -0
  463. package/dist/index.d.ts +28 -14
  464. package/dist/index.d.ts.map +1 -1
  465. package/dist/index.js +189 -177
  466. package/dist/index.js.map +1 -1
  467. package/dist/mixins/FormMixin.d.ts +24 -5
  468. package/dist/mixins/FormMixin.d.ts.map +1 -1
  469. package/dist/mixins/aria-delegation.d.ts +0 -2
  470. package/dist/mixins/aria-delegation.d.ts.map +1 -1
  471. package/dist/mixins/index.d.ts +3 -1
  472. package/dist/mixins/index.d.ts.map +1 -1
  473. package/dist/shared/{FormMixin-Bjvw20G5.js → FormMixin-B8PXk5RQ.js} +31 -14
  474. package/dist/shared/FormMixin-B8PXk5RQ.js.map +1 -0
  475. package/dist/shared/aria-delegation-Doq6RRUy.js.map +1 -1
  476. package/dist/shared/{helix-element-BJh1Ffvi.js → helix-element-BNEYeiys.js} +30 -24
  477. package/dist/shared/helix-element-BNEYeiys.js.map +1 -0
  478. package/dist/shared/{hx-accordion-SlwR2C6S.js → hx-accordion-Wt52OOZD.js} +49 -49
  479. package/dist/shared/hx-accordion-Wt52OOZD.js.map +1 -0
  480. package/dist/shared/{hx-action-bar-CNLYufVd.js → hx-action-bar-BKMADbHj.js} +89 -85
  481. package/dist/shared/hx-action-bar-BKMADbHj.js.map +1 -0
  482. package/dist/shared/{hx-alert-DdlSyJGk.js → hx-alert-D7n94HwI.js} +26 -26
  483. package/dist/shared/hx-alert-D7n94HwI.js.map +1 -0
  484. package/dist/shared/{hx-avatar-an-WsuLl.js → hx-avatar-iLYzu8MJ.js} +10 -10
  485. package/dist/shared/hx-avatar-iLYzu8MJ.js.map +1 -0
  486. package/dist/shared/{hx-badge-B_PzGlUo.js → hx-badge-CVCmMPyW.js} +27 -27
  487. package/dist/shared/hx-badge-CVCmMPyW.js.map +1 -0
  488. package/dist/shared/{hx-banner-D8AxkCfc.js → hx-banner-C_He7Tr4.js} +51 -51
  489. package/dist/shared/hx-banner-C_He7Tr4.js.map +1 -0
  490. package/dist/shared/{hx-breadcrumb-item-BCUIvpYX.js → hx-breadcrumb-item-CldCwD1d.js} +105 -82
  491. package/dist/shared/hx-breadcrumb-item-CldCwD1d.js.map +1 -0
  492. package/dist/shared/{hx-button-BzqsDHmZ.js → hx-button-Ddl-T6T-.js} +110 -84
  493. package/dist/shared/hx-button-Ddl-T6T-.js.map +1 -0
  494. package/dist/shared/{hx-button-group-a5Pb_9fU.js → hx-button-group-BJOGWoMa.js} +30 -17
  495. package/dist/shared/hx-button-group-BJOGWoMa.js.map +1 -0
  496. package/dist/shared/{hx-card-DYlaxQy0.js → hx-card-ycveujjL.js} +13 -13
  497. package/dist/shared/hx-card-ycveujjL.js.map +1 -0
  498. package/dist/shared/{hx-carousel-item-KQfCekKF.js → hx-carousel-item-D_dCv61-.js} +37 -28
  499. package/dist/shared/hx-carousel-item-D_dCv61-.js.map +1 -0
  500. package/dist/shared/{hx-checkbox-DyDbR1B9.js → hx-checkbox-DkkoWoye.js} +77 -60
  501. package/dist/shared/hx-checkbox-DkkoWoye.js.map +1 -0
  502. package/dist/shared/{hx-checkbox-group-C8TaFqy0.js → hx-checkbox-group-C3poJ-Zw.js} +55 -64
  503. package/dist/shared/hx-checkbox-group-C3poJ-Zw.js.map +1 -0
  504. package/dist/shared/{hx-clinical-status-dDyk5oj1.js → hx-clinical-status-BS5lcddT.js} +52 -53
  505. package/dist/shared/hx-clinical-status-BS5lcddT.js.map +1 -0
  506. package/dist/shared/{hx-code-snippet-DasrRF9k.js → hx-code-snippet-B7wUKzyb.js} +12 -13
  507. package/dist/shared/hx-code-snippet-B7wUKzyb.js.map +1 -0
  508. package/dist/shared/{hx-color-picker-zv6wtok4.js → hx-color-picker-DBaKTVLr.js} +318 -57
  509. package/dist/shared/hx-color-picker-DBaKTVLr.js.map +1 -0
  510. package/dist/shared/hx-combobox-BmgYT7Ar.js +929 -0
  511. package/dist/shared/hx-combobox-BmgYT7Ar.js.map +1 -0
  512. package/dist/shared/{hx-container-BwWbMPTH.js → hx-container-DVI7sxfX.js} +25 -15
  513. package/dist/shared/hx-container-DVI7sxfX.js.map +1 -0
  514. package/dist/shared/{hx-copy-button-DikpbhWY.js → hx-copy-button-8deNUdwP.js} +20 -20
  515. package/dist/shared/hx-copy-button-8deNUdwP.js.map +1 -0
  516. package/dist/shared/{hx-counter-_m4cq45V.js → hx-counter-CKfl_g8K.js} +36 -29
  517. package/dist/shared/hx-counter-CKfl_g8K.js.map +1 -0
  518. package/dist/shared/{hx-data-table-609C-e9w.js → hx-data-table-B6h0RPn0.js} +107 -101
  519. package/dist/shared/hx-data-table-B6h0RPn0.js.map +1 -0
  520. package/dist/shared/hx-date-picker-Dq2Nb68_.js +1077 -0
  521. package/dist/shared/hx-date-picker-Dq2Nb68_.js.map +1 -0
  522. package/dist/shared/{hx-dialog-D_DeqcNS.js → hx-dialog-CvIlY0Tc.js} +66 -54
  523. package/dist/shared/hx-dialog-CvIlY0Tc.js.map +1 -0
  524. package/dist/shared/{hx-divider-lfOMElo2.js → hx-divider-DwpOrzMW.js} +7 -7
  525. package/dist/shared/hx-divider-DwpOrzMW.js.map +1 -0
  526. package/dist/shared/{hx-drawer-NleCbKuN.js → hx-drawer-Cx2ZJhBe.js} +14 -14
  527. package/dist/shared/hx-drawer-Cx2ZJhBe.js.map +1 -0
  528. package/dist/shared/{hx-dropdown-CA9WYdhm.js → hx-dropdown-BjDrPUq5.js} +30 -31
  529. package/dist/shared/hx-dropdown-BjDrPUq5.js.map +1 -0
  530. package/dist/shared/{hx-field-Duiib9Bj.js → hx-field-Dp3qQMut.js} +15 -15
  531. package/dist/shared/hx-field-Dp3qQMut.js.map +1 -0
  532. package/dist/shared/{hx-field-label-Dud-psvE.js → hx-field-label-BC8QViXv.js} +8 -8
  533. package/dist/shared/hx-field-label-BC8QViXv.js.map +1 -0
  534. package/dist/shared/{hx-file-upload-CmCCAvej.js → hx-file-upload-B6Yl1u0i.js} +101 -84
  535. package/dist/shared/hx-file-upload-B6Yl1u0i.js.map +1 -0
  536. package/dist/shared/{hx-form-BM6PHsw3.js → hx-form-ButQFt9A.js} +12 -11
  537. package/dist/shared/hx-form-ButQFt9A.js.map +1 -0
  538. package/dist/shared/{hx-format-date-B7L9odbA.js → hx-format-date-CKnlQOmV.js} +20 -9
  539. package/dist/shared/hx-format-date-CKnlQOmV.js.map +1 -0
  540. package/dist/shared/{hx-grid-BIAR5h9m.js → hx-grid-CXZf3jeK.js} +28 -18
  541. package/dist/shared/hx-grid-CXZf3jeK.js.map +1 -0
  542. package/dist/shared/{hx-help-text-DARi-Pfp.js → hx-help-text-D7eytSim.js} +12 -12
  543. package/dist/shared/hx-help-text-D7eytSim.js.map +1 -0
  544. package/dist/shared/{hx-icon-jWcGmn66.js → hx-icon-CcyDPDYY.js} +96 -62
  545. package/dist/shared/hx-icon-CcyDPDYY.js.map +1 -0
  546. package/dist/shared/{hx-icon-button-BcZtVVtH.js → hx-icon-button-BHneqPCU.js} +2 -3
  547. package/dist/shared/{hx-icon-button-BcZtVVtH.js.map → hx-icon-button-BHneqPCU.js.map} +1 -1
  548. package/dist/shared/{hx-image-DOjPp-K5.js → hx-image-2gt14zZd.js} +9 -9
  549. package/dist/shared/hx-image-2gt14zZd.js.map +1 -0
  550. package/dist/shared/{hx-link-DCBct0f4.js → hx-link-BESrWK8M.js} +17 -17
  551. package/dist/shared/hx-link-BESrWK8M.js.map +1 -0
  552. package/dist/shared/{hx-list-Dnei26t4.js → hx-list-_9qVv02L.js} +32 -22
  553. package/dist/shared/hx-list-_9qVv02L.js.map +1 -0
  554. package/dist/shared/{hx-menu-divider-DVWER7iT.js → hx-menu-divider-Ck-9Os1t.js} +19 -19
  555. package/dist/shared/hx-menu-divider-Ck-9Os1t.js.map +1 -0
  556. package/dist/shared/{hx-meter-ChZdWNF2.js → hx-meter-TbROk-dw.js} +18 -18
  557. package/dist/shared/hx-meter-TbROk-dw.js.map +1 -0
  558. package/dist/shared/{hx-nav-CHX1JOWB.js → hx-nav-BcYDmjf7.js} +59 -60
  559. package/dist/shared/hx-nav-BcYDmjf7.js.map +1 -0
  560. package/dist/shared/{hx-nav-item-CRAESq9s.js → hx-nav-item-pqPasRUm.js} +33 -23
  561. package/dist/shared/hx-nav-item-pqPasRUm.js.map +1 -0
  562. package/dist/shared/{hx-number-input-Cm682AVP.js → hx-number-input-mOIZ3-46.js} +57 -66
  563. package/dist/shared/hx-number-input-mOIZ3-46.js.map +1 -0
  564. package/dist/shared/{hx-overflow-menu-BDl6QfUD.js → hx-overflow-menu-Dprb9lnT.js} +46 -47
  565. package/dist/shared/hx-overflow-menu-Dprb9lnT.js.map +1 -0
  566. package/dist/shared/{hx-pagination-BNtx-LG6.js → hx-pagination-AguTQjYC.js} +35 -35
  567. package/dist/shared/hx-pagination-AguTQjYC.js.map +1 -0
  568. package/dist/shared/{hx-patient-banner-B4IjHeTx.js → hx-patient-banner-uE6gqLpT.js} +16 -16
  569. package/dist/shared/hx-patient-banner-uE6gqLpT.js.map +1 -0
  570. package/dist/shared/{hx-phi-field-DD1qcBSO.js → hx-phi-field-BC_XowhC.js} +138 -56
  571. package/dist/shared/hx-phi-field-BC_XowhC.js.map +1 -0
  572. package/dist/shared/{hx-popover-ZGRFgBbx.js → hx-popover-B2_203ct.js} +25 -25
  573. package/dist/shared/hx-popover-B2_203ct.js.map +1 -0
  574. package/dist/shared/{hx-popup-Cc4qz89i.js → hx-popup-DZXpsJ1R.js} +77 -64
  575. package/dist/shared/hx-popup-DZXpsJ1R.js.map +1 -0
  576. package/dist/shared/{hx-progress-bar-BY1uE6bN.js → hx-progress-bar-KjEkEJLy.js} +19 -19
  577. package/dist/shared/hx-progress-bar-KjEkEJLy.js.map +1 -0
  578. package/dist/shared/{hx-progress-ring-Cs0WgWDJ.js → hx-progress-ring-3zMwvrwD.js} +53 -31
  579. package/dist/shared/hx-progress-ring-3zMwvrwD.js.map +1 -0
  580. package/dist/shared/{hx-prose-Ml_L2zje.js → hx-prose-BCtK7YL6.js} +48 -15
  581. package/dist/shared/{hx-prose-Ml_L2zje.js.map → hx-prose-BCtK7YL6.js.map} +1 -1
  582. package/dist/shared/{hx-radio-YEEsbUPN.js → hx-radio-BBC5qZgE.js} +99 -105
  583. package/dist/shared/hx-radio-BBC5qZgE.js.map +1 -0
  584. package/dist/shared/{hx-rating-DjUJTT0M.js → hx-rating-C3E3ENJb.js} +42 -56
  585. package/dist/shared/hx-rating-C3E3ENJb.js.map +1 -0
  586. package/dist/shared/{hx-select-DZ7wfcJx.js → hx-select-CixTo7jp.js} +105 -116
  587. package/dist/shared/hx-select-CixTo7jp.js.map +1 -0
  588. package/dist/shared/{hx-skeleton-aqa-gr1S.js → hx-skeleton-LxkI0pxr.js} +15 -15
  589. package/dist/shared/hx-skeleton-LxkI0pxr.js.map +1 -0
  590. package/dist/shared/{hx-slider-DAilFrR_.js → hx-slider-DFHuzF3N.js} +74 -89
  591. package/dist/shared/hx-slider-DFHuzF3N.js.map +1 -0
  592. package/dist/shared/{hx-spinner-Dw3cRY-9.js → hx-spinner-BKjuCdZB.js} +9 -9
  593. package/dist/shared/hx-spinner-BKjuCdZB.js.map +1 -0
  594. package/dist/shared/{hx-split-button-Dk-zMDDo.js → hx-split-button-CGcJMmCG.js} +14 -14
  595. package/dist/shared/hx-split-button-CGcJMmCG.js.map +1 -0
  596. package/dist/shared/{hx-split-panel-Kdp4BiLz.js → hx-split-panel-C-1R10Mc.js} +57 -47
  597. package/dist/shared/hx-split-panel-C-1R10Mc.js.map +1 -0
  598. package/dist/shared/{hx-stack-B76_1O6g.js → hx-stack-DGfcOfWJ.js} +21 -11
  599. package/dist/shared/hx-stack-DGfcOfWJ.js.map +1 -0
  600. package/dist/shared/{hx-stat-DKlyBL_K.js → hx-stat-BTpykQAt.js} +14 -14
  601. package/dist/shared/hx-stat-BTpykQAt.js.map +1 -0
  602. package/dist/shared/{hx-status-indicator-DWSM0Ctm.js → hx-status-indicator-X2QEWNFt.js} +13 -13
  603. package/dist/shared/hx-status-indicator-X2QEWNFt.js.map +1 -0
  604. package/dist/shared/{hx-step-CuoOvcI8.js → hx-step-CRNQlmSo.js} +47 -30
  605. package/dist/shared/hx-step-CRNQlmSo.js.map +1 -0
  606. package/dist/shared/{hx-structured-list-CQCD7bCT.js → hx-structured-list-CqNbaEXg.js} +12 -12
  607. package/dist/shared/hx-structured-list-CqNbaEXg.js.map +1 -0
  608. package/dist/shared/hx-style-scope-TDnR8H4O.js +251 -0
  609. package/dist/shared/hx-style-scope-TDnR8H4O.js.map +1 -0
  610. package/dist/shared/{hx-switch-BdxKN9WM.js → hx-switch-DqOD9JR7.js} +56 -72
  611. package/dist/shared/hx-switch-DqOD9JR7.js.map +1 -0
  612. package/dist/shared/{hx-tab-panel-CwClQoWP.js → hx-tab-panel-BIzKfW5i.js} +29 -28
  613. package/dist/shared/hx-tab-panel-BIzKfW5i.js.map +1 -0
  614. package/dist/shared/{hx-tag-BL5qJJCN.js → hx-tag-CgnrNnte.js} +23 -23
  615. package/dist/shared/hx-tag-CgnrNnte.js.map +1 -0
  616. package/dist/shared/{hx-td-CzSvVKdp.js → hx-td-Bra35cH4.js} +37 -37
  617. package/dist/shared/hx-td-Bra35cH4.js.map +1 -0
  618. package/dist/shared/{hx-text-DcWBqZwx.js → hx-text-DMC2CPlL.js} +74 -41
  619. package/dist/shared/hx-text-DMC2CPlL.js.map +1 -0
  620. package/dist/shared/{hx-text-input-BfMrvN9N.js → hx-text-input--q0GH78x.js} +19 -20
  621. package/dist/shared/hx-text-input--q0GH78x.js.map +1 -0
  622. package/dist/shared/{hx-textarea-C-i_Vam6.js → hx-textarea-CK621vSL.js} +28 -54
  623. package/dist/shared/hx-textarea-CK621vSL.js.map +1 -0
  624. package/dist/shared/{hx-theme-pc1V7dyL.js → hx-theme-DfEy-SJA.js} +72 -64
  625. package/dist/shared/hx-theme-DfEy-SJA.js.map +1 -0
  626. package/dist/shared/{hx-time-picker-MZyLQPW9.js → hx-time-picker-tPUfgElQ.js} +264 -35
  627. package/dist/shared/hx-time-picker-tPUfgElQ.js.map +1 -0
  628. package/dist/shared/{hx-toggle-button-ClyNYNVI.js → hx-toggle-button-L-uBJr-a.js} +9 -10
  629. package/dist/shared/hx-toggle-button-L-uBJr-a.js.map +1 -0
  630. package/dist/shared/{hx-tooltip-ByWT987R.js → hx-tooltip-B_zfKvwc.js} +22 -23
  631. package/dist/shared/hx-tooltip-B_zfKvwc.js.map +1 -0
  632. package/dist/shared/{hx-top-nav-k7hY78kt.js → hx-top-nav-CATbRvIv.js} +24 -22
  633. package/dist/shared/hx-top-nav-CATbRvIv.js.map +1 -0
  634. package/dist/shared/{hx-tree-item-D0ZphA45.js → hx-tree-item-A45WCiBu.js} +29 -9
  635. package/dist/shared/hx-tree-item-A45WCiBu.js.map +1 -0
  636. package/dist/shared/hx-visually-hidden-0bZKOWgT.js +66 -0
  637. package/dist/shared/hx-visually-hidden-0bZKOWgT.js.map +1 -0
  638. package/dist/shared/id-counter-DuX8vsui.js +11 -0
  639. package/dist/shared/{id-counter-PTgF-zcG.js.map → id-counter-DuX8vsui.js.map} +1 -1
  640. package/dist/shared/{toast-factory-Cwd0PihS.js → toast-factory-BPPnG3mM.js} +23 -24
  641. package/dist/shared/toast-factory-BPPnG3mM.js.map +1 -0
  642. package/dist/utilities/injectLightStyles.d.ts.map +1 -1
  643. package/dist/utilities/sanitizeCss.d.ts +43 -0
  644. package/dist/utilities/sanitizeCss.d.ts.map +1 -0
  645. package/package.json +29 -13
  646. package/dist/shared/FormMixin-Bjvw20G5.js.map +0 -1
  647. package/dist/shared/document-token-adoption-DuYNKd4k.js +0 -21
  648. package/dist/shared/document-token-adoption-DuYNKd4k.js.map +0 -1
  649. package/dist/shared/helix-element-BJh1Ffvi.js.map +0 -1
  650. package/dist/shared/hx-accordion-SlwR2C6S.js.map +0 -1
  651. package/dist/shared/hx-action-bar-CNLYufVd.js.map +0 -1
  652. package/dist/shared/hx-alert-DdlSyJGk.js.map +0 -1
  653. package/dist/shared/hx-avatar-an-WsuLl.js.map +0 -1
  654. package/dist/shared/hx-badge-B_PzGlUo.js.map +0 -1
  655. package/dist/shared/hx-banner-D8AxkCfc.js.map +0 -1
  656. package/dist/shared/hx-breadcrumb-item-BCUIvpYX.js.map +0 -1
  657. package/dist/shared/hx-button-BzqsDHmZ.js.map +0 -1
  658. package/dist/shared/hx-button-group-a5Pb_9fU.js.map +0 -1
  659. package/dist/shared/hx-card-DYlaxQy0.js.map +0 -1
  660. package/dist/shared/hx-carousel-item-KQfCekKF.js.map +0 -1
  661. package/dist/shared/hx-checkbox-DyDbR1B9.js.map +0 -1
  662. package/dist/shared/hx-checkbox-group-C8TaFqy0.js.map +0 -1
  663. package/dist/shared/hx-clinical-status-dDyk5oj1.js.map +0 -1
  664. package/dist/shared/hx-code-snippet-DasrRF9k.js.map +0 -1
  665. package/dist/shared/hx-color-picker-zv6wtok4.js.map +0 -1
  666. package/dist/shared/hx-combobox-C-DVLFpu.js +0 -535
  667. package/dist/shared/hx-combobox-C-DVLFpu.js.map +0 -1
  668. package/dist/shared/hx-container-BwWbMPTH.js.map +0 -1
  669. package/dist/shared/hx-copy-button-DikpbhWY.js.map +0 -1
  670. package/dist/shared/hx-counter-_m4cq45V.js.map +0 -1
  671. package/dist/shared/hx-data-table-609C-e9w.js.map +0 -1
  672. package/dist/shared/hx-date-picker-Bh8410Sf.js +0 -618
  673. package/dist/shared/hx-date-picker-Bh8410Sf.js.map +0 -1
  674. package/dist/shared/hx-dialog-D_DeqcNS.js.map +0 -1
  675. package/dist/shared/hx-divider-lfOMElo2.js.map +0 -1
  676. package/dist/shared/hx-drawer-NleCbKuN.js.map +0 -1
  677. package/dist/shared/hx-dropdown-CA9WYdhm.js.map +0 -1
  678. package/dist/shared/hx-field-Duiib9Bj.js.map +0 -1
  679. package/dist/shared/hx-field-label-Dud-psvE.js.map +0 -1
  680. package/dist/shared/hx-file-upload-CmCCAvej.js.map +0 -1
  681. package/dist/shared/hx-form-BM6PHsw3.js.map +0 -1
  682. package/dist/shared/hx-format-date-B7L9odbA.js.map +0 -1
  683. package/dist/shared/hx-grid-BIAR5h9m.js.map +0 -1
  684. package/dist/shared/hx-help-text-DARi-Pfp.js.map +0 -1
  685. package/dist/shared/hx-icon-jWcGmn66.js.map +0 -1
  686. package/dist/shared/hx-image-DOjPp-K5.js.map +0 -1
  687. package/dist/shared/hx-link-DCBct0f4.js.map +0 -1
  688. package/dist/shared/hx-list-Dnei26t4.js.map +0 -1
  689. package/dist/shared/hx-menu-divider-DVWER7iT.js.map +0 -1
  690. package/dist/shared/hx-meter-ChZdWNF2.js.map +0 -1
  691. package/dist/shared/hx-nav-CHX1JOWB.js.map +0 -1
  692. package/dist/shared/hx-nav-item-CRAESq9s.js.map +0 -1
  693. package/dist/shared/hx-number-input-Cm682AVP.js.map +0 -1
  694. package/dist/shared/hx-overflow-menu-BDl6QfUD.js.map +0 -1
  695. package/dist/shared/hx-pagination-BNtx-LG6.js.map +0 -1
  696. package/dist/shared/hx-patient-banner-B4IjHeTx.js.map +0 -1
  697. package/dist/shared/hx-phi-field-DD1qcBSO.js.map +0 -1
  698. package/dist/shared/hx-popover-ZGRFgBbx.js.map +0 -1
  699. package/dist/shared/hx-popup-Cc4qz89i.js.map +0 -1
  700. package/dist/shared/hx-progress-bar-BY1uE6bN.js.map +0 -1
  701. package/dist/shared/hx-progress-ring-Cs0WgWDJ.js.map +0 -1
  702. package/dist/shared/hx-radio-YEEsbUPN.js.map +0 -1
  703. package/dist/shared/hx-rating-DjUJTT0M.js.map +0 -1
  704. package/dist/shared/hx-select-DZ7wfcJx.js.map +0 -1
  705. package/dist/shared/hx-skeleton-aqa-gr1S.js.map +0 -1
  706. package/dist/shared/hx-slider-DAilFrR_.js.map +0 -1
  707. package/dist/shared/hx-spinner-Dw3cRY-9.js.map +0 -1
  708. package/dist/shared/hx-split-button-Dk-zMDDo.js.map +0 -1
  709. package/dist/shared/hx-split-panel-Kdp4BiLz.js.map +0 -1
  710. package/dist/shared/hx-stack-B76_1O6g.js.map +0 -1
  711. package/dist/shared/hx-stat-DKlyBL_K.js.map +0 -1
  712. package/dist/shared/hx-status-indicator-DWSM0Ctm.js.map +0 -1
  713. package/dist/shared/hx-step-CuoOvcI8.js.map +0 -1
  714. package/dist/shared/hx-structured-list-CQCD7bCT.js.map +0 -1
  715. package/dist/shared/hx-style-scope-CsQ2Phf_.js +0 -126
  716. package/dist/shared/hx-style-scope-CsQ2Phf_.js.map +0 -1
  717. package/dist/shared/hx-switch-BdxKN9WM.js.map +0 -1
  718. package/dist/shared/hx-tab-panel-CwClQoWP.js.map +0 -1
  719. package/dist/shared/hx-tag-BL5qJJCN.js.map +0 -1
  720. package/dist/shared/hx-td-CzSvVKdp.js.map +0 -1
  721. package/dist/shared/hx-text-DcWBqZwx.js.map +0 -1
  722. package/dist/shared/hx-text-input-BfMrvN9N.js.map +0 -1
  723. package/dist/shared/hx-textarea-C-i_Vam6.js.map +0 -1
  724. package/dist/shared/hx-theme-pc1V7dyL.js.map +0 -1
  725. package/dist/shared/hx-time-picker-MZyLQPW9.js.map +0 -1
  726. package/dist/shared/hx-toggle-button-ClyNYNVI.js.map +0 -1
  727. package/dist/shared/hx-tooltip-ByWT987R.js.map +0 -1
  728. package/dist/shared/hx-top-nav-k7hY78kt.js.map +0 -1
  729. package/dist/shared/hx-tree-item-D0ZphA45.js.map +0 -1
  730. package/dist/shared/hx-visually-hidden-vKX8QjeX.js +0 -54
  731. package/dist/shared/hx-visually-hidden-vKX8QjeX.js.map +0 -1
  732. package/dist/shared/id-counter-PTgF-zcG.js +0 -15
  733. package/dist/shared/toast-factory-Cwd0PihS.js.map +0 -1
  734. package/dist/tools/cem-a11y-analyzer/analyzers/aria-analyzer.d.ts +0 -12
  735. package/dist/tools/cem-a11y-analyzer/analyzers/aria-analyzer.d.ts.map +0 -1
  736. package/dist/tools/cem-a11y-analyzer/analyzers/focus-analyzer.d.ts +0 -13
  737. package/dist/tools/cem-a11y-analyzer/analyzers/focus-analyzer.d.ts.map +0 -1
  738. package/dist/tools/cem-a11y-analyzer/analyzers/form-analyzer.d.ts +0 -13
  739. package/dist/tools/cem-a11y-analyzer/analyzers/form-analyzer.d.ts.map +0 -1
  740. package/dist/tools/cem-a11y-analyzer/analyzers/keyboard-analyzer.d.ts +0 -12
  741. package/dist/tools/cem-a11y-analyzer/analyzers/keyboard-analyzer.d.ts.map +0 -1
  742. package/dist/tools/cem-a11y-analyzer/analyzers/label-analyzer.d.ts +0 -13
  743. package/dist/tools/cem-a11y-analyzer/analyzers/label-analyzer.d.ts.map +0 -1
  744. package/dist/tools/cem-a11y-analyzer/analyzers/motion-analyzer.d.ts +0 -12
  745. package/dist/tools/cem-a11y-analyzer/analyzers/motion-analyzer.d.ts.map +0 -1
  746. package/dist/tools/cem-a11y-analyzer/index.d.ts +0 -14
  747. package/dist/tools/cem-a11y-analyzer/index.d.ts.map +0 -1
  748. package/dist/tools/cem-a11y-analyzer/reporter.d.ts +0 -6
  749. package/dist/tools/cem-a11y-analyzer/reporter.d.ts.map +0 -1
  750. package/dist/tools/cem-a11y-analyzer/scorer.d.ts +0 -22
  751. package/dist/tools/cem-a11y-analyzer/scorer.d.ts.map +0 -1
  752. package/dist/tools/cem-a11y-analyzer/types.d.ts +0 -171
  753. package/dist/tools/cem-a11y-analyzer/types.d.ts.map +0 -1
@@ -1,8 +1,7 @@
1
- import { css as b, LitElement as v, nothing as x, html as f } from "lit";
2
- import "./document-token-adoption-DuYNKd4k.js";
3
- import { property as r, customElement as g } from "lit/decorators.js";
4
- import { autoUpdate as w, offset as _, autoPlacement as S, flip as A, shift as z, arrow as P, size as E, computePosition as C } from "@floating-ui/dom";
5
- const U = b`
1
+ import { css as A, nothing as z, html as m } from "lit";
2
+ import { property as r, customElement as P } from "lit/decorators.js";
3
+ import { H as U } from "./helix-element-BNEYeiys.js";
4
+ const E = A`
6
5
  :host {
7
6
  display: inline-block;
8
7
  }
@@ -46,14 +45,18 @@ const U = b`
46
45
  }
47
46
  }
48
47
  `;
49
- var k = Object.defineProperty, $ = Object.getOwnPropertyDescriptor, a = (t, o, e, i) => {
50
- for (var n = i > 1 ? void 0 : i ? $(o, e) : o, p = t.length - 1, l; p >= 0; p--)
51
- (l = t[p]) && (n = (i ? l(o, e, n) : l(n)) || n);
52
- return i && n && k(o, e, n), n;
48
+ var C = Object.defineProperty, k = Object.getOwnPropertyDescriptor, a = (t, i, e, s) => {
49
+ for (var n = s > 1 ? void 0 : s ? k(i, e) : i, p = t.length - 1, l; p >= 0; p--)
50
+ (l = t[p]) && (n = (s ? l(i, e, n) : l(n)) || n);
51
+ return s && n && C(i, e, n), n;
53
52
  };
54
- let s = class extends v {
53
+ let o = class extends U {
55
54
  constructor() {
56
- super(...arguments), this._anchorSlotEl = null, this._cleanupAutoUpdate = null, this.anchor = null, this.placement = "bottom", this.active = !1, this.distance = 0, this.skidding = 0, this.arrow = !1, this.arrowPlacement = null, this.arrowPadding = 10, this.flip = !1, this.flipFallbackPlacements = [], this.shift = !1, this.autoSize = !1, this.strategy = "fixed";
55
+ super(...arguments), this._anchorSlotEl = null, this._cleanupAutoUpdate = null, this._floatingUi = null, this.anchor = null, this.placement = "bottom", this.active = !1, this.distance = 0, this.skidding = 0, this.arrow = !1, this.arrowPlacement = null, this.arrowPadding = 10, this.flip = !1, this.flipFallbackPlacements = [], this.shift = !1, this.autoSize = !1, this.strategy = "fixed";
56
+ }
57
+ /** @internal */
58
+ async _loadFloatingUi() {
59
+ return this._floatingUi || (this._floatingUi = await import("@floating-ui/dom")), this._floatingUi;
57
60
  }
58
61
  // ─── Lifecycle ───
59
62
  connectedCallback() {
@@ -64,8 +67,8 @@ let s = class extends v {
64
67
  }
65
68
  updated(t) {
66
69
  super.updated(t);
67
- const o = t.has("active"), e = t.has("placement") || t.has("distance") || t.has("skidding") || t.has("arrow") || t.has("arrowPadding") || t.has("arrowPlacement") || t.has("flip") || t.has("flipFallbackPlacements") || t.has("shift") || t.has("autoSize") || t.has("anchor") || t.has("strategy");
68
- o ? this.active ? this._startAutoUpdate() : (this._stopAutoUpdate(), this.autoSize && (this.style.removeProperty("--hx-auto-size-available-width"), this.style.removeProperty("--hx-auto-size-available-height"))) : e && this.active && this._reposition(), t.has("autoSize") && !this.autoSize && (this.style.removeProperty("--hx-auto-size-available-width"), this.style.removeProperty("--hx-auto-size-available-height"));
70
+ const i = t.has("active"), e = t.has("placement") || t.has("distance") || t.has("skidding") || t.has("arrow") || t.has("arrowPadding") || t.has("arrowPlacement") || t.has("flip") || t.has("flipFallbackPlacements") || t.has("shift") || t.has("autoSize") || t.has("anchor") || t.has("strategy");
71
+ i ? this.active ? this._startAutoUpdate() : (this._stopAutoUpdate(), this.autoSize && (this.style.removeProperty("--hx-auto-size-available-width"), this.style.removeProperty("--hx-auto-size-available-height"))) : e && this.active && this._reposition(), t.has("autoSize") && !this.autoSize && (this.style.removeProperty("--hx-auto-size-available-width"), this.style.removeProperty("--hx-auto-size-available-height"));
69
72
  }
70
73
  // ─── Anchor Resolution ───
71
74
  /** @internal */
@@ -79,13 +82,15 @@ let s = class extends v {
79
82
  }
80
83
  // ─── Positioning ───
81
84
  /** @internal */
82
- _startAutoUpdate() {
83
- var e;
85
+ async _startAutoUpdate() {
86
+ var s;
84
87
  this._stopAutoUpdate();
85
- const t = this._getAnchorElement(), o = (e = this.shadowRoot) == null ? void 0 : e.querySelector('[part="popup"]');
86
- !t || !o || (this._cleanupAutoUpdate = w(t, o, () => {
88
+ const t = this._getAnchorElement(), i = (s = this.shadowRoot) == null ? void 0 : s.querySelector('[part="popup"]');
89
+ if (!t || !i) return;
90
+ const { autoUpdate: e } = await this._loadFloatingUi();
91
+ this._cleanupAutoUpdate = e(t, i, () => {
87
92
  this._reposition();
88
- }));
93
+ });
89
94
  }
90
95
  /** @internal */
91
96
  _stopAutoUpdate() {
@@ -94,53 +99,61 @@ let s = class extends v {
94
99
  }
95
100
  /** @internal */
96
101
  async _reposition() {
97
- var u, d;
98
- const t = this._getAnchorElement(), o = (u = this.shadowRoot) == null ? void 0 : u.querySelector('[part="popup"]');
99
- if (!t || !o) return;
100
- const e = this.arrow ? ((d = this.shadowRoot) == null ? void 0 : d.querySelector('[part="arrow"]')) ?? null : null, i = [
101
- _({ mainAxis: this.distance, crossAxis: this.skidding })
102
+ var d, f;
103
+ const t = this._getAnchorElement(), i = (d = this.shadowRoot) == null ? void 0 : d.querySelector('[part="popup"]');
104
+ if (!t || !i) return;
105
+ const e = this.arrow ? ((f = this.shadowRoot) == null ? void 0 : f.querySelector('[part="arrow"]')) ?? null : null, {
106
+ computePosition: s,
107
+ flip: n,
108
+ shift: p,
109
+ offset: l,
110
+ arrow: u,
111
+ size: y,
112
+ autoPlacement: b
113
+ } = await this._loadFloatingUi(), h = [
114
+ l({ mainAxis: this.distance, crossAxis: this.skidding })
102
115
  ];
103
- this.placement === "auto" ? i.push(S()) : this.flip && i.push(
104
- A({
116
+ this.placement === "auto" ? h.push(b()) : this.flip && h.push(
117
+ n({
105
118
  fallbackPlacements: this.flipFallbackPlacements
106
119
  })
107
- ), this.shift && i.push(z({ padding: 8 })), e && i.push(P({ element: e, padding: this.arrowPadding })), this.autoSize && i.push(
108
- E({
109
- apply: ({ availableWidth: h, availableHeight: y }) => {
110
- this.style.setProperty("--hx-auto-size-available-width", `${h}px`), this.style.setProperty("--hx-auto-size-available-height", `${y}px`);
120
+ ), this.shift && h.push(p({ padding: 8 })), e && h.push(u({ element: e, padding: this.arrowPadding })), this.autoSize && h.push(
121
+ y({
122
+ apply: ({ availableWidth: c, availableHeight: S }) => {
123
+ this.style.setProperty("--hx-auto-size-available-width", `${c}px`), this.style.setProperty("--hx-auto-size-available-height", `${S}px`);
111
124
  }
112
125
  })
113
126
  );
114
- const n = this.placement === "auto" ? "bottom" : this.placement;
115
- o.style.position = this.strategy;
116
- const { x: p, y: l, placement: c, middlewareData: m } = await C(t, o, {
117
- placement: n,
127
+ const v = this.placement === "auto" ? "bottom" : this.placement;
128
+ i.style.position = this.strategy;
129
+ const { x: w, y: x, placement: g, middlewareData: _ } = await s(t, i, {
130
+ placement: v,
118
131
  strategy: this.strategy,
119
- middleware: i
132
+ middleware: h
120
133
  });
121
- if (Object.assign(o.style, {
122
- left: `${p}px`,
123
- top: `${l}px`
134
+ if (Object.assign(i.style, {
135
+ left: `${w}px`,
136
+ top: `${x}px`
124
137
  }), e) {
125
- const h = m.arrow;
126
- this._positionArrow(e, c, h);
138
+ const c = _.arrow;
139
+ this._positionArrow(e, g, c);
127
140
  }
128
141
  this.dispatchEvent(new CustomEvent("hx-reposition", { bubbles: !0, composed: !0 }));
129
142
  }
130
143
  /** @internal */
131
- _positionArrow(t, o, e) {
132
- const i = o.split("-")[0], p = {
144
+ _positionArrow(t, i, e) {
145
+ const s = i.split("-")[0], p = {
133
146
  top: "bottom",
134
147
  right: "left",
135
148
  bottom: "top",
136
149
  left: "right"
137
- }[i], l = {
150
+ }[s], l = {
138
151
  left: "",
139
152
  top: "",
140
153
  right: "",
141
154
  bottom: ""
142
155
  };
143
- this.arrowPlacement === "start" || this.arrowPlacement === "end" ? i === "top" || i === "bottom" ? l[this.arrowPlacement === "start" ? "left" : "right"] = `${this.arrowPadding}px` : l[this.arrowPlacement === "start" ? "top" : "bottom"] = `${this.arrowPadding}px` : ((e == null ? void 0 : e.x) != null && (l.left = `${e.x}px`), (e == null ? void 0 : e.y) != null && (l.top = `${e.y}px`)), l[p] = "-4px", t.setAttribute("data-placement", i), Object.assign(t.style, l);
156
+ this.arrowPlacement === "start" || this.arrowPlacement === "end" ? s === "top" || s === "bottom" ? l[this.arrowPlacement === "start" ? "left" : "right"] = `${this.arrowPadding}px` : l[this.arrowPlacement === "start" ? "top" : "bottom"] = `${this.arrowPadding}px` : ((e == null ? void 0 : e.x) != null && (l.left = `${e.x}px`), (e == null ? void 0 : e.y) != null && (l.top = `${e.y}px`)), l[p] = "-4px", t.setAttribute("data-placement", s), Object.assign(t.style, l);
144
157
  }
145
158
  // ─── Public API ───
146
159
  /**
@@ -151,43 +164,43 @@ let s = class extends v {
151
164
  }
152
165
  // ─── Render ───
153
166
  render() {
154
- return f`
167
+ return m`
155
168
  <slot name="anchor" @slotchange=${this._handleAnchorSlotChange}></slot>
156
169
  <div part="popup" ?inert=${!this.active}>
157
170
  <slot></slot>
158
- ${this.arrow ? f`<div part="arrow"></div>` : x}
171
+ ${this.arrow ? m`<div part="arrow"></div>` : z}
159
172
  </div>
160
173
  `;
161
174
  }
162
175
  };
163
- s.styles = [U];
176
+ o.styles = [E];
164
177
  a([
165
178
  r({ attribute: "anchor" })
166
- ], s.prototype, "anchor", 2);
179
+ ], o.prototype, "anchor", 2);
167
180
  a([
168
181
  r({ type: String, reflect: !0 })
169
- ], s.prototype, "placement", 2);
182
+ ], o.prototype, "placement", 2);
170
183
  a([
171
184
  r({ type: Boolean, reflect: !0 })
172
- ], s.prototype, "active", 2);
185
+ ], o.prototype, "active", 2);
173
186
  a([
174
187
  r({ type: Number, reflect: !0 })
175
- ], s.prototype, "distance", 2);
188
+ ], o.prototype, "distance", 2);
176
189
  a([
177
190
  r({ type: Number, reflect: !0 })
178
- ], s.prototype, "skidding", 2);
191
+ ], o.prototype, "skidding", 2);
179
192
  a([
180
193
  r({ type: Boolean, reflect: !0 })
181
- ], s.prototype, "arrow", 2);
194
+ ], o.prototype, "arrow", 2);
182
195
  a([
183
196
  r({ attribute: "arrow-placement", reflect: !0 })
184
- ], s.prototype, "arrowPlacement", 2);
197
+ ], o.prototype, "arrowPlacement", 2);
185
198
  a([
186
199
  r({ type: Number, attribute: "arrow-padding" })
187
- ], s.prototype, "arrowPadding", 2);
200
+ ], o.prototype, "arrowPadding", 2);
188
201
  a([
189
202
  r({ type: Boolean, reflect: !0 })
190
- ], s.prototype, "flip", 2);
203
+ ], o.prototype, "flip", 2);
191
204
  a([
192
205
  r({
193
206
  attribute: "flip-fallback-placements",
@@ -205,20 +218,20 @@ a([
205
218
  }
206
219
  }
207
220
  })
208
- ], s.prototype, "flipFallbackPlacements", 2);
221
+ ], o.prototype, "flipFallbackPlacements", 2);
209
222
  a([
210
223
  r({ type: Boolean, reflect: !0 })
211
- ], s.prototype, "shift", 2);
224
+ ], o.prototype, "shift", 2);
212
225
  a([
213
226
  r({ type: Boolean, attribute: "auto-size", reflect: !0 })
214
- ], s.prototype, "autoSize", 2);
227
+ ], o.prototype, "autoSize", 2);
215
228
  a([
216
229
  r({ reflect: !0 })
217
- ], s.prototype, "strategy", 2);
218
- s = a([
219
- g("hx-popup")
220
- ], s);
230
+ ], o.prototype, "strategy", 2);
231
+ o = a([
232
+ P("hx-popup")
233
+ ], o);
221
234
  export {
222
- s as H
235
+ o as H
223
236
  };
224
- //# sourceMappingURL=hx-popup-Cc4qz89i.js.map
237
+ //# sourceMappingURL=hx-popup-DZXpsJ1R.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-popup-DZXpsJ1R.js","sources":["../../src/components/hx-popup/hx-popup.styles.ts","../../src/components/hx-popup/hx-popup.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixPopupStyles = css`\n :host {\n display: inline-block;\n }\n\n [part='popup'] {\n position: fixed;\n z-index: var(--hx-popup-z-index, 9000);\n inset: 0 auto auto 0;\n box-sizing: border-box;\n transition: var(--hx-popup-transition, none);\n }\n\n :host(:not([active])) [part='popup'] {\n display: none;\n }\n\n [part='arrow'] {\n position: absolute;\n width: var(--hx-arrow-size, 8px);\n height: var(--hx-arrow-size, 8px);\n background: var(--hx-arrow-color, var(--hx-color-neutral-0, #ffffff));\n transform: rotate(45deg);\n pointer-events: none;\n }\n\n @media (prefers-reduced-motion: reduce) {\n [part='popup'] {\n transition: none;\n }\n }\n\n /* ─── Forced Colors (Windows High Contrast) ─── */\n\n @media (forced-colors: active) {\n [part='popup'] {\n border: 1px solid CanvasText;\n }\n\n [part='arrow'] {\n border: 1px solid CanvasText;\n }\n }\n`;\n","import { html, nothing, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property } from 'lit/decorators.js';\nimport { HelixElement } from '../../base/index.js';\nimport type { Placement, Middleware } from '@floating-ui/dom';\nimport { helixPopupStyles } from './hx-popup.styles.js';\n\ntype PopupPlacement =\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'left'\n | 'left-start'\n | 'left-end'\n | 'auto';\n\n// More precise type matching @floating-ui/dom's arrow middleware data structure\ntype ArrowData = { x?: number; y?: number; centerOffset: number };\n\n/**\n * A low-level positioning primitive that anchors a floating panel to a reference element.\n * This is the base that hx-tooltip, hx-dropdown, and hx-popover build upon.\n *\n * @summary Low-level popup positioning utility.\n *\n * @tag hx-popup\n *\n * @slot anchor - The reference element the popup is anchored to.\n * @slot - Default slot for popup content.\n *\n * @csspart popup - The popup container element.\n * @csspart arrow - The arrow indicator element (only present when `arrow` is true).\n *\n * @cssprop [--hx-popup-z-index=9000] - Z-index of the popup container.\n * @cssprop [--hx-popup-transition=none] - Transition applied to the popup element.\n * Consumers who need enter/exit animations can set this property AND override the\n * default `display: none` hide mechanism via `::part(popup)`. Example:\n * ```css\n * hx-popup { --hx-popup-transition: opacity 0.2s ease; }\n * hx-popup:not([active])::part(popup) { display: block; opacity: 0; pointer-events: none; }\n * hx-popup[active]::part(popup) { opacity: 1; }\n * ```\n * @cssprop [--hx-arrow-size=8px] - Size of the arrow element.\n * @cssprop [--hx-arrow-color=var(--hx-color-surface-overlay, #ffffff)] - Color of the arrow element.\n * @cssprop --hx-auto-size-available-width - Available width set by auto-size middleware (on :host).\n * @cssprop --hx-auto-size-available-height - Available height set by auto-size middleware (on :host).\n *\n * @fires {CustomEvent} hx-reposition - Emitted after the popup is repositioned.\n *\n * ## Accessibility Contract\n *\n * `hx-popup` is a **positioning utility**, not an interactive widget. It does not provide\n * ARIA semantics. Consumers are responsible for all accessibility:\n *\n * - **Popup role**: Add `role=\"tooltip\"`, `role=\"dialog\"`, `role=\"listbox\"`, etc. to the\n * slotted popup content depending on its purpose.\n * - **Trigger state**: The element that triggers the popup MUST set `aria-expanded=\"true/false\"`.\n * - **Association**: Use `aria-controls` on the trigger to reference the popup content element,\n * and `aria-labelledby` / `aria-describedby` as appropriate.\n * - **Focus management**: `hx-popup` does NOT trap focus. Consumers building dialogs or menus\n * MUST implement focus trapping and keyboard dismiss (Escape key) themselves.\n * - **Visibility**: The popup is hidden via `display: none` (CSS) and the `inert` attribute\n * when inactive. Both are reliable accessibility-tree hiding mechanisms.\n *\n * @example\n * ```html\n * <!-- Tooltip pattern -->\n * <hx-popup id=\"my-tooltip\" placement=\"bottom\" distance=\"8\">\n * <button\n * slot=\"anchor\"\n * aria-describedby=\"tooltip-content\"\n * aria-expanded=\"false\"\n * aria-controls=\"my-tooltip\"\n * >\n * Trigger\n * </button>\n * <div id=\"tooltip-content\" role=\"tooltip\">Tooltip text</div>\n * </hx-popup>\n * ```\n *\n * ## Drupal Integration\n *\n * `hx-popup` is a JS utility — Twig provides markup only. No Drupal behavior file is\n * required for basic usage, since the `anchor` slot and `active` attribute are sufficient.\n *\n * ```twig\n * {# Basic Twig usage — prefer anchor slot in server-rendered contexts #}\n * <hx-popup id=\"my-popup\" placement=\"bottom\" distance=\"8\">\n * <button\n * slot=\"anchor\"\n * aria-expanded=\"false\"\n * aria-controls=\"popup-content\"\n * >Open</button>\n * <div id=\"popup-content\" role=\"dialog\" aria-label=\"Popup content\">...</div>\n * </hx-popup>\n * ```\n *\n * ```js\n * // Drupal behavior for toggle interaction\n * Drupal.behaviors.helixPopup = {\n * attach(context) {\n * context.querySelectorAll('hx-popup').forEach((popup) => {\n * const trigger = popup.querySelector('[slot=\"anchor\"]');\n * if (!trigger) return;\n * trigger.addEventListener('click', () => {\n * popup.active = !popup.active;\n * trigger.setAttribute('aria-expanded', String(popup.active));\n * });\n * });\n * },\n * };\n * ```\n *\n * For Drupal-generated dynamic IDs, prefer the anchor **slot** over the `anchor` CSS selector\n * attribute, since slot-based anchoring does not require knowing the element's ID at render time.\n * If you must use the CSS selector form with dynamic IDs, pass the ID via a Twig variable:\n * ```twig\n * <hx-popup anchor=\"#{{ element['#id'] }}\" placement=\"bottom\">...</hx-popup>\n * ```\n */\n@customElement('hx-popup')\nexport class HelixPopup extends HelixElement {\n static override styles = [helixPopupStyles];\n\n /** @internal */\n private _anchorSlotEl: Element | null = null;\n /** @internal */\n private _cleanupAutoUpdate: (() => void) | null = null;\n /** @internal */\n private _floatingUi: typeof import('@floating-ui/dom') | null = null;\n\n /** @internal */\n private async _loadFloatingUi() {\n if (!this._floatingUi) {\n this._floatingUi = await import('@floating-ui/dom');\n }\n return this._floatingUi;\n }\n\n /**\n * The reference element to anchor the popup to.\n *\n * - **Attribute form** (`anchor=\"#selector\"`): Accepts a CSS selector string resolved via\n * `querySelector` from the component's root node. Use this in HTML/Twig markup.\n * - **Property form** (`el.anchor = element`): Accepts an `Element` reference directly.\n * Setting an Element via JS property does NOT reflect to the attribute.\n *\n * If not set, the element in the `anchor` slot is used.\n *\n * @attr anchor\n */\n @property({ attribute: 'anchor' })\n anchor: string | Element | null = null;\n\n /**\n * Preferred placement of the popup relative to the anchor.\n * @attr placement\n */\n @property({ type: String, reflect: true })\n placement:\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'left'\n | 'left-start'\n | 'left-end'\n | 'auto' = 'bottom';\n\n /**\n * Whether the popup is visible.\n * @attr active\n */\n @property({ type: Boolean, reflect: true })\n active = false;\n\n /**\n * Gap in pixels between the popup and the anchor element.\n * @attr distance\n */\n @property({ type: Number, reflect: true })\n distance = 0;\n\n /**\n * Offset in pixels along the anchor element's axis.\n * @attr skidding\n */\n @property({ type: Number, reflect: true })\n skidding = 0;\n\n /**\n * Whether to show an arrow pointing to the anchor element.\n * @attr arrow\n */\n @property({ type: Boolean, reflect: true })\n arrow = false;\n\n /**\n * Manual placement of the arrow along the popup edge.\n * When not set, floating-ui calculates the optimal position.\n * @attr arrow-placement\n */\n @property({ attribute: 'arrow-placement', reflect: true })\n arrowPlacement: 'start' | 'center' | 'end' | null = null;\n\n /**\n * Minimum padding in pixels from the popup edge to the arrow.\n * @attr arrow-padding\n */\n @property({ type: Number, attribute: 'arrow-padding' })\n arrowPadding = 10;\n\n /**\n * When true, flips the popup to the opposite side to avoid overflow.\n * @attr flip\n */\n @property({ type: Boolean, reflect: true })\n flip = false;\n\n /**\n * Fallback placements to try when flipping. Accepts a JSON array string.\n *\n * @example\n * ```html\n * <!-- Try \"top\" then \"left\" before giving up -->\n * <hx-popup flip flip-fallback-placements='[\"top\",\"left\"]'>...</hx-popup>\n * ```\n *\n * @attr flip-fallback-placements\n */\n @property({\n attribute: 'flip-fallback-placements',\n converter: {\n fromAttribute(value: string | null): PopupPlacement[] {\n if (!value) return [];\n try {\n return JSON.parse(value) as PopupPlacement[];\n } catch {\n return [];\n }\n },\n toAttribute(value: PopupPlacement[]): string {\n return JSON.stringify(value);\n },\n },\n })\n flipFallbackPlacements: (\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'right'\n | 'right-start'\n | 'right-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'left'\n | 'left-start'\n | 'left-end'\n | 'auto'\n )[] = [];\n\n /**\n * When true, shifts the popup along the axis to remain in the viewport.\n * @attr shift\n */\n @property({ type: Boolean, reflect: true })\n shift = false;\n\n /**\n * When true, resizes the popup to fit within the viewport.\n * Sets --hx-auto-size-available-width and --hx-auto-size-available-height CSS custom\n * properties on `:host` so they cascade into shadow DOM and are readable from light DOM.\n * @attr auto-size\n */\n @property({ type: Boolean, attribute: 'auto-size', reflect: true })\n autoSize = false;\n\n /**\n * Positioning strategy passed to floating-ui's `computePosition`.\n *\n * - `'fixed'` (default): works for most cases; positions relative to the viewport.\n * - `'absolute'`: use inside `overflow: hidden` / scroll containers where the popup is\n * positioned relative to the nearest positioned ancestor instead of the viewport.\n *\n * @attr strategy\n */\n @property({ reflect: true })\n strategy: 'fixed' | 'absolute' = 'fixed';\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.active) {\n void this.updateComplete.then(() => this._startAutoUpdate());\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._stopAutoUpdate();\n }\n\n override updated(changedProperties: PropertyValues<this>): void {\n super.updated(changedProperties);\n\n const activeChanged = changedProperties.has('active');\n const positioningChanged =\n changedProperties.has('placement') ||\n changedProperties.has('distance') ||\n changedProperties.has('skidding') ||\n changedProperties.has('arrow') ||\n changedProperties.has('arrowPadding') ||\n changedProperties.has('arrowPlacement') ||\n changedProperties.has('flip') ||\n changedProperties.has('flipFallbackPlacements') ||\n changedProperties.has('shift') ||\n changedProperties.has('autoSize') ||\n changedProperties.has('anchor') ||\n changedProperties.has('strategy');\n\n if (activeChanged) {\n if (this.active) {\n void this._startAutoUpdate();\n } else {\n this._stopAutoUpdate();\n // Clean up autoSize custom properties when popup goes inactive\n if (this.autoSize) {\n this.style.removeProperty('--hx-auto-size-available-width');\n this.style.removeProperty('--hx-auto-size-available-height');\n }\n }\n } else if (positioningChanged && this.active) {\n void this._reposition();\n }\n\n // Remove stale autoSize properties when autoSize is disabled\n if (changedProperties.has('autoSize') && !this.autoSize) {\n this.style.removeProperty('--hx-auto-size-available-width');\n this.style.removeProperty('--hx-auto-size-available-height');\n }\n }\n\n // ─── Anchor Resolution ───\n\n /** @internal */\n private _getAnchorElement(): Element | null {\n if (this.anchor instanceof Element) {\n return this.anchor;\n }\n if (typeof this.anchor === 'string') {\n return (this.getRootNode() as Document | ShadowRoot).querySelector(this.anchor);\n }\n return this._anchorSlotEl;\n }\n\n /** @internal */\n private _handleAnchorSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n const assigned = slot.assignedElements();\n this._anchorSlotEl = assigned[0] ?? null;\n if (this.active) {\n void this._reposition();\n }\n }\n\n // ─── Positioning ───\n\n /** @internal */\n private async _startAutoUpdate(): Promise<void> {\n this._stopAutoUpdate();\n const anchorEl = this._getAnchorElement();\n const popupEl = this.shadowRoot?.querySelector<HTMLElement>('[part=\"popup\"]');\n if (!anchorEl || !popupEl) return;\n\n const { autoUpdate } = await this._loadFloatingUi();\n this._cleanupAutoUpdate = autoUpdate(anchorEl, popupEl, () => {\n void this._reposition();\n });\n }\n\n /** @internal */\n private _stopAutoUpdate(): void {\n this._cleanupAutoUpdate?.();\n this._cleanupAutoUpdate = null;\n }\n\n /** @internal */\n private async _reposition(): Promise<void> {\n const anchorEl = this._getAnchorElement();\n const popupEl = this.shadowRoot?.querySelector<HTMLElement>('[part=\"popup\"]');\n if (!anchorEl || !popupEl) return;\n\n const arrowEl = this.arrow\n ? (this.shadowRoot?.querySelector<HTMLElement>('[part=\"arrow\"]') ?? null)\n : null;\n\n const {\n computePosition,\n flip: flipMiddleware,\n shift: shiftMiddleware,\n offset: offsetMiddleware,\n arrow: arrowMiddleware,\n size: sizeMiddleware,\n autoPlacement: autoPlacementMiddleware,\n } = await this._loadFloatingUi();\n\n const middleware: Middleware[] = [\n offsetMiddleware({ mainAxis: this.distance, crossAxis: this.skidding }),\n ];\n\n if (this.placement === 'auto') {\n middleware.push(autoPlacementMiddleware());\n } else if (this.flip) {\n middleware.push(\n flipMiddleware({\n fallbackPlacements: this.flipFallbackPlacements as Placement[],\n }),\n );\n }\n\n if (this.shift) {\n middleware.push(shiftMiddleware({ padding: 8 }));\n }\n\n if (arrowEl) {\n middleware.push(arrowMiddleware({ element: arrowEl, padding: this.arrowPadding }));\n }\n\n if (this.autoSize) {\n middleware.push(\n sizeMiddleware({\n apply: ({ availableWidth, availableHeight }) => {\n this.style.setProperty('--hx-auto-size-available-width', `${availableWidth}px`);\n this.style.setProperty('--hx-auto-size-available-height', `${availableHeight}px`);\n },\n }),\n );\n }\n\n const effectivePlacement: Placement =\n this.placement === 'auto' ? 'bottom' : (this.placement as Placement);\n\n popupEl.style.position = this.strategy;\n\n const { x, y, placement, middlewareData } = await computePosition(anchorEl, popupEl, {\n placement: effectivePlacement,\n strategy: this.strategy,\n middleware,\n });\n\n Object.assign(popupEl.style, {\n left: `${x}px`,\n top: `${y}px`,\n });\n\n if (arrowEl) {\n const arrowData = middlewareData.arrow as ArrowData | undefined;\n this._positionArrow(arrowEl, placement, arrowData);\n }\n\n this.dispatchEvent(new CustomEvent<void>('hx-reposition', { bubbles: true, composed: true }));\n }\n\n /** @internal */\n private _positionArrow(\n arrowEl: HTMLElement,\n placement: Placement,\n arrowData: ArrowData | undefined,\n ): void {\n const basePlacement = placement.split('-')[0] as 'top' | 'right' | 'bottom' | 'left';\n const staticSides = {\n top: 'bottom',\n right: 'left',\n bottom: 'top',\n left: 'right',\n } as const;\n const staticSide = staticSides[basePlacement];\n\n const arrowStyle: Record<string, string> = {\n left: '',\n top: '',\n right: '',\n bottom: '',\n };\n\n if (this.arrowPlacement === 'start' || this.arrowPlacement === 'end') {\n const isVertical = basePlacement === 'top' || basePlacement === 'bottom';\n if (isVertical) {\n arrowStyle[this.arrowPlacement === 'start' ? 'left' : 'right'] = `${this.arrowPadding}px`;\n } else {\n arrowStyle[this.arrowPlacement === 'start' ? 'top' : 'bottom'] = `${this.arrowPadding}px`;\n }\n } else {\n // 'center' or null: use floating-ui computed position\n if (arrowData?.x != null) arrowStyle.left = `${arrowData.x}px`;\n if (arrowData?.y != null) arrowStyle.top = `${arrowData.y}px`;\n }\n\n arrowStyle[staticSide] = '-4px';\n arrowEl.setAttribute('data-placement', basePlacement);\n Object.assign(arrowEl.style, arrowStyle);\n }\n\n // ─── Public API ───\n\n /**\n * Forces the popup to recalculate its position.\n */\n async reposition(): Promise<void> {\n await this._reposition();\n }\n\n // ─── Render ───\n\n override render() {\n return html`\n <slot name=\"anchor\" @slotchange=${this._handleAnchorSlotChange}></slot>\n <div part=\"popup\" ?inert=${!this.active}>\n <slot></slot>\n ${this.arrow ? html`<div part=\"arrow\"></div>` : nothing}\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-popup': HelixPopup;\n }\n}\n"],"names":["helixPopupStyles","css","HelixPopup","HelixElement","changedProperties","activeChanged","positioningChanged","e","assigned","anchorEl","popupEl","_a","autoUpdate","arrowEl","_b","computePosition","flipMiddleware","shiftMiddleware","offsetMiddleware","arrowMiddleware","sizeMiddleware","autoPlacementMiddleware","middleware","availableWidth","availableHeight","effectivePlacement","x","y","placement","middlewareData","arrowData","basePlacement","staticSide","arrowStyle","html","nothing","__decorateClass","property","value","customElement"],"mappings":"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"}
@@ -1,9 +1,9 @@
1
- import { css as m, LitElement as u, nothing as b, 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 c } from "lit/directives/if-defined.js";
6
- import { c as f } from "./id-counter-PTgF-zcG.js";
1
+ import { css as m, nothing as g, html as p } from "lit";
2
+ import { property as o, state as c, customElement as u } from "lit/decorators.js";
3
+ import { classMap as v } from "lit/directives/class-map.js";
4
+ import { ifDefined as b } from "lit/directives/if-defined.js";
5
+ import { H as _ } from "./helix-element-BNEYeiys.js";
6
+ import { c as f } from "./id-counter-DuX8vsui.js";
7
7
  const x = m`
8
8
  :host {
9
9
  display: block;
@@ -120,7 +120,7 @@ const x = m`
120
120
  .progress-bar--indeterminate .progress-bar__fill {
121
121
  animation: none;
122
122
  transform: scaleX(1);
123
- opacity: var(--hx-opacity-disabled, 0.5); /* reduced from animation; no exact token for 0.4 */
123
+ opacity: var(--hx-opacity-disabled, 0.5);
124
124
  }
125
125
  }
126
126
 
@@ -144,7 +144,7 @@ var y = Object.defineProperty, $ = Object.getOwnPropertyDescriptor, a = (r, t, n
144
144
  return l && s && y(t, n, s), s;
145
145
  };
146
146
  const w = f("hx-progress-bar");
147
- let e = class extends u {
147
+ let e = class extends _ {
148
148
  constructor() {
149
149
  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 = w();
150
150
  }
@@ -187,26 +187,26 @@ let e = class extends u {
187
187
  "progress-bar--indeterminate": this._isIndeterminate
188
188
  }, 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;
189
189
  return p`
190
- <div class=${_(l)}>
190
+ <div class=${v(l)}>
191
191
  ${n || this.label ? p`<span id=${r} part="label" class="progress-bar__label">
192
192
  <slot name="label" @slotchange=${this._onLabelSlotChange}></slot>
193
193
  </span>` : p`<slot name="label" @slotchange=${this._onLabelSlotChange} hidden></slot>`}
194
- ${this.description ? p`<span id=${t} class="sr-only">${this.description}</span>` : b}
194
+ ${this.description ? p`<span id=${t} class="sr-only">${this.description}</span>` : g}
195
195
  <div
196
196
  part="track"
197
197
  class="progress-bar__track"
198
198
  role="progressbar"
199
- aria-valuenow=${c(s)}
199
+ aria-valuenow=${b(s)}
200
200
  aria-valuemin=${this.min}
201
201
  aria-valuemax=${this.max}
202
202
  aria-valuetext=${d}
203
- aria-label=${c(!n && this.label ? this.label : void 0)}
204
- aria-labelledby=${c(n ? r : void 0)}
205
- aria-describedby=${c(t)}
203
+ aria-label=${b(!n && this.label ? this.label : void 0)}
204
+ aria-labelledby=${b(n ? r : void 0)}
205
+ aria-describedby=${b(t)}
206
206
  >
207
207
  <div part="fill" class="progress-bar__fill"></div>
208
208
  </div>
209
- ${i ? p`<span class="sr-only progress-bar__variant-label">${i}</span>` : b}
209
+ ${i ? p`<span class="sr-only progress-bar__variant-label">${i}</span>` : g}
210
210
  <div aria-live="polite" aria-atomic="true" class="sr-only">${this._liveMessage}</div>
211
211
  </div>
212
212
  `;
@@ -243,15 +243,15 @@ a([
243
243
  o({ type: String, reflect: !0 })
244
244
  ], e.prototype, "variant", 2);
245
245
  a([
246
- g()
246
+ c()
247
247
  ], e.prototype, "_liveMessage", 2);
248
248
  a([
249
- g()
249
+ c()
250
250
  ], e.prototype, "_hasLabelSlotContent", 2);
251
251
  e = a([
252
- v("hx-progress-bar")
252
+ u("hx-progress-bar")
253
253
  ], e);
254
254
  export {
255
255
  e as H
256
256
  };
257
- //# sourceMappingURL=hx-progress-bar-BY1uE6bN.js.map
257
+ //# sourceMappingURL=hx-progress-bar-KjEkEJLy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-progress-bar-KjEkEJLy.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);\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 { 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 { HelixElement, createIdCounter } from '../../base/index.js';\nimport { helixProgressBarStyles } from './hx-progress-bar.styles.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\nconst _nextProgressBarId = createIdCounter('hx-progress-bar');\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 HelixElement {\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 _uid = _nextProgressBarId();\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","_nextProgressBarId","createIdCounter","HelixProgressBar","HelixElement","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,6 +1,6 @@
1
- import { css as c, LitElement as g, svg as d, html as u } from "lit";
2
- import "./document-token-adoption-DuYNKd4k.js";
3
- import { property as n, customElement as p } from "lit/decorators.js";
1
+ import { css as c, svg as g, html as d } from "lit";
2
+ import { property as o, customElement as p } from "lit/decorators.js";
3
+ import { H as u } from "./helix-element-BNEYeiys.js";
4
4
  const m = c`
5
5
  :host {
6
6
  display: inline-flex;
@@ -138,18 +138,40 @@ const m = c`
138
138
  justify-content: center;
139
139
  inset: 0;
140
140
  font-size: var(--hx-font-size-xs, 0.75rem);
141
- font-family: var(--hx-font-family-sans, sans-serif);
141
+ font-family: var(--hx-progress-ring-font-family, var(--hx-font-family-sans, sans-serif));
142
142
  font-weight: var(--hx-font-weight-semibold, 600);
143
143
  color: var(--hx-progress-ring-label-color, var(--hx-color-neutral-900, #0f172a));
144
144
  pointer-events: none;
145
145
  }
146
+
147
+ /* ─── High Contrast Mode (forced-colors) ─── */
148
+
149
+ @media (forced-colors: active) {
150
+ /*
151
+ * SVG stroke colors are suppressed in forced-colors mode. Use system color
152
+ * keywords so progress state remains distinguishable.
153
+ */
154
+ .progress-ring__track {
155
+ stroke: GrayText;
156
+ }
157
+
158
+ .progress-ring__indicator {
159
+ stroke: Highlight;
160
+ }
161
+
162
+ :host([variant='success']) .progress-ring__indicator,
163
+ :host([variant='warning']) .progress-ring__indicator,
164
+ :host([variant='danger']) .progress-ring__indicator {
165
+ stroke: Highlight;
166
+ }
167
+ }
146
168
  `;
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
- (h = r[l]) && (s = (t ? h(o, a, s) : h(s)) || s);
150
- return t && s && f(o, a, s), s;
169
+ var f = Object.defineProperty, v = Object.getOwnPropertyDescriptor, i = (e, n, a, t) => {
170
+ for (var s = t > 1 ? void 0 : t ? v(n, a) : n, l = e.length - 1, h; l >= 0; l--)
171
+ (h = e[l]) && (s = (t ? h(n, a, s) : h(s)) || s);
172
+ return t && s && f(n, a, s), s;
151
173
  };
152
- let e = class extends g {
174
+ let r = class extends u {
153
175
  constructor() {
154
176
  super(...arguments), this.value = null, this.max = 100, this.size = "md", this.strokeWidth = 4, this.variant = "default", this.label = "", this._labelWarned = !1;
155
177
  }
@@ -180,16 +202,16 @@ let e = class extends g {
180
202
  // ─── Lifecycle ───
181
203
  connectedCallback() {
182
204
  super.connectedCallback();
183
- const r = this.getAttribute("size");
184
- r !== null && !this.hasAttribute("hx-size") && (this.size = r), this.setAttribute("role", "progressbar"), this.setAttribute("aria-valuemin", "0");
205
+ const e = this.getAttribute("size");
206
+ e !== null && !this.hasAttribute("hx-size") && (this.size = e), this.setAttribute("role", "progressbar"), this.setAttribute("aria-valuemin", "0");
185
207
  }
186
- willUpdate(r) {
208
+ willUpdate(e) {
187
209
  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
210
  }
189
211
  // ─── Render ───
190
212
  render() {
191
213
  const a = this._radius, t = this._circumference;
192
- return u`
214
+ return d`
193
215
  <div class="progress-ring">
194
216
  <svg
195
217
  class="progress-ring__svg"
@@ -198,7 +220,7 @@ let e = class extends g {
198
220
  aria-hidden="true"
199
221
  focusable="false"
200
222
  >
201
- ${d`
223
+ ${g`
202
224
  <circle
203
225
  class="progress-ring__track"
204
226
  part="track"
@@ -226,29 +248,29 @@ let e = class extends g {
226
248
  `;
227
249
  }
228
250
  };
229
- e.styles = [m];
251
+ r.styles = [m];
230
252
  i([
231
- n({ type: Number, reflect: !0 })
232
- ], e.prototype, "value", 2);
253
+ o({ type: Number, reflect: !0 })
254
+ ], r.prototype, "value", 2);
233
255
  i([
234
- n({ type: Number, reflect: !0 })
235
- ], e.prototype, "max", 2);
256
+ o({ type: Number, reflect: !0 })
257
+ ], r.prototype, "max", 2);
236
258
  i([
237
- n({ type: String, reflect: !0, attribute: "hx-size" })
238
- ], e.prototype, "size", 2);
259
+ o({ type: String, reflect: !0, attribute: "hx-size" })
260
+ ], r.prototype, "size", 2);
239
261
  i([
240
- n({ type: Number, attribute: "stroke-width", reflect: !0 })
241
- ], e.prototype, "strokeWidth", 2);
262
+ o({ type: Number, attribute: "stroke-width", reflect: !0 })
263
+ ], r.prototype, "strokeWidth", 2);
242
264
  i([
243
- n({ type: String, reflect: !0 })
244
- ], e.prototype, "variant", 2);
265
+ o({ type: String, reflect: !0 })
266
+ ], r.prototype, "variant", 2);
245
267
  i([
246
- n({ type: String })
247
- ], e.prototype, "label", 2);
248
- e = i([
268
+ o({ type: String })
269
+ ], r.prototype, "label", 2);
270
+ r = i([
249
271
  p("hx-progress-ring")
250
- ], e);
272
+ ], r);
251
273
  export {
252
- e as H
274
+ r as H
253
275
  };
254
- //# sourceMappingURL=hx-progress-ring-Cs0WgWDJ.js.map
276
+ //# sourceMappingURL=hx-progress-ring-3zMwvrwD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-progress-ring-3zMwvrwD.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([hx-size='sm']) .progress-ring {\n width: var(--hx-size-8, 2rem);\n height: var(--hx-size-8, 2rem);\n }\n\n :host([hx-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([hx-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-progress-ring-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 /* ─── High Contrast Mode (forced-colors) ─── */\n\n @media (forced-colors: active) {\n /*\n * SVG stroke colors are suppressed in forced-colors mode. Use system color\n * keywords so progress state remains distinguishable.\n */\n .progress-ring__track {\n stroke: GrayText;\n }\n\n .progress-ring__indicator {\n stroke: Highlight;\n }\n\n :host([variant='success']) .progress-ring__indicator,\n :host([variant='warning']) .progress-ring__indicator,\n :host([variant='danger']) .progress-ring__indicator {\n stroke: Highlight;\n }\n }\n`;\n","import { html, svg, TemplateResult, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property } from 'lit/decorators.js';\nimport { HelixElement } from '../../base/index.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 HelixElement {\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","HelixElement","legacySize","_changed","r","circumference","html","svg","__decorateClass","property","customElement"],"mappings":"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"}