@cube-dev/ui-kit 0.127.3 → 0.128.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 (413) hide show
  1. package/dist/CHANGELOG.md +17 -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.d.ts +3 -1
  109. package/dist/components/fields/FilterListBox/FilterListBox.js +115 -51
  110. package/dist/components/fields/FilterListBox/FilterListBox.js.map +1 -1
  111. package/dist/components/fields/FilterPicker/FilterPicker.d.ts +6 -0
  112. package/dist/components/fields/FilterPicker/FilterPicker.js +3 -2
  113. package/dist/components/fields/FilterPicker/FilterPicker.js.map +1 -1
  114. package/dist/components/fields/Input/Input.js +1 -1
  115. package/dist/components/fields/ListBox/ListBox.js +1 -1
  116. package/dist/components/fields/NumberInput/NumberInput.js +1 -1
  117. package/dist/components/fields/NumberInput/StepButton.js +1 -1
  118. package/dist/components/fields/PasswordInput/PasswordInput.js +1 -1
  119. package/dist/components/fields/Picker/Picker.js +1 -1
  120. package/dist/components/fields/RadioGroup/Radio.js +1 -1
  121. package/dist/components/fields/RadioGroup/RadioGroup.js +1 -1
  122. package/dist/components/fields/RadioGroup/context.js +1 -1
  123. package/dist/components/fields/SearchInput/SearchInput.js +1 -1
  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 +1 -1
  170. package/dist/components/navigation/Tabs/TabsAction.js +1 -1
  171. package/dist/components/navigation/Tabs/TabsContext.js +1 -1
  172. package/dist/components/navigation/Tabs/styled.js +1 -1
  173. package/dist/components/navigation/Tabs/types.js +1 -1
  174. package/dist/components/navigation/Tabs/use-tab-editing.js +1 -1
  175. package/dist/components/navigation/Tabs/use-tab-indicator.js +1 -1
  176. package/dist/components/organisms/FileTabs/FileTabs.js +1 -1
  177. package/dist/components/organisms/StatsCard/StatsCard.js +1 -1
  178. package/dist/components/other/Calendar/Calendar.js +1 -1
  179. package/dist/components/other/Calendar/CalendarCell.js +1 -1
  180. package/dist/components/other/Calendar/CalendarGrid.js +1 -1
  181. package/dist/components/other/Calendar/RangeCalendar.js +1 -1
  182. package/dist/components/other/CloudLogo/CloudLogo.js +1 -1
  183. package/dist/components/overlays/AlertDialog/AlertDialog.js +1 -1
  184. package/dist/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  185. package/dist/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  186. package/dist/components/overlays/Dialog/Dialog.js +1 -1
  187. package/dist/components/overlays/Dialog/DialogContainer.js +1 -1
  188. package/dist/components/overlays/Dialog/DialogForm.js +1 -1
  189. package/dist/components/overlays/Dialog/DialogTrigger.js +1 -1
  190. package/dist/components/overlays/Dialog/context.js +1 -1
  191. package/dist/components/overlays/Dialog/use-dialog-container.js +1 -1
  192. package/dist/components/overlays/Modal/Modal.js +1 -1
  193. package/dist/components/overlays/Modal/OpenTransition.js +1 -1
  194. package/dist/components/overlays/Modal/Overlay.js +1 -1
  195. package/dist/components/overlays/Modal/Popover.js +1 -1
  196. package/dist/components/overlays/Modal/Tray.js +1 -1
  197. package/dist/components/overlays/Modal/Underlay.js +1 -1
  198. package/dist/components/overlays/Notifications/Notification.js +1 -1
  199. package/dist/components/overlays/Notifications/NotificationAction.js +1 -1
  200. package/dist/components/overlays/Notifications/NotificationCard.js +1 -1
  201. package/dist/components/overlays/Notifications/NotificationContext.js +1 -1
  202. package/dist/components/overlays/Notifications/NotificationItem.js +1 -1
  203. package/dist/components/overlays/Notifications/OverlayContainer.js +1 -1
  204. package/dist/components/overlays/Notifications/OverlayProvider.js +1 -1
  205. package/dist/components/overlays/Notifications/PersistentNotificationsList.js +1 -1
  206. package/dist/components/overlays/Notifications/dismissed-storage.js +1 -1
  207. package/dist/components/overlays/Notifications/format-relative-time.js +1 -1
  208. package/dist/components/overlays/Notifications/index.js +1 -1
  209. package/dist/components/overlays/Notifications/use-notification-state.js +1 -1
  210. package/dist/components/overlays/Notifications/use-notifications.js +1 -1
  211. package/dist/components/overlays/Notifications/use-overlay-timers.js +1 -1
  212. package/dist/components/overlays/Notifications/use-persistent-notifications.js +1 -1
  213. package/dist/components/overlays/Notifications/use-persistent-state.js +1 -1
  214. package/dist/components/overlays/Notifications/use-toast-state.js +1 -1
  215. package/dist/components/overlays/Toast/ToastItem.js +1 -1
  216. package/dist/components/overlays/Toast/index.js +1 -1
  217. package/dist/components/overlays/Toast/useProgressToast.js +1 -1
  218. package/dist/components/overlays/Toast/useToast.js +1 -1
  219. package/dist/components/overlays/Tooltip/Tooltip.js +1 -1
  220. package/dist/components/overlays/Tooltip/TooltipProvider.js +1 -1
  221. package/dist/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  222. package/dist/components/overlays/Tooltip/context.js +1 -1
  223. package/dist/components/portal/Portal.js +1 -1
  224. package/dist/components/portal/PortalProvider.js +1 -1
  225. package/dist/components/portal/usePortal.js +1 -1
  226. package/dist/components/shared/InvalidIcon.js +1 -1
  227. package/dist/components/shared/ValidIcon.js +1 -1
  228. package/dist/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  229. package/dist/components/status/Spin/Cube.js +1 -1
  230. package/dist/components/status/Spin/InternalSpinner.js +1 -1
  231. package/dist/components/status/Spin/Spin.js +1 -1
  232. package/dist/components/status/Spin/SpinsContainer.js +1 -1
  233. package/dist/data/item-themes.js +1 -1
  234. package/dist/data/themes.js +1 -1
  235. package/dist/icons/AdjustmentsHorizontalIcon.js +1 -1
  236. package/dist/icons/AdjustmentsIcon.js +1 -1
  237. package/dist/icons/AiIcon.js +1 -1
  238. package/dist/icons/AreaChartIcon.js +1 -1
  239. package/dist/icons/BackwardIcon.js +1 -1
  240. package/dist/icons/BarChartIcon.js +1 -1
  241. package/dist/icons/BellFilledIcon.js +1 -1
  242. package/dist/icons/BellIcon.js +1 -1
  243. package/dist/icons/BooleanIcon.js +1 -1
  244. package/dist/icons/CalendarEditIcon.js +1 -1
  245. package/dist/icons/CalendarIcon.js +1 -1
  246. package/dist/icons/CaretDownIcon.js +1 -1
  247. package/dist/icons/CaretUpIcon.js +1 -1
  248. package/dist/icons/ChartAreaStackedIcon.js +1 -1
  249. package/dist/icons/ChartAreaStackedPercentageIcon.js +1 -1
  250. package/dist/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  251. package/dist/icons/ChartBarGroupedIcon.js +1 -1
  252. package/dist/icons/ChartBarHorizontalIcon.js +1 -1
  253. package/dist/icons/ChartBarLineIcon.js +1 -1
  254. package/dist/icons/ChartBarStackedHorizontalIcon.js +1 -1
  255. package/dist/icons/ChartBarStackedIcon.js +1 -1
  256. package/dist/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  257. package/dist/icons/ChartBarStackedPercentageIcon.js +1 -1
  258. package/dist/icons/ChartBoxPlot2Icon.js +1 -1
  259. package/dist/icons/ChartBoxPlotIcon.js +1 -1
  260. package/dist/icons/ChartBubbleIcon.js +1 -1
  261. package/dist/icons/ChartDonut2Icon.js +1 -1
  262. package/dist/icons/ChartFunnelIcon.js +1 -1
  263. package/dist/icons/ChartHeatmapIcon.js +1 -1
  264. package/dist/icons/ChartKPIIcon.js +1 -1
  265. package/dist/icons/ChartPie2Icon.js +1 -1
  266. package/dist/icons/ChartScatterIcon.js +1 -1
  267. package/dist/icons/CheckCircleFilledIcon.js +1 -1
  268. package/dist/icons/CheckCircleIcon.js +1 -1
  269. package/dist/icons/CheckIcon.js +1 -1
  270. package/dist/icons/CircleFilledIcon.js +1 -1
  271. package/dist/icons/ClearIcon.js +1 -1
  272. package/dist/icons/CloseCircleFilledIcon.js +1 -1
  273. package/dist/icons/CloseCircleIcon.js +1 -1
  274. package/dist/icons/CloseIcon.js +1 -1
  275. package/dist/icons/CodeIcon.js +1 -1
  276. package/dist/icons/ColumnTotalIcon.js +1 -1
  277. package/dist/icons/CopyIcon.js +1 -1
  278. package/dist/icons/CountIcon.js +1 -1
  279. package/dist/icons/CubeIcon.js +1 -1
  280. package/dist/icons/CubePauseIcon.js +1 -1
  281. package/dist/icons/CubePlayIcon.js +1 -1
  282. package/dist/icons/CurrencyDollarIcon.js +1 -1
  283. package/dist/icons/DangerIcon.js +1 -1
  284. package/dist/icons/DashboardIcon.js +1 -1
  285. package/dist/icons/DatabaseIcon.js +1 -1
  286. package/dist/icons/DecimalDecreaseIcon.js +1 -1
  287. package/dist/icons/DecimalIncreaseIcon.js +1 -1
  288. package/dist/icons/DirectionIcon.js +1 -1
  289. package/dist/icons/DonutIcon.js +1 -1
  290. package/dist/icons/DownIcon.js +1 -1
  291. package/dist/icons/EditIcon.js +1 -1
  292. package/dist/icons/ExclamationCircleFilledIcon.js +1 -1
  293. package/dist/icons/ExclamationCircleIcon.js +1 -1
  294. package/dist/icons/ExclamationIcon.js +1 -1
  295. package/dist/icons/EyeIcon.js +1 -1
  296. package/dist/icons/EyeInvisibleIcon.js +1 -1
  297. package/dist/icons/FilterIcon.js +1 -1
  298. package/dist/icons/FolderFilledIcon.js +1 -1
  299. package/dist/icons/FolderIcon.js +1 -1
  300. package/dist/icons/FolderOpenFilledIcon.js +1 -1
  301. package/dist/icons/FolderOpenIcon.js +1 -1
  302. package/dist/icons/ForwardIcon.js +1 -1
  303. package/dist/icons/HierarchyIcon.js +1 -1
  304. package/dist/icons/HierarchyOpenIcon.js +1 -1
  305. package/dist/icons/Icon.js +1 -1
  306. package/dist/icons/InfoCircleIcon.js +1 -1
  307. package/dist/icons/InfoIcon.js +1 -1
  308. package/dist/icons/KeyIcon.js +1 -1
  309. package/dist/icons/LeftIcon.js +1 -1
  310. package/dist/icons/LineChartIcon.js +1 -1
  311. package/dist/icons/LoadingIcon.js +1 -1
  312. package/dist/icons/LockFilledIcon.js +1 -1
  313. package/dist/icons/LockIcon.js +1 -1
  314. package/dist/icons/MoreIcon.js +1 -1
  315. package/dist/icons/NotAllowedIcon.js +1 -1
  316. package/dist/icons/Number123Icon.js +1 -1
  317. package/dist/icons/NumberIcon.js +1 -1
  318. package/dist/icons/PauseCircleFilledIcon.js +1 -1
  319. package/dist/icons/PauseCircleIcon.js +1 -1
  320. package/dist/icons/PauseIcon.js +1 -1
  321. package/dist/icons/PercentageIcon.js +1 -1
  322. package/dist/icons/PieChartIcon.js +1 -1
  323. package/dist/icons/PlayCircleIcon.js +1 -1
  324. package/dist/icons/PlayIcon.js +1 -1
  325. package/dist/icons/PlusIcon.js +1 -1
  326. package/dist/icons/ProgressBarIcon.js +1 -1
  327. package/dist/icons/ReloadIcon.js +1 -1
  328. package/dist/icons/ReportIcon.js +1 -1
  329. package/dist/icons/ReturnIcon.js +1 -1
  330. package/dist/icons/RightIcon.js +1 -1
  331. package/dist/icons/RowTotalsIcon.js +1 -1
  332. package/dist/icons/SchemeIcon.js +1 -1
  333. package/dist/icons/SearchIcon.js +1 -1
  334. package/dist/icons/SemanticQueryIcon.js +1 -1
  335. package/dist/icons/SettingsIcon.js +1 -1
  336. package/dist/icons/ShieldFilledIcon.js +1 -1
  337. package/dist/icons/ShieldIcon.js +1 -1
  338. package/dist/icons/SlashIcon.js +1 -1
  339. package/dist/icons/SparklesIcon.js +1 -1
  340. package/dist/icons/SqlIcon.js +1 -1
  341. package/dist/icons/StatsIcon.js +1 -1
  342. package/dist/icons/StopIcon.js +1 -1
  343. package/dist/icons/StringIcon.js +1 -1
  344. package/dist/icons/SubtotalsIcon.js +1 -1
  345. package/dist/icons/SwitchIcon.js +1 -1
  346. package/dist/icons/TableIcon.js +1 -1
  347. package/dist/icons/ThumbsDownIcon.js +1 -1
  348. package/dist/icons/ThumbsUpIcon.js +1 -1
  349. package/dist/icons/ThunderboltCrossedIcon.js +1 -1
  350. package/dist/icons/ThunderboltFilledIcon.js +1 -1
  351. package/dist/icons/ThunderboltIcon.js +1 -1
  352. package/dist/icons/TimeIcon.js +1 -1
  353. package/dist/icons/TrashIcon.js +1 -1
  354. package/dist/icons/UnlockIcon.js +1 -1
  355. package/dist/icons/UpIcon.js +1 -1
  356. package/dist/icons/UserGroupIcon.js +1 -1
  357. package/dist/icons/UserIcon.js +1 -1
  358. package/dist/icons/UserLockIcon.js +1 -1
  359. package/dist/icons/ViewIcon.js +1 -1
  360. package/dist/icons/WarningFilledIcon.js +1 -1
  361. package/dist/icons/WarningIcon.js +1 -1
  362. package/dist/icons/wrap-icon.js +1 -1
  363. package/dist/index.js +1 -1
  364. package/dist/provider.js +1 -1
  365. package/dist/providers/TrackingProvider.js +1 -1
  366. package/dist/providers/navigationAdapter.default.js +1 -1
  367. package/dist/tokens/base.js +1 -1
  368. package/dist/tokens/colors.js +1 -1
  369. package/dist/tokens/index.js +1 -1
  370. package/dist/tokens/layout.js +1 -1
  371. package/dist/tokens/shadows.js +1 -1
  372. package/dist/tokens/sizes.js +1 -1
  373. package/dist/tokens/spacing.js +1 -1
  374. package/dist/tokens/typography.js +1 -1
  375. package/dist/utils/ResizeSensor.js +1 -1
  376. package/dist/utils/is-dev-env.js +1 -1
  377. package/dist/utils/modules.js +1 -1
  378. package/dist/utils/promise.js +1 -1
  379. package/dist/utils/raf.js +1 -1
  380. package/dist/utils/random.js +1 -1
  381. package/dist/utils/range.js +1 -1
  382. package/dist/utils/react/RenderCache.js +1 -1
  383. package/dist/utils/react/Slots.js +1 -1
  384. package/dist/utils/react/chain.js +1 -1
  385. package/dist/utils/react/forwardRefWithGenerics.js +1 -1
  386. package/dist/utils/react/index.js +1 -1
  387. package/dist/utils/react/interactions.js +1 -1
  388. package/dist/utils/react/isTextOnly.js +1 -1
  389. package/dist/utils/react/mapProps.js +1 -1
  390. package/dist/utils/react/mergeProps.js +1 -1
  391. package/dist/utils/react/nullableValue.js +1 -1
  392. package/dist/utils/react/resolveIcon.js +1 -1
  393. package/dist/utils/react/sharedStore.js +1 -1
  394. package/dist/utils/react/useCombinedRefs.js +1 -1
  395. package/dist/utils/react/useControlledFocusVisible.js +1 -1
  396. package/dist/utils/react/useEventBus.js +1 -1
  397. package/dist/utils/react/useId.js +1 -1
  398. package/dist/utils/react/useIsDarwin.js +1 -1
  399. package/dist/utils/react/useKeySymbols.js +1 -1
  400. package/dist/utils/react/useLayoutEffect.js +1 -1
  401. package/dist/utils/react/useLocalStorage.js +1 -1
  402. package/dist/utils/react/useMergeStyles.js +1 -1
  403. package/dist/utils/react/useQaProps.js +1 -1
  404. package/dist/utils/react/useViewportSize.js +1 -1
  405. package/dist/utils/react/wrapNodeIfPlain.js +1 -1
  406. package/dist/utils/selection.js +1 -1
  407. package/dist/utils/styles.js +1 -1
  408. package/dist/utils/tree.js +1 -1
  409. package/dist/utils/warnings.js +1 -1
  410. package/dist/version.js +2 -2
  411. package/docs/components/fields/FilterListBox.md +27 -17
  412. package/docs/components/fields/FilterPicker.md +58 -59
  413. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"FilterListBox.js","names":["mergeProps","BaseSection","useFocus"],"sources":["../../../../src/components/fields/FilterListBox/FilterListBox.tsx"],"sourcesContent":["import { Key } from '@react-types/shared';\nimport {\n BASE_STYLES,\n COLOR_STYLES,\n OUTER_STYLES,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n cloneElement,\n ForwardedRef,\n forwardRef,\n isValidElement,\n ReactElement,\n ReactNode,\n RefObject,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useFilter, useKeyboard } from 'react-aria';\nimport { Section as BaseSection, Item, useListState } from 'react-stately';\nimport { CubeCollectionItemProps } from 'src/components/CollectionItem';\n\nimport { LoadingIcon } from '../../../icons';\nimport { useProviderProps } from '../../../provider';\nimport { mergeProps, modAttrs, useCombinedRefs } from '../../../utils/react';\nimport { useFocus } from '../../../utils/react/interactions';\nimport { extractStyles } from '../../../utils/styles';\nimport { StyledHeader } from '../../actions/Menu/styled';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { CubeListBoxProps, ListBox } from '../ListBox/ListBox';\nimport {\n DEFAULT_INPUT_STYLES,\n INPUT_WRAPPER_STYLES,\n} from '../TextInput/TextInputBase';\n\nimport type { Collection, Node } from '@react-types/shared';\nimport type { FieldBaseProps } from '../../../shared';\n\ntype FilterFn = (textValue: string, inputValue: string) => boolean;\n\nconst FilterListBoxWrapperElement = tasty({\n styles: {\n display: 'grid',\n flow: 'column',\n gridColumns: '1sf',\n gridRows: 'max-content max-content 1sf',\n gap: 0,\n position: 'relative',\n radius: true,\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 popover: false,\n },\n },\n});\n\nconst SearchWrapperElement = tasty({\n qa: 'FilterListBoxSearchWrapper',\n styles: {\n ...INPUT_WRAPPER_STYLES,\n border: 'bottom',\n radius: '1r top',\n fill: '#clear',\n height: '($size + 1x)',\n $size: {\n '': '$size-md',\n 'size=small': '$size-sm',\n 'size=medium': '$size-md',\n 'size=large': '$size-lg',\n },\n },\n});\n\nconst SearchInputElement = tasty({\n as: 'input',\n styles: {\n ...DEFAULT_INPUT_STYLES,\n fill: '#clear',\n padding: {\n '': '.5x 1.5x',\n prefix: '0 1.5x 0 .5x',\n },\n },\n});\n\nconst StyledHeaderWithoutBorder = tasty(StyledHeader, {\n styles: {\n border: false,\n },\n});\n\nexport interface CubeFilterListBoxProps<T>\n extends Omit<CubeListBoxProps<T>, 'filter'>,\n FieldBaseProps {\n /** Placeholder text for the search input */\n searchPlaceholder?: string;\n /** Whether the search input should have autofocus */\n autoFocus?: boolean;\n /**\n * Custom filter function for determining if an option should be included in search results.\n * Pass `false` to disable internal filtering completely (useful for external filtering).\n */\n filter?: FilterFn | false;\n /** Custom label to display when no results are found after filtering */\n emptyLabel?: ReactNode;\n /** Custom styles for the search input */\n searchInputStyles?: Styles;\n /** Whether the FilterListBox is in loading state (shows loading icon in search input) */\n isLoading?: boolean;\n /** Ref for accessing the search input element */\n searchInputRef?: RefObject<HTMLInputElement | null>;\n /** Whether to allow entering custom values that are not present in the predefined options */\n allowsCustomValue?: boolean;\n /** Additional modifiers for styling the FilterListBox */\n mods?: Record<string, boolean>;\n /** Custom styles for the list box */\n listBoxStyles?: Styles;\n\n /**\n * Callback fired when the user presses Escape key while the search input is empty.\n * Can be used by parent components (e.g. FilterPicker) to close an enclosing Dialog.\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 * Props to apply to existing custom values (values that are already selected but not in the predefined options).\n */\n customValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Props to apply to new custom values (values typed in the search input that are about to be added).\n * These are merged with customValueProps for new custom values.\n */\n newCustomValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Controlled search value. When provided, the search input becomes controlled.\n * Use with `onSearchChange` to manage the search state externally.\n */\n searchValue?: string;\n\n /**\n * Callback fired when the search input value changes.\n * Use with `searchValue` for controlled search input.\n */\n onSearchChange?: (value: string) => void;\n\n /**\n * Pre-built collection to use instead of creating a new one.\n * Used internally by FilterPicker to avoid duplicate collection creation.\n * @internal\n */\n _internalCollection?: Collection<Node<any>>;\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nexport const FilterListBox = forwardRef(function FilterListBox<\n T extends object,\n>(props: CubeFilterListBoxProps<T>, ref: ForwardedRef<HTMLDivElement>) {\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 // 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 labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n isLoading,\n searchPlaceholder = 'Search...',\n autoFocus,\n filter,\n mods: externalMods,\n emptyLabel,\n searchInputStyles,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n searchInputRef,\n listRef,\n message,\n description,\n styles,\n focusOnHover,\n shouldFocusWrap,\n labelSuffix,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n onSelectionChange: externalOnSelectionChange,\n allowsCustomValue = false,\n showSelectAll,\n selectAllLabel,\n header,\n footer,\n size = 'medium',\n headerStyles,\n footerStyles,\n listBoxStyles,\n items,\n children: renderChildren,\n onEscape,\n isCheckable,\n onOptionClick,\n selectionMode = 'single',\n allValueProps,\n customValueProps,\n newCustomValueProps,\n searchValue: controlledSearchValue,\n onSearchChange,\n _internalCollection,\n form,\n ...otherProps\n } = props;\n\n // Preserve the original `children` (may be a render function) before we\n // potentially overwrite it.\n let children: ReactNode = renderChildren as ReactNode;\n\n const renderFn = renderChildren as unknown;\n\n if (items && typeof renderFn === 'function') {\n try {\n const itemsArray = Array.from(items as Iterable<any>);\n // Execute the render function for each item to obtain <Item/> / <Section/> nodes.\n children = itemsArray.map((item, idx) => {\n const rendered = (renderFn as (it: any) => ReactNode)(item);\n // Ensure every element has a stable key: rely on the user-provided key\n // inside the render function, otherwise fall back to the item itself or\n // the index. This mirrors React Aria examples where the render function\n // is expected to set keys, but we add a fallback for robustness.\n if (\n isValidElement(rendered) &&\n (rendered as ReactElement).key == null\n ) {\n return cloneElement(rendered as ReactElement, {\n key: (rendered as any)?.key ?? item?.key ?? idx,\n });\n }\n\n return rendered as ReactNode;\n });\n } catch {\n // If conversion fails for some reason, we silently ignore and proceed\n // with the original children value so we don't break runtime.\n }\n }\n\n // Use provided collection from FilterPicker or create our own\n // Hook call order is stable: _internalCollection is consistent per component instance\n const localCollectionState = _internalCollection\n ? { collection: _internalCollection }\n : useListState({\n children: children as any,\n items: items as any,\n selectionMode: 'none' as any,\n });\n\n // Collect original option keys to avoid duplicating them as custom values.\n const originalKeys = useMemo(() => {\n const keys = new Set<string>();\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n keys.add(String(item.key));\n }\n }\n return keys;\n }, [localCollectionState.collection]);\n\n // State to keep track of custom (user-entered) items that were selected.\n const [customKeys, setCustomKeys] = useState<Set<string>>(new Set());\n\n // Initialize custom keys from current selection\n useEffect(() => {\n if (!allowsCustomValue) return;\n\n const currentSelectedKeys = selectedKeys\n ? selectedKeys === 'all'\n ? [] // Skip custom key detection when 'all' is selected\n : Array.from(selectedKeys).map(String)\n : selectedKey != null\n ? [String(selectedKey)]\n : [];\n\n if (currentSelectedKeys.length === 0) return;\n\n const keysToAdd = currentSelectedKeys.filter((k) => !originalKeys.has(k));\n\n if (keysToAdd.length) {\n setCustomKeys((prev) => new Set([...Array.from(prev), ...keysToAdd]));\n }\n }, [allowsCustomValue, selectedKeys, selectedKey, originalKeys]);\n\n // Merge original children with any custom items so they persist in the list.\n // If there are selected custom values, they should appear on top with other\n // selected items (which are already sorted by the parent component, e.g. FilterPicker).\n const mergedChildren: ReactNode = useMemo(() => {\n if (!children && customKeys.size === 0) return children;\n\n // Build React elements for custom values (kept stable via their key).\n const customArray = Array.from(customKeys).map((key) => (\n <Item key={key} textValue={key} {...customValueProps}>\n {key}\n </Item>\n ));\n\n // Identify which custom keys are currently selected so we can promote them.\n const selectedKeysSet = new Set<string>();\n\n if (selectionMode === 'multiple') {\n if (selectedKeys === 'all') {\n // When 'all' is selected, no custom items should be treated as selected\n // since 'all' means all available items, not custom ones\n } else {\n Array.from(selectedKeys ?? []).forEach((k) =>\n selectedKeysSet.add(String(k)),\n );\n }\n } else {\n if (selectedKey != null) selectedKeysSet.add(String(selectedKey));\n }\n\n const selectedCustom: ReactNode[] = [];\n const unselectedCustom: ReactNode[] = [];\n\n customArray.forEach((item: any) => {\n if (selectedKeysSet.has(String(item.key))) {\n selectedCustom.push(item);\n } else {\n unselectedCustom.push(item);\n }\n });\n\n if (!children) {\n // No original items – just return selected custom followed by the rest.\n return [...selectedCustom, ...unselectedCustom];\n }\n\n const originalArray = Array.isArray(children) ? children : [children];\n\n // Final order: selected custom items -> original array (already possibly\n // sorted by parent) -> unselected custom items.\n return [...selectedCustom, ...originalArray, ...unselectedCustom];\n }, [children, customKeys, selectionMode, selectedKey, selectedKeys]);\n\n // Determine an aria-label for the internal ListBox to avoid React Aria warnings.\n const innerAriaLabel =\n (props as any)['aria-label'] ||\n (typeof label === 'string' ? label : undefined);\n\n // Controlled/uncontrolled search value pattern\n const [internalSearchValue, setInternalSearchValue] = useState('');\n const isSearchControlled = controlledSearchValue !== undefined;\n const searchValue = isSearchControlled\n ? controlledSearchValue\n : internalSearchValue;\n\n const handleSearchChange = useCallback(\n (value: string) => {\n if (!isSearchControlled) {\n setInternalSearchValue(value);\n }\n onSearchChange?.(value);\n },\n [isSearchControlled, onSearchChange],\n );\n\n const { contains } = useFilter({ sensitivity: 'base' });\n\n // Choose the text filter function: user-provided `filter` prop (if any),\n // or the default `contains` helper from `useFilter`.\n // When filter={false}, disable filtering completely.\n const textFilterFn = useMemo<FilterFn>(\n () => (filter === false ? () => true : filter || contains),\n [filter, contains],\n );\n\n // Create a filter function for collection nodes (similar to ComboBox pattern)\n const filterFn = useCallback(\n (nodes: Iterable<any>) => {\n const term = searchValue.trim();\n\n // Don't filter if no search term\n if (!term) {\n return nodes;\n }\n\n // Filter nodes based on their textValue and preserve section structure\n return [...nodes]\n .map((node: any) => {\n if (node.type === 'section' && node.childNodes) {\n const filteredNodes = [...node.childNodes].filter((child: any) =>\n textFilterFn(child.textValue || '', term),\n );\n\n if (filteredNodes.length === 0) {\n return null;\n }\n\n return {\n ...node,\n childNodes: filteredNodes,\n hasChildNodes: true,\n };\n }\n\n return textFilterFn(node.textValue || '', term) ? node : null;\n })\n .filter(Boolean);\n },\n [searchValue, textFilterFn],\n );\n\n // Handle custom values if allowed\n const enhancedChildren = useMemo(() => {\n let childrenToProcess = mergedChildren;\n\n // Handle custom values if allowed\n if (!allowsCustomValue) return childrenToProcess;\n\n const term = searchValue.trim();\n if (!term) return childrenToProcess;\n\n // Helper to determine if the term is already present (exact match on rendered textValue or the key).\n const doesTermExist = (term: string): boolean => {\n // Check if term exists in custom keys\n if (customKeys.has(term)) {\n return true;\n }\n\n // Check if term exists in original collection\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n const textValue = item.textValue || String(item.rendered || '');\n if (term === textValue || String(item.key) === term) {\n return true;\n }\n }\n }\n return false;\n };\n\n if (doesTermExist(term)) {\n return childrenToProcess;\n }\n\n // Check if there are any items that will match the filter\n // This determines whether we need to visually separate the custom value\n const hasVisibleFilteredItems = (() => {\n // Check original collection items\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n const textValue = item.textValue || String(item.rendered || '');\n if (textFilterFn(textValue, term)) {\n return true;\n }\n } else if (item.type === 'section' && item.childNodes) {\n for (const child of item.childNodes) {\n const textValue = child.textValue || String(child.rendered || '');\n if (textFilterFn(textValue, term)) {\n return true;\n }\n }\n }\n }\n\n // Also check custom keys - they appear as items in mergedChildren\n for (const customKey of customKeys) {\n if (textFilterFn(customKey, term)) {\n return true;\n }\n }\n\n return false;\n })();\n\n // Create the custom option\n const customOption = (\n <Item\n key={term}\n textValue={term}\n {...mergeProps(customValueProps, newCustomValueProps)}\n >\n {term}\n </Item>\n );\n\n // If there are visible filtered items, add visual separation for custom value\n if (hasVisibleFilteredItems && childrenToProcess) {\n // Check if the collection contains any sections\n // If it does, we can't wrap childrenToProcess in another section (would create nested sections)\n const hasSections = [...localCollectionState.collection].some(\n (item) => item.type === 'section',\n );\n\n const customValueSection = (\n <BaseSection key=\"__custom_value__\" aria-label=\"Custom value\">\n {customOption}\n </BaseSection>\n );\n\n if (hasSections) {\n // Collection has sections - just append the custom value section without wrapping\n if (Array.isArray(childrenToProcess)) {\n return [...childrenToProcess, customValueSection];\n }\n return [childrenToProcess, customValueSection];\n }\n\n // No sections in collection - wrap items in a section for visual separation\n const filteredItemsSection = (\n <BaseSection key=\"__filtered_items__\" aria-label=\"Filtered items\">\n {childrenToProcess}\n </BaseSection>\n );\n\n return [filteredItemsSection, customValueSection];\n }\n\n // No visible filtered items, just return the custom option without sections\n if (Array.isArray(childrenToProcess)) {\n return [...childrenToProcess, customOption];\n }\n\n if (childrenToProcess) {\n return [childrenToProcess, customOption];\n }\n\n return customOption;\n }, [\n allowsCustomValue,\n mergedChildren,\n searchValue,\n customKeys,\n localCollectionState.collection,\n customValueProps,\n newCustomValueProps,\n textFilterFn,\n ]);\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n ref = useCombinedRefs(ref);\n searchInputRef = useCombinedRefs(searchInputRef);\n listRef = useCombinedRefs(listRef);\n\n const { isFocused, focusProps } = useFocus({ isDisabled });\n const isInvalid = validationState === 'invalid';\n\n const listBoxRef = useRef<HTMLDivElement>(null);\n\n // Ref to access internal ListBox state (selection manager, etc.)\n const listStateRef = useRef<any>(null);\n\n // No separate focusedKey state needed; rely directly on selectionManager.focusedKey.\n\n // When the search value changes, the visible collection of items may change as well.\n // If the currently focused item is no longer visible, move virtual focus to the first\n // available item so that arrow navigation and Enter behaviour continue to work.\n // If there are no available items, reset the selection so Enter won't select anything.\n // Priority: focus on selected items first, then fall back to first visible item.\n useLayoutEffect(() => {\n const listState = listStateRef.current;\n\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Helper to collect visible item keys (supports sections)\n // Collection is already filtered by React Stately via filterFn\n const collectVisibleKeys = (nodes: Iterable<any>, out: Key[]) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n } else if (node.childNodes) {\n collectVisibleKeys(node.childNodes, out);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n // If there are no visible items, reset the focused key so Enter won't select anything\n if (visibleKeys.length === 0) {\n selectionManager.setFocusedKey(null);\n return;\n }\n\n // Early exit if the current focused key is still present in the visible items.\n const currentFocused = selectionManager.focusedKey;\n if (currentFocused != null && visibleKeys.includes(currentFocused)) {\n return;\n }\n\n // Helper to find the first selected item that's visible\n const findFirstVisibleSelectedKey = (): Key | null => {\n if (selectionMode === 'single') {\n // Single selection: check if selectedKey is visible\n if (selectedKey != null) {\n const selectedKeyStr = String(selectedKey);\n if (visibleKeys.some((k) => String(k) === selectedKeyStr)) {\n return selectedKey;\n }\n }\n } else if (selectionMode === 'multiple') {\n // Multiple selection: find first selected key that's visible\n if (selectedKeys && selectedKeys !== 'all') {\n for (const key of selectedKeys) {\n const keyStr = String(key);\n if (visibleKeys.some((k) => String(k) === keyStr)) {\n return key;\n }\n }\n }\n }\n return null;\n };\n\n // Determine which key to focus\n let keyToFocus: Key | null = null;\n\n // If there's no focus yet (initial state), prioritize selected items\n if (currentFocused == null) {\n keyToFocus = findFirstVisibleSelectedKey();\n } else {\n // If current focused item was filtered out, try to focus another selected item\n keyToFocus = findFirstVisibleSelectedKey();\n }\n\n // Fallback to first visible item if no selected item found\n if (keyToFocus == null) {\n keyToFocus = visibleKeys[0];\n }\n\n // Mark this focus change as keyboard navigation so ListBox will scroll to it\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n\n // Set focus to the determined key\n selectionManager.setFocusedKey(keyToFocus);\n }, [searchValue, enhancedChildren, selectionMode, selectedKey, selectedKeys]);\n\n // Keyboard navigation handler for search input\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {\n e.preventDefault();\n\n const listState = listStateRef.current;\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Helper to collect visible item keys (supports sections)\n // Collection is already filtered by React Stately via filterFn\n const collectVisibleKeys = (nodes: Iterable<any>, out: Key[]) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n } else if (node.childNodes) {\n collectVisibleKeys(node.childNodes, out);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n if (visibleKeys.length === 0) return;\n\n const isArrowDown = e.key === 'ArrowDown';\n const direction = isArrowDown ? 1 : -1;\n\n const currentKey = selectionManager.focusedKey;\n\n let nextKey: Key | null = null;\n\n if (currentKey == null) {\n // If nothing focused yet, pick first/last depending on direction\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n } else {\n const currentIndex = visibleKeys.indexOf(currentKey);\n if (currentIndex !== -1) {\n const newIndex = currentIndex + direction;\n if (newIndex >= 0 && newIndex < visibleKeys.length) {\n nextKey = visibleKeys[newIndex];\n } else if (shouldFocusWrap) {\n // Wrap around\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n }\n } else {\n // Fallback\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n }\n }\n\n if (nextKey != null) {\n // Mark this focus change as keyboard navigation\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n selectionManager.setFocusedKey(nextKey);\n }\n } else if (\n e.key === 'Home' ||\n e.key === 'End' ||\n e.key === 'PageUp' ||\n e.key === 'PageDown'\n ) {\n e.preventDefault();\n\n const listState = listStateRef.current;\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Helper to collect visible item keys (supports sections)\n // Collection is already filtered by React Stately via filterFn\n const collectVisibleKeys = (nodes: Iterable<any>, out: Key[]) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n } else if (node.childNodes) {\n collectVisibleKeys(node.childNodes, out);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n if (visibleKeys.length === 0) return;\n\n const targetKey =\n e.key === 'Home' || e.key === 'PageUp'\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n\n // Mark this focus change as keyboard navigation\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n selectionManager.setFocusedKey(targetKey);\n } else if (e.key === 'Enter' || (e.key === ' ' && !searchValue)) {\n const listState = listStateRef.current;\n\n if (!listState) return;\n\n const keyToSelect = listState.selectionManager.focusedKey;\n\n if (keyToSelect != null) {\n e.preventDefault();\n listState.selectionManager.select(keyToSelect, e);\n\n if (\n e.key === 'Enter' &&\n isCheckable &&\n onEscape &&\n selectionMode === 'multiple'\n ) {\n onEscape();\n }\n }\n } else if (e.key === 'Escape') {\n if (searchValue) {\n // Clear the current search if any text is present.\n e.preventDefault();\n handleSearchChange('');\n } else {\n // Notify parent that Escape was pressed on an empty input.\n if (onEscape) {\n e.preventDefault();\n onEscape();\n }\n }\n }\n },\n });\n\n const mods = useMemo(\n () => ({\n invalid: isInvalid,\n valid: validationState === 'valid',\n disabled: !!isDisabled,\n focused: isFocused,\n loading: !!isLoading,\n searchable: true,\n prefix: !!isLoading,\n ...externalMods,\n }),\n [\n isInvalid,\n validationState,\n isDisabled,\n isFocused,\n isLoading,\n externalMods,\n ],\n );\n\n // Handler must be defined before we render ListBox so we can pass it.\n const handleSelectionChange = (selection: any) => {\n if (allowsCustomValue) {\n // Normalize current selection into an array of string keys\n let selectedValues: string[] = [];\n\n if (selection != null) {\n if (Array.isArray(selection)) {\n selectedValues = selection.map(String);\n } else {\n selectedValues = [String(selection)];\n }\n }\n\n // Build next custom keys set based on selected values\n const nextSet = new Set<string>();\n\n selectedValues.forEach((val) => {\n if (!originalKeys.has(val)) {\n nextSet.add(val);\n }\n });\n\n // Update internal custom keys state\n setCustomKeys(nextSet);\n }\n\n if (externalOnSelectionChange) {\n (externalOnSelectionChange as any)(selection);\n }\n };\n\n // Custom option click handler that ensures search input receives focus\n const handleOptionClick = (key: Key) => {\n // Focus the search input to enable keyboard navigation\n // Use setTimeout to ensure this happens after React state updates\n setTimeout(() => {\n if (searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, 0);\n\n // Call the original onOptionClick if provided\n if (onOptionClick) {\n onOptionClick(key);\n }\n };\n\n const searchInput = (\n <SearchWrapperElement mods={mods} data-size={size}>\n {isLoading && (\n <div data-element=\"Prefix\">\n <div data-element=\"InputIcon\">\n {isLoading ? <LoadingIcon /> : null}\n </div>\n </div>\n )}\n <SearchInputElement\n ref={searchInputRef}\n qa={qa || 'FilterListBox'}\n id={id}\n data-prefix={isLoading ? '' : undefined}\n type=\"search\"\n placeholder={searchPlaceholder}\n value={searchValue}\n disabled={isDisabled}\n autoFocus={autoFocus}\n data-autofocus={autoFocus ? '' : undefined}\n styles={searchInputStyles}\n data-size={size}\n data-input-type=\"filterlistbox\"\n role=\"combobox\"\n aria-expanded=\"true\"\n aria-haspopup=\"listbox\"\n aria-activedescendant={\n listStateRef.current?.selectionManager.focusedKey != null\n ? `ListBoxItem-${listStateRef.current?.selectionManager.focusedKey}`\n : undefined\n }\n onChange={(e) => {\n handleSearchChange(e.target.value);\n }}\n {...keyboardProps}\n {...modAttrs(mods)}\n />\n </SearchWrapperElement>\n );\n\n const filterListBoxField = (\n <FilterListBoxWrapperElement\n ref={ref}\n qa=\"FilterListBoxWrapper\"\n {...modAttrs(mods)}\n styles={styles}\n {...focusProps}\n >\n {header ? (\n <StyledHeaderWithoutBorder data-size={size} styles={headerStyles}>\n {header}\n </StyledHeaderWithoutBorder>\n ) : (\n <div role=\"presentation\" />\n )}\n {searchInput}\n <ListBox\n ref={listBoxRef}\n aria-label={innerAriaLabel}\n selectedKey={selectedKey}\n defaultSelectedKey={defaultSelectedKey}\n selectedKeys={selectedKeys}\n defaultSelectedKeys={defaultSelectedKeys}\n selectionMode={selectionMode}\n isDisabled={isDisabled}\n listRef={listRef}\n stateRef={listStateRef}\n listStyles={listStyles}\n shouldFocusWrap={shouldFocusWrap}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n validationState={validationState}\n disallowEmptySelection={props.disallowEmptySelection}\n disabledKeys={props.disabledKeys}\n focusOnHover={focusOnHover}\n shouldUseVirtualFocus={true}\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n footer={footer}\n footerStyles={footerStyles}\n mods={mods}\n size=\"medium\"\n styles={listBoxStyles}\n isCheckable={isCheckable}\n items={items as any}\n allValueProps={allValueProps}\n filter={filterFn}\n emptyLabel={\n searchValue.trim()\n ? emptyLabel !== undefined\n ? emptyLabel\n : 'No results found'\n : 'No items'\n }\n onSelectionChange={handleSelectionChange}\n onEscape={onEscape}\n onOptionClick={handleOptionClick}\n >\n {enhancedChildren as any}\n </ListBox>\n </FilterListBoxWrapperElement>\n );\n\n return wrapWithField<Omit<CubeFilterListBoxProps<T>, 'children'>>(\n filterListBoxField,\n ref,\n props,\n );\n}) as unknown as (<T>(\n props: CubeFilterListBoxProps<T> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement) & { Item: typeof Item; Section: typeof BaseSection };\n\nFilterListBox.Item = ListBox.Item;\n\nFilterListBox.Section = BaseSection;\n\nObject.defineProperty(FilterListBox, 'cubeInputType', {\n value: 'FilterListBox',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
1
+ {"version":3,"file":"FilterListBox.js","names":["mergeProps","BaseSection","useFocus"],"sources":["../../../../src/components/fields/FilterListBox/FilterListBox.tsx"],"sourcesContent":["import { Key } from '@react-types/shared';\nimport {\n BASE_STYLES,\n COLOR_STYLES,\n OUTER_STYLES,\n Styles,\n tasty,\n} from '@tenphi/tasty';\nimport {\n cloneElement,\n ForwardedRef,\n forwardRef,\n isValidElement,\n ReactElement,\n ReactNode,\n RefObject,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useFilter, useKeyboard } from 'react-aria';\nimport { Section as BaseSection, Item, useListState } from 'react-stately';\nimport { CubeCollectionItemProps } from 'src/components/CollectionItem';\n\nimport { LoadingIcon } from '../../../icons';\nimport { useProviderProps } from '../../../provider';\nimport { mergeProps, modAttrs, useCombinedRefs } from '../../../utils/react';\nimport { useFocus } from '../../../utils/react/interactions';\nimport { extractStyles } from '../../../utils/styles';\nimport { StyledHeader } from '../../actions/Menu/styled';\nimport { useFieldProps, useFormProps, wrapWithField } from '../../form';\nimport { CubeListBoxProps, ListBox } from '../ListBox/ListBox';\nimport {\n DEFAULT_INPUT_STYLES,\n INPUT_WRAPPER_STYLES,\n} from '../TextInput/TextInputBase';\n\nimport type { Collection, Node } from '@react-types/shared';\nimport type { FieldBaseProps } from '../../../shared';\n\ntype FilterFn = (textValue: string, inputValue: string) => boolean;\n\nconst FilterListBoxWrapperElement = tasty({\n styles: {\n display: 'grid',\n flow: 'column',\n gridColumns: '1sf',\n gridRows: 'max-content max-content 1sf',\n gap: 0,\n position: 'relative',\n radius: true,\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 popover: false,\n },\n },\n});\n\nconst SearchWrapperElement = tasty({\n qa: 'FilterListBoxSearchWrapper',\n styles: {\n ...INPUT_WRAPPER_STYLES,\n border: 'bottom',\n radius: '1r top',\n fill: '#clear',\n height: '($size + 1x)',\n $size: {\n '': '$size-md',\n 'size=small': '$size-sm',\n 'size=medium': '$size-md',\n 'size=large': '$size-lg',\n },\n },\n});\n\nconst SearchInputElement = tasty({\n as: 'input',\n styles: {\n ...DEFAULT_INPUT_STYLES,\n fill: '#clear',\n padding: {\n '': '.5x 1.5x',\n prefix: '0 1.5x 0 .5x',\n suffix: '.5x .5x .5x 1.5x',\n 'prefix & suffix': '0 .5x 0 .5x',\n },\n },\n});\n\nconst StyledHeaderWithoutBorder = tasty(StyledHeader, {\n styles: {\n border: false,\n },\n});\n\nexport interface CubeFilterListBoxProps<T>\n extends Omit<CubeListBoxProps<T>, 'filter'>,\n FieldBaseProps {\n /** Placeholder text for the search input */\n searchPlaceholder?: string;\n /** Whether the search input should have autofocus */\n autoFocus?: boolean;\n /**\n * Custom filter function for determining if an option should be included in search results.\n * Pass `false` to disable internal filtering completely (useful for external filtering).\n */\n filter?: FilterFn | false;\n /** Label shown when the list is empty. When provided, overrides both the \"No results found\" and \"No items\" defaults. */\n emptyLabel?: ReactNode;\n /** Custom styles for the search input */\n searchInputStyles?: Styles;\n /** Whether the FilterListBox is in loading state (shows loading icon in search input) */\n isLoading?: boolean;\n /** Whether items are currently loading. Shows a loading icon in the search input suffix. */\n isLoadingItems?: boolean;\n /** Ref for accessing the search input element */\n searchInputRef?: RefObject<HTMLInputElement | null>;\n /** Whether to allow entering custom values that are not present in the predefined options */\n allowsCustomValue?: boolean;\n /** Additional modifiers for styling the FilterListBox */\n mods?: Record<string, boolean>;\n /** Custom styles for the list box */\n listBoxStyles?: Styles;\n\n /**\n * Callback fired when the user presses Escape key while the search input is empty.\n * Can be used by parent components (e.g. FilterPicker) to close an enclosing Dialog.\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 * Props to apply to existing custom values (values that are already selected but not in the predefined options).\n */\n customValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Props to apply to new custom values (values typed in the search input that are about to be added).\n * These are merged with customValueProps for new custom values.\n */\n newCustomValueProps?: Partial<CubeCollectionItemProps<T>>;\n\n /**\n * Controlled search value. When provided, the search input becomes controlled.\n * Use with `onSearchChange` to manage the search state externally.\n */\n searchValue?: string;\n\n /**\n * Callback fired when the search input value changes.\n * Use with `searchValue` for controlled search input.\n */\n onSearchChange?: (value: string) => void;\n\n /**\n * Pre-built collection to use instead of creating a new one.\n * Used internally by FilterPicker to avoid duplicate collection creation.\n * @internal\n */\n _internalCollection?: Collection<Node<any>>;\n}\n\nconst PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];\n\nexport const FilterListBox = forwardRef(function FilterListBox<\n T extends object,\n>(props: CubeFilterListBoxProps<T>, ref: ForwardedRef<HTMLDivElement>) {\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 // 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 labelStyles,\n isRequired,\n necessityIndicator,\n validationState,\n isDisabled,\n isLoading,\n isLoadingItems,\n searchPlaceholder = 'Search...',\n autoFocus,\n filter,\n mods: externalMods,\n emptyLabel,\n searchInputStyles,\n listStyles,\n optionStyles,\n sectionStyles,\n headingStyles,\n searchInputRef,\n listRef,\n message,\n description,\n styles,\n focusOnHover,\n shouldFocusWrap,\n labelSuffix,\n selectedKey,\n defaultSelectedKey,\n selectedKeys,\n defaultSelectedKeys,\n onSelectionChange: externalOnSelectionChange,\n allowsCustomValue = false,\n showSelectAll,\n selectAllLabel,\n header,\n footer,\n size = 'medium',\n headerStyles,\n footerStyles,\n listBoxStyles,\n items,\n children: renderChildren,\n onEscape,\n isCheckable,\n onOptionClick,\n selectionMode = 'single',\n allValueProps,\n customValueProps,\n newCustomValueProps,\n searchValue: controlledSearchValue,\n onSearchChange,\n _internalCollection,\n form,\n ...otherProps\n } = props;\n\n // Preserve the original `children` (may be a render function) before we\n // potentially overwrite it.\n let children: ReactNode = renderChildren as ReactNode;\n\n const renderFn = renderChildren as unknown;\n\n if (items && typeof renderFn === 'function') {\n try {\n const itemsArray = Array.from(items as Iterable<any>);\n // Execute the render function for each item to obtain <Item/> / <Section/> nodes.\n children = itemsArray.map((item, idx) => {\n const rendered = (renderFn as (it: any) => ReactNode)(item);\n // Ensure every element has a stable key: rely on the user-provided key\n // inside the render function, otherwise fall back to the item itself or\n // the index. This mirrors React Aria examples where the render function\n // is expected to set keys, but we add a fallback for robustness.\n if (\n isValidElement(rendered) &&\n (rendered as ReactElement).key == null\n ) {\n return cloneElement(rendered as ReactElement, {\n key: (rendered as any)?.key ?? item?.key ?? idx,\n });\n }\n\n return rendered as ReactNode;\n });\n } catch {\n // If conversion fails for some reason, we silently ignore and proceed\n // with the original children value so we don't break runtime.\n }\n }\n\n // Use provided collection from FilterPicker or create our own\n // Hook call order is stable: _internalCollection is consistent per component instance\n const localCollectionState = _internalCollection\n ? { collection: _internalCollection }\n : useListState({\n children: children as any,\n items: items as any,\n selectionMode: 'none' as any,\n });\n\n // Collect original option keys to avoid duplicating them as custom values.\n const originalKeys = useMemo(() => {\n const keys = new Set<string>();\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n keys.add(String(item.key));\n }\n }\n return keys;\n }, [localCollectionState.collection]);\n\n // State to keep track of custom (user-entered) items that were selected.\n const [customKeys, setCustomKeys] = useState<Set<string>>(new Set());\n\n // Controlled/uncontrolled search value pattern\n const [internalSearchValue, setInternalSearchValue] = useState('');\n const isSearchControlled = controlledSearchValue !== undefined;\n const searchValue = isSearchControlled\n ? controlledSearchValue\n : internalSearchValue;\n\n const { contains } = useFilter({ sensitivity: 'base' });\n\n // Initialize custom keys from current selection\n useEffect(() => {\n if (!allowsCustomValue) return;\n\n const currentSelectedKeys = selectedKeys\n ? selectedKeys === 'all'\n ? [] // Skip custom key detection when 'all' is selected\n : Array.from(selectedKeys).map(String)\n : selectedKey != null\n ? [String(selectedKey)]\n : [];\n\n if (currentSelectedKeys.length === 0) return;\n\n const keysToAdd = currentSelectedKeys.filter((k) => !originalKeys.has(k));\n\n if (keysToAdd.length) {\n setCustomKeys((prev) => new Set([...Array.from(prev), ...keysToAdd]));\n }\n }, [allowsCustomValue, selectedKeys, selectedKey, originalKeys]);\n\n // Merge original children with any custom items so they persist in the list.\n // If there are selected custom values, they should appear on top with other\n // selected items (which are already sorted by the parent component, e.g. FilterPicker).\n const mergedChildren: ReactNode = useMemo(() => {\n if (!children && customKeys.size === 0) return children;\n\n // Selected custom values are injected by FilterListBox itself, not by the\n // parent. They must respect the search input regardless of the `filter`\n // prop — `filter={false}` only describes the parent's authority over its\n // own items. Filter them with the user-provided filter (if any) or the\n // default `contains`.\n const term = searchValue.trim();\n const localFilter: FilterFn =\n typeof filter === 'function' ? filter : contains;\n\n // Build React elements for custom values (kept stable via their key).\n const customArray = Array.from(customKeys)\n .filter((key) => !term || localFilter(key, term))\n .map((key) => (\n <Item key={key} textValue={key} {...customValueProps}>\n {key}\n </Item>\n ));\n\n // Identify which custom keys are currently selected so we can promote them.\n const selectedKeysSet = new Set<string>();\n\n if (selectionMode === 'multiple') {\n if (selectedKeys === 'all') {\n // When 'all' is selected, no custom items should be treated as selected\n // since 'all' means all available items, not custom ones\n } else {\n Array.from(selectedKeys ?? []).forEach((k) =>\n selectedKeysSet.add(String(k)),\n );\n }\n } else {\n if (selectedKey != null) selectedKeysSet.add(String(selectedKey));\n }\n\n const selectedCustom: ReactNode[] = [];\n const unselectedCustom: ReactNode[] = [];\n\n customArray.forEach((item: any) => {\n if (selectedKeysSet.has(String(item.key))) {\n selectedCustom.push(item);\n } else {\n unselectedCustom.push(item);\n }\n });\n\n if (!children) {\n // No original items – just return selected custom followed by the rest.\n return [...selectedCustom, ...unselectedCustom];\n }\n\n const originalArray = Array.isArray(children) ? children : [children];\n\n // Final order: selected custom items -> original array (already possibly\n // sorted by parent) -> unselected custom items.\n return [...selectedCustom, ...originalArray, ...unselectedCustom];\n }, [\n children,\n customKeys,\n selectionMode,\n selectedKey,\n selectedKeys,\n searchValue,\n filter,\n contains,\n customValueProps,\n ]);\n\n // Determine an aria-label for the internal ListBox to avoid React Aria warnings.\n const innerAriaLabel =\n (props as any)['aria-label'] ||\n (typeof label === 'string' ? label : undefined);\n\n const handleSearchChange = useCallback(\n (value: string) => {\n if (!isSearchControlled) {\n setInternalSearchValue(value);\n }\n onSearchChange?.(value);\n },\n [isSearchControlled, onSearchChange],\n );\n\n // Choose the text filter function: user-provided `filter` prop (if any),\n // or the default `contains` helper from `useFilter`.\n // When `filter={false}`, the parent owns filtering — we normally pass items\n // through unchanged. The exception is when `isLoadingItems` is `true`: a\n // server fetch is in flight and currently visible items are stale, so we\n // fall back to client-side `contains` to hide non-matching stale items\n // until the new items arrive.\n const textFilterFn = useMemo<FilterFn>(() => {\n if (filter === false) {\n return isLoadingItems ? contains : () => true;\n }\n return filter || contains;\n }, [filter, contains, isLoadingItems]);\n\n // Create a filter function for collection nodes (similar to ComboBox pattern)\n const filterFn = useCallback(\n (nodes: Iterable<any>) => {\n // Server-side filtering with no fetch in flight — items are\n // authoritative and shown as-is.\n if (filter === false && !isLoadingItems) return nodes;\n\n const term = searchValue.trim();\n\n if (!term) {\n return nodes;\n }\n\n // Filter nodes based on their textValue and preserve section structure\n return [...nodes]\n .map((node: any) => {\n if (node.type === 'section' && node.childNodes) {\n const filteredNodes = [...node.childNodes].filter((child: any) =>\n textFilterFn(child.textValue || '', term),\n );\n\n if (filteredNodes.length === 0) {\n return null;\n }\n\n return {\n ...node,\n childNodes: filteredNodes,\n hasChildNodes: true,\n };\n }\n\n return textFilterFn(node.textValue || '', term) ? node : null;\n })\n .filter(Boolean);\n },\n [filter, searchValue, textFilterFn, isLoadingItems],\n );\n\n // Handle custom values if allowed\n const enhancedChildren = useMemo(() => {\n let childrenToProcess = mergedChildren;\n\n // Handle custom values if allowed\n if (!allowsCustomValue) return childrenToProcess;\n\n const term = searchValue.trim();\n if (!term) return childrenToProcess;\n\n // Helper to determine if the term is already present (exact match on rendered textValue or the key).\n const doesTermExist = (term: string): boolean => {\n // Check if term exists in custom keys\n if (customKeys.has(term)) {\n return true;\n }\n\n // Check if term exists in original collection\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n const textValue = item.textValue || String(item.rendered || '');\n if (term === textValue || String(item.key) === term) {\n return true;\n }\n }\n }\n return false;\n };\n\n if (doesTermExist(term)) {\n return childrenToProcess;\n }\n\n // Check if there are any items that will match the filter.\n // This determines whether we need to visually separate the custom value\n // from real items (i.e. render a divider between sections). When there\n // are no visible items, we skip the section wrapper so no divider is\n // drawn above a lone custom-value option.\n //\n // Selected custom values (from `customKeys`) are filtered by `localFilter`\n // in `mergedChildren` regardless of `filter={false}`, so this check must\n // use the same logic — otherwise we'd report \"items visible\" and draw a\n // divider while the actual collection only contains the custom value.\n const localFilter: FilterFn =\n typeof filter === 'function' ? filter : contains;\n\n const hasVisibleFilteredItems = (() => {\n for (const item of localCollectionState.collection) {\n if (item.type === 'item') {\n const textValue = item.textValue || String(item.rendered || '');\n if (textFilterFn(textValue, term)) {\n return true;\n }\n } else if (item.type === 'section' && item.childNodes) {\n for (const child of item.childNodes) {\n const textValue = child.textValue || String(child.rendered || '');\n if (textFilterFn(textValue, term)) {\n return true;\n }\n }\n }\n }\n\n for (const customKey of customKeys) {\n if (localFilter(customKey, term)) {\n return true;\n }\n }\n\n return false;\n })();\n\n // Create the custom option\n const customOption = (\n <Item\n key={term}\n textValue={term}\n {...mergeProps(customValueProps, newCustomValueProps)}\n >\n {term}\n </Item>\n );\n\n // If there are visible filtered items, add visual separation for custom value\n if (hasVisibleFilteredItems && childrenToProcess) {\n // Check if the collection contains any sections\n // If it does, we can't wrap childrenToProcess in another section (would create nested sections)\n const hasSections = [...localCollectionState.collection].some(\n (item) => item.type === 'section',\n );\n\n const customValueSection = (\n <BaseSection key=\"__custom_value__\" aria-label=\"Custom value\">\n {customOption}\n </BaseSection>\n );\n\n if (hasSections) {\n // Collection has sections - just append the custom value section without wrapping\n if (Array.isArray(childrenToProcess)) {\n return [...childrenToProcess, customValueSection];\n }\n return [childrenToProcess, customValueSection];\n }\n\n // No sections in collection - wrap items in a section for visual separation\n const filteredItemsSection = (\n <BaseSection key=\"__filtered_items__\" aria-label=\"Filtered items\">\n {childrenToProcess}\n </BaseSection>\n );\n\n return [filteredItemsSection, customValueSection];\n }\n\n // No visible filtered items, just return the custom option without sections\n if (Array.isArray(childrenToProcess)) {\n return [...childrenToProcess, customOption];\n }\n\n if (childrenToProcess) {\n return [childrenToProcess, customOption];\n }\n\n return customOption;\n }, [\n allowsCustomValue,\n mergedChildren,\n searchValue,\n customKeys,\n localCollectionState.collection,\n customValueProps,\n newCustomValueProps,\n textFilterFn,\n filter,\n contains,\n ]);\n\n styles = extractStyles(otherProps, PROP_STYLES, styles);\n\n ref = useCombinedRefs(ref);\n searchInputRef = useCombinedRefs(searchInputRef);\n listRef = useCombinedRefs(listRef);\n\n const { isFocused, focusProps } = useFocus({ isDisabled });\n const isInvalid = validationState === 'invalid';\n\n const listBoxRef = useRef<HTMLDivElement>(null);\n\n // Ref to access internal ListBox state (selection manager, etc.)\n const listStateRef = useRef<any>(null);\n\n // No separate focusedKey state needed; rely directly on selectionManager.focusedKey.\n\n // When the search value changes, the visible collection of items may change as well.\n // If the currently focused item is no longer visible, move virtual focus to the first\n // available item so that arrow navigation and Enter behaviour continue to work.\n // If there are no available items, reset the selection so Enter won't select anything.\n // Priority: focus on selected items first, then fall back to first visible item.\n useLayoutEffect(() => {\n const listState = listStateRef.current;\n\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Walk the collection and:\n // 1. Collect visible item keys (supports sections).\n // 2. Detect the synthetic \"new custom value\" option — the one generated\n // from the current search term when `allowsCustomValue` is true.\n //\n // The custom value is rendered in one of two layouts depending on whether\n // any real item text-matches the search term (`hasVisibleFilteredItems`\n // in `enhancedChildren`):\n // • Some items match → wrapped in a `__custom_value__` section\n // (`customValueHasMatches = true`)\n // • No items match → appended at the top level with key === term\n // (`customValueHasMatches = false`)\n //\n // The layout itself is the signal we use to decide whether the custom\n // value should be the focus target (no matches) or whether focus should\n // move to a real item (matches present).\n const term = searchValue.trim();\n let newCustomValueKey: Key | null = null;\n let customValueHasMatches = false;\n\n const collectVisibleKeys = (\n nodes: Iterable<any>,\n out: Key[],\n inCustomSection = false,\n ) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n if (inCustomSection) {\n newCustomValueKey = node.key;\n customValueHasMatches = true;\n }\n } else if (node.childNodes) {\n const isCustomSection =\n inCustomSection || node.key === '__custom_value__';\n collectVisibleKeys(node.childNodes, out, isCustomSection);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n // Detect the appended-at-top-level case (no items text-match). The custom\n // option is added with key === trimmed search term and lives directly in\n // the top-level collection (not nested in any section).\n if (newCustomValueKey == null && allowsCustomValue && term) {\n for (const node of collection) {\n if (node.type === 'item' && String(node.key) === term) {\n newCustomValueKey = node.key;\n customValueHasMatches = false;\n break;\n }\n }\n }\n\n // If there are no visible items, reset the focused key so Enter won't select anything\n if (visibleKeys.length === 0) {\n selectionManager.setFocusedKey(null);\n return;\n }\n\n // The custom value should be the focus target when it exists and there\n // are no real text-matches — the user's typed value is then the only\n // actionable option. During an in-flight server fetch (`filter === false`\n // + `isLoadingItems`) `textFilterFn` falls back to client-side `contains`\n // so non-matching stale items are hidden, which keeps this signal honest.\n const customValueShouldBeFocused =\n newCustomValueKey != null && !customValueHasMatches;\n\n // Decide whether the current focus is already on the right thing. If yes,\n // don't disturb it. Otherwise fall through and re-pick a focus target.\n const currentFocused = selectionManager.focusedKey;\n if (currentFocused != null && visibleKeys.includes(currentFocused)) {\n const currentIsNewCustomValue =\n newCustomValueKey != null && currentFocused === newCustomValueKey;\n if (customValueShouldBeFocused) {\n if (currentIsNewCustomValue) return;\n } else if (newCustomValueKey != null) {\n // Custom value exists but isn't the priority (matches available) —\n // any non-custom focus is fine.\n if (!currentIsNewCustomValue) return;\n } else {\n // No custom value involved at all.\n return;\n }\n }\n\n // Helper to find the first selected item that's visible\n const findFirstVisibleSelectedKey = (): Key | null => {\n if (selectionMode === 'single') {\n // Single selection: check if selectedKey is visible\n if (selectedKey != null) {\n const selectedKeyStr = String(selectedKey);\n if (visibleKeys.some((k) => String(k) === selectedKeyStr)) {\n return selectedKey;\n }\n }\n } else if (selectionMode === 'multiple') {\n // Multiple selection: find first selected key that's visible\n if (selectedKeys && selectedKeys !== 'all') {\n for (const key of selectedKeys) {\n const keyStr = String(key);\n if (visibleKeys.some((k) => String(k) === keyStr)) {\n return key;\n }\n }\n }\n }\n return null;\n };\n\n // Determine which key to focus\n let keyToFocus: Key | null = null;\n\n if (customValueShouldBeFocused) {\n // No real matches — promote the custom value over any selected/stale\n // item so the user can press Enter to add the value they just typed.\n keyToFocus = newCustomValueKey;\n } else {\n keyToFocus = findFirstVisibleSelectedKey();\n\n // Fallback to first visible item if no selected item found. Prefer the\n // first real (non-custom-value) item so focus doesn't land on the\n // bottom-of-list custom-value suggestion when real items are available.\n if (keyToFocus == null) {\n const firstRealKey = visibleKeys.find((k) => k !== newCustomValueKey);\n keyToFocus = firstRealKey ?? visibleKeys[0];\n }\n }\n\n // Mark this focus change as keyboard navigation so ListBox will scroll to it\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n\n // Set focus to the determined key\n selectionManager.setFocusedKey(keyToFocus);\n }, [\n searchValue,\n enhancedChildren,\n selectionMode,\n selectedKey,\n selectedKeys,\n allowsCustomValue,\n ]);\n\n // Keyboard navigation handler for search input\n const { keyboardProps } = useKeyboard({\n onKeyDown: (e) => {\n if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {\n e.preventDefault();\n\n const listState = listStateRef.current;\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Helper to collect visible item keys (supports sections)\n // Collection is already filtered by React Stately via filterFn\n const collectVisibleKeys = (nodes: Iterable<any>, out: Key[]) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n } else if (node.childNodes) {\n collectVisibleKeys(node.childNodes, out);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n if (visibleKeys.length === 0) return;\n\n const isArrowDown = e.key === 'ArrowDown';\n const direction = isArrowDown ? 1 : -1;\n\n const currentKey = selectionManager.focusedKey;\n\n let nextKey: Key | null = null;\n\n if (currentKey == null) {\n // If nothing focused yet, pick first/last depending on direction\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n } else {\n const currentIndex = visibleKeys.indexOf(currentKey);\n if (currentIndex !== -1) {\n const newIndex = currentIndex + direction;\n if (newIndex >= 0 && newIndex < visibleKeys.length) {\n nextKey = visibleKeys[newIndex];\n } else if (shouldFocusWrap) {\n // Wrap around\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n }\n } else {\n // Fallback\n nextKey = isArrowDown\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n }\n }\n\n if (nextKey != null) {\n // Mark this focus change as keyboard navigation\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n selectionManager.setFocusedKey(nextKey);\n }\n } else if (\n e.key === 'Home' ||\n e.key === 'End' ||\n e.key === 'PageUp' ||\n e.key === 'PageDown'\n ) {\n e.preventDefault();\n\n const listState = listStateRef.current;\n if (!listState) return;\n\n const { selectionManager, collection } = listState;\n\n // Helper to collect visible item keys (supports sections)\n // Collection is already filtered by React Stately via filterFn\n const collectVisibleKeys = (nodes: Iterable<any>, out: Key[]) => {\n for (const node of nodes) {\n if (node.type === 'item') {\n out.push(node.key);\n } else if (node.childNodes) {\n collectVisibleKeys(node.childNodes, out);\n }\n }\n };\n\n const visibleKeys: Key[] = [];\n collectVisibleKeys(collection, visibleKeys);\n\n if (visibleKeys.length === 0) return;\n\n const targetKey =\n e.key === 'Home' || e.key === 'PageUp'\n ? visibleKeys[0]\n : visibleKeys[visibleKeys.length - 1];\n\n // Mark this focus change as keyboard navigation\n if (listState.lastFocusSourceRef) {\n listState.lastFocusSourceRef.current = 'keyboard';\n }\n selectionManager.setFocusedKey(targetKey);\n } else if (e.key === 'Enter' || (e.key === ' ' && !searchValue)) {\n const listState = listStateRef.current;\n\n if (!listState) return;\n\n const keyToSelect = listState.selectionManager.focusedKey;\n\n if (keyToSelect != null) {\n e.preventDefault();\n listState.selectionManager.select(keyToSelect, e);\n\n if (\n e.key === 'Enter' &&\n isCheckable &&\n onEscape &&\n selectionMode === 'multiple'\n ) {\n onEscape();\n }\n }\n } else if (e.key === 'Escape') {\n if (searchValue) {\n // Clear the current search if any text is present.\n e.preventDefault();\n handleSearchChange('');\n } else {\n // Notify parent that Escape was pressed on an empty input.\n if (onEscape) {\n e.preventDefault();\n onEscape();\n }\n }\n }\n },\n });\n\n const mods = useMemo(\n () => ({\n invalid: isInvalid,\n valid: validationState === 'valid',\n disabled: !!isDisabled,\n focused: isFocused,\n loading: !!isLoading,\n 'loading-items': !!isLoadingItems,\n searchable: true,\n prefix: !!isLoading,\n suffix: !!isLoadingItems,\n ...externalMods,\n }),\n [\n isInvalid,\n validationState,\n isDisabled,\n isFocused,\n isLoading,\n isLoadingItems,\n externalMods,\n ],\n );\n\n // Handler must be defined before we render ListBox so we can pass it.\n const handleSelectionChange = (selection: any) => {\n if (allowsCustomValue) {\n // Normalize current selection into an array of string keys\n let selectedValues: string[] = [];\n\n if (selection != null) {\n if (Array.isArray(selection)) {\n selectedValues = selection.map(String);\n } else {\n selectedValues = [String(selection)];\n }\n }\n\n // Build next custom keys set based on selected values\n const nextSet = new Set<string>();\n\n selectedValues.forEach((val) => {\n if (!originalKeys.has(val)) {\n nextSet.add(val);\n }\n });\n\n // Update internal custom keys state\n setCustomKeys(nextSet);\n }\n\n if (externalOnSelectionChange) {\n (externalOnSelectionChange as any)(selection);\n }\n };\n\n // Custom option click handler that ensures search input receives focus\n const handleOptionClick = (key: Key) => {\n // Focus the search input to enable keyboard navigation\n // Use setTimeout to ensure this happens after React state updates\n setTimeout(() => {\n if (searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, 0);\n\n // Call the original onOptionClick if provided\n if (onOptionClick) {\n onOptionClick(key);\n }\n };\n\n const searchInput = (\n <SearchWrapperElement mods={mods} data-size={size}>\n {isLoading && (\n <div data-element=\"Prefix\">\n <div data-element=\"InputIcon\">\n {isLoading ? <LoadingIcon /> : null}\n </div>\n </div>\n )}\n <SearchInputElement\n ref={searchInputRef}\n qa={qa || 'FilterListBox'}\n id={id}\n data-prefix={isLoading ? '' : undefined}\n data-suffix={isLoadingItems ? '' : undefined}\n type=\"search\"\n placeholder={searchPlaceholder}\n value={searchValue}\n disabled={isDisabled}\n autoFocus={autoFocus}\n data-autofocus={autoFocus ? '' : undefined}\n styles={searchInputStyles}\n data-size={size}\n data-input-type=\"filterlistbox\"\n role=\"combobox\"\n aria-expanded=\"true\"\n aria-haspopup=\"listbox\"\n aria-activedescendant={\n listStateRef.current?.selectionManager.focusedKey != null\n ? `ListBoxItem-${listStateRef.current?.selectionManager.focusedKey}`\n : undefined\n }\n onChange={(e) => {\n handleSearchChange(e.target.value);\n }}\n {...keyboardProps}\n {...modAttrs(mods)}\n />\n {isLoadingItems && (\n <div data-element=\"Suffix\">\n <LoadingIcon data-element=\"InputIcon\" />\n </div>\n )}\n </SearchWrapperElement>\n );\n\n const filterListBoxField = (\n <FilterListBoxWrapperElement\n ref={ref}\n qa=\"FilterListBoxWrapper\"\n {...modAttrs(mods)}\n styles={styles}\n {...focusProps}\n >\n {header ? (\n <StyledHeaderWithoutBorder data-size={size} styles={headerStyles}>\n {header}\n </StyledHeaderWithoutBorder>\n ) : (\n <div role=\"presentation\" />\n )}\n {searchInput}\n <ListBox\n ref={listBoxRef}\n aria-label={innerAriaLabel}\n selectedKey={selectedKey}\n defaultSelectedKey={defaultSelectedKey}\n selectedKeys={selectedKeys}\n defaultSelectedKeys={defaultSelectedKeys}\n selectionMode={selectionMode}\n isDisabled={isDisabled}\n listRef={listRef}\n stateRef={listStateRef}\n listStyles={listStyles}\n shouldFocusWrap={shouldFocusWrap}\n optionStyles={optionStyles}\n sectionStyles={sectionStyles}\n headingStyles={headingStyles}\n validationState={validationState}\n disallowEmptySelection={props.disallowEmptySelection}\n disabledKeys={props.disabledKeys}\n focusOnHover={focusOnHover}\n shouldUseVirtualFocus={true}\n showSelectAll={showSelectAll}\n selectAllLabel={selectAllLabel}\n footer={footer}\n footerStyles={footerStyles}\n mods={mods}\n size=\"medium\"\n styles={listBoxStyles}\n isCheckable={isCheckable}\n items={items as any}\n allValueProps={allValueProps}\n filter={filterFn}\n emptyLabel={\n emptyLabel !== undefined\n ? emptyLabel\n : searchValue.trim()\n ? 'No results found'\n : 'No items'\n }\n onSelectionChange={handleSelectionChange}\n onEscape={onEscape}\n onOptionClick={handleOptionClick}\n >\n {enhancedChildren as any}\n </ListBox>\n </FilterListBoxWrapperElement>\n );\n\n return wrapWithField<Omit<CubeFilterListBoxProps<T>, 'children'>>(\n filterListBoxField,\n ref,\n props,\n );\n}) as unknown as (<T>(\n props: CubeFilterListBoxProps<T> & { ref?: ForwardedRef<HTMLDivElement> },\n) => ReactElement) & { Item: typeof Item; Section: typeof BaseSection };\n\nFilterListBox.Item = ListBox.Item;\n\nFilterListBox.Section = BaseSection;\n\nObject.defineProperty(FilterListBox, 'cubeInputType', {\n value: 'FilterListBox',\n enumerable: false,\n configurable: false,\n});\n"],"mappings":"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"}
@@ -63,6 +63,12 @@ interface CubeFilterPickerProps<T> extends Omit<CubeFilterListBoxProps<T>, 'size
63
63
  isClearable?: boolean;
64
64
  /** Callback called when the clear button is pressed */
65
65
  onClear?: () => void;
66
+ /**
67
+ * Whether items are currently loading. Shows a loading spinner in the search
68
+ * input suffix inside the popover. Unlike `isLoading`, this does NOT disable
69
+ * the trigger.
70
+ */
71
+ isLoadingItems?: boolean;
66
72
  /**
67
73
  * Sort selected items to the top when the popover opens.
68
74
  * Only works when using the `items` prop (data-driven mode).
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { useEventBus } from "../../../utils/react/useEventBus.js";
4
4
  import { useEvent } from "../../../_internal/hooks/use-event.js";
@@ -55,7 +55,7 @@ const FilterPicker = forwardRef(function FilterPicker(props, ref) {
55
55
  };
56
56
  return fieldProps;
57
57
  } });
58
- let { qa, label, extra, id, icon, rightIcon, prefix, suffix, hotkeys, triggerTooltip, triggerDescription, labelStyles, isRequired, necessityIndicator, validationState, isDisabled, isLoading, message, mods: externalMods, description, descriptionPlacement, placeholder, size = "medium", styles, listBoxStyles, popoverStyles, type = "outline", theme = "default", shape, labelSuffix, shouldFocusWrap, children, shouldFlip = true, containerPadding = 8, selectedKey, defaultSelectedKey, selectedKeys, defaultSelectedKeys, disabledKeys, onSelectionChange, selectionMode = "single", listStateRef, focusOnHover, showSelectAll, selectAllLabel = "All", items, header, footer, headerStyles, footerStyles, triggerStyles, allowsCustomValue, renderSummary, isCheckable, allValueProps, customValueProps, newCustomValueProps, searchPlaceholder, autoFocus, filter, emptyLabel, searchInputStyles, searchInputRef, listStyles, optionStyles, sectionStyles, headingStyles, listRef, disallowEmptySelection, shouldUseVirtualFocus, onEscape, onOptionClick, isClearable, searchValue, onSearchChange, sortSelectedToTop: sortSelectedToTopProp, onOpenChange, form, ...otherProps } = props;
58
+ let { qa, label, extra, id, icon, rightIcon, prefix, suffix, hotkeys, triggerTooltip, triggerDescription, labelStyles, isRequired, necessityIndicator, validationState, isDisabled, isLoading, message, mods: externalMods, description, descriptionPlacement, placeholder, size = "medium", styles, listBoxStyles, popoverStyles, type = "outline", theme = "default", shape, labelSuffix, shouldFocusWrap, children, shouldFlip = true, containerPadding = 8, selectedKey, defaultSelectedKey, selectedKeys, defaultSelectedKeys, disabledKeys, onSelectionChange, selectionMode = "single", listStateRef, focusOnHover, showSelectAll, selectAllLabel = "All", items, header, footer, headerStyles, footerStyles, triggerStyles, allowsCustomValue, renderSummary, isCheckable, allValueProps, customValueProps, newCustomValueProps, searchPlaceholder, autoFocus, filter, emptyLabel, searchInputStyles, searchInputRef, listStyles, optionStyles, sectionStyles, headingStyles, listRef, disallowEmptySelection, shouldUseVirtualFocus, onEscape, onOptionClick, isClearable, isLoadingItems, searchValue, onSearchChange, sortSelectedToTop: sortSelectedToTopProp, onOpenChange, form, ...otherProps } = props;
59
59
  const sortSelectedToTopExplicit = sortSelectedToTopProp !== void 0;
60
60
  const sortSelectedToTop = sortSelectedToTopProp ?? (items ? true : false);
61
61
  styles = extractStyles(otherProps, PROP_STYLES, styles);
@@ -408,6 +408,7 @@ const FilterPicker = forwardRef(function FilterPicker(props, ref) {
408
408
  validationState,
409
409
  isDisabled,
410
410
  isLoading,
411
+ isLoadingItems,
411
412
  stateRef: listStateRef,
412
413
  isCheckable,
413
414
  mods: { popover: true },
@@ -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 * 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
+ {"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 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 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 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.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { useEventBus } from "../../../utils/react/useEventBus.js";
4
4
  import { useEvent } from "../../../_internal/hooks/use-event.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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 { useFocus as useFocus$1 } from "../../../utils/react/interactions.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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 { useProviderProps } from "../../../provider.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { createContext, useContext } from "react";
3
3
 
4
4
  //#region src/components/fields/RadioGroup/context.ts
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.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";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { forwardRefWithGenerics } from "../../../utils/react/forwardRefWithGenerics.js";
4
4
  import { useLayoutEffect as useLayoutEffect$1 } from "../../../utils/react/useLayoutEffect.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { SliderGradationElement, SliderGradeElement } from "./elements.js";
3
3
  import { jsx } from "react/jsx-runtime";
4
4
 
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { __Slider } from "./Slider.js";
3
3
  import { forwardRef, useCallback, useMemo, useState } from "react";
4
4
  import { jsx } from "react/jsx-runtime";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { Gradation } from "./Gradation.js";
3
3
  import { _SliderBase } from "./SliderBase.js";
4
4
  import { SliderThumb } from "./SliderThumb.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { mergeProps } from "../../../utils/react/mergeProps.js";
4
4
  import { Gradation } from "./Gradation.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { extractStyles } from "../../../utils/styles.js";
3
3
  import { forwardRefWithGenerics } from "../../../utils/react/forwardRefWithGenerics.js";
4
4
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
@@ -1,4 +1,4 @@
1
- /** @license MIT | @cube-dev/ui-kit v0.127.3 | Cube Dev Team */
1
+ /** @license MIT | @cube-dev/ui-kit v0.128.0 | Cube Dev Team */
2
2
  import { mergeProps as mergeProps$1 } from "../../../utils/react/mergeProps.js";
3
3
  import { SliderThumbElement } from "./elements.js";
4
4
  import { useMemo, useRef } from "react";