@cube-dev/ui-kit 0.0.0-canary-a465ecb → 0.0.0-canary-89f3845

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 (611) hide show
  1. package/es/_internal/hooks/index.js +1 -1
  2. package/es/_internal/hooks/use-chained-callback.js +1 -1
  3. package/es/_internal/hooks/use-debounced-value.js +1 -1
  4. package/es/_internal/hooks/use-deprecation-warning.js +1 -1
  5. package/es/_internal/hooks/use-effect-once.js +1 -1
  6. package/es/_internal/hooks/use-event.js +1 -1
  7. package/es/_internal/hooks/use-is-first-render.js +1 -1
  8. package/es/_internal/hooks/use-sync-ref.js +1 -1
  9. package/es/_internal/hooks/use-timer/index.js +1 -1
  10. package/es/_internal/hooks/use-timer/timer.js +1 -1
  11. package/es/_internal/hooks/use-timer/use-timer.js +1 -1
  12. package/es/_internal/hooks/use-update-effect.js +1 -1
  13. package/es/_internal/hooks/use-warn.js +1 -1
  14. package/es/_internal/index.js +1 -1
  15. package/es/components/Block.js +1 -1
  16. package/es/components/CollectionItem.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/OpenTrasition.js +1 -1
  21. package/es/components/Root.js +1 -1
  22. package/es/components/actions/Action/Action.js +1 -1
  23. package/es/components/actions/Button/Button.js +1 -1
  24. package/es/components/actions/Button/index.js +1 -1
  25. package/es/components/actions/ButtonGroup/ButtonGroup.js +1 -1
  26. package/es/components/actions/CommandMenu/CommandMenu.js +1 -1
  27. package/es/components/actions/CommandMenu/index.js +1 -1
  28. package/es/components/actions/CommandMenu/styled.js +1 -1
  29. package/es/components/actions/ItemAction/ItemAction.js +1 -1
  30. package/es/components/actions/ItemAction/index.js +1 -1
  31. package/es/components/actions/ItemActionContext.js +1 -1
  32. package/es/components/actions/ItemButton/ItemButton.js +1 -1
  33. package/es/components/actions/ItemButton/index.js +1 -1
  34. package/es/components/actions/Link/Link.js +1 -1
  35. package/es/components/actions/Menu/Menu.js +1 -1
  36. package/es/components/actions/Menu/MenuItem.js +1 -1
  37. package/es/components/actions/Menu/MenuSection.js +1 -1
  38. package/es/components/actions/Menu/MenuTrigger.js +1 -1
  39. package/es/components/actions/Menu/SubMenuTrigger.js +1 -1
  40. package/es/components/actions/Menu/SubmenuTriggerContext.js +1 -1
  41. package/es/components/actions/Menu/context.js +1 -1
  42. package/es/components/actions/Menu/index.js +1 -1
  43. package/es/components/actions/Menu/styled.js +1 -1
  44. package/es/components/actions/index.js +1 -1
  45. package/es/components/actions/use-action.js +1 -1
  46. package/es/components/actions/use-anchored-menu.js +1 -1
  47. package/es/components/actions/use-context-menu.js +1 -1
  48. package/es/components/content/ActiveZone/ActiveZone.js +1 -1
  49. package/es/components/content/Alert/Alert.js +1 -1
  50. package/es/components/content/Alert/index.js +1 -1
  51. package/es/components/content/Alert/types.js +1 -1
  52. package/es/components/content/Alert/use-alert.js +1 -1
  53. package/es/components/content/Avatar/Avatar.js +1 -1
  54. package/es/components/content/Badge/Badge.js +1 -1
  55. package/es/components/content/Card/Card.js +1 -1
  56. package/es/components/content/Content.js +1 -1
  57. package/es/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
  58. package/es/components/content/CopyPasteBlock/index.js +1 -1
  59. package/es/components/content/CopySnippet/CopySnippet.js +1 -1
  60. package/es/components/content/CopySnippet/index.js +1 -1
  61. package/es/components/content/Disclosure/Disclosure.js +1 -1
  62. package/es/components/content/Disclosure/index.js +1 -1
  63. package/es/components/content/Divider.js +1 -1
  64. package/es/components/content/Footer.js +1 -1
  65. package/es/components/content/Header.js +1 -1
  66. package/es/components/content/HotKeys/HotKeys.js +1 -1
  67. package/es/components/content/HotKeys/index.js +1 -1
  68. package/es/components/content/Item/Item.js +6 -11
  69. package/es/components/content/Item/index.js +1 -1
  70. package/es/components/content/ItemBadge/ItemBadge.js +1 -1
  71. package/es/components/content/ItemBadge/index.js +1 -1
  72. package/es/components/content/Layout/GridLayout.js +1 -1
  73. package/es/components/content/Layout/Layout.js +1 -1
  74. package/es/components/content/Layout/LayoutBlock.js +1 -1
  75. package/es/components/content/Layout/LayoutCenter.js +1 -1
  76. package/es/components/content/Layout/LayoutContainer.js +1 -1
  77. package/es/components/content/Layout/LayoutContent.js +1 -1
  78. package/es/components/content/Layout/LayoutContext.js +1 -1
  79. package/es/components/content/Layout/LayoutFlex.js +1 -1
  80. package/es/components/content/Layout/LayoutFooter.js +1 -1
  81. package/es/components/content/Layout/LayoutGrid.js +1 -1
  82. package/es/components/content/Layout/LayoutHeader.js +1 -1
  83. package/es/components/content/Layout/LayoutPane.js +1 -1
  84. package/es/components/content/Layout/LayoutPanel.js +1 -1
  85. package/es/components/content/Layout/LayoutPanelHeader.js +1 -1
  86. package/es/components/content/Layout/LayoutToolbar.js +1 -1
  87. package/es/components/content/Layout/hooks/useTinyScrollbar.js +1 -13
  88. package/es/components/content/Layout/index.js +1 -1
  89. package/es/components/content/Layout/utils.js +1 -1
  90. package/es/components/content/List/SectionHeading.js +1 -1
  91. package/es/components/content/List/index.js +1 -1
  92. package/es/components/content/Paragraph.js +1 -1
  93. package/es/components/content/Placeholder/Placeholder.js +1 -1
  94. package/es/components/content/PrismCode/PrismCode.js +1 -1
  95. package/es/components/content/PrismCode/prismSetup.js +1 -1
  96. package/es/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
  97. package/es/components/content/Result/Result.js +1 -1
  98. package/es/components/content/Skeleton/Skeleton.js +1 -1
  99. package/es/components/content/Tag/Tag.js +1 -1
  100. package/es/components/content/Text.js +1 -1
  101. package/es/components/content/TextItem/TextItem.js +1 -1
  102. package/es/components/content/TextItem/index.js +1 -1
  103. package/es/components/content/Title.js +1 -1
  104. package/es/components/content/highlightText.js +1 -1
  105. package/es/components/content/use-auto-tooltip.js +1 -1
  106. package/es/components/fields/Checkbox/Checkbox.js +1 -1
  107. package/es/components/fields/Checkbox/CheckboxGroup.js +1 -1
  108. package/es/components/fields/Checkbox/context.js +1 -1
  109. package/es/components/fields/Checkbox/index.js +1 -1
  110. package/es/components/fields/ComboBox/ComboBox.js +1 -1
  111. package/es/components/fields/ComboBox/index.js +1 -1
  112. package/es/components/fields/DatePicker/DateInput.js +1 -1
  113. package/es/components/fields/DatePicker/DateInputBase.js +1 -1
  114. package/es/components/fields/DatePicker/DatePicker.js +1 -1
  115. package/es/components/fields/DatePicker/DatePickerButton.js +1 -1
  116. package/es/components/fields/DatePicker/DatePickerElement.js +1 -1
  117. package/es/components/fields/DatePicker/DatePickerInput.js +1 -1
  118. package/es/components/fields/DatePicker/DatePickerSegment.js +1 -1
  119. package/es/components/fields/DatePicker/DateRangePicker.js +1 -1
  120. package/es/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
  121. package/es/components/fields/DatePicker/TimeInput.js +1 -1
  122. package/es/components/fields/DatePicker/index.js +1 -1
  123. package/es/components/fields/DatePicker/intl.js +1 -1
  124. package/es/components/fields/DatePicker/parseDate.js +1 -1
  125. package/es/components/fields/DatePicker/props.js +1 -1
  126. package/es/components/fields/DatePicker/types.js +1 -1
  127. package/es/components/fields/DatePicker/utils.js +1 -1
  128. package/es/components/fields/FileInput/FileInput.js +1 -1
  129. package/es/components/fields/FilterListBox/FilterListBox.js +1 -1
  130. package/es/components/fields/FilterListBox/index.js +1 -1
  131. package/es/components/fields/FilterPicker/FilterPicker.js +1 -1
  132. package/es/components/fields/FilterPicker/index.js +1 -1
  133. package/es/components/fields/Input/Input.js +1 -1
  134. package/es/components/fields/Input/index.js +1 -1
  135. package/es/components/fields/ListBox/ListBox.js +11 -4
  136. package/es/components/fields/ListBox/index.js +1 -1
  137. package/es/components/fields/NumberInput/NumberInput.js +1 -1
  138. package/es/components/fields/NumberInput/StepButton.js +1 -1
  139. package/es/components/fields/PasswordInput/PasswordInput.js +1 -1
  140. package/es/components/fields/Picker/Picker.js +1 -1
  141. package/es/components/fields/Picker/index.js +1 -1
  142. package/es/components/fields/RadioGroup/Radio.js +1 -1
  143. package/es/components/fields/RadioGroup/RadioGroup.js +1 -1
  144. package/es/components/fields/RadioGroup/context.js +1 -1
  145. package/es/components/fields/RadioGroup/index.js +1 -1
  146. package/es/components/fields/SearchInput/SearchInput.js +1 -1
  147. package/es/components/fields/SearchInput/index.js +1 -1
  148. package/es/components/fields/Select/Select.js +1 -1
  149. package/es/components/fields/Select/index.js +1 -1
  150. package/es/components/fields/Slider/Gradation.js +1 -1
  151. package/es/components/fields/Slider/Header.js +1 -1
  152. package/es/components/fields/Slider/RangeSlider.js +1 -1
  153. package/es/components/fields/Slider/Slider.js +1 -1
  154. package/es/components/fields/Slider/SliderBase.js +1 -1
  155. package/es/components/fields/Slider/SliderInput.js +1 -1
  156. package/es/components/fields/Slider/SliderThumb.js +1 -1
  157. package/es/components/fields/Slider/SliderTrack.js +1 -1
  158. package/es/components/fields/Slider/elements.js +1 -1
  159. package/es/components/fields/Slider/index.js +1 -1
  160. package/es/components/fields/Slider/types.js +1 -1
  161. package/es/components/fields/Switch/Switch.js +1 -1
  162. package/es/components/fields/Switch/index.js +1 -1
  163. package/es/components/fields/TextArea/TextArea.js +1 -1
  164. package/es/components/fields/TextArea/index.js +1 -1
  165. package/es/components/fields/TextInput/TextInput.js +1 -1
  166. package/es/components/fields/TextInput/TextInputBase.js +1 -1
  167. package/es/components/fields/TextInput/index.js +1 -1
  168. package/es/components/fields/TextInputMapper/TextInputMapper.js +1 -1
  169. package/es/components/fields/TextInputMapper/index.js +1 -1
  170. package/es/components/fields/index.js +1 -1
  171. package/es/components/form/FieldWrapper/FieldWrapper.js +1 -1
  172. package/es/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
  173. package/es/components/form/FieldWrapper/index.js +1 -1
  174. package/es/components/form/FieldWrapper/types.js +1 -1
  175. package/es/components/form/Form/Field.js +1 -1
  176. package/es/components/form/Form/Form.js +1 -1
  177. package/es/components/form/Form/ResetButton/ResetButton.js +1 -1
  178. package/es/components/form/Form/ResetButton/index.js +1 -1
  179. package/es/components/form/Form/SubmitButton/SubmitButton.js +1 -1
  180. package/es/components/form/Form/SubmitButton/index.js +1 -1
  181. package/es/components/form/Form/SubmitError.js +1 -1
  182. package/es/components/form/Form/index.js +1 -1
  183. package/es/components/form/Form/types.js +1 -1
  184. package/es/components/form/Form/use-field/index.js +1 -1
  185. package/es/components/form/Form/use-field/types.js +1 -1
  186. package/es/components/form/Form/use-field/use-field-props.js +1 -1
  187. package/es/components/form/Form/use-field/use-field.js +1 -1
  188. package/es/components/form/Form/use-form.js +1 -1
  189. package/es/components/form/Form/validation.js +1 -1
  190. package/es/components/form/Label.js +1 -1
  191. package/es/components/form/index.js +1 -1
  192. package/es/components/form/wrapper.js +1 -1
  193. package/es/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
  194. package/es/components/helpers/DisplayTransition/index.js +1 -1
  195. package/es/components/helpers/IconSwitch/IconSwitch.js +1 -1
  196. package/es/components/helpers/index.js +1 -1
  197. package/es/components/layout/Flex.js +1 -1
  198. package/es/components/layout/Flow.js +1 -1
  199. package/es/components/layout/Grid.js +1 -1
  200. package/es/components/layout/Panel.js +1 -1
  201. package/es/components/layout/Prefix.js +1 -1
  202. package/es/components/layout/ResizablePanel.js +1 -1
  203. package/es/components/layout/Space.js +1 -1
  204. package/es/components/layout/Suffix.js +1 -1
  205. package/es/components/organisms/FileTabs/FileTabs.js +1 -1
  206. package/es/components/organisms/StatsCard/StatsCard.js +1 -1
  207. package/es/components/other/Calendar/Calendar.js +1 -1
  208. package/es/components/other/Calendar/CalendarCell.js +1 -1
  209. package/es/components/other/Calendar/CalendarGrid.js +1 -1
  210. package/es/components/other/Calendar/RangeCalendar.js +1 -1
  211. package/es/components/other/CloudLogo/CloudLogo.js +1 -1
  212. package/es/components/overlays/AlertDialog/AlertDialog.js +1 -1
  213. package/es/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
  214. package/es/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
  215. package/es/components/overlays/AlertDialog/index.js +1 -1
  216. package/es/components/overlays/AlertDialog/types.js +1 -1
  217. package/es/components/overlays/Dialog/Dialog.js +1 -1
  218. package/es/components/overlays/Dialog/DialogContainer.js +1 -1
  219. package/es/components/overlays/Dialog/DialogForm.js +1 -1
  220. package/es/components/overlays/Dialog/DialogTrigger.js +1 -1
  221. package/es/components/overlays/Dialog/context.js +1 -1
  222. package/es/components/overlays/Dialog/index.js +1 -1
  223. package/es/components/overlays/Dialog/use-dialog-container.js +1 -1
  224. package/es/components/overlays/Modal/Modal.js +1 -1
  225. package/es/components/overlays/Modal/OpenTransition.js +1 -1
  226. package/es/components/overlays/Modal/Overlay.js +1 -1
  227. package/es/components/overlays/Modal/Popover.js +1 -1
  228. package/es/components/overlays/Modal/Tray.js +1 -1
  229. package/es/components/overlays/Modal/Underlay.js +1 -1
  230. package/es/components/overlays/Modal/index.js +1 -1
  231. package/es/components/overlays/Modal/types.js +1 -1
  232. package/es/components/overlays/NewNotifications/Bar/FloatingNotification.js +1 -1
  233. package/es/components/overlays/NewNotifications/Bar/NotificationsBar.js +1 -1
  234. package/es/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
  235. package/es/components/overlays/NewNotifications/Bar/index.js +1 -1
  236. package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogContext.js +1 -1
  237. package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +1 -1
  238. package/es/components/overlays/NewNotifications/Dialog/index.js +1 -1
  239. package/es/components/overlays/NewNotifications/Notification.js +1 -1
  240. package/es/components/overlays/NewNotifications/NotificationView/NotificationAction.js +1 -1
  241. package/es/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +1 -1
  242. package/es/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +1 -1
  243. package/es/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +1 -1
  244. package/es/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +1 -1
  245. package/es/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +1 -1
  246. package/es/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +1 -1
  247. package/es/components/overlays/NewNotifications/NotificationView/NotificationView.js +1 -1
  248. package/es/components/overlays/NewNotifications/NotificationView/index.js +1 -1
  249. package/es/components/overlays/NewNotifications/NotificationView/types.js +1 -1
  250. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsContext.js +1 -1
  251. package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +1 -1
  252. package/es/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
  253. package/es/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +1 -1
  254. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +1 -1
  255. package/es/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +1 -1
  256. package/es/components/overlays/NewNotifications/NotificationsList/index.js +1 -1
  257. package/es/components/overlays/NewNotifications/NotificationsList/types.js +1 -1
  258. package/es/components/overlays/NewNotifications/hooks/index.js +1 -1
  259. package/es/components/overlays/NewNotifications/hooks/types.js +1 -1
  260. package/es/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
  261. package/es/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
  262. package/es/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
  263. package/es/components/overlays/NewNotifications/hooks/use-notifications-observer.js +1 -1
  264. package/es/components/overlays/NewNotifications/index.js +1 -1
  265. package/es/components/overlays/NewNotifications/types.js +1 -1
  266. package/es/components/overlays/Notification/Notification.js +1 -1
  267. package/es/components/overlays/OverlayWrapper.js +1 -1
  268. package/es/components/overlays/Toasts/Toast.js +1 -1
  269. package/es/components/overlays/Toasts/index.js +1 -1
  270. package/es/components/overlays/Toasts/types.js +1 -1
  271. package/es/components/overlays/Toasts/use-toasts-api.js +1 -1
  272. package/es/components/overlays/Tooltip/Tooltip.js +1 -1
  273. package/es/components/overlays/Tooltip/TooltipProvider.js +1 -1
  274. package/es/components/overlays/Tooltip/TooltipTrigger.js +1 -1
  275. package/es/components/overlays/Tooltip/context.js +1 -1
  276. package/es/components/overlays/Tooltip/index.js +1 -1
  277. package/es/components/portal/Portal.js +1 -1
  278. package/es/components/portal/PortalProvider.js +1 -1
  279. package/es/components/portal/index.js +1 -1
  280. package/es/components/portal/types.js +1 -1
  281. package/es/components/portal/usePortal.js +1 -1
  282. package/es/components/shared/InvalidIcon.js +1 -1
  283. package/es/components/shared/ValidIcon.js +1 -1
  284. package/es/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
  285. package/es/components/status/LoadingAnimation/index.js +1 -1
  286. package/es/components/status/Spin/Cube.js +1 -1
  287. package/es/components/status/Spin/InternalSpinner.js +1 -1
  288. package/es/components/status/Spin/Spin.js +1 -1
  289. package/es/components/status/Spin/SpinsContainer.js +1 -1
  290. package/es/components/status/Spin/index.js +1 -1
  291. package/es/components/status/Spin/types.js +1 -1
  292. package/es/components/status/index.js +1 -1
  293. package/es/data/item-themes.js +1 -1
  294. package/es/data/themes.js +1 -1
  295. package/es/icons/AdjustmentsHorizontalIcon.js +1 -1
  296. package/es/icons/AdjustmentsIcon.js +1 -1
  297. package/es/icons/AiIcon.js +1 -1
  298. package/es/icons/AreaChartIcon.js +1 -1
  299. package/es/icons/BackwardIcon.js +1 -1
  300. package/es/icons/BarChartIcon.js +1 -1
  301. package/es/icons/BellFilledIcon.js +1 -1
  302. package/es/icons/BellIcon.js +1 -1
  303. package/es/icons/BooleanIcon.js +1 -1
  304. package/es/icons/CalendarEditIcon.js +1 -1
  305. package/es/icons/CalendarIcon.js +1 -1
  306. package/es/icons/CaretDownIcon.js +1 -1
  307. package/es/icons/CaretUpIcon.js +1 -1
  308. package/es/icons/ChartAreaStackedIcon.js +1 -1
  309. package/es/icons/ChartAreaStackedPercentageIcon.js +1 -1
  310. package/es/icons/ChartBarGroupedHorizontalIcon.js +1 -1
  311. package/es/icons/ChartBarGroupedIcon.js +1 -1
  312. package/es/icons/ChartBarHorizontalIcon.js +1 -1
  313. package/es/icons/ChartBarLineIcon.js +1 -1
  314. package/es/icons/ChartBarStackedHorizontalIcon.js +1 -1
  315. package/es/icons/ChartBarStackedIcon.js +1 -1
  316. package/es/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
  317. package/es/icons/ChartBarStackedPercentageIcon.js +1 -1
  318. package/es/icons/ChartBoxPlot2Icon.js +1 -1
  319. package/es/icons/ChartBoxPlotIcon.js +1 -1
  320. package/es/icons/ChartBubbleIcon.js +1 -1
  321. package/es/icons/ChartDonut2Icon.js +1 -1
  322. package/es/icons/ChartFunnelIcon.js +1 -1
  323. package/es/icons/ChartHeatmapIcon.js +1 -1
  324. package/es/icons/ChartKPIIcon.js +1 -1
  325. package/es/icons/ChartPie2Icon.js +1 -1
  326. package/es/icons/ChartScatterIcon.js +1 -1
  327. package/es/icons/CheckCircleFilledIcon.js +1 -1
  328. package/es/icons/CheckCircleIcon.js +1 -1
  329. package/es/icons/CheckIcon.js +1 -1
  330. package/es/icons/CircleFilledIcon.js +1 -1
  331. package/es/icons/ClearIcon.js +1 -1
  332. package/es/icons/CloseCircleFilledIcon.js +1 -1
  333. package/es/icons/CloseCircleIcon.js +1 -1
  334. package/es/icons/CloseIcon.js +1 -1
  335. package/es/icons/CodeIcon.js +1 -1
  336. package/es/icons/ColumnTotalIcon.js +1 -1
  337. package/es/icons/CopyIcon.js +1 -1
  338. package/es/icons/CountIcon.js +1 -1
  339. package/es/icons/CubeIcon.js +1 -1
  340. package/es/icons/CubePauseIcon.js +1 -1
  341. package/es/icons/CubePlayIcon.js +1 -1
  342. package/es/icons/CurrencyDollarIcon.js +1 -1
  343. package/es/icons/DangerIcon.js +1 -1
  344. package/es/icons/DashboardIcon.js +1 -1
  345. package/es/icons/DatabaseIcon.js +1 -1
  346. package/es/icons/DecimalDecreaseIcon.js +1 -1
  347. package/es/icons/DecimalIncreaseIcon.js +1 -1
  348. package/es/icons/DirectionIcon.js +1 -1
  349. package/es/icons/DonutIcon.js +1 -1
  350. package/es/icons/DownIcon.js +1 -1
  351. package/es/icons/EditIcon.js +1 -1
  352. package/es/icons/ExclamationCircleFilledIcon.js +1 -1
  353. package/es/icons/ExclamationCircleIcon.js +1 -1
  354. package/es/icons/ExclamationIcon.js +1 -1
  355. package/es/icons/EyeIcon.js +1 -1
  356. package/es/icons/EyeInvisibleIcon.js +1 -1
  357. package/es/icons/FilterIcon.js +1 -1
  358. package/es/icons/FolderFilledIcon.js +1 -1
  359. package/es/icons/FolderIcon.js +1 -1
  360. package/es/icons/FolderOpenFilledIcon.js +1 -1
  361. package/es/icons/FolderOpenIcon.js +1 -1
  362. package/es/icons/ForwardIcon.js +1 -1
  363. package/es/icons/HierarchyIcon.js +1 -1
  364. package/es/icons/HierarchyOpenIcon.js +1 -1
  365. package/es/icons/Icon.js +1 -1
  366. package/es/icons/InfoCircleIcon.js +1 -1
  367. package/es/icons/InfoIcon.js +1 -1
  368. package/es/icons/KeyIcon.js +1 -1
  369. package/es/icons/LeftIcon.js +1 -1
  370. package/es/icons/LineChartIcon.js +1 -1
  371. package/es/icons/LoadingIcon.js +1 -1
  372. package/es/icons/LockFilledIcon.js +1 -1
  373. package/es/icons/LockIcon.js +1 -1
  374. package/es/icons/MoreIcon.js +1 -1
  375. package/es/icons/NotAllowedIcon.js +1 -1
  376. package/es/icons/Number123Icon.js +1 -1
  377. package/es/icons/NumberIcon.js +1 -1
  378. package/es/icons/PauseCircleFilledIcon.js +1 -1
  379. package/es/icons/PauseCircleIcon.js +1 -1
  380. package/es/icons/PauseIcon.js +1 -1
  381. package/es/icons/PercentageIcon.js +1 -1
  382. package/es/icons/PieChartIcon.js +1 -1
  383. package/es/icons/PlayCircleIcon.js +1 -1
  384. package/es/icons/PlayIcon.js +1 -1
  385. package/es/icons/PlusIcon.js +1 -1
  386. package/es/icons/ProgressBarIcon.js +1 -1
  387. package/es/icons/ReloadIcon.js +1 -1
  388. package/es/icons/ReportIcon.js +1 -1
  389. package/es/icons/ReturnIcon.js +1 -1
  390. package/es/icons/RightIcon.js +1 -1
  391. package/es/icons/RowTotalsIcon.js +1 -1
  392. package/es/icons/SchemeIcon.js +1 -1
  393. package/es/icons/SearchIcon.js +1 -1
  394. package/es/icons/SemanticQueryIcon.js +1 -1
  395. package/es/icons/SettingsIcon.js +1 -1
  396. package/es/icons/ShieldFilledIcon.js +1 -1
  397. package/es/icons/ShieldIcon.js +1 -1
  398. package/es/icons/SlashIcon.js +1 -1
  399. package/es/icons/SparklesIcon.js +1 -1
  400. package/es/icons/SqlIcon.js +1 -1
  401. package/es/icons/StatsIcon.js +1 -1
  402. package/es/icons/StopIcon.js +1 -1
  403. package/es/icons/StringIcon.js +1 -1
  404. package/es/icons/SubtotalsIcon.js +1 -1
  405. package/es/icons/SwitchIcon.js +1 -1
  406. package/es/icons/TableIcon.js +1 -1
  407. package/es/icons/ThumbsDownIcon.js +1 -1
  408. package/es/icons/ThumbsUpIcon.js +1 -1
  409. package/es/icons/ThunderboltCrossedIcon.js +1 -1
  410. package/es/icons/ThunderboltFilledIcon.js +1 -1
  411. package/es/icons/ThunderboltIcon.js +1 -1
  412. package/es/icons/TimeIcon.js +1 -1
  413. package/es/icons/TrashIcon.js +1 -1
  414. package/es/icons/UnlockIcon.js +1 -1
  415. package/es/icons/UpIcon.js +1 -1
  416. package/es/icons/UserGroupIcon.js +1 -1
  417. package/es/icons/UserIcon.js +1 -1
  418. package/es/icons/UserLockIcon.js +1 -1
  419. package/es/icons/ViewIcon.js +1 -1
  420. package/es/icons/WarningFilledIcon.js +1 -1
  421. package/es/icons/WarningIcon.js +1 -1
  422. package/es/icons/index.js +1 -1
  423. package/es/icons/wrap-icon.js +1 -1
  424. package/es/index.js +1 -3
  425. package/es/provider.js +1 -1
  426. package/es/providers/TrackingProvider.js +1 -1
  427. package/es/providers/navigation.types.js +1 -1
  428. package/es/providers/navigationAdapter.default.js +1 -1
  429. package/es/services/notification.js +1 -1
  430. package/es/shared/form.js +1 -1
  431. package/es/shared/index.js +1 -1
  432. package/es/stories/Form.legacy-stories.js +1 -1
  433. package/es/stories/FormFieldArgs.js +1 -1
  434. package/es/stories/SimpleLayout.stories.js +1 -1
  435. package/es/stories/Tasty.stories.js +1 -1
  436. package/es/stories/components/ConfirmDeletionDialogForm.js +1 -1
  437. package/es/stories/components/DialogFormApp.js +1 -1
  438. package/es/stories/components/StyledButton.js +1 -1
  439. package/es/stories/lists/baseProps.js +1 -1
  440. package/es/stories/playground/PlaygroundEditor.js +1 -1
  441. package/es/stories/playground/PlaygroundLayout.js +1 -1
  442. package/es/stories/playground/PlaygroundOutput.js +1 -1
  443. package/es/stories/playground/PlaygroundPreview.js +1 -1
  444. package/es/stories/playground/components/Button.js +1 -1
  445. package/es/stories/playground/components/Card.js +1 -1
  446. package/es/stories/playground/components/ScrollProgress.js +1 -1
  447. package/es/stories/playground/examples.js +1 -1
  448. package/es/tasty/chunks/cacheKey.js +1 -1
  449. package/es/tasty/chunks/definitions.js +1 -1
  450. package/es/tasty/chunks/index.js +1 -1
  451. package/es/tasty/chunks/renderChunk.js +1 -1
  452. package/es/tasty/config.js +21 -3
  453. package/es/tasty/debug.js +1 -1
  454. package/es/tasty/hooks/index.js +1 -3
  455. package/es/tasty/hooks/useGlobalStyles.js +1 -1
  456. package/es/tasty/hooks/useRawCSS.js +1 -1
  457. package/es/tasty/hooks/useStyles.js +1 -1
  458. package/es/tasty/index.js +3 -2
  459. package/es/tasty/injector/index.js +1 -39
  460. package/es/tasty/injector/injector.js +1 -1
  461. package/es/tasty/injector/sheet-manager.js +1 -1
  462. package/es/tasty/injector/types.js +1 -1
  463. package/es/tasty/keyframes/index.js +1 -1
  464. package/es/tasty/parser/classify.js +1 -1
  465. package/es/tasty/parser/const.js +1 -1
  466. package/es/tasty/parser/lru.js +1 -1
  467. package/es/tasty/parser/parser.js +1 -1
  468. package/es/tasty/parser/tokenizer.js +1 -1
  469. package/es/tasty/parser/types.js +1 -1
  470. package/es/tasty/pipeline/conditions.js +1 -1
  471. package/es/tasty/pipeline/exclusive.js +1 -1
  472. package/es/tasty/pipeline/index.js +1 -1
  473. package/es/tasty/pipeline/materialize.js +1 -1
  474. package/es/tasty/pipeline/parseStateKey.js +1 -1
  475. package/es/tasty/pipeline/simplify.js +1 -1
  476. package/es/tasty/plugins/index.js +1 -1
  477. package/es/tasty/plugins/okhsl-plugin.js +1 -1
  478. package/es/tasty/plugins/types.js +1 -1
  479. package/es/tasty/states/index.js +1 -1
  480. package/es/tasty/static/index.js +1 -1
  481. package/es/tasty/static/tastyStatic.js +1 -1
  482. package/es/tasty/static/types.js +1 -1
  483. package/es/tasty/styles/align.js +1 -1
  484. package/es/tasty/styles/border.js +1 -1
  485. package/es/tasty/styles/boxShadow.combinator.js +2 -2
  486. package/es/tasty/styles/color.js +2 -2
  487. package/es/tasty/styles/createStyle.js +1 -1
  488. package/es/tasty/styles/dimension.js +2 -2
  489. package/es/tasty/styles/display.js +1 -1
  490. package/es/tasty/styles/fade.js +2 -2
  491. package/es/tasty/styles/fill.js +3 -3
  492. package/es/tasty/styles/flow.js +1 -1
  493. package/es/tasty/styles/font.js +1 -1
  494. package/es/tasty/styles/fontStyle.js +1 -1
  495. package/es/tasty/styles/gap.js +1 -1
  496. package/es/tasty/styles/groupRadius.js +2 -2
  497. package/es/tasty/styles/height.js +1 -1
  498. package/es/tasty/styles/index.js +4 -3
  499. package/es/tasty/styles/inset.js +2 -2
  500. package/es/tasty/styles/justify.js +1 -1
  501. package/es/tasty/styles/list.js +1 -1
  502. package/es/tasty/styles/margin.js +1 -1
  503. package/es/tasty/styles/outline.js +1 -1
  504. package/es/tasty/styles/padding.js +1 -1
  505. package/es/tasty/styles/place.js +1 -1
  506. package/es/tasty/styles/predefined.js +245 -1
  507. package/es/tasty/styles/preset.js +2 -2
  508. package/es/tasty/styles/radius.js +2 -2
  509. package/es/tasty/styles/reset.js +1 -1
  510. package/es/tasty/styles/scrollbar.js +1 -1
  511. package/es/tasty/styles/shadow.js +2 -2
  512. package/es/tasty/styles/styledScrollbar.js +1 -1
  513. package/es/tasty/styles/transition.js +1 -1
  514. package/es/tasty/styles/types.js +1 -1
  515. package/es/tasty/styles/width.js +1 -1
  516. package/es/tasty/tasty.js +113 -94
  517. package/es/tasty/types.js +1 -1
  518. package/es/tasty/utils/cache-wrapper.js +1 -1
  519. package/es/tasty/utils/case-converter.js +1 -1
  520. package/es/tasty/utils/colors.js +1 -1
  521. package/es/tasty/utils/dotize.js +1 -1
  522. package/es/tasty/utils/filterBaseProps.js +1 -1
  523. package/es/tasty/utils/getDisplayName.js +1 -1
  524. package/es/tasty/utils/isDevEnv.js +1 -1
  525. package/es/tasty/utils/mergeStyles.js +1 -1
  526. package/es/tasty/utils/modAttrs.js +1 -1
  527. package/es/tasty/utils/processTokens.js +1 -1
  528. package/es/tasty/utils/string.js +1 -1
  529. package/es/tasty/utils/styles.js +1 -1
  530. package/es/tasty/utils/typography.js +1 -1
  531. package/es/tasty/utils/warnings.js +1 -1
  532. package/es/tasty/zero/babel.js +9 -1
  533. package/es/tasty/zero/css-writer.js +1 -1
  534. package/es/tasty/zero/extractor.js +1 -1
  535. package/es/tasty/zero/index.js +1 -1
  536. package/es/tasty/zero/next.js +1 -1
  537. package/es/tokens/base.js +1 -3
  538. package/es/tokens/colors.js +1 -1
  539. package/es/tokens/index.js +1 -1
  540. package/es/tokens/layout.js +1 -1
  541. package/es/tokens/shadows.js +1 -1
  542. package/es/tokens/sizes.js +1 -1
  543. package/es/tokens/spacing.js +1 -1
  544. package/es/tokens/typography.js +1 -1
  545. package/es/utils/ResizeSensor.js +1 -1
  546. package/es/utils/index.js +1 -1
  547. package/es/utils/modules.js +1 -1
  548. package/es/utils/promise.js +1 -1
  549. package/es/utils/raf.js +1 -1
  550. package/es/utils/random.js +1 -1
  551. package/es/utils/range.js +1 -1
  552. package/es/utils/react/RenderCache.js +1 -1
  553. package/es/utils/react/Slots.js +1 -1
  554. package/es/utils/react/chain.js +1 -1
  555. package/es/utils/react/forwardRefWithGenerics.js +1 -1
  556. package/es/utils/react/index.js +1 -1
  557. package/es/utils/react/interactions.js +1 -1
  558. package/es/utils/react/isTextOnly.js +1 -1
  559. package/es/utils/react/mapProps.js +1 -1
  560. package/es/utils/react/mergeProps.js +1 -1
  561. package/es/utils/react/nullableValue.js +1 -1
  562. package/es/utils/react/resolveIcon.js +1 -1
  563. package/es/utils/react/sharedStore.js +1 -1
  564. package/es/utils/react/useCombinedRefs.js +1 -1
  565. package/es/utils/react/useControlledFocusVisible.js +1 -1
  566. package/es/utils/react/useEventBus.js +1 -1
  567. package/es/utils/react/useId.js +1 -1
  568. package/es/utils/react/useIsDarwin.js +1 -1
  569. package/es/utils/react/useKeySymbols.js +1 -1
  570. package/es/utils/react/useLayoutEffect.js +1 -1
  571. package/es/utils/react/useLocalStorage.js +1 -1
  572. package/es/utils/react/useQaProps.js +1 -1
  573. package/es/utils/react/useViewportSize.js +1 -1
  574. package/es/utils/react/wrapNodeIfPlain.js +1 -1
  575. package/es/utils/tree.js +1 -1
  576. package/es/utils/warnings.js +1 -1
  577. package/es/version.js +2 -2
  578. package/package.json +1 -1
  579. package/types/components/content/Item/Item.d.ts +0 -7
  580. package/types/components/content/Layout/hooks/useTinyScrollbar.d.ts +0 -6
  581. package/types/index.d.ts +0 -1
  582. package/types/tasty/config.d.ts +30 -0
  583. package/types/tasty/hooks/index.d.ts +0 -3
  584. package/types/tasty/index.d.ts +3 -2
  585. package/types/tasty/injector/index.d.ts +0 -56
  586. package/types/tasty/plugins/types.d.ts +16 -1
  587. package/types/tasty/styles/boxShadow.combinator.d.ts +2 -2
  588. package/types/tasty/styles/color.d.ts +2 -2
  589. package/types/tasty/styles/dimension.d.ts +1 -1
  590. package/types/tasty/styles/fade.d.ts +2 -2
  591. package/types/tasty/styles/fill.d.ts +4 -4
  592. package/types/tasty/styles/groupRadius.d.ts +2 -2
  593. package/types/tasty/styles/height.d.ts +1 -1
  594. package/types/tasty/styles/index.d.ts +3 -1
  595. package/types/tasty/styles/predefined.d.ts +104 -1
  596. package/types/tasty/styles/preset.d.ts +1 -1
  597. package/types/tasty/styles/radius.d.ts +2 -2
  598. package/types/tasty/styles/shadow.d.ts +2 -2
  599. package/types/tasty/styles/width.d.ts +1 -1
  600. package/types/tasty/utils/styles.d.ts +8 -1
  601. package/types/tasty/zero/babel.d.ts +15 -0
  602. package/es/components/navigation/Tabs/Tabs.js +0 -918
  603. package/es/components/navigation/Tabs/index.js +0 -10
  604. package/es/components/navigation/index.js +0 -10
  605. package/es/tasty/hooks/useKeyframes.js +0 -66
  606. package/es/tasty/hooks/useProperty.js +0 -93
  607. package/types/components/navigation/Tabs/Tabs.d.ts +0 -235
  608. package/types/components/navigation/Tabs/index.d.ts +0 -2
  609. package/types/components/navigation/index.d.ts +0 -2
  610. package/types/tasty/hooks/useKeyframes.d.ts +0 -52
  611. package/types/tasty/hooks/useProperty.d.ts +0 -69
@@ -1,918 +0,0 @@
1
- /**
2
- * @license MIT
3
- * author: Cube Dev Team
4
- * @cube-dev/ui-kit v0.0.0-canary-a465ecb
5
- * Released under the MIT license.
6
- */
7
-
8
- import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
9
- import { Children, forwardRef, isValidElement, useCallback, useEffect, useImperativeHandle, useLayoutEffect, useMemo, useRef, useState, } from 'react';
10
- import { useTab, useTabList, useTabPanel, useTextField, } from 'react-aria';
11
- import { Item as CollectionItem, useTabListState, } from 'react-stately';
12
- import { useEvent } from '../../../_internal/hooks/index.js';
13
- import { CloseIcon } from '../../../icons/index.js';
14
- import { tasty, useProperty } from '../../../tasty/index.js';
15
- import { chainRaf } from '../../../utils/raf.js';
16
- import { ItemAction } from '../../actions/ItemAction/index.js';
17
- import { Item } from '../../content/Item/index.js';
18
- import { useTinyScrollbar } from '../../content/Layout/hooks/useTinyScrollbar.js';
19
- // =============================================================================
20
- // Styled Components
21
- // =============================================================================
22
- const TabsElement = tasty({
23
- styles: {
24
- display: 'flex',
25
- flow: 'row',
26
- placeItems: {
27
- '': 'end stretch',
28
- 'type=radio | type=panel': 'stretch',
29
- },
30
- overflow: 'visible',
31
- border: {
32
- '': 0,
33
- 'type=default': 'bottom',
34
- },
35
- width: {
36
- '': '100%',
37
- 'type=radio': 'max-content',
38
- },
39
- padding: {
40
- '': 0,
41
- 'type=radio': '.5x',
42
- },
43
- radius: {
44
- '': 0,
45
- 'type=radio': '1cr',
46
- },
47
- fill: {
48
- '': '#clear',
49
- 'type=radio': '#dark.06',
50
- },
51
- flexShrink: 0,
52
- flexGrow: 0,
53
- $transition: '$tab-transition',
54
- Prefix: {
55
- display: 'flex',
56
- placeItems: 'center',
57
- placeContent: 'center',
58
- flexShrink: 0,
59
- placeSelf: 'center',
60
- },
61
- Suffix: {
62
- display: 'flex',
63
- placeItems: 'center',
64
- placeContent: 'center',
65
- flexShrink: 0,
66
- placeSelf: 'center',
67
- },
68
- // Wrapper for scroll area and scrollbar (scrollbar is positioned relative to this)
69
- ScrollWrapper: {
70
- position: 'relative',
71
- display: 'flex',
72
- flexGrow: 1,
73
- flexShrink: 1,
74
- width: 'min 0',
75
- },
76
- Scroll: {
77
- position: 'relative',
78
- display: 'block',
79
- overflow: {
80
- '': 'auto hidden',
81
- 'type=radio': 'visible',
82
- },
83
- scrollbar: 'none',
84
- flexGrow: 1,
85
- width: '100%',
86
- fade: '$tabs-fade-left left $tabs-fade-right right',
87
- transition: 'fade, --tabs-fade-left, --tabs-fade-right',
88
- '$tabs-fade-left': {
89
- '': '0px',
90
- 'fade-left': '2x',
91
- },
92
- '$tabs-fade-right': {
93
- '': '0px',
94
- 'fade-right': '2x',
95
- },
96
- },
97
- Container: {
98
- position: 'relative',
99
- display: 'grid',
100
- gridAutoFlow: 'column',
101
- gap: {
102
- '': 0,
103
- 'type=radio': '.5x',
104
- },
105
- placeContent: 'start',
106
- overflow: 'visible',
107
- width: 'max-content',
108
- },
109
- // Custom horizontal scrollbar (tiny) - positioned relative to ScrollWrapper
110
- ScrollbarH: {
111
- position: 'absolute',
112
- bottom: '1px',
113
- left: '$scrollbar-h-left',
114
- height: '1ow',
115
- width: '$scrollbar-h-width',
116
- radius: 'round',
117
- fill: '#dark.35',
118
- opacity: {
119
- '': 0,
120
- 'focused | scrolling': 1,
121
- },
122
- transition: 'opacity 0.15s',
123
- pointerEvents: 'none',
124
- },
125
- },
126
- });
127
- const TabElement = tasty(Item, {
128
- as: 'button',
129
- type: 'clear',
130
- styles: {
131
- preset: {
132
- '': 't3m',
133
- 'size=small | size=xsmall': 't4',
134
- 'size=large | size=xlarge': 't2m',
135
- },
136
- shadow: {
137
- '': 'none',
138
- editing: 'inset 0 0 0 1bw #purple-text',
139
- },
140
- },
141
- });
142
- const CardTabElement = tasty(Item, {
143
- as: 'button',
144
- type: 'clear',
145
- styles: {
146
- radius: 'top',
147
- color: {
148
- '': '#dark-03',
149
- selected: '#purple-text',
150
- },
151
- fill: '#clear',
152
- preset: 'h6',
153
- shadow: {
154
- '': 'none',
155
- editing: 'inset 0 0 0 1bw #purple-text',
156
- },
157
- },
158
- });
159
- const RadioTabElement = tasty(Item, {
160
- as: 'button',
161
- type: 'neutral',
162
- styles: {
163
- fill: {
164
- '': '#clear',
165
- selected: '#white',
166
- },
167
- shadow: {
168
- '': 'none',
169
- selected: '$item-shadow',
170
- },
171
- Label: {
172
- placeSelf: {
173
- '': 'center start',
174
- '!has-prefix & !has-suffix & !has-icon & !has-right-icon': 'center',
175
- },
176
- },
177
- },
178
- });
179
- const TabContainer = tasty({
180
- styles: {
181
- position: 'relative',
182
- display: 'grid',
183
- },
184
- });
185
- // =============================================================================
186
- // EditableTitle Component (inline title editing)
187
- // =============================================================================
188
- const EditableTitleInputElement = tasty({
189
- as: 'input',
190
- styles: {
191
- border: 0,
192
- padding: 0,
193
- margin: 0,
194
- fill: 'transparent',
195
- outline: 0,
196
- preset: 'inherit',
197
- color: 'inherit',
198
- width: 'initial $input-width 100%',
199
- },
200
- });
201
- const HiddenMeasure = tasty({
202
- styles: {
203
- position: 'absolute',
204
- visibility: 'hidden',
205
- whiteSpace: 'pre',
206
- font: 'inherit',
207
- pointerEvents: 'none',
208
- height: 0,
209
- overflow: 'hidden',
210
- },
211
- });
212
- function EditableTitle({ title, isEditing, editValue, onEditValueChange, onStartEditing, onSubmit, onCancel, }) {
213
- const inputRef = useRef(null);
214
- const measureRef = useRef(null);
215
- const [inputWidth, setInputWidth] = useState(null);
216
- const justEnteredEditModeRef = useRef(false);
217
- // React Aria text field hook
218
- const { inputProps } = useTextField({
219
- 'aria-label': 'Edit tab title',
220
- value: editValue,
221
- onChange: onEditValueChange,
222
- }, inputRef);
223
- // Focus and select input when entering edit mode
224
- useLayoutEffect(() => {
225
- if (isEditing && inputRef.current) {
226
- const input = inputRef.current;
227
- // Set flag to ignore immediate blur events
228
- justEnteredEditModeRef.current = true;
229
- input.focus();
230
- // Use requestAnimationFrame to ensure selection happens after focus
231
- requestAnimationFrame(() => {
232
- input.select();
233
- // Clear the flag after focus is established (allow 2 frames for menu to fully close)
234
- requestAnimationFrame(() => {
235
- requestAnimationFrame(() => {
236
- justEnteredEditModeRef.current = false;
237
- });
238
- });
239
- });
240
- }
241
- else {
242
- justEnteredEditModeRef.current = false;
243
- }
244
- }, [isEditing]);
245
- // Measure text width and update input width
246
- useLayoutEffect(() => {
247
- if (isEditing && measureRef.current) {
248
- const width = measureRef.current.scrollWidth;
249
- setInputWidth(width);
250
- }
251
- }, [isEditing, editValue]);
252
- const handleKeyDown = useEvent((e) => {
253
- if (e.key === 'Enter') {
254
- e.preventDefault();
255
- onSubmit();
256
- }
257
- else if (e.key === 'Escape') {
258
- e.preventDefault();
259
- onCancel();
260
- }
261
- else if (e.key === 'ArrowLeft' ||
262
- e.key === 'ArrowRight' ||
263
- e.key === ' ') {
264
- // Stop propagation to prevent tab navigation while editing
265
- e.stopPropagation();
266
- }
267
- });
268
- const handleBlur = useEvent(() => {
269
- // Ignore blur events immediately after entering edit mode (menu closing causes focus loss)
270
- if (justEnteredEditModeRef.current) {
271
- // Re-focus the input since something else stole focus
272
- requestAnimationFrame(() => {
273
- inputRef.current?.focus();
274
- inputRef.current?.select();
275
- });
276
- return;
277
- }
278
- // Submit on blur (per user preference)
279
- onSubmit();
280
- });
281
- const handleDoubleClick = useEvent((e) => {
282
- e.preventDefault();
283
- e.stopPropagation();
284
- onStartEditing();
285
- });
286
- if (isEditing) {
287
- // Merge our handlers with React Aria's inputProps
288
- const mergedProps = {
289
- ...inputProps,
290
- onKeyDown: (e) => {
291
- handleKeyDown(e);
292
- inputProps.onKeyDown?.(e);
293
- },
294
- onBlur: (e) => {
295
- handleBlur();
296
- inputProps.onBlur?.(e);
297
- },
298
- };
299
- return (_jsxs(_Fragment, { children: [_jsx(HiddenMeasure, { ref: measureRef, "aria-hidden": "true", children: editValue || ' ' }), _jsx(EditableTitleInputElement, { ...mergedProps, ref: inputRef, tokens: { '$input-width': inputWidth ? `${inputWidth}px` : 'auto' } })] }));
300
- }
301
- return _jsx("span", { onDoubleClick: handleDoubleClick, children: title });
302
- }
303
- const TabPanelElement = tasty({
304
- as: 'section',
305
- styles: {
306
- display: 'contents',
307
- },
308
- });
309
- const TabIndicatorElement = tasty({
310
- styles: {
311
- position: 'absolute',
312
- bottom: '0',
313
- left: 0,
314
- height: '1ow',
315
- fill: '#purple',
316
- transition: 'left, width',
317
- transitionDuration: '.2s',
318
- transitionTimingFunction: 'ease-out',
319
- pointerEvents: 'none',
320
- },
321
- });
322
- /**
323
- * Hook to track and animate tab indicator position.
324
- * Returns null if disabled (e.g., for non-default types).
325
- */
326
- function useTabIndicator(containerRef, selectedKey, enabled) {
327
- const [style, setStyle] = useState(null);
328
- const cancelRef = useRef(null);
329
- const updateIndicator = useCallback(() => {
330
- if (!enabled || !containerRef.current || selectedKey == null) {
331
- setStyle(null);
332
- return;
333
- }
334
- // Find the selected tab button within the container
335
- const selectedTab = containerRef.current.querySelector('[aria-selected="true"]');
336
- if (!selectedTab) {
337
- setStyle(null);
338
- return;
339
- }
340
- const containerRect = containerRef.current.getBoundingClientRect();
341
- const tabRect = selectedTab.getBoundingClientRect();
342
- // Only update if dimensions are valid (element has been painted)
343
- if (tabRect.width > 0) {
344
- setStyle({
345
- left: tabRect.left - containerRect.left + containerRef.current.scrollLeft,
346
- width: tabRect.width,
347
- });
348
- }
349
- }, [containerRef, selectedKey, enabled]);
350
- // Update on selectedKey change - use chainRaf to ensure DOM is fully painted
351
- useLayoutEffect(() => {
352
- // Cancel any pending RAF chain
353
- if (cancelRef.current) {
354
- cancelRef.current();
355
- }
356
- // Schedule update after 2 frames to ensure layout is complete
357
- cancelRef.current = chainRaf(() => {
358
- updateIndicator();
359
- }, 2);
360
- return () => {
361
- if (cancelRef.current) {
362
- cancelRef.current();
363
- }
364
- };
365
- }, [updateIndicator]);
366
- // Update on window resize
367
- useEffect(() => {
368
- if (!enabled)
369
- return;
370
- const handleResize = () => updateIndicator();
371
- window.addEventListener('resize', handleResize);
372
- return () => window.removeEventListener('resize', handleResize);
373
- }, [enabled, updateIndicator]);
374
- return enabled ? style : null;
375
- }
376
- // =============================================================================
377
- // Helper Functions
378
- // =============================================================================
379
- /**
380
- * Checks if a child is a Tab component.
381
- */
382
- function isTabElement(child) {
383
- return (isValidElement(child) &&
384
- typeof child.type === 'function' &&
385
- child.type.displayName === 'CubeTab');
386
- }
387
- /**
388
- * Checks if a child is a TabPanel component.
389
- */
390
- function isTabPanelElement(child) {
391
- return (isValidElement(child) &&
392
- typeof child.type === 'function' &&
393
- child.type.displayName === 'CubeTabPanel');
394
- }
395
- /**
396
- * Checks if a child is a TabList component.
397
- */
398
- function isTabListElement(child) {
399
- return (isValidElement(child) &&
400
- typeof child.type === 'function' &&
401
- child.type.displayName === 'CubeTabList');
402
- }
403
- /**
404
- * Extracts the raw key from a React child (strips the ".$" prefix added by Children.map).
405
- *
406
- * Note: All keys are converted to strings for React Aria compatibility.
407
- * This means numeric keys like `key={1}` become `"1"`.
408
- *
409
- * @returns The key as a string, or null if no key is present
410
- */
411
- function getRawKey(child) {
412
- if (child.key == null)
413
- return null;
414
- const keyStr = String(child.key);
415
- // React prefixes keys with ".$" in Children.map
416
- if (keyStr.startsWith('.$')) {
417
- return keyStr.slice(2);
418
- }
419
- return keyStr;
420
- }
421
- // =============================================================================
422
- // Tab Component (for building items)
423
- // =============================================================================
424
- function Tab(_props) {
425
- // This component is never rendered directly - it's used for configuration
426
- // The actual rendering happens in TabButton
427
- return null;
428
- }
429
- Tab.displayName = 'CubeTab';
430
- function TabButton({ item, state, tabData, type, size, onDelete, showActionsOnHover: parentShowActionsOnHover, isEditing = false, editValue = '', onEditValueChange, onStartEditing, onSubmitEditing, onCancelEditing, }) {
431
- const ref = useRef(null);
432
- const { tabProps } = useTab({ key: item.key }, state, ref);
433
- const isActive = state.selectedKey === item.key;
434
- const isDisabled = state.disabledKeys.has(item.key);
435
- const isDeletable = !!onDelete;
436
- const isEditable = tabData.isEditable ?? false;
437
- const effectiveType = tabData.type ?? type ?? 'default';
438
- const handleDelete = useEvent(() => {
439
- onDelete?.(item.key);
440
- });
441
- const handleStartEditing = useEvent(() => {
442
- if (!isEditable || isDisabled)
443
- return;
444
- const titleText = typeof tabData.title === 'string' ? tabData.title : String(item.key);
445
- onStartEditing?.(item.key, titleText);
446
- });
447
- const handleSubmitEditing = useEvent(() => {
448
- onSubmitEditing?.(item.key, editValue, tabData.onTitleChange);
449
- });
450
- const handleCancelEditing = useEvent(() => {
451
- onCancelEditing?.();
452
- });
453
- const handleEditValueChange = useEvent((value) => {
454
- onEditValueChange?.(value);
455
- });
456
- const mods = useMemo(() => ({
457
- default: effectiveType === 'default',
458
- panel: effectiveType === 'panel',
459
- radio: effectiveType === 'radio',
460
- active: isActive,
461
- deletable: isDeletable,
462
- disabled: isDisabled,
463
- editing: isEditing,
464
- }), [effectiveType, isActive, isDeletable, isDisabled, isEditing]);
465
- // Scroll active tab into view
466
- useEffect(() => {
467
- if (ref.current && isActive) {
468
- ref.current.scrollIntoView?.({ block: 'nearest', inline: 'nearest' });
469
- }
470
- }, [isActive]);
471
- // Build actions for the tab (custom actions + delete button)
472
- const deleteAction = isDeletable ? (_jsx(ItemAction, { icon: _jsx(CloseIcon, {}), tooltip: "Delete tab", onPress: handleDelete })) : null;
473
- // Combine tab's custom actions with delete action
474
- const actions = tabData.actions || deleteAction ? (_jsxs(_Fragment, { children: [tabData.actions, deleteAction] })) : undefined;
475
- // Determine effective size - map 'medium'/'large' to Item size values
476
- const isRadioType = effectiveType === 'radio';
477
- const isPanelType = effectiveType === 'panel';
478
- const isDefaultType = effectiveType === 'default';
479
- const effectiveSize = tabData.size ?? size ?? 'medium';
480
- // For radio type, use smaller sizes like RadioGroup tabs mode
481
- let itemSize;
482
- if (isRadioType) {
483
- // Map sizes similar to RadioGroup tabs mode
484
- if (effectiveSize === 'medium') {
485
- itemSize = 'xsmall';
486
- }
487
- else {
488
- // large -> medium
489
- itemSize = 'medium';
490
- }
491
- }
492
- else {
493
- itemSize = effectiveSize === 'large' ? 'large' : 'medium';
494
- }
495
- // Determine which element to use based on type
496
- let Element;
497
- if (isRadioType) {
498
- Element = RadioTabElement;
499
- }
500
- else if (isDefaultType) {
501
- Element = CardTabElement;
502
- }
503
- else {
504
- Element = TabElement;
505
- }
506
- // Determine Item type prop
507
- let itemType = !isRadioType
508
- ? isActive
509
- ? 'clear'
510
- : 'neutral'
511
- : 'neutral';
512
- // Determine shape - panel type uses sharp edges
513
- const itemShape = isPanelType ? 'sharp' : undefined;
514
- // Determine showActionsOnHover - tab-level overrides parent-level
515
- const effectiveShowActionsOnHover = tabData.showActionsOnHover ?? parentShowActionsOnHover;
516
- // Render title with editing support if editable
517
- const titleContent = isEditable ? (_jsx(EditableTitle, { title: tabData.title, isEditing: isEditing, editValue: editValue, onEditValueChange: handleEditValueChange, onStartEditing: handleStartEditing, onSubmit: handleSubmitEditing, onCancel: handleCancelEditing })) : (tabData.title);
518
- // Extract tab-specific props and pass through the rest (style props) to the Item
519
- const { title: _title, content: _content, key: _key, isDisabled: _isDisabled, prerender: _prerender, keepMounted: _keepMounted, size: _size, type: _type, actions: _actions, showActionsOnHover: _showActionsOnHover, isEditable: _isEditable, onTitleChange: _onTitleChange, qa, qaVal, styles, ...itemStyleProps } = tabData;
520
- return (_jsx(TabContainer, { mods: mods, children: _jsx(Element, { preserveActionsSpace: true, showActionsOnHover: effectiveShowActionsOnHover, as: "button", ...tabProps, ...itemStyleProps, ref: ref, qa: qa ?? `Tab-${String(item.key)}`, qaVal: qaVal, styles: styles, mods: mods, isSelected: isActive, isDisabled: isDisabled, size: itemSize, type: itemType, shape: itemShape, actions: actions, children: titleContent }) }));
521
- }
522
- function TabPanelRenderer({ tabKey, state, content, prerender, keepMounted, tabPrerender, tabKeepMounted, visitedKeys, panelStyles, qa, qaVal, }) {
523
- const ref = useRef(null);
524
- const { tabPanelProps } = useTabPanel({ key: tabKey }, state, ref);
525
- const isActive = state.selectedKey === tabKey;
526
- // Determine effective prerender/keepMounted (tab-level overrides global)
527
- const effectivePrerender = tabPrerender ?? prerender;
528
- const effectiveKeepMounted = tabKeepMounted ?? keepMounted;
529
- // Determine if panel should render using shared utility
530
- if (!shouldRenderPanel(isActive, visitedKeys.has(tabKey), effectivePrerender, effectiveKeepMounted)) {
531
- return null;
532
- }
533
- return (_jsx(TabPanelElement, { ...tabPanelProps, ref: ref, qa: qa ?? 'TabPanel', qaVal: qaVal ?? String(tabKey), styles: panelStyles, style: {
534
- display: isActive ? 'contents' : 'none',
535
- }, children: content }));
536
- }
537
- /**
538
- * Determines if a panel should be rendered based on prerender/keepMounted settings.
539
- */
540
- function shouldRenderPanel(isActive, wasVisited, effectivePrerender, effectiveKeepMounted) {
541
- return (!!effectivePrerender || isActive || (!!effectiveKeepMounted && wasVisited));
542
- }
543
- /**
544
- * Renders panels with optional content caching.
545
- * Only the content from renderPanel is cached - the TabPanelRenderer wrapper
546
- * is always rendered fresh so it can correctly determine the active state.
547
- *
548
- * Caching behavior:
549
- * - By default, panels re-render on every Tabs render (no caching)
550
- * - When a panel has a non-undefined cache key in `panelCacheKeys`, caching is enabled
551
- * - Cached content is reused until the cache key changes
552
- * - Setting a cache key to `undefined` is the same as not having it (no caching)
553
- */
554
- function CachedPanelRenderer({ parsedTabs, explicitPanels, state, renderPanel, panelCacheKeys, prerender, keepMounted, visitedKeys, }) {
555
- // Cache for rendered content - stores { content, cacheKey } per panel
556
- const contentCacheRef = useRef(new Map());
557
- /**
558
- * Get the cache key for a panel.
559
- * Returns undefined if no cache key is defined or if set to undefined (no caching).
560
- */
561
- const getCacheKey = (key) => {
562
- if (!panelCacheKeys)
563
- return undefined;
564
- if (Object.prototype.hasOwnProperty.call(panelCacheKeys, key)) {
565
- const value = panelCacheKeys[key];
566
- // undefined means no caching
567
- return value;
568
- }
569
- return undefined;
570
- };
571
- /**
572
- * Check if a panel has caching enabled.
573
- * Only enabled when a non-undefined cache key is defined.
574
- */
575
- const hasCacheKey = (key) => {
576
- if (!panelCacheKeys)
577
- return false;
578
- if (!Object.prototype.hasOwnProperty.call(panelCacheKeys, key))
579
- return false;
580
- // undefined value means no caching
581
- return panelCacheKeys[key] !== undefined;
582
- };
583
- // Clean up cache entries for removed tabs
584
- const currentTabKeys = useMemo(() => new Set(parsedTabs.map((t) => t.key)), [parsedTabs]);
585
- // Use effect to clean up stale cache entries when tabs change
586
- useEffect(() => {
587
- for (const key of contentCacheRef.current.keys()) {
588
- if (!currentTabKeys.has(key)) {
589
- contentCacheRef.current.delete(key);
590
- }
591
- }
592
- }, [currentTabKeys]);
593
- return (_jsx(_Fragment, { children: parsedTabs.map((tab) => {
594
- const explicitPanel = explicitPanels.get(tab.key);
595
- const tabPrerender = explicitPanel?.prerender ?? tab.prerender;
596
- const tabKeepMounted = explicitPanel?.keepMounted ?? tab.keepMounted;
597
- const effectivePrerender = tabPrerender ?? prerender;
598
- const effectiveKeepMounted = tabKeepMounted ?? keepMounted;
599
- const isActive = state.selectedKey === tab.key;
600
- const wasVisited = visitedKeys.has(tab.key);
601
- if (!shouldRenderPanel(isActive, wasVisited, effectivePrerender, effectiveKeepMounted)) {
602
- return null;
603
- }
604
- // Check if this panel has caching enabled
605
- const isCachingEnabled = hasCacheKey(tab.key);
606
- let content;
607
- if (isCachingEnabled) {
608
- // Caching is enabled for this panel - check cache
609
- const currentCacheKey = getCacheKey(tab.key);
610
- const cached = contentCacheRef.current.get(tab.key);
611
- // Cache hit if keys match (currentCacheKey is guaranteed non-undefined here)
612
- if (cached !== undefined && cached.cacheKey === currentCacheKey) {
613
- // Cache hit - use cached content
614
- content = cached.content;
615
- }
616
- else {
617
- // Cache miss or key changed - compute fresh and cache
618
- content = renderPanel(tab.key);
619
- contentCacheRef.current.set(tab.key, {
620
- content,
621
- cacheKey: currentCacheKey,
622
- });
623
- }
624
- }
625
- else {
626
- // No caching - always compute fresh
627
- content = renderPanel(tab.key);
628
- // Clear any stale cache entry
629
- contentCacheRef.current.delete(tab.key);
630
- }
631
- return (_jsx(TabPanelRenderer, { tabKey: tab.key, state: state, content: content, prerender: prerender, keepMounted: keepMounted, tabPrerender: tabPrerender, tabKeepMounted: tabKeepMounted, visitedKeys: visitedKeys, panelStyles: explicitPanel?.styles, qa: explicitPanel?.qa, qaVal: explicitPanel?.qaVal }, tab.key));
632
- }) }));
633
- }
634
- // =============================================================================
635
- // TabPanel Component (for explicit panel API)
636
- // =============================================================================
637
- function TabPanel(_props) {
638
- // This component is never rendered directly - it's used for configuration
639
- return null;
640
- }
641
- TabPanel.displayName = 'CubeTabPanel';
642
- // =============================================================================
643
- // TabList Component (for explicit list API)
644
- // =============================================================================
645
- function TabList(_props) {
646
- // This component is never rendered directly - it's used for configuration
647
- return null;
648
- }
649
- TabList.displayName = 'CubeTabList';
650
- // =============================================================================
651
- // Main Tabs Component
652
- // =============================================================================
653
- function TabsComponent(props, ref) {
654
- const { label = 'Tabs', defaultActiveKey, activeKey, size, type = 'default', onChange, onDelete, onTitleChange, showActionsOnHover, children, styles, prefix, suffix, prerender = false, keepMounted = false, qa = 'Tabs', renderPanel, panelCacheKeys, } = props;
655
- // Register CSS properties for fade animation
656
- useProperty('--tabs-fade-left', { syntax: '<length>', initialValue: '0px' });
657
- useProperty('--tabs-fade-right', { syntax: '<length>', initialValue: '0px' });
658
- // DOM element ref (separate from imperative handle ref)
659
- const elementRef = useRef(null);
660
- const listRef = useRef(null);
661
- const scrollRef = useRef(null);
662
- // Track visited tabs for keepMounted functionality
663
- const visitedKeysRef = useRef(new Set());
664
- // =========================================================================
665
- // Tab Title Editing State
666
- // =========================================================================
667
- const [editingKey, setEditingKey] = useState(null);
668
- const [editValue, setEditValue] = useState('');
669
- const startEditing = useCallback((key, currentTitle) => {
670
- // Also select the tab being edited
671
- onChange?.(key);
672
- chainRaf(() => {
673
- setEditingKey(key);
674
- setEditValue(currentTitle);
675
- }, 2);
676
- }, [onChange]);
677
- const cancelEditing = useCallback(() => {
678
- setEditingKey(null);
679
- setEditValue('');
680
- }, []);
681
- const submitEditing = useCallback((key, newTitle, tabOnTitleChange) => {
682
- const trimmed = newTitle.trim();
683
- if (trimmed) {
684
- // Tab-level callback takes precedence
685
- if (tabOnTitleChange) {
686
- tabOnTitleChange(trimmed);
687
- }
688
- else if (onTitleChange) {
689
- onTitleChange(key, trimmed);
690
- }
691
- }
692
- setEditingKey(null);
693
- setEditValue('');
694
- }, [onTitleChange]);
695
- // Parse children to extract tabs and explicit panels
696
- const { parsedTabs, explicitPanels, hasAnyContent } = useMemo(() => {
697
- const childArray = Children.toArray(children);
698
- const tabs = [];
699
- const panels = new Map();
700
- let hasExplicitList = false;
701
- let tabChildren = [];
702
- // Check for explicit Tabs.List / Tabs.Panel structure
703
- for (const child of childArray) {
704
- if (isTabListElement(child)) {
705
- hasExplicitList = true;
706
- tabChildren = Children.toArray(child.props.children);
707
- }
708
- else if (isTabPanelElement(child)) {
709
- const key = getRawKey(child);
710
- if (key != null) {
711
- panels.set(key, {
712
- key,
713
- content: child.props.children,
714
- prerender: child.props.prerender,
715
- keepMounted: child.props.keepMounted,
716
- styles: child.props.styles,
717
- qa: child.props.qa,
718
- qaVal: child.props.qaVal,
719
- });
720
- }
721
- }
722
- }
723
- // If no explicit list, use direct Tab children
724
- if (!hasExplicitList) {
725
- tabChildren = childArray;
726
- }
727
- // Parse Tab elements
728
- let hasContent = panels.size > 0;
729
- for (const child of tabChildren) {
730
- if (isTabElement(child)) {
731
- // Get key from the element's key prop or id prop (convert to string)
732
- const key = getRawKey(child) ?? child.props.id;
733
- if (key != null) {
734
- const { id: _id, children: tabChildren, ...tabProps } = child.props;
735
- tabs.push({
736
- ...tabProps,
737
- key,
738
- content: tabChildren,
739
- });
740
- if (tabChildren != null) {
741
- hasContent = true;
742
- }
743
- }
744
- }
745
- }
746
- return {
747
- parsedTabs: tabs,
748
- explicitPanels: panels,
749
- hasAnyContent: hasContent,
750
- };
751
- }, [children]);
752
- // Clean up visitedKeys when tabs are removed
753
- const currentTabKeysSet = useMemo(() => new Set(parsedTabs.map((t) => t.key)), [parsedTabs]);
754
- useEffect(() => {
755
- for (const key of visitedKeysRef.current) {
756
- if (!currentTabKeysSet.has(key)) {
757
- visitedKeysRef.current.delete(key);
758
- }
759
- }
760
- }, [currentTabKeysSet]);
761
- // Create collection items for React Stately
762
- const collectionItems = useMemo(() => {
763
- return parsedTabs.map((tab) => (_jsx(CollectionItem, { textValue: typeof tab.title === 'string' ? tab.title : String(tab.key), children: tab.title }, tab.key)));
764
- }, [parsedTabs]);
765
- // Create a lookup map for tab data
766
- const tabDataMap = useMemo(() => {
767
- const map = new Map();
768
- for (const tab of parsedTabs) {
769
- map.set(tab.key, tab);
770
- }
771
- return map;
772
- }, [parsedTabs]);
773
- // Expose ref API for programmatic control (separate from DOM ref)
774
- useImperativeHandle(ref, () => ({
775
- element: elementRef.current,
776
- startEditing: (key) => {
777
- // Convert key to string for internal lookup
778
- const keyStr = String(key);
779
- const tabData = tabDataMap.get(keyStr);
780
- if (tabData?.isEditable) {
781
- const titleText = typeof tabData.title === 'string'
782
- ? tabData.title
783
- : String(tabData.key);
784
- startEditing(keyStr, titleText);
785
- }
786
- },
787
- cancelEditing,
788
- }), [tabDataMap, startEditing, cancelEditing]);
789
- // Determine disabled keys
790
- const disabledKeys = useMemo(() => {
791
- return new Set(parsedTabs.filter((tab) => tab.isDisabled).map((tab) => tab.key));
792
- }, [parsedTabs]);
793
- // Handle selection change
794
- const handleSelectionChange = useEvent((key) => {
795
- // Convert to string for internal tracking
796
- visitedKeysRef.current.add(String(key));
797
- onChange?.(key);
798
- });
799
- // Create aria props for useTabListState
800
- const ariaProps = useMemo(() => ({
801
- selectedKey: activeKey,
802
- defaultSelectedKey: defaultActiveKey,
803
- onSelectionChange: handleSelectionChange,
804
- disabledKeys,
805
- children: collectionItems,
806
- 'aria-label': label,
807
- }), [
808
- activeKey,
809
- defaultActiveKey,
810
- handleSelectionChange,
811
- disabledKeys,
812
- collectionItems,
813
- label,
814
- ]);
815
- // Create state using useTabListState
816
- const state = useTabListState(ariaProps);
817
- // Track initial selected key for visited tabs
818
- useEffect(() => {
819
- if (state.selectedKey != null) {
820
- visitedKeysRef.current.add(String(state.selectedKey));
821
- }
822
- }, [state.selectedKey]);
823
- // Get tablist props from react-aria
824
- const { tabListProps } = useTabList(ariaProps, state, listRef);
825
- // Tab indicator for default type
826
- const indicatorStyle = useTabIndicator(listRef, state.selectedKey, type === 'default');
827
- // Tiny scrollbar for horizontal scrolling (not for radio type)
828
- const isTinyScrollbar = type !== 'radio';
829
- const { handleHStyle, hasOverflowX, isScrolling, isAtStartX, isAtEndX } = useTinyScrollbar(scrollRef, isTinyScrollbar);
830
- const mods = useMemo(() => ({
831
- type,
832
- deletable: !!onDelete,
833
- scrolling: isScrolling,
834
- 'fade-left': !isAtStartX,
835
- 'fade-right': !isAtEndX,
836
- }), [type, onDelete, isScrolling, isAtStartX, isAtEndX]);
837
- return (_jsxs(_Fragment, { children: [_jsxs(TabsElement, { ref: elementRef, qa: qa, mods: mods, styles: styles, style: handleHStyle, "data-size": size, children: [prefix ? _jsx("div", { "data-element": "Prefix", children: prefix }) : null, _jsxs("div", { "data-element": "ScrollWrapper", children: [_jsx("div", { ref: scrollRef, "data-element": "Scroll", children: _jsxs("div", { ...tabListProps, ref: listRef, "data-element": "Container", children: [[...state.collection].map((item) => {
838
- // Convert item.key to string for internal lookup
839
- const tabData = tabDataMap.get(String(item.key));
840
- if (!tabData)
841
- return null;
842
- const isItemEditing = editingKey === item.key;
843
- return (_jsx(TabButton, { item: item, state: state, tabData: tabData, type: type, size: size, showActionsOnHover: showActionsOnHover, isEditing: isItemEditing, editValue: isItemEditing ? editValue : '', onDelete: onDelete, onEditValueChange: setEditValue, onStartEditing: startEditing, onSubmitEditing: submitEditing, onCancelEditing: cancelEditing }, item.key));
844
- }), indicatorStyle && (_jsx(TabIndicatorElement, { style: {
845
- left: indicatorStyle.left,
846
- width: indicatorStyle.width,
847
- } }))] }) }), isTinyScrollbar && hasOverflowX && _jsx("div", { "data-element": "ScrollbarH" })] }), suffix ? _jsx("div", { "data-element": "Suffix", children: suffix }) : null] }), renderPanel && (_jsx(CachedPanelRenderer, { parsedTabs: parsedTabs, explicitPanels: explicitPanels, state: state, renderPanel: renderPanel, panelCacheKeys: panelCacheKeys, prerender: prerender, keepMounted: keepMounted, visitedKeys: visitedKeysRef.current })), !renderPanel &&
848
- hasAnyContent &&
849
- parsedTabs.map((tab) => {
850
- // Use explicit panel if provided, otherwise use tab's content
851
- const explicitPanel = explicitPanels.get(tab.key);
852
- const content = explicitPanel?.content ?? tab.content;
853
- if (content == null)
854
- return null;
855
- return (_jsx(TabPanelRenderer, { tabKey: tab.key, state: state, content: content, prerender: prerender, keepMounted: keepMounted, tabPrerender: explicitPanel?.prerender ?? tab.prerender, tabKeepMounted: explicitPanel?.keepMounted ?? tab.keepMounted, visitedKeys: visitedKeysRef.current, panelStyles: explicitPanel?.styles, qa: explicitPanel?.qa, qaVal: explicitPanel?.qaVal }, tab.key));
856
- })] }));
857
- }
858
- // =============================================================================
859
- // Exports
860
- // =============================================================================
861
- const _Tabs = forwardRef(TabsComponent);
862
- /**
863
- * Tabs component for organizing content into multiple panels.
864
- * Built with React Aria for full accessibility support.
865
- *
866
- * **Note:** Tab keys are internally converted to strings for React Aria compatibility.
867
- * When using `activeKey`, `onChange`, etc., be aware that numeric keys will be
868
- * converted to their string equivalents.
869
- *
870
- * @example
871
- * // Simple usage
872
- * <Tabs defaultActiveKey="tab1">
873
- * <Tab key="tab1" title="Tab 1">Content 1</Tab>
874
- * <Tab key="tab2" title="Tab 2">Content 2</Tab>
875
- * </Tabs>
876
- *
877
- * @example
878
- * // Tabs-only (no panels)
879
- * <Tabs activeKey={activeTab} onChange={setActiveTab}>
880
- * <Tab key="overview" title="Overview" />
881
- * <Tab key="settings" title="Settings" />
882
- * </Tabs>
883
- *
884
- * @example
885
- * // Explicit panels
886
- * <Tabs defaultActiveKey="tab1">
887
- * <Tabs.List>
888
- * <Tab key="tab1" title="Tab 1" />
889
- * <Tab key="tab2" title="Tab 2" />
890
- * </Tabs.List>
891
- * <Tabs.Panel key="tab1">Content 1</Tabs.Panel>
892
- * <Tabs.Panel key="tab2">Content 2</Tabs.Panel>
893
- * </Tabs>
894
- *
895
- * @example
896
- * // Optimized lazy rendering with renderPanel
897
- * <Tabs
898
- * defaultActiveKey="tab1"
899
- * renderPanel={(key) => {
900
- * switch (key) {
901
- * case 'tab1': return <ExpensiveComponent />;
902
- * case 'tab2': return <AnotherExpensive />;
903
- * default: return null;
904
- * }
905
- * }}
906
- * >
907
- * <Tab key="tab1" title="Tab 1" />
908
- * <Tab key="tab2" title="Tab 2" />
909
- * </Tabs>
910
- */
911
- export const Tabs = Object.assign(_Tabs, {
912
- Tab,
913
- List: TabList,
914
- Panel: TabPanel,
915
- });
916
- export { Tab, TabList, TabPanel };
917
-
918
-