@automa8e/ui 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +2 -0
- package/dist/_virtual/index.js +6 -0
- package/dist/_virtual/index.js.map +1 -0
- package/dist/_virtual/index2.js +5 -0
- package/dist/_virtual/index2.js.map +1 -0
- package/dist/_virtual/use-sync-external-store-shim.development.js +5 -0
- package/dist/_virtual/use-sync-external-store-shim.development.js.map +1 -0
- package/dist/_virtual/use-sync-external-store-shim.production.js +5 -0
- package/dist/_virtual/use-sync-external-store-shim.production.js.map +1 -0
- package/dist/automa8e-ui.css +226 -0
- package/dist/components/automation/metric-card.d.ts +19 -0
- package/dist/components/automation/metric-card.d.ts.map +1 -0
- package/dist/components/automation/metric-card.js +59 -0
- package/dist/components/automation/metric-card.js.map +1 -0
- package/dist/components/automation/status-badge.d.ts +27 -0
- package/dist/components/automation/status-badge.d.ts.map +1 -0
- package/dist/components/automation/status-badge.js +112 -0
- package/dist/components/automation/status-badge.js.map +1 -0
- package/dist/components/automation/task-card.d.ts +14 -0
- package/dist/components/automation/task-card.d.ts.map +1 -0
- package/dist/components/automation/task-card.js +114 -0
- package/dist/components/automation/task-card.js.map +1 -0
- package/dist/components/automation/workflow-node.d.ts +20 -0
- package/dist/components/automation/workflow-node.d.ts.map +1 -0
- package/dist/components/automation/workflow-node.js +132 -0
- package/dist/components/automation/workflow-node.js.map +1 -0
- package/dist/components/layout/app-shell.d.ts +21 -0
- package/dist/components/layout/app-shell.d.ts.map +1 -0
- package/dist/components/layout/app-shell.js +35 -0
- package/dist/components/layout/app-shell.js.map +1 -0
- package/dist/components/layout/header.d.ts +16 -0
- package/dist/components/layout/header.d.ts.map +1 -0
- package/dist/components/layout/header.js +30 -0
- package/dist/components/layout/header.js.map +1 -0
- package/dist/components/layout/page-header.d.ts +16 -0
- package/dist/components/layout/page-header.d.ts.map +1 -0
- package/dist/components/layout/page-header.js +29 -0
- package/dist/components/layout/page-header.js.map +1 -0
- package/dist/components/layout/sidebar.d.ts +35 -0
- package/dist/components/layout/sidebar.d.ts.map +1 -0
- package/dist/components/layout/sidebar.js +103 -0
- package/dist/components/layout/sidebar.js.map +1 -0
- package/dist/components/ui/accordion.d.ts +8 -0
- package/dist/components/ui/accordion.d.ts.map +1 -0
- package/dist/components/ui/accordion.js +51 -0
- package/dist/components/ui/accordion.js.map +1 -0
- package/dist/components/ui/alert.d.ts +18 -0
- package/dist/components/ui/alert.d.ts.map +1 -0
- package/dist/components/ui/alert.js +89 -0
- package/dist/components/ui/alert.js.map +1 -0
- package/dist/components/ui/avatar.d.ts +20 -0
- package/dist/components/ui/avatar.d.ts.map +1 -0
- package/dist/components/ui/avatar.js +72 -0
- package/dist/components/ui/avatar.js.map +1 -0
- package/dist/components/ui/badge.d.ts +13 -0
- package/dist/components/ui/badge.d.ts.map +1 -0
- package/dist/components/ui/badge.js +54 -0
- package/dist/components/ui/badge.js.map +1 -0
- package/dist/components/ui/button.d.ts +15 -0
- package/dist/components/ui/button.d.ts.map +1 -0
- package/dist/components/ui/button.js +96 -0
- package/dist/components/ui/button.js.map +1 -0
- package/dist/components/ui/card.d.ts +16 -0
- package/dist/components/ui/card.d.ts.map +1 -0
- package/dist/components/ui/card.js +96 -0
- package/dist/components/ui/card.js.map +1 -0
- package/dist/components/ui/checkbox.d.ts +9 -0
- package/dist/components/ui/checkbox.d.ts.map +1 -0
- package/dist/components/ui/checkbox.js +29 -0
- package/dist/components/ui/checkbox.js.map +1 -0
- package/dist/components/ui/dialog.d.ts +28 -0
- package/dist/components/ui/dialog.d.ts.map +1 -0
- package/dist/components/ui/dialog.js +105 -0
- package/dist/components/ui/dialog.js.map +1 -0
- package/dist/components/ui/dropdown-menu.d.ts +29 -0
- package/dist/components/ui/dropdown-menu.d.ts.map +1 -0
- package/dist/components/ui/dropdown-menu.js +160 -0
- package/dist/components/ui/dropdown-menu.js.map +1 -0
- package/dist/components/ui/input.d.ts +14 -0
- package/dist/components/ui/input.d.ts.map +1 -0
- package/dist/components/ui/input.js +60 -0
- package/dist/components/ui/input.js.map +1 -0
- package/dist/components/ui/label.d.ts +13 -0
- package/dist/components/ui/label.d.ts.map +1 -0
- package/dist/components/ui/label.js +26 -0
- package/dist/components/ui/label.js.map +1 -0
- package/dist/components/ui/popover.d.ts +8 -0
- package/dist/components/ui/popover.d.ts.map +1 -0
- package/dist/components/ui/popover.js +29 -0
- package/dist/components/ui/popover.js.map +1 -0
- package/dist/components/ui/progress.d.ts +17 -0
- package/dist/components/ui/progress.d.ts.map +1 -0
- package/dist/components/ui/progress.js +80 -0
- package/dist/components/ui/progress.js.map +1 -0
- package/dist/components/ui/scroll-area.d.ts +6 -0
- package/dist/components/ui/scroll-area.d.ts.map +1 -0
- package/dist/components/ui/scroll-area.js +39 -0
- package/dist/components/ui/scroll-area.js.map +1 -0
- package/dist/components/ui/select.d.ts +16 -0
- package/dist/components/ui/select.d.ts.map +1 -0
- package/dist/components/ui/select.js +131 -0
- package/dist/components/ui/select.js.map +1 -0
- package/dist/components/ui/separator.d.ts +9 -0
- package/dist/components/ui/separator.d.ts.map +1 -0
- package/dist/components/ui/separator.js +50 -0
- package/dist/components/ui/separator.js.map +1 -0
- package/dist/components/ui/skeleton.d.ts +10 -0
- package/dist/components/ui/skeleton.d.ts.map +1 -0
- package/dist/components/ui/skeleton.js +30 -0
- package/dist/components/ui/skeleton.js.map +1 -0
- package/dist/components/ui/spinner.d.ts +14 -0
- package/dist/components/ui/spinner.d.ts.map +1 -0
- package/dist/components/ui/spinner.js +44 -0
- package/dist/components/ui/spinner.js.map +1 -0
- package/dist/components/ui/switch.d.ts +8 -0
- package/dist/components/ui/switch.d.ts.map +1 -0
- package/dist/components/ui/switch.js +43 -0
- package/dist/components/ui/switch.js.map +1 -0
- package/dist/components/ui/table.d.ts +11 -0
- package/dist/components/ui/table.d.ts.map +1 -0
- package/dist/components/ui/table.js +95 -0
- package/dist/components/ui/table.js.map +1 -0
- package/dist/components/ui/tabs.d.ts +20 -0
- package/dist/components/ui/tabs.d.ts.map +1 -0
- package/dist/components/ui/tabs.js +92 -0
- package/dist/components/ui/tabs.js.map +1 -0
- package/dist/components/ui/textarea.d.ts +12 -0
- package/dist/components/ui/textarea.d.ts.map +1 -0
- package/dist/components/ui/textarea.js +41 -0
- package/dist/components/ui/textarea.js.map +1 -0
- package/dist/components/ui/toast.d.ts +16 -0
- package/dist/components/ui/toast.d.ts.map +1 -0
- package/dist/components/ui/toast.js +113 -0
- package/dist/components/ui/toast.js.map +1 -0
- package/dist/components/ui/tooltip.d.ts +8 -0
- package/dist/components/ui/tooltip.d.ts.map +1 -0
- package/dist/components/ui/tooltip.js +28 -0
- package/dist/components/ui/tooltip.js.map +1 -0
- package/dist/hooks/use-debounce.d.ts +15 -0
- package/dist/hooks/use-debounce.d.ts.map +1 -0
- package/dist/hooks/use-debounce.js +15 -0
- package/dist/hooks/use-debounce.js.map +1 -0
- package/dist/hooks/use-local-storage.d.ts +9 -0
- package/dist/hooks/use-local-storage.d.ts.map +1 -0
- package/dist/hooks/use-local-storage.js +49 -0
- package/dist/hooks/use-local-storage.js.map +1 -0
- package/dist/hooks/use-media-query.d.ts +9 -0
- package/dist/hooks/use-media-query.d.ts.map +1 -0
- package/dist/hooks/use-media-query.js +20 -0
- package/dist/hooks/use-media-query.js.map +1 -0
- package/dist/index.d.ts +66 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +153 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/colors.d.ts +73 -0
- package/dist/lib/colors.d.ts.map +1 -0
- package/dist/lib/colors.js +64 -0
- package/dist/lib/colors.js.map +1 -0
- package/dist/lib/utils.d.ts +7 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +9 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/node_modules/@floating-ui/core/dist/floating-ui.core.js +729 -0
- package/dist/node_modules/@floating-ui/core/dist/floating-ui.core.js.map +1 -0
- package/dist/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +630 -0
- package/dist/node_modules/@floating-ui/dom/dist/floating-ui.dom.js.map +1 -0
- package/dist/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js +325 -0
- package/dist/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js.map +1 -0
- package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +177 -0
- package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js.map +1 -0
- package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +152 -0
- package/dist/node_modules/@floating-ui/utils/dist/floating-ui.utils.js.map +1 -0
- package/dist/node_modules/@radix-ui/number/dist/index.js +7 -0
- package/dist/node_modules/@radix-ui/number/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/primitive/dist/index.js +12 -0
- package/dist/node_modules/@radix-ui/primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-accordion/dist/index.js +319 -0
- package/dist/node_modules/@radix-ui/react-accordion/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-arrow/dist/index.js +26 -0
- package/dist/node_modules/@radix-ui/react-arrow/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-avatar/dist/index.js +124 -0
- package/dist/node_modules/@radix-ui/react-avatar/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.js +66 -0
- package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-checkbox/dist/index.js +280 -0
- package/dist/node_modules/@radix-ui/react-checkbox/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-collapsible/dist/index.js +152 -0
- package/dist/node_modules/@radix-ui/react-collapsible/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-collection/dist/index.js +71 -0
- package/dist/node_modules/@radix-ui/react-collection/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-collection/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-collection/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-compose-refs/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-compose-refs/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-context/dist/index.js +82 -0
- package/dist/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-dialog/dist/index.js +342 -0
- package/dist/node_modules/@radix-ui/react-dialog/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-direction/dist/index.js +11 -0
- package/dist/node_modules/@radix-ui/react-direction/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-dismissable-layer/dist/index.js +217 -0
- package/dist/node_modules/@radix-ui/react-dismissable-layer/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-dropdown-menu/dist/index.js +299 -0
- package/dist/node_modules/@radix-ui/react-dropdown-menu/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-focus-guards/dist/index.js +30 -0
- package/dist/node_modules/@radix-ui/react-focus-guards/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-focus-scope/dist/index.js +209 -0
- package/dist/node_modules/@radix-ui/react-focus-scope/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-id/dist/index.js +15 -0
- package/dist/node_modules/@radix-ui/react-id/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-label/dist/index.js +27 -0
- package/dist/node_modules/@radix-ui/react-label/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-label/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-label/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-menu/dist/index.js +881 -0
- package/dist/node_modules/@radix-ui/react-menu/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-popover/dist/index.js +314 -0
- package/dist/node_modules/@radix-ui/react-popover/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-popper/dist/index.js +294 -0
- package/dist/node_modules/@radix-ui/react-popper/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-portal/dist/index.js +19 -0
- package/dist/node_modules/@radix-ui/react-portal/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-presence/dist/index.js +130 -0
- package/dist/node_modules/@radix-ui/react-presence/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-primitive/dist/index.js +44 -0
- package/dist/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-progress/dist/index.js +97 -0
- package/dist/node_modules/@radix-ui/react-progress/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-context/dist/index.js +66 -0
- package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-context/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-roving-focus/dist/index.js +228 -0
- package/dist/node_modules/@radix-ui/react-roving-focus/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-scroll-area/dist/index.js +728 -0
- package/dist/node_modules/@radix-ui/react-scroll-area/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-select/dist/index.js +1200 -0
- package/dist/node_modules/@radix-ui/react-select/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-select/node_modules/@radix-ui/react-slot/dist/index.js +90 -0
- package/dist/node_modules/@radix-ui/react-select/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-separator/dist/index.js +31 -0
- package/dist/node_modules/@radix-ui/react-separator/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-separator/node_modules/@radix-ui/react-primitive/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-separator/node_modules/@radix-ui/react-primitive/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-slot/dist/index.js +107 -0
- package/dist/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-switch/dist/index.js +156 -0
- package/dist/node_modules/@radix-ui/react-switch/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-tabs/dist/index.js +195 -0
- package/dist/node_modules/@radix-ui/react-tabs/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-toast/dist/index.js +645 -0
- package/dist/node_modules/@radix-ui/react-toast/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-tooltip/dist/index.js +501 -0
- package/dist/node_modules/@radix-ui/react-tooltip/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.js +16 -0
- package/dist/node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-callback-ref/dist/index.js +15 -0
- package/dist/node_modules/@radix-ui/react-use-callback-ref/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-controllable-state/dist/index.js +72 -0
- package/dist/node_modules/@radix-ui/react-use-controllable-state/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-escape-keydown/dist/index.js +18 -0
- package/dist/node_modules/@radix-ui/react-use-escape-keydown/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-is-hydrated/dist/index.js +16 -0
- package/dist/node_modules/@radix-ui/react-use-is-hydrated/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-layout-effect/dist/index.js +7 -0
- package/dist/node_modules/@radix-ui/react-use-layout-effect/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-previous/dist/index.js +15 -0
- package/dist/node_modules/@radix-ui/react-use-previous/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-use-size/dist/index.js +40 -0
- package/dist/node_modules/@radix-ui/react-use-size/dist/index.js.map +1 -0
- package/dist/node_modules/@radix-ui/react-visually-hidden/dist/index.js +37 -0
- package/dist/node_modules/@radix-ui/react-visually-hidden/dist/index.js.map +1 -0
- package/dist/node_modules/aria-hidden/dist/es2015/index.js +123 -0
- package/dist/node_modules/aria-hidden/dist/es2015/index.js.map +1 -0
- package/dist/node_modules/class-variance-authority/dist/index.js +46 -0
- package/dist/node_modules/class-variance-authority/dist/index.js.map +1 -0
- package/dist/node_modules/clsx/dist/clsx.js +17 -0
- package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
- package/dist/node_modules/get-nonce/dist/es2015/index.js +10 -0
- package/dist/node_modules/get-nonce/dist/es2015/index.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/Icon.js +43 -0
- package/dist/node_modules/lucide-react/dist/esm/Icon.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.js +25 -0
- package/dist/node_modules/lucide-react/dist/esm/createLucideIcon.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.js +21 -0
- package/dist/node_modules/lucide-react/dist/esm/defaultAttributes.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/ban.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/ban.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/calendar.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/calendar.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/check.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/check.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-down.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-left.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-right.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-up.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/chevron-up.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-alert.js +16 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-alert.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-check.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-minus.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-minus.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.js +16 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle-x.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/circle.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/clock.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/clock.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/flag.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/flag.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/git-branch.js +17 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/git-branch.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/info.js +16 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/info.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/loader-circle.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/minus.js +12 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/minus.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/pause.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/pause.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/play.js +14 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/play.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/send.js +21 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/send.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/tag.js +21 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/tag.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/timer.js +16 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/timer.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/trending-down.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/trending-down.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/trending-up.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/trending-up.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.js +22 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/triangle-alert.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/x.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/x.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/zap.js +20 -0
- package/dist/node_modules/lucide-react/dist/esm/icons/zap.js.map +1 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils.js +15 -0
- package/dist/node_modules/lucide-react/dist/esm/shared/src/utils.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/Combination.js +12 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/Combination.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/SideEffect.js +181 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/SideEffect.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/UI.js +39 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/UI.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js +20 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/handleScroll.js +103 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/handleScroll.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/medium.js +6 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/medium.js.map +1 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/sidecar.js +8 -0
- package/dist/node_modules/react-remove-scroll/dist/es2015/sidecar.js.map +1 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/component.js +48 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/component.js.map +1 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/constants.js +11 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/constants.js.map +1 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/utils.js +38 -0
- package/dist/node_modules/react-remove-scroll-bar/dist/es2015/utils.js.map +1 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/component.js +14 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/component.js.map +1 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/hook.js +17 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/hook.js.map +1 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/singleton.js +49 -0
- package/dist/node_modules/react-style-singleton/dist/es2015/singleton.js.map +1 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js +2467 -0
- package/dist/node_modules/tailwind-merge/dist/bundle-mjs.js.map +1 -0
- package/dist/node_modules/tslib/tslib.es6.js +40 -0
- package/dist/node_modules/tslib/tslib.es6.js.map +1 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/assignRef.js +12 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/assignRef.js.map +1 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/useMergeRef.js +36 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/useMergeRef.js.map +1 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/useRef.js +30 -0
- package/dist/node_modules/use-callback-ref/dist/es2015/useRef.js.map +1 -0
- package/dist/node_modules/use-sidecar/dist/es2015/exports.js +22 -0
- package/dist/node_modules/use-sidecar/dist/es2015/exports.js.map +1 -0
- package/dist/node_modules/use-sidecar/dist/es2015/medium.js +89 -0
- package/dist/node_modules/use-sidecar/dist/es2015/medium.js.map +1 -0
- package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js +78 -0
- package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js.map +1 -0
- package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js +63 -0
- package/dist/node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js.map +1 -0
- package/dist/node_modules/use-sync-external-store/shim/index.js +18 -0
- package/dist/node_modules/use-sync-external-store/shim/index.js.map +1 -0
- package/dist/types/automation.d.ts +59 -0
- package/dist/types/automation.d.ts.map +1 -0
- package/dist/types/common.d.ts +38 -0
- package/dist/types/common.d.ts.map +1 -0
- package/package.json +119 -0
- package/registry/registry.json +218 -0
- package/src/components/automation/metric-card.tsx +113 -0
- package/src/components/automation/status-badge.tsx +136 -0
- package/src/components/automation/task-card.tsx +164 -0
- package/src/components/automation/workflow-node.tsx +186 -0
- package/src/components/layout/app-shell.tsx +58 -0
- package/src/components/layout/header.tsx +39 -0
- package/src/components/layout/page-header.tsx +42 -0
- package/src/components/layout/sidebar.tsx +190 -0
- package/src/components/ui/accordion.tsx +57 -0
- package/src/components/ui/alert.tsx +93 -0
- package/src/components/ui/avatar.tsx +94 -0
- package/src/components/ui/badge.tsx +69 -0
- package/src/components/ui/button.tsx +106 -0
- package/src/components/ui/card.tsx +96 -0
- package/src/components/ui/checkbox.tsx +40 -0
- package/src/components/ui/dialog.tsx +129 -0
- package/src/components/ui/dropdown-menu.tsx +194 -0
- package/src/components/ui/input.tsx +80 -0
- package/src/components/ui/label.tsx +37 -0
- package/src/components/ui/popover.tsx +29 -0
- package/src/components/ui/progress.tsx +92 -0
- package/src/components/ui/scroll-area.tsx +43 -0
- package/src/components/ui/select.tsx +157 -0
- package/src/components/ui/separator.tsx +56 -0
- package/src/components/ui/skeleton.tsx +41 -0
- package/src/components/ui/spinner.tsx +50 -0
- package/src/components/ui/switch.tsx +46 -0
- package/src/components/ui/table.tsx +117 -0
- package/src/components/ui/tabs.tsx +107 -0
- package/src/components/ui/textarea.tsx +50 -0
- package/src/components/ui/toast.tsx +139 -0
- package/src/components/ui/tooltip.tsx +28 -0
- package/src/hooks/use-debounce.ts +28 -0
- package/src/hooks/use-local-storage.ts +63 -0
- package/src/hooks/use-media-query.ts +29 -0
- package/src/index.ts +197 -0
- package/src/lib/colors.ts +102 -0
- package/src/lib/utils.ts +10 -0
- package/src/styles/globals.css +230 -0
- package/src/types/automation.ts +74 -0
- package/src/types/common.ts +48 -0
- package/tailwind/preset.cjs +98 -0
- package/tailwind/preset.css +5 -0
- package/tailwind/preset.ts +159 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils.js";
|
|
3
|
+
import { Card, CardContent } from "../ui/card.js";
|
|
4
|
+
import { Avatar, AvatarImage, AvatarFallback } from "../ui/avatar.js";
|
|
5
|
+
import { Badge } from "../ui/badge.js";
|
|
6
|
+
import { StatusBadge } from "./status-badge.js";
|
|
7
|
+
import Flag from "../../node_modules/lucide-react/dist/esm/icons/flag.js";
|
|
8
|
+
import Calendar from "../../node_modules/lucide-react/dist/esm/icons/calendar.js";
|
|
9
|
+
import Tag from "../../node_modules/lucide-react/dist/esm/icons/tag.js";
|
|
10
|
+
const PRIORITY_CONFIG = {
|
|
11
|
+
critical: { label: "Critical", color: "text-destructive", dotClass: "bg-destructive" },
|
|
12
|
+
high: { label: "High", color: "text-warning", dotClass: "bg-warning" },
|
|
13
|
+
medium: { label: "Medium", color: "text-info", dotClass: "bg-info" },
|
|
14
|
+
low: { label: "Low", color: "text-muted-foreground", dotClass: "bg-muted-foreground" }
|
|
15
|
+
};
|
|
16
|
+
const TASK_TO_WORKFLOW_STATUS = {
|
|
17
|
+
running: "running",
|
|
18
|
+
completed: "completed",
|
|
19
|
+
failed: "failed",
|
|
20
|
+
pending: "pending",
|
|
21
|
+
skipped: "cancelled",
|
|
22
|
+
cancelled: "cancelled"
|
|
23
|
+
};
|
|
24
|
+
function TaskCard({
|
|
25
|
+
className,
|
|
26
|
+
task,
|
|
27
|
+
showPriority = true,
|
|
28
|
+
onSelect,
|
|
29
|
+
compact = false,
|
|
30
|
+
...props
|
|
31
|
+
}) {
|
|
32
|
+
const priority = PRIORITY_CONFIG[task.priority];
|
|
33
|
+
const workflowStatus = TASK_TO_WORKFLOW_STATUS[task.status];
|
|
34
|
+
const formattedDue = task.dueAt ? new Date(task.dueAt).toLocaleDateString("en-US", { month: "short", day: "numeric" }) : null;
|
|
35
|
+
const isOverdue = task.dueAt && task.status !== "completed" && task.status !== "cancelled" && new Date(task.dueAt) < /* @__PURE__ */ new Date();
|
|
36
|
+
if (compact) {
|
|
37
|
+
return /* @__PURE__ */ jsxs(
|
|
38
|
+
"div",
|
|
39
|
+
{
|
|
40
|
+
className: cn(
|
|
41
|
+
"flex items-center gap-3 py-2 px-3 rounded-md hover:bg-muted/50 transition-colors",
|
|
42
|
+
onSelect && "cursor-pointer",
|
|
43
|
+
className
|
|
44
|
+
),
|
|
45
|
+
onClick: () => onSelect == null ? void 0 : onSelect(task),
|
|
46
|
+
...props,
|
|
47
|
+
children: [
|
|
48
|
+
/* @__PURE__ */ jsx(StatusBadge, { status: workflowStatus, size: "xs" }),
|
|
49
|
+
/* @__PURE__ */ jsx("span", { className: "flex-1 text-sm truncate", children: task.title }),
|
|
50
|
+
task.assignee && /* @__PURE__ */ jsxs(Avatar, { size: "xs", children: [
|
|
51
|
+
task.assignee.avatarUrl && /* @__PURE__ */ jsx(AvatarImage, { src: task.assignee.avatarUrl, alt: task.assignee.name }),
|
|
52
|
+
/* @__PURE__ */ jsx(AvatarFallback, { children: task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase() })
|
|
53
|
+
] })
|
|
54
|
+
]
|
|
55
|
+
}
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
return /* @__PURE__ */ jsx(
|
|
59
|
+
Card,
|
|
60
|
+
{
|
|
61
|
+
className: cn(
|
|
62
|
+
"transition-all duration-200",
|
|
63
|
+
onSelect && "cursor-pointer hover:border-primary/40 hover:shadow-glow-primary",
|
|
64
|
+
className
|
|
65
|
+
),
|
|
66
|
+
onClick: () => onSelect == null ? void 0 : onSelect(task),
|
|
67
|
+
...props,
|
|
68
|
+
children: /* @__PURE__ */ jsx(CardContent, { className: "p-4", children: /* @__PURE__ */ jsxs("div", { className: "flex items-start justify-between gap-3", children: [
|
|
69
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
70
|
+
/* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2 flex-wrap", children: [
|
|
71
|
+
/* @__PURE__ */ jsx("h4", { className: cn(
|
|
72
|
+
"text-sm font-medium leading-tight",
|
|
73
|
+
task.status === "completed" && "line-through text-muted-foreground"
|
|
74
|
+
), children: task.title }),
|
|
75
|
+
/* @__PURE__ */ jsx(StatusBadge, { status: workflowStatus, size: "xs" })
|
|
76
|
+
] }),
|
|
77
|
+
task.description && /* @__PURE__ */ jsx("p", { className: "mt-1 text-xs text-muted-foreground line-clamp-2", children: task.description }),
|
|
78
|
+
/* @__PURE__ */ jsxs("div", { className: "mt-3 flex flex-wrap items-center gap-3", children: [
|
|
79
|
+
showPriority && /* @__PURE__ */ jsxs("div", { className: cn("flex items-center gap-1 text-xs font-medium", priority.color), children: [
|
|
80
|
+
/* @__PURE__ */ jsx(Flag, { className: "h-3 w-3" }),
|
|
81
|
+
priority.label
|
|
82
|
+
] }),
|
|
83
|
+
formattedDue && /* @__PURE__ */ jsxs("div", { className: cn(
|
|
84
|
+
"flex items-center gap-1 text-xs",
|
|
85
|
+
isOverdue ? "text-destructive font-medium" : "text-muted-foreground"
|
|
86
|
+
), children: [
|
|
87
|
+
/* @__PURE__ */ jsx(Calendar, { className: "h-3 w-3" }),
|
|
88
|
+
isOverdue && "Overdue · ",
|
|
89
|
+
formattedDue
|
|
90
|
+
] }),
|
|
91
|
+
task.tags && task.tags.length > 0 && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
|
|
92
|
+
/* @__PURE__ */ jsx(Tag, { className: "h-3 w-3 text-muted-foreground" }),
|
|
93
|
+
/* @__PURE__ */ jsxs("div", { className: "flex gap-1 flex-wrap", children: [
|
|
94
|
+
task.tags.slice(0, 3).map((tag) => /* @__PURE__ */ jsx(Badge, { variant: "muted", size: "sm", children: tag }, tag)),
|
|
95
|
+
task.tags.length > 3 && /* @__PURE__ */ jsxs(Badge, { variant: "muted", size: "sm", children: [
|
|
96
|
+
"+",
|
|
97
|
+
task.tags.length - 3
|
|
98
|
+
] })
|
|
99
|
+
] })
|
|
100
|
+
] })
|
|
101
|
+
] })
|
|
102
|
+
] }),
|
|
103
|
+
task.assignee && /* @__PURE__ */ jsxs(Avatar, { size: "sm", children: [
|
|
104
|
+
task.assignee.avatarUrl && /* @__PURE__ */ jsx(AvatarImage, { src: task.assignee.avatarUrl, alt: task.assignee.name }),
|
|
105
|
+
/* @__PURE__ */ jsx(AvatarFallback, { children: task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase() })
|
|
106
|
+
] })
|
|
107
|
+
] }) })
|
|
108
|
+
}
|
|
109
|
+
);
|
|
110
|
+
}
|
|
111
|
+
export {
|
|
112
|
+
TaskCard
|
|
113
|
+
};
|
|
114
|
+
//# sourceMappingURL=task-card.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-card.js","sources":["../../../src/components/automation/task-card.tsx"],"sourcesContent":["import * as React from 'react'\nimport { Calendar, Flag, Tag } from 'lucide-react'\nimport { cn } from '@/lib/utils'\nimport { Card, CardContent } from '@/components/ui/card'\nimport { Avatar, AvatarFallback, AvatarImage } from '@/components/ui/avatar'\nimport { Badge } from '@/components/ui/badge'\nimport { StatusBadge } from './status-badge'\nimport type { Task, TaskPriority } from '@/types/automation'\n\nconst PRIORITY_CONFIG: Record<TaskPriority, { label: string; color: string; dotClass: string }> = {\n critical: { label: 'Critical', color: 'text-destructive', dotClass: 'bg-destructive' },\n high: { label: 'High', color: 'text-warning', dotClass: 'bg-warning' },\n medium: { label: 'Medium', color: 'text-info', dotClass: 'bg-info' },\n low: { label: 'Low', color: 'text-muted-foreground', dotClass: 'bg-muted-foreground' },\n}\n\n// Map TaskStatus to WorkflowStatus for the StatusBadge\nconst TASK_TO_WORKFLOW_STATUS = {\n running: 'running',\n completed: 'completed',\n failed: 'failed',\n pending: 'pending',\n skipped: 'cancelled',\n cancelled: 'cancelled',\n} as const\n\nexport interface TaskCardProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> {\n task: Task\n /** Show/hide priority indicator */\n showPriority?: boolean\n /** Called when card is clicked */\n onSelect?: (task: Task) => void\n /** Compact single-line mode */\n compact?: boolean\n}\n\nfunction TaskCard({\n className,\n task,\n showPriority = true,\n onSelect,\n compact = false,\n ...props\n}: TaskCardProps) {\n const priority = PRIORITY_CONFIG[task.priority]\n const workflowStatus = TASK_TO_WORKFLOW_STATUS[task.status]\n\n const formattedDue = task.dueAt\n ? new Date(task.dueAt).toLocaleDateString('en-US', { month: 'short', day: 'numeric' })\n : null\n\n const isOverdue =\n task.dueAt &&\n task.status !== 'completed' &&\n task.status !== 'cancelled' &&\n new Date(task.dueAt) < new Date()\n\n if (compact) {\n return (\n <div\n className={cn(\n 'flex items-center gap-3 py-2 px-3 rounded-md hover:bg-muted/50 transition-colors',\n onSelect && 'cursor-pointer',\n className\n )}\n onClick={() => onSelect?.(task)}\n {...props}\n >\n <StatusBadge status={workflowStatus} size=\"xs\" />\n <span className=\"flex-1 text-sm truncate\">{task.title}</span>\n {task.assignee && (\n <Avatar size=\"xs\">\n {task.assignee.avatarUrl && <AvatarImage src={task.assignee.avatarUrl} alt={task.assignee.name} />}\n <AvatarFallback>{task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase()}</AvatarFallback>\n </Avatar>\n )}\n </div>\n )\n }\n\n return (\n <Card\n className={cn(\n 'transition-all duration-200',\n onSelect && 'cursor-pointer hover:border-primary/40 hover:shadow-glow-primary',\n className\n )}\n onClick={() => onSelect?.(task)}\n {...props}\n >\n <CardContent className=\"p-4\">\n <div className=\"flex items-start justify-between gap-3\">\n <div className=\"flex-1 min-w-0\">\n {/* Title + status */}\n <div className=\"flex items-center gap-2 flex-wrap\">\n <h4 className={cn(\n 'text-sm font-medium leading-tight',\n task.status === 'completed' && 'line-through text-muted-foreground'\n )}>\n {task.title}\n </h4>\n <StatusBadge status={workflowStatus} size=\"xs\" />\n </div>\n\n {task.description && (\n <p className=\"mt-1 text-xs text-muted-foreground line-clamp-2\">{task.description}</p>\n )}\n\n {/* Meta row */}\n <div className=\"mt-3 flex flex-wrap items-center gap-3\">\n {showPriority && (\n <div className={cn('flex items-center gap-1 text-xs font-medium', priority.color)}>\n <Flag className=\"h-3 w-3\" />\n {priority.label}\n </div>\n )}\n\n {formattedDue && (\n <div className={cn(\n 'flex items-center gap-1 text-xs',\n isOverdue ? 'text-destructive font-medium' : 'text-muted-foreground'\n )}>\n <Calendar className=\"h-3 w-3\" />\n {isOverdue && 'Overdue · '}\n {formattedDue}\n </div>\n )}\n\n {task.tags && task.tags.length > 0 && (\n <div className=\"flex items-center gap-1\">\n <Tag className=\"h-3 w-3 text-muted-foreground\" />\n <div className=\"flex gap-1 flex-wrap\">\n {task.tags.slice(0, 3).map((tag) => (\n <Badge key={tag} variant=\"muted\" size=\"sm\">\n {tag}\n </Badge>\n ))}\n {task.tags.length > 3 && (\n <Badge variant=\"muted\" size=\"sm\">+{task.tags.length - 3}</Badge>\n )}\n </div>\n </div>\n )}\n </div>\n </div>\n\n {/* Assignee */}\n {task.assignee && (\n <Avatar size=\"sm\">\n {task.assignee.avatarUrl && (\n <AvatarImage src={task.assignee.avatarUrl} alt={task.assignee.name} />\n )}\n <AvatarFallback>\n {task.assignee.initials ?? task.assignee.name.slice(0, 2).toUpperCase()}\n </AvatarFallback>\n </Avatar>\n )}\n </div>\n </CardContent>\n </Card>\n )\n}\n\nexport { TaskCard }\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { WorkflowNodeData } from '../../types/automation';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
export interface WorkflowNodeProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
4
|
+
node: WorkflowNodeData;
|
|
5
|
+
/** Show as a compact inline node */
|
|
6
|
+
compact?: boolean;
|
|
7
|
+
/** Whether to show the connector line below */
|
|
8
|
+
showConnector?: boolean;
|
|
9
|
+
/** Whether this is the last node in the chain */
|
|
10
|
+
isLast?: boolean;
|
|
11
|
+
}
|
|
12
|
+
declare function WorkflowNode({ className, node, compact, showConnector, isLast, ...props }: WorkflowNodeProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
/** Renders a vertical workflow pipeline from an array of nodes */
|
|
14
|
+
export interface WorkflowPipelineProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
15
|
+
nodes: WorkflowNodeData[];
|
|
16
|
+
compact?: boolean;
|
|
17
|
+
}
|
|
18
|
+
declare function WorkflowPipeline({ className, nodes, compact, ...props }: WorkflowPipelineProps): import("react/jsx-runtime").JSX.Element;
|
|
19
|
+
export { WorkflowNode, WorkflowPipeline };
|
|
20
|
+
//# sourceMappingURL=workflow-node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-node.d.ts","sourceRoot":"","sources":["../../../src/components/automation/workflow-node.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAc9B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AA8C1D,MAAM,WAAW,iBAAkB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC7E,IAAI,EAAE,gBAAgB,CAAA;IACtB,oCAAoC;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,+CAA+C;IAC/C,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,iDAAiD;IACjD,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB;AAED,iBAAS,YAAY,CAAC,EACpB,SAAS,EACT,IAAI,EACJ,OAAe,EACf,aAAqB,EACrB,MAAc,EACd,GAAG,KAAK,EACT,EAAE,iBAAiB,2CAoFnB;AAED,kEAAkE;AAClE,MAAM,WAAW,qBAAsB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACjF,KAAK,EAAE,gBAAgB,EAAE,CAAA;IACzB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,iBAAS,gBAAgB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,OAAe,EAAE,GAAG,KAAK,EAAE,EAAE,qBAAqB,2CAc/F;AAED,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,CAAA"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { jsxs, jsx, Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils.js";
|
|
3
|
+
import Send from "../../node_modules/lucide-react/dist/esm/icons/send.js";
|
|
4
|
+
import Timer from "../../node_modules/lucide-react/dist/esm/icons/timer.js";
|
|
5
|
+
import GitBranch from "../../node_modules/lucide-react/dist/esm/icons/git-branch.js";
|
|
6
|
+
import Play from "../../node_modules/lucide-react/dist/esm/icons/play.js";
|
|
7
|
+
import Zap from "../../node_modules/lucide-react/dist/esm/icons/zap.js";
|
|
8
|
+
import Clock from "../../node_modules/lucide-react/dist/esm/icons/clock.js";
|
|
9
|
+
import CircleAlert from "../../node_modules/lucide-react/dist/esm/icons/circle-alert.js";
|
|
10
|
+
import Pause from "../../node_modules/lucide-react/dist/esm/icons/pause.js";
|
|
11
|
+
import CircleCheck from "../../node_modules/lucide-react/dist/esm/icons/circle-check.js";
|
|
12
|
+
import LoaderCircle from "../../node_modules/lucide-react/dist/esm/icons/loader-circle.js";
|
|
13
|
+
const NODE_TYPE_CONFIG = {
|
|
14
|
+
trigger: {
|
|
15
|
+
icon: Zap,
|
|
16
|
+
label: "Trigger",
|
|
17
|
+
className: "border-primary/50 bg-primary/10 text-primary",
|
|
18
|
+
headerClass: "bg-primary/10"
|
|
19
|
+
},
|
|
20
|
+
action: {
|
|
21
|
+
icon: Play,
|
|
22
|
+
label: "Action",
|
|
23
|
+
className: "border-border bg-card text-foreground",
|
|
24
|
+
headerClass: "bg-muted"
|
|
25
|
+
},
|
|
26
|
+
condition: {
|
|
27
|
+
icon: GitBranch,
|
|
28
|
+
label: "Condition",
|
|
29
|
+
className: "border-info/50 bg-info/10 text-foreground",
|
|
30
|
+
headerClass: "bg-info/10"
|
|
31
|
+
},
|
|
32
|
+
delay: {
|
|
33
|
+
icon: Timer,
|
|
34
|
+
label: "Delay",
|
|
35
|
+
className: "border-warning/50 bg-warning/10 text-foreground",
|
|
36
|
+
headerClass: "bg-warning/10"
|
|
37
|
+
},
|
|
38
|
+
output: {
|
|
39
|
+
icon: Send,
|
|
40
|
+
label: "Output",
|
|
41
|
+
className: "border-success/50 bg-success/10 text-foreground",
|
|
42
|
+
headerClass: "bg-success/10"
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
const STATUS_INDICATOR = {
|
|
46
|
+
running: { icon: LoaderCircle, className: "text-workflow-running animate-spin" },
|
|
47
|
+
completed: { icon: CircleCheck, className: "text-workflow-completed" },
|
|
48
|
+
failed: { icon: CircleAlert, className: "text-workflow-failed" },
|
|
49
|
+
pending: { icon: Clock, className: "text-workflow-pending" },
|
|
50
|
+
paused: { icon: Pause, className: "text-workflow-paused" },
|
|
51
|
+
cancelled: { icon: CircleAlert, className: "text-workflow-cancelled" },
|
|
52
|
+
idle: { icon: Clock, className: "text-muted-foreground" },
|
|
53
|
+
scheduled: { icon: Clock, className: "text-info" }
|
|
54
|
+
};
|
|
55
|
+
function WorkflowNode({
|
|
56
|
+
className,
|
|
57
|
+
node,
|
|
58
|
+
compact = false,
|
|
59
|
+
showConnector = false,
|
|
60
|
+
isLast = false,
|
|
61
|
+
...props
|
|
62
|
+
}) {
|
|
63
|
+
const typeConfig = NODE_TYPE_CONFIG[node.type];
|
|
64
|
+
const statusIndicator = STATUS_INDICATOR[node.status];
|
|
65
|
+
const TypeIcon = typeConfig.icon;
|
|
66
|
+
const StatusIcon = statusIndicator.icon;
|
|
67
|
+
const formatDuration = (ms) => {
|
|
68
|
+
if (ms < 1e3) return `${ms}ms`;
|
|
69
|
+
if (ms < 6e4) return `${(ms / 1e3).toFixed(1)}s`;
|
|
70
|
+
return `${Math.floor(ms / 6e4)}m ${Math.floor(ms % 6e4 / 1e3)}s`;
|
|
71
|
+
};
|
|
72
|
+
return /* @__PURE__ */ jsxs("div", { className: "relative flex flex-col items-center", children: [
|
|
73
|
+
/* @__PURE__ */ jsx(
|
|
74
|
+
"div",
|
|
75
|
+
{
|
|
76
|
+
className: cn(
|
|
77
|
+
"w-full rounded-lg border transition-all duration-200",
|
|
78
|
+
typeConfig.className,
|
|
79
|
+
node.status === "running" && "shadow-glow-primary animate-workflow-pulse",
|
|
80
|
+
node.status === "failed" && "border-workflow-failed/60",
|
|
81
|
+
compact ? "p-3" : "overflow-hidden",
|
|
82
|
+
className
|
|
83
|
+
),
|
|
84
|
+
...props,
|
|
85
|
+
children: compact ? /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
|
|
86
|
+
/* @__PURE__ */ jsx("div", { className: cn("flex h-6 w-6 shrink-0 items-center justify-center rounded", typeConfig.headerClass), children: /* @__PURE__ */ jsx(TypeIcon, { className: "h-3.5 w-3.5" }) }),
|
|
87
|
+
/* @__PURE__ */ jsx("span", { className: "flex-1 text-sm font-medium truncate", children: node.label }),
|
|
88
|
+
/* @__PURE__ */ jsx(StatusIcon, { className: cn("h-4 w-4 shrink-0", statusIndicator.className) })
|
|
89
|
+
] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
90
|
+
/* @__PURE__ */ jsxs("div", { className: cn("flex items-center gap-2.5 px-3 py-2.5", typeConfig.headerClass), children: [
|
|
91
|
+
/* @__PURE__ */ jsx("div", { className: "flex h-7 w-7 shrink-0 items-center justify-center rounded-md bg-background/50", children: /* @__PURE__ */ jsx(TypeIcon, { className: "h-4 w-4" }) }),
|
|
92
|
+
/* @__PURE__ */ jsxs("div", { className: "flex-1 min-w-0", children: [
|
|
93
|
+
/* @__PURE__ */ jsx("div", { className: "flex items-center gap-1.5", children: /* @__PURE__ */ jsx("span", { className: "text-[10px] font-semibold uppercase tracking-wider opacity-70", children: typeConfig.label }) }),
|
|
94
|
+
/* @__PURE__ */ jsx("p", { className: "text-sm font-semibold leading-tight truncate", children: node.label })
|
|
95
|
+
] }),
|
|
96
|
+
/* @__PURE__ */ jsx(StatusIcon, { className: cn("h-4 w-4 shrink-0", statusIndicator.className) })
|
|
97
|
+
] }),
|
|
98
|
+
(node.description || node.error || node.duration !== void 0) && /* @__PURE__ */ jsxs("div", { className: "px-3 py-2.5 space-y-1.5", children: [
|
|
99
|
+
node.description && /* @__PURE__ */ jsx("p", { className: "text-xs text-muted-foreground", children: node.description }),
|
|
100
|
+
node.error && /* @__PURE__ */ jsx("p", { className: "text-xs text-destructive font-mono bg-destructive/5 rounded px-2 py-1", children: node.error }),
|
|
101
|
+
node.duration !== void 0 && /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 text-[10px] text-muted-foreground", children: [
|
|
102
|
+
/* @__PURE__ */ jsx(Clock, { className: "h-3 w-3" }),
|
|
103
|
+
/* @__PURE__ */ jsx("span", { children: formatDuration(node.duration) })
|
|
104
|
+
] })
|
|
105
|
+
] })
|
|
106
|
+
] })
|
|
107
|
+
}
|
|
108
|
+
),
|
|
109
|
+
showConnector && !isLast && /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center my-1", children: [
|
|
110
|
+
/* @__PURE__ */ jsx("div", { className: "w-px h-4 bg-border" }),
|
|
111
|
+
/* @__PURE__ */ jsx("div", { className: "w-1.5 h-1.5 rounded-full bg-border" }),
|
|
112
|
+
/* @__PURE__ */ jsx("div", { className: "w-px h-4 bg-border" })
|
|
113
|
+
] })
|
|
114
|
+
] });
|
|
115
|
+
}
|
|
116
|
+
function WorkflowPipeline({ className, nodes, compact = false, ...props }) {
|
|
117
|
+
return /* @__PURE__ */ jsx("div", { className: cn("flex flex-col", className), ...props, children: nodes.map((node, i) => /* @__PURE__ */ jsx(
|
|
118
|
+
WorkflowNode,
|
|
119
|
+
{
|
|
120
|
+
node,
|
|
121
|
+
compact,
|
|
122
|
+
showConnector: true,
|
|
123
|
+
isLast: i === nodes.length - 1
|
|
124
|
+
},
|
|
125
|
+
node.id
|
|
126
|
+
)) });
|
|
127
|
+
}
|
|
128
|
+
export {
|
|
129
|
+
WorkflowNode,
|
|
130
|
+
WorkflowPipeline
|
|
131
|
+
};
|
|
132
|
+
//# sourceMappingURL=workflow-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-node.js","sources":["../../../src/components/automation/workflow-node.tsx"],"sourcesContent":["import * as React from 'react'\nimport {\n Zap,\n Play,\n GitBranch,\n Timer,\n Send,\n AlertCircle,\n CheckCircle2,\n Loader2,\n Clock,\n Pause,\n} from 'lucide-react'\nimport { cn } from '@/lib/utils'\nimport type { WorkflowNodeData } from '@/types/automation'\n\nconst NODE_TYPE_CONFIG = {\n trigger: {\n icon: Zap,\n label: 'Trigger',\n className: 'border-primary/50 bg-primary/10 text-primary',\n headerClass: 'bg-primary/10',\n },\n action: {\n icon: Play,\n label: 'Action',\n className: 'border-border bg-card text-foreground',\n headerClass: 'bg-muted',\n },\n condition: {\n icon: GitBranch,\n label: 'Condition',\n className: 'border-info/50 bg-info/10 text-foreground',\n headerClass: 'bg-info/10',\n },\n delay: {\n icon: Timer,\n label: 'Delay',\n className: 'border-warning/50 bg-warning/10 text-foreground',\n headerClass: 'bg-warning/10',\n },\n output: {\n icon: Send,\n label: 'Output',\n className: 'border-success/50 bg-success/10 text-foreground',\n headerClass: 'bg-success/10',\n },\n}\n\nconst STATUS_INDICATOR = {\n running: { icon: Loader2, className: 'text-workflow-running animate-spin' },\n completed: { icon: CheckCircle2, className: 'text-workflow-completed' },\n failed: { icon: AlertCircle, className: 'text-workflow-failed' },\n pending: { icon: Clock, className: 'text-workflow-pending' },\n paused: { icon: Pause, className: 'text-workflow-paused' },\n cancelled: { icon: AlertCircle, className: 'text-workflow-cancelled' },\n idle: { icon: Clock, className: 'text-muted-foreground' },\n scheduled: { icon: Clock, className: 'text-info' },\n}\n\nexport interface WorkflowNodeProps extends React.HTMLAttributes<HTMLDivElement> {\n node: WorkflowNodeData\n /** Show as a compact inline node */\n compact?: boolean\n /** Whether to show the connector line below */\n showConnector?: boolean\n /** Whether this is the last node in the chain */\n isLast?: boolean\n}\n\nfunction WorkflowNode({\n className,\n node,\n compact = false,\n showConnector = false,\n isLast = false,\n ...props\n}: WorkflowNodeProps) {\n const typeConfig = NODE_TYPE_CONFIG[node.type]\n const statusIndicator = STATUS_INDICATOR[node.status]\n const TypeIcon = typeConfig.icon\n const StatusIcon = statusIndicator.icon\n\n const formatDuration = (ms: number) => {\n if (ms < 1000) return `${ms}ms`\n if (ms < 60000) return `${(ms / 1000).toFixed(1)}s`\n return `${Math.floor(ms / 60000)}m ${Math.floor((ms % 60000) / 1000)}s`\n }\n\n return (\n <div className=\"relative flex flex-col items-center\">\n <div\n className={cn(\n 'w-full rounded-lg border transition-all duration-200',\n typeConfig.className,\n node.status === 'running' && 'shadow-glow-primary animate-workflow-pulse',\n node.status === 'failed' && 'border-workflow-failed/60',\n compact ? 'p-3' : 'overflow-hidden',\n className\n )}\n {...props}\n >\n {compact ? (\n <div className=\"flex items-center gap-2\">\n <div className={cn('flex h-6 w-6 shrink-0 items-center justify-center rounded', typeConfig.headerClass)}>\n <TypeIcon className=\"h-3.5 w-3.5\" />\n </div>\n <span className=\"flex-1 text-sm font-medium truncate\">{node.label}</span>\n <StatusIcon className={cn('h-4 w-4 shrink-0', statusIndicator.className)} />\n </div>\n ) : (\n <>\n {/* Node header */}\n <div className={cn('flex items-center gap-2.5 px-3 py-2.5', typeConfig.headerClass)}>\n <div className=\"flex h-7 w-7 shrink-0 items-center justify-center rounded-md bg-background/50\">\n <TypeIcon className=\"h-4 w-4\" />\n </div>\n <div className=\"flex-1 min-w-0\">\n <div className=\"flex items-center gap-1.5\">\n <span className=\"text-[10px] font-semibold uppercase tracking-wider opacity-70\">\n {typeConfig.label}\n </span>\n </div>\n <p className=\"text-sm font-semibold leading-tight truncate\">{node.label}</p>\n </div>\n <StatusIcon className={cn('h-4 w-4 shrink-0', statusIndicator.className)} />\n </div>\n\n {/* Node body */}\n {(node.description || node.error || node.duration !== undefined) && (\n <div className=\"px-3 py-2.5 space-y-1.5\">\n {node.description && (\n <p className=\"text-xs text-muted-foreground\">{node.description}</p>\n )}\n {node.error && (\n <p className=\"text-xs text-destructive font-mono bg-destructive/5 rounded px-2 py-1\">\n {node.error}\n </p>\n )}\n {node.duration !== undefined && (\n <div className=\"flex items-center gap-1 text-[10px] text-muted-foreground\">\n <Clock className=\"h-3 w-3\" />\n <span>{formatDuration(node.duration)}</span>\n </div>\n )}\n </div>\n )}\n </>\n )}\n </div>\n\n {/* Connector line */}\n {showConnector && !isLast && (\n <div className=\"flex flex-col items-center my-1\">\n <div className=\"w-px h-4 bg-border\" />\n <div className=\"w-1.5 h-1.5 rounded-full bg-border\" />\n <div className=\"w-px h-4 bg-border\" />\n </div>\n )}\n </div>\n )\n}\n\n/** Renders a vertical workflow pipeline from an array of nodes */\nexport interface WorkflowPipelineProps extends React.HTMLAttributes<HTMLDivElement> {\n nodes: WorkflowNodeData[]\n compact?: boolean\n}\n\nfunction WorkflowPipeline({ className, nodes, compact = false, ...props }: WorkflowPipelineProps) {\n return (\n <div className={cn('flex flex-col', className)} {...props}>\n {nodes.map((node, i) => (\n <WorkflowNode\n key={node.id}\n node={node}\n compact={compact}\n showConnector\n isLast={i === nodes.length - 1}\n />\n ))}\n </div>\n )\n}\n\nexport { WorkflowNode, WorkflowPipeline }\n"],"names":["Loader2","CheckCircle2","AlertCircle"],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface AppShellProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
3
|
+
/** The sidebar component */
|
|
4
|
+
sidebar?: React.ReactNode;
|
|
5
|
+
/** The top header component */
|
|
6
|
+
header?: React.ReactNode;
|
|
7
|
+
/** Main content */
|
|
8
|
+
children: React.ReactNode;
|
|
9
|
+
/** Whether the sidebar is currently shown (for mobile overlay handling) */
|
|
10
|
+
sidebarOpen?: boolean;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* AppShell provides the top-level layout structure:
|
|
14
|
+
* - Sidebar (left)
|
|
15
|
+
* - Main area (header + content)
|
|
16
|
+
*/
|
|
17
|
+
declare function AppShell({ className, sidebar, header, children, sidebarOpen, ...props }: AppShellProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
/** Content wrapper with standard page padding */
|
|
19
|
+
declare function PageContent({ className, children, ...props }: React.HTMLAttributes<HTMLDivElement>): import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
export { AppShell, PageContent };
|
|
21
|
+
//# sourceMappingURL=app-shell.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-shell.d.ts","sourceRoot":"","sources":["../../../src/components/layout/app-shell.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,aAAc,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,4BAA4B;IAC5B,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,+BAA+B;IAC/B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,mBAAmB;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,2EAA2E;IAC3E,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED;;;;GAIG;AACH,iBAAS,QAAQ,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAkB,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,2CA2BtG;AAED,iDAAiD;AACjD,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,2CAM3F;AAED,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAA"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cn } from "../../lib/utils.js";
|
|
3
|
+
function AppShell({ className, sidebar, header, children, sidebarOpen = true, ...props }) {
|
|
4
|
+
return /* @__PURE__ */ jsxs(
|
|
5
|
+
"div",
|
|
6
|
+
{
|
|
7
|
+
className: cn("flex h-screen w-full overflow-hidden bg-background", className),
|
|
8
|
+
...props,
|
|
9
|
+
children: [
|
|
10
|
+
sidebar && /* @__PURE__ */ jsx(
|
|
11
|
+
"div",
|
|
12
|
+
{
|
|
13
|
+
className: cn(
|
|
14
|
+
"shrink-0 h-full transition-all duration-200",
|
|
15
|
+
!sidebarOpen && "hidden md:flex"
|
|
16
|
+
),
|
|
17
|
+
children: sidebar
|
|
18
|
+
}
|
|
19
|
+
),
|
|
20
|
+
/* @__PURE__ */ jsxs("div", { className: "flex flex-1 flex-col overflow-hidden min-w-0", children: [
|
|
21
|
+
header,
|
|
22
|
+
/* @__PURE__ */ jsx("main", { className: "flex-1 overflow-y-auto", children })
|
|
23
|
+
] })
|
|
24
|
+
]
|
|
25
|
+
}
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
function PageContent({ className, children, ...props }) {
|
|
29
|
+
return /* @__PURE__ */ jsx("div", { className: cn("p-6", className), ...props, children });
|
|
30
|
+
}
|
|
31
|
+
export {
|
|
32
|
+
AppShell,
|
|
33
|
+
PageContent
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=app-shell.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-shell.js","sources":["../../../src/components/layout/app-shell.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface AppShellProps extends React.HTMLAttributes<HTMLDivElement> {\n /** The sidebar component */\n sidebar?: React.ReactNode\n /** The top header component */\n header?: React.ReactNode\n /** Main content */\n children: React.ReactNode\n /** Whether the sidebar is currently shown (for mobile overlay handling) */\n sidebarOpen?: boolean\n}\n\n/**\n * AppShell provides the top-level layout structure:\n * - Sidebar (left)\n * - Main area (header + content)\n */\nfunction AppShell({ className, sidebar, header, children, sidebarOpen = true, ...props }: AppShellProps) {\n return (\n <div\n className={cn('flex h-screen w-full overflow-hidden bg-background', className)}\n {...props}\n >\n {/* Sidebar */}\n {sidebar && (\n <div\n className={cn(\n 'shrink-0 h-full transition-all duration-200',\n !sidebarOpen && 'hidden md:flex'\n )}\n >\n {sidebar}\n </div>\n )}\n\n {/* Main column */}\n <div className=\"flex flex-1 flex-col overflow-hidden min-w-0\">\n {header}\n <main className=\"flex-1 overflow-y-auto\">\n {children}\n </main>\n </div>\n </div>\n )\n}\n\n/** Content wrapper with standard page padding */\nfunction PageContent({ className, children, ...props }: React.HTMLAttributes<HTMLDivElement>) {\n return (\n <div className={cn('p-6', className)} {...props}>\n {children}\n </div>\n )\n}\n\nexport { AppShell, PageContent }\n"],"names":[],"mappings":";;AAmBA,SAAS,SAAS,EAAE,WAAW,SAAS,QAAQ,UAAU,cAAc,MAAM,GAAG,SAAwB;AACvG,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,GAAG,sDAAsD,SAAS;AAAA,MAC5E,GAAG;AAAA,MAGH,UAAA;AAAA,QAAA,WACC;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAW;AAAA,cACT;AAAA,cACA,CAAC,eAAe;AAAA,YAAA;AAAA,YAGjB,UAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAKL,qBAAC,OAAA,EAAI,WAAU,gDACZ,UAAA;AAAA,UAAA;AAAA,UACD,oBAAC,QAAA,EAAK,WAAU,0BACb,SAAA,CACH;AAAA,QAAA,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN;AAGA,SAAS,YAAY,EAAE,WAAW,UAAU,GAAG,SAA+C;AAC5F,SACE,oBAAC,SAAI,WAAW,GAAG,OAAO,SAAS,GAAI,GAAG,OACvC,UACH;AAEJ;"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface HeaderProps extends React.HTMLAttributes<HTMLElement> {
|
|
3
|
+
/** Left slot — typically logo + nav */
|
|
4
|
+
left?: React.ReactNode;
|
|
5
|
+
/** Center slot — search, breadcrumbs */
|
|
6
|
+
center?: React.ReactNode;
|
|
7
|
+
/** Right slot — user menu, notifications, settings */
|
|
8
|
+
right?: React.ReactNode;
|
|
9
|
+
/** Makes header sticky at top */
|
|
10
|
+
sticky?: boolean;
|
|
11
|
+
/** Adds a bottom border */
|
|
12
|
+
bordered?: boolean;
|
|
13
|
+
}
|
|
14
|
+
declare const Header: React.ForwardRefExoticComponent<HeaderProps & React.RefAttributes<HTMLElement>>;
|
|
15
|
+
export { Header };
|
|
16
|
+
//# sourceMappingURL=header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"header.d.ts","sourceRoot":"","sources":["../../../src/components/layout/header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,WAAY,SAAQ,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC;IACpE,uCAAuC;IACvC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,wCAAwC;IACxC,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,sDAAsD;IACtD,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACvB,iCAAiC;IACjC,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,2BAA2B;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,QAAA,MAAM,MAAM,iFAmBX,CAAA;AAGD,OAAO,EAAE,MAAM,EAAE,CAAA"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { cn } from "../../lib/utils.js";
|
|
4
|
+
const Header = React.forwardRef(
|
|
5
|
+
({ className, left, center, right, sticky = false, bordered = true, children, ...props }, ref) => /* @__PURE__ */ jsxs(
|
|
6
|
+
"header",
|
|
7
|
+
{
|
|
8
|
+
ref,
|
|
9
|
+
className: cn(
|
|
10
|
+
"z-40 flex h-14 w-full items-center gap-4 bg-background px-4",
|
|
11
|
+
sticky && "sticky top-0",
|
|
12
|
+
bordered && "border-b border-border",
|
|
13
|
+
className
|
|
14
|
+
),
|
|
15
|
+
...props,
|
|
16
|
+
children: [
|
|
17
|
+
left && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-3", children: left }),
|
|
18
|
+
center && /* @__PURE__ */ jsx("div", { className: "flex flex-1 items-center justify-center", children: center }),
|
|
19
|
+
!center && /* @__PURE__ */ jsx("div", { className: "flex-1" }),
|
|
20
|
+
right && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-2", children: right }),
|
|
21
|
+
children
|
|
22
|
+
]
|
|
23
|
+
}
|
|
24
|
+
)
|
|
25
|
+
);
|
|
26
|
+
Header.displayName = "Header";
|
|
27
|
+
export {
|
|
28
|
+
Header
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"header.js","sources":["../../../src/components/layout/header.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface HeaderProps extends React.HTMLAttributes<HTMLElement> {\n /** Left slot — typically logo + nav */\n left?: React.ReactNode\n /** Center slot — search, breadcrumbs */\n center?: React.ReactNode\n /** Right slot — user menu, notifications, settings */\n right?: React.ReactNode\n /** Makes header sticky at top */\n sticky?: boolean\n /** Adds a bottom border */\n bordered?: boolean\n}\n\nconst Header = React.forwardRef<HTMLElement, HeaderProps>(\n ({ className, left, center, right, sticky = false, bordered = true, children, ...props }, ref) => (\n <header\n ref={ref}\n className={cn(\n 'z-40 flex h-14 w-full items-center gap-4 bg-background px-4',\n sticky && 'sticky top-0',\n bordered && 'border-b border-border',\n className\n )}\n {...props}\n >\n {left && <div className=\"flex items-center gap-3\">{left}</div>}\n {center && <div className=\"flex flex-1 items-center justify-center\">{center}</div>}\n {!center && <div className=\"flex-1\" />}\n {right && <div className=\"flex items-center gap-2\">{right}</div>}\n {children}\n </header>\n )\n)\nHeader.displayName = 'Header'\n\nexport { Header }\n"],"names":[],"mappings":";;;AAgBA,MAAM,SAAS,MAAM;AAAA,EACnB,CAAC,EAAE,WAAW,MAAM,QAAQ,OAAO,SAAS,OAAO,WAAW,MAAM,UAAU,GAAG,MAAA,GAAS,QACxF;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,WAAW;AAAA,QACT;AAAA,QACA,UAAU;AAAA,QACV,YAAY;AAAA,QACZ;AAAA,MAAA;AAAA,MAED,GAAG;AAAA,MAEH,UAAA;AAAA,QAAA,QAAQ,oBAAC,OAAA,EAAI,WAAU,2BAA2B,UAAA,MAAK;AAAA,QACvD,UAAU,oBAAC,OAAA,EAAI,WAAU,2CAA2C,UAAA,QAAO;AAAA,QAC3E,CAAC,UAAU,oBAAC,OAAA,EAAI,WAAU,SAAA,CAAS;AAAA,QACnC,SAAS,oBAAC,OAAA,EAAI,WAAU,2BAA2B,UAAA,OAAM;AAAA,QACzD;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGP;AACA,OAAO,cAAc;"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface PageHeaderProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
3
|
+
/** Page title */
|
|
4
|
+
title: string;
|
|
5
|
+
/** Subtitle / description */
|
|
6
|
+
description?: string;
|
|
7
|
+
/** Slot for breadcrumbs above the title */
|
|
8
|
+
breadcrumbs?: React.ReactNode;
|
|
9
|
+
/** Slot for action buttons (top-right) */
|
|
10
|
+
actions?: React.ReactNode;
|
|
11
|
+
/** Optional decorative badge next to the title */
|
|
12
|
+
badge?: React.ReactNode;
|
|
13
|
+
}
|
|
14
|
+
declare const PageHeader: React.ForwardRefExoticComponent<PageHeaderProps & React.RefAttributes<HTMLDivElement>>;
|
|
15
|
+
export { PageHeader };
|
|
16
|
+
//# sourceMappingURL=page-header.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-header.d.ts","sourceRoot":"","sources":["../../../src/components/layout/page-header.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,WAAW,eAAgB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC3E,iBAAiB;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,6BAA6B;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,2CAA2C;IAC3C,WAAW,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IAC7B,0CAA0C;IAC1C,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,kDAAkD;IAClD,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACxB;AAED,QAAA,MAAM,UAAU,wFAsBf,CAAA;AAGD,OAAO,EAAE,UAAU,EAAE,CAAA"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from "react";
|
|
3
|
+
import { cn } from "../../lib/utils.js";
|
|
4
|
+
const PageHeader = React.forwardRef(
|
|
5
|
+
({ className, title, description, breadcrumbs, actions, badge, ...props }, ref) => /* @__PURE__ */ jsxs(
|
|
6
|
+
"div",
|
|
7
|
+
{
|
|
8
|
+
ref,
|
|
9
|
+
className: cn("flex flex-col gap-1 pb-6 md:flex-row md:items-start md:justify-between", className),
|
|
10
|
+
...props,
|
|
11
|
+
children: [
|
|
12
|
+
/* @__PURE__ */ jsxs("div", { className: "space-y-1.5", children: [
|
|
13
|
+
breadcrumbs && /* @__PURE__ */ jsx("div", { className: "mb-2", children: breadcrumbs }),
|
|
14
|
+
/* @__PURE__ */ jsxs("div", { className: "flex items-center gap-3 flex-wrap", children: [
|
|
15
|
+
/* @__PURE__ */ jsx("h1", { className: "text-2xl font-bold tracking-tight font-display", children: title }),
|
|
16
|
+
badge
|
|
17
|
+
] }),
|
|
18
|
+
description && /* @__PURE__ */ jsx("p", { className: "text-sm text-muted-foreground max-w-2xl", children: description })
|
|
19
|
+
] }),
|
|
20
|
+
actions && /* @__PURE__ */ jsx("div", { className: "flex items-center gap-2 shrink-0 mt-2 md:mt-0", children: actions })
|
|
21
|
+
]
|
|
22
|
+
}
|
|
23
|
+
)
|
|
24
|
+
);
|
|
25
|
+
PageHeader.displayName = "PageHeader";
|
|
26
|
+
export {
|
|
27
|
+
PageHeader
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=page-header.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-header.js","sources":["../../../src/components/layout/page-header.tsx"],"sourcesContent":["import * as React from 'react'\nimport { cn } from '@/lib/utils'\n\nexport interface PageHeaderProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Page title */\n title: string\n /** Subtitle / description */\n description?: string\n /** Slot for breadcrumbs above the title */\n breadcrumbs?: React.ReactNode\n /** Slot for action buttons (top-right) */\n actions?: React.ReactNode\n /** Optional decorative badge next to the title */\n badge?: React.ReactNode\n}\n\nconst PageHeader = React.forwardRef<HTMLDivElement, PageHeaderProps>(\n ({ className, title, description, breadcrumbs, actions, badge, ...props }, ref) => (\n <div\n ref={ref}\n className={cn('flex flex-col gap-1 pb-6 md:flex-row md:items-start md:justify-between', className)}\n {...props}\n >\n <div className=\"space-y-1.5\">\n {breadcrumbs && <div className=\"mb-2\">{breadcrumbs}</div>}\n <div className=\"flex items-center gap-3 flex-wrap\">\n <h1 className=\"text-2xl font-bold tracking-tight font-display\">{title}</h1>\n {badge}\n </div>\n {description && (\n <p className=\"text-sm text-muted-foreground max-w-2xl\">{description}</p>\n )}\n </div>\n {actions && (\n <div className=\"flex items-center gap-2 shrink-0 mt-2 md:mt-0\">{actions}</div>\n )}\n </div>\n )\n)\nPageHeader.displayName = 'PageHeader'\n\nexport { PageHeader }\n"],"names":[],"mappings":";;;AAgBA,MAAM,aAAa,MAAM;AAAA,EACvB,CAAC,EAAE,WAAW,OAAO,aAAa,aAAa,SAAS,OAAO,GAAG,SAAS,QACzE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA,WAAW,GAAG,0EAA0E,SAAS;AAAA,MAChG,GAAG;AAAA,MAEJ,UAAA;AAAA,QAAA,qBAAC,OAAA,EAAI,WAAU,eACZ,UAAA;AAAA,UAAA,eAAe,oBAAC,OAAA,EAAI,WAAU,QAAQ,UAAA,aAAY;AAAA,UACnD,qBAAC,OAAA,EAAI,WAAU,qCACb,UAAA;AAAA,YAAA,oBAAC,MAAA,EAAG,WAAU,kDAAkD,UAAA,OAAM;AAAA,YACrE;AAAA,UAAA,GACH;AAAA,UACC,eACC,oBAAC,KAAA,EAAE,WAAU,2CAA2C,UAAA,YAAA,CAAY;AAAA,QAAA,GAExE;AAAA,QACC,WACC,oBAAC,OAAA,EAAI,WAAU,iDAAiD,UAAA,QAAA,CAAQ;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAIhF;AACA,WAAW,cAAc;"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface SidebarNavItem {
|
|
3
|
+
id: string;
|
|
4
|
+
label: string;
|
|
5
|
+
icon?: React.ReactNode;
|
|
6
|
+
href?: string;
|
|
7
|
+
badge?: string | number;
|
|
8
|
+
active?: boolean;
|
|
9
|
+
disabled?: boolean;
|
|
10
|
+
onClick?: () => void;
|
|
11
|
+
children?: SidebarNavItem[];
|
|
12
|
+
}
|
|
13
|
+
export interface SidebarSection {
|
|
14
|
+
id: string;
|
|
15
|
+
label?: string;
|
|
16
|
+
items: SidebarNavItem[];
|
|
17
|
+
}
|
|
18
|
+
export interface SidebarProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
19
|
+
sections?: SidebarSection[];
|
|
20
|
+
/** Whether sidebar is collapsed to icon-only mode */
|
|
21
|
+
collapsed?: boolean;
|
|
22
|
+
/** Called when collapse toggle is pressed */
|
|
23
|
+
onCollapsedChange?: (collapsed: boolean) => void;
|
|
24
|
+
/** Show collapse toggle button */
|
|
25
|
+
collapsible?: boolean;
|
|
26
|
+
/** Width when expanded */
|
|
27
|
+
width?: string;
|
|
28
|
+
/** Slot for logo/brand area */
|
|
29
|
+
header?: React.ReactNode;
|
|
30
|
+
/** Slot for footer content (user menu, etc.) */
|
|
31
|
+
footer?: React.ReactNode;
|
|
32
|
+
}
|
|
33
|
+
declare const Sidebar: React.ForwardRefExoticComponent<SidebarProps & React.RefAttributes<HTMLDivElement>>;
|
|
34
|
+
export { Sidebar };
|
|
35
|
+
//# sourceMappingURL=sidebar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../../src/components/layout/sidebar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAO9B,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACvB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;IACpB,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAA;CAC5B;AAED,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAA;IACV,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,cAAc,EAAE,CAAA;CACxB;AAED,MAAM,WAAW,YAAa,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACxE,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAA;IAC3B,qDAAqD;IACrD,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,6CAA6C;IAC7C,iBAAiB,CAAC,EAAE,CAAC,SAAS,EAAE,OAAO,KAAK,IAAI,CAAA;IAChD,kCAAkC;IAClC,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,0BAA0B;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,+BAA+B;IAC/B,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACxB,gDAAgD;IAChD,MAAM,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACzB;AAwDD,QAAA,MAAM,OAAO,qFA2FZ,CAAA;AAGD,OAAO,EAAE,OAAO,EAAE,CAAA"}
|