@cube-dev/ui-kit 0.124.4 → 0.125.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (420) hide show
  1. package/dist/CHANGELOG.md +12 -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 +1 -1
  20. package/dist/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  21. package/dist/components/actions/ButtonSplit/ButtonSplit.js +1 -1
  22. package/dist/components/actions/ButtonSplit/context.js +1 -1
  23. package/dist/components/actions/CommandMenu/CommandMenu.js +1 -1
  24. package/dist/components/actions/CommandMenu/styled.js +1 -1
  25. package/dist/components/actions/ItemAction/ItemAction.js +1 -1
  26. package/dist/components/actions/ItemActionContext.js +1 -1
  27. package/dist/components/actions/ItemButton/ItemButton.js +1 -1
  28. package/dist/components/actions/Link/Link.js +1 -1
  29. package/dist/components/actions/Menu/Menu.js +1 -1
  30. package/dist/components/actions/Menu/MenuItem.js +1 -1
  31. package/dist/components/actions/Menu/MenuSection.js +1 -1
  32. package/dist/components/actions/Menu/MenuTrigger.js +1 -1
  33. package/dist/components/actions/Menu/SubMenuTrigger.js +1 -1
  34. package/dist/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  35. package/dist/components/actions/Menu/context.js +1 -1
  36. package/dist/components/actions/Menu/styled.js +1 -1
  37. package/dist/components/actions/index.js +1 -1
  38. package/dist/components/actions/use-action.js +1 -1
  39. package/dist/components/actions/use-anchored-menu.js +1 -1
  40. package/dist/components/actions/use-context-menu.js +1 -1
  41. package/dist/components/content/ActiveZone/ActiveZone.js +1 -1
  42. package/dist/components/content/Alert/Alert.js +1 -1
  43. package/dist/components/content/Alert/use-alert.js +1 -1
  44. package/dist/components/content/Avatar/Avatar.js +1 -1
  45. package/dist/components/content/Badge/Badge.js +1 -1
  46. package/dist/components/content/Card/Card.js +1 -1
  47. package/dist/components/content/Content.js +1 -1
  48. package/dist/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
  49. package/dist/components/content/CopySnippet/CopySnippet.js +1 -1
  50. package/dist/components/content/Disclosure/Disclosure.js +1 -1
  51. package/dist/components/content/Divider.js +1 -1
  52. package/dist/components/content/Footer.js +1 -1
  53. package/dist/components/content/Header.js +1 -1
  54. package/dist/components/content/HotKeys/HotKeys.js +1 -1
  55. package/dist/components/content/Item/Item.js +1 -1
  56. package/dist/components/content/ItemBadge/ItemBadge.js +1 -1
  57. package/dist/components/content/ItemCard/ItemCard.js +1 -1
  58. package/dist/components/content/Layout/GridLayout.js +1 -1
  59. package/dist/components/content/Layout/Layout.js +1 -1
  60. package/dist/components/content/Layout/LayoutBlock.js +1 -1
  61. package/dist/components/content/Layout/LayoutCenter.js +1 -1
  62. package/dist/components/content/Layout/LayoutContainer.js +1 -1
  63. package/dist/components/content/Layout/LayoutContent.js +1 -1
  64. package/dist/components/content/Layout/LayoutContext.js +1 -1
  65. package/dist/components/content/Layout/LayoutFlex.js +1 -1
  66. package/dist/components/content/Layout/LayoutFooter.js +1 -1
  67. package/dist/components/content/Layout/LayoutGrid.js +1 -1
  68. package/dist/components/content/Layout/LayoutHeader.js +1 -1
  69. package/dist/components/content/Layout/LayoutPane.js +1 -1
  70. package/dist/components/content/Layout/LayoutPanel.js +1 -1
  71. package/dist/components/content/Layout/LayoutPanelHeader.js +1 -1
  72. package/dist/components/content/Layout/LayoutToolbar.js +1 -1
  73. package/dist/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
  74. package/dist/components/content/Layout/index.js +1 -1
  75. package/dist/components/content/Layout/utils.js +1 -1
  76. package/dist/components/content/Paragraph.js +1 -1
  77. package/dist/components/content/Placeholder/Placeholder.js +1 -1
  78. package/dist/components/content/PrismCode/PrismCode.js +1 -1
  79. package/dist/components/content/PrismCode/prismSetup.js +1 -1
  80. package/dist/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  81. package/dist/components/content/Result/Result.js +1 -1
  82. package/dist/components/content/Skeleton/Skeleton.js +1 -1
  83. package/dist/components/content/Tag/Tag.js +1 -1
  84. package/dist/components/content/Text.js +1 -1
  85. package/dist/components/content/TextItem/TextItem.js +1 -1
  86. package/dist/components/content/Title.js +1 -1
  87. package/dist/components/content/highlightText.js +1 -1
  88. package/dist/components/content/use-auto-tooltip.js +1 -1
  89. package/dist/components/fields/Checkbox/Checkbox.js +1 -1
  90. package/dist/components/fields/Checkbox/CheckboxGroup.js +1 -1
  91. package/dist/components/fields/Checkbox/context.js +1 -1
  92. package/dist/components/fields/ComboBox/ComboBox.js +1 -1
  93. package/dist/components/fields/DatePicker/DateInput.js +1 -1
  94. package/dist/components/fields/DatePicker/DateInputBase.js +1 -1
  95. package/dist/components/fields/DatePicker/DatePicker.js +1 -1
  96. package/dist/components/fields/DatePicker/DatePickerButton.js +1 -1
  97. package/dist/components/fields/DatePicker/DatePickerElement.js +1 -1
  98. package/dist/components/fields/DatePicker/DatePickerInput.js +1 -1
  99. package/dist/components/fields/DatePicker/DatePickerSegment.js +1 -1
  100. package/dist/components/fields/DatePicker/DateRangePicker.js +1 -1
  101. package/dist/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
  102. package/dist/components/fields/DatePicker/TimeInput.js +1 -1
  103. package/dist/components/fields/DatePicker/intl.js +1 -1
  104. package/dist/components/fields/DatePicker/parseDate.js +1 -1
  105. package/dist/components/fields/DatePicker/props.js +1 -1
  106. package/dist/components/fields/DatePicker/utils.js +1 -1
  107. package/dist/components/fields/FileInput/FileInput.js +1 -1
  108. package/dist/components/fields/FilterListBox/FilterListBox.js +1 -1
  109. package/dist/components/fields/FilterPicker/FilterPicker.js +190 -194
  110. package/dist/components/fields/FilterPicker/FilterPicker.js.map +1 -1
  111. package/dist/components/fields/Input/Input.js +1 -1
  112. package/dist/components/fields/ListBox/ListBox.d.ts +7 -7
  113. package/dist/components/fields/ListBox/ListBox.js +1 -1
  114. package/dist/components/fields/NumberInput/NumberInput.js +1 -1
  115. package/dist/components/fields/NumberInput/StepButton.js +1 -1
  116. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  117. package/dist/components/fields/Picker/Picker.js +178 -157
  118. package/dist/components/fields/Picker/Picker.js.map +1 -1
  119. package/dist/components/fields/RadioGroup/Radio.js +1 -1
  120. package/dist/components/fields/RadioGroup/RadioGroup.js +1 -1
  121. package/dist/components/fields/RadioGroup/context.js +1 -1
  122. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  123. package/dist/components/fields/Select/Select.d.ts +4 -4
  124. package/dist/components/fields/Select/Select.js +1 -1
  125. package/dist/components/fields/Slider/Gradation.js +1 -1
  126. package/dist/components/fields/Slider/HueSlider.js +1 -1
  127. package/dist/components/fields/Slider/RangeSlider.js +1 -1
  128. package/dist/components/fields/Slider/Slider.js +1 -1
  129. package/dist/components/fields/Slider/SliderBase.js +1 -1
  130. package/dist/components/fields/Slider/SliderThumb.js +1 -1
  131. package/dist/components/fields/Slider/SliderTrack.js +1 -1
  132. package/dist/components/fields/Slider/elements.js +1 -1
  133. package/dist/components/fields/Slider/index.js +1 -1
  134. package/dist/components/fields/Switch/Switch.js +1 -1
  135. package/dist/components/fields/TextArea/TextArea.js +1 -1
  136. package/dist/components/fields/TextInput/TextInput.js +1 -1
  137. package/dist/components/fields/TextInput/TextInputBase.js +1 -1
  138. package/dist/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  139. package/dist/components/form/FieldWrapper/FieldWrapper.js +1 -1
  140. package/dist/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  141. package/dist/components/form/Form/Field.js +1 -1
  142. package/dist/components/form/Form/Form.js +1 -1
  143. package/dist/components/form/Form/ResetButton/ResetButton.js +1 -1
  144. package/dist/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  145. package/dist/components/form/Form/SubmitError.js +1 -1
  146. package/dist/components/form/Form/index.js +1 -1
  147. package/dist/components/form/Form/use-field/use-field-props.js +1 -1
  148. package/dist/components/form/Form/use-field/use-field.js +1 -1
  149. package/dist/components/form/Form/use-form.js +1 -1
  150. package/dist/components/form/Form/validation.js +1 -1
  151. package/dist/components/form/Label.js +1 -1
  152. package/dist/components/form/wrapper.js +1 -1
  153. package/dist/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  154. package/dist/components/helpers/IconSwitch/IconSwitch.js +1 -1
  155. package/dist/components/layout/Flex.js +1 -1
  156. package/dist/components/layout/Flow.js +1 -1
  157. package/dist/components/layout/Grid.js +1 -1
  158. package/dist/components/layout/Panel.js +1 -1
  159. package/dist/components/layout/Prefix.js +1 -1
  160. package/dist/components/layout/ResizablePanel.js +1 -1
  161. package/dist/components/layout/Space.js +1 -1
  162. package/dist/components/layout/Suffix.js +1 -1
  163. package/dist/components/navigation/Tabs/DraggableTabList.js +1 -1
  164. package/dist/components/navigation/Tabs/EditableTitle.js +1 -1
  165. package/dist/components/navigation/Tabs/TabButton.js +1 -1
  166. package/dist/components/navigation/Tabs/TabDropIndicator.js +1 -1
  167. package/dist/components/navigation/Tabs/TabPanel.js +1 -1
  168. package/dist/components/navigation/Tabs/TabPicker.js +1 -1
  169. package/dist/components/navigation/Tabs/Tabs.js +7 -5
  170. package/dist/components/navigation/Tabs/Tabs.js.map +1 -1
  171. package/dist/components/navigation/Tabs/TabsAction.js +1 -1
  172. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  173. package/dist/components/navigation/Tabs/styled.js +1 -1
  174. package/dist/components/navigation/Tabs/types.d.ts +7 -0
  175. package/dist/components/navigation/Tabs/types.js +1 -1
  176. package/dist/components/navigation/Tabs/types.js.map +1 -1
  177. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  178. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  179. package/dist/components/organisms/FileTabs/FileTabs.js +1 -1
  180. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  181. package/dist/components/other/Calendar/Calendar.js +1 -1
  182. package/dist/components/other/Calendar/CalendarCell.js +1 -1
  183. package/dist/components/other/Calendar/CalendarGrid.js +1 -1
  184. package/dist/components/other/Calendar/RangeCalendar.js +1 -1
  185. package/dist/components/other/CloudLogo/CloudLogo.js +1 -1
  186. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  187. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  188. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  189. package/dist/components/overlays/Dialog/Dialog.js +1 -1
  190. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  191. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  192. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  193. package/dist/components/overlays/Dialog/context.js +1 -1
  194. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  195. package/dist/components/overlays/Modal/Modal.js +1 -1
  196. package/dist/components/overlays/Modal/OpenTransition.js +1 -1
  197. package/dist/components/overlays/Modal/Overlay.js +1 -1
  198. package/dist/components/overlays/Modal/Popover.js +1 -1
  199. package/dist/components/overlays/Modal/Tray.js +1 -1
  200. package/dist/components/overlays/Modal/Underlay.js +1 -1
  201. package/dist/components/overlays/Notifications/Notification.js +1 -1
  202. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  203. package/dist/components/overlays/Notifications/NotificationCard.js +1 -1
  204. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  205. package/dist/components/overlays/Notifications/NotificationItem.js +1 -1
  206. package/dist/components/overlays/Notifications/OverlayContainer.js +1 -1
  207. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  208. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +1 -1
  209. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  210. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  211. package/dist/components/overlays/Notifications/index.js +1 -1
  212. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  213. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  214. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  215. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  216. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  217. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  218. package/dist/components/overlays/Toast/ToastItem.js +1 -1
  219. package/dist/components/overlays/Toast/index.js +1 -1
  220. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  221. package/dist/components/overlays/Toast/useToast.js +1 -1
  222. package/dist/components/overlays/Tooltip/Tooltip.js +1 -1
  223. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  224. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  225. package/dist/components/overlays/Tooltip/context.js +1 -1
  226. package/dist/components/portal/Portal.js +1 -1
  227. package/dist/components/portal/PortalProvider.js +1 -1
  228. package/dist/components/portal/usePortal.js +1 -1
  229. package/dist/components/shared/InvalidIcon.js +1 -1
  230. package/dist/components/shared/ValidIcon.js +1 -1
  231. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  232. package/dist/components/status/Spin/Cube.js +1 -1
  233. package/dist/components/status/Spin/InternalSpinner.js +1 -1
  234. package/dist/components/status/Spin/Spin.js +1 -1
  235. package/dist/components/status/Spin/SpinsContainer.js +1 -1
  236. package/dist/data/item-themes.js +1 -1
  237. package/dist/data/themes.js +1 -1
  238. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  239. package/dist/icons/AdjustmentsIcon.js +1 -1
  240. package/dist/icons/AiIcon.js +1 -1
  241. package/dist/icons/AreaChartIcon.js +1 -1
  242. package/dist/icons/BackwardIcon.js +1 -1
  243. package/dist/icons/BarChartIcon.js +1 -1
  244. package/dist/icons/BellFilledIcon.js +1 -1
  245. package/dist/icons/BellIcon.js +1 -1
  246. package/dist/icons/BooleanIcon.js +1 -1
  247. package/dist/icons/CalendarEditIcon.js +1 -1
  248. package/dist/icons/CalendarIcon.js +1 -1
  249. package/dist/icons/CaretDownIcon.js +1 -1
  250. package/dist/icons/CaretUpIcon.js +1 -1
  251. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  252. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  253. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  254. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  255. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  256. package/dist/icons/ChartBarLineIcon.js +1 -1
  257. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  258. package/dist/icons/ChartBarStackedIcon.js +1 -1
  259. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  260. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  261. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  262. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  263. package/dist/icons/ChartBubbleIcon.js +1 -1
  264. package/dist/icons/ChartDonut2Icon.js +1 -1
  265. package/dist/icons/ChartFunnelIcon.js +1 -1
  266. package/dist/icons/ChartHeatmapIcon.js +1 -1
  267. package/dist/icons/ChartKPIIcon.js +1 -1
  268. package/dist/icons/ChartPie2Icon.js +1 -1
  269. package/dist/icons/ChartScatterIcon.js +1 -1
  270. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  271. package/dist/icons/CheckCircleIcon.js +1 -1
  272. package/dist/icons/CheckIcon.js +1 -1
  273. package/dist/icons/CircleFilledIcon.js +1 -1
  274. package/dist/icons/ClearIcon.js +1 -1
  275. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  276. package/dist/icons/CloseCircleIcon.js +1 -1
  277. package/dist/icons/CloseIcon.js +1 -1
  278. package/dist/icons/CodeIcon.js +1 -1
  279. package/dist/icons/ColumnTotalIcon.js +1 -1
  280. package/dist/icons/CopyIcon.js +1 -1
  281. package/dist/icons/CountIcon.js +1 -1
  282. package/dist/icons/CubeIcon.js +1 -1
  283. package/dist/icons/CubePauseIcon.js +1 -1
  284. package/dist/icons/CubePlayIcon.js +1 -1
  285. package/dist/icons/CurrencyDollarIcon.js +1 -1
  286. package/dist/icons/DangerIcon.js +1 -1
  287. package/dist/icons/DashboardIcon.js +1 -1
  288. package/dist/icons/DatabaseIcon.js +1 -1
  289. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  290. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  291. package/dist/icons/DirectionIcon.js +1 -1
  292. package/dist/icons/DonutIcon.js +1 -1
  293. package/dist/icons/DownIcon.js +1 -1
  294. package/dist/icons/EditIcon.js +1 -1
  295. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  296. package/dist/icons/ExclamationCircleIcon.js +1 -1
  297. package/dist/icons/ExclamationIcon.js +1 -1
  298. package/dist/icons/EyeIcon.js +1 -1
  299. package/dist/icons/EyeInvisibleIcon.js +1 -1
  300. package/dist/icons/FilterIcon.js +1 -1
  301. package/dist/icons/FolderFilledIcon.js +1 -1
  302. package/dist/icons/FolderIcon.js +1 -1
  303. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  304. package/dist/icons/FolderOpenIcon.js +1 -1
  305. package/dist/icons/ForwardIcon.js +1 -1
  306. package/dist/icons/HierarchyIcon.js +1 -1
  307. package/dist/icons/HierarchyOpenIcon.js +1 -1
  308. package/dist/icons/Icon.js +1 -1
  309. package/dist/icons/InfoCircleIcon.js +1 -1
  310. package/dist/icons/InfoIcon.js +1 -1
  311. package/dist/icons/KeyIcon.js +1 -1
  312. package/dist/icons/LeftIcon.js +1 -1
  313. package/dist/icons/LineChartIcon.js +1 -1
  314. package/dist/icons/LoadingIcon.js +1 -1
  315. package/dist/icons/LockFilledIcon.js +1 -1
  316. package/dist/icons/LockIcon.js +1 -1
  317. package/dist/icons/MoreIcon.js +1 -1
  318. package/dist/icons/NotAllowedIcon.js +1 -1
  319. package/dist/icons/Number123Icon.js +1 -1
  320. package/dist/icons/NumberIcon.js +1 -1
  321. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  322. package/dist/icons/PauseCircleIcon.js +1 -1
  323. package/dist/icons/PauseIcon.js +1 -1
  324. package/dist/icons/PercentageIcon.js +1 -1
  325. package/dist/icons/PieChartIcon.js +1 -1
  326. package/dist/icons/PlayCircleIcon.js +1 -1
  327. package/dist/icons/PlayIcon.js +1 -1
  328. package/dist/icons/PlusIcon.js +1 -1
  329. package/dist/icons/ProgressBarIcon.js +1 -1
  330. package/dist/icons/ReloadIcon.js +1 -1
  331. package/dist/icons/ReportIcon.js +1 -1
  332. package/dist/icons/ReturnIcon.js +1 -1
  333. package/dist/icons/RightIcon.js +1 -1
  334. package/dist/icons/RowTotalsIcon.js +1 -1
  335. package/dist/icons/SchemeIcon.js +1 -1
  336. package/dist/icons/SearchIcon.js +1 -1
  337. package/dist/icons/SemanticQueryIcon.js +1 -1
  338. package/dist/icons/SettingsIcon.js +1 -1
  339. package/dist/icons/ShieldFilledIcon.js +1 -1
  340. package/dist/icons/ShieldIcon.js +1 -1
  341. package/dist/icons/SlashIcon.js +1 -1
  342. package/dist/icons/SparklesIcon.js +1 -1
  343. package/dist/icons/SqlIcon.js +1 -1
  344. package/dist/icons/StatsIcon.js +1 -1
  345. package/dist/icons/StopIcon.js +1 -1
  346. package/dist/icons/StringIcon.js +1 -1
  347. package/dist/icons/SubtotalsIcon.js +1 -1
  348. package/dist/icons/SwitchIcon.js +1 -1
  349. package/dist/icons/TableIcon.js +1 -1
  350. package/dist/icons/ThumbsDownIcon.js +1 -1
  351. package/dist/icons/ThumbsUpIcon.js +1 -1
  352. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  353. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  354. package/dist/icons/ThunderboltIcon.js +1 -1
  355. package/dist/icons/TimeIcon.js +1 -1
  356. package/dist/icons/TrashIcon.js +1 -1
  357. package/dist/icons/UnlockIcon.js +1 -1
  358. package/dist/icons/UpIcon.js +1 -1
  359. package/dist/icons/UserGroupIcon.js +1 -1
  360. package/dist/icons/UserIcon.js +1 -1
  361. package/dist/icons/UserLockIcon.js +1 -1
  362. package/dist/icons/ViewIcon.js +1 -1
  363. package/dist/icons/WarningFilledIcon.js +1 -1
  364. package/dist/icons/WarningIcon.js +1 -1
  365. package/dist/icons/wrap-icon.js +1 -1
  366. package/dist/index.d.ts +2 -1
  367. package/dist/index.js +3 -2
  368. package/dist/index.js.map +1 -1
  369. package/dist/provider.js +1 -1
  370. package/dist/providers/TrackingProvider.js +1 -1
  371. package/dist/providers/navigationAdapter.default.js +1 -1
  372. package/dist/tokens/base.js +1 -1
  373. package/dist/tokens/colors.js +1 -1
  374. package/dist/tokens/index.js +1 -1
  375. package/dist/tokens/layout.js +1 -1
  376. package/dist/tokens/shadows.js +1 -1
  377. package/dist/tokens/sizes.js +1 -1
  378. package/dist/tokens/spacing.js +1 -1
  379. package/dist/tokens/typography.js +1 -1
  380. package/dist/utils/ResizeSensor.js +1 -1
  381. package/dist/utils/index.d.ts +2 -1
  382. package/dist/utils/is-dev-env.js +1 -1
  383. package/dist/utils/modules.js +1 -1
  384. package/dist/utils/promise.js +1 -1
  385. package/dist/utils/raf.js +1 -1
  386. package/dist/utils/random.js +1 -1
  387. package/dist/utils/range.js +1 -1
  388. package/dist/utils/react/RenderCache.js +1 -1
  389. package/dist/utils/react/Slots.js +1 -1
  390. package/dist/utils/react/chain.js +1 -1
  391. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  392. package/dist/utils/react/index.js +1 -1
  393. package/dist/utils/react/interactions.js +1 -1
  394. package/dist/utils/react/isTextOnly.js +1 -1
  395. package/dist/utils/react/mapProps.js +1 -1
  396. package/dist/utils/react/mergeProps.js +1 -1
  397. package/dist/utils/react/nullableValue.js +1 -1
  398. package/dist/utils/react/resolveIcon.js +1 -1
  399. package/dist/utils/react/sharedStore.js +1 -1
  400. package/dist/utils/react/useCombinedRefs.js +1 -1
  401. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  402. package/dist/utils/react/useEventBus.js +1 -1
  403. package/dist/utils/react/useId.js +1 -1
  404. package/dist/utils/react/useIsDarwin.js +1 -1
  405. package/dist/utils/react/useKeySymbols.js +1 -1
  406. package/dist/utils/react/useLayoutEffect.js +1 -1
  407. package/dist/utils/react/useLocalStorage.js +1 -1
  408. package/dist/utils/react/useMergeStyles.js +1 -1
  409. package/dist/utils/react/useQaProps.js +1 -1
  410. package/dist/utils/react/useViewportSize.js +1 -1
  411. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  412. package/dist/utils/selection.d.ts +12 -0
  413. package/dist/utils/selection.js +19 -0
  414. package/dist/utils/selection.js.map +1 -0
  415. package/dist/utils/styles.js +1 -1
  416. package/dist/utils/tree.js +1 -1
  417. package/dist/utils/warnings.js +1 -1
  418. package/dist/version.js +2 -2
  419. package/docs/components/navigation/Tabs.md +1 -0
  420. package/package.json +1 -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 useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { FocusScope, Key, useKeyboard } from 'react-aria';\nimport { Section as BaseSection, ListState, useListState } from 'react-stately';\n\nimport { useEvent } from '../../../_internal';\nimport { useWarn } from '../../../_internal/hooks/use-warn';\nimport { CloseIcon, DirectionIcon, LoadingIcon } from '../../../icons';\nimport { useProviderProps } from '../../../provider';\nimport { generateRandomId } from '../../../utils/random';\nimport { mergeProps } from '../../../utils/react';\nimport { useEventBus } from '../../../utils/react/useEventBus';\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\n// Define interface for items that can have keys\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 * 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 // Handle \"all\" selection and array selections\n if (key === 'all') {\n onChange('all');\n } else {\n onChange(key ? (Array.isArray(key) ? key : [key]) : []);\n }\n } else {\n onChange(Array.isArray(key) ? key[0] : key);\n }\n };\n\n return fieldProps;\n },\n });\n\n let {\n 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 searchValue,\n onSearchChange,\n sortSelectedToTop: sortSelectedToTopProp,\n onOpenChange,\n form,\n ...otherProps\n } = props;\n\n // Track if sortSelectedToTop was explicitly provided\n const sortSelectedToTopExplicit = sortSelectedToTopProp !== undefined;\n // Default to true if items are provided, false otherwise\n const sortSelectedToTop = sortSelectedToTopProp ?? (items ? true : false);\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n // Generate a unique ID for this FilterPicker instance\n const filterPickerId = useMemo(() => generateRandomId(), []);\n\n // Get event bus for menu synchronization\n const { emit, on } = useEventBus();\n\n // Warn if isCheckable is false in single selection mode\n useWarn(isCheckable === false && selectionMode === 'single', {\n key: ['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 // Internal selection state (uncontrolled scenario)\n const [internalSelectedKey, setInternalSelectedKey] = useState<Key | null>(\n defaultSelectedKey ?? null,\n );\n const [internalSelectedKeys, setInternalSelectedKeys] = useState<\n 'all' | Key[]\n >(defaultSelectedKeys ?? []);\n\n // Track popover open/close and capture children order for session\n const [isPopoverOpen, setIsPopoverOpen] = useState(false);\n // Cache for sorted items array when using `items` prop\n const cachedItemsOrder = useRef<T[] | null>(null);\n const triggerRef = useRef<FocusableRefValue<HTMLButtonElement>>(null);\n\n // ---------------------------------------------------------------------------\n // Invalidate cached sorting whenever the available options change.\n // This ensures newly provided options are displayed and properly sorted on\n // the next popover open instead of re-using a stale order from a previous\n // session (which caused only the previously selected options to be rendered\n // or the list to appear unsorted).\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 // Create a local collection for label extraction only (not for rendering)\n // This gives us immediate access to textValue without waiting for FilterListBox\n const localCollectionState = useListState({\n children: children as any,\n items: items as any,\n selectionMode: 'none' as any, // We don't need selection management\n });\n\n // ---------------------------------------------------------------------------\n // Map user-provided keys to collection keys using the local collection.\n // The collection handles key normalization internally, so we use direct\n // string comparison.\n // ---------------------------------------------------------------------------\n\n const findCollectionKey = useCallback(\n (lookup: Key): Key => {\n if (lookup == null) return lookup;\n\n // Direct comparison - collection handles normalization internally\n for (const item of localCollectionState.collection) {\n if (String(item.key) === String(lookup)) {\n return item.key;\n }\n }\n\n // Fallback: return the lookup key as-is\n return lookup;\n },\n [localCollectionState.collection],\n );\n\n const mappedSelectedKey = useMemo(() => {\n if (selectionMode !== 'single') return null;\n return effectiveSelectedKey\n ? findCollectionKey(effectiveSelectedKey)\n : null;\n }, [selectionMode, effectiveSelectedKey, findCollectionKey]);\n\n const mappedSelectedKeys = useMemo(() => {\n if (selectionMode !== 'multiple') return undefined;\n\n if (effectiveSelectedKeys === 'all') return 'all' as const;\n\n if (Array.isArray(effectiveSelectedKeys)) {\n return (effectiveSelectedKeys as Key[]).map((k) => findCollectionKey(k));\n }\n\n return effectiveSelectedKeys;\n }, [selectionMode, effectiveSelectedKeys, findCollectionKey]);\n\n // Given an iterable of keys (array or Set) toggle membership for duplicates\n const processSelectionArray = (iterable: Iterable<Key>): string[] => {\n const resultSet = new Set<string>();\n for (const key of iterable) {\n const nKey = String(key);\n if (resultSet.has(nKey)) {\n resultSet.delete(nKey); // toggle off if clicked twice\n } else {\n resultSet.add(nKey); // select\n }\n }\n return Array.from(resultSet);\n };\n\n // Helper to get selected item labels for display using local collection\n const getSelectedLabels = () => {\n const collection = localCollectionState.collection;\n\n // Helper to recursively collect all item labels from collection (including nested in sections)\n const collectAllLabels = (): string[] => {\n const allLabels: string[] = [];\n\n const traverse = (nodes: Iterable<any>) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n allLabels.push(node.textValue || String(node.key));\n } else if (node.childNodes) {\n traverse(node.childNodes);\n }\n }\n };\n\n traverse(collection);\n return allLabels;\n };\n\n // Handle \"all\" selection - return all available labels\n if (selectionMode === 'multiple' && effectiveSelectedKeys === 'all') {\n return collectAllLabels();\n }\n\n const selectedSet = new Set(\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map((k) => String(k))\n : effectiveSelectedKey != null\n ? [String(effectiveSelectedKey)]\n : [],\n );\n\n const labels: string[] = [];\n const processedKeys = new Set<string>();\n\n // Use collection.getItem() to directly retrieve items by key (works with sections)\n selectedSet.forEach((key) => {\n const item = collection.getItem(key);\n if (item) {\n labels.push(item.textValue || String(item.key));\n processedKeys.add(String(item.key));\n }\n });\n\n // Handle custom values that aren't in the collection\n const selectedKeysArr =\n selectionMode === 'multiple' && effectiveSelectedKeys !== 'all'\n ? (effectiveSelectedKeys || []).map(String)\n : effectiveSelectedKey != null\n ? [String(effectiveSelectedKey)]\n : [];\n\n // Add labels for any selected keys that weren't found in collection (custom values)\n selectedKeysArr.forEach((key) => {\n if (!processedKeys.has(String(key))) {\n // This is a custom value, use the key as the label\n labels.push(key);\n }\n });\n\n return labels;\n };\n\n const selectedLabels = getSelectedLabels();\n const hasSelection = selectedLabels.length > 0;\n\n // Always keep the latest selection in a ref (with normalized keys) so that we can read it synchronously in the popover close effect.\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 const selectionsWhenClosed = useRef<{\n single: string | null;\n multiple: 'all' | string[];\n }>({ single: null, multiple: [] });\n\n // Capture the initial selection (from defaultSelectedKey(s)) so that\n // the very first popover open can already use it for sorting.\n useEffect(() => {\n selectionsWhenClosed.current = { ...latestSelectionRef.current };\n }, []); // run only once on mount\n\n // Function to sort children with selected items on top\n const getSortedChildren = useCallback(() => {\n // Warn if sorting is explicitly requested but not supported\n if (sortSelectedToTopExplicit && sortSelectedToTop && !items) {\n console.warn(\n 'FilterPicker: sortSelectedToTop only works with the items prop. ' +\n 'Sorting will be skipped when using JSX children.',\n );\n }\n\n // Return children as-is (no sorting for JSX children)\n return children;\n }, [children, sortSelectedToTop, sortSelectedToTopExplicit, items]);\n\n // Compute sorted items array when using `items` prop\n const getSortedItems = useCallback(() => {\n if (!items) return items;\n\n // Only sort if explicitly enabled\n if (!sortSelectedToTop) {\n return items;\n }\n\n // Reuse the cached order if we have it. We only compute the sorted array\n // once when the pop-over is opened. Cache is cleared on close.\n if (cachedItemsOrder.current) {\n return cachedItemsOrder.current;\n }\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 // Do not sort when all selected – keep original order\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 // Helpers to extract key from item object\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 // Section-like object – keep order, but sort its 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 if (isPopoverOpen || !cachedItemsOrder.current) {\n cachedItemsOrder.current = sorted;\n }\n\n return sorted;\n }, [\n items,\n sortSelectedToTop,\n selectionMode,\n isPopoverOpen,\n selectionsWhenClosed.current.multiple,\n selectionsWhenClosed.current.single,\n ]);\n\n const finalItems = getSortedItems();\n\n // FilterListBox handles custom values internally when allowsCustomValue={true}\n // We provide sorted children (if any) and sorted items\n const finalChildren = getSortedChildren();\n\n const renderTriggerContent = () => {\n // When there is a selection and a custom summary renderer is provided – use it.\n if (typeof renderSummary === 'function') {\n if (selectionMode === 'single') {\n return renderSummary({\n selectedLabel: selectedLabels[0],\n selectedKey: effectiveSelectedKey ?? null,\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'single',\n });\n }\n\n return renderSummary({\n selectedLabels,\n selectedKeys: effectiveSelectedKeys,\n selectionMode: 'multiple',\n });\n } else if (renderSummary === false) {\n return null;\n }\n\n let content: ReactNode = '';\n\n if (!hasSelection) {\n return <Text.Placeholder>{placeholder}</Text.Placeholder>;\n } else if (selectionMode === 'single') {\n content = selectedLabels[0];\n } else if (effectiveSelectedKeys === 'all') {\n content = selectAllLabel;\n } else {\n content = selectedLabels.join(', ');\n }\n\n if (!content) {\n return null;\n }\n\n return content;\n };\n\n const [shouldUpdatePosition, setShouldUpdatePosition] = useState(true);\n\n // Capture trigger width for overlay min-width\n const triggerWidth = triggerRef?.current?.UNSAFE_getDOMNode()?.offsetWidth;\n\n // The trigger is rendered as a function so we can access the dialog state\n const renderTrigger = (state) => {\n // Listen for other menus opening and close this one if needed\n useEffect(() => {\n const unsubscribe = on('popover:open', (data: { menuId: string }) => {\n // If another menu is opening and this FilterPicker is open, close this one\n if (data.menuId !== filterPickerId && state.isOpen) {\n state.close();\n }\n });\n\n return unsubscribe;\n }, [on, filterPickerId, state]);\n\n // Emit event when this FilterPicker opens\n useEffect(() => {\n if (state.isOpen) {\n emit('popover:open', { menuId: filterPickerId });\n }\n }, [state.isOpen, emit, filterPickerId]);\n\n // Track popover open/close state to control sorting\n useEffect(() => {\n if (state.isOpen !== isPopoverOpen) {\n setIsPopoverOpen(state.isOpen);\n if (!state.isOpen) {\n // Popover just closed – record the latest selection for the next opening\n // and clear the cached order so the next session can compute afresh.\n selectionsWhenClosed.current = { ...latestSelectionRef.current };\n cachedItemsOrder.current = null;\n }\n onOpenChange?.(state.isOpen);\n }\n }, [state.isOpen, isPopoverOpen, onOpenChange]);\n\n // Add keyboard support for arrow keys to open the popover\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if ((e.key === 'ArrowUp' || e.key === 'ArrowDown') && !state.isOpen) {\n e.preventDefault();\n state.open();\n }\n },\n });\n\n useEffect(() => {\n // Allow initial positioning & flipping when opening, then lock placement after transition\n // Popover transition is ~120ms, give it a bit more time to finalize placement\n if (state.isOpen) {\n setShouldUpdatePosition(true);\n const id = window.setTimeout(() => setShouldUpdatePosition(false), 160);\n return () => window.clearTimeout(id);\n } else {\n setShouldUpdatePosition(true);\n }\n }, [state.isOpen]);\n\n // Clear button logic\n let showClearButton =\n isClearable && hasSelection && !isDisabled && !props.isReadOnly;\n\n // Clear function\n let clearValue = useEvent(() => {\n if (selectionMode === 'multiple') {\n if (!isControlledMultiple) {\n setInternalSelectedKeys([]);\n }\n onSelectionChange?.([]);\n } else {\n if (!isControlledSingle) {\n setInternalSelectedKey(null);\n }\n onSelectionChange?.(null);\n }\n\n if (state.isOpen) {\n state.close();\n }\n\n triggerRef?.current?.focus?.();\n\n props.onClear?.();\n\n return false;\n });\n\n return (\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={state.isOpen ? 'top' : 'bottom'} />\n )\n }\n prefix={prefix}\n suffix={suffix}\n hotkeys={hotkeys}\n tooltip={triggerTooltip}\n description={triggerDescription}\n descriptionPlacement={descriptionPlacement}\n styles={triggerStyles}\n {...keyboardProps}\n aria-label={`${props['aria-label'] ?? props.label ?? ''}`}\n >\n {renderTriggerContent()}\n </ItemButton>\n );\n };\n\n const filterPickerField = (\n <FilterPickerWrapper\n qa=\"FilterPickerWrapper\"\n styles={styles}\n {...filterBaseProps(otherProps, { eventProps: true })}\n >\n <DialogTrigger\n type=\"popover\"\n placement=\"bottom start\"\n containerPadding={containerPadding}\n shouldUpdatePosition={shouldUpdatePosition}\n shouldFlip={shouldFlip && shouldUpdatePosition}\n isDismissable={true}\n shouldCloseOnInteractOutside={(el) => {\n const menuTriggerEl = el.closest('[data-popover-trigger]');\n // If no menu trigger was clicked, allow closing\n if (!menuTriggerEl) return true;\n // If the same trigger that opened this popover was clicked, allow closing (toggle)\n if (menuTriggerEl === (triggerRef as any)?.current) return true;\n // Otherwise, don't close here. Let the event bus handle closing when the other opens.\n return false;\n }}\n >\n {renderTrigger}\n {(close) => (\n <Dialog\n qa=\"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 triggerWidth\n ? ({ '--overlay-min-width': `${triggerWidth}px` } as any)\n : undefined\n }\n >\n <FocusScope restoreFocus>\n <FilterListBox\n autoFocus\n items={items ? (finalItems as typeof props.items) : undefined}\n // Pass an aria-label so the internal ListBox is properly labeled and React Aria doesn't warn.\n aria-label={`${props['aria-label'] ?? props.label ?? ''} Picker`}\n _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 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 onSearchChange={onSearchChange}\n onEscape={() => close()}\n onOptionClick={(key) => {\n // For FilterPicker, clicking the content area should close the popover\n // in multiple selection mode (single mode already closes via onSelectionChange)\n if (\n (selectionMode === 'multiple' && isCheckable) ||\n key === '__ALL__'\n ) {\n close();\n }\n }}\n onSelectionChange={(selection) => {\n // No need to change any flags - children order is cached\n\n // Update internal state if uncontrolled\n if (selectionMode === 'single') {\n if (!isControlledSingle) {\n setInternalSelectedKey(selection as Key | null);\n }\n } else {\n if (!isControlledMultiple) {\n let normalized: 'all' | Key[] = selection as\n | 'all'\n | Key[];\n\n if (selection === 'all') {\n normalized = 'all';\n } else if (Array.isArray(selection)) {\n normalized = processSelectionArray(selection);\n } else if (\n selection &&\n typeof selection === 'object' &&\n (selection as any) instanceof Set\n ) {\n normalized = processSelectionArray(\n selection as Set<Key>,\n );\n }\n\n setInternalSelectedKeys(normalized);\n }\n }\n\n // 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 as any) 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 close();\n }\n }}\n >\n {\n (children\n ? (finalChildren 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 { 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 * 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 searchValue,\n onSearchChange,\n sortSelectedToTop: sortSelectedToTopProp,\n onOpenChange,\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 }\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 // Position update management\n const [shouldUpdatePosition, setShouldUpdatePosition] = useState(true);\n\n useEffect(() => {\n if (isPopoverOpen) {\n setShouldUpdatePosition(true);\n const timerId = window.setTimeout(\n () => setShouldUpdatePosition(false),\n 160,\n );\n return () => window.clearTimeout(timerId);\n } else {\n setShouldUpdatePosition(true);\n }\n }, [isPopoverOpen]);\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 shouldUpdatePosition={shouldUpdatePosition}\n shouldFlip={shouldFlip && shouldUpdatePosition}\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 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 onSearchChange={onSearchChange}\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.124.4 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.125.1 | 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";
@@ -6,7 +6,7 @@ import { BasePropsWithoutChildren, Styles } from "@tenphi/tasty";
6
6
  import { ForwardedRef, ReactElement, ReactNode, RefObject } from "react";
7
7
  import { AriaListBoxProps } from "react-aria";
8
8
  import { Section } from "react-stately";
9
- import { CollectionBase, Key as Key$1 } from "@react-types/shared";
9
+ import { CollectionBase, Key as Key$2 } from "@react-types/shared";
10
10
 
11
11
  //#region src/components/fields/ListBox/ListBox.d.ts
12
12
  interface CubeListBoxProps<T> extends AriaListBoxProps<T>, CollectionBase<T>, FieldBaseProps, BasePropsWithoutChildren {
@@ -21,15 +21,15 @@ interface CubeListBoxProps<T> extends AriaListBoxProps<T>, CollectionBase<T>, Fi
21
21
  /** Whether the ListBox is disabled */
22
22
  isDisabled?: boolean;
23
23
  /** The selected key in controlled single selection mode */
24
- selectedKey?: Key$1 | null;
24
+ selectedKey?: Key$2 | null;
25
25
  /** The selected keys in controlled multiple selection mode. Use "all" to select all items or an array of keys */
26
- selectedKeys?: 'all' | Key$1[];
26
+ selectedKeys?: 'all' | Key$2[];
27
27
  /** The default selected key in uncontrolled single selection mode */
28
- defaultSelectedKey?: Key$1 | null;
28
+ defaultSelectedKey?: Key$2 | null;
29
29
  /** The default selected keys in uncontrolled multiple selection mode. Use "all" to select all items or an array of keys */
30
- defaultSelectedKeys?: 'all' | Key$1[];
30
+ defaultSelectedKeys?: 'all' | Key$2[];
31
31
  /** Callback fired when selection changes */
32
- onSelectionChange?: (key: Key$1 | null | 'all' | Key$1[]) => void;
32
+ onSelectionChange?: (key: Key$2 | null | 'all' | Key$2[]) => void;
33
33
  /** The selection mode of the ListBox */
34
34
  selectionMode?: 'single' | 'multiple';
35
35
  /** Ref for accessing the list DOM element */
@@ -86,7 +86,7 @@ interface CubeListBoxProps<T> extends AriaListBoxProps<T>, CollectionBase<T>, Fi
86
86
  * Callback fired when an option is clicked but not on the checkbox area.
87
87
  * Used by FilterPicker to close the popover on non-checkbox clicks.
88
88
  */
89
- onOptionClick?: (key: Key$1) => void;
89
+ onOptionClick?: (key: Key$2) => void;
90
90
  /**
91
91
  * Whether to show the "Select All" option in multiple selection mode.
92
92
  * This adds a select all option to the header that allows selecting/deselecting all items.
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.124.4 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.125.1 | 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";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.124.4 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.125.1 | Cube Dev Team */
2
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
3
  import { useProviderProps } from "../../../provider.js";
4
4
  import { useFieldProps } from "../../form/Form/use-field/use-field-props.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.124.4 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.125.1 | 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.124.4 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.125.1 | Cube Dev Team */
2
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
3
  import { useProviderProps } from "../../../provider.js";
4
4
  import { ItemAction } from "../../actions/ItemAction/ItemAction.js";