@cube-dev/ui-kit 0.101.0 → 0.103.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +58 -0
- package/es/_internal/hooks/index.js +1 -1
- package/es/_internal/hooks/use-chained-callback.js +1 -1
- package/es/_internal/hooks/use-debounced-value.js +1 -1
- package/es/_internal/hooks/use-deprecation-warning.js +1 -1
- package/es/_internal/hooks/use-effect-once.js +1 -1
- package/es/_internal/hooks/use-event.js +1 -1
- package/es/_internal/hooks/use-is-first-render.js +1 -1
- package/es/_internal/hooks/use-sync-ref.js +1 -1
- package/es/_internal/hooks/use-timer/index.js +1 -1
- package/es/_internal/hooks/use-timer/timer.js +1 -1
- package/es/_internal/hooks/use-timer/use-timer.js +1 -1
- package/es/_internal/hooks/use-update-effect.js +1 -1
- package/es/_internal/hooks/use-warn.js +1 -1
- package/es/_internal/index.js +1 -1
- package/es/components/Block.js +1 -1
- package/es/components/CollectionItem.js +1 -1
- package/es/components/GlobalStyles.js +1 -1
- package/es/components/GridProvider.js +1 -1
- package/es/components/HiddenInput.js +1 -1
- package/es/components/OpenTrasition.js +1 -1
- package/es/components/Root.js +1 -1
- package/es/components/actions/Action/Action.js +1 -1
- package/es/components/actions/Button/Button.js +1 -1
- package/es/components/actions/Button/index.js +1 -1
- package/es/components/actions/ButtonGroup/ButtonGroup.js +1 -1
- package/es/components/actions/CommandMenu/CommandMenu.js +1 -1
- package/es/components/actions/CommandMenu/index.js +1 -1
- package/es/components/actions/CommandMenu/styled.js +1 -1
- package/es/components/actions/ItemAction/ItemAction.js +1 -1
- package/es/components/actions/ItemAction/index.js +1 -1
- package/es/components/actions/ItemActionContext.js +1 -1
- package/es/components/actions/ItemButton/ItemButton.js +1 -1
- package/es/components/actions/ItemButton/index.js +1 -1
- package/es/components/actions/Link/Link.js +1 -1
- package/es/components/actions/Menu/Menu.js +1 -1
- package/es/components/actions/Menu/MenuItem.js +1 -1
- package/es/components/actions/Menu/MenuSection.js +1 -1
- package/es/components/actions/Menu/MenuTrigger.js +1 -1
- package/es/components/actions/Menu/SubMenuTrigger.js +1 -1
- package/es/components/actions/Menu/SubmenuTriggerContext.js +1 -1
- package/es/components/actions/Menu/context.js +1 -1
- package/es/components/actions/Menu/index.js +1 -1
- package/es/components/actions/Menu/styled.js +1 -1
- package/es/components/actions/index.js +1 -1
- package/es/components/actions/use-action.js +1 -1
- package/es/components/actions/use-anchored-menu.js +1 -1
- package/es/components/actions/use-context-menu.js +1 -1
- package/es/components/content/ActiveZone/ActiveZone.js +1 -1
- package/es/components/content/Alert/Alert.js +1 -1
- package/es/components/content/Alert/index.js +1 -1
- package/es/components/content/Alert/types.js +1 -1
- package/es/components/content/Alert/use-alert.js +1 -1
- package/es/components/content/Avatar/Avatar.js +1 -1
- package/es/components/content/Badge/Badge.js +1 -1
- package/es/components/content/Card/Card.js +2 -2
- package/es/components/content/Content.js +1 -1
- package/es/components/content/CopyPasteBlock/CopyPasteBlock.js +1 -1
- package/es/components/content/CopyPasteBlock/index.js +1 -1
- package/es/components/content/CopySnippet/CopySnippet.js +1 -1
- package/es/components/content/CopySnippet/index.js +1 -1
- package/es/components/content/Disclosure/Disclosure.js +1 -1
- package/es/components/content/Disclosure/index.js +1 -1
- package/es/components/content/Divider.js +3 -3
- package/es/components/content/Footer.js +1 -1
- package/es/components/content/Header.js +1 -1
- package/es/components/content/HotKeys/HotKeys.js +1 -1
- package/es/components/content/HotKeys/index.js +1 -1
- package/es/components/content/Item/Item.js +7 -5
- package/es/components/content/Item/index.js +1 -1
- package/es/components/content/ItemBadge/ItemBadge.js +1 -1
- package/es/components/content/ItemBadge/index.js +1 -1
- package/es/components/content/Layout/GridLayout.js +1 -1
- package/es/components/content/Layout/Layout.js +2 -2
- package/es/components/content/Layout/LayoutBlock.js +1 -1
- package/es/components/content/Layout/LayoutCenter.js +1 -1
- package/es/components/content/Layout/LayoutContainer.js +1 -1
- package/es/components/content/Layout/LayoutContent.js +1 -1
- package/es/components/content/Layout/LayoutContext.js +1 -1
- package/es/components/content/Layout/LayoutFlex.js +1 -1
- package/es/components/content/Layout/LayoutFooter.js +1 -1
- package/es/components/content/Layout/LayoutGrid.js +1 -1
- package/es/components/content/Layout/LayoutHeader.js +1 -1
- package/es/components/content/Layout/LayoutPane.js +1 -1
- package/es/components/content/Layout/LayoutPanel.js +2 -2
- package/es/components/content/Layout/LayoutPanelHeader.js +1 -1
- package/es/components/content/Layout/LayoutToolbar.js +1 -1
- package/es/components/content/Layout/hooks/useTinyScrollbar.js +1 -1
- package/es/components/content/Layout/index.js +1 -1
- package/es/components/content/Layout/utils.js +1 -1
- package/es/components/content/List/SectionHeading.js +1 -1
- package/es/components/content/List/index.js +1 -1
- package/es/components/content/Paragraph.js +1 -1
- package/es/components/content/Placeholder/Placeholder.js +1 -1
- package/es/components/content/PrismCode/PrismCode.js +1 -1
- package/es/components/content/PrismCode/prismSetup.js +1 -1
- package/es/components/content/PrismDiffCode/PrismDiffCode.js +1 -1
- package/es/components/content/Result/Result.js +2 -2
- package/es/components/content/Skeleton/Skeleton.js +1 -1
- package/es/components/content/Tag/Tag.js +1 -1
- package/es/components/content/Text.js +1 -1
- package/es/components/content/TextItem/TextItem.js +1 -1
- package/es/components/content/TextItem/index.js +1 -1
- package/es/components/content/Title.js +1 -1
- package/es/components/content/highlightText.js +1 -1
- package/es/components/content/use-auto-tooltip.js +1 -1
- package/es/components/fields/Checkbox/Checkbox.js +2 -2
- package/es/components/fields/Checkbox/CheckboxGroup.js +1 -1
- package/es/components/fields/Checkbox/context.js +1 -1
- package/es/components/fields/Checkbox/index.js +1 -1
- package/es/components/fields/ComboBox/ComboBox.js +1 -1
- package/es/components/fields/ComboBox/index.js +1 -1
- package/es/components/fields/DatePicker/DateInput.js +1 -1
- package/es/components/fields/DatePicker/DateInputBase.js +1 -1
- package/es/components/fields/DatePicker/DatePicker.js +1 -1
- package/es/components/fields/DatePicker/DatePickerButton.js +1 -1
- package/es/components/fields/DatePicker/DatePickerElement.js +1 -1
- package/es/components/fields/DatePicker/DatePickerInput.js +1 -1
- package/es/components/fields/DatePicker/DatePickerSegment.js +1 -1
- package/es/components/fields/DatePicker/DateRangePicker.js +1 -1
- package/es/components/fields/DatePicker/DateRangeSeparatedPicker.js +1 -1
- package/es/components/fields/DatePicker/TimeInput.js +1 -1
- package/es/components/fields/DatePicker/index.js +1 -1
- package/es/components/fields/DatePicker/intl.js +1 -1
- package/es/components/fields/DatePicker/parseDate.js +1 -1
- package/es/components/fields/DatePicker/props.js +1 -1
- package/es/components/fields/DatePicker/types.js +1 -1
- package/es/components/fields/DatePicker/utils.js +1 -1
- package/es/components/fields/FileInput/FileInput.js +1 -1
- package/es/components/fields/FilterListBox/FilterListBox.js +1 -1
- package/es/components/fields/FilterListBox/index.js +1 -1
- package/es/components/fields/FilterPicker/FilterPicker.js +1 -1
- package/es/components/fields/FilterPicker/index.js +1 -1
- package/es/components/fields/Input/Input.js +1 -1
- package/es/components/fields/Input/index.js +1 -1
- package/es/components/fields/ListBox/ListBox.js +1 -1
- package/es/components/fields/ListBox/index.js +1 -1
- package/es/components/fields/NumberInput/NumberInput.js +1 -1
- package/es/components/fields/NumberInput/StepButton.js +1 -1
- package/es/components/fields/PasswordInput/PasswordInput.js +1 -1
- package/es/components/fields/Picker/Picker.js +1 -1
- package/es/components/fields/Picker/index.js +1 -1
- package/es/components/fields/RadioGroup/Radio.js +2 -2
- package/es/components/fields/RadioGroup/RadioGroup.js +1 -1
- package/es/components/fields/RadioGroup/context.js +1 -1
- package/es/components/fields/RadioGroup/index.js +1 -1
- package/es/components/fields/SearchInput/SearchInput.js +1 -1
- package/es/components/fields/SearchInput/index.js +1 -1
- package/es/components/fields/Select/Select.js +1 -1
- package/es/components/fields/Select/index.js +1 -1
- package/es/components/fields/Slider/Gradation.js +1 -1
- package/es/components/fields/Slider/Header.js +1 -1
- package/es/components/fields/Slider/RangeSlider.js +1 -1
- package/es/components/fields/Slider/Slider.js +1 -1
- package/es/components/fields/Slider/SliderBase.js +1 -1
- package/es/components/fields/Slider/SliderInput.js +1 -1
- package/es/components/fields/Slider/SliderThumb.js +1 -1
- package/es/components/fields/Slider/SliderTrack.js +1 -1
- package/es/components/fields/Slider/elements.js +1 -1
- package/es/components/fields/Slider/index.js +1 -1
- package/es/components/fields/Slider/types.js +1 -1
- package/es/components/fields/Switch/Switch.js +1 -1
- package/es/components/fields/Switch/index.js +1 -1
- package/es/components/fields/TextArea/TextArea.js +1 -1
- package/es/components/fields/TextArea/index.js +1 -1
- package/es/components/fields/TextInput/TextInput.js +1 -1
- package/es/components/fields/TextInput/TextInputBase.js +1 -1
- package/es/components/fields/TextInput/index.js +1 -1
- package/es/components/fields/TextInputMapper/TextInputMapper.js +1 -1
- package/es/components/fields/TextInputMapper/index.js +1 -1
- package/es/components/fields/index.js +1 -1
- package/es/components/form/FieldWrapper/FieldWrapper.js +1 -1
- package/es/components/form/FieldWrapper/extract-field-wrapper-props.js +1 -1
- package/es/components/form/FieldWrapper/index.js +1 -1
- package/es/components/form/FieldWrapper/types.js +1 -1
- package/es/components/form/Form/Field.js +1 -1
- package/es/components/form/Form/Form.js +1 -1
- package/es/components/form/Form/ResetButton/ResetButton.js +1 -1
- package/es/components/form/Form/ResetButton/index.js +1 -1
- package/es/components/form/Form/SubmitButton/SubmitButton.js +1 -1
- package/es/components/form/Form/SubmitButton/index.js +1 -1
- package/es/components/form/Form/SubmitError.js +1 -1
- package/es/components/form/Form/index.js +1 -1
- package/es/components/form/Form/types.js +1 -1
- package/es/components/form/Form/use-field/index.js +1 -1
- package/es/components/form/Form/use-field/types.js +1 -1
- package/es/components/form/Form/use-field/use-field-props.js +1 -1
- package/es/components/form/Form/use-field/use-field.js +1 -1
- package/es/components/form/Form/use-form.js +1 -1
- package/es/components/form/Form/validation.js +1 -1
- package/es/components/form/Label.js +1 -1
- package/es/components/form/index.js +1 -1
- package/es/components/form/wrapper.js +1 -1
- package/es/components/helpers/DisplayTransition/DisplayTransition.js +1 -1
- package/es/components/helpers/DisplayTransition/index.js +1 -1
- package/es/components/helpers/IconSwitch/IconSwitch.js +1 -1
- package/es/components/helpers/index.js +1 -1
- package/es/components/layout/Flex.js +1 -1
- package/es/components/layout/Flow.js +1 -1
- package/es/components/layout/Grid.js +1 -1
- package/es/components/layout/Panel.js +1 -1
- package/es/components/layout/Prefix.js +1 -1
- package/es/components/layout/ResizablePanel.js +2 -2
- package/es/components/layout/Space.js +1 -1
- package/es/components/layout/Suffix.js +1 -1
- package/es/components/navigation/Tabs/DraggableTabList.js +101 -0
- package/es/components/navigation/Tabs/EditableTitle.js +116 -0
- package/es/components/navigation/Tabs/TabButton.js +320 -0
- package/es/components/navigation/Tabs/TabDropIndicator.js +34 -0
- package/es/components/navigation/Tabs/TabPanel.js +128 -0
- package/es/components/navigation/Tabs/TabPicker.js +32 -0
- package/es/components/navigation/Tabs/Tabs.js +163 -706
- package/es/components/navigation/Tabs/TabsContext.js +29 -0
- package/es/components/navigation/Tabs/index.js +1 -1
- package/es/components/navigation/Tabs/styled.js +337 -0
- package/es/components/navigation/Tabs/types.js +17 -0
- package/es/components/navigation/Tabs/use-tab-editing.js +61 -0
- package/es/components/navigation/Tabs/use-tab-indicator.js +77 -0
- package/es/components/navigation/index.js +1 -1
- package/es/components/organisms/FileTabs/FileTabs.js +2 -2
- package/es/components/organisms/StatsCard/StatsCard.js +1 -1
- package/es/components/other/Calendar/Calendar.js +1 -1
- package/es/components/other/Calendar/CalendarCell.js +1 -1
- package/es/components/other/Calendar/CalendarGrid.js +1 -1
- package/es/components/other/Calendar/RangeCalendar.js +1 -1
- package/es/components/other/CloudLogo/CloudLogo.js +1 -1
- package/es/components/overlays/AlertDialog/AlertDialog.js +1 -1
- package/es/components/overlays/AlertDialog/AlertDialogApiProvider.js +1 -1
- package/es/components/overlays/AlertDialog/AlertDialogZone.js +1 -1
- package/es/components/overlays/AlertDialog/index.js +1 -1
- package/es/components/overlays/AlertDialog/types.js +1 -1
- package/es/components/overlays/Dialog/Dialog.js +1 -1
- package/es/components/overlays/Dialog/DialogContainer.js +1 -1
- package/es/components/overlays/Dialog/DialogForm.js +1 -1
- package/es/components/overlays/Dialog/DialogTrigger.js +1 -1
- package/es/components/overlays/Dialog/context.js +1 -1
- package/es/components/overlays/Dialog/index.js +1 -1
- package/es/components/overlays/Dialog/use-dialog-container.js +1 -1
- package/es/components/overlays/Modal/Modal.js +1 -1
- package/es/components/overlays/Modal/OpenTransition.js +1 -1
- package/es/components/overlays/Modal/Overlay.js +1 -1
- package/es/components/overlays/Modal/Popover.js +1 -1
- package/es/components/overlays/Modal/Tray.js +1 -1
- package/es/components/overlays/Modal/Underlay.js +1 -1
- package/es/components/overlays/Modal/index.js +1 -1
- package/es/components/overlays/Modal/types.js +1 -1
- package/es/components/overlays/NewNotifications/Bar/FloatingNotification.js +1 -1
- package/es/components/overlays/NewNotifications/Bar/NotificationsBar.js +1 -1
- package/es/components/overlays/NewNotifications/Bar/TransitionComponent.js +1 -1
- package/es/components/overlays/NewNotifications/Bar/index.js +1 -1
- package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogContext.js +1 -1
- package/es/components/overlays/NewNotifications/Dialog/NotificationsDialogTrigger.js +1 -1
- package/es/components/overlays/NewNotifications/Dialog/index.js +1 -1
- package/es/components/overlays/NewNotifications/Notification.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationAction.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationCloseButton.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationDescription.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationFooter.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationHeader.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationIcon.js +5 -5
- package/es/components/overlays/NewNotifications/NotificationView/NotificationProvider.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/NotificationView.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/index.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationView/types.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsContext.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsContext/NotificationsProvider.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsContext/index.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsContext/use-notifications.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsList/NotificationsList.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsList/NotificationsListItem.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsList/index.js +1 -1
- package/es/components/overlays/NewNotifications/NotificationsList/types.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/index.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/types.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/use-notification-list-item.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/use-notifications-api.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/use-notifications-list.js +1 -1
- package/es/components/overlays/NewNotifications/hooks/use-notifications-observer.js +1 -1
- package/es/components/overlays/NewNotifications/index.js +1 -1
- package/es/components/overlays/NewNotifications/types.js +1 -1
- package/es/components/overlays/Notification/Notification.js +1 -1
- package/es/components/overlays/OverlayWrapper.js +1 -1
- package/es/components/overlays/Toasts/Toast.js +1 -1
- package/es/components/overlays/Toasts/index.js +1 -1
- package/es/components/overlays/Toasts/types.js +1 -1
- package/es/components/overlays/Toasts/use-toasts-api.js +1 -1
- package/es/components/overlays/Tooltip/Tooltip.js +1 -1
- package/es/components/overlays/Tooltip/TooltipProvider.js +1 -1
- package/es/components/overlays/Tooltip/TooltipTrigger.js +1 -1
- package/es/components/overlays/Tooltip/context.js +1 -1
- package/es/components/overlays/Tooltip/index.js +1 -1
- package/es/components/portal/Portal.js +1 -1
- package/es/components/portal/PortalProvider.js +1 -1
- package/es/components/portal/index.js +1 -1
- package/es/components/portal/types.js +1 -1
- package/es/components/portal/usePortal.js +1 -1
- package/es/components/shared/InvalidIcon.js +1 -1
- package/es/components/shared/ValidIcon.js +1 -1
- package/es/components/status/LoadingAnimation/LoadingAnimation.js +1 -1
- package/es/components/status/LoadingAnimation/index.js +1 -1
- package/es/components/status/Spin/Cube.js +1 -1
- package/es/components/status/Spin/InternalSpinner.js +1 -1
- package/es/components/status/Spin/Spin.js +1 -1
- package/es/components/status/Spin/SpinsContainer.js +1 -1
- package/es/components/status/Spin/index.js +1 -1
- package/es/components/status/Spin/types.js +1 -1
- package/es/components/status/index.js +1 -1
- package/es/data/item-themes.js +6 -1
- package/es/data/themes.js +6 -1
- package/es/icons/AdjustmentsHorizontalIcon.js +1 -1
- package/es/icons/AdjustmentsIcon.js +1 -1
- package/es/icons/AiIcon.js +1 -1
- package/es/icons/AreaChartIcon.js +1 -1
- package/es/icons/BackwardIcon.js +1 -1
- package/es/icons/BarChartIcon.js +1 -1
- package/es/icons/BellFilledIcon.js +1 -1
- package/es/icons/BellIcon.js +1 -1
- package/es/icons/BooleanIcon.js +1 -1
- package/es/icons/CalendarEditIcon.js +1 -1
- package/es/icons/CalendarIcon.js +1 -1
- package/es/icons/CaretDownIcon.js +1 -1
- package/es/icons/CaretUpIcon.js +1 -1
- package/es/icons/ChartAreaStackedIcon.js +1 -1
- package/es/icons/ChartAreaStackedPercentageIcon.js +1 -1
- package/es/icons/ChartBarGroupedHorizontalIcon.js +1 -1
- package/es/icons/ChartBarGroupedIcon.js +1 -1
- package/es/icons/ChartBarHorizontalIcon.js +1 -1
- package/es/icons/ChartBarLineIcon.js +1 -1
- package/es/icons/ChartBarStackedHorizontalIcon.js +1 -1
- package/es/icons/ChartBarStackedIcon.js +1 -1
- package/es/icons/ChartBarStackedPercentageHorizontalIcon.js +1 -1
- package/es/icons/ChartBarStackedPercentageIcon.js +1 -1
- package/es/icons/ChartBoxPlot2Icon.js +1 -1
- package/es/icons/ChartBoxPlotIcon.js +1 -1
- package/es/icons/ChartBubbleIcon.js +1 -1
- package/es/icons/ChartDonut2Icon.js +1 -1
- package/es/icons/ChartFunnelIcon.js +1 -1
- package/es/icons/ChartHeatmapIcon.js +1 -1
- package/es/icons/ChartKPIIcon.js +1 -1
- package/es/icons/ChartPie2Icon.js +1 -1
- package/es/icons/ChartScatterIcon.js +1 -1
- package/es/icons/CheckCircleFilledIcon.js +1 -1
- package/es/icons/CheckCircleIcon.js +1 -1
- package/es/icons/CheckIcon.js +1 -1
- package/es/icons/CircleFilledIcon.js +1 -1
- package/es/icons/ClearIcon.js +1 -1
- package/es/icons/CloseCircleFilledIcon.js +1 -1
- package/es/icons/CloseCircleIcon.js +1 -1
- package/es/icons/CloseIcon.js +1 -1
- package/es/icons/CodeIcon.js +1 -1
- package/es/icons/ColumnTotalIcon.js +1 -1
- package/es/icons/CopyIcon.js +1 -1
- package/es/icons/CountIcon.js +1 -1
- package/es/icons/CubeIcon.js +1 -1
- package/es/icons/CubePauseIcon.js +1 -1
- package/es/icons/CubePlayIcon.js +1 -1
- package/es/icons/CurrencyDollarIcon.js +1 -1
- package/es/icons/DangerIcon.js +1 -1
- package/es/icons/DashboardIcon.js +1 -1
- package/es/icons/DatabaseIcon.js +1 -1
- package/es/icons/DecimalDecreaseIcon.js +1 -1
- package/es/icons/DecimalIncreaseIcon.js +1 -1
- package/es/icons/DirectionIcon.js +1 -1
- package/es/icons/DonutIcon.js +1 -1
- package/es/icons/DownIcon.js +1 -1
- package/es/icons/EditIcon.js +1 -1
- package/es/icons/ExclamationCircleFilledIcon.js +1 -1
- package/es/icons/ExclamationCircleIcon.js +1 -1
- package/es/icons/ExclamationIcon.js +1 -1
- package/es/icons/EyeIcon.js +1 -1
- package/es/icons/EyeInvisibleIcon.js +1 -1
- package/es/icons/FilterIcon.js +1 -1
- package/es/icons/FolderFilledIcon.js +1 -1
- package/es/icons/FolderIcon.js +1 -1
- package/es/icons/FolderOpenFilledIcon.js +1 -1
- package/es/icons/FolderOpenIcon.js +1 -1
- package/es/icons/ForwardIcon.js +1 -1
- package/es/icons/HierarchyIcon.js +1 -1
- package/es/icons/HierarchyOpenIcon.js +1 -1
- package/es/icons/Icon.js +1 -1
- package/es/icons/InfoCircleIcon.js +1 -1
- package/es/icons/InfoIcon.js +1 -1
- package/es/icons/KeyIcon.js +1 -1
- package/es/icons/LeftIcon.js +1 -1
- package/es/icons/LineChartIcon.js +1 -1
- package/es/icons/LoadingIcon.js +1 -1
- package/es/icons/LockFilledIcon.js +1 -1
- package/es/icons/LockIcon.js +1 -1
- package/es/icons/MoreIcon.js +1 -1
- package/es/icons/NotAllowedIcon.js +1 -1
- package/es/icons/Number123Icon.js +1 -1
- package/es/icons/NumberIcon.js +1 -1
- package/es/icons/PauseCircleFilledIcon.js +1 -1
- package/es/icons/PauseCircleIcon.js +1 -1
- package/es/icons/PauseIcon.js +1 -1
- package/es/icons/PercentageIcon.js +1 -1
- package/es/icons/PieChartIcon.js +1 -1
- package/es/icons/PlayCircleIcon.js +1 -1
- package/es/icons/PlayIcon.js +1 -1
- package/es/icons/PlusIcon.js +1 -1
- package/es/icons/ProgressBarIcon.js +1 -1
- package/es/icons/ReloadIcon.js +1 -1
- package/es/icons/ReportIcon.js +1 -1
- package/es/icons/ReturnIcon.js +1 -1
- package/es/icons/RightIcon.js +1 -1
- package/es/icons/RowTotalsIcon.js +1 -1
- package/es/icons/SchemeIcon.js +1 -1
- package/es/icons/SearchIcon.js +1 -1
- package/es/icons/SemanticQueryIcon.js +1 -1
- package/es/icons/SettingsIcon.js +1 -1
- package/es/icons/ShieldFilledIcon.js +1 -1
- package/es/icons/ShieldIcon.js +1 -1
- package/es/icons/SlashIcon.js +1 -1
- package/es/icons/SparklesIcon.js +1 -1
- package/es/icons/SqlIcon.js +1 -1
- package/es/icons/StatsIcon.js +1 -1
- package/es/icons/StopIcon.js +1 -1
- package/es/icons/StringIcon.js +1 -1
- package/es/icons/SubtotalsIcon.js +1 -1
- package/es/icons/SwitchIcon.js +1 -1
- package/es/icons/TableIcon.js +1 -1
- package/es/icons/ThumbsDownIcon.js +1 -1
- package/es/icons/ThumbsUpIcon.js +1 -1
- package/es/icons/ThunderboltCrossedIcon.js +1 -1
- package/es/icons/ThunderboltFilledIcon.js +1 -1
- package/es/icons/ThunderboltIcon.js +1 -1
- package/es/icons/TimeIcon.js +1 -1
- package/es/icons/TrashIcon.js +1 -1
- package/es/icons/UnlockIcon.js +1 -1
- package/es/icons/UpIcon.js +1 -1
- package/es/icons/UserGroupIcon.js +1 -1
- package/es/icons/UserIcon.js +1 -1
- package/es/icons/UserLockIcon.js +1 -1
- package/es/icons/ViewIcon.js +1 -1
- package/es/icons/WarningFilledIcon.js +1 -1
- package/es/icons/WarningIcon.js +1 -1
- package/es/icons/index.js +1 -1
- package/es/icons/wrap-icon.js +1 -1
- package/es/index.js +1 -1
- package/es/provider.js +1 -1
- package/es/providers/TrackingProvider.js +1 -1
- package/es/providers/navigation.types.js +1 -1
- package/es/providers/navigationAdapter.default.js +1 -1
- package/es/services/notification.js +1 -1
- package/es/shared/form.js +1 -1
- package/es/shared/index.js +1 -1
- package/es/stories/Form.legacy-stories.js +1 -1
- package/es/stories/FormFieldArgs.js +1 -1
- package/es/stories/SimpleLayout.stories.js +1 -1
- package/es/stories/Tasty.stories.js +1 -1
- package/es/stories/components/ConfirmDeletionDialogForm.js +1 -1
- package/es/stories/components/DialogFormApp.js +1 -1
- package/es/stories/components/StyledButton.js +1 -1
- package/es/stories/lists/baseProps.js +1 -1
- package/es/stories/playground/PlaygroundEditor.js +1 -1
- package/es/stories/playground/PlaygroundLayout.js +1 -1
- package/es/stories/playground/PlaygroundOutput.js +1 -1
- package/es/stories/playground/PlaygroundPreview.js +1 -1
- package/es/stories/playground/components/Button.js +1 -1
- package/es/stories/playground/components/Card.js +1 -1
- package/es/stories/playground/components/ScrollProgress.js +1 -1
- package/es/stories/playground/examples.js +1 -1
- package/es/tasty/chunks/cacheKey.js +1 -1
- package/es/tasty/chunks/definitions.js +1 -1
- package/es/tasty/chunks/index.js +1 -1
- package/es/tasty/chunks/renderChunk.js +1 -1
- package/es/tasty/config.js +2 -2
- package/es/tasty/debug.js +2 -2
- package/es/tasty/hooks/index.js +1 -1
- package/es/tasty/hooks/useGlobalStyles.js +1 -1
- package/es/tasty/hooks/useKeyframes.js +1 -1
- package/es/tasty/hooks/useProperty.js +1 -1
- package/es/tasty/hooks/useRawCSS.js +1 -1
- package/es/tasty/hooks/useStyles.js +1 -1
- package/es/tasty/index.js +6 -6
- package/es/tasty/injector/index.js +1 -1
- package/es/tasty/injector/injector.js +2 -2
- package/es/tasty/injector/sheet-manager.js +1 -1
- package/es/tasty/injector/types.js +1 -1
- package/es/tasty/keyframes/index.js +1 -1
- package/es/tasty/parser/classify.js +1 -1
- package/es/tasty/parser/const.js +1 -1
- package/es/tasty/parser/lru.js +1 -1
- package/es/tasty/parser/parser.js +1 -1
- package/es/tasty/parser/tokenizer.js +1 -1
- package/es/tasty/parser/types.js +1 -1
- package/es/tasty/pipeline/conditions.js +1 -1
- package/es/tasty/pipeline/exclusive.js +1 -1
- package/es/tasty/pipeline/index.js +1 -1
- package/es/tasty/pipeline/materialize.js +1 -1
- package/es/tasty/pipeline/parseStateKey.js +1 -1
- package/es/tasty/pipeline/simplify.js +1 -1
- package/es/tasty/plugins/index.js +1 -1
- package/es/tasty/plugins/okhsl-plugin.js +1 -1
- package/es/tasty/plugins/types.js +1 -1
- package/es/tasty/properties/index.js +1 -1
- package/es/tasty/states/index.js +2 -2
- package/es/tasty/static/index.js +2 -2
- package/es/tasty/static/tastyStatic.js +2 -2
- package/es/tasty/static/types.js +1 -1
- package/es/tasty/styles/align.js +1 -1
- package/es/tasty/styles/border.js +1 -1
- package/es/tasty/styles/boxShadow.combinator.js +1 -1
- package/es/tasty/styles/color.js +1 -1
- package/es/tasty/styles/createStyle.js +1 -1
- package/es/tasty/styles/dimension.js +1 -1
- package/es/tasty/styles/display.js +1 -1
- package/es/tasty/styles/fade.js +1 -1
- package/es/tasty/styles/fill.js +1 -1
- package/es/tasty/styles/flow.js +1 -1
- package/es/tasty/styles/gap.js +1 -1
- package/es/tasty/styles/height.js +1 -1
- package/es/tasty/styles/index.js +1 -1
- package/es/tasty/styles/inset.js +6 -5
- package/es/tasty/styles/justify.js +1 -1
- package/es/tasty/styles/list.js +1 -1
- package/es/tasty/styles/margin.js +6 -5
- package/es/tasty/styles/outline.js +1 -1
- package/es/tasty/styles/padding.js +6 -5
- package/es/tasty/styles/place.js +1 -1
- package/es/tasty/styles/predefined.js +2 -2
- package/es/tasty/styles/preset.js +1 -1
- package/es/tasty/styles/radius.js +1 -1
- package/es/tasty/styles/reset.js +1 -1
- package/es/tasty/styles/scrollbar.js +1 -1
- package/es/tasty/styles/shadow.js +1 -1
- package/es/tasty/styles/styledScrollbar.js +1 -1
- package/es/tasty/styles/transition.js +1 -1
- package/es/tasty/styles/types.js +1 -1
- package/es/tasty/styles/width.js +1 -1
- package/es/tasty/tasty.js +5 -5
- package/es/tasty/types.js +1 -1
- package/es/tasty/utils/cache-wrapper.js +1 -1
- package/es/tasty/utils/case-converter.js +1 -1
- package/es/tasty/utils/colors.js +1 -1
- package/es/tasty/utils/dotize.js +1 -1
- package/es/tasty/utils/{filterBaseProps.js → filter-base-props.js} +1 -1
- package/es/tasty/utils/{getDisplayName.js → get-display-name.js} +1 -1
- package/es/tasty/utils/hsl-to-rgb.js +53 -0
- package/es/tasty/utils/{isDevEnv.js → is-dev-env.js} +1 -1
- package/es/tasty/utils/{mergeStyles.js → merge-styles.js} +1 -1
- package/es/tasty/utils/{modAttrs.js → mod-attrs.js} +1 -1
- package/es/tasty/utils/okhsl-to-rgb.js +298 -0
- package/es/tasty/utils/{processTokens.js → process-tokens.js} +15 -3
- package/es/tasty/utils/rgb-to-okhsl.js +448 -0
- package/es/tasty/utils/string.js +1 -1
- package/es/tasty/utils/styles.js +7 -1
- package/es/tasty/utils/typography.js +1 -1
- package/es/tasty/utils/warnings.js +1 -1
- package/es/tasty/zero/babel.js +2 -2
- package/es/tasty/zero/css-writer.js +1 -1
- package/es/tasty/zero/extractor.js +1 -1
- package/es/tasty/zero/index.js +1 -1
- package/es/tasty/zero/next.js +1 -1
- package/es/tokens/base.js +1 -1
- package/es/tokens/colors.js +79 -45
- package/es/tokens/index.js +1 -1
- package/es/tokens/layout.js +1 -1
- package/es/tokens/shadows.js +1 -1
- package/es/tokens/sizes.js +1 -1
- package/es/tokens/spacing.js +1 -1
- package/es/tokens/typography.js +1 -1
- package/es/utils/ResizeSensor.js +1 -1
- package/es/utils/index.js +1 -1
- package/es/utils/modules.js +1 -1
- package/es/utils/promise.js +1 -1
- package/es/utils/raf.js +1 -1
- package/es/utils/random.js +1 -1
- package/es/utils/range.js +1 -1
- package/es/utils/react/RenderCache.js +1 -1
- package/es/utils/react/Slots.js +1 -1
- package/es/utils/react/chain.js +1 -1
- package/es/utils/react/forwardRefWithGenerics.js +1 -1
- package/es/utils/react/index.js +1 -1
- package/es/utils/react/interactions.js +1 -1
- package/es/utils/react/isTextOnly.js +1 -1
- package/es/utils/react/mapProps.js +1 -1
- package/es/utils/react/mergeProps.js +1 -1
- package/es/utils/react/nullableValue.js +1 -1
- package/es/utils/react/resolveIcon.js +1 -1
- package/es/utils/react/sharedStore.js +1 -1
- package/es/utils/react/useCombinedRefs.js +1 -1
- package/es/utils/react/useControlledFocusVisible.js +1 -1
- package/es/utils/react/useEventBus.js +1 -1
- package/es/utils/react/useId.js +1 -1
- package/es/utils/react/useIsDarwin.js +1 -1
- package/es/utils/react/useKeySymbols.js +1 -1
- package/es/utils/react/useLayoutEffect.js +1 -1
- package/es/utils/react/useLocalStorage.js +1 -1
- package/es/utils/react/useQaProps.js +1 -1
- package/es/utils/react/useViewportSize.js +1 -1
- package/es/utils/react/wrapNodeIfPlain.js +1 -1
- package/es/utils/tree.js +1 -1
- package/es/utils/warnings.js +1 -1
- package/es/version.js +2 -2
- package/package.json +2 -2
- package/types/components/HiddenInput.d.ts +60 -60
- package/types/components/actions/Action/Action.d.ts +1 -1
- package/types/components/actions/Button/Button.d.ts +74 -74
- package/types/components/actions/CommandMenu/styled.d.ts +300 -300
- package/types/components/actions/Menu/styled.d.ts +1033 -1033
- package/types/components/actions/use-action.d.ts +1 -1
- package/types/components/content/Alert/use-alert.d.ts +1 -1
- package/types/components/content/Item/Item.d.ts +1 -1
- package/types/components/content/List/SectionHeading.d.ts +244 -244
- package/types/components/content/Tag/Tag.d.ts +1 -1
- package/types/components/content/Text.d.ts +1519 -1519
- package/types/components/fields/DatePicker/DatePickerElement.d.ts +244 -244
- package/types/components/fields/Select/Select.d.ts +60 -60
- package/types/components/fields/Slider/elements.d.ts +360 -360
- package/types/components/navigation/Tabs/DraggableTabList.d.ts +23 -0
- package/types/components/navigation/Tabs/EditableTitle.d.ts +24 -0
- package/types/components/navigation/Tabs/TabButton.d.ts +22 -0
- package/types/components/navigation/Tabs/TabDropIndicator.d.ts +17 -0
- package/types/components/navigation/Tabs/TabPanel.d.ts +49 -0
- package/types/components/navigation/Tabs/TabPicker.d.ts +19 -0
- package/types/components/navigation/Tabs/Tabs.d.ts +3 -188
- package/types/components/navigation/Tabs/TabsContext.d.ts +52 -0
- package/types/components/navigation/Tabs/index.d.ts +1 -1
- package/types/components/navigation/Tabs/styled.d.ts +5927 -0
- package/types/components/navigation/Tabs/types.d.ts +238 -0
- package/types/components/navigation/Tabs/use-tab-editing.d.ts +30 -0
- package/types/components/navigation/Tabs/use-tab-indicator.d.ts +20 -0
- package/types/data/item-themes.d.ts +2 -1
- package/types/data/themes.d.ts +5 -0
- package/types/tasty/index.d.ts +5 -5
- package/types/tasty/static/index.d.ts +1 -1
- package/types/tasty/styles/types.d.ts +3 -3
- package/types/tasty/tasty.d.ts +60 -60
- package/types/tasty/types.d.ts +1 -1
- package/types/tasty/utils/hsl-to-rgb.d.ts +7 -0
- package/types/tasty/utils/okhsl-to-rgb.d.ts +5 -0
- package/types/tasty/utils/{processTokens.d.ts → process-tokens.d.ts} +11 -0
- package/types/tasty/utils/rgb-to-okhsl.d.ts +38 -0
- package/types/tokens/colors.d.ts +14 -0
- /package/types/tasty/utils/{filterBaseProps.d.ts → filter-base-props.d.ts} +0 -0
- /package/types/tasty/utils/{getDisplayName.d.ts → get-display-name.d.ts} +0 -0
- /package/types/tasty/utils/{isDevEnv.d.ts → is-dev-env.d.ts} +0 -0
- /package/types/tasty/utils/{mergeStyles.d.ts → merge-styles.d.ts} +0 -0
- /package/types/tasty/utils/{modAttrs.d.ts → mod-attrs.d.ts} +0 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ReactNode, RefObject } from 'react';
|
|
2
|
+
import { DraggableCollectionState, DroppableCollectionState, TabListState } from 'react-stately';
|
|
3
|
+
import type { Key } from '@react-types/shared';
|
|
4
|
+
export interface DraggableTabListProps {
|
|
5
|
+
/** Tab list state from React Stately */
|
|
6
|
+
state: TabListState<object>;
|
|
7
|
+
/** Ref to the tab list container */
|
|
8
|
+
listRef: RefObject<HTMLDivElement | null>;
|
|
9
|
+
/** Current ordered keys */
|
|
10
|
+
orderedKeys: string[];
|
|
11
|
+
/** Callback when tabs are reordered */
|
|
12
|
+
onReorder?: (newOrder: Key[]) => void;
|
|
13
|
+
/** Render function that receives drag/drop states */
|
|
14
|
+
children: (dragState: DraggableCollectionState, dropState: DroppableCollectionState, collectionProps: Record<string, unknown>) => ReactNode;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Component that enables drag-and-drop reordering for tabs.
|
|
18
|
+
*
|
|
19
|
+
* This component encapsulates all drag/drop hook calls, ensuring they're only
|
|
20
|
+
* called when reordering is actually enabled. It uses the render prop pattern
|
|
21
|
+
* to pass the drag/drop states to its children.
|
|
22
|
+
*/
|
|
23
|
+
export declare function DraggableTabList({ state, listRef, orderedKeys, onReorder, children, }: DraggableTabListProps): ReactNode;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
export interface EditableTitleProps {
|
|
3
|
+
/** The current title to display (when not editing) */
|
|
4
|
+
title: ReactNode;
|
|
5
|
+
/** Whether the title is currently being edited */
|
|
6
|
+
isEditing: boolean;
|
|
7
|
+
/** Current edit input value */
|
|
8
|
+
editValue: string;
|
|
9
|
+
/** Callback when edit value changes */
|
|
10
|
+
onEditValueChange: (value: string) => void;
|
|
11
|
+
/** Callback to start editing (e.g., on double-click) */
|
|
12
|
+
onStartEditing: () => void;
|
|
13
|
+
/** Callback when editing is submitted (Enter or blur) */
|
|
14
|
+
onSubmit: () => void;
|
|
15
|
+
/** Callback when editing is cancelled (Escape) */
|
|
16
|
+
onCancel: () => void;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Inline editable title component for tab labels.
|
|
20
|
+
*
|
|
21
|
+
* When not editing, displays the title as a span with double-click to edit.
|
|
22
|
+
* When editing, displays an auto-sizing input field.
|
|
23
|
+
*/
|
|
24
|
+
export declare function EditableTitle({ title, isEditing, editValue, onEditValueChange, onStartEditing, onSubmit, onCancel, }: EditableTitleProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ParsedTab } from './types';
|
|
2
|
+
import type { Node } from '@react-types/shared';
|
|
3
|
+
export interface TabButtonProps {
|
|
4
|
+
/** React Aria collection item */
|
|
5
|
+
item: Node<object>;
|
|
6
|
+
/** Parsed tab data */
|
|
7
|
+
tabData: ParsedTab;
|
|
8
|
+
/** Whether this is the last tab (for drop indicator) */
|
|
9
|
+
isLastTab?: boolean;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Individual tab button component.
|
|
13
|
+
*
|
|
14
|
+
* Uses TabsContext to access shared props, dramatically reducing prop drilling.
|
|
15
|
+
* Handles:
|
|
16
|
+
* - Tab selection and keyboard navigation
|
|
17
|
+
* - Inline title editing
|
|
18
|
+
* - Menu and context menu
|
|
19
|
+
* - Drag-and-drop reordering
|
|
20
|
+
* - Focus and hover states
|
|
21
|
+
*/
|
|
22
|
+
export declare function TabButton({ item, tabData, isLastTab }: TabButtonProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { DropTarget } from 'react-aria';
|
|
2
|
+
import type { DroppableCollectionState } from 'react-stately';
|
|
3
|
+
export interface TabDropIndicatorProps {
|
|
4
|
+
/** Drop target configuration */
|
|
5
|
+
target: DropTarget;
|
|
6
|
+
/** Droppable collection state from React Aria */
|
|
7
|
+
dropState: DroppableCollectionState;
|
|
8
|
+
/** Position of the indicator (before or after the tab) */
|
|
9
|
+
position: 'before' | 'after';
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Visual drop indicator for drag-and-drop tab reordering.
|
|
13
|
+
*
|
|
14
|
+
* Renders a vertical line showing where the dragged tab will be dropped.
|
|
15
|
+
* Only visible when the drop target is active.
|
|
16
|
+
*/
|
|
17
|
+
export declare function TabDropIndicator({ target, dropState, position, }: TabDropIndicatorProps): import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { Key } from '@react-types/shared';
|
|
2
|
+
import type { ReactNode } from 'react';
|
|
3
|
+
import type { TabListState } from 'react-stately';
|
|
4
|
+
import type { Styles } from '../../../tasty';
|
|
5
|
+
import type { CacheKeyValue, ParsedPanel, ParsedTab } from './types';
|
|
6
|
+
/**
|
|
7
|
+
* Determines if a panel should be rendered based on prerender/keepMounted settings.
|
|
8
|
+
*/
|
|
9
|
+
export declare function shouldRenderPanel(isActive: boolean, wasVisited: boolean, effectivePrerender: boolean | undefined, effectiveKeepMounted: boolean | undefined): boolean;
|
|
10
|
+
export interface TabPanelRendererProps {
|
|
11
|
+
tabKey: string;
|
|
12
|
+
state: TabListState<object>;
|
|
13
|
+
content: ReactNode;
|
|
14
|
+
prerender?: boolean;
|
|
15
|
+
keepMounted?: boolean;
|
|
16
|
+
tabPrerender?: boolean;
|
|
17
|
+
tabKeepMounted?: boolean;
|
|
18
|
+
visitedKeys: Set<string>;
|
|
19
|
+
panelStyles?: Styles;
|
|
20
|
+
qa?: string;
|
|
21
|
+
qaVal?: string;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Renders a single tab panel with proper ARIA attributes.
|
|
25
|
+
*/
|
|
26
|
+
export declare function TabPanelRenderer({ tabKey, state, content, prerender, keepMounted, tabPrerender, tabKeepMounted, visitedKeys, panelStyles, qa, qaVal, }: TabPanelRendererProps): import("react/jsx-runtime").JSX.Element | null;
|
|
27
|
+
export interface CachedPanelRendererProps {
|
|
28
|
+
parsedTabs: ParsedTab[];
|
|
29
|
+
explicitPanels: Map<string, ParsedPanel>;
|
|
30
|
+
state: TabListState<object>;
|
|
31
|
+
renderPanel: (key: Key) => ReactNode;
|
|
32
|
+
panelCacheKeys?: Record<string | number, CacheKeyValue>;
|
|
33
|
+
prerender: boolean;
|
|
34
|
+
keepMounted: boolean;
|
|
35
|
+
visitedKeys: Set<string>;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Renders panels with content caching for `renderPanel`.
|
|
39
|
+
*
|
|
40
|
+
* Core principle: `renderPanel` is only called when the tab is active
|
|
41
|
+
* (or once on mount for `prerender`). Inactive panels use cached content.
|
|
42
|
+
*
|
|
43
|
+
* Caching behavior:
|
|
44
|
+
* - `keepMounted=true`: Cache content after first activation, reuse while inactive
|
|
45
|
+
* - `prerender=true`: Call `renderPanel` once on mount, reuse until active again
|
|
46
|
+
* - `panelCacheKeys`: Adds cache-key-based invalidation (lazy - only when active)
|
|
47
|
+
* - No caching props: Only active panel is rendered, unmount when inactive
|
|
48
|
+
*/
|
|
49
|
+
export declare function CachedPanelRenderer({ parsedTabs, explicitPanels, state, renderPanel, panelCacheKeys, prerender, keepMounted, visitedKeys, }: CachedPanelRendererProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Key } from 'react-aria';
|
|
2
|
+
import type { ParsedTab } from './types';
|
|
3
|
+
export interface TabPickerProps {
|
|
4
|
+
/** Ordered list of parsed tabs to display in the picker */
|
|
5
|
+
tabs: ParsedTab[];
|
|
6
|
+
/** Currently selected tab key */
|
|
7
|
+
selectedKey: Key | null;
|
|
8
|
+
/** Callback when a tab is selected from the picker */
|
|
9
|
+
onSelect: (key: Key) => void;
|
|
10
|
+
/** Callback when a tab should be deleted. When provided, shows delete action on items. */
|
|
11
|
+
onDelete?: (key: Key) => void;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Tab picker component that displays a dropdown menu of all tabs.
|
|
15
|
+
*
|
|
16
|
+
* Used in the Tabs suffix area when tabs overflow to provide quick navigation
|
|
17
|
+
* to any tab without scrolling.
|
|
18
|
+
*/
|
|
19
|
+
export declare function TabPicker({ tabs, selectedKey, onSelect, onDelete, }: TabPickerProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,172 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { BaseProps, OuterStyleProps, Styles } from '../../../tasty';
|
|
4
|
-
import { CubeItemProps } from '../../content/Item';
|
|
5
|
-
/** Visual appearance type for tabs */
|
|
6
|
-
export type TabType = 'default' | 'file' | 'panel' | 'radio';
|
|
7
|
-
/** Tab size options */
|
|
8
|
-
export type TabSize = 'medium' | 'large';
|
|
9
|
-
/** Common props for panel rendering behavior */
|
|
10
|
-
interface PanelBehaviorProps {
|
|
11
|
-
/** If true, panel is rendered but hidden when not active. */
|
|
12
|
-
prerender?: boolean;
|
|
13
|
-
/** If true, once visited the panel stays in DOM. */
|
|
14
|
-
keepMounted?: boolean;
|
|
15
|
-
}
|
|
16
|
-
/** Common props for QA attributes */
|
|
17
|
-
interface QAProps {
|
|
18
|
-
/** QA selector attribute. */
|
|
19
|
-
qa?: string;
|
|
20
|
-
/** Additional QA value attribute. */
|
|
21
|
-
qaVal?: string;
|
|
22
|
-
}
|
|
23
|
-
/** Props from CubeItemProps that don't apply to Tab */
|
|
24
|
-
type OmittedItemProps = 'id' | 'type' | 'size' | 'theme' | 'shape' | 'icon' | 'rightIcon' | 'prefix' | 'suffix' | 'description' | 'descriptionPlacement' | 'descriptionProps' | 'tooltip' | 'defaultTooltipPlacement' | 'hotkeys' | 'keyboardShortcutProps' | 'loadingSlot' | 'isLoading' | 'labelProps' | 'labelRef' | 'level' | 'highlight' | 'highlightCaseSensitive' | 'highlightStyles' | 'variant' | 'htmlType' | 'isSelected' | 'preserveActionsSpace' | 'disableActionsFocus' | 'actions' | 'showActionsOnHover';
|
|
25
|
-
/** Common styling props for tabs - inherits style props from CubeItemProps */
|
|
26
|
-
interface TabStyleProps extends Omit<CubeItemProps, OmittedItemProps> {
|
|
27
|
-
/** Tab size. Large uses `t2m` preset, medium uses `t3m`. */
|
|
28
|
-
size?: TabSize;
|
|
29
|
-
/** Visual appearance type. */
|
|
30
|
-
type?: TabType;
|
|
31
|
-
/** Whether to show actions only on hover. */
|
|
32
|
-
showActionsOnHover?: boolean;
|
|
33
|
-
}
|
|
34
|
-
export interface CubeTabsProps extends BaseProps, OuterStyleProps, PanelBehaviorProps {
|
|
35
|
-
/** Controlled active tab key. When provided, component is controlled. */
|
|
36
|
-
activeKey?: Key;
|
|
37
|
-
/** Initial active tab key for uncontrolled mode. */
|
|
38
|
-
defaultActiveKey?: Key;
|
|
39
|
-
/**
|
|
40
|
-
* Visual appearance type for tabs.
|
|
41
|
-
* - `default` - Standard tabs with selection indicator below (default)
|
|
42
|
-
* - `file` - File-style tabs with fill highlight on selection, delimiter between tabs
|
|
43
|
-
* - `panel` - Panel-style tabs with border bottom highlight on selection, delimiter between tabs
|
|
44
|
-
* - `radio` - Radio button style for tab selection
|
|
45
|
-
* @default 'default'
|
|
46
|
-
*/
|
|
47
|
-
type?: TabType;
|
|
48
|
-
/** Tab size. Large uses `t2m` preset, medium uses `t3m`. */
|
|
49
|
-
size?: TabSize;
|
|
50
|
-
/** Accessible label for the tab list. */
|
|
51
|
-
label?: string;
|
|
52
|
-
/** Content rendered before the tab list. */
|
|
53
|
-
prefix?: ReactNode;
|
|
54
|
-
/** Content rendered after the tab list. */
|
|
55
|
-
suffix?: ReactNode;
|
|
56
|
-
/** Callback when active tab changes. */
|
|
57
|
-
onChange?: (key: Key) => void;
|
|
58
|
-
/** Callback when tab delete button is clicked. Presence enables delete buttons. */
|
|
59
|
-
onDelete?: (key: Key) => void;
|
|
60
|
-
/** Callback when a tab title is changed. Enables title editing on tabs with isEditable. */
|
|
61
|
-
onTitleChange?: (key: Key, newTitle: string) => void;
|
|
62
|
-
/** Whether to show tab actions only on hover. Can be overridden per-tab. */
|
|
63
|
-
showActionsOnHover?: boolean;
|
|
64
|
-
/** Custom tasty styles for the tab bar container. */
|
|
65
|
-
styles?: Styles;
|
|
66
|
-
/** QA selector attribute. */
|
|
67
|
-
qa?: string;
|
|
68
|
-
/** Tab components or Tabs.List with Tabs.Panel. */
|
|
69
|
-
children?: ReactNode;
|
|
70
|
-
/**
|
|
71
|
-
* Functional content renderer for optimized lazy evaluation.
|
|
72
|
-
* When provided, panel content is only evaluated for the active tab,
|
|
73
|
-
* while inactive tabs use cached content. This prevents expensive
|
|
74
|
-
* re-renders of tab content on every parent render.
|
|
75
|
-
*
|
|
76
|
-
* Use with tabs that have no children for maximum optimization.
|
|
77
|
-
*
|
|
78
|
-
* @param key - The key of the tab to render content for
|
|
79
|
-
* @returns Panel content for the given tab
|
|
80
|
-
*
|
|
81
|
-
* @example
|
|
82
|
-
* ```tsx
|
|
83
|
-
* <Tabs
|
|
84
|
-
* renderPanel={(key) => {
|
|
85
|
-
* switch (key) {
|
|
86
|
-
* case 'tab1': return <ExpensiveComponent />;
|
|
87
|
-
* case 'tab2': return <AnotherExpensive />;
|
|
88
|
-
* default: return null;
|
|
89
|
-
* }
|
|
90
|
-
* }}
|
|
91
|
-
* >
|
|
92
|
-
* <Tab key="tab1" title="Tab 1" />
|
|
93
|
-
* <Tab key="tab2" title="Tab 2" />
|
|
94
|
-
* </Tabs>
|
|
95
|
-
* ```
|
|
96
|
-
*/
|
|
97
|
-
renderPanel?: (key: Key) => ReactNode;
|
|
98
|
-
/**
|
|
99
|
-
* Cache keys for individual panels. Enables caching for specified panels.
|
|
100
|
-
*
|
|
101
|
-
* By default (without cache keys), panels re-render on every Tabs render.
|
|
102
|
-
* When a panel has a non-undefined cache key defined, its content is cached
|
|
103
|
-
* and reused until the cache key changes.
|
|
104
|
-
*
|
|
105
|
-
* **Important:**
|
|
106
|
-
* - Cache keys must be primitive values (string, number, boolean, null).
|
|
107
|
-
* - Objects/arrays will cause cache misses on every render (reference comparison).
|
|
108
|
-
* - Symbol tab keys are not supported for caching (use string keys instead).
|
|
109
|
-
* - Setting a key to `undefined` is the same as not having it (no caching).
|
|
110
|
-
*
|
|
111
|
-
* @example
|
|
112
|
-
* ```tsx
|
|
113
|
-
* // Enable caching for specific panels with their dependencies as cache keys
|
|
114
|
-
* <Tabs
|
|
115
|
-
* renderPanel={(key) => <Panel data={data[key]} />}
|
|
116
|
-
* panelCacheKeys={{
|
|
117
|
-
* tab1: data.tab1.version, // Cached, invalidates when version changes
|
|
118
|
-
* tab2: data.tab2.version, // Cached, invalidates when version changes
|
|
119
|
-
* // tab3 has no cache key - re-renders on every Tabs render
|
|
120
|
-
* }}
|
|
121
|
-
* />
|
|
122
|
-
* ```
|
|
123
|
-
*/
|
|
124
|
-
panelCacheKeys?: Record<string | number, string | number | boolean | null | undefined>;
|
|
125
|
-
}
|
|
126
|
-
export interface CubeTabProps extends TabStyleProps, PanelBehaviorProps {
|
|
127
|
-
/**
|
|
128
|
-
* Unique identifier for the tab. Used for activeKey matching.
|
|
129
|
-
* Auto-injected from the React `key` prop (converted to string).
|
|
130
|
-
* Note: All keys are internally converted to strings for React Aria compatibility.
|
|
131
|
-
*/
|
|
132
|
-
id?: string;
|
|
133
|
-
/** Content displayed in the tab button. */
|
|
134
|
-
title: ReactNode;
|
|
135
|
-
/** Panel content rendered when tab is active. */
|
|
136
|
-
children?: ReactNode;
|
|
137
|
-
/** Disables the tab (cannot be selected). */
|
|
138
|
-
isDisabled?: boolean;
|
|
139
|
-
/** Actions to render in the tab (e.g., icons, buttons). Rendered before delete action if tab is deletable. */
|
|
140
|
-
actions?: ReactNode;
|
|
141
|
-
/** Whether the tab title can be edited. Requires onTitleChange on Tabs or Tab. */
|
|
142
|
-
isEditable?: boolean;
|
|
143
|
-
/** Callback when this tab's title is changed. Overrides parent's onTitleChange. */
|
|
144
|
-
onTitleChange?: (newTitle: string) => void;
|
|
145
|
-
}
|
|
146
|
-
export interface CubeTabPanelProps extends PanelBehaviorProps, QAProps {
|
|
147
|
-
/**
|
|
148
|
-
* Panel identifier. Must match a Tab's id.
|
|
149
|
-
* Auto-injected from the React `key` prop (converted to string).
|
|
150
|
-
*/
|
|
151
|
-
id?: string;
|
|
152
|
-
/** Panel content. */
|
|
153
|
-
children?: ReactNode;
|
|
154
|
-
/** Custom tasty styles for the panel container. */
|
|
155
|
-
styles?: Styles;
|
|
156
|
-
}
|
|
157
|
-
export interface CubeTabListProps {
|
|
158
|
-
/** Tab components. */
|
|
159
|
-
children?: ReactNode;
|
|
160
|
-
}
|
|
161
|
-
/** Ref API for programmatic control of Tabs component */
|
|
162
|
-
export interface CubeTabsRef {
|
|
163
|
-
/** The root DOM element of the Tabs component */
|
|
164
|
-
element: HTMLDivElement | null;
|
|
165
|
-
/** Start editing a tab's title by its key */
|
|
166
|
-
startEditing: (key: Key) => void;
|
|
167
|
-
/** Cancel the current editing session */
|
|
168
|
-
cancelEditing: () => void;
|
|
169
|
-
}
|
|
1
|
+
import { ReactElement } from 'react';
|
|
2
|
+
import type { CubeTabListProps, CubeTabPanelProps, CubeTabProps, CubeTabsProps } from './types';
|
|
170
3
|
declare function Tab(_props: CubeTabProps): ReactElement | null;
|
|
171
4
|
declare namespace Tab {
|
|
172
5
|
var displayName: string;
|
|
@@ -184,8 +17,6 @@ declare namespace TabList {
|
|
|
184
17
|
* Built with React Aria for full accessibility support.
|
|
185
18
|
*
|
|
186
19
|
* **Note:** Tab keys are internally converted to strings for React Aria compatibility.
|
|
187
|
-
* When using `activeKey`, `onChange`, etc., be aware that numeric keys will be
|
|
188
|
-
* converted to their string equivalents.
|
|
189
20
|
*
|
|
190
21
|
* @example
|
|
191
22
|
* // Simple usage
|
|
@@ -211,24 +42,8 @@ declare namespace TabList {
|
|
|
211
42
|
* <Tabs.Panel key="tab1">Content 1</Tabs.Panel>
|
|
212
43
|
* <Tabs.Panel key="tab2">Content 2</Tabs.Panel>
|
|
213
44
|
* </Tabs>
|
|
214
|
-
*
|
|
215
|
-
* @example
|
|
216
|
-
* // Optimized lazy rendering with renderPanel
|
|
217
|
-
* <Tabs
|
|
218
|
-
* defaultActiveKey="tab1"
|
|
219
|
-
* renderPanel={(key) => {
|
|
220
|
-
* switch (key) {
|
|
221
|
-
* case 'tab1': return <ExpensiveComponent />;
|
|
222
|
-
* case 'tab2': return <AnotherExpensive />;
|
|
223
|
-
* default: return null;
|
|
224
|
-
* }
|
|
225
|
-
* }}
|
|
226
|
-
* >
|
|
227
|
-
* <Tab key="tab1" title="Tab 1" />
|
|
228
|
-
* <Tab key="tab2" title="Tab 2" />
|
|
229
|
-
* </Tabs>
|
|
230
45
|
*/
|
|
231
|
-
export declare const Tabs: import("react").ForwardRefExoticComponent<CubeTabsProps & import("react").RefAttributes<
|
|
46
|
+
export declare const Tabs: import("react").ForwardRefExoticComponent<CubeTabsProps & import("react").RefAttributes<HTMLDivElement>> & {
|
|
232
47
|
Tab: typeof Tab;
|
|
233
48
|
List: typeof TabList;
|
|
234
49
|
Panel: typeof TabPanel;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import type { Key } from '@react-types/shared';
|
|
3
|
+
import type { DraggableCollectionState, DroppableCollectionState, TabListState } from 'react-stately';
|
|
4
|
+
import type { CubeItemActionProps } from '../../actions/ItemAction';
|
|
5
|
+
import type { CubeMenuProps } from '../../actions/Menu';
|
|
6
|
+
import type { TabSize, TabType } from './types';
|
|
7
|
+
export interface TabsContextValue {
|
|
8
|
+
/** Tab list state from React Stately */
|
|
9
|
+
state: TabListState<object>;
|
|
10
|
+
/** Parent-level type default */
|
|
11
|
+
type: TabType;
|
|
12
|
+
/** Parent-level size default */
|
|
13
|
+
size?: TabSize;
|
|
14
|
+
/** Parent-level showActionsOnHover default */
|
|
15
|
+
showActionsOnHover?: boolean;
|
|
16
|
+
/** Parent-level isEditable default */
|
|
17
|
+
isEditable?: boolean;
|
|
18
|
+
/** Parent-level menu default */
|
|
19
|
+
menu?: ReactNode;
|
|
20
|
+
/** Parent-level menuTriggerProps default */
|
|
21
|
+
menuTriggerProps?: Partial<CubeItemActionProps>;
|
|
22
|
+
/** Parent-level menuProps default */
|
|
23
|
+
menuProps?: Partial<CubeMenuProps<object>>;
|
|
24
|
+
/** Parent-level contextMenu default */
|
|
25
|
+
contextMenu?: boolean;
|
|
26
|
+
/** Callback when tab is deleted */
|
|
27
|
+
onDelete?: (key: Key) => void;
|
|
28
|
+
/** Parent-level onAction callback */
|
|
29
|
+
onAction?: (action: Key, tabKey: Key) => void;
|
|
30
|
+
/** Drag state for reorderable tabs (undefined if not reorderable) */
|
|
31
|
+
dragState?: DraggableCollectionState;
|
|
32
|
+
/** Drop state for reorderable tabs (undefined if not reorderable) */
|
|
33
|
+
dropState?: DroppableCollectionState;
|
|
34
|
+
/** Current tab being edited (null if none) */
|
|
35
|
+
editingKey: Key | null;
|
|
36
|
+
/** Current edit value */
|
|
37
|
+
editValue: string;
|
|
38
|
+
/** Set the edit value */
|
|
39
|
+
setEditValue: (value: string) => void;
|
|
40
|
+
/** Start editing a tab */
|
|
41
|
+
startEditing: (key: Key, currentTitle: string) => void;
|
|
42
|
+
/** Submit the current edit */
|
|
43
|
+
submitEditing: (key: Key, newTitle: string, tabOnTitleChange?: (title: string) => void) => void;
|
|
44
|
+
/** Cancel the current edit */
|
|
45
|
+
cancelEditing: () => void;
|
|
46
|
+
}
|
|
47
|
+
export interface TabsProviderProps {
|
|
48
|
+
value: TabsContextValue;
|
|
49
|
+
children: ReactNode;
|
|
50
|
+
}
|
|
51
|
+
export declare function TabsProvider({ value, children }: TabsProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
52
|
+
export declare function useTabsContext(): TabsContextValue;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export { Tabs, Tab } from './Tabs';
|
|
2
|
-
export type { CubeTabsProps,
|
|
2
|
+
export type { CubeTabsProps, CubeTabProps, CubeTabPanelProps, CubeTabListProps, TabType, TabSize, } from './types';
|