@hanzo/ui 5.3.33 → 5.3.35
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/bin/create-registry.js +0 -0
- package/bin/npx-registry-mcp.js +0 -0
- package/bin/registry-mcp-wrapper.sh +0 -0
- package/bin/registry-mcp.js +0 -0
- package/bin/start-mcp-server.sh +0 -0
- package/bin/test-mcp.sh +0 -0
- package/dist/alert-dialog.js +18 -13
- package/dist/alert-dialog.mjs +18 -13
- package/dist/alert.js +67 -37
- package/dist/alert.mjs +66 -38
- package/dist/assets/ai-icons.d.ts +28 -0
- package/dist/assets/ai-icons.d.ts.map +1 -0
- package/dist/assets/ai-icons.js +60 -0
- package/dist/assets/crypto.d.ts +7 -0
- package/dist/assets/crypto.d.ts.map +1 -0
- package/dist/assets/crypto.js +4 -0
- package/dist/assets/file-type-icon.d.ts +7 -0
- package/dist/assets/file-type-icon.d.ts.map +1 -0
- package/dist/assets/file-type-icon.js +36 -0
- package/dist/assets/file.d.ts +5 -0
- package/dist/assets/file.d.ts.map +1 -0
- package/dist/assets/file.js +29 -0
- package/dist/assets/general.d.ts +220 -0
- package/dist/assets/general.d.ts.map +1 -0
- package/dist/assets/general.js +136 -0
- package/dist/assets/hanzo-logo.d.ts +4 -0
- package/dist/assets/hanzo-logo.d.ts.map +1 -0
- package/dist/assets/hanzo-logo.js +3 -0
- package/dist/assets/index.d.ts +7 -0
- package/dist/assets/index.d.ts.map +1 -0
- package/dist/assets/index.js +23 -0
- package/dist/assets/llm-provider.d.ts +64 -0
- package/dist/assets/llm-provider.d.ts.map +1 -0
- package/dist/assets/llm-provider.js +90 -0
- package/dist/badge.js +28 -33
- package/dist/badge.mjs +28 -13
- package/dist/blocks/index.js +90 -70
- package/dist/blocks/index.mjs +90 -70
- package/dist/calendar-ext/index.js +18 -13
- package/dist/calendar-ext/index.mjs +18 -13
- package/dist/calendar.js +18 -13
- package/dist/calendar.mjs +18 -13
- package/dist/carousel.js +18 -13
- package/dist/carousel.mjs +18 -13
- package/dist/charts/index.js +5564 -0
- package/dist/charts/index.mjs +5503 -2
- package/dist/command.js +115 -94
- package/dist/command.mjs +116 -96
- package/dist/components/cal-embed.d.ts +11 -0
- package/dist/components/cal-embed.d.ts.map +1 -0
- package/dist/components/cal-embed.js +38 -0
- package/dist/components/index.d.ts +3 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +7 -0
- package/dist/desktop/hooks.js +224 -0
- package/dist/desktop/hooks.mjs +199 -0
- package/dist/desktop/index.js +686 -0
- package/dist/desktop/index.mjs +658 -0
- package/dist/desktop/spotlight.js +261 -0
- package/dist/desktop/spotlight.mjs +236 -0
- package/dist/desktop/window.js +274 -0
- package/dist/desktop/window.mjs +248 -0
- package/dist/dialog.js +182 -87
- package/dist/dialog.mjs +183 -90
- package/dist/dock/index.js +45 -25
- package/dist/dock/index.mjs +45 -25
- package/dist/dock/limelight-nav.js +59 -39
- package/dist/dock/limelight-nav.mjs +53 -33
- package/dist/dock/message.js +18 -13
- package/dist/dock/message.mjs +18 -13
- package/dist/form/index.js +7 -8
- package/dist/form/index.mjs +7 -8
- package/dist/frameworks/core/index.d.ts +4 -0
- package/dist/frameworks/core/index.d.ts.map +1 -0
- package/dist/frameworks/core/index.js +5 -0
- package/dist/frameworks/core/styles.d.ts +12 -0
- package/dist/frameworks/core/styles.d.ts.map +1 -0
- package/dist/frameworks/core/styles.js +11 -0
- package/dist/frameworks/core/types.d.ts +17 -0
- package/dist/frameworks/core/types.d.ts.map +1 -0
- package/dist/frameworks/core/types.js +11 -0
- package/dist/frameworks/core/utils/index.d.ts +19 -0
- package/dist/frameworks/core/utils/index.d.ts.map +1 -0
- package/dist/frameworks/core/utils/index.js +49 -0
- package/dist/frameworks/react/components/button.d.ts +8 -0
- package/dist/frameworks/react/components/button.d.ts.map +1 -0
- package/dist/frameworks/react/components/button.js +8 -0
- package/dist/frameworks/react/components/index.d.ts +2 -0
- package/dist/frameworks/react/components/index.d.ts.map +1 -0
- package/dist/frameworks/react/components/index.js +4 -0
- package/dist/frameworks/react/hooks/index.d.ts +2 -0
- package/dist/frameworks/react/hooks/index.d.ts.map +1 -0
- package/dist/frameworks/react/hooks/index.js +5 -0
- package/dist/frameworks/react/index.d.ts +5 -0
- package/dist/frameworks/react/index.d.ts.map +1 -0
- package/dist/frameworks/react/index.js +7 -0
- package/dist/frameworks/react/utils/index.d.ts +2 -0
- package/dist/frameworks/react/utils/index.d.ts.map +1 -0
- package/dist/frameworks/react/utils/index.js +2 -0
- package/dist/frameworks/react-native/components.d.ts +17 -0
- package/dist/frameworks/react-native/components.d.ts.map +1 -0
- package/dist/frameworks/react-native/components.js +17 -0
- package/dist/frameworks/react-native/hooks.d.ts +10 -0
- package/dist/frameworks/react-native/hooks.d.ts.map +1 -0
- package/dist/frameworks/react-native/hooks.js +9 -0
- package/dist/frameworks/react-native/index.d.ts +5 -0
- package/dist/frameworks/react-native/index.d.ts.map +1 -0
- package/dist/frameworks/react-native/index.js +7 -0
- package/dist/frameworks/react-native/utils.d.ts +7 -0
- package/dist/frameworks/react-native/utils.d.ts.map +1 -0
- package/dist/frameworks/react-native/utils.js +9 -0
- package/dist/frameworks/svelte/components.d.ts +15 -0
- package/dist/frameworks/svelte/components.d.ts.map +1 -0
- package/dist/frameworks/svelte/components.js +16 -0
- package/dist/frameworks/svelte/index.d.ts +5 -0
- package/dist/frameworks/svelte/index.d.ts.map +1 -0
- package/dist/frameworks/svelte/index.js +7 -0
- package/dist/frameworks/svelte/stores.d.ts +13 -0
- package/dist/frameworks/svelte/stores.d.ts.map +1 -0
- package/dist/frameworks/svelte/stores.js +9 -0
- package/dist/frameworks/svelte/utils.d.ts +7 -0
- package/dist/frameworks/svelte/utils.d.ts.map +1 -0
- package/dist/frameworks/svelte/utils.js +8 -0
- package/dist/frameworks/vue/components.d.ts +15 -0
- package/dist/frameworks/vue/components.d.ts.map +1 -0
- package/dist/frameworks/vue/components.js +16 -0
- package/dist/frameworks/vue/composables.d.ts +16 -0
- package/dist/frameworks/vue/composables.d.ts.map +1 -0
- package/dist/frameworks/vue/composables.js +14 -0
- package/dist/frameworks/vue/index.d.ts +5 -0
- package/dist/frameworks/vue/index.d.ts.map +1 -0
- package/dist/frameworks/vue/index.js +7 -0
- package/dist/frameworks/vue/utils.d.ts +7 -0
- package/dist/frameworks/vue/utils.d.ts.map +1 -0
- package/dist/frameworks/vue/utils.js +8 -0
- package/dist/helpers/file.d.ts +7 -0
- package/dist/helpers/file.d.ts.map +1 -0
- package/dist/helpers/file.js +30 -0
- package/dist/helpers/memoization.d.ts +9 -0
- package/dist/helpers/memoization.d.ts.map +1 -0
- package/dist/helpers/memoization.js +24 -0
- package/dist/index.js +1519 -348
- package/dist/index.mjs +1469 -335
- package/dist/mermaid/index.js +19 -13
- package/dist/mermaid/index.mjs +19 -14
- package/dist/primitives/accordion.d.ts +27 -0
- package/dist/primitives/accordion.d.ts.map +1 -0
- package/dist/primitives/accordion.js +12 -0
- package/dist/primitives/action-button.d.ts +10 -0
- package/dist/primitives/action-button.d.ts.map +1 -0
- package/dist/primitives/action-button.js +14 -0
- package/dist/primitives/alert-dialog.d.ts +57 -0
- package/dist/primitives/alert-dialog.d.ts.map +1 -0
- package/dist/primitives/alert-dialog.js +25 -0
- package/dist/primitives/alert.d.ts +11 -0
- package/dist/primitives/alert.d.ts.map +1 -0
- package/dist/primitives/alert.js +32 -0
- package/dist/primitives/apply-typography.d.ts +8 -0
- package/dist/primitives/apply-typography.d.ts.map +1 -0
- package/dist/primitives/apply-typography.js +36 -0
- package/dist/primitives/aspect-ratio.d.ts +4 -0
- package/dist/primitives/aspect-ratio.d.ts.map +1 -0
- package/dist/primitives/aspect-ratio.js +4 -0
- package/dist/primitives/avatar.d.ts +25 -0
- package/dist/primitives/avatar.d.ts.map +1 -0
- package/dist/primitives/avatar.js +10 -0
- package/dist/primitives/badge.d.ts +11 -0
- package/dist/primitives/badge.d.ts.map +1 -0
- package/dist/primitives/badge.js +28 -0
- package/dist/primitives/breadcrumb.d.ts +51 -0
- package/dist/primitives/breadcrumb.d.ts.map +1 -0
- package/dist/primitives/breadcrumb.js +22 -0
- package/dist/primitives/breakpoint-indicator.d.ts +4 -0
- package/dist/primitives/breakpoint-indicator.d.ts.map +1 -0
- package/dist/primitives/breakpoint-indicator.js +7 -0
- package/dist/primitives/button-group.d.ts +12 -0
- package/dist/primitives/button-group.d.ts.map +1 -0
- package/dist/primitives/button-group.js +28 -0
- package/dist/primitives/button.d.ts +14 -0
- package/dist/primitives/button.d.ts.map +1 -0
- package/dist/primitives/button.js +41 -0
- package/dist/primitives/cal-embed.d.ts +11 -0
- package/dist/primitives/cal-embed.d.ts.map +1 -0
- package/dist/primitives/cal-embed.js +38 -0
- package/dist/primitives/calendar.d.ts +11 -0
- package/dist/primitives/calendar.d.ts.map +1 -0
- package/dist/primitives/calendar.js +58 -0
- package/dist/primitives/card.d.ts +10 -0
- package/dist/primitives/card.d.ts.map +1 -0
- package/dist/primitives/card.js +24 -0
- package/dist/primitives/carousel.d.ts +19 -0
- package/dist/primitives/carousel.d.ts.map +1 -0
- package/dist/primitives/carousel.js +95 -0
- package/dist/primitives/chart.d.ts +41 -0
- package/dist/primitives/chart.d.ts.map +1 -0
- package/dist/primitives/chart.js +128 -0
- package/dist/primitives/charts/area/chart-area-axes.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-axes.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-axes.js +31 -0
- package/dist/primitives/charts/area/chart-area-default.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-default.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-default.js +27 -0
- package/dist/primitives/charts/area/chart-area-gradient.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-gradient.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-gradient.js +31 -0
- package/dist/primitives/charts/area/chart-area-icons.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-icons.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-icons.js +33 -0
- package/dist/primitives/charts/area/chart-area-interactive.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-interactive.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-interactive.js +143 -0
- package/dist/primitives/charts/area/chart-area-legend.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-legend.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-legend.js +31 -0
- package/dist/primitives/charts/area/chart-area-linear.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-linear.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-linear.js +27 -0
- package/dist/primitives/charts/area/chart-area-stacked-expand.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-stacked-expand.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-stacked-expand.js +36 -0
- package/dist/primitives/charts/area/chart-area-stacked.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-stacked.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-stacked.js +31 -0
- package/dist/primitives/charts/area/chart-area-step.d.ts +3 -0
- package/dist/primitives/charts/area/chart-area-step.d.ts.map +1 -0
- package/dist/primitives/charts/area/chart-area-step.js +28 -0
- package/dist/primitives/charts/area/index.d.ts +11 -0
- package/dist/primitives/charts/area/index.d.ts.map +1 -0
- package/dist/primitives/charts/area/index.js +11 -0
- package/dist/primitives/charts/bar/chart-bar-active.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-active.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-active.js +44 -0
- package/dist/primitives/charts/bar/chart-bar-default.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-default.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-default.js +24 -0
- package/dist/primitives/charts/bar/chart-bar-horizontal.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-horizontal.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-horizontal.js +26 -0
- package/dist/primitives/charts/bar/chart-bar-interactive.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-interactive.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-interactive.js +139 -0
- package/dist/primitives/charts/bar/chart-bar-label-custom.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-label-custom.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-label-custom.js +33 -0
- package/dist/primitives/charts/bar/chart-bar-label.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-label.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-label.js +26 -0
- package/dist/primitives/charts/bar/chart-bar-mixed.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-mixed.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-mixed.js +44 -0
- package/dist/primitives/charts/bar/chart-bar-multiple.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-multiple.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-multiple.js +28 -0
- package/dist/primitives/charts/bar/chart-bar-negative.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-negative.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-negative.js +25 -0
- package/dist/primitives/charts/bar/chart-bar-stacked.d.ts +3 -0
- package/dist/primitives/charts/bar/chart-bar-stacked.d.ts.map +1 -0
- package/dist/primitives/charts/bar/chart-bar-stacked.js +28 -0
- package/dist/primitives/charts/bar/index.d.ts +11 -0
- package/dist/primitives/charts/bar/index.d.ts.map +1 -0
- package/dist/primitives/charts/bar/index.js +11 -0
- package/dist/primitives/charts/index.d.ts +8 -0
- package/dist/primitives/charts/index.d.ts.map +1 -0
- package/dist/primitives/charts/index.js +11 -0
- package/dist/primitives/charts/line/chart-line-default.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-default.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-default.js +27 -0
- package/dist/primitives/charts/line/chart-line-dots-colors.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-dots-colors.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-dots-colors.js +49 -0
- package/dist/primitives/charts/line/chart-line-dots-custom.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-dots-custom.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-dots-custom.js +34 -0
- package/dist/primitives/charts/line/chart-line-dots.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-dots.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-dots.js +35 -0
- package/dist/primitives/charts/line/chart-line-interactive.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-interactive.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-interactive.js +139 -0
- package/dist/primitives/charts/line/chart-line-label-custom.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-label-custom.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-label-custom.js +51 -0
- package/dist/primitives/charts/line/chart-line-label.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-label.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-label.js +36 -0
- package/dist/primitives/charts/line/chart-line-linear.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-linear.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-linear.js +27 -0
- package/dist/primitives/charts/line/chart-line-multiple.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-multiple.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-multiple.js +31 -0
- package/dist/primitives/charts/line/chart-line-step.d.ts +3 -0
- package/dist/primitives/charts/line/chart-line-step.d.ts.map +1 -0
- package/dist/primitives/charts/line/chart-line-step.js +27 -0
- package/dist/primitives/charts/line/index.d.ts +11 -0
- package/dist/primitives/charts/line/index.d.ts.map +1 -0
- package/dist/primitives/charts/line/index.js +11 -0
- package/dist/primitives/charts/pie/chart-pie-donut-active.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-donut-active.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-donut-active.js +42 -0
- package/dist/primitives/charts/pie/chart-pie-donut-text.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-donut-text.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-donut-text.js +50 -0
- package/dist/primitives/charts/pie/chart-pie-donut.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-donut.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-donut.js +42 -0
- package/dist/primitives/charts/pie/chart-pie-interactive.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-interactive.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-interactive.js +65 -0
- package/dist/primitives/charts/pie/chart-pie-label-custom.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-label-custom.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-label-custom.js +44 -0
- package/dist/primitives/charts/pie/chart-pie-label-list.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-label-list.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-label-list.js +42 -0
- package/dist/primitives/charts/pie/chart-pie-label.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-label.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-label.js +42 -0
- package/dist/primitives/charts/pie/chart-pie-legend.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-legend.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-legend.js +41 -0
- package/dist/primitives/charts/pie/chart-pie-separator-none.d.ts +3 -0
- package/dist/primitives/charts/pie/chart-pie-separator-none.d.ts.map +1 -0
- package/dist/primitives/charts/pie/chart-pie-separator-none.js +42 -0
- package/dist/primitives/charts/pie/index.d.ts +10 -0
- package/dist/primitives/charts/pie/index.d.ts.map +1 -0
- package/dist/primitives/charts/pie/index.js +10 -0
- package/dist/primitives/charts/radar/chart-radar-default.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-default.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-default.js +24 -0
- package/dist/primitives/charts/radar/chart-radar-dots.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-dots.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-dots.js +27 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-fill.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-fill.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-fill.js +24 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-no-lines.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-no-lines.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle-no-lines.js +27 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-circle.js +27 -0
- package/dist/primitives/charts/radar/chart-radar-grid-custom.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-custom.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-custom.js +24 -0
- package/dist/primitives/charts/radar/chart-radar-grid-fill.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-fill.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-fill.js +24 -0
- package/dist/primitives/charts/radar/chart-radar-grid-none.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-grid-none.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-grid-none.js +27 -0
- package/dist/primitives/charts/radar/chart-radar-icons.d.ts +3 -0
- package/dist/primitives/charts/radar/chart-radar-icons.d.ts.map +1 -0
- package/dist/primitives/charts/radar/chart-radar-icons.js +33 -0
- package/dist/primitives/charts/radar/index.d.ts +10 -0
- package/dist/primitives/charts/radar/index.d.ts.map +1 -0
- package/dist/primitives/charts/radar/index.js +10 -0
- package/dist/primitives/charts/radial/chart-radial-grid.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-grid.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-grid.js +42 -0
- package/dist/primitives/charts/radial/chart-radial-label.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-label.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-label.js +42 -0
- package/dist/primitives/charts/radial/chart-radial-shape.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-shape.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-shape.js +26 -0
- package/dist/primitives/charts/radial/chart-radial-simple.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-simple.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-simple.js +42 -0
- package/dist/primitives/charts/radial/chart-radial-stacked.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-stacked.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-stacked.js +26 -0
- package/dist/primitives/charts/radial/chart-radial-text.d.ts +3 -0
- package/dist/primitives/charts/radial/chart-radial-text.d.ts.map +1 -0
- package/dist/primitives/charts/radial/chart-radial-text.js +26 -0
- package/dist/primitives/charts/radial/index.d.ts +7 -0
- package/dist/primitives/charts/radial/index.d.ts.map +1 -0
- package/dist/primitives/charts/radial/index.js +7 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-advanced.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-advanced.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-advanced.js +34 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-default.d.ts +5 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-default.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-default.js +33 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-formatter.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-formatter.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-formatter.js +32 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-icons.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-icons.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-icons.js +34 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-line.d.ts +5 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-line.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-line.js +33 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-none.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-none.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-indicator-none.js +31 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-custom.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-custom.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-custom.js +34 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-formatter.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-formatter.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-formatter.js +37 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-none.d.ts +3 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-none.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/chart-tooltip-label-none.js +31 -0
- package/dist/primitives/charts/tooltip/index.d.ts +10 -0
- package/dist/primitives/charts/tooltip/index.d.ts.map +1 -0
- package/dist/primitives/charts/tooltip/index.js +10 -0
- package/dist/primitives/chat/chat-input-area.d.ts +24 -0
- package/dist/primitives/chat/chat-input-area.d.ts.map +1 -0
- package/dist/primitives/chat/chat-input-area.js +23 -0
- package/dist/primitives/chat/chat-input.d.ts +13 -0
- package/dist/primitives/chat/chat-input.d.ts.map +1 -0
- package/dist/primitives/chat/chat-input.js +33 -0
- package/dist/primitives/chat/json-form.d.ts +4 -0
- package/dist/primitives/chat/json-form.d.ts.map +1 -0
- package/dist/primitives/chat/json-form.js +6 -0
- package/dist/primitives/checkbox.d.ts +12 -0
- package/dist/primitives/checkbox.d.ts.map +1 -0
- package/dist/primitives/checkbox.js +8 -0
- package/dist/primitives/collapsible.d.ts +6 -0
- package/dist/primitives/collapsible.d.ts.map +1 -0
- package/dist/primitives/collapsible.js +5 -0
- package/dist/primitives/combobox.d.ts +42 -0
- package/dist/primitives/combobox.d.ts.map +1 -0
- package/dist/primitives/combobox.js +49 -0
- package/dist/primitives/command.d.ts +39 -0
- package/dist/primitives/command.d.ts.map +1 -0
- package/dist/primitives/command.js +28 -0
- package/dist/primitives/context-menu.d.ts +54 -0
- package/dist/primitives/context-menu.d.ts.map +1 -0
- package/dist/primitives/context-menu.js +32 -0
- package/dist/primitives/copy-to-clipboard-icon.d.ts +15 -0
- package/dist/primitives/copy-to-clipboard-icon.d.ts.map +1 -0
- package/dist/primitives/copy-to-clipboard-icon.js +21 -0
- package/dist/primitives/dialog-video-controller.d.ts +4 -0
- package/dist/primitives/dialog-video-controller.d.ts.map +1 -0
- package/dist/primitives/dialog-video-controller.js +23 -0
- package/dist/primitives/dialog.d.ts +18 -0
- package/dist/primitives/dialog.d.ts.map +1 -0
- package/dist/primitives/dialog.js +37 -0
- package/dist/primitives/dot-pattern.d.ts +14 -0
- package/dist/primitives/dot-pattern.d.ts.map +1 -0
- package/dist/primitives/dot-pattern.js +8 -0
- package/dist/primitives/dots-loader.d.ts +5 -0
- package/dist/primitives/dots-loader.d.ts.map +1 -0
- package/dist/primitives/dots-loader.js +5 -0
- package/dist/primitives/drawer.d.ts +38 -0
- package/dist/primitives/drawer.d.ts.map +1 -0
- package/dist/primitives/drawer.js +22 -0
- package/dist/primitives/dropdown-menu.d.ts +52 -0
- package/dist/primitives/dropdown-menu.d.ts.map +1 -0
- package/dist/primitives/dropdown-menu.js +34 -0
- package/dist/primitives/empty.d.ts +12 -0
- package/dist/primitives/empty.d.ts.map +1 -0
- package/dist/primitives/empty.js +33 -0
- package/dist/primitives/error-message.d.ts +7 -0
- package/dist/primitives/error-message.d.ts.map +1 -0
- package/dist/primitives/error-message.js +5 -0
- package/dist/primitives/field.d.ts +10 -0
- package/dist/primitives/field.d.ts.map +1 -0
- package/dist/primitives/field.js +16 -0
- package/dist/primitives/file-uploader.d.ts +20 -0
- package/dist/primitives/file-uploader.d.ts.map +1 -0
- package/dist/primitives/file-uploader.js +68 -0
- package/dist/primitives/form.d.ts +40 -0
- package/dist/primitives/form.d.ts.map +1 -0
- package/dist/primitives/form.js +67 -0
- package/dist/primitives/hover-card.d.ts +10 -0
- package/dist/primitives/hover-card.d.ts.map +1 -0
- package/dist/primitives/hover-card.js +8 -0
- package/dist/primitives/icons/github.d.ts +5 -0
- package/dist/primitives/icons/github.d.ts.map +1 -0
- package/dist/primitives/icons/github.js +3 -0
- package/dist/primitives/icons/index.d.ts +5 -0
- package/dist/primitives/icons/index.d.ts.map +1 -0
- package/dist/primitives/icons/index.js +4 -0
- package/dist/primitives/icons/youtube-logo.d.ts +5 -0
- package/dist/primitives/icons/youtube-logo.d.ts.map +1 -0
- package/dist/primitives/icons/youtube-logo.js +33 -0
- package/dist/primitives/index-blocks.d.ts +5 -0
- package/dist/primitives/index-blocks.d.ts.map +1 -0
- package/dist/primitives/index-blocks.js +6 -0
- package/dist/primitives/index-common.d.ts +75 -0
- package/dist/primitives/index-common.d.ts.map +1 -0
- package/dist/primitives/index-common.js +82 -0
- package/dist/primitives/index-core.d.ts +29 -0
- package/dist/primitives/index-core.d.ts.map +1 -0
- package/dist/primitives/index-core.js +30 -0
- package/dist/primitives/index-next.d.ts +3 -0
- package/dist/primitives/index-next.d.ts.map +1 -0
- package/dist/primitives/index-next.js +4 -0
- package/dist/primitives/index-standard.d.ts +79 -0
- package/dist/primitives/index-standard.d.ts.map +1 -0
- package/dist/primitives/index-standard.js +98 -0
- package/dist/primitives/index.js +1519 -348
- package/dist/primitives/index.mjs +1469 -335
- package/dist/primitives/input-group.d.ts +17 -0
- package/dist/primitives/input-group.d.ts.map +1 -0
- package/dist/primitives/input-group.js +61 -0
- package/dist/primitives/input-otp.d.ts +35 -0
- package/dist/primitives/input-otp.d.ts.map +1 -0
- package/dist/primitives/input-otp.js +19 -0
- package/dist/primitives/input.d.ts +15 -0
- package/dist/primitives/input.d.ts.map +1 -0
- package/dist/primitives/input.js +43 -0
- package/dist/primitives/item.d.ts +24 -0
- package/dist/primitives/item.d.ts.map +1 -0
- package/dist/primitives/item.js +67 -0
- package/dist/primitives/kbd.d.ts +5 -0
- package/dist/primitives/kbd.d.ts.map +1 -0
- package/dist/primitives/kbd.js +9 -0
- package/dist/primitives/label.d.ts +11 -0
- package/dist/primitives/label.d.ts.map +1 -0
- package/dist/primitives/label.js +9 -0
- package/dist/primitives/list-adaptor.d.ts +10 -0
- package/dist/primitives/list-adaptor.d.ts.map +1 -0
- package/dist/primitives/list-adaptor.js +1 -0
- package/dist/primitives/list-box.d.ts +12 -0
- package/dist/primitives/list-box.d.ts.map +1 -0
- package/dist/primitives/list-box.js +10 -0
- package/dist/primitives/loading-spinner.d.ts +6 -0
- package/dist/primitives/loading-spinner.d.ts.map +1 -0
- package/dist/primitives/loading-spinner.js +7 -0
- package/dist/primitives/markdown-preview.d.ts +129 -0
- package/dist/primitives/markdown-preview.d.ts.map +1 -0
- package/dist/primitives/markdown-preview.js +165 -0
- package/dist/primitives/menubar.d.ts +29 -0
- package/dist/primitives/menubar.d.ts.map +1 -0
- package/dist/primitives/menubar.js +46 -0
- package/dist/primitives/mermaid.d.ts +8 -0
- package/dist/primitives/mermaid.d.ts.map +1 -0
- package/dist/primitives/mermaid.js +112 -0
- package/dist/primitives/native-select.d.ts +9 -0
- package/dist/primitives/native-select.d.ts.map +1 -0
- package/dist/primitives/native-select.js +14 -0
- package/dist/primitives/navigation-menu.d.ts +13 -0
- package/dist/primitives/navigation-menu.d.ts.map +1 -0
- package/dist/primitives/navigation-menu.js +29 -0
- package/dist/primitives/next/image.d.ts +12 -0
- package/dist/primitives/next/image.d.ts.map +1 -0
- package/dist/primitives/next/image.js +40 -0
- package/dist/primitives/next/index.d.ts +8 -0
- package/dist/primitives/next/index.d.ts.map +1 -0
- package/dist/primitives/next/index.js +7 -0
- package/dist/primitives/next/inline-icon.d.ts +14 -0
- package/dist/primitives/next/inline-icon.d.ts.map +1 -0
- package/dist/primitives/next/inline-icon.js +13 -0
- package/dist/primitives/next/link-element.d.ts +24 -0
- package/dist/primitives/next/link-element.d.ts.map +1 -0
- package/dist/primitives/next/link-element.js +47 -0
- package/dist/primitives/next/mdx-link.d.ts +4 -0
- package/dist/primitives/next/mdx-link.d.ts.map +1 -0
- package/dist/primitives/next/mdx-link.js +10 -0
- package/dist/primitives/next/media-stack.d.ts +9 -0
- package/dist/primitives/next/media-stack.d.ts.map +1 -0
- package/dist/primitives/next/media-stack.js +20 -0
- package/dist/primitives/next/nav-items.d.ts +11 -0
- package/dist/primitives/next/nav-items.d.ts.map +1 -0
- package/dist/primitives/next/nav-items.js +22 -0
- package/dist/primitives/next/youtube-embed.d.ts +12 -0
- package/dist/primitives/next/youtube-embed.d.ts.map +1 -0
- package/dist/primitives/next/youtube-embed.js +16 -0
- package/dist/primitives/popover.d.ts +12 -0
- package/dist/primitives/popover.d.ts.map +1 -0
- package/dist/primitives/popover.js +10 -0
- package/dist/primitives/pretty-json-print.d.ts +5 -0
- package/dist/primitives/pretty-json-print.d.ts.map +1 -0
- package/dist/primitives/pretty-json-print.js +22 -0
- package/dist/primitives/progress.d.ts +9 -0
- package/dist/primitives/progress.d.ts.map +1 -0
- package/dist/primitives/progress.js +7 -0
- package/dist/primitives/prompt-textarea.d.ts +19 -0
- package/dist/primitives/prompt-textarea.d.ts.map +1 -0
- package/dist/primitives/prompt-textarea.js +30 -0
- package/dist/primitives/radio-group.d.ts +12 -0
- package/dist/primitives/radio-group.d.ts.map +1 -0
- package/dist/primitives/radio-group.js +14 -0
- package/dist/primitives/resizable.d.ts +24 -0
- package/dist/primitives/resizable.d.ts.map +1 -0
- package/dist/primitives/resizable.js +8 -0
- package/dist/primitives/scroll-area.d.ts +14 -0
- package/dist/primitives/scroll-area.d.ts.map +1 -0
- package/dist/primitives/scroll-area.js +10 -0
- package/dist/primitives/search-input.d.ts +14 -0
- package/dist/primitives/search-input.d.ts.map +1 -0
- package/dist/primitives/search-input.js +16 -0
- package/dist/primitives/select.d.ts +27 -0
- package/dist/primitives/select.d.ts.map +1 -0
- package/dist/primitives/select.js +21 -0
- package/dist/primitives/separator.d.ts +9 -0
- package/dist/primitives/separator.d.ts.map +1 -0
- package/dist/primitives/separator.js +7 -0
- package/dist/primitives/sheet.d.ts +41 -0
- package/dist/primitives/sheet.d.ts.map +1 -0
- package/dist/primitives/sheet.js +35 -0
- package/dist/primitives/skeleton.d.ts +5 -0
- package/dist/primitives/skeleton.d.ts.map +1 -0
- package/dist/primitives/skeleton.js +7 -0
- package/dist/primitives/slider.d.ts +6 -0
- package/dist/primitives/slider.d.ts.map +1 -0
- package/dist/primitives/slider.js +15 -0
- package/dist/primitives/sonner.d.ts +6 -0
- package/dist/primitives/sonner.d.ts.map +1 -0
- package/dist/primitives/sonner.js +17 -0
- package/dist/primitives/spinner.d.ts +3 -0
- package/dist/primitives/spinner.d.ts.map +1 -0
- package/dist/primitives/spinner.js +7 -0
- package/dist/primitives/step-indicator.d.ts +10 -0
- package/dist/primitives/step-indicator.d.ts.map +1 -0
- package/dist/primitives/step-indicator.js +13 -0
- package/dist/primitives/stepper.d.ts +49 -0
- package/dist/primitives/stepper.d.ts.map +1 -0
- package/dist/primitives/stepper.js +75 -0
- package/dist/primitives/switch.d.ts +9 -0
- package/dist/primitives/switch.d.ts.map +1 -0
- package/dist/primitives/switch.js +7 -0
- package/dist/primitives/table.d.ts +35 -0
- package/dist/primitives/table.d.ts.map +1 -0
- package/dist/primitives/table.js +19 -0
- package/dist/primitives/tabs.d.ts +12 -0
- package/dist/primitives/tabs.d.ts.map +1 -0
- package/dist/primitives/tabs.js +35 -0
- package/dist/primitives/text-area.d.ts +6 -0
- package/dist/primitives/text-area.d.ts.map +1 -0
- package/dist/primitives/text-area.js +10 -0
- package/dist/primitives/text-link.d.ts +6 -0
- package/dist/primitives/text-link.d.ts.map +1 -0
- package/dist/primitives/text-link.js +5 -0
- package/dist/primitives/textarea.d.ts +13 -0
- package/dist/primitives/textarea.d.ts.map +1 -0
- package/dist/primitives/textarea.js +28 -0
- package/dist/primitives/textfield.d.ts +33 -0
- package/dist/primitives/textfield.d.ts.map +1 -0
- package/dist/primitives/textfield.js +9 -0
- package/dist/primitives/toast.d.ts +6 -0
- package/dist/primitives/toast.d.ts.map +1 -0
- package/dist/primitives/toast.js +13 -0
- package/dist/primitives/toggle-group.d.ts +14 -0
- package/dist/primitives/toggle-group.d.ts.map +1 -0
- package/dist/primitives/toggle-group.js +20 -0
- package/dist/primitives/toggle.d.ts +13 -0
- package/dist/primitives/toggle.d.ts.map +1 -0
- package/dist/primitives/toggle.js +24 -0
- package/dist/primitives/tooltip.d.ts +15 -0
- package/dist/primitives/tooltip.d.ts.map +1 -0
- package/dist/primitives/tooltip.js +11 -0
- package/dist/primitives/video-player.d.ts +7 -0
- package/dist/primitives/video-player.d.ts.map +1 -0
- package/dist/primitives/video-player.js +7 -0
- package/dist/primitives/youtube-pip-player.d.ts +33 -0
- package/dist/primitives/youtube-pip-player.d.ts.map +1 -0
- package/dist/primitives/youtube-pip-player.js +253 -0
- package/dist/primitives-export.js +1519 -348
- package/dist/primitives-export.mjs +1469 -335
- package/dist/src/3d/button.d.ts +27 -0
- package/dist/src/3d/button.d.ts.map +1 -0
- package/dist/src/3d/button.js +181 -0
- package/dist/src/3d/card.d.ts +29 -0
- package/dist/src/3d/card.d.ts.map +1 -0
- package/dist/src/3d/card.js +117 -0
- package/dist/src/3d/carousel.d.ts +26 -0
- package/dist/src/3d/carousel.d.ts.map +1 -0
- package/dist/src/3d/carousel.js +171 -0
- package/dist/src/3d/grid.d.ts +49 -0
- package/dist/src/3d/grid.d.ts.map +1 -0
- package/dist/src/3d/grid.js +126 -0
- package/dist/src/3d/index.d.ts +7 -0
- package/dist/src/3d/index.d.ts.map +1 -0
- package/dist/src/3d/index.js +7 -0
- package/dist/src/3d/marquee.d.ts +37 -0
- package/dist/src/3d/marquee.d.ts.map +1 -0
- package/dist/src/3d/marquee.js +208 -0
- package/dist/src/3d/pin.d.ts +8 -0
- package/dist/src/3d/pin.d.ts.map +1 -0
- package/dist/src/3d/pin.js +9 -0
- package/dist/src/avatar.d.ts +2 -0
- package/dist/src/avatar.d.ts.map +1 -0
- package/dist/src/avatar.js +1 -0
- package/dist/src/badge.d.ts +2 -0
- package/dist/src/badge.d.ts.map +1 -0
- package/dist/src/badge.js +1 -0
- package/dist/src/billing/components/billing-workspace.d.ts +28 -0
- package/dist/src/billing/components/billing-workspace.d.ts.map +1 -0
- package/dist/src/billing/components/billing-workspace.js +22 -0
- package/dist/src/billing/components/business-profile-panel.d.ts +7 -0
- package/dist/src/billing/components/business-profile-panel.d.ts.map +1 -0
- package/dist/src/billing/components/business-profile-panel.js +44 -0
- package/dist/src/billing/components/index.d.ts +13 -0
- package/dist/src/billing/components/index.d.ts.map +1 -0
- package/dist/src/billing/components/index.js +6 -0
- package/dist/src/billing/components/invoice-manager.d.ts +10 -0
- package/dist/src/billing/components/invoice-manager.d.ts.map +1 -0
- package/dist/src/billing/components/invoice-manager.js +131 -0
- package/dist/src/billing/components/payment-manager.d.ts +13 -0
- package/dist/src/billing/components/payment-manager.d.ts.map +1 -0
- package/dist/src/billing/components/payment-manager.js +146 -0
- package/dist/src/billing/components/subscription-portal.d.ts +16 -0
- package/dist/src/billing/components/subscription-portal.d.ts.map +1 -0
- package/dist/src/billing/components/subscription-portal.js +88 -0
- package/dist/src/billing/components/tax-compliance-panel.d.ts +8 -0
- package/dist/src/billing/components/tax-compliance-panel.d.ts.map +1 -0
- package/dist/src/billing/components/tax-compliance-panel.js +41 -0
- package/dist/src/billing/index.d.ts +7 -0
- package/dist/src/billing/index.d.ts.map +1 -0
- package/dist/src/billing/index.js +8 -0
- package/dist/src/billing/types/index.d.ts +177 -0
- package/dist/src/billing/types/index.d.ts.map +1 -0
- package/dist/src/billing/types/index.js +1 -0
- package/dist/src/button.d.ts +2 -0
- package/dist/src/button.d.ts.map +1 -0
- package/dist/src/button.js +1 -0
- package/dist/src/calendar-ext/index.d.ts +4 -0
- package/dist/src/calendar-ext/index.d.ts.map +1 -0
- package/dist/src/calendar-ext/index.js +7 -0
- package/dist/src/charts/index.d.ts +65 -0
- package/dist/src/charts/index.d.ts.map +1 -0
- package/dist/src/charts/index.js +76 -0
- package/dist/src/desktop/hooks.d.ts +75 -0
- package/dist/src/desktop/hooks.d.ts.map +1 -0
- package/dist/src/desktop/hooks.js +194 -0
- package/dist/src/desktop/index.d.ts +7 -0
- package/dist/src/desktop/index.d.ts.map +1 -0
- package/dist/src/desktop/index.js +8 -0
- package/dist/src/desktop/spotlight.d.ts +24 -0
- package/dist/src/desktop/spotlight.d.ts.map +1 -0
- package/dist/src/desktop/spotlight.js +126 -0
- package/dist/src/desktop/window.d.ts +34 -0
- package/dist/src/desktop/window.d.ts.map +1 -0
- package/dist/src/desktop/window.js +114 -0
- package/dist/src/device/index.d.ts +2 -0
- package/dist/src/device/index.d.ts.map +1 -0
- package/dist/src/device/index.js +1 -0
- package/dist/src/dock/basic.d.ts +20 -0
- package/dist/src/dock/basic.d.ts.map +1 -0
- package/dist/src/dock/basic.js +50 -0
- package/dist/src/dock/index.d.ts +6 -0
- package/dist/src/dock/index.d.ts.map +1 -0
- package/dist/src/dock/index.js +6 -0
- package/dist/src/dock/limelight-nav.d.ts +10 -0
- package/dist/src/dock/limelight-nav.d.ts.map +1 -0
- package/dist/src/dock/limelight-nav.js +25 -0
- package/dist/src/dock/macos.d.ts +17 -0
- package/dist/src/dock/macos.d.ts.map +1 -0
- package/dist/src/dock/macos.js +38 -0
- package/dist/src/dock/menu.d.ts +14 -0
- package/dist/src/dock/menu.d.ts.map +1 -0
- package/dist/src/dock/menu.js +10 -0
- package/dist/src/dock/message.d.ts +15 -0
- package/dist/src/dock/message.d.ts.map +1 -0
- package/dist/src/dock/message.js +21 -0
- package/dist/src/form/form.d.ts +24 -0
- package/dist/src/form/form.d.ts.map +1 -0
- package/dist/src/form/form.js +66 -0
- package/dist/src/form/index.d.ts +2 -0
- package/dist/src/form/index.d.ts.map +1 -0
- package/dist/src/form/index.js +2 -0
- package/dist/src/hooks/index.d.ts +8 -0
- package/dist/src/hooks/index.d.ts.map +1 -0
- package/dist/src/hooks/index.js +7 -0
- package/dist/src/hooks/use-click-away.d.ts +3 -0
- package/dist/src/hooks/use-click-away.d.ts.map +1 -0
- package/dist/src/hooks/use-click-away.js +23 -0
- package/dist/src/hooks/use-combined-refs.d.ts +4 -0
- package/dist/src/hooks/use-combined-refs.d.ts.map +1 -0
- package/dist/src/hooks/use-combined-refs.js +18 -0
- package/dist/src/hooks/use-copy-clipboard.d.ts +10 -0
- package/dist/src/hooks/use-copy-clipboard.d.ts.map +1 -0
- package/dist/src/hooks/use-copy-clipboard.js +21 -0
- package/dist/src/hooks/use-debounce.d.ts +2 -0
- package/dist/src/hooks/use-debounce.d.ts.map +1 -0
- package/dist/src/hooks/use-debounce.js +13 -0
- package/dist/src/hooks/use-fill-ids.d.ts +9 -0
- package/dist/src/hooks/use-fill-ids.d.ts.map +1 -0
- package/dist/src/hooks/use-fill-ids.js +20 -0
- package/dist/src/hooks/use-map.d.ts +2 -0
- package/dist/src/hooks/use-map.d.ts.map +1 -0
- package/dist/src/hooks/use-map.js +20 -0
- package/dist/src/hooks/use-measure.d.ts +9 -0
- package/dist/src/hooks/use-measure.d.ts.map +1 -0
- package/dist/src/hooks/use-measure.js +25 -0
- package/dist/src/hooks/use-reverse-video-playback.d.ts +2 -0
- package/dist/src/hooks/use-reverse-video-playback.d.ts.map +1 -0
- package/dist/src/hooks/use-reverse-video-playback.js +41 -0
- package/dist/src/hooks/use-scroll-restoration.d.ts +9 -0
- package/dist/src/hooks/use-scroll-restoration.d.ts.map +1 -0
- package/dist/src/hooks/use-scroll-restoration.js +36 -0
- package/dist/src/kanban/index.d.ts +3 -0
- package/dist/src/kanban/index.d.ts.map +1 -0
- package/dist/src/kanban/index.js +4 -0
- package/dist/src/mcp/enhanced-server.d.ts +41 -0
- package/dist/src/mcp/enhanced-server.d.ts.map +1 -0
- package/dist/src/mcp/enhanced-server.js +1128 -0
- package/dist/src/mcp/index.d.ts +40 -0
- package/dist/src/mcp/index.d.ts.map +1 -0
- package/dist/src/mcp/index.js +436 -0
- package/dist/src/mermaid/index.d.ts +3 -0
- package/dist/src/mermaid/index.d.ts.map +1 -0
- package/dist/src/mermaid/index.js +3 -0
- package/dist/src/navigation/advanced-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/advanced-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/advanced-navigation-bar.js +4 -0
- package/dist/src/navigation/ai-model-selector-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/ai-model-selector-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/ai-model-selector-navigation-bar.js +4 -0
- package/dist/src/navigation/app-switcher-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/app-switcher-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/app-switcher-navigation-bar.js +4 -0
- package/dist/src/navigation/breadcrumb-and-filters-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/breadcrumb-and-filters-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/breadcrumb-and-filters-navigation-bar.js +4 -0
- package/dist/src/navigation/breadcrumb-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/breadcrumb-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/breadcrumb-navigation-bar.js +4 -0
- package/dist/src/navigation/centered-logo-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/centered-logo-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/centered-logo-navigation-bar.js +4 -0
- package/dist/src/navigation/collaboration-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/collaboration-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/collaboration-navigation-bar.js +4 -0
- package/dist/src/navigation/communication-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/communication-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/communication-navigation-bar.js +4 -0
- package/dist/src/navigation/context-switcher-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/context-switcher-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/context-switcher-navigation-bar.js +4 -0
- package/dist/src/navigation/dashboard-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/dashboard-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/dashboard-navigation-bar.js +4 -0
- package/dist/src/navigation/e-commerce-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/e-commerce-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/e-commerce-navigation-bar.js +4 -0
- package/dist/src/navigation/icon-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/icon-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/icon-navigation-bar.js +4 -0
- package/dist/src/navigation/index.d.ts +19 -0
- package/dist/src/navigation/index.d.ts.map +1 -0
- package/dist/src/navigation/index.js +19 -0
- package/dist/src/navigation/search-and-toggle-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/search-and-toggle-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/search-and-toggle-navigation-bar.js +4 -0
- package/dist/src/navigation/simple-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/simple-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/simple-navigation-bar.js +4 -0
- package/dist/src/navigation/status-dashboard-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/status-dashboard-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/status-dashboard-navigation-bar.js +4 -0
- package/dist/src/navigation/team-switcher-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/team-switcher-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/team-switcher-navigation-bar.js +4 -0
- package/dist/src/navigation/two-tier-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/two-tier-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/two-tier-navigation-bar.js +4 -0
- package/dist/src/navigation/underline-navigation-bar.d.ts +2 -0
- package/dist/src/navigation/underline-navigation-bar.d.ts.map +1 -0
- package/dist/src/navigation/underline-navigation-bar.js +4 -0
- package/dist/src/pattern/grid.d.ts +111 -0
- package/dist/src/pattern/grid.d.ts.map +1 -0
- package/dist/src/pattern/grid.js +126 -0
- package/dist/src/pattern/index.d.ts +3 -0
- package/dist/src/pattern/index.d.ts.map +1 -0
- package/dist/src/pattern/index.js +2 -0
- package/dist/src/project/gantt.d.ts +13 -0
- package/dist/src/project/gantt.d.ts.map +1 -0
- package/dist/src/project/gantt.js +9 -0
- package/dist/src/project/index.d.ts +4 -0
- package/dist/src/project/index.d.ts.map +1 -0
- package/dist/src/project/index.js +7 -0
- package/dist/src/project/kanban.d.ts +36 -0
- package/dist/src/project/kanban.d.ts.map +1 -0
- package/dist/src/project/kanban.js +259 -0
- package/dist/src/project/list.d.ts +5 -0
- package/dist/src/project/list.d.ts.map +1 -0
- package/dist/src/project/list.js +8 -0
- package/dist/src/registry/api.d.ts +38 -0
- package/dist/src/registry/api.d.ts.map +1 -0
- package/dist/src/registry/api.js +129 -0
- package/dist/src/registry/index.d.ts +354 -0
- package/dist/src/registry/index.d.ts.map +1 -0
- package/dist/src/registry/index.js +45 -0
- package/dist/src/spline/index.d.ts +3 -0
- package/dist/src/spline/index.d.ts.map +1 -0
- package/dist/src/spline/index.js +4 -0
- package/dist/src/spline/media-stack.d.ts +15 -0
- package/dist/src/spline/media-stack.d.ts.map +1 -0
- package/dist/src/spline/media-stack.js +33 -0
- package/dist/src/spline/player.d.ts +15 -0
- package/dist/src/spline/player.d.ts.map +1 -0
- package/dist/src/spline/player.js +12 -0
- package/dist/src/ui/announcement.d.ts +9 -0
- package/dist/src/ui/announcement.d.ts.map +1 -0
- package/dist/src/ui/announcement.js +18 -0
- package/dist/src/ui/avatar-group.d.ts +12 -0
- package/dist/src/ui/avatar-group.d.ts.map +1 -0
- package/dist/src/ui/avatar-group.js +12 -0
- package/dist/src/ui/banner.d.ts +11 -0
- package/dist/src/ui/banner.d.ts.map +1 -0
- package/dist/src/ui/banner.js +25 -0
- package/dist/src/ui/cursor.d.ts +9 -0
- package/dist/src/ui/cursor.d.ts.map +1 -0
- package/dist/src/ui/cursor.js +24 -0
- package/dist/src/ui/index.d.ts +18 -0
- package/dist/src/ui/index.d.ts.map +1 -0
- package/dist/src/ui/index.js +10 -0
- package/dist/src/ui/marquee.d.ts +10 -0
- package/dist/src/ui/marquee.d.ts.map +1 -0
- package/dist/src/ui/marquee.js +14 -0
- package/dist/src/ui/pill.d.ts +11 -0
- package/dist/src/ui/pill.d.ts.map +1 -0
- package/dist/src/ui/pill.js +25 -0
- package/dist/src/ui/spinner.d.ts +3 -0
- package/dist/src/ui/spinner.d.ts.map +1 -0
- package/dist/src/ui/spinner.js +7 -0
- package/dist/src/ui/tags.d.ts +13 -0
- package/dist/src/ui/tags.d.ts.map +1 -0
- package/dist/src/ui/tags.js +11 -0
- package/dist/src/ui/ticker.d.ts +10 -0
- package/dist/src/ui/ticker.d.ts.map +1 -0
- package/dist/src/ui/ticker.js +12 -0
- package/dist/src/utils.d.ts +5 -0
- package/dist/src/utils.d.ts.map +1 -0
- package/dist/src/utils.js +16 -0
- package/dist/style/theme-provider.d.ts +5 -0
- package/dist/style/theme-provider.d.ts.map +1 -0
- package/dist/style/theme-provider.js +8 -0
- package/dist/tabs.js +81 -35
- package/dist/tabs.mjs +81 -36
- package/dist/tailwind/colors.tailwind.d.ts +53 -0
- package/dist/tailwind/colors.tailwind.d.ts.map +1 -0
- package/dist/tailwind/colors.tailwind.js +52 -0
- package/dist/tailwind/fontFamily.tailwind.d.ts +9 -0
- package/dist/tailwind/fontFamily.tailwind.d.ts.map +1 -0
- package/dist/tailwind/fontFamily.tailwind.js +7 -0
- package/dist/tailwind/fontSize.tailwind.d.ts +37 -0
- package/dist/tailwind/fontSize.tailwind.d.ts.map +1 -0
- package/dist/tailwind/fontSize.tailwind.js +13 -0
- package/dist/tailwind/index.d.ts +4 -0
- package/dist/tailwind/index.d.ts.map +1 -0
- package/dist/tailwind/index.js +2 -2023
- package/dist/tailwind/safelist.tailwind.d.ts +9 -0
- package/dist/tailwind/safelist.tailwind.d.ts.map +1 -0
- package/dist/tailwind/safelist.tailwind.js +25 -0
- package/dist/tailwind/screens.tailwind.d.ts +10 -0
- package/dist/tailwind/screens.tailwind.d.ts.map +1 -0
- package/dist/tailwind/screens.tailwind.js +8 -0
- package/dist/tailwind/spacing.tailwind.d.ts +59 -0
- package/dist/tailwind/spacing.tailwind.d.ts.map +1 -0
- package/dist/tailwind/spacing.tailwind.js +62 -0
- package/dist/tailwind/tailwind.config.hanzo-preset.d.ts +1299 -0
- package/dist/tailwind/tailwind.config.hanzo-preset.d.ts.map +1 -0
- package/dist/tailwind/tailwind.config.hanzo-preset.js +911 -0
- package/dist/tailwind/tw-font-desc.d.ts +7 -0
- package/dist/tailwind/tw-font-desc.d.ts.map +1 -0
- package/dist/tailwind/tw-font-desc.js +6 -0
- package/dist/tailwind/typo-plugin/get-plugin-styles.d.ts +595 -0
- package/dist/tailwind/typo-plugin/get-plugin-styles.d.ts.map +1 -0
- package/dist/tailwind/typo-plugin/get-plugin-styles.js +661 -0
- package/dist/tailwind/typo-plugin/index.d.ts +3 -0
- package/dist/tailwind/typo-plugin/index.d.ts.map +1 -0
- package/dist/tailwind/typo-plugin/index.js +102 -0
- package/dist/tailwind/typo-plugin/utils.d.ts +6 -0
- package/dist/tailwind/typo-plugin/utils.d.ts.map +1 -0
- package/dist/tailwind/typo-plugin/utils.js +47 -0
- package/dist/tailwind/z-index.tailwind.d.ts +51 -0
- package/dist/tailwind/z-index.tailwind.d.ts.map +1 -0
- package/dist/tailwind/z-index.tailwind.js +67 -0
- package/dist/types/animation-def.d.ts +3 -0
- package/dist/types/animation-def.d.ts.map +1 -0
- package/dist/types/animation-def.js +1 -0
- package/dist/types/breakpoints.d.ts +5 -0
- package/dist/types/breakpoints.d.ts.map +1 -0
- package/dist/types/breakpoints.js +4 -0
- package/dist/types/bullet-item.d.ts +7 -0
- package/dist/types/bullet-item.d.ts.map +1 -0
- package/dist/types/bullet-item.js +1 -0
- package/dist/types/button-def.d.ts +30 -0
- package/dist/types/button-def.d.ts.map +1 -0
- package/dist/types/button-def.js +1 -0
- package/dist/types/dimensions.d.ts +6 -0
- package/dist/types/dimensions.d.ts.map +1 -0
- package/dist/types/dimensions.js +1 -0
- package/dist/types/grid-def.d.ts +37 -0
- package/dist/types/grid-def.d.ts.map +1 -0
- package/dist/types/grid-def.js +33 -0
- package/dist/types/image-def.d.ts +28 -0
- package/dist/types/image-def.d.ts.map +1 -0
- package/dist/types/image-def.js +1 -0
- package/dist/types/index.d.ts +15 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -57
- package/dist/types/link-def.d.ts +45 -0
- package/dist/types/link-def.d.ts.map +1 -0
- package/dist/types/link-def.js +1 -0
- package/dist/types/media-stack-def.d.ts +26 -0
- package/dist/types/media-stack-def.d.ts.map +1 -0
- package/dist/types/media-stack-def.js +1 -0
- package/dist/types/t-shirt-size.d.ts +3 -0
- package/dist/types/t-shirt-size.d.ts.map +1 -0
- package/dist/types/t-shirt-size.js +1 -0
- package/dist/types/tshirt-dimensions.d.ts +13 -0
- package/dist/types/tshirt-dimensions.d.ts.map +1 -0
- package/dist/types/tshirt-dimensions.js +1 -0
- package/dist/types/video-def.d.ts +10 -0
- package/dist/types/video-def.d.ts.map +1 -0
- package/dist/types/video-def.js +1 -0
- package/dist/ui/announcement.js +18 -13
- package/dist/ui/announcement.mjs +18 -13
- package/dist/ui/index.js +45 -25
- package/dist/ui/index.mjs +45 -25
- package/dist/ui/tags.js +28 -12
- package/dist/ui/tags.mjs +28 -12
- package/dist/util/blob.d.ts +3 -0
- package/dist/util/blob.d.ts.map +1 -0
- package/dist/util/blob.js +23 -0
- package/dist/util/copy-to-clipboard.d.ts +2 -0
- package/dist/util/copy-to-clipboard.d.ts.map +1 -0
- package/dist/util/copy-to-clipboard.js +18 -0
- package/dist/util/create-shadow-root.d.ts +8 -0
- package/dist/util/create-shadow-root.d.ts.map +1 -0
- package/dist/util/create-shadow-root.js +18 -0
- package/dist/util/date.d.ts +29 -0
- package/dist/util/date.d.ts.map +1 -0
- package/dist/util/date.js +60 -0
- package/dist/util/debounce.d.ts +2 -0
- package/dist/util/debounce.d.ts.map +1 -0
- package/dist/util/debounce.js +11 -0
- package/dist/util/file.d.ts +4 -0
- package/dist/util/file.d.ts.map +1 -0
- package/dist/util/file.js +13 -0
- package/dist/util/format-and-abbreviate-as-currency.d.ts +12 -0
- package/dist/util/format-and-abbreviate-as-currency.d.ts.map +1 -0
- package/dist/util/format-and-abbreviate-as-currency.js +91 -0
- package/dist/util/format-text.d.ts +8 -0
- package/dist/util/format-text.d.ts.map +1 -0
- package/dist/util/format-text.js +26 -0
- package/dist/util/format-to-max-char.d.ts +6 -0
- package/dist/util/format-to-max-char.d.ts.map +1 -0
- package/dist/util/format-to-max-char.js +57 -0
- package/dist/util/index-client.d.ts +3 -0
- package/dist/util/index-client.d.ts.map +1 -0
- package/dist/util/index-client.js +3 -0
- package/dist/util/index.d.ts +37 -0
- package/dist/util/index.d.ts.map +1 -0
- package/dist/util/index.js +74 -457
- package/dist/util/number-abbreviate.d.ts +10 -0
- package/dist/util/number-abbreviate.d.ts.map +1 -0
- package/dist/util/number-abbreviate.js +30 -0
- package/dist/util/specifier.d.ts +8 -0
- package/dist/util/specifier.d.ts.map +1 -0
- package/dist/util/specifier.js +31 -0
- package/dist/util/spread-to-transform.d.ts +8 -0
- package/dist/util/spread-to-transform.d.ts.map +1 -0
- package/dist/util/spread-to-transform.js +19 -0
- package/dist/util/step-animation.d.ts +6 -0
- package/dist/util/step-animation.d.ts.map +1 -0
- package/dist/util/step-animation.js +60 -0
- package/dist/util/timing.d.ts +2 -0
- package/dist/util/timing.d.ts.map +1 -0
- package/dist/util/timing.js +3 -0
- package/dist/util/toasts.d.ts +3 -0
- package/dist/util/toasts.d.ts.map +1 -0
- package/dist/util/toasts.js +10 -0
- package/dist/util/two-way-map.d.ts +9 -0
- package/dist/util/two-way-map.d.ts.map +1 -0
- package/dist/util/two-way-map.js +16 -0
- package/dist/util/use-mobile.d.ts +2 -0
- package/dist/util/use-mobile.d.ts.map +1 -0
- package/dist/util/use-mobile.js +15 -0
- package/dist/utils.d.ts +4 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +7 -0
- package/docs/css/aspen.css +39 -0
- package/docs/css/emerald.css +39 -0
- package/docs/css/ruby.css +39 -0
- package/package.json +79 -40
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cn } from "@hanzo/ui/lib/utils";
|
|
5
|
+
const Grid3D = React.forwardRef(({ items, columns = 4, rows = 3, gap = 16, perspective = 1000, rotateX = 25, rotateY = 15, cellHeight = 200, cellWidth = 200, isometric = false, tiltOnHover = true, staggerAnimation = true, animationDelay = 100, elevationOnHover = true, maxElevation = 50, className, ...props }, ref) => {
|
|
6
|
+
const gridRef = React.useRef(null);
|
|
7
|
+
const [hoveredIndex, setHoveredIndex] = React.useState(null);
|
|
8
|
+
const [mousePosition, setMousePosition] = React.useState({ x: 0, y: 0 });
|
|
9
|
+
const [isGridHovered, setIsGridHovered] = React.useState(false);
|
|
10
|
+
// Calculate grid transforms based on isometric mode
|
|
11
|
+
const gridTransform = React.useMemo(() => {
|
|
12
|
+
if (isometric) {
|
|
13
|
+
return `perspective(${perspective}px) rotateX(45deg) rotateY(45deg)`;
|
|
14
|
+
}
|
|
15
|
+
return `perspective(${perspective}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;
|
|
16
|
+
}, [isometric, perspective, rotateX, rotateY]);
|
|
17
|
+
// Handle mouse movement for global tilt effect
|
|
18
|
+
const handleMouseMove = React.useCallback((e) => {
|
|
19
|
+
if (!tiltOnHover || !gridRef.current)
|
|
20
|
+
return;
|
|
21
|
+
const rect = gridRef.current.getBoundingClientRect();
|
|
22
|
+
const centerX = rect.left + rect.width / 2;
|
|
23
|
+
const centerY = rect.top + rect.height / 2;
|
|
24
|
+
const mouseX = (e.clientX - centerX) / (rect.width / 2);
|
|
25
|
+
const mouseY = (e.clientY - centerY) / (rect.height / 2);
|
|
26
|
+
setMousePosition({ x: mouseX * 10, y: mouseY * 10 });
|
|
27
|
+
}, [tiltOnHover]);
|
|
28
|
+
const handleMouseEnter = React.useCallback(() => {
|
|
29
|
+
setIsGridHovered(true);
|
|
30
|
+
}, []);
|
|
31
|
+
const handleMouseLeave = React.useCallback(() => {
|
|
32
|
+
setIsGridHovered(false);
|
|
33
|
+
setMousePosition({ x: 0, y: 0 });
|
|
34
|
+
setHoveredIndex(null);
|
|
35
|
+
}, []);
|
|
36
|
+
React.useImperativeHandle(ref, () => gridRef.current);
|
|
37
|
+
const containerStyle = {
|
|
38
|
+
perspective: `${perspective}px`,
|
|
39
|
+
transformStyle: "preserve-3d",
|
|
40
|
+
};
|
|
41
|
+
const gridStyle = {
|
|
42
|
+
display: "grid",
|
|
43
|
+
gridTemplateColumns: `repeat(${columns}, ${cellWidth}px)`,
|
|
44
|
+
gridTemplateRows: `repeat(${rows}, ${cellHeight}px)`,
|
|
45
|
+
gap: `${gap}px`,
|
|
46
|
+
transform: tiltOnHover && isGridHovered
|
|
47
|
+
? `${gridTransform} rotateX(${-mousePosition.y}deg) rotateY(${mousePosition.x}deg)`
|
|
48
|
+
: gridTransform,
|
|
49
|
+
transition: "transform 0.3s cubic-bezier(0.4, 0, 0.2, 1)",
|
|
50
|
+
transformStyle: "preserve-3d",
|
|
51
|
+
};
|
|
52
|
+
// Calculate grid position for each item
|
|
53
|
+
const getGridPosition = (index) => {
|
|
54
|
+
const x = index % columns;
|
|
55
|
+
const y = Math.floor(index / columns);
|
|
56
|
+
return { x, y };
|
|
57
|
+
};
|
|
58
|
+
// Calculate stagger delay for animations
|
|
59
|
+
const getStaggerDelay = (index) => {
|
|
60
|
+
if (!staggerAnimation)
|
|
61
|
+
return 0;
|
|
62
|
+
const { x, y } = getGridPosition(index);
|
|
63
|
+
return (x + y) * animationDelay;
|
|
64
|
+
};
|
|
65
|
+
return (_jsxs("div", { ref: gridRef, className: cn("w-fit mx-auto", className), style: containerStyle, onMouseMove: handleMouseMove, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ...props, children: [_jsx("div", { style: gridStyle, children: items.map((item, index) => {
|
|
66
|
+
const isHovered = hoveredIndex === index;
|
|
67
|
+
const { x, y } = getGridPosition(index);
|
|
68
|
+
const staggerDelay = getStaggerDelay(index);
|
|
69
|
+
const itemStyle = {
|
|
70
|
+
gridColumn: item.span ? `span ${item.span.x}` : undefined,
|
|
71
|
+
gridRow: item.span ? `span ${item.span.y}` : undefined,
|
|
72
|
+
transform: `translateZ(${(item.elevation || 0) +
|
|
73
|
+
(isHovered && elevationOnHover ? maxElevation : 0)}px)`,
|
|
74
|
+
transition: "all 0.3s cubic-bezier(0.4, 0, 0.2, 1)",
|
|
75
|
+
transformStyle: "preserve-3d",
|
|
76
|
+
animationDelay: `${staggerDelay}ms`,
|
|
77
|
+
};
|
|
78
|
+
return (_jsxs("div", { className: cn("relative rounded-lg border bg-card text-card-foreground shadow-lg", "transform-gpu will-change-transform cursor-pointer", "transition-all duration-300 hover:shadow-xl", staggerAnimation &&
|
|
79
|
+
"animate-in fade-in slide-in-from-bottom-4", isHovered && "ring-2 ring-primary ring-offset-2"), style: itemStyle, onMouseEnter: () => setHoveredIndex(index), onMouseLeave: () => setHoveredIndex(null), children: [_jsx("div", { className: "w-full h-full overflow-hidden rounded-lg", children: item.content }), (item.elevation || 0) > 0 && (_jsx("div", { className: "absolute inset-0 -z-10 rounded-lg bg-black/20 blur-sm", style: {
|
|
80
|
+
transform: `translateY(${(item.elevation || 0) / 2}px) scale(0.95)`,
|
|
81
|
+
} }))] }, item.id));
|
|
82
|
+
}) }), isometric && (_jsx("div", { className: "absolute inset-0 pointer-events-none opacity-20", children: _jsx("div", { className: "grid border-dashed border-muted-foreground/30", style: {
|
|
83
|
+
gridTemplateColumns: `repeat(${columns}, ${cellWidth}px)`,
|
|
84
|
+
gridTemplateRows: `repeat(${rows}, ${cellHeight}px)`,
|
|
85
|
+
gap: `${gap}px`,
|
|
86
|
+
transform: gridTransform,
|
|
87
|
+
transformStyle: "preserve-3d",
|
|
88
|
+
}, children: Array.from({ length: columns * rows }).map((_, index) => (_jsx("div", { className: "border border-dashed border-muted-foreground/20 rounded-lg" }, index))) }) }))] }));
|
|
89
|
+
});
|
|
90
|
+
Grid3D.displayName = "Grid3D";
|
|
91
|
+
// 3D Grid Card component optimized for the grid
|
|
92
|
+
const Grid3DCard = React.forwardRef(({ className, title, description, image, badge, elevation = 0, children, ...props }, ref) => (_jsxs("div", { ref: ref, className: cn("group relative w-full h-full flex flex-col bg-gradient-to-br from-background to-muted/20", "border rounded-lg overflow-hidden", className), style: {
|
|
93
|
+
transform: `translateZ(${elevation}px)`,
|
|
94
|
+
transformStyle: "preserve-3d",
|
|
95
|
+
}, ...props, children: [image && (_jsxs("div", { className: "relative h-32 overflow-hidden", children: [_jsx("img", { src: image, alt: title || "", className: "w-full h-full object-cover transition-transform duration-300 group-hover:scale-110" }), badge && (_jsx("div", { className: "absolute top-2 right-2 px-2 py-1 text-xs rounded-full bg-primary text-primary-foreground", children: badge }))] })), _jsxs("div", { className: "flex-1 p-4 flex flex-col justify-between", children: [title && (_jsx("h3", { className: "font-semibold text-lg mb-2 line-clamp-2 group-hover:text-primary transition-colors", children: title })), description && (_jsx("p", { className: "text-sm text-muted-foreground line-clamp-3 mb-4", children: description })), children && _jsx("div", { className: "mt-auto", children: children })] }), _jsx("div", { className: "absolute inset-0 -z-10 rounded-lg bg-gradient-to-br from-muted/50 to-muted", style: {
|
|
96
|
+
transform: "translateZ(-2px) scale(0.98)",
|
|
97
|
+
transformStyle: "preserve-3d",
|
|
98
|
+
} })] })));
|
|
99
|
+
Grid3DCard.displayName = "Grid3DCard";
|
|
100
|
+
// Preset grid layouts
|
|
101
|
+
const Grid3DPreset = {
|
|
102
|
+
Dashboard: React.forwardRef(({ children, ...props }, ref) => (_jsx(Grid3D, { ref: ref, columns: 4, rows: 3, cellWidth: 250, cellHeight: 200, gap: 20, perspective: 1200, rotateX: 20, rotateY: 10, tiltOnHover: true, elevationOnHover: true, maxElevation: 30, items: [], ...props }))),
|
|
103
|
+
Isometric: React.forwardRef(({ children, ...props }, ref) => (_jsx(Grid3D, { ref: ref, columns: 3, rows: 3, cellWidth: 180, cellHeight: 180, gap: 16, isometric: true, perspective: 1000, staggerAnimation: true, animationDelay: 50, items: [], ...props }))),
|
|
104
|
+
Gallery: React.forwardRef(({ children, ...props }, ref) => (_jsx(Grid3D, { ref: ref, columns: 5, rows: 2, cellWidth: 200, cellHeight: 280, gap: 24, perspective: 1500, rotateX: 15, rotateY: 5, tiltOnHover: true, elevationOnHover: true, maxElevation: 40, items: [], ...props }))),
|
|
105
|
+
Compact: React.forwardRef(({ children, ...props }, ref) => (_jsx(Grid3D, { ref: ref, columns: 6, rows: 4, cellWidth: 120, cellHeight: 120, gap: 8, perspective: 800, rotateX: 30, rotateY: 20, tiltOnHover: true, staggerAnimation: true, animationDelay: 30, items: [], ...props }))),
|
|
106
|
+
};
|
|
107
|
+
// Assign display names
|
|
108
|
+
Grid3DPreset.Dashboard.displayName = "Grid3DPreset.Dashboard";
|
|
109
|
+
Grid3DPreset.Isometric.displayName = "Grid3DPreset.Isometric";
|
|
110
|
+
Grid3DPreset.Gallery.displayName = "Grid3DPreset.Gallery";
|
|
111
|
+
Grid3DPreset.Compact.displayName = "Grid3DPreset.Compact";
|
|
112
|
+
// Auto-arranging grid that adjusts based on content
|
|
113
|
+
const Grid3DAuto = React.forwardRef(({ items, minCellWidth = 200, maxCellWidth = 300, aspectRatio = 1, ...props }, ref) => {
|
|
114
|
+
const [dimensions, setDimensions] = React.useState({ columns: 3, rows: 2 });
|
|
115
|
+
React.useEffect(() => {
|
|
116
|
+
const itemCount = items.length;
|
|
117
|
+
const columns = Math.ceil(Math.sqrt(itemCount));
|
|
118
|
+
const rows = Math.ceil(itemCount / columns);
|
|
119
|
+
setDimensions({ columns, rows });
|
|
120
|
+
}, [items.length]);
|
|
121
|
+
const cellWidth = Math.min(maxCellWidth, Math.max(minCellWidth, 200));
|
|
122
|
+
const cellHeight = cellWidth / aspectRatio;
|
|
123
|
+
return (_jsx(Grid3D, { ref: ref, items: items, columns: dimensions.columns, rows: dimensions.rows, cellWidth: cellWidth, cellHeight: cellHeight, ...props }));
|
|
124
|
+
});
|
|
125
|
+
Grid3DAuto.displayName = "Grid3DAuto";
|
|
126
|
+
export { Grid3D, Grid3DCard, Grid3DPreset, Grid3DAuto, };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { Button3D, Button3DPreset, Button3DLoading, button3DVariants, type Button3DProps, } from "./button";
|
|
2
|
+
export { Card3D, Card3DHeader, Card3DTitle, Card3DDescription, Card3DContent, Card3DFooter, } from "./card";
|
|
3
|
+
export { Carousel3D, Carousel3DCard, Carousel3DCardImage, Carousel3DCardContent, Carousel3DCardTitle, Carousel3DCardDescription, type Carousel3DItem, type Carousel3DProps, } from "./carousel";
|
|
4
|
+
export { Grid3D, Grid3DCard, Grid3DPreset, Grid3DAuto, type Grid3DItem, type Grid3DProps, } from "./grid";
|
|
5
|
+
export { Marquee3D, Marquee3DPreset, Marquee3DFloating, marquee3DVariants, type Marquee3DProps, } from "./marquee";
|
|
6
|
+
export { Pin3D } from "./pin";
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/3d/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,QAAQ,EACR,cAAc,EACd,eAAe,EACf,gBAAgB,EAChB,KAAK,aAAa,GACnB,MAAM,UAAU,CAAA;AAEjB,OAAO,EACL,MAAM,EACN,YAAY,EACZ,WAAW,EACX,iBAAiB,EACjB,aAAa,EACb,YAAY,GACb,MAAM,QAAQ,CAAA;AAEf,OAAO,EACL,UAAU,EACV,cAAc,EACd,mBAAmB,EACnB,qBAAqB,EACrB,mBAAmB,EACnB,yBAAyB,EACzB,KAAK,cAAc,EACnB,KAAK,eAAe,GACrB,MAAM,YAAY,CAAA;AAEnB,OAAO,EACL,MAAM,EACN,UAAU,EACV,YAAY,EACZ,UAAU,EACV,KAAK,UAAU,EACf,KAAK,WAAW,GACjB,MAAM,QAAQ,CAAA;AAEf,OAAO,EACL,SAAS,EACT,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,KAAK,cAAc,GACpB,MAAM,WAAW,CAAA;AAElB,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// 3D Components
|
|
2
|
+
export { Button3D, Button3DPreset, Button3DLoading, button3DVariants, } from "./button";
|
|
3
|
+
export { Card3D, Card3DHeader, Card3DTitle, Card3DDescription, Card3DContent, Card3DFooter, } from "./card";
|
|
4
|
+
export { Carousel3D, Carousel3DCard, Carousel3DCardImage, Carousel3DCardContent, Carousel3DCardTitle, Carousel3DCardDescription, } from "./carousel";
|
|
5
|
+
export { Grid3D, Grid3DCard, Grid3DPreset, Grid3DAuto, } from "./grid";
|
|
6
|
+
export { Marquee3D, Marquee3DPreset, Marquee3DFloating, marquee3DVariants, } from "./marquee";
|
|
7
|
+
export { Pin3D } from "./pin";
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { type VariantProps } from "class-variance-authority";
|
|
3
|
+
declare const marquee3DVariants: (props?: ({
|
|
4
|
+
variant?: "default" | "neon" | "glass" | "rainbow" | "metallic" | "fire" | null | undefined;
|
|
5
|
+
size?: "default" | "sm" | "lg" | "xl" | "2xl" | "3xl" | null | undefined;
|
|
6
|
+
direction?: "left" | "right" | "up" | "down" | null | undefined;
|
|
7
|
+
perspective?: "none" | "default" | "sm" | "lg" | "xl" | null | undefined;
|
|
8
|
+
} & import("class-variance-authority/types").ClassProp) | undefined) => string;
|
|
9
|
+
interface Marquee3DProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof marquee3DVariants> {
|
|
10
|
+
children: React.ReactNode;
|
|
11
|
+
speed?: number;
|
|
12
|
+
pauseOnHover?: boolean;
|
|
13
|
+
reverse?: boolean;
|
|
14
|
+
repeat?: number;
|
|
15
|
+
gap?: number;
|
|
16
|
+
rotateX?: number;
|
|
17
|
+
rotateY?: number;
|
|
18
|
+
rotateZ?: number;
|
|
19
|
+
autoFill?: boolean;
|
|
20
|
+
gradient?: boolean;
|
|
21
|
+
gradientColor?: string;
|
|
22
|
+
gradientWidth?: number;
|
|
23
|
+
}
|
|
24
|
+
declare const Marquee3D: React.ForwardRefExoticComponent<Marquee3DProps & React.RefAttributes<HTMLDivElement>>;
|
|
25
|
+
declare const Marquee3DPreset: {
|
|
26
|
+
Hero: React.ForwardRefExoticComponent<Omit<Marquee3DProps, "variant" | "size"> & React.RefAttributes<HTMLDivElement>>;
|
|
27
|
+
Neon: React.ForwardRefExoticComponent<Omit<Marquee3DProps, "variant" | "size"> & React.RefAttributes<HTMLDivElement>>;
|
|
28
|
+
Metallic: React.ForwardRefExoticComponent<Omit<Marquee3DProps, "variant" | "size"> & React.RefAttributes<HTMLDivElement>>;
|
|
29
|
+
Fire: React.ForwardRefExoticComponent<Omit<Marquee3DProps, "variant" | "size"> & React.RefAttributes<HTMLDivElement>>;
|
|
30
|
+
Glass: React.ForwardRefExoticComponent<Omit<Marquee3DProps, "variant" | "size"> & React.RefAttributes<HTMLDivElement>>;
|
|
31
|
+
};
|
|
32
|
+
declare const Marquee3DFloating: React.ForwardRefExoticComponent<Marquee3DProps & {
|
|
33
|
+
floatIntensity?: number;
|
|
34
|
+
floatSpeed?: number;
|
|
35
|
+
} & React.RefAttributes<HTMLDivElement>>;
|
|
36
|
+
export { Marquee3D, Marquee3DPreset, Marquee3DFloating, marquee3DVariants, type Marquee3DProps, };
|
|
37
|
+
//# sourceMappingURL=marquee.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"marquee.d.ts","sourceRoot":"","sources":["../../../src/3d/marquee.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAKjE,QAAA,MAAM,iBAAiB;;;;;8EAsEtB,CAAA;AAED,UAAU,cACR,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAC1C,YAAY,CAAC,OAAO,iBAAiB,CAAC;IACxC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;CACvB;AAED,QAAA,MAAM,SAAS,uFAsLd,CAAA;AAID,QAAA,MAAM,eAAe;;;;;;CAgFpB,CAAA;AAUD,QAAA,MAAM,iBAAiB;qBAGF,MAAM;iBACV,MAAM;wCAkCrB,CAAA;AAGF,OAAO,EACL,SAAS,EACT,eAAe,EACf,iBAAiB,EACjB,iBAAiB,EACjB,KAAK,cAAc,GACpB,CAAA"}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cva } from "class-variance-authority";
|
|
5
|
+
import { motion } from "framer-motion";
|
|
6
|
+
import { cn } from "@hanzo/ui/lib/utils";
|
|
7
|
+
const marquee3DVariants = cva([
|
|
8
|
+
"relative overflow-hidden whitespace-nowrap",
|
|
9
|
+
"transform-gpu will-change-transform",
|
|
10
|
+
"[perspective:1000px]",
|
|
11
|
+
], {
|
|
12
|
+
variants: {
|
|
13
|
+
variant: {
|
|
14
|
+
default: [
|
|
15
|
+
"bg-background text-foreground",
|
|
16
|
+
"[&_.marquee-content]:text-current",
|
|
17
|
+
],
|
|
18
|
+
neon: [
|
|
19
|
+
"bg-black text-cyan-400",
|
|
20
|
+
"[&_.marquee-content]:text-cyan-400",
|
|
21
|
+
"[&_.marquee-content]:drop-shadow-[0_0_10px_currentColor]",
|
|
22
|
+
"[&_.marquee-content]:animate-pulse",
|
|
23
|
+
],
|
|
24
|
+
rainbow: [
|
|
25
|
+
"bg-black",
|
|
26
|
+
"[&_.marquee-content]:bg-gradient-to-r [&_.marquee-content]:from-red-500 [&_.marquee-content]:via-yellow-500 [&_.marquee-content]:via-green-500 [&_.marquee-content]:via-blue-500 [&_.marquee-content]:to-purple-500",
|
|
27
|
+
"[&_.marquee-content]:bg-clip-text [&_.marquee-content]:text-transparent",
|
|
28
|
+
],
|
|
29
|
+
metallic: [
|
|
30
|
+
"bg-slate-900",
|
|
31
|
+
"[&_.marquee-content]:bg-gradient-to-b [&_.marquee-content]:from-gray-200 [&_.marquee-content]:via-gray-400 [&_.marquee-content]:to-gray-600",
|
|
32
|
+
"[&_.marquee-content]:bg-clip-text [&_.marquee-content]:text-transparent",
|
|
33
|
+
],
|
|
34
|
+
fire: [
|
|
35
|
+
"bg-black",
|
|
36
|
+
"[&_.marquee-content]:bg-gradient-to-t [&_.marquee-content]:from-red-600 [&_.marquee-content]:via-orange-500 [&_.marquee-content]:to-yellow-400",
|
|
37
|
+
"[&_.marquee-content]:bg-clip-text [&_.marquee-content]:text-transparent",
|
|
38
|
+
"[&_.marquee-content]:drop-shadow-[0_0_20px_#ff6600]",
|
|
39
|
+
],
|
|
40
|
+
glass: [
|
|
41
|
+
"bg-white/10 backdrop-blur-sm",
|
|
42
|
+
"[&_.marquee-content]:text-white/90",
|
|
43
|
+
"[&_.marquee-content]:drop-shadow-[0_0_10px_rgba(255,255,255,0.3)]",
|
|
44
|
+
],
|
|
45
|
+
},
|
|
46
|
+
size: {
|
|
47
|
+
sm: "h-8 text-sm [&_.marquee-content]:py-1",
|
|
48
|
+
default: "h-12 text-base [&_.marquee-content]:py-2",
|
|
49
|
+
lg: "h-16 text-lg [&_.marquee-content]:py-3",
|
|
50
|
+
xl: "h-20 text-xl [&_.marquee-content]:py-4",
|
|
51
|
+
"2xl": "h-24 text-2xl [&_.marquee-content]:py-5",
|
|
52
|
+
"3xl": "h-32 text-3xl [&_.marquee-content]:py-6",
|
|
53
|
+
},
|
|
54
|
+
direction: {
|
|
55
|
+
left: "",
|
|
56
|
+
right: "",
|
|
57
|
+
up: "flex-col",
|
|
58
|
+
down: "flex-col",
|
|
59
|
+
},
|
|
60
|
+
perspective: {
|
|
61
|
+
none: "[perspective:none]",
|
|
62
|
+
sm: "[perspective:500px]",
|
|
63
|
+
default: "[perspective:1000px]",
|
|
64
|
+
lg: "[perspective:1500px]",
|
|
65
|
+
xl: "[perspective:2000px]",
|
|
66
|
+
},
|
|
67
|
+
},
|
|
68
|
+
defaultVariants: {
|
|
69
|
+
variant: "default",
|
|
70
|
+
size: "default",
|
|
71
|
+
direction: "left",
|
|
72
|
+
perspective: "default",
|
|
73
|
+
},
|
|
74
|
+
});
|
|
75
|
+
const Marquee3D = React.forwardRef(({ className, variant, size, direction = "left", perspective, children, speed = 50, pauseOnHover = false, reverse = false, repeat = 5, gap = 0, rotateX = 0, rotateY = 0, rotateZ = 0, autoFill = false, gradient = false, gradientColor = "#ffffff", gradientWidth = 200, style, ...props }, ref) => {
|
|
76
|
+
const [containerWidth, setContainerWidth] = React.useState(0);
|
|
77
|
+
const [contentWidth, setContentWidth] = React.useState(0);
|
|
78
|
+
const containerRef = React.useRef(null);
|
|
79
|
+
const contentRef = React.useRef(null);
|
|
80
|
+
// Measure container and content dimensions
|
|
81
|
+
React.useEffect(() => {
|
|
82
|
+
const measureDimensions = () => {
|
|
83
|
+
if (containerRef.current && contentRef.current) {
|
|
84
|
+
const containerRect = containerRef.current.getBoundingClientRect();
|
|
85
|
+
const contentRect = contentRef.current.getBoundingClientRect();
|
|
86
|
+
if (direction === "left" || direction === "right") {
|
|
87
|
+
setContainerWidth(containerRect.width);
|
|
88
|
+
setContentWidth(contentRect.width);
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
setContainerWidth(containerRect.height);
|
|
92
|
+
setContentWidth(contentRect.height);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
measureDimensions();
|
|
97
|
+
window.addEventListener("resize", measureDimensions);
|
|
98
|
+
return () => window.removeEventListener("resize", measureDimensions);
|
|
99
|
+
}, [direction, children]);
|
|
100
|
+
// Calculate animation duration based on speed and content width
|
|
101
|
+
const duration = React.useMemo(() => {
|
|
102
|
+
if (contentWidth === 0)
|
|
103
|
+
return 20;
|
|
104
|
+
return contentWidth / speed;
|
|
105
|
+
}, [contentWidth, speed]);
|
|
106
|
+
// Calculate number of repeats needed for smooth infinite scroll
|
|
107
|
+
const actualRepeat = React.useMemo(() => {
|
|
108
|
+
if (autoFill && containerWidth > 0 && contentWidth > 0) {
|
|
109
|
+
return Math.ceil(containerWidth / contentWidth) + 2;
|
|
110
|
+
}
|
|
111
|
+
return repeat;
|
|
112
|
+
}, [autoFill, containerWidth, contentWidth, repeat]);
|
|
113
|
+
// Animation variants for different directions
|
|
114
|
+
const getAnimationProps = () => {
|
|
115
|
+
const isVertical = direction === "up" || direction === "down";
|
|
116
|
+
const distance = contentWidth + gap;
|
|
117
|
+
let animateProps = {};
|
|
118
|
+
if (direction === "left") {
|
|
119
|
+
animateProps = {
|
|
120
|
+
x: reverse ? [distance, -distance] : [-distance, distance],
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
else if (direction === "right") {
|
|
124
|
+
animateProps = {
|
|
125
|
+
x: reverse ? [-distance, distance] : [distance, -distance],
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
else if (direction === "up") {
|
|
129
|
+
animateProps = {
|
|
130
|
+
y: reverse ? [distance, -distance] : [-distance, distance],
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
else if (direction === "down") {
|
|
134
|
+
animateProps = {
|
|
135
|
+
y: reverse ? [-distance, distance] : [distance, -distance],
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
return {
|
|
139
|
+
animate: animateProps,
|
|
140
|
+
transition: {
|
|
141
|
+
duration,
|
|
142
|
+
ease: "linear",
|
|
143
|
+
repeat: Infinity,
|
|
144
|
+
},
|
|
145
|
+
};
|
|
146
|
+
};
|
|
147
|
+
// 3D transform style
|
|
148
|
+
const transform3D = `perspective(1000px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) rotateZ(${rotateZ}deg)`;
|
|
149
|
+
// Gradient mask style
|
|
150
|
+
const gradientMask = gradient
|
|
151
|
+
? {
|
|
152
|
+
maskImage: `linear-gradient(to right, transparent, ${gradientColor} ${gradientWidth}px, ${gradientColor} calc(100% - ${gradientWidth}px), transparent)`,
|
|
153
|
+
WebkitMaskImage: `linear-gradient(to right, transparent, ${gradientColor} ${gradientWidth}px, ${gradientColor} calc(100% - ${gradientWidth}px), transparent)`,
|
|
154
|
+
}
|
|
155
|
+
: {};
|
|
156
|
+
return (_jsx("div", { ref: containerRef, className: cn(marquee3DVariants({ variant, size, direction, perspective }), "flex items-center", direction === "up" || direction === "down" ? "flex-col" : "flex-row", className), style: {
|
|
157
|
+
...style,
|
|
158
|
+
transform: transform3D,
|
|
159
|
+
...gradientMask,
|
|
160
|
+
}, ...props, children: _jsx(motion.div, { ref: contentRef, className: cn("marquee-content flex shrink-0 font-bold", direction === "up" || direction === "down"
|
|
161
|
+
? "flex-col"
|
|
162
|
+
: "flex-row", pauseOnHover && "hover:[animation-play-state:paused]"), style: {
|
|
163
|
+
gap: `${gap}px`,
|
|
164
|
+
}, ...getAnimationProps(), children: Array.from({ length: actualRepeat }).map((_, index) => (_jsxs(React.Fragment, { children: [_jsx("div", { className: cn("flex shrink-0 items-center justify-center", direction === "up" || direction === "down"
|
|
165
|
+
? "flex-col"
|
|
166
|
+
: "flex-row"), style: {
|
|
167
|
+
transform: `rotateX(${rotateX}deg) rotateY(${rotateY}deg) rotateZ(${rotateZ}deg)`,
|
|
168
|
+
transformStyle: "preserve-3d",
|
|
169
|
+
}, children: children }), index < actualRepeat - 1 && gap > 0 && (_jsx("div", { style: {
|
|
170
|
+
width: direction === "up" || direction === "down"
|
|
171
|
+
? "100%"
|
|
172
|
+
: `${gap}px`,
|
|
173
|
+
height: direction === "up" || direction === "down"
|
|
174
|
+
? `${gap}px`
|
|
175
|
+
: "100%",
|
|
176
|
+
} }))] }, index))) }) }));
|
|
177
|
+
});
|
|
178
|
+
Marquee3D.displayName = "Marquee3D";
|
|
179
|
+
// Preset marquee variants
|
|
180
|
+
const Marquee3DPreset = {
|
|
181
|
+
Hero: React.forwardRef((props, ref) => (_jsx(Marquee3D, { ref: ref, variant: "rainbow", size: "3xl", speed: 30, rotateX: -10, gradient: true, ...props }))),
|
|
182
|
+
Neon: React.forwardRef((props, ref) => (_jsx(Marquee3D, { ref: ref, variant: "neon", size: "xl", speed: 40, rotateY: 5, pauseOnHover: true, ...props }))),
|
|
183
|
+
Metallic: React.forwardRef((props, ref) => (_jsx(Marquee3D, { ref: ref, variant: "metallic", size: "lg", speed: 35, rotateX: -5, rotateY: 2, gradient: true, gradientColor: "#c4c4c4", ...props }))),
|
|
184
|
+
Fire: React.forwardRef((props, ref) => (_jsx(Marquee3D, { ref: ref, variant: "fire", size: "2xl", speed: 60, rotateZ: 1, gradient: true, gradientColor: "#ff6600", ...props }))),
|
|
185
|
+
Glass: React.forwardRef((props, ref) => (_jsx(Marquee3D, { ref: ref, variant: "glass", size: "lg", speed: 25, rotateX: -8, pauseOnHover: true, gradient: true, gradientColor: "rgba(255,255,255,0.9)", ...props }))),
|
|
186
|
+
};
|
|
187
|
+
// Assign display names
|
|
188
|
+
Marquee3DPreset.Hero.displayName = "Marquee3DPreset.Hero";
|
|
189
|
+
Marquee3DPreset.Neon.displayName = "Marquee3DPreset.Neon";
|
|
190
|
+
Marquee3DPreset.Metallic.displayName = "Marquee3DPreset.Metallic";
|
|
191
|
+
Marquee3DPreset.Fire.displayName = "Marquee3DPreset.Fire";
|
|
192
|
+
Marquee3DPreset.Glass.displayName = "Marquee3DPreset.Glass";
|
|
193
|
+
// Marquee with floating 3D text effect
|
|
194
|
+
const Marquee3DFloating = React.forwardRef(({ children, floatIntensity = 10, floatSpeed = 3, ...props }, ref) => {
|
|
195
|
+
const text = typeof children === "string" ? children : "";
|
|
196
|
+
return (_jsx(Marquee3D, { ref: ref, ...props, children: text ? (_jsx("div", { className: "flex space-x-1", children: text.split("").map((char, index) => (_jsx(motion.span, { className: "inline-block", animate: {
|
|
197
|
+
y: [0, -floatIntensity, 0],
|
|
198
|
+
rotateX: [0, 5, 0],
|
|
199
|
+
rotateY: [0, 2, 0],
|
|
200
|
+
}, transition: {
|
|
201
|
+
duration: floatSpeed,
|
|
202
|
+
ease: "easeInOut",
|
|
203
|
+
repeat: Infinity,
|
|
204
|
+
delay: index * 0.1,
|
|
205
|
+
}, children: char === " " ? "\u00A0" : char }, index))) })) : (children) }));
|
|
206
|
+
});
|
|
207
|
+
Marquee3DFloating.displayName = "Marquee3DFloating";
|
|
208
|
+
export { Marquee3D, Marquee3DPreset, Marquee3DFloating, marquee3DVariants, };
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
interface Pin3DProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
3
|
+
title?: string;
|
|
4
|
+
href?: string;
|
|
5
|
+
}
|
|
6
|
+
declare const Pin3D: React.ForwardRefExoticComponent<Pin3DProps & React.RefAttributes<HTMLDivElement>>;
|
|
7
|
+
export { Pin3D };
|
|
8
|
+
//# sourceMappingURL=pin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pin.d.ts","sourceRoot":"","sources":["../../../src/3d/pin.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAK9B,UAAU,UAAW,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC/D,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,QAAA,MAAM,KAAK,mFAmBV,CAAA;AAID,OAAO,EAAE,KAAK,EAAE,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from "react";
|
|
4
|
+
import { cn } from "@hanzo/ui/lib/utils";
|
|
5
|
+
const Pin3D = React.forwardRef(({ className, title, href, children, ...props }, ref) => {
|
|
6
|
+
return (_jsxs("div", { ref: ref, className: cn("group/pin relative cursor-pointer", className), ...props, children: [_jsx("div", { className: "pointer-events-none absolute inset-0 z-10 flex h-full w-full items-center justify-center opacity-0 transition duration-500 group-hover/pin:opacity-100", children: _jsx("div", { className: "relative flex h-full w-full items-center justify-center", children: _jsx("div", { className: "absolute inset-0 bg-white opacity-0 transition duration-500 group-hover/pin:opacity-50" }) }) }), _jsx("div", { className: "transform-gpu transition duration-500 group-hover/pin:scale-95", children: children })] }));
|
|
7
|
+
});
|
|
8
|
+
Pin3D.displayName = "Pin3D";
|
|
9
|
+
export { Pin3D };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"avatar.d.ts","sourceRoot":"","sources":["../../src/avatar.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../primitives/avatar';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge.d.ts","sourceRoot":"","sources":["../../src/badge.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from '../primitives/badge';
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { BillingMetric, BusinessProfile, ComplianceItem, Invoice, PaymentMethod, Subscription, SubscriptionHistory, SubscriptionPlan, TaxSettings, RetentionOffer } from '../types';
|
|
2
|
+
type WorkspaceTab = 'overview' | 'payment' | 'invoices' | 'business' | 'compliance';
|
|
3
|
+
export interface BillingWorkspaceProps {
|
|
4
|
+
subscription: Subscription;
|
|
5
|
+
plans: SubscriptionPlan[];
|
|
6
|
+
usageMetrics?: BillingMetric[];
|
|
7
|
+
retentionOffers?: RetentionOffer[];
|
|
8
|
+
subscriptionHistory?: SubscriptionHistory[];
|
|
9
|
+
paymentMethods?: PaymentMethod[];
|
|
10
|
+
invoices?: Invoice[];
|
|
11
|
+
businessProfile: BusinessProfile;
|
|
12
|
+
taxSettings: TaxSettings;
|
|
13
|
+
complianceItems: ComplianceItem[];
|
|
14
|
+
defaultTab?: WorkspaceTab;
|
|
15
|
+
onUpgrade?: (planId: string) => Promise<void>;
|
|
16
|
+
onDowngrade?: (planId: string) => Promise<void>;
|
|
17
|
+
onCancel?: (reason: string, feedback?: string) => Promise<void>;
|
|
18
|
+
onAcceptOffer?: (offerId: string) => Promise<void>;
|
|
19
|
+
onAddPaymentMethod?: (method: PaymentMethod) => Promise<void>;
|
|
20
|
+
onRemovePaymentMethod?: (id: string) => Promise<void>;
|
|
21
|
+
onSetDefaultPaymentMethod?: (id: string) => Promise<void>;
|
|
22
|
+
onDownloadInvoice?: (invoice: Invoice) => Promise<void>;
|
|
23
|
+
onSaveBusinessProfile?: (profile: BusinessProfile) => Promise<void>;
|
|
24
|
+
onToggleAutomaticTax?: (enabled: boolean) => Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
export declare function BillingWorkspace(props: BillingWorkspaceProps): import("react/jsx-runtime").JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=billing-workspace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"billing-workspace.d.ts","sourceRoot":"","sources":["../../../../src/billing/components/billing-workspace.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EACV,aAAa,EACb,eAAe,EACf,cAAc,EACd,OAAO,EACP,aAAa,EACb,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,EAChB,WAAW,EACX,cAAc,EACf,MAAM,UAAU,CAAA;AAEjB,KAAK,YAAY,GACb,UAAU,GACV,SAAS,GACT,UAAU,GACV,UAAU,GACV,YAAY,CAAA;AAEhB,MAAM,WAAW,qBAAqB;IACpC,YAAY,EAAE,YAAY,CAAA;IAC1B,KAAK,EAAE,gBAAgB,EAAE,CAAA;IACzB,YAAY,CAAC,EAAE,aAAa,EAAE,CAAA;IAC9B,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;IAClC,mBAAmB,CAAC,EAAE,mBAAmB,EAAE,CAAA;IAC3C,cAAc,CAAC,EAAE,aAAa,EAAE,CAAA;IAChC,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAA;IACpB,eAAe,EAAE,eAAe,CAAA;IAChC,WAAW,EAAE,WAAW,CAAA;IACxB,eAAe,EAAE,cAAc,EAAE,CAAA;IACjC,UAAU,CAAC,EAAE,YAAY,CAAA;IAEzB,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAC7C,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/C,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/D,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAElD,kBAAkB,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAC7D,qBAAqB,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IACrD,yBAAyB,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAEzD,iBAAiB,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IACvD,qBAAqB,CAAC,EAAE,CAAC,OAAO,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IACnE,oBAAoB,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3D;AAUD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,2CAiG5D"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { InvoiceManager } from './invoice-manager';
|
|
5
|
+
import { PaymentMethodManager } from './payment-manager';
|
|
6
|
+
import { SubscriptionPortal } from './subscription-portal';
|
|
7
|
+
import { BusinessProfilePanel } from './business-profile-panel';
|
|
8
|
+
import { TaxCompliancePanel } from './tax-compliance-panel';
|
|
9
|
+
const tabs = [
|
|
10
|
+
{ id: 'overview', label: 'Overview' },
|
|
11
|
+
{ id: 'payment', label: 'Payment methods' },
|
|
12
|
+
{ id: 'invoices', label: 'Invoices' },
|
|
13
|
+
{ id: 'business', label: 'Business info' },
|
|
14
|
+
{ id: 'compliance', label: 'Tax & compliance' },
|
|
15
|
+
];
|
|
16
|
+
export function BillingWorkspace(props) {
|
|
17
|
+
const { subscription, plans, usageMetrics, retentionOffers, subscriptionHistory, paymentMethods, invoices, businessProfile, taxSettings, complianceItems, defaultTab = 'overview', onUpgrade, onDowngrade, onCancel, onAcceptOffer, onAddPaymentMethod, onRemovePaymentMethod, onSetDefaultPaymentMethod, onDownloadInvoice, onSaveBusinessProfile, onToggleAutomaticTax, } = props;
|
|
18
|
+
const [activeTab, setActiveTab] = React.useState(defaultTab);
|
|
19
|
+
return (_jsxs("div", { className: "space-y-4", children: [_jsxs("div", { className: "overflow-hidden rounded-2xl border border-zinc-200 bg-gradient-to-b from-zinc-50 to-white", children: [_jsxs("div", { className: "border-b border-zinc-200 px-4 py-4", children: [_jsx("h2", { className: "text-2xl font-semibold text-zinc-900", children: "Billing workspace" }), _jsx("p", { className: "text-sm text-zinc-500", children: "Run subscription, invoicing, payment, business profile, and compliance operations from one surface." })] }), _jsx("div", { className: "flex flex-wrap gap-2 p-3", children: tabs.map((tab) => (_jsx("button", { type: "button", onClick: () => setActiveTab(tab.id), className: `rounded-lg px-3 py-1.5 text-sm transition ${activeTab === tab.id
|
|
20
|
+
? 'bg-zinc-900 text-white'
|
|
21
|
+
: 'text-zinc-600 hover:bg-zinc-100'}`, children: tab.label }, tab.id))) })] }), activeTab === 'overview' ? (_jsx(SubscriptionPortal, { subscription: subscription, availablePlans: plans, usageMetrics: usageMetrics, retentionOffers: retentionOffers, subscriptionHistory: subscriptionHistory, onUpgrade: onUpgrade, onDowngrade: onDowngrade, onCancel: onCancel, onAcceptOffer: onAcceptOffer })) : null, activeTab === 'payment' ? (_jsx(PaymentMethodManager, { paymentMethods: paymentMethods, onAdd: onAddPaymentMethod, onRemove: onRemovePaymentMethod, onSetDefault: onSetDefaultPaymentMethod })) : null, activeTab === 'invoices' ? (_jsx(InvoiceManager, { invoices: invoices, onDownload: onDownloadInvoice })) : null, activeTab === 'business' ? (_jsx(BusinessProfilePanel, { profile: businessProfile, onSave: onSaveBusinessProfile })) : null, activeTab === 'compliance' ? (_jsx(TaxCompliancePanel, { taxSettings: taxSettings, complianceItems: complianceItems, onToggleAutomaticTax: onToggleAutomaticTax })) : null] }));
|
|
22
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { BusinessProfile } from '../types';
|
|
2
|
+
export interface BusinessProfilePanelProps {
|
|
3
|
+
profile: BusinessProfile;
|
|
4
|
+
onSave?: (profile: BusinessProfile) => Promise<void>;
|
|
5
|
+
}
|
|
6
|
+
export declare function BusinessProfilePanel(props: BusinessProfilePanelProps): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
//# sourceMappingURL=business-profile-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"business-profile-panel.d.ts","sourceRoot":"","sources":["../../../../src/billing/components/business-profile-panel.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,MAAM,WAAW,yBAAyB;IACxC,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CACrD;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,2CAgLpE"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
export function BusinessProfilePanel(props) {
|
|
5
|
+
const { profile, onSave } = props;
|
|
6
|
+
const [draft, setDraft] = React.useState(profile);
|
|
7
|
+
const [saving, setSaving] = React.useState(false);
|
|
8
|
+
React.useEffect(() => {
|
|
9
|
+
setDraft(profile);
|
|
10
|
+
}, [profile]);
|
|
11
|
+
const hasFinanceAndLegal = (draft.contacts || []).some((contact) => contact.role === 'finance' || contact.role === 'legal');
|
|
12
|
+
const handleSave = React.useCallback(async () => {
|
|
13
|
+
if (!onSave)
|
|
14
|
+
return;
|
|
15
|
+
setSaving(true);
|
|
16
|
+
try {
|
|
17
|
+
await onSave(draft);
|
|
18
|
+
}
|
|
19
|
+
finally {
|
|
20
|
+
setSaving(false);
|
|
21
|
+
}
|
|
22
|
+
}, [draft, onSave]);
|
|
23
|
+
return (_jsx("div", { className: "space-y-4", children: _jsxs("div", { className: "overflow-hidden rounded-xl border border-zinc-200 bg-white", children: [_jsxs("div", { className: "border-b border-zinc-200 p-4", children: [_jsx("h3", { className: "text-lg font-semibold text-zinc-900", children: "Business profile" }), _jsx("p", { className: "text-sm text-zinc-500", children: "Keep your legal and support details accurate for invoices, tax, and compliance workflows." })] }), _jsxs("div", { className: "grid gap-4 p-4 md:grid-cols-2", children: [_jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Legal name" }), _jsx("input", { value: draft.legalName, onChange: (e) => setDraft((prev) => ({ ...prev, legalName: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] }), _jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Display name" }), _jsx("input", { value: draft.displayName, onChange: (e) => setDraft((prev) => ({ ...prev, displayName: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] }), _jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Website" }), _jsx("input", { value: draft.website || '', onChange: (e) => setDraft((prev) => ({ ...prev, website: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] }), _jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Support email" }), _jsx("input", { value: draft.supportEmail || '', onChange: (e) => setDraft((prev) => ({ ...prev, supportEmail: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] }), _jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Statement descriptor" }), _jsx("input", { value: draft.statementDescriptor || '', onChange: (e) => setDraft((prev) => ({ ...prev, statementDescriptor: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] }), _jsxs("label", { className: "space-y-1 text-sm", children: [_jsx("span", { className: "font-medium text-zinc-700", children: "Tax ID" }), _jsx("input", { value: draft.taxId || '', onChange: (e) => setDraft((prev) => ({ ...prev, taxId: e.target.value })), className: "w-full rounded-lg border border-zinc-300 px-3 py-2 outline-none transition focus:border-zinc-900" })] })] }), _jsxs("div", { className: "border-t border-zinc-200 bg-zinc-50 p-4", children: [_jsx("p", { className: "mb-2 text-sm font-medium text-zinc-700", children: "Registered address" }), _jsxs("div", { className: "grid gap-3 md:grid-cols-2", children: [_jsx("input", { value: draft.registeredAddress.line1, onChange: (e) => setDraft((prev) => ({
|
|
24
|
+
...prev,
|
|
25
|
+
registeredAddress: { ...prev.registeredAddress, line1: e.target.value },
|
|
26
|
+
})), placeholder: "Line 1", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" }), _jsx("input", { value: draft.registeredAddress.line2 || '', onChange: (e) => setDraft((prev) => ({
|
|
27
|
+
...prev,
|
|
28
|
+
registeredAddress: { ...prev.registeredAddress, line2: e.target.value },
|
|
29
|
+
})), placeholder: "Line 2", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" }), _jsx("input", { value: draft.registeredAddress.city, onChange: (e) => setDraft((prev) => ({
|
|
30
|
+
...prev,
|
|
31
|
+
registeredAddress: { ...prev.registeredAddress, city: e.target.value },
|
|
32
|
+
})), placeholder: "City", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" }), _jsx("input", { value: draft.registeredAddress.state || '', onChange: (e) => setDraft((prev) => ({
|
|
33
|
+
...prev,
|
|
34
|
+
registeredAddress: { ...prev.registeredAddress, state: e.target.value },
|
|
35
|
+
})), placeholder: "State/Province", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" }), _jsx("input", { value: draft.registeredAddress.zip, onChange: (e) => setDraft((prev) => ({
|
|
36
|
+
...prev,
|
|
37
|
+
registeredAddress: { ...prev.registeredAddress, zip: e.target.value },
|
|
38
|
+
})), placeholder: "Postal code", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" }), _jsx("input", { value: draft.registeredAddress.country, onChange: (e) => setDraft((prev) => ({
|
|
39
|
+
...prev,
|
|
40
|
+
registeredAddress: { ...prev.registeredAddress, country: e.target.value },
|
|
41
|
+
})), placeholder: "Country", className: "rounded-lg border border-zinc-300 px-3 py-2 text-sm outline-none transition focus:border-zinc-900" })] })] }), _jsxs("div", { className: "flex flex-wrap items-center justify-between gap-3 border-t border-zinc-200 p-4", children: [_jsx("p", { className: "text-xs text-zinc-500", children: hasFinanceAndLegal
|
|
42
|
+
? 'Finance and legal contacts are configured.'
|
|
43
|
+
: 'Tip: add at least one finance or legal contact for smooth audits.' }), _jsx("button", { type: "button", onClick: handleSave, disabled: !onSave || saving, className: "rounded-lg bg-zinc-900 px-3 py-2 text-sm font-medium text-white transition hover:bg-zinc-700 disabled:cursor-not-allowed disabled:opacity-60", children: saving ? 'Saving…' : 'Save profile' })] })] }) }));
|
|
44
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export { SubscriptionPortal } from './subscription-portal';
|
|
2
|
+
export type { SubscriptionPortalProps } from './subscription-portal';
|
|
3
|
+
export { PaymentMethodManager } from './payment-manager';
|
|
4
|
+
export type { PaymentMethodManagerProps } from './payment-manager';
|
|
5
|
+
export { InvoiceManager } from './invoice-manager';
|
|
6
|
+
export type { InvoiceManagerProps } from './invoice-manager';
|
|
7
|
+
export { BusinessProfilePanel } from './business-profile-panel';
|
|
8
|
+
export type { BusinessProfilePanelProps } from './business-profile-panel';
|
|
9
|
+
export { TaxCompliancePanel } from './tax-compliance-panel';
|
|
10
|
+
export type { TaxCompliancePanelProps } from './tax-compliance-panel';
|
|
11
|
+
export { BillingWorkspace } from './billing-workspace';
|
|
12
|
+
export type { BillingWorkspaceProps } from './billing-workspace';
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/billing/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AAC1D,YAAY,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAA;AAEpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AACxD,YAAY,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAA;AAElE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,YAAY,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AAE5D,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAA;AAC/D,YAAY,EAAE,yBAAyB,EAAE,MAAM,0BAA0B,CAAA;AAEzE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAA;AAC3D,YAAY,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAA;AAErE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AACtD,YAAY,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { SubscriptionPortal } from './subscription-portal';
|
|
2
|
+
export { PaymentMethodManager } from './payment-manager';
|
|
3
|
+
export { InvoiceManager } from './invoice-manager';
|
|
4
|
+
export { BusinessProfilePanel } from './business-profile-panel';
|
|
5
|
+
export { TaxCompliancePanel } from './tax-compliance-panel';
|
|
6
|
+
export { BillingWorkspace } from './billing-workspace';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Invoice, InvoiceFilters } from '../types';
|
|
2
|
+
export interface InvoiceManagerProps {
|
|
3
|
+
invoices?: Invoice[];
|
|
4
|
+
onDownload?: (invoice: Invoice) => Promise<void>;
|
|
5
|
+
onFilter?: (filters: InvoiceFilters) => void;
|
|
6
|
+
defaultView?: 'table' | 'grid';
|
|
7
|
+
pageSize?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare function InvoiceManager(props: InvoiceManagerProps): import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
//# sourceMappingURL=invoice-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"invoice-manager.d.ts","sourceRoot":"","sources":["../../../../src/billing/components/invoice-manager.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAEvD,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAA;IACpB,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAChD,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,cAAc,KAAK,IAAI,CAAA;IAC5C,WAAW,CAAC,EAAE,OAAO,GAAG,MAAM,CAAA;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAqED,wBAAgB,cAAc,CAAC,KAAK,EAAE,mBAAmB,2CAqQxD"}
|