@cube-dev/ui-kit 0.0.0-canary-76be278 → 0.0.0-canary-7e4ec9d
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/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 +67 -61
- 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 +52 -12
- package/es/components/actions/Action/Action.js +1 -1
- package/es/components/actions/Button/Button.js +2 -2
- 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 +1 -1
- package/es/components/content/Content.js +1 -1
- package/es/components/content/CopyPasteBlock/CopyPasteBlock.js +2 -2
- 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 +1 -1
- 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 +2 -2
- 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 +1 -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 -2
- 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 -2
- package/es/components/content/Layout/LayoutPanel.js +1 -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 +1 -1
- 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 +1 -1
- 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 +1 -1
- 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 +2 -2
- 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 +1 -1
- package/es/components/layout/Space.js +1 -1
- package/es/components/layout/Suffix.js +1 -1
- package/es/components/navigation/LegacyTabs/LegacyTabs.js +1 -1
- package/es/components/organisms/FileTabs/FileTabs.js +1 -1
- package/es/components/organisms/StatsCard/StatsCard.js +1 -1
- package/es/components/other/Base64Upload/Base64Upload.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 +1 -1
- 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 +1 -1
- package/es/data/themes.js +1 -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/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/add-new-icon.js +1 -1
- package/es/icons/index.js +1 -1
- package/es/icons/wrap-icon.js +1 -1
- package/es/index.js +1 -2
- package/es/provider.js +8 -2
- 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 +14 -18
- package/es/stories/lists/baseProps.js +1 -1
- package/es/tasty/debug.js +7 -193
- package/es/tasty/index.js +4 -18
- package/es/tasty/injector/index.js +87 -31
- package/es/tasty/injector/injector.js +279 -30
- package/es/tasty/injector/sheet-manager.js +2 -126
- package/es/tasty/injector/types.js +1 -1
- package/es/tasty/parser/classify.js +3 -5
- package/es/tasty/parser/const.js +1 -1
- package/es/tasty/parser/lru.js +1 -1
- package/es/tasty/parser/parser.js +1 -14
- package/es/tasty/parser/tokenizer.js +1 -1
- package/es/tasty/parser/types.js +1 -2
- package/es/tasty/providers/BreakpointsProvider.js +16 -0
- 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 +20 -10
- package/es/tasty/styles/flow.js +1 -1
- package/es/tasty/styles/font.js +1 -1
- package/es/tasty/styles/fontStyle.js +1 -1
- package/es/tasty/styles/gap.js +1 -1
- package/es/tasty/styles/groupRadius.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 +1 -1
- package/es/tasty/styles/justify.js +1 -1
- package/es/tasty/styles/list.js +1 -1
- package/es/tasty/styles/margin.js +55 -75
- package/es/tasty/styles/outline.js +1 -1
- package/es/tasty/styles/padding.js +55 -75
- package/es/tasty/styles/place.js +1 -1
- package/es/tasty/styles/predefined.js +2 -3
- 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 +117 -76
- 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 +1 -1
- package/es/tasty/utils/getDisplayName.js +1 -1
- package/es/tasty/utils/getModCombinations.js +38 -0
- package/es/tasty/utils/isDevEnv.js +1 -1
- package/es/tasty/utils/mergeStyles.js +2 -2
- package/es/tasty/utils/modAttrs.js +1 -1
- package/es/tasty/utils/processTokens.js +1 -1
- package/es/tasty/utils/renderStyles.js +1050 -0
- package/es/tasty/utils/responsive.js +60 -0
- package/es/tasty/utils/string.js +1 -1
- package/es/tasty/utils/styles.js +19 -252
- package/es/tasty/utils/warnings.js +1 -1
- package/es/tokens.js +309 -0
- 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 +1 -3
- package/types/components/GlobalStyles.d.ts +1 -2
- package/types/components/HiddenInput.d.ts +826 -827
- package/types/components/Root.d.ts +0 -1
- package/types/components/actions/Button/Button.d.ts +1645 -1647
- package/types/components/actions/CommandMenu/styled.d.ts +4130 -4135
- package/types/components/actions/Menu/styled.d.ts +4379 -4384
- package/types/components/actions/use-action.d.ts +1 -1
- package/types/components/content/List/SectionHeading.d.ts +83 -83
- package/types/components/content/Text.d.ts +311 -311
- package/types/components/fields/DatePicker/DatePickerElement.d.ts +83 -83
- package/types/components/fields/Select/Select.d.ts +826 -827
- package/types/components/fields/Slider/elements.d.ts +4956 -4962
- package/types/index.d.ts +0 -1
- package/types/provider.d.ts +2 -1
- package/types/stories/components/StyledButton.d.ts +1 -1
- package/types/tasty/debug.d.ts +0 -35
- package/types/tasty/index.d.ts +4 -14
- package/types/tasty/injector/index.d.ts +19 -30
- package/types/tasty/injector/injector.d.ts +13 -13
- package/types/tasty/injector/sheet-manager.d.ts +1 -25
- package/types/tasty/injector/types.d.ts +1 -20
- package/types/tasty/parser/parser.d.ts +0 -4
- package/types/tasty/parser/types.d.ts +0 -1
- package/types/tasty/providers/BreakpointsProvider.d.ts +8 -0
- package/types/tasty/styles/fill.d.ts +1 -11
- package/types/tasty/styles/margin.d.ts +1 -3
- package/types/tasty/styles/padding.d.ts +1 -3
- package/types/tasty/styles/types.d.ts +3 -13
- package/types/tasty/tasty.d.ts +840 -891
- package/types/tasty/utils/getModCombinations.d.ts +9 -0
- package/types/tasty/utils/renderStyles.d.ts +41 -0
- package/types/tasty/utils/responsive.d.ts +8 -0
- package/types/tasty/utils/styles.d.ts +6 -50
- package/types/tokens.d.ts +221 -0
- package/es/tasty/chunks/cacheKey.js +0 -98
- package/es/tasty/chunks/definitions.js +0 -280
- package/es/tasty/chunks/index.js +0 -12
- package/es/tasty/chunks/renderChunk.js +0 -97
- package/es/tasty/config.js +0 -244
- package/es/tasty/hooks/index.js +0 -12
- package/es/tasty/hooks/useGlobalStyles.js +0 -67
- package/es/tasty/hooks/useRawCSS.js +0 -40
- package/es/tasty/hooks/useStyles.js +0 -146
- package/es/tasty/pipeline/conditions.js +0 -469
- package/es/tasty/pipeline/exclusive.js +0 -193
- package/es/tasty/pipeline/index.js +0 -515
- package/es/tasty/pipeline/materialize.js +0 -1001
- package/es/tasty/pipeline/parseStateKey.js +0 -565
- package/es/tasty/pipeline/simplify.js +0 -786
- package/es/tasty/plugins/index.js +0 -26
- package/es/tasty/plugins/okhsl-plugin.js +0 -400
- package/es/tasty/plugins/types.js +0 -10
- package/es/tasty/states/index.js +0 -515
- package/es/tasty/static/index.js +0 -47
- package/es/tasty/static/tastyStatic.js +0 -55
- package/es/tasty/static/types.js +0 -34
- package/es/tasty/utils/typography.js +0 -67
- package/es/tasty/zero/babel.js +0 -401
- package/es/tasty/zero/css-writer.js +0 -94
- package/es/tasty/zero/extractor.js +0 -75
- package/es/tasty/zero/index.js +0 -28
- package/es/tasty/zero/next.js +0 -102
- package/es/tokens/base.js +0 -64
- package/es/tokens/colors.js +0 -68
- package/es/tokens/index.js +0 -63
- package/es/tokens/layout.js +0 -26
- package/es/tokens/shadows.js +0 -27
- package/es/tokens/sizes.js +0 -44
- package/es/tokens/spacing.js +0 -22
- package/es/tokens/typography.js +0 -237
- package/types/tasty/chunks/cacheKey.d.ts +0 -26
- package/types/tasty/chunks/definitions.d.ts +0 -75
- package/types/tasty/chunks/index.d.ts +0 -4
- package/types/tasty/chunks/renderChunk.d.ts +0 -25
- package/types/tasty/config.d.ts +0 -145
- package/types/tasty/hooks/index.d.ts +0 -4
- package/types/tasty/hooks/useGlobalStyles.d.ts +0 -22
- package/types/tasty/hooks/useRawCSS.d.ts +0 -50
- package/types/tasty/hooks/useStyles.d.ts +0 -38
- package/types/tasty/pipeline/conditions.d.ts +0 -248
- package/types/tasty/pipeline/exclusive.d.ts +0 -78
- package/types/tasty/pipeline/index.d.ts +0 -67
- package/types/tasty/pipeline/materialize.d.ts +0 -115
- package/types/tasty/pipeline/parseStateKey.d.ts +0 -20
- package/types/tasty/pipeline/simplify.d.ts +0 -28
- package/types/tasty/plugins/index.d.ts +0 -17
- package/types/tasty/plugins/okhsl-plugin.d.ts +0 -45
- package/types/tasty/plugins/types.d.ts +0 -34
- package/types/tasty/states/index.d.ts +0 -101
- package/types/tasty/static/index.d.ts +0 -39
- package/types/tasty/static/tastyStatic.d.ts +0 -41
- package/types/tasty/static/types.d.ts +0 -44
- package/types/tasty/utils/typography.d.ts +0 -32
- package/types/tasty/zero/babel.d.ts +0 -56
- package/types/tasty/zero/css-writer.d.ts +0 -41
- package/types/tasty/zero/extractor.d.ts +0 -19
- package/types/tasty/zero/index.d.ts +0 -18
- package/types/tasty/zero/next.d.ts +0 -57
- package/types/tokens/base.d.ts +0 -8
- package/types/tokens/colors.d.ts +0 -6
- package/types/tokens/index.d.ts +0 -41
- package/types/tokens/layout.d.ts +0 -7
- package/types/tokens/shadows.d.ts +0 -12
- package/types/tokens/sizes.d.ts +0 -27
- package/types/tokens/spacing.d.ts +0 -8
- package/types/tokens/typography.d.ts +0 -30
|
@@ -1,67 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license MIT
|
|
3
|
-
* author: Cube Dev Team
|
|
4
|
-
* @cube-dev/ui-kit v0.0.0-canary-76be278
|
|
5
|
-
* Released under the MIT license.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { TYPOGRAPHY_PRESETS } from '../../tokens/typography';
|
|
9
|
-
/**
|
|
10
|
-
* Generate typography tokens with $ prefix for CSS custom properties.
|
|
11
|
-
*
|
|
12
|
-
* Each preset generates the following CSS custom properties:
|
|
13
|
-
* - `${name}-font-size`
|
|
14
|
-
* - `${name}-line-height`
|
|
15
|
-
* - `${name}-letter-spacing`
|
|
16
|
-
* - `${name}-font-weight`
|
|
17
|
-
* - `${name}-bold-font-weight` (if defined)
|
|
18
|
-
* - `${name}-icon-size` (if defined)
|
|
19
|
-
* - `${name}-text-transform` (if defined)
|
|
20
|
-
* - `${name}-font-family` (if defined)
|
|
21
|
-
* - `${name}-font-style` (if defined)
|
|
22
|
-
*
|
|
23
|
-
* @param presets - Typography presets object (defaults to TYPOGRAPHY_PRESETS)
|
|
24
|
-
* @returns Styles object with $ prefixed keys
|
|
25
|
-
*
|
|
26
|
-
* @example
|
|
27
|
-
* // Using default presets
|
|
28
|
-
* const tokens = generateTypographyTokens();
|
|
29
|
-
* // tokens['$h1-font-size'] === '36px'
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
* // Using custom presets
|
|
33
|
-
* const customTokens = generateTypographyTokens({
|
|
34
|
-
* myHeading: { fontSize: '24px', lineHeight: '32px', fontWeight: '700' }
|
|
35
|
-
* });
|
|
36
|
-
*/
|
|
37
|
-
export function generateTypographyTokens(presets = TYPOGRAPHY_PRESETS) {
|
|
38
|
-
const tokens = {};
|
|
39
|
-
for (const [name, preset] of Object.entries(presets)) {
|
|
40
|
-
tokens[`$${name}-font-size`] = preset.fontSize;
|
|
41
|
-
tokens[`$${name}-line-height`] = preset.lineHeight;
|
|
42
|
-
tokens[`$${name}-letter-spacing`] = preset.letterSpacing ?? '0';
|
|
43
|
-
tokens[`$${name}-font-weight`] = preset.fontWeight;
|
|
44
|
-
if (preset.boldFontWeight !== undefined) {
|
|
45
|
-
// Handle different property naming for c1 (uses font-bold-weight instead of bold-font-weight)
|
|
46
|
-
const boldKey = name === 'c1'
|
|
47
|
-
? `$${name}-font-bold-weight`
|
|
48
|
-
: `$${name}-bold-font-weight`;
|
|
49
|
-
tokens[boldKey] = preset.boldFontWeight;
|
|
50
|
-
}
|
|
51
|
-
if (preset.iconSize !== undefined) {
|
|
52
|
-
tokens[`$${name}-icon-size`] = preset.iconSize;
|
|
53
|
-
}
|
|
54
|
-
if (preset.textTransform !== undefined) {
|
|
55
|
-
tokens[`$${name}-text-transform`] = preset.textTransform;
|
|
56
|
-
}
|
|
57
|
-
if (preset.fontFamily !== undefined) {
|
|
58
|
-
tokens[`$${name}-font-family`] = preset.fontFamily;
|
|
59
|
-
}
|
|
60
|
-
if (preset.fontStyle !== undefined) {
|
|
61
|
-
tokens[`$${name}-font-style`] = preset.fontStyle;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
return tokens;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
|
package/es/tasty/zero/babel.js
DELETED
|
@@ -1,401 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license MIT
|
|
3
|
-
* author: Cube Dev Team
|
|
4
|
-
* @cube-dev/ui-kit v0.0.0-canary-76be278
|
|
5
|
-
* Released under the MIT license.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Babel plugin for zero-runtime tasty static site generation.
|
|
10
|
-
*
|
|
11
|
-
* Transforms:
|
|
12
|
-
* - `tastyStatic(styles)` → StaticStyle object { className, styles, toString() }
|
|
13
|
-
* - `tastyStatic(base, styles)` → StaticStyle object with merged styles
|
|
14
|
-
* - `tastyStatic(selector, styles)` → removed entirely
|
|
15
|
-
*
|
|
16
|
-
* Usage:
|
|
17
|
-
* ```javascript
|
|
18
|
-
* // babel.config.js
|
|
19
|
-
* module.exports = {
|
|
20
|
-
* plugins: [
|
|
21
|
-
* ['@cube-dev/ui-kit/tasty/zero/babel', { output: 'public/tasty.css' }]
|
|
22
|
-
* ]
|
|
23
|
-
* };
|
|
24
|
-
* ```
|
|
25
|
-
*/
|
|
26
|
-
import { declare } from '@babel/helper-plugin-utils';
|
|
27
|
-
import * as t from '@babel/types';
|
|
28
|
-
import { setGlobalPredefinedStates } from '../states';
|
|
29
|
-
import { mergeStyles } from '../utils/mergeStyles';
|
|
30
|
-
import { CUSTOM_UNITS, getGlobalFuncs, getGlobalParser } from '../utils/styles';
|
|
31
|
-
import { CSSWriter } from './css-writer';
|
|
32
|
-
import { extractStylesForSelector, extractStylesWithChunks } from './extractor';
|
|
33
|
-
export default declare((api, options) => {
|
|
34
|
-
api.assertVersion(7);
|
|
35
|
-
const outputPath = options.output || 'tasty.css';
|
|
36
|
-
const config = options.config || {};
|
|
37
|
-
const devMode = config.devMode ?? false;
|
|
38
|
-
// Apply global predefined states if configured
|
|
39
|
-
if (config.states) {
|
|
40
|
-
setGlobalPredefinedStates(config.states);
|
|
41
|
-
}
|
|
42
|
-
// Apply parser configuration (merge semantics - extend, not replace)
|
|
43
|
-
const parser = getGlobalParser();
|
|
44
|
-
if (config.units) {
|
|
45
|
-
// Merge with existing units
|
|
46
|
-
const currentUnits = parser.getUnits() ?? CUSTOM_UNITS;
|
|
47
|
-
parser.setUnits({ ...currentUnits, ...config.units });
|
|
48
|
-
}
|
|
49
|
-
if (config.funcs) {
|
|
50
|
-
// Merge with existing funcs
|
|
51
|
-
const currentFuncs = getGlobalFuncs();
|
|
52
|
-
const mergedFuncs = { ...currentFuncs, ...config.funcs };
|
|
53
|
-
parser.setFuncs(mergedFuncs);
|
|
54
|
-
// Also update the global registry so customFunc() continues to work
|
|
55
|
-
Object.assign(currentFuncs, config.funcs);
|
|
56
|
-
}
|
|
57
|
-
const cssWriter = new CSSWriter(outputPath, { devMode });
|
|
58
|
-
// Global registry for cross-file references (same build)
|
|
59
|
-
const globalRegistry = {};
|
|
60
|
-
return {
|
|
61
|
-
name: 'tasty-zero',
|
|
62
|
-
pre() {
|
|
63
|
-
// Initialize per-file registry
|
|
64
|
-
this.staticStyleRegistry = {};
|
|
65
|
-
// Extract source filename for devMode comments
|
|
66
|
-
if (devMode && this.filename) {
|
|
67
|
-
// Get relative path or just filename
|
|
68
|
-
this.sourceFile = this.filename.split('/').pop() || this.filename;
|
|
69
|
-
}
|
|
70
|
-
},
|
|
71
|
-
visitor: {
|
|
72
|
-
// Remove import statements for tasty/static
|
|
73
|
-
ImportDeclaration(path) {
|
|
74
|
-
const source = path.node.source.value;
|
|
75
|
-
if (source === '@cube-dev/ui-kit/tasty/static' ||
|
|
76
|
-
source.endsWith('/tasty/static')) {
|
|
77
|
-
path.remove();
|
|
78
|
-
}
|
|
79
|
-
},
|
|
80
|
-
// Transform tastyStatic() calls
|
|
81
|
-
CallExpression(path, state) {
|
|
82
|
-
const callee = path.node.callee;
|
|
83
|
-
// Match tastyStatic(...) calls
|
|
84
|
-
if (!t.isIdentifier(callee, { name: 'tastyStatic' })) {
|
|
85
|
-
return;
|
|
86
|
-
}
|
|
87
|
-
const args = path.node.arguments;
|
|
88
|
-
if (args.length === 0) {
|
|
89
|
-
throw path.buildCodeFrameError('tastyStatic() requires at least one argument');
|
|
90
|
-
}
|
|
91
|
-
const firstArg = args[0];
|
|
92
|
-
if (t.isStringLiteral(firstArg)) {
|
|
93
|
-
// Selector mode: tastyStatic(selector, styles)
|
|
94
|
-
handleSelectorMode(path, args, cssWriter, state.sourceFile);
|
|
95
|
-
}
|
|
96
|
-
else if (t.isObjectExpression(firstArg)) {
|
|
97
|
-
// Styles mode: tastyStatic(styles)
|
|
98
|
-
handleStylesMode(path, args, cssWriter, state, globalRegistry);
|
|
99
|
-
}
|
|
100
|
-
else if (t.isIdentifier(firstArg)) {
|
|
101
|
-
// Extension mode: tastyStatic(base, styles)
|
|
102
|
-
handleExtensionMode(path, args, cssWriter, state, globalRegistry);
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
throw path.buildCodeFrameError('tastyStatic() first argument must be an object (styles), ' +
|
|
106
|
-
'identifier (base StaticStyle), or string (selector)');
|
|
107
|
-
}
|
|
108
|
-
},
|
|
109
|
-
// Track variable declarations to register StaticStyle objects
|
|
110
|
-
VariableDeclarator(path, state) {
|
|
111
|
-
const init = path.node.init;
|
|
112
|
-
const id = path.node.id;
|
|
113
|
-
// Check if this is a StaticStyle object (has className and styles properties)
|
|
114
|
-
if (t.isIdentifier(id) &&
|
|
115
|
-
t.isObjectExpression(init) &&
|
|
116
|
-
isStaticStyleObject(init)) {
|
|
117
|
-
const variableName = id.name;
|
|
118
|
-
const styles = extractStylesFromStaticStyleObject(init, path);
|
|
119
|
-
const className = extractClassNameFromStaticStyleObject(init);
|
|
120
|
-
if (styles && className) {
|
|
121
|
-
state.staticStyleRegistry[variableName] = { styles, className };
|
|
122
|
-
globalRegistry[variableName] = { styles, className };
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
},
|
|
127
|
-
post() {
|
|
128
|
-
// Write all collected CSS at the end of the build
|
|
129
|
-
if (cssWriter.size > 0) {
|
|
130
|
-
cssWriter.write();
|
|
131
|
-
}
|
|
132
|
-
},
|
|
133
|
-
};
|
|
134
|
-
});
|
|
135
|
-
/**
|
|
136
|
-
* Check if an object expression looks like a StaticStyle object
|
|
137
|
-
*/
|
|
138
|
-
function isStaticStyleObject(node) {
|
|
139
|
-
const hasClassName = node.properties.some((p) => t.isObjectProperty(p) && t.isIdentifier(p.key, { name: 'className' }));
|
|
140
|
-
const hasStyles = node.properties.some((p) => t.isObjectProperty(p) && t.isIdentifier(p.key, { name: 'styles' }));
|
|
141
|
-
return hasClassName && hasStyles;
|
|
142
|
-
}
|
|
143
|
-
/**
|
|
144
|
-
* Extract styles object from a StaticStyle object expression
|
|
145
|
-
*/
|
|
146
|
-
function extractStylesFromStaticStyleObject(node, path) {
|
|
147
|
-
for (const prop of node.properties) {
|
|
148
|
-
if (t.isObjectProperty(prop) &&
|
|
149
|
-
t.isIdentifier(prop.key, { name: 'styles' }) &&
|
|
150
|
-
t.isObjectExpression(prop.value)) {
|
|
151
|
-
return evaluateObjectExpression(prop.value, path);
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
return null;
|
|
155
|
-
}
|
|
156
|
-
/**
|
|
157
|
-
* Extract className from a StaticStyle object expression
|
|
158
|
-
*/
|
|
159
|
-
function extractClassNameFromStaticStyleObject(node) {
|
|
160
|
-
for (const prop of node.properties) {
|
|
161
|
-
if (t.isObjectProperty(prop) &&
|
|
162
|
-
t.isIdentifier(prop.key, { name: 'className' }) &&
|
|
163
|
-
t.isStringLiteral(prop.value)) {
|
|
164
|
-
return prop.value.value;
|
|
165
|
-
}
|
|
166
|
-
}
|
|
167
|
-
return null;
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* Handle tastyStatic(styles) - returns StaticStyle object
|
|
171
|
-
*/
|
|
172
|
-
function handleStylesMode(path, args, cssWriter, state, globalRegistry) {
|
|
173
|
-
const stylesArg = args[0];
|
|
174
|
-
if (!t.isObjectExpression(stylesArg)) {
|
|
175
|
-
throw path.buildCodeFrameError('tastyStatic(styles) argument must be a static object literal');
|
|
176
|
-
}
|
|
177
|
-
// Evaluate styles object at build time
|
|
178
|
-
const styles = evaluateObjectExpression(stylesArg, path);
|
|
179
|
-
// Extract styles with chunking
|
|
180
|
-
const chunks = extractStylesWithChunks(styles);
|
|
181
|
-
// Add CSS to writer (with source for devMode)
|
|
182
|
-
for (const chunk of chunks) {
|
|
183
|
-
cssWriter.add(chunk.className, chunk.css, state.sourceFile);
|
|
184
|
-
}
|
|
185
|
-
// Generate className
|
|
186
|
-
const className = chunks.length > 0 ? chunks.map((c) => c.className).join(' ') : '';
|
|
187
|
-
// Replace call with StaticStyle object
|
|
188
|
-
const staticStyleObject = createStaticStyleAST(className, styles);
|
|
189
|
-
path.replaceWith(staticStyleObject);
|
|
190
|
-
// Register if this is being assigned to a variable
|
|
191
|
-
registerIfVariableDeclaration(path, className, styles, state, globalRegistry);
|
|
192
|
-
}
|
|
193
|
-
/**
|
|
194
|
-
* Handle tastyStatic(base, styles) - extends base with additional styles
|
|
195
|
-
*/
|
|
196
|
-
function handleExtensionMode(path, args, cssWriter, state, globalRegistry) {
|
|
197
|
-
if (args.length < 2) {
|
|
198
|
-
throw path.buildCodeFrameError('tastyStatic(base, styles) requires two arguments');
|
|
199
|
-
}
|
|
200
|
-
const baseArg = args[0];
|
|
201
|
-
const stylesArg = args[1];
|
|
202
|
-
if (!t.isIdentifier(baseArg)) {
|
|
203
|
-
throw path.buildCodeFrameError('tastyStatic(base, styles) first argument must be an identifier');
|
|
204
|
-
}
|
|
205
|
-
if (!t.isObjectExpression(stylesArg)) {
|
|
206
|
-
throw path.buildCodeFrameError('tastyStatic(base, styles) second argument must be a static object literal');
|
|
207
|
-
}
|
|
208
|
-
const baseName = baseArg.name;
|
|
209
|
-
// Look up base styles in registry
|
|
210
|
-
const baseEntry = state.staticStyleRegistry[baseName] || globalRegistry[baseName];
|
|
211
|
-
if (!baseEntry) {
|
|
212
|
-
throw path.buildCodeFrameError(`Cannot find base StaticStyle '${baseName}'. ` +
|
|
213
|
-
'Make sure it is defined before being extended.');
|
|
214
|
-
}
|
|
215
|
-
// Evaluate override styles
|
|
216
|
-
const overrideStyles = evaluateObjectExpression(stylesArg, path);
|
|
217
|
-
// Merge styles using mergeStyles
|
|
218
|
-
const mergedStyles = mergeStyles(baseEntry.styles, overrideStyles);
|
|
219
|
-
// Extract styles with chunking
|
|
220
|
-
const chunks = extractStylesWithChunks(mergedStyles);
|
|
221
|
-
// Add CSS to writer (with source for devMode)
|
|
222
|
-
for (const chunk of chunks) {
|
|
223
|
-
cssWriter.add(chunk.className, chunk.css, state.sourceFile);
|
|
224
|
-
}
|
|
225
|
-
// Generate className
|
|
226
|
-
const className = chunks.length > 0 ? chunks.map((c) => c.className).join(' ') : '';
|
|
227
|
-
// Replace call with StaticStyle object
|
|
228
|
-
const staticStyleObject = createStaticStyleAST(className, mergedStyles);
|
|
229
|
-
path.replaceWith(staticStyleObject);
|
|
230
|
-
// Register if this is being assigned to a variable
|
|
231
|
-
registerIfVariableDeclaration(path, className, mergedStyles, state, globalRegistry);
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* Handle tastyStatic(selector, styles) - removes the call entirely
|
|
235
|
-
*/
|
|
236
|
-
function handleSelectorMode(path, args, cssWriter, sourceFile) {
|
|
237
|
-
if (args.length < 2) {
|
|
238
|
-
throw path.buildCodeFrameError('tastyStatic(selector, styles) requires two arguments');
|
|
239
|
-
}
|
|
240
|
-
const selectorArg = args[0];
|
|
241
|
-
const stylesArg = args[1];
|
|
242
|
-
if (!t.isStringLiteral(selectorArg)) {
|
|
243
|
-
throw path.buildCodeFrameError('tastyStatic(selector, styles) first argument must be a string literal');
|
|
244
|
-
}
|
|
245
|
-
if (!t.isObjectExpression(stylesArg)) {
|
|
246
|
-
throw path.buildCodeFrameError('tastyStatic(selector, styles) second argument must be a static object literal');
|
|
247
|
-
}
|
|
248
|
-
const selector = selectorArg.value;
|
|
249
|
-
const styles = evaluateObjectExpression(stylesArg, path);
|
|
250
|
-
// Extract styles for selector
|
|
251
|
-
const result = extractStylesForSelector(selector, styles);
|
|
252
|
-
// Add CSS to writer (use selector as key for deduplication, with source for devMode)
|
|
253
|
-
cssWriter.add(selector, result.css, sourceFile);
|
|
254
|
-
// Remove the entire statement
|
|
255
|
-
const parent = path.parentPath;
|
|
256
|
-
if (parent && t.isExpressionStatement(parent.node)) {
|
|
257
|
-
parent.remove();
|
|
258
|
-
}
|
|
259
|
-
else {
|
|
260
|
-
// If used in an expression context (which would be incorrect usage),
|
|
261
|
-
// replace with undefined
|
|
262
|
-
path.replaceWith(t.identifier('undefined'));
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
/**
|
|
266
|
-
* Create a StaticStyle object AST node
|
|
267
|
-
*/
|
|
268
|
-
function createStaticStyleAST(className, styles) {
|
|
269
|
-
return t.objectExpression([
|
|
270
|
-
t.objectProperty(t.identifier('className'), t.stringLiteral(className)),
|
|
271
|
-
t.objectProperty(t.identifier('styles'), valueToAST(styles)),
|
|
272
|
-
t.objectMethod('method', t.identifier('toString'), [], t.blockStatement([
|
|
273
|
-
t.returnStatement(t.memberExpression(t.thisExpression(), t.identifier('className'))),
|
|
274
|
-
])),
|
|
275
|
-
]);
|
|
276
|
-
}
|
|
277
|
-
/**
|
|
278
|
-
* Register a StaticStyle in the registry if it's being assigned to a variable
|
|
279
|
-
*/
|
|
280
|
-
function registerIfVariableDeclaration(path, className, styles, state, globalRegistry) {
|
|
281
|
-
const parent = path.parentPath;
|
|
282
|
-
if (parent && t.isVariableDeclarator(parent.node)) {
|
|
283
|
-
const id = parent.node.id;
|
|
284
|
-
if (t.isIdentifier(id)) {
|
|
285
|
-
const variableName = id.name;
|
|
286
|
-
state.staticStyleRegistry[variableName] = { styles, className };
|
|
287
|
-
globalRegistry[variableName] = { styles, className };
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
/**
|
|
292
|
-
* Convert a JavaScript value to an AST node
|
|
293
|
-
*/
|
|
294
|
-
function valueToAST(value) {
|
|
295
|
-
if (value === null) {
|
|
296
|
-
return t.nullLiteral();
|
|
297
|
-
}
|
|
298
|
-
if (value === undefined) {
|
|
299
|
-
return t.identifier('undefined');
|
|
300
|
-
}
|
|
301
|
-
if (typeof value === 'string') {
|
|
302
|
-
return t.stringLiteral(value);
|
|
303
|
-
}
|
|
304
|
-
if (typeof value === 'number') {
|
|
305
|
-
return t.numericLiteral(value);
|
|
306
|
-
}
|
|
307
|
-
if (typeof value === 'boolean') {
|
|
308
|
-
return t.booleanLiteral(value);
|
|
309
|
-
}
|
|
310
|
-
if (Array.isArray(value)) {
|
|
311
|
-
return t.arrayExpression(value.map(valueToAST));
|
|
312
|
-
}
|
|
313
|
-
if (typeof value === 'object') {
|
|
314
|
-
const properties = Object.entries(value).map(([key, val]) => t.objectProperty(/^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(key)
|
|
315
|
-
? t.identifier(key)
|
|
316
|
-
: t.stringLiteral(key), valueToAST(val)));
|
|
317
|
-
return t.objectExpression(properties);
|
|
318
|
-
}
|
|
319
|
-
// Fallback for unsupported types
|
|
320
|
-
return t.identifier('undefined');
|
|
321
|
-
}
|
|
322
|
-
/**
|
|
323
|
-
* Evaluate an ObjectExpression to a plain JavaScript object.
|
|
324
|
-
* Only supports static values that can be determined at build time.
|
|
325
|
-
*/
|
|
326
|
-
function evaluateObjectExpression(node, path) {
|
|
327
|
-
const result = {};
|
|
328
|
-
for (const prop of node.properties) {
|
|
329
|
-
if (t.isSpreadElement(prop)) {
|
|
330
|
-
throw path.buildCodeFrameError('Spread elements are not supported in tastyStatic() - styles must be fully static');
|
|
331
|
-
}
|
|
332
|
-
if (!t.isObjectProperty(prop)) {
|
|
333
|
-
throw path.buildCodeFrameError('Only object properties are supported in tastyStatic()');
|
|
334
|
-
}
|
|
335
|
-
// Get key
|
|
336
|
-
let key;
|
|
337
|
-
if (t.isIdentifier(prop.key)) {
|
|
338
|
-
key = prop.key.name;
|
|
339
|
-
}
|
|
340
|
-
else if (t.isStringLiteral(prop.key)) {
|
|
341
|
-
key = prop.key.value;
|
|
342
|
-
}
|
|
343
|
-
else {
|
|
344
|
-
throw path.buildCodeFrameError('Dynamic property keys are not supported in tastyStatic()');
|
|
345
|
-
}
|
|
346
|
-
// Get value
|
|
347
|
-
const value = evaluateExpression(prop.value, path);
|
|
348
|
-
result[key] = value;
|
|
349
|
-
}
|
|
350
|
-
return result;
|
|
351
|
-
}
|
|
352
|
-
/**
|
|
353
|
-
* Evaluate an expression to a JavaScript value.
|
|
354
|
-
*/
|
|
355
|
-
function evaluateExpression(node, path) {
|
|
356
|
-
if (t.isStringLiteral(node)) {
|
|
357
|
-
return node.value;
|
|
358
|
-
}
|
|
359
|
-
if (t.isNumericLiteral(node)) {
|
|
360
|
-
return node.value;
|
|
361
|
-
}
|
|
362
|
-
if (t.isBooleanLiteral(node)) {
|
|
363
|
-
return node.value;
|
|
364
|
-
}
|
|
365
|
-
if (t.isNullLiteral(node)) {
|
|
366
|
-
return null;
|
|
367
|
-
}
|
|
368
|
-
if (t.isIdentifier(node, { name: 'undefined' })) {
|
|
369
|
-
return undefined;
|
|
370
|
-
}
|
|
371
|
-
if (t.isArrayExpression(node)) {
|
|
372
|
-
return node.elements.map((el) => {
|
|
373
|
-
if (el === null)
|
|
374
|
-
return null;
|
|
375
|
-
if (t.isSpreadElement(el)) {
|
|
376
|
-
throw path.buildCodeFrameError('Spread elements are not supported in tastyStatic()');
|
|
377
|
-
}
|
|
378
|
-
return evaluateExpression(el, path);
|
|
379
|
-
});
|
|
380
|
-
}
|
|
381
|
-
if (t.isObjectExpression(node)) {
|
|
382
|
-
return evaluateObjectExpression(node, path);
|
|
383
|
-
}
|
|
384
|
-
if (t.isTemplateLiteral(node)) {
|
|
385
|
-
// Only support template literals without expressions
|
|
386
|
-
if (node.expressions.length > 0) {
|
|
387
|
-
throw path.buildCodeFrameError('Template literals with expressions are not supported in tastyStatic()');
|
|
388
|
-
}
|
|
389
|
-
return node.quasis.map((q) => q.value.cooked).join('');
|
|
390
|
-
}
|
|
391
|
-
if (t.isUnaryExpression(node, { operator: '-' })) {
|
|
392
|
-
const arg = evaluateExpression(node.argument, path);
|
|
393
|
-
if (typeof arg === 'number') {
|
|
394
|
-
return -arg;
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
throw path.buildCodeFrameError(`Dynamic expressions are not supported in tastyStatic() - got ${node.type}. ` +
|
|
398
|
-
'All values must be static literals.');
|
|
399
|
-
}
|
|
400
|
-
|
|
401
|
-
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license MIT
|
|
3
|
-
* author: Cube Dev Team
|
|
4
|
-
* @cube-dev/ui-kit v0.0.0-canary-76be278
|
|
5
|
-
* Released under the MIT license.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import * as fs from 'fs';
|
|
9
|
-
import * as path from 'path';
|
|
10
|
-
export class CSSWriter {
|
|
11
|
-
cssBlocks = new Map();
|
|
12
|
-
outputPath;
|
|
13
|
-
devMode;
|
|
14
|
-
constructor(outputPath, options = {}) {
|
|
15
|
-
this.outputPath = outputPath;
|
|
16
|
-
this.devMode = options.devMode ?? false;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Add CSS block with deduplication key
|
|
20
|
-
* @param key - Unique key for deduplication
|
|
21
|
-
* @param css - CSS content
|
|
22
|
-
* @param source - Optional source file path (used in devMode)
|
|
23
|
-
*/
|
|
24
|
-
add(key, css, source) {
|
|
25
|
-
if (!this.cssBlocks.has(key)) {
|
|
26
|
-
this.cssBlocks.set(key, { css, source });
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Check if a key already exists
|
|
31
|
-
*/
|
|
32
|
-
has(key) {
|
|
33
|
-
return this.cssBlocks.has(key);
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Get the number of CSS blocks
|
|
37
|
-
*/
|
|
38
|
-
get size() {
|
|
39
|
-
return this.cssBlocks.size;
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Write all collected CSS to the output file
|
|
43
|
-
*/
|
|
44
|
-
write() {
|
|
45
|
-
const outputDir = path.dirname(this.outputPath);
|
|
46
|
-
// Ensure directory exists
|
|
47
|
-
if (!fs.existsSync(outputDir)) {
|
|
48
|
-
fs.mkdirSync(outputDir, { recursive: true });
|
|
49
|
-
}
|
|
50
|
-
// Combine all CSS blocks with optional source comments
|
|
51
|
-
const cssBlocks = [];
|
|
52
|
-
for (const block of this.cssBlocks.values()) {
|
|
53
|
-
if (this.devMode && block.source) {
|
|
54
|
-
cssBlocks.push(`/* from: ${block.source} */\n${block.css}`);
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
cssBlocks.push(block.css);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
const css = cssBlocks.join('\n\n');
|
|
61
|
-
// Add header comment
|
|
62
|
-
const header = `/* Generated by @cube-dev/ui-kit/tasty/zero - DO NOT EDIT */\n\n`;
|
|
63
|
-
fs.writeFileSync(this.outputPath, header + css);
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Get all CSS as string (for testing or in-memory use)
|
|
67
|
-
*/
|
|
68
|
-
getCSS() {
|
|
69
|
-
const cssBlocks = [];
|
|
70
|
-
for (const block of this.cssBlocks.values()) {
|
|
71
|
-
if (this.devMode && block.source) {
|
|
72
|
-
cssBlocks.push(`/* from: ${block.source} */\n${block.css}`);
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
cssBlocks.push(block.css);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
return cssBlocks.join('\n\n');
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Clear all collected CSS
|
|
82
|
-
*/
|
|
83
|
-
clear() {
|
|
84
|
-
this.cssBlocks.clear();
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* Get the output path
|
|
88
|
-
*/
|
|
89
|
-
getOutputPath() {
|
|
90
|
-
return this.outputPath;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license MIT
|
|
3
|
-
* author: Cube Dev Team
|
|
4
|
-
* @cube-dev/ui-kit v0.0.0-canary-76be278
|
|
5
|
-
* Released under the MIT license.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { createHash } from 'crypto';
|
|
9
|
-
import { categorizeStyleKeys, generateChunkCacheKey, renderStylesForChunk, } from '../chunks';
|
|
10
|
-
import { renderStyles } from '../pipeline';
|
|
11
|
-
/**
|
|
12
|
-
* Generate a deterministic className from a cache key using content hash.
|
|
13
|
-
* This ensures the same styles always produce the same className,
|
|
14
|
-
* regardless of build order or incremental compilation.
|
|
15
|
-
*/
|
|
16
|
-
function generateClassName(cacheKey) {
|
|
17
|
-
const hash = createHash('md5').update(cacheKey).digest('hex').slice(0, 6);
|
|
18
|
-
return `ts${hash}`; // 'ts' prefix for "tasty-static" to distinguish from runtime 't' classes
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Extract styles using chunking (for className mode).
|
|
22
|
-
* Returns multiple classes, one per chunk.
|
|
23
|
-
*/
|
|
24
|
-
export function extractStylesWithChunks(styles) {
|
|
25
|
-
const chunks = [];
|
|
26
|
-
// Categorize style keys into chunks
|
|
27
|
-
const chunkMap = categorizeStyleKeys(styles);
|
|
28
|
-
for (const [chunkName, chunkStyleKeys] of chunkMap) {
|
|
29
|
-
if (chunkStyleKeys.length === 0)
|
|
30
|
-
continue;
|
|
31
|
-
// Generate cache key for this chunk (used for className hash)
|
|
32
|
-
const cacheKey = generateChunkCacheKey(styles, chunkName, chunkStyleKeys);
|
|
33
|
-
// Render styles for this chunk
|
|
34
|
-
const renderResult = renderStylesForChunk(styles, chunkName, chunkStyleKeys);
|
|
35
|
-
if (renderResult.rules.length === 0)
|
|
36
|
-
continue;
|
|
37
|
-
// Generate deterministic className from content hash
|
|
38
|
-
const className = generateClassName(cacheKey);
|
|
39
|
-
const selector = `.${className}.${className}`;
|
|
40
|
-
// Format CSS
|
|
41
|
-
const css = formatRulesToCSS(renderResult.rules, selector);
|
|
42
|
-
chunks.push({ className, css });
|
|
43
|
-
}
|
|
44
|
-
return chunks;
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Extract styles for a specific selector (for global/selector mode).
|
|
48
|
-
* Returns a single CSS block.
|
|
49
|
-
*/
|
|
50
|
-
export function extractStylesForSelector(selector, styles) {
|
|
51
|
-
const rules = renderStyles(styles, selector);
|
|
52
|
-
const css = formatRulesToCSS(rules, selector);
|
|
53
|
-
return { selector, css };
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Format StyleResult[] to CSS string
|
|
57
|
-
*/
|
|
58
|
-
function formatRulesToCSS(rules, _baseSelector) {
|
|
59
|
-
return rules
|
|
60
|
-
.map((rule) => {
|
|
61
|
-
let css = `${rule.selector} { ${rule.declarations} }`;
|
|
62
|
-
// Wrap in at-rules (in reverse order for proper nesting)
|
|
63
|
-
if (rule.atRules && rule.atRules.length > 0) {
|
|
64
|
-
for (const atRule of [...rule.atRules].reverse()) {
|
|
65
|
-
css = `${atRule} {\n ${css}\n}`;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
return css;
|
|
69
|
-
})
|
|
70
|
-
.join('\n\n');
|
|
71
|
-
}
|
|
72
|
-
// Note: With hash-based className generation, counter management functions
|
|
73
|
-
// are no longer needed. ClassNames are deterministic based on content.
|
|
74
|
-
|
|
75
|
-
|
package/es/tasty/zero/index.js
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license MIT
|
|
3
|
-
* author: Cube Dev Team
|
|
4
|
-
* @cube-dev/ui-kit v0.0.0-canary-76be278
|
|
5
|
-
* Released under the MIT license.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Zero-runtime module for programmatic use.
|
|
10
|
-
*
|
|
11
|
-
* For the Babel plugin, import from '@cube-dev/ui-kit/tasty/zero/babel'
|
|
12
|
-
*
|
|
13
|
-
* @example
|
|
14
|
-
* ```typescript
|
|
15
|
-
* import { extractStylesWithChunks, CSSWriter } from '@cube-dev/ui-kit/tasty/zero';
|
|
16
|
-
*
|
|
17
|
-
* const chunks = extractStylesWithChunks({ fill: '#blue', padding: '2x' });
|
|
18
|
-
* const writer = new CSSWriter('output.css');
|
|
19
|
-
* chunks.forEach(chunk => writer.add(chunk.className, chunk.css));
|
|
20
|
-
* writer.write();
|
|
21
|
-
* ```
|
|
22
|
-
*/
|
|
23
|
-
// Core extraction utilities
|
|
24
|
-
export { extractStylesWithChunks, extractStylesForSelector } from './extractor';
|
|
25
|
-
// CSS output utilities
|
|
26
|
-
export { CSSWriter } from './css-writer';
|
|
27
|
-
|
|
28
|
-
|