orbital-command 0.2.0 → 1.0.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/README.md +67 -42
- package/bin/commands/config.js +19 -0
- package/bin/commands/events.js +40 -0
- package/bin/commands/launch.js +126 -0
- package/bin/commands/manifest.js +283 -0
- package/bin/commands/registry.js +104 -0
- package/bin/commands/update.js +24 -0
- package/bin/lib/helpers.js +229 -0
- package/bin/orbital.js +147 -319
- package/dist/assets/Landing-CfQdHR0N.js +11 -0
- package/dist/assets/PrimitivesConfig-DThSipFy.js +32 -0
- package/dist/assets/QualityGates-B4kxM5UU.js +26 -0
- package/dist/assets/SessionTimeline-Bz1iZnmg.js +1 -0
- package/dist/assets/Settings-DLcZwbCT.js +12 -0
- package/dist/assets/SourceControl-BMNIz7Lt.js +36 -0
- package/dist/assets/WorkflowVisualizer-CxuSBOYu.js +69 -0
- package/dist/assets/arrow-down-DVPp6_qp.js +6 -0
- package/dist/assets/bot-NFaJBDn_.js +6 -0
- package/dist/assets/charts-LGLb8hyU.js +68 -0
- package/dist/assets/circle-x-IsFCkBZu.js +6 -0
- package/dist/assets/file-text-J1cebZXF.js +6 -0
- package/dist/assets/globe-WzeyHsUc.js +6 -0
- package/dist/assets/index-BdJ57EhC.css +1 -0
- package/dist/assets/index-o4ScMAuR.js +349 -0
- package/dist/assets/key-CKR8JJSj.js +6 -0
- package/dist/assets/minus-CHBsJyjp.js +6 -0
- package/dist/assets/radio-xqZaR-Uk.js +6 -0
- package/dist/assets/rocket-D_xvvNG6.js +6 -0
- package/dist/assets/shield-TdB1yv_a.js +6 -0
- package/dist/assets/ui-BmsSg9jU.js +53 -0
- package/dist/assets/useSocketListener-0L5yiN5i.js +1 -0
- package/dist/assets/useWorkflowEditor-CqeRWVQX.js +11 -0
- package/dist/assets/{vendor-Dzv9lrRc.js → vendor-Bqt8AJn2.js} +1 -1
- package/dist/assets/workflow-constants-Rw-GmgHZ.js +6 -0
- package/dist/assets/zap-C9wqYMpl.js +6 -0
- package/dist/favicon.svg +1 -0
- package/dist/index.html +6 -5
- package/dist/server/server/__tests__/data-routes.test.js +126 -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 +138 -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 +135 -0
- package/dist/server/server/config.js +51 -7
- package/dist/server/server/database.js +21 -28
- package/dist/server/server/global-config.js +143 -0
- package/dist/server/server/index.js +118 -276
- package/dist/server/server/init.js +243 -225
- 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.js +4 -1
- 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 +265 -0
- package/dist/server/server/project-emitter.js +41 -0
- package/dist/server/server/project-manager.js +297 -0
- package/dist/server/server/routes/aggregate-routes.js +871 -0
- package/dist/server/server/routes/config-routes.js +41 -90
- package/dist/server/server/routes/data-routes.js +25 -123
- package/dist/server/server/routes/dispatch-routes.js +37 -15
- 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 +45 -28
- 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 +3 -0
- package/dist/server/server/services/batch-orchestrator.js +41 -17
- package/dist/server/server/services/claude-session-service.js +17 -14
- package/dist/server/server/services/config-service.js +10 -1
- 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 +222 -131
- package/dist/server/server/services/scope-service.test.js +137 -0
- package/dist/server/server/services/sprint-orchestrator.js +29 -15
- package/dist/server/server/services/sprint-service.js +23 -3
- 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/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/uninstall.js +195 -0
- package/dist/server/server/update-planner.js +279 -0
- package/dist/server/server/update.js +212 -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 +83 -24
- package/dist/server/server/utils/dispatch-utils.test.js +182 -0
- package/dist/server/server/utils/flag-builder.js +54 -0
- package/dist/server/server/utils/json-fields.js +14 -0
- package/dist/server/server/utils/json-fields.test.js +73 -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 +47 -0
- package/dist/server/server/utils/route-helpers.test.js +115 -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/event-watcher.js +28 -13
- 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 +340 -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 +32 -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 +73 -0
- package/dist/server/shared/__fixtures__/workflow-configs.js +75 -0
- package/dist/server/shared/api-types.js +80 -1
- 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.js +1 -1
- 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 +34 -29
- package/schemas/orbital.config.schema.json +2 -5
- package/scripts/postinstall.js +18 -6
- package/scripts/release.sh +53 -0
- package/server/__tests__/data-routes.test.ts +151 -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 +158 -0
- package/server/__tests__/sprint-routes.test.ts +118 -0
- package/server/__tests__/workflow-routes.test.ts +120 -0
- package/server/config-migrator.ts +160 -0
- package/server/config.ts +64 -12
- package/server/database.ts +22 -31
- package/server/global-config.ts +204 -0
- package/server/index.ts +139 -316
- package/server/init.ts +266 -234
- 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/event-parser.ts +4 -1
- package/server/parsers/scope-parser.test.ts +270 -0
- package/server/parsers/scope-parser.ts +79 -31
- package/server/project-context.ts +325 -0
- package/server/project-emitter.ts +50 -0
- package/server/project-manager.ts +368 -0
- package/server/routes/aggregate-routes.ts +968 -0
- package/server/routes/config-routes.ts +43 -85
- package/server/routes/data-routes.ts +34 -156
- package/server/routes/dispatch-routes.ts +46 -17
- package/server/routes/git-routes.ts +77 -0
- package/server/routes/manifest-routes.ts +388 -0
- package/server/routes/scope-routes.ts +39 -30
- 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 +3 -0
- package/server/services/batch-orchestrator.ts +41 -17
- package/server/services/claude-session-service.ts +16 -14
- package/server/services/config-service.ts +10 -1
- 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 +224 -130
- package/server/services/sprint-orchestrator.ts +30 -15
- package/server/services/sprint-service.test.ts +271 -0
- package/server/services/sprint-service.ts +29 -5
- package/server/services/sync-service.ts +482 -0
- package/server/services/sync-types.ts +77 -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/uninstall.ts +214 -0
- package/server/update-planner.ts +346 -0
- package/server/update.ts +263 -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 +102 -30
- package/server/utils/flag-builder.ts +56 -0
- package/server/utils/json-fields.test.ts +83 -0
- package/server/utils/json-fields.ts +14 -0
- package/server/utils/logger.ts +40 -3
- package/server/utils/package-info.ts +32 -0
- package/server/utils/route-helpers.test.ts +144 -0
- package/server/utils/route-helpers.ts +50 -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/event-watcher.ts +24 -12
- 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 +438 -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 +39 -0
- package/server/wizard/phases/workflow-setup.ts +28 -0
- package/server/wizard/types.ts +56 -0
- package/server/wizard/ui.ts +92 -0
- package/shared/__fixtures__/workflow-configs.ts +80 -0
- package/shared/api-types.ts +106 -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-engine.ts +1 -1
- package/shared/workflow-normalizer.test.ts +119 -0
- package/shared/workflow-normalizer.ts +118 -0
- package/templates/agents/QUICK-REFERENCE.md +1 -0
- package/templates/agents/README.md +1 -0
- package/templates/agents/SKILL-TRIGGERS.md +11 -0
- package/templates/agents/green-team/deep-dive.md +361 -0
- package/templates/hooks/end-session.sh +4 -1
- package/templates/hooks/init-session.sh +1 -0
- 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-commit-logger.sh +2 -2
- package/templates/hooks/scope-create-cleanup.sh +2 -2
- package/templates/hooks/scope-create-gate.sh +2 -5
- package/templates/hooks/scope-gate.sh +4 -6
- package/templates/hooks/scope-helpers.sh +28 -1
- package/templates/hooks/scope-lifecycle-gate.sh +14 -5
- package/templates/hooks/scope-prepare.sh +67 -12
- package/templates/hooks/scope-transition.sh +14 -6
- package/templates/hooks/time-tracker.sh +2 -5
- package/templates/migrations/renames.json +1 -0
- package/templates/orbital.config.json +8 -6
- package/{shared/default-workflow.json → templates/presets/default.json} +65 -0
- package/templates/presets/development.json +4 -4
- package/templates/presets/gitflow.json +7 -0
- package/templates/prompts/README.md +23 -0
- package/templates/prompts/deep-dive-audit.md +94 -0
- package/templates/quick/rules.md +56 -5
- package/templates/settings-hooks.json +1 -1
- package/templates/skills/git-commit/SKILL.md +27 -7
- package/templates/skills/git-dev/SKILL.md +13 -4
- package/templates/skills/git-main/SKILL.md +13 -3
- package/templates/skills/git-production/SKILL.md +9 -2
- package/templates/skills/git-staging/SKILL.md +11 -3
- package/templates/skills/scope-create/SKILL.md +17 -3
- package/templates/skills/scope-fix-review/SKILL.md +14 -7
- package/templates/skills/scope-implement/SKILL.md +15 -4
- package/templates/skills/scope-post-review/SKILL.md +77 -7
- package/templates/skills/scope-pre-review/SKILL.md +11 -4
- 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 -38
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
import { useMemo } from 'react';
|
|
2
|
-
import { useDroppable } from '@dnd-kit/core';
|
|
3
|
-
import { ArrowDown, Terminal, Zap, Users } from 'lucide-react';
|
|
4
|
-
import { Card } from '@/components/ui/card';
|
|
5
|
-
import { Badge } from '@/components/ui/badge';
|
|
6
|
-
import { ScrollArea } from '@/components/ui/scroll-area';
|
|
7
|
-
import { cn } from '@/lib/utils';
|
|
8
|
-
import { useWorkflow } from '@/hooks/useWorkflow';
|
|
9
|
-
import type { ConfigPrimitiveType } from '@/types';
|
|
10
|
-
import type { WorkflowList, WorkflowEdge } from '../../../shared/workflow-config';
|
|
11
|
-
|
|
12
|
-
interface WorkflowPipelineProps {
|
|
13
|
-
type: ConfigPrimitiveType;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/** A droppable zone on the pipeline where tree items can be dropped */
|
|
17
|
-
function PipelineDropZone({ id, children, className }: { id: string; children: React.ReactNode; className?: string }) {
|
|
18
|
-
const { isOver, setNodeRef } = useDroppable({ id });
|
|
19
|
-
|
|
20
|
-
return (
|
|
21
|
-
<div
|
|
22
|
-
ref={setNodeRef}
|
|
23
|
-
className={cn(
|
|
24
|
-
'rounded border border-dashed border-transparent transition-colors',
|
|
25
|
-
isOver && 'border-accent-blue/40 bg-accent-blue/5',
|
|
26
|
-
className,
|
|
27
|
-
)}
|
|
28
|
-
>
|
|
29
|
-
{children}
|
|
30
|
-
</div>
|
|
31
|
-
);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/** A single workflow list card in the pipeline */
|
|
35
|
-
function ListCard({
|
|
36
|
-
list,
|
|
37
|
-
type,
|
|
38
|
-
outEdges,
|
|
39
|
-
}: {
|
|
40
|
-
list: WorkflowList;
|
|
41
|
-
type: ConfigPrimitiveType;
|
|
42
|
-
outEdges: WorkflowEdge[];
|
|
43
|
-
}) {
|
|
44
|
-
const hookBadges = type === 'hooks' && list.activeHooks?.length
|
|
45
|
-
? list.activeHooks
|
|
46
|
-
: [];
|
|
47
|
-
|
|
48
|
-
return (
|
|
49
|
-
<PipelineDropZone id={`pipeline-list-${list.id}`}>
|
|
50
|
-
<Card className="overflow-hidden">
|
|
51
|
-
<div className="flex items-center gap-2 px-3 py-2">
|
|
52
|
-
<div
|
|
53
|
-
className="h-2.5 w-2.5 shrink-0 rounded-full"
|
|
54
|
-
style={{ backgroundColor: list.hex }}
|
|
55
|
-
/>
|
|
56
|
-
<span className="text-xs font-medium text-foreground">{list.label}</span>
|
|
57
|
-
<span className="text-[10px] text-muted-foreground/50 font-mono">{list.id}</span>
|
|
58
|
-
</div>
|
|
59
|
-
|
|
60
|
-
{/* Hook badges on list (hooks mode) */}
|
|
61
|
-
{hookBadges.length > 0 && (
|
|
62
|
-
<div className="flex flex-wrap gap-1 border-t border-border px-3 py-1.5">
|
|
63
|
-
{hookBadges.map((hook) => (
|
|
64
|
-
<Badge key={hook} variant="secondary" className="text-[10px] gap-1 px-1.5 py-0">
|
|
65
|
-
<Zap className="h-2.5 w-2.5" />
|
|
66
|
-
{hook}
|
|
67
|
-
</Badge>
|
|
68
|
-
))}
|
|
69
|
-
</div>
|
|
70
|
-
)}
|
|
71
|
-
</Card>
|
|
72
|
-
|
|
73
|
-
{/* Outgoing edges */}
|
|
74
|
-
{outEdges.map((edge) => (
|
|
75
|
-
<EdgeSlot key={`${edge.from}:${edge.to}`} edge={edge} type={type} />
|
|
76
|
-
))}
|
|
77
|
-
</PipelineDropZone>
|
|
78
|
-
);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/** The connector between two lists, showing edge metadata */
|
|
82
|
-
function EdgeSlot({ edge, type }: { edge: WorkflowEdge; type: ConfigPrimitiveType }) {
|
|
83
|
-
const showCommand = type === 'skills' && edge.command;
|
|
84
|
-
const showAgents = type === 'agents' && edge.agents?.length;
|
|
85
|
-
const hasContent = showCommand || showAgents;
|
|
86
|
-
|
|
87
|
-
return (
|
|
88
|
-
<PipelineDropZone id={`pipeline-edge-${edge.from}:${edge.to}`} className="my-1">
|
|
89
|
-
<div className="flex items-center gap-2 px-4 py-1">
|
|
90
|
-
<ArrowDown className="h-3 w-3 shrink-0 text-muted-foreground/40" />
|
|
91
|
-
<span className="text-[10px] text-muted-foreground/60 truncate">
|
|
92
|
-
{edge.label}
|
|
93
|
-
</span>
|
|
94
|
-
|
|
95
|
-
{hasContent && (
|
|
96
|
-
<div className="ml-auto flex items-center gap-1">
|
|
97
|
-
{showCommand && (
|
|
98
|
-
<Badge variant="outline" className="text-[10px] gap-1 px-1.5 py-0 text-accent-blue border-accent-blue/30">
|
|
99
|
-
<Terminal className="h-2.5 w-2.5" />
|
|
100
|
-
{edge.command}
|
|
101
|
-
</Badge>
|
|
102
|
-
)}
|
|
103
|
-
{showAgents && edge.agents?.map((agent) => (
|
|
104
|
-
<Badge key={agent} variant="outline" className="text-[10px] gap-1 px-1.5 py-0 text-purple-400 border-purple-400/30">
|
|
105
|
-
<Users className="h-2.5 w-2.5" />
|
|
106
|
-
{agent}
|
|
107
|
-
</Badge>
|
|
108
|
-
))}
|
|
109
|
-
</div>
|
|
110
|
-
)}
|
|
111
|
-
</div>
|
|
112
|
-
</PipelineDropZone>
|
|
113
|
-
);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
export function WorkflowPipeline({ type }: WorkflowPipelineProps) {
|
|
117
|
-
const { engine } = useWorkflow();
|
|
118
|
-
|
|
119
|
-
const lists = useMemo(() => engine.getLists(), [engine]);
|
|
120
|
-
const edges = useMemo(() => engine.getAllEdges(), [engine]);
|
|
121
|
-
|
|
122
|
-
// Group edges by source list for rendering
|
|
123
|
-
const edgesByFrom = useMemo(() => {
|
|
124
|
-
const map = new Map<string, WorkflowEdge[]>();
|
|
125
|
-
for (const edge of edges) {
|
|
126
|
-
if (edge.direction !== 'forward') continue; // Only show forward edges in pipeline
|
|
127
|
-
const existing = map.get(edge.from);
|
|
128
|
-
if (existing) existing.push(edge);
|
|
129
|
-
else map.set(edge.from, [edge]);
|
|
130
|
-
}
|
|
131
|
-
return map;
|
|
132
|
-
}, [edges]);
|
|
133
|
-
|
|
134
|
-
return (
|
|
135
|
-
<div className="flex h-full flex-col">
|
|
136
|
-
{/* Header */}
|
|
137
|
-
<div className="flex items-center justify-between border-b border-border px-3 py-2">
|
|
138
|
-
<span className="text-xxs font-medium uppercase tracking-wider text-muted-foreground">
|
|
139
|
-
Workflow Pipeline
|
|
140
|
-
</span>
|
|
141
|
-
<Badge variant="secondary" className="text-[10px]">
|
|
142
|
-
{lists.length} stages
|
|
143
|
-
</Badge>
|
|
144
|
-
</div>
|
|
145
|
-
|
|
146
|
-
{/* Pipeline */}
|
|
147
|
-
<ScrollArea className="flex-1">
|
|
148
|
-
<div className="space-y-0 p-3">
|
|
149
|
-
{lists.map((list) => (
|
|
150
|
-
<ListCard
|
|
151
|
-
key={list.id}
|
|
152
|
-
list={list}
|
|
153
|
-
type={type}
|
|
154
|
-
outEdges={edgesByFrom.get(list.id) ?? []}
|
|
155
|
-
/>
|
|
156
|
-
))}
|
|
157
|
-
</div>
|
|
158
|
-
</ScrollArea>
|
|
159
|
-
</div>
|
|
160
|
-
);
|
|
161
|
-
}
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
import { formatDistanceToNow } from 'date-fns';
|
|
2
|
-
import { GitBranch, ArrowUp, ArrowDown } from 'lucide-react';
|
|
3
|
-
import { Badge } from '@/components/ui/badge';
|
|
4
|
-
import { cn } from '@/lib/utils';
|
|
5
|
-
import type { BranchInfoData } from '@/types';
|
|
6
|
-
|
|
7
|
-
interface Props {
|
|
8
|
-
branches: BranchInfoData[];
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export function BranchList({ branches }: Props) {
|
|
12
|
-
// Sort: current first, then by date descending, stale at bottom
|
|
13
|
-
const sorted = [...branches]
|
|
14
|
-
.filter(b => !b.isRemote)
|
|
15
|
-
.sort((a, b) => {
|
|
16
|
-
if (a.isCurrent) return -1;
|
|
17
|
-
if (b.isCurrent) return 1;
|
|
18
|
-
if (a.isStale !== b.isStale) return a.isStale ? 1 : -1;
|
|
19
|
-
return new Date(b.headDate).getTime() - new Date(a.headDate).getTime();
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
if (sorted.length === 0) {
|
|
23
|
-
return (
|
|
24
|
-
<div className="py-6 text-center">
|
|
25
|
-
<GitBranch className="mx-auto mb-2 h-8 w-8 text-muted-foreground/50" />
|
|
26
|
-
<p className="text-xs text-muted-foreground">No branches found.</p>
|
|
27
|
-
</div>
|
|
28
|
-
);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
return (
|
|
32
|
-
<div className="space-y-0.5">
|
|
33
|
-
{sorted.map(branch => (
|
|
34
|
-
<div
|
|
35
|
-
key={branch.name}
|
|
36
|
-
className={cn(
|
|
37
|
-
'flex items-center gap-2 rounded px-2.5 py-1.5 transition-colors hover:bg-surface-light',
|
|
38
|
-
branch.isStale && 'opacity-50',
|
|
39
|
-
)}
|
|
40
|
-
>
|
|
41
|
-
<GitBranch className={cn(
|
|
42
|
-
'h-3.5 w-3.5 shrink-0',
|
|
43
|
-
branch.isCurrent ? 'text-primary' : 'text-muted-foreground',
|
|
44
|
-
)} />
|
|
45
|
-
|
|
46
|
-
<span className={cn(
|
|
47
|
-
'min-w-0 flex-1 truncate font-mono text-xs',
|
|
48
|
-
branch.isCurrent && 'text-foreground font-medium',
|
|
49
|
-
)}>
|
|
50
|
-
{branch.name}
|
|
51
|
-
</span>
|
|
52
|
-
|
|
53
|
-
{/* Scope badge */}
|
|
54
|
-
{branch.scopeId && (
|
|
55
|
-
<Badge variant="secondary" className="shrink-0 text-xs">
|
|
56
|
-
#{branch.scopeId}
|
|
57
|
-
</Badge>
|
|
58
|
-
)}
|
|
59
|
-
|
|
60
|
-
{/* Ahead/behind */}
|
|
61
|
-
{branch.aheadBehind && (
|
|
62
|
-
<div className="flex shrink-0 items-center gap-1 text-xs">
|
|
63
|
-
{branch.aheadBehind.ahead > 0 && (
|
|
64
|
-
<span className="flex items-center gap-0.5 text-bid-green">
|
|
65
|
-
<ArrowUp className="h-2.5 w-2.5" />
|
|
66
|
-
{branch.aheadBehind.ahead}
|
|
67
|
-
</span>
|
|
68
|
-
)}
|
|
69
|
-
{branch.aheadBehind.behind > 0 && (
|
|
70
|
-
<span className="flex items-center gap-0.5 text-ask-red">
|
|
71
|
-
<ArrowDown className="h-2.5 w-2.5" />
|
|
72
|
-
{branch.aheadBehind.behind}
|
|
73
|
-
</span>
|
|
74
|
-
)}
|
|
75
|
-
</div>
|
|
76
|
-
)}
|
|
77
|
-
|
|
78
|
-
{/* SHA */}
|
|
79
|
-
<code className="shrink-0 font-mono text-xs text-muted-foreground/60">
|
|
80
|
-
{branch.headSha}
|
|
81
|
-
</code>
|
|
82
|
-
|
|
83
|
-
{/* Last commit time */}
|
|
84
|
-
{branch.headDate && (
|
|
85
|
-
<span className="shrink-0 text-xs text-muted-foreground/60">
|
|
86
|
-
{formatDistanceToNow(new Date(branch.headDate), { addSuffix: true })}
|
|
87
|
-
</span>
|
|
88
|
-
)}
|
|
89
|
-
</div>
|
|
90
|
-
))}
|
|
91
|
-
</div>
|
|
92
|
-
);
|
|
93
|
-
}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import { useState } from 'react';
|
|
2
|
-
import { GitBranch, GitFork, ArrowRight } from 'lucide-react';
|
|
3
|
-
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
|
|
4
|
-
import { Badge } from '@/components/ui/badge';
|
|
5
|
-
import { ScrollArea } from '@/components/ui/scroll-area';
|
|
6
|
-
import { BranchList } from './BranchList';
|
|
7
|
-
import { WorktreeList } from './WorktreeList';
|
|
8
|
-
import type { BranchInfoData, WorktreeDetail, DriftPair } from '@/types';
|
|
9
|
-
import { cn } from '@/lib/utils';
|
|
10
|
-
|
|
11
|
-
interface Props {
|
|
12
|
-
branches: BranchInfoData[];
|
|
13
|
-
worktrees: WorktreeDetail[];
|
|
14
|
-
drift: DriftPair[];
|
|
15
|
-
branchingMode: 'trunk' | 'worktree';
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
type PanelTab = 'branches' | 'worktrees';
|
|
19
|
-
|
|
20
|
-
function driftColor(count: number): string {
|
|
21
|
-
if (count === 0) return 'text-bid-green';
|
|
22
|
-
if (count <= 5) return 'text-accent-blue';
|
|
23
|
-
if (count <= 20) return 'text-warning-amber';
|
|
24
|
-
return 'text-ask-red';
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
export function BranchPanel({ branches, worktrees, drift, branchingMode }: Props) {
|
|
28
|
-
const showWorktrees = branchingMode === 'worktree';
|
|
29
|
-
const [tab, setTab] = useState<PanelTab>('branches');
|
|
30
|
-
|
|
31
|
-
return (
|
|
32
|
-
<Card>
|
|
33
|
-
<CardHeader className="pb-2">
|
|
34
|
-
<div className="flex items-center justify-between">
|
|
35
|
-
<CardTitle className="flex items-center gap-2 text-base">
|
|
36
|
-
<GitBranch className="h-4 w-4 text-primary" />
|
|
37
|
-
{showWorktrees ? (tab === 'branches' ? 'Branches' : 'Worktrees') : 'Branches'}
|
|
38
|
-
<Badge variant="secondary">
|
|
39
|
-
{tab === 'branches' ? branches.filter(b => !b.isRemote).length : worktrees.length}
|
|
40
|
-
</Badge>
|
|
41
|
-
</CardTitle>
|
|
42
|
-
{showWorktrees && (
|
|
43
|
-
<div className="flex gap-1">
|
|
44
|
-
<button
|
|
45
|
-
onClick={() => setTab('branches')}
|
|
46
|
-
className={cn(
|
|
47
|
-
'rounded-md px-2.5 py-1 text-xs transition-colors',
|
|
48
|
-
tab === 'branches'
|
|
49
|
-
? 'bg-surface-light text-foreground'
|
|
50
|
-
: 'text-muted-foreground hover:text-foreground',
|
|
51
|
-
)}
|
|
52
|
-
>
|
|
53
|
-
<GitBranch className="inline h-3 w-3 mr-1" />
|
|
54
|
-
Branches
|
|
55
|
-
</button>
|
|
56
|
-
<button
|
|
57
|
-
onClick={() => setTab('worktrees')}
|
|
58
|
-
className={cn(
|
|
59
|
-
'rounded-md px-2.5 py-1 text-xs transition-colors',
|
|
60
|
-
tab === 'worktrees'
|
|
61
|
-
? 'bg-surface-light text-foreground'
|
|
62
|
-
: 'text-muted-foreground hover:text-foreground',
|
|
63
|
-
)}
|
|
64
|
-
>
|
|
65
|
-
<GitFork className="inline h-3 w-3 mr-1" />
|
|
66
|
-
Worktrees
|
|
67
|
-
</button>
|
|
68
|
-
</div>
|
|
69
|
-
)}
|
|
70
|
-
</div>
|
|
71
|
-
</CardHeader>
|
|
72
|
-
<CardContent>
|
|
73
|
-
<ScrollArea className="max-h-[400px]">
|
|
74
|
-
{tab === 'branches' ? (
|
|
75
|
-
<BranchList branches={branches} />
|
|
76
|
-
) : (
|
|
77
|
-
<WorktreeList worktrees={worktrees} />
|
|
78
|
-
)}
|
|
79
|
-
</ScrollArea>
|
|
80
|
-
|
|
81
|
-
{/* Drift indicators */}
|
|
82
|
-
{drift.length > 0 && (
|
|
83
|
-
<div className="mt-4 border-t border-border pt-3">
|
|
84
|
-
<h4 className="mb-2 text-xs font-medium text-muted-foreground">Branch Drift</h4>
|
|
85
|
-
<div className="space-y-1.5">
|
|
86
|
-
{drift.map(d => (
|
|
87
|
-
<div key={`${d.from}-${d.to}`} className="flex items-center gap-2 text-xs">
|
|
88
|
-
<code className="font-mono text-muted-foreground">{d.from}</code>
|
|
89
|
-
<ArrowRight className="h-3 w-3 text-muted-foreground/50" />
|
|
90
|
-
<code className="font-mono text-muted-foreground">{d.to}</code>
|
|
91
|
-
<Badge
|
|
92
|
-
variant="outline"
|
|
93
|
-
className={cn('ml-auto text-xs', driftColor(d.count))}
|
|
94
|
-
>
|
|
95
|
-
{d.count === 0 ? 'in sync' : `${d.count} commit${d.count !== 1 ? 's' : ''}`}
|
|
96
|
-
</Badge>
|
|
97
|
-
</div>
|
|
98
|
-
))}
|
|
99
|
-
</div>
|
|
100
|
-
</div>
|
|
101
|
-
)}
|
|
102
|
-
</CardContent>
|
|
103
|
-
</Card>
|
|
104
|
-
);
|
|
105
|
-
}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { useState, useMemo } from 'react';
|
|
2
|
-
import { GitCommit } from 'lucide-react';
|
|
3
|
-
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
|
|
4
|
-
import { Badge } from '@/components/ui/badge';
|
|
5
|
-
import { ScrollArea } from '@/components/ui/scroll-area';
|
|
6
|
-
import { CommitRow } from './CommitRow';
|
|
7
|
-
import type { CommitEntry, BranchInfoData } from '@/types';
|
|
8
|
-
|
|
9
|
-
interface Props {
|
|
10
|
-
commits: CommitEntry[];
|
|
11
|
-
branches: BranchInfoData[];
|
|
12
|
-
hasMore: boolean;
|
|
13
|
-
onLoadMore: () => void;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
type FilterTab = 'all' | 'main' | 'feature';
|
|
17
|
-
|
|
18
|
-
export function CommitLog({ commits, branches, hasMore, onLoadMore }: Props) {
|
|
19
|
-
const [filter, setFilter] = useState<FilterTab>('all');
|
|
20
|
-
|
|
21
|
-
const mainBranches = useMemo(() => {
|
|
22
|
-
const names = new Set(['main', 'master', 'dev', 'develop', 'staging', 'production']);
|
|
23
|
-
for (const b of branches) {
|
|
24
|
-
if (!b.isRemote && !b.name.startsWith('feat/') && !b.name.startsWith('fix/')) {
|
|
25
|
-
names.add(b.name);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
return names;
|
|
29
|
-
}, [branches]);
|
|
30
|
-
|
|
31
|
-
const filtered = useMemo(() => {
|
|
32
|
-
if (filter === 'all') return commits;
|
|
33
|
-
if (filter === 'main') {
|
|
34
|
-
return commits.filter(c => !c.branch || mainBranches.has(c.branch));
|
|
35
|
-
}
|
|
36
|
-
// feature
|
|
37
|
-
return commits.filter(c => c.branch && !mainBranches.has(c.branch));
|
|
38
|
-
}, [commits, filter, mainBranches]);
|
|
39
|
-
|
|
40
|
-
const tabs: { key: FilterTab; label: string }[] = [
|
|
41
|
-
{ key: 'all', label: 'All' },
|
|
42
|
-
{ key: 'main', label: 'Main' },
|
|
43
|
-
{ key: 'feature', label: 'Feature' },
|
|
44
|
-
];
|
|
45
|
-
|
|
46
|
-
return (
|
|
47
|
-
<Card className="lg:col-span-2">
|
|
48
|
-
<CardHeader className="pb-2">
|
|
49
|
-
<div className="flex items-center justify-between">
|
|
50
|
-
<CardTitle className="flex items-center gap-2 text-base">
|
|
51
|
-
<GitCommit className="h-4 w-4 text-primary" />
|
|
52
|
-
Commits
|
|
53
|
-
<Badge variant="secondary">{filtered.length}</Badge>
|
|
54
|
-
</CardTitle>
|
|
55
|
-
<div className="flex gap-1">
|
|
56
|
-
{tabs.map(tab => (
|
|
57
|
-
<button
|
|
58
|
-
key={tab.key}
|
|
59
|
-
onClick={() => setFilter(tab.key)}
|
|
60
|
-
className={`rounded-md px-2.5 py-1 text-xs transition-colors ${
|
|
61
|
-
filter === tab.key
|
|
62
|
-
? 'bg-surface-light text-foreground'
|
|
63
|
-
: 'text-muted-foreground hover:text-foreground'
|
|
64
|
-
}`}
|
|
65
|
-
>
|
|
66
|
-
{tab.label}
|
|
67
|
-
</button>
|
|
68
|
-
))}
|
|
69
|
-
</div>
|
|
70
|
-
</div>
|
|
71
|
-
</CardHeader>
|
|
72
|
-
<CardContent>
|
|
73
|
-
{filtered.length === 0 ? (
|
|
74
|
-
<div className="py-8 text-center">
|
|
75
|
-
<GitCommit className="mx-auto mb-3 h-10 w-10 text-muted-foreground/50" />
|
|
76
|
-
<p className="text-sm text-muted-foreground">No commits found.</p>
|
|
77
|
-
</div>
|
|
78
|
-
) : (
|
|
79
|
-
<>
|
|
80
|
-
<ScrollArea className="max-h-[600px]">
|
|
81
|
-
<div className="space-y-0.5">
|
|
82
|
-
{filtered.map(commit => (
|
|
83
|
-
<CommitRow key={commit.sha} commit={commit} />
|
|
84
|
-
))}
|
|
85
|
-
</div>
|
|
86
|
-
</ScrollArea>
|
|
87
|
-
{hasMore && (
|
|
88
|
-
<button
|
|
89
|
-
onClick={onLoadMore}
|
|
90
|
-
className="mt-3 w-full rounded border border-border py-2 text-xs text-muted-foreground transition-colors hover:bg-surface-light hover:text-foreground"
|
|
91
|
-
>
|
|
92
|
-
Load more commits
|
|
93
|
-
</button>
|
|
94
|
-
)}
|
|
95
|
-
</>
|
|
96
|
-
)}
|
|
97
|
-
</CardContent>
|
|
98
|
-
</Card>
|
|
99
|
-
);
|
|
100
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import { formatDistanceToNow } from 'date-fns';
|
|
2
|
-
import { Badge } from '@/components/ui/badge';
|
|
3
|
-
import type { CommitEntry } from '@/types';
|
|
4
|
-
|
|
5
|
-
interface Props {
|
|
6
|
-
commit: CommitEntry;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export function CommitRow({ commit }: Props) {
|
|
10
|
-
return (
|
|
11
|
-
<div className="flex items-center gap-3 rounded px-2.5 py-1.5 transition-colors hover:bg-surface-light">
|
|
12
|
-
{/* SHA */}
|
|
13
|
-
<code className="shrink-0 font-mono text-xs text-primary">
|
|
14
|
-
{commit.shortSha}
|
|
15
|
-
</code>
|
|
16
|
-
|
|
17
|
-
{/* Message */}
|
|
18
|
-
<span className="min-w-0 flex-1 truncate text-sm">
|
|
19
|
-
{commit.message}
|
|
20
|
-
</span>
|
|
21
|
-
|
|
22
|
-
{/* Branch ref badge */}
|
|
23
|
-
{commit.branch && (
|
|
24
|
-
<Badge variant="outline" className="shrink-0 text-xs font-normal">
|
|
25
|
-
{commit.branch}
|
|
26
|
-
</Badge>
|
|
27
|
-
)}
|
|
28
|
-
|
|
29
|
-
{/* Scope link */}
|
|
30
|
-
{commit.scopeId && (
|
|
31
|
-
<Badge variant="secondary" className="shrink-0 text-xs">
|
|
32
|
-
#{commit.scopeId}
|
|
33
|
-
</Badge>
|
|
34
|
-
)}
|
|
35
|
-
|
|
36
|
-
{/* Author */}
|
|
37
|
-
<span className="shrink-0 text-xs text-muted-foreground">
|
|
38
|
-
{commit.author}
|
|
39
|
-
</span>
|
|
40
|
-
|
|
41
|
-
{/* Time */}
|
|
42
|
-
<span className="shrink-0 text-xs text-muted-foreground/60">
|
|
43
|
-
{formatDistanceToNow(new Date(commit.date), { addSuffix: true })}
|
|
44
|
-
</span>
|
|
45
|
-
</div>
|
|
46
|
-
);
|
|
47
|
-
}
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { useState, useEffect, useCallback } from 'react';
|
|
2
|
-
import { Github, ChevronDown, ChevronRight, Eye, Lock, Globe } from 'lucide-react';
|
|
3
|
-
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
|
|
4
|
-
import { Badge } from '@/components/ui/badge';
|
|
5
|
-
import { GitHubSetupGuide } from './GitHubSetupGuide';
|
|
6
|
-
import { PullRequestList } from './PullRequestList';
|
|
7
|
-
import type { GitHubStatus, PullRequestInfo } from '@/types';
|
|
8
|
-
|
|
9
|
-
interface Props {
|
|
10
|
-
github: GitHubStatus | null;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export function GitHubPanel({ github }: Props) {
|
|
14
|
-
const [expanded, setExpanded] = useState(true);
|
|
15
|
-
const [prs, setPrs] = useState<PullRequestInfo[]>([]);
|
|
16
|
-
|
|
17
|
-
const fetchPRs = useCallback(async () => {
|
|
18
|
-
if (!github?.connected) return;
|
|
19
|
-
try {
|
|
20
|
-
const res = await fetch('/api/orbital/github/prs');
|
|
21
|
-
if (res.ok) setPrs(await res.json());
|
|
22
|
-
} catch { /* ok */ }
|
|
23
|
-
}, [github?.connected]);
|
|
24
|
-
|
|
25
|
-
useEffect(() => {
|
|
26
|
-
if (expanded && github?.connected) fetchPRs();
|
|
27
|
-
}, [expanded, github?.connected, fetchPRs]);
|
|
28
|
-
|
|
29
|
-
const VisibilityIcon = github?.repo?.visibility === 'public' ? Globe : Lock;
|
|
30
|
-
|
|
31
|
-
return (
|
|
32
|
-
<Card className="mt-6">
|
|
33
|
-
<CardHeader
|
|
34
|
-
className="cursor-pointer select-none"
|
|
35
|
-
onClick={() => setExpanded(!expanded)}
|
|
36
|
-
>
|
|
37
|
-
<CardTitle className="flex items-center gap-2 text-base">
|
|
38
|
-
{expanded ? (
|
|
39
|
-
<ChevronDown className="h-4 w-4 text-muted-foreground" />
|
|
40
|
-
) : (
|
|
41
|
-
<ChevronRight className="h-4 w-4 text-muted-foreground" />
|
|
42
|
-
)}
|
|
43
|
-
<Github className="h-4 w-4 text-primary" />
|
|
44
|
-
GitHub
|
|
45
|
-
{github?.connected && github.repo && (
|
|
46
|
-
<Badge variant="secondary" className="ml-1 text-xs gap-1">
|
|
47
|
-
<VisibilityIcon className="h-2.5 w-2.5" />
|
|
48
|
-
{github.repo.fullName}
|
|
49
|
-
</Badge>
|
|
50
|
-
)}
|
|
51
|
-
{github?.openPRs ? (
|
|
52
|
-
<Badge variant="outline" className="text-xs">
|
|
53
|
-
{github.openPRs} open PR{github.openPRs !== 1 ? 's' : ''}
|
|
54
|
-
</Badge>
|
|
55
|
-
) : null}
|
|
56
|
-
</CardTitle>
|
|
57
|
-
</CardHeader>
|
|
58
|
-
|
|
59
|
-
{expanded && (
|
|
60
|
-
<CardContent>
|
|
61
|
-
{!github || !github.connected ? (
|
|
62
|
-
<GitHubSetupGuide error={github?.error ?? null} />
|
|
63
|
-
) : (
|
|
64
|
-
<div className="space-y-4">
|
|
65
|
-
{/* Repo info */}
|
|
66
|
-
{github.repo && (
|
|
67
|
-
<div className="grid grid-cols-2 gap-x-4 gap-y-1 text-xs">
|
|
68
|
-
<span className="text-muted-foreground">Repository</span>
|
|
69
|
-
<a
|
|
70
|
-
href={github.repo.url}
|
|
71
|
-
target="_blank"
|
|
72
|
-
rel="noopener noreferrer"
|
|
73
|
-
className="text-primary hover:underline"
|
|
74
|
-
>
|
|
75
|
-
{github.repo.fullName}
|
|
76
|
-
</a>
|
|
77
|
-
|
|
78
|
-
<span className="text-muted-foreground">Default branch</span>
|
|
79
|
-
<code className="font-mono">{github.repo.defaultBranch}</code>
|
|
80
|
-
|
|
81
|
-
<span className="text-muted-foreground">Visibility</span>
|
|
82
|
-
<span className="flex items-center gap-1 capitalize">
|
|
83
|
-
<VisibilityIcon className="h-3 w-3" />
|
|
84
|
-
{github.repo.visibility}
|
|
85
|
-
</span>
|
|
86
|
-
|
|
87
|
-
{github.authUser && (
|
|
88
|
-
<>
|
|
89
|
-
<span className="text-muted-foreground">Signed in as</span>
|
|
90
|
-
<span>{github.authUser}</span>
|
|
91
|
-
</>
|
|
92
|
-
)}
|
|
93
|
-
</div>
|
|
94
|
-
)}
|
|
95
|
-
|
|
96
|
-
{/* PRs */}
|
|
97
|
-
<div className="border-t border-border pt-3">
|
|
98
|
-
<h4 className="mb-2 flex items-center gap-2 text-xs font-medium text-muted-foreground">
|
|
99
|
-
<Eye className="h-3 w-3" />
|
|
100
|
-
Open Pull Requests
|
|
101
|
-
</h4>
|
|
102
|
-
<PullRequestList prs={prs} />
|
|
103
|
-
</div>
|
|
104
|
-
</div>
|
|
105
|
-
)}
|
|
106
|
-
</CardContent>
|
|
107
|
-
)}
|
|
108
|
-
</Card>
|
|
109
|
-
);
|
|
110
|
-
}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { Terminal, ExternalLink } from 'lucide-react';
|
|
2
|
-
|
|
3
|
-
interface Props {
|
|
4
|
-
error: string | null;
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export function GitHubSetupGuide({ error }: Props) {
|
|
8
|
-
const isNotInstalled = error?.includes('not installed');
|
|
9
|
-
|
|
10
|
-
return (
|
|
11
|
-
<div className="space-y-4">
|
|
12
|
-
<p className="text-sm text-muted-foreground">
|
|
13
|
-
{isNotInstalled
|
|
14
|
-
? 'The GitHub CLI (gh) is required to connect your repository.'
|
|
15
|
-
: 'Authenticate with GitHub to see PRs, repo info, and more.'}
|
|
16
|
-
</p>
|
|
17
|
-
|
|
18
|
-
<div className="space-y-3">
|
|
19
|
-
{isNotInstalled && (
|
|
20
|
-
<div className="rounded border border-border bg-surface-light p-3">
|
|
21
|
-
<h4 className="mb-1.5 text-xs font-medium">1. Install GitHub CLI</h4>
|
|
22
|
-
<div className="flex items-center gap-2 rounded bg-background px-3 py-2 font-mono text-xs">
|
|
23
|
-
<Terminal className="h-3 w-3 shrink-0 text-muted-foreground" />
|
|
24
|
-
<code>brew install gh</code>
|
|
25
|
-
</div>
|
|
26
|
-
<p className="mt-1.5 text-xs text-muted-foreground">
|
|
27
|
-
Or visit{' '}
|
|
28
|
-
<a
|
|
29
|
-
href="https://cli.github.com"
|
|
30
|
-
target="_blank"
|
|
31
|
-
rel="noopener noreferrer"
|
|
32
|
-
className="inline-flex items-center gap-0.5 text-primary hover:underline"
|
|
33
|
-
>
|
|
34
|
-
cli.github.com <ExternalLink className="h-2.5 w-2.5" />
|
|
35
|
-
</a>
|
|
36
|
-
</p>
|
|
37
|
-
</div>
|
|
38
|
-
)}
|
|
39
|
-
|
|
40
|
-
<div className="rounded border border-border bg-surface-light p-3">
|
|
41
|
-
<h4 className="mb-1.5 text-xs font-medium">
|
|
42
|
-
{isNotInstalled ? '2' : '1'}. Authenticate
|
|
43
|
-
</h4>
|
|
44
|
-
<div className="flex items-center gap-2 rounded bg-background px-3 py-2 font-mono text-xs">
|
|
45
|
-
<Terminal className="h-3 w-3 shrink-0 text-muted-foreground" />
|
|
46
|
-
<code>gh auth login</code>
|
|
47
|
-
</div>
|
|
48
|
-
</div>
|
|
49
|
-
</div>
|
|
50
|
-
</div>
|
|
51
|
-
);
|
|
52
|
-
}
|