@cube-dev/ui-kit 0.118.0 → 0.119.1

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 (1012) hide show
  1. package/dist/CHANGELOG.md +24 -0
  2. package/dist/_internal/hooks/use-chained-callback.js +1 -1
  3. package/dist/_internal/hooks/use-debounced-value.js +1 -1
  4. package/dist/_internal/hooks/use-deprecation-warning.js +1 -1
  5. package/dist/_internal/hooks/use-event.js +1 -1
  6. package/dist/_internal/hooks/use-is-first-render.js +1 -1
  7. package/dist/_internal/hooks/use-sync-ref.js +1 -1
  8. package/dist/_internal/hooks/use-timer/timer.js +1 -1
  9. package/dist/_internal/hooks/use-timer/use-timer.js +1 -1
  10. package/dist/_internal/hooks/use-warn.js +1 -1
  11. package/dist/components/Block.d.ts +1 -2
  12. package/dist/components/Block.js +2 -5
  13. package/dist/components/Block.js.map +1 -1
  14. package/dist/components/CollectionItem.js +1 -1
  15. package/dist/components/GlobalStyles.js +2 -3
  16. package/dist/components/GlobalStyles.js.map +1 -1
  17. package/dist/components/GridProvider.d.ts +1 -2
  18. package/dist/components/GridProvider.js +2 -3
  19. package/dist/components/GridProvider.js.map +1 -1
  20. package/dist/components/HiddenInput.js +2 -2
  21. package/dist/components/HiddenInput.js.map +1 -1
  22. package/dist/components/Root.d.ts +1 -2
  23. package/dist/components/Root.js +2 -6
  24. package/dist/components/Root.js.map +1 -1
  25. package/dist/components/actions/Action/Action.d.ts +1 -2
  26. package/dist/components/actions/Action/Action.js +2 -4
  27. package/dist/components/actions/Action/Action.js.map +1 -1
  28. package/dist/components/actions/Banner/Banner.js +2 -2
  29. package/dist/components/actions/Banner/Banner.js.map +1 -1
  30. package/dist/components/actions/Button/Button.d.ts +3 -1769
  31. package/dist/components/actions/Button/Button.js +2 -4
  32. package/dist/components/actions/Button/Button.js.map +1 -1
  33. package/dist/components/actions/ButtonGroup/ButtonGroup.js +2 -2
  34. package/dist/components/actions/ButtonGroup/ButtonGroup.js.map +1 -1
  35. package/dist/components/actions/CommandMenu/CommandMenu.d.ts +1 -3
  36. package/dist/components/actions/CommandMenu/CommandMenu.js +2 -4
  37. package/dist/components/actions/CommandMenu/CommandMenu.js.map +1 -1
  38. package/dist/components/actions/CommandMenu/styled.js +3 -3
  39. package/dist/components/actions/CommandMenu/styled.js.map +1 -1
  40. package/dist/components/actions/ItemAction/ItemAction.d.ts +1 -3
  41. package/dist/components/actions/ItemAction/ItemAction.js +2 -2
  42. package/dist/components/actions/ItemAction/ItemAction.js.map +1 -1
  43. package/dist/components/actions/ItemActionContext.js +1 -1
  44. package/dist/components/actions/ItemButton/ItemButton.d.ts +1 -2
  45. package/dist/components/actions/ItemButton/ItemButton.js +2 -2
  46. package/dist/components/actions/ItemButton/ItemButton.js.map +1 -1
  47. package/dist/components/actions/Link/Link.js +1 -1
  48. package/dist/components/actions/Menu/Menu.d.ts +1 -3
  49. package/dist/components/actions/Menu/Menu.js +2 -4
  50. package/dist/components/actions/Menu/Menu.js.map +1 -1
  51. package/dist/components/actions/Menu/MenuItem.d.ts +1 -2
  52. package/dist/components/actions/Menu/MenuItem.js +1 -1
  53. package/dist/components/actions/Menu/MenuItem.js.map +1 -1
  54. package/dist/components/actions/Menu/MenuSection.d.ts +1 -2
  55. package/dist/components/actions/Menu/MenuSection.js +1 -1
  56. package/dist/components/actions/Menu/MenuSection.js.map +1 -1
  57. package/dist/components/actions/Menu/MenuTrigger.js +1 -1
  58. package/dist/components/actions/Menu/SubMenuTrigger.js +1 -1
  59. package/dist/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  60. package/dist/components/actions/Menu/context.js +1 -1
  61. package/dist/components/actions/Menu/styled.js +2 -2
  62. package/dist/components/actions/Menu/styled.js.map +1 -1
  63. package/dist/components/actions/index.js +1 -1
  64. package/dist/components/actions/use-action.d.ts +1 -2
  65. package/dist/components/actions/use-action.js +2 -2
  66. package/dist/components/actions/use-action.js.map +1 -1
  67. package/dist/components/actions/use-anchored-menu.js +1 -1
  68. package/dist/components/actions/use-context-menu.js +1 -1
  69. package/dist/components/content/ActiveZone/ActiveZone.d.ts +1 -2
  70. package/dist/components/content/ActiveZone/ActiveZone.js +2 -5
  71. package/dist/components/content/ActiveZone/ActiveZone.js.map +1 -1
  72. package/dist/components/content/Alert/Alert.js +2 -2
  73. package/dist/components/content/Alert/Alert.js.map +1 -1
  74. package/dist/components/content/Alert/types.d.ts +1 -2
  75. package/dist/components/content/Alert/use-alert.js +2 -4
  76. package/dist/components/content/Alert/use-alert.js.map +1 -1
  77. package/dist/components/content/Avatar/Avatar.d.ts +1 -3
  78. package/dist/components/content/Avatar/Avatar.js +2 -5
  79. package/dist/components/content/Avatar/Avatar.js.map +1 -1
  80. package/dist/components/content/Badge/Badge.js +2 -2
  81. package/dist/components/content/Badge/Badge.js.map +1 -1
  82. package/dist/components/content/Card/Card.d.ts +1 -2
  83. package/dist/components/content/Card/Card.js +2 -5
  84. package/dist/components/content/Card/Card.js.map +1 -1
  85. package/dist/components/content/Content.d.ts +1 -2
  86. package/dist/components/content/Content.js +2 -5
  87. package/dist/components/content/Content.js.map +1 -1
  88. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.d.ts +1 -3
  89. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js +2 -4
  90. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js.map +1 -1
  91. package/dist/components/content/CopySnippet/CopySnippet.js +2 -2
  92. package/dist/components/content/CopySnippet/CopySnippet.js.map +1 -1
  93. package/dist/components/content/Disclosure/Disclosure.d.ts +1 -3
  94. package/dist/components/content/Disclosure/Disclosure.js +3 -4
  95. package/dist/components/content/Disclosure/Disclosure.js.map +1 -1
  96. package/dist/components/content/Divider.d.ts +1 -2
  97. package/dist/components/content/Divider.js +2 -4
  98. package/dist/components/content/Divider.js.map +1 -1
  99. package/dist/components/content/Footer.d.ts +1 -2
  100. package/dist/components/content/Footer.js +2 -5
  101. package/dist/components/content/Footer.js.map +1 -1
  102. package/dist/components/content/Header.d.ts +1 -2
  103. package/dist/components/content/Header.js +2 -5
  104. package/dist/components/content/Header.js.map +1 -1
  105. package/dist/components/content/HotKeys/HotKeys.d.ts +1 -2
  106. package/dist/components/content/HotKeys/HotKeys.js +2 -5
  107. package/dist/components/content/HotKeys/HotKeys.js.map +1 -1
  108. package/dist/components/content/Item/Item.d.ts +1 -3
  109. package/dist/components/content/Item/Item.js +2 -3
  110. package/dist/components/content/Item/Item.js.map +1 -1
  111. package/dist/components/content/ItemBadge/ItemBadge.d.ts +1 -2
  112. package/dist/components/content/ItemBadge/ItemBadge.js +2 -2
  113. package/dist/components/content/ItemBadge/ItemBadge.js.map +1 -1
  114. package/dist/components/content/Layout/GridLayout.d.ts +1 -2
  115. package/dist/components/content/Layout/GridLayout.js +2 -2
  116. package/dist/components/content/Layout/GridLayout.js.map +1 -1
  117. package/dist/components/content/Layout/Layout.d.ts +1 -3
  118. package/dist/components/content/Layout/Layout.js +3 -7
  119. package/dist/components/content/Layout/Layout.js.map +1 -1
  120. package/dist/components/content/Layout/LayoutBlock.js +2 -2
  121. package/dist/components/content/Layout/LayoutBlock.js.map +1 -1
  122. package/dist/components/content/Layout/LayoutCenter.js +2 -2
  123. package/dist/components/content/Layout/LayoutCenter.js.map +1 -1
  124. package/dist/components/content/Layout/LayoutContainer.d.ts +1 -3
  125. package/dist/components/content/Layout/LayoutContainer.js +2 -6
  126. package/dist/components/content/Layout/LayoutContainer.js.map +1 -1
  127. package/dist/components/content/Layout/LayoutContent.d.ts +1 -2
  128. package/dist/components/content/Layout/LayoutContent.js +2 -6
  129. package/dist/components/content/Layout/LayoutContent.js.map +1 -1
  130. package/dist/components/content/Layout/LayoutContext.js +1 -1
  131. package/dist/components/content/Layout/LayoutFlex.js +2 -2
  132. package/dist/components/content/Layout/LayoutFlex.js.map +1 -1
  133. package/dist/components/content/Layout/LayoutFooter.js +2 -2
  134. package/dist/components/content/Layout/LayoutFooter.js.map +1 -1
  135. package/dist/components/content/Layout/LayoutGrid.d.ts +1 -2
  136. package/dist/components/content/Layout/LayoutGrid.js +2 -2
  137. package/dist/components/content/Layout/LayoutGrid.js.map +1 -1
  138. package/dist/components/content/Layout/LayoutHeader.js +2 -2
  139. package/dist/components/content/Layout/LayoutHeader.js.map +1 -1
  140. package/dist/components/content/Layout/LayoutPane.d.ts +1 -3
  141. package/dist/components/content/Layout/LayoutPane.js +2 -6
  142. package/dist/components/content/Layout/LayoutPane.js.map +1 -1
  143. package/dist/components/content/Layout/LayoutPanel.d.ts +1 -3
  144. package/dist/components/content/Layout/LayoutPanel.js +2 -6
  145. package/dist/components/content/Layout/LayoutPanel.js.map +1 -1
  146. package/dist/components/content/Layout/LayoutPanelHeader.d.ts +1 -2
  147. package/dist/components/content/Layout/LayoutPanelHeader.js +2 -4
  148. package/dist/components/content/Layout/LayoutPanelHeader.js.map +1 -1
  149. package/dist/components/content/Layout/LayoutToolbar.js +2 -2
  150. package/dist/components/content/Layout/LayoutToolbar.js.map +1 -1
  151. package/dist/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
  152. package/dist/components/content/Layout/index.js +1 -1
  153. package/dist/components/content/Layout/utils.js +1 -1
  154. package/dist/components/content/Paragraph.d.ts +1 -2
  155. package/dist/components/content/Paragraph.js +2 -3
  156. package/dist/components/content/Paragraph.js.map +1 -1
  157. package/dist/components/content/Placeholder/Placeholder.d.ts +1 -3
  158. package/dist/components/content/Placeholder/Placeholder.js +2 -6
  159. package/dist/components/content/Placeholder/Placeholder.js.map +1 -1
  160. package/dist/components/content/PrismCode/PrismCode.d.ts +1 -3
  161. package/dist/components/content/PrismCode/PrismCode.js +2 -3
  162. package/dist/components/content/PrismCode/PrismCode.js.map +1 -1
  163. package/dist/components/content/PrismCode/prismSetup.js +1 -1
  164. package/dist/components/content/PrismDiffCode/PrismDiffCode.d.ts +1 -3
  165. package/dist/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  166. package/dist/components/content/PrismDiffCode/PrismDiffCode.js.map +1 -1
  167. package/dist/components/content/Result/Result.d.ts +1 -2
  168. package/dist/components/content/Result/Result.js +2 -5
  169. package/dist/components/content/Result/Result.js.map +1 -1
  170. package/dist/components/content/Skeleton/Skeleton.d.ts +1 -2
  171. package/dist/components/content/Skeleton/Skeleton.js +1 -1
  172. package/dist/components/content/Skeleton/Skeleton.js.map +1 -1
  173. package/dist/components/content/Tag/Tag.d.ts +1 -2
  174. package/dist/components/content/Tag/Tag.js +2 -2
  175. package/dist/components/content/Tag/Tag.js.map +1 -1
  176. package/dist/components/content/Text.d.ts +128 -159
  177. package/dist/components/content/Text.js +2 -5
  178. package/dist/components/content/Text.js.map +1 -1
  179. package/dist/components/content/TextItem/TextItem.d.ts +1 -2
  180. package/dist/components/content/TextItem/TextItem.js +2 -5
  181. package/dist/components/content/TextItem/TextItem.js.map +1 -1
  182. package/dist/components/content/Title.d.ts +1 -2
  183. package/dist/components/content/Title.js +2 -5
  184. package/dist/components/content/Title.js.map +1 -1
  185. package/dist/components/content/highlightText.js +1 -1
  186. package/dist/components/content/highlightText.js.map +1 -1
  187. package/dist/components/content/use-auto-tooltip.d.ts +1 -1
  188. package/dist/components/content/use-auto-tooltip.js +1 -1
  189. package/dist/components/content/use-auto-tooltip.js.map +1 -1
  190. package/dist/components/fields/Checkbox/Checkbox.d.ts +1 -3
  191. package/dist/components/fields/Checkbox/Checkbox.js +2 -5
  192. package/dist/components/fields/Checkbox/Checkbox.js.map +1 -1
  193. package/dist/components/fields/Checkbox/CheckboxGroup.d.ts +1 -3
  194. package/dist/components/fields/Checkbox/CheckboxGroup.js +2 -4
  195. package/dist/components/fields/Checkbox/CheckboxGroup.js.map +1 -1
  196. package/dist/components/fields/Checkbox/context.js +1 -1
  197. package/dist/components/fields/ComboBox/ComboBox.d.ts +1 -3
  198. package/dist/components/fields/ComboBox/ComboBox.js +2 -4
  199. package/dist/components/fields/ComboBox/ComboBox.js.map +1 -1
  200. package/dist/components/fields/DatePicker/DateInput.d.ts +1 -3
  201. package/dist/components/fields/DatePicker/DateInput.js +2 -3
  202. package/dist/components/fields/DatePicker/DateInput.js.map +1 -1
  203. package/dist/components/fields/DatePicker/DateInputBase.js +2 -4
  204. package/dist/components/fields/DatePicker/DateInputBase.js.map +1 -1
  205. package/dist/components/fields/DatePicker/DatePicker.d.ts +1 -3
  206. package/dist/components/fields/DatePicker/DatePicker.js +2 -3
  207. package/dist/components/fields/DatePicker/DatePicker.js.map +1 -1
  208. package/dist/components/fields/DatePicker/DatePickerButton.js +2 -2
  209. package/dist/components/fields/DatePicker/DatePickerButton.js.map +1 -1
  210. package/dist/components/fields/DatePicker/DatePickerElement.js +2 -2
  211. package/dist/components/fields/DatePicker/DatePickerElement.js.map +1 -1
  212. package/dist/components/fields/DatePicker/DatePickerInput.js +2 -2
  213. package/dist/components/fields/DatePicker/DatePickerInput.js.map +1 -1
  214. package/dist/components/fields/DatePicker/DatePickerSegment.js +2 -2
  215. package/dist/components/fields/DatePicker/DatePickerSegment.js.map +1 -1
  216. package/dist/components/fields/DatePicker/DateRangePicker.d.ts +1 -3
  217. package/dist/components/fields/DatePicker/DateRangePicker.js +2 -4
  218. package/dist/components/fields/DatePicker/DateRangePicker.js.map +1 -1
  219. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.d.ts +1 -3
  220. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js +2 -4
  221. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js.map +1 -1
  222. package/dist/components/fields/DatePicker/TimeInput.d.ts +1 -3
  223. package/dist/components/fields/DatePicker/TimeInput.js +2 -3
  224. package/dist/components/fields/DatePicker/TimeInput.js.map +1 -1
  225. package/dist/components/fields/DatePicker/intl.js +1 -1
  226. package/dist/components/fields/DatePicker/parseDate.js +1 -1
  227. package/dist/components/fields/DatePicker/props.js +1 -1
  228. package/dist/components/fields/DatePicker/utils.js +1 -1
  229. package/dist/components/fields/FileInput/FileInput.d.ts +1 -3
  230. package/dist/components/fields/FileInput/FileInput.js +2 -4
  231. package/dist/components/fields/FileInput/FileInput.js.map +1 -1
  232. package/dist/components/fields/FilterListBox/FilterListBox.d.ts +1 -2
  233. package/dist/components/fields/FilterListBox/FilterListBox.js +5 -7
  234. package/dist/components/fields/FilterListBox/FilterListBox.js.map +1 -1
  235. package/dist/components/fields/FilterPicker/FilterPicker.d.ts +1 -3
  236. package/dist/components/fields/FilterPicker/FilterPicker.js +2 -5
  237. package/dist/components/fields/FilterPicker/FilterPicker.js.map +1 -1
  238. package/dist/components/fields/Input/Input.js +1 -1
  239. package/dist/components/fields/ListBox/ListBox.d.ts +1 -3
  240. package/dist/components/fields/ListBox/ListBox.js +2 -5
  241. package/dist/components/fields/ListBox/ListBox.js.map +1 -1
  242. package/dist/components/fields/NumberInput/NumberInput.js +2 -2
  243. package/dist/components/fields/NumberInput/NumberInput.js.map +1 -1
  244. package/dist/components/fields/NumberInput/StepButton.js +2 -2
  245. package/dist/components/fields/NumberInput/StepButton.js.map +1 -1
  246. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  247. package/dist/components/fields/Picker/Picker.d.ts +1 -3
  248. package/dist/components/fields/Picker/Picker.js +2 -5
  249. package/dist/components/fields/Picker/Picker.js.map +1 -1
  250. package/dist/components/fields/RadioGroup/Radio.d.ts +1 -2
  251. package/dist/components/fields/RadioGroup/Radio.js +2 -5
  252. package/dist/components/fields/RadioGroup/Radio.js.map +1 -1
  253. package/dist/components/fields/RadioGroup/RadioGroup.d.ts +1 -3
  254. package/dist/components/fields/RadioGroup/RadioGroup.js +2 -4
  255. package/dist/components/fields/RadioGroup/RadioGroup.js.map +1 -1
  256. package/dist/components/fields/RadioGroup/context.js +1 -1
  257. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  258. package/dist/components/fields/Select/Select.d.ts +834 -836
  259. package/dist/components/fields/Select/Select.js +2 -4
  260. package/dist/components/fields/Select/Select.js.map +1 -1
  261. package/dist/components/fields/Slider/Gradation.js +1 -1
  262. package/dist/components/fields/Slider/HueSlider.js +1 -1
  263. package/dist/components/fields/Slider/HueSlider.js.map +1 -1
  264. package/dist/components/fields/Slider/RangeSlider.js +1 -1
  265. package/dist/components/fields/Slider/Slider.d.ts +1 -3
  266. package/dist/components/fields/Slider/Slider.js +2 -3
  267. package/dist/components/fields/Slider/Slider.js.map +1 -1
  268. package/dist/components/fields/Slider/SliderBase.js +2 -4
  269. package/dist/components/fields/Slider/SliderBase.js.map +1 -1
  270. package/dist/components/fields/Slider/SliderThumb.js +1 -1
  271. package/dist/components/fields/Slider/SliderThumb.js.map +1 -1
  272. package/dist/components/fields/Slider/SliderTrack.js +1 -1
  273. package/dist/components/fields/Slider/SliderTrack.js.map +1 -1
  274. package/dist/components/fields/Slider/elements.js +2 -2
  275. package/dist/components/fields/Slider/elements.js.map +1 -1
  276. package/dist/components/fields/Slider/index.js +1 -1
  277. package/dist/components/fields/Slider/types.d.ts +1 -3
  278. package/dist/components/fields/Switch/Switch.d.ts +1 -3
  279. package/dist/components/fields/Switch/Switch.js +2 -4
  280. package/dist/components/fields/Switch/Switch.js.map +1 -1
  281. package/dist/components/fields/TextArea/TextArea.js +1 -1
  282. package/dist/components/fields/TextInput/TextInput.js +1 -1
  283. package/dist/components/fields/TextInput/TextInputBase.d.ts +1 -3
  284. package/dist/components/fields/TextInput/TextInputBase.js +3 -5
  285. package/dist/components/fields/TextInput/TextInputBase.js.map +1 -1
  286. package/dist/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  287. package/dist/components/form/FieldWrapper/FieldWrapper.js +2 -2
  288. package/dist/components/form/FieldWrapper/FieldWrapper.js.map +1 -1
  289. package/dist/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  290. package/dist/components/form/FieldWrapper/types.d.ts +1 -3
  291. package/dist/components/form/Form/Field.d.ts +1 -2
  292. package/dist/components/form/Form/Field.js +1 -1
  293. package/dist/components/form/Form/Field.js.map +1 -1
  294. package/dist/components/form/Form/Form.d.ts +1 -3
  295. package/dist/components/form/Form/Form.js +2 -5
  296. package/dist/components/form/Form/Form.js.map +1 -1
  297. package/dist/components/form/Form/ResetButton/ResetButton.js +1 -1
  298. package/dist/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  299. package/dist/components/form/Form/SubmitError.js +1 -1
  300. package/dist/components/form/Form/index.js +1 -1
  301. package/dist/components/form/Form/use-field/use-field-props.js +1 -1
  302. package/dist/components/form/Form/use-field/use-field.js +1 -1
  303. package/dist/components/form/Form/use-form.js +2 -2
  304. package/dist/components/form/Form/use-form.js.map +1 -1
  305. package/dist/components/form/Form/validation.js +1 -1
  306. package/dist/components/form/Label.d.ts +1 -3
  307. package/dist/components/form/Label.js +2 -5
  308. package/dist/components/form/Label.js.map +1 -1
  309. package/dist/components/form/wrapper.d.ts +1 -2
  310. package/dist/components/form/wrapper.js +1 -1
  311. package/dist/components/form/wrapper.js.map +1 -1
  312. package/dist/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  313. package/dist/components/helpers/IconSwitch/IconSwitch.js +2 -2
  314. package/dist/components/helpers/IconSwitch/IconSwitch.js.map +1 -1
  315. package/dist/components/layout/Flex.d.ts +1 -2
  316. package/dist/components/layout/Flex.js +2 -5
  317. package/dist/components/layout/Flex.js.map +1 -1
  318. package/dist/components/layout/Flow.d.ts +1 -2
  319. package/dist/components/layout/Flow.js +2 -5
  320. package/dist/components/layout/Flow.js.map +1 -1
  321. package/dist/components/layout/Grid.d.ts +1 -2
  322. package/dist/components/layout/Grid.js +2 -5
  323. package/dist/components/layout/Grid.js.map +1 -1
  324. package/dist/components/layout/Panel.d.ts +1 -3
  325. package/dist/components/layout/Panel.js +2 -3
  326. package/dist/components/layout/Panel.js.map +1 -1
  327. package/dist/components/layout/Prefix.d.ts +1 -2
  328. package/dist/components/layout/Prefix.js +2 -5
  329. package/dist/components/layout/Prefix.js.map +1 -1
  330. package/dist/components/layout/ResizablePanel.d.ts +1 -2
  331. package/dist/components/layout/ResizablePanel.js +2 -2
  332. package/dist/components/layout/ResizablePanel.js.map +1 -1
  333. package/dist/components/layout/Space.d.ts +1 -2
  334. package/dist/components/layout/Space.js +2 -5
  335. package/dist/components/layout/Space.js.map +1 -1
  336. package/dist/components/layout/Suffix.d.ts +1 -2
  337. package/dist/components/layout/Suffix.js +2 -5
  338. package/dist/components/layout/Suffix.js.map +1 -1
  339. package/dist/components/navigation/Tabs/DraggableTabList.js +1 -1
  340. package/dist/components/navigation/Tabs/EditableTitle.js +1 -1
  341. package/dist/components/navigation/Tabs/TabButton.js +1 -1
  342. package/dist/components/navigation/Tabs/TabDropIndicator.js +1 -1
  343. package/dist/components/navigation/Tabs/TabPanel.js +1 -1
  344. package/dist/components/navigation/Tabs/TabPanel.js.map +1 -1
  345. package/dist/components/navigation/Tabs/TabPicker.js +1 -1
  346. package/dist/components/navigation/Tabs/Tabs.js +2 -4
  347. package/dist/components/navigation/Tabs/Tabs.js.map +1 -1
  348. package/dist/components/navigation/Tabs/TabsAction.js +2 -2
  349. package/dist/components/navigation/Tabs/TabsAction.js.map +1 -1
  350. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  351. package/dist/components/navigation/Tabs/styled.js +2 -2
  352. package/dist/components/navigation/Tabs/styled.js.map +1 -1
  353. package/dist/components/navigation/Tabs/types.d.ts +1 -3
  354. package/dist/components/navigation/Tabs/types.js +1 -1
  355. package/dist/components/navigation/Tabs/types.js.map +1 -1
  356. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  357. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  358. package/dist/components/organisms/FileTabs/FileTabs.d.ts +1 -2
  359. package/dist/components/organisms/FileTabs/FileTabs.js +2 -2
  360. package/dist/components/organisms/FileTabs/FileTabs.js.map +1 -1
  361. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  362. package/dist/components/other/Calendar/Calendar.js +2 -2
  363. package/dist/components/other/Calendar/Calendar.js.map +1 -1
  364. package/dist/components/other/Calendar/CalendarCell.js +2 -2
  365. package/dist/components/other/Calendar/CalendarCell.js.map +1 -1
  366. package/dist/components/other/Calendar/CalendarGrid.js +2 -2
  367. package/dist/components/other/Calendar/CalendarGrid.js.map +1 -1
  368. package/dist/components/other/Calendar/RangeCalendar.js +2 -2
  369. package/dist/components/other/Calendar/RangeCalendar.js.map +1 -1
  370. package/dist/components/other/CloudLogo/CloudLogo.js +2 -2
  371. package/dist/components/other/CloudLogo/CloudLogo.js.map +1 -1
  372. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  373. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  374. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  375. package/dist/components/overlays/AlertDialog/types.d.ts +1 -1
  376. package/dist/components/overlays/Dialog/Dialog.d.ts +1 -3
  377. package/dist/components/overlays/Dialog/Dialog.js +2 -4
  378. package/dist/components/overlays/Dialog/Dialog.js.map +1 -1
  379. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  380. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  381. package/dist/components/overlays/Dialog/DialogTrigger.d.ts +1 -2
  382. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  383. package/dist/components/overlays/Dialog/DialogTrigger.js.map +1 -1
  384. package/dist/components/overlays/Dialog/context.js +1 -1
  385. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  386. package/dist/components/overlays/Modal/Modal.d.ts +3 -2
  387. package/dist/components/overlays/Modal/Modal.js +2 -2
  388. package/dist/components/overlays/Modal/Modal.js.map +1 -1
  389. package/dist/components/overlays/Modal/OpenTransition.js +1 -1
  390. package/dist/components/overlays/Modal/Overlay.d.ts +1 -0
  391. package/dist/components/overlays/Modal/Overlay.js +1 -1
  392. package/dist/components/overlays/Modal/Overlay.js.map +1 -1
  393. package/dist/components/overlays/Modal/Popover.d.ts +1 -1
  394. package/dist/components/overlays/Modal/Popover.js +2 -2
  395. package/dist/components/overlays/Modal/Popover.js.map +1 -1
  396. package/dist/components/overlays/Modal/Tray.d.ts +1 -1
  397. package/dist/components/overlays/Modal/Tray.js +2 -2
  398. package/dist/components/overlays/Modal/Tray.js.map +1 -1
  399. package/dist/components/overlays/Modal/Underlay.js +2 -2
  400. package/dist/components/overlays/Modal/Underlay.js.map +1 -1
  401. package/dist/components/overlays/Notifications/Notification.js +1 -1
  402. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  403. package/dist/components/overlays/Notifications/NotificationCard.js +2 -2
  404. package/dist/components/overlays/Notifications/NotificationCard.js.map +1 -1
  405. package/dist/components/overlays/Notifications/NotificationContext.d.ts +2 -0
  406. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  407. package/dist/components/overlays/Notifications/NotificationItem.js +2 -2
  408. package/dist/components/overlays/Notifications/NotificationItem.js.map +1 -1
  409. package/dist/components/overlays/Notifications/OverlayContainer.js +2 -2
  410. package/dist/components/overlays/Notifications/OverlayContainer.js.map +1 -1
  411. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  412. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +2 -2
  413. package/dist/components/overlays/Notifications/PersistentNotificationsList.js.map +1 -1
  414. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  415. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  416. package/dist/components/overlays/Notifications/index.js +1 -1
  417. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  418. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  419. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  420. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  421. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  422. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  423. package/dist/components/overlays/Toast/ToastItem.js +2 -2
  424. package/dist/components/overlays/Toast/ToastItem.js.map +1 -1
  425. package/dist/components/overlays/Toast/index.js +1 -1
  426. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  427. package/dist/components/overlays/Toast/useToast.js +2 -2
  428. package/dist/components/overlays/Tooltip/Tooltip.d.ts +1 -3
  429. package/dist/components/overlays/Tooltip/Tooltip.js +2 -4
  430. package/dist/components/overlays/Tooltip/Tooltip.js.map +1 -1
  431. package/dist/components/overlays/Tooltip/TooltipProvider.d.ts +1 -2
  432. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  433. package/dist/components/overlays/Tooltip/TooltipProvider.js.map +1 -1
  434. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  435. package/dist/components/overlays/Tooltip/context.js +1 -1
  436. package/dist/components/overlays/Tooltip/context.js.map +1 -1
  437. package/dist/components/portal/Portal.js +1 -1
  438. package/dist/components/portal/PortalProvider.d.ts +2 -0
  439. package/dist/components/portal/PortalProvider.js +1 -1
  440. package/dist/components/portal/index.d.ts +1 -0
  441. package/dist/components/portal/usePortal.js +1 -1
  442. package/dist/components/shared/InvalidIcon.js +1 -1
  443. package/dist/components/shared/ValidIcon.js +1 -1
  444. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +2 -2
  445. package/dist/components/status/LoadingAnimation/LoadingAnimation.js.map +1 -1
  446. package/dist/components/status/Spin/Cube.js +2 -2
  447. package/dist/components/status/Spin/Cube.js.map +1 -1
  448. package/dist/components/status/Spin/InternalSpinner.js +2 -2
  449. package/dist/components/status/Spin/InternalSpinner.js.map +1 -1
  450. package/dist/components/status/Spin/Spin.js +2 -2
  451. package/dist/components/status/Spin/Spin.js.map +1 -1
  452. package/dist/components/status/Spin/SpinsContainer.js +2 -2
  453. package/dist/components/status/Spin/SpinsContainer.js.map +1 -1
  454. package/dist/components/status/Spin/types.d.ts +1 -2
  455. package/dist/data/item-themes.d.ts +1 -1
  456. package/dist/data/item-themes.js +1 -1
  457. package/dist/data/item-themes.js.map +1 -1
  458. package/dist/data/themes.js +1 -1
  459. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  460. package/dist/icons/AdjustmentsIcon.js +1 -1
  461. package/dist/icons/AiIcon.js +1 -1
  462. package/dist/icons/AreaChartIcon.js +1 -1
  463. package/dist/icons/BackwardIcon.js +1 -1
  464. package/dist/icons/BarChartIcon.js +1 -1
  465. package/dist/icons/BellFilledIcon.js +1 -1
  466. package/dist/icons/BellIcon.js +1 -1
  467. package/dist/icons/BooleanIcon.js +1 -1
  468. package/dist/icons/CalendarEditIcon.js +1 -1
  469. package/dist/icons/CalendarIcon.js +1 -1
  470. package/dist/icons/CaretDownIcon.js +1 -1
  471. package/dist/icons/CaretUpIcon.js +1 -1
  472. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  473. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  474. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  475. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  476. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  477. package/dist/icons/ChartBarLineIcon.js +1 -1
  478. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  479. package/dist/icons/ChartBarStackedIcon.js +1 -1
  480. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  481. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  482. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  483. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  484. package/dist/icons/ChartBubbleIcon.js +1 -1
  485. package/dist/icons/ChartDonut2Icon.js +1 -1
  486. package/dist/icons/ChartFunnelIcon.js +1 -1
  487. package/dist/icons/ChartHeatmapIcon.js +1 -1
  488. package/dist/icons/ChartKPIIcon.js +1 -1
  489. package/dist/icons/ChartPie2Icon.js +1 -1
  490. package/dist/icons/ChartScatterIcon.js +1 -1
  491. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  492. package/dist/icons/CheckCircleIcon.js +1 -1
  493. package/dist/icons/CheckIcon.js +1 -1
  494. package/dist/icons/CircleFilledIcon.js +1 -1
  495. package/dist/icons/ClearIcon.js +1 -1
  496. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  497. package/dist/icons/CloseCircleIcon.js +1 -1
  498. package/dist/icons/CloseIcon.js +1 -1
  499. package/dist/icons/CodeIcon.js +1 -1
  500. package/dist/icons/ColumnTotalIcon.js +1 -1
  501. package/dist/icons/CopyIcon.js +1 -1
  502. package/dist/icons/CountIcon.js +1 -1
  503. package/dist/icons/CubeIcon.js +1 -1
  504. package/dist/icons/CubePauseIcon.js +1 -1
  505. package/dist/icons/CubePlayIcon.js +1 -1
  506. package/dist/icons/CurrencyDollarIcon.js +1 -1
  507. package/dist/icons/DangerIcon.js +1 -1
  508. package/dist/icons/DashboardIcon.js +1 -1
  509. package/dist/icons/DatabaseIcon.js +1 -1
  510. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  511. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  512. package/dist/icons/DirectionIcon.js +2 -2
  513. package/dist/icons/DirectionIcon.js.map +1 -1
  514. package/dist/icons/DonutIcon.js +1 -1
  515. package/dist/icons/DownIcon.js +1 -1
  516. package/dist/icons/EditIcon.js +1 -1
  517. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  518. package/dist/icons/ExclamationCircleIcon.js +1 -1
  519. package/dist/icons/ExclamationIcon.js +1 -1
  520. package/dist/icons/EyeIcon.js +1 -1
  521. package/dist/icons/EyeInvisibleIcon.js +1 -1
  522. package/dist/icons/FilterIcon.js +1 -1
  523. package/dist/icons/FolderFilledIcon.js +1 -1
  524. package/dist/icons/FolderIcon.js +1 -1
  525. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  526. package/dist/icons/FolderOpenIcon.js +1 -1
  527. package/dist/icons/ForwardIcon.js +1 -1
  528. package/dist/icons/HierarchyIcon.js +1 -1
  529. package/dist/icons/HierarchyOpenIcon.js +1 -1
  530. package/dist/icons/Icon.d.ts +1 -3
  531. package/dist/icons/Icon.js +2 -3
  532. package/dist/icons/Icon.js.map +1 -1
  533. package/dist/icons/InfoCircleIcon.js +1 -1
  534. package/dist/icons/InfoIcon.js +1 -1
  535. package/dist/icons/KeyIcon.js +1 -1
  536. package/dist/icons/LeftIcon.js +1 -1
  537. package/dist/icons/LineChartIcon.js +1 -1
  538. package/dist/icons/LoadingIcon.js +1 -1
  539. package/dist/icons/LockFilledIcon.js +1 -1
  540. package/dist/icons/LockIcon.js +1 -1
  541. package/dist/icons/MoreIcon.js +1 -1
  542. package/dist/icons/NotAllowedIcon.js +1 -1
  543. package/dist/icons/Number123Icon.js +1 -1
  544. package/dist/icons/NumberIcon.js +1 -1
  545. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  546. package/dist/icons/PauseCircleIcon.js +1 -1
  547. package/dist/icons/PauseIcon.js +1 -1
  548. package/dist/icons/PercentageIcon.js +1 -1
  549. package/dist/icons/PieChartIcon.js +1 -1
  550. package/dist/icons/PlayCircleIcon.js +1 -1
  551. package/dist/icons/PlayIcon.js +1 -1
  552. package/dist/icons/PlusIcon.js +1 -1
  553. package/dist/icons/ProgressBarIcon.js +1 -1
  554. package/dist/icons/ReloadIcon.js +1 -1
  555. package/dist/icons/ReportIcon.js +1 -1
  556. package/dist/icons/ReturnIcon.js +1 -1
  557. package/dist/icons/RightIcon.js +1 -1
  558. package/dist/icons/RowTotalsIcon.js +1 -1
  559. package/dist/icons/SchemeIcon.js +1 -1
  560. package/dist/icons/SearchIcon.js +1 -1
  561. package/dist/icons/SemanticQueryIcon.js +1 -1
  562. package/dist/icons/SettingsIcon.js +1 -1
  563. package/dist/icons/ShieldFilledIcon.js +1 -1
  564. package/dist/icons/ShieldIcon.js +1 -1
  565. package/dist/icons/SlashIcon.js +1 -1
  566. package/dist/icons/SparklesIcon.js +1 -1
  567. package/dist/icons/SqlIcon.js +1 -1
  568. package/dist/icons/StatsIcon.js +1 -1
  569. package/dist/icons/StopIcon.js +1 -1
  570. package/dist/icons/StringIcon.js +1 -1
  571. package/dist/icons/SubtotalsIcon.js +1 -1
  572. package/dist/icons/SwitchIcon.js +1 -1
  573. package/dist/icons/TableIcon.js +1 -1
  574. package/dist/icons/ThumbsDownIcon.js +1 -1
  575. package/dist/icons/ThumbsUpIcon.js +1 -1
  576. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  577. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  578. package/dist/icons/ThunderboltIcon.js +1 -1
  579. package/dist/icons/TimeIcon.js +1 -1
  580. package/dist/icons/TrashIcon.js +1 -1
  581. package/dist/icons/UnlockIcon.js +1 -1
  582. package/dist/icons/UpIcon.js +1 -1
  583. package/dist/icons/UserGroupIcon.js +1 -1
  584. package/dist/icons/UserIcon.js +1 -1
  585. package/dist/icons/UserLockIcon.js +1 -1
  586. package/dist/icons/ViewIcon.js +1 -1
  587. package/dist/icons/WarningFilledIcon.js +1 -1
  588. package/dist/icons/WarningIcon.js +1 -1
  589. package/dist/icons/wrap-icon.js +1 -1
  590. package/dist/index.d.ts +4 -35
  591. package/dist/index.js +5 -31
  592. package/dist/index.js.map +1 -1
  593. package/dist/provider.d.ts +1 -2
  594. package/dist/provider.js +1 -1
  595. package/dist/provider.js.map +1 -1
  596. package/dist/providers/TrackingProvider.js +1 -1
  597. package/dist/providers/navigationAdapter.default.js +1 -1
  598. package/dist/shared/form.d.ts +1 -3
  599. package/dist/tokens/base.d.ts +1 -1
  600. package/dist/tokens/base.js +1 -1
  601. package/dist/tokens/base.js.map +1 -1
  602. package/dist/tokens/colors.d.ts +1 -1
  603. package/dist/tokens/colors.js +1 -1
  604. package/dist/tokens/colors.js.map +1 -1
  605. package/dist/tokens/index.d.ts +1 -2
  606. package/dist/tokens/index.js +2 -3
  607. package/dist/tokens/index.js.map +1 -1
  608. package/dist/tokens/layout.d.ts +1 -1
  609. package/dist/tokens/layout.js +1 -1
  610. package/dist/tokens/layout.js.map +1 -1
  611. package/dist/tokens/shadows.d.ts +1 -1
  612. package/dist/tokens/shadows.js +1 -1
  613. package/dist/tokens/shadows.js.map +1 -1
  614. package/dist/tokens/sizes.d.ts +1 -1
  615. package/dist/tokens/sizes.js +1 -1
  616. package/dist/tokens/sizes.js.map +1 -1
  617. package/dist/tokens/spacing.d.ts +1 -1
  618. package/dist/tokens/spacing.js +1 -1
  619. package/dist/tokens/spacing.js.map +1 -1
  620. package/dist/utils/ResizeSensor.js +1 -1
  621. package/dist/utils/index.d.ts +1 -2
  622. package/dist/utils/is-dev-env.js +5 -10
  623. package/dist/utils/is-dev-env.js.map +1 -1
  624. package/dist/utils/modules.js +1 -1
  625. package/dist/utils/promise.js +1 -1
  626. package/dist/utils/raf.js +1 -1
  627. package/dist/utils/random.js +1 -1
  628. package/dist/utils/range.js +1 -1
  629. package/dist/utils/react/RenderCache.js +1 -1
  630. package/dist/utils/react/Slots.js +1 -1
  631. package/dist/utils/react/chain.js +1 -1
  632. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  633. package/dist/utils/react/index.d.ts +3 -3
  634. package/dist/utils/react/index.js +20 -0
  635. package/dist/utils/react/interactions.js +1 -1
  636. package/dist/utils/react/isTextOnly.js +1 -1
  637. package/dist/utils/react/mapProps.js +1 -1
  638. package/dist/utils/react/mergeProps.d.ts +1 -2
  639. package/dist/utils/react/mergeProps.js +2 -2
  640. package/dist/utils/react/mergeProps.js.map +1 -1
  641. package/dist/utils/react/nullableValue.d.ts +1 -2
  642. package/dist/utils/react/nullableValue.js +1 -1
  643. package/dist/utils/react/nullableValue.js.map +1 -1
  644. package/dist/utils/react/resolveIcon.d.ts +1 -2
  645. package/dist/utils/react/resolveIcon.js +1 -1
  646. package/dist/utils/react/resolveIcon.js.map +1 -1
  647. package/dist/utils/react/sharedStore.js +1 -1
  648. package/dist/utils/react/useCombinedRefs.js +1 -1
  649. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  650. package/dist/utils/react/useEventBus.js +1 -1
  651. package/dist/utils/react/useId.js +1 -1
  652. package/dist/utils/react/useIsDarwin.js +1 -1
  653. package/dist/utils/react/useKeySymbols.js +1 -1
  654. package/dist/utils/react/useLayoutEffect.js +1 -1
  655. package/dist/utils/react/useLocalStorage.js +1 -1
  656. package/dist/utils/react/useMergeStyles.d.ts +1 -2
  657. package/dist/utils/react/useMergeStyles.js +2 -2
  658. package/dist/utils/react/useMergeStyles.js.map +1 -1
  659. package/dist/utils/react/useQaProps.js +1 -1
  660. package/dist/utils/react/useViewportSize.js +1 -1
  661. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  662. package/dist/utils/tree.js +1 -1
  663. package/dist/utils/warnings.js +1 -1
  664. package/dist/version.js +2 -2
  665. package/package.json +4 -21
  666. package/dist/_virtual/_rolldown/runtime.js +0 -8
  667. package/dist/chunks/cacheKey.js +0 -71
  668. package/dist/chunks/cacheKey.js.map +0 -1
  669. package/dist/chunks/definitions.js +0 -261
  670. package/dist/chunks/definitions.js.map +0 -1
  671. package/dist/chunks/renderChunk.js +0 -68
  672. package/dist/chunks/renderChunk.js.map +0 -1
  673. package/dist/config.js +0 -232
  674. package/dist/config.js.map +0 -1
  675. package/dist/css-writer.d.ts +0 -46
  676. package/dist/css-writer.js +0 -75
  677. package/dist/css-writer.js.map +0 -1
  678. package/dist/extractor.d.ts +0 -25
  679. package/dist/extractor.js +0 -151
  680. package/dist/extractor.js.map +0 -1
  681. package/dist/injector/injector.js +0 -401
  682. package/dist/injector/injector.js.map +0 -1
  683. package/dist/injector/sheet-manager.js +0 -715
  684. package/dist/injector/sheet-manager.js.map +0 -1
  685. package/dist/injector/types.d.ts +0 -19
  686. package/dist/keyframes/index.js +0 -157
  687. package/dist/keyframes/index.js.map +0 -1
  688. package/dist/parser/classify.js +0 -320
  689. package/dist/parser/classify.js.map +0 -1
  690. package/dist/parser/const.js +0 -34
  691. package/dist/parser/const.js.map +0 -1
  692. package/dist/parser/lru.js +0 -110
  693. package/dist/parser/lru.js.map +0 -1
  694. package/dist/parser/parser.js +0 -117
  695. package/dist/parser/parser.js.map +0 -1
  696. package/dist/parser/tokenizer.js +0 -70
  697. package/dist/parser/tokenizer.js.map +0 -1
  698. package/dist/parser/types.d.ts +0 -38
  699. package/dist/parser/types.js +0 -47
  700. package/dist/parser/types.js.map +0 -1
  701. package/dist/pipeline/conditions.js +0 -378
  702. package/dist/pipeline/conditions.js.map +0 -1
  703. package/dist/pipeline/exclusive.js +0 -232
  704. package/dist/pipeline/exclusive.js.map +0 -1
  705. package/dist/pipeline/index.js +0 -633
  706. package/dist/pipeline/index.js.map +0 -1
  707. package/dist/pipeline/materialize.js +0 -822
  708. package/dist/pipeline/materialize.js.map +0 -1
  709. package/dist/pipeline/parseStateKey.js +0 -422
  710. package/dist/pipeline/parseStateKey.js.map +0 -1
  711. package/dist/pipeline/simplify.js +0 -558
  712. package/dist/pipeline/simplify.js.map +0 -1
  713. package/dist/plugins/okhsl-plugin.js +0 -346
  714. package/dist/plugins/okhsl-plugin.js.map +0 -1
  715. package/dist/plugins/types.d.ts +0 -52
  716. package/dist/properties/index.js +0 -142
  717. package/dist/properties/index.js.map +0 -1
  718. package/dist/states/index.js +0 -162
  719. package/dist/states/index.js.map +0 -1
  720. package/dist/styles/align.js +0 -15
  721. package/dist/styles/align.js.map +0 -1
  722. package/dist/styles/border.js +0 -115
  723. package/dist/styles/border.js.map +0 -1
  724. package/dist/styles/color.js +0 -24
  725. package/dist/styles/color.js.map +0 -1
  726. package/dist/styles/createStyle.js +0 -78
  727. package/dist/styles/createStyle.js.map +0 -1
  728. package/dist/styles/dimension.js +0 -100
  729. package/dist/styles/dimension.js.map +0 -1
  730. package/dist/styles/display.js +0 -68
  731. package/dist/styles/display.js.map +0 -1
  732. package/dist/styles/fade.js +0 -58
  733. package/dist/styles/fade.js.map +0 -1
  734. package/dist/styles/fill.js +0 -52
  735. package/dist/styles/fill.js.map +0 -1
  736. package/dist/styles/flow.js +0 -13
  737. package/dist/styles/flow.js.map +0 -1
  738. package/dist/styles/gap.js +0 -37
  739. package/dist/styles/gap.js.map +0 -1
  740. package/dist/styles/height.js +0 -21
  741. package/dist/styles/height.js.map +0 -1
  742. package/dist/styles/index.js +0 -10
  743. package/dist/styles/index.js.map +0 -1
  744. package/dist/styles/inset.js +0 -143
  745. package/dist/styles/inset.js.map +0 -1
  746. package/dist/styles/justify.js +0 -15
  747. package/dist/styles/justify.js.map +0 -1
  748. package/dist/styles/margin.js +0 -97
  749. package/dist/styles/margin.js.map +0 -1
  750. package/dist/styles/outline.js +0 -66
  751. package/dist/styles/outline.js.map +0 -1
  752. package/dist/styles/padding.js +0 -97
  753. package/dist/styles/padding.js.map +0 -1
  754. package/dist/styles/predefined.js +0 -233
  755. package/dist/styles/predefined.js.map +0 -1
  756. package/dist/styles/preset.js +0 -126
  757. package/dist/styles/preset.js.map +0 -1
  758. package/dist/styles/radius.js +0 -52
  759. package/dist/styles/radius.js.map +0 -1
  760. package/dist/styles/scrollbar.js +0 -109
  761. package/dist/styles/scrollbar.js.map +0 -1
  762. package/dist/styles/shadow.js +0 -28
  763. package/dist/styles/shadow.js.map +0 -1
  764. package/dist/styles/styledScrollbar.js +0 -39
  765. package/dist/styles/styledScrollbar.js.map +0 -1
  766. package/dist/styles/transition.js +0 -139
  767. package/dist/styles/transition.js.map +0 -1
  768. package/dist/styles/types.d.ts +0 -495
  769. package/dist/styles/width.js +0 -21
  770. package/dist/styles/width.js.map +0 -1
  771. package/dist/tasty/chunks/cacheKey.js +0 -71
  772. package/dist/tasty/chunks/cacheKey.js.map +0 -1
  773. package/dist/tasty/chunks/definitions.d.ts +0 -38
  774. package/dist/tasty/chunks/definitions.js +0 -261
  775. package/dist/tasty/chunks/definitions.js.map +0 -1
  776. package/dist/tasty/chunks/renderChunk.js +0 -68
  777. package/dist/tasty/chunks/renderChunk.js.map +0 -1
  778. package/dist/tasty/config.d.ts +0 -283
  779. package/dist/tasty/config.js +0 -401
  780. package/dist/tasty/config.js.map +0 -1
  781. package/dist/tasty/debug.d.ts +0 -200
  782. package/dist/tasty/debug.js +0 -734
  783. package/dist/tasty/debug.js.map +0 -1
  784. package/dist/tasty/hooks/useGlobalStyles.d.ts +0 -28
  785. package/dist/tasty/hooks/useGlobalStyles.js +0 -57
  786. package/dist/tasty/hooks/useGlobalStyles.js.map +0 -1
  787. package/dist/tasty/hooks/useKeyframes.d.ts +0 -57
  788. package/dist/tasty/hooks/useKeyframes.js +0 -55
  789. package/dist/tasty/hooks/useKeyframes.js.map +0 -1
  790. package/dist/tasty/hooks/useProperty.d.ts +0 -80
  791. package/dist/tasty/hooks/useProperty.js +0 -92
  792. package/dist/tasty/hooks/useProperty.js.map +0 -1
  793. package/dist/tasty/hooks/useRawCSS.d.ts +0 -54
  794. package/dist/tasty/hooks/useRawCSS.js +0 -29
  795. package/dist/tasty/hooks/useRawCSS.js.map +0 -1
  796. package/dist/tasty/hooks/useStyles.d.ts +0 -41
  797. package/dist/tasty/hooks/useStyles.js +0 -170
  798. package/dist/tasty/hooks/useStyles.js.map +0 -1
  799. package/dist/tasty/index.d.ts +0 -35
  800. package/dist/tasty/injector/index.d.ts +0 -158
  801. package/dist/tasty/injector/index.js +0 -155
  802. package/dist/tasty/injector/index.js.map +0 -1
  803. package/dist/tasty/injector/injector.d.ts +0 -137
  804. package/dist/tasty/injector/injector.js +0 -401
  805. package/dist/tasty/injector/injector.js.map +0 -1
  806. package/dist/tasty/injector/sheet-manager.d.ts +0 -128
  807. package/dist/tasty/injector/sheet-manager.js +0 -715
  808. package/dist/tasty/injector/sheet-manager.js.map +0 -1
  809. package/dist/tasty/injector/types.d.ts +0 -136
  810. package/dist/tasty/keyframes/index.js +0 -207
  811. package/dist/tasty/keyframes/index.js.map +0 -1
  812. package/dist/tasty/parser/classify.js +0 -320
  813. package/dist/tasty/parser/classify.js.map +0 -1
  814. package/dist/tasty/parser/const.js +0 -34
  815. package/dist/tasty/parser/const.js.map +0 -1
  816. package/dist/tasty/parser/lru.js +0 -110
  817. package/dist/tasty/parser/lru.js.map +0 -1
  818. package/dist/tasty/parser/parser.d.ts +0 -26
  819. package/dist/tasty/parser/parser.js +0 -117
  820. package/dist/tasty/parser/parser.js.map +0 -1
  821. package/dist/tasty/parser/tokenizer.js +0 -70
  822. package/dist/tasty/parser/tokenizer.js.map +0 -1
  823. package/dist/tasty/parser/types.d.ts +0 -47
  824. package/dist/tasty/parser/types.js +0 -47
  825. package/dist/tasty/parser/types.js.map +0 -1
  826. package/dist/tasty/pipeline/conditions.js +0 -378
  827. package/dist/tasty/pipeline/conditions.js.map +0 -1
  828. package/dist/tasty/pipeline/exclusive.js +0 -232
  829. package/dist/tasty/pipeline/exclusive.js.map +0 -1
  830. package/dist/tasty/pipeline/index.d.ts +0 -52
  831. package/dist/tasty/pipeline/index.js +0 -639
  832. package/dist/tasty/pipeline/index.js.map +0 -1
  833. package/dist/tasty/pipeline/materialize.js +0 -822
  834. package/dist/tasty/pipeline/materialize.js.map +0 -1
  835. package/dist/tasty/pipeline/parseStateKey.js +0 -422
  836. package/dist/tasty/pipeline/parseStateKey.js.map +0 -1
  837. package/dist/tasty/pipeline/simplify.js +0 -558
  838. package/dist/tasty/pipeline/simplify.js.map +0 -1
  839. package/dist/tasty/plugins/okhsl-plugin.d.ts +0 -36
  840. package/dist/tasty/plugins/okhsl-plugin.js +0 -372
  841. package/dist/tasty/plugins/okhsl-plugin.js.map +0 -1
  842. package/dist/tasty/plugins/types.d.ts +0 -72
  843. package/dist/tasty/properties/index.js +0 -159
  844. package/dist/tasty/properties/index.js.map +0 -1
  845. package/dist/tasty/states/index.d.ts +0 -44
  846. package/dist/tasty/states/index.js +0 -390
  847. package/dist/tasty/states/index.js.map +0 -1
  848. package/dist/tasty/static/index.d.ts +0 -6
  849. package/dist/tasty/static/index.js +0 -6
  850. package/dist/tasty/static/tastyStatic.d.ts +0 -47
  851. package/dist/tasty/static/tastyStatic.js +0 -32
  852. package/dist/tasty/static/tastyStatic.js.map +0 -1
  853. package/dist/tasty/static/types.d.ts +0 -50
  854. package/dist/tasty/static/types.js +0 -25
  855. package/dist/tasty/static/types.js.map +0 -1
  856. package/dist/tasty/styles/align.d.ts +0 -16
  857. package/dist/tasty/styles/align.js +0 -15
  858. package/dist/tasty/styles/align.js.map +0 -1
  859. package/dist/tasty/styles/border.d.ts +0 -26
  860. package/dist/tasty/styles/border.js +0 -115
  861. package/dist/tasty/styles/border.js.map +0 -1
  862. package/dist/tasty/styles/color.d.ts +0 -15
  863. package/dist/tasty/styles/color.js +0 -24
  864. package/dist/tasty/styles/color.js.map +0 -1
  865. package/dist/tasty/styles/createStyle.js +0 -78
  866. package/dist/tasty/styles/createStyle.js.map +0 -1
  867. package/dist/tasty/styles/dimension.js +0 -100
  868. package/dist/tasty/styles/dimension.js.map +0 -1
  869. package/dist/tasty/styles/display.d.ts +0 -38
  870. package/dist/tasty/styles/display.js +0 -68
  871. package/dist/tasty/styles/display.js.map +0 -1
  872. package/dist/tasty/styles/fade.d.ts +0 -16
  873. package/dist/tasty/styles/fade.js +0 -58
  874. package/dist/tasty/styles/fade.js.map +0 -1
  875. package/dist/tasty/styles/fill.d.ts +0 -45
  876. package/dist/tasty/styles/fill.js +0 -52
  877. package/dist/tasty/styles/fill.js.map +0 -1
  878. package/dist/tasty/styles/flow.d.ts +0 -17
  879. package/dist/tasty/styles/flow.js +0 -13
  880. package/dist/tasty/styles/flow.js.map +0 -1
  881. package/dist/tasty/styles/gap.d.ts +0 -32
  882. package/dist/tasty/styles/gap.js +0 -37
  883. package/dist/tasty/styles/gap.js.map +0 -1
  884. package/dist/tasty/styles/height.d.ts +0 -18
  885. package/dist/tasty/styles/height.js +0 -21
  886. package/dist/tasty/styles/height.js.map +0 -1
  887. package/dist/tasty/styles/index.d.ts +0 -3
  888. package/dist/tasty/styles/index.js +0 -10
  889. package/dist/tasty/styles/index.js.map +0 -1
  890. package/dist/tasty/styles/inset.d.ts +0 -51
  891. package/dist/tasty/styles/inset.js +0 -143
  892. package/dist/tasty/styles/inset.js.map +0 -1
  893. package/dist/tasty/styles/justify.d.ts +0 -16
  894. package/dist/tasty/styles/justify.js +0 -15
  895. package/dist/tasty/styles/justify.js.map +0 -1
  896. package/dist/tasty/styles/list.d.ts +0 -17
  897. package/dist/tasty/styles/list.js +0 -99
  898. package/dist/tasty/styles/list.js.map +0 -1
  899. package/dist/tasty/styles/margin.d.ts +0 -29
  900. package/dist/tasty/styles/margin.js +0 -97
  901. package/dist/tasty/styles/margin.js.map +0 -1
  902. package/dist/tasty/styles/outline.d.ts +0 -30
  903. package/dist/tasty/styles/outline.js +0 -66
  904. package/dist/tasty/styles/outline.js.map +0 -1
  905. package/dist/tasty/styles/padding.d.ts +0 -29
  906. package/dist/tasty/styles/padding.js +0 -97
  907. package/dist/tasty/styles/padding.js.map +0 -1
  908. package/dist/tasty/styles/predefined.d.ts +0 -74
  909. package/dist/tasty/styles/predefined.js +0 -242
  910. package/dist/tasty/styles/predefined.js.map +0 -1
  911. package/dist/tasty/styles/preset.d.ts +0 -48
  912. package/dist/tasty/styles/preset.js +0 -126
  913. package/dist/tasty/styles/preset.js.map +0 -1
  914. package/dist/tasty/styles/radius.d.ts +0 -15
  915. package/dist/tasty/styles/radius.js +0 -52
  916. package/dist/tasty/styles/radius.js.map +0 -1
  917. package/dist/tasty/styles/scrollbar.d.ts +0 -22
  918. package/dist/tasty/styles/scrollbar.js +0 -109
  919. package/dist/tasty/styles/scrollbar.js.map +0 -1
  920. package/dist/tasty/styles/shadow.d.ts +0 -15
  921. package/dist/tasty/styles/shadow.js +0 -28
  922. package/dist/tasty/styles/shadow.js.map +0 -1
  923. package/dist/tasty/styles/styledScrollbar.d.ts +0 -48
  924. package/dist/tasty/styles/styledScrollbar.js +0 -39
  925. package/dist/tasty/styles/styledScrollbar.js.map +0 -1
  926. package/dist/tasty/styles/transition.d.ts +0 -15
  927. package/dist/tasty/styles/transition.js +0 -139
  928. package/dist/tasty/styles/transition.js.map +0 -1
  929. package/dist/tasty/styles/types.d.ts +0 -499
  930. package/dist/tasty/styles/width.d.ts +0 -18
  931. package/dist/tasty/styles/width.js +0 -21
  932. package/dist/tasty/styles/width.js.map +0 -1
  933. package/dist/tasty/tasty.d.ts +0 -936
  934. package/dist/tasty/tasty.js +0 -191
  935. package/dist/tasty/tasty.js.map +0 -1
  936. package/dist/tasty/types.d.ts +0 -192
  937. package/dist/tasty/utils/cache-wrapper.js +0 -25
  938. package/dist/tasty/utils/cache-wrapper.js.map +0 -1
  939. package/dist/tasty/utils/case-converter.js +0 -9
  940. package/dist/tasty/utils/case-converter.js.map +0 -1
  941. package/dist/tasty/utils/colors.d.ts +0 -6
  942. package/dist/tasty/utils/colors.js +0 -10
  943. package/dist/tasty/utils/colors.js.map +0 -1
  944. package/dist/tasty/utils/dotize.d.ts +0 -27
  945. package/dist/tasty/utils/dotize.js +0 -123
  946. package/dist/tasty/utils/dotize.js.map +0 -1
  947. package/dist/tasty/utils/filter-base-props.d.ts +0 -16
  948. package/dist/tasty/utils/filter-base-props.js +0 -46
  949. package/dist/tasty/utils/filter-base-props.js.map +0 -1
  950. package/dist/tasty/utils/get-display-name.d.ts +0 -8
  951. package/dist/tasty/utils/get-display-name.js +0 -11
  952. package/dist/tasty/utils/get-display-name.js.map +0 -1
  953. package/dist/tasty/utils/hsl-to-rgb.js +0 -39
  954. package/dist/tasty/utils/hsl-to-rgb.js.map +0 -1
  955. package/dist/tasty/utils/is-dev-env.js +0 -20
  956. package/dist/tasty/utils/is-dev-env.js.map +0 -1
  957. package/dist/tasty/utils/merge-styles.d.ts +0 -8
  958. package/dist/tasty/utils/merge-styles.js +0 -147
  959. package/dist/tasty/utils/merge-styles.js.map +0 -1
  960. package/dist/tasty/utils/mod-attrs.d.ts +0 -9
  961. package/dist/tasty/utils/mod-attrs.js +0 -22
  962. package/dist/tasty/utils/mod-attrs.js.map +0 -1
  963. package/dist/tasty/utils/okhsl-to-rgb.js +0 -297
  964. package/dist/tasty/utils/okhsl-to-rgb.js.map +0 -1
  965. package/dist/tasty/utils/process-tokens.d.ts +0 -32
  966. package/dist/tasty/utils/process-tokens.js +0 -172
  967. package/dist/tasty/utils/process-tokens.js.map +0 -1
  968. package/dist/tasty/utils/resolve-recipes.d.ts +0 -18
  969. package/dist/tasty/utils/resolve-recipes.js +0 -144
  970. package/dist/tasty/utils/resolve-recipes.js.map +0 -1
  971. package/dist/tasty/utils/string.js +0 -9
  972. package/dist/tasty/utils/string.js.map +0 -1
  973. package/dist/tasty/utils/styles.d.ts +0 -204
  974. package/dist/tasty/utils/styles.js +0 -577
  975. package/dist/tasty/utils/styles.js.map +0 -1
  976. package/dist/tasty/utils/typography.d.ts +0 -37
  977. package/dist/tasty/utils/typography.js +0 -54
  978. package/dist/tasty/utils/typography.js.map +0 -1
  979. package/dist/tasty/utils/warnings.d.ts +0 -17
  980. package/dist/tasty/utils/warnings.js +0 -17
  981. package/dist/tasty/utils/warnings.js.map +0 -1
  982. package/dist/tasty/zero/babel.d.ts +0 -111
  983. package/dist/tasty/zero/babel.js +0 -283
  984. package/dist/tasty/zero/babel.js.map +0 -1
  985. package/dist/tasty/zero/index.d.ts +0 -4
  986. package/dist/tasty/zero/index.js +0 -5
  987. package/dist/tasty/zero/next.d.ts +0 -61
  988. package/dist/tasty/zero/next.js +0 -79
  989. package/dist/tasty/zero/next.js.map +0 -1
  990. package/dist/tasty.config.ts +0 -311
  991. package/dist/tokens/typography.d.ts +0 -35
  992. package/dist/tokens/typography.js +0 -238
  993. package/dist/tokens/typography.js.map +0 -1
  994. package/dist/utils/cache-wrapper.js +0 -25
  995. package/dist/utils/cache-wrapper.js.map +0 -1
  996. package/dist/utils/case-converter.js +0 -9
  997. package/dist/utils/case-converter.js.map +0 -1
  998. package/dist/utils/hsl-to-rgb.js +0 -39
  999. package/dist/utils/hsl-to-rgb.js.map +0 -1
  1000. package/dist/utils/merge-styles.js +0 -147
  1001. package/dist/utils/merge-styles.js.map +0 -1
  1002. package/dist/utils/okhsl-to-rgb.js +0 -297
  1003. package/dist/utils/okhsl-to-rgb.js.map +0 -1
  1004. package/dist/utils/process-tokens.js +0 -29
  1005. package/dist/utils/process-tokens.js.map +0 -1
  1006. package/dist/utils/resolve-recipes.js +0 -144
  1007. package/dist/utils/resolve-recipes.js.map +0 -1
  1008. package/dist/utils/string.js +0 -9
  1009. package/dist/utils/string.js.map +0 -1
  1010. package/dist/utils/styles.d.ts +0 -23
  1011. package/dist/utils/styles.js +0 -338
  1012. package/dist/utils/styles.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ListBox.js","names":["Item","useHover","mergeProps","useFocus","BaseSection","CollectionItem"],"sources":["../../../../src/components/fields/ListBox/ListBox.tsx"],"sourcesContent":["import { useHover } from '@react-aria/interactions';\nimport { IconMinus } from '@tabler/icons-react';\nimport { useVirtualizer } from '@tanstack/react-virtual';\nimport {\n CSSProperties,\n ForwardedRef,\n forwardRef,\n MutableRefObject,\n ReactElement,\n ReactNode,\n RefObject,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport {\n AriaListBoxProps,\n useKeyboard,\n useListBox,\n useListBoxSection,\n useOption,\n} from 'react-aria';\nimport { Section as BaseSection, useListState } from 'react-stately';\n\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CheckIcon } from '../../../icons';\nimport { Icon } from '../../../icons/index';\nimport { useProviderProps } from '../../../provider';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n COLOR_STYLES,\n extractStyles,\n mergeStyles,\n OUTER_STYLES,\n Styles,\n tasty,\n} from '../../../tasty';\nimport { SIZE_NAME_TO_KEY, SIZES } from '../../../tokens';\nimport { mergeProps, useCombinedRefs } from '../../../utils/react';\nimport { useFocus } from '../../../utils/react/interactions';\n// Import Menu styled components for header and footer\nimport {\n StyledDivider,\n StyledFooter,\n StyledHeader,\n StyledSectionHeading,\n} from '../../actions/Menu/styled';\nimport {\n CollectionItem,\n CubeCollectionItemProps,\n filterCollectionItemProps,\n} from '../../CollectionItem';\nimport { Item } from '../../content/Item/Item';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport type { CollectionBase, Key } from '@react-types/shared';\nimport type { FieldBaseProps } from '../../../shared';\n\ntype FirstArg<F> = F extends (...args: infer A) => any ? A[0] : never;\n\nconst ListBoxWrapperElement = tasty({\n qa: 'ListBox',\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: 'max-content max-content max-content 1sf max-content',\n flow: 'column',\n gap: 0,\n position: 'relative',\n radius: {\n '': '1cr',\n '[data-shape=\"popover\"]': '(1cr - 1bw)',\n '[data-shape=\"plain\"]': '0',\n },\n color: '#dark-02',\n transition: 'theme',\n outline: {\n '': '#purple-03.0',\n 'invalid & focused': '#danger.50',\n focused: '#purple-03',\n },\n border: {\n '': true,\n focused: '#primary-text',\n valid: '#success-text.50',\n invalid: '#danger-text.50',\n disabled: true,\n '[data-shape=\"plain\"] | [data-shape=\"popover\"] | searchable': false,\n },\n },\n});\n\nconst ListElement = tasty({\n as: 'ul',\n styles: {\n display: 'block',\n padding: 0,\n listStyle: 'none',\n boxSizing: 'border-box',\n margin: {\n '': '.5x .5x 0 .5x',\n '[data-shape=\"plain\"]': '0',\n },\n height: 'max-content',\n },\n});\n\n// NEW: dedicated scroll container for ListBox\nconst ListBoxScrollElement = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: '1sf',\n overflow: 'auto',\n scrollbar: 'styled',\n },\n});\n\n// Create an extended Item for ListBox options with 'all' modifier support\nconst ListBoxItem = tasty(Item, {\n as: 'li',\n disableActionsFocus: true,\n styles: {\n margin: {\n '': '0 0 1bw 0',\n ':last-of-type': '0',\n all: '.5x',\n },\n },\n});\n\nconst SectionWrapperElement = tasty({\n as: 'li',\n styles: {\n display: 'block',\n padding: {\n '': 0,\n ':last-of-type': '0 0 .5x 0',\n },\n },\n});\n\nconst SectionListElement = tasty({\n qa: 'ListBoxSectionList',\n as: 'ul',\n styles: {\n display: 'flex',\n gap: '0',\n flow: 'column',\n margin: '0',\n padding: '0',\n listStyle: 'none',\n },\n});\n\n// Checkbox component for multiple selection options\nconst ListBoxCheckbox = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n placeItems: 'center',\n radius: '.5r',\n width: '(2x - 2bw)',\n height: '(2x - 2bw)',\n flexShrink: 0,\n transition: 'theme',\n opacity: {\n '': 0,\n 'selected | indeterminate | hovered | focused': 1,\n },\n fill: {\n '': '#white',\n 'selected | indeterminate': '#primary-text',\n 'invalid & !(selected | indeterminate)': '#white',\n 'invalid & (selected | indeterminate)': '#danger',\n disabled: '#dark.12',\n },\n color: {\n '': '#white',\n 'disabled & !selected': '#clear',\n },\n border: {\n '': '#dark.30',\n invalid: '#danger',\n 'disabled | ((selected | indeterminate) & !invalid)': '#clear',\n },\n },\n});\n\nconst ListBoxCheckboxWrapper = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n placeItems: 'center',\n placeContent: 'center',\n cursor: '$pointer',\n placeSelf: 'stretch',\n },\n});\n\nexport interface CubeListBoxProps<T>\n extends AriaListBoxProps<T>,\n CollectionBase<T>,\n FieldBaseProps,\n BasePropsWithoutChildren {\n /** Custom styles for the list container */\n listStyles?: Styles;\n /** Custom styles for individual options */\n optionStyles?: Styles;\n /** Custom styles for section containers */\n sectionStyles?: Styles;\n /** Custom styles for section headings */\n headingStyles?: Styles;\n /** Whether the ListBox is disabled */\n isDisabled?: boolean;\n /** The selected key in controlled single selection mode */\n selectedKey?: Key | null;\n /** The selected keys in controlled multiple selection mode. Use \"all\" to select all items or an array of keys */\n selectedKeys?: 'all' | Key[];\n /** The default selected key in uncontrolled single selection mode */\n defaultSelectedKey?: Key | null;\n /** The default selected keys in uncontrolled multiple selection mode. Use \"all\" to select all items or an array of keys */\n defaultSelectedKeys?: 'all' | Key[];\n /** Callback fired when selection changes */\n onSelectionChange?: (key: Key | null | 'all' | Key[]) => void;\n /** The selection mode of the ListBox */\n selectionMode?: 'single' | 'multiple';\n /** Ref for accessing the list DOM element */\n listRef?: RefObject<HTMLUListElement | null>;\n /** Whether to disallow empty selection */\n disallowEmptySelection?: boolean;\n /** Whether to wrap focus when reaching the end of the list */\n shouldFocusWrap?: boolean;\n /**\n * Ref to access the internal ListState instance.\n * This allows parent components to access selection state and other list functionality.\n */\n stateRef?: RefObject<any | null>;\n\n /**\n * Whether moving the pointer over an option will move DOM focus to that option.\n * Set to false for components that keep DOM focus outside (e.g. searchable FilterListBox).\n * Defaults to true.\n */\n focusOnHover?: boolean;\n /** Custom header content displayed above the list */\n header?: ReactNode;\n /** Custom footer content displayed below the list */\n footer?: ReactNode;\n /** Custom styles for the header */\n headerStyles?: Styles;\n /** Custom styles for the footer */\n footerStyles?: Styles;\n /** Additional modifiers for styling the ListBox */\n mods?: Record<string, boolean>;\n /** Size variant of the ListBox */\n size?: 'small' | 'medium' | 'large';\n\n /**\n * When `true`, clicking an already-selected item keeps it selected instead of toggling it off.\n * Useful when embedding ListBox inside components like ComboBox.\n */\n disableSelectionToggle?: boolean;\n\n /**\n * Whether to use virtual focus for keyboard navigation.\n * When true, DOM focus stays outside individual option elements (useful for searchable lists).\n * Defaults to false for backward compatibility.\n */\n shouldUseVirtualFocus?: boolean;\n\n /**\n * Callback fired when the user presses Escape key.\n * When provided, this prevents React Aria's default Escape behavior (selection reset).\n */\n onEscape?: () => void;\n\n /**\n * Whether to show checkboxes for multiple selection mode.\n * This adds a checkbox icon to the left of each option.\n */\n isCheckable?: boolean;\n\n /**\n * Callback fired when an option is clicked but not on the checkbox area.\n * Used by FilterPicker to close the popover on non-checkbox clicks.\n */\n onOptionClick?: (key: Key) => void;\n\n /**\n * Whether to show the \"Select All\" option in multiple selection mode.\n * This adds a select all option to the header that allows selecting/deselecting all items.\n */\n showSelectAll?: boolean;\n\n /**\n * Label for the \"Select All\" option. Defaults to \"Select All\".\n */\n selectAllLabel?: ReactNode;\n\n /**\n * Props to apply to the \"Select All\" option.\n */\n allValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Filter function to apply to the collection nodes.\n * Takes an iterable of nodes and returns a filtered iterable.\n * Useful for implementing search/filter functionality.\n */\n filter?: (nodes: Iterable<any>) => Iterable<any>;\n\n /**\n * Label to display when the list is empty (no items available).\n * Defaults to \"No items\".\n */\n emptyLabel?: ReactNode;\n\n /**\n * Visual shape of the ListBox styling.\n * - `card` (default): Standard card styling with border and margin\n * - `plain`: No border, no margin, no radius - suitable for embedded use\n * - `popover`: No border, but keeps margin and radius - suitable for overlay use\n * Defaults to 'card'.\n */\n shape?: 'card' | 'plain' | 'popover';\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nconst SelectAllOption = ({\n label = 'Select All',\n isSelected,\n isIndeterminate,\n isDisabled,\n isCheckable,\n size = 'medium',\n state,\n lastFocusSourceRef,\n onClick,\n allValueProps = {},\n}: {\n label?: ReactNode;\n isSelected: boolean;\n isIndeterminate: boolean;\n isDisabled?: boolean;\n isCheckable?: boolean;\n size?: 'small' | 'medium' | 'large';\n state: any;\n lastFocusSourceRef: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n onClick: (propagate?: boolean) => void;\n allValueProps?: Partial<CubeCollectionItemProps<any>>;\n}) => {\n const { hoverProps, isHovered } = useHover({ isDisabled });\n\n const markIcon = isIndeterminate ? (\n <Icon size={12} stroke={3}>\n <IconMinus />\n </Icon>\n ) : (\n <CheckIcon size={12} stroke={3} />\n );\n\n const localRef = useRef<HTMLLIElement>(null);\n\n // Create checkbox icon for select all option\n const checkboxIcon = useMemo(() => {\n if (!isCheckable) {\n return null;\n }\n\n return (\n <ListBoxCheckboxWrapper\n data-element=\"CheckboxWrapper\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n }}\n >\n <ListBoxCheckbox\n data-element=\"Checkbox\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n }}\n >\n {(isIndeterminate || isSelected) && markIcon}\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\n );\n }, [\n isCheckable,\n isSelected,\n isDisabled,\n isHovered,\n isIndeterminate,\n markIcon,\n ]);\n\n const handleOptionClick = (e) => {\n // Mark focus changes from mouse clicks\n if (lastFocusSourceRef) {\n lastFocusSourceRef.current = 'mouse';\n }\n\n // If there's an onOptionClick callback and this is checkable in multiple mode,\n // we need to distinguish between checkbox and content clicks\n if (state.selectionManager.selectionMode === 'multiple') {\n // Check if the click target is within the checkbox area\n const clickTarget = e.target as HTMLElement;\n const checkboxElement = localRef.current?.querySelector(\n '[data-element=\"CheckboxWrapper\"]',\n );\n\n if (\n checkboxElement &&\n (checkboxElement === clickTarget ||\n checkboxElement.contains(clickTarget))\n ) {\n onClick?.(false);\n } else {\n // Then call the callback (which will close the popover in FilterPicker)\n onClick?.(true);\n }\n } else {\n onClick?.(true);\n }\n };\n\n return (\n <>\n <ListBoxItem\n ref={localRef}\n data-size={size}\n size={size}\n role=\"option\"\n aria-selected={isSelected}\n isSelected={isSelected}\n isDisabled={isDisabled}\n icon={checkboxIcon}\n mods={{\n listboxitem: true,\n disabled: isDisabled,\n checkable: isCheckable,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n all: true, // Important: this preserves the 'all' modifier\n }}\n {...mergeProps(hoverProps, allValueProps, {\n onClick: handleOptionClick,\n })}\n >\n {label}\n </ListBoxItem>\n <StyledDivider />\n </>\n );\n};\n\nexport const ListBox = forwardRef(function ListBox<T extends object>(\n props: CubeListBoxProps<T>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n valuePropsMapper: ({ value, onChange }) => {\n const fieldProps: any = {};\n\n if (props.selectionMode === 'multiple') {\n fieldProps.selectedKeys = value || [];\n } else {\n fieldProps.selectedKey = value ?? null;\n }\n\n fieldProps.onSelectionChange = (key: any) => {\n if (props.selectionMode === 'multiple') {\n onChange(key ? (Array.isArray(key) ? key : [key]) : []);\n } else {\n onChange(Array.isArray(key) ? key[0] : key);\n }\n };\n\n return fieldProps;\n },\n });\n\n let {\n qa,\n label,\n extra,\n id,\n labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n message,\n description,\n styles,\n mods: externalMods,\n size = 'medium',\n labelSuffix,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n shouldUseVirtualFocus,\n onSelectionChange,\n disableSelectionToggle = false,\n stateRef,\n focusOnHover,\n header,\n footer,\n headerStyles,\n footerStyles,\n onEscape,\n isCheckable,\n onOptionClick,\n showSelectAll,\n selectAllLabel,\n allValueProps,\n filter,\n emptyLabel = 'No items',\n shape = 'card',\n form,\n ...otherProps\n } = props;\n\n const [, forceUpdate] = useState({});\n const lastSelectedKeyRef = useRef<Key | null>(null);\n\n // Wrap onSelectionChange to prevent selection when disabled and handle React Aria's Set format\n const externalSelectionHandler = onSelectionChange || (props as any).onChange;\n\n const wrappedOnSelectionChange = useMemo(() => {\n if (!externalSelectionHandler) return undefined;\n\n return (keys: any) => {\n // Don't allow selection changes when disabled\n if (isDisabled) {\n return;\n }\n\n // React Aria always passes a Set for selection changes\n // Handle the special \"all\" case and convert to our public API format\n if (keys === 'all') {\n externalSelectionHandler('all');\n } else if (keys instanceof Set) {\n if (keys.size === 0) {\n if (disableSelectionToggle && props.selectionMode === 'single') {\n const prevKey = lastSelectedKeyRef.current;\n if (prevKey != null) {\n externalSelectionHandler(prevKey);\n return;\n }\n }\n externalSelectionHandler(\n props.selectionMode === 'multiple' ? [] : null,\n );\n } else if (props.selectionMode === 'multiple') {\n externalSelectionHandler(Array.from(keys));\n } else {\n const key = Array.from(keys)[0];\n lastSelectedKeyRef.current = key ?? null;\n externalSelectionHandler(key);\n }\n } else {\n lastSelectedKeyRef.current = keys as Key | null;\n externalSelectionHandler(keys);\n }\n };\n }, [\n externalSelectionHandler,\n isDisabled,\n props.selectionMode,\n disableSelectionToggle,\n ]);\n\n // Prepare props for useListState with correct selection props\n const listStateProps: FirstArg<typeof useListState> = {\n ...props,\n onSelectionChange: wrappedOnSelectionChange,\n isDisabled,\n disabledBehavior: 'all',\n filter,\n selectionMode: props.selectionMode || 'single',\n };\n\n // Set selection props based on mode\n if (listStateProps.selectionMode === 'multiple') {\n if (selectedKeys !== undefined) {\n // Handle \"all\" selection by passing it directly to React Aria\n listStateProps.selectedKeys =\n selectedKeys === 'all' ? 'all' : new Set(selectedKeys as Key[]);\n }\n if (defaultSelectedKeys !== undefined) {\n // Handle \"all\" default selection\n listStateProps.defaultSelectedKeys =\n defaultSelectedKeys === 'all'\n ? 'all'\n : new Set(defaultSelectedKeys as Key[]);\n }\n // Remove single-selection props if any\n delete listStateProps.selectedKey;\n delete listStateProps.defaultSelectedKey;\n } else {\n // For single-selection we convert the scalar key props that our public\n // API exposes into the Set-based props that React Stately expects.\n if (selectedKey !== undefined) {\n listStateProps.selectedKeys =\n selectedKey == null ? new Set() : new Set([selectedKey]);\n }\n\n if (defaultSelectedKey !== undefined) {\n listStateProps.defaultSelectedKeys =\n defaultSelectedKey == null ? new Set() : new Set([defaultSelectedKey]);\n }\n\n // Remove the single-value props so we don't pass unsupported keys through.\n delete listStateProps.selectedKey;\n delete listStateProps.defaultSelectedKey;\n }\n\n const listState = useListState(listStateProps);\n\n useLayoutEffect(() => {\n const selected = listState.selectionManager.selectedKeys;\n if (selected && (selected as any).size > 0) {\n const first = Array.from(selected as Set<Key>)[0];\n lastSelectedKeyRef.current = first ?? null;\n }\n }, [listState.selectionManager.selectedKeys]);\n\n // Calculate select all state for multiple selection mode\n const selectAllState = useMemo(() => {\n // Select-all only makes sense for multiple selection mode *and* when the UI is enabled\n if (props.selectionMode !== 'multiple' || !showSelectAll) {\n return { isSelected: false, isIndeterminate: false };\n }\n\n // React Stately exposes the raw selection value which is either the string \"all\"\n // (when `selectAll(true)` was used) **or** a Set of item keys.\n const rawSelection: any = (listState.selectionManager as any).rawSelection;\n\n // Fast path – user pressed our \"Select All\" control previously.\n if (rawSelection === 'all') {\n return { isSelected: true, isIndeterminate: false };\n }\n\n const selectedKeys = listState.selectionManager.selectedKeys as Set<Key>;\n\n // When there is nothing selected, we are in a clear state\n if (selectedKeys.size === 0) {\n return { isSelected: false, isIndeterminate: false };\n }\n\n // Otherwise it must be a partial (indeterminate) selection.\n return { isSelected: false, isIndeterminate: true };\n }, [\n props.selectionMode,\n showSelectAll,\n listState.collection,\n listState.disabledKeys,\n listState.selectionManager.selectedKeys,\n listState.selectionManager.rawSelection,\n ]);\n\n // Handle select all click\n const handleSelectAllClick = (propagate?: boolean) => {\n if (isDisabled || props.selectionMode !== 'multiple') return;\n\n if (selectAllState.isSelected) {\n // All selected, deselect all\n listState.selectionManager.clearSelection();\n // Manually call the wrapped handler since React Aria might not trigger it\n wrappedOnSelectionChange?.(new Set());\n } else {\n // Some or none selected, select all\n listState.selectionManager.selectAll(true);\n // Manually call the wrapped handler since React Aria might not trigger it\n wrappedOnSelectionChange?.('all');\n forceUpdate({});\n }\n\n if (propagate && !selectAllState.isSelected) {\n onOptionClick?.('__ALL__');\n }\n };\n\n // Track whether the last focus change was due to keyboard navigation\n const lastFocusSourceRef = useRef<'keyboard' | 'mouse' | 'other'>('other');\n\n // Expose the list state instance via the provided ref (if any)\n if (stateRef) {\n stateRef.current = {\n ...listState,\n lastFocusSourceRef,\n };\n }\n\n // Warn if isCheckable is false in single selection mode\n useWarn(isCheckable === false && props.selectionMode === 'single', {\n key: ['listbox-checkable-single-mode'],\n args: [\n 'CubeUIKit: isCheckable=false is not recommended in single selection mode as it may confuse users about selection behavior.',\n ],\n });\n\n // Custom keyboard handling to prevent selection clearing on Escape while allowing overlay dismiss\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n // Mark focus changes from keyboard navigation\n if (\n e.key === 'ArrowDown' ||\n e.key === 'ArrowUp' ||\n e.key === 'Home' ||\n e.key === 'End' ||\n e.key === 'PageUp' ||\n e.key === 'PageDown'\n ) {\n lastFocusSourceRef.current = 'keyboard';\n }\n\n if (e.key === 'Escape' && onEscape) {\n // Don't prevent default - let the overlay system handle closing\n // But we'll call onEscape to potentially override the default selection clearing\n onEscape();\n }\n },\n });\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n ref = useCombinedRefs(ref);\n listRef = useCombinedRefs(listRef);\n\n const { listBoxProps } = useListBox(\n {\n ...props,\n id: id,\n 'aria-label': props['aria-label'] || label?.toString(),\n isDisabled,\n isVirtualized: true,\n shouldUseVirtualFocus: shouldUseVirtualFocus ?? false,\n escapeKeyBehavior: onEscape ? 'none' : 'clearSelection',\n },\n listState,\n listRef,\n );\n\n const { isFocused, focusProps } = useFocus({ isDisabled });\n const isInvalid = validationState === 'invalid';\n\n // ----- Virtualization logic -----\n const itemsArray = useMemo(\n () => [...listState.collection],\n [listState.collection],\n );\n\n const hasSections = useMemo(\n () => itemsArray.some((i) => i.type === 'section'),\n [itemsArray],\n );\n\n const shouldVirtualize = !hasSections;\n\n // Use ref to ensure estimateSize always accesses current itemsArray\n const itemsArrayRef = useRef(itemsArray);\n itemsArrayRef.current = itemsArray;\n\n // Scroll container ref for virtualization\n const scrollRef = useRef<HTMLDivElement>(null);\n\n const rowVirtualizer = useVirtualizer({\n count: shouldVirtualize ? itemsArray.length : 0,\n getScrollElement: () => scrollRef.current,\n // Use the actual item key to ensure React properly reconciles DOM elements\n // when items are filtered, added, or removed. Without this, the virtualizer\n // uses index-based keys which causes DOM reuse issues and style leaking.\n getItemKey: (index: number) => {\n const item = itemsArrayRef.current[index];\n return item?.key ?? index;\n },\n estimateSize: (index: number) => {\n const currentItem: any = itemsArrayRef.current[index];\n\n if (currentItem?.props?.description) {\n return SIZES.XL + 1;\n }\n return SIZES[SIZE_NAME_TO_KEY[size] as keyof typeof SIZES] + 1;\n },\n measureElement: (el) => {\n return el.offsetHeight + 1;\n },\n overscan: 10,\n });\n\n // Trigger remeasurement when items change (for filtering scenarios)\n useEffect(() => {\n if (shouldVirtualize) {\n rowVirtualizer.measure();\n }\n }, [shouldVirtualize, itemsArray, rowVirtualizer]);\n\n // Keep focused item visible, but only for keyboard navigation\n useLayoutEffect(() => {\n const focusedKey = listState.selectionManager.focusedKey;\n if (focusedKey == null) return;\n\n // Only scroll on keyboard navigation\n if (lastFocusSourceRef.current !== 'keyboard') return;\n\n const scrollElement = scrollRef.current;\n if (!scrollElement) return;\n\n const itemElement = scrollElement.querySelector(\n `[data-key=\"${CSS.escape(String(focusedKey))}\"]`,\n ) as HTMLElement;\n if (!itemElement) return;\n\n const scrollTop = scrollElement.scrollTop;\n const viewportHeight = scrollElement.clientHeight;\n const viewportBottom = scrollTop + viewportHeight;\n\n const itemRect = itemElement.getBoundingClientRect();\n const scrollRect = scrollElement.getBoundingClientRect();\n\n // Calculate item position relative to scroll container\n const itemTop = itemRect.top - scrollRect.top + scrollTop;\n const itemBottom = itemTop + itemRect.height;\n\n // Check if the item is fully visible in the viewport\n const isAlreadyVisible =\n itemTop >= scrollTop && itemBottom <= viewportBottom;\n\n if (!isAlreadyVisible) {\n // Use scrollIntoView with block: 'nearest' to minimize scroll jumps\n itemElement.scrollIntoView({ block: 'nearest', behavior: 'auto' });\n }\n }, [listState.selectionManager.focusedKey, itemsArray]);\n\n // Merge React Aria listbox props with custom keyboard props so both sets of\n // event handlers (e.g. Arrow navigation *and* our Escape handler) are\n // preserved.\n const mergedListBoxProps = mergeProps(listBoxProps, keyboardProps);\n\n const mods = useMemo(\n () => ({\n invalid: isInvalid,\n valid: validationState === 'valid',\n disabled: isDisabled,\n focused: isFocused,\n header: !!header || (showSelectAll && props.selectionMode === 'multiple'),\n footer: !!footer,\n selectAll: showSelectAll && props.selectionMode === 'multiple',\n ...externalMods,\n }),\n [\n isInvalid,\n validationState,\n isDisabled,\n isFocused,\n header,\n footer,\n showSelectAll,\n props.selectionMode,\n externalMods,\n ],\n );\n\n const listBoxField = (\n <ListBoxWrapperElement\n ref={ref}\n qa=\"ListBoxWrapper\"\n mods={mods}\n styles={styles}\n data-shape={shape}\n >\n {header ? (\n <StyledHeader styles={headerStyles} data-size={size}>\n {header}\n </StyledHeader>\n ) : (\n <div role=\"presentation\" />\n )}\n {showSelectAll && props.selectionMode === 'multiple' ? (\n <SelectAllOption\n label={selectAllLabel || 'Select All'}\n state={listState}\n lastFocusSourceRef={lastFocusSourceRef}\n isSelected={selectAllState.isSelected}\n isIndeterminate={selectAllState.isIndeterminate}\n isDisabled={isDisabled}\n isCheckable={isCheckable}\n size={size}\n allValueProps={allValueProps}\n onClick={handleSelectAllClick}\n />\n ) : (\n <>\n <div role=\"presentation\" />\n <div role=\"presentation\" />\n </>\n )}\n {/* Scroll container wrapper */}\n <ListBoxScrollElement ref={scrollRef} mods={mods} {...focusProps}>\n {listState.collection.size === 0 ? (\n <Item preset=\"t4\" color=\"#dark-03\" size={size} padding=\"(.5x - 1bw)\">\n {emptyLabel}\n </Item>\n ) : (\n <ListElement\n qa={qa || 'ListBox'}\n {...mergedListBoxProps}\n ref={listRef}\n styles={listStyles}\n aria-disabled={isDisabled || undefined}\n mods={{ sections: hasSections }}\n data-shape={shape}\n data-input-type=\"listbox\"\n style={\n shouldVirtualize\n ? {\n position: 'relative',\n height: `${rowVirtualizer.getTotalSize() + 3}px`,\n }\n : undefined\n }\n >\n {shouldVirtualize\n ? rowVirtualizer.getVirtualItems().map((virtualItem) => {\n const item = itemsArray[virtualItem.index];\n\n return (\n <Option\n key={item.key}\n size={size}\n item={item}\n state={listState}\n styles={optionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n // We don't need to measure the element here, because the height is already set by the virtualizer\n // This is a workaround to avoid glitches when selecting/deselecting items\n virtualRef={rowVirtualizer.measureElement as any}\n virtualStyle={{\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n virtualIndex={virtualItem.index}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />\n );\n })\n : (() => {\n const renderedItems: ReactNode[] = [];\n let isFirstSection = true;\n\n for (const item of listState.collection) {\n if (item.type === 'section') {\n if (!isFirstSection) {\n renderedItems.push(\n <StyledDivider\n key={`divider-${String(item.key)}`}\n role=\"separator\"\n aria-orientation=\"horizontal\"\n />,\n );\n }\n\n renderedItems.push(\n <ListBoxSection\n key={item.key}\n item={item}\n state={listState}\n optionStyles={optionStyles}\n headingStyles={headingStyles}\n sectionStyles={sectionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n size={size}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />,\n );\n\n isFirstSection = false;\n } else {\n renderedItems.push(\n <Option\n key={item.key}\n size={size}\n item={item}\n state={listState}\n styles={optionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />,\n );\n }\n }\n\n return renderedItems;\n })()}\n </ListElement>\n )}\n </ListBoxScrollElement>\n {footer ? (\n <StyledFooter styles={footerStyles} data-size={size}>\n {footer}\n </StyledFooter>\n ) : (\n <div role=\"presentation\" />\n )}\n </ListBoxWrapperElement>\n );\n\n return wrapWithField<Omit<CubeListBoxProps<T>, 'children'>>(\n listBoxField,\n ref,\n props,\n );\n}) as unknown as (<T>(\n props: CubeListBoxProps<T> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement) & {\n Item: typeof CollectionItem;\n Section: typeof BaseSection;\n};\n\nfunction Option({\n size = 'medium',\n item,\n state,\n styles,\n isParentDisabled,\n validationState,\n focusOnHover = false,\n isCheckable,\n onClick: onOptionClick,\n virtualStyle,\n virtualRef,\n virtualIndex,\n lastFocusSourceRef,\n}: {\n size?: 'small' | 'medium' | 'large';\n item: any;\n state: any;\n styles?: Styles;\n isParentDisabled?: boolean;\n validationState?: any;\n focusOnHover?: boolean;\n isCheckable?: boolean;\n onClick?: (key: Key) => void;\n /** Inline style applied when virtualized (absolute positioning etc.) */\n virtualStyle?: CSSProperties;\n /** Ref callback from react-virtual to measure row height */\n virtualRef?: (element: HTMLElement | null) => void;\n /** Virtual index from react-virtual for data-index attribute */\n virtualIndex?: number;\n /** Ref to track the source of focus changes */\n lastFocusSourceRef?: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n}) {\n const localRef = useRef<HTMLLIElement>(null);\n // Merge local ref with react-virtual measure ref when provided\n const combinedRef = useCombinedRefs(localRef, virtualRef);\n\n const isDisabled = isParentDisabled || state.disabledKeys.has(item.key);\n const isSelected = state.selectionManager.isSelected(item.key);\n const isFocused = state.selectionManager.focusedKey === item.key;\n\n const { hoverProps, isHovered } = useHover({ isDisabled });\n\n const { optionProps, isPressed, labelProps, descriptionProps } = useOption(\n {\n key: item.key,\n isDisabled,\n isSelected,\n shouldSelectOnPressUp: true,\n shouldFocusOnHover: focusOnHover,\n },\n state,\n combinedRef,\n );\n\n // Filter out service props - all remaining props can be passed to Item\n const filteredItemProps = filterCollectionItemProps(item.props);\n\n // Create checkbox icon for multiple selection mode\n const effectiveIcon = useMemo(() => {\n if (\n !isCheckable ||\n state.selectionManager.selectionMode !== 'multiple' ||\n filteredItemProps.icon\n ) {\n return (\n filteredItemProps.icon ??\n (state.selectionManager.selectionMode !== 'multiple' ? null : undefined)\n );\n }\n\n return (\n <ListBoxCheckboxWrapper\n data-element=\"CheckboxWrapper\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n }}\n >\n <ListBoxCheckbox\n data-element=\"Checkbox\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n }}\n >\n <CheckIcon size={12} stroke={3} />\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\n );\n }, [\n isCheckable,\n state.selectionManager.selectionMode,\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n filteredItemProps.icon,\n ]);\n\n // Custom click handler for the entire option\n const handleOptionClick = (e) => {\n // Mark focus changes from mouse clicks\n if (lastFocusSourceRef) {\n lastFocusSourceRef.current = 'mouse';\n }\n\n // If there's an onOptionClick callback and this is checkable in multiple mode,\n // we need to distinguish between checkbox and content clicks\n if (\n onOptionClick &&\n isCheckable &&\n state.selectionManager.selectionMode === 'multiple'\n ) {\n // Check if the click target is within the checkbox area\n const clickTarget = e.target as HTMLElement;\n const checkboxElement = localRef.current?.querySelector(\n '[data-element=\"CheckboxWrapper\"]',\n );\n\n if (\n checkboxElement &&\n (checkboxElement === clickTarget ||\n checkboxElement.contains(clickTarget))\n ) {\n // Checkbox area clicked - only toggle, don't call onOptionClick\n // Let React Aria handle the selection\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n } else {\n // Content area clicked - toggle and trigger callback\n // Let React Aria handle the selection first\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n // Then call the callback (which will close the popover in FilterPicker)\n if (onOptionClick) {\n onOptionClick(item.key);\n }\n }\n } else {\n // Normal behavior - let React Aria handle it\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n // Call onOptionClick if provided\n if (onOptionClick) {\n onOptionClick(item.key);\n }\n }\n };\n\n // Filter out React Aria props that shouldn't reach the DOM\n const {\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n ...filteredOptionProps\n } = optionProps;\n\n const theme =\n { valid: 'success', invalid: 'danger' }[validationState] || 'default';\n\n return (\n <ListBoxItem\n ref={combinedRef}\n id={`ListBoxItem-${String(item.key)}`}\n data-key={String(item.key)}\n {...mergeProps(filteredOptionProps, hoverProps, filteredItemProps, {\n onClick: handleOptionClick,\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n })}\n theme={theme}\n style={virtualStyle}\n data-size={size}\n data-index={virtualIndex}\n size={size}\n isSelected={isSelected}\n isDisabled={isDisabled}\n icon={effectiveIcon}\n labelProps={labelProps}\n descriptionProps={descriptionProps}\n styles={mergeStyles(styles, filteredItemProps.styles)}\n defaultTooltipPlacement=\"right\"\n mods={{\n listboxitem: true,\n focused: isFocused,\n pressed: isPressed,\n valid: isSelected && validationState === 'valid',\n invalid: isSelected && validationState === 'invalid',\n checkable: isCheckable,\n hovered: isHovered,\n all: false, // This will be set to true for SelectAllOption\n }}\n >\n {item.rendered}\n </ListBoxItem>\n );\n}\n\ninterface ListBoxSectionProps<T> {\n item: any;\n state: any;\n optionStyles?: Styles;\n headingStyles?: Styles;\n sectionStyles?: Styles;\n isParentDisabled?: boolean;\n validationState?: any;\n focusOnHover?: boolean;\n isCheckable?: boolean;\n onClick?: (key: Key) => void;\n size?: 'small' | 'medium' | 'large';\n lastFocusSourceRef?: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n}\n\nfunction ListBoxSection<T>(props: ListBoxSectionProps<T>) {\n const {\n item,\n state,\n optionStyles,\n headingStyles,\n sectionStyles,\n isParentDisabled,\n validationState,\n focusOnHover,\n isCheckable,\n onClick: onOptionClick,\n lastFocusSourceRef,\n } = props;\n const heading = item.rendered;\n\n const { itemProps, headingProps, groupProps } = useListBoxSection({\n heading,\n 'aria-label': item['aria-label'],\n });\n\n return (\n <SectionWrapperElement {...itemProps} styles={sectionStyles}>\n {heading && (\n <StyledSectionHeading\n {...headingProps}\n size={props.size}\n styles={headingStyles}\n >\n {heading}\n </StyledSectionHeading>\n )}\n <SectionListElement {...groupProps}>\n {[...item.childNodes]\n .filter((node: any) => state.collection.getItem(node.key))\n .map((node: any) => (\n <Option\n key={node.key}\n size={props.size}\n item={node}\n state={state}\n styles={optionStyles}\n isParentDisabled={isParentDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />\n ))}\n </SectionListElement>\n </SectionWrapperElement>\n );\n}\n\ntype SectionComponent = typeof BaseSection;\n\nconst ListBoxSectionComponent = Object.assign(BaseSection, {\n displayName: 'Section',\n}) as SectionComponent;\n\nListBox.Item = CollectionItem;\n\nListBox.Section = ListBoxSectionComponent;\n\nObject.defineProperty(ListBox, 'cubeInputType', {\n value: 'ListBox',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"ListBox.js","names":["Item","useHover","mergeProps","useFocus","BaseSection","CollectionItem"],"sources":["../../../../src/components/fields/ListBox/ListBox.tsx"],"sourcesContent":["import { useHover } from '@react-aria/interactions';\nimport { IconMinus } from '@tabler/icons-react';\nimport { useVirtualizer } from '@tanstack/react-virtual';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n COLOR_STYLES,\n extractStyles,\n mergeStyles,\n OUTER_STYLES,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n CSSProperties,\n ForwardedRef,\n forwardRef,\n MutableRefObject,\n ReactElement,\n ReactNode,\n RefObject,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport {\n AriaListBoxProps,\n useKeyboard,\n useListBox,\n useListBoxSection,\n useOption,\n} from 'react-aria';\nimport { Section as BaseSection, useListState } from 'react-stately';\n\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CheckIcon } from '../../../icons';\nimport { Icon } from '../../../icons/index';\nimport { useProviderProps } from '../../../provider';\nimport { SIZE_NAME_TO_KEY, SIZES } from '../../../tokens';\nimport { mergeProps, useCombinedRefs } from '../../../utils/react';\nimport { useFocus } from '../../../utils/react/interactions';\n// Import Menu styled components for header and footer\nimport {\n StyledDivider,\n StyledFooter,\n StyledHeader,\n StyledSectionHeading,\n} from '../../actions/Menu/styled';\nimport {\n CollectionItem,\n CubeCollectionItemProps,\n filterCollectionItemProps,\n} from '../../CollectionItem';\nimport { Item } from '../../content/Item/Item';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\n\nimport type { CollectionBase, Key } from '@react-types/shared';\nimport type { FieldBaseProps } from '../../../shared';\n\ntype FirstArg<F> = F extends (...args: infer A) => any ? A[0] : never;\n\nconst ListBoxWrapperElement = tasty({\n qa: 'ListBox',\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: 'max-content max-content max-content 1sf max-content',\n flow: 'column',\n gap: 0,\n position: 'relative',\n radius: {\n '': '1cr',\n '[data-shape=\"popover\"]': '(1cr - 1bw)',\n '[data-shape=\"plain\"]': '0',\n },\n color: '#dark-02',\n transition: 'theme',\n outline: {\n '': '#purple-03.0',\n 'invalid & focused': '#danger.50',\n focused: '#purple-03',\n },\n border: {\n '': true,\n focused: '#primary-text',\n valid: '#success-text.50',\n invalid: '#danger-text.50',\n disabled: true,\n '[data-shape=\"plain\"] | [data-shape=\"popover\"] | searchable': false,\n },\n },\n});\n\nconst ListElement = tasty({\n as: 'ul',\n styles: {\n display: 'block',\n padding: 0,\n listStyle: 'none',\n boxSizing: 'border-box',\n margin: {\n '': '.5x .5x 0 .5x',\n '[data-shape=\"plain\"]': '0',\n },\n height: 'max-content',\n },\n});\n\n// NEW: dedicated scroll container for ListBox\nconst ListBoxScrollElement = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: '1sf',\n overflow: 'auto',\n scrollbar: 'styled',\n },\n});\n\n// Create an extended Item for ListBox options with 'all' modifier support\nconst ListBoxItem = tasty(Item, {\n as: 'li',\n disableActionsFocus: true,\n styles: {\n margin: {\n '': '0 0 1bw 0',\n ':last-of-type': '0',\n all: '.5x',\n },\n },\n});\n\nconst SectionWrapperElement = tasty({\n as: 'li',\n styles: {\n display: 'block',\n padding: {\n '': 0,\n ':last-of-type': '0 0 .5x 0',\n },\n },\n});\n\nconst SectionListElement = tasty({\n qa: 'ListBoxSectionList',\n as: 'ul',\n styles: {\n display: 'flex',\n gap: '0',\n flow: 'column',\n margin: '0',\n padding: '0',\n listStyle: 'none',\n },\n});\n\n// Checkbox component for multiple selection options\nconst ListBoxCheckbox = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n placeItems: 'center',\n radius: '.5r',\n width: '(2x - 2bw)',\n height: '(2x - 2bw)',\n flexShrink: 0,\n transition: 'theme',\n opacity: {\n '': 0,\n 'selected | indeterminate | hovered | focused': 1,\n },\n fill: {\n '': '#white',\n 'selected | indeterminate': '#primary-text',\n 'invalid & !(selected | indeterminate)': '#white',\n 'invalid & (selected | indeterminate)': '#danger',\n disabled: '#dark.12',\n },\n color: {\n '': '#white',\n 'disabled & !selected': '#clear',\n },\n border: {\n '': '#dark.30',\n invalid: '#danger',\n 'disabled | ((selected | indeterminate) & !invalid)': '#clear',\n },\n },\n});\n\nconst ListBoxCheckboxWrapper = tasty({\n as: 'div',\n styles: {\n display: 'grid',\n placeItems: 'center',\n placeContent: 'center',\n cursor: '$pointer',\n placeSelf: 'stretch',\n },\n});\n\nexport interface CubeListBoxProps<T>\n extends AriaListBoxProps<T>,\n CollectionBase<T>,\n FieldBaseProps,\n BasePropsWithoutChildren {\n /** Custom styles for the list container */\n listStyles?: Styles;\n /** Custom styles for individual options */\n optionStyles?: Styles;\n /** Custom styles for section containers */\n sectionStyles?: Styles;\n /** Custom styles for section headings */\n headingStyles?: Styles;\n /** Whether the ListBox is disabled */\n isDisabled?: boolean;\n /** The selected key in controlled single selection mode */\n selectedKey?: Key | null;\n /** The selected keys in controlled multiple selection mode. Use \"all\" to select all items or an array of keys */\n selectedKeys?: 'all' | Key[];\n /** The default selected key in uncontrolled single selection mode */\n defaultSelectedKey?: Key | null;\n /** The default selected keys in uncontrolled multiple selection mode. Use \"all\" to select all items or an array of keys */\n defaultSelectedKeys?: 'all' | Key[];\n /** Callback fired when selection changes */\n onSelectionChange?: (key: Key | null | 'all' | Key[]) => void;\n /** The selection mode of the ListBox */\n selectionMode?: 'single' | 'multiple';\n /** Ref for accessing the list DOM element */\n listRef?: RefObject<HTMLUListElement | null>;\n /** Whether to disallow empty selection */\n disallowEmptySelection?: boolean;\n /** Whether to wrap focus when reaching the end of the list */\n shouldFocusWrap?: boolean;\n /**\n * Ref to access the internal ListState instance.\n * This allows parent components to access selection state and other list functionality.\n */\n stateRef?: RefObject<any | null>;\n\n /**\n * Whether moving the pointer over an option will move DOM focus to that option.\n * Set to false for components that keep DOM focus outside (e.g. searchable FilterListBox).\n * Defaults to true.\n */\n focusOnHover?: boolean;\n /** Custom header content displayed above the list */\n header?: ReactNode;\n /** Custom footer content displayed below the list */\n footer?: ReactNode;\n /** Custom styles for the header */\n headerStyles?: Styles;\n /** Custom styles for the footer */\n footerStyles?: Styles;\n /** Additional modifiers for styling the ListBox */\n mods?: Record<string, boolean>;\n /** Size variant of the ListBox */\n size?: 'small' | 'medium' | 'large';\n\n /**\n * When `true`, clicking an already-selected item keeps it selected instead of toggling it off.\n * Useful when embedding ListBox inside components like ComboBox.\n */\n disableSelectionToggle?: boolean;\n\n /**\n * Whether to use virtual focus for keyboard navigation.\n * When true, DOM focus stays outside individual option elements (useful for searchable lists).\n * Defaults to false for backward compatibility.\n */\n shouldUseVirtualFocus?: boolean;\n\n /**\n * Callback fired when the user presses Escape key.\n * When provided, this prevents React Aria's default Escape behavior (selection reset).\n */\n onEscape?: () => void;\n\n /**\n * Whether to show checkboxes for multiple selection mode.\n * This adds a checkbox icon to the left of each option.\n */\n isCheckable?: boolean;\n\n /**\n * Callback fired when an option is clicked but not on the checkbox area.\n * Used by FilterPicker to close the popover on non-checkbox clicks.\n */\n onOptionClick?: (key: Key) => void;\n\n /**\n * Whether to show the \"Select All\" option in multiple selection mode.\n * This adds a select all option to the header that allows selecting/deselecting all items.\n */\n showSelectAll?: boolean;\n\n /**\n * Label for the \"Select All\" option. Defaults to \"Select All\".\n */\n selectAllLabel?: ReactNode;\n\n /**\n * Props to apply to the \"Select All\" option.\n */\n allValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Filter function to apply to the collection nodes.\n * Takes an iterable of nodes and returns a filtered iterable.\n * Useful for implementing search/filter functionality.\n */\n filter?: (nodes: Iterable<any>) => Iterable<any>;\n\n /**\n * Label to display when the list is empty (no items available).\n * Defaults to \"No items\".\n */\n emptyLabel?: ReactNode;\n\n /**\n * Visual shape of the ListBox styling.\n * - `card` (default): Standard card styling with border and margin\n * - `plain`: No border, no margin, no radius - suitable for embedded use\n * - `popover`: No border, but keeps margin and radius - suitable for overlay use\n * Defaults to 'card'.\n */\n shape?: 'card' | 'plain' | 'popover';\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nconst SelectAllOption = ({\n label = 'Select All',\n isSelected,\n isIndeterminate,\n isDisabled,\n isCheckable,\n size = 'medium',\n state,\n lastFocusSourceRef,\n onClick,\n allValueProps = {},\n}: {\n label?: ReactNode;\n isSelected: boolean;\n isIndeterminate: boolean;\n isDisabled?: boolean;\n isCheckable?: boolean;\n size?: 'small' | 'medium' | 'large';\n state: any;\n lastFocusSourceRef: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n onClick: (propagate?: boolean) => void;\n allValueProps?: Partial<CubeCollectionItemProps<any>>;\n}) => {\n const { hoverProps, isHovered } = useHover({ isDisabled });\n\n const markIcon = isIndeterminate ? (\n <Icon size={12} stroke={3}>\n <IconMinus />\n </Icon>\n ) : (\n <CheckIcon size={12} stroke={3} />\n );\n\n const localRef = useRef<HTMLLIElement>(null);\n\n // Create checkbox icon for select all option\n const checkboxIcon = useMemo(() => {\n if (!isCheckable) {\n return null;\n }\n\n return (\n <ListBoxCheckboxWrapper\n data-element=\"CheckboxWrapper\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n }}\n >\n <ListBoxCheckbox\n data-element=\"Checkbox\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n }}\n >\n {(isIndeterminate || isSelected) && markIcon}\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\n );\n }, [\n isCheckable,\n isSelected,\n isDisabled,\n isHovered,\n isIndeterminate,\n markIcon,\n ]);\n\n const handleOptionClick = (e) => {\n // Mark focus changes from mouse clicks\n if (lastFocusSourceRef) {\n lastFocusSourceRef.current = 'mouse';\n }\n\n // If there's an onOptionClick callback and this is checkable in multiple mode,\n // we need to distinguish between checkbox and content clicks\n if (state.selectionManager.selectionMode === 'multiple') {\n // Check if the click target is within the checkbox area\n const clickTarget = e.target as HTMLElement;\n const checkboxElement = localRef.current?.querySelector(\n '[data-element=\"CheckboxWrapper\"]',\n );\n\n if (\n checkboxElement &&\n (checkboxElement === clickTarget ||\n checkboxElement.contains(clickTarget))\n ) {\n onClick?.(false);\n } else {\n // Then call the callback (which will close the popover in FilterPicker)\n onClick?.(true);\n }\n } else {\n onClick?.(true);\n }\n };\n\n return (\n <>\n <ListBoxItem\n ref={localRef}\n data-size={size}\n size={size}\n role=\"option\"\n aria-selected={isSelected}\n isSelected={isSelected}\n isDisabled={isDisabled}\n icon={checkboxIcon}\n mods={{\n listboxitem: true,\n disabled: isDisabled,\n checkable: isCheckable,\n hovered: isHovered,\n indeterminate: isIndeterminate,\n all: true, // Important: this preserves the 'all' modifier\n }}\n {...mergeProps(hoverProps, allValueProps, {\n onClick: handleOptionClick,\n })}\n >\n {label}\n </ListBoxItem>\n <StyledDivider />\n </>\n );\n};\n\nexport const ListBox = forwardRef(function ListBox<T extends object>(\n props: CubeListBoxProps<T>,\n ref: ForwardedRef<HTMLDivElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n valuePropsMapper: ({ value, onChange }) => {\n const fieldProps: any = {};\n\n if (props.selectionMode === 'multiple') {\n fieldProps.selectedKeys = value || [];\n } else {\n fieldProps.selectedKey = value ?? null;\n }\n\n fieldProps.onSelectionChange = (key: any) => {\n if (props.selectionMode === 'multiple') {\n onChange(key ? (Array.isArray(key) ? key : [key]) : []);\n } else {\n onChange(Array.isArray(key) ? key[0] : key);\n }\n };\n\n return fieldProps;\n },\n });\n\n let {\n qa,\n label,\n extra,\n id,\n labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n message,\n description,\n styles,\n mods: externalMods,\n size = 'medium',\n labelSuffix,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n shouldUseVirtualFocus,\n onSelectionChange,\n disableSelectionToggle = false,\n stateRef,\n focusOnHover,\n header,\n footer,\n headerStyles,\n footerStyles,\n onEscape,\n isCheckable,\n onOptionClick,\n showSelectAll,\n selectAllLabel,\n allValueProps,\n filter,\n emptyLabel = 'No items',\n shape = 'card',\n form,\n ...otherProps\n } = props;\n\n const [, forceUpdate] = useState({});\n const lastSelectedKeyRef = useRef<Key | null>(null);\n\n // Wrap onSelectionChange to prevent selection when disabled and handle React Aria's Set format\n const externalSelectionHandler = onSelectionChange || (props as any).onChange;\n\n const wrappedOnSelectionChange = useMemo(() => {\n if (!externalSelectionHandler) return undefined;\n\n return (keys: any) => {\n // Don't allow selection changes when disabled\n if (isDisabled) {\n return;\n }\n\n // React Aria always passes a Set for selection changes\n // Handle the special \"all\" case and convert to our public API format\n if (keys === 'all') {\n externalSelectionHandler('all');\n } else if (keys instanceof Set) {\n if (keys.size === 0) {\n if (disableSelectionToggle && props.selectionMode === 'single') {\n const prevKey = lastSelectedKeyRef.current;\n if (prevKey != null) {\n externalSelectionHandler(prevKey);\n return;\n }\n }\n externalSelectionHandler(\n props.selectionMode === 'multiple' ? [] : null,\n );\n } else if (props.selectionMode === 'multiple') {\n externalSelectionHandler(Array.from(keys));\n } else {\n const key = Array.from(keys)[0];\n lastSelectedKeyRef.current = key ?? null;\n externalSelectionHandler(key);\n }\n } else {\n lastSelectedKeyRef.current = keys as Key | null;\n externalSelectionHandler(keys);\n }\n };\n }, [\n externalSelectionHandler,\n isDisabled,\n props.selectionMode,\n disableSelectionToggle,\n ]);\n\n // Prepare props for useListState with correct selection props\n const listStateProps: FirstArg<typeof useListState> = {\n ...props,\n onSelectionChange: wrappedOnSelectionChange,\n isDisabled,\n disabledBehavior: 'all',\n filter,\n selectionMode: props.selectionMode || 'single',\n };\n\n // Set selection props based on mode\n if (listStateProps.selectionMode === 'multiple') {\n if (selectedKeys !== undefined) {\n // Handle \"all\" selection by passing it directly to React Aria\n listStateProps.selectedKeys =\n selectedKeys === 'all' ? 'all' : new Set(selectedKeys as Key[]);\n }\n if (defaultSelectedKeys !== undefined) {\n // Handle \"all\" default selection\n listStateProps.defaultSelectedKeys =\n defaultSelectedKeys === 'all'\n ? 'all'\n : new Set(defaultSelectedKeys as Key[]);\n }\n // Remove single-selection props if any\n delete listStateProps.selectedKey;\n delete listStateProps.defaultSelectedKey;\n } else {\n // For single-selection we convert the scalar key props that our public\n // API exposes into the Set-based props that React Stately expects.\n if (selectedKey !== undefined) {\n listStateProps.selectedKeys =\n selectedKey == null ? new Set() : new Set([selectedKey]);\n }\n\n if (defaultSelectedKey !== undefined) {\n listStateProps.defaultSelectedKeys =\n defaultSelectedKey == null ? new Set() : new Set([defaultSelectedKey]);\n }\n\n // Remove the single-value props so we don't pass unsupported keys through.\n delete listStateProps.selectedKey;\n delete listStateProps.defaultSelectedKey;\n }\n\n const listState = useListState(listStateProps);\n\n useLayoutEffect(() => {\n const selected = listState.selectionManager.selectedKeys;\n if (selected && (selected as any).size > 0) {\n const first = Array.from(selected as Set<Key>)[0];\n lastSelectedKeyRef.current = first ?? null;\n }\n }, [listState.selectionManager.selectedKeys]);\n\n // Calculate select all state for multiple selection mode\n const selectAllState = useMemo(() => {\n // Select-all only makes sense for multiple selection mode *and* when the UI is enabled\n if (props.selectionMode !== 'multiple' || !showSelectAll) {\n return { isSelected: false, isIndeterminate: false };\n }\n\n // React Stately exposes the raw selection value which is either the string \"all\"\n // (when `selectAll(true)` was used) **or** a Set of item keys.\n const rawSelection: any = (listState.selectionManager as any).rawSelection;\n\n // Fast path – user pressed our \"Select All\" control previously.\n if (rawSelection === 'all') {\n return { isSelected: true, isIndeterminate: false };\n }\n\n const selectedKeys = listState.selectionManager.selectedKeys as Set<Key>;\n\n // When there is nothing selected, we are in a clear state\n if (selectedKeys.size === 0) {\n return { isSelected: false, isIndeterminate: false };\n }\n\n // Otherwise it must be a partial (indeterminate) selection.\n return { isSelected: false, isIndeterminate: true };\n }, [\n props.selectionMode,\n showSelectAll,\n listState.collection,\n listState.disabledKeys,\n listState.selectionManager.selectedKeys,\n listState.selectionManager.rawSelection,\n ]);\n\n // Handle select all click\n const handleSelectAllClick = (propagate?: boolean) => {\n if (isDisabled || props.selectionMode !== 'multiple') return;\n\n if (selectAllState.isSelected) {\n // All selected, deselect all\n listState.selectionManager.clearSelection();\n // Manually call the wrapped handler since React Aria might not trigger it\n wrappedOnSelectionChange?.(new Set());\n } else {\n // Some or none selected, select all\n listState.selectionManager.selectAll(true);\n // Manually call the wrapped handler since React Aria might not trigger it\n wrappedOnSelectionChange?.('all');\n forceUpdate({});\n }\n\n if (propagate && !selectAllState.isSelected) {\n onOptionClick?.('__ALL__');\n }\n };\n\n // Track whether the last focus change was due to keyboard navigation\n const lastFocusSourceRef = useRef<'keyboard' | 'mouse' | 'other'>('other');\n\n // Expose the list state instance via the provided ref (if any)\n if (stateRef) {\n stateRef.current = {\n ...listState,\n lastFocusSourceRef,\n };\n }\n\n // Warn if isCheckable is false in single selection mode\n useWarn(isCheckable === false && props.selectionMode === 'single', {\n key: ['listbox-checkable-single-mode'],\n args: [\n 'CubeUIKit: isCheckable=false is not recommended in single selection mode as it may confuse users about selection behavior.',\n ],\n });\n\n // Custom keyboard handling to prevent selection clearing on Escape while allowing overlay dismiss\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n // Mark focus changes from keyboard navigation\n if (\n e.key === 'ArrowDown' ||\n e.key === 'ArrowUp' ||\n e.key === 'Home' ||\n e.key === 'End' ||\n e.key === 'PageUp' ||\n e.key === 'PageDown'\n ) {\n lastFocusSourceRef.current = 'keyboard';\n }\n\n if (e.key === 'Escape' && onEscape) {\n // Don't prevent default - let the overlay system handle closing\n // But we'll call onEscape to potentially override the default selection clearing\n onEscape();\n }\n },\n });\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n ref = useCombinedRefs(ref);\n listRef = useCombinedRefs(listRef);\n\n const { listBoxProps } = useListBox(\n {\n ...props,\n id: id,\n 'aria-label': props['aria-label'] || label?.toString(),\n isDisabled,\n isVirtualized: true,\n shouldUseVirtualFocus: shouldUseVirtualFocus ?? false,\n escapeKeyBehavior: onEscape ? 'none' : 'clearSelection',\n },\n listState,\n listRef,\n );\n\n const { isFocused, focusProps } = useFocus({ isDisabled });\n const isInvalid = validationState === 'invalid';\n\n // ----- Virtualization logic -----\n const itemsArray = useMemo(\n () => [...listState.collection],\n [listState.collection],\n );\n\n const hasSections = useMemo(\n () => itemsArray.some((i) => i.type === 'section'),\n [itemsArray],\n );\n\n const shouldVirtualize = !hasSections;\n\n // Use ref to ensure estimateSize always accesses current itemsArray\n const itemsArrayRef = useRef(itemsArray);\n itemsArrayRef.current = itemsArray;\n\n // Scroll container ref for virtualization\n const scrollRef = useRef<HTMLDivElement>(null);\n\n const rowVirtualizer = useVirtualizer({\n count: shouldVirtualize ? itemsArray.length : 0,\n getScrollElement: () => scrollRef.current,\n // Use the actual item key to ensure React properly reconciles DOM elements\n // when items are filtered, added, or removed. Without this, the virtualizer\n // uses index-based keys which causes DOM reuse issues and style leaking.\n getItemKey: (index: number) => {\n const item = itemsArrayRef.current[index];\n return item?.key ?? index;\n },\n estimateSize: (index: number) => {\n const currentItem: any = itemsArrayRef.current[index];\n\n if (currentItem?.props?.description) {\n return SIZES.XL + 1;\n }\n return SIZES[SIZE_NAME_TO_KEY[size] as keyof typeof SIZES] + 1;\n },\n measureElement: (el) => {\n return el.offsetHeight + 1;\n },\n overscan: 10,\n });\n\n // Trigger remeasurement when items change (for filtering scenarios)\n useEffect(() => {\n if (shouldVirtualize) {\n rowVirtualizer.measure();\n }\n }, [shouldVirtualize, itemsArray, rowVirtualizer]);\n\n // Keep focused item visible, but only for keyboard navigation\n useLayoutEffect(() => {\n const focusedKey = listState.selectionManager.focusedKey;\n if (focusedKey == null) return;\n\n // Only scroll on keyboard navigation\n if (lastFocusSourceRef.current !== 'keyboard') return;\n\n const scrollElement = scrollRef.current;\n if (!scrollElement) return;\n\n const itemElement = scrollElement.querySelector(\n `[data-key=\"${CSS.escape(String(focusedKey))}\"]`,\n ) as HTMLElement;\n if (!itemElement) return;\n\n const scrollTop = scrollElement.scrollTop;\n const viewportHeight = scrollElement.clientHeight;\n const viewportBottom = scrollTop + viewportHeight;\n\n const itemRect = itemElement.getBoundingClientRect();\n const scrollRect = scrollElement.getBoundingClientRect();\n\n // Calculate item position relative to scroll container\n const itemTop = itemRect.top - scrollRect.top + scrollTop;\n const itemBottom = itemTop + itemRect.height;\n\n // Check if the item is fully visible in the viewport\n const isAlreadyVisible =\n itemTop >= scrollTop && itemBottom <= viewportBottom;\n\n if (!isAlreadyVisible) {\n // Use scrollIntoView with block: 'nearest' to minimize scroll jumps\n itemElement.scrollIntoView({ block: 'nearest', behavior: 'auto' });\n }\n }, [listState.selectionManager.focusedKey, itemsArray]);\n\n // Merge React Aria listbox props with custom keyboard props so both sets of\n // event handlers (e.g. Arrow navigation *and* our Escape handler) are\n // preserved.\n const mergedListBoxProps = mergeProps(listBoxProps, keyboardProps);\n\n const mods = useMemo(\n () => ({\n invalid: isInvalid,\n valid: validationState === 'valid',\n disabled: isDisabled,\n focused: isFocused,\n header: !!header || (showSelectAll && props.selectionMode === 'multiple'),\n footer: !!footer,\n selectAll: showSelectAll && props.selectionMode === 'multiple',\n ...externalMods,\n }),\n [\n isInvalid,\n validationState,\n isDisabled,\n isFocused,\n header,\n footer,\n showSelectAll,\n props.selectionMode,\n externalMods,\n ],\n );\n\n const listBoxField = (\n <ListBoxWrapperElement\n ref={ref}\n qa=\"ListBoxWrapper\"\n mods={mods}\n styles={styles}\n data-shape={shape}\n >\n {header ? (\n <StyledHeader styles={headerStyles} data-size={size}>\n {header}\n </StyledHeader>\n ) : (\n <div role=\"presentation\" />\n )}\n {showSelectAll && props.selectionMode === 'multiple' ? (\n <SelectAllOption\n label={selectAllLabel || 'Select All'}\n state={listState}\n lastFocusSourceRef={lastFocusSourceRef}\n isSelected={selectAllState.isSelected}\n isIndeterminate={selectAllState.isIndeterminate}\n isDisabled={isDisabled}\n isCheckable={isCheckable}\n size={size}\n allValueProps={allValueProps}\n onClick={handleSelectAllClick}\n />\n ) : (\n <>\n <div role=\"presentation\" />\n <div role=\"presentation\" />\n </>\n )}\n {/* Scroll container wrapper */}\n <ListBoxScrollElement ref={scrollRef} mods={mods} {...focusProps}>\n {listState.collection.size === 0 ? (\n <Item preset=\"t4\" color=\"#dark-03\" size={size} padding=\"(.5x - 1bw)\">\n {emptyLabel}\n </Item>\n ) : (\n <ListElement\n qa={qa || 'ListBox'}\n {...mergedListBoxProps}\n ref={listRef}\n styles={listStyles}\n aria-disabled={isDisabled || undefined}\n mods={{ sections: hasSections }}\n data-shape={shape}\n data-input-type=\"listbox\"\n style={\n shouldVirtualize\n ? {\n position: 'relative',\n height: `${rowVirtualizer.getTotalSize() + 3}px`,\n }\n : undefined\n }\n >\n {shouldVirtualize\n ? rowVirtualizer.getVirtualItems().map((virtualItem) => {\n const item = itemsArray[virtualItem.index];\n\n return (\n <Option\n key={item.key}\n size={size}\n item={item}\n state={listState}\n styles={optionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n // We don't need to measure the element here, because the height is already set by the virtualizer\n // This is a workaround to avoid glitches when selecting/deselecting items\n virtualRef={rowVirtualizer.measureElement as any}\n virtualStyle={{\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n virtualIndex={virtualItem.index}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />\n );\n })\n : (() => {\n const renderedItems: ReactNode[] = [];\n let isFirstSection = true;\n\n for (const item of listState.collection) {\n if (item.type === 'section') {\n if (!isFirstSection) {\n renderedItems.push(\n <StyledDivider\n key={`divider-${String(item.key)}`}\n role=\"separator\"\n aria-orientation=\"horizontal\"\n />,\n );\n }\n\n renderedItems.push(\n <ListBoxSection\n key={item.key}\n item={item}\n state={listState}\n optionStyles={optionStyles}\n headingStyles={headingStyles}\n sectionStyles={sectionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n size={size}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />,\n );\n\n isFirstSection = false;\n } else {\n renderedItems.push(\n <Option\n key={item.key}\n size={size}\n item={item}\n state={listState}\n styles={optionStyles}\n isParentDisabled={isDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />,\n );\n }\n }\n\n return renderedItems;\n })()}\n </ListElement>\n )}\n </ListBoxScrollElement>\n {footer ? (\n <StyledFooter styles={footerStyles} data-size={size}>\n {footer}\n </StyledFooter>\n ) : (\n <div role=\"presentation\" />\n )}\n </ListBoxWrapperElement>\n );\n\n return wrapWithField<Omit<CubeListBoxProps<T>, 'children'>>(\n listBoxField,\n ref,\n props,\n );\n}) as unknown as (<T>(\n props: CubeListBoxProps<T> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement) & {\n Item: typeof CollectionItem;\n Section: typeof BaseSection;\n};\n\nfunction Option({\n size = 'medium',\n item,\n state,\n styles,\n isParentDisabled,\n validationState,\n focusOnHover = false,\n isCheckable,\n onClick: onOptionClick,\n virtualStyle,\n virtualRef,\n virtualIndex,\n lastFocusSourceRef,\n}: {\n size?: 'small' | 'medium' | 'large';\n item: any;\n state: any;\n styles?: Styles;\n isParentDisabled?: boolean;\n validationState?: any;\n focusOnHover?: boolean;\n isCheckable?: boolean;\n onClick?: (key: Key) => void;\n /** Inline style applied when virtualized (absolute positioning etc.) */\n virtualStyle?: CSSProperties;\n /** Ref callback from react-virtual to measure row height */\n virtualRef?: (element: HTMLElement | null) => void;\n /** Virtual index from react-virtual for data-index attribute */\n virtualIndex?: number;\n /** Ref to track the source of focus changes */\n lastFocusSourceRef?: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n}) {\n const localRef = useRef<HTMLLIElement>(null);\n // Merge local ref with react-virtual measure ref when provided\n const combinedRef = useCombinedRefs(localRef, virtualRef);\n\n const isDisabled = isParentDisabled || state.disabledKeys.has(item.key);\n const isSelected = state.selectionManager.isSelected(item.key);\n const isFocused = state.selectionManager.focusedKey === item.key;\n\n const { hoverProps, isHovered } = useHover({ isDisabled });\n\n const { optionProps, isPressed, labelProps, descriptionProps } = useOption(\n {\n key: item.key,\n isDisabled,\n isSelected,\n shouldSelectOnPressUp: true,\n shouldFocusOnHover: focusOnHover,\n },\n state,\n combinedRef,\n );\n\n // Filter out service props - all remaining props can be passed to Item\n const filteredItemProps = filterCollectionItemProps(item.props);\n\n // Create checkbox icon for multiple selection mode\n const effectiveIcon = useMemo(() => {\n if (\n !isCheckable ||\n state.selectionManager.selectionMode !== 'multiple' ||\n filteredItemProps.icon\n ) {\n return (\n filteredItemProps.icon ??\n (state.selectionManager.selectionMode !== 'multiple' ? null : undefined)\n );\n }\n\n return (\n <ListBoxCheckboxWrapper\n data-element=\"CheckboxWrapper\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n }}\n >\n <ListBoxCheckbox\n data-element=\"Checkbox\"\n mods={{\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n }}\n >\n <CheckIcon size={12} stroke={3} />\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\n );\n }, [\n isCheckable,\n state.selectionManager.selectionMode,\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n filteredItemProps.icon,\n ]);\n\n // Custom click handler for the entire option\n const handleOptionClick = (e) => {\n // Mark focus changes from mouse clicks\n if (lastFocusSourceRef) {\n lastFocusSourceRef.current = 'mouse';\n }\n\n // If there's an onOptionClick callback and this is checkable in multiple mode,\n // we need to distinguish between checkbox and content clicks\n if (\n onOptionClick &&\n isCheckable &&\n state.selectionManager.selectionMode === 'multiple'\n ) {\n // Check if the click target is within the checkbox area\n const clickTarget = e.target as HTMLElement;\n const checkboxElement = localRef.current?.querySelector(\n '[data-element=\"CheckboxWrapper\"]',\n );\n\n if (\n checkboxElement &&\n (checkboxElement === clickTarget ||\n checkboxElement.contains(clickTarget))\n ) {\n // Checkbox area clicked - only toggle, don't call onOptionClick\n // Let React Aria handle the selection\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n } else {\n // Content area clicked - toggle and trigger callback\n // Let React Aria handle the selection first\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n // Then call the callback (which will close the popover in FilterPicker)\n if (onOptionClick) {\n onOptionClick(item.key);\n }\n }\n } else {\n // Normal behavior - let React Aria handle it\n optionProps.onClick?.(e);\n // Set focus to the clicked item\n state.selectionManager.setFocusedKey(item.key);\n // Call onOptionClick if provided\n if (onOptionClick) {\n onOptionClick(item.key);\n }\n }\n };\n\n // Filter out React Aria props that shouldn't reach the DOM\n const {\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n ...filteredOptionProps\n } = optionProps;\n\n const theme =\n { valid: 'success', invalid: 'danger' }[validationState] || 'default';\n\n return (\n <ListBoxItem\n ref={combinedRef}\n id={`ListBoxItem-${String(item.key)}`}\n data-key={String(item.key)}\n {...mergeProps(filteredOptionProps, hoverProps, filteredItemProps, {\n onClick: handleOptionClick,\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n })}\n theme={theme}\n style={virtualStyle}\n data-size={size}\n data-index={virtualIndex}\n size={size}\n isSelected={isSelected}\n isDisabled={isDisabled}\n icon={effectiveIcon}\n labelProps={labelProps}\n descriptionProps={descriptionProps}\n styles={mergeStyles(styles, filteredItemProps.styles)}\n defaultTooltipPlacement=\"right\"\n mods={{\n listboxitem: true,\n focused: isFocused,\n pressed: isPressed,\n valid: isSelected && validationState === 'valid',\n invalid: isSelected && validationState === 'invalid',\n checkable: isCheckable,\n hovered: isHovered,\n all: false, // This will be set to true for SelectAllOption\n }}\n >\n {item.rendered}\n </ListBoxItem>\n );\n}\n\ninterface ListBoxSectionProps<T> {\n item: any;\n state: any;\n optionStyles?: Styles;\n headingStyles?: Styles;\n sectionStyles?: Styles;\n isParentDisabled?: boolean;\n validationState?: any;\n focusOnHover?: boolean;\n isCheckable?: boolean;\n onClick?: (key: Key) => void;\n size?: 'small' | 'medium' | 'large';\n lastFocusSourceRef?: MutableRefObject<'keyboard' | 'mouse' | 'other'>;\n}\n\nfunction ListBoxSection<T>(props: ListBoxSectionProps<T>) {\n const {\n item,\n state,\n optionStyles,\n headingStyles,\n sectionStyles,\n isParentDisabled,\n validationState,\n focusOnHover,\n isCheckable,\n onClick: onOptionClick,\n lastFocusSourceRef,\n } = props;\n const heading = item.rendered;\n\n const { itemProps, headingProps, groupProps } = useListBoxSection({\n heading,\n 'aria-label': item['aria-label'],\n });\n\n return (\n <SectionWrapperElement {...itemProps} styles={sectionStyles}>\n {heading && (\n <StyledSectionHeading\n {...headingProps}\n size={props.size}\n styles={headingStyles}\n >\n {heading}\n </StyledSectionHeading>\n )}\n <SectionListElement {...groupProps}>\n {[...item.childNodes]\n .filter((node: any) => state.collection.getItem(node.key))\n .map((node: any) => (\n <Option\n key={node.key}\n size={props.size}\n item={node}\n state={state}\n styles={optionStyles}\n isParentDisabled={isParentDisabled}\n validationState={validationState}\n focusOnHover={focusOnHover}\n isCheckable={isCheckable}\n lastFocusSourceRef={lastFocusSourceRef}\n onClick={onOptionClick}\n />\n ))}\n </SectionListElement>\n </SectionWrapperElement>\n );\n}\n\ntype SectionComponent = typeof BaseSection;\n\nconst ListBoxSectionComponent = Object.assign(BaseSection, {\n displayName: 'Section',\n}) as SectionComponent;\n\nListBox.Item = CollectionItem;\n\nListBox.Section = ListBoxSectionComponent;\n\nObject.defineProperty(ListBox, 'cubeInputType', {\n value: 'ListBox',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
@@ -1,11 +1,11 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.118.0 | Cube Dev Team */
2
- import { tasty } from "../../../tasty/tasty.js";
1
+ /** @license MIT | @cube-dev/ui-kit v0.119.1 | Cube Dev Team */
3
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
4
3
  import { useProviderProps } from "../../../provider.js";
5
4
  import { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
6
5
  import { TextInputBase } from "../TextInput/TextInputBase.js";
7
6
  import { castNullableNumberValue } from "../../../utils/react/nullableValue.js";
8
7
  import { StepButton } from "./StepButton.js";
8
+ import { tasty } from "@tenphi/tasty";
9
9
  import { forwardRef, useRef } from "react";
10
10
  import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
11
11
  import { useLocale, useNumberField } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"NumberInput.js","names":["mergeProps"],"sources":["../../../../src/components/fields/NumberInput/NumberInput.tsx"],"sourcesContent":["import { ForwardedRef, forwardRef, RefObject, useRef } from 'react';\nimport { AriaNumberFieldProps, useLocale, useNumberField } from 'react-aria';\nimport { useNumberFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { tasty } from '../../../tasty';\nimport { mergeProps } from '../../../utils/react';\nimport {\n castNullableNumberValue,\n WithNullableValue,\n} from '../../../utils/react/nullableValue';\nimport { useFieldProps } from '../../form';\nimport { CubeTextInputBaseProps, TextInputBase } from '../TextInput';\n\nimport { StepButton } from './StepButton';\n\nexport interface CubeNumberInputProps\n extends Omit<CubeTextInputBaseProps, 'defaultValue' | 'value' | 'onChange'>,\n Omit<AriaNumberFieldProps, 'validate'> {\n /** Whether or to hide stepper */\n hideStepper?: boolean;\n}\n\nconst StyledTextInputBase = tasty(TextInputBase, {\n inputStyles: {\n textAlign: 'right',\n },\n});\n\nconst StepperContainer = tasty({\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: '1sf 1sf',\n flow: 'column',\n placeSelf: 'stretch',\n margin: '(.5x - 1bw) left',\n },\n});\n\nfunction NumberInput(\n props: WithNullableValue<CubeNumberInputProps>,\n ref: ForwardedRef<HTMLElement>,\n) {\n props = castNullableNumberValue(props);\n props = useProviderProps(props);\n props = useFieldProps(props);\n\n let {\n hideStepper,\n suffix,\n value,\n defaultValue,\n onChange,\n inputRef,\n labelProps: userLabelProps,\n ...otherProps\n } = props;\n let showStepper = !hideStepper;\n let { locale } = useLocale();\n let state = useNumberFieldState({ ...props, locale });\n let localInputRef = useRef<HTMLInputElement>(null);\n\n inputRef = inputRef ?? localInputRef;\n\n let {\n groupProps,\n labelProps,\n inputProps,\n incrementButtonProps,\n decrementButtonProps,\n } = useNumberField(props, state, inputRef as RefObject<HTMLInputElement>);\n\n // Merge user-provided labelProps with aria labelProps\n const mergedLabelProps = mergeProps(labelProps, userLabelProps);\n\n const steppers = showStepper ? (\n <StepperContainer>\n <StepButton\n isDisabled={props.isDisabled}\n direction=\"up\"\n {...incrementButtonProps}\n size={otherProps.size}\n />\n <StepButton\n isDisabled={props.isDisabled}\n direction=\"down\"\n {...decrementButtonProps}\n size={otherProps.size}\n />\n </StepperContainer>\n ) : undefined;\n\n return (\n <StyledTextInputBase\n {...otherProps}\n ref={ref}\n labelProps={mergedLabelProps}\n inputProps={{ ...inputProps, 'data-input-type': 'numberinput' }}\n inputRef={inputRef}\n wrapperProps={groupProps}\n suffixPosition=\"after\"\n suffix={\n showStepper ? (\n props.suffixPosition === 'before' ? (\n <>\n {suffix}\n {steppers}\n </>\n ) : (\n <>\n {steppers}\n {suffix}\n </>\n )\n ) : (\n suffix\n )\n }\n />\n );\n}\n\n/**\n * NumberFields allow users to enter a number and increment or decrement the value using stepper buttons.\n */\nconst _NumberInput = forwardRef(NumberInput);\n\n(_NumberInput as any).cubeInputType = 'Number';\n\n_NumberInput.displayName = 'NumberInput';\n\nexport { _NumberInput as NumberInput };\nexport type { AriaNumberFieldProps };\n"],"mappings":";;;;;;;;;;;;;;AAuBA,MAAM,sBAAsB,MAAM,eAAe,EAC/C,aAAa,EACX,WAAW,SACZ,EACF,CAAC;AAEF,MAAM,mBAAmB,MAAM,EAC7B,QAAQ;CACN,SAAS;CACT,aAAa;CACb,UAAU;CACV,MAAM;CACN,WAAW;CACX,QAAQ;CACT,EACF,CAAC;AAEF,SAAS,YACP,OACA,KACA;AACA,SAAQ,wBAAwB,MAAM;AACtC,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,cAAc,MAAM;CAE5B,IAAI,EACF,aACA,QACA,OACA,cACA,UACA,UACA,YAAY,gBACZ,GAAG,eACD;CACJ,IAAI,cAAc,CAAC;CACnB,IAAI,EAAE,WAAW,WAAW;CAC5B,IAAI,QAAQ,oBAAoB;EAAE,GAAG;EAAO;EAAQ,CAAC;CACrD,IAAI,gBAAgB,OAAyB,KAAK;AAElD,YAAW,YAAY;CAEvB,IAAI,EACF,YACA,YACA,YACA,sBACA,yBACE,eAAe,OAAO,OAAO,SAAwC;CAGzE,MAAM,mBAAmBA,aAAW,YAAY,eAAe;CAE/D,MAAM,WAAW,cACf,qBAAC,+BACC,oBAAC;EACC,YAAY,MAAM;EAClB,WAAU;EACV,GAAI;EACJ,MAAM,WAAW;GACjB,EACF,oBAAC;EACC,YAAY,MAAM;EAClB,WAAU;EACV,GAAI;EACJ,MAAM,WAAW;GACjB,IACe,GACjB;AAEJ,QACE,oBAAC;EACC,GAAI;EACC;EACL,YAAY;EACZ,YAAY;GAAE,GAAG;GAAY,mBAAmB;GAAe;EACrD;EACV,cAAc;EACd,gBAAe;EACf,QACE,cACE,MAAM,mBAAmB,WACvB,8CACG,QACA,YACA,GAEH,8CACG,UACA,UACA,GAGL;GAGJ;;;;;AAON,MAAM,eAAe,WAAW,YAAY;AAE5C,AAAC,aAAqB,gBAAgB;AAEtC,aAAa,cAAc"}
1
+ {"version":3,"file":"NumberInput.js","names":["mergeProps"],"sources":["../../../../src/components/fields/NumberInput/NumberInput.tsx"],"sourcesContent":["import { tasty } from '@tenphi/tasty';\nimport { ForwardedRef, forwardRef, RefObject, useRef } from 'react';\nimport { AriaNumberFieldProps, useLocale, useNumberField } from 'react-aria';\nimport { useNumberFieldState } from 'react-stately';\n\nimport { useProviderProps } from '../../../provider';\nimport { mergeProps } from '../../../utils/react';\nimport {\n castNullableNumberValue,\n WithNullableValue,\n} from '../../../utils/react/nullableValue';\nimport { useFieldProps } from '../../form';\nimport { CubeTextInputBaseProps, TextInputBase } from '../TextInput';\n\nimport { StepButton } from './StepButton';\n\nexport interface CubeNumberInputProps\n extends Omit<CubeTextInputBaseProps, 'defaultValue' | 'value' | 'onChange'>,\n Omit<AriaNumberFieldProps, 'validate'> {\n /** Whether or to hide stepper */\n hideStepper?: boolean;\n}\n\nconst StyledTextInputBase = tasty(TextInputBase, {\n inputStyles: {\n textAlign: 'right',\n },\n});\n\nconst StepperContainer = tasty({\n styles: {\n display: 'grid',\n gridColumns: '1sf',\n gridRows: '1sf 1sf',\n flow: 'column',\n placeSelf: 'stretch',\n margin: '(.5x - 1bw) left',\n },\n});\n\nfunction NumberInput(\n props: WithNullableValue<CubeNumberInputProps>,\n ref: ForwardedRef<HTMLElement>,\n) {\n props = castNullableNumberValue(props);\n props = useProviderProps(props);\n props = useFieldProps(props);\n\n let {\n hideStepper,\n suffix,\n value,\n defaultValue,\n onChange,\n inputRef,\n labelProps: userLabelProps,\n ...otherProps\n } = props;\n let showStepper = !hideStepper;\n let { locale } = useLocale();\n let state = useNumberFieldState({ ...props, locale });\n let localInputRef = useRef<HTMLInputElement>(null);\n\n inputRef = inputRef ?? localInputRef;\n\n let {\n groupProps,\n labelProps,\n inputProps,\n incrementButtonProps,\n decrementButtonProps,\n } = useNumberField(props, state, inputRef as RefObject<HTMLInputElement>);\n\n // Merge user-provided labelProps with aria labelProps\n const mergedLabelProps = mergeProps(labelProps, userLabelProps);\n\n const steppers = showStepper ? (\n <StepperContainer>\n <StepButton\n isDisabled={props.isDisabled}\n direction=\"up\"\n {...incrementButtonProps}\n size={otherProps.size}\n />\n <StepButton\n isDisabled={props.isDisabled}\n direction=\"down\"\n {...decrementButtonProps}\n size={otherProps.size}\n />\n </StepperContainer>\n ) : undefined;\n\n return (\n <StyledTextInputBase\n {...otherProps}\n ref={ref}\n labelProps={mergedLabelProps}\n inputProps={{ ...inputProps, 'data-input-type': 'numberinput' }}\n inputRef={inputRef}\n wrapperProps={groupProps}\n suffixPosition=\"after\"\n suffix={\n showStepper ? (\n props.suffixPosition === 'before' ? (\n <>\n {suffix}\n {steppers}\n </>\n ) : (\n <>\n {steppers}\n {suffix}\n </>\n )\n ) : (\n suffix\n )\n }\n />\n );\n}\n\n/**\n * NumberFields allow users to enter a number and increment or decrement the value using stepper buttons.\n */\nconst _NumberInput = forwardRef(NumberInput);\n\n(_NumberInput as any).cubeInputType = 'Number';\n\n_NumberInput.displayName = 'NumberInput';\n\nexport { _NumberInput as NumberInput };\nexport type { AriaNumberFieldProps };\n"],"mappings":";;;;;;;;;;;;;;AAuBA,MAAM,sBAAsB,MAAM,eAAe,EAC/C,aAAa,EACX,WAAW,SACZ,EACF,CAAC;AAEF,MAAM,mBAAmB,MAAM,EAC7B,QAAQ;CACN,SAAS;CACT,aAAa;CACb,UAAU;CACV,MAAM;CACN,WAAW;CACX,QAAQ;CACT,EACF,CAAC;AAEF,SAAS,YACP,OACA,KACA;AACA,SAAQ,wBAAwB,MAAM;AACtC,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,cAAc,MAAM;CAE5B,IAAI,EACF,aACA,QACA,OACA,cACA,UACA,UACA,YAAY,gBACZ,GAAG,eACD;CACJ,IAAI,cAAc,CAAC;CACnB,IAAI,EAAE,WAAW,WAAW;CAC5B,IAAI,QAAQ,oBAAoB;EAAE,GAAG;EAAO;EAAQ,CAAC;CACrD,IAAI,gBAAgB,OAAyB,KAAK;AAElD,YAAW,YAAY;CAEvB,IAAI,EACF,YACA,YACA,YACA,sBACA,yBACE,eAAe,OAAO,OAAO,SAAwC;CAGzE,MAAM,mBAAmBA,aAAW,YAAY,eAAe;CAE/D,MAAM,WAAW,cACf,qBAAC,+BACC,oBAAC;EACC,YAAY,MAAM;EAClB,WAAU;EACV,GAAI;EACJ,MAAM,WAAW;GACjB,EACF,oBAAC;EACC,YAAY,MAAM;EAClB,WAAU;EACV,GAAI;EACJ,MAAM,WAAW;GACjB,IACe,GACjB;AAEJ,QACE,oBAAC;EACC,GAAI;EACC;EACL,YAAY;EACZ,YAAY;GAAE,GAAG;GAAY,mBAAmB;GAAe;EACrD;EACV,cAAc;EACd,gBAAe;EACf,QACE,cACE,MAAM,mBAAmB,WACvB,8CACG,QACA,YACA,GAEH,8CACG,UACA,UACA,GAGL;GAGJ;;;;;AAON,MAAM,eAAe,WAAW,YAAY;AAE5C,AAAC,aAAqB,gBAAgB;AAEtC,aAAa,cAAc"}
@@ -1,7 +1,7 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.118.0 | Cube Dev Team */
2
- import { tasty } from "../../../tasty/tasty.js";
1
+ /** @license MIT | @cube-dev/ui-kit v0.119.1 | Cube Dev Team */
3
2
  import { DirectionIcon } from "../../../icons/DirectionIcon.js";
4
3
  import { Button } from "../../actions/index.js";
4
+ import { tasty } from "@tenphi/tasty";
5
5
  import { jsx } from "react/jsx-runtime";
6
6
 
7
7
  //#region src/components/fields/NumberInput/StepButton.tsx
@@ -1 +1 @@
1
- {"version":3,"file":"StepButton.js","names":[],"sources":["../../../../src/components/fields/NumberInput/StepButton.tsx"],"sourcesContent":["import { CaretDownIcon, CaretUpIcon, DirectionIcon } from '../../../icons';\nimport { Styles, tasty } from '../../../tasty';\nimport { Button } from '../../actions';\n\nconst StepButtonElement = tasty(Button, {\n preventDefault: true,\n type: 'neutral',\n styles: {\n width: '2.5x',\n height: 'auto',\n radius: {\n '': '0 (1r - 1bw) 0 0',\n down: '0 0 (1r - 1bw) 0',\n },\n padding: 0,\n\n '$icon-size': '1fs',\n\n Icon: {\n width: 'auto',\n height: 'auto',\n },\n },\n});\n\n/**\n * Buttons for NumberField.\n */\nexport function StepButton(props) {\n return (\n <StepButtonElement\n preventDefault\n type=\"neutral\"\n mods={{\n up: props.direction === 'up',\n down: props.direction === 'down',\n }}\n label={`Step ${props.direction}`}\n {...props}\n >\n <DirectionIcon to={props.direction} />\n </StepButtonElement>\n );\n}\n"],"mappings":";;;;;;;AAIA,MAAM,oBAAoB,MAAM,QAAQ;CACtC,gBAAgB;CAChB,MAAM;CACN,QAAQ;EACN,OAAO;EACP,QAAQ;EACR,QAAQ;GACN,IAAI;GACJ,MAAM;GACP;EACD,SAAS;EAET,cAAc;EAEd,MAAM;GACJ,OAAO;GACP,QAAQ;GACT;EACF;CACF,CAAC;;;;AAKF,SAAgB,WAAW,OAAO;AAChC,QACE,oBAAC;EACC;EACA,MAAK;EACL,MAAM;GACJ,IAAI,MAAM,cAAc;GACxB,MAAM,MAAM,cAAc;GAC3B;EACD,OAAO,QAAQ,MAAM;EACrB,GAAI;YAEJ,oBAAC,iBAAc,IAAI,MAAM,YAAa;GACpB"}
1
+ {"version":3,"file":"StepButton.js","names":[],"sources":["../../../../src/components/fields/NumberInput/StepButton.tsx"],"sourcesContent":["import { Styles, tasty } from '@tenphi/tasty';\n\nimport { CaretDownIcon, CaretUpIcon, DirectionIcon } from '../../../icons';\nimport { Button } from '../../actions';\n\nconst StepButtonElement = tasty(Button, {\n preventDefault: true,\n type: 'neutral',\n styles: {\n width: '2.5x',\n height: 'auto',\n radius: {\n '': '0 (1r - 1bw) 0 0',\n down: '0 0 (1r - 1bw) 0',\n },\n padding: 0,\n\n '$icon-size': '1fs',\n\n Icon: {\n width: 'auto',\n height: 'auto',\n },\n },\n});\n\n/**\n * Buttons for NumberField.\n */\nexport function StepButton(props) {\n return (\n <StepButtonElement\n preventDefault\n type=\"neutral\"\n mods={{\n up: props.direction === 'up',\n down: props.direction === 'down',\n }}\n label={`Step ${props.direction}`}\n {...props}\n >\n <DirectionIcon to={props.direction} />\n </StepButtonElement>\n );\n}\n"],"mappings":";;;;;;;AAKA,MAAM,oBAAoB,MAAM,QAAQ;CACtC,gBAAgB;CAChB,MAAM;CACN,QAAQ;EACN,OAAO;EACP,QAAQ;EACR,QAAQ;GACN,IAAI;GACJ,MAAM;GACP;EACD,SAAS;EAET,cAAc;EAEd,MAAM;GACJ,OAAO;GACP,QAAQ;GACT;EACF;CACF,CAAC;;;;AAKF,SAAgB,WAAW,OAAO;AAChC,QACE,oBAAC;EACC;EACA,MAAK;EACL,MAAM;GACJ,IAAI,MAAM,cAAc;GACxB,MAAM,MAAM,cAAc;GAC3B;EACD,OAAO,QAAQ,MAAM;EACrB,GAAI;YAEJ,oBAAC,iBAAc,IAAI,MAAM,YAAa;GACpB"}
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.118.0 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.119.1 | Cube Dev Team */
2
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
3
  import { useProviderProps } from "../../../provider.js";
4
4
  import { ItemAction } from "../../actions/ItemAction/ItemAction.js";
@@ -1,7 +1,4 @@
1
1
 
2
- import { Styles } from "../../../tasty/styles/types.js";
3
- import { BasePropsWithoutChildren, BaseStyleProps, ColorStyleProps, OuterStyleProps } from "../../../tasty/types.js";
4
- import "../../../tasty/index.js";
5
2
  import { FieldBaseProps } from "../../../shared/form.js";
6
3
  import "../../../shared/index.js";
7
4
  import "../../content/Item/index.js";
@@ -9,6 +6,7 @@ import { CubeItemProps } from "../../content/Item/Item.js";
9
6
  import { CubeItemButtonProps } from "../../actions/ItemButton/ItemButton.js";
10
7
  import "../../actions/index.js";
11
8
  import { CubeListBoxProps, ListBox } from "../ListBox/ListBox.js";
9
+ import { BasePropsWithoutChildren, BaseStyleProps, ColorStyleProps, OuterStyleProps, Styles } from "@tenphi/tasty";
12
10
  import { ForwardedRef, MutableRefObject, ReactElement, ReactNode } from "react";
13
11
  import { ListState, Section } from "react-stately";
14
12
 
@@ -1,8 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.118.0 | Cube Dev Team */
2
- import { extractStyles } from "../../../tasty/utils/styles.js";
3
- import { BASE_STYLES, COLOR_STYLES, OUTER_STYLES } from "../../../tasty/styles/list.js";
4
- import { tasty } from "../../../tasty/tasty.js";
5
- import { filterBaseProps } from "../../../tasty/utils/filter-base-props.js";
1
+ /** @license MIT | @cube-dev/ui-kit v0.119.1 | Cube Dev Team */
6
2
  import { useEventBus } from "../../../utils/react/useEventBus.js";
7
3
  import { useEvent } from "../../../_internal/hooks/use-event.js";
8
4
  import { _Text } from "../../content/Text.js";
@@ -20,6 +16,7 @@ import { wrapWithField } from "../../form/wrapper.js";
20
16
  import { Dialog } from "../../overlays/Dialog/Dialog.js";
21
17
  import { DialogTrigger } from "../../overlays/Dialog/DialogTrigger.js";
22
18
  import { ListBox } from "../ListBox/ListBox.js";
19
+ import { BASE_STYLES, COLOR_STYLES, OUTER_STYLES, extractStyles, filterBaseProps, tasty } from "@tenphi/tasty";
23
20
  import { forwardRef, useCallback, useEffect, useMemo, useRef, useState } from "react";
24
21
  import { jsx, jsxs } from "react/jsx-runtime";
25
22
  import { FocusScope, useKeyboard } from "react-aria";
@@ -1 +1 @@
1
- {"version":3,"file":"Picker.js","names":["Text","ItemButton","BaseSection"],"sources":["../../../../src/components/fields/Picker/Picker.tsx"],"sourcesContent":["import { CollectionChildren, FocusableRefValue } from '@react-types/shared';\nimport {\n ForwardedRef,\n forwardRef,\n MutableRefObject,\n ReactElement,\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { FocusScope, Key, useKeyboard } from 'react-aria';\nimport { Section as BaseSection, ListState, useListState } from 'react-stately';\n\nimport { useEvent } from '../../../_internal';\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CloseIcon, DirectionIcon, LoadingIcon } from '../../../icons';\nimport { useProviderProps } from '../../../provider';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n BaseStyleProps,\n COLOR_STYLES,\n ColorStyleProps,\n extractStyles,\n filterBaseProps,\n OUTER_STYLES,\n OuterStyleProps,\n Styles,\n tasty,\n} from '../../../tasty';\nimport { generateRandomId } from '../../../utils/random';\nimport { useEventBus } from '../../../utils/react/useEventBus';\nimport { CubeItemButtonProps, ItemAction, ItemButton } from '../../actions';\nimport { CubeItemProps } from '../../content/Item';\nimport { Text } from '../../content/Text';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\nimport { CubeListBoxProps, ListBox } from '../ListBox/ListBox';\n\nimport type { FieldBaseProps } from '../../../shared';\n\nexport interface CubePickerProps<T>\n extends Omit<CubeListBoxProps<T>, 'size' | 'tooltip' | 'shape'>,\n Omit<CubeItemProps, 'children' | 'size'>,\n BasePropsWithoutChildren,\n BaseStyleProps,\n OuterStyleProps,\n ColorStyleProps,\n Omit<FieldBaseProps, 'tooltip'>,\n Pick<\n CubeItemButtonProps,\n | 'type'\n | 'theme'\n | 'icon'\n | 'rightIcon'\n | 'prefix'\n | 'suffix'\n | 'hotkeys'\n | 'shape'\n > {\n /** Placeholder text when no selection is made */\n placeholder?: string;\n /** Size of the picker component */\n size?: 'small' | 'medium' | 'large';\n /** Custom styles for the list box popover */\n listBoxStyles?: Styles;\n /** Custom styles for the popover container */\n popoverStyles?: Styles;\n /** Custom styles for the trigger button */\n triggerStyles?: Styles;\n /** Whether to show checkboxes for multiple selection mode */\n isCheckable?: boolean;\n /** Whether to flip the popover placement */\n shouldFlip?: boolean;\n /** Minimum padding in pixels between the popover and viewport edges */\n containerPadding?: number;\n /** Tooltip for the trigger button (separate from field tooltip) */\n triggerTooltip?: CubeItemProps['tooltip'];\n /** Description for the trigger button (separate from field description) */\n triggerDescription?: CubeItemProps['description'];\n\n /**\n * Custom renderer for the summary shown inside the trigger when there is a selection.\n *\n * For `selectionMode=\"multiple\"` the function receives:\n * - `selectedLabels`: array of labels of the selected items.\n * - `selectedKeys`: array of keys of the selected items or \"all\".\n *\n * For `selectionMode=\"single\"` the function receives:\n * - `selectedLabel`: label of the selected item.\n * - `selectedKey`: key of the selected item.\n *\n * The function should return a `ReactNode` that will be rendered inside the trigger.\n * Set to `false` to hide the summary text completely.\n */\n renderSummary?:\n | ((args: {\n selectedLabels?: string[];\n selectedKeys?: 'all' | (string | number)[];\n selectedLabel?: string;\n selectedKey?: string | number | null;\n selectionMode?: 'single' | 'multiple';\n }) => ReactNode)\n | false;\n\n /** Ref to access internal ListBox state */\n listStateRef?: MutableRefObject<ListState<T>>;\n /** Additional modifiers for styling the Picker */\n mods?: Record<string, boolean>;\n /** Whether the picker is clearable using a clear button in the rightIcon slot */\n isClearable?: boolean;\n /** Callback called when the clear button is pressed */\n onClear?: () => void;\n /**\n * Sort selected item(s) to the top when the popover opens.\n * Only works when using the `items` prop (data-driven mode).\n * Supports both single and multiple selection modes.\n * @default true when items are provided, false when using JSX children\n */\n sortSelectedToTop?: boolean;\n /** Callback called when the popover open state changes */\n onOpenChange?: (isOpen: boolean) => void;\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nconst PickerWrapper = tasty({\n qa: 'PickerWrapper',\n styles: {\n display: 'inline-grid',\n flow: 'column',\n gridRows: '1sf',\n placeContent: 'stretch',\n placeItems: 'stretch',\n },\n});\n\nexport const Picker = forwardRef(function Picker<T extends object>(\n props: CubePickerProps<T>,\n ref: ForwardedRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n valuePropsMapper: ({ value, onChange }) => {\n const fieldProps: Record<string, unknown> = {};\n\n if (props.selectionMode === 'multiple') {\n fieldProps.selectedKeys = value || [];\n } else {\n fieldProps.selectedKey = value ?? null;\n }\n\n fieldProps.onSelectionChange = (key: Key | null | 'all' | Key[]) => {\n if (props.selectionMode === 'multiple') {\n // Handle \"all\" selection and array selections\n if (key === 'all') {\n onChange('all');\n } else {\n onChange(key ? (Array.isArray(key) ? key : [key]) : []);\n }\n } else {\n onChange(Array.isArray(key) ? key[0] : key);\n }\n };\n\n return fieldProps;\n },\n });\n\n let {\n id,\n qa,\n label,\n extra,\n icon,\n rightIcon,\n prefix,\n suffix,\n hotkeys,\n triggerTooltip,\n triggerDescription,\n labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n isLoading,\n message,\n mods: externalMods,\n description,\n descriptionPlacement,\n placeholder,\n size = 'medium',\n styles,\n listBoxStyles,\n popoverStyles,\n type = 'outline',\n theme = 'default',\n shape,\n labelSuffix,\n shouldFocusWrap,\n children,\n shouldFlip = true,\n containerPadding = 8,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n disabledKeys,\n onSelectionChange,\n selectionMode = 'single',\n listStateRef,\n focusOnHover,\n showSelectAll,\n selectAllLabel = 'All',\n items,\n header,\n footer,\n headerStyles,\n footerStyles,\n triggerStyles,\n renderSummary,\n isCheckable,\n allValueProps,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n disallowEmptySelection,\n shouldUseVirtualFocus,\n onEscape,\n onOptionClick,\n isClearable,\n onClear,\n sortSelectedToTop,\n onOpenChange,\n listStateRef: externalListStateRef,\n ...otherProps\n } = props;\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n // Generate a unique ID for this Picker instance\n const pickerId = useMemo(() => generateRandomId(), []);\n\n // Get event bus for menu synchronization\n const { emit, on } = useEventBus();\n\n // Warn if isCheckable is false in single selection mode\n useWarn(isCheckable === false && selectionMode === 'single', {\n key: ['picker-checkable-single-mode'],\n args: [\n 'CubeUIKit: isCheckable=false is not recommended in single selection mode as it may confuse users about selection behavior.',\n ],\n });\n\n // Internal selection state (uncontrolled scenario)\n const [internalSelectedKey, setInternalSelectedKey] = useState<Key | null>(\n defaultSelectedKey ?? null,\n );\n const [internalSelectedKeys, setInternalSelectedKeys] = useState<\n 'all' | Key[]\n >(defaultSelectedKeys ?? []);\n\n // Track popover open/close and capture children order for session\n const [isPopoverOpen, setIsPopoverOpen] = useState(false);\n const triggerRef = useRef<FocusableRefValue<HTMLButtonElement>>(null);\n\n const isControlledSingle = selectedKey !== undefined;\n const isControlledMultiple = selectedKeys !== undefined;\n\n const effectiveSelectedKey = isControlledSingle\n ? selectedKey\n : internalSelectedKey;\n const effectiveSelectedKeys = isControlledMultiple\n ? selectedKeys\n : internalSelectedKeys;\n\n // Given an iterable of keys (array or Set) toggle membership for duplicates\n const processSelectionArray = (iterable: Iterable<Key>): string[] => {\n const resultSet = new Set<string>();\n for (const key of iterable) {\n const nKey = String(key);\n if (resultSet.has(nKey)) {\n resultSet.delete(nKey); // toggle off if clicked twice\n } else {\n resultSet.add(nKey); // select\n }\n }\n return Array.from(resultSet);\n };\n\n // Ref to access internal ListBox state for collection API\n const internalListStateRef = useRef<ListState<T>>(null);\n\n // Sync internal ref with external ref if provided\n useEffect(() => {\n if (externalListStateRef && internalListStateRef.current) {\n externalListStateRef.current = internalListStateRef.current;\n }\n }, [externalListStateRef]);\n\n // Cache for sorted items array when using `items` prop\n const cachedItemsOrder = useRef<T[] | null>(null);\n const selectionWhenClosed = useRef<{\n single: string | null;\n multiple: string[];\n }>({ single: null, multiple: [] });\n\n // Track if sortSelectedToTop was explicitly provided\n const sortSelectedToTopExplicit = sortSelectedToTop !== undefined;\n // Default to true if items are provided, false otherwise\n const shouldSortSelectedToTop = sortSelectedToTop ?? (items ? true : false);\n\n // Invalidate cache when items change\n useEffect(() => {\n cachedItemsOrder.current = null;\n }, [items]);\n\n // Capture selection when popover closes\n useEffect(() => {\n if (!isPopoverOpen) {\n selectionWhenClosed.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map(String)\n : [],\n };\n cachedItemsOrder.current = null;\n }\n }, [\n isPopoverOpen,\n effectiveSelectedKey,\n effectiveSelectedKeys,\n selectionMode,\n ]);\n\n // Call onOpenChange when popover state changes\n useEffect(() => {\n onOpenChange?.(isPopoverOpen);\n }, [isPopoverOpen]);\n\n // Sort items with selected on top if enabled\n const getSortedItems = useCallback((): typeof items => {\n if (!items || !shouldSortSelectedToTop) return items;\n\n // Reuse cached order if available\n if (cachedItemsOrder.current) {\n return cachedItemsOrder.current;\n }\n\n // Warn if explicitly requested but JSX children used\n if (sortSelectedToTopExplicit && !items) {\n console.warn(\n 'Picker: sortSelectedToTop only works with the items prop. ' +\n 'Sorting will be skipped when using JSX children.',\n );\n return items;\n }\n\n const selectedKeys = new Set<string>();\n\n if (selectionMode === 'multiple') {\n // Don't sort when \"all\" is selected\n if (\n selectionWhenClosed.current.multiple.length === 0 ||\n effectiveSelectedKeys === 'all'\n ) {\n return items;\n }\n selectionWhenClosed.current.multiple.forEach((k) => selectedKeys.add(k));\n } else if (selectionWhenClosed.current.single) {\n selectedKeys.add(selectionWhenClosed.current.single);\n }\n\n if (selectedKeys.size === 0) return items;\n\n const itemsArray = Array.isArray(items) ? items : Array.from(items);\n const selectedItems: T[] = [];\n const unselectedItems: T[] = [];\n\n itemsArray.forEach((item) => {\n const key = (item as any)?.key ?? (item as any)?.id;\n if (key != null && selectedKeys.has(String(key))) {\n selectedItems.push(item);\n } else {\n unselectedItems.push(item);\n }\n });\n\n const sorted = [...selectedItems, ...unselectedItems];\n\n if (isPopoverOpen) {\n cachedItemsOrder.current = sorted;\n }\n\n return sorted;\n }, [\n items,\n shouldSortSelectedToTop,\n sortSelectedToTopExplicit,\n selectionMode,\n effectiveSelectedKeys,\n isPopoverOpen,\n ]);\n\n const finalItems = getSortedItems();\n\n // Create local collection state for reading item data (labels, etc.)\n // This allows us to read item labels even before the popover opens\n const localCollectionState = useListState({\n children,\n items: finalItems, // Use sorted items to match what's shown in popover\n selectionMode: 'none', // Don't manage selection in this state\n });\n\n // Helper to get label from local collection\n const getItemLabel = useCallback(\n (key: Key): string => {\n const item = localCollectionState?.collection?.getItem(key);\n return item?.textValue || String(key);\n },\n [localCollectionState?.collection],\n );\n\n const selectedLabels = useMemo(() => {\n const keysToGet =\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? effectiveSelectedKeys || []\n : effectiveSelectedKey != null\n ? [effectiveSelectedKey]\n : [];\n\n // Handle \"all\" selection\n if (selectionMode === 'multiple' && effectiveSelectedKeys === 'all') {\n if (!localCollectionState?.collection) return [];\n const labels: string[] = [];\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n labels.push(item.textValue || String(item.key));\n }\n }\n return labels;\n }\n\n // Get labels for selected keys\n return keysToGet.map((key) => getItemLabel(key)).filter(Boolean);\n }, [\n selectionMode,\n effectiveSelectedKeys,\n effectiveSelectedKey,\n getItemLabel,\n localCollectionState?.collection,\n ]);\n\n const hasSelection = selectedLabels.length > 0;\n\n const renderTriggerContent = () => {\n // When there is a selection and a custom summary renderer is provided – use it.\n if (typeof renderSummary === 'function') {\n if (selectionMode === 'single') {\n return renderSummary({\n selectedLabel: selectedLabels[0],\n selectedKey: effectiveSelectedKey ?? null,\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'single',\n });\n }\n\n return renderSummary({\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'multiple',\n });\n } else if (renderSummary === false) {\n return null;\n }\n\n let content: ReactNode = '';\n\n if (!hasSelection) {\n return <Text.Placeholder>{placeholder}</Text.Placeholder>;\n } else if (selectionMode === 'single') {\n content = selectedLabels[0];\n } else if (effectiveSelectedKeys === 'all') {\n content = selectAllLabel;\n } else {\n content = selectedLabels.join(', ');\n }\n\n if (!content) {\n return null;\n }\n\n return content;\n };\n\n const [shouldUpdatePosition, setShouldUpdatePosition] = useState(true);\n\n // Capture trigger width for overlay min-width\n const triggerWidth = triggerRef?.current?.UNSAFE_getDOMNode()?.offsetWidth;\n\n // The trigger is rendered as a function so we can access the dialog state\n const renderTrigger = (state) => {\n // Listen for other menus opening and close this one if needed\n useEffect(() => {\n const unsubscribe = on('popover:open', (data: { menuId: string }) => {\n // If another menu is opening and this Picker is open, close this one\n if (data.menuId !== pickerId && state.isOpen) {\n state.close();\n }\n });\n\n return unsubscribe;\n }, [on, pickerId, state]);\n\n // Emit event when this Picker opens\n useEffect(() => {\n if (state.isOpen) {\n emit('popover:open', { menuId: pickerId });\n }\n }, [state.isOpen, emit, pickerId]);\n\n // Track popover open/close state to control sorting\n useEffect(() => {\n if (state.isOpen !== isPopoverOpen) {\n setIsPopoverOpen(state.isOpen);\n }\n }, [state.isOpen, isPopoverOpen]);\n\n // Add keyboard support for arrow keys to open the popover\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if ((e.key === 'ArrowUp' || e.key === 'ArrowDown') && !state.isOpen) {\n e.preventDefault();\n state.open();\n }\n },\n });\n\n useEffect(() => {\n // Allow initial positioning & flipping when opening, then lock placement after transition\n // Popover transition is ~120ms, give it a bit more time to finalize placement\n if (state.isOpen) {\n setShouldUpdatePosition(true);\n const id = window.setTimeout(() => setShouldUpdatePosition(false), 160);\n return () => window.clearTimeout(id);\n } else {\n setShouldUpdatePosition(true);\n }\n }, [state.isOpen]);\n\n // Clear button logic\n let showClearButton =\n isClearable && hasSelection && !isDisabled && !props.isReadOnly;\n\n // Clear function\n let clearValue = useEvent(() => {\n if (selectionMode === 'multiple') {\n if (!isControlledMultiple) {\n setInternalSelectedKeys([]);\n }\n onSelectionChange?.([]);\n } else {\n if (!isControlledSingle) {\n setInternalSelectedKey(null);\n }\n onSelectionChange?.(null);\n }\n\n if (state.isOpen) {\n state.close();\n }\n\n triggerRef?.current?.focus?.();\n\n onClear?.();\n\n return false;\n });\n\n return (\n <ItemButton\n ref={triggerRef as any}\n data-popover-trigger\n id={id}\n qa={qa || 'PickerTrigger'}\n type={type}\n theme={validationState === 'invalid' ? 'danger' : theme}\n size={size}\n shape={shape}\n isDisabled={isDisabled || isLoading}\n data-input-type=\"picker\"\n mods={{\n placeholder: !hasSelection,\n ...externalMods,\n }}\n icon={icon}\n rightIcon={\n isLoading ? (\n <LoadingIcon />\n ) : rightIcon !== undefined ? (\n rightIcon\n ) : showClearButton ? (\n <ItemAction\n icon={<CloseIcon />}\n size={size}\n theme={validationState === 'invalid' ? 'danger' : undefined}\n qa=\"PickerClearButton\"\n mods={{ pressed: false }}\n onPress={clearValue}\n />\n ) : (\n <DirectionIcon to={state.isOpen ? 'top' : 'bottom'} />\n )\n }\n prefix={prefix}\n suffix={suffix}\n hotkeys={hotkeys}\n tooltip={triggerTooltip}\n description={triggerDescription}\n descriptionPlacement={descriptionPlacement}\n styles={triggerStyles}\n {...keyboardProps}\n aria-label={`${props['aria-label'] ?? props.label ?? ''}`}\n >\n {renderTriggerContent()}\n </ItemButton>\n );\n };\n\n const pickerField = (\n <PickerWrapper\n styles={styles}\n {...filterBaseProps(otherProps, { eventProps: true })}\n >\n <DialogTrigger\n type=\"popover\"\n placement=\"bottom start\"\n containerPadding={containerPadding}\n shouldUpdatePosition={shouldUpdatePosition}\n shouldFlip={shouldFlip && shouldUpdatePosition}\n isDismissable={true}\n shouldCloseOnInteractOutside={(el) => {\n const menuTriggerEl = el.closest('[data-popover-trigger]');\n // If no menu trigger was clicked, allow closing\n if (!menuTriggerEl) return true;\n // If the same trigger that opened this popover was clicked, allow closing (toggle)\n if (menuTriggerEl === (triggerRef as any)?.current) return true;\n // Otherwise, don't close here. Let the event bus handle closing when the other opens.\n return false;\n }}\n >\n {renderTrigger}\n {(close) => (\n <Dialog\n qa=\"PickerOverlay\"\n display=\"grid\"\n styles={{\n gridRows: '1sf',\n width: 'max($overlay-min-width, 30x) max-content 50vw',\n '$overlay-min-width': '30x',\n ...popoverStyles,\n }}\n style={\n triggerWidth\n ? ({ '--overlay-min-width': `${triggerWidth}px` } as any)\n : undefined\n }\n >\n <FocusScope restoreFocus>\n <ListBox\n autoFocus\n items={items ? (finalItems as typeof props.items) : undefined}\n // Pass an aria-label so the internal ListBox is properly labeled and React Aria doesn't warn.\n aria-label={`${props['aria-label'] ?? props.label ?? ''} Picker`}\n selectedKey={\n selectionMode === 'single' ? effectiveSelectedKey : undefined\n }\n selectedKeys={\n selectionMode === 'multiple'\n ? effectiveSelectedKeys\n : undefined\n }\n listStyles={listStyles}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n listRef={listRef}\n disallowEmptySelection={disallowEmptySelection}\n disabledKeys={disabledKeys}\n focusOnHover={focusOnHover}\n shouldFocusWrap={shouldFocusWrap}\n selectionMode={selectionMode}\n validationState={validationState}\n isDisabled={isDisabled}\n isLoading={isLoading}\n stateRef={internalListStateRef}\n isCheckable={isCheckable}\n shape=\"popover\"\n size=\"medium\"\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n header={header}\n footer={footer}\n headerStyles={headerStyles}\n footerStyles={footerStyles}\n qa={`${props.qa || 'Picker'}ListBox`}\n allValueProps={allValueProps}\n onEscape={() => close()}\n onOptionClick={(key) => {\n // For Picker, clicking the content area should close the popover\n // in multiple selection mode (single mode already closes via onSelectionChange)\n if (\n (selectionMode === 'multiple' && isCheckable) ||\n key === '__ALL__'\n ) {\n close();\n }\n }}\n onSelectionChange={(selection) => {\n // No need to change any flags - children order is cached\n\n // Update internal state if uncontrolled\n if (selectionMode === 'single') {\n if (!isControlledSingle) {\n setInternalSelectedKey(selection as Key | null);\n }\n } else {\n if (!isControlledMultiple) {\n let normalized: 'all' | Key[] = selection as\n | 'all'\n | Key[];\n\n if (selection === 'all') {\n normalized = 'all';\n } else if (Array.isArray(selection)) {\n normalized = processSelectionArray(selection);\n } else if (\n selection &&\n typeof selection === 'object' &&\n (selection as any) instanceof Set\n ) {\n normalized = processSelectionArray(\n selection as Set<Key>,\n );\n }\n\n setInternalSelectedKeys(normalized);\n }\n }\n\n onSelectionChange?.(selection);\n\n if (selectionMode === 'single') {\n close();\n }\n }}\n >\n {children as CollectionChildren<T>}\n </ListBox>\n </FocusScope>\n </Dialog>\n )}\n </DialogTrigger>\n </PickerWrapper>\n );\n\n return wrapWithField<Omit<CubePickerProps<T>, 'children' | 'tooltip'>>(\n pickerField,\n ref as any,\n props,\n );\n}) as unknown as (<T>(\n props: CubePickerProps<T> & { ref?: ForwardedRef<HTMLElement> },\n) => ReactElement) & { Item: typeof ListBox.Item; Section: typeof BaseSection };\n\nPicker.Item = ListBox.Item;\n\nPicker.Section = BaseSection;\n\nObject.defineProperty(Picker, 'cubeInputType', {\n value: 'Picker',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"Picker.js","names":["Text","ItemButton","BaseSection"],"sources":["../../../../src/components/fields/Picker/Picker.tsx"],"sourcesContent":["import { CollectionChildren, FocusableRefValue } from '@react-types/shared';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n BaseStyleProps,\n COLOR_STYLES,\n ColorStyleProps,\n extractStyles,\n filterBaseProps,\n OUTER_STYLES,\n OuterStyleProps,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n ForwardedRef,\n forwardRef,\n MutableRefObject,\n ReactElement,\n ReactNode,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { FocusScope, Key, useKeyboard } from 'react-aria';\nimport { Section as BaseSection, ListState, useListState } from 'react-stately';\n\nimport { useEvent } from '../../../_internal';\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CloseIcon, DirectionIcon, LoadingIcon } from '../../../icons';\nimport { useProviderProps } from '../../../provider';\nimport { generateRandomId } from '../../../utils/random';\nimport { useEventBus } from '../../../utils/react/useEventBus';\nimport { CubeItemButtonProps, ItemAction, ItemButton } from '../../actions';\nimport { CubeItemProps } from '../../content/Item';\nimport { Text } from '../../content/Text';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { Dialog, DialogTrigger } from '../../overlays/Dialog';\nimport { CubeListBoxProps, ListBox } from '../ListBox/ListBox';\n\nimport type { FieldBaseProps } from '../../../shared';\n\nexport interface CubePickerProps<T>\n extends Omit<CubeListBoxProps<T>, 'size' | 'tooltip' | 'shape'>,\n Omit<CubeItemProps, 'children' | 'size'>,\n BasePropsWithoutChildren,\n BaseStyleProps,\n OuterStyleProps,\n ColorStyleProps,\n Omit<FieldBaseProps, 'tooltip'>,\n Pick<\n CubeItemButtonProps,\n | 'type'\n | 'theme'\n | 'icon'\n | 'rightIcon'\n | 'prefix'\n | 'suffix'\n | 'hotkeys'\n | 'shape'\n > {\n /** Placeholder text when no selection is made */\n placeholder?: string;\n /** Size of the picker component */\n size?: 'small' | 'medium' | 'large';\n /** Custom styles for the list box popover */\n listBoxStyles?: Styles;\n /** Custom styles for the popover container */\n popoverStyles?: Styles;\n /** Custom styles for the trigger button */\n triggerStyles?: Styles;\n /** Whether to show checkboxes for multiple selection mode */\n isCheckable?: boolean;\n /** Whether to flip the popover placement */\n shouldFlip?: boolean;\n /** Minimum padding in pixels between the popover and viewport edges */\n containerPadding?: number;\n /** Tooltip for the trigger button (separate from field tooltip) */\n triggerTooltip?: CubeItemProps['tooltip'];\n /** Description for the trigger button (separate from field description) */\n triggerDescription?: CubeItemProps['description'];\n\n /**\n * Custom renderer for the summary shown inside the trigger when there is a selection.\n *\n * For `selectionMode=\"multiple\"` the function receives:\n * - `selectedLabels`: array of labels of the selected items.\n * - `selectedKeys`: array of keys of the selected items or \"all\".\n *\n * For `selectionMode=\"single\"` the function receives:\n * - `selectedLabel`: label of the selected item.\n * - `selectedKey`: key of the selected item.\n *\n * The function should return a `ReactNode` that will be rendered inside the trigger.\n * Set to `false` to hide the summary text completely.\n */\n renderSummary?:\n | ((args: {\n selectedLabels?: string[];\n selectedKeys?: 'all' | (string | number)[];\n selectedLabel?: string;\n selectedKey?: string | number | null;\n selectionMode?: 'single' | 'multiple';\n }) => ReactNode)\n | false;\n\n /** Ref to access internal ListBox state */\n listStateRef?: MutableRefObject<ListState<T>>;\n /** Additional modifiers for styling the Picker */\n mods?: Record<string, boolean>;\n /** Whether the picker is clearable using a clear button in the rightIcon slot */\n isClearable?: boolean;\n /** Callback called when the clear button is pressed */\n onClear?: () => void;\n /**\n * Sort selected item(s) to the top when the popover opens.\n * Only works when using the `items` prop (data-driven mode).\n * Supports both single and multiple selection modes.\n * @default true when items are provided, false when using JSX children\n */\n sortSelectedToTop?: boolean;\n /** Callback called when the popover open state changes */\n onOpenChange?: (isOpen: boolean) => void;\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nconst PickerWrapper = tasty({\n qa: 'PickerWrapper',\n styles: {\n display: 'inline-grid',\n flow: 'column',\n gridRows: '1sf',\n placeContent: 'stretch',\n placeItems: 'stretch',\n },\n});\n\nexport const Picker = forwardRef(function Picker<T extends object>(\n props: CubePickerProps<T>,\n ref: ForwardedRef<HTMLElement>,\n) {\n props = useProviderProps(props);\n props = useFormProps(props);\n props = useFieldProps(props, {\n valuePropsMapper: ({ value, onChange }) => {\n const fieldProps: Record<string, unknown> = {};\n\n if (props.selectionMode === 'multiple') {\n fieldProps.selectedKeys = value || [];\n } else {\n fieldProps.selectedKey = value ?? null;\n }\n\n fieldProps.onSelectionChange = (key: Key | null | 'all' | Key[]) => {\n if (props.selectionMode === 'multiple') {\n // Handle \"all\" selection and array selections\n if (key === 'all') {\n onChange('all');\n } else {\n onChange(key ? (Array.isArray(key) ? key : [key]) : []);\n }\n } else {\n onChange(Array.isArray(key) ? key[0] : key);\n }\n };\n\n return fieldProps;\n },\n });\n\n let {\n id,\n qa,\n label,\n extra,\n icon,\n rightIcon,\n prefix,\n suffix,\n hotkeys,\n triggerTooltip,\n triggerDescription,\n labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n isLoading,\n message,\n mods: externalMods,\n description,\n descriptionPlacement,\n placeholder,\n size = 'medium',\n styles,\n listBoxStyles,\n popoverStyles,\n type = 'outline',\n theme = 'default',\n shape,\n labelSuffix,\n shouldFocusWrap,\n children,\n shouldFlip = true,\n containerPadding = 8,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n disabledKeys,\n onSelectionChange,\n selectionMode = 'single',\n listStateRef,\n focusOnHover,\n showSelectAll,\n selectAllLabel = 'All',\n items,\n header,\n footer,\n headerStyles,\n footerStyles,\n triggerStyles,\n renderSummary,\n isCheckable,\n allValueProps,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n disallowEmptySelection,\n shouldUseVirtualFocus,\n onEscape,\n onOptionClick,\n isClearable,\n onClear,\n sortSelectedToTop,\n onOpenChange,\n listStateRef: externalListStateRef,\n ...otherProps\n } = props;\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n // Generate a unique ID for this Picker instance\n const pickerId = useMemo(() => generateRandomId(), []);\n\n // Get event bus for menu synchronization\n const { emit, on } = useEventBus();\n\n // Warn if isCheckable is false in single selection mode\n useWarn(isCheckable === false && selectionMode === 'single', {\n key: ['picker-checkable-single-mode'],\n args: [\n 'CubeUIKit: isCheckable=false is not recommended in single selection mode as it may confuse users about selection behavior.',\n ],\n });\n\n // Internal selection state (uncontrolled scenario)\n const [internalSelectedKey, setInternalSelectedKey] = useState<Key | null>(\n defaultSelectedKey ?? null,\n );\n const [internalSelectedKeys, setInternalSelectedKeys] = useState<\n 'all' | Key[]\n >(defaultSelectedKeys ?? []);\n\n // Track popover open/close and capture children order for session\n const [isPopoverOpen, setIsPopoverOpen] = useState(false);\n const triggerRef = useRef<FocusableRefValue<HTMLButtonElement>>(null);\n\n const isControlledSingle = selectedKey !== undefined;\n const isControlledMultiple = selectedKeys !== undefined;\n\n const effectiveSelectedKey = isControlledSingle\n ? selectedKey\n : internalSelectedKey;\n const effectiveSelectedKeys = isControlledMultiple\n ? selectedKeys\n : internalSelectedKeys;\n\n // Given an iterable of keys (array or Set) toggle membership for duplicates\n const processSelectionArray = (iterable: Iterable<Key>): string[] => {\n const resultSet = new Set<string>();\n for (const key of iterable) {\n const nKey = String(key);\n if (resultSet.has(nKey)) {\n resultSet.delete(nKey); // toggle off if clicked twice\n } else {\n resultSet.add(nKey); // select\n }\n }\n return Array.from(resultSet);\n };\n\n // Ref to access internal ListBox state for collection API\n const internalListStateRef = useRef<ListState<T>>(null);\n\n // Sync internal ref with external ref if provided\n useEffect(() => {\n if (externalListStateRef && internalListStateRef.current) {\n externalListStateRef.current = internalListStateRef.current;\n }\n }, [externalListStateRef]);\n\n // Cache for sorted items array when using `items` prop\n const cachedItemsOrder = useRef<T[] | null>(null);\n const selectionWhenClosed = useRef<{\n single: string | null;\n multiple: string[];\n }>({ single: null, multiple: [] });\n\n // Track if sortSelectedToTop was explicitly provided\n const sortSelectedToTopExplicit = sortSelectedToTop !== undefined;\n // Default to true if items are provided, false otherwise\n const shouldSortSelectedToTop = sortSelectedToTop ?? (items ? true : false);\n\n // Invalidate cache when items change\n useEffect(() => {\n cachedItemsOrder.current = null;\n }, [items]);\n\n // Capture selection when popover closes\n useEffect(() => {\n if (!isPopoverOpen) {\n selectionWhenClosed.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map(String)\n : [],\n };\n cachedItemsOrder.current = null;\n }\n }, [\n isPopoverOpen,\n effectiveSelectedKey,\n effectiveSelectedKeys,\n selectionMode,\n ]);\n\n // Call onOpenChange when popover state changes\n useEffect(() => {\n onOpenChange?.(isPopoverOpen);\n }, [isPopoverOpen]);\n\n // Sort items with selected on top if enabled\n const getSortedItems = useCallback((): typeof items => {\n if (!items || !shouldSortSelectedToTop) return items;\n\n // Reuse cached order if available\n if (cachedItemsOrder.current) {\n return cachedItemsOrder.current;\n }\n\n // Warn if explicitly requested but JSX children used\n if (sortSelectedToTopExplicit && !items) {\n console.warn(\n 'Picker: sortSelectedToTop only works with the items prop. ' +\n 'Sorting will be skipped when using JSX children.',\n );\n return items;\n }\n\n const selectedKeys = new Set<string>();\n\n if (selectionMode === 'multiple') {\n // Don't sort when \"all\" is selected\n if (\n selectionWhenClosed.current.multiple.length === 0 ||\n effectiveSelectedKeys === 'all'\n ) {\n return items;\n }\n selectionWhenClosed.current.multiple.forEach((k) => selectedKeys.add(k));\n } else if (selectionWhenClosed.current.single) {\n selectedKeys.add(selectionWhenClosed.current.single);\n }\n\n if (selectedKeys.size === 0) return items;\n\n const itemsArray = Array.isArray(items) ? items : Array.from(items);\n const selectedItems: T[] = [];\n const unselectedItems: T[] = [];\n\n itemsArray.forEach((item) => {\n const key = (item as any)?.key ?? (item as any)?.id;\n if (key != null && selectedKeys.has(String(key))) {\n selectedItems.push(item);\n } else {\n unselectedItems.push(item);\n }\n });\n\n const sorted = [...selectedItems, ...unselectedItems];\n\n if (isPopoverOpen) {\n cachedItemsOrder.current = sorted;\n }\n\n return sorted;\n }, [\n items,\n shouldSortSelectedToTop,\n sortSelectedToTopExplicit,\n selectionMode,\n effectiveSelectedKeys,\n isPopoverOpen,\n ]);\n\n const finalItems = getSortedItems();\n\n // Create local collection state for reading item data (labels, etc.)\n // This allows us to read item labels even before the popover opens\n const localCollectionState = useListState({\n children,\n items: finalItems, // Use sorted items to match what's shown in popover\n selectionMode: 'none', // Don't manage selection in this state\n });\n\n // Helper to get label from local collection\n const getItemLabel = useCallback(\n (key: Key): string => {\n const item = localCollectionState?.collection?.getItem(key);\n return item?.textValue || String(key);\n },\n [localCollectionState?.collection],\n );\n\n const selectedLabels = useMemo(() => {\n const keysToGet =\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? effectiveSelectedKeys || []\n : effectiveSelectedKey != null\n ? [effectiveSelectedKey]\n : [];\n\n // Handle \"all\" selection\n if (selectionMode === 'multiple' && effectiveSelectedKeys === 'all') {\n if (!localCollectionState?.collection) return [];\n const labels: string[] = [];\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n labels.push(item.textValue || String(item.key));\n }\n }\n return labels;\n }\n\n // Get labels for selected keys\n return keysToGet.map((key) => getItemLabel(key)).filter(Boolean);\n }, [\n selectionMode,\n effectiveSelectedKeys,\n effectiveSelectedKey,\n getItemLabel,\n localCollectionState?.collection,\n ]);\n\n const hasSelection = selectedLabels.length > 0;\n\n const renderTriggerContent = () => {\n // When there is a selection and a custom summary renderer is provided – use it.\n if (typeof renderSummary === 'function') {\n if (selectionMode === 'single') {\n return renderSummary({\n selectedLabel: selectedLabels[0],\n selectedKey: effectiveSelectedKey ?? null,\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'single',\n });\n }\n\n return renderSummary({\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'multiple',\n });\n } else if (renderSummary === false) {\n return null;\n }\n\n let content: ReactNode = '';\n\n if (!hasSelection) {\n return <Text.Placeholder>{placeholder}</Text.Placeholder>;\n } else if (selectionMode === 'single') {\n content = selectedLabels[0];\n } else if (effectiveSelectedKeys === 'all') {\n content = selectAllLabel;\n } else {\n content = selectedLabels.join(', ');\n }\n\n if (!content) {\n return null;\n }\n\n return content;\n };\n\n const [shouldUpdatePosition, setShouldUpdatePosition] = useState(true);\n\n // Capture trigger width for overlay min-width\n const triggerWidth = triggerRef?.current?.UNSAFE_getDOMNode()?.offsetWidth;\n\n // The trigger is rendered as a function so we can access the dialog state\n const renderTrigger = (state) => {\n // Listen for other menus opening and close this one if needed\n useEffect(() => {\n const unsubscribe = on('popover:open', (data: { menuId: string }) => {\n // If another menu is opening and this Picker is open, close this one\n if (data.menuId !== pickerId && state.isOpen) {\n state.close();\n }\n });\n\n return unsubscribe;\n }, [on, pickerId, state]);\n\n // Emit event when this Picker opens\n useEffect(() => {\n if (state.isOpen) {\n emit('popover:open', { menuId: pickerId });\n }\n }, [state.isOpen, emit, pickerId]);\n\n // Track popover open/close state to control sorting\n useEffect(() => {\n if (state.isOpen !== isPopoverOpen) {\n setIsPopoverOpen(state.isOpen);\n }\n }, [state.isOpen, isPopoverOpen]);\n\n // Add keyboard support for arrow keys to open the popover\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if ((e.key === 'ArrowUp' || e.key === 'ArrowDown') && !state.isOpen) {\n e.preventDefault();\n state.open();\n }\n },\n });\n\n useEffect(() => {\n // Allow initial positioning & flipping when opening, then lock placement after transition\n // Popover transition is ~120ms, give it a bit more time to finalize placement\n if (state.isOpen) {\n setShouldUpdatePosition(true);\n const id = window.setTimeout(() => setShouldUpdatePosition(false), 160);\n return () => window.clearTimeout(id);\n } else {\n setShouldUpdatePosition(true);\n }\n }, [state.isOpen]);\n\n // Clear button logic\n let showClearButton =\n isClearable && hasSelection && !isDisabled && !props.isReadOnly;\n\n // Clear function\n let clearValue = useEvent(() => {\n if (selectionMode === 'multiple') {\n if (!isControlledMultiple) {\n setInternalSelectedKeys([]);\n }\n onSelectionChange?.([]);\n } else {\n if (!isControlledSingle) {\n setInternalSelectedKey(null);\n }\n onSelectionChange?.(null);\n }\n\n if (state.isOpen) {\n state.close();\n }\n\n triggerRef?.current?.focus?.();\n\n onClear?.();\n\n return false;\n });\n\n return (\n <ItemButton\n ref={triggerRef as any}\n data-popover-trigger\n id={id}\n qa={qa || 'PickerTrigger'}\n type={type}\n theme={validationState === 'invalid' ? 'danger' : theme}\n size={size}\n shape={shape}\n isDisabled={isDisabled || isLoading}\n data-input-type=\"picker\"\n mods={{\n placeholder: !hasSelection,\n ...externalMods,\n }}\n icon={icon}\n rightIcon={\n isLoading ? (\n <LoadingIcon />\n ) : rightIcon !== undefined ? (\n rightIcon\n ) : showClearButton ? (\n <ItemAction\n icon={<CloseIcon />}\n size={size}\n theme={validationState === 'invalid' ? 'danger' : undefined}\n qa=\"PickerClearButton\"\n mods={{ pressed: false }}\n onPress={clearValue}\n />\n ) : (\n <DirectionIcon to={state.isOpen ? 'top' : 'bottom'} />\n )\n }\n prefix={prefix}\n suffix={suffix}\n hotkeys={hotkeys}\n tooltip={triggerTooltip}\n description={triggerDescription}\n descriptionPlacement={descriptionPlacement}\n styles={triggerStyles}\n {...keyboardProps}\n aria-label={`${props['aria-label'] ?? props.label ?? ''}`}\n >\n {renderTriggerContent()}\n </ItemButton>\n );\n };\n\n const pickerField = (\n <PickerWrapper\n styles={styles}\n {...filterBaseProps(otherProps, { eventProps: true })}\n >\n <DialogTrigger\n type=\"popover\"\n placement=\"bottom start\"\n containerPadding={containerPadding}\n shouldUpdatePosition={shouldUpdatePosition}\n shouldFlip={shouldFlip && shouldUpdatePosition}\n isDismissable={true}\n shouldCloseOnInteractOutside={(el) => {\n const menuTriggerEl = el.closest('[data-popover-trigger]');\n // If no menu trigger was clicked, allow closing\n if (!menuTriggerEl) return true;\n // If the same trigger that opened this popover was clicked, allow closing (toggle)\n if (menuTriggerEl === (triggerRef as any)?.current) return true;\n // Otherwise, don't close here. Let the event bus handle closing when the other opens.\n return false;\n }}\n >\n {renderTrigger}\n {(close) => (\n <Dialog\n qa=\"PickerOverlay\"\n display=\"grid\"\n styles={{\n gridRows: '1sf',\n width: 'max($overlay-min-width, 30x) max-content 50vw',\n '$overlay-min-width': '30x',\n ...popoverStyles,\n }}\n style={\n triggerWidth\n ? ({ '--overlay-min-width': `${triggerWidth}px` } as any)\n : undefined\n }\n >\n <FocusScope restoreFocus>\n <ListBox\n autoFocus\n items={items ? (finalItems as typeof props.items) : undefined}\n // Pass an aria-label so the internal ListBox is properly labeled and React Aria doesn't warn.\n aria-label={`${props['aria-label'] ?? props.label ?? ''} Picker`}\n selectedKey={\n selectionMode === 'single' ? effectiveSelectedKey : undefined\n }\n selectedKeys={\n selectionMode === 'multiple'\n ? effectiveSelectedKeys\n : undefined\n }\n listStyles={listStyles}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n listRef={listRef}\n disallowEmptySelection={disallowEmptySelection}\n disabledKeys={disabledKeys}\n focusOnHover={focusOnHover}\n shouldFocusWrap={shouldFocusWrap}\n selectionMode={selectionMode}\n validationState={validationState}\n isDisabled={isDisabled}\n isLoading={isLoading}\n stateRef={internalListStateRef}\n isCheckable={isCheckable}\n shape=\"popover\"\n size=\"medium\"\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n header={header}\n footer={footer}\n headerStyles={headerStyles}\n footerStyles={footerStyles}\n qa={`${props.qa || 'Picker'}ListBox`}\n allValueProps={allValueProps}\n onEscape={() => close()}\n onOptionClick={(key) => {\n // For Picker, clicking the content area should close the popover\n // in multiple selection mode (single mode already closes via onSelectionChange)\n if (\n (selectionMode === 'multiple' && isCheckable) ||\n key === '__ALL__'\n ) {\n close();\n }\n }}\n onSelectionChange={(selection) => {\n // No need to change any flags - children order is cached\n\n // Update internal state if uncontrolled\n if (selectionMode === 'single') {\n if (!isControlledSingle) {\n setInternalSelectedKey(selection as Key | null);\n }\n } else {\n if (!isControlledMultiple) {\n let normalized: 'all' | Key[] = selection as\n | 'all'\n | Key[];\n\n if (selection === 'all') {\n normalized = 'all';\n } else if (Array.isArray(selection)) {\n normalized = processSelectionArray(selection);\n } else if (\n selection &&\n typeof selection === 'object' &&\n (selection as any) instanceof Set\n ) {\n normalized = processSelectionArray(\n selection as Set<Key>,\n );\n }\n\n setInternalSelectedKeys(normalized);\n }\n }\n\n onSelectionChange?.(selection);\n\n if (selectionMode === 'single') {\n close();\n }\n }}\n >\n {children as CollectionChildren<T>}\n </ListBox>\n </FocusScope>\n </Dialog>\n )}\n </DialogTrigger>\n </PickerWrapper>\n );\n\n return wrapWithField<Omit<CubePickerProps<T>, 'children' | 'tooltip'>>(\n pickerField,\n ref as any,\n props,\n );\n}) as unknown as (<T>(\n props: CubePickerProps<T> & { ref?: ForwardedRef<HTMLElement> },\n) => ReactElement) & { Item: typeof ListBox.Item; Section: typeof BaseSection };\n\nPicker.Item = ListBox.Item;\n\nPicker.Section = BaseSection;\n\nObject.defineProperty(Picker, 'cubeInputType', {\n value: 'Picker',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA+HA,MAAM,cAAc;CAAC,GAAG;CAAa,GAAG;CAAc,GAAG;CAAa;AAEtE,MAAM,gBAAgB,MAAM;CAC1B,IAAI;CACJ,QAAQ;EACN,SAAS;EACT,MAAM;EACN,UAAU;EACV,cAAc;EACd,YAAY;EACb;CACF,CAAC;AAEF,MAAa,SAAS,WAAW,SAAS,OACxC,OACA,KACA;AACA,SAAQ,iBAAiB,MAAM;AAC/B,SAAQ,aAAa,MAAM;AAC3B,SAAQ,cAAc,OAAO,EAC3B,mBAAmB,EAAE,OAAO,eAAe;EACzC,MAAM,aAAsC,EAAE;AAE9C,MAAI,MAAM,kBAAkB,WAC1B,YAAW,eAAe,SAAS,EAAE;MAErC,YAAW,cAAc,SAAS;AAGpC,aAAW,qBAAqB,QAAoC;AAClE,OAAI,MAAM,kBAAkB,WAE1B,KAAI,QAAQ,MACV,UAAS,MAAM;OAEf,UAAS,MAAO,MAAM,QAAQ,IAAI,GAAG,MAAM,CAAC,IAAI,GAAI,EAAE,CAAC;OAGzD,UAAS,MAAM,QAAQ,IAAI,GAAG,IAAI,KAAK,IAAI;;AAI/C,SAAO;IAEV,CAAC;CAEF,IAAI,EACF,IACA,IACA,OACA,OACA,MACA,WACA,QACA,QACA,SACA,gBACA,oBACA,aACA,YACA,oBACA,iBACA,YACA,WACA,SACA,MAAM,cACN,aACA,sBACA,aACA,OAAO,UACP,QACA,eACA,eACA,OAAO,WACP,QAAQ,WACR,OACA,aACA,iBACA,UACA,aAAa,MACb,mBAAmB,GACnB,aACA,oBACA,cACA,qBACA,cACA,mBACA,gBAAgB,UAChB,cACA,cACA,eACA,iBAAiB,OACjB,OACA,QACA,QACA,cACA,cACA,eACA,eACA,aACA,eACA,YACA,cACA,eACA,eACA,SACA,wBACA,uBACA,UACA,eACA,aACA,SACA,mBACA,cACA,cAAc,sBACd,GAAG,eACD;AAEJ,UAAS,cAAc,YAAY,aAAa,OAAO;CAGvD,MAAM,WAAW,cAAc,kBAAkB,EAAE,EAAE,CAAC;CAGtD,MAAM,EAAE,MAAM,OAAO,aAAa;AAGlC,SAAQ,gBAAgB,SAAS,kBAAkB,UAAU;EAC3D,KAAK,CAAC,+BAA+B;EACrC,MAAM,CACJ,6HACD;EACF,CAAC;CAGF,MAAM,CAAC,qBAAqB,0BAA0B,SACpD,sBAAsB,KACvB;CACD,MAAM,CAAC,sBAAsB,2BAA2B,SAEtD,uBAAuB,EAAE,CAAC;CAG5B,MAAM,CAAC,eAAe,oBAAoB,SAAS,MAAM;CACzD,MAAM,aAAa,OAA6C,KAAK;CAErE,MAAM,qBAAqB,gBAAgB;CAC3C,MAAM,uBAAuB,iBAAiB;CAE9C,MAAM,uBAAuB,qBACzB,cACA;CACJ,MAAM,wBAAwB,uBAC1B,eACA;CAGJ,MAAM,yBAAyB,aAAsC;EACnE,MAAM,4BAAY,IAAI,KAAa;AACnC,OAAK,MAAM,OAAO,UAAU;GAC1B,MAAM,OAAO,OAAO,IAAI;AACxB,OAAI,UAAU,IAAI,KAAK,CACrB,WAAU,OAAO,KAAK;OAEtB,WAAU,IAAI,KAAK;;AAGvB,SAAO,MAAM,KAAK,UAAU;;CAI9B,MAAM,uBAAuB,OAAqB,KAAK;AAGvD,iBAAgB;AACd,MAAI,wBAAwB,qBAAqB,QAC/C,sBAAqB,UAAU,qBAAqB;IAErD,CAAC,qBAAqB,CAAC;CAG1B,MAAM,mBAAmB,OAAmB,KAAK;CACjD,MAAM,sBAAsB,OAGzB;EAAE,QAAQ;EAAM,UAAU,EAAE;EAAE,CAAC;CAGlC,MAAM,4BAA4B,sBAAsB;CAExD,MAAM,0BAA0B,sBAAsB,QAAQ,OAAO;AAGrE,iBAAgB;AACd,mBAAiB,UAAU;IAC1B,CAAC,MAAM,CAAC;AAGX,iBAAgB;AACd,MAAI,CAAC,eAAe;AAClB,uBAAoB,UAAU;IAC5B,QACE,wBAAwB,OAAO,OAAO,qBAAqB,GAAG;IAChE,UACE,kBAAkB,cAAc,0BAA0B,SACrD,yBAAyB,EAAE,EAAE,IAAI,OAAO,GACzC,EAAE;IACT;AACD,oBAAiB,UAAU;;IAE5B;EACD;EACA;EACA;EACA;EACD,CAAC;AAGF,iBAAgB;AACd,iBAAe,cAAc;IAC5B,CAAC,cAAc,CAAC;CAkEnB,MAAM,aA/DiB,kBAAgC;AACrD,MAAI,CAAC,SAAS,CAAC,wBAAyB,QAAO;AAG/C,MAAI,iBAAiB,QACnB,QAAO,iBAAiB;AAI1B,MAAI,6BAA6B,CAAC,OAAO;AACvC,WAAQ,KACN,6GAED;AACD,UAAO;;EAGT,MAAM,+BAAe,IAAI,KAAa;AAEtC,MAAI,kBAAkB,YAAY;AAEhC,OACE,oBAAoB,QAAQ,SAAS,WAAW,KAChD,0BAA0B,MAE1B,QAAO;AAET,uBAAoB,QAAQ,SAAS,SAAS,MAAM,aAAa,IAAI,EAAE,CAAC;aAC/D,oBAAoB,QAAQ,OACrC,cAAa,IAAI,oBAAoB,QAAQ,OAAO;AAGtD,MAAI,aAAa,SAAS,EAAG,QAAO;EAEpC,MAAM,aAAa,MAAM,QAAQ,MAAM,GAAG,QAAQ,MAAM,KAAK,MAAM;EACnE,MAAM,gBAAqB,EAAE;EAC7B,MAAM,kBAAuB,EAAE;AAE/B,aAAW,SAAS,SAAS;GAC3B,MAAM,MAAO,MAAc,OAAQ,MAAc;AACjD,OAAI,OAAO,QAAQ,aAAa,IAAI,OAAO,IAAI,CAAC,CAC9C,eAAc,KAAK,KAAK;OAExB,iBAAgB,KAAK,KAAK;IAE5B;EAEF,MAAM,SAAS,CAAC,GAAG,eAAe,GAAG,gBAAgB;AAErD,MAAI,cACF,kBAAiB,UAAU;AAG7B,SAAO;IACN;EACD;EACA;EACA;EACA;EACA;EACA;EACD,CAAC,EAEiC;CAInC,MAAM,uBAAuB,aAAa;EACxC;EACA,OAAO;EACP,eAAe;EAChB,CAAC;CAGF,MAAM,eAAe,aAClB,QAAqB;AAEpB,UADa,sBAAsB,YAAY,QAAQ,IAAI,GAC9C,aAAa,OAAO,IAAI;IAEvC,CAAC,sBAAsB,WAAW,CACnC;CAED,MAAM,iBAAiB,cAAc;EACnC,MAAM,YACJ,kBAAkB,cAAc,0BAA0B,QACtD,yBAAyB,EAAE,GAC3B,wBAAwB,OACtB,CAAC,qBAAqB,GACtB,EAAE;AAGV,MAAI,kBAAkB,cAAc,0BAA0B,OAAO;AACnE,OAAI,CAAC,sBAAsB,WAAY,QAAO,EAAE;GAChD,MAAM,SAAmB,EAAE;AAC3B,QAAK,MAAM,QAAQ,qBAAqB,WACtC,KAAI,KAAK,SAAS,OAChB,QAAO,KAAK,KAAK,aAAa,OAAO,KAAK,IAAI,CAAC;AAGnD,UAAO;;AAIT,SAAO,UAAU,KAAK,QAAQ,aAAa,IAAI,CAAC,CAAC,OAAO,QAAQ;IAC/D;EACD;EACA;EACA;EACA;EACA,sBAAsB;EACvB,CAAC;CAEF,MAAM,eAAe,eAAe,SAAS;CAE7C,MAAM,6BAA6B;AAEjC,MAAI,OAAO,kBAAkB,YAAY;AACvC,OAAI,kBAAkB,SACpB,QAAO,cAAc;IACnB,eAAe,eAAe;IAC9B,aAAa,wBAAwB;IACrC;IACA,cAAc;IACd,eAAe;IAChB,CAAC;AAGJ,UAAO,cAAc;IACnB;IACA,cAAc;IACd,eAAe;IAChB,CAAC;aACO,kBAAkB,MAC3B,QAAO;EAGT,IAAI,UAAqB;AAEzB,MAAI,CAAC,aACH,QAAO,oBAACA,MAAK,yBAAa,cAA+B;WAChD,kBAAkB,SAC3B,WAAU,eAAe;WAChB,0BAA0B,MACnC,WAAU;MAEV,WAAU,eAAe,KAAK,KAAK;AAGrC,MAAI,CAAC,QACH,QAAO;AAGT,SAAO;;CAGT,MAAM,CAAC,sBAAsB,2BAA2B,SAAS,KAAK;CAGtE,MAAM,eAAe,YAAY,SAAS,mBAAmB,EAAE;CAG/D,MAAM,iBAAiB,UAAU;AAE/B,kBAAgB;AAQd,UAPoB,GAAG,iBAAiB,SAA6B;AAEnE,QAAI,KAAK,WAAW,YAAY,MAAM,OACpC,OAAM,OAAO;KAEf;KAGD;GAAC;GAAI;GAAU;GAAM,CAAC;AAGzB,kBAAgB;AACd,OAAI,MAAM,OACR,MAAK,gBAAgB,EAAE,QAAQ,UAAU,CAAC;KAE3C;GAAC,MAAM;GAAQ;GAAM;GAAS,CAAC;AAGlC,kBAAgB;AACd,OAAI,MAAM,WAAW,cACnB,kBAAiB,MAAM,OAAO;KAE/B,CAAC,MAAM,QAAQ,cAAc,CAAC;EAGjC,MAAM,EAAE,kBAAkB,YAAY,EACpC,YAAY,MAAM;AAChB,QAAK,EAAE,QAAQ,aAAa,EAAE,QAAQ,gBAAgB,CAAC,MAAM,QAAQ;AACnE,MAAE,gBAAgB;AAClB,UAAM,MAAM;;KAGjB,CAAC;AAEF,kBAAgB;AAGd,OAAI,MAAM,QAAQ;AAChB,4BAAwB,KAAK;IAC7B,MAAM,KAAK,OAAO,iBAAiB,wBAAwB,MAAM,EAAE,IAAI;AACvE,iBAAa,OAAO,aAAa,GAAG;SAEpC,yBAAwB,KAAK;KAE9B,CAAC,MAAM,OAAO,CAAC;EAGlB,IAAI,kBACF,eAAe,gBAAgB,CAAC,cAAc,CAAC,MAAM;EAGvD,IAAI,aAAa,eAAe;AAC9B,OAAI,kBAAkB,YAAY;AAChC,QAAI,CAAC,qBACH,yBAAwB,EAAE,CAAC;AAE7B,wBAAoB,EAAE,CAAC;UAClB;AACL,QAAI,CAAC,mBACH,wBAAuB,KAAK;AAE9B,wBAAoB,KAAK;;AAG3B,OAAI,MAAM,OACR,OAAM,OAAO;AAGf,eAAY,SAAS,SAAS;AAE9B,cAAW;AAEX,UAAO;IACP;AAEF,SACE,oBAACC;GACC,KAAK;GACL;GACI;GACJ,IAAI,MAAM;GACJ;GACN,OAAO,oBAAoB,YAAY,WAAW;GAC5C;GACC;GACP,YAAY,cAAc;GAC1B,mBAAgB;GAChB,MAAM;IACJ,aAAa,CAAC;IACd,GAAG;IACJ;GACK;GACN,WACE,YACE,oBAAC,gBAAc,GACb,cAAc,SAChB,YACE,kBACF,oBAAC;IACC,MAAM,oBAAC,cAAY;IACb;IACN,OAAO,oBAAoB,YAAY,WAAW;IAClD,IAAG;IACH,MAAM,EAAE,SAAS,OAAO;IACxB,SAAS;KACT,GAEF,oBAAC,iBAAc,IAAI,MAAM,SAAS,QAAQ,WAAY;GAGlD;GACA;GACC;GACT,SAAS;GACT,aAAa;GACS;GACtB,QAAQ;GACR,GAAI;GACJ,cAAY,GAAG,MAAM,iBAAiB,MAAM,SAAS;aAEpD,sBAAsB;IACZ;;AA6IjB,QAAO,cAxIL,oBAAC;EACS;EACR,GAAI,gBAAgB,YAAY,EAAE,YAAY,MAAM,CAAC;YAErD,qBAAC;GACC,MAAK;GACL,WAAU;GACQ;GACI;GACtB,YAAY,cAAc;GAC1B,eAAe;GACf,+BAA+B,OAAO;IACpC,MAAM,gBAAgB,GAAG,QAAQ,yBAAyB;AAE1D,QAAI,CAAC,cAAe,QAAO;AAE3B,QAAI,kBAAmB,YAAoB,QAAS,QAAO;AAE3D,WAAO;;cAGR,gBACC,UACA,oBAAC;IACC,IAAG;IACH,SAAQ;IACR,QAAQ;KACN,UAAU;KACV,OAAO;KACP,sBAAsB;KACtB,GAAG;KACJ;IACD,OACE,eACK,EAAE,uBAAuB,GAAG,aAAa,KAAK,GAC/C;cAGN,oBAAC;KAAW;eACV,oBAAC;MACC;MACA,OAAO,QAAS,aAAoC;MAEpD,cAAY,GAAG,MAAM,iBAAiB,MAAM,SAAS,GAAG;MACxD,aACE,kBAAkB,WAAW,uBAAuB;MAEtD,cACE,kBAAkB,aACd,wBACA;MAEM;MACE;MACC;MACA;MACN;MACe;MACV;MACA;MACG;MACF;MACE;MACL;MACD;MACX,UAAU;MACG;MACb,OAAM;MACN,MAAK;MACU;MACC;MACR;MACA;MACM;MACA;MACd,IAAI,GAAG,MAAM,MAAM,SAAS;MACb;MACf,gBAAgB,OAAO;MACvB,gBAAgB,QAAQ;AAGtB,WACG,kBAAkB,cAAc,eACjC,QAAQ,UAER,QAAO;;MAGX,oBAAoB,cAAc;AAIhC,WAAI,kBAAkB,UACpB;YAAI,CAAC,mBACH,wBAAuB,UAAwB;kBAG7C,CAAC,sBAAsB;QACzB,IAAI,aAA4B;AAIhC,YAAI,cAAc,MAChB,cAAa;iBACJ,MAAM,QAAQ,UAAU,CACjC,cAAa,sBAAsB,UAAU;iBAE7C,aACA,OAAO,cAAc,YACpB,qBAA6B,IAE9B,cAAa,sBACX,UACD;AAGH,gCAAwB,WAAW;;AAIvC,2BAAoB,UAAU;AAE9B,WAAI,kBAAkB,SACpB,QAAO;;MAIV;OACO;MACC;KACN;IAEG;GACF,EAKhB,KACA,MACD;EACD;AAIF,OAAO,OAAO,QAAQ;AAEtB,OAAO,UAAUC;AAEjB,OAAO,eAAe,QAAQ,iBAAiB;CAC7C,OAAO;CACP,YAAY;CACZ,cAAc;CACf,CAAC"}
@@ -1,11 +1,10 @@
1
1
 
2
- import { BaseProps, OuterStyleProps } from "../../../tasty/types.js";
3
- import "../../../tasty/index.js";
4
2
  import { FieldBaseProps } from "../../../shared/form.js";
5
3
  import "../../../shared/index.js";
6
4
  import { CubeItemProps } from "../../content/Item/Item.js";
7
5
  import { WithNullableValue } from "../../../utils/react/nullableValue.js";
8
6
  import { CubeRadioGroupProps, _RadioGroup } from "./RadioGroup.js";
7
+ import { BaseProps, OuterStyleProps } from "@tenphi/tasty";
9
8
  import * as react from "react";
10
9
  import { AriaRadioProps, useRadio } from "react-aria";
11
10
 
@@ -1,8 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.118.0 | Cube Dev Team */
2
- import { extractStyles } from "../../../tasty/utils/styles.js";
3
- import { OUTER_STYLES } from "../../../tasty/styles/list.js";
4
- import { tasty } from "../../../tasty/tasty.js";
5
- import { filterBaseProps } from "../../../tasty/utils/filter-base-props.js";
1
+ /** @license MIT | @cube-dev/ui-kit v0.119.1 | Cube Dev Team */
6
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
7
3
  import { useFocus as useFocus$1 } from "../../../utils/react/interactions.js";
8
4
  import { useProviderProps } from "../../../provider.js";
@@ -13,6 +9,7 @@ import { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
13
9
  import { HiddenInput } from "../../HiddenInput.js";
14
10
  import { useRadioProvider } from "./context.js";
15
11
  import { _RadioGroup } from "./RadioGroup.js";
12
+ import { OUTER_STYLES, extractStyles, filterBaseProps, tasty } from "@tenphi/tasty";
16
13
  import { forwardRef, useMemo, useRef } from "react";
17
14
  import { jsx, jsxs } from "react/jsx-runtime";
18
15
  import { useHover, useRadio } from "react-aria";