entangle-ui 0.1.0 → 0.3.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 +54 -0
- package/README.md +129 -75
- package/dist/esm/components/Icons/CheckIcon.js +27 -0
- package/dist/esm/components/Icons/CheckIcon.js.map +1 -0
- package/dist/esm/components/Icons/ChevronDownIcon.js +27 -0
- package/dist/esm/components/Icons/ChevronDownIcon.js.map +1 -0
- package/dist/esm/components/Icons/ChevronUpIcon.js +27 -0
- package/dist/esm/components/Icons/ChevronUpIcon.js.map +1 -0
- package/dist/esm/components/Icons/CircleIcon.js +27 -0
- package/dist/esm/components/Icons/CircleIcon.js.map +1 -0
- package/dist/esm/components/Icons/CloseIcon.js +27 -0
- package/dist/esm/components/Icons/CloseIcon.js.map +1 -0
- package/dist/esm/components/Icons/EyeDropperIcon.js +28 -0
- package/dist/esm/components/Icons/EyeDropperIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentAlignedIcon.js +9 -0
- package/dist/esm/components/Icons/TangentAlignedIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentAutoIcon.js +9 -0
- package/dist/esm/components/Icons/TangentAutoIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentFreeIcon.js +9 -0
- package/dist/esm/components/Icons/TangentFreeIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentLinearIcon.js +9 -0
- package/dist/esm/components/Icons/TangentLinearIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentMirroredIcon.js +9 -0
- package/dist/esm/components/Icons/TangentMirroredIcon.js.map +1 -0
- package/dist/esm/components/Icons/TangentStepIcon.js +9 -0
- package/dist/esm/components/Icons/TangentStepIcon.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/AlphaSlider.js +92 -0
- package/dist/esm/components/controls/ColorPicker/AlphaSlider.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorArea.js +93 -0
- package/dist/esm/components/controls/ColorPicker/ColorArea.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorInputs.js +129 -0
- package/dist/esm/components/controls/ColorPicker/ColorInputs.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorPalette.js +89 -0
- package/dist/esm/components/controls/ColorPicker/ColorPalette.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorPicker.js +75 -0
- package/dist/esm/components/controls/ColorPicker/ColorPicker.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorPresets.js +57 -0
- package/dist/esm/components/controls/ColorPicker/ColorPresets.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/ColorSwatch.js +67 -0
- package/dist/esm/components/controls/ColorPicker/ColorSwatch.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/EyeDropper.js +85 -0
- package/dist/esm/components/controls/ColorPicker/EyeDropper.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/HueSlider.js +85 -0
- package/dist/esm/components/controls/ColorPicker/HueSlider.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/colorUtils.js +220 -0
- package/dist/esm/components/controls/ColorPicker/colorUtils.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/palettes/material.js +299 -0
- package/dist/esm/components/controls/ColorPicker/palettes/material.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/palettes/professional.js +479 -0
- package/dist/esm/components/controls/ColorPicker/palettes/professional.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js +366 -0
- package/dist/esm/components/controls/ColorPicker/palettes/tailwind.js.map +1 -0
- package/dist/esm/components/controls/ColorPicker/useColor.js +63 -0
- package/dist/esm/components/controls/ColorPicker/useColor.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/CurveCanvas.js +84 -0
- package/dist/esm/components/controls/CurveEditor/CurveCanvas.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/CurveEditor.js +134 -0
- package/dist/esm/components/controls/CurveEditor/CurveEditor.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/CurveToolbar.js +96 -0
- package/dist/esm/components/controls/CurveEditor/CurveToolbar.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/curvePresets.js +184 -0
- package/dist/esm/components/controls/CurveEditor/curvePresets.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/curveUtils.js +338 -0
- package/dist/esm/components/controls/CurveEditor/curveUtils.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js +569 -0
- package/dist/esm/components/controls/CurveEditor/useCurveInteraction.js.map +1 -0
- package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js +400 -0
- package/dist/esm/components/controls/CurveEditor/useCurveRenderer.js.map +1 -0
- package/dist/esm/components/controls/NumberInput/NumberInput.js +377 -0
- package/dist/esm/components/controls/NumberInput/NumberInput.js.map +1 -0
- package/dist/esm/components/controls/NumberInput/useNumberInput.js +324 -0
- package/dist/esm/components/controls/NumberInput/useNumberInput.js.map +1 -0
- package/dist/esm/components/controls/Select/Select.js +533 -0
- package/dist/esm/components/controls/Select/Select.js.map +1 -0
- package/dist/esm/components/controls/Slider/Slider.js +413 -0
- package/dist/esm/components/controls/Slider/Slider.js.map +1 -0
- package/dist/esm/components/controls/TreeView/TreeNode.js +189 -0
- package/dist/esm/components/controls/TreeView/TreeNode.js.map +1 -0
- package/dist/esm/components/controls/TreeView/TreeView.js +213 -0
- package/dist/esm/components/controls/TreeView/TreeView.js.map +1 -0
- package/dist/esm/components/controls/TreeView/useTreeState.js +154 -0
- package/dist/esm/components/controls/TreeView/useTreeState.js.map +1 -0
- package/dist/esm/components/controls/VectorInput/VectorInput.js +202 -0
- package/dist/esm/components/controls/VectorInput/VectorInput.js.map +1 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js +42 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyGroup.js.map +1 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js +98 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyPanel.js.map +1 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyRow.js +154 -0
- package/dist/esm/components/editor/PropertyInspector/PropertyRow.js.map +1 -0
- package/dist/esm/components/editor/PropertyInspector/PropertySection.js +136 -0
- package/dist/esm/components/editor/PropertyInspector/PropertySection.js.map +1 -0
- package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js +86 -0
- package/dist/esm/components/editor/PropertyInspector/usePropertyUndo.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/Dialog.js +92 -0
- package/dist/esm/components/feedback/Dialog/Dialog.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/Dialog.styled.js +80 -0
- package/dist/esm/components/feedback/Dialog/Dialog.styled.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/DialogBody.js +33 -0
- package/dist/esm/components/feedback/Dialog/DialogBody.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/DialogClose.js +26 -0
- package/dist/esm/components/feedback/Dialog/DialogClose.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/DialogFooter.js +43 -0
- package/dist/esm/components/feedback/Dialog/DialogFooter.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/DialogHeader.js +84 -0
- package/dist/esm/components/feedback/Dialog/DialogHeader.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/useDialogAnimation.js +70 -0
- package/dist/esm/components/feedback/Dialog/useDialogAnimation.js.map +1 -0
- package/dist/esm/components/feedback/Dialog/useFocusTrap.js +55 -0
- package/dist/esm/components/feedback/Dialog/useFocusTrap.js.map +1 -0
- package/dist/esm/components/feedback/Toast/ToastContainer.js +34 -0
- package/dist/esm/components/feedback/Toast/ToastContainer.js.map +1 -0
- package/dist/esm/components/feedback/Toast/ToastItem.js +214 -0
- package/dist/esm/components/feedback/Toast/ToastItem.js.map +1 -0
- package/dist/esm/components/feedback/Toast/ToastProvider.js +47 -0
- package/dist/esm/components/feedback/Toast/ToastProvider.js.map +1 -0
- package/dist/esm/components/feedback/Toast/useToast.js +60 -0
- package/dist/esm/components/feedback/Toast/useToast.js.map +1 -0
- package/dist/esm/components/form/FormHelperText.js +38 -0
- package/dist/esm/components/form/FormHelperText.js.map +1 -0
- package/dist/esm/components/form/FormLabel.js +43 -0
- package/dist/esm/components/form/FormLabel.js.map +1 -0
- package/dist/esm/components/form/InputWrapper.js +100 -0
- package/dist/esm/components/form/InputWrapper.js.map +1 -0
- package/dist/esm/components/layout/Accordion/Accordion.js +103 -0
- package/dist/esm/components/layout/Accordion/Accordion.js.map +1 -0
- package/dist/esm/components/layout/Accordion/AccordionContent.js +37 -0
- package/dist/esm/components/layout/Accordion/AccordionContent.js.map +1 -0
- package/dist/esm/components/layout/Accordion/AccordionItem.js +24 -0
- package/dist/esm/components/layout/Accordion/AccordionItem.js.map +1 -0
- package/dist/esm/components/layout/Accordion/AccordionTrigger.js +123 -0
- package/dist/esm/components/layout/Accordion/AccordionTrigger.js.map +1 -0
- package/dist/esm/components/layout/Flex/Flex.js +149 -0
- package/dist/esm/components/layout/Flex/Flex.js.map +1 -0
- package/dist/esm/components/layout/Grid/Grid.js +118 -0
- package/dist/esm/components/layout/Grid/Grid.js.map +1 -0
- package/dist/esm/components/layout/PanelSurface/PanelSurface.js +106 -0
- package/dist/esm/components/layout/PanelSurface/PanelSurface.js.map +1 -0
- package/dist/esm/components/layout/ScrollArea/ScrollArea.js +362 -0
- package/dist/esm/components/layout/ScrollArea/ScrollArea.js.map +1 -0
- package/dist/esm/components/layout/Spacer/Spacer.js +78 -0
- package/dist/esm/components/layout/Spacer/Spacer.js.map +1 -0
- package/dist/esm/components/layout/SplitPane/SplitPane.js +581 -0
- package/dist/esm/components/layout/SplitPane/SplitPane.js.map +1 -0
- package/dist/esm/components/layout/SplitPane/SplitPanePanel.js +29 -0
- package/dist/esm/components/layout/SplitPane/SplitPanePanel.js.map +1 -0
- package/dist/esm/components/layout/Stack/Stack.js +138 -0
- package/dist/esm/components/layout/Stack/Stack.js.map +1 -0
- package/dist/esm/components/navigation/ContextMenu/ContextMenu.js +45 -0
- package/dist/esm/components/navigation/ContextMenu/ContextMenu.js.map +1 -0
- package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js +52 -0
- package/dist/esm/components/navigation/ContextMenu/useContextMenuTarget.js.map +1 -0
- package/dist/esm/components/navigation/Menu/Menu.helpers.js +52 -0
- package/dist/esm/components/navigation/Menu/Menu.helpers.js.map +1 -0
- package/dist/esm/components/navigation/Menu/Menu.js +80 -0
- package/dist/esm/components/navigation/Menu/Menu.js.map +1 -0
- package/dist/esm/components/navigation/Menu/Menu.styled.js +83 -0
- package/dist/esm/components/navigation/Menu/Menu.styled.js.map +1 -0
- package/dist/esm/components/navigation/Menu/useMenu.js +87 -0
- package/dist/esm/components/navigation/Menu/useMenu.js.map +1 -0
- package/dist/esm/components/navigation/Tabs/Tab.js +222 -0
- package/dist/esm/components/navigation/Tabs/Tab.js.map +1 -0
- package/dist/esm/components/navigation/Tabs/TabList.js +115 -0
- package/dist/esm/components/navigation/Tabs/TabList.js.map +1 -0
- package/dist/esm/components/navigation/Tabs/TabPanel.js +32 -0
- package/dist/esm/components/navigation/Tabs/TabPanel.js.map +1 -0
- package/dist/esm/components/navigation/Tabs/Tabs.js +77 -0
- package/dist/esm/components/navigation/Tabs/Tabs.js.map +1 -0
- package/dist/esm/components/primitives/BaseButton/BaseButton.js +17 -0
- package/dist/esm/components/primitives/BaseButton/BaseButton.js.map +1 -0
- package/dist/esm/components/primitives/Button/Button.js +183 -0
- package/dist/esm/components/primitives/Button/Button.js.map +1 -0
- package/dist/esm/components/primitives/Checkbox/Checkbox.js +205 -0
- package/dist/esm/components/primitives/Checkbox/Checkbox.js.map +1 -0
- package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js +71 -0
- package/dist/esm/components/primitives/Checkbox/CheckboxGroup.js.map +1 -0
- package/dist/esm/components/primitives/Collapsible/Collapsible.js +116 -0
- package/dist/esm/components/primitives/Collapsible/Collapsible.js.map +1 -0
- package/dist/esm/components/primitives/Icon/Icon.js +63 -0
- package/dist/esm/components/primitives/Icon/Icon.js.map +1 -0
- package/dist/esm/components/primitives/IconButton/IconButton.js +222 -0
- package/dist/esm/components/primitives/IconButton/IconButton.js.map +1 -0
- package/dist/esm/components/primitives/Input/Input.js +133 -0
- package/dist/esm/components/primitives/Input/Input.js.map +1 -0
- package/dist/esm/components/primitives/Paper/Paper.js +146 -0
- package/dist/esm/components/primitives/Paper/Paper.js.map +1 -0
- package/dist/esm/components/primitives/Popover/Popover.js +121 -0
- package/dist/esm/components/primitives/Popover/Popover.js.map +1 -0
- package/dist/esm/components/primitives/Popover/PopoverClose.js +50 -0
- package/dist/esm/components/primitives/Popover/PopoverClose.js.map +1 -0
- package/dist/esm/components/primitives/Popover/PopoverContent.js +102 -0
- package/dist/esm/components/primitives/Popover/PopoverContent.js.map +1 -0
- package/dist/esm/components/primitives/Popover/PopoverTrigger.js +37 -0
- package/dist/esm/components/primitives/Popover/PopoverTrigger.js.map +1 -0
- package/dist/esm/components/primitives/Switch/Switch.js +170 -0
- package/dist/esm/components/primitives/Switch/Switch.js.map +1 -0
- package/dist/esm/components/primitives/Text/Text.js +166 -0
- package/dist/esm/components/primitives/Text/Text.js.map +1 -0
- package/dist/esm/components/primitives/Tooltip/Arrow.js +52 -0
- package/dist/esm/components/primitives/Tooltip/Arrow.js.map +1 -0
- package/dist/esm/components/primitives/Tooltip/Tooltip.js +219 -0
- package/dist/esm/components/primitives/Tooltip/Tooltip.js.map +1 -0
- package/dist/esm/components/primitives/Tooltip/utils.js +66 -0
- package/dist/esm/components/primitives/Tooltip/utils.js.map +1 -0
- package/dist/esm/components/shell/AppShell/AppShell.js +157 -0
- package/dist/esm/components/shell/AppShell/AppShell.js.map +1 -0
- package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js +236 -0
- package/dist/esm/components/shell/FloatingPanel/FloatingPanel.js.map +1 -0
- package/dist/esm/components/shell/MenuBar/MenuBar.js +340 -0
- package/dist/esm/components/shell/MenuBar/MenuBar.js.map +1 -0
- package/dist/esm/components/shell/StatusBar/StatusBar.js +134 -0
- package/dist/esm/components/shell/StatusBar/StatusBar.js.map +1 -0
- package/dist/esm/components/shell/Toolbar/Toolbar.js +185 -0
- package/dist/esm/components/shell/Toolbar/Toolbar.js.map +1 -0
- package/dist/esm/context/KeyboardContext.js +14 -0
- package/dist/esm/context/KeyboardContext.js.map +1 -0
- package/dist/esm/index.js +78 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/palettes.js +4 -0
- package/dist/esm/palettes.js.map +1 -0
- package/dist/esm/theme/ThemeProvider.js +12 -0
- package/dist/esm/theme/ThemeProvider.js.map +1 -0
- package/dist/esm/theme/createTheme.js +10 -0
- package/dist/esm/theme/createTheme.js.map +1 -0
- package/dist/esm/theme/tokens.js +144 -0
- package/dist/esm/theme/tokens.js.map +1 -0
- package/dist/esm/utils/cn.js +6 -0
- package/dist/esm/utils/cn.js.map +1 -0
- package/dist/esm/utils/mathExpression.js +275 -0
- package/dist/esm/utils/mathExpression.js.map +1 -0
- package/dist/esm/utils/mathUtils.js +18 -0
- package/dist/esm/utils/mathUtils.js.map +1 -0
- package/dist/esm/utils/objects.js +22 -0
- package/dist/esm/utils/objects.js.map +1 -0
- package/dist/esm/utils/styledUtils.js +81 -0
- package/dist/esm/utils/styledUtils.js.map +1 -0
- package/dist/types/components/controls/ColorPicker/ColorPalette.d.ts +16 -0
- package/dist/types/components/controls/ColorPicker/ColorPicker.d.ts +6 -0
- package/dist/types/components/controls/ColorPicker/ColorPicker.types.d.ts +120 -0
- package/dist/types/components/controls/ColorPicker/ColorSwatch.d.ts +6 -0
- package/dist/types/components/controls/ColorPicker/EyeDropper.d.ts +28 -0
- package/dist/types/components/controls/ColorPicker/colorUtils.d.ts +3 -0
- package/dist/types/components/controls/ColorPicker/palettes/material.d.ts +24 -0
- package/dist/types/components/controls/ColorPicker/palettes/professional.d.ts +19 -0
- package/dist/types/components/controls/ColorPicker/palettes/tailwind.d.ts +12 -0
- package/dist/types/components/controls/CurveEditor/CurveEditor.d.ts +6 -0
- package/dist/types/components/controls/CurveEditor/CurveEditor.types.d.ts +297 -0
- package/dist/types/components/controls/CurveEditor/curvePresets.d.ts +5 -0
- package/dist/types/components/controls/CurveEditor/curveUtils.d.ts +28 -0
- package/dist/types/components/controls/NumberInput/NumberInput.d.ts +150 -0
- package/dist/types/components/controls/NumberInput/useNumberInput.d.ts +65 -0
- package/dist/types/components/controls/Select/Select.d.ts +29 -0
- package/dist/types/components/controls/Select/Select.types.d.ts +131 -0
- package/dist/types/components/controls/Slider/Slider.d.ts +178 -0
- package/dist/types/components/controls/TreeView/TreeView.d.ts +27 -0
- package/dist/types/components/controls/TreeView/TreeView.types.d.ts +135 -0
- package/dist/types/components/controls/VectorInput/VectorInput.d.ts +26 -0
- package/dist/types/components/controls/VectorInput/VectorInput.types.d.ts +158 -0
- package/dist/types/components/editor/PropertyInspector/PropertyGroup.d.ts +6 -0
- package/dist/types/components/editor/PropertyInspector/PropertyInspector.types.d.ts +238 -0
- package/dist/types/components/editor/PropertyInspector/PropertyPanel.d.ts +6 -0
- package/dist/types/components/editor/PropertyInspector/PropertyRow.d.ts +6 -0
- package/dist/types/components/editor/PropertyInspector/PropertySection.d.ts +6 -0
- package/dist/types/components/editor/PropertyInspector/usePropertyUndo.d.ts +9 -0
- package/dist/types/components/feedback/Dialog/Dialog.d.ts +25 -0
- package/dist/types/components/feedback/Dialog/Dialog.types.d.ts +55 -0
- package/dist/types/components/feedback/Dialog/DialogBody.d.ts +16 -0
- package/dist/types/components/feedback/Dialog/DialogClose.d.ts +21 -0
- package/dist/types/components/feedback/Dialog/DialogFooter.d.ts +17 -0
- package/dist/types/components/feedback/Dialog/DialogHeader.d.ts +17 -0
- package/dist/types/components/feedback/Toast/Toast.types.d.ts +39 -0
- package/dist/types/components/feedback/Toast/ToastProvider.d.ts +19 -0
- package/dist/types/components/feedback/Toast/useToast.d.ts +22 -0
- package/dist/types/components/form/FormHelperText.d.ts +321 -0
- package/dist/types/components/form/FormLabel.d.ts +331 -0
- package/dist/types/components/form/InputWrapper.d.ts +346 -0
- package/dist/types/components/layout/Accordion/Accordion.d.ts +23 -0
- package/dist/types/components/layout/Accordion/Accordion.types.d.ts +109 -0
- package/dist/types/components/layout/Accordion/AccordionContent.d.ts +6 -0
- package/dist/types/components/layout/Accordion/AccordionItem.d.ts +6 -0
- package/dist/types/components/layout/Accordion/AccordionTrigger.d.ts +6 -0
- package/dist/types/components/layout/Flex/Flex.d.ts +215 -0
- package/dist/types/components/layout/Grid/Grid.d.ts +113 -0
- package/dist/types/components/layout/PanelSurface/PanelSurface.d.ts +1153 -0
- package/dist/types/components/layout/PanelSurface/PanelSurface.types.d.ts +64 -0
- package/dist/types/components/layout/ScrollArea/ScrollArea.d.ts +6 -0
- package/dist/types/components/layout/ScrollArea/ScrollArea.types.d.ts +93 -0
- package/dist/types/components/layout/Spacer/Spacer.d.ts +329 -0
- package/dist/types/components/layout/SplitPane/SplitPane.d.ts +21 -0
- package/dist/types/components/layout/SplitPane/SplitPane.types.d.ts +87 -0
- package/dist/types/components/layout/SplitPane/SplitPanePanel.d.ts +20 -0
- package/dist/types/components/layout/Stack/Stack.d.ts +166 -0
- package/dist/types/components/navigation/ContextMenu/ContextMenu.d.ts +6 -0
- package/dist/types/components/navigation/ContextMenu/ContextMenu.types.d.ts +74 -0
- package/dist/types/components/navigation/ContextMenu/useContextMenuTarget.d.ts +5 -0
- package/dist/types/components/navigation/Menu/Menu.d.ts +42 -0
- package/dist/types/components/navigation/Menu/Menu.types.d.ts +94 -0
- package/dist/types/components/navigation/Menu/useMenu.d.ts +16 -0
- package/dist/types/components/navigation/Tabs/Tab.d.ts +6 -0
- package/dist/types/components/navigation/Tabs/TabList.d.ts +6 -0
- package/dist/types/components/navigation/Tabs/TabPanel.d.ts +6 -0
- package/dist/types/components/navigation/Tabs/Tabs.d.ts +23 -0
- package/dist/types/components/navigation/Tabs/Tabs.types.d.ts +117 -0
- package/dist/types/components/primitives/Button/Button.d.ts +392 -0
- package/dist/types/components/primitives/Checkbox/Checkbox.d.ts +20 -0
- package/dist/types/components/primitives/Checkbox/Checkbox.types.d.ts +156 -0
- package/dist/types/components/primitives/Checkbox/CheckboxGroup.d.ts +25 -0
- package/dist/types/components/primitives/Collapsible/Collapsible.d.ts +6 -0
- package/dist/types/components/primitives/Collapsible/Collapsible.types.d.ts +28 -0
- package/dist/types/components/primitives/Icon/Icon.d.ts +40 -0
- package/dist/types/components/primitives/IconButton/IconButton.d.ts +354 -0
- package/dist/types/components/primitives/Input/Input.d.ts +134 -0
- package/dist/types/components/primitives/Paper/Paper.d.ts +419 -0
- package/dist/types/components/primitives/Popover/Popover.d.ts +25 -0
- package/dist/types/components/primitives/Popover/Popover.types.d.ts +99 -0
- package/dist/types/components/primitives/Popover/PopoverClose.d.ts +6 -0
- package/dist/types/components/primitives/Popover/PopoverContent.d.ts +6 -0
- package/dist/types/components/primitives/Popover/PopoverTrigger.d.ts +10 -0
- package/dist/types/components/primitives/Switch/Switch.d.ts +78 -0
- package/dist/types/components/primitives/Text/Text.d.ts +442 -0
- package/dist/types/components/primitives/Tooltip/Tooltip.d.ts +175 -0
- package/dist/types/components/primitives/Tooltip/types.d.ts +82 -0
- package/dist/types/components/shell/AppShell/AppShell.d.ts +1437 -0
- package/dist/types/components/shell/AppShell/AppShell.types.d.ts +48 -0
- package/dist/types/components/shell/FloatingPanel/FloatingPanel.d.ts +7 -0
- package/dist/types/components/shell/FloatingPanel/FloatingPanel.types.d.ts +61 -0
- package/dist/types/components/shell/MenuBar/MenuBar.d.ts +1441 -0
- package/dist/types/components/shell/MenuBar/MenuBar.types.d.ts +48 -0
- package/dist/types/components/shell/StatusBar/StatusBar.d.ts +868 -0
- package/dist/types/components/shell/StatusBar/StatusBar.types.d.ts +40 -0
- package/dist/types/components/shell/Toolbar/Toolbar.d.ts +1728 -0
- package/dist/types/components/shell/Toolbar/Toolbar.types.d.ts +59 -0
- package/dist/types/index.d.ts +101 -0
- package/dist/types/palettes.d.ts +3 -0
- package/dist/types/theme/ThemeProvider.d.ts +11 -0
- package/dist/types/theme/createTheme.d.ts +6 -0
- package/dist/types/theme/tokens.d.ts +147 -0
- package/dist/types/theme/types.d.ts +7 -0
- package/dist/types/types/common.d.ts +24 -0
- package/dist/types/types/utilities.d.ts +72 -0
- package/dist/types/utils/cn.d.ts +3 -0
- package/package.json +23 -7
- package/dist/index.d.ts +0 -11
- package/dist/index.esm.js +0 -12149
- package/dist/index.esm.js.map +0 -1
- package/dist/index.js +0 -12223
- package/dist/index.js.map +0 -1
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useState, useRef, useCallback, useEffect } from 'react';
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import { keyframes } from '@emotion/react';
|
|
5
|
+
|
|
6
|
+
// --- Severity color map ---
|
|
7
|
+
const SEVERITY_COLOR_MAP = {
|
|
8
|
+
info: 'primary',
|
|
9
|
+
success: 'success',
|
|
10
|
+
warning: 'warning',
|
|
11
|
+
error: 'error',
|
|
12
|
+
};
|
|
13
|
+
// --- Severity icons (inline SVGs) ---
|
|
14
|
+
const SeverityIcon = ({ severity, color, }) => {
|
|
15
|
+
const size = 16;
|
|
16
|
+
const commonProps = {
|
|
17
|
+
width: size,
|
|
18
|
+
height: size,
|
|
19
|
+
viewBox: '0 0 16 16',
|
|
20
|
+
fill: 'none',
|
|
21
|
+
'aria-hidden': true,
|
|
22
|
+
};
|
|
23
|
+
switch (severity) {
|
|
24
|
+
case 'info':
|
|
25
|
+
return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("line", { x1: "8", y1: "7", x2: "8", y2: "11", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("circle", { cx: "8", cy: "5", r: "0.75", fill: color })] }));
|
|
26
|
+
case 'success':
|
|
27
|
+
return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("path", { d: "M5 8L7 10L11 6", stroke: color, strokeWidth: "1.5", strokeLinecap: "round", strokeLinejoin: "round" })] }));
|
|
28
|
+
case 'warning':
|
|
29
|
+
return (jsxs("svg", { ...commonProps, children: [jsx("path", { d: "M8 2L14.5 13H1.5L8 2Z", stroke: color, strokeWidth: "1.5", strokeLinejoin: "round" }), jsx("line", { x1: "8", y1: "6", x2: "8", y2: "9", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("circle", { cx: "8", cy: "11", r: "0.75", fill: color })] }));
|
|
30
|
+
case 'error':
|
|
31
|
+
return (jsxs("svg", { ...commonProps, children: [jsx("circle", { cx: "8", cy: "8", r: "7", stroke: color, strokeWidth: "1.5" }), jsx("line", { x1: "5.5", y1: "5.5", x2: "10.5", y2: "10.5", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" }), jsx("line", { x1: "10.5", y1: "5.5", x2: "5.5", y2: "10.5", stroke: color, strokeWidth: "1.5", strokeLinecap: "round" })] }));
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
// --- Animations ---
|
|
35
|
+
const slideIn = keyframes `
|
|
36
|
+
from {
|
|
37
|
+
opacity: 0;
|
|
38
|
+
transform: translateX(20px);
|
|
39
|
+
}
|
|
40
|
+
to {
|
|
41
|
+
opacity: 1;
|
|
42
|
+
transform: translateX(0);
|
|
43
|
+
}
|
|
44
|
+
`;
|
|
45
|
+
const progressShrink = keyframes `
|
|
46
|
+
from {
|
|
47
|
+
width: 100%;
|
|
48
|
+
}
|
|
49
|
+
to {
|
|
50
|
+
width: 0%;
|
|
51
|
+
}
|
|
52
|
+
`;
|
|
53
|
+
const StyledToast = styled.div `
|
|
54
|
+
width: 360px;
|
|
55
|
+
background: ${props => props.theme.colors.background.elevated};
|
|
56
|
+
border: 1px solid ${props => props.theme.colors.border.default};
|
|
57
|
+
border-left: 3px solid
|
|
58
|
+
${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
|
|
59
|
+
border-radius: ${props => props.theme.borderRadius.lg}px;
|
|
60
|
+
box-shadow: ${props => props.theme.shadows.md};
|
|
61
|
+
padding: ${props => props.theme.spacing.md}px;
|
|
62
|
+
pointer-events: auto;
|
|
63
|
+
position: relative;
|
|
64
|
+
overflow: hidden;
|
|
65
|
+
animation: ${slideIn} ${props => props.theme.transitions.normal} forwards;
|
|
66
|
+
`;
|
|
67
|
+
const StyledContent = styled.div `
|
|
68
|
+
display: flex;
|
|
69
|
+
align-items: flex-start;
|
|
70
|
+
gap: ${props => props.theme.spacing.md}px;
|
|
71
|
+
`;
|
|
72
|
+
const StyledIconWrapper = styled.div `
|
|
73
|
+
flex-shrink: 0;
|
|
74
|
+
display: flex;
|
|
75
|
+
align-items: center;
|
|
76
|
+
padding-top: 1px;
|
|
77
|
+
`;
|
|
78
|
+
const StyledTextContent = styled.div `
|
|
79
|
+
flex: 1;
|
|
80
|
+
min-width: 0;
|
|
81
|
+
`;
|
|
82
|
+
const StyledTitle = styled.div `
|
|
83
|
+
font-weight: ${props => props.theme.typography.fontWeight.semibold};
|
|
84
|
+
color: ${props => props.theme.colors.text.primary};
|
|
85
|
+
font-size: ${props => props.theme.typography.fontSize.sm}px;
|
|
86
|
+
line-height: ${props => props.theme.typography.lineHeight.normal};
|
|
87
|
+
`;
|
|
88
|
+
const StyledMessage = styled.div `
|
|
89
|
+
color: ${props => props.theme.colors.text.secondary};
|
|
90
|
+
font-size: ${props => props.theme.typography.fontSize.xs}px;
|
|
91
|
+
line-height: ${props => props.theme.typography.lineHeight.normal};
|
|
92
|
+
margin-top: ${props => props.theme.spacing.xs}px;
|
|
93
|
+
`;
|
|
94
|
+
const StyledCloseButton = styled.button `
|
|
95
|
+
/* Reset */
|
|
96
|
+
padding: 0;
|
|
97
|
+
margin: 0;
|
|
98
|
+
border: none;
|
|
99
|
+
background: none;
|
|
100
|
+
cursor: pointer;
|
|
101
|
+
outline: none;
|
|
102
|
+
|
|
103
|
+
/* Layout */
|
|
104
|
+
display: flex;
|
|
105
|
+
align-items: center;
|
|
106
|
+
justify-content: center;
|
|
107
|
+
flex-shrink: 0;
|
|
108
|
+
width: 20px;
|
|
109
|
+
height: 20px;
|
|
110
|
+
border-radius: ${props => props.theme.borderRadius.sm}px;
|
|
111
|
+
color: ${props => props.theme.colors.text.muted};
|
|
112
|
+
transition:
|
|
113
|
+
color ${props => props.theme.transitions.fast},
|
|
114
|
+
background ${props => props.theme.transitions.fast};
|
|
115
|
+
|
|
116
|
+
&:hover {
|
|
117
|
+
color: ${props => props.theme.colors.text.primary};
|
|
118
|
+
background: ${props => props.theme.colors.surface.hover};
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
&:focus-visible {
|
|
122
|
+
box-shadow: ${props => props.theme.shadows.focus};
|
|
123
|
+
}
|
|
124
|
+
`;
|
|
125
|
+
const StyledActionButton = styled.button `
|
|
126
|
+
/* Reset */
|
|
127
|
+
padding: ${props => props.theme.spacing.xs}px
|
|
128
|
+
${props => props.theme.spacing.sm}px;
|
|
129
|
+
margin: 0;
|
|
130
|
+
border: none;
|
|
131
|
+
background: none;
|
|
132
|
+
cursor: pointer;
|
|
133
|
+
outline: none;
|
|
134
|
+
|
|
135
|
+
/* Styling */
|
|
136
|
+
color: ${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
|
|
137
|
+
font-size: ${props => props.theme.typography.fontSize.xs}px;
|
|
138
|
+
font-weight: ${props => props.theme.typography.fontWeight.medium};
|
|
139
|
+
border-radius: ${props => props.theme.borderRadius.sm}px;
|
|
140
|
+
transition: background ${props => props.theme.transitions.fast};
|
|
141
|
+
margin-top: ${props => props.theme.spacing.sm}px;
|
|
142
|
+
|
|
143
|
+
&:hover {
|
|
144
|
+
background: ${props => props.theme.colors.surface.hover};
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
&:focus-visible {
|
|
148
|
+
box-shadow: ${props => props.theme.shadows.focus};
|
|
149
|
+
}
|
|
150
|
+
`;
|
|
151
|
+
const StyledProgressBar = styled.div `
|
|
152
|
+
position: absolute;
|
|
153
|
+
bottom: 0;
|
|
154
|
+
left: 0;
|
|
155
|
+
height: 2px;
|
|
156
|
+
background: ${props => props.theme.colors.accent[SEVERITY_COLOR_MAP[props.$severity]]};
|
|
157
|
+
animation: ${progressShrink} ${props => props.$duration}ms linear forwards;
|
|
158
|
+
animation-play-state: ${props => (props.$paused ? 'paused' : 'running')};
|
|
159
|
+
`;
|
|
160
|
+
/**
|
|
161
|
+
* Individual toast notification with severity indicator, auto-dismiss,
|
|
162
|
+
* optional progress bar, and action button support.
|
|
163
|
+
*
|
|
164
|
+
* - info/success: role="status", aria-live="polite"
|
|
165
|
+
* - warning/error: role="alert", aria-live="assertive"
|
|
166
|
+
* - Auto-dismiss pauses on hover
|
|
167
|
+
*/
|
|
168
|
+
const ToastItem = ({ toast, onDismiss }) => {
|
|
169
|
+
const { id, title, message, severity, duration, closable, showProgress, icon, action, } = toast;
|
|
170
|
+
const [paused, setPaused] = useState(false);
|
|
171
|
+
const timerRef = useRef(null);
|
|
172
|
+
const remainingRef = useRef(duration);
|
|
173
|
+
const startRef = useRef(Date.now());
|
|
174
|
+
const isAlert = severity === 'warning' || severity === 'error';
|
|
175
|
+
const role = isAlert ? 'alert' : 'status';
|
|
176
|
+
const ariaLive = isAlert ? 'assertive' : 'polite';
|
|
177
|
+
const clearTimer = useCallback(() => {
|
|
178
|
+
if (timerRef.current !== null) {
|
|
179
|
+
clearTimeout(timerRef.current);
|
|
180
|
+
timerRef.current = null;
|
|
181
|
+
}
|
|
182
|
+
}, []);
|
|
183
|
+
const startTimer = useCallback(() => {
|
|
184
|
+
if (duration <= 0)
|
|
185
|
+
return;
|
|
186
|
+
clearTimer();
|
|
187
|
+
startRef.current = Date.now();
|
|
188
|
+
timerRef.current = setTimeout(() => {
|
|
189
|
+
onDismiss(id);
|
|
190
|
+
}, remainingRef.current);
|
|
191
|
+
}, [duration, clearTimer, onDismiss, id]);
|
|
192
|
+
const handleMouseEnter = useCallback(() => {
|
|
193
|
+
if (duration <= 0)
|
|
194
|
+
return;
|
|
195
|
+
setPaused(true);
|
|
196
|
+
clearTimer();
|
|
197
|
+
remainingRef.current -= Date.now() - startRef.current;
|
|
198
|
+
}, [duration, clearTimer]);
|
|
199
|
+
const handleMouseLeave = useCallback(() => {
|
|
200
|
+
if (duration <= 0)
|
|
201
|
+
return;
|
|
202
|
+
setPaused(false);
|
|
203
|
+
startTimer();
|
|
204
|
+
}, [duration, startTimer]);
|
|
205
|
+
useEffect(() => {
|
|
206
|
+
startTimer();
|
|
207
|
+
return clearTimer;
|
|
208
|
+
}, [startTimer, clearTimer]);
|
|
209
|
+
return (jsxs(StyledToast, { "$severity": severity, role: role, "aria-live": ariaLive, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, "data-testid": `toast-${id}`, children: [jsxs(StyledContent, { children: [jsx(StyledIconWrapper, { children: icon ?? jsx(SeverityIcon, { severity: severity, color: "currentColor" }) }), jsxs(StyledTextContent, { children: [title && jsx(StyledTitle, { children: title }), jsx(StyledMessage, { children: message }), action && (jsx(StyledActionButton, { "$severity": severity, onClick: action.onClick, type: "button", children: action.label }))] }), closable && (jsx(StyledCloseButton, { onClick: () => onDismiss(id), "aria-label": "Dismiss notification", type: "button", children: jsxs("svg", { width: 12, height: 12, viewBox: "0 0 12 12", fill: "none", "aria-hidden": "true", children: [jsx("line", { x1: "2", y1: "2", x2: "10", y2: "10", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" }), jsx("line", { x1: "10", y1: "2", x2: "2", y2: "10", stroke: "currentColor", strokeWidth: "1.5", strokeLinecap: "round" })] }) }))] }), showProgress && duration > 0 && (jsx(StyledProgressBar, { "$severity": severity, "$duration": duration, "$paused": paused, "data-testid": `toast-progress-${id}` }))] }));
|
|
210
|
+
};
|
|
211
|
+
ToastItem.displayName = 'ToastItem';
|
|
212
|
+
|
|
213
|
+
export { ToastItem };
|
|
214
|
+
//# sourceMappingURL=ToastItem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ToastItem.js","sources":["../../../../../../src/components/feedback/Toast/ToastItem.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useReducer, useMemo, createContext } from 'react';
|
|
3
|
+
import { createPortal } from 'react-dom';
|
|
4
|
+
import { ToastContainer } from './ToastContainer.js';
|
|
5
|
+
|
|
6
|
+
const ToastContext =
|
|
7
|
+
/*#__PURE__*/ createContext(null);
|
|
8
|
+
// --- Reducer ---
|
|
9
|
+
function toastReducer(state, action) {
|
|
10
|
+
switch (action.type) {
|
|
11
|
+
case 'ADD_TOAST':
|
|
12
|
+
return [...state, action.toast];
|
|
13
|
+
case 'DISMISS_TOAST':
|
|
14
|
+
return state.filter(t => t.id !== action.id);
|
|
15
|
+
case 'DISMISS_ALL':
|
|
16
|
+
return [];
|
|
17
|
+
default:
|
|
18
|
+
return state;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* ToastProvider manages toast notification state and renders them via portal.
|
|
23
|
+
*
|
|
24
|
+
* Wrap your application (or a section of it) with this provider, then use
|
|
25
|
+
* the `useToast()` hook to trigger notifications from any child component.
|
|
26
|
+
*
|
|
27
|
+
* @example
|
|
28
|
+
* ```tsx
|
|
29
|
+
* <ToastProvider position="bottom-right" maxVisible={5}>
|
|
30
|
+
* <App />
|
|
31
|
+
* </ToastProvider>
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
const ToastProvider = ({ children, position = 'bottom-right', maxVisible = 5, defaultDuration = 5000, gap = 8, zIndex = 1200, }) => {
|
|
35
|
+
const [toasts, dispatch] = useReducer(toastReducer, []);
|
|
36
|
+
const contextValue = useMemo(() => ({ dispatch, defaultDuration }), [dispatch, defaultDuration]);
|
|
37
|
+
const visibleToasts = toasts.slice(-maxVisible);
|
|
38
|
+
const handleDismiss = (id) => {
|
|
39
|
+
dispatch({ type: 'DISMISS_TOAST', id });
|
|
40
|
+
};
|
|
41
|
+
return (jsxs(ToastContext.Provider, { value: contextValue, children: [children, typeof document !== 'undefined' &&
|
|
42
|
+
createPortal(jsx(ToastContainer, { toasts: visibleToasts, position: position, gap: gap, zIndex: zIndex, onDismiss: handleDismiss }), document.body)] }));
|
|
43
|
+
};
|
|
44
|
+
ToastProvider.displayName = 'ToastProvider';
|
|
45
|
+
|
|
46
|
+
export { ToastContext, ToastProvider };
|
|
47
|
+
//# sourceMappingURL=ToastProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ToastProvider.js","sources":["../../../../../../src/components/feedback/Toast/ToastProvider.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;MAmBa,YAAY;AACvB,cAAc,aAAa,CAA2B,IAAI;AAE5D;AAEA,SAAS,YAAY,CACnB,KAA0B,EAC1B,MAAmB,EAAA;AAEnB,IAAA,QAAQ,MAAM,CAAC,IAAI;AACjB,QAAA,KAAK,WAAW;YACd,OAAO,CAAC,GAAG,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC;AACjC,QAAA,KAAK,eAAe;AAClB,YAAA,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,EAAE,CAAC;AAC9C,QAAA,KAAK,aAAa;AAChB,YAAA,OAAO,EAAE;AACX,QAAA;AACE,YAAA,OAAO,KAAK;;AAElB;AAEA;;;;;;;;;;;;AAYG;AACI,MAAM,aAAa,GAAiC,CAAC,EAC1D,QAAQ,EACR,QAAQ,GAAG,cAAc,EACzB,UAAU,GAAG,CAAC,EACd,eAAe,GAAG,IAAI,EACtB,GAAG,GAAG,CAAC,EACP,MAAM,GAAG,IAAI,GACd,KAAI;AACH,IAAA,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,GAAG,UAAU,CAAC,YAAY,EAAE,EAAE,CAAC;IAEvD,MAAM,YAAY,GAAG,OAAO,CAC1B,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC,EACrC,CAAC,QAAQ,EAAE,eAAe,CAAC,CAC5B;IAED,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC;AAE/C,IAAA,MAAM,aAAa,GAAG,CAAC,EAAU,KAAI;QACnC,QAAQ,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,EAAE,EAAE,CAAC;AACzC,KAAC;AAED,IAAA,QACEA,IAAA,CAAC,YAAY,CAAC,QAAQ,EAAC,EAAA,KAAK,EAAE,YAAY,aACvC,QAAQ,EACR,OAAO,QAAQ,KAAK,WAAW;AAC9B,gBAAA,YAAY,CACVC,GAAA,CAAC,cAAc,EAAA,EACb,MAAM,EAAE,aAAa,EACrB,QAAQ,EAAE,QAAQ,EAClB,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,aAAa,EAAA,CACxB,EACF,QAAQ,CAAC,IAAI,CACd,CAAA,EAAA,CACmB;AAE5B;AAEA,aAAa,CAAC,WAAW,GAAG,eAAe;;;;"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { useContext, useRef, useCallback } from 'react';
|
|
2
|
+
import { ToastContext } from './ToastProvider.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Hook to trigger toast notifications from any component
|
|
6
|
+
* inside a `<ToastProvider>`.
|
|
7
|
+
*
|
|
8
|
+
* @throws Error if used outside of a `<ToastProvider>`
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```tsx
|
|
12
|
+
* const { toast, success, error, dismiss } = useToast();
|
|
13
|
+
*
|
|
14
|
+
* success('File saved successfully');
|
|
15
|
+
* error('Failed to export', { title: 'Export Error' });
|
|
16
|
+
*
|
|
17
|
+
* const id = toast({ message: 'Custom toast', severity: 'info' });
|
|
18
|
+
* dismiss(id);
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
function useToast() {
|
|
22
|
+
const context = useContext(ToastContext);
|
|
23
|
+
if (!context) {
|
|
24
|
+
throw new Error('useToast must be used within a ToastProvider');
|
|
25
|
+
}
|
|
26
|
+
const { dispatch, defaultDuration } = context;
|
|
27
|
+
const counterRef = useRef(0);
|
|
28
|
+
const generateId = useCallback(() => {
|
|
29
|
+
counterRef.current += 1;
|
|
30
|
+
return `toast-${Date.now()}-${counterRef.current}`;
|
|
31
|
+
}, []);
|
|
32
|
+
const toast = useCallback((data) => {
|
|
33
|
+
const id = data.id ?? generateId();
|
|
34
|
+
const internalData = {
|
|
35
|
+
...data,
|
|
36
|
+
id,
|
|
37
|
+
severity: data.severity ?? 'info',
|
|
38
|
+
duration: data.duration ?? defaultDuration,
|
|
39
|
+
closable: data.closable ?? true,
|
|
40
|
+
showProgress: data.showProgress ?? false,
|
|
41
|
+
createdAt: Date.now(),
|
|
42
|
+
};
|
|
43
|
+
dispatch({ type: 'ADD_TOAST', toast: internalData });
|
|
44
|
+
return id;
|
|
45
|
+
}, [dispatch, defaultDuration, generateId]);
|
|
46
|
+
const info = useCallback((message, options) => toast({ message, severity: 'info', ...options }), [toast]);
|
|
47
|
+
const success = useCallback((message, options) => toast({ message, severity: 'success', ...options }), [toast]);
|
|
48
|
+
const warning = useCallback((message, options) => toast({ message, severity: 'warning', ...options }), [toast]);
|
|
49
|
+
const error = useCallback((message, options) => toast({ message, severity: 'error', ...options }), [toast]);
|
|
50
|
+
const dismiss = useCallback((id) => {
|
|
51
|
+
dispatch({ type: 'DISMISS_TOAST', id });
|
|
52
|
+
}, [dispatch]);
|
|
53
|
+
const dismissAll = useCallback(() => {
|
|
54
|
+
dispatch({ type: 'DISMISS_ALL' });
|
|
55
|
+
}, [dispatch]);
|
|
56
|
+
return { toast, info, success, warning, error, dismiss, dismissAll };
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
export { useToast };
|
|
60
|
+
//# sourceMappingURL=useToast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useToast.js","sources":["../../../../../../src/components/feedback/Toast/useToast.ts"],"sourcesContent":[null],"names":[],"mappings":";;;AAQA;;;;;;;;;;;;;;;;AAgBG;SACa,QAAQ,GAAA;AACtB,IAAA,MAAM,OAAO,GAAG,UAAU,CAAC,YAAY,CAAC;IACxC,IAAI,CAAC,OAAO,EAAE;AACZ,QAAA,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC;;AAGjE,IAAA,MAAM,EAAE,QAAQ,EAAE,eAAe,EAAE,GAAG,OAAO;AAC7C,IAAA,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC;AAE5B,IAAA,MAAM,UAAU,GAAG,WAAW,CAAC,MAAK;AAClC,QAAA,UAAU,CAAC,OAAO,IAAI,CAAC;QACvB,OAAO,CAAA,MAAA,EAAS,IAAI,CAAC,GAAG,EAAE,IAAI,UAAU,CAAC,OAAO,CAAA,CAAE;KACnD,EAAE,EAAE,CAAC;AAEN,IAAA,MAAM,KAAK,GAAG,WAAW,CACvB,CAAC,IAAe,KAAY;QAC1B,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,UAAU,EAAE;AAClC,QAAA,MAAM,YAAY,GAAsB;AACtC,YAAA,GAAG,IAAI;YACP,EAAE;AACF,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,MAAM;AACjC,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,eAAe;AAC1C,YAAA,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI;AAC/B,YAAA,YAAY,EAAE,IAAI,CAAC,YAAY,IAAI,KAAK;AACxC,YAAA,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB;QACD,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;AACpD,QAAA,OAAO,EAAE;KACV,EACD,CAAC,QAAQ,EAAE,eAAe,EAAE,UAAU,CAAC,CACxC;AAED,IAAA,MAAM,IAAI,GAAG,WAAW,CACtB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE,CAAC,EAClD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,OAAO,EAAE,CAAC,EACrD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,OAAO,EAAE,CAAC,EACrD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,KAAK,GAAG,WAAW,CACvB,CAAC,OAAe,EAAE,OAA4B,KAC5C,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,EAAE,CAAC,EACnD,CAAC,KAAK,CAAC,CACR;AAED,IAAA,MAAM,OAAO,GAAG,WAAW,CACzB,CAAC,EAAU,KAAI;QACb,QAAQ,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,EAAE,EAAE,CAAC;AACzC,KAAC,EACD,CAAC,QAAQ,CAAC,CACX;AAED,IAAA,MAAM,UAAU,GAAG,WAAW,CAAC,MAAK;AAClC,QAAA,QAAQ,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;AACnC,KAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;AAEd,IAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE;AACtE;;;;"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import { processCss } from '../../utils/styledUtils.js';
|
|
5
|
+
|
|
6
|
+
const StyledHelperText = styled.div `
|
|
7
|
+
font-size: ${props => props.theme.typography.fontSize.xs}px;
|
|
8
|
+
line-height: ${props => props.theme.typography.lineHeight.tight};
|
|
9
|
+
color: ${props => props.$error
|
|
10
|
+
? props.theme.colors.accent.error
|
|
11
|
+
: props.theme.colors.text.muted};
|
|
12
|
+
margin-top: ${props => props.theme.spacing.xs}px;
|
|
13
|
+
|
|
14
|
+
/* Custom CSS */
|
|
15
|
+
${props => processCss(props.$css, props.theme)}
|
|
16
|
+
`;
|
|
17
|
+
/**
|
|
18
|
+
* A standardized helper text component for use with form controls.
|
|
19
|
+
*
|
|
20
|
+
* Provides consistent styling for helper text and error messages
|
|
21
|
+
* across different form components.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```tsx
|
|
25
|
+
* <Input label="Email" />
|
|
26
|
+
* <FormHelperText>We'll never share your email with anyone else.</FormHelperText>
|
|
27
|
+
*
|
|
28
|
+
* <Input label="Username" error={!!usernameError} />
|
|
29
|
+
* <FormHelperText error>{usernameError}</FormHelperText>
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
const FormHelperText = /*#__PURE__*/ React.memo(({ children, error = false, className, style, css, ref, ...rest }) => {
|
|
33
|
+
return (jsx(StyledHelperText, { ref: ref, "$error": error, "$css": css, className: className, style: style, ...rest, children: children }));
|
|
34
|
+
});
|
|
35
|
+
FormHelperText.displayName = 'FormHelperText';
|
|
36
|
+
|
|
37
|
+
export { FormHelperText };
|
|
38
|
+
//# sourceMappingURL=FormHelperText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormHelperText.js","sources":["../../../../../src/components/form/FormHelperText.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;AAqBA,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAGjC;eACa,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAA;iBACzC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAA;AACtD,SAAA,EAAA,KAAK,IACZ,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;MAC1B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAA;gBACrB,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAA;;;AAG3C,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;CAC/C;AAED;;;;;;;;;;;;;;AAcG;AACI,MAAM,cAAc,iBAAiB,KAAK,CAAC,IAAI,CACpD,CAAC,EAAE,QAAQ,EAAE,KAAK,GAAG,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,KAAI;IACnE,QACEA,GAAC,CAAA,gBAAgB,EACf,EAAA,GAAG,EAAE,GAAG,EAAA,QAAA,EACA,KAAK,EAAA,MAAA,EACP,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACR,GAAA,IAAI,EAEP,QAAA,EAAA,QAAQ,EACQ,CAAA;AAEvB,CAAC;AAGH,cAAc,CAAC,WAAW,GAAG,gBAAgB;;;;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import { processCss } from '../../utils/styledUtils.js';
|
|
5
|
+
|
|
6
|
+
const StyledLabel = styled.label `
|
|
7
|
+
font-size: ${props => props.theme.typography.fontSize.sm}px;
|
|
8
|
+
font-weight: ${props => props.theme.typography.fontWeight.medium};
|
|
9
|
+
color: ${props => props.$disabled
|
|
10
|
+
? props.theme.colors.text.disabled
|
|
11
|
+
: props.theme.colors.text.secondary};
|
|
12
|
+
line-height: ${props => props.theme.typography.lineHeight.tight};
|
|
13
|
+
margin-bottom: ${props => props.theme.spacing.xs}px;
|
|
14
|
+
display: inline-block;
|
|
15
|
+
|
|
16
|
+
/* Custom CSS */
|
|
17
|
+
${props => processCss(props.$css, props.theme)}
|
|
18
|
+
`;
|
|
19
|
+
const RequiredIndicator = styled.span `
|
|
20
|
+
color: ${props => props.theme.colors.accent.error};
|
|
21
|
+
margin-left: 2px;
|
|
22
|
+
`;
|
|
23
|
+
/**
|
|
24
|
+
* A standardized form label component for use with form controls.
|
|
25
|
+
*
|
|
26
|
+
* Provides consistent styling and behavior for labels across different
|
|
27
|
+
* form components, with support for required indicators and disabled states.
|
|
28
|
+
*
|
|
29
|
+
* @example
|
|
30
|
+
* ```tsx
|
|
31
|
+
* <FormLabel htmlFor="name-input" required>
|
|
32
|
+
* Full Name
|
|
33
|
+
* </FormLabel>
|
|
34
|
+
* <Input id="name-input" />
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
const FormLabel = /*#__PURE__*/ React.memo(({ children, htmlFor, disabled = false, required = false, className, style, css, ref, ...rest }) => {
|
|
38
|
+
return (jsxs(StyledLabel, { ref: ref, htmlFor: htmlFor, "$disabled": disabled, "$css": css, className: className, style: style, ...rest, children: [children, required && jsx(RequiredIndicator, { children: " *" })] }));
|
|
39
|
+
});
|
|
40
|
+
FormLabel.displayName = 'FormLabel';
|
|
41
|
+
|
|
42
|
+
export { FormLabel };
|
|
43
|
+
//# sourceMappingURL=FormLabel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FormLabel.js","sources":["../../../../../src/components/form/FormLabel.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;;AAgCA,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAG9B;eACa,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAA;iBACzC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,MAAM,CAAA;AACvD,SAAA,EAAA,KAAK,IACZ,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC;MACxB,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAA;iBACxB,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,CAAA;mBAC9C,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAA;;;;AAI9C,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;CAC/C;AAED,MAAM,iBAAiB,GAAG,MAAM,CAAC,IAAI,CAAA;WAC1B,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAA;;CAElD;AAED;;;;;;;;;;;;;AAaG;AACU,MAAA,SAAS,iBAAiB,KAAK,CAAC,IAAI,CAC/C,CAAC,EACC,QAAQ,EACR,OAAO,EACP,QAAQ,GAAG,KAAK,EAChB,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,IAAI,EACR,KAAI;AACH,IAAA,QACEA,IAAA,CAAC,WAAW,EAAA,EACV,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,OAAO,EAAA,WAAA,EACL,QAAQ,EAAA,MAAA,EACb,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EAAA,GACR,IAAI,EAEP,QAAA,EAAA,CAAA,QAAQ,EACR,QAAQ,IAAIC,GAAC,CAAA,iBAAiB,EAAuB,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,CAAA,EAAA,CAC1C;AAElB,CAAC;AAGH,SAAS,CAAC,WAAW,GAAG,WAAW;;;;"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import { processCss } from '../../utils/styledUtils.js';
|
|
5
|
+
|
|
6
|
+
const StyledInputWrapper = styled.div `
|
|
7
|
+
position: relative;
|
|
8
|
+
display: flex;
|
|
9
|
+
align-items: center;
|
|
10
|
+
border: 1px solid;
|
|
11
|
+
border-radius: ${props => props.theme.borderRadius.md}px;
|
|
12
|
+
transition: all ${props => props.theme.transitions.normal};
|
|
13
|
+
background: ${props => props.$disabled
|
|
14
|
+
? props.theme.colors.surface.disabled
|
|
15
|
+
: props.theme.colors.surface.default};
|
|
16
|
+
|
|
17
|
+
/* Size variants */
|
|
18
|
+
${props => {
|
|
19
|
+
const sizes = {
|
|
20
|
+
sm: {
|
|
21
|
+
height: '20px',
|
|
22
|
+
padding: `0 ${props.theme.spacing.sm}px`,
|
|
23
|
+
},
|
|
24
|
+
md: {
|
|
25
|
+
height: '24px',
|
|
26
|
+
padding: `0 ${props.theme.spacing.md}px`,
|
|
27
|
+
},
|
|
28
|
+
lg: {
|
|
29
|
+
height: '32px',
|
|
30
|
+
padding: `0 ${props.theme.spacing.lg}px`,
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
const size = sizes[props.$size];
|
|
34
|
+
return `
|
|
35
|
+
height: ${size.height};
|
|
36
|
+
padding: ${size.padding};
|
|
37
|
+
`;
|
|
38
|
+
}}
|
|
39
|
+
|
|
40
|
+
/* Border color states */
|
|
41
|
+
border-color: ${props => {
|
|
42
|
+
if (props.$error)
|
|
43
|
+
return props.theme.colors.border.error;
|
|
44
|
+
if (props.$focused)
|
|
45
|
+
return props.theme.colors.border.focus;
|
|
46
|
+
return props.theme.colors.border.default;
|
|
47
|
+
}};
|
|
48
|
+
|
|
49
|
+
/* Focus ring */
|
|
50
|
+
${props => props.$focused &&
|
|
51
|
+
!props.$error &&
|
|
52
|
+
`
|
|
53
|
+
box-shadow: 0 0 0 2px ${props.theme.colors.accent.primary}20;
|
|
54
|
+
`}
|
|
55
|
+
|
|
56
|
+
/* Disabled state */
|
|
57
|
+
${props => props.$disabled &&
|
|
58
|
+
`
|
|
59
|
+
opacity: 0.5;
|
|
60
|
+
cursor: not-allowed;
|
|
61
|
+
`}
|
|
62
|
+
|
|
63
|
+
/* Hover state */
|
|
64
|
+
&:hover:not(:focus-within) {
|
|
65
|
+
border-color: ${props => {
|
|
66
|
+
if (props.$disabled || props.$error)
|
|
67
|
+
return 'inherit';
|
|
68
|
+
return props.theme.colors.border.focus;
|
|
69
|
+
}};
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/* Custom CSS */
|
|
73
|
+
${props => processCss(props.$css, props.theme)}
|
|
74
|
+
`;
|
|
75
|
+
/**
|
|
76
|
+
* A standardized wrapper component for form inputs.
|
|
77
|
+
*
|
|
78
|
+
* Provides consistent styling and behavior for input containers
|
|
79
|
+
* across different form components, with support for different sizes,
|
|
80
|
+
* states (error, disabled, focused), and consistent border styling.
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* ```tsx
|
|
84
|
+
* <InputWrapper
|
|
85
|
+
* size="md"
|
|
86
|
+
* error={!!inputError}
|
|
87
|
+
* disabled={isDisabled}
|
|
88
|
+
* focused={isFocused}
|
|
89
|
+
* >
|
|
90
|
+
* <input type="text" />
|
|
91
|
+
* </InputWrapper>
|
|
92
|
+
* ```
|
|
93
|
+
*/
|
|
94
|
+
const InputWrapper = /*#__PURE__*/ React.memo(({ children, size = 'md', error = false, disabled = false, focused = false, className, style, css, ref, ...rest }) => {
|
|
95
|
+
return (jsx(StyledInputWrapper, { ref: ref, "$size": size, "$error": error, "$disabled": disabled, "$focused": focused, "$css": css, className: className, style: style, ...rest, children: children }));
|
|
96
|
+
});
|
|
97
|
+
InputWrapper.displayName = 'InputWrapper';
|
|
98
|
+
|
|
99
|
+
export { InputWrapper, StyledInputWrapper };
|
|
100
|
+
//# sourceMappingURL=InputWrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InputWrapper.js","sources":["../../../../../src/components/form/InputWrapper.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":";;;;;AAkDa,MAAA,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAyB;;;;;mBAKlD,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAA;oBACnC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAA;AAC3C,cAAA,EAAA,KAAK,IACjB,KAAK,CAAC;MACF,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;MAC3B,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAA;;;AAGtC,EAAA,EAAA,KAAK,IAAG;AACR,IAAA,MAAM,KAAK,GAAG;AACZ,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;AACD,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;AACD,QAAA,EAAE,EAAE;AACF,YAAA,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAI,EAAA,CAAA;AACzC,SAAA;KACF;IACD,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;IAC/B,OAAO;AACK,cAAA,EAAA,IAAI,CAAC,MAAM,CAAA;AACV,eAAA,EAAA,IAAI,CAAC,OAAO,CAAA;KACxB;AACH,CAAC;;;AAGe,gBAAA,EAAA,KAAK,IAAG;IACtB,IAAI,KAAK,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;IACxD,IAAI,KAAK,CAAC,QAAQ;QAAE,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;IAC1D,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO;AAC1C,CAAC,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,QAAQ;IACd,CAAC,KAAK,CAAC,MAAM;AACb,IAAA;AACwB,0BAAA,EAAA,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAA;AAC1D,EAAA,CAAA;;;AAGC,EAAA,EAAA,KAAK,IACL,KAAK,CAAC,SAAS;AACf,IAAA;;;AAGD,EAAA,CAAA;;;;AAIiB,kBAAA,EAAA,KAAK,IAAG;AACtB,IAAA,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM;AAAE,QAAA,OAAO,SAAS;IACrD,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;AACxC,CAAC,CAAA;;;;AAID,EAAA,EAAA,KAAK,IAAI,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC;;AAGhD;;;;;;;;;;;;;;;;;;AAkBG;AACU,MAAA,YAAY,iBAAiB,KAAK,CAAC,IAAI,CAClD,CAAC,EACC,QAAQ,EACR,IAAI,GAAG,IAAI,EACX,KAAK,GAAG,KAAK,EACb,QAAQ,GAAG,KAAK,EAChB,OAAO,GAAG,KAAK,EACf,SAAS,EACT,KAAK,EACL,GAAG,EACH,GAAG,EACH,GAAG,IAAI,EACR,KAAI;AACH,IAAA,QACEA,GAAA,CAAC,kBAAkB,EAAA,EACjB,GAAG,EAAE,GAAG,EAAA,OAAA,EACD,IAAI,EAAA,QAAA,EACH,KAAK,EAAA,WAAA,EACF,QAAQ,EACT,UAAA,EAAA,OAAO,EACX,MAAA,EAAA,GAAG,EACT,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EAAA,GACR,IAAI,EAAA,QAAA,EAEP,QAAQ,EAAA,CACU;AAEzB,CAAC;AAGH,YAAY,CAAC,WAAW,GAAG,cAAc;;;;"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useId, useState, useCallback, createContext, useContext } from 'react';
|
|
3
|
+
import styled from '@emotion/styled';
|
|
4
|
+
import { processCss } from '../../../utils/styledUtils.js';
|
|
5
|
+
|
|
6
|
+
// --- Contexts ---
|
|
7
|
+
const AccordionContext =
|
|
8
|
+
/*#__PURE__*/ createContext(null);
|
|
9
|
+
const AccordionItemContext =
|
|
10
|
+
/*#__PURE__*/ createContext(null);
|
|
11
|
+
function useAccordionContext() {
|
|
12
|
+
const ctx = useContext(AccordionContext);
|
|
13
|
+
if (!ctx) {
|
|
14
|
+
throw new Error('Accordion compound components must be used within <Accordion>');
|
|
15
|
+
}
|
|
16
|
+
return ctx;
|
|
17
|
+
}
|
|
18
|
+
function useAccordionItemContext() {
|
|
19
|
+
const ctx = useContext(AccordionItemContext);
|
|
20
|
+
if (!ctx) {
|
|
21
|
+
throw new Error('AccordionTrigger/AccordionContent must be used within <AccordionItem>');
|
|
22
|
+
}
|
|
23
|
+
return ctx;
|
|
24
|
+
}
|
|
25
|
+
// --- Helpers ---
|
|
26
|
+
function normalizeValue(value) {
|
|
27
|
+
if (value === undefined)
|
|
28
|
+
return [];
|
|
29
|
+
if (Array.isArray(value))
|
|
30
|
+
return value;
|
|
31
|
+
return [value];
|
|
32
|
+
}
|
|
33
|
+
const StyledAccordionRoot = styled.div `
|
|
34
|
+
display: flex;
|
|
35
|
+
flex-direction: column;
|
|
36
|
+
gap: ${props => props.$gap}px;
|
|
37
|
+
|
|
38
|
+
${props => processCss(props.$css, props.theme)}
|
|
39
|
+
`;
|
|
40
|
+
// --- Component ---
|
|
41
|
+
/**
|
|
42
|
+
* Accordion component for collapsible sections in property inspectors
|
|
43
|
+
* and settings panels.
|
|
44
|
+
*
|
|
45
|
+
* Compound component pattern: use with AccordionItem, AccordionTrigger,
|
|
46
|
+
* and AccordionContent.
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```tsx
|
|
50
|
+
* <Accordion defaultValue="transform">
|
|
51
|
+
* <AccordionItem value="transform">
|
|
52
|
+
* <AccordionTrigger>Transform</AccordionTrigger>
|
|
53
|
+
* <AccordionContent>Position, rotation, scale fields...</AccordionContent>
|
|
54
|
+
* </AccordionItem>
|
|
55
|
+
* </Accordion>
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
const Accordion = ({ value: valueProp, defaultValue, multiple = false, collapsible = false, variant = 'default', size = 'md', gap = 0, children, onChange, className, style, css, testId, ref, ...rest }) => {
|
|
59
|
+
const autoId = useId();
|
|
60
|
+
const [internalValue, setInternalValue] = useState(normalizeValue(defaultValue));
|
|
61
|
+
const isControlled = valueProp !== undefined;
|
|
62
|
+
const expandedItems = isControlled
|
|
63
|
+
? normalizeValue(valueProp)
|
|
64
|
+
: internalValue;
|
|
65
|
+
const toggleItem = useCallback((itemValue) => {
|
|
66
|
+
const isExpanded = expandedItems.includes(itemValue);
|
|
67
|
+
let nextExpanded;
|
|
68
|
+
if (multiple) {
|
|
69
|
+
nextExpanded = isExpanded
|
|
70
|
+
? expandedItems.filter(v => v !== itemValue)
|
|
71
|
+
: [...expandedItems, itemValue];
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
if (isExpanded) {
|
|
75
|
+
nextExpanded = collapsible ? [] : expandedItems;
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
nextExpanded = [itemValue];
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (!isControlled) {
|
|
82
|
+
setInternalValue(nextExpanded);
|
|
83
|
+
}
|
|
84
|
+
if (multiple) {
|
|
85
|
+
onChange?.(nextExpanded);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
onChange?.(nextExpanded[0] ?? '');
|
|
89
|
+
}
|
|
90
|
+
}, [expandedItems, multiple, collapsible, isControlled, onChange]);
|
|
91
|
+
const contextValue = {
|
|
92
|
+
expandedItems,
|
|
93
|
+
toggleItem,
|
|
94
|
+
variant,
|
|
95
|
+
size,
|
|
96
|
+
accordionId: autoId,
|
|
97
|
+
};
|
|
98
|
+
return (jsx(AccordionContext.Provider, { value: contextValue, children: jsx(StyledAccordionRoot, { ref: ref, "$gap": gap, "$css": css, className: className, style: style, "data-testid": testId, ...rest, children: children }) }));
|
|
99
|
+
};
|
|
100
|
+
Accordion.displayName = 'Accordion';
|
|
101
|
+
|
|
102
|
+
export { Accordion, AccordionContext, AccordionItemContext, useAccordionContext, useAccordionItemContext };
|
|
103
|
+
//# sourceMappingURL=Accordion.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Accordion.js","sources":["../../../../../../src/components/layout/Accordion/Accordion.tsx"],"sourcesContent":[null],"names":["_jsx"],"mappings":"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"}
|