@jahanxu/trellis 0.4.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 (422) hide show
  1. package/LICENSE +235 -0
  2. package/README.md +212 -0
  3. package/bin/trellis.js +3 -0
  4. package/dist/cli/index.d.ts +3 -0
  5. package/dist/cli/index.d.ts.map +1 -0
  6. package/dist/cli/index.js +97 -0
  7. package/dist/cli/index.js.map +1 -0
  8. package/dist/commands/init.d.ts +21 -0
  9. package/dist/commands/init.d.ts.map +1 -0
  10. package/dist/commands/init.js +527 -0
  11. package/dist/commands/init.js.map +1 -0
  12. package/dist/commands/update.d.ts +27 -0
  13. package/dist/commands/update.d.ts.map +1 -0
  14. package/dist/commands/update.js +1289 -0
  15. package/dist/commands/update.js.map +1 -0
  16. package/dist/configurators/antigravity.d.ts +8 -0
  17. package/dist/configurators/antigravity.d.ts.map +1 -0
  18. package/dist/configurators/antigravity.js +18 -0
  19. package/dist/configurators/antigravity.js.map +1 -0
  20. package/dist/configurators/claude.d.ts +32 -0
  21. package/dist/configurators/claude.d.ts.map +1 -0
  22. package/dist/configurators/claude.js +98 -0
  23. package/dist/configurators/claude.js.map +1 -0
  24. package/dist/configurators/codex.d.ts +8 -0
  25. package/dist/configurators/codex.d.ts.map +1 -0
  26. package/dist/configurators/codex.js +20 -0
  27. package/dist/configurators/codex.js.map +1 -0
  28. package/dist/configurators/cursor.d.ts +5 -0
  29. package/dist/configurators/cursor.d.ts.map +1 -0
  30. package/dist/configurators/cursor.js +52 -0
  31. package/dist/configurators/cursor.js.map +1 -0
  32. package/dist/configurators/gemini.d.ts +8 -0
  33. package/dist/configurators/gemini.d.ts.map +1 -0
  34. package/dist/configurators/gemini.js +52 -0
  35. package/dist/configurators/gemini.js.map +1 -0
  36. package/dist/configurators/iflow.d.ts +33 -0
  37. package/dist/configurators/iflow.d.ts.map +1 -0
  38. package/dist/configurators/iflow.js +99 -0
  39. package/dist/configurators/iflow.js.map +1 -0
  40. package/dist/configurators/index.d.ts +55 -0
  41. package/dist/configurators/index.d.ts.map +1 -0
  42. package/dist/configurators/index.js +220 -0
  43. package/dist/configurators/index.js.map +1 -0
  44. package/dist/configurators/kilo.d.ts +8 -0
  45. package/dist/configurators/kilo.d.ts.map +1 -0
  46. package/dist/configurators/kilo.js +51 -0
  47. package/dist/configurators/kilo.js.map +1 -0
  48. package/dist/configurators/kiro.d.ts +8 -0
  49. package/dist/configurators/kiro.d.ts.map +1 -0
  50. package/dist/configurators/kiro.js +20 -0
  51. package/dist/configurators/kiro.js.map +1 -0
  52. package/dist/configurators/opencode.d.ts +32 -0
  53. package/dist/configurators/opencode.d.ts.map +1 -0
  54. package/dist/configurators/opencode.js +92 -0
  55. package/dist/configurators/opencode.js.map +1 -0
  56. package/dist/configurators/shared.d.ts +12 -0
  57. package/dist/configurators/shared.d.ts.map +1 -0
  58. package/dist/configurators/shared.js +21 -0
  59. package/dist/configurators/shared.js.map +1 -0
  60. package/dist/configurators/workflow.d.ts +28 -0
  61. package/dist/configurators/workflow.d.ts.map +1 -0
  62. package/dist/configurators/workflow.js +134 -0
  63. package/dist/configurators/workflow.js.map +1 -0
  64. package/dist/constants/paths.d.ts +68 -0
  65. package/dist/constants/paths.d.ts.map +1 -0
  66. package/dist/constants/paths.js +77 -0
  67. package/dist/constants/paths.js.map +1 -0
  68. package/dist/constants/version.d.ts +9 -0
  69. package/dist/constants/version.d.ts.map +1 -0
  70. package/dist/constants/version.js +15 -0
  71. package/dist/constants/version.js.map +1 -0
  72. package/dist/index.d.ts +9 -0
  73. package/dist/index.d.ts.map +1 -0
  74. package/dist/index.js +9 -0
  75. package/dist/index.js.map +1 -0
  76. package/dist/migrations/index.d.ts +54 -0
  77. package/dist/migrations/index.d.ts.map +1 -0
  78. package/dist/migrations/index.js +160 -0
  79. package/dist/migrations/index.js.map +1 -0
  80. package/dist/migrations/manifests/0.1.9.json +30 -0
  81. package/dist/migrations/manifests/0.2.0.json +49 -0
  82. package/dist/migrations/manifests/0.2.12.json +9 -0
  83. package/dist/migrations/manifests/0.2.13.json +9 -0
  84. package/dist/migrations/manifests/0.2.14.json +175 -0
  85. package/dist/migrations/manifests/0.2.15.json +33 -0
  86. package/dist/migrations/manifests/0.3.0-beta.0.json +278 -0
  87. package/dist/migrations/manifests/0.3.0-beta.1.json +9 -0
  88. package/dist/migrations/manifests/0.3.0-beta.10.json +9 -0
  89. package/dist/migrations/manifests/0.3.0-beta.11.json +9 -0
  90. package/dist/migrations/manifests/0.3.0-beta.12.json +9 -0
  91. package/dist/migrations/manifests/0.3.0-beta.13.json +9 -0
  92. package/dist/migrations/manifests/0.3.0-beta.14.json +9 -0
  93. package/dist/migrations/manifests/0.3.0-beta.15.json +9 -0
  94. package/dist/migrations/manifests/0.3.0-beta.16.json +9 -0
  95. package/dist/migrations/manifests/0.3.0-beta.2.json +9 -0
  96. package/dist/migrations/manifests/0.3.0-beta.3.json +9 -0
  97. package/dist/migrations/manifests/0.3.0-beta.4.json +9 -0
  98. package/dist/migrations/manifests/0.3.0-beta.5.json +9 -0
  99. package/dist/migrations/manifests/0.3.0-beta.6.json +9 -0
  100. package/dist/migrations/manifests/0.3.0-beta.7.json +11 -0
  101. package/dist/migrations/manifests/0.3.0-beta.8.json +9 -0
  102. package/dist/migrations/manifests/0.3.0-beta.9.json +9 -0
  103. package/dist/migrations/manifests/0.3.0-rc.0.json +9 -0
  104. package/dist/migrations/manifests/0.3.0-rc.1.json +9 -0
  105. package/dist/migrations/manifests/0.3.0-rc.2.json +9 -0
  106. package/dist/migrations/manifests/0.3.0-rc.3.json +9 -0
  107. package/dist/migrations/manifests/0.3.0-rc.4.json +9 -0
  108. package/dist/migrations/manifests/0.3.0-rc.5.json +9 -0
  109. package/dist/migrations/manifests/0.3.0-rc.6.json +9 -0
  110. package/dist/migrations/manifests/0.3.0.json +11 -0
  111. package/dist/templates/antigravity/index.d.ts +12 -0
  112. package/dist/templates/antigravity/index.d.ts.map +1 -0
  113. package/dist/templates/antigravity/index.js +29 -0
  114. package/dist/templates/antigravity/index.js.map +1 -0
  115. package/dist/templates/claude/agents/check.md +122 -0
  116. package/dist/templates/claude/agents/debug.md +106 -0
  117. package/dist/templates/claude/agents/dispatch.md +214 -0
  118. package/dist/templates/claude/agents/implement.md +96 -0
  119. package/dist/templates/claude/agents/plan.md +396 -0
  120. package/dist/templates/claude/agents/research.md +120 -0
  121. package/dist/templates/claude/commands/trellis/before-backend-dev.md +13 -0
  122. package/dist/templates/claude/commands/trellis/before-frontend-dev.md +13 -0
  123. package/dist/templates/claude/commands/trellis/before-role-work.md +364 -0
  124. package/dist/templates/claude/commands/trellis/brainstorm.md +474 -0
  125. package/dist/templates/claude/commands/trellis/break-loop.md +125 -0
  126. package/dist/templates/claude/commands/trellis/check-backend.md +13 -0
  127. package/dist/templates/claude/commands/trellis/check-cross-layer.md +153 -0
  128. package/dist/templates/claude/commands/trellis/check-frontend.md +13 -0
  129. package/dist/templates/claude/commands/trellis/create-command.md +154 -0
  130. package/dist/templates/claude/commands/trellis/finish-work.md +153 -0
  131. package/dist/templates/claude/commands/trellis/handoff.md +445 -0
  132. package/dist/templates/claude/commands/trellis/integrate-skill.md +219 -0
  133. package/dist/templates/claude/commands/trellis/onboard.md +358 -0
  134. package/dist/templates/claude/commands/trellis/parallel.md +193 -0
  135. package/dist/templates/claude/commands/trellis/pick-task.md +515 -0
  136. package/dist/templates/claude/commands/trellis/record-session.md +62 -0
  137. package/dist/templates/claude/commands/trellis/start.md +373 -0
  138. package/dist/templates/claude/commands/trellis/update-spec.md +354 -0
  139. package/dist/templates/claude/hooks/inject-subagent-context.py +873 -0
  140. package/dist/templates/claude/hooks/ralph-loop.py +388 -0
  141. package/dist/templates/claude/hooks/session-start.py +200 -0
  142. package/dist/templates/claude/index.d.ts +54 -0
  143. package/dist/templates/claude/index.d.ts.map +1 -0
  144. package/dist/templates/claude/index.js +85 -0
  145. package/dist/templates/claude/index.js.map +1 -0
  146. package/dist/templates/claude/settings.json +41 -0
  147. package/dist/templates/codex/index.d.ts +18 -0
  148. package/dist/templates/codex/index.d.ts.map +1 -0
  149. package/dist/templates/codex/index.js +40 -0
  150. package/dist/templates/codex/index.js.map +1 -0
  151. package/dist/templates/codex/skills/before-backend-dev/SKILL.md +18 -0
  152. package/dist/templates/codex/skills/before-frontend-dev/SKILL.md +18 -0
  153. package/dist/templates/codex/skills/brainstorm/SKILL.md +479 -0
  154. package/dist/templates/codex/skills/break-loop/SKILL.md +130 -0
  155. package/dist/templates/codex/skills/check-backend/SKILL.md +18 -0
  156. package/dist/templates/codex/skills/check-cross-layer/SKILL.md +158 -0
  157. package/dist/templates/codex/skills/check-frontend/SKILL.md +18 -0
  158. package/dist/templates/codex/skills/create-command/SKILL.md +101 -0
  159. package/dist/templates/codex/skills/finish-work/SKILL.md +148 -0
  160. package/dist/templates/codex/skills/integrate-skill/SKILL.md +221 -0
  161. package/dist/templates/codex/skills/onboard/SKILL.md +363 -0
  162. package/dist/templates/codex/skills/record-session/SKILL.md +67 -0
  163. package/dist/templates/codex/skills/start/SKILL.md +330 -0
  164. package/dist/templates/codex/skills/update-spec/SKILL.md +335 -0
  165. package/dist/templates/cursor/commands/trellis-before-backend-dev.md +13 -0
  166. package/dist/templates/cursor/commands/trellis-before-frontend-dev.md +13 -0
  167. package/dist/templates/cursor/commands/trellis-brainstorm.md +474 -0
  168. package/dist/templates/cursor/commands/trellis-break-loop.md +107 -0
  169. package/dist/templates/cursor/commands/trellis-check-backend.md +13 -0
  170. package/dist/templates/cursor/commands/trellis-check-cross-layer.md +153 -0
  171. package/dist/templates/cursor/commands/trellis-check-frontend.md +13 -0
  172. package/dist/templates/cursor/commands/trellis-create-command.md +154 -0
  173. package/dist/templates/cursor/commands/trellis-finish-work.md +143 -0
  174. package/dist/templates/cursor/commands/trellis-integrate-skill.md +219 -0
  175. package/dist/templates/cursor/commands/trellis-onboard.md +358 -0
  176. package/dist/templates/cursor/commands/trellis-record-session.md +62 -0
  177. package/dist/templates/cursor/commands/trellis-start.md +366 -0
  178. package/dist/templates/cursor/commands/trellis-update-spec.md +354 -0
  179. package/dist/templates/cursor/index.d.ts +24 -0
  180. package/dist/templates/cursor/index.d.ts.map +1 -0
  181. package/dist/templates/cursor/index.js +44 -0
  182. package/dist/templates/cursor/index.js.map +1 -0
  183. package/dist/templates/extract.d.ts +166 -0
  184. package/dist/templates/extract.d.ts.map +1 -0
  185. package/dist/templates/extract.js +296 -0
  186. package/dist/templates/extract.js.map +1 -0
  187. package/dist/templates/gemini/commands/trellis/before-backend-dev.toml +17 -0
  188. package/dist/templates/gemini/commands/trellis/before-frontend-dev.toml +17 -0
  189. package/dist/templates/gemini/commands/trellis/brainstorm.toml +420 -0
  190. package/dist/templates/gemini/commands/trellis/break-loop.toml +129 -0
  191. package/dist/templates/gemini/commands/trellis/check-backend.toml +17 -0
  192. package/dist/templates/gemini/commands/trellis/check-cross-layer.toml +147 -0
  193. package/dist/templates/gemini/commands/trellis/check-frontend.toml +17 -0
  194. package/dist/templates/gemini/commands/trellis/create-command.toml +119 -0
  195. package/dist/templates/gemini/commands/trellis/finish-work.toml +133 -0
  196. package/dist/templates/gemini/commands/trellis/integrate-skill.toml +104 -0
  197. package/dist/templates/gemini/commands/trellis/onboard.toml +111 -0
  198. package/dist/templates/gemini/commands/trellis/record-session.toml +66 -0
  199. package/dist/templates/gemini/commands/trellis/start.toml +292 -0
  200. package/dist/templates/gemini/commands/trellis/update-spec.toml +132 -0
  201. package/dist/templates/gemini/index.d.ts +21 -0
  202. package/dist/templates/gemini/index.d.ts.map +1 -0
  203. package/dist/templates/gemini/index.js +44 -0
  204. package/dist/templates/gemini/index.js.map +1 -0
  205. package/dist/templates/iflow/agents/check.md +122 -0
  206. package/dist/templates/iflow/agents/debug.md +106 -0
  207. package/dist/templates/iflow/agents/dispatch.md +214 -0
  208. package/dist/templates/iflow/agents/implement.md +96 -0
  209. package/dist/templates/iflow/agents/plan.md +396 -0
  210. package/dist/templates/iflow/agents/research.md +120 -0
  211. package/dist/templates/iflow/commands/trellis/before-backend-dev.md +13 -0
  212. package/dist/templates/iflow/commands/trellis/before-frontend-dev.md +13 -0
  213. package/dist/templates/iflow/commands/trellis/brainstorm.md +474 -0
  214. package/dist/templates/iflow/commands/trellis/break-loop.md +125 -0
  215. package/dist/templates/iflow/commands/trellis/check-backend.md +13 -0
  216. package/dist/templates/iflow/commands/trellis/check-cross-layer.md +153 -0
  217. package/dist/templates/iflow/commands/trellis/check-frontend.md +13 -0
  218. package/dist/templates/iflow/commands/trellis/create-command.md +152 -0
  219. package/dist/templates/iflow/commands/trellis/finish-work.md +153 -0
  220. package/dist/templates/iflow/commands/trellis/integrate-skill.md +219 -0
  221. package/dist/templates/iflow/commands/trellis/onboard.md +358 -0
  222. package/dist/templates/iflow/commands/trellis/parallel.md +193 -0
  223. package/dist/templates/iflow/commands/trellis/record-session.md +62 -0
  224. package/dist/templates/iflow/commands/trellis/start.md +373 -0
  225. package/dist/templates/iflow/commands/trellis/update-spec.md +354 -0
  226. package/dist/templates/iflow/hooks/inject-subagent-context.py +788 -0
  227. package/dist/templates/iflow/hooks/ralph-loop.py +388 -0
  228. package/dist/templates/iflow/hooks/session-start.py +143 -0
  229. package/dist/templates/iflow/index.d.ts +54 -0
  230. package/dist/templates/iflow/index.d.ts.map +1 -0
  231. package/dist/templates/iflow/index.js +85 -0
  232. package/dist/templates/iflow/index.js.map +1 -0
  233. package/dist/templates/iflow/settings.json +40 -0
  234. package/dist/templates/kilo/commands/trellis/before-backend-dev.md +13 -0
  235. package/dist/templates/kilo/commands/trellis/before-frontend-dev.md +13 -0
  236. package/dist/templates/kilo/commands/trellis/brainstorm.md +474 -0
  237. package/dist/templates/kilo/commands/trellis/break-loop.md +125 -0
  238. package/dist/templates/kilo/commands/trellis/check-backend.md +13 -0
  239. package/dist/templates/kilo/commands/trellis/check-cross-layer.md +153 -0
  240. package/dist/templates/kilo/commands/trellis/check-frontend.md +13 -0
  241. package/dist/templates/kilo/commands/trellis/create-command.md +152 -0
  242. package/dist/templates/kilo/commands/trellis/finish-work.md +129 -0
  243. package/dist/templates/kilo/commands/trellis/integrate-skill.md +219 -0
  244. package/dist/templates/kilo/commands/trellis/onboard.md +358 -0
  245. package/dist/templates/kilo/commands/trellis/parallel.md +194 -0
  246. package/dist/templates/kilo/commands/trellis/record-session.md +62 -0
  247. package/dist/templates/kilo/commands/trellis/start.md +321 -0
  248. package/dist/templates/kilo/commands/trellis/update-spec.md +285 -0
  249. package/dist/templates/kilo/index.d.ts +16 -0
  250. package/dist/templates/kilo/index.d.ts.map +1 -0
  251. package/dist/templates/kilo/index.js +39 -0
  252. package/dist/templates/kilo/index.js.map +1 -0
  253. package/dist/templates/kiro/index.d.ts +18 -0
  254. package/dist/templates/kiro/index.d.ts.map +1 -0
  255. package/dist/templates/kiro/index.js +40 -0
  256. package/dist/templates/kiro/index.js.map +1 -0
  257. package/dist/templates/kiro/skills/before-backend-dev/SKILL.md +18 -0
  258. package/dist/templates/kiro/skills/before-frontend-dev/SKILL.md +18 -0
  259. package/dist/templates/kiro/skills/brainstorm/SKILL.md +479 -0
  260. package/dist/templates/kiro/skills/break-loop/SKILL.md +130 -0
  261. package/dist/templates/kiro/skills/check-backend/SKILL.md +18 -0
  262. package/dist/templates/kiro/skills/check-cross-layer/SKILL.md +158 -0
  263. package/dist/templates/kiro/skills/check-frontend/SKILL.md +18 -0
  264. package/dist/templates/kiro/skills/create-command/SKILL.md +101 -0
  265. package/dist/templates/kiro/skills/finish-work/SKILL.md +148 -0
  266. package/dist/templates/kiro/skills/integrate-skill/SKILL.md +221 -0
  267. package/dist/templates/kiro/skills/onboard/SKILL.md +363 -0
  268. package/dist/templates/kiro/skills/record-session/SKILL.md +67 -0
  269. package/dist/templates/kiro/skills/start/SKILL.md +330 -0
  270. package/dist/templates/kiro/skills/update-spec/SKILL.md +335 -0
  271. package/dist/templates/markdown/agents.md +18 -0
  272. package/dist/templates/markdown/gitignore.txt +12 -0
  273. package/dist/templates/markdown/index.d.ts +27 -0
  274. package/dist/templates/markdown/index.d.ts.map +1 -0
  275. package/dist/templates/markdown/index.js +52 -0
  276. package/dist/templates/markdown/index.js.map +1 -0
  277. package/dist/templates/markdown/spec/backend/database-guidelines.md.txt +51 -0
  278. package/dist/templates/markdown/spec/backend/directory-structure.md.txt +54 -0
  279. package/dist/templates/markdown/spec/backend/error-handling.md.txt +51 -0
  280. package/dist/templates/markdown/spec/backend/index.md +40 -0
  281. package/dist/templates/markdown/spec/backend/index.md.txt +38 -0
  282. package/dist/templates/markdown/spec/backend/logging-guidelines.md.txt +51 -0
  283. package/dist/templates/markdown/spec/backend/quality-guidelines.md.txt +51 -0
  284. package/dist/templates/markdown/spec/backend/script-conventions.md +467 -0
  285. package/dist/templates/markdown/spec/frontend/component-guidelines.md.txt +59 -0
  286. package/dist/templates/markdown/spec/frontend/directory-structure.md.txt +54 -0
  287. package/dist/templates/markdown/spec/frontend/hook-guidelines.md.txt +51 -0
  288. package/dist/templates/markdown/spec/frontend/index.md.txt +39 -0
  289. package/dist/templates/markdown/spec/frontend/quality-guidelines.md.txt +51 -0
  290. package/dist/templates/markdown/spec/frontend/state-management.md.txt +51 -0
  291. package/dist/templates/markdown/spec/frontend/type-safety.md.txt +51 -0
  292. package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md +118 -0
  293. package/dist/templates/markdown/spec/guides/code-reuse-thinking-guide.md.txt +92 -0
  294. package/dist/templates/markdown/spec/guides/cross-layer-thinking-guide.md.txt +94 -0
  295. package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md +394 -0
  296. package/dist/templates/markdown/spec/guides/cross-platform-thinking-guide.md.txt +319 -0
  297. package/dist/templates/markdown/spec/guides/index.md.txt +79 -0
  298. package/dist/templates/markdown/workspace-index.md +123 -0
  299. package/dist/templates/markdown/worktree.yaml.txt +58 -0
  300. package/dist/templates/opencode/agents/check.md +146 -0
  301. package/dist/templates/opencode/agents/debug.md +129 -0
  302. package/dist/templates/opencode/agents/dispatch.md +223 -0
  303. package/dist/templates/opencode/agents/implement.md +120 -0
  304. package/dist/templates/opencode/agents/research.md +147 -0
  305. package/dist/templates/opencode/agents/trellis-plan.md +427 -0
  306. package/dist/templates/opencode/commands/trellis/before-backend-dev.md +13 -0
  307. package/dist/templates/opencode/commands/trellis/before-frontend-dev.md +13 -0
  308. package/dist/templates/opencode/commands/trellis/brainstorm.md +474 -0
  309. package/dist/templates/opencode/commands/trellis/break-loop.md +125 -0
  310. package/dist/templates/opencode/commands/trellis/check-backend.md +13 -0
  311. package/dist/templates/opencode/commands/trellis/check-cross-layer.md +153 -0
  312. package/dist/templates/opencode/commands/trellis/check-frontend.md +13 -0
  313. package/dist/templates/opencode/commands/trellis/create-command.md +154 -0
  314. package/dist/templates/opencode/commands/trellis/finish-work.md +144 -0
  315. package/dist/templates/opencode/commands/trellis/integrate-skill.md +219 -0
  316. package/dist/templates/opencode/commands/trellis/migrate-specs.md +0 -0
  317. package/dist/templates/opencode/commands/trellis/onboard.md +358 -0
  318. package/dist/templates/opencode/commands/trellis/parallel.md +194 -0
  319. package/dist/templates/opencode/commands/trellis/record-session.md +62 -0
  320. package/dist/templates/opencode/commands/trellis/start.md +338 -0
  321. package/dist/templates/opencode/commands/trellis/update-spec.md +354 -0
  322. package/dist/templates/opencode/lib/trellis-context.js +436 -0
  323. package/dist/templates/opencode/package.json +5 -0
  324. package/dist/templates/opencode/plugin/inject-subagent-context.js +538 -0
  325. package/dist/templates/opencode/plugin/session-start.js +192 -0
  326. package/dist/templates/trellis/VERSION +1 -0
  327. package/dist/templates/trellis/deliverables/README.md +51 -0
  328. package/dist/templates/trellis/gitignore.txt +29 -0
  329. package/dist/templates/trellis/index.d.ts +49 -0
  330. package/dist/templates/trellis/index.d.ts.map +1 -0
  331. package/dist/templates/trellis/index.js +92 -0
  332. package/dist/templates/trellis/index.js.map +1 -0
  333. package/dist/templates/trellis/paths.README.md +277 -0
  334. package/dist/templates/trellis/paths.yaml +41 -0
  335. package/dist/templates/trellis/pool/implementations.json +5 -0
  336. package/dist/templates/trellis/pool/prototypes.json +5 -0
  337. package/dist/templates/trellis/pool/requirements.json +5 -0
  338. package/dist/templates/trellis/scripts/__init__.py +5 -0
  339. package/dist/templates/trellis/scripts/add_session.py +391 -0
  340. package/dist/templates/trellis/scripts/common/__init__.py +80 -0
  341. package/dist/templates/trellis/scripts/common/cli_adapter.py +522 -0
  342. package/dist/templates/trellis/scripts/common/developer.py +189 -0
  343. package/dist/templates/trellis/scripts/common/git_context.py +383 -0
  344. package/dist/templates/trellis/scripts/common/paths.py +346 -0
  345. package/dist/templates/trellis/scripts/common/phase.py +253 -0
  346. package/dist/templates/trellis/scripts/common/project_paths.py +189 -0
  347. package/dist/templates/trellis/scripts/common/registry.py +365 -0
  348. package/dist/templates/trellis/scripts/common/task_queue.py +255 -0
  349. package/dist/templates/trellis/scripts/common/task_utils.py +177 -0
  350. package/dist/templates/trellis/scripts/common/worktree.py +218 -0
  351. package/dist/templates/trellis/scripts/create_bootstrap.py +290 -0
  352. package/dist/templates/trellis/scripts/get_context.py +16 -0
  353. package/dist/templates/trellis/scripts/get_developer.py +26 -0
  354. package/dist/templates/trellis/scripts/handoff_generator.py +380 -0
  355. package/dist/templates/trellis/scripts/init_developer.py +51 -0
  356. package/dist/templates/trellis/scripts/multi_agent/__init__.py +5 -0
  357. package/dist/templates/trellis/scripts/multi_agent/cleanup.py +403 -0
  358. package/dist/templates/trellis/scripts/multi_agent/create_pr.py +329 -0
  359. package/dist/templates/trellis/scripts/multi_agent/plan.py +233 -0
  360. package/dist/templates/trellis/scripts/multi_agent/start.py +461 -0
  361. package/dist/templates/trellis/scripts/multi_agent/status.py +817 -0
  362. package/dist/templates/trellis/scripts/pool.py +373 -0
  363. package/dist/templates/trellis/scripts/task.py +1162 -0
  364. package/dist/templates/trellis/scripts-shell-archive/add-session.sh +384 -0
  365. package/dist/templates/trellis/scripts-shell-archive/common/developer.sh +129 -0
  366. package/dist/templates/trellis/scripts-shell-archive/common/git-context.sh +263 -0
  367. package/dist/templates/trellis/scripts-shell-archive/common/paths.sh +208 -0
  368. package/dist/templates/trellis/scripts-shell-archive/common/phase.sh +150 -0
  369. package/dist/templates/trellis/scripts-shell-archive/common/registry.sh +247 -0
  370. package/dist/templates/trellis/scripts-shell-archive/common/task-queue.sh +142 -0
  371. package/dist/templates/trellis/scripts-shell-archive/common/task-utils.sh +151 -0
  372. package/dist/templates/trellis/scripts-shell-archive/common/worktree.sh +128 -0
  373. package/dist/templates/trellis/scripts-shell-archive/create-bootstrap.sh +299 -0
  374. package/dist/templates/trellis/scripts-shell-archive/get-context.sh +7 -0
  375. package/dist/templates/trellis/scripts-shell-archive/get-developer.sh +15 -0
  376. package/dist/templates/trellis/scripts-shell-archive/init-developer.sh +34 -0
  377. package/dist/templates/trellis/scripts-shell-archive/multi-agent/cleanup.sh +396 -0
  378. package/dist/templates/trellis/scripts-shell-archive/multi-agent/create-pr.sh +241 -0
  379. package/dist/templates/trellis/scripts-shell-archive/multi-agent/plan.sh +207 -0
  380. package/dist/templates/trellis/scripts-shell-archive/multi-agent/start.sh +317 -0
  381. package/dist/templates/trellis/scripts-shell-archive/multi-agent/status.sh +828 -0
  382. package/dist/templates/trellis/scripts-shell-archive/task.sh +1204 -0
  383. package/dist/templates/trellis/spec/roles/designer/index.md +243 -0
  384. package/dist/templates/trellis/spec/roles/designer/mock-data-standards.md +481 -0
  385. package/dist/templates/trellis/spec/roles/designer/prototype-guidelines.md +429 -0
  386. package/dist/templates/trellis/spec/roles/frontend-impl/api-integration.md +565 -0
  387. package/dist/templates/trellis/spec/roles/frontend-impl/index.md +321 -0
  388. package/dist/templates/trellis/spec/roles/frontend-impl/state-management.md +599 -0
  389. package/dist/templates/trellis/spec/roles/pm/index.md +112 -0
  390. package/dist/templates/trellis/spec/roles/pm/prd-template.md +124 -0
  391. package/dist/templates/trellis/tasks/.gitkeep +0 -0
  392. package/dist/templates/trellis/workflow.md +416 -0
  393. package/dist/templates/trellis/worktree.yaml +47 -0
  394. package/dist/types/ai-tools.d.ts +56 -0
  395. package/dist/types/ai-tools.d.ts.map +1 -0
  396. package/dist/types/ai-tools.js +103 -0
  397. package/dist/types/ai-tools.js.map +1 -0
  398. package/dist/types/migration.d.ts +86 -0
  399. package/dist/types/migration.d.ts.map +1 -0
  400. package/dist/types/migration.js +8 -0
  401. package/dist/types/migration.js.map +1 -0
  402. package/dist/utils/compare-versions.d.ts +12 -0
  403. package/dist/utils/compare-versions.d.ts.map +1 -0
  404. package/dist/utils/compare-versions.js +76 -0
  405. package/dist/utils/compare-versions.js.map +1 -0
  406. package/dist/utils/file-writer.d.ts +23 -0
  407. package/dist/utils/file-writer.d.ts.map +1 -0
  408. package/dist/utils/file-writer.js +140 -0
  409. package/dist/utils/file-writer.js.map +1 -0
  410. package/dist/utils/project-detector.d.ts +16 -0
  411. package/dist/utils/project-detector.d.ts.map +1 -0
  412. package/dist/utils/project-detector.js +186 -0
  413. package/dist/utils/project-detector.js.map +1 -0
  414. package/dist/utils/template-fetcher.d.ts +51 -0
  415. package/dist/utils/template-fetcher.d.ts.map +1 -0
  416. package/dist/utils/template-fetcher.js +174 -0
  417. package/dist/utils/template-fetcher.js.map +1 -0
  418. package/dist/utils/template-hash.d.ts +78 -0
  419. package/dist/utils/template-hash.d.ts.map +1 -0
  420. package/dist/utils/template-hash.js +233 -0
  421. package/dist/utils/template-hash.js.map +1 -0
  422. package/package.json +87 -0
@@ -0,0 +1,565 @@
1
+ # API 集成指南
2
+
3
+ > Frontend 角色将原型 Mock API 替换为真实 API 的指南
4
+
5
+ ---
6
+
7
+ ## 核心原则
8
+
9
+ API 集成的目标是:
10
+ 1. **定位准确** - 快速找到所有需要替换的 Mock API
11
+ 2. **类型安全** - 使用 TypeScript 确保 API 响应类型正确
12
+ 3. **错误处理** - 完善处理网络错误、业务错误
13
+ 4. **复用性强** - API 调用逻辑集中管理,便于维护
14
+
15
+ ---
16
+
17
+ ## 定位 Mock API
18
+
19
+ ### 1. 搜索 TODO 注释
20
+
21
+ Designer 会用 TODO 注释标注需要替换的位置:
22
+
23
+ ```bash
24
+ # 搜索所有需要替换的 Mock API
25
+ grep -r "TODO:.*Frontend.*API" src/
26
+ ```
27
+
28
+ **示例输出**:
29
+ ```
30
+ src/pages/LoginPage.tsx:45: // TODO: [Frontend] 替换为真实API调用 POST /api/auth/login
31
+ src/pages/UserList.tsx:23: // TODO: [Frontend] 替换为真实API调用 GET /api/users
32
+ ```
33
+
34
+ ### 2. 搜索 Mock 函数调用
35
+
36
+ ```bash
37
+ # 搜索 mock 关键字
38
+ grep -r "mock.*API\|\.mock\." src/
39
+ ```
40
+
41
+ ### 3. 检查 HANDOFF 文档
42
+
43
+ Designer 的 HANDOFF.md 会列出所有需要替换的 API:
44
+
45
+ ```markdown
46
+ ## 需要Frontend补充的逻辑
47
+
48
+ 1. **API集成点**
49
+ - 文件:`LoginPage.tsx:45`
50
+ - Mock: `mockLoginAPI()`
51
+ - 真实API: `POST /api/auth/login`
52
+ ```
53
+
54
+ ---
55
+
56
+ ## API 客户端配置
57
+
58
+ ### 1. 创建 API 客户端
59
+
60
+ 使用 Axios 或 Fetch 封装统一的 API 客户端:
61
+
62
+ ```typescript
63
+ // src/lib/api/client.ts
64
+ import axios, { AxiosInstance, AxiosRequestConfig } from 'axios';
65
+
66
+ const baseURL = import.meta.env.VITE_API_BASE_URL || 'http://localhost:3000';
67
+
68
+ export const apiClient: AxiosInstance = axios.create({
69
+ baseURL,
70
+ timeout: 10000,
71
+ headers: {
72
+ 'Content-Type': 'application/json',
73
+ },
74
+ });
75
+
76
+ // 请求拦截器:添加 token
77
+ apiClient.interceptors.request.use(
78
+ (config) => {
79
+ const token = localStorage.getItem('auth_token');
80
+ if (token) {
81
+ config.headers.Authorization = `Bearer ${token}`;
82
+ }
83
+ return config;
84
+ },
85
+ (error) => Promise.reject(error)
86
+ );
87
+
88
+ // 响应拦截器:统一错误处理
89
+ apiClient.interceptors.response.use(
90
+ (response) => response.data, // 直接返回 data
91
+ (error) => {
92
+ if (error.response?.status === 401) {
93
+ // Token 过期,跳转登录
94
+ localStorage.removeItem('auth_token');
95
+ window.location.href = '/login';
96
+ }
97
+ return Promise.reject(error);
98
+ }
99
+ );
100
+ ```
101
+
102
+ ### 2. 环境变量配置
103
+
104
+ ```bash
105
+ # .env.development
106
+ VITE_API_BASE_URL=http://localhost:3000
107
+
108
+ # .env.production
109
+ VITE_API_BASE_URL=https://api.example.com
110
+ ```
111
+
112
+ ---
113
+
114
+ ## API 函数封装
115
+
116
+ ### 1. 按模块组织 API
117
+
118
+ ```
119
+ src/lib/api/
120
+ ├── client.ts # API 客户端配置
121
+ ├── auth.ts # 认证相关 API
122
+ ├── user.ts # 用户相关 API
123
+ ├── product.ts # 产品相关 API
124
+ └── index.ts # 统一导出
125
+ ```
126
+
127
+ ### 2. 定义 API 函数
128
+
129
+ ```typescript
130
+ // src/lib/api/auth.ts
131
+ import { apiClient } from './client';
132
+ import type { User } from '@/types/user';
133
+
134
+ export interface LoginRequest {
135
+ email: string;
136
+ password: string;
137
+ }
138
+
139
+ export interface LoginResponse {
140
+ user: User;
141
+ token: string;
142
+ }
143
+
144
+ /**
145
+ * 用户登录
146
+ * POST /api/auth/login
147
+ */
148
+ export const login = async (data: LoginRequest): Promise<LoginResponse> => {
149
+ return apiClient.post('/api/auth/login', data);
150
+ };
151
+
152
+ /**
153
+ * 用户登出
154
+ * POST /api/auth/logout
155
+ */
156
+ export const logout = async (): Promise<void> => {
157
+ return apiClient.post('/api/auth/logout');
158
+ };
159
+
160
+ /**
161
+ * 获取当前用户信息
162
+ * GET /api/auth/me
163
+ */
164
+ export const getCurrentUser = async (): Promise<User> => {
165
+ return apiClient.get('/api/auth/me');
166
+ };
167
+ ```
168
+
169
+ ### 3. 列表 API 封装
170
+
171
+ ```typescript
172
+ // src/lib/api/user.ts
173
+ import { apiClient } from './client';
174
+ import type { User } from '@/types/user';
175
+ import type { ApiListResponse } from '@/types/api';
176
+
177
+ export interface GetUsersParams {
178
+ page?: number;
179
+ pageSize?: number;
180
+ keyword?: string;
181
+ }
182
+
183
+ /**
184
+ * 获取用户列表
185
+ * GET /api/users?page=1&pageSize=10&keyword=xxx
186
+ */
187
+ export const getUsers = async (
188
+ params: GetUsersParams = {}
189
+ ): Promise<ApiListResponse<User>> => {
190
+ return apiClient.get('/api/users', { params });
191
+ };
192
+
193
+ /**
194
+ * 获取用户详情
195
+ * GET /api/users/:id
196
+ */
197
+ export const getUserById = async (id: string): Promise<User> => {
198
+ return apiClient.get(`/api/users/${id}`);
199
+ };
200
+ ```
201
+
202
+ ---
203
+
204
+ ## 替换 Mock API
205
+
206
+ ### Before(Designer 的 Mock)
207
+
208
+ ```typescript
209
+ // src/pages/LoginPage.tsx
210
+ import { mockLoginAPI } from '@/mocks/api/auth.mock';
211
+
212
+ const LoginPage = () => {
213
+ const handleSubmit = async (email: string, password: string) => {
214
+ try {
215
+ // TODO: [Frontend] 替换为真实API调用 POST /api/auth/login
216
+ const { user, token } = await mockLoginAPI(email, password);
217
+ localStorage.setItem('auth_token', token);
218
+ setUser(user);
219
+ } catch (error) {
220
+ setError('登录失败');
221
+ }
222
+ };
223
+
224
+ // ...
225
+ };
226
+ ```
227
+
228
+ ### After(真实 API)
229
+
230
+ ```typescript
231
+ // src/pages/LoginPage.tsx
232
+ import { login } from '@/lib/api/auth';
233
+
234
+ const LoginPage = () => {
235
+ const handleSubmit = async (email: string, password: string) => {
236
+ try {
237
+ const { user, token } = await login({ email, password });
238
+ localStorage.setItem('auth_token', token);
239
+ setUser(user);
240
+ navigate('/dashboard');
241
+ } catch (error) {
242
+ if (error.response?.status === 401) {
243
+ setError('邮箱或密码错误');
244
+ } else {
245
+ setError('登录失败,请稍后重试');
246
+ }
247
+ }
248
+ };
249
+
250
+ // ...
251
+ };
252
+ ```
253
+
254
+ ---
255
+
256
+ ## 错误处理规范
257
+
258
+ ### 1. 错误类型定义
259
+
260
+ ```typescript
261
+ // src/lib/api/errors.ts
262
+ export class ApiError extends Error {
263
+ constructor(
264
+ public status: number,
265
+ public message: string,
266
+ public data?: any
267
+ ) {
268
+ super(message);
269
+ this.name = 'ApiError';
270
+ }
271
+ }
272
+
273
+ export class NetworkError extends Error {
274
+ constructor(message: string = '网络连接失败') {
275
+ super(message);
276
+ this.name = 'NetworkError';
277
+ }
278
+ }
279
+ ```
280
+
281
+ ### 2. 统一错误处理
282
+
283
+ ```typescript
284
+ // src/lib/api/client.ts(响应拦截器)
285
+ apiClient.interceptors.response.use(
286
+ (response) => response.data,
287
+ (error) => {
288
+ if (error.response) {
289
+ // 服务器返回错误
290
+ const { status, data } = error.response;
291
+ throw new ApiError(status, data.message || '请求失败', data);
292
+ } else if (error.request) {
293
+ // 网络错误
294
+ throw new NetworkError('网络连接失败,请检查网络设置');
295
+ } else {
296
+ // 其他错误
297
+ throw new Error('请求失败,请稍后重试');
298
+ }
299
+ }
300
+ );
301
+ ```
302
+
303
+ ### 3. 组件中处理错误
304
+
305
+ ```typescript
306
+ const LoginPage = () => {
307
+ const [error, setError] = useState<string | null>(null);
308
+
309
+ const handleSubmit = async (email: string, password: string) => {
310
+ setError(null);
311
+ try {
312
+ await login({ email, password });
313
+ } catch (err) {
314
+ if (err instanceof ApiError) {
315
+ // 业务错误
316
+ if (err.status === 401) {
317
+ setError('邮箱或密码错误');
318
+ } else if (err.status === 429) {
319
+ setError('请求过于频繁,请稍后重试');
320
+ } else {
321
+ setError(err.message);
322
+ }
323
+ } else if (err instanceof NetworkError) {
324
+ // 网络错误
325
+ setError('网络连接失败,请检查网络设置');
326
+ } else {
327
+ // 未知错误
328
+ setError('登录失败,请稍后重试');
329
+ }
330
+ }
331
+ };
332
+
333
+ return (
334
+ <form onSubmit={handleSubmit}>
335
+ {error && <p className="text-red-500">{error}</p>}
336
+ {/* ... */}
337
+ </form>
338
+ );
339
+ };
340
+ ```
341
+
342
+ ---
343
+
344
+ ## 加载状态管理
345
+
346
+ ### 1. 基本加载状态
347
+
348
+ ```typescript
349
+ const UserList = () => {
350
+ const [users, setUsers] = useState<User[]>([]);
351
+ const [loading, setLoading] = useState(false);
352
+ const [error, setError] = useState<string | null>(null);
353
+
354
+ useEffect(() => {
355
+ const fetchUsers = async () => {
356
+ setLoading(true);
357
+ setError(null);
358
+ try {
359
+ const response = await getUsers({ page: 1, pageSize: 10 });
360
+ setUsers(response.data.items);
361
+ } catch (err) {
362
+ setError('加载用户列表失败');
363
+ } finally {
364
+ setLoading(false);
365
+ }
366
+ };
367
+
368
+ fetchUsers();
369
+ }, []);
370
+
371
+ if (loading) return <div>加载中...</div>;
372
+ if (error) return <div>错误: {error}</div>;
373
+
374
+ return (
375
+ <ul>
376
+ {users.map((user) => (
377
+ <li key={user.id}>{user.name}</li>
378
+ ))}
379
+ </ul>
380
+ );
381
+ };
382
+ ```
383
+
384
+ ### 2. 使用 React Query(推荐)
385
+
386
+ ```typescript
387
+ import { useQuery } from '@tanstack/react-query';
388
+ import { getUsers } from '@/lib/api/user';
389
+
390
+ const UserList = () => {
391
+ const {
392
+ data,
393
+ isLoading,
394
+ error,
395
+ refetch
396
+ } = useQuery({
397
+ queryKey: ['users', { page: 1 }],
398
+ queryFn: () => getUsers({ page: 1, pageSize: 10 }),
399
+ });
400
+
401
+ if (isLoading) return <div>加载中...</div>;
402
+ if (error) return <div>错误: {error.message}</div>;
403
+
404
+ return (
405
+ <div>
406
+ <button onClick={() => refetch()}>刷新</button>
407
+ <ul>
408
+ {data?.data.items.map((user) => (
409
+ <li key={user.id}>{user.name}</li>
410
+ ))}
411
+ </ul>
412
+ </div>
413
+ );
414
+ };
415
+ ```
416
+
417
+ ---
418
+
419
+ ## 类型安全保证
420
+
421
+ ### 1. API 响应类型定义
422
+
423
+ ```typescript
424
+ // src/types/api.ts
425
+ export interface ApiResponse<T> {
426
+ code: number;
427
+ message: string;
428
+ data: T;
429
+ }
430
+
431
+ export interface ApiListResponse<T> {
432
+ code: number;
433
+ message: string;
434
+ data: {
435
+ items: T[];
436
+ total: number;
437
+ page: number;
438
+ pageSize: number;
439
+ };
440
+ }
441
+ ```
442
+
443
+ ### 2. 运行时类型验证(可选)
444
+
445
+ 使用 Zod 进行运行时验证:
446
+
447
+ ```typescript
448
+ import { z } from 'zod';
449
+
450
+ const UserSchema = z.object({
451
+ id: z.string(),
452
+ name: z.string(),
453
+ email: z.string().email(),
454
+ role: z.enum(['admin', 'user', 'guest']),
455
+ });
456
+
457
+ export const login = async (data: LoginRequest): Promise<LoginResponse> => {
458
+ const response = await apiClient.post('/api/auth/login', data);
459
+
460
+ // 验证响应数据
461
+ const user = UserSchema.parse(response.user);
462
+
463
+ return {
464
+ user,
465
+ token: response.token,
466
+ };
467
+ };
468
+ ```
469
+
470
+ ---
471
+
472
+ ## 检查清单
473
+
474
+ API 集成完成前,确保:
475
+
476
+ - [ ] 所有 TODO 标记的 Mock API 已替换
477
+ - [ ] API 客户端配置完成(baseURL、拦截器)
478
+ - [ ] 环境变量配置正确
479
+ - [ ] 所有 API 函数包含类型定义
480
+ - [ ] 错误处理完善(网络错误、业务错误)
481
+ - [ ] 加载状态管理完善
482
+ - [ ] Token 刷新逻辑实现(如需要)
483
+ - [ ] API 调用已测试(手动测试或单元测试)
484
+
485
+ ---
486
+
487
+ ## 常见问题
488
+
489
+ ### Q: 如何处理 Token 过期?
490
+ A: 在响应拦截器中检测 401 状态,自动刷新 Token 或跳转登录页
491
+
492
+ ```typescript
493
+ apiClient.interceptors.response.use(
494
+ (response) => response.data,
495
+ async (error) => {
496
+ if (error.response?.status === 401) {
497
+ const refreshToken = localStorage.getItem('refresh_token');
498
+ if (refreshToken) {
499
+ // 尝试刷新 Token
500
+ try {
501
+ const { token } = await refreshAuthToken(refreshToken);
502
+ localStorage.setItem('auth_token', token);
503
+ // 重试原请求
504
+ return apiClient.request(error.config);
505
+ } catch {
506
+ // 刷新失败,跳转登录
507
+ window.location.href = '/login';
508
+ }
509
+ } else {
510
+ window.location.href = '/login';
511
+ }
512
+ }
513
+ return Promise.reject(error);
514
+ }
515
+ );
516
+ ```
517
+
518
+ ### Q: 如何处理并发请求?
519
+ A: 使用 Promise.all 或 React Query 的并发查询
520
+
521
+ ```typescript
522
+ // Promise.all
523
+ const [users, products] = await Promise.all([
524
+ getUsers(),
525
+ getProducts(),
526
+ ]);
527
+
528
+ // React Query
529
+ const usersQuery = useQuery(['users'], getUsers);
530
+ const productsQuery = useQuery(['products'], getProducts);
531
+ ```
532
+
533
+ ### Q: 如何实现请求取消?
534
+ A: 使用 AbortController
535
+
536
+ ```typescript
537
+ useEffect(() => {
538
+ const controller = new AbortController();
539
+
540
+ const fetchData = async () => {
541
+ try {
542
+ await apiClient.get('/api/users', {
543
+ signal: controller.signal,
544
+ });
545
+ } catch (error) {
546
+ if (error.name === 'AbortError') {
547
+ // 请求被取消
548
+ return;
549
+ }
550
+ }
551
+ };
552
+
553
+ fetchData();
554
+
555
+ return () => controller.abort(); // 组件卸载时取消请求
556
+ }, []);
557
+ ```
558
+
559
+ ---
560
+
561
+ ## 相关文档
562
+
563
+ - [错误处理规范](./error-handling.md)
564
+ - [状态管理规范](./state-management.md)
565
+ - [Frontend 工作规范](./index.md)