prjct-cli 0.45.0 → 0.45.3

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 (207) hide show
  1. package/CHANGELOG.md +75 -0
  2. package/bin/prjct.ts +117 -10
  3. package/core/__tests__/agentic/memory-system.test.ts +39 -26
  4. package/core/__tests__/agentic/plan-mode.test.ts +64 -46
  5. package/core/__tests__/agentic/prompt-builder.test.ts +14 -14
  6. package/core/__tests__/services/project-index.test.ts +353 -0
  7. package/core/__tests__/types/fs.test.ts +3 -3
  8. package/core/__tests__/utils/date-helper.test.ts +10 -10
  9. package/core/__tests__/utils/output.test.ts +9 -6
  10. package/core/__tests__/utils/project-commands.test.ts +5 -6
  11. package/core/agentic/agent-router.ts +9 -10
  12. package/core/agentic/chain-of-thought.ts +16 -4
  13. package/core/agentic/command-executor.ts +66 -40
  14. package/core/agentic/context-builder.ts +8 -5
  15. package/core/agentic/ground-truth.ts +15 -9
  16. package/core/agentic/index.ts +145 -152
  17. package/core/agentic/loop-detector.ts +40 -11
  18. package/core/agentic/memory-system.ts +98 -35
  19. package/core/agentic/orchestrator-executor.ts +135 -71
  20. package/core/agentic/plan-mode.ts +46 -16
  21. package/core/agentic/prompt-builder.ts +108 -42
  22. package/core/agentic/services.ts +10 -9
  23. package/core/agentic/skill-loader.ts +9 -15
  24. package/core/agentic/smart-context.ts +129 -79
  25. package/core/agentic/template-executor.ts +13 -12
  26. package/core/agentic/template-loader.ts +7 -4
  27. package/core/agentic/tool-registry.ts +16 -13
  28. package/core/agents/index.ts +1 -1
  29. package/core/agents/performance.ts +10 -27
  30. package/core/ai-tools/formatters.ts +8 -6
  31. package/core/ai-tools/generator.ts +4 -4
  32. package/core/ai-tools/index.ts +1 -1
  33. package/core/ai-tools/registry.ts +21 -11
  34. package/core/bus/bus.ts +23 -16
  35. package/core/bus/index.ts +2 -2
  36. package/core/cli/linear.ts +3 -5
  37. package/core/cli/start.ts +28 -25
  38. package/core/commands/analysis.ts +58 -39
  39. package/core/commands/analytics.ts +52 -44
  40. package/core/commands/base.ts +15 -13
  41. package/core/commands/cleanup.ts +6 -13
  42. package/core/commands/command-data.ts +28 -4
  43. package/core/commands/commands.ts +57 -24
  44. package/core/commands/context.ts +4 -4
  45. package/core/commands/design.ts +3 -10
  46. package/core/commands/index.ts +5 -8
  47. package/core/commands/maintenance.ts +7 -4
  48. package/core/commands/planning.ts +179 -56
  49. package/core/commands/register.ts +13 -9
  50. package/core/commands/registry.ts +15 -14
  51. package/core/commands/setup.ts +26 -14
  52. package/core/commands/shipping.ts +11 -16
  53. package/core/commands/snapshots.ts +16 -32
  54. package/core/commands/uninstall.ts +541 -0
  55. package/core/commands/workflow.ts +24 -28
  56. package/core/constants/index.ts +10 -22
  57. package/core/context/generator.ts +82 -33
  58. package/core/context-tools/files-tool.ts +18 -19
  59. package/core/context-tools/imports-tool.ts +13 -33
  60. package/core/context-tools/index.ts +29 -54
  61. package/core/context-tools/recent-tool.ts +16 -22
  62. package/core/context-tools/signatures-tool.ts +17 -26
  63. package/core/context-tools/summary-tool.ts +20 -22
  64. package/core/context-tools/token-counter.ts +25 -20
  65. package/core/context-tools/types.ts +5 -5
  66. package/core/domain/agent-generator.ts +7 -5
  67. package/core/domain/agent-loader.ts +2 -2
  68. package/core/domain/analyzer.ts +19 -16
  69. package/core/domain/architecture-generator.ts +6 -3
  70. package/core/domain/context-estimator.ts +3 -4
  71. package/core/domain/snapshot-manager.ts +25 -22
  72. package/core/domain/task-stack.ts +24 -14
  73. package/core/errors.ts +1 -1
  74. package/core/events/events.ts +2 -4
  75. package/core/events/index.ts +1 -2
  76. package/core/index.ts +28 -16
  77. package/core/infrastructure/agent-detector.ts +3 -3
  78. package/core/infrastructure/ai-provider.ts +23 -20
  79. package/core/infrastructure/author-detector.ts +16 -10
  80. package/core/infrastructure/capability-installer.ts +2 -2
  81. package/core/infrastructure/claude-agent.ts +6 -6
  82. package/core/infrastructure/command-installer.ts +22 -17
  83. package/core/infrastructure/config-manager.ts +18 -14
  84. package/core/infrastructure/editors-config.ts +8 -4
  85. package/core/infrastructure/path-manager.ts +8 -6
  86. package/core/infrastructure/permission-manager.ts +20 -17
  87. package/core/infrastructure/setup.ts +42 -38
  88. package/core/infrastructure/update-checker.ts +5 -5
  89. package/core/integrations/issue-tracker/enricher.ts +8 -19
  90. package/core/integrations/issue-tracker/index.ts +2 -2
  91. package/core/integrations/issue-tracker/manager.ts +15 -15
  92. package/core/integrations/issue-tracker/types.ts +5 -22
  93. package/core/integrations/jira/client.ts +67 -59
  94. package/core/integrations/jira/index.ts +11 -14
  95. package/core/integrations/jira/mcp-adapter.ts +5 -10
  96. package/core/integrations/jira/service.ts +10 -10
  97. package/core/integrations/linear/client.ts +27 -18
  98. package/core/integrations/linear/index.ts +9 -12
  99. package/core/integrations/linear/service.ts +11 -11
  100. package/core/integrations/linear/sync.ts +8 -8
  101. package/core/outcomes/analyzer.ts +5 -18
  102. package/core/outcomes/index.ts +2 -2
  103. package/core/outcomes/recorder.ts +3 -3
  104. package/core/plugin/builtin/webhook.ts +19 -15
  105. package/core/plugin/hooks.ts +29 -21
  106. package/core/plugin/index.ts +7 -7
  107. package/core/plugin/loader.ts +19 -19
  108. package/core/plugin/registry.ts +12 -23
  109. package/core/schemas/agents.ts +1 -1
  110. package/core/schemas/analysis.ts +1 -1
  111. package/core/schemas/enriched-task.ts +62 -49
  112. package/core/schemas/ideas.ts +13 -13
  113. package/core/schemas/index.ts +17 -27
  114. package/core/schemas/issues.ts +40 -25
  115. package/core/schemas/metrics.ts +25 -25
  116. package/core/schemas/outcomes.ts +70 -62
  117. package/core/schemas/permissions.ts +15 -12
  118. package/core/schemas/prd.ts +27 -14
  119. package/core/schemas/project.ts +3 -3
  120. package/core/schemas/roadmap.ts +47 -34
  121. package/core/schemas/schemas.ts +3 -4
  122. package/core/schemas/shipped.ts +3 -3
  123. package/core/schemas/state.ts +43 -29
  124. package/core/server/index.ts +5 -6
  125. package/core/server/routes-extended.ts +68 -72
  126. package/core/server/routes.ts +3 -3
  127. package/core/server/server.ts +31 -26
  128. package/core/services/agent-generator.ts +237 -0
  129. package/core/services/agent-service.ts +2 -2
  130. package/core/services/breakdown-service.ts +2 -4
  131. package/core/services/context-generator.ts +299 -0
  132. package/core/services/context-selector.ts +420 -0
  133. package/core/services/doctor-service.ts +426 -0
  134. package/core/services/file-categorizer.ts +448 -0
  135. package/core/services/file-scorer.ts +270 -0
  136. package/core/services/git-analyzer.ts +267 -0
  137. package/core/services/index.ts +27 -10
  138. package/core/services/memory-service.ts +3 -4
  139. package/core/services/project-index.ts +911 -0
  140. package/core/services/project-service.ts +4 -4
  141. package/core/services/skill-installer.ts +14 -17
  142. package/core/services/skill-lock.ts +3 -3
  143. package/core/services/skill-service.ts +12 -6
  144. package/core/services/stack-detector.ts +245 -0
  145. package/core/services/sync-service.ts +87 -345
  146. package/core/services/watch-service.ts +294 -0
  147. package/core/session/compaction.ts +23 -31
  148. package/core/session/index.ts +11 -5
  149. package/core/session/log-migration.ts +3 -3
  150. package/core/session/metrics.ts +19 -14
  151. package/core/session/session-log-manager.ts +12 -17
  152. package/core/session/task-session-manager.ts +25 -25
  153. package/core/session/utils.ts +1 -1
  154. package/core/storage/ideas-storage.ts +41 -57
  155. package/core/storage/index-storage.ts +514 -0
  156. package/core/storage/index.ts +41 -17
  157. package/core/storage/metrics-storage.ts +39 -34
  158. package/core/storage/queue-storage.ts +35 -45
  159. package/core/storage/shipped-storage.ts +17 -20
  160. package/core/storage/state-storage.ts +50 -30
  161. package/core/storage/storage-manager.ts +6 -6
  162. package/core/storage/storage.ts +18 -15
  163. package/core/sync/auth-config.ts +3 -3
  164. package/core/sync/index.ts +13 -19
  165. package/core/sync/oauth-handler.ts +3 -3
  166. package/core/sync/sync-client.ts +4 -9
  167. package/core/sync/sync-manager.ts +12 -14
  168. package/core/types/commands.ts +42 -7
  169. package/core/types/index.ts +284 -305
  170. package/core/types/integrations.ts +3 -3
  171. package/core/types/storage.ts +14 -14
  172. package/core/types/utils.ts +3 -3
  173. package/core/utils/agent-stream.ts +3 -1
  174. package/core/utils/animations.ts +14 -11
  175. package/core/utils/branding.ts +7 -7
  176. package/core/utils/cache.ts +1 -3
  177. package/core/utils/collection-filters.ts +3 -15
  178. package/core/utils/date-helper.ts +2 -7
  179. package/core/utils/file-helper.ts +13 -8
  180. package/core/utils/jsonl-helper.ts +13 -10
  181. package/core/utils/keychain.ts +4 -8
  182. package/core/utils/logger.ts +1 -1
  183. package/core/utils/next-steps.ts +3 -3
  184. package/core/utils/output.ts +58 -11
  185. package/core/utils/project-commands.ts +6 -6
  186. package/core/utils/project-credentials.ts +5 -12
  187. package/core/utils/runtime.ts +2 -2
  188. package/core/utils/session-helper.ts +3 -4
  189. package/core/utils/version.ts +3 -3
  190. package/core/wizard/index.ts +13 -0
  191. package/core/wizard/onboarding.ts +633 -0
  192. package/core/workflow/state-machine.ts +7 -7
  193. package/dist/bin/prjct.mjs +18755 -15574
  194. package/dist/core/infrastructure/command-installer.js +86 -79
  195. package/dist/core/infrastructure/editors-config.js +6 -6
  196. package/dist/core/infrastructure/setup.js +246 -225
  197. package/dist/core/utils/version.js +9 -9
  198. package/package.json +11 -12
  199. package/scripts/build.js +3 -3
  200. package/scripts/postinstall.js +2 -2
  201. package/templates/mcp-config.json +6 -1
  202. package/templates/permissions/permissive.jsonc +1 -1
  203. package/templates/permissions/strict.jsonc +5 -9
  204. package/templates/global/docs/agents.md +0 -88
  205. package/templates/global/docs/architecture.md +0 -103
  206. package/templates/global/docs/commands.md +0 -96
  207. package/templates/global/docs/validation.md +0 -95
@@ -3,21 +3,20 @@
3
3
  * Unified dashboard and contextual help - MD-First Architecture
4
4
  */
5
5
 
6
- import path from 'path'
7
-
8
- import { commandRegistry } from './registry'
6
+ import path from 'node:path'
7
+ import { ideasStorage, queueStorage, shippedStorage, stateStorage } from '../storage'
9
8
  import type { CommandResult, ProjectContext } from '../types'
10
9
  import {
11
- PrjctCommandsBase,
12
- contextBuilder,
13
- toolRegistry,
14
- pathManager,
15
10
  configManager,
16
- jsonlHelper,
11
+ contextBuilder,
17
12
  dateHelper,
18
- out
13
+ jsonlHelper,
14
+ out,
15
+ PrjctCommandsBase,
16
+ pathManager,
17
+ toolRegistry,
19
18
  } from './base'
20
- import { stateStorage, queueStorage, shippedStorage, ideasStorage } from '../storage'
19
+ import { commandRegistry } from './registry'
21
20
 
22
21
  interface MemoryEntry {
23
22
  timestamp: string
@@ -30,7 +29,10 @@ export class AnalyticsCommands extends PrjctCommandsBase {
30
29
  * /p:dash - Unified dashboard
31
30
  * Views: default, week, month, roadmap, compact
32
31
  */
33
- async dash(view: string = 'default', projectPath: string = process.cwd()): Promise<CommandResult> {
32
+ async dash(
33
+ view: string = 'default',
34
+ projectPath: string = process.cwd()
35
+ ): Promise<CommandResult> {
34
36
  try {
35
37
  const initResult = await this.ensureProjectInit(projectPath)
36
38
  if (!initResult.success) return initResult
@@ -72,9 +74,11 @@ export class AnalyticsCommands extends PrjctCommandsBase {
72
74
  const memoryPath = pathManager.getFilePath(projectId, 'memory', 'context.jsonl')
73
75
  let entries: MemoryEntry[] = []
74
76
  try {
75
- const allEntries = await jsonlHelper.readJsonLines(memoryPath) as MemoryEntry[]
77
+ const allEntries = (await jsonlHelper.readJsonLines(memoryPath)) as MemoryEntry[]
76
78
  entries = allEntries.filter((e) => new Date(e.timestamp) >= startDate)
77
- } catch { entries = [] }
79
+ } catch {
80
+ entries = []
81
+ }
78
82
 
79
83
  const metrics = {
80
84
  tasksCompleted: entries.filter((e) => e.action === 'task_completed').length,
@@ -98,8 +102,10 @@ export class AnalyticsCommands extends PrjctCommandsBase {
98
102
 
99
103
  if (view === 'roadmap') {
100
104
  // Roadmap view
101
- const context = await contextBuilder.build(projectPath) as ProjectContext
102
- const roadmapContent = (await toolRegistry.get('Read')!(context.paths.roadmap)) as string | null
105
+ const context = (await contextBuilder.build(projectPath)) as ProjectContext
106
+ const roadmapContent = (await toolRegistry.get('Read')!(context.paths.roadmap)) as
107
+ | string
108
+ | null
103
109
 
104
110
  console.log(`\n🗺️ ROADMAP - ${projectName}\n`)
105
111
  console.log('═'.repeat(50))
@@ -109,7 +115,9 @@ export class AnalyticsCommands extends PrjctCommandsBase {
109
115
  console.log(' Use /p:feature to add features.\n')
110
116
  } else {
111
117
  // Parse and display roadmap
112
- const features = roadmapContent.split('##').filter(s => s.trim() && !s.includes('ROADMAP'))
118
+ const features = roadmapContent
119
+ .split('##')
120
+ .filter((s) => s.trim() && !s.includes('ROADMAP'))
113
121
  features.slice(0, 5).forEach((f, i) => {
114
122
  const name = f.split('\n')[0].trim()
115
123
  console.log(` ${i + 1}. ${name}`)
@@ -118,7 +126,7 @@ export class AnalyticsCommands extends PrjctCommandsBase {
118
126
  console.log(` ... and ${features.length - 5} more`)
119
127
  }
120
128
  }
121
- console.log('═'.repeat(50) + '\n')
129
+ console.log(`${'═'.repeat(50)}\n`)
122
130
 
123
131
  return { success: true, view: 'roadmap' }
124
132
  }
@@ -168,7 +176,7 @@ export class AnalyticsCommands extends PrjctCommandsBase {
168
176
  console.log('\n💡 IDEAS')
169
177
  console.log(` ${ideas.length} pending ideas`)
170
178
 
171
- console.log('\n' + '═'.repeat(50))
179
+ console.log(`\n${'═'.repeat(50)}`)
172
180
  console.log('💡 /p:work to start | /p:done to complete | /p:ship to ship\n')
173
181
 
174
182
  await this.logToMemory(projectPath, 'dash_viewed', {
@@ -183,8 +191,8 @@ export class AnalyticsCommands extends PrjctCommandsBase {
183
191
  currentTask: currentTask?.description || null,
184
192
  queueCount: queueTasks.length,
185
193
  shippedCount: shipped.length,
186
- ideasCount: ideas.length
187
- }
194
+ ideasCount: ideas.length,
195
+ },
188
196
  }
189
197
  } catch (error) {
190
198
  out.fail((error as Error).message)
@@ -195,7 +203,7 @@ export class AnalyticsCommands extends PrjctCommandsBase {
195
203
  /**
196
204
  * /p:help - Contextual help and guidance
197
205
  */
198
- async help(topic: string = '', projectPath: string = process.cwd()): Promise<CommandResult> {
206
+ async help(topic: string = '', _projectPath: string = process.cwd()): Promise<CommandResult> {
199
207
  try {
200
208
  if (!topic) {
201
209
  // Show command overview
@@ -207,7 +215,7 @@ export class AnalyticsCommands extends PrjctCommandsBase {
207
215
 
208
216
  // Group by category
209
217
  const byCategory: Record<string, typeof commands> = {}
210
- commands.forEach(cmd => {
218
+ commands.forEach((cmd) => {
211
219
  if (cmd.deprecated) return
212
220
  if (!byCategory[cmd.group]) byCategory[cmd.group] = []
213
221
  byCategory[cmd.group].push(cmd)
@@ -216,14 +224,14 @@ export class AnalyticsCommands extends PrjctCommandsBase {
216
224
  Object.entries(byCategory).forEach(([cat, cmds]) => {
217
225
  const catInfo = categories.get(cat)
218
226
  console.log(`\n${catInfo?.title || cat}:`)
219
- cmds.forEach(cmd => {
227
+ cmds.forEach((cmd) => {
220
228
  const params = cmd.params ? ` ${cmd.params}` : ''
221
229
  console.log(` ${cmd.name}${params}`)
222
230
  console.log(` ${cmd.description}`)
223
231
  })
224
232
  })
225
233
 
226
- console.log('\n' + '═'.repeat(50))
234
+ console.log(`\n${'═'.repeat(50)}`)
227
235
  console.log('💡 Use /p:help <command> for detailed help\n')
228
236
 
229
237
  return { success: true, topic: 'overview' }
@@ -248,31 +256,31 @@ export class AnalyticsCommands extends PrjctCommandsBase {
248
256
 
249
257
  if (command.features) {
250
258
  console.log('\nFeatures:')
251
- command.features.forEach(f => console.log(` • ${f}`))
259
+ command.features.forEach((f) => console.log(` • ${f}`))
252
260
  }
253
261
 
254
- console.log('\n' + '═'.repeat(50) + '\n')
262
+ console.log(`\n${'═'.repeat(50)}\n`)
255
263
  return { success: true, topic, command }
256
264
  }
257
265
 
258
266
  // Intent translation (like old /p:ask)
259
267
  const intents: Record<string, { command: string; hint: string }> = {
260
- 'start': { command: 'work', hint: 'Start working on a task' },
261
- 'begin': { command: 'work', hint: 'Start working on a task' },
262
- 'finish': { command: 'done', hint: 'Mark current task complete' },
263
- 'complete': { command: 'done', hint: 'Mark current task complete' },
264
- 'deploy': { command: 'ship', hint: 'Ship a feature' },
265
- 'release': { command: 'ship', hint: 'Ship a feature' },
266
- 'status': { command: 'dash', hint: 'View project dashboard' },
267
- 'overview': { command: 'dash', hint: 'View project dashboard' },
268
- 'queue': { command: 'next', hint: 'View task queue' },
269
- 'tasks': { command: 'next', hint: 'View task queue' },
270
- 'add': { command: 'feature', hint: 'Add a new feature' },
271
- 'new': { command: 'feature', hint: 'Add a new feature' },
272
- 'break': { command: 'pause', hint: 'Pause current task' },
273
- 'stop': { command: 'pause', hint: 'Pause current task' },
274
- 'continue': { command: 'resume', hint: 'Resume paused task' },
275
- 'back': { command: 'resume', hint: 'Resume paused task' },
268
+ start: { command: 'work', hint: 'Start working on a task' },
269
+ begin: { command: 'work', hint: 'Start working on a task' },
270
+ finish: { command: 'done', hint: 'Mark current task complete' },
271
+ complete: { command: 'done', hint: 'Mark current task complete' },
272
+ deploy: { command: 'ship', hint: 'Ship a feature' },
273
+ release: { command: 'ship', hint: 'Ship a feature' },
274
+ status: { command: 'dash', hint: 'View project dashboard' },
275
+ overview: { command: 'dash', hint: 'View project dashboard' },
276
+ queue: { command: 'next', hint: 'View task queue' },
277
+ tasks: { command: 'next', hint: 'View task queue' },
278
+ add: { command: 'feature', hint: 'Add a new feature' },
279
+ new: { command: 'feature', hint: 'Add a new feature' },
280
+ break: { command: 'pause', hint: 'Pause current task' },
281
+ stop: { command: 'pause', hint: 'Pause current task' },
282
+ continue: { command: 'resume', hint: 'Resume paused task' },
283
+ back: { command: 'resume', hint: 'Resume paused task' },
276
284
  }
277
285
 
278
286
  const lowerTopic = topic.toLowerCase()
@@ -308,7 +316,7 @@ export class AnalyticsCommands extends PrjctCommandsBase {
308
316
  const dayStart = new Date(date.setHours(0, 0, 0, 0))
309
317
  const dayEnd = new Date(date.setHours(23, 59, 59, 999))
310
318
 
311
- const count = entries.filter(e => {
319
+ const count = entries.filter((e) => {
312
320
  const ts = new Date(e.timestamp)
313
321
  return ts >= dayStart && ts <= dayEnd
314
322
  }).length
@@ -317,6 +325,6 @@ export class AnalyticsCommands extends PrjctCommandsBase {
317
325
  }
318
326
 
319
327
  const max = Math.max(...counts, 1)
320
- return counts.map(c => bars[Math.floor((c / max) * (bars.length - 1))]).join('')
328
+ return counts.map((c) => bars[Math.floor((c / max) * (bars.length - 1))]).join('')
321
329
  }
322
330
  }
@@ -8,24 +8,22 @@
8
8
  import commandExecutor from '../agentic/command-executor'
9
9
  import contextBuilder from '../agentic/context-builder'
10
10
  import toolRegistry from '../agentic/tool-registry'
11
- import pathManager from '../infrastructure/path-manager'
12
11
  import configManager from '../infrastructure/config-manager'
12
+ import pathManager from '../infrastructure/path-manager'
13
13
  import UpdateChecker from '../infrastructure/update-checker'
14
- import dateHelper from '../utils/date-helper'
15
- import jsonlHelper from '../utils/jsonl-helper'
16
- import * as fileHelper from '../utils/file-helper'
17
- import out from '../utils/output'
18
-
19
14
  // Services
20
- import { agentService, projectService, memoryService, breakdownService } from '../services'
21
-
15
+ import { agentService, breakdownService, memoryService, projectService } from '../services'
22
16
  import type {
23
- CommandResult,
17
+ AgentAssignmentResult,
24
18
  AgentInfo,
25
19
  Author,
26
- AgentAssignmentResult,
27
- ProjectContext
20
+ CommandResult,
21
+ ProjectContext,
28
22
  } from '../types'
23
+ import dateHelper from '../utils/date-helper'
24
+ import * as fileHelper from '../utils/file-helper'
25
+ import jsonlHelper from '../utils/jsonl-helper'
26
+ import out from '../utils/output'
29
27
 
30
28
  /**
31
29
  * Base class with shared state and utilities
@@ -73,7 +71,11 @@ export class PrjctCommandsBase {
73
71
  return projectService.getGlobalPath(projectPath)
74
72
  }
75
73
 
76
- async logToMemory(projectPath: string, action: string, data: Record<string, unknown>): Promise<void> {
74
+ async logToMemory(
75
+ projectPath: string,
76
+ action: string,
77
+ data: Record<string, unknown>
78
+ ): Promise<void> {
77
79
  const author = await this.ensureAuthor()
78
80
  return memoryService.log(projectPath, action, data, author.name)
79
81
  }
@@ -112,5 +114,5 @@ export {
112
114
  fileHelper,
113
115
  jsonlHelper,
114
116
  dateHelper,
115
- out
117
+ out,
116
118
  }
@@ -4,19 +4,12 @@
4
4
  * Memory and project file cleanup operations.
5
5
  */
6
6
 
7
- import path from 'path'
8
-
9
- import { isNotFoundError } from '../types/fs'
10
- import type { CommandResult, CleanupOptions } from '../types'
11
- import {
12
- pathManager,
13
- configManager,
14
- jsonlHelper,
15
- dateHelper,
16
- out
17
- } from './base'
18
- import { ideasStorage, queueStorage } from '../storage'
7
+ import path from 'node:path'
19
8
  import { memoryService } from '../services'
9
+ import { ideasStorage, queueStorage } from '../storage'
10
+ import type { CleanupOptions, CommandResult } from '../types'
11
+ import { isNotFoundError } from '../types/fs'
12
+ import { configManager, dateHelper, jsonlHelper, out, pathManager } from './base'
20
13
 
21
14
  /**
22
15
  * Memory cleanup helper
@@ -131,7 +124,7 @@ export async function cleanup(
131
124
  // Check queue for completed tasks using queueStorage
132
125
  try {
133
126
  const tasks = await queueStorage.getActiveTasks(projectId)
134
- const completedTasks = tasks.filter(t => t.completed).length
127
+ const completedTasks = tasks.filter((t) => t.completed).length
135
128
 
136
129
  if (completedTasks > 0) {
137
130
  cleaned.push(
@@ -5,7 +5,7 @@
5
5
  * Used by registry for introspection and help display.
6
6
  */
7
7
 
8
- import type { CommandMeta, CategoryInfo } from '../types'
8
+ import type { CategoryInfo, CommandMeta } from '../types'
9
9
 
10
10
  // Category definitions
11
11
  export const CATEGORIES: Record<string, CategoryInfo> = {
@@ -38,7 +38,11 @@ export const COMMANDS: CommandMeta[] = [
38
38
  implemented: true,
39
39
  hasTemplate: true,
40
40
  requiresProject: false,
41
- features: ['Architect mode for blank projects', 'Auto tech stack recommendation', 'Analyzes existing codebases'],
41
+ features: [
42
+ 'Architect mode for blank projects',
43
+ 'Auto tech stack recommendation',
44
+ 'Analyzes existing codebases',
45
+ ],
42
46
  },
43
47
  {
44
48
  name: 'idea',
@@ -60,7 +64,12 @@ export const COMMANDS: CommandMeta[] = [
60
64
  implemented: true,
61
65
  hasTemplate: true,
62
66
  requiresProject: true,
63
- features: ['Agentic type classification', '7-phase workflow', 'Git branch management', 'Task breakdown'],
67
+ features: [
68
+ 'Agentic type classification',
69
+ '7-phase workflow',
70
+ 'Git branch management',
71
+ 'Task breakdown',
72
+ ],
64
73
  },
65
74
  {
66
75
  name: 'spec',
@@ -333,5 +342,20 @@ export const COMMANDS: CommandMeta[] = [
333
342
  'summary - Intelligent file summarization',
334
343
  ],
335
344
  },
345
+ {
346
+ name: 'uninstall',
347
+ group: 'setup',
348
+ description: 'Complete system removal of prjct',
349
+ usage: { claude: null, terminal: 'prjct uninstall' },
350
+ params: '[--force] [--backup] [--dry-run]',
351
+ implemented: true,
352
+ hasTemplate: false,
353
+ requiresProject: false,
354
+ features: [
355
+ 'Removes ~/.prjct-cli/ data',
356
+ 'Cleans CLAUDE.md prjct section',
357
+ 'Uninstalls Homebrew/npm packages',
358
+ 'Backup option before deletion',
359
+ ],
360
+ },
336
361
  ]
337
-
@@ -14,24 +14,23 @@
14
14
  * - Context: context
15
15
  */
16
16
 
17
- import { WorkflowCommands } from './workflow'
18
- import { PlanningCommands } from './planning'
19
- import { ShippingCommands } from './shipping'
20
- import { AnalyticsCommands } from './analytics'
21
- import { MaintenanceCommands } from './maintenance'
22
- import { AnalysisCommands } from './analysis'
23
- import { SetupCommands } from './setup'
24
- import { ContextCommands } from './context'
25
-
26
17
  import type {
27
- CommandResult,
28
18
  AgentInfo,
19
+ AnalyzeOptions,
29
20
  Author,
30
- DesignOptions,
31
21
  CleanupOptions,
22
+ CommandResult,
23
+ DesignOptions,
32
24
  SetupOptions,
33
- AnalyzeOptions
34
25
  } from '../types'
26
+ import { AnalysisCommands } from './analysis'
27
+ import { AnalyticsCommands } from './analytics'
28
+ import { ContextCommands } from './context'
29
+ import { MaintenanceCommands } from './maintenance'
30
+ import { PlanningCommands } from './planning'
31
+ import { SetupCommands } from './setup'
32
+ import { ShippingCommands } from './shipping'
33
+ import { WorkflowCommands } from './workflow'
35
34
 
36
35
  /**
37
36
  * PrjctCommands - Combined class with all commands
@@ -84,13 +83,19 @@ class PrjctCommands {
84
83
  return this.workflow.pause(reason, projectPath)
85
84
  }
86
85
 
87
- async resume(taskId: string | null = null, projectPath: string = process.cwd()): Promise<CommandResult> {
86
+ async resume(
87
+ taskId: string | null = null,
88
+ projectPath: string = process.cwd()
89
+ ): Promise<CommandResult> {
88
90
  return this.workflow.resume(taskId, projectPath)
89
91
  }
90
92
 
91
93
  // ========== Planning Commands ==========
92
94
 
93
- async init(idea: string | null = null, projectPath: string = process.cwd()): Promise<CommandResult> {
95
+ async init(
96
+ idea: string | null = null,
97
+ projectPath: string = process.cwd()
98
+ ): Promise<CommandResult> {
94
99
  return this.planning.init(idea, projectPath)
95
100
  }
96
101
 
@@ -102,7 +107,10 @@ class PrjctCommands {
102
107
  return this.planning.idea(description, projectPath)
103
108
  }
104
109
 
105
- async spec(featureName: string | null = null, projectPath: string = process.cwd()): Promise<CommandResult> {
110
+ async spec(
111
+ featureName: string | null = null,
112
+ projectPath: string = process.cwd()
113
+ ): Promise<CommandResult> {
106
114
  return this.planning.spec(featureName, projectPath)
107
115
  }
108
116
 
@@ -114,7 +122,10 @@ class PrjctCommands {
114
122
 
115
123
  // ========== Analytics Commands ==========
116
124
 
117
- async dash(view: string = 'default', projectPath: string = process.cwd()): Promise<CommandResult> {
125
+ async dash(
126
+ view: string = 'default',
127
+ projectPath: string = process.cwd()
128
+ ): Promise<CommandResult> {
118
129
  return this.analytics.dash(view, projectPath)
119
130
  }
120
131
 
@@ -124,11 +135,18 @@ class PrjctCommands {
124
135
 
125
136
  // ========== Maintenance Commands ==========
126
137
 
127
- async cleanup(options: CleanupOptions = {}, projectPath: string = process.cwd()): Promise<CommandResult> {
138
+ async cleanup(
139
+ options: CleanupOptions = {},
140
+ projectPath: string = process.cwd()
141
+ ): Promise<CommandResult> {
128
142
  return this.maintenance.cleanup(options, projectPath)
129
143
  }
130
144
 
131
- async design(target: string | null = null, options: DesignOptions = {}, projectPath: string = process.cwd()): Promise<CommandResult> {
145
+ async design(
146
+ target: string | null = null,
147
+ options: DesignOptions = {},
148
+ projectPath: string = process.cwd()
149
+ ): Promise<CommandResult> {
132
150
  return this.maintenance.design(target, options, projectPath)
133
151
  }
134
152
 
@@ -150,21 +168,33 @@ class PrjctCommands {
150
168
 
151
169
  // ========== Analysis Commands ==========
152
170
 
153
- async analyze(options: AnalyzeOptions = {}, projectPath: string = process.cwd()): Promise<CommandResult> {
171
+ async analyze(
172
+ options: AnalyzeOptions = {},
173
+ projectPath: string = process.cwd()
174
+ ): Promise<CommandResult> {
154
175
  return this.analysis.analyze(options, projectPath)
155
176
  }
156
177
 
157
- async sync(projectPath: string = process.cwd(), options: { aiTools?: string[] } = {}): Promise<CommandResult> {
178
+ async sync(
179
+ projectPath: string = process.cwd(),
180
+ options: { aiTools?: string[] } = {}
181
+ ): Promise<CommandResult> {
158
182
  return this.analysis.sync(projectPath, options)
159
183
  }
160
184
 
161
- async stats(projectPath: string = process.cwd(), options: { json?: boolean; export?: boolean } = {}): Promise<CommandResult> {
185
+ async stats(
186
+ projectPath: string = process.cwd(),
187
+ options: { json?: boolean; export?: boolean } = {}
188
+ ): Promise<CommandResult> {
162
189
  return this.analysis.stats(projectPath, options)
163
190
  }
164
191
 
165
192
  // ========== Context Commands ==========
166
193
 
167
- async context(input: string | null = null, projectPath: string = process.cwd()): Promise<CommandResult> {
194
+ async context(
195
+ input: string | null = null,
196
+ projectPath: string = process.cwd()
197
+ ): Promise<CommandResult> {
168
198
  return this.contextCmds.context(input, projectPath)
169
199
  }
170
200
 
@@ -204,7 +234,11 @@ class PrjctCommands {
204
234
  return this.workflow.getGlobalProjectPath(projectPath)
205
235
  }
206
236
 
207
- async logToMemory(projectPath: string, action: string, data: Record<string, unknown>): Promise<void> {
237
+ async logToMemory(
238
+ projectPath: string,
239
+ action: string,
240
+ data: Record<string, unknown>
241
+ ): Promise<void> {
208
242
  return this.workflow.logToMemory(projectPath, action, data)
209
243
  }
210
244
  }
@@ -214,4 +248,3 @@ const instance = new PrjctCommands()
214
248
 
215
249
  export default instance
216
250
  export { PrjctCommands }
217
-
@@ -15,14 +15,14 @@
15
15
  * @version 1.0.0
16
16
  */
17
17
 
18
- import fs from 'fs/promises'
19
- import path from 'path'
18
+ import fs from 'node:fs/promises'
19
+ import path from 'node:path'
20
+ import orchestratorExecutor from '../agentic/orchestrator-executor'
20
21
  import configManager from '../infrastructure/config-manager'
21
22
  import pathManager from '../infrastructure/path-manager'
22
23
  import { stateStorage } from '../storage'
23
- import orchestratorExecutor from '../agentic/orchestrator-executor'
24
- import { isNotFoundError } from '../types/fs'
25
24
  import type { CommandResult } from '../types'
25
+ import { isNotFoundError } from '../types/fs'
26
26
 
27
27
  // =============================================================================
28
28
  // Types
@@ -4,17 +4,10 @@
4
4
  * System architecture, API, and component design operations.
5
5
  */
6
6
 
7
- import path from 'path'
8
-
9
- import type { CommandResult, DesignOptions } from '../types'
10
- import {
11
- pathManager,
12
- configManager,
13
- fileHelper,
14
- dateHelper,
15
- out
16
- } from './base'
7
+ import path from 'node:path'
17
8
  import { memoryService } from '../services'
9
+ import type { CommandResult, DesignOptions } from '../types'
10
+ import { configManager, dateHelper, fileHelper, out, pathManager } from './base'
18
11
 
19
12
  /**
20
13
  * /p:design - Design system architecture, APIs, and components
@@ -8,15 +8,12 @@
8
8
  * - New: import { commandRegistry } from './commands' → registry.execute('work')
9
9
  */
10
10
 
11
+ // Types
12
+ export * from '../types'
11
13
  // Legacy exports (backwards compat)
12
14
  export { default, PrjctCommands } from './commands'
13
-
14
- // New registry-based exports
15
- export { commandRegistry, CommandRegistry } from './registry'
16
- export type { ExecutionContext, CommandHandler, HandlerFn, CommandMeta } from './registry'
17
-
18
15
  // Command registration (auto-runs on import)
19
16
  export { registerAllCommands } from './register'
20
-
21
- // Types
22
- export * from '../types'
17
+ export type { CommandHandler, CommandMeta, ExecutionContext, HandlerFn } from './registry'
18
+ // New registry-based exports
19
+ export { CommandRegistry, commandRegistry } from './registry'
@@ -7,13 +7,13 @@
7
7
  * - snapshots: Git-based undo/redo and session recovery
8
8
  */
9
9
 
10
- import type { CommandResult, CleanupOptions, DesignOptions } from '../types'
10
+ import type { CleanupOptions, CommandResult, DesignOptions } from '../types'
11
11
  import { PrjctCommandsBase } from './base'
12
12
 
13
13
  // Import individual command functions
14
14
  import { cleanup, cleanupMemory, cleanupMemoryInternal } from './cleanup'
15
15
  import { design } from './design'
16
- import { recover, undo, redo, history } from './snapshots'
16
+ import { history, recover, redo, undo } from './snapshots'
17
17
 
18
18
  /**
19
19
  * MaintenanceCommands - Facade class for maintenance operations
@@ -25,7 +25,10 @@ export class MaintenanceCommands extends PrjctCommandsBase {
25
25
  _cleanupMemory = cleanupMemory
26
26
  _cleanupMemoryInternal = cleanupMemoryInternal
27
27
 
28
- async cleanup(options: CleanupOptions = {}, projectPath: string = process.cwd()): Promise<CommandResult> {
28
+ async cleanup(
29
+ options: CleanupOptions = {},
30
+ projectPath: string = process.cwd()
31
+ ): Promise<CommandResult> {
29
32
  const initResult = await this.ensureProjectInit(projectPath)
30
33
  if (!initResult.success) return initResult
31
34
  return cleanup(options, projectPath)
@@ -71,4 +74,4 @@ export class MaintenanceCommands extends PrjctCommandsBase {
71
74
  // Re-export individual functions for direct use
72
75
  export { cleanup, cleanupMemory, cleanupMemoryInternal } from './cleanup'
73
76
  export { design } from './design'
74
- export { recover, undo, redo, history } from './snapshots'
77
+ export { history, recover, redo, undo } from './snapshots'