orbital-command 0.1.4 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/orbital.js +676 -53
- package/dist/assets/PrimitivesConfig-CrmQXYh4.js +32 -0
- package/dist/assets/QualityGates-BbasOsF3.js +21 -0
- package/dist/assets/SessionTimeline-CGeJsVvy.js +1 -0
- package/dist/assets/Settings-oiM496mc.js +12 -0
- package/dist/assets/SourceControl-B1fP2nJL.js +41 -0
- package/dist/assets/WorkflowVisualizer-CWLYf-f0.js +74 -0
- package/dist/assets/arrow-down-CPy85_J6.js +6 -0
- package/dist/assets/charts-DbDg0Psc.js +68 -0
- package/dist/assets/circle-x-Cwz6ZQDV.js +6 -0
- package/dist/assets/file-text-C46Xr65c.js +6 -0
- package/dist/assets/formatDistanceToNow-BMqsSP44.js +1 -0
- package/dist/assets/globe-Cn2yNZUD.js +6 -0
- package/dist/assets/index-Aj4sV8Al.css +1 -0
- package/dist/assets/index-Bc9dK3MW.js +354 -0
- package/dist/assets/key-OPaNTWJ5.js +6 -0
- package/dist/assets/minus-GMsbpKym.js +6 -0
- package/dist/assets/shield-DwAFkDYI.js +6 -0
- package/dist/assets/ui-BmsSg9jU.js +53 -0
- package/dist/assets/useWorkflowEditor-BJkTX_NR.js +16 -0
- package/dist/assets/{vendor-Dzv9lrRc.js → vendor-Bqt8AJn2.js} +1 -1
- package/dist/assets/zap-DfbUoOty.js +11 -0
- package/dist/favicon.svg +1 -0
- package/dist/index.html +6 -5
- package/dist/server/server/__tests__/data-routes.test.js +124 -0
- package/dist/server/server/__tests__/helpers/db.js +17 -0
- package/dist/server/server/__tests__/helpers/mock-emitter.js +8 -0
- package/dist/server/server/__tests__/scope-routes.test.js +137 -0
- package/dist/server/server/__tests__/sprint-routes.test.js +102 -0
- package/dist/server/server/__tests__/workflow-routes.test.js +107 -0
- package/dist/server/server/config-migrator.js +138 -0
- package/dist/server/server/config.js +17 -2
- package/dist/server/server/database.js +27 -12
- package/dist/server/server/global-config.js +143 -0
- package/dist/server/server/index.js +882 -252
- package/dist/server/server/init.js +579 -194
- package/dist/server/server/launch.js +29 -0
- package/dist/server/server/manifest-types.js +8 -0
- package/dist/server/server/manifest.js +454 -0
- package/dist/server/server/migrate-legacy.js +229 -0
- package/dist/server/server/parsers/event-parser.test.js +117 -0
- package/dist/server/server/parsers/scope-parser.js +74 -28
- package/dist/server/server/parsers/scope-parser.test.js +230 -0
- package/dist/server/server/project-context.js +255 -0
- package/dist/server/server/project-emitter.js +41 -0
- package/dist/server/server/project-manager.js +297 -0
- package/dist/server/server/routes/config-routes.js +1 -3
- package/dist/server/server/routes/data-routes.js +22 -110
- package/dist/server/server/routes/dispatch-routes.js +15 -9
- package/dist/server/server/routes/git-routes.js +74 -0
- package/dist/server/server/routes/manifest-routes.js +319 -0
- package/dist/server/server/routes/scope-routes.js +37 -23
- package/dist/server/server/routes/sync-routes.js +134 -0
- package/dist/server/server/routes/version-routes.js +1 -15
- package/dist/server/server/routes/workflow-routes.js +9 -3
- package/dist/server/server/schema.js +2 -0
- package/dist/server/server/services/batch-orchestrator.js +26 -16
- package/dist/server/server/services/claude-session-service.js +17 -14
- package/dist/server/server/services/deploy-service.test.js +119 -0
- package/dist/server/server/services/event-service.js +64 -1
- package/dist/server/server/services/event-service.test.js +191 -0
- package/dist/server/server/services/gate-service.test.js +105 -0
- package/dist/server/server/services/git-service.js +108 -4
- package/dist/server/server/services/github-service.js +110 -2
- package/dist/server/server/services/readiness-service.test.js +190 -0
- package/dist/server/server/services/scope-cache.js +5 -1
- package/dist/server/server/services/scope-cache.test.js +142 -0
- package/dist/server/server/services/scope-service.js +217 -126
- package/dist/server/server/services/scope-service.test.js +137 -0
- package/dist/server/server/services/sprint-orchestrator.js +7 -6
- package/dist/server/server/services/sprint-service.js +21 -1
- package/dist/server/server/services/sprint-service.test.js +238 -0
- package/dist/server/server/services/sync-service.js +434 -0
- package/dist/server/server/services/sync-types.js +2 -0
- package/dist/server/server/services/telemetry-service.js +143 -0
- package/dist/server/server/services/workflow-service.js +26 -5
- package/dist/server/server/services/workflow-service.test.js +159 -0
- package/dist/server/server/settings-sync.js +284 -0
- package/dist/server/server/update-planner.js +279 -0
- package/dist/server/server/utils/cc-hooks-parser.js +3 -0
- package/dist/server/server/utils/cc-hooks-parser.test.js +86 -0
- package/dist/server/server/utils/dispatch-utils.js +77 -20
- package/dist/server/server/utils/dispatch-utils.test.js +182 -0
- package/dist/server/server/utils/logger.js +37 -3
- package/dist/server/server/utils/package-info.js +30 -0
- package/dist/server/server/utils/route-helpers.js +10 -0
- package/dist/server/server/utils/terminal-launcher.js +79 -25
- package/dist/server/server/utils/worktree-manager.js +13 -4
- package/dist/server/server/validator.js +230 -0
- package/dist/server/server/watchers/global-watcher.js +63 -0
- package/dist/server/server/watchers/scope-watcher.js +27 -12
- package/dist/server/server/wizard/config-editor.js +237 -0
- package/dist/server/server/wizard/detect.js +96 -0
- package/dist/server/server/wizard/doctor.js +115 -0
- package/dist/server/server/wizard/index.js +155 -0
- package/dist/server/server/wizard/phases/confirm.js +39 -0
- package/dist/server/server/wizard/phases/project-setup.js +90 -0
- package/dist/server/server/wizard/phases/setup-wizard.js +66 -0
- package/dist/server/server/wizard/phases/welcome.js +35 -0
- package/dist/server/server/wizard/phases/workflow-setup.js +22 -0
- package/dist/server/server/wizard/types.js +29 -0
- package/dist/server/server/wizard/ui.js +74 -0
- package/dist/server/shared/__fixtures__/workflow-configs.js +75 -0
- package/dist/server/shared/default-workflow.json +65 -0
- package/dist/server/shared/onboarding-tour.test.js +81 -0
- package/dist/server/shared/project-colors.js +24 -0
- package/dist/server/shared/workflow-config.test.js +84 -0
- package/dist/server/shared/workflow-engine.test.js +302 -0
- package/dist/server/shared/workflow-normalizer.js +101 -0
- package/dist/server/shared/workflow-normalizer.test.js +100 -0
- package/dist/server/src/components/onboarding/tour-steps.js +84 -0
- package/package.json +20 -15
- package/schemas/orbital.config.schema.json +16 -1
- package/scripts/postinstall.js +55 -7
- package/server/__tests__/data-routes.test.ts +149 -0
- package/server/__tests__/helpers/db.ts +19 -0
- package/server/__tests__/helpers/mock-emitter.ts +10 -0
- package/server/__tests__/scope-routes.test.ts +157 -0
- package/server/__tests__/sprint-routes.test.ts +118 -0
- package/server/__tests__/workflow-routes.test.ts +120 -0
- package/server/config-migrator.ts +163 -0
- package/server/config.ts +26 -2
- package/server/database.ts +35 -18
- package/server/global-config.ts +200 -0
- package/server/index.ts +975 -287
- package/server/init.ts +625 -182
- package/server/launch.ts +32 -0
- package/server/manifest-types.ts +145 -0
- package/server/manifest.ts +494 -0
- package/server/migrate-legacy.ts +290 -0
- package/server/parsers/event-parser.test.ts +135 -0
- package/server/parsers/scope-parser.test.ts +270 -0
- package/server/parsers/scope-parser.ts +79 -31
- package/server/project-context.ts +309 -0
- package/server/project-emitter.ts +50 -0
- package/server/project-manager.ts +369 -0
- package/server/routes/config-routes.ts +3 -5
- package/server/routes/data-routes.ts +28 -141
- package/server/routes/dispatch-routes.ts +19 -11
- package/server/routes/git-routes.ts +77 -0
- package/server/routes/manifest-routes.ts +388 -0
- package/server/routes/scope-routes.ts +29 -25
- package/server/routes/sync-routes.ts +175 -0
- package/server/routes/version-routes.ts +1 -16
- package/server/routes/workflow-routes.ts +9 -3
- package/server/schema.ts +2 -0
- package/server/services/batch-orchestrator.ts +24 -16
- package/server/services/claude-session-service.ts +16 -14
- package/server/services/deploy-service.test.ts +145 -0
- package/server/services/deploy-service.ts +2 -2
- package/server/services/event-service.test.ts +242 -0
- package/server/services/event-service.ts +92 -3
- package/server/services/gate-service.test.ts +131 -0
- package/server/services/gate-service.ts +2 -2
- package/server/services/git-service.ts +137 -4
- package/server/services/github-service.ts +120 -2
- package/server/services/readiness-service.test.ts +217 -0
- package/server/services/scope-cache.test.ts +167 -0
- package/server/services/scope-cache.ts +4 -1
- package/server/services/scope-service.test.ts +169 -0
- package/server/services/scope-service.ts +220 -126
- package/server/services/sprint-orchestrator.ts +7 -7
- package/server/services/sprint-service.test.ts +271 -0
- package/server/services/sprint-service.ts +27 -3
- package/server/services/sync-service.ts +482 -0
- package/server/services/sync-types.ts +77 -0
- package/server/services/telemetry-service.ts +195 -0
- package/server/services/workflow-service.test.ts +190 -0
- package/server/services/workflow-service.ts +29 -9
- package/server/settings-sync.ts +359 -0
- package/server/update-planner.ts +346 -0
- package/server/utils/cc-hooks-parser.test.ts +96 -0
- package/server/utils/cc-hooks-parser.ts +4 -0
- package/server/utils/dispatch-utils.test.ts +245 -0
- package/server/utils/dispatch-utils.ts +97 -27
- package/server/utils/logger.ts +40 -3
- package/server/utils/package-info.ts +32 -0
- package/server/utils/route-helpers.ts +12 -0
- package/server/utils/terminal-launcher.ts +85 -25
- package/server/utils/worktree-manager.ts +9 -4
- package/server/validator.ts +270 -0
- package/server/watchers/global-watcher.ts +77 -0
- package/server/watchers/scope-watcher.ts +21 -9
- package/server/wizard/config-editor.ts +248 -0
- package/server/wizard/detect.ts +104 -0
- package/server/wizard/doctor.ts +114 -0
- package/server/wizard/index.ts +187 -0
- package/server/wizard/phases/confirm.ts +45 -0
- package/server/wizard/phases/project-setup.ts +106 -0
- package/server/wizard/phases/setup-wizard.ts +78 -0
- package/server/wizard/phases/welcome.ts +43 -0
- package/server/wizard/phases/workflow-setup.ts +28 -0
- package/server/wizard/types.ts +56 -0
- package/server/wizard/ui.ts +93 -0
- package/shared/__fixtures__/workflow-configs.ts +80 -0
- package/shared/default-workflow.json +65 -0
- package/shared/onboarding-tour.test.ts +94 -0
- package/shared/project-colors.ts +24 -0
- package/shared/workflow-config.test.ts +111 -0
- package/shared/workflow-config.ts +7 -0
- package/shared/workflow-engine.test.ts +388 -0
- package/shared/workflow-normalizer.test.ts +119 -0
- package/shared/workflow-normalizer.ts +118 -0
- package/templates/hooks/end-session.sh +3 -1
- package/templates/hooks/orbital-emit.sh +2 -2
- package/templates/hooks/orbital-report-deploy.sh +4 -4
- package/templates/hooks/orbital-report-gates.sh +4 -4
- package/templates/hooks/orbital-scope-update.sh +1 -1
- package/templates/hooks/scope-create-cleanup.sh +2 -2
- package/templates/hooks/scope-create-gate.sh +0 -1
- package/templates/hooks/scope-helpers.sh +18 -0
- package/templates/hooks/scope-prepare.sh +66 -11
- package/templates/migrations/renames.json +1 -0
- package/templates/orbital.config.json +7 -2
- package/templates/settings-hooks.json +1 -1
- package/templates/skills/git-commit/SKILL.md +9 -4
- package/templates/skills/git-dev/SKILL.md +8 -3
- package/templates/skills/git-main/SKILL.md +8 -2
- package/templates/skills/git-production/SKILL.md +6 -2
- package/templates/skills/git-staging/SKILL.md +8 -3
- package/templates/skills/scope-create/SKILL.md +17 -3
- package/templates/skills/scope-fix-review/SKILL.md +6 -3
- package/templates/skills/scope-implement/SKILL.md +4 -1
- package/templates/skills/scope-post-review/SKILL.md +63 -5
- package/templates/skills/scope-pre-review/SKILL.md +5 -2
- package/templates/skills/scope-verify/SKILL.md +5 -3
- package/templates/skills/test-code-review/SKILL.md +41 -33
- package/templates/skills/test-scaffold/SKILL.md +222 -0
- package/dist/assets/WorkflowVisualizer-BZ21PIIF.js +0 -84
- package/dist/assets/charts-D__PA1zp.js +0 -72
- package/dist/assets/index-D1G6i0nS.css +0 -1
- package/dist/assets/index-DpItvKpf.js +0 -419
- package/dist/assets/ui-BvF022GT.js +0 -53
- package/index.html +0 -15
- package/postcss.config.js +0 -6
- package/src/App.tsx +0 -33
- package/src/components/AgentBadge.tsx +0 -40
- package/src/components/BatchPreflightModal.tsx +0 -115
- package/src/components/CardDisplayToggle.tsx +0 -74
- package/src/components/ColumnHeaderActions.tsx +0 -55
- package/src/components/ColumnMenu.tsx +0 -99
- package/src/components/DeployHistory.tsx +0 -141
- package/src/components/DispatchModal.tsx +0 -164
- package/src/components/DispatchPopover.tsx +0 -139
- package/src/components/DragOverlay.tsx +0 -25
- package/src/components/DriftSidebar.tsx +0 -140
- package/src/components/EnvironmentStrip.tsx +0 -88
- package/src/components/ErrorBoundary.tsx +0 -62
- package/src/components/FilterChip.tsx +0 -105
- package/src/components/GateIndicator.tsx +0 -33
- package/src/components/IdeaDetailModal.tsx +0 -190
- package/src/components/IdeaFormDialog.tsx +0 -113
- package/src/components/KanbanColumn.tsx +0 -201
- package/src/components/MarkdownRenderer.tsx +0 -114
- package/src/components/NeonGrid.tsx +0 -128
- package/src/components/PromotionQueue.tsx +0 -89
- package/src/components/ScopeCard.tsx +0 -234
- package/src/components/ScopeDetailModal.tsx +0 -255
- package/src/components/ScopeFilterBar.tsx +0 -152
- package/src/components/SearchInput.tsx +0 -102
- package/src/components/SessionPanel.tsx +0 -335
- package/src/components/SprintContainer.tsx +0 -303
- package/src/components/SprintDependencyDialog.tsx +0 -78
- package/src/components/SprintPreflightModal.tsx +0 -138
- package/src/components/StatusBar.tsx +0 -168
- package/src/components/SwimCell.tsx +0 -67
- package/src/components/SwimLaneRow.tsx +0 -94
- package/src/components/SwimlaneBoardView.tsx +0 -108
- package/src/components/VersionBadge.tsx +0 -139
- package/src/components/ViewModeSelector.tsx +0 -114
- package/src/components/config/AgentChip.tsx +0 -53
- package/src/components/config/AgentCreateDialog.tsx +0 -321
- package/src/components/config/AgentEditor.tsx +0 -175
- package/src/components/config/DirectoryTree.tsx +0 -582
- package/src/components/config/FileEditor.tsx +0 -550
- package/src/components/config/HookChip.tsx +0 -50
- package/src/components/config/StageCard.tsx +0 -198
- package/src/components/config/TransitionZone.tsx +0 -173
- package/src/components/config/UnifiedWorkflowPipeline.tsx +0 -216
- package/src/components/config/WorkflowPipeline.tsx +0 -161
- package/src/components/source-control/BranchList.tsx +0 -93
- package/src/components/source-control/BranchPanel.tsx +0 -105
- package/src/components/source-control/CommitLog.tsx +0 -100
- package/src/components/source-control/CommitRow.tsx +0 -47
- package/src/components/source-control/GitHubPanel.tsx +0 -110
- package/src/components/source-control/GitHubSetupGuide.tsx +0 -52
- package/src/components/source-control/GitOverviewBar.tsx +0 -101
- package/src/components/source-control/PullRequestList.tsx +0 -69
- package/src/components/source-control/WorktreeList.tsx +0 -80
- package/src/components/ui/badge.tsx +0 -41
- package/src/components/ui/button.tsx +0 -55
- package/src/components/ui/card.tsx +0 -78
- package/src/components/ui/dialog.tsx +0 -94
- package/src/components/ui/popover.tsx +0 -33
- package/src/components/ui/scroll-area.tsx +0 -54
- package/src/components/ui/separator.tsx +0 -28
- package/src/components/ui/tabs.tsx +0 -52
- package/src/components/ui/toggle-switch.tsx +0 -35
- package/src/components/ui/tooltip.tsx +0 -27
- package/src/components/workflow/AddEdgeDialog.tsx +0 -217
- package/src/components/workflow/AddListDialog.tsx +0 -201
- package/src/components/workflow/ChecklistEditor.tsx +0 -239
- package/src/components/workflow/CommandPrefixManager.tsx +0 -118
- package/src/components/workflow/ConfigSettingsPanel.tsx +0 -189
- package/src/components/workflow/DirectionSelector.tsx +0 -133
- package/src/components/workflow/DispatchConfigPanel.tsx +0 -180
- package/src/components/workflow/EdgeDetailPanel.tsx +0 -236
- package/src/components/workflow/EdgePropertyEditor.tsx +0 -251
- package/src/components/workflow/EditToolbar.tsx +0 -138
- package/src/components/workflow/HookDetailPanel.tsx +0 -250
- package/src/components/workflow/HookExecutionLog.tsx +0 -24
- package/src/components/workflow/HookSourceModal.tsx +0 -129
- package/src/components/workflow/HooksDashboard.tsx +0 -363
- package/src/components/workflow/ListPropertyEditor.tsx +0 -251
- package/src/components/workflow/MigrationPreviewDialog.tsx +0 -237
- package/src/components/workflow/MovementRulesPanel.tsx +0 -188
- package/src/components/workflow/NodeDetailPanel.tsx +0 -245
- package/src/components/workflow/PresetSelector.tsx +0 -414
- package/src/components/workflow/SkillCommandBuilder.tsx +0 -174
- package/src/components/workflow/WorkflowEdgeComponent.tsx +0 -145
- package/src/components/workflow/WorkflowNode.tsx +0 -147
- package/src/components/workflow/graphLayout.ts +0 -186
- package/src/components/workflow/mergeHooks.ts +0 -85
- package/src/components/workflow/useEditHistory.ts +0 -88
- package/src/components/workflow/useWorkflowEditor.ts +0 -262
- package/src/components/workflow/validateConfig.ts +0 -70
- package/src/hooks/useActiveDispatches.ts +0 -198
- package/src/hooks/useBoardSettings.ts +0 -170
- package/src/hooks/useCardDisplay.ts +0 -57
- package/src/hooks/useCcHooks.ts +0 -24
- package/src/hooks/useConfigTree.ts +0 -51
- package/src/hooks/useEnforcementRules.ts +0 -46
- package/src/hooks/useEvents.ts +0 -59
- package/src/hooks/useFileEditor.ts +0 -165
- package/src/hooks/useGates.ts +0 -57
- package/src/hooks/useIdeaActions.ts +0 -53
- package/src/hooks/useKanbanDnd.ts +0 -410
- package/src/hooks/useOrbitalConfig.ts +0 -54
- package/src/hooks/usePipeline.ts +0 -47
- package/src/hooks/usePipelineData.ts +0 -338
- package/src/hooks/useReconnect.ts +0 -25
- package/src/hooks/useScopeFilters.ts +0 -125
- package/src/hooks/useScopeSessions.ts +0 -44
- package/src/hooks/useScopes.ts +0 -67
- package/src/hooks/useSearch.ts +0 -67
- package/src/hooks/useSettings.tsx +0 -187
- package/src/hooks/useSocket.ts +0 -25
- package/src/hooks/useSourceControl.ts +0 -105
- package/src/hooks/useSprintPreflight.ts +0 -55
- package/src/hooks/useSprints.ts +0 -154
- package/src/hooks/useStatusBarHighlight.ts +0 -18
- package/src/hooks/useSwimlaneBoardSettings.ts +0 -104
- package/src/hooks/useTheme.ts +0 -9
- package/src/hooks/useTransitionReadiness.ts +0 -53
- package/src/hooks/useVersion.ts +0 -155
- package/src/hooks/useViolations.ts +0 -65
- package/src/hooks/useWorkflow.tsx +0 -125
- package/src/hooks/useZoomModifier.ts +0 -19
- package/src/index.css +0 -797
- package/src/layouts/DashboardLayout.tsx +0 -113
- package/src/lib/collisionDetection.ts +0 -20
- package/src/lib/scope-fields.ts +0 -61
- package/src/lib/swimlane.ts +0 -146
- package/src/lib/utils.ts +0 -15
- package/src/main.tsx +0 -19
- package/src/socket.ts +0 -11
- package/src/types/index.ts +0 -497
- package/src/views/AgentFeed.tsx +0 -339
- package/src/views/DeployPipeline.tsx +0 -59
- package/src/views/EnforcementView.tsx +0 -378
- package/src/views/PrimitivesConfig.tsx +0 -500
- package/src/views/QualityGates.tsx +0 -1012
- package/src/views/ScopeBoard.tsx +0 -454
- package/src/views/SessionTimeline.tsx +0 -516
- package/src/views/Settings.tsx +0 -183
- package/src/views/SourceControl.tsx +0 -95
- package/src/views/WorkflowVisualizer.tsx +0 -382
- package/tailwind.config.js +0 -161
- package/tsconfig.json +0 -25
- package/vite.config.ts +0 -49
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
GitBranch,
|
|
3
|
-
Circle,
|
|
4
|
-
ArrowUpDown,
|
|
5
|
-
GitFork,
|
|
6
|
-
Github,
|
|
7
|
-
} from 'lucide-react';
|
|
8
|
-
import { Badge } from '@/components/ui/badge';
|
|
9
|
-
import { Card, CardContent } from '@/components/ui/card';
|
|
10
|
-
import { Tooltip, TooltipTrigger, TooltipContent } from '@/components/ui/tooltip';
|
|
11
|
-
import type { GitOverview, GitHubStatus } from '@/types';
|
|
12
|
-
|
|
13
|
-
interface Props {
|
|
14
|
-
overview: GitOverview;
|
|
15
|
-
github: GitHubStatus | null;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function GitOverviewBar({ overview, github }: Props) {
|
|
19
|
-
return (
|
|
20
|
-
<Card className="mb-6">
|
|
21
|
-
<CardContent className="flex flex-wrap items-center gap-4 py-3">
|
|
22
|
-
{/* Current branch */}
|
|
23
|
-
<div className="flex items-center gap-2">
|
|
24
|
-
<GitBranch className="h-4 w-4 text-primary" />
|
|
25
|
-
<code className="font-mono text-sm">{overview.currentBranch}</code>
|
|
26
|
-
{overview.dirty && (
|
|
27
|
-
<Tooltip>
|
|
28
|
-
<TooltipTrigger>
|
|
29
|
-
<Circle className="h-2.5 w-2.5 fill-warning-amber text-warning-amber" />
|
|
30
|
-
</TooltipTrigger>
|
|
31
|
-
<TooltipContent>Uncommitted changes</TooltipContent>
|
|
32
|
-
</Tooltip>
|
|
33
|
-
)}
|
|
34
|
-
</div>
|
|
35
|
-
|
|
36
|
-
{/* Branching mode badge */}
|
|
37
|
-
<Badge variant="outline" className="text-xs">
|
|
38
|
-
{overview.branchingMode}
|
|
39
|
-
</Badge>
|
|
40
|
-
|
|
41
|
-
{/* HEAD SHA */}
|
|
42
|
-
{overview.mainHead && (
|
|
43
|
-
<div className="flex items-center gap-1.5 text-xs text-muted-foreground">
|
|
44
|
-
<span>HEAD</span>
|
|
45
|
-
<code className="font-mono text-xs">{overview.mainHead.sha.slice(0, 7)}</code>
|
|
46
|
-
<span className="max-w-[200px] truncate">{overview.mainHead.message}</span>
|
|
47
|
-
</div>
|
|
48
|
-
)}
|
|
49
|
-
|
|
50
|
-
{/* Ahead/Behind */}
|
|
51
|
-
{overview.aheadBehind && (overview.aheadBehind.ahead > 0 || overview.aheadBehind.behind > 0) && (
|
|
52
|
-
<div className="flex items-center gap-1 text-xs">
|
|
53
|
-
<ArrowUpDown className="h-3 w-3 text-muted-foreground" />
|
|
54
|
-
{overview.aheadBehind.ahead > 0 && (
|
|
55
|
-
<span className="text-bid-green">{overview.aheadBehind.ahead}↑</span>
|
|
56
|
-
)}
|
|
57
|
-
{overview.aheadBehind.behind > 0 && (
|
|
58
|
-
<span className="text-ask-red">{overview.aheadBehind.behind}↓</span>
|
|
59
|
-
)}
|
|
60
|
-
</div>
|
|
61
|
-
)}
|
|
62
|
-
|
|
63
|
-
{/* Worktree / feature branch count */}
|
|
64
|
-
{overview.branchingMode === 'worktree' && overview.worktreeCount > 0 && (
|
|
65
|
-
<div className="flex items-center gap-1 text-xs text-muted-foreground">
|
|
66
|
-
<GitFork className="h-3 w-3" />
|
|
67
|
-
<span>{overview.worktreeCount} worktree{overview.worktreeCount !== 1 ? 's' : ''}</span>
|
|
68
|
-
</div>
|
|
69
|
-
)}
|
|
70
|
-
{overview.branchingMode === 'trunk' && overview.featureBranchCount > 0 && (
|
|
71
|
-
<div className="flex items-center gap-1 text-xs text-muted-foreground">
|
|
72
|
-
<GitBranch className="h-3 w-3" />
|
|
73
|
-
<span>{overview.featureBranchCount} feature branch{overview.featureBranchCount !== 1 ? 'es' : ''}</span>
|
|
74
|
-
</div>
|
|
75
|
-
)}
|
|
76
|
-
|
|
77
|
-
{/* GitHub connection badge — pushed to the right */}
|
|
78
|
-
<div className="ml-auto flex items-center gap-1.5">
|
|
79
|
-
<Github className="h-3.5 w-3.5 text-muted-foreground" />
|
|
80
|
-
{github?.connected ? (
|
|
81
|
-
<Tooltip>
|
|
82
|
-
<TooltipTrigger>
|
|
83
|
-
<Badge variant="secondary" className="text-xs gap-1">
|
|
84
|
-
<Circle className="h-1.5 w-1.5 fill-bid-green text-bid-green" />
|
|
85
|
-
{github.repo?.fullName ?? 'Connected'}
|
|
86
|
-
</Badge>
|
|
87
|
-
</TooltipTrigger>
|
|
88
|
-
<TooltipContent>
|
|
89
|
-
{github.authUser ? `Signed in as ${github.authUser}` : 'Connected to GitHub'}
|
|
90
|
-
</TooltipContent>
|
|
91
|
-
</Tooltip>
|
|
92
|
-
) : (
|
|
93
|
-
<Badge variant="outline" className="text-xs text-muted-foreground">
|
|
94
|
-
Not connected
|
|
95
|
-
</Badge>
|
|
96
|
-
)}
|
|
97
|
-
</div>
|
|
98
|
-
</CardContent>
|
|
99
|
-
</Card>
|
|
100
|
-
);
|
|
101
|
-
}
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { formatDistanceToNow } from 'date-fns';
|
|
2
|
-
import { GitPullRequest, ExternalLink } from 'lucide-react';
|
|
3
|
-
import { Badge } from '@/components/ui/badge';
|
|
4
|
-
import type { PullRequestInfo } from '@/types';
|
|
5
|
-
|
|
6
|
-
interface Props {
|
|
7
|
-
prs: PullRequestInfo[];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function PullRequestList({ prs }: Props) {
|
|
11
|
-
if (prs.length === 0) {
|
|
12
|
-
return (
|
|
13
|
-
<div className="py-4 text-center">
|
|
14
|
-
<GitPullRequest className="mx-auto mb-2 h-8 w-8 text-muted-foreground/50" />
|
|
15
|
-
<p className="text-xs text-muted-foreground">No open pull requests.</p>
|
|
16
|
-
</div>
|
|
17
|
-
);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return (
|
|
21
|
-
<div className="space-y-0.5">
|
|
22
|
-
{prs.map(pr => (
|
|
23
|
-
<a
|
|
24
|
-
key={pr.number}
|
|
25
|
-
href={pr.url}
|
|
26
|
-
target="_blank"
|
|
27
|
-
rel="noopener noreferrer"
|
|
28
|
-
className="flex items-center gap-3 rounded px-2.5 py-1.5 transition-colors hover:bg-surface-light group"
|
|
29
|
-
>
|
|
30
|
-
<GitPullRequest className="h-4 w-4 shrink-0 text-bid-green" />
|
|
31
|
-
|
|
32
|
-
<span className="shrink-0 font-mono text-xs text-muted-foreground">
|
|
33
|
-
#{pr.number}
|
|
34
|
-
</span>
|
|
35
|
-
|
|
36
|
-
<span className="min-w-0 flex-1 truncate text-sm">
|
|
37
|
-
{pr.title}
|
|
38
|
-
</span>
|
|
39
|
-
|
|
40
|
-
{/* Branch badges */}
|
|
41
|
-
<Badge variant="outline" className="shrink-0 text-xs font-normal">
|
|
42
|
-
{pr.branch}
|
|
43
|
-
</Badge>
|
|
44
|
-
<span className="text-xs text-muted-foreground">→</span>
|
|
45
|
-
<Badge variant="outline" className="shrink-0 text-xs font-normal">
|
|
46
|
-
{pr.baseBranch}
|
|
47
|
-
</Badge>
|
|
48
|
-
|
|
49
|
-
{/* Scope IDs */}
|
|
50
|
-
{pr.scopeIds.map(id => (
|
|
51
|
-
<Badge key={id} variant="secondary" className="shrink-0 text-xs">
|
|
52
|
-
#{id}
|
|
53
|
-
</Badge>
|
|
54
|
-
))}
|
|
55
|
-
|
|
56
|
-
<span className="shrink-0 text-xs text-muted-foreground">
|
|
57
|
-
{pr.author}
|
|
58
|
-
</span>
|
|
59
|
-
|
|
60
|
-
<span className="shrink-0 text-xs text-muted-foreground/60">
|
|
61
|
-
{formatDistanceToNow(new Date(pr.createdAt), { addSuffix: true })}
|
|
62
|
-
</span>
|
|
63
|
-
|
|
64
|
-
<ExternalLink className="h-3 w-3 shrink-0 text-muted-foreground/40 opacity-0 group-hover:opacity-100 transition-opacity" />
|
|
65
|
-
</a>
|
|
66
|
-
))}
|
|
67
|
-
</div>
|
|
68
|
-
);
|
|
69
|
-
}
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { GitFork, Circle, ArrowUp, ArrowDown } from 'lucide-react';
|
|
2
|
-
import { Badge } from '@/components/ui/badge';
|
|
3
|
-
import { cn } from '@/lib/utils';
|
|
4
|
-
import type { WorktreeDetail } from '@/types';
|
|
5
|
-
|
|
6
|
-
interface Props {
|
|
7
|
-
worktrees: WorktreeDetail[];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function WorktreeList({ worktrees }: Props) {
|
|
11
|
-
if (worktrees.length === 0) {
|
|
12
|
-
return (
|
|
13
|
-
<div className="py-6 text-center">
|
|
14
|
-
<GitFork className="mx-auto mb-2 h-8 w-8 text-muted-foreground/50" />
|
|
15
|
-
<p className="text-xs text-muted-foreground">No active worktrees.</p>
|
|
16
|
-
</div>
|
|
17
|
-
);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return (
|
|
21
|
-
<div className="space-y-1">
|
|
22
|
-
{worktrees.map(wt => (
|
|
23
|
-
<div
|
|
24
|
-
key={wt.path}
|
|
25
|
-
className="rounded border border-border/50 px-3 py-2 transition-colors hover:bg-surface-light"
|
|
26
|
-
>
|
|
27
|
-
<div className="flex items-center gap-2">
|
|
28
|
-
<GitFork className="h-3.5 w-3.5 shrink-0 text-primary" />
|
|
29
|
-
<code className="min-w-0 flex-1 truncate font-mono text-xs">
|
|
30
|
-
{wt.branch}
|
|
31
|
-
</code>
|
|
32
|
-
{wt.dirty && (
|
|
33
|
-
<Circle className="h-2 w-2 shrink-0 fill-warning-amber text-warning-amber" />
|
|
34
|
-
)}
|
|
35
|
-
<code className="shrink-0 font-mono text-xs text-muted-foreground/60">
|
|
36
|
-
{wt.head}
|
|
37
|
-
</code>
|
|
38
|
-
</div>
|
|
39
|
-
|
|
40
|
-
{/* Scope info */}
|
|
41
|
-
{wt.scopeId && (
|
|
42
|
-
<div className="mt-1 flex items-center gap-2">
|
|
43
|
-
<Badge variant="secondary" className="text-xs">
|
|
44
|
-
#{wt.scopeId}
|
|
45
|
-
</Badge>
|
|
46
|
-
{wt.scopeTitle && (
|
|
47
|
-
<span className="min-w-0 truncate text-xs text-muted-foreground">
|
|
48
|
-
{wt.scopeTitle}
|
|
49
|
-
</span>
|
|
50
|
-
)}
|
|
51
|
-
{wt.scopeStatus && (
|
|
52
|
-
<Badge variant="outline" className={cn('shrink-0 text-xs capitalize')}>
|
|
53
|
-
{wt.scopeStatus}
|
|
54
|
-
</Badge>
|
|
55
|
-
)}
|
|
56
|
-
</div>
|
|
57
|
-
)}
|
|
58
|
-
|
|
59
|
-
{/* Ahead/behind */}
|
|
60
|
-
{wt.aheadBehind && (wt.aheadBehind.ahead > 0 || wt.aheadBehind.behind > 0) && (
|
|
61
|
-
<div className="mt-1 flex items-center gap-2 text-xs">
|
|
62
|
-
{wt.aheadBehind.ahead > 0 && (
|
|
63
|
-
<span className="flex items-center gap-0.5 text-bid-green">
|
|
64
|
-
<ArrowUp className="h-2.5 w-2.5" />
|
|
65
|
-
{wt.aheadBehind.ahead} ahead
|
|
66
|
-
</span>
|
|
67
|
-
)}
|
|
68
|
-
{wt.aheadBehind.behind > 0 && (
|
|
69
|
-
<span className="flex items-center gap-0.5 text-ask-red">
|
|
70
|
-
<ArrowDown className="h-2.5 w-2.5" />
|
|
71
|
-
{wt.aheadBehind.behind} behind
|
|
72
|
-
</span>
|
|
73
|
-
)}
|
|
74
|
-
</div>
|
|
75
|
-
)}
|
|
76
|
-
</div>
|
|
77
|
-
))}
|
|
78
|
-
</div>
|
|
79
|
-
);
|
|
80
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { cva, type VariantProps } from 'class-variance-authority';
|
|
3
|
-
import { cn } from '@/lib/utils';
|
|
4
|
-
|
|
5
|
-
const badgeVariants = cva(
|
|
6
|
-
'inline-flex items-center rounded border px-1.5 py-0.5 text-xxs font-normal transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2',
|
|
7
|
-
{
|
|
8
|
-
variants: {
|
|
9
|
-
variant: {
|
|
10
|
-
default:
|
|
11
|
-
'border-transparent bg-primary text-primary-foreground hover:bg-primary/80',
|
|
12
|
-
secondary:
|
|
13
|
-
'border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80',
|
|
14
|
-
destructive:
|
|
15
|
-
'border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80',
|
|
16
|
-
outline: 'text-foreground',
|
|
17
|
-
success:
|
|
18
|
-
'border-transparent bg-[#00c85322] text-[#00c853] glow-green',
|
|
19
|
-
warning:
|
|
20
|
-
'border-transparent bg-[#ffab0022] text-[#ffab00] glow-amber',
|
|
21
|
-
error:
|
|
22
|
-
'border-transparent bg-[#ff174422] text-[#ff1744] glow-red',
|
|
23
|
-
},
|
|
24
|
-
},
|
|
25
|
-
defaultVariants: {
|
|
26
|
-
variant: 'default',
|
|
27
|
-
},
|
|
28
|
-
}
|
|
29
|
-
);
|
|
30
|
-
|
|
31
|
-
export interface BadgeProps
|
|
32
|
-
extends React.HTMLAttributes<HTMLDivElement>,
|
|
33
|
-
VariantProps<typeof badgeVariants> {}
|
|
34
|
-
|
|
35
|
-
function Badge({ className, variant, ...props }: BadgeProps) {
|
|
36
|
-
return (
|
|
37
|
-
<div className={cn(badgeVariants({ variant }), className)} {...props} />
|
|
38
|
-
);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
export { Badge, badgeVariants };
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { Slot } from '@radix-ui/react-slot';
|
|
3
|
-
import { cva, type VariantProps } from 'class-variance-authority';
|
|
4
|
-
import { cn } from '@/lib/utils';
|
|
5
|
-
|
|
6
|
-
const buttonVariants = cva(
|
|
7
|
-
'inline-flex items-center justify-center whitespace-nowrap rounded text-xs font-normal ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50',
|
|
8
|
-
{
|
|
9
|
-
variants: {
|
|
10
|
-
variant: {
|
|
11
|
-
default: 'bg-primary text-primary-foreground hover:bg-primary/90 glow-blue',
|
|
12
|
-
destructive:
|
|
13
|
-
'bg-destructive text-destructive-foreground hover:bg-destructive/90',
|
|
14
|
-
outline:
|
|
15
|
-
'border border-border bg-background hover:bg-surface-light hover:text-accent-foreground',
|
|
16
|
-
secondary:
|
|
17
|
-
'bg-secondary text-secondary-foreground hover:bg-secondary/80',
|
|
18
|
-
ghost: 'hover:bg-surface-light hover:text-accent-foreground',
|
|
19
|
-
link: 'text-primary underline-offset-4 hover:underline',
|
|
20
|
-
},
|
|
21
|
-
size: {
|
|
22
|
-
default: 'h-8 px-3 py-1.5',
|
|
23
|
-
sm: 'h-7 rounded px-2.5',
|
|
24
|
-
lg: 'h-9 rounded px-5',
|
|
25
|
-
icon: 'h-8 w-8',
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
defaultVariants: {
|
|
29
|
-
variant: 'default',
|
|
30
|
-
size: 'default',
|
|
31
|
-
},
|
|
32
|
-
}
|
|
33
|
-
);
|
|
34
|
-
|
|
35
|
-
export interface ButtonProps
|
|
36
|
-
extends React.ButtonHTMLAttributes<HTMLButtonElement>,
|
|
37
|
-
VariantProps<typeof buttonVariants> {
|
|
38
|
-
asChild?: boolean;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
const Button = React.forwardRef<HTMLButtonElement, ButtonProps>(
|
|
42
|
-
({ className, variant, size, asChild = false, ...props }, ref) => {
|
|
43
|
-
const Comp = asChild ? Slot : 'button';
|
|
44
|
-
return (
|
|
45
|
-
<Comp
|
|
46
|
-
className={cn(buttonVariants({ variant, size, className }))}
|
|
47
|
-
ref={ref}
|
|
48
|
-
{...props}
|
|
49
|
-
/>
|
|
50
|
-
);
|
|
51
|
-
}
|
|
52
|
-
);
|
|
53
|
-
Button.displayName = 'Button';
|
|
54
|
-
|
|
55
|
-
export { Button, buttonVariants };
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import { cn } from '@/lib/utils';
|
|
3
|
-
|
|
4
|
-
const Card = React.forwardRef<
|
|
5
|
-
HTMLDivElement,
|
|
6
|
-
React.HTMLAttributes<HTMLDivElement>
|
|
7
|
-
>(({ className, ...props }, ref) => (
|
|
8
|
-
<div
|
|
9
|
-
ref={ref}
|
|
10
|
-
className={cn(
|
|
11
|
-
'card-glass rounded border bg-card text-card-foreground shadow-none',
|
|
12
|
-
className
|
|
13
|
-
)}
|
|
14
|
-
{...props}
|
|
15
|
-
/>
|
|
16
|
-
));
|
|
17
|
-
Card.displayName = 'Card';
|
|
18
|
-
|
|
19
|
-
const CardHeader = React.forwardRef<
|
|
20
|
-
HTMLDivElement,
|
|
21
|
-
React.HTMLAttributes<HTMLDivElement>
|
|
22
|
-
>(({ className, ...props }, ref) => (
|
|
23
|
-
<div
|
|
24
|
-
ref={ref}
|
|
25
|
-
className={cn('flex flex-col space-y-0.5 px-3 py-2', className)}
|
|
26
|
-
{...props}
|
|
27
|
-
/>
|
|
28
|
-
));
|
|
29
|
-
CardHeader.displayName = 'CardHeader';
|
|
30
|
-
|
|
31
|
-
const CardTitle = React.forwardRef<
|
|
32
|
-
HTMLHeadingElement,
|
|
33
|
-
React.HTMLAttributes<HTMLHeadingElement>
|
|
34
|
-
>(({ className, ...props }, ref) => (
|
|
35
|
-
<h3
|
|
36
|
-
ref={ref}
|
|
37
|
-
className={cn(
|
|
38
|
-
'text-sm font-light uppercase tracking-wider text-muted-foreground',
|
|
39
|
-
className
|
|
40
|
-
)}
|
|
41
|
-
{...props}
|
|
42
|
-
/>
|
|
43
|
-
));
|
|
44
|
-
CardTitle.displayName = 'CardTitle';
|
|
45
|
-
|
|
46
|
-
const CardDescription = React.forwardRef<
|
|
47
|
-
HTMLParagraphElement,
|
|
48
|
-
React.HTMLAttributes<HTMLParagraphElement>
|
|
49
|
-
>(({ className, ...props }, ref) => (
|
|
50
|
-
<p
|
|
51
|
-
ref={ref}
|
|
52
|
-
className={cn('text-xs text-muted-foreground', className)}
|
|
53
|
-
{...props}
|
|
54
|
-
/>
|
|
55
|
-
));
|
|
56
|
-
CardDescription.displayName = 'CardDescription';
|
|
57
|
-
|
|
58
|
-
const CardContent = React.forwardRef<
|
|
59
|
-
HTMLDivElement,
|
|
60
|
-
React.HTMLAttributes<HTMLDivElement>
|
|
61
|
-
>(({ className, ...props }, ref) => (
|
|
62
|
-
<div ref={ref} className={cn('p-3 pt-0', className)} {...props} />
|
|
63
|
-
));
|
|
64
|
-
CardContent.displayName = 'CardContent';
|
|
65
|
-
|
|
66
|
-
const CardFooter = React.forwardRef<
|
|
67
|
-
HTMLDivElement,
|
|
68
|
-
React.HTMLAttributes<HTMLDivElement>
|
|
69
|
-
>(({ className, ...props }, ref) => (
|
|
70
|
-
<div
|
|
71
|
-
ref={ref}
|
|
72
|
-
className={cn('flex items-center p-3 pt-0', className)}
|
|
73
|
-
{...props}
|
|
74
|
-
/>
|
|
75
|
-
));
|
|
76
|
-
CardFooter.displayName = 'CardFooter';
|
|
77
|
-
|
|
78
|
-
export { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent };
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import * as DialogPrimitive from '@radix-ui/react-dialog';
|
|
3
|
-
import { X } from 'lucide-react';
|
|
4
|
-
import { cn } from '@/lib/utils';
|
|
5
|
-
|
|
6
|
-
const Dialog = DialogPrimitive.Root;
|
|
7
|
-
const DialogTrigger = DialogPrimitive.Trigger;
|
|
8
|
-
const DialogPortal = DialogPrimitive.Portal;
|
|
9
|
-
const DialogClose = DialogPrimitive.Close;
|
|
10
|
-
|
|
11
|
-
const DialogOverlay = React.forwardRef<
|
|
12
|
-
React.ComponentRef<typeof DialogPrimitive.Overlay>,
|
|
13
|
-
React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>
|
|
14
|
-
>(({ className, ...props }, ref) => (
|
|
15
|
-
<DialogPrimitive.Overlay
|
|
16
|
-
ref={ref}
|
|
17
|
-
className={cn(
|
|
18
|
-
'fixed inset-0 z-50 bg-black/70 dialog-overlay-glass data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',
|
|
19
|
-
className,
|
|
20
|
-
)}
|
|
21
|
-
{...props}
|
|
22
|
-
/>
|
|
23
|
-
));
|
|
24
|
-
DialogOverlay.displayName = DialogPrimitive.Overlay.displayName;
|
|
25
|
-
|
|
26
|
-
const DialogContent = React.forwardRef<
|
|
27
|
-
React.ComponentRef<typeof DialogPrimitive.Content>,
|
|
28
|
-
React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>
|
|
29
|
-
>(({ className, children, ...props }, ref) => (
|
|
30
|
-
<DialogPortal>
|
|
31
|
-
<DialogOverlay />
|
|
32
|
-
<DialogPrimitive.Content
|
|
33
|
-
ref={ref}
|
|
34
|
-
className={cn(
|
|
35
|
-
'fixed left-1/2 top-1/2 z-50 -translate-x-1/2 -translate-y-1/2',
|
|
36
|
-
'w-full border bg-background shadow-lg duration-200',
|
|
37
|
-
'data-[state=open]:animate-in data-[state=closed]:animate-out',
|
|
38
|
-
'data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',
|
|
39
|
-
'data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95',
|
|
40
|
-
'data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%]',
|
|
41
|
-
'data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%]',
|
|
42
|
-
'card-glass rounded border-border bg-[#12121a]',
|
|
43
|
-
className,
|
|
44
|
-
)}
|
|
45
|
-
{...props}
|
|
46
|
-
>
|
|
47
|
-
{children}
|
|
48
|
-
<DialogPrimitive.Close className="absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground">
|
|
49
|
-
<X className="h-4 w-4" />
|
|
50
|
-
<span className="sr-only">Close</span>
|
|
51
|
-
</DialogPrimitive.Close>
|
|
52
|
-
</DialogPrimitive.Content>
|
|
53
|
-
</DialogPortal>
|
|
54
|
-
));
|
|
55
|
-
DialogContent.displayName = DialogPrimitive.Content.displayName;
|
|
56
|
-
|
|
57
|
-
function DialogHeader({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) {
|
|
58
|
-
return (
|
|
59
|
-
<div
|
|
60
|
-
className={cn('flex flex-col space-y-1.5 text-center sm:text-left', className)}
|
|
61
|
-
{...props}
|
|
62
|
-
/>
|
|
63
|
-
);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
function DialogTitle({ className, ...props }: React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>) {
|
|
67
|
-
return (
|
|
68
|
-
<DialogPrimitive.Title
|
|
69
|
-
className={cn('text-sm font-normal leading-none tracking-tight', className)}
|
|
70
|
-
{...props}
|
|
71
|
-
/>
|
|
72
|
-
);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
function DialogDescription({ className, ...props }: React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>) {
|
|
76
|
-
return (
|
|
77
|
-
<DialogPrimitive.Description
|
|
78
|
-
className={cn('text-sm text-muted-foreground', className)}
|
|
79
|
-
{...props}
|
|
80
|
-
/>
|
|
81
|
-
);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
export {
|
|
85
|
-
Dialog,
|
|
86
|
-
DialogPortal,
|
|
87
|
-
DialogOverlay,
|
|
88
|
-
DialogClose,
|
|
89
|
-
DialogTrigger,
|
|
90
|
-
DialogContent,
|
|
91
|
-
DialogHeader,
|
|
92
|
-
DialogTitle,
|
|
93
|
-
DialogDescription,
|
|
94
|
-
};
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import * as PopoverPrimitive from '@radix-ui/react-popover';
|
|
3
|
-
import { cn } from '@/lib/utils';
|
|
4
|
-
|
|
5
|
-
const Popover = PopoverPrimitive.Root;
|
|
6
|
-
const PopoverTrigger = PopoverPrimitive.Trigger;
|
|
7
|
-
const PopoverAnchor = PopoverPrimitive.Anchor;
|
|
8
|
-
|
|
9
|
-
const PopoverContent = React.forwardRef<
|
|
10
|
-
React.ComponentRef<typeof PopoverPrimitive.Content>,
|
|
11
|
-
React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>
|
|
12
|
-
>(({ className, align = 'start', sideOffset = 4, ...props }, ref) => (
|
|
13
|
-
<PopoverPrimitive.Portal>
|
|
14
|
-
<PopoverPrimitive.Content
|
|
15
|
-
ref={ref}
|
|
16
|
-
align={align}
|
|
17
|
-
sideOffset={sideOffset}
|
|
18
|
-
className={cn(
|
|
19
|
-
'z-50 min-w-[180px] rounded border border-border bg-popover p-2 text-popover-foreground shadow-md outline-none',
|
|
20
|
-
'data-[state=open]:animate-in data-[state=closed]:animate-out',
|
|
21
|
-
'data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0',
|
|
22
|
-
'data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95',
|
|
23
|
-
'data-[side=bottom]:slide-in-from-top-2',
|
|
24
|
-
'data-[side=top]:slide-in-from-bottom-2',
|
|
25
|
-
className
|
|
26
|
-
)}
|
|
27
|
-
{...props}
|
|
28
|
-
/>
|
|
29
|
-
</PopoverPrimitive.Portal>
|
|
30
|
-
));
|
|
31
|
-
PopoverContent.displayName = PopoverPrimitive.Content.displayName;
|
|
32
|
-
|
|
33
|
-
export { Popover, PopoverTrigger, PopoverContent, PopoverAnchor };
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area';
|
|
3
|
-
import { cn } from '@/lib/utils';
|
|
4
|
-
|
|
5
|
-
interface ScrollAreaProps extends React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.Root> {
|
|
6
|
-
orientation?: 'vertical' | 'horizontal' | 'both';
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
const ScrollArea = React.forwardRef<
|
|
10
|
-
React.ComponentRef<typeof ScrollAreaPrimitive.Root>,
|
|
11
|
-
ScrollAreaProps
|
|
12
|
-
>(({ className, children, orientation = 'vertical', ...props }, ref) => (
|
|
13
|
-
<ScrollAreaPrimitive.Root
|
|
14
|
-
ref={ref}
|
|
15
|
-
className={cn('relative overflow-hidden', className)}
|
|
16
|
-
{...props}
|
|
17
|
-
>
|
|
18
|
-
<ScrollAreaPrimitive.Viewport className="h-full w-full rounded-[inherit]">
|
|
19
|
-
{children}
|
|
20
|
-
</ScrollAreaPrimitive.Viewport>
|
|
21
|
-
{(orientation === 'vertical' || orientation === 'both') && (
|
|
22
|
-
<ScrollBar orientation="vertical" />
|
|
23
|
-
)}
|
|
24
|
-
{(orientation === 'horizontal' || orientation === 'both') && (
|
|
25
|
-
<ScrollBar orientation="horizontal" />
|
|
26
|
-
)}
|
|
27
|
-
<ScrollAreaPrimitive.Corner />
|
|
28
|
-
</ScrollAreaPrimitive.Root>
|
|
29
|
-
));
|
|
30
|
-
ScrollArea.displayName = ScrollAreaPrimitive.Root.displayName;
|
|
31
|
-
|
|
32
|
-
const ScrollBar = React.forwardRef<
|
|
33
|
-
React.ComponentRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>,
|
|
34
|
-
React.ComponentPropsWithoutRef<typeof ScrollAreaPrimitive.ScrollAreaScrollbar>
|
|
35
|
-
>(({ className, orientation = 'vertical', ...props }, ref) => (
|
|
36
|
-
<ScrollAreaPrimitive.ScrollAreaScrollbar
|
|
37
|
-
ref={ref}
|
|
38
|
-
orientation={orientation}
|
|
39
|
-
className={cn(
|
|
40
|
-
'flex touch-none select-none transition-colors',
|
|
41
|
-
orientation === 'vertical' &&
|
|
42
|
-
'h-full w-1.5 border-l border-l-transparent p-[1px]',
|
|
43
|
-
orientation === 'horizontal' &&
|
|
44
|
-
'h-1.5 flex-col border-t border-t-transparent p-[1px]',
|
|
45
|
-
className
|
|
46
|
-
)}
|
|
47
|
-
{...props}
|
|
48
|
-
>
|
|
49
|
-
<ScrollAreaPrimitive.ScrollAreaThumb className="relative flex-1 rounded-full bg-border" />
|
|
50
|
-
</ScrollAreaPrimitive.ScrollAreaScrollbar>
|
|
51
|
-
));
|
|
52
|
-
ScrollBar.displayName = ScrollAreaPrimitive.ScrollAreaScrollbar.displayName;
|
|
53
|
-
|
|
54
|
-
export { ScrollArea, ScrollBar };
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import * as SeparatorPrimitive from '@radix-ui/react-separator';
|
|
3
|
-
import { cn } from '@/lib/utils';
|
|
4
|
-
|
|
5
|
-
const Separator = React.forwardRef<
|
|
6
|
-
React.ComponentRef<typeof SeparatorPrimitive.Root>,
|
|
7
|
-
React.ComponentPropsWithoutRef<typeof SeparatorPrimitive.Root>
|
|
8
|
-
>(
|
|
9
|
-
(
|
|
10
|
-
{ className, orientation = 'horizontal', decorative = true, ...props },
|
|
11
|
-
ref
|
|
12
|
-
) => (
|
|
13
|
-
<SeparatorPrimitive.Root
|
|
14
|
-
ref={ref}
|
|
15
|
-
decorative={decorative}
|
|
16
|
-
orientation={orientation}
|
|
17
|
-
className={cn(
|
|
18
|
-
'shrink-0 bg-border',
|
|
19
|
-
orientation === 'horizontal' ? 'h-[1px] w-full' : 'h-full w-[1px]',
|
|
20
|
-
className
|
|
21
|
-
)}
|
|
22
|
-
{...props}
|
|
23
|
-
/>
|
|
24
|
-
)
|
|
25
|
-
);
|
|
26
|
-
Separator.displayName = SeparatorPrimitive.Root.displayName;
|
|
27
|
-
|
|
28
|
-
export { Separator };
|