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.
Files changed (380) hide show
  1. package/bin/orbital.js +676 -53
  2. package/dist/assets/PrimitivesConfig-CrmQXYh4.js +32 -0
  3. package/dist/assets/QualityGates-BbasOsF3.js +21 -0
  4. package/dist/assets/SessionTimeline-CGeJsVvy.js +1 -0
  5. package/dist/assets/Settings-oiM496mc.js +12 -0
  6. package/dist/assets/SourceControl-B1fP2nJL.js +41 -0
  7. package/dist/assets/WorkflowVisualizer-CWLYf-f0.js +74 -0
  8. package/dist/assets/arrow-down-CPy85_J6.js +6 -0
  9. package/dist/assets/charts-DbDg0Psc.js +68 -0
  10. package/dist/assets/circle-x-Cwz6ZQDV.js +6 -0
  11. package/dist/assets/file-text-C46Xr65c.js +6 -0
  12. package/dist/assets/formatDistanceToNow-BMqsSP44.js +1 -0
  13. package/dist/assets/globe-Cn2yNZUD.js +6 -0
  14. package/dist/assets/index-Aj4sV8Al.css +1 -0
  15. package/dist/assets/index-Bc9dK3MW.js +354 -0
  16. package/dist/assets/key-OPaNTWJ5.js +6 -0
  17. package/dist/assets/minus-GMsbpKym.js +6 -0
  18. package/dist/assets/shield-DwAFkDYI.js +6 -0
  19. package/dist/assets/ui-BmsSg9jU.js +53 -0
  20. package/dist/assets/useWorkflowEditor-BJkTX_NR.js +16 -0
  21. package/dist/assets/{vendor-Dzv9lrRc.js → vendor-Bqt8AJn2.js} +1 -1
  22. package/dist/assets/zap-DfbUoOty.js +11 -0
  23. package/dist/favicon.svg +1 -0
  24. package/dist/index.html +6 -5
  25. package/dist/server/server/__tests__/data-routes.test.js +124 -0
  26. package/dist/server/server/__tests__/helpers/db.js +17 -0
  27. package/dist/server/server/__tests__/helpers/mock-emitter.js +8 -0
  28. package/dist/server/server/__tests__/scope-routes.test.js +137 -0
  29. package/dist/server/server/__tests__/sprint-routes.test.js +102 -0
  30. package/dist/server/server/__tests__/workflow-routes.test.js +107 -0
  31. package/dist/server/server/config-migrator.js +138 -0
  32. package/dist/server/server/config.js +17 -2
  33. package/dist/server/server/database.js +27 -12
  34. package/dist/server/server/global-config.js +143 -0
  35. package/dist/server/server/index.js +882 -252
  36. package/dist/server/server/init.js +579 -194
  37. package/dist/server/server/launch.js +29 -0
  38. package/dist/server/server/manifest-types.js +8 -0
  39. package/dist/server/server/manifest.js +454 -0
  40. package/dist/server/server/migrate-legacy.js +229 -0
  41. package/dist/server/server/parsers/event-parser.test.js +117 -0
  42. package/dist/server/server/parsers/scope-parser.js +74 -28
  43. package/dist/server/server/parsers/scope-parser.test.js +230 -0
  44. package/dist/server/server/project-context.js +255 -0
  45. package/dist/server/server/project-emitter.js +41 -0
  46. package/dist/server/server/project-manager.js +297 -0
  47. package/dist/server/server/routes/config-routes.js +1 -3
  48. package/dist/server/server/routes/data-routes.js +22 -110
  49. package/dist/server/server/routes/dispatch-routes.js +15 -9
  50. package/dist/server/server/routes/git-routes.js +74 -0
  51. package/dist/server/server/routes/manifest-routes.js +319 -0
  52. package/dist/server/server/routes/scope-routes.js +37 -23
  53. package/dist/server/server/routes/sync-routes.js +134 -0
  54. package/dist/server/server/routes/version-routes.js +1 -15
  55. package/dist/server/server/routes/workflow-routes.js +9 -3
  56. package/dist/server/server/schema.js +2 -0
  57. package/dist/server/server/services/batch-orchestrator.js +26 -16
  58. package/dist/server/server/services/claude-session-service.js +17 -14
  59. package/dist/server/server/services/deploy-service.test.js +119 -0
  60. package/dist/server/server/services/event-service.js +64 -1
  61. package/dist/server/server/services/event-service.test.js +191 -0
  62. package/dist/server/server/services/gate-service.test.js +105 -0
  63. package/dist/server/server/services/git-service.js +108 -4
  64. package/dist/server/server/services/github-service.js +110 -2
  65. package/dist/server/server/services/readiness-service.test.js +190 -0
  66. package/dist/server/server/services/scope-cache.js +5 -1
  67. package/dist/server/server/services/scope-cache.test.js +142 -0
  68. package/dist/server/server/services/scope-service.js +217 -126
  69. package/dist/server/server/services/scope-service.test.js +137 -0
  70. package/dist/server/server/services/sprint-orchestrator.js +7 -6
  71. package/dist/server/server/services/sprint-service.js +21 -1
  72. package/dist/server/server/services/sprint-service.test.js +238 -0
  73. package/dist/server/server/services/sync-service.js +434 -0
  74. package/dist/server/server/services/sync-types.js +2 -0
  75. package/dist/server/server/services/telemetry-service.js +143 -0
  76. package/dist/server/server/services/workflow-service.js +26 -5
  77. package/dist/server/server/services/workflow-service.test.js +159 -0
  78. package/dist/server/server/settings-sync.js +284 -0
  79. package/dist/server/server/update-planner.js +279 -0
  80. package/dist/server/server/utils/cc-hooks-parser.js +3 -0
  81. package/dist/server/server/utils/cc-hooks-parser.test.js +86 -0
  82. package/dist/server/server/utils/dispatch-utils.js +77 -20
  83. package/dist/server/server/utils/dispatch-utils.test.js +182 -0
  84. package/dist/server/server/utils/logger.js +37 -3
  85. package/dist/server/server/utils/package-info.js +30 -0
  86. package/dist/server/server/utils/route-helpers.js +10 -0
  87. package/dist/server/server/utils/terminal-launcher.js +79 -25
  88. package/dist/server/server/utils/worktree-manager.js +13 -4
  89. package/dist/server/server/validator.js +230 -0
  90. package/dist/server/server/watchers/global-watcher.js +63 -0
  91. package/dist/server/server/watchers/scope-watcher.js +27 -12
  92. package/dist/server/server/wizard/config-editor.js +237 -0
  93. package/dist/server/server/wizard/detect.js +96 -0
  94. package/dist/server/server/wizard/doctor.js +115 -0
  95. package/dist/server/server/wizard/index.js +155 -0
  96. package/dist/server/server/wizard/phases/confirm.js +39 -0
  97. package/dist/server/server/wizard/phases/project-setup.js +90 -0
  98. package/dist/server/server/wizard/phases/setup-wizard.js +66 -0
  99. package/dist/server/server/wizard/phases/welcome.js +35 -0
  100. package/dist/server/server/wizard/phases/workflow-setup.js +22 -0
  101. package/dist/server/server/wizard/types.js +29 -0
  102. package/dist/server/server/wizard/ui.js +74 -0
  103. package/dist/server/shared/__fixtures__/workflow-configs.js +75 -0
  104. package/dist/server/shared/default-workflow.json +65 -0
  105. package/dist/server/shared/onboarding-tour.test.js +81 -0
  106. package/dist/server/shared/project-colors.js +24 -0
  107. package/dist/server/shared/workflow-config.test.js +84 -0
  108. package/dist/server/shared/workflow-engine.test.js +302 -0
  109. package/dist/server/shared/workflow-normalizer.js +101 -0
  110. package/dist/server/shared/workflow-normalizer.test.js +100 -0
  111. package/dist/server/src/components/onboarding/tour-steps.js +84 -0
  112. package/package.json +20 -15
  113. package/schemas/orbital.config.schema.json +16 -1
  114. package/scripts/postinstall.js +55 -7
  115. package/server/__tests__/data-routes.test.ts +149 -0
  116. package/server/__tests__/helpers/db.ts +19 -0
  117. package/server/__tests__/helpers/mock-emitter.ts +10 -0
  118. package/server/__tests__/scope-routes.test.ts +157 -0
  119. package/server/__tests__/sprint-routes.test.ts +118 -0
  120. package/server/__tests__/workflow-routes.test.ts +120 -0
  121. package/server/config-migrator.ts +163 -0
  122. package/server/config.ts +26 -2
  123. package/server/database.ts +35 -18
  124. package/server/global-config.ts +200 -0
  125. package/server/index.ts +975 -287
  126. package/server/init.ts +625 -182
  127. package/server/launch.ts +32 -0
  128. package/server/manifest-types.ts +145 -0
  129. package/server/manifest.ts +494 -0
  130. package/server/migrate-legacy.ts +290 -0
  131. package/server/parsers/event-parser.test.ts +135 -0
  132. package/server/parsers/scope-parser.test.ts +270 -0
  133. package/server/parsers/scope-parser.ts +79 -31
  134. package/server/project-context.ts +309 -0
  135. package/server/project-emitter.ts +50 -0
  136. package/server/project-manager.ts +369 -0
  137. package/server/routes/config-routes.ts +3 -5
  138. package/server/routes/data-routes.ts +28 -141
  139. package/server/routes/dispatch-routes.ts +19 -11
  140. package/server/routes/git-routes.ts +77 -0
  141. package/server/routes/manifest-routes.ts +388 -0
  142. package/server/routes/scope-routes.ts +29 -25
  143. package/server/routes/sync-routes.ts +175 -0
  144. package/server/routes/version-routes.ts +1 -16
  145. package/server/routes/workflow-routes.ts +9 -3
  146. package/server/schema.ts +2 -0
  147. package/server/services/batch-orchestrator.ts +24 -16
  148. package/server/services/claude-session-service.ts +16 -14
  149. package/server/services/deploy-service.test.ts +145 -0
  150. package/server/services/deploy-service.ts +2 -2
  151. package/server/services/event-service.test.ts +242 -0
  152. package/server/services/event-service.ts +92 -3
  153. package/server/services/gate-service.test.ts +131 -0
  154. package/server/services/gate-service.ts +2 -2
  155. package/server/services/git-service.ts +137 -4
  156. package/server/services/github-service.ts +120 -2
  157. package/server/services/readiness-service.test.ts +217 -0
  158. package/server/services/scope-cache.test.ts +167 -0
  159. package/server/services/scope-cache.ts +4 -1
  160. package/server/services/scope-service.test.ts +169 -0
  161. package/server/services/scope-service.ts +220 -126
  162. package/server/services/sprint-orchestrator.ts +7 -7
  163. package/server/services/sprint-service.test.ts +271 -0
  164. package/server/services/sprint-service.ts +27 -3
  165. package/server/services/sync-service.ts +482 -0
  166. package/server/services/sync-types.ts +77 -0
  167. package/server/services/telemetry-service.ts +195 -0
  168. package/server/services/workflow-service.test.ts +190 -0
  169. package/server/services/workflow-service.ts +29 -9
  170. package/server/settings-sync.ts +359 -0
  171. package/server/update-planner.ts +346 -0
  172. package/server/utils/cc-hooks-parser.test.ts +96 -0
  173. package/server/utils/cc-hooks-parser.ts +4 -0
  174. package/server/utils/dispatch-utils.test.ts +245 -0
  175. package/server/utils/dispatch-utils.ts +97 -27
  176. package/server/utils/logger.ts +40 -3
  177. package/server/utils/package-info.ts +32 -0
  178. package/server/utils/route-helpers.ts +12 -0
  179. package/server/utils/terminal-launcher.ts +85 -25
  180. package/server/utils/worktree-manager.ts +9 -4
  181. package/server/validator.ts +270 -0
  182. package/server/watchers/global-watcher.ts +77 -0
  183. package/server/watchers/scope-watcher.ts +21 -9
  184. package/server/wizard/config-editor.ts +248 -0
  185. package/server/wizard/detect.ts +104 -0
  186. package/server/wizard/doctor.ts +114 -0
  187. package/server/wizard/index.ts +187 -0
  188. package/server/wizard/phases/confirm.ts +45 -0
  189. package/server/wizard/phases/project-setup.ts +106 -0
  190. package/server/wizard/phases/setup-wizard.ts +78 -0
  191. package/server/wizard/phases/welcome.ts +43 -0
  192. package/server/wizard/phases/workflow-setup.ts +28 -0
  193. package/server/wizard/types.ts +56 -0
  194. package/server/wizard/ui.ts +93 -0
  195. package/shared/__fixtures__/workflow-configs.ts +80 -0
  196. package/shared/default-workflow.json +65 -0
  197. package/shared/onboarding-tour.test.ts +94 -0
  198. package/shared/project-colors.ts +24 -0
  199. package/shared/workflow-config.test.ts +111 -0
  200. package/shared/workflow-config.ts +7 -0
  201. package/shared/workflow-engine.test.ts +388 -0
  202. package/shared/workflow-normalizer.test.ts +119 -0
  203. package/shared/workflow-normalizer.ts +118 -0
  204. package/templates/hooks/end-session.sh +3 -1
  205. package/templates/hooks/orbital-emit.sh +2 -2
  206. package/templates/hooks/orbital-report-deploy.sh +4 -4
  207. package/templates/hooks/orbital-report-gates.sh +4 -4
  208. package/templates/hooks/orbital-scope-update.sh +1 -1
  209. package/templates/hooks/scope-create-cleanup.sh +2 -2
  210. package/templates/hooks/scope-create-gate.sh +0 -1
  211. package/templates/hooks/scope-helpers.sh +18 -0
  212. package/templates/hooks/scope-prepare.sh +66 -11
  213. package/templates/migrations/renames.json +1 -0
  214. package/templates/orbital.config.json +7 -2
  215. package/templates/settings-hooks.json +1 -1
  216. package/templates/skills/git-commit/SKILL.md +9 -4
  217. package/templates/skills/git-dev/SKILL.md +8 -3
  218. package/templates/skills/git-main/SKILL.md +8 -2
  219. package/templates/skills/git-production/SKILL.md +6 -2
  220. package/templates/skills/git-staging/SKILL.md +8 -3
  221. package/templates/skills/scope-create/SKILL.md +17 -3
  222. package/templates/skills/scope-fix-review/SKILL.md +6 -3
  223. package/templates/skills/scope-implement/SKILL.md +4 -1
  224. package/templates/skills/scope-post-review/SKILL.md +63 -5
  225. package/templates/skills/scope-pre-review/SKILL.md +5 -2
  226. package/templates/skills/scope-verify/SKILL.md +5 -3
  227. package/templates/skills/test-code-review/SKILL.md +41 -33
  228. package/templates/skills/test-scaffold/SKILL.md +222 -0
  229. package/dist/assets/WorkflowVisualizer-BZ21PIIF.js +0 -84
  230. package/dist/assets/charts-D__PA1zp.js +0 -72
  231. package/dist/assets/index-D1G6i0nS.css +0 -1
  232. package/dist/assets/index-DpItvKpf.js +0 -419
  233. package/dist/assets/ui-BvF022GT.js +0 -53
  234. package/index.html +0 -15
  235. package/postcss.config.js +0 -6
  236. package/src/App.tsx +0 -33
  237. package/src/components/AgentBadge.tsx +0 -40
  238. package/src/components/BatchPreflightModal.tsx +0 -115
  239. package/src/components/CardDisplayToggle.tsx +0 -74
  240. package/src/components/ColumnHeaderActions.tsx +0 -55
  241. package/src/components/ColumnMenu.tsx +0 -99
  242. package/src/components/DeployHistory.tsx +0 -141
  243. package/src/components/DispatchModal.tsx +0 -164
  244. package/src/components/DispatchPopover.tsx +0 -139
  245. package/src/components/DragOverlay.tsx +0 -25
  246. package/src/components/DriftSidebar.tsx +0 -140
  247. package/src/components/EnvironmentStrip.tsx +0 -88
  248. package/src/components/ErrorBoundary.tsx +0 -62
  249. package/src/components/FilterChip.tsx +0 -105
  250. package/src/components/GateIndicator.tsx +0 -33
  251. package/src/components/IdeaDetailModal.tsx +0 -190
  252. package/src/components/IdeaFormDialog.tsx +0 -113
  253. package/src/components/KanbanColumn.tsx +0 -201
  254. package/src/components/MarkdownRenderer.tsx +0 -114
  255. package/src/components/NeonGrid.tsx +0 -128
  256. package/src/components/PromotionQueue.tsx +0 -89
  257. package/src/components/ScopeCard.tsx +0 -234
  258. package/src/components/ScopeDetailModal.tsx +0 -255
  259. package/src/components/ScopeFilterBar.tsx +0 -152
  260. package/src/components/SearchInput.tsx +0 -102
  261. package/src/components/SessionPanel.tsx +0 -335
  262. package/src/components/SprintContainer.tsx +0 -303
  263. package/src/components/SprintDependencyDialog.tsx +0 -78
  264. package/src/components/SprintPreflightModal.tsx +0 -138
  265. package/src/components/StatusBar.tsx +0 -168
  266. package/src/components/SwimCell.tsx +0 -67
  267. package/src/components/SwimLaneRow.tsx +0 -94
  268. package/src/components/SwimlaneBoardView.tsx +0 -108
  269. package/src/components/VersionBadge.tsx +0 -139
  270. package/src/components/ViewModeSelector.tsx +0 -114
  271. package/src/components/config/AgentChip.tsx +0 -53
  272. package/src/components/config/AgentCreateDialog.tsx +0 -321
  273. package/src/components/config/AgentEditor.tsx +0 -175
  274. package/src/components/config/DirectoryTree.tsx +0 -582
  275. package/src/components/config/FileEditor.tsx +0 -550
  276. package/src/components/config/HookChip.tsx +0 -50
  277. package/src/components/config/StageCard.tsx +0 -198
  278. package/src/components/config/TransitionZone.tsx +0 -173
  279. package/src/components/config/UnifiedWorkflowPipeline.tsx +0 -216
  280. package/src/components/config/WorkflowPipeline.tsx +0 -161
  281. package/src/components/source-control/BranchList.tsx +0 -93
  282. package/src/components/source-control/BranchPanel.tsx +0 -105
  283. package/src/components/source-control/CommitLog.tsx +0 -100
  284. package/src/components/source-control/CommitRow.tsx +0 -47
  285. package/src/components/source-control/GitHubPanel.tsx +0 -110
  286. package/src/components/source-control/GitHubSetupGuide.tsx +0 -52
  287. package/src/components/source-control/GitOverviewBar.tsx +0 -101
  288. package/src/components/source-control/PullRequestList.tsx +0 -69
  289. package/src/components/source-control/WorktreeList.tsx +0 -80
  290. package/src/components/ui/badge.tsx +0 -41
  291. package/src/components/ui/button.tsx +0 -55
  292. package/src/components/ui/card.tsx +0 -78
  293. package/src/components/ui/dialog.tsx +0 -94
  294. package/src/components/ui/popover.tsx +0 -33
  295. package/src/components/ui/scroll-area.tsx +0 -54
  296. package/src/components/ui/separator.tsx +0 -28
  297. package/src/components/ui/tabs.tsx +0 -52
  298. package/src/components/ui/toggle-switch.tsx +0 -35
  299. package/src/components/ui/tooltip.tsx +0 -27
  300. package/src/components/workflow/AddEdgeDialog.tsx +0 -217
  301. package/src/components/workflow/AddListDialog.tsx +0 -201
  302. package/src/components/workflow/ChecklistEditor.tsx +0 -239
  303. package/src/components/workflow/CommandPrefixManager.tsx +0 -118
  304. package/src/components/workflow/ConfigSettingsPanel.tsx +0 -189
  305. package/src/components/workflow/DirectionSelector.tsx +0 -133
  306. package/src/components/workflow/DispatchConfigPanel.tsx +0 -180
  307. package/src/components/workflow/EdgeDetailPanel.tsx +0 -236
  308. package/src/components/workflow/EdgePropertyEditor.tsx +0 -251
  309. package/src/components/workflow/EditToolbar.tsx +0 -138
  310. package/src/components/workflow/HookDetailPanel.tsx +0 -250
  311. package/src/components/workflow/HookExecutionLog.tsx +0 -24
  312. package/src/components/workflow/HookSourceModal.tsx +0 -129
  313. package/src/components/workflow/HooksDashboard.tsx +0 -363
  314. package/src/components/workflow/ListPropertyEditor.tsx +0 -251
  315. package/src/components/workflow/MigrationPreviewDialog.tsx +0 -237
  316. package/src/components/workflow/MovementRulesPanel.tsx +0 -188
  317. package/src/components/workflow/NodeDetailPanel.tsx +0 -245
  318. package/src/components/workflow/PresetSelector.tsx +0 -414
  319. package/src/components/workflow/SkillCommandBuilder.tsx +0 -174
  320. package/src/components/workflow/WorkflowEdgeComponent.tsx +0 -145
  321. package/src/components/workflow/WorkflowNode.tsx +0 -147
  322. package/src/components/workflow/graphLayout.ts +0 -186
  323. package/src/components/workflow/mergeHooks.ts +0 -85
  324. package/src/components/workflow/useEditHistory.ts +0 -88
  325. package/src/components/workflow/useWorkflowEditor.ts +0 -262
  326. package/src/components/workflow/validateConfig.ts +0 -70
  327. package/src/hooks/useActiveDispatches.ts +0 -198
  328. package/src/hooks/useBoardSettings.ts +0 -170
  329. package/src/hooks/useCardDisplay.ts +0 -57
  330. package/src/hooks/useCcHooks.ts +0 -24
  331. package/src/hooks/useConfigTree.ts +0 -51
  332. package/src/hooks/useEnforcementRules.ts +0 -46
  333. package/src/hooks/useEvents.ts +0 -59
  334. package/src/hooks/useFileEditor.ts +0 -165
  335. package/src/hooks/useGates.ts +0 -57
  336. package/src/hooks/useIdeaActions.ts +0 -53
  337. package/src/hooks/useKanbanDnd.ts +0 -410
  338. package/src/hooks/useOrbitalConfig.ts +0 -54
  339. package/src/hooks/usePipeline.ts +0 -47
  340. package/src/hooks/usePipelineData.ts +0 -338
  341. package/src/hooks/useReconnect.ts +0 -25
  342. package/src/hooks/useScopeFilters.ts +0 -125
  343. package/src/hooks/useScopeSessions.ts +0 -44
  344. package/src/hooks/useScopes.ts +0 -67
  345. package/src/hooks/useSearch.ts +0 -67
  346. package/src/hooks/useSettings.tsx +0 -187
  347. package/src/hooks/useSocket.ts +0 -25
  348. package/src/hooks/useSourceControl.ts +0 -105
  349. package/src/hooks/useSprintPreflight.ts +0 -55
  350. package/src/hooks/useSprints.ts +0 -154
  351. package/src/hooks/useStatusBarHighlight.ts +0 -18
  352. package/src/hooks/useSwimlaneBoardSettings.ts +0 -104
  353. package/src/hooks/useTheme.ts +0 -9
  354. package/src/hooks/useTransitionReadiness.ts +0 -53
  355. package/src/hooks/useVersion.ts +0 -155
  356. package/src/hooks/useViolations.ts +0 -65
  357. package/src/hooks/useWorkflow.tsx +0 -125
  358. package/src/hooks/useZoomModifier.ts +0 -19
  359. package/src/index.css +0 -797
  360. package/src/layouts/DashboardLayout.tsx +0 -113
  361. package/src/lib/collisionDetection.ts +0 -20
  362. package/src/lib/scope-fields.ts +0 -61
  363. package/src/lib/swimlane.ts +0 -146
  364. package/src/lib/utils.ts +0 -15
  365. package/src/main.tsx +0 -19
  366. package/src/socket.ts +0 -11
  367. package/src/types/index.ts +0 -497
  368. package/src/views/AgentFeed.tsx +0 -339
  369. package/src/views/DeployPipeline.tsx +0 -59
  370. package/src/views/EnforcementView.tsx +0 -378
  371. package/src/views/PrimitivesConfig.tsx +0 -500
  372. package/src/views/QualityGates.tsx +0 -1012
  373. package/src/views/ScopeBoard.tsx +0 -454
  374. package/src/views/SessionTimeline.tsx +0 -516
  375. package/src/views/Settings.tsx +0 -183
  376. package/src/views/SourceControl.tsx +0 -95
  377. package/src/views/WorkflowVisualizer.tsx +0 -382
  378. package/tailwind.config.js +0 -161
  379. package/tsconfig.json +0 -25
  380. 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 };