@thiagodiogo/pastelsdd 1.0.0-beta.1

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 (369) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +3 -0
  3. package/bin/pastelsdd.js +5 -0
  4. package/dist/cli/index.d.ts +5 -0
  5. package/dist/cli/index.js +526 -0
  6. package/dist/commands/change.d.ts +35 -0
  7. package/dist/commands/change.js +277 -0
  8. package/dist/commands/completion.d.ts +72 -0
  9. package/dist/commands/completion.js +264 -0
  10. package/dist/commands/config.d.ts +36 -0
  11. package/dist/commands/config.js +611 -0
  12. package/dist/commands/context-store.d.ts +3 -0
  13. package/dist/commands/context-store.js +282 -0
  14. package/dist/commands/feedback.d.ts +9 -0
  15. package/dist/commands/feedback.js +183 -0
  16. package/dist/commands/initiative.d.ts +13 -0
  17. package/dist/commands/initiative.js +318 -0
  18. package/dist/commands/schema.d.ts +6 -0
  19. package/dist/commands/schema.js +869 -0
  20. package/dist/commands/show.d.ts +14 -0
  21. package/dist/commands/show.js +132 -0
  22. package/dist/commands/spec.d.ts +15 -0
  23. package/dist/commands/spec.js +225 -0
  24. package/dist/commands/validate.d.ts +24 -0
  25. package/dist/commands/validate.js +294 -0
  26. package/dist/commands/workflow/index.d.ts +19 -0
  27. package/dist/commands/workflow/index.js +13 -0
  28. package/dist/commands/workflow/initiative-link.d.ts +24 -0
  29. package/dist/commands/workflow/initiative-link.js +47 -0
  30. package/dist/commands/workflow/instructions.d.ts +29 -0
  31. package/dist/commands/workflow/instructions.js +344 -0
  32. package/dist/commands/workflow/new-change.d.ts +17 -0
  33. package/dist/commands/workflow/new-change.js +141 -0
  34. package/dist/commands/workflow/schemas.d.ts +10 -0
  35. package/dist/commands/workflow/schemas.js +34 -0
  36. package/dist/commands/workflow/set-change.d.ts +13 -0
  37. package/dist/commands/workflow/set-change.js +87 -0
  38. package/dist/commands/workflow/shared.d.ts +59 -0
  39. package/dist/commands/workflow/shared.js +116 -0
  40. package/dist/commands/workflow/status.d.ts +14 -0
  41. package/dist/commands/workflow/status.js +90 -0
  42. package/dist/commands/workflow/templates.d.ts +16 -0
  43. package/dist/commands/workflow/templates.js +69 -0
  44. package/dist/commands/workspace/context-status.d.ts +4 -0
  45. package/dist/commands/workspace/context-status.js +59 -0
  46. package/dist/commands/workspace/open-view.d.ts +62 -0
  47. package/dist/commands/workspace/open-view.js +228 -0
  48. package/dist/commands/workspace/open.d.ts +37 -0
  49. package/dist/commands/workspace/open.js +102 -0
  50. package/dist/commands/workspace/opener-selection.d.ts +11 -0
  51. package/dist/commands/workspace/opener-selection.js +93 -0
  52. package/dist/commands/workspace/operations.d.ts +28 -0
  53. package/dist/commands/workspace/operations.js +543 -0
  54. package/dist/commands/workspace/prompt-theme.d.ts +29 -0
  55. package/dist/commands/workspace/prompt-theme.js +24 -0
  56. package/dist/commands/workspace/registration.d.ts +13 -0
  57. package/dist/commands/workspace/registration.js +84 -0
  58. package/dist/commands/workspace/selection.d.ts +6 -0
  59. package/dist/commands/workspace/selection.js +122 -0
  60. package/dist/commands/workspace/types.d.ts +103 -0
  61. package/dist/commands/workspace/types.js +36 -0
  62. package/dist/commands/workspace.d.ts +6 -0
  63. package/dist/commands/workspace.js +678 -0
  64. package/dist/core/archive.d.ts +11 -0
  65. package/dist/core/archive.js +318 -0
  66. package/dist/core/artifact-graph/graph.d.ts +56 -0
  67. package/dist/core/artifact-graph/graph.js +141 -0
  68. package/dist/core/artifact-graph/index.d.ts +9 -0
  69. package/dist/core/artifact-graph/index.js +14 -0
  70. package/dist/core/artifact-graph/instruction-loader.d.ts +183 -0
  71. package/dist/core/artifact-graph/instruction-loader.js +256 -0
  72. package/dist/core/artifact-graph/outputs.d.ts +14 -0
  73. package/dist/core/artifact-graph/outputs.js +39 -0
  74. package/dist/core/artifact-graph/resolver.d.ts +81 -0
  75. package/dist/core/artifact-graph/resolver.js +257 -0
  76. package/dist/core/artifact-graph/schema.d.ts +13 -0
  77. package/dist/core/artifact-graph/schema.js +108 -0
  78. package/dist/core/artifact-graph/state.d.ts +12 -0
  79. package/dist/core/artifact-graph/state.js +31 -0
  80. package/dist/core/artifact-graph/types.d.ts +40 -0
  81. package/dist/core/artifact-graph/types.js +29 -0
  82. package/dist/core/available-tools.d.ts +17 -0
  83. package/dist/core/available-tools.js +43 -0
  84. package/dist/core/change-metadata/index.d.ts +2 -0
  85. package/dist/core/change-metadata/index.js +2 -0
  86. package/dist/core/change-metadata/schema.d.ts +18 -0
  87. package/dist/core/change-metadata/schema.js +28 -0
  88. package/dist/core/change-status-policy.d.ts +50 -0
  89. package/dist/core/change-status-policy.js +70 -0
  90. package/dist/core/collections/index.d.ts +3 -0
  91. package/dist/core/collections/index.js +3 -0
  92. package/dist/core/collections/initiatives/collection.d.ts +4 -0
  93. package/dist/core/collections/initiatives/collection.js +17 -0
  94. package/dist/core/collections/initiatives/index.d.ts +6 -0
  95. package/dist/core/collections/initiatives/index.js +6 -0
  96. package/dist/core/collections/initiatives/operations.d.ts +49 -0
  97. package/dist/core/collections/initiatives/operations.js +175 -0
  98. package/dist/core/collections/initiatives/resolution.d.ts +87 -0
  99. package/dist/core/collections/initiatives/resolution.js +374 -0
  100. package/dist/core/collections/initiatives/schema.d.ts +41 -0
  101. package/dist/core/collections/initiatives/schema.js +134 -0
  102. package/dist/core/collections/initiatives/templates.d.ts +12 -0
  103. package/dist/core/collections/initiatives/templates.js +90 -0
  104. package/dist/core/collections/runtime.d.ts +46 -0
  105. package/dist/core/collections/runtime.js +194 -0
  106. package/dist/core/command-generation/adapters/amazon-q.d.ts +13 -0
  107. package/dist/core/command-generation/adapters/amazon-q.js +26 -0
  108. package/dist/core/command-generation/adapters/antigravity.d.ts +13 -0
  109. package/dist/core/command-generation/adapters/antigravity.js +26 -0
  110. package/dist/core/command-generation/adapters/auggie.d.ts +13 -0
  111. package/dist/core/command-generation/adapters/auggie.js +27 -0
  112. package/dist/core/command-generation/adapters/bob.d.ts +14 -0
  113. package/dist/core/command-generation/adapters/bob.js +45 -0
  114. package/dist/core/command-generation/adapters/claude.d.ts +13 -0
  115. package/dist/core/command-generation/adapters/claude.js +50 -0
  116. package/dist/core/command-generation/adapters/cline.d.ts +14 -0
  117. package/dist/core/command-generation/adapters/cline.js +27 -0
  118. package/dist/core/command-generation/adapters/codebuddy.d.ts +13 -0
  119. package/dist/core/command-generation/adapters/codebuddy.js +28 -0
  120. package/dist/core/command-generation/adapters/codex.d.ts +16 -0
  121. package/dist/core/command-generation/adapters/codex.js +39 -0
  122. package/dist/core/command-generation/adapters/continue.d.ts +13 -0
  123. package/dist/core/command-generation/adapters/continue.js +28 -0
  124. package/dist/core/command-generation/adapters/costrict.d.ts +13 -0
  125. package/dist/core/command-generation/adapters/costrict.js +27 -0
  126. package/dist/core/command-generation/adapters/crush.d.ts +13 -0
  127. package/dist/core/command-generation/adapters/crush.js +30 -0
  128. package/dist/core/command-generation/adapters/cursor.d.ts +14 -0
  129. package/dist/core/command-generation/adapters/cursor.js +44 -0
  130. package/dist/core/command-generation/adapters/factory.d.ts +13 -0
  131. package/dist/core/command-generation/adapters/factory.js +27 -0
  132. package/dist/core/command-generation/adapters/gemini.d.ts +13 -0
  133. package/dist/core/command-generation/adapters/gemini.js +26 -0
  134. package/dist/core/command-generation/adapters/github-copilot.d.ts +13 -0
  135. package/dist/core/command-generation/adapters/github-copilot.js +26 -0
  136. package/dist/core/command-generation/adapters/iflow.d.ts +13 -0
  137. package/dist/core/command-generation/adapters/iflow.js +29 -0
  138. package/dist/core/command-generation/adapters/index.d.ts +32 -0
  139. package/dist/core/command-generation/adapters/index.js +32 -0
  140. package/dist/core/command-generation/adapters/junie.d.ts +13 -0
  141. package/dist/core/command-generation/adapters/junie.js +26 -0
  142. package/dist/core/command-generation/adapters/kilocode.d.ts +14 -0
  143. package/dist/core/command-generation/adapters/kilocode.js +23 -0
  144. package/dist/core/command-generation/adapters/kiro.d.ts +13 -0
  145. package/dist/core/command-generation/adapters/kiro.js +26 -0
  146. package/dist/core/command-generation/adapters/lingma.d.ts +13 -0
  147. package/dist/core/command-generation/adapters/lingma.js +30 -0
  148. package/dist/core/command-generation/adapters/opencode.d.ts +13 -0
  149. package/dist/core/command-generation/adapters/opencode.js +29 -0
  150. package/dist/core/command-generation/adapters/pi.d.ts +18 -0
  151. package/dist/core/command-generation/adapters/pi.js +55 -0
  152. package/dist/core/command-generation/adapters/qoder.d.ts +13 -0
  153. package/dist/core/command-generation/adapters/qoder.js +30 -0
  154. package/dist/core/command-generation/adapters/qwen.d.ts +13 -0
  155. package/dist/core/command-generation/adapters/qwen.js +26 -0
  156. package/dist/core/command-generation/adapters/roocode.d.ts +14 -0
  157. package/dist/core/command-generation/adapters/roocode.js +27 -0
  158. package/dist/core/command-generation/adapters/windsurf.d.ts +14 -0
  159. package/dist/core/command-generation/adapters/windsurf.js +51 -0
  160. package/dist/core/command-generation/generator.d.ts +21 -0
  161. package/dist/core/command-generation/generator.js +27 -0
  162. package/dist/core/command-generation/index.d.ts +22 -0
  163. package/dist/core/command-generation/index.js +24 -0
  164. package/dist/core/command-generation/registry.d.ts +36 -0
  165. package/dist/core/command-generation/registry.js +98 -0
  166. package/dist/core/command-generation/types.d.ts +56 -0
  167. package/dist/core/command-generation/types.js +8 -0
  168. package/dist/core/completions/command-registry.d.ts +3 -0
  169. package/dist/core/completions/command-registry.js +939 -0
  170. package/dist/core/completions/completion-provider.d.ts +71 -0
  171. package/dist/core/completions/completion-provider.js +129 -0
  172. package/dist/core/completions/factory.d.ts +64 -0
  173. package/dist/core/completions/factory.js +75 -0
  174. package/dist/core/completions/generators/bash-generator.d.ts +35 -0
  175. package/dist/core/completions/generators/bash-generator.js +230 -0
  176. package/dist/core/completions/generators/fish-generator.d.ts +32 -0
  177. package/dist/core/completions/generators/fish-generator.js +160 -0
  178. package/dist/core/completions/generators/powershell-generator.d.ts +36 -0
  179. package/dist/core/completions/generators/powershell-generator.js +266 -0
  180. package/dist/core/completions/generators/zsh-generator.d.ts +47 -0
  181. package/dist/core/completions/generators/zsh-generator.js +274 -0
  182. package/dist/core/completions/installers/bash-installer.d.ts +87 -0
  183. package/dist/core/completions/installers/bash-installer.js +318 -0
  184. package/dist/core/completions/installers/fish-installer.d.ts +43 -0
  185. package/dist/core/completions/installers/fish-installer.js +143 -0
  186. package/dist/core/completions/installers/powershell-installer.d.ts +102 -0
  187. package/dist/core/completions/installers/powershell-installer.js +387 -0
  188. package/dist/core/completions/installers/zsh-installer.d.ts +117 -0
  189. package/dist/core/completions/installers/zsh-installer.js +421 -0
  190. package/dist/core/completions/shared-flags.d.ts +12 -0
  191. package/dist/core/completions/shared-flags.js +28 -0
  192. package/dist/core/completions/templates/bash-templates.d.ts +6 -0
  193. package/dist/core/completions/templates/bash-templates.js +30 -0
  194. package/dist/core/completions/templates/fish-templates.d.ts +7 -0
  195. package/dist/core/completions/templates/fish-templates.js +45 -0
  196. package/dist/core/completions/templates/powershell-templates.d.ts +6 -0
  197. package/dist/core/completions/templates/powershell-templates.js +34 -0
  198. package/dist/core/completions/templates/zsh-templates.d.ts +6 -0
  199. package/dist/core/completions/templates/zsh-templates.js +45 -0
  200. package/dist/core/completions/types.d.ts +101 -0
  201. package/dist/core/completions/types.js +2 -0
  202. package/dist/core/config-prompts.d.ts +9 -0
  203. package/dist/core/config-prompts.js +34 -0
  204. package/dist/core/config-schema.d.ts +86 -0
  205. package/dist/core/config-schema.js +213 -0
  206. package/dist/core/config.d.ts +18 -0
  207. package/dist/core/config.js +38 -0
  208. package/dist/core/context-store/binding.d.ts +53 -0
  209. package/dist/core/context-store/binding.js +197 -0
  210. package/dist/core/context-store/errors.d.ts +20 -0
  211. package/dist/core/context-store/errors.js +22 -0
  212. package/dist/core/context-store/foundation.d.ts +54 -0
  213. package/dist/core/context-store/foundation.js +318 -0
  214. package/dist/core/context-store/index.d.ts +6 -0
  215. package/dist/core/context-store/index.js +6 -0
  216. package/dist/core/context-store/operations.d.ts +62 -0
  217. package/dist/core/context-store/operations.js +352 -0
  218. package/dist/core/context-store/registry.d.ts +35 -0
  219. package/dist/core/context-store/registry.js +158 -0
  220. package/dist/core/converters/json-converter.d.ts +6 -0
  221. package/dist/core/converters/json-converter.js +51 -0
  222. package/dist/core/global-config.d.ts +49 -0
  223. package/dist/core/global-config.js +124 -0
  224. package/dist/core/index.d.ts +6 -0
  225. package/dist/core/index.js +7 -0
  226. package/dist/core/init.d.ts +37 -0
  227. package/dist/core/init.js +593 -0
  228. package/dist/core/legacy-cleanup.d.ts +162 -0
  229. package/dist/core/legacy-cleanup.js +514 -0
  230. package/dist/core/list.d.ts +9 -0
  231. package/dist/core/list.js +171 -0
  232. package/dist/core/migration.d.ts +23 -0
  233. package/dist/core/migration.js +108 -0
  234. package/dist/core/parsers/change-parser.d.ts +13 -0
  235. package/dist/core/parsers/change-parser.js +197 -0
  236. package/dist/core/parsers/markdown-parser.d.ts +26 -0
  237. package/dist/core/parsers/markdown-parser.js +227 -0
  238. package/dist/core/parsers/requirement-blocks.d.ts +37 -0
  239. package/dist/core/parsers/requirement-blocks.js +201 -0
  240. package/dist/core/parsers/spec-structure.d.ts +9 -0
  241. package/dist/core/parsers/spec-structure.js +88 -0
  242. package/dist/core/planning-home.d.ts +21 -0
  243. package/dist/core/planning-home.js +108 -0
  244. package/dist/core/profile-sync-drift.d.ts +38 -0
  245. package/dist/core/profile-sync-drift.js +200 -0
  246. package/dist/core/profiles.d.ts +26 -0
  247. package/dist/core/profiles.js +40 -0
  248. package/dist/core/project-config.d.ts +64 -0
  249. package/dist/core/project-config.js +223 -0
  250. package/dist/core/schemas/base.schema.d.ts +13 -0
  251. package/dist/core/schemas/base.schema.js +13 -0
  252. package/dist/core/schemas/change.schema.d.ts +73 -0
  253. package/dist/core/schemas/change.schema.js +31 -0
  254. package/dist/core/schemas/index.d.ts +4 -0
  255. package/dist/core/schemas/index.js +4 -0
  256. package/dist/core/schemas/spec.schema.d.ts +18 -0
  257. package/dist/core/schemas/spec.schema.js +15 -0
  258. package/dist/core/shared/index.d.ts +8 -0
  259. package/dist/core/shared/index.js +8 -0
  260. package/dist/core/shared/skill-generation.d.ts +49 -0
  261. package/dist/core/shared/skill-generation.js +96 -0
  262. package/dist/core/shared/tool-detection.d.ts +71 -0
  263. package/dist/core/shared/tool-detection.js +158 -0
  264. package/dist/core/specs-apply.d.ts +73 -0
  265. package/dist/core/specs-apply.js +392 -0
  266. package/dist/core/styles/palette.d.ts +7 -0
  267. package/dist/core/styles/palette.js +8 -0
  268. package/dist/core/templates/index.d.ts +8 -0
  269. package/dist/core/templates/index.js +9 -0
  270. package/dist/core/templates/skill-templates.d.ts +19 -0
  271. package/dist/core/templates/skill-templates.js +18 -0
  272. package/dist/core/templates/types.d.ts +19 -0
  273. package/dist/core/templates/types.js +5 -0
  274. package/dist/core/templates/workflows/apply-change.d.ts +10 -0
  275. package/dist/core/templates/workflows/apply-change.js +314 -0
  276. package/dist/core/templates/workflows/archive-change.d.ts +10 -0
  277. package/dist/core/templates/workflows/archive-change.js +277 -0
  278. package/dist/core/templates/workflows/bulk-archive-change.d.ts +10 -0
  279. package/dist/core/templates/workflows/bulk-archive-change.js +492 -0
  280. package/dist/core/templates/workflows/continue-change.d.ts +10 -0
  281. package/dist/core/templates/workflows/continue-change.js +234 -0
  282. package/dist/core/templates/workflows/explore.d.ts +10 -0
  283. package/dist/core/templates/workflows/explore.js +459 -0
  284. package/dist/core/templates/workflows/feedback.d.ts +9 -0
  285. package/dist/core/templates/workflows/feedback.js +108 -0
  286. package/dist/core/templates/workflows/ff-change.d.ts +10 -0
  287. package/dist/core/templates/workflows/ff-change.js +200 -0
  288. package/dist/core/templates/workflows/new-change.d.ts +10 -0
  289. package/dist/core/templates/workflows/new-change.js +143 -0
  290. package/dist/core/templates/workflows/onboard.d.ts +10 -0
  291. package/dist/core/templates/workflows/onboard.js +563 -0
  292. package/dist/core/templates/workflows/propose.d.ts +10 -0
  293. package/dist/core/templates/workflows/propose.js +218 -0
  294. package/dist/core/templates/workflows/sync-specs.d.ts +10 -0
  295. package/dist/core/templates/workflows/sync-specs.js +290 -0
  296. package/dist/core/templates/workflows/verify-change.d.ts +10 -0
  297. package/dist/core/templates/workflows/verify-change.js +338 -0
  298. package/dist/core/update.d.ts +82 -0
  299. package/dist/core/update.js +557 -0
  300. package/dist/core/validation/constants.d.ts +34 -0
  301. package/dist/core/validation/constants.js +40 -0
  302. package/dist/core/validation/types.d.ts +18 -0
  303. package/dist/core/validation/types.js +2 -0
  304. package/dist/core/validation/validator.d.ts +33 -0
  305. package/dist/core/validation/validator.js +418 -0
  306. package/dist/core/view.d.ts +8 -0
  307. package/dist/core/view.js +168 -0
  308. package/dist/core/workspace/foundation.d.ts +62 -0
  309. package/dist/core/workspace/foundation.js +274 -0
  310. package/dist/core/workspace/index.d.ts +8 -0
  311. package/dist/core/workspace/index.js +8 -0
  312. package/dist/core/workspace/legacy-state.d.ts +28 -0
  313. package/dist/core/workspace/legacy-state.js +200 -0
  314. package/dist/core/workspace/link-input.d.ts +9 -0
  315. package/dist/core/workspace/link-input.js +32 -0
  316. package/dist/core/workspace/open-surface.d.ts +43 -0
  317. package/dist/core/workspace/open-surface.js +214 -0
  318. package/dist/core/workspace/openers.d.ts +21 -0
  319. package/dist/core/workspace/openers.js +119 -0
  320. package/dist/core/workspace/registry.d.ts +24 -0
  321. package/dist/core/workspace/registry.js +146 -0
  322. package/dist/core/workspace/skills.d.ts +57 -0
  323. package/dist/core/workspace/skills.js +334 -0
  324. package/dist/core/workspace/state-io.d.ts +10 -0
  325. package/dist/core/workspace/state-io.js +119 -0
  326. package/dist/index.d.ts +3 -0
  327. package/dist/index.js +3 -0
  328. package/dist/prompts/searchable-multi-select.d.ts +28 -0
  329. package/dist/prompts/searchable-multi-select.js +159 -0
  330. package/dist/telemetry/config.d.ts +38 -0
  331. package/dist/telemetry/config.js +136 -0
  332. package/dist/telemetry/index.d.ts +31 -0
  333. package/dist/telemetry/index.js +164 -0
  334. package/dist/ui/ascii-patterns.d.ts +16 -0
  335. package/dist/ui/ascii-patterns.js +133 -0
  336. package/dist/ui/welcome-screen.d.ts +10 -0
  337. package/dist/ui/welcome-screen.js +146 -0
  338. package/dist/utils/change-metadata.d.ts +54 -0
  339. package/dist/utils/change-metadata.js +141 -0
  340. package/dist/utils/change-utils.d.ts +71 -0
  341. package/dist/utils/change-utils.js +123 -0
  342. package/dist/utils/command-references.d.ts +18 -0
  343. package/dist/utils/command-references.js +20 -0
  344. package/dist/utils/file-system.d.ts +41 -0
  345. package/dist/utils/file-system.js +301 -0
  346. package/dist/utils/index.d.ts +6 -0
  347. package/dist/utils/index.js +9 -0
  348. package/dist/utils/interactive.d.ts +18 -0
  349. package/dist/utils/interactive.js +21 -0
  350. package/dist/utils/item-discovery.d.ts +4 -0
  351. package/dist/utils/item-discovery.js +72 -0
  352. package/dist/utils/match.d.ts +3 -0
  353. package/dist/utils/match.js +22 -0
  354. package/dist/utils/shell-detection.d.ts +20 -0
  355. package/dist/utils/shell-detection.js +41 -0
  356. package/dist/utils/task-progress.d.ts +8 -0
  357. package/dist/utils/task-progress.js +36 -0
  358. package/package.json +84 -0
  359. package/schemas/spec-driven/schema.yaml +153 -0
  360. package/schemas/spec-driven/templates/design.md +19 -0
  361. package/schemas/spec-driven/templates/proposal.md +23 -0
  362. package/schemas/spec-driven/templates/spec.md +8 -0
  363. package/schemas/spec-driven/templates/tasks.md +9 -0
  364. package/schemas/workspace-planning/schema.yaml +72 -0
  365. package/schemas/workspace-planning/templates/design.md +33 -0
  366. package/schemas/workspace-planning/templates/proposal.md +28 -0
  367. package/schemas/workspace-planning/templates/spec.md +9 -0
  368. package/schemas/workspace-planning/templates/tasks.md +15 -0
  369. package/scripts/postinstall.js +83 -0
@@ -0,0 +1,492 @@
1
+ export function getBulkArchiveChangeSkillTemplate() {
2
+ return {
3
+ name: 'pastelsdd-bulk-archive-change',
4
+ description: 'Archive multiple completed changes at once. Use when archiving several parallel changes.',
5
+ instructions: `Archive multiple completed changes in a single operation.
6
+
7
+ This skill allows you to batch-archive changes, handling spec conflicts intelligently by checking the codebase to determine what's actually implemented.
8
+
9
+ **Input**: None required (prompts for selection)
10
+
11
+ **Steps**
12
+
13
+ 1. **Get active changes**
14
+
15
+ Run \`pastelsdd list --json\` to get all active changes.
16
+
17
+ If no active changes exist, inform user and stop.
18
+
19
+ 2. **Prompt for change selection**
20
+
21
+ Use **AskUserQuestion tool** with multi-select to let user choose changes:
22
+ - Show each change with its schema
23
+ - Include an option for "All changes"
24
+ - Allow any number of selections (1+ works, 2+ is the typical use case)
25
+
26
+ **IMPORTANT**: Do NOT auto-select. Always let the user choose.
27
+
28
+ 3. **Batch validation - gather status for all selected changes**
29
+
30
+ For each selected change, collect:
31
+
32
+ a. **Artifact status** - Run \`pastelsdd status --change "<name>" --json\`
33
+ - Parse \`schemaName\`, \`artifacts\`, \`planningHome\`, \`changeRoot\`, \`artifactPaths\`, and \`actionContext\`
34
+ - Note which artifacts are \`done\` vs other states
35
+
36
+ If any selected change reports \`actionContext.mode: "workspace-planning"\`, explain that workspace bulk archive is not supported in this slice and STOP before syncing specs or moving changes. Do not fall back to repo-local paths or edit linked repos.
37
+
38
+ b. **Task completion** - Read \`artifactPaths.tasks.existingOutputPaths\` from status JSON
39
+ - Count \`- [ ]\` (incomplete) vs \`- [x]\` (complete)
40
+ - If no tasks file exists, note as "No tasks"
41
+
42
+ c. **Delta specs** - Check \`artifactPaths.specs.existingOutputPaths\` from status JSON
43
+ - List which capability specs exist
44
+ - For each, extract requirement names (lines matching \`### Requirement: <name>\`)
45
+
46
+ 4. **Detect spec conflicts**
47
+
48
+ Build a map of \`capability -> [changes that touch it]\`:
49
+
50
+ \`\`\`
51
+ auth -> [change-a, change-b] <- CONFLICT (2+ changes)
52
+ api -> [change-c] <- OK (only 1 change)
53
+ \`\`\`
54
+
55
+ A conflict exists when 2+ selected changes have delta specs for the same capability.
56
+
57
+ 5. **Resolve conflicts agentically**
58
+
59
+ **For each conflict**, investigate the codebase:
60
+
61
+ a. **Read the delta specs** from each conflicting change to understand what each claims to add/modify
62
+
63
+ b. **Search the codebase** for implementation evidence:
64
+ - Look for code implementing requirements from each delta spec
65
+ - Check for related files, functions, or tests
66
+
67
+ c. **Determine resolution**:
68
+ - If only one change is actually implemented -> sync that one's specs
69
+ - If both implemented -> apply in chronological order (older first, newer overwrites)
70
+ - If neither implemented -> skip spec sync, warn user
71
+
72
+ d. **Record resolution** for each conflict:
73
+ - Which change's specs to apply
74
+ - In what order (if both)
75
+ - Rationale (what was found in codebase)
76
+
77
+ 6. **Show consolidated status table**
78
+
79
+ Display a table summarizing all changes:
80
+
81
+ \`\`\`
82
+ | Change | Artifacts | Tasks | Specs | Conflicts | Status |
83
+ |---------------------|-----------|-------|---------|-----------|--------|
84
+ | schema-management | Done | 5/5 | 2 delta | None | Ready |
85
+ | project-config | Done | 3/3 | 1 delta | None | Ready |
86
+ | add-oauth | Done | 4/4 | 1 delta | auth (!) | Ready* |
87
+ | add-verify-skill | 1 left | 2/5 | None | None | Warn |
88
+ \`\`\`
89
+
90
+ For conflicts, show the resolution:
91
+ \`\`\`
92
+ * Conflict resolution:
93
+ - auth spec: Will apply add-oauth then add-jwt (both implemented, chronological order)
94
+ \`\`\`
95
+
96
+ For incomplete changes, show warnings:
97
+ \`\`\`
98
+ Warnings:
99
+ - add-verify-skill: 1 incomplete artifact, 3 incomplete tasks
100
+ \`\`\`
101
+
102
+ 7. **Confirm batch operation**
103
+
104
+ Use **AskUserQuestion tool** with a single confirmation:
105
+
106
+ - "Archive N changes?" with options based on status
107
+ - Options might include:
108
+ - "Archive all N changes"
109
+ - "Archive only N ready changes (skip incomplete)"
110
+ - "Cancel"
111
+
112
+ If there are incomplete changes, make clear they'll be archived with warnings.
113
+
114
+ 8. **Execute archive for each confirmed change**
115
+
116
+ Process changes in the determined order (respecting conflict resolution):
117
+
118
+ a. **Sync specs** if delta specs exist:
119
+ - Use the pastelsdd-sync-specs approach (agent-driven intelligent merge)
120
+ - For conflicts, apply in resolved order
121
+ - Track if sync was done
122
+
123
+ b. **Perform the archive**:
124
+ \`\`\`bash
125
+ mkdir -p "<planningHome.changesDir>/archive"
126
+ mv "<changeRoot>" "<planningHome.changesDir>/archive/YYYY-MM-DD-<name>"
127
+ \`\`\`
128
+
129
+ c. **Track outcome** for each change:
130
+ - Success: archived successfully
131
+ - Failed: error during archive (record error)
132
+ - Skipped: user chose not to archive (if applicable)
133
+
134
+ 9. **Display summary**
135
+
136
+ Show final results:
137
+
138
+ \`\`\`
139
+ ## Bulk Archive Complete
140
+
141
+ Archived 3 changes:
142
+ - schema-management-cli -> archive/2026-01-19-schema-management-cli/
143
+ - project-config -> archive/2026-01-19-project-config/
144
+ - add-oauth -> archive/2026-01-19-add-oauth/
145
+
146
+ Skipped 1 change:
147
+ - add-verify-skill (user chose not to archive incomplete)
148
+
149
+ Spec sync summary:
150
+ - 4 delta specs synced to main specs
151
+ - 1 conflict resolved (auth: applied both in chronological order)
152
+ \`\`\`
153
+
154
+ If any failures:
155
+ \`\`\`
156
+ Failed 1 change:
157
+ - some-change: Archive directory already exists
158
+ \`\`\`
159
+
160
+ **Conflict Resolution Examples**
161
+
162
+ Example 1: Only one implemented
163
+ \`\`\`
164
+ Conflict: specs/auth/spec.md touched by [add-oauth, add-jwt]
165
+
166
+ Checking add-oauth:
167
+ - Delta adds "OAuth Provider Integration" requirement
168
+ - Searching codebase... found src/auth/oauth.ts implementing OAuth flow
169
+
170
+ Checking add-jwt:
171
+ - Delta adds "JWT Token Handling" requirement
172
+ - Searching codebase... no JWT implementation found
173
+
174
+ Resolution: Only add-oauth is implemented. Will sync add-oauth specs only.
175
+ \`\`\`
176
+
177
+ Example 2: Both implemented
178
+ \`\`\`
179
+ Conflict: specs/api/spec.md touched by [add-rest-api, add-graphql]
180
+
181
+ Checking add-rest-api (created 2026-01-10):
182
+ - Delta adds "REST Endpoints" requirement
183
+ - Searching codebase... found src/api/rest.ts
184
+
185
+ Checking add-graphql (created 2026-01-15):
186
+ - Delta adds "GraphQL Schema" requirement
187
+ - Searching codebase... found src/api/graphql.ts
188
+
189
+ Resolution: Both implemented. Will apply add-rest-api specs first,
190
+ then add-graphql specs (chronological order, newer takes precedence).
191
+ \`\`\`
192
+
193
+ **Output On Success**
194
+
195
+ \`\`\`
196
+ ## Bulk Archive Complete
197
+
198
+ Archived N changes:
199
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
200
+ - <change-2> -> archive/YYYY-MM-DD-<change-2>/
201
+
202
+ Spec sync summary:
203
+ - N delta specs synced to main specs
204
+ - No conflicts (or: M conflicts resolved)
205
+ \`\`\`
206
+
207
+ **Output On Partial Success**
208
+
209
+ \`\`\`
210
+ ## Bulk Archive Complete (partial)
211
+
212
+ Archived N changes:
213
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
214
+
215
+ Skipped M changes:
216
+ - <change-2> (user chose not to archive incomplete)
217
+
218
+ Failed K changes:
219
+ - <change-3>: Archive directory already exists
220
+ \`\`\`
221
+
222
+ **Output When No Changes**
223
+
224
+ \`\`\`
225
+ ## No Changes to Archive
226
+
227
+ No active changes found. Create a new change to get started.
228
+ \`\`\`
229
+
230
+ **Guardrails**
231
+ - Allow any number of changes (1+ is fine, 2+ is the typical use case)
232
+ - Always prompt for selection, never auto-select
233
+ - Detect spec conflicts early and resolve by checking codebase
234
+ - When both changes are implemented, apply specs in chronological order
235
+ - Skip spec sync only when implementation is missing (warn user)
236
+ - Show clear per-change status before confirming
237
+ - Use single confirmation for entire batch
238
+ - Track and report all outcomes (success/skip/fail)
239
+ - Preserve .pastelsdd.yaml when moving to archive
240
+ - Archive directory target uses current date: YYYY-MM-DD-<name>
241
+ - If archive target exists, fail that change but continue with others`,
242
+ license: 'MIT',
243
+ compatibility: 'Requires pastelsdd CLI.',
244
+ metadata: { author: 'pastelsdd', version: '1.0' },
245
+ };
246
+ }
247
+ export function getOpsxBulkArchiveCommandTemplate() {
248
+ return {
249
+ name: 'OPSX: Bulk Archive',
250
+ description: 'Archive multiple completed changes at once',
251
+ category: 'Workflow',
252
+ tags: ['workflow', 'archive', 'experimental', 'bulk'],
253
+ content: `Archive multiple completed changes in a single operation.
254
+
255
+ This skill allows you to batch-archive changes, handling spec conflicts intelligently by checking the codebase to determine what's actually implemented.
256
+
257
+ **Input**: None required (prompts for selection)
258
+
259
+ **Steps**
260
+
261
+ 1. **Get active changes**
262
+
263
+ Run \`pastelsdd list --json\` to get all active changes.
264
+
265
+ If no active changes exist, inform user and stop.
266
+
267
+ 2. **Prompt for change selection**
268
+
269
+ Use **AskUserQuestion tool** with multi-select to let user choose changes:
270
+ - Show each change with its schema
271
+ - Include an option for "All changes"
272
+ - Allow any number of selections (1+ works, 2+ is the typical use case)
273
+
274
+ **IMPORTANT**: Do NOT auto-select. Always let the user choose.
275
+
276
+ 3. **Batch validation - gather status for all selected changes**
277
+
278
+ For each selected change, collect:
279
+
280
+ a. **Artifact status** - Run \`pastelsdd status --change "<name>" --json\`
281
+ - Parse \`schemaName\`, \`artifacts\`, \`planningHome\`, \`changeRoot\`, \`artifactPaths\`, and \`actionContext\`
282
+ - Note which artifacts are \`done\` vs other states
283
+
284
+ If any selected change reports \`actionContext.mode: "workspace-planning"\`, explain that workspace bulk archive is not supported in this slice and STOP before syncing specs or moving changes. Do not fall back to repo-local paths or edit linked repos.
285
+
286
+ b. **Task completion** - Read \`artifactPaths.tasks.existingOutputPaths\` from status JSON
287
+ - Count \`- [ ]\` (incomplete) vs \`- [x]\` (complete)
288
+ - If no tasks file exists, note as "No tasks"
289
+
290
+ c. **Delta specs** - Check \`artifactPaths.specs.existingOutputPaths\` from status JSON
291
+ - List which capability specs exist
292
+ - For each, extract requirement names (lines matching \`### Requirement: <name>\`)
293
+
294
+ 4. **Detect spec conflicts**
295
+
296
+ Build a map of \`capability -> [changes that touch it]\`:
297
+
298
+ \`\`\`
299
+ auth -> [change-a, change-b] <- CONFLICT (2+ changes)
300
+ api -> [change-c] <- OK (only 1 change)
301
+ \`\`\`
302
+
303
+ A conflict exists when 2+ selected changes have delta specs for the same capability.
304
+
305
+ 5. **Resolve conflicts agentically**
306
+
307
+ **For each conflict**, investigate the codebase:
308
+
309
+ a. **Read the delta specs** from each conflicting change to understand what each claims to add/modify
310
+
311
+ b. **Search the codebase** for implementation evidence:
312
+ - Look for code implementing requirements from each delta spec
313
+ - Check for related files, functions, or tests
314
+
315
+ c. **Determine resolution**:
316
+ - If only one change is actually implemented -> sync that one's specs
317
+ - If both implemented -> apply in chronological order (older first, newer overwrites)
318
+ - If neither implemented -> skip spec sync, warn user
319
+
320
+ d. **Record resolution** for each conflict:
321
+ - Which change's specs to apply
322
+ - In what order (if both)
323
+ - Rationale (what was found in codebase)
324
+
325
+ 6. **Show consolidated status table**
326
+
327
+ Display a table summarizing all changes:
328
+
329
+ \`\`\`
330
+ | Change | Artifacts | Tasks | Specs | Conflicts | Status |
331
+ |---------------------|-----------|-------|---------|-----------|--------|
332
+ | schema-management | Done | 5/5 | 2 delta | None | Ready |
333
+ | project-config | Done | 3/3 | 1 delta | None | Ready |
334
+ | add-oauth | Done | 4/4 | 1 delta | auth (!) | Ready* |
335
+ | add-verify-skill | 1 left | 2/5 | None | None | Warn |
336
+ \`\`\`
337
+
338
+ For conflicts, show the resolution:
339
+ \`\`\`
340
+ * Conflict resolution:
341
+ - auth spec: Will apply add-oauth then add-jwt (both implemented, chronological order)
342
+ \`\`\`
343
+
344
+ For incomplete changes, show warnings:
345
+ \`\`\`
346
+ Warnings:
347
+ - add-verify-skill: 1 incomplete artifact, 3 incomplete tasks
348
+ \`\`\`
349
+
350
+ 7. **Confirm batch operation**
351
+
352
+ Use **AskUserQuestion tool** with a single confirmation:
353
+
354
+ - "Archive N changes?" with options based on status
355
+ - Options might include:
356
+ - "Archive all N changes"
357
+ - "Archive only N ready changes (skip incomplete)"
358
+ - "Cancel"
359
+
360
+ If there are incomplete changes, make clear they'll be archived with warnings.
361
+
362
+ 8. **Execute archive for each confirmed change**
363
+
364
+ Process changes in the determined order (respecting conflict resolution):
365
+
366
+ a. **Sync specs** if delta specs exist:
367
+ - Use the pastelsdd-sync-specs approach (agent-driven intelligent merge)
368
+ - For conflicts, apply in resolved order
369
+ - Track if sync was done
370
+
371
+ b. **Perform the archive**:
372
+ \`\`\`bash
373
+ mkdir -p "<planningHome.changesDir>/archive"
374
+ mv "<changeRoot>" "<planningHome.changesDir>/archive/YYYY-MM-DD-<name>"
375
+ \`\`\`
376
+
377
+ c. **Track outcome** for each change:
378
+ - Success: archived successfully
379
+ - Failed: error during archive (record error)
380
+ - Skipped: user chose not to archive (if applicable)
381
+
382
+ 9. **Display summary**
383
+
384
+ Show final results:
385
+
386
+ \`\`\`
387
+ ## Bulk Archive Complete
388
+
389
+ Archived 3 changes:
390
+ - schema-management-cli -> archive/2026-01-19-schema-management-cli/
391
+ - project-config -> archive/2026-01-19-project-config/
392
+ - add-oauth -> archive/2026-01-19-add-oauth/
393
+
394
+ Skipped 1 change:
395
+ - add-verify-skill (user chose not to archive incomplete)
396
+
397
+ Spec sync summary:
398
+ - 4 delta specs synced to main specs
399
+ - 1 conflict resolved (auth: applied both in chronological order)
400
+ \`\`\`
401
+
402
+ If any failures:
403
+ \`\`\`
404
+ Failed 1 change:
405
+ - some-change: Archive directory already exists
406
+ \`\`\`
407
+
408
+ **Conflict Resolution Examples**
409
+
410
+ Example 1: Only one implemented
411
+ \`\`\`
412
+ Conflict: specs/auth/spec.md touched by [add-oauth, add-jwt]
413
+
414
+ Checking add-oauth:
415
+ - Delta adds "OAuth Provider Integration" requirement
416
+ - Searching codebase... found src/auth/oauth.ts implementing OAuth flow
417
+
418
+ Checking add-jwt:
419
+ - Delta adds "JWT Token Handling" requirement
420
+ - Searching codebase... no JWT implementation found
421
+
422
+ Resolution: Only add-oauth is implemented. Will sync add-oauth specs only.
423
+ \`\`\`
424
+
425
+ Example 2: Both implemented
426
+ \`\`\`
427
+ Conflict: specs/api/spec.md touched by [add-rest-api, add-graphql]
428
+
429
+ Checking add-rest-api (created 2026-01-10):
430
+ - Delta adds "REST Endpoints" requirement
431
+ - Searching codebase... found src/api/rest.ts
432
+
433
+ Checking add-graphql (created 2026-01-15):
434
+ - Delta adds "GraphQL Schema" requirement
435
+ - Searching codebase... found src/api/graphql.ts
436
+
437
+ Resolution: Both implemented. Will apply add-rest-api specs first,
438
+ then add-graphql specs (chronological order, newer takes precedence).
439
+ \`\`\`
440
+
441
+ **Output On Success**
442
+
443
+ \`\`\`
444
+ ## Bulk Archive Complete
445
+
446
+ Archived N changes:
447
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
448
+ - <change-2> -> archive/YYYY-MM-DD-<change-2>/
449
+
450
+ Spec sync summary:
451
+ - N delta specs synced to main specs
452
+ - No conflicts (or: M conflicts resolved)
453
+ \`\`\`
454
+
455
+ **Output On Partial Success**
456
+
457
+ \`\`\`
458
+ ## Bulk Archive Complete (partial)
459
+
460
+ Archived N changes:
461
+ - <change-1> -> archive/YYYY-MM-DD-<change-1>/
462
+
463
+ Skipped M changes:
464
+ - <change-2> (user chose not to archive incomplete)
465
+
466
+ Failed K changes:
467
+ - <change-3>: Archive directory already exists
468
+ \`\`\`
469
+
470
+ **Output When No Changes**
471
+
472
+ \`\`\`
473
+ ## No Changes to Archive
474
+
475
+ No active changes found. Create a new change to get started.
476
+ \`\`\`
477
+
478
+ **Guardrails**
479
+ - Allow any number of changes (1+ is fine, 2+ is the typical use case)
480
+ - Always prompt for selection, never auto-select
481
+ - Detect spec conflicts early and resolve by checking codebase
482
+ - When both changes are implemented, apply specs in chronological order
483
+ - Skip spec sync only when implementation is missing (warn user)
484
+ - Show clear per-change status before confirming
485
+ - Use single confirmation for entire batch
486
+ - Track and report all outcomes (success/skip/fail)
487
+ - Preserve .pastelsdd.yaml when moving to archive
488
+ - Archive directory target uses current date: YYYY-MM-DD-<name>
489
+ - If archive target exists, fail that change but continue with others`
490
+ };
491
+ }
492
+ //# sourceMappingURL=bulk-archive-change.js.map
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Skill Template Workflow Modules
3
+ *
4
+ * This file is generated by splitting the legacy monolithic
5
+ * templates file into workflow-focused modules.
6
+ */
7
+ import type { SkillTemplate, CommandTemplate } from '../types.js';
8
+ export declare function getContinueChangeSkillTemplate(): SkillTemplate;
9
+ export declare function getOpsxContinueCommandTemplate(): CommandTemplate;
10
+ //# sourceMappingURL=continue-change.d.ts.map