@cube-dev/ui-kit 0.135.1 → 0.136.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (431) hide show
  1. package/dist/CHANGELOG.md +21 -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.js +1 -1
  12. package/dist/components/CollectionItem.js +1 -1
  13. package/dist/components/GlobalStyles.js +1 -1
  14. package/dist/components/GridProvider.js +1 -1
  15. package/dist/components/HiddenInput.js +1 -1
  16. package/dist/components/Root.js +1 -1
  17. package/dist/components/actions/Action/Action.js +1 -1
  18. package/dist/components/actions/Banner/Banner.js +1 -1
  19. package/dist/components/actions/Button/Button.js +2 -1
  20. package/dist/components/actions/Button/Button.js.map +1 -1
  21. package/dist/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  22. package/dist/components/actions/ButtonSplit/ButtonSplit.js +1 -1
  23. package/dist/components/actions/ButtonSplit/context.js +1 -1
  24. package/dist/components/actions/CommandMenu/CommandMenu.js +1 -1
  25. package/dist/components/actions/CommandMenu/styled.js +1 -1
  26. package/dist/components/actions/ItemAction/ItemAction.js +1 -1
  27. package/dist/components/actions/ItemActionContext.js +1 -1
  28. package/dist/components/actions/ItemButton/ItemButton.js +2 -1
  29. package/dist/components/actions/ItemButton/ItemButton.js.map +1 -1
  30. package/dist/components/actions/Link/Link.js +1 -1
  31. package/dist/components/actions/Menu/Menu.js +1 -1
  32. package/dist/components/actions/Menu/MenuItem.js +1 -1
  33. package/dist/components/actions/Menu/MenuSection.js +1 -1
  34. package/dist/components/actions/Menu/MenuTrigger.d.ts +7 -0
  35. package/dist/components/actions/Menu/MenuTrigger.js +32 -33
  36. package/dist/components/actions/Menu/MenuTrigger.js.map +1 -1
  37. package/dist/components/actions/Menu/SubMenuTrigger.js +7 -20
  38. package/dist/components/actions/Menu/SubMenuTrigger.js.map +1 -1
  39. package/dist/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  40. package/dist/components/actions/Menu/context.js +1 -1
  41. package/dist/components/actions/Menu/styled.js +1 -1
  42. package/dist/components/actions/index.js +1 -1
  43. package/dist/components/actions/use-action.js +1 -1
  44. package/dist/components/actions/use-anchored-menu.js +6 -19
  45. package/dist/components/actions/use-anchored-menu.js.map +1 -1
  46. package/dist/components/actions/use-context-menu.js +17 -21
  47. package/dist/components/actions/use-context-menu.js.map +1 -1
  48. package/dist/components/content/ActiveZone/ActiveZone.js +1 -1
  49. package/dist/components/content/Alert/Alert.js +1 -1
  50. package/dist/components/content/Alert/use-alert.js +1 -1
  51. package/dist/components/content/Avatar/Avatar.js +1 -1
  52. package/dist/components/content/Badge/Badge.js +1 -1
  53. package/dist/components/content/Card/Card.js +1 -1
  54. package/dist/components/content/Content.js +1 -1
  55. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
  56. package/dist/components/content/CopySnippet/CopySnippet.js +1 -1
  57. package/dist/components/content/Disclosure/Disclosure.js +1 -1
  58. package/dist/components/content/Divider.js +1 -1
  59. package/dist/components/content/Footer.js +1 -1
  60. package/dist/components/content/Header.js +1 -1
  61. package/dist/components/content/HotKeys/HotKeys.js +1 -1
  62. package/dist/components/content/Item/Item.js +1 -1
  63. package/dist/components/content/ItemBadge/ItemBadge.js +1 -1
  64. package/dist/components/content/ItemCard/ItemCard.js +1 -1
  65. package/dist/components/content/Layout/GridLayout.js +1 -1
  66. package/dist/components/content/Layout/Layout.js +1 -1
  67. package/dist/components/content/Layout/LayoutBlock.js +1 -1
  68. package/dist/components/content/Layout/LayoutCenter.js +1 -1
  69. package/dist/components/content/Layout/LayoutContainer.js +1 -1
  70. package/dist/components/content/Layout/LayoutContent.js +1 -1
  71. package/dist/components/content/Layout/LayoutContext.js +1 -1
  72. package/dist/components/content/Layout/LayoutFlex.js +1 -1
  73. package/dist/components/content/Layout/LayoutFooter.js +1 -1
  74. package/dist/components/content/Layout/LayoutGrid.js +1 -1
  75. package/dist/components/content/Layout/LayoutHeader.js +1 -1
  76. package/dist/components/content/Layout/LayoutPane.js +1 -1
  77. package/dist/components/content/Layout/LayoutPanel.js +1 -1
  78. package/dist/components/content/Layout/LayoutPanelHeader.js +1 -1
  79. package/dist/components/content/Layout/LayoutToolbar.js +1 -1
  80. package/dist/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
  81. package/dist/components/content/Layout/index.js +1 -1
  82. package/dist/components/content/Layout/utils.js +1 -1
  83. package/dist/components/content/Paragraph.js +1 -1
  84. package/dist/components/content/Placeholder/Placeholder.js +1 -1
  85. package/dist/components/content/PrismCode/PrismCode.js +1 -1
  86. package/dist/components/content/PrismCode/prismSetup.js +1 -1
  87. package/dist/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  88. package/dist/components/content/Result/Result.js +1 -1
  89. package/dist/components/content/Skeleton/Skeleton.js +1 -1
  90. package/dist/components/content/Tag/Tag.js +1 -1
  91. package/dist/components/content/Text.js +1 -1
  92. package/dist/components/content/TextItem/TextItem.js +1 -1
  93. package/dist/components/content/Title.js +1 -1
  94. package/dist/components/content/Tree/Tree.js +1 -1
  95. package/dist/components/content/Tree/TreeNode.js +1 -1
  96. package/dist/components/content/Tree/styled.js +1 -1
  97. package/dist/components/content/Tree/tree-index.js +1 -1
  98. package/dist/components/content/Tree/use-checkbox-tree.js +1 -1
  99. package/dist/components/content/Tree/use-load-data.js +1 -1
  100. package/dist/components/content/highlightText.js +1 -1
  101. package/dist/components/content/use-auto-tooltip.js +1 -1
  102. package/dist/components/fields/Checkbox/Checkbox.js +1 -1
  103. package/dist/components/fields/Checkbox/CheckboxGroup.js +1 -1
  104. package/dist/components/fields/Checkbox/context.js +1 -1
  105. package/dist/components/fields/ComboBox/ComboBox.js +14 -20
  106. package/dist/components/fields/ComboBox/ComboBox.js.map +1 -1
  107. package/dist/components/fields/DatePicker/DateInput.js +1 -1
  108. package/dist/components/fields/DatePicker/DateInputBase.js +1 -1
  109. package/dist/components/fields/DatePicker/DatePicker.js +1 -1
  110. package/dist/components/fields/DatePicker/DatePickerButton.js +1 -1
  111. package/dist/components/fields/DatePicker/DatePickerElement.js +1 -1
  112. package/dist/components/fields/DatePicker/DatePickerInput.js +1 -1
  113. package/dist/components/fields/DatePicker/DatePickerSegment.js +1 -1
  114. package/dist/components/fields/DatePicker/DateRangePicker.js +1 -1
  115. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
  116. package/dist/components/fields/DatePicker/TimeInput.js +1 -1
  117. package/dist/components/fields/DatePicker/intl.js +1 -1
  118. package/dist/components/fields/DatePicker/parseDate.js +1 -1
  119. package/dist/components/fields/DatePicker/props.js +1 -1
  120. package/dist/components/fields/DatePicker/utils.js +1 -1
  121. package/dist/components/fields/FileInput/FileInput.js +1 -1
  122. package/dist/components/fields/FilterListBox/FilterListBox.js +1 -1
  123. package/dist/components/fields/FilterPicker/FilterPicker.js +14 -21
  124. package/dist/components/fields/FilterPicker/FilterPicker.js.map +1 -1
  125. package/dist/components/fields/Input/Input.js +1 -1
  126. package/dist/components/fields/ListBox/DraggableListBox.js +1 -1
  127. package/dist/components/fields/ListBox/ListBox.js +8 -16
  128. package/dist/components/fields/ListBox/ListBox.js.map +1 -1
  129. package/dist/components/fields/NumberInput/NumberInput.js +1 -1
  130. package/dist/components/fields/NumberInput/StepButton.js +1 -1
  131. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  132. package/dist/components/fields/Picker/Picker.js +14 -21
  133. package/dist/components/fields/Picker/Picker.js.map +1 -1
  134. package/dist/components/fields/RadioGroup/Radio.js +1 -1
  135. package/dist/components/fields/RadioGroup/RadioGroup.js +1 -1
  136. package/dist/components/fields/RadioGroup/context.js +1 -1
  137. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  138. package/dist/components/fields/Select/Select.js +14 -21
  139. package/dist/components/fields/Select/Select.js.map +1 -1
  140. package/dist/components/fields/Slider/Gradation.js +1 -1
  141. package/dist/components/fields/Slider/HueSlider.js +1 -1
  142. package/dist/components/fields/Slider/RangeSlider.js +1 -1
  143. package/dist/components/fields/Slider/Slider.js +1 -1
  144. package/dist/components/fields/Slider/SliderBase.js +1 -1
  145. package/dist/components/fields/Slider/SliderThumb.js +1 -1
  146. package/dist/components/fields/Slider/SliderTrack.js +1 -1
  147. package/dist/components/fields/Slider/elements.js +1 -1
  148. package/dist/components/fields/Slider/index.js +1 -1
  149. package/dist/components/fields/Switch/Switch.js +1 -1
  150. package/dist/components/fields/TextArea/TextArea.js +1 -1
  151. package/dist/components/fields/TextInput/TextInput.js +1 -1
  152. package/dist/components/fields/TextInput/TextInputBase.js +1 -1
  153. package/dist/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  154. package/dist/components/form/FieldWrapper/FieldWrapper.js +1 -1
  155. package/dist/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  156. package/dist/components/form/Form/Field.js +1 -1
  157. package/dist/components/form/Form/Form.js +1 -1
  158. package/dist/components/form/Form/ResetButton/ResetButton.js +1 -1
  159. package/dist/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  160. package/dist/components/form/Form/SubmitError.js +1 -1
  161. package/dist/components/form/Form/index.js +1 -1
  162. package/dist/components/form/Form/use-field/use-field-props.js +1 -1
  163. package/dist/components/form/Form/use-field/use-field.js +1 -1
  164. package/dist/components/form/Form/use-form.js +1 -1
  165. package/dist/components/form/Form/validation.js +1 -1
  166. package/dist/components/form/Label.js +1 -1
  167. package/dist/components/form/wrapper.js +1 -1
  168. package/dist/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  169. package/dist/components/helpers/IconSwitch/IconSwitch.js +1 -1
  170. package/dist/components/layout/Flex.js +1 -1
  171. package/dist/components/layout/Flow.js +1 -1
  172. package/dist/components/layout/Grid.js +1 -1
  173. package/dist/components/layout/Panel.js +1 -1
  174. package/dist/components/layout/Prefix.js +1 -1
  175. package/dist/components/layout/ResizablePanel.js +1 -1
  176. package/dist/components/layout/Space.js +1 -1
  177. package/dist/components/layout/Suffix.js +1 -1
  178. package/dist/components/navigation/Tabs/DraggableTabList.js +1 -1
  179. package/dist/components/navigation/Tabs/EditableTitle.js +1 -1
  180. package/dist/components/navigation/Tabs/TabButton.js +1 -1
  181. package/dist/components/navigation/Tabs/TabDropIndicator.js +1 -1
  182. package/dist/components/navigation/Tabs/TabPanel.js +1 -1
  183. package/dist/components/navigation/Tabs/TabPicker.js +1 -1
  184. package/dist/components/navigation/Tabs/Tabs.js +1 -1
  185. package/dist/components/navigation/Tabs/TabsAction.js +1 -1
  186. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  187. package/dist/components/navigation/Tabs/styled.js +1 -1
  188. package/dist/components/navigation/Tabs/types.js +1 -1
  189. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  190. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  191. package/dist/components/organisms/FileTabs/FileTabs.js +1 -1
  192. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  193. package/dist/components/other/Calendar/Calendar.js +1 -1
  194. package/dist/components/other/Calendar/CalendarCell.js +1 -1
  195. package/dist/components/other/Calendar/CalendarGrid.js +1 -1
  196. package/dist/components/other/Calendar/RangeCalendar.js +1 -1
  197. package/dist/components/other/CloudLogo/CloudLogo.js +1 -1
  198. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  199. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  200. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  201. package/dist/components/overlays/Dialog/Dialog.js +1 -1
  202. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  203. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  204. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  205. package/dist/components/overlays/Dialog/context.js +1 -1
  206. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  207. package/dist/components/overlays/Modal/Modal.js +1 -1
  208. package/dist/components/overlays/Modal/OpenTransitionContext.js +1 -1
  209. package/dist/components/overlays/Modal/Overlay.js +1 -1
  210. package/dist/components/overlays/Modal/Popover.js +1 -1
  211. package/dist/components/overlays/Modal/Tray.js +4 -3
  212. package/dist/components/overlays/Modal/Tray.js.map +1 -1
  213. package/dist/components/overlays/Modal/Underlay.js +1 -1
  214. package/dist/components/overlays/Notifications/Notification.js +1 -1
  215. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  216. package/dist/components/overlays/Notifications/NotificationCard.js +1 -1
  217. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  218. package/dist/components/overlays/Notifications/NotificationItem.js +1 -1
  219. package/dist/components/overlays/Notifications/OverlayContainer.js +1 -1
  220. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  221. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +1 -1
  222. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  223. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  224. package/dist/components/overlays/Notifications/index.js +1 -1
  225. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  226. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  227. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  228. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  229. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  230. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  231. package/dist/components/overlays/Toast/ToastItem.js +1 -1
  232. package/dist/components/overlays/Toast/index.js +1 -1
  233. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  234. package/dist/components/overlays/Toast/useToast.js +1 -1
  235. package/dist/components/overlays/Tooltip/Tooltip.js +1 -1
  236. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  237. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  238. package/dist/components/overlays/Tooltip/context.js +1 -1
  239. package/dist/components/portal/Portal.js +1 -1
  240. package/dist/components/portal/PortalProvider.js +1 -1
  241. package/dist/components/portal/usePortal.js +1 -1
  242. package/dist/components/shared/DraggableCollection.js +1 -1
  243. package/dist/components/shared/InvalidIcon.js +1 -1
  244. package/dist/components/shared/ValidIcon.js +1 -1
  245. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  246. package/dist/components/status/Spin/Cube.js +1 -1
  247. package/dist/components/status/Spin/InternalSpinner.js +1 -1
  248. package/dist/components/status/Spin/Spin.js +1 -1
  249. package/dist/components/status/Spin/SpinsContainer.js +1 -1
  250. package/dist/data/item-themes.js +1 -1
  251. package/dist/data/themes.js +1 -1
  252. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  253. package/dist/icons/AdjustmentsIcon.js +1 -1
  254. package/dist/icons/AiIcon.js +1 -1
  255. package/dist/icons/AreaChartIcon.js +1 -1
  256. package/dist/icons/BackwardIcon.js +1 -1
  257. package/dist/icons/BarChartIcon.js +1 -1
  258. package/dist/icons/BellFilledIcon.js +1 -1
  259. package/dist/icons/BellIcon.js +1 -1
  260. package/dist/icons/BooleanIcon.js +1 -1
  261. package/dist/icons/CalendarEditIcon.js +1 -1
  262. package/dist/icons/CalendarIcon.js +1 -1
  263. package/dist/icons/CaretDownIcon.js +1 -1
  264. package/dist/icons/CaretUpIcon.js +1 -1
  265. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  266. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  267. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  268. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  269. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  270. package/dist/icons/ChartBarLineIcon.js +1 -1
  271. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  272. package/dist/icons/ChartBarStackedIcon.js +1 -1
  273. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  274. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  275. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  276. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  277. package/dist/icons/ChartBubbleIcon.js +1 -1
  278. package/dist/icons/ChartDonut2Icon.js +1 -1
  279. package/dist/icons/ChartFunnelIcon.js +1 -1
  280. package/dist/icons/ChartHeatmapIcon.js +1 -1
  281. package/dist/icons/ChartKPIIcon.js +1 -1
  282. package/dist/icons/ChartPie2Icon.js +1 -1
  283. package/dist/icons/ChartScatterIcon.js +1 -1
  284. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  285. package/dist/icons/CheckCircleIcon.js +1 -1
  286. package/dist/icons/CheckIcon.js +1 -1
  287. package/dist/icons/CircleFilledIcon.js +1 -1
  288. package/dist/icons/ClearIcon.js +1 -1
  289. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  290. package/dist/icons/CloseCircleIcon.js +1 -1
  291. package/dist/icons/CloseIcon.js +1 -1
  292. package/dist/icons/CodeIcon.js +1 -1
  293. package/dist/icons/ColumnTotalIcon.js +1 -1
  294. package/dist/icons/CopyIcon.js +1 -1
  295. package/dist/icons/CountIcon.js +1 -1
  296. package/dist/icons/CubeIcon.js +1 -1
  297. package/dist/icons/CubePauseIcon.js +1 -1
  298. package/dist/icons/CubePlayIcon.js +1 -1
  299. package/dist/icons/CurrencyDollarIcon.js +1 -1
  300. package/dist/icons/DangerIcon.js +1 -1
  301. package/dist/icons/DashboardIcon.js +1 -1
  302. package/dist/icons/DatabaseIcon.js +1 -1
  303. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  304. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  305. package/dist/icons/DirectionIcon.js +1 -1
  306. package/dist/icons/DonutIcon.js +1 -1
  307. package/dist/icons/DownIcon.js +1 -1
  308. package/dist/icons/EditIcon.js +1 -1
  309. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  310. package/dist/icons/ExclamationCircleIcon.js +1 -1
  311. package/dist/icons/ExclamationIcon.js +1 -1
  312. package/dist/icons/EyeIcon.js +1 -1
  313. package/dist/icons/EyeInvisibleIcon.js +1 -1
  314. package/dist/icons/FilterIcon.js +1 -1
  315. package/dist/icons/FolderFilledIcon.js +1 -1
  316. package/dist/icons/FolderIcon.js +1 -1
  317. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  318. package/dist/icons/FolderOpenIcon.js +1 -1
  319. package/dist/icons/ForwardIcon.js +1 -1
  320. package/dist/icons/GripVerticalIcon.js +1 -1
  321. package/dist/icons/HierarchyIcon.js +1 -1
  322. package/dist/icons/HierarchyOpenIcon.js +1 -1
  323. package/dist/icons/Icon.js +1 -1
  324. package/dist/icons/InfoCircleIcon.js +1 -1
  325. package/dist/icons/InfoIcon.js +1 -1
  326. package/dist/icons/KeyIcon.js +1 -1
  327. package/dist/icons/LeftIcon.js +1 -1
  328. package/dist/icons/LineChartIcon.js +1 -1
  329. package/dist/icons/LoadingIcon.js +1 -1
  330. package/dist/icons/LockFilledIcon.js +1 -1
  331. package/dist/icons/LockIcon.js +1 -1
  332. package/dist/icons/MoreIcon.js +1 -1
  333. package/dist/icons/NotAllowedIcon.js +1 -1
  334. package/dist/icons/Number123Icon.js +1 -1
  335. package/dist/icons/NumberIcon.js +1 -1
  336. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  337. package/dist/icons/PauseCircleIcon.js +1 -1
  338. package/dist/icons/PauseIcon.js +1 -1
  339. package/dist/icons/PercentageIcon.js +1 -1
  340. package/dist/icons/PieChartIcon.js +1 -1
  341. package/dist/icons/PlayCircleIcon.js +1 -1
  342. package/dist/icons/PlayIcon.js +1 -1
  343. package/dist/icons/PlusIcon.js +1 -1
  344. package/dist/icons/ProgressBarIcon.js +1 -1
  345. package/dist/icons/ReloadIcon.js +1 -1
  346. package/dist/icons/ReportIcon.js +1 -1
  347. package/dist/icons/ReturnIcon.js +1 -1
  348. package/dist/icons/RightIcon.js +1 -1
  349. package/dist/icons/RowTotalsIcon.js +1 -1
  350. package/dist/icons/SchemeIcon.js +1 -1
  351. package/dist/icons/SearchIcon.js +1 -1
  352. package/dist/icons/SemanticQueryIcon.js +1 -1
  353. package/dist/icons/SettingsIcon.js +1 -1
  354. package/dist/icons/ShieldFilledIcon.js +1 -1
  355. package/dist/icons/ShieldIcon.js +1 -1
  356. package/dist/icons/SlashIcon.js +1 -1
  357. package/dist/icons/SparklesIcon.js +1 -1
  358. package/dist/icons/SqlIcon.js +1 -1
  359. package/dist/icons/StatsIcon.js +1 -1
  360. package/dist/icons/StopIcon.js +1 -1
  361. package/dist/icons/StringIcon.js +1 -1
  362. package/dist/icons/SubtotalsIcon.js +1 -1
  363. package/dist/icons/SwitchIcon.js +1 -1
  364. package/dist/icons/TableIcon.js +1 -1
  365. package/dist/icons/ThumbsDownIcon.js +1 -1
  366. package/dist/icons/ThumbsUpIcon.js +1 -1
  367. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  368. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  369. package/dist/icons/ThunderboltIcon.js +1 -1
  370. package/dist/icons/TimeIcon.js +1 -1
  371. package/dist/icons/TrashIcon.js +1 -1
  372. package/dist/icons/UnlockIcon.js +1 -1
  373. package/dist/icons/UpIcon.js +1 -1
  374. package/dist/icons/UserGroupIcon.js +1 -1
  375. package/dist/icons/UserIcon.js +1 -1
  376. package/dist/icons/UserLockIcon.js +1 -1
  377. package/dist/icons/ViewIcon.js +1 -1
  378. package/dist/icons/WarningFilledIcon.js +1 -1
  379. package/dist/icons/WarningIcon.js +1 -1
  380. package/dist/icons/wrap-icon.js +1 -1
  381. package/dist/index.js +1 -1
  382. package/dist/provider.js +1 -1
  383. package/dist/providers/TrackingProvider.js +1 -1
  384. package/dist/providers/navigationAdapter.default.js +1 -1
  385. package/dist/tokens/base.js +1 -1
  386. package/dist/tokens/colors.js +1 -1
  387. package/dist/tokens/index.js +1 -1
  388. package/dist/tokens/layout.js +1 -1
  389. package/dist/tokens/shadows.js +1 -1
  390. package/dist/tokens/sizes.js +1 -1
  391. package/dist/tokens/spacing.js +1 -1
  392. package/dist/tokens/typography.js +1 -1
  393. package/dist/utils/ResizeSensor.js +1 -1
  394. package/dist/utils/is-dev-env.js +1 -1
  395. package/dist/utils/modules.js +1 -1
  396. package/dist/utils/promise.js +1 -1
  397. package/dist/utils/raf.js +1 -1
  398. package/dist/utils/random.js +1 -1
  399. package/dist/utils/range.js +1 -1
  400. package/dist/utils/react/RenderCache.js +1 -1
  401. package/dist/utils/react/Slots.js +1 -1
  402. package/dist/utils/react/chain.js +1 -1
  403. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  404. package/dist/utils/react/index.js +1 -1
  405. package/dist/utils/react/interactions.js +1 -1
  406. package/dist/utils/react/isTextOnly.js +1 -1
  407. package/dist/utils/react/mapProps.js +1 -1
  408. package/dist/utils/react/mergeProps.js +1 -1
  409. package/dist/utils/react/nullableValue.js +1 -1
  410. package/dist/utils/react/resolveIcon.js +1 -1
  411. package/dist/utils/react/sharedStore.js +1 -1
  412. package/dist/utils/react/useCombinedRefs.js +1 -1
  413. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  414. package/dist/utils/react/useEventBus.js +1 -1
  415. package/dist/utils/react/useId.js +1 -1
  416. package/dist/utils/react/useIsDarwin.js +1 -1
  417. package/dist/utils/react/useKeySymbols.js +1 -1
  418. package/dist/utils/react/useLayoutEffect.js +1 -1
  419. package/dist/utils/react/useLocalStorage.js +1 -1
  420. package/dist/utils/react/useMergeStyles.js +1 -1
  421. package/dist/utils/react/usePopoverSync.js +69 -0
  422. package/dist/utils/react/usePopoverSync.js.map +1 -0
  423. package/dist/utils/react/useQaProps.js +1 -1
  424. package/dist/utils/react/useViewportSize.js +1 -1
  425. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  426. package/dist/utils/selection.js +1 -1
  427. package/dist/utils/styles.js +1 -1
  428. package/dist/utils/tree.js +1 -1
  429. package/dist/utils/warnings.js +1 -1
  430. package/dist/version.js +2 -2
  431. package/package.json +2 -1
@@ -1 +1 @@
1
- {"version":3,"file":"FilterPicker.js","names":["Text","ItemButton","BaseSection"],"sources":["../../../../src/components/fields/FilterPicker/FilterPicker.tsx"],"sourcesContent":["import { CollectionChildren, FocusableRefValue } from '@react-types/shared';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n BaseStyleProps,\n COLOR_STYLES,\n ColorStyleProps,\n filterBaseProps,\n OUTER_STYLES,\n OuterStyleProps,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n ForwardedRef,\n forwardRef,\n ReactElement,\n ReactNode,\n RefObject,\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 { processSelectionArray } from '../../../utils/selection';\nimport { extractStyles } from '../../../utils/styles';\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 {\n CubeFilterListBoxProps,\n FilterListBox,\n} from '../FilterListBox/FilterListBox';\nimport { ListBox } from '../ListBox';\n\nimport type { FieldBaseProps } from '../../../shared';\n\ninterface ItemWithKey {\n key?: string | number;\n id?: string | number;\n textValue?: string;\n children?: ItemWithKey[];\n [key: string]: unknown;\n}\n\nexport interface CubeFilterPickerProps<T>\n extends Omit<CubeFilterListBoxProps<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 (from FilterListBox) */\n listStateRef?: RefObject<ListState<T>>;\n /** Additional modifiers for styling the FilterPicker */\n mods?: Record<string, boolean>;\n /** Whether the filter 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 * Whether items are currently loading. Shows a loading spinner in the search\n * input suffix inside the popover. Unlike `isLoading`, this does NOT disable\n * the trigger.\n */\n isLoadingItems?: boolean;\n /**\n * Sort selected items to the top when the popover opens.\n * Only works when using the `items` prop (data-driven mode).\n * Ignored when using JSX children.\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 FilterPickerWrapper = tasty({\n qa: 'FilterPicker',\n styles: {\n display: 'inline-grid',\n flow: 'column',\n gridRows: '1sf',\n placeContent: 'stretch',\n placeItems: 'stretch',\n },\n});\n\nexport const FilterPicker = forwardRef(function FilterPicker<T extends object>(\n props: CubeFilterPickerProps<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 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 qa,\n label,\n extra,\n id,\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 allowsCustomValue,\n renderSummary,\n isCheckable,\n allValueProps,\n customValueProps,\n newCustomValueProps,\n searchPlaceholder,\n autoFocus,\n filter,\n emptyLabel,\n searchInputStyles,\n searchInputRef,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n disallowEmptySelection,\n shouldUseVirtualFocus,\n onEscape,\n onOptionClick,\n isClearable,\n isLoadingItems,\n searchValue,\n onSearchChange,\n sortSelectedToTop: sortSelectedToTopProp,\n onOpenChange,\n isReorderable,\n onReorder,\n form,\n ...otherProps\n } = props;\n\n const sortSelectedToTopExplicit = sortSelectedToTopProp !== undefined;\n const sortSelectedToTop = sortSelectedToTopProp ?? (items ? true : false);\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n const filterPickerId = useMemo(() => generateRandomId(), []);\n\n const { emit, on } = useEventBus();\n\n useWarn(isCheckable === false && selectionMode === 'single', {\n key: ['filterpicker-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 useWarn(sortSelectedToTopExplicit && sortSelectedToTop && !items, {\n key: ['filterpicker-sort-selected-to-top-children'],\n args: [\n 'FilterPicker: sortSelectedToTop only works with the items prop. Sorting will be skipped when using JSX children.',\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 // Popover state — used as controlled prop for DialogTrigger\n const [isPopoverOpen, setIsPopoverOpen] = useState(false);\n const cachedItemsOrder = useRef<T[] | null>(null);\n const triggerRef = useRef<FocusableRefValue<HTMLButtonElement>>(null);\n // Measured lazily on popover open instead of on every render\n const triggerWidthRef = useRef<number | undefined>(undefined);\n\n useEffect(() => {\n cachedItemsOrder.current = null;\n }, [items]);\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 // Collection for label extraction (shared with FilterListBox via _internalCollection)\n const localCollectionState = useListState({\n children: children as any,\n items: items as any,\n selectionMode: 'none' as any,\n });\n\n // Build Maps for O(1) label and key lookups from the collection\n const { labelMap, keyMap } = useMemo(() => {\n const lm = new Map<string, string>();\n const km = new Map<string, Key>();\n\n const traverse = (nodes: Iterable<any>) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n const strKey = String(node.key);\n lm.set(strKey, node.textValue || strKey);\n km.set(strKey, node.key);\n } else if (node.childNodes) {\n traverse(node.childNodes);\n }\n }\n };\n\n traverse(localCollectionState.collection);\n return { labelMap: lm, keyMap: km };\n }, [localCollectionState.collection]);\n\n // O(1) key mapping via Map (replaces O(n) iteration per key)\n const mappedSelectedKey = useMemo(() => {\n if (selectionMode !== 'single' || effectiveSelectedKey == null) return null;\n const strKey = String(effectiveSelectedKey);\n return keyMap.get(strKey) ?? effectiveSelectedKey;\n }, [selectionMode, effectiveSelectedKey, keyMap]);\n\n const mappedSelectedKeys = useMemo(() => {\n if (selectionMode !== 'multiple') return undefined;\n if (effectiveSelectedKeys === 'all') return 'all' as const;\n if (Array.isArray(effectiveSelectedKeys)) {\n return effectiveSelectedKeys.map((k) => {\n const strKey = String(k);\n return keyMap.get(strKey) ?? k;\n });\n }\n return effectiveSelectedKeys;\n }, [selectionMode, effectiveSelectedKeys, keyMap]);\n\n // Memoized label extraction using the labelMap\n const selectedLabels = useMemo(() => {\n if (selectionMode === 'multiple' && effectiveSelectedKeys === 'all') {\n return Array.from(labelMap.values());\n }\n\n const selectedKeyStrs =\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map(String)\n : effectiveSelectedKey != null\n ? [String(effectiveSelectedKey)]\n : [];\n\n return selectedKeyStrs.map((k) => labelMap.get(k) ?? k);\n }, [selectionMode, effectiveSelectedKey, effectiveSelectedKeys, labelMap]);\n\n const hasSelection = selectedLabels.length > 0;\n\n // Refs for tracking selection state synchronously\n const latestSelectionRef = useRef<{\n single: string | null;\n multiple: 'all' | string[];\n }>({\n single: effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n });\n\n useEffect(() => {\n latestSelectionRef.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n };\n }, [effectiveSelectedKey, effectiveSelectedKeys]);\n\n const selectionsWhenClosed = useRef<{\n single: string | null;\n multiple: 'all' | string[];\n }>({ single: null, multiple: [] });\n\n useEffect(() => {\n if (!isPopoverOpen) {\n selectionsWhenClosed.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n };\n }\n }, [effectiveSelectedKey, effectiveSelectedKeys, isPopoverOpen]);\n\n // ---------------------------------------------------------------------------\n // Popover lifecycle — all effects moved out of the inline renderTrigger\n // function so they have a stable component identity and don't tear\n // down/setup on every parent re-render.\n // DialogTrigger is controlled via isOpen/onOpenChange.\n // ---------------------------------------------------------------------------\n\n const handleOpenChange = useEvent((isOpen: boolean) => {\n if (isOpen === isPopoverOpen) return;\n\n if (isOpen) {\n triggerWidthRef.current =\n triggerRef?.current?.UNSAFE_getDOMNode()?.offsetWidth;\n }\n setIsPopoverOpen(isOpen);\n if (!isOpen) {\n selectionsWhenClosed.current = { ...latestSelectionRef.current };\n cachedItemsOrder.current = null;\n onSearchChange?.('');\n }\n onOpenChange?.(isOpen);\n });\n\n // Close this picker when another menu opens (event bus)\n useEffect(() => {\n return on('popover:open', (data: { menuId: string }) => {\n if (data.menuId !== filterPickerId && isPopoverOpen) {\n handleOpenChange(false);\n }\n });\n }, [on, filterPickerId, isPopoverOpen, handleOpenChange]);\n\n // Emit event when this picker opens\n useEffect(() => {\n if (isPopoverOpen) {\n emit('popover:open', { menuId: filterPickerId });\n }\n }, [isPopoverOpen, emit, filterPickerId]);\n\n // Keyboard handler for arrow keys to open popover\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if ((e.key === 'ArrowUp' || e.key === 'ArrowDown') && !isPopoverOpen) {\n e.preventDefault();\n handleOpenChange(true);\n }\n },\n });\n\n // Clear handler\n const 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 handleOpenChange(false);\n triggerRef?.current?.focus?.();\n props.onClear?.();\n\n return false;\n });\n\n // ---------------------------------------------------------------------------\n // Sorting\n // ---------------------------------------------------------------------------\n\n // Ref values (selectionsWhenClosed.current) are read synchronously inside\n // the memo body; isPopoverOpen changing triggers recomputation at the right\n // time (the ref is updated before the next render).\n const finalItems = useMemo(() => {\n if (!items) return items;\n if (!sortSelectedToTop) return items;\n if (!isPopoverOpen) return items;\n if (cachedItemsOrder.current) return cachedItemsOrder.current;\n\n const selectedSet = new Set<string>();\n\n const addSelected = (key: Key) => {\n if (key != null) selectedSet.add(String(key));\n };\n\n if (selectionMode === 'multiple') {\n if (selectionsWhenClosed.current.multiple === 'all') {\n return items;\n }\n (selectionsWhenClosed.current.multiple as string[]).forEach(addSelected);\n } else {\n if (selectionsWhenClosed.current.single != null) {\n addSelected(selectionsWhenClosed.current.single);\n }\n }\n\n if (selectedSet.size === 0) {\n return items;\n }\n\n const getItemKey = (obj: unknown): string | undefined => {\n if (obj == null || typeof obj !== 'object') return undefined;\n\n const item = obj as ItemWithKey;\n if (item.key != null) return String(item.key);\n if (item.id != null) return String(item.id);\n return undefined;\n };\n\n const sortArray = (arr: unknown[]): unknown[] => {\n const selectedArr: unknown[] = [];\n const unselectedArr: unknown[] = [];\n\n arr.forEach((obj) => {\n const item = obj as ItemWithKey;\n if (obj && Array.isArray(item.children)) {\n const sortedChildren = sortArray(item.children);\n unselectedArr.push({ ...item, children: sortedChildren });\n } else {\n const key = getItemKey(obj);\n if (key && selectedSet.has(key)) {\n selectedArr.push(obj);\n } else {\n unselectedArr.push(obj);\n }\n }\n });\n\n return [...selectedArr, ...unselectedArr];\n };\n\n const itemsArray = Array.isArray(items)\n ? items\n : Array.from(items as Iterable<unknown>);\n const sorted = sortArray(itemsArray) as T[];\n\n cachedItemsOrder.current = sorted;\n\n return sorted;\n }, [items, sortSelectedToTop, selectionMode, isPopoverOpen]);\n\n // ---------------------------------------------------------------------------\n // Trigger content\n // ---------------------------------------------------------------------------\n\n const triggerContent = useMemo((): ReactNode => {\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 if (!hasSelection) {\n return <Text.Placeholder>{placeholder}</Text.Placeholder>;\n } else if (selectionMode === 'single') {\n return selectedLabels[0] || null;\n } else if (effectiveSelectedKeys === 'all') {\n return selectAllLabel;\n } else {\n return selectedLabels.join(', ') || null;\n }\n }, [\n renderSummary,\n selectionMode,\n selectedLabels,\n effectiveSelectedKey,\n effectiveSelectedKeys,\n hasSelection,\n placeholder,\n selectAllLabel,\n ]);\n\n const showClearButton =\n isClearable && hasSelection && !isDisabled && !props.isReadOnly;\n\n // Trigger element — plain JSX with no hooks.\n // The element type (ItemButton) is stable so React can reconcile efficiently.\n const triggerElement = (\n <ItemButton\n ref={triggerRef as any}\n data-popover-trigger\n qa={qa || 'FilterPicker'}\n id={id}\n type={type}\n theme={validationState === 'invalid' ? 'danger' : theme}\n size={size}\n shape={shape}\n isDisabled={isDisabled || isLoading}\n data-input-type=\"filterpicker\"\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=\"FilterPickerClearButton\"\n mods={{ pressed: false }}\n onPress={clearValue}\n />\n ) : (\n <DirectionIcon to={isPopoverOpen ? '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 {triggerContent}\n </ItemButton>\n );\n\n // ---------------------------------------------------------------------------\n // Selection change handler\n // ---------------------------------------------------------------------------\n\n const handleSelectionChange = useEvent((selection: any) => {\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;\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 instanceof Set\n ) {\n normalized = processSelectionArray(selection as Set<Key>);\n }\n\n setInternalSelectedKeys(normalized);\n }\n }\n\n // Update latest selection ref synchronously\n if (selectionMode === 'single') {\n latestSelectionRef.current.single =\n selection != null ? String(selection) : null;\n } else {\n if (selection === 'all') {\n latestSelectionRef.current.multiple = 'all';\n } else if (Array.isArray(selection)) {\n latestSelectionRef.current.multiple = Array.from(\n new Set(processSelectionArray(selection)),\n );\n } else if (\n selection &&\n typeof selection === 'object' &&\n selection instanceof Set\n ) {\n latestSelectionRef.current.multiple = Array.from(\n new Set(processSelectionArray(selection as Set<Key>)),\n );\n } else {\n latestSelectionRef.current.multiple =\n selection === 'all'\n ? 'all'\n : Array.isArray(selection)\n ? selection.map(String)\n : [];\n }\n }\n\n onSelectionChange?.(selection);\n\n if (selectionMode === 'single') {\n handleOpenChange(false);\n }\n });\n\n // Stable callbacks for popover content (avoid inline closures that change every render)\n const handleEscape = useEvent(() => {\n handleOpenChange(false);\n });\n\n const handleOptionClick = useEvent((key: Key) => {\n if ((selectionMode === 'multiple' && isCheckable) || key === '__ALL__') {\n handleOpenChange(false);\n }\n });\n\n const filterPickerField = (\n <FilterPickerWrapper\n qa=\"FilterPickerWrapper\"\n styles={styles}\n {...filterBaseProps(otherProps, { eventProps: true })}\n >\n <DialogTrigger\n isDismissable\n type=\"popover\"\n placement=\"bottom start\"\n isOpen={isPopoverOpen}\n containerPadding={containerPadding}\n shouldFlip={shouldFlip}\n shouldCloseOnInteractOutside={(el) => {\n const menuTriggerEl = el.closest('[data-popover-trigger]');\n if (!menuTriggerEl) return true;\n if (menuTriggerEl === triggerRef?.current?.UNSAFE_getDOMNode())\n return true;\n return false;\n }}\n onOpenChange={handleOpenChange}\n >\n {triggerElement}\n {() => (\n <Dialog\n qa=\"FilterPickerOverlay\"\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 triggerWidthRef.current\n ? ({\n '--overlay-min-width': `${triggerWidthRef.current}px`,\n } as any)\n : undefined\n }\n >\n <FocusScope restoreFocus>\n <FilterListBox\n autoFocus\n items={items ? (finalItems as typeof props.items) : undefined}\n aria-label={`${props['aria-label'] ?? props.label ?? ''} Picker`}\n _internalCollection={localCollectionState.collection}\n selectedKey={\n selectionMode === 'single' ? mappedSelectedKey : undefined\n }\n selectedKeys={\n selectionMode === 'multiple' ? mappedSelectedKeys : undefined\n }\n searchPlaceholder={searchPlaceholder}\n filter={filter}\n searchValue={searchValue}\n listStyles={listStyles}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n listRef={listRef}\n disallowEmptySelection={disallowEmptySelection}\n emptyLabel={emptyLabel}\n searchInputStyles={searchInputStyles}\n searchInputRef={searchInputRef}\n disabledKeys={disabledKeys}\n focusOnHover={focusOnHover}\n shouldFocusWrap={shouldFocusWrap}\n allowsCustomValue={allowsCustomValue}\n selectionMode={selectionMode}\n validationState={validationState}\n isDisabled={isDisabled}\n isLoading={isLoading}\n isLoadingItems={isLoadingItems}\n stateRef={listStateRef}\n isCheckable={isCheckable}\n mods={{\n popover: true,\n }}\n size={size === 'small' ? 'medium' : size}\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n header={header}\n footer={footer}\n headerStyles={headerStyles}\n footerStyles={footerStyles}\n allValueProps={allValueProps}\n customValueProps={customValueProps}\n newCustomValueProps={newCustomValueProps}\n isReorderable={isReorderable}\n onSearchChange={onSearchChange}\n onReorder={onReorder}\n onEscape={handleEscape}\n onOptionClick={handleOptionClick}\n onSelectionChange={handleSelectionChange}\n >\n {\n (children\n ? (children as CollectionChildren<T>)\n : undefined) as CollectionChildren<T>\n }\n </FilterListBox>\n </FocusScope>\n </Dialog>\n )}\n </DialogTrigger>\n </FilterPickerWrapper>\n );\n\n return wrapWithField<Omit<CubeFilterPickerProps<T>, 'children' | 'tooltip'>>(\n filterPickerField,\n ref as any,\n props,\n );\n}) as unknown as (<T>(\n props: CubeFilterPickerProps<T> & { ref?: ForwardedRef<HTMLElement> },\n) => ReactElement) & { Item: typeof ListBox.Item; Section: typeof BaseSection };\n\nFilterPicker.Item = ListBox.Item;\n\nFilterPicker.Section = BaseSection;\n\nObject.defineProperty(FilterPicker, 'cubeInputType', {\n value: 'FilterPicker',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"FilterPicker.js","names":["Text","ItemButton","BaseSection"],"sources":["../../../../src/components/fields/FilterPicker/FilterPicker.tsx"],"sourcesContent":["import { CollectionChildren, FocusableRefValue } from '@react-types/shared';\nimport {\n BASE_STYLES,\n BasePropsWithoutChildren,\n BaseStyleProps,\n COLOR_STYLES,\n ColorStyleProps,\n filterBaseProps,\n OUTER_STYLES,\n OuterStyleProps,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n ForwardedRef,\n forwardRef,\n ReactElement,\n ReactNode,\n RefObject,\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 { usePopoverSync } from '../../../utils/react/usePopoverSync';\nimport { processSelectionArray } from '../../../utils/selection';\nimport { extractStyles } from '../../../utils/styles';\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 {\n CubeFilterListBoxProps,\n FilterListBox,\n} from '../FilterListBox/FilterListBox';\nimport { ListBox } from '../ListBox';\n\nimport type { FieldBaseProps } from '../../../shared';\n\ninterface ItemWithKey {\n key?: string | number;\n id?: string | number;\n textValue?: string;\n children?: ItemWithKey[];\n [key: string]: unknown;\n}\n\nexport interface CubeFilterPickerProps<T>\n extends Omit<CubeFilterListBoxProps<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 (from FilterListBox) */\n listStateRef?: RefObject<ListState<T>>;\n /** Additional modifiers for styling the FilterPicker */\n mods?: Record<string, boolean>;\n /** Whether the filter 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 * Whether items are currently loading. Shows a loading spinner in the search\n * input suffix inside the popover. Unlike `isLoading`, this does NOT disable\n * the trigger.\n */\n isLoadingItems?: boolean;\n /**\n * Sort selected items to the top when the popover opens.\n * Only works when using the `items` prop (data-driven mode).\n * Ignored when using JSX children.\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 FilterPickerWrapper = tasty({\n qa: 'FilterPicker',\n styles: {\n display: 'inline-grid',\n flow: 'column',\n gridRows: '1sf',\n placeContent: 'stretch',\n placeItems: 'stretch',\n },\n});\n\nexport const FilterPicker = forwardRef(function FilterPicker<T extends object>(\n props: CubeFilterPickerProps<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 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 qa,\n label,\n extra,\n id,\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 allowsCustomValue,\n renderSummary,\n isCheckable,\n allValueProps,\n customValueProps,\n newCustomValueProps,\n searchPlaceholder,\n autoFocus,\n filter,\n emptyLabel,\n searchInputStyles,\n searchInputRef,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n listRef,\n disallowEmptySelection,\n shouldUseVirtualFocus,\n onEscape,\n onOptionClick,\n isClearable,\n isLoadingItems,\n searchValue,\n onSearchChange,\n sortSelectedToTop: sortSelectedToTopProp,\n onOpenChange,\n isReorderable,\n onReorder,\n form,\n ...otherProps\n } = props;\n\n const sortSelectedToTopExplicit = sortSelectedToTopProp !== undefined;\n const sortSelectedToTop = sortSelectedToTopProp ?? (items ? true : false);\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n const filterPickerId = useMemo(() => generateRandomId(), []);\n\n useWarn(isCheckable === false && selectionMode === 'single', {\n key: ['filterpicker-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 useWarn(sortSelectedToTopExplicit && sortSelectedToTop && !items, {\n key: ['filterpicker-sort-selected-to-top-children'],\n args: [\n 'FilterPicker: sortSelectedToTop only works with the items prop. Sorting will be skipped when using JSX children.',\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 // Popover state — used as controlled prop for DialogTrigger\n const [isPopoverOpen, setIsPopoverOpen] = useState(false);\n const cachedItemsOrder = useRef<T[] | null>(null);\n const triggerRef = useRef<FocusableRefValue<HTMLButtonElement>>(null);\n // Measured lazily on popover open instead of on every render\n const triggerWidthRef = useRef<number | undefined>(undefined);\n\n useEffect(() => {\n cachedItemsOrder.current = null;\n }, [items]);\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 // Collection for label extraction (shared with FilterListBox via _internalCollection)\n const localCollectionState = useListState({\n children: children as any,\n items: items as any,\n selectionMode: 'none' as any,\n });\n\n // Build Maps for O(1) label and key lookups from the collection\n const { labelMap, keyMap } = useMemo(() => {\n const lm = new Map<string, string>();\n const km = new Map<string, Key>();\n\n const traverse = (nodes: Iterable<any>) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n const strKey = String(node.key);\n lm.set(strKey, node.textValue || strKey);\n km.set(strKey, node.key);\n } else if (node.childNodes) {\n traverse(node.childNodes);\n }\n }\n };\n\n traverse(localCollectionState.collection);\n return { labelMap: lm, keyMap: km };\n }, [localCollectionState.collection]);\n\n // O(1) key mapping via Map (replaces O(n) iteration per key)\n const mappedSelectedKey = useMemo(() => {\n if (selectionMode !== 'single' || effectiveSelectedKey == null) return null;\n const strKey = String(effectiveSelectedKey);\n return keyMap.get(strKey) ?? effectiveSelectedKey;\n }, [selectionMode, effectiveSelectedKey, keyMap]);\n\n const mappedSelectedKeys = useMemo(() => {\n if (selectionMode !== 'multiple') return undefined;\n if (effectiveSelectedKeys === 'all') return 'all' as const;\n if (Array.isArray(effectiveSelectedKeys)) {\n return effectiveSelectedKeys.map((k) => {\n const strKey = String(k);\n return keyMap.get(strKey) ?? k;\n });\n }\n return effectiveSelectedKeys;\n }, [selectionMode, effectiveSelectedKeys, keyMap]);\n\n // Memoized label extraction using the labelMap\n const selectedLabels = useMemo(() => {\n if (selectionMode === 'multiple' && effectiveSelectedKeys === 'all') {\n return Array.from(labelMap.values());\n }\n\n const selectedKeyStrs =\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map(String)\n : effectiveSelectedKey != null\n ? [String(effectiveSelectedKey)]\n : [];\n\n return selectedKeyStrs.map((k) => labelMap.get(k) ?? k);\n }, [selectionMode, effectiveSelectedKey, effectiveSelectedKeys, labelMap]);\n\n const hasSelection = selectedLabels.length > 0;\n\n // Refs for tracking selection state synchronously\n const latestSelectionRef = useRef<{\n single: string | null;\n multiple: 'all' | string[];\n }>({\n single: effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n });\n\n useEffect(() => {\n latestSelectionRef.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n };\n }, [effectiveSelectedKey, effectiveSelectedKeys]);\n\n const selectionsWhenClosed = useRef<{\n single: string | null;\n multiple: 'all' | string[];\n }>({ single: null, multiple: [] });\n\n useEffect(() => {\n if (!isPopoverOpen) {\n selectionsWhenClosed.current = {\n single:\n effectiveSelectedKey != null ? String(effectiveSelectedKey) : null,\n multiple:\n effectiveSelectedKeys === 'all'\n ? 'all'\n : (effectiveSelectedKeys ?? []).map(String),\n };\n }\n }, [effectiveSelectedKey, effectiveSelectedKeys, isPopoverOpen]);\n\n // ---------------------------------------------------------------------------\n // Popover lifecycle — all effects moved out of the inline renderTrigger\n // function so they have a stable component identity and don't tear\n // down/setup on every parent re-render.\n // DialogTrigger is controlled via isOpen/onOpenChange.\n // ---------------------------------------------------------------------------\n\n const handleOpenChange = useEvent((isOpen: boolean) => {\n if (isOpen === isPopoverOpen) return;\n\n if (isOpen) {\n triggerWidthRef.current =\n triggerRef?.current?.UNSAFE_getDOMNode()?.offsetWidth;\n }\n setIsPopoverOpen(isOpen);\n if (!isOpen) {\n selectionsWhenClosed.current = { ...latestSelectionRef.current };\n cachedItemsOrder.current = null;\n onSearchChange?.('');\n }\n onOpenChange?.(isOpen);\n });\n\n usePopoverSync({\n menuId: filterPickerId,\n isOpen: isPopoverOpen,\n onClose: () => handleOpenChange(false),\n });\n\n // Keyboard handler for arrow keys to open popover\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if ((e.key === 'ArrowUp' || e.key === 'ArrowDown') && !isPopoverOpen) {\n e.preventDefault();\n handleOpenChange(true);\n }\n },\n });\n\n // Clear handler\n const 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 handleOpenChange(false);\n triggerRef?.current?.focus?.();\n props.onClear?.();\n\n return false;\n });\n\n // ---------------------------------------------------------------------------\n // Sorting\n // ---------------------------------------------------------------------------\n\n // Ref values (selectionsWhenClosed.current) are read synchronously inside\n // the memo body; isPopoverOpen changing triggers recomputation at the right\n // time (the ref is updated before the next render).\n const finalItems = useMemo(() => {\n if (!items) return items;\n if (!sortSelectedToTop) return items;\n if (!isPopoverOpen) return items;\n if (cachedItemsOrder.current) return cachedItemsOrder.current;\n\n const selectedSet = new Set<string>();\n\n const addSelected = (key: Key) => {\n if (key != null) selectedSet.add(String(key));\n };\n\n if (selectionMode === 'multiple') {\n if (selectionsWhenClosed.current.multiple === 'all') {\n return items;\n }\n (selectionsWhenClosed.current.multiple as string[]).forEach(addSelected);\n } else {\n if (selectionsWhenClosed.current.single != null) {\n addSelected(selectionsWhenClosed.current.single);\n }\n }\n\n if (selectedSet.size === 0) {\n return items;\n }\n\n const getItemKey = (obj: unknown): string | undefined => {\n if (obj == null || typeof obj !== 'object') return undefined;\n\n const item = obj as ItemWithKey;\n if (item.key != null) return String(item.key);\n if (item.id != null) return String(item.id);\n return undefined;\n };\n\n const sortArray = (arr: unknown[]): unknown[] => {\n const selectedArr: unknown[] = [];\n const unselectedArr: unknown[] = [];\n\n arr.forEach((obj) => {\n const item = obj as ItemWithKey;\n if (obj && Array.isArray(item.children)) {\n const sortedChildren = sortArray(item.children);\n unselectedArr.push({ ...item, children: sortedChildren });\n } else {\n const key = getItemKey(obj);\n if (key && selectedSet.has(key)) {\n selectedArr.push(obj);\n } else {\n unselectedArr.push(obj);\n }\n }\n });\n\n return [...selectedArr, ...unselectedArr];\n };\n\n const itemsArray = Array.isArray(items)\n ? items\n : Array.from(items as Iterable<unknown>);\n const sorted = sortArray(itemsArray) as T[];\n\n cachedItemsOrder.current = sorted;\n\n return sorted;\n }, [items, sortSelectedToTop, selectionMode, isPopoverOpen]);\n\n // ---------------------------------------------------------------------------\n // Trigger content\n // ---------------------------------------------------------------------------\n\n const triggerContent = useMemo((): ReactNode => {\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 if (!hasSelection) {\n return <Text.Placeholder>{placeholder}</Text.Placeholder>;\n } else if (selectionMode === 'single') {\n return selectedLabels[0] || null;\n } else if (effectiveSelectedKeys === 'all') {\n return selectAllLabel;\n } else {\n return selectedLabels.join(', ') || null;\n }\n }, [\n renderSummary,\n selectionMode,\n selectedLabels,\n effectiveSelectedKey,\n effectiveSelectedKeys,\n hasSelection,\n placeholder,\n selectAllLabel,\n ]);\n\n const showClearButton =\n isClearable && hasSelection && !isDisabled && !props.isReadOnly;\n\n // Trigger element — plain JSX with no hooks.\n // The element type (ItemButton) is stable so React can reconcile efficiently.\n const triggerElement = (\n <ItemButton\n ref={triggerRef as any}\n data-popover-trigger\n qa={qa || 'FilterPicker'}\n id={id}\n type={type}\n theme={validationState === 'invalid' ? 'danger' : theme}\n size={size}\n shape={shape}\n isDisabled={isDisabled || isLoading}\n data-input-type=\"filterpicker\"\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=\"FilterPickerClearButton\"\n mods={{ pressed: false }}\n onPress={clearValue}\n />\n ) : (\n <DirectionIcon to={isPopoverOpen ? '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 {triggerContent}\n </ItemButton>\n );\n\n // ---------------------------------------------------------------------------\n // Selection change handler\n // ---------------------------------------------------------------------------\n\n const handleSelectionChange = useEvent((selection: any) => {\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;\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 instanceof Set\n ) {\n normalized = processSelectionArray(selection as Set<Key>);\n }\n\n setInternalSelectedKeys(normalized);\n }\n }\n\n // Update latest selection ref synchronously\n if (selectionMode === 'single') {\n latestSelectionRef.current.single =\n selection != null ? String(selection) : null;\n } else {\n if (selection === 'all') {\n latestSelectionRef.current.multiple = 'all';\n } else if (Array.isArray(selection)) {\n latestSelectionRef.current.multiple = Array.from(\n new Set(processSelectionArray(selection)),\n );\n } else if (\n selection &&\n typeof selection === 'object' &&\n selection instanceof Set\n ) {\n latestSelectionRef.current.multiple = Array.from(\n new Set(processSelectionArray(selection as Set<Key>)),\n );\n } else {\n latestSelectionRef.current.multiple =\n selection === 'all'\n ? 'all'\n : Array.isArray(selection)\n ? selection.map(String)\n : [];\n }\n }\n\n onSelectionChange?.(selection);\n\n if (selectionMode === 'single') {\n handleOpenChange(false);\n }\n });\n\n // Stable callbacks for popover content (avoid inline closures that change every render)\n const handleEscape = useEvent(() => {\n handleOpenChange(false);\n });\n\n const handleOptionClick = useEvent((key: Key) => {\n if ((selectionMode === 'multiple' && isCheckable) || key === '__ALL__') {\n handleOpenChange(false);\n }\n });\n\n const filterPickerField = (\n <FilterPickerWrapper\n qa=\"FilterPickerWrapper\"\n styles={styles}\n {...filterBaseProps(otherProps, { eventProps: true })}\n >\n <DialogTrigger\n isDismissable\n type=\"popover\"\n placement=\"bottom start\"\n isOpen={isPopoverOpen}\n containerPadding={containerPadding}\n shouldFlip={shouldFlip}\n shouldCloseOnInteractOutside={(el) => {\n const menuTriggerEl = el.closest('[data-popover-trigger]');\n if (!menuTriggerEl) {\n // Plain interactive controls (Button, ItemButton) opt in via\n // `data-popover-dismiss` to dismiss us without losing their click\n // to useOverlay's stopPropagation. Schedule the close after the\n // click finishes so the button's onPress runs first.\n if (el.closest('[data-popover-dismiss]')) {\n setTimeout(() => handleOpenChange(false), 0);\n return false;\n }\n return true;\n }\n if (menuTriggerEl === triggerRef?.current?.UNSAFE_getDOMNode())\n return true;\n return false;\n }}\n onOpenChange={handleOpenChange}\n >\n {triggerElement}\n {() => (\n <Dialog\n qa=\"FilterPickerOverlay\"\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 triggerWidthRef.current\n ? ({\n '--overlay-min-width': `${triggerWidthRef.current}px`,\n } as any)\n : undefined\n }\n >\n <FocusScope restoreFocus>\n <FilterListBox\n autoFocus\n items={items ? (finalItems as typeof props.items) : undefined}\n aria-label={`${props['aria-label'] ?? props.label ?? ''} Picker`}\n _internalCollection={localCollectionState.collection}\n selectedKey={\n selectionMode === 'single' ? mappedSelectedKey : undefined\n }\n selectedKeys={\n selectionMode === 'multiple' ? mappedSelectedKeys : undefined\n }\n searchPlaceholder={searchPlaceholder}\n filter={filter}\n searchValue={searchValue}\n listStyles={listStyles}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n listRef={listRef}\n disallowEmptySelection={disallowEmptySelection}\n emptyLabel={emptyLabel}\n searchInputStyles={searchInputStyles}\n searchInputRef={searchInputRef}\n disabledKeys={disabledKeys}\n focusOnHover={focusOnHover}\n shouldFocusWrap={shouldFocusWrap}\n allowsCustomValue={allowsCustomValue}\n selectionMode={selectionMode}\n validationState={validationState}\n isDisabled={isDisabled}\n isLoading={isLoading}\n isLoadingItems={isLoadingItems}\n stateRef={listStateRef}\n isCheckable={isCheckable}\n mods={{\n popover: true,\n }}\n size={size === 'small' ? 'medium' : size}\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n header={header}\n footer={footer}\n headerStyles={headerStyles}\n footerStyles={footerStyles}\n allValueProps={allValueProps}\n customValueProps={customValueProps}\n newCustomValueProps={newCustomValueProps}\n isReorderable={isReorderable}\n onSearchChange={onSearchChange}\n onReorder={onReorder}\n onEscape={handleEscape}\n onOptionClick={handleOptionClick}\n onSelectionChange={handleSelectionChange}\n >\n {\n (children\n ? (children as CollectionChildren<T>)\n : undefined) as CollectionChildren<T>\n }\n </FilterListBox>\n </FocusScope>\n </Dialog>\n )}\n </DialogTrigger>\n </FilterPickerWrapper>\n );\n\n return wrapWithField<Omit<CubeFilterPickerProps<T>, 'children' | 'tooltip'>>(\n filterPickerField,\n ref as any,\n props,\n );\n}) as unknown as (<T>(\n props: CubeFilterPickerProps<T> & { ref?: ForwardedRef<HTMLElement> },\n) => ReactElement) & { Item: typeof ListBox.Item; Section: typeof BaseSection };\n\nFilterPicker.Item = ListBox.Item;\n\nFilterPicker.Section = BaseSection;\n\nObject.defineProperty(FilterPicker, 'cubeInputType', {\n value: 'FilterPicker',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | Cube Dev Team */
2
2
  import { _FileInput } from "../FileInput/FileInput.js";
3
3
  import { TextInput } from "../TextInput/TextInput.js";
4
4
  import { _NumberInput } from "../NumberInput/NumberInput.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | Cube Dev Team */
2
2
  import { DraggableCollection } from "../../shared/DraggableCollection.js";
3
3
  import { jsx } from "react/jsx-runtime";
4
4
 
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
4
4
  import { useCombinedRefs } from "../../../utils/react/useCombinedRefs.js";
@@ -679,24 +679,16 @@ function Option({ size = "medium", item, state, styles, isParentDisabled, valida
679
679
  validationState,
680
680
  filteredItemProps.icon
681
681
  ]);
682
- const handleOptionClick = (e) => {
682
+ const handleOptionExtras = (e) => {
683
683
  if (lastFocusSourceRef) lastFocusSourceRef.current = "mouse";
684
- if (onOptionClick && isCheckable && state.selectionManager.selectionMode === "multiple") {
684
+ state.selectionManager.setFocusedKey(item.key);
685
+ if (!onOptionClick) return;
686
+ if (isCheckable && state.selectionManager.selectionMode === "multiple") {
685
687
  const clickTarget = e.target;
686
688
  const checkboxElement = localRef.current?.querySelector("[data-element=\"CheckboxWrapper\"]");
687
- if (checkboxElement && (checkboxElement === clickTarget || checkboxElement.contains(clickTarget))) {
688
- optionProps.onClick?.(e);
689
- state.selectionManager.setFocusedKey(item.key);
690
- } else {
691
- optionProps.onClick?.(e);
692
- state.selectionManager.setFocusedKey(item.key);
693
- if (onOptionClick) onOptionClick(item.key);
694
- }
695
- } else {
696
- optionProps.onClick?.(e);
697
- state.selectionManager.setFocusedKey(item.key);
698
- if (onOptionClick) onOptionClick(item.key);
689
+ if (checkboxElement && (checkboxElement === clickTarget || checkboxElement.contains(clickTarget))) return;
699
690
  }
691
+ onOptionClick(item.key);
700
692
  };
701
693
  const { onKeyDown, onKeyUp, tabIndex, "aria-selected": ariaSelected, "aria-disabled": ariaDisabled, role, ...filteredOptionProps } = optionProps;
702
694
  const theme = {
@@ -708,7 +700,7 @@ function Option({ size = "medium", item, state, styles, isParentDisabled, valida
708
700
  id: `ListBoxItem-${String(item.key)}`,
709
701
  "data-key": String(item.key),
710
702
  ...mergeProps$1(filteredOptionProps, hoverProps, filteredItemProps, {
711
- onClick: handleOptionClick,
703
+ onClick: handleOptionExtras,
712
704
  onKeyDown,
713
705
  onKeyUp,
714
706
  tabIndex,
@@ -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 BASE_STYLES,\n BasePropsWithoutChildren,\n COLOR_STYLES,\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 DropTarget,\n useDraggableItem,\n useDropIndicator,\n useKeyboard,\n useListBox,\n useListBoxSection,\n useOption,\n} from 'react-aria';\nimport {\n Section as BaseSection,\n DraggableCollectionState,\n DroppableCollectionState,\n useListState,\n} from 'react-stately';\n\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CheckIcon, GripVerticalIcon } 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';\nimport { extractStyles } from '../../../utils/styles';\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';\nimport { createMockDragState } from '../../shared/DraggableCollection';\n\nimport { DraggableListBox } from './DraggableListBox';\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 Icon: {\n cursor: {\n draggable: 'grab',\n },\n opacity: {\n draggable: '.4',\n 'draggable & :hover': '1',\n },\n transition: {\n draggable: 'opacity',\n },\n },\n },\n});\n\n// Horizontal drop indicator for DnD reordering\nconst ListBoxDropIndicatorElement = tasty({\n as: 'li',\n styles: {\n zIndex: 10,\n position: 'relative',\n pointerEvents: 'none',\n height: 0,\n opacity: {\n '': 0,\n 'drop-target': 1,\n },\n\n Indicator: {\n $: '>',\n position: 'absolute',\n left: '.5x',\n right: '.5x',\n top: '-1px',\n height: '2px',\n fill: '#primary',\n radius: 'round',\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\nfunction renderCheckboxIcon({\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n}: {\n isSelected: boolean;\n isDisabled: boolean;\n isFocused: boolean;\n isHovered: boolean;\n validationState?: string;\n}) {\n const mods = {\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n };\n\n return (\n <ListBoxCheckboxWrapper data-element=\"CheckboxWrapper\" mods={mods}>\n <ListBoxCheckbox data-element=\"Checkbox\" mods={mods}>\n <CheckIcon size={12} stroke={3} />\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\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 /**\n * Enable drag-and-drop reordering of list items.\n * When enabled, virtualization is disabled and each item gets a drag handle.\n * @default false\n */\n isReorderable?: boolean;\n\n /**\n * Callback when items are reordered via drag-and-drop.\n * Called with the new array of item keys in their new order.\n */\n onReorder?: (newOrder: string[]) => void;\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 isReorderable = false,\n onReorder,\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 // ----- Collection and virtualization decision (must precede useListBox) -----\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 && !isReorderable;\n\n const { listBoxProps } = useListBox(\n {\n ...props,\n id: id,\n 'aria-label': props['aria-label'] || label?.toString(),\n isDisabled,\n // Only disable isVirtualized for reorderable lists (DnD needs real DOM focus).\n // Section-based lists keep isVirtualized: true to preserve ARIA attributes.\n isVirtualized: !isReorderable,\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 // 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 // Ordered keys for DnD reordering\n const orderedKeys = useMemo(() => {\n if (!isReorderable) {\n return [];\n }\n\n return itemsArray\n .filter((i) => i.type === 'item')\n .map((i) => String(i.key));\n }, [isReorderable, itemsArray]);\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 ) : isReorderable ? (\n <DraggableListBox\n state={listState}\n listRef={listRef}\n orderedKeys={orderedKeys}\n onReorder={onReorder}\n >\n {(dragState, dropState, collectionProps) => (\n <ListElement\n qa={qa || 'ListBox'}\n {...mergeProps(mergedListBoxProps, collectionProps)}\n ref={listRef}\n styles={listStyles}\n aria-disabled={isDisabled || undefined}\n mods={{ sections: false }}\n data-shape={shape}\n data-input-type=\"listbox\"\n >\n {itemsArray\n .filter((item) => item.type === 'item')\n .map((item) => (\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 dragState={dragState}\n dropState={dropState}\n onClick={onOptionClick}\n />\n ))}\n </ListElement>\n )}\n </DraggableListBox>\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 dragState,\n dropState,\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 /** Drag state from DraggableCollection. When provided, enables drag-and-drop. */\n dragState?: DraggableCollectionState;\n /** Drop state from DraggableCollection. When provided, renders drop indicators. */\n dropState?: DroppableCollectionState;\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 // Drag-and-drop support — only enable when both states are provided\n const isDraggable = !!dragState && !!dropState;\n\n // useDraggableItem must be called unconditionally (Rules of Hooks).\n // When dragState is undefined, we pass a minimal mock state to satisfy the hook.\n const mockDragState = useMemo(\n () => createMockDragState(state.collection, state.selectionManager),\n [state.collection, state.selectionManager],\n );\n\n const dragResult = useDraggableItem(\n { key: item.key },\n dragState ?? mockDragState,\n );\n const effectiveDragProps = isDraggable ? dragResult.dragProps : {};\n const isDragging = isDraggable && dragResult.isDragging;\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 // Determine icon: drag handle > checkbox > user icon > default\n const effectiveIcon = useMemo(() => {\n if (isDraggable && !filteredItemProps.icon) {\n return <GripVerticalIcon size={14} />;\n }\n\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 renderCheckboxIcon({\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n });\n }, [\n isDraggable,\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: MouseEvent) => {\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 const listBoxItem = (\n <ListBoxItem\n ref={combinedRef}\n id={`ListBoxItem-${String(item.key)}`}\n data-key={String(item.key)}\n {...mergeProps(\n filteredOptionProps,\n hoverProps,\n filteredItemProps,\n {\n onClick: handleOptionClick,\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n },\n effectiveDragProps,\n )}\n theme={theme}\n style={virtualStyle}\n data-size={size}\n data-index={virtualIndex}\n size={size}\n display={isDraggable ? 'grid' : undefined}\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 dragging: isDragging,\n draggable: isDraggable,\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 if (!isDraggable || !dropState) {\n return listBoxItem;\n }\n\n return (\n <>\n <ListBoxDropIndicator\n target={{ type: 'item', key: item.key, dropPosition: 'before' }}\n dropState={dropState}\n />\n {listBoxItem}\n <ListBoxDropIndicator\n target={{ type: 'item', key: item.key, dropPosition: 'after' }}\n dropState={dropState}\n />\n </>\n );\n}\n\n// =============================================================================\n// Drop Indicator for DnD reordering\n// =============================================================================\n\nfunction ListBoxDropIndicator({\n target,\n dropState,\n}: {\n target: DropTarget;\n dropState: DroppableCollectionState;\n}) {\n const ref = useRef<HTMLLIElement>(null);\n const { dropIndicatorProps, isHidden, isDropTarget } = useDropIndicator(\n { target },\n dropState,\n ref,\n );\n\n if (isHidden) {\n return null;\n }\n\n return (\n <ListBoxDropIndicatorElement\n ref={ref}\n role=\"option\"\n {...dropIndicatorProps}\n mods={{ 'drop-target': isDropTarget }}\n >\n <div data-element=\"Indicator\" />\n </ListBoxDropIndicatorElement>\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 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 DropTarget,\n useDraggableItem,\n useDropIndicator,\n useKeyboard,\n useListBox,\n useListBoxSection,\n useOption,\n} from 'react-aria';\nimport {\n Section as BaseSection,\n DraggableCollectionState,\n DroppableCollectionState,\n useListState,\n} from 'react-stately';\n\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CheckIcon, GripVerticalIcon } 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';\nimport { extractStyles } from '../../../utils/styles';\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';\nimport { createMockDragState } from '../../shared/DraggableCollection';\n\nimport { DraggableListBox } from './DraggableListBox';\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 Icon: {\n cursor: {\n draggable: 'grab',\n },\n opacity: {\n draggable: '.4',\n 'draggable & :hover': '1',\n },\n transition: {\n draggable: 'opacity',\n },\n },\n },\n});\n\n// Horizontal drop indicator for DnD reordering\nconst ListBoxDropIndicatorElement = tasty({\n as: 'li',\n styles: {\n zIndex: 10,\n position: 'relative',\n pointerEvents: 'none',\n height: 0,\n opacity: {\n '': 0,\n 'drop-target': 1,\n },\n\n Indicator: {\n $: '>',\n position: 'absolute',\n left: '.5x',\n right: '.5x',\n top: '-1px',\n height: '2px',\n fill: '#primary',\n radius: 'round',\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\nfunction renderCheckboxIcon({\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n}: {\n isSelected: boolean;\n isDisabled: boolean;\n isFocused: boolean;\n isHovered: boolean;\n validationState?: string;\n}) {\n const mods = {\n selected: isSelected,\n disabled: isDisabled,\n focused: isFocused,\n hovered: isHovered,\n invalid: validationState === 'invalid',\n };\n\n return (\n <ListBoxCheckboxWrapper data-element=\"CheckboxWrapper\" mods={mods}>\n <ListBoxCheckbox data-element=\"Checkbox\" mods={mods}>\n <CheckIcon size={12} stroke={3} />\n </ListBoxCheckbox>\n </ListBoxCheckboxWrapper>\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 /**\n * Enable drag-and-drop reordering of list items.\n * When enabled, virtualization is disabled and each item gets a drag handle.\n * @default false\n */\n isReorderable?: boolean;\n\n /**\n * Callback when items are reordered via drag-and-drop.\n * Called with the new array of item keys in their new order.\n */\n onReorder?: (newOrder: string[]) => void;\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 isReorderable = false,\n onReorder,\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 // ----- Collection and virtualization decision (must precede useListBox) -----\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 && !isReorderable;\n\n const { listBoxProps } = useListBox(\n {\n ...props,\n id: id,\n 'aria-label': props['aria-label'] || label?.toString(),\n isDisabled,\n // Only disable isVirtualized for reorderable lists (DnD needs real DOM focus).\n // Section-based lists keep isVirtualized: true to preserve ARIA attributes.\n isVirtualized: !isReorderable,\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 // 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 // Ordered keys for DnD reordering\n const orderedKeys = useMemo(() => {\n if (!isReorderable) {\n return [];\n }\n\n return itemsArray\n .filter((i) => i.type === 'item')\n .map((i) => String(i.key));\n }, [isReorderable, itemsArray]);\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 ) : isReorderable ? (\n <DraggableListBox\n state={listState}\n listRef={listRef}\n orderedKeys={orderedKeys}\n onReorder={onReorder}\n >\n {(dragState, dropState, collectionProps) => (\n <ListElement\n qa={qa || 'ListBox'}\n {...mergeProps(mergedListBoxProps, collectionProps)}\n ref={listRef}\n styles={listStyles}\n aria-disabled={isDisabled || undefined}\n mods={{ sections: false }}\n data-shape={shape}\n data-input-type=\"listbox\"\n >\n {itemsArray\n .filter((item) => item.type === 'item')\n .map((item) => (\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 dragState={dragState}\n dropState={dropState}\n onClick={onOptionClick}\n />\n ))}\n </ListElement>\n )}\n </DraggableListBox>\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 dragState,\n dropState,\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 /** Drag state from DraggableCollection. When provided, enables drag-and-drop. */\n dragState?: DraggableCollectionState;\n /** Drop state from DraggableCollection. When provided, renders drop indicators. */\n dropState?: DroppableCollectionState;\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 // Drag-and-drop support — only enable when both states are provided\n const isDraggable = !!dragState && !!dropState;\n\n // useDraggableItem must be called unconditionally (Rules of Hooks).\n // When dragState is undefined, we pass a minimal mock state to satisfy the hook.\n const mockDragState = useMemo(\n () => createMockDragState(state.collection, state.selectionManager),\n [state.collection, state.selectionManager],\n );\n\n const dragResult = useDraggableItem(\n { key: item.key },\n dragState ?? mockDragState,\n );\n const effectiveDragProps = isDraggable ? dragResult.dragProps : {};\n const isDragging = isDraggable && dragResult.isDragging;\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 // Determine icon: drag handle > checkbox > user icon > default\n const effectiveIcon = useMemo(() => {\n if (isDraggable && !filteredItemProps.icon) {\n return <GripVerticalIcon size={14} />;\n }\n\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 renderCheckboxIcon({\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n });\n }, [\n isDraggable,\n isCheckable,\n state.selectionManager.selectionMode,\n isSelected,\n isDisabled,\n isFocused,\n isHovered,\n validationState,\n filteredItemProps.icon,\n ]);\n\n // Side-effects layered on top of React Aria's own onClick. The underlying\n // React Aria onClick is already chained via mergeProps below, so this handler\n // must NOT call optionProps.onClick again — re-invoking it would trigger\n // usePress's virtual-click branch and double-fire onPress (and toggle\n // selection twice in multiple mode).\n const handleOptionExtras = (e: MouseEvent) => {\n if (lastFocusSourceRef) {\n lastFocusSourceRef.current = 'mouse';\n }\n\n state.selectionManager.setFocusedKey(item.key);\n\n if (!onOptionClick) {\n return;\n }\n\n // In checkable multiple mode, suppress the callback when the click landed\n // inside the checkbox wrapper — that area is reserved for toggle-only\n // behaviour (React Aria still handles the toggle via the chained onClick).\n if (isCheckable && state.selectionManager.selectionMode === 'multiple') {\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 return;\n }\n }\n\n onOptionClick(item.key);\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 const listBoxItem = (\n <ListBoxItem\n ref={combinedRef}\n id={`ListBoxItem-${String(item.key)}`}\n data-key={String(item.key)}\n {...mergeProps(\n filteredOptionProps,\n hoverProps,\n filteredItemProps,\n {\n onClick: handleOptionExtras,\n onKeyDown,\n onKeyUp,\n tabIndex,\n 'aria-selected': ariaSelected,\n 'aria-disabled': ariaDisabled,\n role,\n },\n effectiveDragProps,\n )}\n theme={theme}\n style={virtualStyle}\n data-size={size}\n data-index={virtualIndex}\n size={size}\n display={isDraggable ? 'grid' : undefined}\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 dragging: isDragging,\n draggable: isDraggable,\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 if (!isDraggable || !dropState) {\n return listBoxItem;\n }\n\n return (\n <>\n <ListBoxDropIndicator\n target={{ type: 'item', key: item.key, dropPosition: 'before' }}\n dropState={dropState}\n />\n {listBoxItem}\n <ListBoxDropIndicator\n target={{ type: 'item', key: item.key, dropPosition: 'after' }}\n dropState={dropState}\n />\n </>\n );\n}\n\n// =============================================================================\n// Drop Indicator for DnD reordering\n// =============================================================================\n\nfunction ListBoxDropIndicator({\n target,\n dropState,\n}: {\n target: DropTarget;\n dropState: DroppableCollectionState;\n}) {\n const ref = useRef<HTMLLIElement>(null);\n const { dropIndicatorProps, isHidden, isDropTarget } = useDropIndicator(\n { target },\n dropState,\n ref,\n );\n\n if (isHidden) {\n return null;\n }\n\n return (\n <ListBoxDropIndicatorElement\n ref={ref}\n role=\"option\"\n {...dropIndicatorProps}\n mods={{ 'drop-target': isDropTarget }}\n >\n <div data-element=\"Indicator\" />\n </ListBoxDropIndicatorElement>\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,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | 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 { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | Cube Dev Team */
2
2
  import { DirectionIcon } from "../../../icons/DirectionIcon.js";
3
3
  import { Button } from "../../actions/index.js";
4
4
  import { tasty } from "@tenphi/tasty";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.135.1 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.136.0 | 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";