selva-shared 0.8.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +45 -0
- package/dist/components/AppLayout.svelte +439 -0
- package/dist/components/AppLayout.svelte.d.ts +17 -0
- package/dist/components/CollapsedPanelStrip.svelte +67 -0
- package/dist/components/CollapsedPanelStrip.svelte.d.ts +11 -0
- package/dist/components/ComputeMessages.svelte +172 -0
- package/dist/components/ComputeMessages.svelte.d.ts +7 -0
- package/dist/components/ErrorScreen.svelte +55 -0
- package/dist/components/ErrorScreen.svelte.d.ts +9 -0
- package/dist/components/StateManager.svelte +318 -0
- package/dist/components/StateManager.svelte.d.ts +9 -0
- package/dist/components/Viewer.svelte +207 -0
- package/dist/components/Viewer.svelte.d.ts +12 -0
- package/dist/components/layout/FooterItemRenderer.svelte +20 -0
- package/dist/components/layout/FooterItemRenderer.svelte.d.ts +7 -0
- package/dist/components/layout/PageContainer.svelte +36 -0
- package/dist/components/layout/PageContainer.svelte.d.ts +12 -0
- package/dist/components/layout/PageFooter.svelte +223 -0
- package/dist/components/layout/PageFooter.svelte.d.ts +9 -0
- package/dist/components/layout/PageHeader.svelte +89 -0
- package/dist/components/layout/PageHeader.svelte.d.ts +12 -0
- package/dist/components/layout/index.d.ts +3 -0
- package/dist/components/layout/index.js +4 -0
- package/dist/components/preview/ChartOutput.svelte +257 -0
- package/dist/components/preview/ChartOutput.svelte.d.ts +8 -0
- package/dist/components/preview/Group.svelte +121 -0
- package/dist/components/preview/Group.svelte.d.ts +23 -0
- package/dist/components/preview/InputControl.svelte +119 -0
- package/dist/components/preview/InputControl.svelte.d.ts +11 -0
- package/dist/components/preview/OutputDisplay.svelte +296 -0
- package/dist/components/preview/OutputDisplay.svelte.d.ts +9 -0
- package/dist/components/preview/TabBar.svelte +36 -0
- package/dist/components/preview/TabBar.svelte.d.ts +8 -0
- package/dist/components/preview/TabContent.svelte +124 -0
- package/dist/components/preview/TabContent.svelte.d.ts +13 -0
- package/dist/components/preview/TabLayout.svelte +109 -0
- package/dist/components/preview/TabLayout.svelte.d.ts +13 -0
- package/dist/components/preview/index.d.ts +3 -0
- package/dist/components/preview/index.js +4 -0
- package/dist/components/preview/inputs/CheckboxInput.svelte +29 -0
- package/dist/components/preview/inputs/CheckboxInput.svelte.d.ts +10 -0
- package/dist/components/preview/inputs/ColorInput.svelte +21 -0
- package/dist/components/preview/inputs/ColorInput.svelte.d.ts +7 -0
- package/dist/components/preview/inputs/DropdownInput.svelte +40 -0
- package/dist/components/preview/inputs/DropdownInput.svelte.d.ts +10 -0
- package/dist/components/preview/inputs/FileInput.svelte +358 -0
- package/dist/components/preview/inputs/FileInput.svelte.d.ts +10 -0
- package/dist/components/preview/inputs/NumberInput.svelte +152 -0
- package/dist/components/preview/inputs/NumberInput.svelte.d.ts +11 -0
- package/dist/components/preview/inputs/TextInput.svelte +74 -0
- package/dist/components/preview/inputs/TextInput.svelte.d.ts +11 -0
- package/dist/components/preview/inputs/index.d.ts +6 -0
- package/dist/components/preview/inputs/index.js +6 -0
- package/dist/components/ui/CalculateButton.svelte +56 -0
- package/dist/components/ui/CalculateButton.svelte.d.ts +9 -0
- package/dist/components/ui/SolvingIndicator.svelte +55 -0
- package/dist/components/ui/SolvingIndicator.svelte.d.ts +6 -0
- package/dist/components/ui/StateDisplay.svelte +106 -0
- package/dist/components/ui/StateDisplay.svelte.d.ts +10 -0
- package/dist/components/ui/alert/alert-description.svelte +23 -0
- package/dist/components/ui/alert/alert-description.svelte.d.ts +5 -0
- package/dist/components/ui/alert/alert-title.svelte +20 -0
- package/dist/components/ui/alert/alert-title.svelte.d.ts +5 -0
- package/dist/components/ui/alert/alert.svelte +44 -0
- package/dist/components/ui/alert/alert.svelte.d.ts +26 -0
- package/dist/components/ui/alert/index.d.ts +5 -0
- package/dist/components/ui/alert/index.js +7 -0
- package/dist/components/ui/alert-dialog/alert-dialog-action.svelte +18 -0
- package/dist/components/ui/alert-dialog/alert-dialog-action.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/alert-dialog-cancel.svelte +18 -0
- package/dist/components/ui/alert-dialog/alert-dialog-cancel.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/alert-dialog-content.svelte +27 -0
- package/dist/components/ui/alert-dialog/alert-dialog-content.svelte.d.ts +8 -0
- package/dist/components/ui/alert-dialog/alert-dialog-description.svelte +17 -0
- package/dist/components/ui/alert-dialog/alert-dialog-description.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/alert-dialog-footer.svelte +20 -0
- package/dist/components/ui/alert-dialog/alert-dialog-footer.svelte.d.ts +5 -0
- package/dist/components/ui/alert-dialog/alert-dialog-header.svelte +20 -0
- package/dist/components/ui/alert-dialog/alert-dialog-header.svelte.d.ts +5 -0
- package/dist/components/ui/alert-dialog/alert-dialog-overlay.svelte +20 -0
- package/dist/components/ui/alert-dialog/alert-dialog-overlay.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/alert-dialog-title.svelte +17 -0
- package/dist/components/ui/alert-dialog/alert-dialog-title.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/alert-dialog-trigger.svelte +7 -0
- package/dist/components/ui/alert-dialog/alert-dialog-trigger.svelte.d.ts +4 -0
- package/dist/components/ui/alert-dialog/index.d.ts +12 -0
- package/dist/components/ui/alert-dialog/index.js +15 -0
- package/dist/components/ui/badge/badge.svelte +50 -0
- package/dist/components/ui/badge/badge.svelte.d.ts +32 -0
- package/dist/components/ui/badge/index.d.ts +2 -0
- package/dist/components/ui/badge/index.js +2 -0
- package/dist/components/ui/button/button.svelte +83 -0
- package/dist/components/ui/button/button.svelte.d.ts +67 -0
- package/dist/components/ui/button/index.d.ts +2 -0
- package/dist/components/ui/button/index.js +4 -0
- package/dist/components/ui/button-group/button-group-separator.svelte +20 -0
- package/dist/components/ui/button-group/button-group-separator.svelte.d.ts +13 -0
- package/dist/components/ui/button-group/button-group-text.svelte +30 -0
- package/dist/components/ui/button-group/button-group-text.svelte.d.ts +11 -0
- package/dist/components/ui/button-group/button-group.svelte +46 -0
- package/dist/components/ui/button-group/button-group.svelte.d.ts +26 -0
- package/dist/components/ui/button-group/index.d.ts +4 -0
- package/dist/components/ui/button-group/index.js +6 -0
- package/dist/components/ui/card/card-action.svelte +20 -0
- package/dist/components/ui/card/card-action.svelte.d.ts +5 -0
- package/dist/components/ui/card/card-content.svelte +15 -0
- package/dist/components/ui/card/card-content.svelte.d.ts +5 -0
- package/dist/components/ui/card/card-description.svelte +20 -0
- package/dist/components/ui/card/card-description.svelte.d.ts +5 -0
- package/dist/components/ui/card/card-footer.svelte +20 -0
- package/dist/components/ui/card/card-footer.svelte.d.ts +5 -0
- package/dist/components/ui/card/card-header.svelte +23 -0
- package/dist/components/ui/card/card-header.svelte.d.ts +5 -0
- package/dist/components/ui/card/card-title.svelte +20 -0
- package/dist/components/ui/card/card-title.svelte.d.ts +5 -0
- package/dist/components/ui/card/card.svelte +23 -0
- package/dist/components/ui/card/card.svelte.d.ts +5 -0
- package/dist/components/ui/card/index.d.ts +8 -0
- package/dist/components/ui/card/index.js +10 -0
- package/dist/components/ui/checkbox/checkbox.svelte +36 -0
- package/dist/components/ui/checkbox/checkbox.svelte.d.ts +4 -0
- package/dist/components/ui/checkbox/index.d.ts +2 -0
- package/dist/components/ui/checkbox/index.js +4 -0
- package/dist/components/ui/collapsible/collapsible-content.svelte +7 -0
- package/dist/components/ui/collapsible/collapsible-content.svelte.d.ts +4 -0
- package/dist/components/ui/collapsible/collapsible-trigger.svelte +7 -0
- package/dist/components/ui/collapsible/collapsible-trigger.svelte.d.ts +4 -0
- package/dist/components/ui/collapsible/collapsible.svelte +11 -0
- package/dist/components/ui/collapsible/collapsible.svelte.d.ts +4 -0
- package/dist/components/ui/collapsible/index.d.ts +4 -0
- package/dist/components/ui/collapsible/index.js +6 -0
- package/dist/components/ui/context-menu/context-menu-checkbox-item.svelte +38 -0
- package/dist/components/ui/context-menu/context-menu-checkbox-item.svelte.d.ts +9 -0
- package/dist/components/ui/context-menu/context-menu-content.svelte +25 -0
- package/dist/components/ui/context-menu/context-menu-content.svelte.d.ts +7 -0
- package/dist/components/ui/context-menu/context-menu-group-heading.svelte +21 -0
- package/dist/components/ui/context-menu/context-menu-group-heading.svelte.d.ts +7 -0
- package/dist/components/ui/context-menu/context-menu-group.svelte +7 -0
- package/dist/components/ui/context-menu/context-menu-group.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/context-menu-item.svelte +27 -0
- package/dist/components/ui/context-menu/context-menu-item.svelte.d.ts +8 -0
- package/dist/components/ui/context-menu/context-menu-label.svelte +24 -0
- package/dist/components/ui/context-menu/context-menu-label.svelte.d.ts +8 -0
- package/dist/components/ui/context-menu/context-menu-radio-group.svelte +16 -0
- package/dist/components/ui/context-menu/context-menu-radio-group.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/context-menu-radio-item.svelte +31 -0
- package/dist/components/ui/context-menu/context-menu-radio-item.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/context-menu-separator.svelte +17 -0
- package/dist/components/ui/context-menu/context-menu-separator.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/context-menu-shortcut.svelte +20 -0
- package/dist/components/ui/context-menu/context-menu-shortcut.svelte.d.ts +5 -0
- package/dist/components/ui/context-menu/context-menu-sub-content.svelte +20 -0
- package/dist/components/ui/context-menu/context-menu-sub-content.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/context-menu-sub-trigger.svelte +29 -0
- package/dist/components/ui/context-menu/context-menu-sub-trigger.svelte.d.ts +8 -0
- package/dist/components/ui/context-menu/context-menu-trigger.svelte +7 -0
- package/dist/components/ui/context-menu/context-menu-trigger.svelte.d.ts +4 -0
- package/dist/components/ui/context-menu/index.d.ts +16 -0
- package/dist/components/ui/context-menu/index.js +19 -0
- package/dist/components/ui/dialog/dialog-close.svelte +7 -0
- package/dist/components/ui/dialog/dialog-close.svelte.d.ts +4 -0
- package/dist/components/ui/dialog/dialog-content.svelte +43 -0
- package/dist/components/ui/dialog/dialog-content.svelte.d.ts +11 -0
- package/dist/components/ui/dialog/dialog-description.svelte +17 -0
- package/dist/components/ui/dialog/dialog-description.svelte.d.ts +4 -0
- package/dist/components/ui/dialog/dialog-footer.svelte +20 -0
- package/dist/components/ui/dialog/dialog-footer.svelte.d.ts +5 -0
- package/dist/components/ui/dialog/dialog-header.svelte +20 -0
- package/dist/components/ui/dialog/dialog-header.svelte.d.ts +5 -0
- package/dist/components/ui/dialog/dialog-overlay.svelte +20 -0
- package/dist/components/ui/dialog/dialog-overlay.svelte.d.ts +4 -0
- package/dist/components/ui/dialog/dialog-title.svelte +17 -0
- package/dist/components/ui/dialog/dialog-title.svelte.d.ts +4 -0
- package/dist/components/ui/dialog/dialog-trigger.svelte +7 -0
- package/dist/components/ui/dialog/dialog-trigger.svelte.d.ts +4 -0
- package/dist/components/ui/dialog/index.d.ts +11 -0
- package/dist/components/ui/dialog/index.js +14 -0
- package/dist/components/ui/field/field-content.svelte +20 -0
- package/dist/components/ui/field/field-content.svelte.d.ts +5 -0
- package/dist/components/ui/field/field-description.svelte +25 -0
- package/dist/components/ui/field/field-description.svelte.d.ts +5 -0
- package/dist/components/ui/field/field-error.svelte +58 -0
- package/dist/components/ui/field/field-error.svelte.d.ts +12 -0
- package/dist/components/ui/field/field-group.svelte +23 -0
- package/dist/components/ui/field/field-group.svelte.d.ts +5 -0
- package/dist/components/ui/field/field-label.svelte +26 -0
- package/dist/components/ui/field/field-label.svelte.d.ts +10 -0
- package/dist/components/ui/field/field-legend.svelte +29 -0
- package/dist/components/ui/field/field-legend.svelte.d.ts +8 -0
- package/dist/components/ui/field/field-separator.svelte +38 -0
- package/dist/components/ui/field/field-separator.svelte.d.ts +9 -0
- package/dist/components/ui/field/field-set.svelte +24 -0
- package/dist/components/ui/field/field-set.svelte.d.ts +5 -0
- package/dist/components/ui/field/field-title.svelte +23 -0
- package/dist/components/ui/field/field-title.svelte.d.ts +5 -0
- package/dist/components/ui/field/field.svelte +53 -0
- package/dist/components/ui/field/field.svelte.d.ts +29 -0
- package/dist/components/ui/field/index.d.ts +11 -0
- package/dist/components/ui/field/index.js +13 -0
- package/dist/components/ui/index.d.ts +21 -0
- package/dist/components/ui/index.js +24 -0
- package/dist/components/ui/input/index.d.ts +2 -0
- package/dist/components/ui/input/index.js +4 -0
- package/dist/components/ui/input/input.svelte +52 -0
- package/dist/components/ui/input/input.svelte.d.ts +13 -0
- package/dist/components/ui/label/index.d.ts +2 -0
- package/dist/components/ui/label/index.js +4 -0
- package/dist/components/ui/label/label.svelte +20 -0
- package/dist/components/ui/label/label.svelte.d.ts +4 -0
- package/dist/components/ui/mode-toggle/index.d.ts +1 -0
- package/dist/components/ui/mode-toggle/index.js +1 -0
- package/dist/components/ui/mode-toggle/mode-toggle.svelte +16 -0
- package/dist/components/ui/mode-toggle/mode-toggle.svelte.d.ts +18 -0
- package/dist/components/ui/resizable/index.d.ts +4 -0
- package/dist/components/ui/resizable/index.js +6 -0
- package/dist/components/ui/resizable/resizable-handle.svelte +30 -0
- package/dist/components/ui/resizable/resizable-handle.svelte.d.ts +8 -0
- package/dist/components/ui/resizable/resizable-pane-group.svelte +20 -0
- package/dist/components/ui/resizable/resizable-pane-group.svelte.d.ts +7 -0
- package/dist/components/ui/scroll-area/index.d.ts +3 -0
- package/dist/components/ui/scroll-area/index.js +5 -0
- package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
- package/dist/components/ui/scroll-area/scroll-area-scrollbar.svelte.d.ts +4 -0
- package/dist/components/ui/scroll-area/scroll-area.svelte +43 -0
- package/dist/components/ui/scroll-area/scroll-area.svelte.d.ts +11 -0
- package/dist/components/ui/select/index.d.ts +11 -0
- package/dist/components/ui/select/index.js +14 -0
- package/dist/components/ui/select/select-content.svelte +40 -0
- package/dist/components/ui/select/select-content.svelte.d.ts +8 -0
- package/dist/components/ui/select/select-group-heading.svelte +21 -0
- package/dist/components/ui/select/select-group-heading.svelte.d.ts +10 -0
- package/dist/components/ui/select/select-group.svelte +7 -0
- package/dist/components/ui/select/select-group.svelte.d.ts +4 -0
- package/dist/components/ui/select/select-item.svelte +38 -0
- package/dist/components/ui/select/select-item.svelte.d.ts +4 -0
- package/dist/components/ui/select/select-label.svelte +20 -0
- package/dist/components/ui/select/select-label.svelte.d.ts +6 -0
- package/dist/components/ui/select/select-scroll-down-button.svelte +20 -0
- package/dist/components/ui/select/select-scroll-down-button.svelte.d.ts +4 -0
- package/dist/components/ui/select/select-scroll-up-button.svelte +20 -0
- package/dist/components/ui/select/select-scroll-up-button.svelte.d.ts +4 -0
- package/dist/components/ui/select/select-separator.svelte +18 -0
- package/dist/components/ui/select/select-separator.svelte.d.ts +4 -0
- package/dist/components/ui/select/select-trigger.svelte +29 -0
- package/dist/components/ui/select/select-trigger.svelte.d.ts +8 -0
- package/dist/components/ui/separator/index.d.ts +2 -0
- package/dist/components/ui/separator/index.js +4 -0
- package/dist/components/ui/separator/separator.svelte +21 -0
- package/dist/components/ui/separator/separator.svelte.d.ts +4 -0
- package/dist/components/ui/slider/index.d.ts +2 -0
- package/dist/components/ui/slider/index.js +4 -0
- package/dist/components/ui/slider/slider.svelte +52 -0
- package/dist/components/ui/slider/slider.svelte.d.ts +5 -0
- package/dist/components/ui/sonner/index.d.ts +2 -0
- package/dist/components/ui/sonner/index.js +2 -0
- package/dist/components/ui/sonner/sonner.svelte +13 -0
- package/dist/components/ui/sonner/sonner.svelte.d.ts +4 -0
- package/dist/components/ui/switch/index.d.ts +2 -0
- package/dist/components/ui/switch/index.js +4 -0
- package/dist/components/ui/switch/switch.svelte +29 -0
- package/dist/components/ui/switch/switch.svelte.d.ts +4 -0
- package/dist/components/ui/tabs/index.d.ts +5 -0
- package/dist/components/ui/tabs/index.js +7 -0
- package/dist/components/ui/tabs/tabs-content.svelte +17 -0
- package/dist/components/ui/tabs/tabs-content.svelte.d.ts +4 -0
- package/dist/components/ui/tabs/tabs-list.svelte +16 -0
- package/dist/components/ui/tabs/tabs-list.svelte.d.ts +4 -0
- package/dist/components/ui/tabs/tabs-trigger.svelte +20 -0
- package/dist/components/ui/tabs/tabs-trigger.svelte.d.ts +4 -0
- package/dist/components/ui/tabs/tabs.svelte +19 -0
- package/dist/components/ui/tabs/tabs.svelte.d.ts +4 -0
- package/dist/components/ui/textarea/index.d.ts +2 -0
- package/dist/components/ui/textarea/index.js +4 -0
- package/dist/components/ui/textarea/textarea.svelte +23 -0
- package/dist/components/ui/textarea/textarea.svelte.d.ts +5 -0
- package/dist/components/ui/theme-switcher/ThemeSwitcher.svelte +39 -0
- package/dist/components/ui/theme-switcher/ThemeSwitcher.svelte.d.ts +3 -0
- package/dist/components/ui/theme-switcher/index.d.ts +1 -0
- package/dist/components/ui/theme-switcher/index.js +1 -0
- package/dist/composables/useFooterItem.svelte.d.ts +15 -0
- package/dist/composables/useFooterItem.svelte.js +31 -0
- package/dist/constants.d.ts +6 -0
- package/dist/constants.js +6 -0
- package/dist/contexts/FOOTER_USAGE.md +164 -0
- package/dist/contexts/footerContext.svelte.d.ts +17 -0
- package/dist/contexts/footerContext.svelte.js +24 -0
- package/dist/dummy-output-values.d.ts +3 -0
- package/dist/dummy-output-values.js +53 -0
- package/dist/dummy-surface-chart.json +13 -0
- package/dist/example-schema-left-only.json +367 -0
- package/dist/example-schema-right-only.json +322 -0
- package/dist/example-schema.json +1582 -0
- package/dist/features/preview/handlers.d.ts +55 -0
- package/dist/features/preview/handlers.js +175 -0
- package/dist/features/preview/index.d.ts +2 -0
- package/dist/features/preview/index.js +2 -0
- package/dist/features/preview/notifications.d.ts +11 -0
- package/dist/features/preview/notifications.js +41 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +39 -0
- package/dist/stores/themeStore.svelte.d.ts +12 -0
- package/dist/stores/themeStore.svelte.js +42 -0
- package/dist/styles/base.css +142 -0
- package/dist/styles/themes/cyberpunk.css +98 -0
- package/dist/styles/themes/neutral.css +72 -0
- package/dist/styles/themes/ocean.css +75 -0
- package/dist/styles/themes/selva.css +105 -0
- package/dist/themes.d.ts +5 -0
- package/dist/themes.js +13 -0
- package/dist/types/generated/index.d.ts +6 -0
- package/dist/types/generated/index.js +6 -0
- package/dist/types/generated/preset.d.ts +80 -0
- package/dist/types/generated/preset.js +7 -0
- package/dist/types/generated/schema.d.ts +451 -0
- package/dist/types/generated/schema.js +48 -0
- package/dist/utils/computeThrottle.svelte.d.ts +28 -0
- package/dist/utils/computeThrottle.svelte.js +93 -0
- package/dist/utils/debounce.d.ts +14 -0
- package/dist/utils/debounce.js +25 -0
- package/dist/utils/file-download.d.ts +26 -0
- package/dist/utils/file-download.js +76 -0
- package/dist/utils/loadScript.d.ts +14 -0
- package/dist/utils/loadScript.js +41 -0
- package/dist/utils/param-exporter.d.ts +30 -0
- package/dist/utils/param-exporter.js +186 -0
- package/dist/utils/solving.svelte.d.ts +12 -0
- package/dist/utils/solving.svelte.js +86 -0
- package/dist/utils/utils-shared.d.ts +9 -0
- package/dist/utils/utils-shared.js +53 -0
- package/dist/utils/visibility-rules.d.ts +12 -0
- package/dist/utils/visibility-rules.js +52 -0
- package/dist/utils.d.ts +12 -0
- package/dist/utils.js +5 -0
- package/package.json +70 -0
- package/src/lib/components/AppLayout.svelte +439 -0
- package/src/lib/components/CollapsedPanelStrip.svelte +67 -0
- package/src/lib/components/ComputeMessages.svelte +172 -0
- package/src/lib/components/ErrorScreen.svelte +55 -0
- package/src/lib/components/StateManager.svelte +318 -0
- package/src/lib/components/Viewer.svelte +207 -0
- package/src/lib/components/layout/FooterItemRenderer.svelte +20 -0
- package/src/lib/components/layout/PageContainer.svelte +36 -0
- package/src/lib/components/layout/PageFooter.svelte +223 -0
- package/src/lib/components/layout/PageHeader.svelte +89 -0
- package/src/lib/components/layout/index.ts +4 -0
- package/src/lib/components/preview/ChartOutput.svelte +257 -0
- package/src/lib/components/preview/Group.svelte +121 -0
- package/src/lib/components/preview/InputControl.svelte +119 -0
- package/src/lib/components/preview/OutputDisplay.svelte +296 -0
- package/src/lib/components/preview/TabBar.svelte +36 -0
- package/src/lib/components/preview/TabContent.svelte +124 -0
- package/src/lib/components/preview/TabLayout.svelte +109 -0
- package/src/lib/components/preview/index.ts +4 -0
- package/src/lib/components/preview/inputs/CheckboxInput.svelte +29 -0
- package/src/lib/components/preview/inputs/ColorInput.svelte +21 -0
- package/src/lib/components/preview/inputs/DropdownInput.svelte +40 -0
- package/src/lib/components/preview/inputs/FileInput.svelte +358 -0
- package/src/lib/components/preview/inputs/NumberInput.svelte +152 -0
- package/src/lib/components/preview/inputs/TextInput.svelte +74 -0
- package/src/lib/components/preview/inputs/index.ts +6 -0
- package/src/lib/components/ui/CalculateButton.svelte +56 -0
- package/src/lib/components/ui/SolvingIndicator.svelte +55 -0
- package/src/lib/components/ui/StateDisplay.svelte +106 -0
- package/src/lib/components/ui/alert/alert-description.svelte +23 -0
- package/src/lib/components/ui/alert/alert-title.svelte +20 -0
- package/src/lib/components/ui/alert/alert.svelte +44 -0
- package/src/lib/components/ui/alert/index.ts +14 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-action.svelte +18 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-cancel.svelte +18 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-content.svelte +27 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-description.svelte +17 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-footer.svelte +20 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-header.svelte +20 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-overlay.svelte +20 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-title.svelte +17 -0
- package/src/lib/components/ui/alert-dialog/alert-dialog-trigger.svelte +7 -0
- package/src/lib/components/ui/alert-dialog/index.ts +39 -0
- package/src/lib/components/ui/badge/badge.svelte +50 -0
- package/src/lib/components/ui/badge/index.ts +2 -0
- package/src/lib/components/ui/button/button.svelte +83 -0
- package/src/lib/components/ui/button/index.ts +17 -0
- package/src/lib/components/ui/button-group/button-group-separator.svelte +20 -0
- package/src/lib/components/ui/button-group/button-group-text.svelte +30 -0
- package/src/lib/components/ui/button-group/button-group.svelte +46 -0
- package/src/lib/components/ui/button-group/index.ts +13 -0
- package/src/lib/components/ui/card/card-action.svelte +20 -0
- package/src/lib/components/ui/card/card-content.svelte +15 -0
- package/src/lib/components/ui/card/card-description.svelte +20 -0
- package/src/lib/components/ui/card/card-footer.svelte +20 -0
- package/src/lib/components/ui/card/card-header.svelte +23 -0
- package/src/lib/components/ui/card/card-title.svelte +20 -0
- package/src/lib/components/ui/card/card.svelte +23 -0
- package/src/lib/components/ui/card/index.ts +25 -0
- package/src/lib/components/ui/checkbox/checkbox.svelte +36 -0
- package/src/lib/components/ui/checkbox/index.ts +6 -0
- package/src/lib/components/ui/collapsible/collapsible-content.svelte +7 -0
- package/src/lib/components/ui/collapsible/collapsible-trigger.svelte +7 -0
- package/src/lib/components/ui/collapsible/collapsible.svelte +11 -0
- package/src/lib/components/ui/collapsible/index.ts +13 -0
- package/src/lib/components/ui/context-menu/context-menu-checkbox-item.svelte +38 -0
- package/src/lib/components/ui/context-menu/context-menu-content.svelte +25 -0
- package/src/lib/components/ui/context-menu/context-menu-group-heading.svelte +21 -0
- package/src/lib/components/ui/context-menu/context-menu-group.svelte +7 -0
- package/src/lib/components/ui/context-menu/context-menu-item.svelte +27 -0
- package/src/lib/components/ui/context-menu/context-menu-label.svelte +24 -0
- package/src/lib/components/ui/context-menu/context-menu-radio-group.svelte +16 -0
- package/src/lib/components/ui/context-menu/context-menu-radio-item.svelte +31 -0
- package/src/lib/components/ui/context-menu/context-menu-separator.svelte +17 -0
- package/src/lib/components/ui/context-menu/context-menu-shortcut.svelte +20 -0
- package/src/lib/components/ui/context-menu/context-menu-sub-content.svelte +20 -0
- package/src/lib/components/ui/context-menu/context-menu-sub-trigger.svelte +29 -0
- package/src/lib/components/ui/context-menu/context-menu-trigger.svelte +7 -0
- package/src/lib/components/ui/context-menu/index.ts +51 -0
- package/src/lib/components/ui/dialog/dialog-close.svelte +7 -0
- package/src/lib/components/ui/dialog/dialog-content.svelte +43 -0
- package/src/lib/components/ui/dialog/dialog-description.svelte +17 -0
- package/src/lib/components/ui/dialog/dialog-footer.svelte +20 -0
- package/src/lib/components/ui/dialog/dialog-header.svelte +20 -0
- package/src/lib/components/ui/dialog/dialog-overlay.svelte +20 -0
- package/src/lib/components/ui/dialog/dialog-title.svelte +17 -0
- package/src/lib/components/ui/dialog/dialog-trigger.svelte +7 -0
- package/src/lib/components/ui/dialog/index.ts +37 -0
- package/src/lib/components/ui/field/field-content.svelte +20 -0
- package/src/lib/components/ui/field/field-description.svelte +25 -0
- package/src/lib/components/ui/field/field-error.svelte +58 -0
- package/src/lib/components/ui/field/field-group.svelte +23 -0
- package/src/lib/components/ui/field/field-label.svelte +26 -0
- package/src/lib/components/ui/field/field-legend.svelte +29 -0
- package/src/lib/components/ui/field/field-separator.svelte +38 -0
- package/src/lib/components/ui/field/field-set.svelte +24 -0
- package/src/lib/components/ui/field/field-title.svelte +23 -0
- package/src/lib/components/ui/field/field.svelte +53 -0
- package/src/lib/components/ui/field/index.ts +33 -0
- package/src/lib/components/ui/index.ts +33 -0
- package/src/lib/components/ui/input/index.ts +7 -0
- package/src/lib/components/ui/input/input.svelte +52 -0
- package/src/lib/components/ui/label/index.ts +7 -0
- package/src/lib/components/ui/label/label.svelte +20 -0
- package/src/lib/components/ui/mode-toggle/index.ts +1 -0
- package/src/lib/components/ui/mode-toggle/mode-toggle.svelte +16 -0
- package/src/lib/components/ui/resizable/index.ts +13 -0
- package/src/lib/components/ui/resizable/resizable-handle.svelte +30 -0
- package/src/lib/components/ui/resizable/resizable-pane-group.svelte +20 -0
- package/src/lib/components/ui/scroll-area/index.ts +10 -0
- package/src/lib/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
- package/src/lib/components/ui/scroll-area/scroll-area.svelte +43 -0
- package/src/lib/components/ui/select/index.ts +37 -0
- package/src/lib/components/ui/select/select-content.svelte +40 -0
- package/src/lib/components/ui/select/select-group-heading.svelte +21 -0
- package/src/lib/components/ui/select/select-group.svelte +7 -0
- package/src/lib/components/ui/select/select-item.svelte +38 -0
- package/src/lib/components/ui/select/select-label.svelte +20 -0
- package/src/lib/components/ui/select/select-scroll-down-button.svelte +20 -0
- package/src/lib/components/ui/select/select-scroll-up-button.svelte +20 -0
- package/src/lib/components/ui/select/select-separator.svelte +18 -0
- package/src/lib/components/ui/select/select-trigger.svelte +29 -0
- package/src/lib/components/ui/separator/index.ts +7 -0
- package/src/lib/components/ui/separator/separator.svelte +21 -0
- package/src/lib/components/ui/slider/index.ts +7 -0
- package/src/lib/components/ui/slider/slider.svelte +52 -0
- package/src/lib/components/ui/sonner/index.ts +2 -0
- package/src/lib/components/ui/sonner/sonner.svelte +13 -0
- package/src/lib/components/ui/switch/index.ts +7 -0
- package/src/lib/components/ui/switch/switch.svelte +29 -0
- package/src/lib/components/ui/tabs/index.ts +16 -0
- package/src/lib/components/ui/tabs/tabs-content.svelte +17 -0
- package/src/lib/components/ui/tabs/tabs-list.svelte +16 -0
- package/src/lib/components/ui/tabs/tabs-trigger.svelte +20 -0
- package/src/lib/components/ui/tabs/tabs.svelte +19 -0
- package/src/lib/components/ui/textarea/index.ts +7 -0
- package/src/lib/components/ui/textarea/textarea.svelte +23 -0
- package/src/lib/components/ui/theme-switcher/ThemeSwitcher.svelte +39 -0
- package/src/lib/components/ui/theme-switcher/index.ts +1 -0
- package/src/lib/composables/useFooterItem.svelte.ts +39 -0
- package/src/lib/constants.ts +6 -0
- package/src/lib/contexts/FOOTER_USAGE.md +164 -0
- package/src/lib/contexts/footerContext.svelte.ts +52 -0
- package/src/lib/dummy-output-values.ts +62 -0
- package/src/lib/dummy-surface-chart.json +13 -0
- package/src/lib/example-schema-left-only.json +367 -0
- package/src/lib/example-schema-right-only.json +322 -0
- package/src/lib/example-schema.json +1582 -0
- package/src/lib/features/preview/handlers.ts +243 -0
- package/src/lib/features/preview/index.ts +2 -0
- package/src/lib/features/preview/notifications.ts +52 -0
- package/src/lib/index.ts +52 -0
- package/src/lib/stores/themeStore.svelte.ts +54 -0
- package/src/lib/styles/base.css +142 -0
- package/src/lib/styles/themes/cyberpunk.css +98 -0
- package/src/lib/styles/themes/neutral.css +72 -0
- package/src/lib/styles/themes/ocean.css +75 -0
- package/src/lib/styles/themes/selva.css +105 -0
- package/src/lib/themes.ts +18 -0
- package/src/lib/types/generated/index.ts +6 -0
- package/src/lib/types/generated/preset.ts +82 -0
- package/src/lib/types/generated/schema.ts +527 -0
- package/src/lib/utils/computeThrottle.svelte.ts +117 -0
- package/src/lib/utils/debounce.ts +30 -0
- package/src/lib/utils/file-download.ts +88 -0
- package/src/lib/utils/loadScript.ts +52 -0
- package/src/lib/utils/param-exporter.ts +242 -0
- package/src/lib/utils/solving.svelte.ts +100 -0
- package/src/lib/utils/utils-shared.ts +57 -0
- package/src/lib/utils/visibility-rules.ts +97 -0
- package/src/lib/utils.ts +13 -0
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { Button } from './button';
|
|
3
|
+
import { Zap, Check, Loader, Play } from '@lucide/svelte';
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
hasPendingChanges: boolean;
|
|
7
|
+
hasNeverSolved?: boolean;
|
|
8
|
+
isSolving: boolean;
|
|
9
|
+
oncalculate: () => void;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
let { hasPendingChanges, hasNeverSolved = false, isSolving, oncalculate }: Props = $props();
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<div class="bottom-0 mt-3 pb-3 pt-2 backdrop-blur-sm px-2 sticky border-t border-border/50">
|
|
16
|
+
<Button
|
|
17
|
+
variant={hasPendingChanges ? 'default' : 'ghost'}
|
|
18
|
+
size="lg"
|
|
19
|
+
onclick={() => !isSolving && oncalculate()}
|
|
20
|
+
disabled={!hasPendingChanges && !isSolving}
|
|
21
|
+
aria-busy={isSolving}
|
|
22
|
+
class="gap-2 font-medium w-full transition-all duration-200
|
|
23
|
+
{hasPendingChanges && !isSolving ? 'selva-pending-pulse shadow-md' : ''}
|
|
24
|
+
{!hasPendingChanges && !isSolving ? 'text-muted-foreground' : ''}"
|
|
25
|
+
>
|
|
26
|
+
{#if isSolving}
|
|
27
|
+
<Loader class="h-4 w-4 animate-spin" />
|
|
28
|
+
Solving...
|
|
29
|
+
{:else if hasNeverSolved}
|
|
30
|
+
<Play class="h-4 w-4" />
|
|
31
|
+
Press to calculate
|
|
32
|
+
{:else if hasPendingChanges}
|
|
33
|
+
<Zap class="h-4 w-4" />
|
|
34
|
+
Calculate
|
|
35
|
+
{:else}
|
|
36
|
+
<Check class="h-4 w-4" />
|
|
37
|
+
Up to date
|
|
38
|
+
{/if}
|
|
39
|
+
</Button>
|
|
40
|
+
</div>
|
|
41
|
+
|
|
42
|
+
<style>
|
|
43
|
+
:global(.selva-pending-pulse) {
|
|
44
|
+
animation: selva-pending-pulse 2s ease-in-out infinite;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
@keyframes selva-pending-pulse {
|
|
48
|
+
0%,
|
|
49
|
+
100% {
|
|
50
|
+
box-shadow: 0 0 0 0 hsl(var(--primary) / 0.35);
|
|
51
|
+
}
|
|
52
|
+
50% {
|
|
53
|
+
box-shadow: 0 0 0 5px hsl(var(--primary) / 0);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
</style>
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
interface Props {
|
|
3
|
+
show: boolean;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
let { show }: Props = $props();
|
|
7
|
+
</script>
|
|
8
|
+
|
|
9
|
+
{#if show}
|
|
10
|
+
<!-- Prominent toast in bottom-left -->
|
|
11
|
+
<div
|
|
12
|
+
class="bottom-6 left-6 gap-3 px-5 py-3 shadow-xl fixed z-50 flex animate-[selva-slideInLeft_0.2s_ease-out] items-center rounded-lg border border-primary/20 bg-primary text-primary-foreground"
|
|
13
|
+
>
|
|
14
|
+
<div class="h-5 w-5 relative flex shrink-0 items-center justify-center">
|
|
15
|
+
<div
|
|
16
|
+
class="animate-ping absolute h-full w-full rounded-full bg-primary-foreground opacity-30"
|
|
17
|
+
></div>
|
|
18
|
+
<div
|
|
19
|
+
class="h-3 w-3 animate-spin rounded-full border-2 border-primary-foreground border-t-transparent"
|
|
20
|
+
></div>
|
|
21
|
+
</div>
|
|
22
|
+
<div class="leading-tight flex flex-col">
|
|
23
|
+
<span class="text-sm font-semibold">Solving</span>
|
|
24
|
+
<span class="text-xs opacity-70">Grasshopper is calculating...</span>
|
|
25
|
+
</div>
|
|
26
|
+
</div>
|
|
27
|
+
{/if}
|
|
28
|
+
|
|
29
|
+
<style>
|
|
30
|
+
@keyframes selva-slideInLeft {
|
|
31
|
+
from {
|
|
32
|
+
transform: translateX(-110%);
|
|
33
|
+
opacity: 0;
|
|
34
|
+
}
|
|
35
|
+
to {
|
|
36
|
+
transform: translateX(0);
|
|
37
|
+
opacity: 1;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
@keyframes selva-sweep {
|
|
42
|
+
0% {
|
|
43
|
+
width: 0%;
|
|
44
|
+
margin-left: 0%;
|
|
45
|
+
}
|
|
46
|
+
50% {
|
|
47
|
+
width: 60%;
|
|
48
|
+
margin-left: 20%;
|
|
49
|
+
}
|
|
50
|
+
100% {
|
|
51
|
+
width: 0%;
|
|
52
|
+
margin-left: 100%;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
</style>
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { Loader, AlertCircle, AlertTriangle, Inbox } from '@lucide/svelte';
|
|
3
|
+
import * as Card from '$lib/components/ui/card';
|
|
4
|
+
|
|
5
|
+
interface StateDisplayProps {
|
|
6
|
+
type: 'loading' | 'error' | 'warning' | 'empty';
|
|
7
|
+
message?: string;
|
|
8
|
+
title?: string;
|
|
9
|
+
size?: 'small' | 'medium' | 'large';
|
|
10
|
+
class?: string;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
let {
|
|
14
|
+
type,
|
|
15
|
+
message = '',
|
|
16
|
+
title,
|
|
17
|
+
size = 'medium',
|
|
18
|
+
class: className = ''
|
|
19
|
+
}: StateDisplayProps = $props();
|
|
20
|
+
|
|
21
|
+
const sizeClasses = {
|
|
22
|
+
small: {
|
|
23
|
+
container: 'p-6 gap-3',
|
|
24
|
+
icon: 'w-8 h-8',
|
|
25
|
+
title: 'text-sm font-semibold',
|
|
26
|
+
message: 'text-xs'
|
|
27
|
+
},
|
|
28
|
+
medium: {
|
|
29
|
+
container: 'p-12 gap-4',
|
|
30
|
+
icon: 'w-12 h-12',
|
|
31
|
+
title: 'text-lg font-semibold',
|
|
32
|
+
message: 'text-sm'
|
|
33
|
+
},
|
|
34
|
+
large: {
|
|
35
|
+
container: 'p-16 gap-6',
|
|
36
|
+
icon: 'w-16 h-16',
|
|
37
|
+
title: 'text-2xl font-bold',
|
|
38
|
+
message: 'text-base'
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
/* Fully semantic, contrast-safe mappings */
|
|
43
|
+
const typeClasses = {
|
|
44
|
+
loading: {
|
|
45
|
+
icon: 'text-primary',
|
|
46
|
+
title: 'text-primary-foreground',
|
|
47
|
+
message: 'text-primary-foreground/80',
|
|
48
|
+
border: 'border-primary',
|
|
49
|
+
background: 'bg-primary/15'
|
|
50
|
+
},
|
|
51
|
+
error: {
|
|
52
|
+
icon: 'text-destructive',
|
|
53
|
+
title: 'text-destructive-foreground',
|
|
54
|
+
message: 'text-destructive-foreground/80',
|
|
55
|
+
border: 'border-destructive',
|
|
56
|
+
background: 'bg-destructive/15'
|
|
57
|
+
},
|
|
58
|
+
warning: {
|
|
59
|
+
icon: 'text-accent',
|
|
60
|
+
title: 'text-accent-foreground',
|
|
61
|
+
message: 'text-accent-foreground/80',
|
|
62
|
+
border: 'border-accent',
|
|
63
|
+
background: 'bg-accent/15'
|
|
64
|
+
},
|
|
65
|
+
empty: {
|
|
66
|
+
icon: 'text-neutral',
|
|
67
|
+
title: 'text-neutral-foreground',
|
|
68
|
+
message: 'text-neutral-foreground/80',
|
|
69
|
+
border: 'border-neutral',
|
|
70
|
+
background: 'bg-neutral/15'
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
const sizeConfig = $derived(sizeClasses[size]);
|
|
75
|
+
const typeConfig = $derived(typeClasses[type]);
|
|
76
|
+
</script>
|
|
77
|
+
|
|
78
|
+
<Card.Root class="rounded-lg border-2 {typeConfig.border} {typeConfig.background} {className}">
|
|
79
|
+
<Card.Content
|
|
80
|
+
class="flex flex-col items-center justify-center text-center {sizeConfig.container}"
|
|
81
|
+
>
|
|
82
|
+
<div class="{sizeConfig.icon} {typeConfig.icon}">
|
|
83
|
+
{#if type === 'loading'}
|
|
84
|
+
<Loader class="animate-spin h-full w-full" />
|
|
85
|
+
{:else if type === 'error'}
|
|
86
|
+
<AlertCircle class="h-full w-full" />
|
|
87
|
+
{:else if type === 'warning'}
|
|
88
|
+
<AlertTriangle class="h-full w-full" />
|
|
89
|
+
{:else if type === 'empty'}
|
|
90
|
+
<Inbox class="h-full w-full" />
|
|
91
|
+
{/if}
|
|
92
|
+
</div>
|
|
93
|
+
|
|
94
|
+
{#if title}
|
|
95
|
+
<h3 class="{sizeConfig.title} {typeConfig.title} mt-1">
|
|
96
|
+
{title}
|
|
97
|
+
</h3>
|
|
98
|
+
{/if}
|
|
99
|
+
|
|
100
|
+
{#if message}
|
|
101
|
+
<p class="{sizeConfig.message} {typeConfig.message} max-w-md leading-relaxed">
|
|
102
|
+
{message}
|
|
103
|
+
</p>
|
|
104
|
+
{/if}
|
|
105
|
+
</Card.Content>
|
|
106
|
+
</Card.Root>
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { HTMLAttributes } from 'svelte/elements';
|
|
3
|
+
import { cn, type WithElementRef } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
children,
|
|
9
|
+
...restProps
|
|
10
|
+
}: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<div
|
|
14
|
+
bind:this={ref}
|
|
15
|
+
data-slot="alert-description"
|
|
16
|
+
class={cn(
|
|
17
|
+
'gap-1 text-sm [&_p]:leading-relaxed col-start-2 grid justify-items-start text-muted-foreground',
|
|
18
|
+
className
|
|
19
|
+
)}
|
|
20
|
+
{...restProps}
|
|
21
|
+
>
|
|
22
|
+
{@render children?.()}
|
|
23
|
+
</div>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { HTMLAttributes } from 'svelte/elements';
|
|
3
|
+
import { cn, type WithElementRef } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
children,
|
|
9
|
+
...restProps
|
|
10
|
+
}: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<div
|
|
14
|
+
bind:this={ref}
|
|
15
|
+
data-slot="alert-title"
|
|
16
|
+
class={cn('min-h-4 font-medium tracking-tight col-start-2 line-clamp-1', className)}
|
|
17
|
+
{...restProps}
|
|
18
|
+
>
|
|
19
|
+
{@render children?.()}
|
|
20
|
+
</div>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<script lang="ts" module>
|
|
2
|
+
import { type VariantProps, tv } from 'tailwind-variants';
|
|
3
|
+
|
|
4
|
+
export const alertVariants = tv({
|
|
5
|
+
base: 'relative grid w-full grid-cols-[0_1fr] items-start gap-y-0.5 rounded-lg border px-4 py-3 text-sm has-[>svg]:grid-cols-[calc(var(--spacing)*4)_1fr] has-[>svg]:gap-x-3 [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current',
|
|
6
|
+
variants: {
|
|
7
|
+
variant: {
|
|
8
|
+
default: 'bg-card text-card-foreground',
|
|
9
|
+
destructive:
|
|
10
|
+
'text-destructive bg-card *:data-[slot=alert-description]:text-destructive/90 [&>svg]:text-current'
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
defaultVariants: {
|
|
14
|
+
variant: 'default'
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export type AlertVariant = VariantProps<typeof alertVariants>['variant'];
|
|
19
|
+
</script>
|
|
20
|
+
|
|
21
|
+
<script lang="ts">
|
|
22
|
+
import type { HTMLAttributes } from 'svelte/elements';
|
|
23
|
+
import { cn, type WithElementRef } from '$lib/utils.js';
|
|
24
|
+
|
|
25
|
+
let {
|
|
26
|
+
ref = $bindable(null),
|
|
27
|
+
class: className,
|
|
28
|
+
variant = 'default',
|
|
29
|
+
children,
|
|
30
|
+
...restProps
|
|
31
|
+
}: WithElementRef<HTMLAttributes<HTMLDivElement>> & {
|
|
32
|
+
variant?: AlertVariant;
|
|
33
|
+
} = $props();
|
|
34
|
+
</script>
|
|
35
|
+
|
|
36
|
+
<div
|
|
37
|
+
bind:this={ref}
|
|
38
|
+
data-slot="alert"
|
|
39
|
+
class={cn(alertVariants({ variant }), className)}
|
|
40
|
+
{...restProps}
|
|
41
|
+
role="alert"
|
|
42
|
+
>
|
|
43
|
+
{@render children?.()}
|
|
44
|
+
</div>
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import Root from './alert.svelte';
|
|
2
|
+
import Description from './alert-description.svelte';
|
|
3
|
+
import Title from './alert-title.svelte';
|
|
4
|
+
export { alertVariants, type AlertVariant } from './alert.svelte';
|
|
5
|
+
|
|
6
|
+
export {
|
|
7
|
+
Root,
|
|
8
|
+
Description,
|
|
9
|
+
Title,
|
|
10
|
+
//
|
|
11
|
+
Root as Alert,
|
|
12
|
+
Description as AlertDescription,
|
|
13
|
+
Title as AlertTitle
|
|
14
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import { buttonVariants } from '$lib/components/ui/button/index.js';
|
|
4
|
+
import { cn } from '$lib/utils.js';
|
|
5
|
+
|
|
6
|
+
let {
|
|
7
|
+
ref = $bindable(null),
|
|
8
|
+
class: className,
|
|
9
|
+
...restProps
|
|
10
|
+
}: AlertDialogPrimitive.ActionProps = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<AlertDialogPrimitive.Action
|
|
14
|
+
bind:ref
|
|
15
|
+
data-slot="alert-dialog-action"
|
|
16
|
+
class={cn(buttonVariants(), className)}
|
|
17
|
+
{...restProps}
|
|
18
|
+
/>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import { buttonVariants } from '$lib/components/ui/button/index.js';
|
|
4
|
+
import { cn } from '$lib/utils.js';
|
|
5
|
+
|
|
6
|
+
let {
|
|
7
|
+
ref = $bindable(null),
|
|
8
|
+
class: className,
|
|
9
|
+
...restProps
|
|
10
|
+
}: AlertDialogPrimitive.CancelProps = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<AlertDialogPrimitive.Cancel
|
|
14
|
+
bind:ref
|
|
15
|
+
data-slot="alert-dialog-cancel"
|
|
16
|
+
class={cn(buttonVariants({ variant: 'outline' }), className)}
|
|
17
|
+
{...restProps}
|
|
18
|
+
/>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import AlertDialogOverlay from './alert-dialog-overlay.svelte';
|
|
4
|
+
import { cn, type WithoutChild, type WithoutChildrenOrChild } from '$lib/utils.js';
|
|
5
|
+
|
|
6
|
+
let {
|
|
7
|
+
ref = $bindable(null),
|
|
8
|
+
class: className,
|
|
9
|
+
portalProps,
|
|
10
|
+
...restProps
|
|
11
|
+
}: WithoutChild<AlertDialogPrimitive.ContentProps> & {
|
|
12
|
+
portalProps?: WithoutChildrenOrChild<AlertDialogPrimitive.PortalProps>;
|
|
13
|
+
} = $props();
|
|
14
|
+
</script>
|
|
15
|
+
|
|
16
|
+
<AlertDialogPrimitive.Portal {...portalProps}>
|
|
17
|
+
<AlertDialogOverlay />
|
|
18
|
+
<AlertDialogPrimitive.Content
|
|
19
|
+
bind:ref
|
|
20
|
+
data-slot="alert-dialog-content"
|
|
21
|
+
class={cn(
|
|
22
|
+
'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 gap-4 p-6 shadow-lg sm:max-w-lg fixed start-[50%] top-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] rounded-lg border bg-background duration-200',
|
|
23
|
+
className
|
|
24
|
+
)}
|
|
25
|
+
{...restProps}
|
|
26
|
+
/>
|
|
27
|
+
</AlertDialogPrimitive.Portal>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import { cn } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
...restProps
|
|
9
|
+
}: AlertDialogPrimitive.DescriptionProps = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<AlertDialogPrimitive.Description
|
|
13
|
+
bind:ref
|
|
14
|
+
data-slot="alert-dialog-description"
|
|
15
|
+
class={cn('text-sm text-muted-foreground', className)}
|
|
16
|
+
{...restProps}
|
|
17
|
+
/>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { cn, type WithElementRef } from '$lib/utils.js';
|
|
3
|
+
import type { HTMLAttributes } from 'svelte/elements';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
children,
|
|
9
|
+
...restProps
|
|
10
|
+
}: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<div
|
|
14
|
+
bind:this={ref}
|
|
15
|
+
data-slot="alert-dialog-footer"
|
|
16
|
+
class={cn('gap-2 sm:flex-row sm:justify-end flex flex-col-reverse', className)}
|
|
17
|
+
{...restProps}
|
|
18
|
+
>
|
|
19
|
+
{@render children?.()}
|
|
20
|
+
</div>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { HTMLAttributes } from 'svelte/elements';
|
|
3
|
+
import { cn, type WithElementRef } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
children,
|
|
9
|
+
...restProps
|
|
10
|
+
}: WithElementRef<HTMLAttributes<HTMLDivElement>> = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<div
|
|
14
|
+
bind:this={ref}
|
|
15
|
+
data-slot="alert-dialog-header"
|
|
16
|
+
class={cn('gap-2 sm:text-start flex flex-col text-center', className)}
|
|
17
|
+
{...restProps}
|
|
18
|
+
>
|
|
19
|
+
{@render children?.()}
|
|
20
|
+
</div>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import { cn } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
...restProps
|
|
9
|
+
}: AlertDialogPrimitive.OverlayProps = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<AlertDialogPrimitive.Overlay
|
|
13
|
+
bind:ref
|
|
14
|
+
data-slot="alert-dialog-overlay"
|
|
15
|
+
class={cn(
|
|
16
|
+
'data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 inset-0 bg-black/50 fixed z-50',
|
|
17
|
+
className
|
|
18
|
+
)}
|
|
19
|
+
{...restProps}
|
|
20
|
+
/>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
import { cn } from '$lib/utils.js';
|
|
4
|
+
|
|
5
|
+
let {
|
|
6
|
+
ref = $bindable(null),
|
|
7
|
+
class: className,
|
|
8
|
+
...restProps
|
|
9
|
+
}: AlertDialogPrimitive.TitleProps = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<AlertDialogPrimitive.Title
|
|
13
|
+
bind:ref
|
|
14
|
+
data-slot="alert-dialog-title"
|
|
15
|
+
class={cn('text-lg font-semibold', className)}
|
|
16
|
+
{...restProps}
|
|
17
|
+
/>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
3
|
+
|
|
4
|
+
let { ref = $bindable(null), ...restProps }: AlertDialogPrimitive.TriggerProps = $props();
|
|
5
|
+
</script>
|
|
6
|
+
|
|
7
|
+
<AlertDialogPrimitive.Trigger bind:ref data-slot="alert-dialog-trigger" {...restProps} />
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { AlertDialog as AlertDialogPrimitive } from 'bits-ui';
|
|
2
|
+
import Trigger from './alert-dialog-trigger.svelte';
|
|
3
|
+
import Title from './alert-dialog-title.svelte';
|
|
4
|
+
import Action from './alert-dialog-action.svelte';
|
|
5
|
+
import Cancel from './alert-dialog-cancel.svelte';
|
|
6
|
+
import Footer from './alert-dialog-footer.svelte';
|
|
7
|
+
import Header from './alert-dialog-header.svelte';
|
|
8
|
+
import Overlay from './alert-dialog-overlay.svelte';
|
|
9
|
+
import Content from './alert-dialog-content.svelte';
|
|
10
|
+
import Description from './alert-dialog-description.svelte';
|
|
11
|
+
|
|
12
|
+
const Root = AlertDialogPrimitive.Root;
|
|
13
|
+
const Portal = AlertDialogPrimitive.Portal;
|
|
14
|
+
|
|
15
|
+
export {
|
|
16
|
+
Root,
|
|
17
|
+
Title,
|
|
18
|
+
Action,
|
|
19
|
+
Cancel,
|
|
20
|
+
Portal,
|
|
21
|
+
Footer,
|
|
22
|
+
Header,
|
|
23
|
+
Trigger,
|
|
24
|
+
Overlay,
|
|
25
|
+
Content,
|
|
26
|
+
Description,
|
|
27
|
+
//
|
|
28
|
+
Root as AlertDialog,
|
|
29
|
+
Title as AlertDialogTitle,
|
|
30
|
+
Action as AlertDialogAction,
|
|
31
|
+
Cancel as AlertDialogCancel,
|
|
32
|
+
Portal as AlertDialogPortal,
|
|
33
|
+
Footer as AlertDialogFooter,
|
|
34
|
+
Header as AlertDialogHeader,
|
|
35
|
+
Trigger as AlertDialogTrigger,
|
|
36
|
+
Overlay as AlertDialogOverlay,
|
|
37
|
+
Content as AlertDialogContent,
|
|
38
|
+
Description as AlertDialogDescription
|
|
39
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
<script lang="ts" module>
|
|
2
|
+
import { type VariantProps, tv } from "tailwind-variants";
|
|
3
|
+
|
|
4
|
+
export const badgeVariants = tv({
|
|
5
|
+
base: "focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive inline-flex w-fit shrink-0 items-center justify-center gap-1 overflow-hidden rounded-full border px-2 py-0.5 text-xs font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] [&>svg]:pointer-events-none [&>svg]:size-3",
|
|
6
|
+
variants: {
|
|
7
|
+
variant: {
|
|
8
|
+
default:
|
|
9
|
+
"bg-primary text-primary-foreground [a&]:hover:bg-primary/90 border-transparent",
|
|
10
|
+
secondary:
|
|
11
|
+
"bg-secondary text-secondary-foreground [a&]:hover:bg-secondary/90 border-transparent",
|
|
12
|
+
destructive:
|
|
13
|
+
"bg-destructive [a&]:hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/70 border-transparent text-white",
|
|
14
|
+
outline: "text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground",
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
defaultVariants: {
|
|
18
|
+
variant: "default",
|
|
19
|
+
},
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
export type BadgeVariant = VariantProps<typeof badgeVariants>["variant"];
|
|
23
|
+
</script>
|
|
24
|
+
|
|
25
|
+
<script lang="ts">
|
|
26
|
+
import type { HTMLAnchorAttributes } from "svelte/elements";
|
|
27
|
+
import { cn, type WithElementRef } from "$lib/utils.js";
|
|
28
|
+
|
|
29
|
+
let {
|
|
30
|
+
ref = $bindable(null),
|
|
31
|
+
href,
|
|
32
|
+
class: className,
|
|
33
|
+
variant = "default",
|
|
34
|
+
children,
|
|
35
|
+
...restProps
|
|
36
|
+
}: WithElementRef<HTMLAnchorAttributes> & {
|
|
37
|
+
variant?: BadgeVariant;
|
|
38
|
+
} = $props();
|
|
39
|
+
</script>
|
|
40
|
+
|
|
41
|
+
<svelte:element
|
|
42
|
+
this={href ? "a" : "span"}
|
|
43
|
+
bind:this={ref}
|
|
44
|
+
data-slot="badge"
|
|
45
|
+
{href}
|
|
46
|
+
class={cn(badgeVariants({ variant }), className)}
|
|
47
|
+
{...restProps}
|
|
48
|
+
>
|
|
49
|
+
{@render children?.()}
|
|
50
|
+
</svelte:element>
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
<script lang="ts" module>
|
|
2
|
+
import { cn, type WithElementRef } from '$lib/utils';
|
|
3
|
+
import type { HTMLAnchorAttributes, HTMLButtonAttributes } from 'svelte/elements';
|
|
4
|
+
import { type VariantProps, tv } from 'tailwind-variants';
|
|
5
|
+
|
|
6
|
+
export const buttonVariants = tv({
|
|
7
|
+
base: "focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive inline-flex shrink-0 items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium outline-none transition-all focus-visible:ring-[3px] disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0",
|
|
8
|
+
variants: {
|
|
9
|
+
variant: {
|
|
10
|
+
default: 'bg-primary text-primary-foreground shadow-xs hover:bg-primary/90',
|
|
11
|
+
destructive:
|
|
12
|
+
'bg-destructive shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60 text-white',
|
|
13
|
+
outline:
|
|
14
|
+
'bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50 border',
|
|
15
|
+
secondary: 'bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80',
|
|
16
|
+
ghost: 'hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50',
|
|
17
|
+
dashed:
|
|
18
|
+
'border border-dashed border-input bg-background text-muted-foreground hover:bg-muted hover:text-foreground',
|
|
19
|
+
link: 'text-primary underline-offset-4 hover:underline'
|
|
20
|
+
},
|
|
21
|
+
size: {
|
|
22
|
+
default: 'h-9 px-4 py-2 has-[>svg]:px-3',
|
|
23
|
+
sm: 'h-8 gap-1.5 rounded-md px-3 has-[>svg]:px-2.5',
|
|
24
|
+
lg: 'h-10 rounded-md px-6 has-[>svg]:px-4',
|
|
25
|
+
icon: 'size-9',
|
|
26
|
+
'icon-sm': 'size-8',
|
|
27
|
+
'icon-lg': 'size-10'
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
defaultVariants: {
|
|
31
|
+
variant: 'default',
|
|
32
|
+
size: 'default'
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
export type ButtonVariant = VariantProps<typeof buttonVariants>['variant'];
|
|
37
|
+
export type ButtonSize = VariantProps<typeof buttonVariants>['size'];
|
|
38
|
+
|
|
39
|
+
export type ButtonProps = WithElementRef<HTMLButtonAttributes> &
|
|
40
|
+
WithElementRef<HTMLAnchorAttributes> & {
|
|
41
|
+
variant?: ButtonVariant;
|
|
42
|
+
size?: ButtonSize;
|
|
43
|
+
};
|
|
44
|
+
</script>
|
|
45
|
+
|
|
46
|
+
<script lang="ts">
|
|
47
|
+
let {
|
|
48
|
+
class: className,
|
|
49
|
+
variant = 'default',
|
|
50
|
+
size = 'default',
|
|
51
|
+
ref = $bindable(null),
|
|
52
|
+
href = undefined,
|
|
53
|
+
type = 'button',
|
|
54
|
+
disabled,
|
|
55
|
+
children,
|
|
56
|
+
...restProps
|
|
57
|
+
}: ButtonProps = $props();
|
|
58
|
+
</script>
|
|
59
|
+
|
|
60
|
+
{#if href}
|
|
61
|
+
<a
|
|
62
|
+
bind:this={ref}
|
|
63
|
+
data-slot="button"
|
|
64
|
+
class={cn(buttonVariants({ variant, size }), className)}
|
|
65
|
+
href={disabled ? undefined : href}
|
|
66
|
+
aria-disabled={disabled}
|
|
67
|
+
data-sveltekit-reload
|
|
68
|
+
{...restProps}
|
|
69
|
+
>
|
|
70
|
+
{@render children?.()}
|
|
71
|
+
</a>
|
|
72
|
+
{:else}
|
|
73
|
+
<button
|
|
74
|
+
bind:this={ref}
|
|
75
|
+
data-slot="button"
|
|
76
|
+
class={cn(buttonVariants({ variant, size }), className)}
|
|
77
|
+
{type}
|
|
78
|
+
{disabled}
|
|
79
|
+
{...restProps}
|
|
80
|
+
>
|
|
81
|
+
{@render children?.()}
|
|
82
|
+
</button>
|
|
83
|
+
{/if}
|