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

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 (477) hide show
  1. package/custom-elements.json +522 -466
  2. package/dist/base/helix-element.d.ts.map +1 -1
  3. package/dist/components/hx-accordion/hx-accordion-item.d.ts +0 -2
  4. package/dist/components/hx-accordion/hx-accordion-item.d.ts.map +1 -1
  5. package/dist/components/hx-accordion/hx-accordion-item.styles.d.ts.map +1 -1
  6. package/dist/components/hx-accordion/hx-accordion.styles.d.ts.map +1 -1
  7. package/dist/components/hx-accordion/index.js +1 -1
  8. package/dist/components/hx-alert/hx-alert.styles.d.ts.map +1 -1
  9. package/dist/components/hx-alert/index.js +1 -1
  10. package/dist/components/hx-badge/hx-badge.styles.d.ts.map +1 -1
  11. package/dist/components/hx-badge/index.js +1 -1
  12. package/dist/components/hx-banner/hx-banner.styles.d.ts.map +1 -1
  13. package/dist/components/hx-banner/index.js +1 -1
  14. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.d.ts.map +1 -1
  15. package/dist/components/hx-breadcrumb/hx-breadcrumb-item.styles.d.ts.map +1 -1
  16. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts +0 -7
  17. package/dist/components/hx-breadcrumb/hx-breadcrumb.d.ts.map +1 -1
  18. package/dist/components/hx-breadcrumb/index.js +1 -1
  19. package/dist/components/hx-button/hx-button.d.ts +9 -9
  20. package/dist/components/hx-button/hx-button.d.ts.map +1 -1
  21. package/dist/components/hx-button/hx-button.styles.d.ts.map +1 -1
  22. package/dist/components/hx-button/index.js +1 -1
  23. package/dist/components/hx-button-group/hx-button-group.d.ts +1 -4
  24. package/dist/components/hx-button-group/hx-button-group.d.ts.map +1 -1
  25. package/dist/components/hx-button-group/index.js +1 -1
  26. package/dist/components/hx-card/hx-card.d.ts +16 -0
  27. package/dist/components/hx-card/hx-card.d.ts.map +1 -1
  28. package/dist/components/hx-card/hx-card.styles.d.ts.map +1 -1
  29. package/dist/components/hx-card/index.js +1 -1
  30. package/dist/components/hx-carousel/hx-carousel.d.ts.map +1 -1
  31. package/dist/components/hx-carousel/hx-carousel.styles.d.ts.map +1 -1
  32. package/dist/components/hx-carousel/index.js +1 -1
  33. package/dist/components/hx-checkbox/hx-checkbox.d.ts +8 -0
  34. package/dist/components/hx-checkbox/hx-checkbox.d.ts.map +1 -1
  35. package/dist/components/hx-checkbox/hx-checkbox.styles.d.ts.map +1 -1
  36. package/dist/components/hx-checkbox/index.js +1 -1
  37. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts +6 -8
  38. package/dist/components/hx-checkbox-group/hx-checkbox-group.d.ts.map +1 -1
  39. package/dist/components/hx-checkbox-group/hx-checkbox-group.styles.d.ts.map +1 -1
  40. package/dist/components/hx-checkbox-group/index.js +1 -1
  41. package/dist/components/hx-clinical-status/hx-clinical-status.styles.d.ts.map +1 -1
  42. package/dist/components/hx-clinical-status/index.js +1 -1
  43. package/dist/components/hx-code-snippet/hx-code-snippet.styles.d.ts.map +1 -1
  44. package/dist/components/hx-code-snippet/index.js +1 -1
  45. package/dist/components/hx-color-picker/hx-color-picker.styles.d.ts.map +1 -1
  46. package/dist/components/hx-color-picker/index.js +1 -1
  47. package/dist/components/hx-combobox/hx-combobox.d.ts +20 -14
  48. package/dist/components/hx-combobox/hx-combobox.d.ts.map +1 -1
  49. package/dist/components/hx-combobox/hx-combobox.styles.d.ts.map +1 -1
  50. package/dist/components/hx-combobox/index.js +1 -1
  51. package/dist/components/hx-copy-button/hx-copy-button.styles.d.ts.map +1 -1
  52. package/dist/components/hx-copy-button/index.js +1 -1
  53. package/dist/components/hx-counter/hx-counter.styles.d.ts.map +1 -1
  54. package/dist/components/hx-counter/index.js +1 -1
  55. package/dist/components/hx-data-table/hx-data-table.d.ts +20 -0
  56. package/dist/components/hx-data-table/hx-data-table.d.ts.map +1 -1
  57. package/dist/components/hx-data-table/hx-data-table.styles.d.ts.map +1 -1
  58. package/dist/components/hx-data-table/index.js +1 -1
  59. package/dist/components/hx-date-picker/hx-date-picker.d.ts +6 -17
  60. package/dist/components/hx-date-picker/hx-date-picker.d.ts.map +1 -1
  61. package/dist/components/hx-date-picker/index.js +1 -1
  62. package/dist/components/hx-dialog/hx-dialog.d.ts +7 -0
  63. package/dist/components/hx-dialog/hx-dialog.d.ts.map +1 -1
  64. package/dist/components/hx-dialog/hx-dialog.styles.d.ts.map +1 -1
  65. package/dist/components/hx-dialog/index.js +1 -1
  66. package/dist/components/hx-divider/hx-divider.styles.d.ts.map +1 -1
  67. package/dist/components/hx-divider/index.js +1 -1
  68. package/dist/components/hx-drawer/hx-drawer.d.ts +7 -0
  69. package/dist/components/hx-drawer/hx-drawer.d.ts.map +1 -1
  70. package/dist/components/hx-drawer/hx-drawer.styles.d.ts.map +1 -1
  71. package/dist/components/hx-drawer/index.js +1 -1
  72. package/dist/components/hx-dropdown/hx-dropdown.d.ts +8 -5
  73. package/dist/components/hx-dropdown/hx-dropdown.d.ts.map +1 -1
  74. package/dist/components/hx-dropdown/hx-dropdown.styles.d.ts.map +1 -1
  75. package/dist/components/hx-dropdown/index.js +1 -1
  76. package/dist/components/hx-field/hx-field.d.ts.map +1 -1
  77. package/dist/components/hx-field/hx-field.styles.d.ts.map +1 -1
  78. package/dist/components/hx-field/index.js +1 -1
  79. package/dist/components/hx-field-label/hx-field-label.styles.d.ts.map +1 -1
  80. package/dist/components/hx-field-label/index.js +1 -1
  81. package/dist/components/hx-file-upload/hx-file-upload.d.ts +6 -14
  82. package/dist/components/hx-file-upload/hx-file-upload.d.ts.map +1 -1
  83. package/dist/components/hx-file-upload/index.js +1 -1
  84. package/dist/components/hx-help-text/hx-help-text.styles.d.ts.map +1 -1
  85. package/dist/components/hx-help-text/index.js +1 -1
  86. package/dist/components/hx-icon/hx-icon.styles.d.ts.map +1 -1
  87. package/dist/components/hx-icon/index.js +1 -1
  88. package/dist/components/hx-icon-button/hx-icon-button.d.ts +10 -14
  89. package/dist/components/hx-icon-button/hx-icon-button.d.ts.map +1 -1
  90. package/dist/components/hx-icon-button/hx-icon-button.styles.d.ts.map +1 -1
  91. package/dist/components/hx-icon-button/index.js +1 -1
  92. package/dist/components/hx-image/hx-image.styles.d.ts.map +1 -1
  93. package/dist/components/hx-image/index.js +1 -1
  94. package/dist/components/hx-link/hx-link.styles.d.ts.map +1 -1
  95. package/dist/components/hx-link/index.js +1 -1
  96. package/dist/components/hx-list/index.js +1 -1
  97. package/dist/components/hx-menu/hx-menu-divider.styles.d.ts.map +1 -1
  98. package/dist/components/hx-menu/hx-menu-item.styles.d.ts.map +1 -1
  99. package/dist/components/hx-menu/hx-menu.styles.d.ts.map +1 -1
  100. package/dist/components/hx-menu/index.js +1 -1
  101. package/dist/components/hx-meter/hx-meter.d.ts +0 -2
  102. package/dist/components/hx-meter/hx-meter.d.ts.map +1 -1
  103. package/dist/components/hx-meter/hx-meter.styles.d.ts.map +1 -1
  104. package/dist/components/hx-meter/index.js +1 -1
  105. package/dist/components/hx-nav/hx-nav.styles.d.ts.map +1 -1
  106. package/dist/components/hx-nav/index.js +1 -1
  107. package/dist/components/hx-number-input/hx-number-input.d.ts +6 -8
  108. package/dist/components/hx-number-input/hx-number-input.d.ts.map +1 -1
  109. package/dist/components/hx-number-input/hx-number-input.styles.d.ts.map +1 -1
  110. package/dist/components/hx-number-input/index.js +1 -1
  111. package/dist/components/hx-overflow-menu/hx-overflow-menu.d.ts.map +1 -1
  112. package/dist/components/hx-overflow-menu/hx-overflow-menu.styles.d.ts.map +1 -1
  113. package/dist/components/hx-overflow-menu/index.js +1 -1
  114. package/dist/components/hx-patient-banner/hx-patient-banner.styles.d.ts.map +1 -1
  115. package/dist/components/hx-patient-banner/index.js +1 -1
  116. package/dist/components/hx-phi-field/index.js +1 -1
  117. package/dist/components/hx-popover/hx-popover.d.ts +1 -0
  118. package/dist/components/hx-popover/hx-popover.d.ts.map +1 -1
  119. package/dist/components/hx-popover/hx-popover.styles.d.ts.map +1 -1
  120. package/dist/components/hx-popover/index.js +1 -1
  121. package/dist/components/hx-popup/hx-popup.styles.d.ts.map +1 -1
  122. package/dist/components/hx-popup/index.js +1 -1
  123. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts +0 -2
  124. package/dist/components/hx-progress-bar/hx-progress-bar.d.ts.map +1 -1
  125. package/dist/components/hx-progress-bar/index.js +1 -1
  126. package/dist/components/hx-radio-group/hx-radio-group.d.ts +6 -11
  127. package/dist/components/hx-radio-group/hx-radio-group.d.ts.map +1 -1
  128. package/dist/components/hx-radio-group/hx-radio-group.styles.d.ts.map +1 -1
  129. package/dist/components/hx-radio-group/hx-radio.d.ts.map +1 -1
  130. package/dist/components/hx-radio-group/hx-radio.styles.d.ts.map +1 -1
  131. package/dist/components/hx-radio-group/index.js +1 -1
  132. package/dist/components/hx-rating/hx-rating.d.ts +6 -11
  133. package/dist/components/hx-rating/hx-rating.d.ts.map +1 -1
  134. package/dist/components/hx-rating/hx-rating.styles.d.ts.map +1 -1
  135. package/dist/components/hx-rating/index.js +1 -1
  136. package/dist/components/hx-select/hx-select.d.ts +8 -0
  137. package/dist/components/hx-select/hx-select.d.ts.map +1 -1
  138. package/dist/components/hx-select/hx-select.styles.d.ts.map +1 -1
  139. package/dist/components/hx-select/index.js +1 -1
  140. package/dist/components/hx-side-nav/hx-nav-item.d.ts +0 -3
  141. package/dist/components/hx-side-nav/hx-nav-item.d.ts.map +1 -1
  142. package/dist/components/hx-side-nav/hx-nav-item.styles.d.ts.map +1 -1
  143. package/dist/components/hx-side-nav/hx-side-nav.styles.d.ts.map +1 -1
  144. package/dist/components/hx-side-nav/index.js +1 -1
  145. package/dist/components/hx-skeleton/hx-skeleton.styles.d.ts.map +1 -1
  146. package/dist/components/hx-skeleton/index.js +1 -1
  147. package/dist/components/hx-slider/hx-slider.d.ts +9 -9
  148. package/dist/components/hx-slider/hx-slider.d.ts.map +1 -1
  149. package/dist/components/hx-slider/index.js +1 -1
  150. package/dist/components/hx-spinner/hx-spinner.styles.d.ts.map +1 -1
  151. package/dist/components/hx-spinner/index.js +1 -1
  152. package/dist/components/hx-split-button/hx-split-button.d.ts.map +1 -1
  153. package/dist/components/hx-split-button/hx-split-button.styles.d.ts.map +1 -1
  154. package/dist/components/hx-split-button/index.js +1 -1
  155. package/dist/components/hx-split-panel/hx-split-panel.styles.d.ts.map +1 -1
  156. package/dist/components/hx-split-panel/index.js +1 -1
  157. package/dist/components/hx-stat/hx-stat.d.ts +2 -2
  158. package/dist/components/hx-stat/hx-stat.d.ts.map +1 -1
  159. package/dist/components/hx-status-indicator/hx-status-indicator.styles.d.ts.map +1 -1
  160. package/dist/components/hx-status-indicator/index.js +1 -1
  161. package/dist/components/hx-steps/hx-step.styles.d.ts.map +1 -1
  162. package/dist/components/hx-steps/index.js +1 -1
  163. package/dist/components/hx-structured-list/hx-structured-list.styles.d.ts.map +1 -1
  164. package/dist/components/hx-structured-list/index.js +1 -1
  165. package/dist/components/hx-switch/hx-switch.d.ts +14 -17
  166. package/dist/components/hx-switch/hx-switch.d.ts.map +1 -1
  167. package/dist/components/hx-switch/hx-switch.styles.d.ts.map +1 -1
  168. package/dist/components/hx-switch/index.js +1 -1
  169. package/dist/components/hx-table/hx-table.styles.d.ts.map +1 -1
  170. package/dist/components/hx-table/index.js +1 -1
  171. package/dist/components/hx-tabs/hx-tab-panel.styles.d.ts.map +1 -1
  172. package/dist/components/hx-tabs/hx-tab.styles.d.ts.map +1 -1
  173. package/dist/components/hx-tabs/hx-tabs.d.ts +6 -0
  174. package/dist/components/hx-tabs/hx-tabs.d.ts.map +1 -1
  175. package/dist/components/hx-tabs/hx-tabs.styles.d.ts.map +1 -1
  176. package/dist/components/hx-tabs/index.js +1 -1
  177. package/dist/components/hx-tag/hx-tag.styles.d.ts.map +1 -1
  178. package/dist/components/hx-tag/index.js +1 -1
  179. package/dist/components/hx-text-input/hx-text-input.d.ts +11 -0
  180. package/dist/components/hx-text-input/hx-text-input.d.ts.map +1 -1
  181. package/dist/components/hx-text-input/hx-text-input.styles.d.ts.map +1 -1
  182. package/dist/components/hx-text-input/index.js +1 -1
  183. package/dist/components/hx-textarea/hx-textarea.d.ts +17 -9
  184. package/dist/components/hx-textarea/hx-textarea.d.ts.map +1 -1
  185. package/dist/components/hx-textarea/hx-textarea.styles.d.ts.map +1 -1
  186. package/dist/components/hx-textarea/index.js +1 -1
  187. package/dist/components/hx-time-picker/hx-time-picker.d.ts +6 -17
  188. package/dist/components/hx-time-picker/hx-time-picker.d.ts.map +1 -1
  189. package/dist/components/hx-time-picker/index.js +1 -1
  190. package/dist/components/hx-toast/hx-toast.styles.d.ts.map +1 -1
  191. package/dist/components/hx-toast/index.js +1 -1
  192. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts +6 -13
  193. package/dist/components/hx-toggle-button/hx-toggle-button.d.ts.map +1 -1
  194. package/dist/components/hx-toggle-button/hx-toggle-button.styles.d.ts.map +1 -1
  195. package/dist/components/hx-toggle-button/index.js +1 -1
  196. package/dist/components/hx-tooltip/hx-tooltip.d.ts.map +1 -1
  197. package/dist/components/hx-tooltip/hx-tooltip.styles.d.ts.map +1 -1
  198. package/dist/components/hx-tooltip/index.js +1 -1
  199. package/dist/components/hx-top-nav/hx-top-nav.styles.d.ts.map +1 -1
  200. package/dist/components/hx-top-nav/index.js +1 -1
  201. package/dist/components/hx-tree-view/hx-tree-item.styles.d.ts.map +1 -1
  202. package/dist/components/hx-tree-view/index.js +1 -1
  203. package/dist/css/helix-all.css +1269 -11
  204. package/dist/css/helix-core.css +137 -1
  205. package/dist/css/helix-data.css +69 -0
  206. package/dist/css/helix-feedback.css +77 -0
  207. package/dist/css/helix-forms.css +627 -3
  208. package/dist/css/helix-layout.css +22 -0
  209. package/dist/css/helix-media.css +24 -0
  210. package/dist/css/helix-navigation.css +110 -0
  211. package/dist/css/helix-overlay.css +87 -0
  212. package/dist/css/helix-utility.css +66 -0
  213. package/dist/css/hx-accordion.css +8 -0
  214. package/dist/css/hx-alert.css +21 -0
  215. package/dist/css/hx-badge.css +16 -0
  216. package/dist/css/hx-banner.css +17 -0
  217. package/dist/css/hx-button.css +4 -1
  218. package/dist/css/hx-card.css +12 -0
  219. package/dist/css/hx-carousel.css +24 -0
  220. package/dist/css/hx-checkbox-group.css +32 -0
  221. package/dist/css/hx-checkbox.css +66 -0
  222. package/dist/css/hx-clinical-status.css +23 -0
  223. package/dist/css/hx-code-snippet.css +22 -0
  224. package/dist/css/hx-color-picker.css +1 -1
  225. package/dist/css/hx-combobox.css +1 -1
  226. package/dist/css/hx-copy-button.css +28 -0
  227. package/dist/css/hx-counter.css +3 -0
  228. package/dist/css/hx-data-table.css +23 -0
  229. package/dist/css/hx-dialog.css +21 -0
  230. package/dist/css/hx-divider.css +8 -0
  231. package/dist/css/hx-drawer.css +21 -0
  232. package/dist/css/hx-dropdown.css +9 -0
  233. package/dist/css/hx-field-label.css +16 -0
  234. package/dist/css/hx-field.css +36 -0
  235. package/dist/css/hx-help-text.css +20 -0
  236. package/dist/css/hx-icon-button.css +27 -0
  237. package/dist/css/hx-icon.css +8 -0
  238. package/dist/css/hx-image.css +8 -0
  239. package/dist/css/hx-link.css +18 -0
  240. package/dist/css/hx-menu.css +9 -0
  241. package/dist/css/hx-meter.css +13 -0
  242. package/dist/css/hx-nav.css +16 -0
  243. package/dist/css/hx-number-input.css +78 -0
  244. package/dist/css/hx-overflow-menu.css +31 -0
  245. package/dist/css/hx-patient-banner.css +20 -0
  246. package/dist/css/hx-phi-field.css +1 -1
  247. package/dist/css/hx-popover.css +12 -0
  248. package/dist/css/hx-popup.css +12 -0
  249. package/dist/css/hx-radio-group.css +32 -0
  250. package/dist/css/hx-rating.css +39 -0
  251. package/dist/css/hx-select.css +82 -0
  252. package/dist/css/hx-side-nav.css +21 -0
  253. package/dist/css/hx-skeleton.css +12 -0
  254. package/dist/css/hx-spinner.css +12 -0
  255. package/dist/css/hx-split-button.css +35 -0
  256. package/dist/css/hx-split-panel.css +14 -0
  257. package/dist/css/hx-status-indicator.css +13 -0
  258. package/dist/css/hx-structured-list.css +16 -0
  259. package/dist/css/hx-switch.css +62 -0
  260. package/dist/css/hx-table.css +8 -0
  261. package/dist/css/hx-tabs.css +12 -0
  262. package/dist/css/hx-tag.css +12 -0
  263. package/dist/css/hx-text-input.css +62 -0
  264. package/dist/css/hx-textarea.css +62 -0
  265. package/dist/css/hx-toast.css +13 -0
  266. package/dist/css/hx-toggle-button.css +38 -1
  267. package/dist/css/hx-tooltip.css +12 -0
  268. package/dist/css/hx-top-nav.css +21 -0
  269. package/dist/css/index.css +1 -1
  270. package/dist/css/manifest.json +5 -3
  271. package/dist/index.js +67 -67
  272. package/dist/mixins/aria-delegation.d.ts +3 -1
  273. package/dist/mixins/aria-delegation.d.ts.map +1 -1
  274. package/dist/mixins/index.d.ts +1 -1
  275. package/dist/mixins/index.d.ts.map +1 -1
  276. package/dist/shared/{aria-delegation-CBP9eQ0M.js → aria-delegation-Doq6RRUy.js} +6 -6
  277. package/dist/shared/aria-delegation-Doq6RRUy.js.map +1 -0
  278. package/dist/shared/{helix-element-CZvaIEQP.js → helix-element-BJh1Ffvi.js} +18 -21
  279. package/dist/shared/{helix-element-CZvaIEQP.js.map → helix-element-BJh1Ffvi.js.map} +1 -1
  280. package/dist/shared/{hx-accordion-CpfO0YQo.js → hx-accordion-SlwR2C6S.js} +109 -62
  281. package/dist/shared/hx-accordion-SlwR2C6S.js.map +1 -0
  282. package/dist/shared/{hx-alert-CHOjTBds.js → hx-alert-DdlSyJGk.js} +22 -1
  283. package/dist/shared/hx-alert-DdlSyJGk.js.map +1 -0
  284. package/dist/shared/{hx-badge-RPzd-t5l.js → hx-badge-B_PzGlUo.js} +17 -1
  285. package/dist/shared/hx-badge-B_PzGlUo.js.map +1 -0
  286. package/dist/shared/{hx-banner-B-WEDiq7.js → hx-banner-D8AxkCfc.js} +30 -13
  287. package/dist/shared/hx-banner-D8AxkCfc.js.map +1 -0
  288. package/dist/shared/{hx-breadcrumb-item-jLAKK038.js → hx-breadcrumb-item-BCUIvpYX.js} +32 -15
  289. package/dist/shared/hx-breadcrumb-item-BCUIvpYX.js.map +1 -0
  290. package/dist/shared/{hx-button-DoN8jjQT.js → hx-button-BzqsDHmZ.js} +15 -16
  291. package/dist/shared/hx-button-BzqsDHmZ.js.map +1 -0
  292. package/dist/shared/{hx-button-group-BXlMQTt_.js → hx-button-group-a5Pb_9fU.js} +8 -9
  293. package/dist/shared/{hx-button-group-BXlMQTt_.js.map → hx-button-group-a5Pb_9fU.js.map} +1 -1
  294. package/dist/shared/{hx-card-BgXZXDuc.js → hx-card-DYlaxQy0.js} +59 -33
  295. package/dist/shared/hx-card-DYlaxQy0.js.map +1 -0
  296. package/dist/shared/{hx-carousel-item-Dwt9Pphz.js → hx-carousel-item-KQfCekKF.js} +45 -19
  297. package/dist/shared/hx-carousel-item-KQfCekKF.js.map +1 -0
  298. package/dist/shared/{hx-checkbox-C82GjRXe.js → hx-checkbox-DyDbR1B9.js} +97 -31
  299. package/dist/shared/hx-checkbox-DyDbR1B9.js.map +1 -0
  300. package/dist/shared/{hx-checkbox-group-DThZeN5d.js → hx-checkbox-group-C8TaFqy0.js} +75 -40
  301. package/dist/shared/hx-checkbox-group-C8TaFqy0.js.map +1 -0
  302. package/dist/shared/{hx-clinical-status-BjtT5c0M.js → hx-clinical-status-dDyk5oj1.js} +53 -30
  303. package/dist/shared/hx-clinical-status-dDyk5oj1.js.map +1 -0
  304. package/dist/shared/{hx-code-snippet-DcVENSuC.js → hx-code-snippet-DasrRF9k.js} +27 -5
  305. package/dist/shared/hx-code-snippet-DasrRF9k.js.map +1 -0
  306. package/dist/shared/{hx-color-picker-C6EIuS9t.js → hx-color-picker-zv6wtok4.js} +81 -81
  307. package/dist/shared/hx-color-picker-zv6wtok4.js.map +1 -0
  308. package/dist/shared/{hx-combobox-BJ4lQocO.js → hx-combobox-C-DVLFpu.js} +36 -45
  309. package/dist/shared/hx-combobox-C-DVLFpu.js.map +1 -0
  310. package/dist/shared/{hx-copy-button-BoM0WsMd.js → hx-copy-button-DikpbhWY.js} +54 -26
  311. package/dist/shared/hx-copy-button-DikpbhWY.js.map +1 -0
  312. package/dist/shared/{hx-counter-B5NgKlw4.js → hx-counter-_m4cq45V.js} +21 -18
  313. package/dist/shared/hx-counter-_m4cq45V.js.map +1 -0
  314. package/dist/shared/{hx-data-table-D5Ne-goy.js → hx-data-table-609C-e9w.js} +215 -150
  315. package/dist/shared/hx-data-table-609C-e9w.js.map +1 -0
  316. package/dist/shared/{hx-date-picker-Cd3I3WkX.js → hx-date-picker-Bh8410Sf.js} +26 -35
  317. package/dist/shared/hx-date-picker-Bh8410Sf.js.map +1 -0
  318. package/dist/shared/{hx-dialog-D4ubstxx.js → hx-dialog-D_DeqcNS.js} +46 -25
  319. package/dist/shared/hx-dialog-D_DeqcNS.js.map +1 -0
  320. package/dist/shared/{hx-divider-BBtOLHRP.js → hx-divider-lfOMElo2.js} +18 -10
  321. package/dist/shared/hx-divider-lfOMElo2.js.map +1 -0
  322. package/dist/shared/{hx-drawer--WDLuWtS.js → hx-drawer-NleCbKuN.js} +95 -60
  323. package/dist/shared/hx-drawer-NleCbKuN.js.map +1 -0
  324. package/dist/shared/{hx-dropdown-n5-XSmiV.js → hx-dropdown-CA9WYdhm.js} +37 -27
  325. package/dist/shared/hx-dropdown-CA9WYdhm.js.map +1 -0
  326. package/dist/shared/{hx-field-CwT9tki1.js → hx-field-Duiib9Bj.js} +48 -12
  327. package/dist/shared/hx-field-Duiib9Bj.js.map +1 -0
  328. package/dist/shared/{hx-field-label-CcOK9VU3.js → hx-field-label-Dud-psvE.js} +37 -21
  329. package/dist/shared/hx-field-label-Dud-psvE.js.map +1 -0
  330. package/dist/shared/{hx-file-upload-Di_vpQaG.js → hx-file-upload-CmCCAvej.js} +24 -33
  331. package/dist/shared/hx-file-upload-CmCCAvej.js.map +1 -0
  332. package/dist/shared/{hx-help-text-Bmb80bP4.js → hx-help-text-DARi-Pfp.js} +37 -17
  333. package/dist/shared/hx-help-text-DARi-Pfp.js.map +1 -0
  334. package/dist/shared/{hx-icon-button-CJuy9xbw.js → hx-icon-button-BcZtVVtH.js} +58 -41
  335. package/dist/shared/hx-icon-button-BcZtVVtH.js.map +1 -0
  336. package/dist/shared/{hx-icon-BKHs3OLu.js → hx-icon-jWcGmn66.js} +9 -1
  337. package/dist/shared/hx-icon-jWcGmn66.js.map +1 -0
  338. package/dist/shared/{hx-image-ztiXumZB.js → hx-image-DOjPp-K5.js} +28 -20
  339. package/dist/shared/hx-image-DOjPp-K5.js.map +1 -0
  340. package/dist/shared/{hx-link-CN7AvGOW.js → hx-link-DCBct0f4.js} +44 -26
  341. package/dist/shared/hx-link-DCBct0f4.js.map +1 -0
  342. package/dist/shared/{hx-list-CnDK30Yk.js → hx-list-Dnei26t4.js} +16 -16
  343. package/dist/shared/{hx-list-CnDK30Yk.js.map → hx-list-Dnei26t4.js.map} +1 -1
  344. package/dist/shared/{hx-menu-divider-DRT8yHRZ.js → hx-menu-divider-DVWER7iT.js} +93 -50
  345. package/dist/shared/hx-menu-divider-DVWER7iT.js.map +1 -0
  346. package/dist/shared/{hx-meter-BcVC9yrt.js → hx-meter-ChZdWNF2.js} +42 -28
  347. package/dist/shared/hx-meter-ChZdWNF2.js.map +1 -0
  348. package/dist/shared/{hx-nav-l0Rp7WPW.js → hx-nav-CHX1JOWB.js} +28 -12
  349. package/dist/shared/hx-nav-CHX1JOWB.js.map +1 -0
  350. package/dist/shared/{hx-nav-item-CJN4VDrf.js → hx-nav-item-CRAESq9s.js} +56 -22
  351. package/dist/shared/hx-nav-item-CRAESq9s.js.map +1 -0
  352. package/dist/shared/{hx-number-input-0Waw7Z7u.js → hx-number-input-Cm682AVP.js} +154 -72
  353. package/dist/shared/hx-number-input-Cm682AVP.js.map +1 -0
  354. package/dist/shared/{hx-overflow-menu-DElwFSCd.js → hx-overflow-menu-BDl6QfUD.js} +52 -19
  355. package/dist/shared/hx-overflow-menu-BDl6QfUD.js.map +1 -0
  356. package/dist/shared/{hx-patient-banner-BKiN7nIE.js → hx-patient-banner-B4IjHeTx.js} +54 -34
  357. package/dist/shared/hx-patient-banner-B4IjHeTx.js.map +1 -0
  358. package/dist/shared/{hx-phi-field-Df06K0J3.js → hx-phi-field-DD1qcBSO.js} +2 -2
  359. package/dist/shared/hx-phi-field-DD1qcBSO.js.map +1 -0
  360. package/dist/shared/{hx-popover-CydNuVkT.js → hx-popover-ZGRFgBbx.js} +29 -15
  361. package/dist/shared/hx-popover-ZGRFgBbx.js.map +1 -0
  362. package/dist/shared/{hx-popup-DbzezTOd.js → hx-popup-Cc4qz89i.js} +24 -12
  363. package/dist/shared/hx-popup-Cc4qz89i.js.map +1 -0
  364. package/dist/shared/{hx-progress-bar-Cm0VihTN.js → hx-progress-bar-BY1uE6bN.js} +17 -16
  365. package/dist/shared/hx-progress-bar-BY1uE6bN.js.map +1 -0
  366. package/dist/shared/{hx-radio-f8c5ggHG.js → hx-radio-YEEsbUPN.js} +139 -54
  367. package/dist/shared/hx-radio-YEEsbUPN.js.map +1 -0
  368. package/dist/shared/{hx-rating-qRJZXskm.js → hx-rating-DjUJTT0M.js} +54 -17
  369. package/dist/shared/hx-rating-DjUJTT0M.js.map +1 -0
  370. package/dist/shared/{hx-select-CgcgsHU5.js → hx-select-DZ7wfcJx.js} +119 -37
  371. package/dist/shared/hx-select-DZ7wfcJx.js.map +1 -0
  372. package/dist/shared/{hx-skeleton-tiYvKO-t.js → hx-skeleton-aqa-gr1S.js} +28 -16
  373. package/dist/shared/hx-skeleton-aqa-gr1S.js.map +1 -0
  374. package/dist/shared/{hx-slider-BvXtvxmN.js → hx-slider-DAilFrR_.js} +28 -25
  375. package/dist/shared/hx-slider-DAilFrR_.js.map +1 -0
  376. package/dist/shared/{hx-spinner-D6nzuGmj.js → hx-spinner-Dw3cRY-9.js} +26 -14
  377. package/dist/shared/hx-spinner-Dw3cRY-9.js.map +1 -0
  378. package/dist/shared/{hx-split-button-CPndTJlC.js → hx-split-button-Dk-zMDDo.js} +51 -14
  379. package/dist/shared/hx-split-button-Dk-zMDDo.js.map +1 -0
  380. package/dist/shared/{hx-split-panel-Dx72NaET.js → hx-split-panel-Kdp4BiLz.js} +15 -1
  381. package/dist/shared/hx-split-panel-Kdp4BiLz.js.map +1 -0
  382. package/dist/shared/hx-stat-DKlyBL_K.js.map +1 -1
  383. package/dist/shared/{hx-status-indicator-ClWpK6zz.js → hx-status-indicator-DWSM0Ctm.js} +30 -17
  384. package/dist/shared/hx-status-indicator-DWSM0Ctm.js.map +1 -0
  385. package/dist/shared/{hx-step-C2Jk4mHa.js → hx-step-CuoOvcI8.js} +52 -18
  386. package/dist/shared/{hx-step-C2Jk4mHa.js.map → hx-step-CuoOvcI8.js.map} +1 -1
  387. package/dist/shared/{hx-structured-list-DKlrv7kS.js → hx-structured-list-CQCD7bCT.js} +21 -5
  388. package/dist/shared/hx-structured-list-CQCD7bCT.js.map +1 -0
  389. package/dist/shared/{hx-switch-BzMN37PV.js → hx-switch-BdxKN9WM.js} +89 -32
  390. package/dist/shared/hx-switch-BdxKN9WM.js.map +1 -0
  391. package/dist/shared/{hx-tab-panel-J58zOSjq.js → hx-tab-panel-CwClQoWP.js} +141 -88
  392. package/dist/shared/hx-tab-panel-CwClQoWP.js.map +1 -0
  393. package/dist/shared/{hx-tag-F0ZcYj9b.js → hx-tag-BL5qJJCN.js} +20 -8
  394. package/dist/shared/hx-tag-BL5qJJCN.js.map +1 -0
  395. package/dist/shared/{hx-td-CNCvzBwY.js → hx-td-CzSvVKdp.js} +21 -13
  396. package/dist/shared/hx-td-CzSvVKdp.js.map +1 -0
  397. package/dist/shared/{hx-text-input-Zuodg9s_.js → hx-text-input-BfMrvN9N.js} +110 -48
  398. package/dist/shared/hx-text-input-BfMrvN9N.js.map +1 -0
  399. package/dist/shared/{hx-textarea-BfSJJtA1.js → hx-textarea-C-i_Vam6.js} +108 -47
  400. package/dist/shared/hx-textarea-C-i_Vam6.js.map +1 -0
  401. package/dist/shared/{hx-time-picker-CZvmihHD.js → hx-time-picker-MZyLQPW9.js} +50 -61
  402. package/dist/shared/hx-time-picker-MZyLQPW9.js.map +1 -0
  403. package/dist/shared/{hx-toggle-button-BZUQUULm.js → hx-toggle-button-ClyNYNVI.js} +68 -37
  404. package/dist/shared/hx-toggle-button-ClyNYNVI.js.map +1 -0
  405. package/dist/shared/{hx-tooltip-Ny4i1Idj.js → hx-tooltip-ByWT987R.js} +33 -19
  406. package/dist/shared/hx-tooltip-ByWT987R.js.map +1 -0
  407. package/dist/shared/{hx-top-nav-CC4FW2Hp.js → hx-top-nav-k7hY78kt.js} +35 -14
  408. package/dist/shared/hx-top-nav-k7hY78kt.js.map +1 -0
  409. package/dist/shared/{hx-tree-item-CPQ9dJiK.js → hx-tree-item-D0ZphA45.js} +9 -1
  410. package/dist/shared/hx-tree-item-D0ZphA45.js.map +1 -0
  411. package/dist/shared/{toast-factory-CEMNOt1T.js → toast-factory-Cwd0PihS.js} +49 -36
  412. package/dist/shared/toast-factory-Cwd0PihS.js.map +1 -0
  413. package/package.json +2 -2
  414. package/dist/shared/aria-delegation-CBP9eQ0M.js.map +0 -1
  415. package/dist/shared/hx-accordion-CpfO0YQo.js.map +0 -1
  416. package/dist/shared/hx-alert-CHOjTBds.js.map +0 -1
  417. package/dist/shared/hx-badge-RPzd-t5l.js.map +0 -1
  418. package/dist/shared/hx-banner-B-WEDiq7.js.map +0 -1
  419. package/dist/shared/hx-breadcrumb-item-jLAKK038.js.map +0 -1
  420. package/dist/shared/hx-button-DoN8jjQT.js.map +0 -1
  421. package/dist/shared/hx-card-BgXZXDuc.js.map +0 -1
  422. package/dist/shared/hx-carousel-item-Dwt9Pphz.js.map +0 -1
  423. package/dist/shared/hx-checkbox-C82GjRXe.js.map +0 -1
  424. package/dist/shared/hx-checkbox-group-DThZeN5d.js.map +0 -1
  425. package/dist/shared/hx-clinical-status-BjtT5c0M.js.map +0 -1
  426. package/dist/shared/hx-code-snippet-DcVENSuC.js.map +0 -1
  427. package/dist/shared/hx-color-picker-C6EIuS9t.js.map +0 -1
  428. package/dist/shared/hx-combobox-BJ4lQocO.js.map +0 -1
  429. package/dist/shared/hx-copy-button-BoM0WsMd.js.map +0 -1
  430. package/dist/shared/hx-counter-B5NgKlw4.js.map +0 -1
  431. package/dist/shared/hx-data-table-D5Ne-goy.js.map +0 -1
  432. package/dist/shared/hx-date-picker-Cd3I3WkX.js.map +0 -1
  433. package/dist/shared/hx-dialog-D4ubstxx.js.map +0 -1
  434. package/dist/shared/hx-divider-BBtOLHRP.js.map +0 -1
  435. package/dist/shared/hx-drawer--WDLuWtS.js.map +0 -1
  436. package/dist/shared/hx-dropdown-n5-XSmiV.js.map +0 -1
  437. package/dist/shared/hx-field-CwT9tki1.js.map +0 -1
  438. package/dist/shared/hx-field-label-CcOK9VU3.js.map +0 -1
  439. package/dist/shared/hx-file-upload-Di_vpQaG.js.map +0 -1
  440. package/dist/shared/hx-help-text-Bmb80bP4.js.map +0 -1
  441. package/dist/shared/hx-icon-BKHs3OLu.js.map +0 -1
  442. package/dist/shared/hx-icon-button-CJuy9xbw.js.map +0 -1
  443. package/dist/shared/hx-image-ztiXumZB.js.map +0 -1
  444. package/dist/shared/hx-link-CN7AvGOW.js.map +0 -1
  445. package/dist/shared/hx-menu-divider-DRT8yHRZ.js.map +0 -1
  446. package/dist/shared/hx-meter-BcVC9yrt.js.map +0 -1
  447. package/dist/shared/hx-nav-item-CJN4VDrf.js.map +0 -1
  448. package/dist/shared/hx-nav-l0Rp7WPW.js.map +0 -1
  449. package/dist/shared/hx-number-input-0Waw7Z7u.js.map +0 -1
  450. package/dist/shared/hx-overflow-menu-DElwFSCd.js.map +0 -1
  451. package/dist/shared/hx-patient-banner-BKiN7nIE.js.map +0 -1
  452. package/dist/shared/hx-phi-field-Df06K0J3.js.map +0 -1
  453. package/dist/shared/hx-popover-CydNuVkT.js.map +0 -1
  454. package/dist/shared/hx-popup-DbzezTOd.js.map +0 -1
  455. package/dist/shared/hx-progress-bar-Cm0VihTN.js.map +0 -1
  456. package/dist/shared/hx-radio-f8c5ggHG.js.map +0 -1
  457. package/dist/shared/hx-rating-qRJZXskm.js.map +0 -1
  458. package/dist/shared/hx-select-CgcgsHU5.js.map +0 -1
  459. package/dist/shared/hx-skeleton-tiYvKO-t.js.map +0 -1
  460. package/dist/shared/hx-slider-BvXtvxmN.js.map +0 -1
  461. package/dist/shared/hx-spinner-D6nzuGmj.js.map +0 -1
  462. package/dist/shared/hx-split-button-CPndTJlC.js.map +0 -1
  463. package/dist/shared/hx-split-panel-Dx72NaET.js.map +0 -1
  464. package/dist/shared/hx-status-indicator-ClWpK6zz.js.map +0 -1
  465. package/dist/shared/hx-structured-list-DKlrv7kS.js.map +0 -1
  466. package/dist/shared/hx-switch-BzMN37PV.js.map +0 -1
  467. package/dist/shared/hx-tab-panel-J58zOSjq.js.map +0 -1
  468. package/dist/shared/hx-tag-F0ZcYj9b.js.map +0 -1
  469. package/dist/shared/hx-td-CNCvzBwY.js.map +0 -1
  470. package/dist/shared/hx-text-input-Zuodg9s_.js.map +0 -1
  471. package/dist/shared/hx-textarea-BfSJJtA1.js.map +0 -1
  472. package/dist/shared/hx-time-picker-CZvmihHD.js.map +0 -1
  473. package/dist/shared/hx-toggle-button-BZUQUULm.js.map +0 -1
  474. package/dist/shared/hx-tooltip-Ny4i1Idj.js.map +0 -1
  475. package/dist/shared/hx-top-nav-CC4FW2Hp.js.map +0 -1
  476. package/dist/shared/hx-tree-item-CPQ9dJiK.js.map +0 -1
  477. package/dist/shared/toast-factory-CEMNOt1T.js.map +0 -1
@@ -1,9 +1,10 @@
1
- import { css as h, LitElement as c, nothing as u, html as m } from "lit";
1
+ import { css as c, LitElement as h, nothing as u, html as m } from "lit";
2
2
  import "./document-token-adoption-DuYNKd4k.js";
3
3
  import { property as l, state as f, query as p, customElement as g } from "lit/decorators.js";
4
4
  import { d as b } from "./dev-warn-YlwPHjtX.js";
5
5
  import { computePosition as _, offset as v, flip as y, shift as w } from "@floating-ui/dom";
6
- const x = h`
6
+ import { c as x } from "./id-counter-PTgF-zcG.js";
7
+ const k = c`
7
8
  :host {
8
9
  display: inline-block;
9
10
  position: relative;
@@ -49,15 +50,25 @@ const x = h`
49
50
  transition: none;
50
51
  }
51
52
  }
53
+
54
+ /* ─── High Contrast Mode (forced-colors) ─── */
55
+
56
+ @media (forced-colors: active) {
57
+ [part='panel'] {
58
+ background-color: Canvas;
59
+ border: 2px solid CanvasText;
60
+ }
61
+ }
52
62
  `;
53
- var k = Object.defineProperty, C = Object.getOwnPropertyDescriptor, a = (e, t, n, i) => {
54
- for (var s = i > 1 ? void 0 : i ? C(t, n) : t, r = e.length - 1, d; r >= 0; r--)
55
- (d = e[r]) && (s = (i ? d(t, n, s) : d(s)) || s);
56
- return i && s && k(t, n, s), s;
63
+ var C = Object.defineProperty, E = Object.getOwnPropertyDescriptor, a = (e, t, n, i) => {
64
+ for (var s = i > 1 ? void 0 : i ? E(t, n) : t, o = e.length - 1, d; o >= 0; o--)
65
+ (d = e[o]) && (s = (i ? d(t, n, s) : d(s)) || s);
66
+ return i && s && C(t, n, s), s;
57
67
  };
58
- let o = class extends c {
68
+ const A = x("hx-dropdown");
69
+ let r = class extends h {
59
70
  constructor() {
60
- super(...arguments), this.open = !1, this.placement = "bottom-start", this.label = "Menu", this.disabled = !1, this.distance = 4, this._panelVisible = !1, this._documentListenerAttached = !1, this._panelId = `hx-dropdown-panel-${++o._instanceCounter}`, this._handleKeydown = (e) => {
71
+ super(...arguments), this.open = !1, this.placement = "bottom-start", this.label = "Menu", this.disabled = !1, this.distance = 4, this._panelVisible = !1, this._documentListenerAttached = !1, this._panelId = `${A()}-panel`, this._handleKeydown = (e) => {
61
72
  e.key === "Escape" && this.open ? (e.stopPropagation(), this._hide(!0)) : e.key === "Tab" && this.open ? this._hide(!1) : this.open && (e.key === "ArrowDown" || e.key === "ArrowUp" || e.key === "Home" || e.key === "End") && (e.preventDefault(), this._handleMenuNavigation(e.key));
62
73
  }, this._handleOutsideClick = (e) => {
63
74
  e.composedPath().includes(this) || this._hide();
@@ -130,7 +141,7 @@ let o = class extends c {
130
141
  if (!e) return [];
131
142
  const t = e.querySelector("slot"), n = (t == null ? void 0 : t.assignedElements({ flatten: !0 })) ?? [], i = [];
132
143
  for (const s of n)
133
- s instanceof HTMLElement && (s.matches('[role="menuitem"]') ? i.push(s) : s.querySelectorAll('[role="menuitem"]').forEach((r) => i.push(r)));
144
+ s instanceof HTMLElement && (s.matches('[role="menuitem"]') ? i.push(s) : s.querySelectorAll('[role="menuitem"]').forEach((o) => i.push(o)));
134
145
  return i;
135
146
  }
136
147
  // P0-01: Find the first focusable element in slotted panel content.
@@ -142,17 +153,17 @@ let o = class extends c {
142
153
  for (const s of n) {
143
154
  if (!(s instanceof HTMLElement)) continue;
144
155
  if (s.matches(i)) return s;
145
- const r = s.querySelector(i);
146
- if (r) return r;
156
+ const o = s.querySelector(i);
157
+ if (o) return o;
147
158
  }
148
159
  return null;
149
160
  }
150
161
  /** @internal */
151
162
  _handlePanelClick(e) {
152
- var r;
163
+ var o;
153
164
  const n = e.target.closest('[role="menuitem"], [data-value]');
154
165
  if (!n) return;
155
- const i = n.dataset.value ?? n.getAttribute("value") ?? null, s = ((r = n.textContent) == null ? void 0 : r.trim()) ?? "";
166
+ const i = n.dataset.value ?? n.getAttribute("value") ?? null, s = ((o = n.textContent) == null ? void 0 : o.trim()) ?? "";
156
167
  this.dispatchEvent(
157
168
  new CustomEvent("hx-select", {
158
169
  bubbles: !0,
@@ -218,36 +229,35 @@ let o = class extends c {
218
229
  }
219
230
  }
220
231
  };
221
- o.styles = [x];
222
- o._instanceCounter = 0;
232
+ r.styles = [k];
223
233
  a([
224
234
  l({ type: Boolean, reflect: !0 })
225
- ], o.prototype, "open", 2);
235
+ ], r.prototype, "open", 2);
226
236
  a([
227
237
  l({ type: String, reflect: !0 })
228
- ], o.prototype, "placement", 2);
238
+ ], r.prototype, "placement", 2);
229
239
  a([
230
240
  l()
231
- ], o.prototype, "label", 2);
241
+ ], r.prototype, "label", 2);
232
242
  a([
233
243
  l({ type: Boolean, reflect: !0 })
234
- ], o.prototype, "disabled", 2);
244
+ ], r.prototype, "disabled", 2);
235
245
  a([
236
246
  l({ type: Number })
237
- ], o.prototype, "distance", 2);
247
+ ], r.prototype, "distance", 2);
238
248
  a([
239
249
  f()
240
- ], o.prototype, "_panelVisible", 2);
250
+ ], r.prototype, "_panelVisible", 2);
241
251
  a([
242
252
  p('[part="panel"]')
243
- ], o.prototype, "_panel", 2);
253
+ ], r.prototype, "_panel", 2);
244
254
  a([
245
255
  p('[part="trigger"]')
246
- ], o.prototype, "_triggerWrapper", 2);
247
- o = a([
256
+ ], r.prototype, "_triggerWrapper", 2);
257
+ r = a([
248
258
  g("hx-dropdown")
249
- ], o);
259
+ ], r);
250
260
  export {
251
- o as H
261
+ r as H
252
262
  };
253
- //# sourceMappingURL=hx-dropdown-n5-XSmiV.js.map
263
+ //# sourceMappingURL=hx-dropdown-CA9WYdhm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-dropdown-CA9WYdhm.js","sources":["../../src/components/hx-dropdown/hx-dropdown.styles.ts","../../src/components/hx-dropdown/hx-dropdown.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixDropdownStyles = css`\n :host {\n display: inline-block;\n position: relative;\n }\n\n :host([disabled]) {\n pointer-events: none;\n opacity: var(--hx-opacity-disabled, 0.5);\n }\n\n .trigger-wrapper {\n display: inline-block;\n }\n\n [part='panel'] {\n position: fixed;\n z-index: var(--hx-dropdown-panel-z-index, 1000);\n min-width: var(--hx-dropdown-panel-min-width, 160px);\n background: var(--hx-dropdown-panel-bg, var(--hx-color-neutral-0, #ffffff));\n border: 1px solid var(--hx-dropdown-panel-border-color, var(--hx-color-neutral-200, #e5e7eb));\n border-radius: var(--hx-dropdown-panel-border-radius, var(--hx-border-radius-md, 0.375rem));\n box-shadow: var(\n --hx-dropdown-panel-shadow,\n 0 4px 16px var(--hx-overlay-black-12, rgba(0, 0, 0, 0.12))\n );\n visibility: hidden;\n opacity: 0;\n pointer-events: none;\n transition:\n opacity var(--hx-transition-fast, 150ms ease),\n visibility var(--hx-transition-fast, 150ms ease);\n outline: none;\n }\n\n [part='panel'].panel--visible {\n visibility: visible;\n opacity: 1;\n pointer-events: auto;\n }\n\n @media (prefers-reduced-motion: reduce) {\n [part='panel'] {\n transition: none;\n }\n }\n\n /* ─── High Contrast Mode (forced-colors) ─── */\n\n @media (forced-colors: active) {\n [part='panel'] {\n background-color: Canvas;\n border: 2px solid CanvasText;\n }\n }\n`;\n","import { LitElement, html, nothing, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property, state, query } from 'lit/decorators.js';\nimport { devWarn } from '../../utils/dev-warn.js';\nimport {\n computePosition,\n flip,\n shift,\n offset,\n type Placement as FloatingPlacement,\n} from '@floating-ui/dom';\nimport { createIdCounter } from '../../base/index.js';\nimport { helixDropdownStyles } from './hx-dropdown.styles.js';\n\n// P2-03: Export so TypeScript consumers can import this type for prop typing.\nexport type DropdownPlacement =\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'start'\n | 'end';\n\nconst _nextDropdownId = createIdCounter('hx-dropdown');\n\n/**\n * A dropdown component — a button that opens a floating panel on click.\n *\n * @summary Button that opens a floating menu panel on click.\n *\n * @tag hx-dropdown\n *\n * @slot trigger - The element that opens the dropdown (e.g. hx-button).\n * @slot - Default slot for dropdown panel content (e.g. menu items).\n *\n * @fires {CustomEvent<void>} hx-show - Dispatched when the dropdown is opened.\n * @fires {CustomEvent<void>} hx-hide - Dispatched when the dropdown is closed.\n * @fires {CustomEvent<{value: string | null; label: string}>} hx-select - Dispatched when a menu item is selected.\n *\n * @csspart trigger - The trigger wrapper element.\n * @csspart panel - The floating panel element.\n *\n * @cssprop [--hx-dropdown-panel-bg=var(--hx-color-neutral-0)] - Panel background color.\n * @cssprop [--hx-dropdown-panel-border-color=var(--hx-color-neutral-200)] - Panel border color.\n * @cssprop [--hx-dropdown-panel-border-radius=var(--hx-border-radius-md)] - Panel border radius.\n * @cssprop [--hx-dropdown-panel-shadow=0 4px 16px rgba(0,0,0,0.12)] - Panel box shadow.\n * @cssprop [--hx-dropdown-panel-z-index=1000] - Panel z-index.\n * @cssprop [--hx-dropdown-panel-min-width=160px] - Panel minimum width.\n *\n * @example\n * ```html\n * <hx-dropdown>\n * <button slot=\"trigger\">Open Menu</button>\n * <ul>\n * <li data-value=\"edit\">Edit</li>\n * <li data-value=\"delete\">Delete</li>\n * </ul>\n * </hx-dropdown>\n * ```\n */\n@customElement('hx-dropdown')\nexport class HelixDropdown extends LitElement {\n static override styles = [helixDropdownStyles];\n\n // ─── Public Properties ───\n\n /**\n * Whether the dropdown panel is open.\n * @attr open\n */\n @property({ type: Boolean, reflect: true })\n open = false;\n\n /**\n * Preferred placement of the panel relative to the trigger.\n * @attr placement\n */\n @property({ type: String, reflect: true })\n placement:\n | 'top'\n | 'top-start'\n | 'top-end'\n | 'bottom'\n | 'bottom-start'\n | 'bottom-end'\n | 'start'\n | 'end' = 'bottom-start';\n\n /**\n * Accessible label for the dropdown menu panel. Override for i18n.\n * @attr label\n */\n @property() label = 'Menu';\n\n /**\n * Whether the dropdown is disabled. Prevents opening.\n * @attr disabled\n */\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n /**\n * Gap in pixels between the trigger and the panel.\n * @attr distance\n */\n @property({ type: Number })\n distance = 4;\n\n // ─── Internal State ───\n\n /**\n * Whether the dropdown panel is currently visible.\n * @internal\n */\n @state() private _panelVisible = false;\n\n /**\n * Guards against accumulating multiple document click listeners when open state\n * changes faster than the microtask queue can process removeEventListener calls.\n * @internal\n */\n private _documentListenerAttached = false;\n\n // P1-02: Unique panel ID for aria-controls.\n /**\n * Unique ID assigned to the floating panel element, referenced by `aria-controls` on the trigger.\n * @internal\n */\n private _panelId = `${_nextDropdownId()}-panel`;\n\n /**\n * Reference to the floating panel element inside the shadow DOM.\n * @internal\n */\n @query('[part=\"panel\"]') private _panel: HTMLElement | undefined;\n /**\n * Reference to the trigger wrapper element inside the shadow DOM.\n * @internal\n */\n @query('[part=\"trigger\"]') private _triggerWrapper: HTMLElement | undefined;\n\n // ─── Lifecycle ───\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('keydown', this._handleKeydown);\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.removeEventListener('keydown', this._handleKeydown);\n if (this._documentListenerAttached) {\n document.removeEventListener('click', this._handleOutsideClick, { capture: true });\n this._documentListenerAttached = false;\n }\n }\n\n // ─── Open/Close ───\n\n /** @internal */\n private async _show(): Promise<void> {\n if (this.open || this.disabled) return;\n this.open = true;\n this._panelVisible = true;\n // Add outside-click listener synchronously before any await so it is registered\n // by the time the test fires an outside click after a single await el.updateComplete.\n if (!this._documentListenerAttached) {\n document.addEventListener('click', this._handleOutsideClick, { capture: true });\n this._documentListenerAttached = true;\n }\n await this.updateComplete;\n // P0-01: Fix focus management — use slot.assignedElements() to traverse slotted (light DOM) content.\n // Focus is set after updateComplete (panel is rendered) but before _updatePosition so\n // it executes in the same microtask as the test's await-continuation.\n const panel = this._panel;\n if (panel) {\n const firstFocusable = this._getFirstFocusableItem();\n firstFocusable?.focus();\n }\n await this._updatePosition();\n this.dispatchEvent(new CustomEvent<void>('hx-show', { bubbles: true, composed: true }));\n }\n\n // P2-02: returnFocus=true only on Escape; Tab should let focus advance naturally.\n /** @internal */\n private _hide(returnFocus = true): void {\n if (!this.open) return;\n this.open = false;\n this._panelVisible = false;\n if (this._documentListenerAttached) {\n document.removeEventListener('click', this._handleOutsideClick, { capture: true });\n this._documentListenerAttached = false;\n }\n this.dispatchEvent(new CustomEvent<void>('hx-hide', { bubbles: true, composed: true }));\n if (returnFocus) {\n const slot = this.shadowRoot?.querySelector<HTMLSlotElement>('slot[name=\"trigger\"]');\n const trigger = slot?.assignedElements()[0] as HTMLElement | undefined;\n trigger?.focus();\n }\n }\n\n // ─── Positioning ───\n\n /** @internal */\n private async _updatePosition(): Promise<void> {\n const reference = this._triggerWrapper;\n const panel = this._panel;\n if (!reference || !panel) return;\n\n // Map 'start' and 'end' to floating-ui's 'left'/'right'\n const floatingPlacement = this.placement\n .replace(/^start$/, 'left')\n .replace(/^end$/, 'right') as FloatingPlacement;\n\n const { x, y } = await computePosition(reference, panel, {\n placement: floatingPlacement,\n strategy: 'fixed',\n middleware: [offset(this.distance), flip(), shift({ padding: 8 })],\n });\n\n Object.assign(panel.style, {\n left: `${x}px`,\n top: `${y}px`,\n });\n }\n\n // ─── Event Handlers ───\n\n /** @internal */\n private _handleTriggerClick(e: MouseEvent): void {\n e.stopPropagation();\n if (this.open) {\n this._hide();\n } else {\n void this._show();\n }\n }\n\n /** @internal */\n private _handleTriggerKeydown(e: KeyboardEvent): void {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault();\n void this._show();\n }\n }\n\n /** @internal */\n private _handleKeydown = (e: KeyboardEvent): void => {\n if (e.key === 'Escape' && this.open) {\n e.stopPropagation();\n this._hide(true); // return focus to trigger on Escape\n } else if (e.key === 'Tab' && this.open) {\n // P2-02: Do not return focus to trigger on Tab — let focus advance naturally to next page element.\n this._hide(false);\n } else if (\n this.open &&\n (e.key === 'ArrowDown' || e.key === 'ArrowUp' || e.key === 'Home' || e.key === 'End')\n ) {\n // P2-01: Arrow key roving within panel per APG Menu Button pattern.\n e.preventDefault();\n this._handleMenuNavigation(e.key);\n }\n };\n\n // P2-01: Move focus among menuitem elements using arrow keys.\n /** @internal */\n private _handleMenuNavigation(key: string): void {\n const items = this._getFocusableMenuItems();\n if (items.length === 0) return;\n const currentIndex = items.indexOf(document.activeElement as HTMLElement);\n let nextIndex: number;\n if (key === 'ArrowDown') {\n nextIndex = currentIndex < items.length - 1 ? currentIndex + 1 : 0;\n } else if (key === 'ArrowUp') {\n nextIndex = currentIndex > 0 ? currentIndex - 1 : items.length - 1;\n } else if (key === 'Home') {\n nextIndex = 0;\n } else {\n nextIndex = items.length - 1;\n }\n items[nextIndex]?.focus();\n }\n\n // P0-01 / P2-01: Get focusable menu items from slotted content.\n /** @internal */\n private _getFocusableMenuItems(): HTMLElement[] {\n const panel = this._panel;\n if (!panel) return [];\n const slot = panel.querySelector<HTMLSlotElement>('slot');\n const assignedNodes = slot?.assignedElements({ flatten: true }) ?? [];\n const items: HTMLElement[] = [];\n for (const node of assignedNodes) {\n if (!(node instanceof HTMLElement)) continue;\n if (node.matches('[role=\"menuitem\"]')) {\n items.push(node);\n } else {\n node.querySelectorAll<HTMLElement>('[role=\"menuitem\"]').forEach((item) => items.push(item));\n }\n }\n return items;\n }\n\n // P0-01: Find the first focusable element in slotted panel content.\n /** @internal */\n private _getFirstFocusableItem(): HTMLElement | null {\n const panel = this._panel;\n if (!panel) return null;\n const slot = panel.querySelector<HTMLSlotElement>('slot');\n const assignedNodes = slot?.assignedElements({ flatten: true }) ?? [];\n const focusableSelector =\n '[role=\"menuitem\"], button, [tabindex]:not([tabindex=\"-1\"]), a[href], input, select, textarea';\n for (const node of assignedNodes) {\n if (!(node instanceof HTMLElement)) continue;\n if (node.matches(focusableSelector)) return node;\n const found = node.querySelector<HTMLElement>(focusableSelector);\n if (found) return found;\n }\n return null;\n }\n\n /** @internal */\n private _handleOutsideClick = (e: MouseEvent): void => {\n const path = e.composedPath();\n if (!path.includes(this)) {\n this._hide();\n }\n };\n\n /** @internal */\n private _handlePanelClick(e: MouseEvent): void {\n const target = e.target as HTMLElement;\n // P2-06: Narrow selector — bare 'li' and 'button' cause spurious hx-select events.\n const item = target.closest<HTMLElement>('[role=\"menuitem\"], [data-value]');\n if (!item) return;\n\n const value = item.dataset['value'] ?? item.getAttribute('value') ?? null;\n const label = item.textContent?.trim() ?? '';\n\n this.dispatchEvent(\n new CustomEvent<{ value: string | null; label: string }>('hx-select', {\n bubbles: true,\n composed: true,\n detail: { value, label },\n }),\n );\n\n this._hide();\n }\n\n // ─── Render ───\n\n override render() {\n return html`\n <div\n part=\"trigger\"\n class=\"trigger-wrapper\"\n @click=${this._handleTriggerClick}\n @keydown=${this._handleTriggerKeydown}\n >\n <slot name=\"trigger\" @slotchange=${this._onTriggerSlotChange}></slot>\n </div>\n <div\n part=\"panel\"\n id=${this._panelId}\n role=\"menu\"\n aria-hidden=${this._panelVisible ? nothing : 'true'}\n aria-label=${this.label}\n class=${this._panelVisible ? 'panel panel--visible' : 'panel'}\n @click=${this._handlePanelClick}\n >\n <slot @slotchange=${this._onPanelSlotChange}></slot>\n </div>\n `;\n }\n\n // ─── Panel slot validation ───\n\n /** @internal */\n private _onPanelSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n const assigned = slot.assignedElements({ flatten: true });\n const nonItems = assigned.filter((el) => el.tagName.toLowerCase() !== 'hx-dropdown-item');\n if (nonItems.length > 0) {\n devWarn(\n 'hx-dropdown',\n `Default slot should contain only hx-dropdown-item elements. Found unexpected: ${nonItems.map((el) => `<${el.tagName.toLowerCase()}>`).join(', ')}. Non-hx-dropdown-item children will be included in keyboard navigation incorrectly.`,\n );\n }\n }\n\n // ─── ARIA setup for trigger slot ───\n\n /** @internal */\n private _onTriggerSlotChange(): void {\n this._setupTriggerAria();\n }\n\n override firstUpdated(): void {\n this._setupTriggerAria();\n }\n\n /** @internal */\n private _setupTriggerAria(): void {\n const slot = this.shadowRoot?.querySelector<HTMLSlotElement>('slot[name=\"trigger\"]');\n if (!slot) return;\n const trigger = slot.assignedElements()[0] as HTMLElement | undefined;\n if (trigger) {\n // P1-01: Use aria-haspopup=\"menu\" per ARIA 1.1+ / APG Menu Button pattern.\n trigger.setAttribute('aria-haspopup', 'menu');\n trigger.setAttribute('aria-expanded', String(this.open));\n // aria-controls is intentionally omitted: the panel lives in Shadow DOM and\n // IDREF values cannot be resolved across shadow boundaries by assistive technology.\n // P2-06: Remove host fallback when a trigger element is present.\n this.removeAttribute('aria-expanded');\n } else {\n // P2-06: Fallback — set aria-expanded on host when trigger slot is empty or unassigned.\n this.setAttribute('aria-expanded', String(this.open));\n }\n }\n\n override updated(changedProperties: PropertyValues<this>): void {\n super.updated(changedProperties);\n if (changedProperties.has('open')) {\n // Keep aria-expanded in sync\n const slot = this.shadowRoot?.querySelector<HTMLSlotElement>('slot[name=\"trigger\"]');\n const trigger = slot?.assignedElements()[0] as HTMLElement | undefined;\n if (trigger) {\n trigger.setAttribute('aria-expanded', String(this.open));\n } else {\n // P2-06: Fallback — keep host aria-expanded in sync when trigger slot is empty.\n this.setAttribute('aria-expanded', String(this.open));\n }\n }\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-dropdown': HelixDropdown;\n }\n interface HTMLElementEventMap {\n 'hx-show': CustomEvent<void>;\n 'hx-hide': CustomEvent<void>;\n 'hx-select': CustomEvent<{ value: string | null; label: string }>;\n }\n}\n"],"names":["helixDropdownStyles","css","_nextDropdownId","createIdCounter","HelixDropdown","LitElement","firstFocusable","returnFocus","slot","_a","trigger","reference","panel","floatingPlacement","x","y","computePosition","offset","flip","shift","key","items","currentIndex","nextIndex","assignedNodes","node","item","focusableSelector","found","value","label","html","nothing","nonItems","el","devWarn","changedProperties","__decorateClass","property","state","query","customElement"],"mappings":"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"}
@@ -3,7 +3,8 @@ import "./document-token-adoption-DuYNKd4k.js";
3
3
  import { property as o, state as f, customElement as u } from "lit/decorators.js";
4
4
  import { classMap as x } from "lit/directives/class-map.js";
5
5
  import { d as b } from "./dev-warn-YlwPHjtX.js";
6
- const m = p`
6
+ import { c as m } from "./id-counter-PTgF-zcG.js";
7
+ const v = p`
7
8
  :host {
8
9
  display: block;
9
10
  }
@@ -122,20 +123,55 @@ const m = p`
122
123
  outline-offset: var(--hx-focus-ring-offset, 2px);
123
124
  border-radius: var(--hx-border-radius-sm, 0.25rem);
124
125
  }
126
+
127
+ /* ─── High Contrast Mode (forced-colors) ─── */
128
+
129
+ @media (forced-colors: active) {
130
+ .field__label {
131
+ color: CanvasText;
132
+ }
133
+
134
+ .field__required-marker {
135
+ color: LinkText;
136
+ }
137
+
138
+ .field--error .field__label {
139
+ color: LinkText;
140
+ }
141
+
142
+ .field--error .field__control {
143
+ outline-color: LinkText;
144
+ }
145
+
146
+ :host([disabled]) {
147
+ opacity: 1;
148
+ }
149
+
150
+ :host([disabled]) .field__label {
151
+ color: GrayText;
152
+ }
153
+
154
+ .field__help-text {
155
+ color: GrayText;
156
+ }
157
+
158
+ .field__error {
159
+ color: LinkText;
160
+ }
161
+ }
125
162
  `;
126
- var v = Object.defineProperty, y = Object.getOwnPropertyDescriptor, l = (e, t, i, a) => {
127
- for (var s = a > 1 ? void 0 : a ? y(t, i) : t, h = e.length - 1, d; h >= 0; h--)
163
+ var y = Object.defineProperty, g = Object.getOwnPropertyDescriptor, l = (e, t, i, a) => {
164
+ for (var s = a > 1 ? void 0 : a ? g(t, i) : t, h = e.length - 1, d; h >= 0; h--)
128
165
  (d = e[h]) && (s = (a ? d(t, i, s) : d(s)) || s);
129
- return a && s && v(t, i, s), s;
166
+ return a && s && y(t, i, s), s;
130
167
  };
131
- const g = /* @__PURE__ */ new Set(["INPUT", "SELECT", "TEXTAREA", "BUTTON"]);
132
- let S = 0;
133
- function E(e) {
134
- return g.has(e.tagName) || e.tagName.includes("-");
168
+ const S = /* @__PURE__ */ new Set(["INPUT", "SELECT", "TEXTAREA", "BUTTON"]), E = m("hx-field");
169
+ function C(e) {
170
+ return S.has(e.tagName) || e.tagName.includes("-");
135
171
  }
136
172
  let r = class extends _ {
137
173
  constructor() {
138
- super(...arguments), this.label = "", this.required = !1, this.error = "", this.helpText = "", this.disabled = !1, this.size = "md", this.layout = "column", this._hasLabelSlot = !1, this._hasErrorSlot = !1, this._hasHelpSlot = !1, this._fieldId = `hx-field-${++S}`, this._helpTextId = `${this._fieldId}-help`, this._errorId = `${this._fieldId}-error`, this._a11yDescId = `${this._fieldId}-desc`, this._slottedControl = null, this._a11yDescEl = null;
174
+ super(...arguments), this.label = "", this.required = !1, this.error = "", this.helpText = "", this.disabled = !1, this.size = "md", this.layout = "column", this._hasLabelSlot = !1, this._hasErrorSlot = !1, this._hasHelpSlot = !1, this._fieldId = E(), this._helpTextId = `${this._fieldId}-help`, this._errorId = `${this._fieldId}-error`, this._a11yDescId = `${this._fieldId}-desc`, this._slottedControl = null, this._a11yDescEl = null;
139
175
  }
140
176
  /** @internal */
141
177
  _handleLabelSlotChange(e) {
@@ -182,7 +218,7 @@ let r = class extends _ {
182
218
  /** @internal */
183
219
  _handleDefaultSlotChange(e) {
184
220
  const i = e.target.assignedElements();
185
- this._slottedControl = i.find(E) ?? null, this._syncSlottedControl();
221
+ this._slottedControl = i.find(C) ?? null, this._syncSlottedControl();
186
222
  }
187
223
  /**
188
224
  * Focuses the slotted form control when the shadow DOM label is clicked.
@@ -279,7 +315,7 @@ let r = class extends _ {
279
315
  `;
280
316
  }
281
317
  };
282
- r.styles = [m];
318
+ r.styles = [v];
283
319
  l([
284
320
  o({ type: String })
285
321
  ], r.prototype, "label", 2);
@@ -316,4 +352,4 @@ r = l([
316
352
  export {
317
353
  r as H
318
354
  };
319
- //# sourceMappingURL=hx-field-CwT9tki1.js.map
355
+ //# sourceMappingURL=hx-field-Duiib9Bj.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-field-Duiib9Bj.js","sources":["../../src/components/hx-field/hx-field.styles.ts","../../src/components/hx-field/hx-field.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixFieldStyles = css`\n :host {\n display: block;\n }\n\n :host([disabled]) {\n opacity: var(--hx-opacity-disabled, 0.5);\n pointer-events: none;\n }\n\n * {\n box-sizing: border-box;\n }\n\n .field {\n display: flex;\n flex-direction: column;\n gap: var(--hx-field-gap, var(--hx-space-1, 0.25rem));\n font-family: var(--hx-field-font-family, var(--hx-font-family-sans, sans-serif));\n }\n\n /* ─── Inline Layout ─── */\n\n .field--layout-inline {\n flex-direction: row;\n align-items: baseline;\n flex-wrap: wrap;\n }\n\n .field--layout-inline .field__label-wrapper {\n display: flex;\n align-items: baseline;\n flex-shrink: 0;\n min-width: 8rem;\n }\n\n /* ─── Label ─── */\n\n .field__label-wrapper {\n display: contents;\n }\n\n .field__label {\n display: flex;\n align-items: baseline;\n gap: var(--hx-space-1, 0.25rem);\n font-size: var(--hx-font-size-sm, 0.875rem);\n font-weight: var(--hx-font-weight-medium, 500);\n color: var(--hx-field-label-color, var(--hx-color-neutral-700, #374151));\n line-height: var(--hx-line-height-normal, 1.5);\n cursor: pointer;\n }\n\n .field__required-marker {\n color: var(--hx-field-error-color, var(--hx-color-error-text, #b91c1c));\n font-weight: var(--hx-font-weight-bold, 700);\n }\n\n /* ─── Control Wrapper ─── */\n\n .field__control {\n display: block;\n }\n\n /* ─── Error Slot Announcer (visually hidden live region) ─── */\n\n .field__error-slot-announcer {\n position: absolute;\n width: 1px;\n height: 1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n }\n\n /* ─── Size Variants ─── */\n\n :host([hx-size='sm']) .field__label {\n font-size: var(--hx-font-size-xs, 0.75rem);\n }\n\n :host([hx-size='lg']) .field__label {\n font-size: var(--hx-font-size-md, 1rem);\n }\n\n :host([hx-size='sm']) .field__help-text {\n font-size: var(--hx-font-size-xs, 0.75rem);\n }\n\n :host([hx-size='lg']) .field__help-text {\n font-size: var(--hx-font-size-sm, 0.875rem);\n }\n\n /* ─── Help Text & Error Messages ─── */\n\n .field__help-text {\n font-size: var(--hx-font-size-xs, 0.75rem);\n color: var(--hx-field-help-text-color, var(--hx-color-neutral-500, #6b7280));\n line-height: var(--hx-line-height-normal, 1.5);\n }\n\n .field__error {\n font-size: var(--hx-font-size-xs, 0.75rem);\n color: var(--hx-field-error-color, var(--hx-color-error-text, #b91c1c));\n line-height: var(--hx-line-height-normal, 1.5);\n }\n\n /* ─── Error State ─── */\n\n .field--error .field__label {\n color: var(--hx-field-error-color, var(--hx-color-error-text, #b91c1c));\n }\n\n .field--error .field__control {\n outline: 2px solid var(--hx-field-error-color, var(--hx-color-error-500, #ef4444));\n outline-offset: var(--hx-focus-ring-offset, 2px);\n border-radius: var(--hx-border-radius-sm, 0.25rem);\n }\n\n /* ─── High Contrast Mode (forced-colors) ─── */\n\n @media (forced-colors: active) {\n .field__label {\n color: CanvasText;\n }\n\n .field__required-marker {\n color: LinkText;\n }\n\n .field--error .field__label {\n color: LinkText;\n }\n\n .field--error .field__control {\n outline-color: LinkText;\n }\n\n :host([disabled]) {\n opacity: 1;\n }\n\n :host([disabled]) .field__label {\n color: GrayText;\n }\n\n .field__help-text {\n color: GrayText;\n }\n\n .field__error {\n color: LinkText;\n }\n }\n`;\n","import { LitElement, html, nothing, type PropertyValues } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { createIdCounter } from '../../base/index.js';\nimport { helixFieldStyles } from './hx-field.styles.js';\nimport { devWarn } from '../../utils/dev-warn.js';\n\n/** Native form control tag names that can receive ARIA attributes. */\nconst FORM_CONTROL_TAGS = new Set(['INPUT', 'SELECT', 'TEXTAREA', 'BUTTON']);\n\nconst _nextFieldId = createIdCounter('hx-field');\n\n/** Returns true if the element is a native form control or a custom element. */\nfunction isFormControl(el: Element): el is HTMLElement {\n return FORM_CONTROL_TAGS.has(el.tagName) || el.tagName.includes('-');\n}\n\n/**\n * Layout wrapper providing consistent label + input + help text + validation\n * message structure for any form control. Use this when wrapping non-HELiX\n * form controls or native HTML elements in the HELiX form field pattern.\n *\n * This component is NOT form-associated — it is a pure visual layout wrapper.\n *\n * **Light DOM side effect:** This component injects a visually-hidden `<span>`\n * into its light DOM children for ARIA describedby linkage across the shadow\n * DOM boundary. This span has `id=\"${fieldId}-desc\"` and is removed on\n * `disconnectedCallback`. This is an intentional, documented accessibility\n * mechanism.\n *\n * @summary Layout wrapper for label, control, help text, and error message.\n *\n * @tag hx-field\n *\n * @slot - The form control element (native or custom).\n * @slot label - Custom label content (overrides the label property).\n * @slot help-text - Custom help text content (overrides the helpText property).\n * @slot error - Custom error content (overrides the error property).\n * @slot description - Additional descriptive content above the control.\n *\n * @csspart field - The outer field container.\n * @csspart label - The label element.\n * @csspart control - The wrapper around slotted content.\n * @csspart help-text - The help text container.\n * @csspart error-message - The error message container.\n * @csspart required-indicator - The required asterisk span.\n *\n * @cssprop [--hx-field-label-color=var(--hx-color-neutral-700)] - Label color.\n * @cssprop [--hx-field-error-color=var(--hx-color-error-500)] - Error color.\n * @cssprop [--hx-field-font-family=var(--hx-font-family-sans)] - Font family.\n * @cssprop [--hx-field-gap=var(--hx-space-1, 0.25rem)] - Gap between field segments.\n * @cssprop [--hx-field-help-text-color=var(--hx-color-neutral-500)] - Help text color.\n */\n@customElement('hx-field')\nexport class HelixField extends LitElement {\n static override styles = [helixFieldStyles];\n\n // ─── Properties ───\n\n /**\n * The visible label text for the field.\n * @attr label\n */\n @property({ type: String })\n label = '';\n\n /**\n * Whether the field is required. Shows a required indicator on the label.\n * @attr required\n */\n @property({ type: Boolean, reflect: true })\n required = false;\n\n /**\n * Error message to display. When set, the field enters an error state.\n * @attr error\n */\n @property({ type: String })\n error = '';\n\n /**\n * Help text displayed below the control for guidance.\n * @attr help-text\n */\n @property({ type: String, attribute: 'help-text' })\n helpText = '';\n\n /**\n * Visual disabled state applied via opacity. Does not affect slotted control\n * interactivity — set disabled on the slotted control directly.\n * @attr disabled\n */\n @property({ type: Boolean, reflect: true })\n disabled = false;\n\n /**\n * Size variant controlling label and help text font sizes.\n * @attr hx-size\n */\n @property({ type: String, attribute: 'hx-size', reflect: true })\n size: 'sm' | 'md' | 'lg' = 'md';\n\n /**\n * Layout variant. 'column' stacks label above control; 'inline' places them side-by-side.\n * @attr layout\n */\n @property({ type: String, reflect: true })\n layout: 'column' | 'inline' = 'column';\n\n // ─── Slot Tracking ───\n\n /**\n * Tracks whether any content is assigned to the label slot, used to conditionally render the label property.\n * @internal\n */\n @state() private _hasLabelSlot = false;\n\n /**\n * Tracks whether any content is assigned to the error slot, used to toggle error state rendering.\n * @internal\n */\n @state() private _hasErrorSlot = false;\n\n /**\n * Tracks whether any content is assigned to the help-text slot, used to toggle help text rendering.\n * @internal\n */\n @state() private _hasHelpSlot = false;\n\n /** @internal */\n private _handleLabelSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasLabelSlot = slot.assignedElements().length > 0;\n }\n\n /** @internal */\n private _handleErrorSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasErrorSlot = slot.assignedElements().length > 0;\n }\n\n /** @internal */\n private _handleHelpSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n this._hasHelpSlot = slot.assignedElements().length > 0;\n }\n\n // ─── Unique IDs for Accessibility ───\n\n /**\n * Unique ID for this field instance, used as a base for all derived accessibility IDs.\n * @internal\n */\n private _fieldId = _nextFieldId();\n\n /**\n * ID for the help text element, allowing aria-describedby to reference it.\n * @internal\n */\n private _helpTextId = `${this._fieldId}-help`;\n\n /**\n * ID for the error message element, allowing aria-describedby to reference it.\n * @internal\n */\n private _errorId = `${this._fieldId}-error`;\n\n /**\n * ID for the light-DOM description span injected for cross-shadow-root aria-describedby linkage.\n * @internal\n */\n private _a11yDescId = `${this._fieldId}-desc`;\n\n // ─── A11y: Slotted control tracking + light-DOM description element ───\n\n /**\n * The first form control in the default slot. We set aria attributes on this\n * element to bridge the shadow DOM accessibility boundary.\n * @internal\n */\n private _slottedControl: HTMLElement | null = null;\n\n /**\n * A visually-hidden span injected into the host's light DOM (assigned to the\n * default slot). Because it lives in the same document as the slotted input,\n * `aria-describedby` can reference its ID without cross-shadow-root IDREF\n * limitations.\n *\n * **Documented side effect:** This element is intentionally injected into the\n * component's light DOM children. It is invisible to users but present in the\n * accessibility tree. It is removed in `disconnectedCallback`. Consumers\n * should not remove or modify this span (identifiable by its `id` ending in\n * `-desc`).\n * @internal\n */\n private _a11yDescEl: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this._ensureA11yDescEl();\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this._a11yDescEl?.remove();\n this._a11yDescEl = null;\n // Remove aria attributes we set on the slotted control\n if (this._slottedControl) {\n this._slottedControl.removeAttribute('aria-label');\n this._slottedControl.removeAttribute('aria-required');\n this._slottedControl.removeAttribute('aria-invalid');\n this._slottedControl.removeAttribute('aria-describedby');\n this._slottedControl = null;\n }\n }\n\n override updated(changedProps: PropertyValues<this>): void {\n super.updated(changedProps);\n\n // P2-01: Warn on invalid size values\n if (changedProps.has('size')) {\n const validSizes = ['sm', 'md', 'lg'];\n if (!validSizes.includes(this.size)) {\n devWarn(\n 'hx-field',\n `Invalid hx-size value: \"${this.size}\". Expected \"sm\" | \"md\" | \"lg\". Defaulting to \"md\".`,\n );\n }\n }\n\n this._syncA11yDescEl();\n this._syncSlottedControl();\n }\n\n /** Creates a visually-hidden span in light DOM used as the ARIA description anchor. */\n /** @internal */\n private _ensureA11yDescEl(): void {\n if (this._a11yDescEl) return;\n // Guard for SSR — document is unavailable server-side\n if (typeof document === 'undefined') return;\n const span = document.createElement('span');\n span.id = this._a11yDescId;\n // Visually hidden but present in the accessibility tree\n span.style.cssText =\n 'position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0';\n this.appendChild(span);\n this._a11yDescEl = span;\n }\n\n /** Keeps the light-DOM description span in sync with the current error/help text. */\n /** @internal */\n private _syncA11yDescEl(): void {\n if (!this._a11yDescEl) return;\n const hasError = !!this.error || this._hasErrorSlot;\n if (hasError && this.error) {\n this._a11yDescEl.textContent = this.error;\n } else if (this.helpText) {\n this._a11yDescEl.textContent = this.helpText;\n } else {\n this._a11yDescEl.textContent = '';\n }\n }\n\n /** Tracks the first form control assigned to the default slot. */\n /** @internal */\n private _handleDefaultSlotChange(e: Event): void {\n const slot = e.target as HTMLSlotElement;\n const assigned = slot.assignedElements();\n this._slottedControl = assigned.find(isFormControl) ?? null;\n this._syncSlottedControl();\n }\n\n /**\n * Focuses the slotted form control when the shadow DOM label is clicked.\n * The shadow `<label>` cannot use `for`/`id` to link to a slotted input\n * across the shadow boundary, so we handle focus programmatically.\n */\n /** @internal */\n private _handleLabelClick(_e: Event): void {\n this._slottedControl?.focus();\n }\n\n /**\n * Applies ARIA attributes to the slotted form control, bridging the\n * shadow DOM accessibility boundary.\n *\n * - aria-label: associates the field label with the control\n * - aria-required: communicates required state to AT\n * - aria-invalid: communicates error state to AT\n * - aria-describedby: points to the light-DOM description span\n *\n * **Skip conditions:**\n * - `HX-*` elements manage their own ARIA attributes; bridging is skipped.\n * - Elements with `data-aria-managed` attribute opt out of ARIA mutation;\n * bridging is skipped entirely for those elements.\n */\n /** @internal */\n private _syncSlottedControl(): void {\n const control = this._slottedControl;\n if (!control) return;\n\n // hx-* elements manage their own ARIA attributes; skip bridging for them\n if (control.tagName.startsWith('HX-')) return;\n\n // Elements that declare data-aria-managed opt out of ARIA mutation\n if (control.hasAttribute('data-aria-managed')) return;\n\n const hasError = !!this.error || this._hasErrorSlot;\n const hasDesc = !!(this.error || this.helpText || this._hasErrorSlot || this._hasHelpSlot);\n\n // Label association: aria-label bridges the shadow DOM boundary\n if (this.label && !this._hasLabelSlot) {\n control.setAttribute('aria-label', this.label);\n } else {\n control.removeAttribute('aria-label');\n }\n\n // Required state\n if (this.required) {\n control.setAttribute('aria-required', 'true');\n } else {\n control.removeAttribute('aria-required');\n }\n\n // Invalid state\n if (hasError) {\n control.setAttribute('aria-invalid', 'true');\n } else {\n control.removeAttribute('aria-invalid');\n }\n\n // Description (error or help text) via light-DOM span\n if (hasDesc) {\n control.setAttribute('aria-describedby', this._a11yDescId);\n } else {\n control.removeAttribute('aria-describedby');\n }\n }\n\n // ─── Render ───\n\n override render() {\n const hasError = !!this.error || this._hasErrorSlot;\n const hasHelp = !!this.helpText || this._hasHelpSlot;\n\n const fieldClasses = {\n field: true,\n 'field--error': hasError,\n 'field--disabled': this.disabled,\n 'field--required': this.required,\n 'field--size-sm': this.size === 'sm',\n 'field--size-md': this.size === 'md',\n 'field--size-lg': this.size === 'lg',\n 'field--layout-inline': this.layout === 'inline',\n };\n\n return html`\n <div part=\"field\" class=${classMap(fieldClasses)}>\n <!-- Label -->\n <div class=\"field__label-wrapper\">\n <slot name=\"label\" @slotchange=${this._handleLabelSlotChange}>\n ${this.label && !this._hasLabelSlot\n ? html`\n <label part=\"label\" class=\"field__label\" @click=${this._handleLabelClick}>\n ${this.label}\n ${this.required\n ? html`<span\n part=\"required-indicator\"\n class=\"field__required-marker\"\n aria-hidden=\"true\"\n >*</span\n >`\n : nothing}\n </label>\n `\n : nothing}\n </slot>\n </div>\n\n <!-- Description -->\n <slot name=\"description\"></slot>\n\n <!-- Control (default slot) -->\n <div part=\"control\" class=\"field__control\">\n <slot @slotchange=${this._handleDefaultSlotChange}></slot>\n </div>\n\n <!-- Error -->\n <slot name=\"error\" @slotchange=${this._handleErrorSlotChange}>\n ${this.error\n ? html`\n <div part=\"error-message\" class=\"field__error\" id=${this._errorId} role=\"alert\">\n ${this.error}\n </div>\n `\n : nothing}\n </slot>\n\n <!-- Slotted error live region — ensures slotted error content is announced -->\n <div aria-live=\"assertive\" class=\"field__error-slot-announcer\"></div>\n\n <!-- Help text (always in DOM so slot detection works; hidden when no help or error is shown) -->\n <div\n part=\"help-text\"\n class=\"field__help-text\"\n id=${this._helpTextId}\n ?hidden=${!hasHelp || hasError}\n >\n <slot name=\"help-text\" @slotchange=${this._handleHelpSlotChange}>${this.helpText}</slot>\n </div>\n </div>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-field': HelixField;\n }\n}\n"],"names":["helixFieldStyles","css","FORM_CONTROL_TAGS","_nextFieldId","createIdCounter","isFormControl","el","HelixField","LitElement","slot","_a","changedProps","devWarn","span","assigned","_e","control","hasError","hasDesc","hasHelp","fieldClasses","html","classMap","nothing","__decorateClass","property","state","customElement"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
- import { css as f, LitElement as d, html as a, nothing as c } from "lit";
1
+ import { css as d, LitElement as f, html as a, nothing as h } from "lit";
2
2
  import "./document-token-adoption-DuYNKd4k.js";
3
- import { property as h, customElement as x } from "lit/decorators.js";
4
- const u = f`
3
+ import { property as c, customElement as x } from "lit/decorators.js";
4
+ const u = d`
5
5
  :host {
6
6
  display: block;
7
7
  }
@@ -28,6 +28,22 @@ const u = f`
28
28
  color: var(--hx-color-neutral-500, #6b7280);
29
29
  }
30
30
 
31
+ /* ─── High Contrast Mode (forced-colors) ─── */
32
+
33
+ @media (forced-colors: active) {
34
+ .label {
35
+ color: CanvasText;
36
+ }
37
+
38
+ .required-indicator {
39
+ color: LinkText;
40
+ }
41
+
42
+ .optional-indicator {
43
+ color: GrayText;
44
+ }
45
+ }
46
+
31
47
  .visually-hidden {
32
48
  position: absolute;
33
49
  width: 1px;
@@ -40,12 +56,12 @@ const u = f`
40
56
  border: 0;
41
57
  }
42
58
  `;
43
- var v = Object.defineProperty, b = Object.getOwnPropertyDescriptor, n = (i, r, t, l) => {
44
- for (var e = l > 1 ? void 0 : l ? b(r, t) : r, s = i.length - 1, p; s >= 0; s--)
45
- (p = i[s]) && (e = (l ? p(r, t, e) : p(e)) || e);
46
- return l && e && v(r, t, e), e;
59
+ var v = Object.defineProperty, b = Object.getOwnPropertyDescriptor, n = (i, r, o, l) => {
60
+ for (var e = l > 1 ? void 0 : l ? b(r, o) : r, s = i.length - 1, p; s >= 0; s--)
61
+ (p = i[s]) && (e = (l ? p(r, o, e) : p(e)) || e);
62
+ return l && e && v(r, o, e), e;
47
63
  };
48
- let o = class extends d {
64
+ let t = class extends f {
49
65
  constructor() {
50
66
  super(...arguments), this.for = "", this.required = !1, this.optional = !1;
51
67
  }
@@ -53,24 +69,24 @@ let o = class extends d {
53
69
  const i = this.required ? a`<span part="required-indicator" class="required-indicator"
54
70
  ><span aria-hidden="true"><slot name="required-indicator">*</slot></span
55
71
  ><span class="visually-hidden">required</span></span
56
- >` : c, r = this.optional ? a`<span part="optional-indicator" class="optional-indicator">(optional)</span>` : c, t = a`<slot></slot>${i}${r}`;
57
- return this.for ? a`<label part="base" class="label" for=${this.for}>${t}</label>` : a`<span part="base" class="label">${t}</span>`;
72
+ >` : h, r = this.optional ? a`<span part="optional-indicator" class="optional-indicator">(optional)</span>` : h, o = a`<slot></slot>${i}${r}`;
73
+ return this.for ? a`<label part="base" class="label" for=${this.for}>${o}</label>` : a`<span part="base" class="label">${o}</span>`;
58
74
  }
59
75
  };
60
- o.styles = [u];
76
+ t.styles = [u];
61
77
  n([
62
- h({ type: String })
63
- ], o.prototype, "for", 2);
78
+ c({ type: String })
79
+ ], t.prototype, "for", 2);
64
80
  n([
65
- h({ type: Boolean, reflect: !0 })
66
- ], o.prototype, "required", 2);
81
+ c({ type: Boolean, reflect: !0 })
82
+ ], t.prototype, "required", 2);
67
83
  n([
68
- h({ type: Boolean, reflect: !0 })
69
- ], o.prototype, "optional", 2);
70
- o = n([
84
+ c({ type: Boolean, reflect: !0 })
85
+ ], t.prototype, "optional", 2);
86
+ t = n([
71
87
  x("hx-field-label")
72
- ], o);
88
+ ], t);
73
89
  export {
74
- o as H
90
+ t as H
75
91
  };
76
- //# sourceMappingURL=hx-field-label-CcOK9VU3.js.map
92
+ //# sourceMappingURL=hx-field-label-Dud-psvE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hx-field-label-Dud-psvE.js","sources":["../../src/components/hx-field-label/hx-field-label.styles.ts","../../src/components/hx-field-label/hx-field-label.ts"],"sourcesContent":["import { css } from 'lit';\n\nexport const helixFieldLabelStyles = css`\n :host {\n display: block;\n }\n\n .label {\n display: inline-flex;\n align-items: baseline;\n gap: var(--hx-space-1, 0.25rem);\n font-size: var(--hx-font-label-size, var(--hx-font-size-sm, 0.875rem));\n font-weight: var(--hx-font-label-weight, var(--hx-font-weight-medium, 500));\n color: var(--hx-field-label-color, var(--hx-color-neutral-700, #374151));\n line-height: var(--hx-font-label-line-height, var(--hx-line-height-normal, 1.5));\n font-family: var(--hx-font-label-family, var(--hx-font-family-sans, sans-serif));\n }\n\n .required-indicator {\n color: var(--hx-field-label-required-color, var(--hx-color-error-text, #b91c1c));\n font-weight: var(--hx-font-weight-bold, 700);\n }\n\n .optional-indicator {\n font-size: var(--hx-font-size-xs, 0.75rem);\n font-weight: var(--hx-font-weight-normal, 400);\n color: var(--hx-color-neutral-500, #6b7280);\n }\n\n /* ─── High Contrast Mode (forced-colors) ─── */\n\n @media (forced-colors: active) {\n .label {\n color: CanvasText;\n }\n\n .required-indicator {\n color: LinkText;\n }\n\n .optional-indicator {\n color: GrayText;\n }\n }\n\n .visually-hidden {\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: 0;\n }\n`;\n","import { LitElement, html, nothing } from 'lit';\nimport '../../utilities/document-token-adoption.js';\nimport { customElement, property } from 'lit/decorators.js';\nimport { helixFieldLabelStyles } from './hx-field-label.styles.js';\n\n/**\n * Standardized label for form fields. Used as a consistent sub-component\n * for hx-field and other form field components.\n *\n * ## Label Association\n *\n * **For inputs in light DOM (the typical consumer deployment):** Use\n * `aria-labelledby` pointing to the host element's `id`. The `for` attribute\n * renders a native `<label for=\"...\">` inside shadow DOM, but the HTML spec\n * scopes `for`/`id` lookup to the same tree — a shadow-DOM label cannot\n * associate with a light-DOM input. Example:\n *\n * ```html\n * <hx-field-label id=\"label-email\">Email</hx-field-label>\n * <input id=\"email\" aria-labelledby=\"label-email\" />\n * ```\n *\n * **For inputs in the same shadow root:** The `for` attribute works as\n * expected for direct label association.\n *\n * When `for` is unset, renders a `<span>` that can be referenced via\n * `aria-labelledby` for labeling controls across the shadow DOM boundary.\n *\n * @summary Standardized label for form fields.\n *\n * @tag hx-field-label\n *\n * @slot - Label text content.\n * @slot required-indicator - Custom required marker (defaults to \"*\").\n *\n * @csspart base - The label or span element.\n * @csspart required-indicator - The required indicator wrapper.\n * @csspart optional-indicator - The optional text indicator.\n *\n * @cssprop [--hx-field-label-color=var(--hx-color-neutral-700)] - Label text color.\n * @cssprop [--hx-field-label-required-color=var(--hx-color-danger, var(--hx-color-error-text, #b91c1c))] - Required indicator color.\n * @cssprop [--hx-font-label-size=var(--hx-font-size-sm)] - Label font size.\n * @cssprop [--hx-font-label-weight=var(--hx-font-weight-medium)] - Label font weight.\n * @cssprop [--hx-font-label-line-height=var(--hx-line-height-normal)] - Label line height.\n * @cssprop [--hx-font-label-family=var(--hx-font-family-sans)] - Label font family.\n */\n@customElement('hx-field-label')\nexport class HelixFieldLabel extends LitElement {\n static override styles = [helixFieldLabelStyles];\n\n /**\n * The ID of the associated form control. When set, renders a native\n * `<label for=\"...\">` element for direct label association.\n * @attr for\n */\n @property({ type: String })\n for = '';\n\n /**\n * Whether the associated field is required. Shows a required indicator (*).\n * @attr required\n */\n @property({ type: Boolean, reflect: true })\n required = false;\n\n /**\n * Whether the associated field is optional. Shows \"(optional)\" text.\n * @attr optional\n */\n @property({ type: Boolean, reflect: true })\n optional = false;\n\n override render() {\n const requiredIndicator = this.required\n ? html`<span part=\"required-indicator\" class=\"required-indicator\"\n ><span aria-hidden=\"true\"><slot name=\"required-indicator\">*</slot></span\n ><span class=\"visually-hidden\">required</span></span\n >`\n : nothing;\n\n const optionalIndicator = this.optional\n ? html`<span part=\"optional-indicator\" class=\"optional-indicator\">(optional)</span>`\n : nothing;\n\n const content = html`<slot></slot>${requiredIndicator}${optionalIndicator}`;\n\n if (this.for) {\n return html`<label part=\"base\" class=\"label\" for=${this.for}>${content}</label>`;\n }\n\n return html`<span part=\"base\" class=\"label\">${content}</span>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hx-field-label': HelixFieldLabel;\n }\n}\n"],"names":["helixFieldLabelStyles","css","HelixFieldLabel","LitElement","requiredIndicator","html","nothing","optionalIndicator","content","__decorateClass","property","customElement"],"mappings":";;;AAEO,MAAMA,IAAwBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;;;;AC6C9B,IAAMC,IAAN,cAA8BC,EAAW;AAAA,EAAzC,cAAA;AAAA,UAAA,GAAA,SAAA,GASL,KAAA,MAAM,IAON,KAAA,WAAW,IAOX,KAAA,WAAW;AAAA,EAAA;AAAA,EAEF,SAAS;AAChB,UAAMC,IAAoB,KAAK,WAC3BC;AAAA;AAAA;AAAA,aAIAC,GAEEC,IAAoB,KAAK,WAC3BF,kFACAC,GAEEE,IAAUH,iBAAoBD,CAAiB,GAAGG,CAAiB;AAEzE,WAAI,KAAK,MACAF,yCAA4C,KAAK,GAAG,IAAIG,CAAO,aAGjEH,oCAAuCG,CAAO;AAAA,EACvD;AACF;AA7CaN,EACK,SAAS,CAACF,CAAqB;AAQ/CS,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GARfR,EASX,WAAA,OAAA,CAAA;AAOAO,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAf/BR,EAgBX,WAAA,YAAA,CAAA;AAOAO,EAAA;AAAA,EADCC,EAAS,EAAE,MAAM,SAAS,SAAS,IAAM;AAAA,GAtB/BR,EAuBX,WAAA,YAAA,CAAA;AAvBWA,IAANO,EAAA;AAAA,EADNE,EAAc,gBAAgB;AAAA,GAClBT,CAAA;"}
@@ -1,11 +1,13 @@
1
- import { css as b, nothing as c, html as f, LitElement as x } from "lit";
1
+ import { css as x, nothing as c, html as f } from "lit";
2
2
  import "./document-token-adoption-DuYNKd4k.js";
3
- import { property as n, state as g, query as _, customElement as y } from "lit/decorators.js";
4
- import { classMap as w } from "lit/directives/class-map.js";
3
+ import { property as n, state as g, query as b, customElement as _ } from "lit/decorators.js";
4
+ import { classMap as y } from "lit/directives/class-map.js";
5
5
  import { ifDefined as v } from "lit/directives/if-defined.js";
6
- import { repeat as z } from "lit/directives/repeat.js";
7
- import { m as $ } from "./aria-delegation-CBP9eQ0M.js";
8
- const F = b`
6
+ import { repeat as w } from "lit/directives/repeat.js";
7
+ import { m as z } from "./aria-delegation-Doq6RRUy.js";
8
+ import { c as $ } from "./id-counter-PTgF-zcG.js";
9
+ import { H as F } from "./helix-element-BJh1Ffvi.js";
10
+ const D = x`
9
11
  :host {
10
12
  display: block;
11
13
  }
@@ -295,14 +297,15 @@ const F = b`
295
297
  }
296
298
  }
297
299
  `;
298
- var D = Object.defineProperty, k = Object.getOwnPropertyDescriptor, l = (e, r, t, i) => {
299
- for (var s = i > 1 ? void 0 : i ? k(r, t) : r, a = e.length - 1, d; a >= 0; a--)
300
+ var k = Object.defineProperty, S = Object.getOwnPropertyDescriptor, l = (e, r, t, i) => {
301
+ for (var s = i > 1 ? void 0 : i ? S(r, t) : r, a = e.length - 1, d; a >= 0; a--)
300
302
  (d = e[a]) && (s = (i ? d(r, t, s) : d(s)) || s);
301
- return i && s && D(r, t, s), s;
303
+ return i && s && k(r, t, s), s;
302
304
  };
303
- let C = 0, o = class extends $(x) {
305
+ const C = $("hx-file-upload");
306
+ let o = class extends z(F) {
304
307
  constructor() {
305
- super(), this.name = "", this.accept = "", this.maxSize = 0, this.maxFiles = 0, this.multiple = !1, this.label = "", this.disabled = !1, this.error = "", this.labelDropzone = "Drag files here or click to browse", this.labelFileList = "Selected files", this.labelUploadProgress = (e, r) => `Upload progress for ${e}: ${r}%`, this.labelDragDetected = "File detected. Release to upload.", this._files = [], this._dragOver = !1, this._hasFileListSlot = !1, this._baseId = `hx-file-upload-${++C}`, this._labelId = `${this._baseId}-label`, this._errorId = `${this._baseId}-error`, this._dropzoneId = `${this._baseId}-dropzone`, this._liveId = `${this._baseId}-live`, this._internals = this.attachInternals();
308
+ super(...arguments), this.name = "", this.accept = "", this.maxSize = 0, this.maxFiles = 0, this.multiple = !1, this.label = "", this.disabled = !1, this.error = "", this.labelDropzone = "Drag files here or click to browse", this.labelFileList = "Selected files", this.labelUploadProgress = (e, r) => `Upload progress for ${e}: ${r}%`, this.labelDragDetected = "File detected. Release to upload.", this._files = [], this._dragOver = !1, this._hasFileListSlot = !1, this._baseId = C(), this._labelId = `${this._baseId}-label`, this._errorId = `${this._baseId}-error`, this._dropzoneId = `${this._baseId}-dropzone`, this._liveId = `${this._baseId}-live`;
306
309
  }
307
310
  // ─── Slot Handling ───
308
311
  /** @internal */
@@ -315,18 +318,6 @@ let C = 0, o = class extends $(x) {
315
318
  super.updated(e), (e.has("_files") || e.has("name")) && this._syncFormValue();
316
319
  }
317
320
  // ─── Form Integration ───
318
- /** Returns the associated form element, if any. */
319
- get form() {
320
- return this._internals.form;
321
- }
322
- /** Returns the validation message. */
323
- get validationMessage() {
324
- return this._internals.validationMessage;
325
- }
326
- /** Returns the ValidityState object. */
327
- get validity() {
328
- return this._internals.validity;
329
- }
330
321
  /** Checks whether the component satisfies its constraints. */
331
322
  checkValidity() {
332
323
  return this._internals.checkValidity();
@@ -336,15 +327,15 @@ let C = 0, o = class extends $(x) {
336
327
  return this._internals.reportValidity();
337
328
  }
338
329
  /** @internal */
339
- formResetCallback() {
330
+ _onFormReset() {
340
331
  this._files = [], this._internals.setFormValue(null);
341
332
  }
342
333
  /** @internal */
343
- formDisabledCallback(e) {
334
+ _onFormDisabled(e) {
344
335
  this.disabled = e;
345
336
  }
346
337
  /** @internal */
347
- formStateRestoreCallback(e, r) {
338
+ _onFormStateRestore(e, r) {
348
339
  (r === "restore" || r === "autocomplete") && (this._files = [], this._internals.setFormValue(null));
349
340
  }
350
341
  /** @internal */
@@ -543,7 +534,7 @@ let C = 0, o = class extends $(x) {
543
534
  _renderFileList() {
544
535
  return this._hasFileListSlot ? c : this._files.length === 0 ? c : f`
545
536
  <ul part="file-list" class="file-list" aria-label=${this.labelFileList}>
546
- ${z(
537
+ ${w(
547
538
  this._files,
548
539
  (e) => e.file.name + e.file.size,
549
540
  (e, r) => f`
@@ -612,7 +603,7 @@ let C = 0, o = class extends $(x) {
612
603
 
613
604
  <div
614
605
  part="dropzone"
615
- class=${w(r)}
606
+ class=${y(r)}
616
607
  id=${this._dropzoneId}
617
608
  role="button"
618
609
  tabindex=${this.disabled ? "-1" : "0"}
@@ -657,10 +648,10 @@ let C = 0, o = class extends $(x) {
657
648
  `;
658
649
  }
659
650
  };
660
- o.styles = [F];
651
+ o.styles = [D];
661
652
  o.formAssociated = !0;
662
653
  l([
663
- n({ type: String })
654
+ n({ type: String, reflect: !0 })
664
655
  ], o.prototype, "name", 2);
665
656
  l([
666
657
  n({ type: String })
@@ -705,12 +696,12 @@ l([
705
696
  g()
706
697
  ], o.prototype, "_hasFileListSlot", 2);
707
698
  l([
708
- _(".file-input")
699
+ b(".file-input")
709
700
  ], o.prototype, "_fileInput", 2);
710
701
  o = l([
711
- y("hx-file-upload")
702
+ _("hx-file-upload")
712
703
  ], o);
713
704
  export {
714
705
  o as H
715
706
  };
716
- //# sourceMappingURL=hx-file-upload-Di_vpQaG.js.map
707
+ //# sourceMappingURL=hx-file-upload-CmCCAvej.js.map