@k2works/claude-code-booster 1.10.0 → 1.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +42 -42
  3. package/bin/claude-code-booster +79 -79
  4. package/lib/assets/.claude/README.md +162 -162
  5. package/lib/assets/.claude/SKILLS_TEMPLATE.md +100 -100
  6. package/lib/assets/.claude/scripts/generate-inception-deck.mjs +911 -911
  7. package/lib/assets/.claude/settings.json +11 -11
  8. package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +119 -119
  9. package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +87 -87
  10. package/lib/assets/.claude/skills/analyzing-business/SKILL.md +117 -117
  11. package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +80 -80
  12. package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +88 -88
  13. package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +137 -137
  14. package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +91 -91
  15. package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +91 -91
  16. package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +89 -87
  17. package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +102 -102
  18. package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +87 -87
  19. package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +86 -86
  20. package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +87 -87
  21. package/lib/assets/.claude/skills/creating-adr/SKILL.md +115 -115
  22. package/lib/assets/.claude/skills/developing-backend/SKILL.md +106 -106
  23. package/lib/assets/.claude/skills/developing-frontend/SKILL.md +96 -96
  24. package/lib/assets/.claude/skills/developing-release/SKILL.md +154 -154
  25. package/lib/assets/.claude/skills/generating-slides/SKILL.md +136 -136
  26. package/lib/assets/.claude/skills/git-commit/SKILL.md +106 -106
  27. package/lib/assets/.claude/skills/killing-processes/SKILL.md +98 -98
  28. package/lib/assets/.claude/skills/managing-docs/SKILL.md +200 -200
  29. package/lib/assets/.claude/skills/managing-operations/DEPLOY.md +77 -77
  30. package/lib/assets/.claude/skills/managing-operations/SETUP_CSHARP.md +80 -80
  31. package/lib/assets/.claude/skills/managing-operations/SETUP_FRONTEND.md +84 -84
  32. package/lib/assets/.claude/skills/managing-operations/SETUP_JAVA.md +75 -75
  33. package/lib/assets/.claude/skills/managing-operations/SKILL.md +156 -156
  34. package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +134 -134
  35. package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +243 -243
  36. package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +193 -193
  37. package/lib/assets/.claude/skills/planning-releases/SKILL.md +222 -222
  38. package/lib/assets/.claude/skills/tracking-progress/SKILL.md +164 -164
  39. package/lib/assets/.devcontainer/devcontainer.json +34 -34
  40. package/lib/assets/.env.example +17 -17
  41. package/lib/assets/.gitattributes +4 -4
  42. package/lib/assets/.github/workflows/docker-publish.yml +77 -77
  43. package/lib/assets/.github/workflows/mkdocs.yml +39 -39
  44. package/lib/assets/AGENTS.md +94 -94
  45. package/lib/assets/CLAUDE.md +162 -162
  46. package/lib/assets/README.md +285 -269
  47. package/lib/assets/docker-compose.yml +33 -33
  48. package/lib/assets/docs/assets/css/extra.css +29 -29
  49. package/lib/assets/docs/assets/js/extra.js +44 -44
  50. package/lib/assets/docs/index.md +14 -14
  51. package/lib/assets/docs/reference/CodexCLIMCP/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/343/203/225/343/203/255/343/203/274.md +532 -532
  52. package/lib/assets/docs/reference/CodexCLIMCP/343/202/265/343/203/274/343/203/220/343/203/274/350/250/255/345/256/232/346/211/213/351/240/206.md +341 -341
  53. package/lib/assets/docs/reference/Java/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +578 -578
  54. package/lib/assets/docs/reference/TypeScript/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +465 -465
  55. package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +448 -448
  56. package/lib/assets/docs/reference//343/202/210/343/201/204/343/202/275/343/203/225/343/203/210/343/202/246/343/202/247/343/202/242/343/201/250/343/201/257.md +242 -242
  57. package/lib/assets/docs/reference//343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +2216 -2216
  58. package/lib/assets/docs/reference//343/202/244/343/203/263/343/203/225/343/203/251/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +1878 -1878
  59. package/lib/assets/docs/reference//343/202/250/343/202/257/343/202/271/343/203/210/343/203/252/343/203/274/343/203/240/343/203/227/343/203/255/343/202/260/343/203/251/343/203/237/343/203/263/343/202/260.md +554 -554
  60. package/lib/assets/docs/reference//343/202/263/343/203/274/343/203/207/343/202/243/343/203/263/343/202/260/343/201/250/343/203/206/343/202/271/343/203/210/343/202/254/343/202/244/343/203/211.md +705 -705
  61. package/lib/assets/docs/reference//343/203/206/343/202/271/343/203/210/346/210/246/347/225/245/343/202/254/343/202/244/343/203/211.md +1313 -1313
  62. package/lib/assets/docs/reference//343/203/207/343/203/274/343/202/277/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +311 -311
  63. package/lib/assets/docs/reference//343/203/211/343/203/241/343/202/244/343/203/263/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +599 -599
  64. package/lib/assets/docs/reference//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/345/210/206/346/236/220/343/202/254/343/202/244/343/203/211.md +528 -528
  65. package/lib/assets/docs/reference//343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +682 -682
  66. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/202/254/343/202/244/343/203/211.md +442 -442
  67. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/203/273/343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273/343/202/254/343/202/244/343/203/211.md +558 -558
  68. package/lib/assets/docs/reference//347/222/260/345/242/203/345/244/211/346/225/260/347/256/241/347/220/206/343/202/254/343/202/244/343/203/211.md +663 -663
  69. package/lib/assets/docs/reference//350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1248 -1248
  70. package/lib/assets/docs/reference//351/201/213/347/224/250/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +392 -392
  71. package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +235 -235
  72. package/lib/assets/docs/reference//351/235/236/346/251/237/350/203/275/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1236 -1236
  73. package/lib/assets/docs/template/ADR.md +30 -30
  74. package/lib/assets/docs/template/README.md +50 -50
  75. package/lib/assets/docs/template//343/201/276/343/201/232/343/201/223/343/202/214/343/202/222/350/252/255/343/202/202/343/201/206/343/203/252/343/202/271/343/203/210.md +12 -12
  76. package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/345/256/214/344/272/206/345/240/261/345/221/212/346/233/270.md +58 -58
  77. package/lib/assets/docs/template//343/202/244/343/203/263/343/202/273/343/203/227/343/202/267/343/203/247/343/203/263/343/203/207/343/203/203/343/202/255.md +13 -13
  78. package/lib/assets/docs/template//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243.md +379 -379
  79. package/lib/assets/docs/template//345/256/214/345/205/250/345/275/242/345/274/217/343/201/256/343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271.md +68 -68
  80. package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +669 -669
  81. package/lib/assets/docs/template//350/250/255/350/250/210.md +163 -163
  82. package/lib/assets/gulpfile.js +23 -23
  83. package/lib/assets/mkdocs.yml +65 -65
  84. package/lib/assets/ops/docker/mkdoc/Dockerfile +19 -19
  85. package/lib/assets/ops/scripts/journal.js +180 -180
  86. package/lib/assets/ops/scripts/mkdocs.js +82 -82
  87. package/lib/assets/ops/scripts/release.js +431 -431
  88. package/lib/assets/ops/scripts/ssh.js +190 -190
  89. package/lib/assets/ops/scripts/vault.js +299 -299
  90. package/lib/assets/package-lock.json +1653 -1653
  91. package/lib/assets/package.json +40 -40
  92. package/lib/gulpfile.js +37 -37
  93. package/package.json +41 -41
@@ -1,532 +1,532 @@
1
- # アプリケーション開発フロー
2
-
3
- ## 概要
4
-
5
- 本ドキュメントは、Claude(AI アシスタント)と Codex(実装エージェント)を活用した開発フローを定義します。計画・設計は Claude が担当し、実装は Codex に委譲することで、効率的かつ品質の高い開発を実現します。
6
-
7
- ---
8
-
9
- ## 開発フローの全体像
10
-
11
- ```plantuml
12
- @startuml
13
- title 開発フロー
14
-
15
- skinparam rectangle {
16
- BackgroundColor<<claude>> LightBlue
17
- BackgroundColor<<codex>> LightGreen
18
- }
19
-
20
- rectangle "1. 計画\n\n・要件分析\n・タスク分解\n・優先度決定" <<claude>> as plan
21
- rectangle "2. 設計\n\n・API設計\n・UI設計\n・データ設計" <<claude>> as design
22
- rectangle "3. 実装指示\n\n・コード実装\n・テスト作成\n・リファクタ" <<codex>> as impl
23
- rectangle "4. 受入\n\n・設計レビュー\n・E2Eテスト\n・品質確認" <<claude>> as accept
24
-
25
- plan --> design
26
- design --> impl
27
- impl --> accept
28
-
29
- note bottom of plan : Claude
30
- note bottom of design : Claude
31
- note bottom of impl : Codex
32
- note bottom of accept : Claude
33
-
34
- @enduml
35
- ```
36
-
37
- ```plantuml
38
- @startuml
39
- title 開発フロー シーケンス図
40
-
41
- actor ユーザー as user
42
- participant Claude as claude
43
- participant "Codex MCP" as codex
44
- database コードベース as code
45
-
46
- user -> claude : /dev US-103 開始
47
- activate claude
48
-
49
- == 計画フェーズ ==
50
- claude -> code : イテレーション計画読み込み
51
- claude -> code : 既存コード調査
52
- claude -> claude : タスク分解・優先度決定
53
-
54
- == 設計フェーズ ==
55
- claude -> code : 既存パターン確認
56
- claude -> claude : API/UI/データ設計
57
- claude -> claude : Codex指示作成
58
-
59
- == 実装フェーズ ==
60
- claude -> codex : 実装指示(MCP)
61
- activate codex
62
- codex -> code : コード実装
63
- codex -> code : ユニットテスト作成
64
- codex -> codex : Lint/テスト実行
65
- codex --> claude : 実装完了
66
- deactivate codex
67
-
68
- == 受入フェーズ ==
69
- claude -> code : 設計レビュー
70
- claude -> code : E2Eテスト作成
71
- claude -> code : E2Eテスト実行
72
- claude -> code : バグ修正(必要に応じて)
73
- claude --> user : 完了報告
74
-
75
- deactivate claude
76
-
77
- @enduml
78
- ```
79
-
80
- ### 役割分担
81
-
82
- | フェーズ | 担当 | 責務 |
83
- |---------|------|------|
84
- | 計画 | Claude | 要件分析、タスク分解、優先度決定 |
85
- | 設計 | Claude | API 設計、UI 設計、データモデル設計 |
86
- | 実装指示 | Codex | コード実装、ユニットテスト作成 |
87
- | 受入 | Claude | 設計レビュー、E2E テスト作成・実行、品質確認 |
88
-
89
- ---
90
-
91
- ## フェーズ 1: 計画
92
-
93
- ### 目的
94
-
95
- イテレーション計画とユーザーストーリーに基づき、実装すべきタスクを明確化する。
96
-
97
- ### 入力
98
-
99
- - イテレーション計画(`docs/development/iteration_plan-*.md`)
100
- - ユーザーストーリーと受入条件
101
-
102
- ### 活動
103
-
104
- 1. **要件分析**: ユーザーストーリーの受入条件を確認
105
- 2. **既存コード調査**: 関連する既存実装を確認
106
- 3. **タスク分解**: 実装タスクを細分化
107
- 4. **優先度決定**: 依存関係を考慮してタスク順序を決定
108
-
109
- ### 出力
110
-
111
- - タスクリスト(TODO)
112
- - 実装方針
113
-
114
- ### 例: US-103 お知らせ管理
115
-
116
- ```markdown
117
- ## タスクリスト
118
-
119
- 1. AuthContext に role と canManageAnnouncements を追加
120
- 2. API クライアントに CRUD 関数を追加(create/update/delete)
121
- 3. ConfirmDialog 汎用コンポーネント作成
122
- 4. AnnouncementForm コンポーネント作成
123
- 5. AnnouncementFormPage 作成(新規作成・編集兼用)
124
- 6. App.tsx にルーティング追加
125
- 7. AnnouncementsPage に新規作成ボタン追加
126
- 8. AnnouncementDetailPage に編集・削除ボタン追加
127
- 9. ユニットテスト作成
128
- ```
129
-
130
- ---
131
-
132
- ## フェーズ 2: 設計
133
-
134
- ### 目的
135
-
136
- 実装前に詳細な設計を行い、Codex への指示内容を明確化する。
137
-
138
- ### 入力
139
-
140
- - タスクリスト
141
- - 既存のアーキテクチャ・パターン
142
-
143
- ### 活動
144
-
145
- 1. **API 設計**: エンドポイント、リクエスト/レスポンス形式
146
- 2. **データモデル設計**: 型定義、バリデーションルール
147
- 3. **UI 設計**: コンポーネント構造、状態管理
148
- 4. **既存パターン確認**: プロジェクトの既存実装に合わせる
149
-
150
- ### 出力
151
-
152
- - 詳細設計仕様
153
- - Codex への実装指示
154
-
155
- ### 例: AnnouncementForm 設計
156
-
157
- ```typescript
158
- // 設計仕様
159
- type FormValues = {
160
- title: string // 必須、最大200文字
161
- content: string // 必須
162
- category: AnnouncementCategory // GENERAL | IMPORTANT | EVENT | HR
163
- publishedAt: string // datetime-local 形式
164
- }
165
-
166
- // バリデーション
167
- - title: z.string().min(1).max(200)
168
- - content: z.string().min(1)
169
- - category: z.enum(['GENERAL', 'IMPORTANT', 'EVENT', 'HR'])
170
- - publishedAt: z.string().min(1)
171
-
172
- // コンポーネント構造
173
- - AnnouncementForm
174
- - Input (タイトル)
175
- - TextArea (本文)
176
- - Select (カテゴリ)
177
- - DateTimeInput (公開日時)
178
- - Button (キャンセル/保存)
179
- ```
180
-
181
- ---
182
-
183
- ## フェーズ 3: 実装指示(Codex)
184
-
185
- ### 目的
186
-
187
- Codex MCP サーバーを通じて、設計に基づいた実装を委譲する。
188
-
189
- ### Codex MCP 呼び出し方法
190
-
191
- ```
192
- mcp__codex__codex ツールを使用
193
-
194
- パラメータ:
195
- - prompt: 実装指示(詳細な要件を含む)
196
- - sandbox: danger-full-access(workspace-write ではread-onlyエラーになることがある)
197
- - approval-policy: never(自動承認)
198
- - cwd: プロジェクトルート
199
- ```
200
-
201
- ### 指示サイズに関する注意
202
-
203
- > **重要**: ユーザーストーリー単位など大きな単位で Codex に指示を出すと、処理が長時間化しレスポンスがなくなることがあります。
204
-
205
- #### 推奨される指示の粒度
206
-
207
- | 粒度 | 推奨度 | 説明 |
208
- |------|--------|------|
209
- | タスク単位(1-3 ファイル) | ✅ 推奨 | 1 つのコンポーネントや機能単位 |
210
- | 機能単位(3-5 ファイル) | ⚠️ 注意 | 進捗確認を頻繁に行う |
211
- | ユーザーストーリー単位 | ❌ 非推奨 | タスクに分割して実行 |
212
-
213
- #### 大きなタスクの分割例
214
-
215
- ```
216
- ❌ 悪い例: ユーザーストーリー全体を一度に指示
217
- 「US-103 お知らせ管理機能を全て実装してください」
218
-
219
- ✅ 良い例: タスク単位で分割して指示
220
- 1. 「AuthContext に role と canManageAnnouncements を追加」
221
- 2. 「API クライアントに create/update/delete 関数を追加」
222
- 3. 「ConfirmDialog コンポーネントを作成」
223
- 4. 「AnnouncementForm コンポーネントを作成」
224
- 5. ...
225
- ```
226
-
227
- #### レスポンスがない場合の対処
228
-
229
- 1. `codex-reply` で進捗を確認
230
- 2. 長時間応答がない場合はタスクを中断
231
- 3. より小さな単位に分割して再実行
232
-
233
- #### Codex が書き込みできない場合の対処(重要)
234
-
235
- Codex が read-only 制限やファイルロック等で書き込みできなかった場合:
236
-
237
- 1. **Claude が勝手に直接編集を進めてはいけない**
238
- 2. ユーザーに状況を報告し、確認を待つ
239
- 3. ユーザーの許可を得てから代替手段(Claude による直接編集等)を実行
240
-
241
- ```
242
- ❌ 悪い例:
243
- Claude: 「Codex が read-only 制限で書き込みできませんでした。直接編集を行います。」
244
- → 勝手に進めている
245
-
246
- ✅ 良い例:
247
- Claude: 「Codex が read-only 制限で書き込みできませんでした。
248
- 以下の選択肢があります:
249
- 1. Claude が直接編集を行う
250
- 2. 環境の問題を解決してから Codex で再実行
251
- どちらで進めますか?」
252
- → ユーザーの確認を待っている
253
- ```
254
-
255
- ### 実装指示のベストプラクティス
256
-
257
- 1. **明確な要件**: 何を実装するか具体的に記述
258
- 2. **既存パターン参照**: 既存ファイルを参照先として指定
259
- 3. **型定義の明示**: TypeScript の型を事前に定義
260
- 4. **テスト要件**: テストも同時に作成させる
261
- 5. **適切な粒度**: タスク単位(1-3 ファイル)で指示を分割
262
-
263
- ### 例: Codex への実装指示
264
-
265
- ```
266
- prompt: |
267
- お知らせ管理機能を実装してください。
268
-
269
- ## タスク
270
- 1. AuthContext に role プロパティと canManageAnnouncements を追加
271
- 2. API クライアント(src/lib/api.ts)に以下を追加:
272
- - createAnnouncement(input: AnnouncementCreateInput)
273
- - updateAnnouncement(id, input)
274
- - deleteAnnouncement(id)
275
- 3. ConfirmDialog コンポーネントを作成(既存の Button を参考に)
276
- 4. AnnouncementForm コンポーネントを作成(React Hook Form + Zod)
277
- 5. AnnouncementFormPage を作成(/announcements/new と /announcements/:id/edit)
278
- 6. App.tsx にルーティングを追加
279
-
280
- ## 既存パターン参照
281
- - API クライアント: src/lib/api.ts
282
- - フォームコンポーネント: src/components/ui/Input.tsx
283
- - ページコンポーネント: src/pages/AnnouncementsPage.tsx
284
-
285
- ## 完了条件
286
- - ESLint エラーなし
287
- - 既存テストがパス
288
-
289
- sandbox: workspace-write
290
- approval-policy: never
291
- ```
292
-
293
- ### Codex 実行中の確認
294
-
295
- - Codex の進捗は `codex-reply` ツールで確認
296
- - 問題発生時は追加指示で修正を依頼
297
-
298
- ---
299
-
300
- ## フェーズ 4: 受入
301
-
302
- ### 目的
303
-
304
- 実装された機能が設計通りに動作することを確認する。
305
-
306
- ### 活動
307
-
308
- 1. **設計レビュー**: 実装が設計仕様に準拠しているか確認
309
- 2. **コード品質確認**: ESLint、テストカバレッジの確認
310
- 3. **E2E テスト作成**: 成功基準に基づくテストを作成
311
- 4. **E2E テスト実行**: 機能が正しく動作することを検証
312
- 5. **バグ修正**: 問題があれば修正
313
-
314
- ### E2E テスト作成のポイント
315
-
316
- ```typescript
317
- // 成功基準に対応するテストケース
318
- test.describe('お知らせ管理機能(管理者)', () => {
319
- test('管理者がお知らせを新規作成できる', async ({ page }) => {
320
- // 1. 新規作成ボタンをクリック
321
- // 2. フォームに入力
322
- // 3. 保存
323
- // 4. 詳細ページで確認
324
- })
325
-
326
- test('管理者がお知らせを編集できる', async ({ page }) => {
327
- // ...
328
- })
329
-
330
- test('管理者がお知らせを削除できる(確認ダイアログあり)', async ({ page }) => {
331
- // ...
332
- })
333
- })
334
- ```
335
-
336
- ### 受入基準
337
-
338
- - [ ] すべての受入条件が満たされている
339
- - [ ] E2E テストがすべてパス
340
- - [ ] ESLint エラーがない
341
- - [ ] 既存テストが壊れていない
342
-
343
- ---
344
-
345
- ## 実践例: US-103 お知らせ管理
346
-
347
- ```plantuml
348
- @startuml
349
- title US-103 お知らせ管理 開発フロー
350
-
351
- |Claude|
352
- start
353
- :イテレーション計画読み込み;
354
- :受入条件確認;
355
- :既存コード調査;
356
- :タスクリスト作成;
357
-
358
- |Claude|
359
- :API設計確認;
360
- :フロントエンド設計;
361
- :Codex指示作成;
362
-
363
- |Codex|
364
- :AuthContext拡張;
365
- :APIクライアント追加;
366
- :ConfirmDialog作成;
367
- :AnnouncementForm作成;
368
- :AnnouncementFormPage作成;
369
- :ルーティング追加;
370
- :既存ページ修正;
371
- :ユニットテスト実行;
372
-
373
- |Claude|
374
- :設計レビュー;
375
- :E2Eテスト作成;
376
- :E2Eテスト実行;
377
-
378
- if (テスト失敗?) then (yes)
379
- :バグ修正;
380
- :再テスト;
381
- else (no)
382
- endif
383
-
384
- :完了報告;
385
- stop
386
-
387
- @enduml
388
- ```
389
-
390
- ### 1. 計画フェーズ
391
-
392
- ```
393
- ユーザー: /dev iteration3 US-103: お知らせ管理 開始
394
- 計画・設計は claude 実装は codex が担当する
395
-
396
- Claude:
397
- 1. イテレーション計画を読み込み
398
- 2. 受入条件を確認
399
- 3. 既存コードを調査(API、フロントエンド構造)
400
- 4. タスクリストを作成
401
- ```
402
-
403
- ### 2. 設計フェーズ
404
-
405
- ```
406
- Claude:
407
- 1. API エンドポイント設計を確認(既に実装済み)
408
- 2. フロントエンドコンポーネント設計
409
- - AuthContext の拡張
410
- - AnnouncementForm コンポーネント
411
- - AnnouncementFormPage
412
- - 既存ページの修正
413
- 3. Codex への詳細指示を作成
414
- ```
415
-
416
- ### 3. 実装フェーズ
417
-
418
- ```
419
- Claude → Codex MCP:
420
- prompt: "お知らせ管理機能を実装..."
421
- sandbox: workspace-write
422
- approval-policy: never
423
-
424
- Codex:
425
- 1. AuthContext に role, canManageAnnouncements 追加
426
- 2. API クライアントに CRUD 関数追加
427
- 3. ConfirmDialog コンポーネント作成
428
- 4. AnnouncementForm コンポーネント作成
429
- 5. AnnouncementFormPage 作成
430
- 6. App.tsx ルーティング追加
431
- 7. AnnouncementsPage, AnnouncementDetailPage 修正
432
- 8. テスト作成・実行
433
- ```
434
-
435
- ### 4. 受入フェーズ
436
-
437
- ```
438
- Claude:
439
- 1. 設計レビュー
440
- - 実装が設計に準拠しているか確認
441
- - コード品質確認
442
-
443
- 2. E2E テスト作成
444
- - announcements.spec.ts に管理機能テストを追加
445
-
446
- 3. E2E テスト実行
447
- - npm run test:e2e -- --grep "お知らせ"
448
-
449
- 4. バグ修正
450
- - publishedAt の ISO 8601 形式変換を追加
451
- - テストの待機処理を追加
452
-
453
- 5. 最終確認
454
- - 15 tests passed
455
- ```
456
-
457
- ---
458
-
459
- ## コマンドリファレンス
460
-
461
- ### 開発開始
462
-
463
- ```bash
464
- # イテレーションのユーザーストーリー開始
465
- /dev iteration3 US-103: お知らせ管理 開始
466
- ```
467
-
468
- ### Codex MCP 呼び出し
469
-
470
- ```
471
- mcp__codex__codex
472
- prompt: "実装指示..."
473
- sandbox: workspace-write
474
- approval-policy: never
475
- cwd: /path/to/project
476
- ```
477
-
478
- ### テスト実行
479
-
480
- ```bash
481
- # ユニットテスト
482
- npm run test
483
-
484
- # E2E テスト(全体)
485
- npm run test:e2e
486
-
487
- # E2E テスト(特定機能)
488
- npm run test:e2e -- --grep "お知らせ"
489
- ```
490
-
491
- ### 品質チェック
492
-
493
- ```bash
494
- # Lint + Format + Test
495
- npm run check
496
- ```
497
-
498
- ---
499
-
500
- ## ベストプラクティス
501
-
502
- ### 計画・設計
503
-
504
- 1. **既存パターンを尊重**: プロジェクトの既存実装に合わせる
505
- 2. **受入条件を明確に**: テスト可能な条件を定義する
506
- 3. **依存関係を考慮**: タスクの実行順序を適切に設定
507
-
508
- ### 実装指示
509
-
510
- 1. **具体的な指示**: 曖昧さを排除した詳細な要件
511
- 2. **参照ファイルの明示**: 既存のパターンを参照先として指定
512
- 3. **完了条件の明示**: 何をもって完了とするか明確に
513
-
514
- ### 受入
515
-
516
- 1. **設計レビュー先行**: テスト前にコードを確認
517
- 2. **E2E テストで検証**: 成功基準に対応するテストを作成
518
- 3. **継続的なフィードバック**: 問題があれば即座に修正
519
-
520
- ---
521
-
522
- ## 関連ドキュメント
523
-
524
- - [開発環境セットアップ](dev_app_instruction.md)
525
- - [Codex CLI MCP サーバー設定](codex_instruction.md)
526
- - [イテレーション計画](../development/iteration_plan-3.md)
527
- - [コーディングとテストガイド](../reference/コーディングとテストガイド.md)
528
-
529
- ---
530
-
531
- **作成日**: 2026-01-19
532
- **更新日**: 2026-01-19
1
+ # アプリケーション開発フロー
2
+
3
+ ## 概要
4
+
5
+ 本ドキュメントは、Claude(AI アシスタント)と Codex(実装エージェント)を活用した開発フローを定義します。計画・設計は Claude が担当し、実装は Codex に委譲することで、効率的かつ品質の高い開発を実現します。
6
+
7
+ ---
8
+
9
+ ## 開発フローの全体像
10
+
11
+ ```plantuml
12
+ @startuml
13
+ title 開発フロー
14
+
15
+ skinparam rectangle {
16
+ BackgroundColor<<claude>> LightBlue
17
+ BackgroundColor<<codex>> LightGreen
18
+ }
19
+
20
+ rectangle "1. 計画\n\n・要件分析\n・タスク分解\n・優先度決定" <<claude>> as plan
21
+ rectangle "2. 設計\n\n・API設計\n・UI設計\n・データ設計" <<claude>> as design
22
+ rectangle "3. 実装指示\n\n・コード実装\n・テスト作成\n・リファクタ" <<codex>> as impl
23
+ rectangle "4. 受入\n\n・設計レビュー\n・E2Eテスト\n・品質確認" <<claude>> as accept
24
+
25
+ plan --> design
26
+ design --> impl
27
+ impl --> accept
28
+
29
+ note bottom of plan : Claude
30
+ note bottom of design : Claude
31
+ note bottom of impl : Codex
32
+ note bottom of accept : Claude
33
+
34
+ @enduml
35
+ ```
36
+
37
+ ```plantuml
38
+ @startuml
39
+ title 開発フロー シーケンス図
40
+
41
+ actor ユーザー as user
42
+ participant Claude as claude
43
+ participant "Codex MCP" as codex
44
+ database コードベース as code
45
+
46
+ user -> claude : /dev US-103 開始
47
+ activate claude
48
+
49
+ == 計画フェーズ ==
50
+ claude -> code : イテレーション計画読み込み
51
+ claude -> code : 既存コード調査
52
+ claude -> claude : タスク分解・優先度決定
53
+
54
+ == 設計フェーズ ==
55
+ claude -> code : 既存パターン確認
56
+ claude -> claude : API/UI/データ設計
57
+ claude -> claude : Codex指示作成
58
+
59
+ == 実装フェーズ ==
60
+ claude -> codex : 実装指示(MCP)
61
+ activate codex
62
+ codex -> code : コード実装
63
+ codex -> code : ユニットテスト作成
64
+ codex -> codex : Lint/テスト実行
65
+ codex --> claude : 実装完了
66
+ deactivate codex
67
+
68
+ == 受入フェーズ ==
69
+ claude -> code : 設計レビュー
70
+ claude -> code : E2Eテスト作成
71
+ claude -> code : E2Eテスト実行
72
+ claude -> code : バグ修正(必要に応じて)
73
+ claude --> user : 完了報告
74
+
75
+ deactivate claude
76
+
77
+ @enduml
78
+ ```
79
+
80
+ ### 役割分担
81
+
82
+ | フェーズ | 担当 | 責務 |
83
+ |---------|------|------|
84
+ | 計画 | Claude | 要件分析、タスク分解、優先度決定 |
85
+ | 設計 | Claude | API 設計、UI 設計、データモデル設計 |
86
+ | 実装指示 | Codex | コード実装、ユニットテスト作成 |
87
+ | 受入 | Claude | 設計レビュー、E2E テスト作成・実行、品質確認 |
88
+
89
+ ---
90
+
91
+ ## フェーズ 1: 計画
92
+
93
+ ### 目的
94
+
95
+ イテレーション計画とユーザーストーリーに基づき、実装すべきタスクを明確化する。
96
+
97
+ ### 入力
98
+
99
+ - イテレーション計画(`docs/development/iteration_plan-*.md`)
100
+ - ユーザーストーリーと受入条件
101
+
102
+ ### 活動
103
+
104
+ 1. **要件分析**: ユーザーストーリーの受入条件を確認
105
+ 2. **既存コード調査**: 関連する既存実装を確認
106
+ 3. **タスク分解**: 実装タスクを細分化
107
+ 4. **優先度決定**: 依存関係を考慮してタスク順序を決定
108
+
109
+ ### 出力
110
+
111
+ - タスクリスト(TODO)
112
+ - 実装方針
113
+
114
+ ### 例: US-103 お知らせ管理
115
+
116
+ ```markdown
117
+ ## タスクリスト
118
+
119
+ 1. AuthContext に role と canManageAnnouncements を追加
120
+ 2. API クライアントに CRUD 関数を追加(create/update/delete)
121
+ 3. ConfirmDialog 汎用コンポーネント作成
122
+ 4. AnnouncementForm コンポーネント作成
123
+ 5. AnnouncementFormPage 作成(新規作成・編集兼用)
124
+ 6. App.tsx にルーティング追加
125
+ 7. AnnouncementsPage に新規作成ボタン追加
126
+ 8. AnnouncementDetailPage に編集・削除ボタン追加
127
+ 9. ユニットテスト作成
128
+ ```
129
+
130
+ ---
131
+
132
+ ## フェーズ 2: 設計
133
+
134
+ ### 目的
135
+
136
+ 実装前に詳細な設計を行い、Codex への指示内容を明確化する。
137
+
138
+ ### 入力
139
+
140
+ - タスクリスト
141
+ - 既存のアーキテクチャ・パターン
142
+
143
+ ### 活動
144
+
145
+ 1. **API 設計**: エンドポイント、リクエスト/レスポンス形式
146
+ 2. **データモデル設計**: 型定義、バリデーションルール
147
+ 3. **UI 設計**: コンポーネント構造、状態管理
148
+ 4. **既存パターン確認**: プロジェクトの既存実装に合わせる
149
+
150
+ ### 出力
151
+
152
+ - 詳細設計仕様
153
+ - Codex への実装指示
154
+
155
+ ### 例: AnnouncementForm 設計
156
+
157
+ ```typescript
158
+ // 設計仕様
159
+ type FormValues = {
160
+ title: string // 必須、最大200文字
161
+ content: string // 必須
162
+ category: AnnouncementCategory // GENERAL | IMPORTANT | EVENT | HR
163
+ publishedAt: string // datetime-local 形式
164
+ }
165
+
166
+ // バリデーション
167
+ - title: z.string().min(1).max(200)
168
+ - content: z.string().min(1)
169
+ - category: z.enum(['GENERAL', 'IMPORTANT', 'EVENT', 'HR'])
170
+ - publishedAt: z.string().min(1)
171
+
172
+ // コンポーネント構造
173
+ - AnnouncementForm
174
+ - Input (タイトル)
175
+ - TextArea (本文)
176
+ - Select (カテゴリ)
177
+ - DateTimeInput (公開日時)
178
+ - Button (キャンセル/保存)
179
+ ```
180
+
181
+ ---
182
+
183
+ ## フェーズ 3: 実装指示(Codex)
184
+
185
+ ### 目的
186
+
187
+ Codex MCP サーバーを通じて、設計に基づいた実装を委譲する。
188
+
189
+ ### Codex MCP 呼び出し方法
190
+
191
+ ```
192
+ mcp__codex__codex ツールを使用
193
+
194
+ パラメータ:
195
+ - prompt: 実装指示(詳細な要件を含む)
196
+ - sandbox: danger-full-access(workspace-write ではread-onlyエラーになることがある)
197
+ - approval-policy: never(自動承認)
198
+ - cwd: プロジェクトルート
199
+ ```
200
+
201
+ ### 指示サイズに関する注意
202
+
203
+ > **重要**: ユーザーストーリー単位など大きな単位で Codex に指示を出すと、処理が長時間化しレスポンスがなくなることがあります。
204
+
205
+ #### 推奨される指示の粒度
206
+
207
+ | 粒度 | 推奨度 | 説明 |
208
+ |------|--------|------|
209
+ | タスク単位(1-3 ファイル) | ✅ 推奨 | 1 つのコンポーネントや機能単位 |
210
+ | 機能単位(3-5 ファイル) | ⚠️ 注意 | 進捗確認を頻繁に行う |
211
+ | ユーザーストーリー単位 | ❌ 非推奨 | タスクに分割して実行 |
212
+
213
+ #### 大きなタスクの分割例
214
+
215
+ ```
216
+ ❌ 悪い例: ユーザーストーリー全体を一度に指示
217
+ 「US-103 お知らせ管理機能を全て実装してください」
218
+
219
+ ✅ 良い例: タスク単位で分割して指示
220
+ 1. 「AuthContext に role と canManageAnnouncements を追加」
221
+ 2. 「API クライアントに create/update/delete 関数を追加」
222
+ 3. 「ConfirmDialog コンポーネントを作成」
223
+ 4. 「AnnouncementForm コンポーネントを作成」
224
+ 5. ...
225
+ ```
226
+
227
+ #### レスポンスがない場合の対処
228
+
229
+ 1. `codex-reply` で進捗を確認
230
+ 2. 長時間応答がない場合はタスクを中断
231
+ 3. より小さな単位に分割して再実行
232
+
233
+ #### Codex が書き込みできない場合の対処(重要)
234
+
235
+ Codex が read-only 制限やファイルロック等で書き込みできなかった場合:
236
+
237
+ 1. **Claude が勝手に直接編集を進めてはいけない**
238
+ 2. ユーザーに状況を報告し、確認を待つ
239
+ 3. ユーザーの許可を得てから代替手段(Claude による直接編集等)を実行
240
+
241
+ ```
242
+ ❌ 悪い例:
243
+ Claude: 「Codex が read-only 制限で書き込みできませんでした。直接編集を行います。」
244
+ → 勝手に進めている
245
+
246
+ ✅ 良い例:
247
+ Claude: 「Codex が read-only 制限で書き込みできませんでした。
248
+ 以下の選択肢があります:
249
+ 1. Claude が直接編集を行う
250
+ 2. 環境の問題を解決してから Codex で再実行
251
+ どちらで進めますか?」
252
+ → ユーザーの確認を待っている
253
+ ```
254
+
255
+ ### 実装指示のベストプラクティス
256
+
257
+ 1. **明確な要件**: 何を実装するか具体的に記述
258
+ 2. **既存パターン参照**: 既存ファイルを参照先として指定
259
+ 3. **型定義の明示**: TypeScript の型を事前に定義
260
+ 4. **テスト要件**: テストも同時に作成させる
261
+ 5. **適切な粒度**: タスク単位(1-3 ファイル)で指示を分割
262
+
263
+ ### 例: Codex への実装指示
264
+
265
+ ```
266
+ prompt: |
267
+ お知らせ管理機能を実装してください。
268
+
269
+ ## タスク
270
+ 1. AuthContext に role プロパティと canManageAnnouncements を追加
271
+ 2. API クライアント(src/lib/api.ts)に以下を追加:
272
+ - createAnnouncement(input: AnnouncementCreateInput)
273
+ - updateAnnouncement(id, input)
274
+ - deleteAnnouncement(id)
275
+ 3. ConfirmDialog コンポーネントを作成(既存の Button を参考に)
276
+ 4. AnnouncementForm コンポーネントを作成(React Hook Form + Zod)
277
+ 5. AnnouncementFormPage を作成(/announcements/new と /announcements/:id/edit)
278
+ 6. App.tsx にルーティングを追加
279
+
280
+ ## 既存パターン参照
281
+ - API クライアント: src/lib/api.ts
282
+ - フォームコンポーネント: src/components/ui/Input.tsx
283
+ - ページコンポーネント: src/pages/AnnouncementsPage.tsx
284
+
285
+ ## 完了条件
286
+ - ESLint エラーなし
287
+ - 既存テストがパス
288
+
289
+ sandbox: workspace-write
290
+ approval-policy: never
291
+ ```
292
+
293
+ ### Codex 実行中の確認
294
+
295
+ - Codex の進捗は `codex-reply` ツールで確認
296
+ - 問題発生時は追加指示で修正を依頼
297
+
298
+ ---
299
+
300
+ ## フェーズ 4: 受入
301
+
302
+ ### 目的
303
+
304
+ 実装された機能が設計通りに動作することを確認する。
305
+
306
+ ### 活動
307
+
308
+ 1. **設計レビュー**: 実装が設計仕様に準拠しているか確認
309
+ 2. **コード品質確認**: ESLint、テストカバレッジの確認
310
+ 3. **E2E テスト作成**: 成功基準に基づくテストを作成
311
+ 4. **E2E テスト実行**: 機能が正しく動作することを検証
312
+ 5. **バグ修正**: 問題があれば修正
313
+
314
+ ### E2E テスト作成のポイント
315
+
316
+ ```typescript
317
+ // 成功基準に対応するテストケース
318
+ test.describe('お知らせ管理機能(管理者)', () => {
319
+ test('管理者がお知らせを新規作成できる', async ({ page }) => {
320
+ // 1. 新規作成ボタンをクリック
321
+ // 2. フォームに入力
322
+ // 3. 保存
323
+ // 4. 詳細ページで確認
324
+ })
325
+
326
+ test('管理者がお知らせを編集できる', async ({ page }) => {
327
+ // ...
328
+ })
329
+
330
+ test('管理者がお知らせを削除できる(確認ダイアログあり)', async ({ page }) => {
331
+ // ...
332
+ })
333
+ })
334
+ ```
335
+
336
+ ### 受入基準
337
+
338
+ - [ ] すべての受入条件が満たされている
339
+ - [ ] E2E テストがすべてパス
340
+ - [ ] ESLint エラーがない
341
+ - [ ] 既存テストが壊れていない
342
+
343
+ ---
344
+
345
+ ## 実践例: US-103 お知らせ管理
346
+
347
+ ```plantuml
348
+ @startuml
349
+ title US-103 お知らせ管理 開発フロー
350
+
351
+ |Claude|
352
+ start
353
+ :イテレーション計画読み込み;
354
+ :受入条件確認;
355
+ :既存コード調査;
356
+ :タスクリスト作成;
357
+
358
+ |Claude|
359
+ :API設計確認;
360
+ :フロントエンド設計;
361
+ :Codex指示作成;
362
+
363
+ |Codex|
364
+ :AuthContext拡張;
365
+ :APIクライアント追加;
366
+ :ConfirmDialog作成;
367
+ :AnnouncementForm作成;
368
+ :AnnouncementFormPage作成;
369
+ :ルーティング追加;
370
+ :既存ページ修正;
371
+ :ユニットテスト実行;
372
+
373
+ |Claude|
374
+ :設計レビュー;
375
+ :E2Eテスト作成;
376
+ :E2Eテスト実行;
377
+
378
+ if (テスト失敗?) then (yes)
379
+ :バグ修正;
380
+ :再テスト;
381
+ else (no)
382
+ endif
383
+
384
+ :完了報告;
385
+ stop
386
+
387
+ @enduml
388
+ ```
389
+
390
+ ### 1. 計画フェーズ
391
+
392
+ ```
393
+ ユーザー: /dev iteration3 US-103: お知らせ管理 開始
394
+ 計画・設計は claude 実装は codex が担当する
395
+
396
+ Claude:
397
+ 1. イテレーション計画を読み込み
398
+ 2. 受入条件を確認
399
+ 3. 既存コードを調査(API、フロントエンド構造)
400
+ 4. タスクリストを作成
401
+ ```
402
+
403
+ ### 2. 設計フェーズ
404
+
405
+ ```
406
+ Claude:
407
+ 1. API エンドポイント設計を確認(既に実装済み)
408
+ 2. フロントエンドコンポーネント設計
409
+ - AuthContext の拡張
410
+ - AnnouncementForm コンポーネント
411
+ - AnnouncementFormPage
412
+ - 既存ページの修正
413
+ 3. Codex への詳細指示を作成
414
+ ```
415
+
416
+ ### 3. 実装フェーズ
417
+
418
+ ```
419
+ Claude → Codex MCP:
420
+ prompt: "お知らせ管理機能を実装..."
421
+ sandbox: workspace-write
422
+ approval-policy: never
423
+
424
+ Codex:
425
+ 1. AuthContext に role, canManageAnnouncements 追加
426
+ 2. API クライアントに CRUD 関数追加
427
+ 3. ConfirmDialog コンポーネント作成
428
+ 4. AnnouncementForm コンポーネント作成
429
+ 5. AnnouncementFormPage 作成
430
+ 6. App.tsx ルーティング追加
431
+ 7. AnnouncementsPage, AnnouncementDetailPage 修正
432
+ 8. テスト作成・実行
433
+ ```
434
+
435
+ ### 4. 受入フェーズ
436
+
437
+ ```
438
+ Claude:
439
+ 1. 設計レビュー
440
+ - 実装が設計に準拠しているか確認
441
+ - コード品質確認
442
+
443
+ 2. E2E テスト作成
444
+ - announcements.spec.ts に管理機能テストを追加
445
+
446
+ 3. E2E テスト実行
447
+ - npm run test:e2e -- --grep "お知らせ"
448
+
449
+ 4. バグ修正
450
+ - publishedAt の ISO 8601 形式変換を追加
451
+ - テストの待機処理を追加
452
+
453
+ 5. 最終確認
454
+ - 15 tests passed
455
+ ```
456
+
457
+ ---
458
+
459
+ ## コマンドリファレンス
460
+
461
+ ### 開発開始
462
+
463
+ ```bash
464
+ # イテレーションのユーザーストーリー開始
465
+ /dev iteration3 US-103: お知らせ管理 開始
466
+ ```
467
+
468
+ ### Codex MCP 呼び出し
469
+
470
+ ```
471
+ mcp__codex__codex
472
+ prompt: "実装指示..."
473
+ sandbox: workspace-write
474
+ approval-policy: never
475
+ cwd: /path/to/project
476
+ ```
477
+
478
+ ### テスト実行
479
+
480
+ ```bash
481
+ # ユニットテスト
482
+ npm run test
483
+
484
+ # E2E テスト(全体)
485
+ npm run test:e2e
486
+
487
+ # E2E テスト(特定機能)
488
+ npm run test:e2e -- --grep "お知らせ"
489
+ ```
490
+
491
+ ### 品質チェック
492
+
493
+ ```bash
494
+ # Lint + Format + Test
495
+ npm run check
496
+ ```
497
+
498
+ ---
499
+
500
+ ## ベストプラクティス
501
+
502
+ ### 計画・設計
503
+
504
+ 1. **既存パターンを尊重**: プロジェクトの既存実装に合わせる
505
+ 2. **受入条件を明確に**: テスト可能な条件を定義する
506
+ 3. **依存関係を考慮**: タスクの実行順序を適切に設定
507
+
508
+ ### 実装指示
509
+
510
+ 1. **具体的な指示**: 曖昧さを排除した詳細な要件
511
+ 2. **参照ファイルの明示**: 既存のパターンを参照先として指定
512
+ 3. **完了条件の明示**: 何をもって完了とするか明確に
513
+
514
+ ### 受入
515
+
516
+ 1. **設計レビュー先行**: テスト前にコードを確認
517
+ 2. **E2E テストで検証**: 成功基準に対応するテストを作成
518
+ 3. **継続的なフィードバック**: 問題があれば即座に修正
519
+
520
+ ---
521
+
522
+ ## 関連ドキュメント
523
+
524
+ - [開発環境セットアップ](dev_app_instruction.md)
525
+ - [Codex CLI MCP サーバー設定](codex_instruction.md)
526
+ - [イテレーション計画](../development/iteration_plan-3.md)
527
+ - [コーディングとテストガイド](../reference/コーディングとテストガイド.md)
528
+
529
+ ---
530
+
531
+ **作成日**: 2026-01-19
532
+ **更新日**: 2026-01-19