@cube-dev/ui-kit 0.72.3 → 0.73.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (513) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/es/_internal/hooks/index.js +1 -1
  3. package/es/_internal/hooks/use-chained-callback.js +1 -1
  4. package/es/_internal/hooks/use-debounced-value.js +1 -1
  5. package/es/_internal/hooks/use-deprecation-warning.js +1 -1
  6. package/es/_internal/hooks/use-effect-once.js +1 -1
  7. package/es/_internal/hooks/use-event.js +1 -1
  8. package/es/_internal/hooks/use-is-first-render.js +1 -1
  9. package/es/_internal/hooks/use-sync-ref.js +1 -1
  10. package/es/_internal/hooks/use-timer/index.js +1 -1
  11. package/es/_internal/hooks/use-timer/timer.js +1 -1
  12. package/es/_internal/hooks/use-timer/use-timer.js +1 -1
  13. package/es/_internal/hooks/use-update-effect.js +1 -1
  14. package/es/_internal/hooks/use-warn.js +1 -1
  15. package/es/_internal/index.js +1 -1
  16. package/es/components/Block.js +1 -1
  17. package/es/components/GlobalStyles.js +1 -1
  18. package/es/components/GridProvider.js +1 -1
  19. package/es/components/HiddenInput.js +1 -1
  20. package/es/components/Item.js +12 -0
  21. package/es/components/OpenTrasition.js +1 -1
  22. package/es/components/Root.js +1 -1
  23. package/es/components/actions/Action/Action.js +1 -1
  24. package/es/components/actions/Button/Button.js +21 -435
  25. package/es/components/actions/Button/index.js +1 -1
  26. package/es/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  27. package/es/components/actions/CommandMenu/CommandMenu.js +3 -4
  28. package/es/components/actions/CommandMenu/index.js +1 -1
  29. package/es/components/actions/CommandMenu/styled.js +14 -8
  30. package/es/components/actions/ItemButton/ItemButton.js +29 -0
  31. package/es/components/actions/ItemButton/index.js +10 -0
  32. package/es/components/actions/Menu/Menu.js +19 -24
  33. package/es/components/actions/Menu/MenuItem.js +19 -60
  34. package/es/components/actions/Menu/MenuSection.js +2 -2
  35. package/es/components/actions/Menu/MenuTrigger.js +3 -3
  36. package/es/components/actions/Menu/SubMenuTrigger.js +1 -1
  37. package/es/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  38. package/es/components/actions/Menu/context.js +1 -1
  39. package/es/components/actions/Menu/index.js +1 -1
  40. package/es/components/actions/Menu/styled.js +27 -8
  41. package/es/components/actions/index.js +2 -1
  42. package/es/components/actions/use-action.js +1 -1
  43. package/es/components/actions/use-anchored-menu.js +14 -5
  44. package/es/components/actions/use-context-menu.js +2 -2
  45. package/es/components/content/ActiveZone/ActiveZone.js +1 -1
  46. package/es/components/content/Alert/Alert.js +1 -1
  47. package/es/components/content/Alert/index.js +1 -1
  48. package/es/components/content/Alert/types.js +1 -1
  49. package/es/components/content/Alert/use-alert.js +1 -1
  50. package/es/components/content/Avatar/Avatar.js +1 -1
  51. package/es/components/content/Badge/Badge.js +1 -1
  52. package/es/components/content/Card/Card.js +1 -1
  53. package/es/components/content/Content.js +1 -1
  54. package/es/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
  55. package/es/components/content/CopyPasteBlock/index.js +1 -1
  56. package/es/components/content/CopySnippet/CopySnippet.js +1 -1
  57. package/es/components/content/CopySnippet/index.js +1 -1
  58. package/es/components/content/Divider.js +1 -1
  59. package/es/components/content/Footer.js +1 -1
  60. package/es/components/content/Header.js +1 -1
  61. package/es/components/content/HotKeys/HotKeys.js +33 -4
  62. package/es/components/content/HotKeys/index.js +1 -1
  63. package/es/components/content/ItemBase/ItemBase.js +342 -0
  64. package/es/components/content/ItemBase/index.js +10 -0
  65. package/es/components/content/List/SectionHeading.js +23 -0
  66. package/es/components/content/List/index.js +10 -0
  67. package/es/components/content/Paragraph.js +1 -1
  68. package/es/components/content/Placeholder/Placeholder.js +1 -1
  69. package/es/components/content/PrismCode/PrismCode.js +1 -1
  70. package/es/components/content/PrismCode/prismSetup.js +1 -1
  71. package/es/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  72. package/es/components/content/Result/Result.js +1 -1
  73. package/es/components/content/Skeleton/Skeleton.js +1 -1
  74. package/es/components/content/Tag/Tag.js +1 -1
  75. package/es/components/content/Text.js +1 -1
  76. package/es/components/content/Title.js +1 -1
  77. package/es/components/fields/Checkbox/Checkbox.js +1 -1
  78. package/es/components/fields/Checkbox/CheckboxGroup.js +1 -1
  79. package/es/components/fields/Checkbox/context.js +1 -1
  80. package/es/components/fields/Checkbox/index.js +1 -1
  81. package/es/components/fields/ComboBox/ComboBox.js +4 -3
  82. package/es/components/fields/ComboBox/index.js +1 -1
  83. package/es/components/fields/DatePicker/DateInput.js +1 -1
  84. package/es/components/fields/DatePicker/DateInputBase.js +1 -1
  85. package/es/components/fields/DatePicker/DatePicker.js +1 -1
  86. package/es/components/fields/DatePicker/DatePickerButton.js +1 -1
  87. package/es/components/fields/DatePicker/DatePickerElement.js +1 -1
  88. package/es/components/fields/DatePicker/DatePickerInput.js +1 -1
  89. package/es/components/fields/DatePicker/DatePickerSegment.js +1 -1
  90. package/es/components/fields/DatePicker/DateRangePicker.js +1 -1
  91. package/es/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
  92. package/es/components/fields/DatePicker/TimeInput.js +1 -1
  93. package/es/components/fields/DatePicker/index.js +1 -1
  94. package/es/components/fields/DatePicker/intl.js +1 -1
  95. package/es/components/fields/DatePicker/parseDate.js +1 -1
  96. package/es/components/fields/DatePicker/props.js +1 -1
  97. package/es/components/fields/DatePicker/types.js +1 -1
  98. package/es/components/fields/DatePicker/utils.js +1 -1
  99. package/es/components/fields/FileInput/FileInput.js +1 -1
  100. package/es/components/fields/FilterListBox/FilterListBox.js +18 -8
  101. package/es/components/fields/FilterListBox/index.js +1 -1
  102. package/es/components/fields/FilterPicker/FilterPicker.js +39 -7
  103. package/es/components/fields/FilterPicker/index.js +1 -1
  104. package/es/components/fields/Input/Input.js +1 -1
  105. package/es/components/fields/Input/index.js +1 -1
  106. package/es/components/fields/ListBox/ListBox.js +130 -116
  107. package/es/components/fields/ListBox/index.js +1 -1
  108. package/es/components/fields/NumberInput/NumberInput.js +1 -1
  109. package/es/components/fields/NumberInput/StepButton.js +1 -1
  110. package/es/components/fields/PasswordInput/PasswordInput.js +1 -1
  111. package/es/components/fields/RadioGroup/Radio.js +1 -1
  112. package/es/components/fields/RadioGroup/RadioGroup.js +1 -1
  113. package/es/components/fields/RadioGroup/context.js +1 -1
  114. package/es/components/fields/RadioGroup/index.js +1 -1
  115. package/es/components/fields/SearchInput/SearchInput.js +1 -1
  116. package/es/components/fields/SearchInput/index.js +1 -1
  117. package/es/components/fields/Select/Select.js +36 -154
  118. package/es/components/fields/Select/index.js +1 -1
  119. package/es/components/fields/Slider/Gradation.js +1 -1
  120. package/es/components/fields/Slider/Header.js +1 -1
  121. package/es/components/fields/Slider/RangeSlider.js +1 -1
  122. package/es/components/fields/Slider/Slider.js +1 -1
  123. package/es/components/fields/Slider/SliderBase.js +1 -1
  124. package/es/components/fields/Slider/SliderInput.js +1 -1
  125. package/es/components/fields/Slider/SliderThumb.js +1 -1
  126. package/es/components/fields/Slider/SliderTrack.js +1 -1
  127. package/es/components/fields/Slider/elements.js +1 -1
  128. package/es/components/fields/Slider/index.js +1 -1
  129. package/es/components/fields/Slider/types.js +1 -1
  130. package/es/components/fields/Switch/Switch.js +1 -1
  131. package/es/components/fields/Switch/index.js +1 -1
  132. package/es/components/fields/TextArea/TextArea.js +1 -1
  133. package/es/components/fields/TextArea/index.js +1 -1
  134. package/es/components/fields/TextInput/TextInput.js +1 -1
  135. package/es/components/fields/TextInput/TextInputBase.js +1 -1
  136. package/es/components/fields/TextInput/index.js +1 -1
  137. package/es/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  138. package/es/components/fields/TextInputMapper/index.js +1 -1
  139. package/es/components/fields/index.js +1 -1
  140. package/es/components/form/FieldWrapper/FieldWrapper.js +1 -1
  141. package/es/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  142. package/es/components/form/FieldWrapper/index.js +1 -1
  143. package/es/components/form/FieldWrapper/types.js +1 -1
  144. package/es/components/form/Form/Field.js +1 -1
  145. package/es/components/form/Form/Form.js +1 -1
  146. package/es/components/form/Form/ResetButton/ResetButton.js +1 -1
  147. package/es/components/form/Form/ResetButton/index.js +1 -1
  148. package/es/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  149. package/es/components/form/Form/SubmitButton/index.js +1 -1
  150. package/es/components/form/Form/SubmitError.js +1 -1
  151. package/es/components/form/Form/index.js +1 -1
  152. package/es/components/form/Form/types.js +1 -1
  153. package/es/components/form/Form/use-field/index.js +1 -1
  154. package/es/components/form/Form/use-field/types.js +1 -1
  155. package/es/components/form/Form/use-field/use-field-props.js +1 -1
  156. package/es/components/form/Form/use-field/use-field.js +1 -1
  157. package/es/components/form/Form/use-form.js +1 -1
  158. package/es/components/form/Form/validation.js +1 -1
  159. package/es/components/form/Label.js +1 -1
  160. package/es/components/form/index.js +1 -1
  161. package/es/components/form/wrapper.js +1 -1
  162. package/es/components/layout/Flex.js +1 -1
  163. package/es/components/layout/Flow.js +1 -1
  164. package/es/components/layout/Grid.js +1 -1
  165. package/es/components/layout/Panel.js +1 -1
  166. package/es/components/layout/Prefix.js +1 -1
  167. package/es/components/layout/ResizablePanel.js +1 -1
  168. package/es/components/layout/Space.js +1 -1
  169. package/es/components/layout/Suffix.js +1 -1
  170. package/es/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
  171. package/es/components/navigation/Link/Link.js +1 -1
  172. package/es/components/organisms/FileTabs/FileTabs.js +1 -1
  173. package/es/components/organisms/Modal/Modal.js +1 -1
  174. package/es/components/organisms/StatsCard/StatsCard.js +1 -1
  175. package/es/components/other/Base64Upload/Base64Upload.js +1 -1
  176. package/es/components/other/Calendar/Calendar.js +1 -1
  177. package/es/components/other/Calendar/CalendarCell.js +1 -1
  178. package/es/components/other/Calendar/CalendarGrid.js +1 -1
  179. package/es/components/other/Calendar/RangeCalendar.js +1 -1
  180. package/es/components/other/CloudLogo/CloudLogo.js +1 -1
  181. package/es/components/overlays/AlertDialog/AlertDialog.js +1 -1
  182. package/es/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  183. package/es/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  184. package/es/components/overlays/AlertDialog/index.js +1 -1
  185. package/es/components/overlays/AlertDialog/types.js +1 -1
  186. package/es/components/overlays/Dialog/Dialog.js +1 -1
  187. package/es/components/overlays/Dialog/DialogContainer.js +1 -1
  188. package/es/components/overlays/Dialog/DialogForm.js +1 -1
  189. package/es/components/overlays/Dialog/DialogTrigger.js +1 -1
  190. package/es/components/overlays/Dialog/context.js +1 -1
  191. package/es/components/overlays/Dialog/index.js +1 -1
  192. package/es/components/overlays/Dialog/use-dialog-container.js +1 -1
  193. package/es/components/overlays/Modal/Modal.js +1 -1
  194. package/es/components/overlays/Modal/OpenTransition.js +1 -1
  195. package/es/components/overlays/Modal/Overlay.js +1 -1
  196. package/es/components/overlays/Modal/Popover.js +1 -1
  197. package/es/components/overlays/Modal/Tray.js +1 -1
  198. package/es/components/overlays/Modal/Underlay.js +1 -1
  199. package/es/components/overlays/Modal/index.js +1 -1
  200. package/es/components/overlays/Modal/types.js +1 -1
  201. package/es/components/overlays/NewNotifications/Bar/FloatingNotification.js +1 -1
  202. package/es/components/overlays/NewNotifications/Bar/NotificationsBar.js +1 -1
  203. package/es/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  204. package/es/components/overlays/NewNotifications/Bar/index.js +1 -1
  205. package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +1 -1
  206. package/es/components/overlays/NewNotifications/Dialog/index.js +1 -1
  207. package/es/components/overlays/NewNotifications/Notification.js +1 -1
  208. package/es/components/overlays/NewNotifications/NotificationView/NotificationAction.js +1 -1
  209. package/es/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +1 -1
  210. package/es/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +1 -1
  211. package/es/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +1 -1
  212. package/es/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +1 -1
  213. package/es/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +1 -1
  214. package/es/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +1 -1
  215. package/es/components/overlays/NewNotifications/NotificationView/NotificationView.js +1 -1
  216. package/es/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  217. package/es/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  218. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsContext.js +1 -1
  219. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +1 -1
  220. package/es/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  221. package/es/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +1 -1
  222. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +1 -1
  223. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +1 -1
  224. package/es/components/overlays/NewNotifications/NotificationsList/index.js +1 -1
  225. package/es/components/overlays/NewNotifications/NotificationsList/types.js +1 -1
  226. package/es/components/overlays/NewNotifications/hooks/index.js +1 -1
  227. package/es/components/overlays/NewNotifications/hooks/types.js +1 -1
  228. package/es/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  229. package/es/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  230. package/es/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  231. package/es/components/overlays/NewNotifications/hooks/use-notifications-observer.js +1 -1
  232. package/es/components/overlays/NewNotifications/index.js +1 -1
  233. package/es/components/overlays/NewNotifications/types.js +1 -1
  234. package/es/components/overlays/Notification/Notification.js +1 -1
  235. package/es/components/overlays/OverlayWrapper.js +1 -1
  236. package/es/components/overlays/Toasts/Toast.js +1 -1
  237. package/es/components/overlays/Toasts/index.js +1 -1
  238. package/es/components/overlays/Toasts/types.js +1 -1
  239. package/es/components/overlays/Toasts/use-toasts-api.js +1 -1
  240. package/es/components/overlays/Tooltip/Tooltip.js +1 -1
  241. package/es/components/overlays/Tooltip/TooltipProvider.js +1 -1
  242. package/es/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  243. package/es/components/overlays/Tooltip/context.js +1 -1
  244. package/es/components/overlays/Tooltip/index.js +1 -1
  245. package/es/components/portal/Portal.js +1 -1
  246. package/es/components/portal/PortalProvider.js +1 -1
  247. package/es/components/portal/index.js +1 -1
  248. package/es/components/portal/types.js +1 -1
  249. package/es/components/portal/usePortal.js +1 -1
  250. package/es/components/shared/InvalidIcon.js +1 -1
  251. package/es/components/shared/ValidIcon.js +1 -1
  252. package/es/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  253. package/es/components/status/LoadingAnimation/index.js +1 -1
  254. package/es/components/status/Spin/Cube.js +1 -1
  255. package/es/components/status/Spin/InternalSpinner.js +1 -1
  256. package/es/components/status/Spin/Spin.js +1 -1
  257. package/es/components/status/Spin/SpinsContainer.js +1 -1
  258. package/es/components/status/Spin/index.js +1 -1
  259. package/es/components/status/Spin/types.js +1 -1
  260. package/es/components/status/index.js +1 -1
  261. package/es/data/item-themes.js +516 -0
  262. package/es/data/themes.js +2 -2
  263. package/es/icons/AdjustmentsHorizontalIcon.js +1 -1
  264. package/es/icons/AdjustmentsIcon.js +1 -1
  265. package/es/icons/AiIcon.js +1 -1
  266. package/es/icons/AreaChartIcon.js +1 -1
  267. package/es/icons/BackwardIcon.js +1 -1
  268. package/es/icons/BarChartIcon.js +1 -1
  269. package/es/icons/BellFilledIcon.js +1 -1
  270. package/es/icons/BellIcon.js +1 -1
  271. package/es/icons/BooleanIcon.js +1 -1
  272. package/es/icons/CalendarEditIcon.js +1 -1
  273. package/es/icons/CalendarIcon.js +1 -1
  274. package/es/icons/CaretDownIcon.js +1 -1
  275. package/es/icons/CaretUpIcon.js +1 -1
  276. package/es/icons/ChartAreaStackedIcon.js +1 -1
  277. package/es/icons/ChartAreaStackedPercentageIcon.js +1 -1
  278. package/es/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  279. package/es/icons/ChartBarGroupedIcon.js +1 -1
  280. package/es/icons/ChartBarHorizontalIcon.js +1 -1
  281. package/es/icons/ChartBarLineIcon.js +1 -1
  282. package/es/icons/ChartBarStackedHorizontalIcon.js +1 -1
  283. package/es/icons/ChartBarStackedIcon.js +1 -1
  284. package/es/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  285. package/es/icons/ChartBarStackedPercentageIcon.js +1 -1
  286. package/es/icons/ChartBoxPlot2Icon.js +1 -1
  287. package/es/icons/ChartBoxPlotIcon.js +1 -1
  288. package/es/icons/ChartBubbleIcon.js +1 -1
  289. package/es/icons/ChartDonut2Icon.js +1 -1
  290. package/es/icons/ChartFunnelIcon.js +1 -1
  291. package/es/icons/ChartKPIIcon.js +1 -1
  292. package/es/icons/ChartPie2Icon.js +1 -1
  293. package/es/icons/ChartScatterIcon.js +1 -1
  294. package/es/icons/CheckCircleFilledIcon.js +1 -1
  295. package/es/icons/CheckCircleIcon.js +1 -1
  296. package/es/icons/CheckIcon.js +1 -1
  297. package/es/icons/CircleFilledIcon.js +1 -1
  298. package/es/icons/ClearIcon.js +1 -1
  299. package/es/icons/CloseCircleFilledIcon.js +1 -1
  300. package/es/icons/CloseCircleIcon.js +1 -1
  301. package/es/icons/CloseIcon.js +1 -1
  302. package/es/icons/CodeIcon.js +1 -1
  303. package/es/icons/CopyIcon.js +1 -1
  304. package/es/icons/CountIcon.js +1 -1
  305. package/es/icons/CubeIcon.js +1 -1
  306. package/es/icons/DangerIcon.js +1 -1
  307. package/es/icons/DashboardIcon.js +1 -1
  308. package/es/icons/DatabaseIcon.js +1 -1
  309. package/es/icons/DirectionIcon.js +1 -1
  310. package/es/icons/DonutIcon.js +1 -1
  311. package/es/icons/DownIcon.js +1 -1
  312. package/es/icons/EditIcon.js +1 -1
  313. package/es/icons/ExclamationCircleFilledIcon.js +1 -1
  314. package/es/icons/ExclamationCircleIcon.js +1 -1
  315. package/es/icons/ExclamationIcon.js +1 -1
  316. package/es/icons/EyeIcon.js +1 -1
  317. package/es/icons/EyeInvisibleIcon.js +1 -1
  318. package/es/icons/FilterIcon.js +1 -1
  319. package/es/icons/FolderFilledIcon.js +1 -1
  320. package/es/icons/FolderIcon.js +1 -1
  321. package/es/icons/FolderOpenFilledIcon.js +1 -1
  322. package/es/icons/FolderOpenIcon.js +1 -1
  323. package/es/icons/ForwardIcon.js +1 -1
  324. package/es/icons/HierarchyIcon.js +1 -1
  325. package/es/icons/Icon.js +1 -1
  326. package/es/icons/InfoCircleIcon.js +1 -1
  327. package/es/icons/InfoIcon.js +1 -1
  328. package/es/icons/KeyIcon.js +1 -1
  329. package/es/icons/LeftIcon.js +1 -1
  330. package/es/icons/LineChartIcon.js +1 -1
  331. package/es/icons/LoadingIcon.js +1 -1
  332. package/es/icons/LockFilledIcon.js +1 -1
  333. package/es/icons/LockIcon.js +1 -1
  334. package/es/icons/MoreIcon.js +1 -1
  335. package/es/icons/NotAllowedIcon.js +1 -1
  336. package/es/icons/NumberIcon.js +1 -1
  337. package/es/icons/PauseCircleFilledIcon.js +1 -1
  338. package/es/icons/PauseCircleIcon.js +1 -1
  339. package/es/icons/PauseIcon.js +1 -1
  340. package/es/icons/PieChartIcon.js +1 -1
  341. package/es/icons/PlayCircleIcon.js +1 -1
  342. package/es/icons/PlayIcon.js +1 -1
  343. package/es/icons/PlusIcon.js +1 -1
  344. package/es/icons/ReloadIcon.js +1 -1
  345. package/es/icons/ReportIcon.js +1 -1
  346. package/es/icons/ReturnIcon.js +1 -1
  347. package/es/icons/RightIcon.js +1 -1
  348. package/es/icons/SchemeIcon.js +1 -1
  349. package/es/icons/SearchIcon.js +1 -1
  350. package/es/icons/SettingsIcon.js +1 -1
  351. package/es/icons/ShieldFilledIcon.js +1 -1
  352. package/es/icons/ShieldIcon.js +1 -1
  353. package/es/icons/SlashIcon.js +1 -1
  354. package/es/icons/SparklesIcon.js +1 -1
  355. package/es/icons/SqlIcon.js +1 -1
  356. package/es/icons/StatsIcon.js +1 -1
  357. package/es/icons/StopIcon.js +1 -1
  358. package/es/icons/StringIcon.js +1 -1
  359. package/es/icons/SwitchIcon.js +1 -1
  360. package/es/icons/TableIcon.js +1 -1
  361. package/es/icons/ThumbsDownIcon.js +1 -1
  362. package/es/icons/ThumbsUpIcon.js +1 -1
  363. package/es/icons/ThunderboltCrossedIcon.js +1 -1
  364. package/es/icons/ThunderboltFilledIcon.js +1 -1
  365. package/es/icons/ThunderboltIcon.js +1 -1
  366. package/es/icons/TimeIcon.js +1 -1
  367. package/es/icons/UnlockIcon.js +1 -1
  368. package/es/icons/UpIcon.js +1 -1
  369. package/es/icons/UserGroupIcon.js +1 -1
  370. package/es/icons/UserIcon.js +1 -1
  371. package/es/icons/UserLockIcon.js +1 -1
  372. package/es/icons/ViewIcon.js +1 -1
  373. package/es/icons/WarningFilledIcon.js +1 -1
  374. package/es/icons/WarningIcon.js +1 -1
  375. package/es/icons/add-new-icon.js +1 -1
  376. package/es/icons/index.js +1 -1
  377. package/es/icons/wrap-icon.js +1 -1
  378. package/es/index.js +4 -2
  379. package/es/provider.js +1 -1
  380. package/es/providers/TrackingProvider.js +1 -1
  381. package/es/services/notification.js +1 -1
  382. package/es/shared/form.js +1 -1
  383. package/es/shared/index.js +1 -1
  384. package/es/stories/Form.legacy-stories.js +1 -1
  385. package/es/stories/FormFieldArgs.js +1 -1
  386. package/es/stories/Layout.stories.js +1 -1
  387. package/es/stories/Tasty.stories.js +1 -1
  388. package/es/stories/components/ConfirmDeletionDialogForm.js +1 -1
  389. package/es/stories/components/DialogFormApp.js +1 -1
  390. package/es/stories/components/StyledButton.js +1 -1
  391. package/es/stories/lists/baseProps.js +1 -1
  392. package/es/tasty/index.js +1 -1
  393. package/es/tasty/parser/classify.js +1 -1
  394. package/es/tasty/parser/const.js +1 -1
  395. package/es/tasty/parser/lru.js +1 -1
  396. package/es/tasty/parser/parser.js +1 -1
  397. package/es/tasty/parser/tokenizer.js +1 -1
  398. package/es/tasty/parser/types.js +1 -1
  399. package/es/tasty/providers/BreakpointsProvider.js +1 -1
  400. package/es/tasty/styles/align.js +1 -1
  401. package/es/tasty/styles/border.js +1 -1
  402. package/es/tasty/styles/boxShadow.combinator.js +1 -1
  403. package/es/tasty/styles/color.js +1 -1
  404. package/es/tasty/styles/createStyle.js +1 -1
  405. package/es/tasty/styles/dimension.js +1 -1
  406. package/es/tasty/styles/display.js +1 -1
  407. package/es/tasty/styles/fade.js +1 -1
  408. package/es/tasty/styles/fill.js +1 -1
  409. package/es/tasty/styles/flow.js +1 -1
  410. package/es/tasty/styles/font.js +1 -1
  411. package/es/tasty/styles/fontStyle.js +1 -1
  412. package/es/tasty/styles/gap.js +1 -1
  413. package/es/tasty/styles/groupRadius.js +1 -1
  414. package/es/tasty/styles/height.js +1 -1
  415. package/es/tasty/styles/index.js +1 -1
  416. package/es/tasty/styles/inset.js +1 -1
  417. package/es/tasty/styles/justify.js +1 -1
  418. package/es/tasty/styles/list.js +1 -1
  419. package/es/tasty/styles/margin.js +1 -1
  420. package/es/tasty/styles/marginBlock.js +1 -1
  421. package/es/tasty/styles/marginInline.js +1 -1
  422. package/es/tasty/styles/outline.js +1 -1
  423. package/es/tasty/styles/padding.js +1 -1
  424. package/es/tasty/styles/paddingBlock.js +1 -1
  425. package/es/tasty/styles/paddingInline.js +1 -1
  426. package/es/tasty/styles/place.js +1 -1
  427. package/es/tasty/styles/predefined.js +1 -1
  428. package/es/tasty/styles/preset.js +1 -1
  429. package/es/tasty/styles/radius.js +1 -1
  430. package/es/tasty/styles/reset.js +1 -1
  431. package/es/tasty/styles/scrollbar.js +1 -1
  432. package/es/tasty/styles/shadow.js +1 -1
  433. package/es/tasty/styles/styledScrollbar.js +1 -1
  434. package/es/tasty/styles/transition.js +1 -1
  435. package/es/tasty/styles/types.js +1 -1
  436. package/es/tasty/styles/width.js +1 -1
  437. package/es/tasty/tasty.js +1 -1
  438. package/es/tasty/types.js +1 -1
  439. package/es/tasty/utils/cache-wrapper.js +1 -1
  440. package/es/tasty/utils/case-converter.js +1 -1
  441. package/es/tasty/utils/colors.js +1 -1
  442. package/es/tasty/utils/dotize.js +1 -1
  443. package/es/tasty/utils/filterBaseProps.js +1 -1
  444. package/es/tasty/utils/getDisplayName.js +1 -1
  445. package/es/tasty/utils/getModCombinations.js +1 -1
  446. package/es/tasty/utils/mergeStyles.js +1 -1
  447. package/es/tasty/utils/modAttrs.js +1 -1
  448. package/es/tasty/utils/renderStyles.js +1 -1
  449. package/es/tasty/utils/responsive.js +1 -1
  450. package/es/tasty/utils/string.js +1 -1
  451. package/es/tasty/utils/styles.js +1 -1
  452. package/es/tasty/utils/warnings.js +1 -1
  453. package/es/tokens.js +1 -1
  454. package/es/type-checks.js +1 -1
  455. package/es/utils/ResizeSensor.js +1 -1
  456. package/es/utils/modules.js +1 -1
  457. package/es/utils/promise.js +1 -1
  458. package/es/utils/random.js +1 -1
  459. package/es/utils/range.js +1 -1
  460. package/es/utils/react/Slots.js +1 -1
  461. package/es/utils/react/chain.js +1 -1
  462. package/es/utils/react/index.js +1 -1
  463. package/es/utils/react/interactions.js +1 -1
  464. package/es/utils/react/isTextOnly.js +1 -1
  465. package/es/utils/react/mapProps.js +1 -1
  466. package/es/utils/react/mergeProps.js +1 -1
  467. package/es/utils/react/nullableValue.js +1 -1
  468. package/es/utils/react/sharedStore.js +1 -1
  469. package/es/utils/react/useCombinedRefs.js +1 -1
  470. package/es/utils/react/useControlledFocusVisible.js +1 -1
  471. package/es/utils/react/useEventBus.js +1 -1
  472. package/es/utils/react/useId.js +1 -1
  473. package/es/utils/react/useIsDarwin.js +1 -1
  474. package/es/utils/react/useKeySymbols.js +1 -1
  475. package/es/utils/react/useLayoutEffect.js +1 -1
  476. package/es/utils/react/useQaProps.js +1 -1
  477. package/es/utils/react/useViewportSize.js +1 -1
  478. package/es/utils/react/wrapNodeIfPlain.js +1 -1
  479. package/es/utils/transitions.js +1 -1
  480. package/es/utils/tree.js +1 -1
  481. package/es/utils/warnings.js +1 -6
  482. package/es/version.js +2 -2
  483. package/package.json +1 -1
  484. package/types/components/Item.d.ts +18 -0
  485. package/types/components/actions/Button/Button.d.ts +0 -25
  486. package/types/components/actions/ItemButton/ItemButton.d.ts +6 -0
  487. package/types/components/actions/ItemButton/index.d.ts +1 -0
  488. package/types/components/actions/Menu/Menu.d.ts +3 -24
  489. package/types/components/actions/Menu/MenuItem.d.ts +0 -1
  490. package/types/components/actions/index.d.ts +1 -0
  491. package/types/components/actions/use-anchored-menu.d.ts +3 -2
  492. package/types/components/content/HotKeys/HotKeys.d.ts +1 -0
  493. package/types/components/content/ItemBase/ItemBase.d.ts +45 -0
  494. package/types/components/content/ItemBase/index.d.ts +1 -0
  495. package/types/components/content/List/SectionHeading.d.ts +432 -0
  496. package/types/components/content/List/index.d.ts +1 -0
  497. package/types/components/fields/ComboBox/ComboBox.d.ts +2 -1
  498. package/types/components/fields/FilterListBox/FilterListBox.d.ts +10 -0
  499. package/types/components/fields/FilterPicker/FilterPicker.d.ts +8 -8
  500. package/types/components/fields/ListBox/ListBox.d.ts +7 -2
  501. package/types/components/fields/Select/Select.d.ts +20 -6
  502. package/types/data/item-themes.d.ts +31 -0
  503. package/types/data/themes.d.ts +1 -1
  504. package/types/index.d.ts +4 -1
  505. package/types/utils/warnings.d.ts +0 -1
  506. package/es/components/portal/storybook/templates/CustomRoot.js +0 -16
  507. package/es/components/portal/storybook/templates/PortalOrder.js +0 -13
  508. package/es/components/portal/storybook/templates/basic.js +0 -13
  509. package/es/components/portal/storybook/templates/index.js +0 -12
  510. package/types/components/portal/storybook/templates/CustomRoot.d.ts +0 -3
  511. package/types/components/portal/storybook/templates/PortalOrder.d.ts +0 -3
  512. package/types/components/portal/storybook/templates/basic.d.ts +0 -3
  513. package/types/components/portal/storybook/templates/index.d.ts +0 -3
@@ -1,17 +1,17 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
8
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
8
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  import { useHover } from '@react-aria/interactions';
10
10
  import { IconMinus } from '@tabler/icons-react';
11
11
  import { useVirtualizer } from '@tanstack/react-virtual';
12
12
  import { forwardRef, useEffect, useMemo, useRef, useState, } from 'react';
13
13
  import { useKeyboard, useListBox, useListBoxSection, useOption, } from 'react-aria';
14
- import { Section as BaseSection, Item, useListState } from 'react-stately';
14
+ import { Section as BaseSection, useListState } from 'react-stately';
15
15
  import { useWarn } from '../../../_internal/hooks/use-warn';
16
16
  import { CheckIcon } from '../../../icons';
17
17
  import { Icon } from '../../../icons/index';
@@ -22,7 +22,9 @@ import { mergeProps, useCombinedRefs } from '../../../utils/react';
22
22
  import { useFocus } from '../../../utils/react/interactions';
23
23
  // Import Menu styled components for header and footer
24
24
  import { StyledDivider, StyledFooter, StyledHeader, StyledSectionHeading, } from '../../actions/Menu/styled';
25
+ import { ItemBase } from '../../content/ItemBase/ItemBase';
25
26
  import { useFieldProps, useFormProps, wrapWithField } from '../../form';
27
+ import { Item } from '../../Item';
26
28
  const ListBoxWrapperElement = tasty({
27
29
  qa: 'ListBox',
28
30
  styles: {
@@ -75,111 +77,15 @@ const ListBoxScrollElement = tasty({
75
77
  scrollbar: 'styled',
76
78
  },
77
79
  });
78
- const OptionElement = tasty({
80
+ // Create an extended ItemBase for ListBox options with 'all' modifier support
81
+ const ListBoxItemBase = tasty(ItemBase, {
79
82
  as: 'li',
80
83
  styles: {
81
- display: 'flex',
82
- flow: 'row',
83
- placeItems: 'center start',
84
- gap: '.75x',
85
- padding: '.5x 1x',
86
84
  margin: {
87
85
  '': '0 0 1bw 0',
88
86
  ':last-of-type': '0',
89
87
  all: '.5x',
90
88
  },
91
- height: {
92
- '': 'min $size-md',
93
- '[data-size="large"]': 'min $size-lg',
94
- },
95
- boxSizing: 'border-box',
96
- radius: '1r',
97
- cursor: {
98
- '': 'default',
99
- disabled: 'not-allowed',
100
- },
101
- transition: 'theme',
102
- border: 0,
103
- userSelect: 'none',
104
- color: {
105
- '': '#dark-02',
106
- 'selected | pressed': '#dark',
107
- disabled: '#dark-04',
108
- valid: '#success-text',
109
- invalid: '#danger-text',
110
- },
111
- fill: {
112
- '': '#clear',
113
- 'hovered | focused': '#dark.03',
114
- selected: '#dark.09',
115
- 'selected & (hovered | focused)': '#dark.12',
116
- 'selected & hovered & focused': '#dark.15',
117
- pressed: '#dark.09',
118
- valid: '#success-bg',
119
- invalid: '#danger-bg',
120
- disabled: '#clear',
121
- },
122
- outline: 0,
123
- backgroundClip: 'padding-box',
124
- CheckboxWrapper: {
125
- cursor: 'pointer',
126
- padding: '.75x',
127
- margin: '-.75x',
128
- },
129
- Checkbox: {
130
- display: 'grid',
131
- placeItems: 'center',
132
- radius: '.5r',
133
- width: '(2x - 2bw)',
134
- height: '(2x - 2bw)',
135
- flexShrink: 0,
136
- transition: 'theme',
137
- opacity: {
138
- '': 0,
139
- 'selected | indeterminate | :hover | focused': 1,
140
- },
141
- fill: {
142
- '': '#white',
143
- 'selected | indeterminate': '#purple-text',
144
- 'invalid & !(selected | indeterminate)': '#white',
145
- 'invalid & (selected | indeterminate)': '#danger',
146
- disabled: '#dark.12',
147
- },
148
- color: {
149
- '': '#white',
150
- 'disabled & !selected': '#clear',
151
- },
152
- border: {
153
- '': '#dark.30',
154
- invalid: '#danger',
155
- 'disabled | ((selected | indeterminate) & !invalid)': '#clear',
156
- },
157
- },
158
- Content: {
159
- display: 'flex',
160
- flow: 'column',
161
- gap: '.25x',
162
- flex: 1,
163
- width: 'max 100%',
164
- },
165
- Label: {
166
- preset: 't3',
167
- color: 'inherit',
168
- overflow: 'hidden',
169
- textOverflow: 'ellipsis',
170
- whiteSpace: 'nowrap',
171
- width: 'max 100%',
172
- },
173
- Description: {
174
- preset: 't4',
175
- color: {
176
- '': '#dark-03',
177
- },
178
- overflow: 'hidden',
179
- textOverflow: 'ellipsis',
180
- whiteSpace: 'nowrap',
181
- width: 'max 100%',
182
- },
183
89
  },
184
90
  });
185
91
  const SectionWrapperElement = tasty({
@@ -204,11 +110,78 @@ const SectionListElement = tasty({
204
110
  listStyle: 'none',
205
111
  },
206
112
  });
113
+ // Checkbox component for multiple selection options
114
+ const ListBoxCheckbox = tasty({
115
+ as: 'div',
116
+ styles: {
117
+ display: 'grid',
118
+ placeItems: 'center',
119
+ radius: '.5r',
120
+ width: '(2x - 2bw)',
121
+ height: '(2x - 2bw)',
122
+ flexShrink: 0,
123
+ transition: 'theme',
124
+ opacity: {
125
+ '': 0,
126
+ 'selected | indeterminate | :hover | focused': 1,
127
+ },
128
+ fill: {
129
+ '': '#white',
130
+ 'selected | indeterminate': '#purple-text',
131
+ 'invalid & !(selected | indeterminate)': '#white',
132
+ 'invalid & (selected | indeterminate)': '#danger',
133
+ disabled: '#dark.12',
134
+ },
135
+ color: {
136
+ '': '#white',
137
+ 'disabled & !selected': '#clear',
138
+ },
139
+ border: {
140
+ '': '#dark.30',
141
+ invalid: '#danger',
142
+ 'disabled | ((selected | indeterminate) & !invalid)': '#clear',
143
+ },
144
+ },
145
+ });
146
+ const ListBoxCheckboxWrapper = tasty({
147
+ as: 'div',
148
+ styles: {
149
+ display: 'grid',
150
+ placeItems: 'center',
151
+ placeContent: 'center',
152
+ cursor: 'pointer',
153
+ placeSelf: 'stretch',
154
+ },
155
+ });
207
156
  const PROP_STYLES = [...BASE_STYLES, ...OUTER_STYLES, ...COLOR_STYLES];
208
- const SelectAllOption = ({ label = 'Select All', isSelected, isIndeterminate, isDisabled, isCheckable, size = 'medium', state, lastFocusSourceRef, onClick, }) => {
157
+ const SelectAllOption = ({ label = 'Select All', isSelected, isIndeterminate, isDisabled, isCheckable, size = 'medium', state, lastFocusSourceRef, onClick, allValueProps = {}, }) => {
209
158
  const { hoverProps, isHovered } = useHover({ isDisabled });
210
159
  const markIcon = isIndeterminate ? (_jsx(Icon, { size: 12, stroke: 3, children: _jsx(IconMinus, {}) })) : (_jsx(CheckIcon, { size: 12, stroke: 3 }));
211
160
  const localRef = useRef(null);
161
+ // Create checkbox icon for select all option
162
+ const checkboxIcon = useMemo(() => {
163
+ if (!isCheckable) {
164
+ return null;
165
+ }
166
+ return (_jsx(ListBoxCheckboxWrapper, { "data-element": "CheckboxWrapper", mods: {
167
+ selected: isSelected,
168
+ disabled: isDisabled,
169
+ hovered: isHovered,
170
+ indeterminate: isIndeterminate,
171
+ }, children: _jsx(ListBoxCheckbox, { "data-element": "Checkbox", mods: {
172
+ selected: isSelected,
173
+ disabled: isDisabled,
174
+ hovered: isHovered,
175
+ indeterminate: isIndeterminate,
176
+ }, children: (isIndeterminate || isSelected) && markIcon }) }));
177
+ }, [
178
+ isCheckable,
179
+ isSelected,
180
+ isDisabled,
181
+ isHovered,
182
+ isIndeterminate,
183
+ markIcon,
184
+ ]);
212
185
  const handleOptionClick = (e) => {
213
186
  // Mark focus changes from mouse clicks
214
187
  if (lastFocusSourceRef) {
@@ -234,14 +207,15 @@ const SelectAllOption = ({ label = 'Select All', isSelected, isIndeterminate, is
234
207
  onClick?.(true);
235
208
  }
236
209
  };
237
- return (_jsxs(_Fragment, { children: [_jsxs(OptionElement, { ref: localRef, as: "div", ...hoverProps, "data-size": size, role: "option", "aria-selected": isSelected, mods: {
238
- selected: isSelected,
210
+ return (_jsxs(_Fragment, { children: [_jsx(ListBoxItemBase, { ref: localRef, "data-size": size, size: size, role: "option", "aria-selected": isSelected, isSelected: isSelected, isDisabled: isDisabled, icon: checkboxIcon, mods: {
239
211
  disabled: isDisabled,
240
212
  checkable: isCheckable,
241
213
  hovered: isHovered,
242
214
  indeterminate: isIndeterminate,
243
- all: true,
244
- }, style: { cursor: isDisabled ? 'not-allowed' : 'pointer' }, onClick: handleOptionClick, children: [isCheckable && (_jsx("div", { "data-element": "CheckboxWrapper", children: _jsx("div", { "data-element": "Checkbox", children: (isIndeterminate || isSelected) && markIcon }) })), _jsx("div", { "data-element": "Content", children: _jsx("div", { "data-element": "Label", children: label }) })] }), _jsx(StyledDivider, {})] }));
215
+ all: true, // Important: this preserves the 'all' modifier
216
+ }, ...mergeProps(hoverProps, allValueProps, {
217
+ onClick: handleOptionClick,
218
+ }), children: label }), _jsx(StyledDivider, {})] }));
245
219
  };
246
220
  export const ListBox = forwardRef(function ListBox(props, ref) {
247
221
  props = useProviderProps(props);
@@ -266,7 +240,7 @@ export const ListBox = forwardRef(function ListBox(props, ref) {
266
240
  return fieldProps;
267
241
  },
268
242
  });
269
- let { qa, label, extra, labelStyles, isRequired, necessityIndicator, validationState, isDisabled, listStyles, optionStyles, sectionStyles, headingStyles, listRef, message, description, styles, mods: externalMods, size = 'medium', labelSuffix, selectedKey, defaultSelectedKey, selectedKeys, defaultSelectedKeys, shouldUseVirtualFocus, onSelectionChange, stateRef, focusOnHover, header, footer, headerStyles, footerStyles, onEscape, isCheckable, onOptionClick, showSelectAll, selectAllLabel, ...otherProps } = props;
243
+ let { qa, label, extra, labelStyles, isRequired, necessityIndicator, validationState, isDisabled, listStyles, optionStyles, sectionStyles, headingStyles, listRef, message, description, styles, mods: externalMods, size = 'medium', labelSuffix, selectedKey, defaultSelectedKey, selectedKeys, defaultSelectedKeys, shouldUseVirtualFocus, onSelectionChange, stateRef, focusOnHover, header, footer, headerStyles, footerStyles, onEscape, isCheckable, onOptionClick, showSelectAll, selectAllLabel, allValueProps, ...otherProps } = props;
270
244
  const [, forceUpdate] = useState({});
271
245
  // Wrap onSelectionChange to prevent selection when disabled and handle React Aria's Set format
272
246
  const externalSelectionHandler = onSelectionChange || props.onChange;
@@ -532,7 +506,7 @@ export const ListBox = forwardRef(function ListBox(props, ref) {
532
506
  props.selectionMode,
533
507
  externalMods,
534
508
  ]);
535
- const listBoxField = (_jsxs(ListBoxWrapperElement, { ref: ref, qa: qa || 'ListBox', mods: mods, styles: styles, children: [header ? (_jsx(StyledHeader, { styles: headerStyles, "data-size": size, children: header })) : (_jsx("div", { role: "presentation" })), showSelectAll && props.selectionMode === 'multiple' ? (_jsx(SelectAllOption, { label: selectAllLabel || 'Select All', state: listState, lastFocusSourceRef: lastFocusSourceRef, isSelected: selectAllState.isSelected, isIndeterminate: selectAllState.isIndeterminate, isDisabled: isDisabled, isCheckable: isCheckable, size: size, onClick: handleSelectAllClick })) : (_jsxs(_Fragment, { children: [_jsx("div", { role: "presentation" }), _jsx("div", { role: "presentation" })] })), _jsx(ListBoxScrollElement, { ref: scrollRef, mods: mods, ...focusProps, children: _jsx(ListElement, { ...mergedListBoxProps, ref: listRef, styles: listStyles, "aria-disabled": isDisabled || undefined, mods: { sections: hasSections }, style: shouldVirtualize
509
+ const listBoxField = (_jsxs(ListBoxWrapperElement, { ref: ref, qa: qa || 'ListBox', mods: mods, styles: styles, children: [header ? (_jsx(StyledHeader, { styles: headerStyles, "data-size": size, children: header })) : (_jsx("div", { role: "presentation" })), showSelectAll && props.selectionMode === 'multiple' ? (_jsx(SelectAllOption, { label: selectAllLabel || 'Select All', state: listState, lastFocusSourceRef: lastFocusSourceRef, isSelected: selectAllState.isSelected, isIndeterminate: selectAllState.isIndeterminate, isDisabled: isDisabled, isCheckable: isCheckable, size: size, allValueProps: allValueProps, onClick: handleSelectAllClick })) : (_jsxs(_Fragment, { children: [_jsx("div", { role: "presentation" }), _jsx("div", { role: "presentation" })] })), _jsx(ListBoxScrollElement, { ref: scrollRef, mods: mods, ...focusProps, children: _jsx(ListElement, { ...mergedListBoxProps, ref: listRef, styles: listStyles, "aria-disabled": isDisabled || undefined, mods: { sections: hasSections }, style: shouldVirtualize
536
510
  ? {
537
511
  position: 'relative',
538
512
  height: `${rowVirtualizer.getTotalSize() + 3}px`,
@@ -578,14 +552,44 @@ function Option({ size = 'medium', item, state, styles, isParentDisabled, valida
578
552
  const isSelected = state.selectionManager.isSelected(item.key);
579
553
  const isFocused = state.selectionManager.focusedKey === item.key;
580
554
  const { hoverProps, isHovered } = useHover({ isDisabled });
581
- const { optionProps, isPressed } = useOption({
555
+ const { optionProps, isPressed, labelProps, descriptionProps } = useOption({
582
556
  key: item.key,
583
557
  isDisabled,
584
558
  isSelected,
585
559
  shouldSelectOnPressUp: true,
586
560
  shouldFocusOnHover: focusOnHover,
587
561
  }, state, combinedRef);
588
- const description = item?.props?.description;
562
+ // Create checkbox icon for multiple selection mode
563
+ const effectiveIcon = useMemo(() => {
564
+ if (!isCheckable ||
565
+ state.selectionManager.selectionMode !== 'multiple' ||
566
+ item.icon) {
567
+ return (item?.props?.icon ??
568
+ (state.selectionManager.selectionMode !== 'multiple' ? null : undefined));
569
+ }
570
+ return (_jsx(ListBoxCheckboxWrapper, { "data-element": "CheckboxWrapper", mods: {
571
+ selected: isSelected,
572
+ disabled: isDisabled,
573
+ focused: isFocused,
574
+ hovered: isHovered,
575
+ invalid: validationState === 'invalid',
576
+ }, children: _jsx(ListBoxCheckbox, { "data-element": "Checkbox", mods: {
577
+ selected: isSelected,
578
+ disabled: isDisabled,
579
+ focused: isFocused,
580
+ hovered: isHovered,
581
+ invalid: validationState === 'invalid',
582
+ }, children: _jsx(CheckIcon, { size: 12, stroke: 3 }) }) }));
583
+ }, [
584
+ isCheckable,
585
+ state.selectionManager.selectionMode,
586
+ isSelected,
587
+ isDisabled,
588
+ isFocused,
589
+ isHovered,
590
+ validationState,
591
+ item.icon,
592
+ ]);
589
593
  // Custom click handler for the entire option
590
594
  const handleOptionClick = (e) => {
591
595
  // Mark focus changes from mouse clicks
@@ -632,16 +636,26 @@ function Option({ size = 'medium', item, state, styles, isParentDisabled, valida
632
636
  }
633
637
  }
634
638
  };
635
- return (_jsxs(OptionElement, { id: `ListBoxItem-${String(item.key)}`, ...mergeProps(optionProps, hoverProps), ref: combinedRef, style: virtualStyle, "data-size": size, "data-index": virtualIndex, mods: {
636
- selected: isSelected,
639
+ // Filter out React Aria props that shouldn't reach the DOM
640
+ const { onKeyDown, onKeyUp, tabIndex, 'aria-selected': ariaSelected, 'aria-disabled': ariaDisabled, role, ...filteredOptionProps } = optionProps;
641
+ const theme = { valid: 'success', invalid: 'danger' }[validationState] || 'default';
642
+ return (_jsx(ListBoxItemBase, { ref: combinedRef, qa: item.props?.qa, id: `ListBoxItem-${String(item.key)}`, ...mergeProps(filteredOptionProps, hoverProps, {
643
+ onClick: handleOptionClick,
644
+ onKeyDown,
645
+ onKeyUp,
646
+ tabIndex,
647
+ 'aria-selected': ariaSelected,
648
+ 'aria-disabled': ariaDisabled,
649
+ role,
650
+ }), theme: theme, style: virtualStyle, "data-size": size, "data-index": virtualIndex, size: size, isSelected: isSelected, isDisabled: isDisabled, icon: effectiveIcon, rightIcon: item.props?.rightIcon, hotkeys: item.props?.hotkeys, suffix: item.props?.suffix, description: item.props?.description, descriptionPlacement: item.props?.descriptionPlacement, labelProps: labelProps, descriptionProps: descriptionProps, styles: styles, tooltip: item.props?.tooltip, defaultTooltipPlacement: "right", mods: {
637
651
  focused: isFocused,
638
- disabled: isDisabled,
639
652
  pressed: isPressed,
640
653
  valid: isSelected && validationState === 'valid',
641
654
  invalid: isSelected && validationState === 'invalid',
642
655
  checkable: isCheckable,
643
- hovered: isHovered, // We'll treat focus as hover for the checkbox visibility
644
- }, styles: styles, onClick: handleOptionClick, children: [isCheckable && state.selectionManager.selectionMode === 'multiple' && (_jsx("div", { "data-element": "CheckboxWrapper", children: _jsx("div", { "data-element": "Checkbox", children: _jsx(CheckIcon, { size: 12, stroke: 3 }) }) })), _jsxs("div", { "data-element": "Content", children: [_jsx("div", { "data-element": "Label", children: item.rendered }), description ? (_jsx("div", { "data-element": "Description", children: description })) : null] })] }));
656
+ hovered: isHovered,
657
+ all: false, // This will be set to true for SelectAllOption
658
+ }, children: item.rendered }));
645
659
  }
646
660
  function ListBoxSection(props) {
647
661
  const { item, state, optionStyles, headingStyles, sectionStyles, isParentDisabled, validationState, focusOnHover, isCheckable, onClick: onOptionClick, lastFocusSourceRef, } = props;
@@ -650,7 +664,7 @@ function ListBoxSection(props) {
650
664
  heading,
651
665
  'aria-label': item['aria-label'],
652
666
  });
653
- return (_jsxs(SectionWrapperElement, { ...itemProps, styles: sectionStyles, children: [heading && (_jsx(StyledSectionHeading, { ...headingProps, styles: headingStyles, children: heading })), _jsx(SectionListElement, { ...groupProps, children: [...item.childNodes]
667
+ return (_jsxs(SectionWrapperElement, { ...itemProps, styles: sectionStyles, children: [heading && (_jsx(StyledSectionHeading, { ...headingProps, size: props.size, styles: headingStyles, children: heading })), _jsx(SectionListElement, { ...groupProps, children: [...item.childNodes]
654
668
  .filter((node) => state.collection.getItem(node.key))
655
669
  .map((node) => (_jsx(Option, { size: props.size, item: node, state: state, styles: optionStyles, isParentDisabled: isParentDisabled, validationState: validationState, focusOnHover: focusOnHover, isCheckable: isCheckable, lastFocusSourceRef: lastFocusSourceRef, onClick: onOptionClick }, node.key))) })] }));
656
670
  }
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7
 
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license MIT
3
3
  * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.72.3
4
+ * @cube-dev/ui-kit v0.73.1
5
5
  * Released under the MIT license.
6
6
  */
7
7