Skip to content

作業履歴 2025-08-05

概要

2025-08-05の作業内容をまとめています。

コミット: d271c0d

メッセージ

docs: Phase 1要件フェーズの完全実装
## 主要成果物
- ADRファイル: 7個(技術選定記録)
- 要件設計書: 5個(ユーザーストーリー、ユースケース等)
- システム設計書: 5個(データモデル、アーキテクチャ等)
- テンプレートファイル: 2個

## 実装内容
### アーキテクチャ決定記録 (ADR)
- TypeScript、Vitest、Canvas API、TDD、GitHub Actions、Vercelの採用決定
- 各技術選定の理由と影響を明文化

### 要件設計
- 11のユーザーストーリー詳細化(55ストーリーポイント)
- 10の主要ユースケース詳細化
- 包括的な非機能要件定義
- 段階的リリース計画策定

### システム設計
- レイヤードアーキテクチャ(4層構造)
- DDD原則に基づくドメインモデル設計
- データモデル設計(7つの主要エンティティ)
- レスポンシブUI設計
- 3層テスト戦略(単体・統合・E2E)

## ディレクトリ構造改善
- docs/requirements/: 要件定義系ドキュメント
- docs/design/: システム設計系ドキュメント
- docs/adr/: アーキテクチャ決定記録
- mkdocs.yml: navigation構造を論理的に整理

## 品質指標
- TODO完了率: 11/11 (100%)
- PlantUML図: 20+個作成
- 総ページ数: 50+ページ
- Phase 2への実装準備: 完了

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>

変更されたファイル

  • A docs/adr/0001-adopt-typescript.md
  • A docs/adr/0002-adopt-vitest.md
  • A docs/adr/0003-adopt-canvas-api.md
  • A docs/adr/0004-adopt-tdd-approach.md
  • A docs/adr/0005-adopt-github-actions.md
  • A docs/adr/0006-adopt-vercel.md
  • A docs/adr/index.md
  • A docs/design/index.md
  • A "docs/design/\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.md"
  • A "docs/design/\343\203\206\343\202\271\343\203\210\346\210\246\347\225\245.md"
  • A "docs/design/\343\203\207\343\203\274\343\202\277\343\203\242\343\203\207\343\203\253\350\250\255\350\250\210.md"
  • A "docs/design/\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.md"
  • A "docs/design/\343\203\246\343\203\274\343\202\266\343\203\274\343\202\244\343\203\263\343\202\277\343\203\274\343\203\225\343\202\247\343\203\274\343\202\271\350\250\255\350\250\210.md"
  • A "docs/requirements/\343\203\246\343\203\274\343\202\266\343\203\274\343\202\271\343\203\210\343\203\274\343\203\252\343\203\274\350\251\263\347\264\260.md"
  • A "docs/requirements/\343\203\246\343\203\274\343\202\271\343\202\261\343\203\274\343\202\271\350\251\263\347\264\260.md"
  • A "docs/requirements/\350\246\201\344\273\266.md"
  • A "docs/requirements/\351\201\213\347\224\250\350\246\201\344\273\266\343\201\250\343\203\252\343\203\252\343\203\274\343\202\271\350\250\210\347\224\273.md"
  • A "docs/requirements/\351\235\236\346\251\237\350\203\275\350\246\201\344\273\266.md"
  • A docs/template/ADR.md
  • A "docs/template/\350\250\255\350\250\210.md"
  • M mkdocs.yml

変更内容

commit d271c0d9919bc7c5b72315002ff33780d47631e2
Author: k2works <kakimomokuri@gmail.com>
Date:   Tue Aug 5 13:17:28 2025 +0900

    docs: Phase 1要件フェーズの完全実装

    ## 主要成果物
    - ADRファイル: 7個(技術選定記録)
    - 要件設計書: 5個(ユーザーストーリー、ユースケース等)
    - システム設計書: 5個(データモデル、アーキテクチャ等)
    - テンプレートファイル: 2個

    ## 実装内容
    ### アーキテクチャ決定記録 (ADR)
    - TypeScript、Vitest、Canvas API、TDD、GitHub Actions、Vercelの採用決定
    - 各技術選定の理由と影響を明文化

    ### 要件設計
    - 11のユーザーストーリー詳細化(55ストーリーポイント)
    - 10の主要ユースケース詳細化
    - 包括的な非機能要件定義
    - 段階的リリース計画策定

    ### システム設計
    - レイヤードアーキテクチャ(4層構造)
    - DDD原則に基づくドメインモデル設計
    - データモデル設計(7つの主要エンティティ)
    - レスポンシブUI設計
    - 3層テスト戦略(単体・統合・E2E)

    ## ディレクトリ構造改善
    - docs/requirements/: 要件定義系ドキュメント
    - docs/design/: システム設計系ドキュメント
    - docs/adr/: アーキテクチャ決定記録
    - mkdocs.yml: navigation構造を論理的に整理

    ## 品質指標
    - TODO完了率: 11/11 (100%)
    - PlantUML図: 20+個作成
    - 総ページ数: 50+ページ
    - Phase 2への実装準備: 完了

    🤖 Generated with [Claude Code](https://claude.ai/code)

    Co-Authored-By: Claude <noreply@anthropic.com>

diff --git a/docs/adr/0001-adopt-typescript.md b/docs/adr/0001-adopt-typescript.md
new file mode 100644
index 0000000..22f12b7
--- /dev/null
+++ b/docs/adr/0001-adopt-typescript.md
@@ -0,0 +1,41 @@
+# ADR-0001: TypeScriptの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+ぷよぷよゲームをWebブラウザで動作させるアプリケーションを開発する必要がある。
+開発言語を選定するにあたり、以下の要件を考慮する必要がある:
+
+- ブラウザでの動作が必要
+- ゲームロジックの複雑性に対応できる型安全性
+- テスト駆動開発を実践できる環境
+- 開発効率とメンテナンス性
+- 連鎖処理やスコア計算などの複雑な計算ロジック
+
+## 決定
+
+TypeScriptを開発言語として採用する。
+
+## 理由
+
+- **型安全性**: 静的型付けによりコンパイル時にエラーを検出でき、ぷよの色や位置座標、連鎖計算などの複雑なゲームロジックの実装において高い安全性を確保できる
+- **開発効率**: IDEの補完機能やリファクタリング支援が充実しており、大量のゲームロジックの実装において生産性が高い
+- **テスト環境**: Vitestなどの優れたテストツールが利用可能で、TDD実践に適している
+- **エコシステム**: npmによる豊富なライブラリとツールが利用可能
+- **ブラウザ互換性**: TypeScriptはJavaScriptにトランスパイルされるため、すべてのモダンブラウザで動作する
+- **保守性**: 型情報により複雑なゲーム状態の管理が容易になる
+
+## 結果
+
+### 良い結果
+- 型による安全性の向上(ぷよの状態、座標、色などの管理が安全)
+- 開発効率の向上(IDEサポートによる開発支援)
+- テスト駆動開発の実践が容易
+- 複雑なゲームロジックの実装における安全性
+
+### 悪い結果
+- ビルドプロセスが必要
+- 学習コストが発生する可能性
\ No newline at end of file
diff --git a/docs/adr/0002-adopt-vitest.md b/docs/adr/0002-adopt-vitest.md
new file mode 100644
index 0000000..3025273
--- /dev/null
+++ b/docs/adr/0002-adopt-vitest.md
@@ -0,0 +1,42 @@
+# ADR-0002: Vitestの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+TypeScriptプロジェクトにおいてテスト駆動開発を実践するため、適切なテスティングフレームワークを選定する必要がある。
+ぷよぷよゲームのような複雑なゲームロジック(連鎖処理、消去判定、スコア計算等)を安全に実装するために、効果的なテスト環境が必要。
+
+選定にあたっての要件:
+- TypeScriptとの親和性
+- 高速なテスト実行(TDDサイクルの高速化)
+- 使いやすいAPI
+- ウォッチモードのサポート
+- ゲームロジックのテストに適した機能
+
+## 決定
+
+Vitestをテスティングフレームワークとして採用する。
+
+## 理由
+
+- **高速**: Viteベースで動作し、高速なテスト実行が可能。TDDのRed-Green-Refactorサイクルを高速で回せる
+- **TypeScript対応**: TypeScriptを標準でサポートし、追加設定が最小限
+- **Jest互換**: Jest互換のAPIを提供し、学習コストが低い
+- **ウォッチモード**: ファイル変更を検知して自動的にテストを再実行。連続的な開発に適している
+- **ESM対応**: ES Modulesを標準でサポート
+- **ゲームテスト対応**: モック機能やスパイ機能により、ゲーム状態やイベントのテストが容易
+
+## 結果
+
+### 良い結果
+- テスト実行速度の向上によるTDDサイクルの高速化
+- 開発体験の向上
+- 設定の簡素化
+- ゲームロジックの安全な実装
+
+### 悪い結果
+- Jestからの移行が必要な場合がある
+- 比較的新しいツールのため、一部のエコシステムが未成熟な可能性
\ No newline at end of file
diff --git a/docs/adr/0003-adopt-canvas-api.md b/docs/adr/0003-adopt-canvas-api.md
new file mode 100644
index 0000000..ea488ed
--- /dev/null
+++ b/docs/adr/0003-adopt-canvas-api.md
@@ -0,0 +1,45 @@
+# ADR-0003: Canvas APIの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+ぷよぷよゲームの描画システムを実装するにあたり、適切な描画技術を選定する必要がある。
+ゲームでは以下の描画要件がある:
+
+考慮すべき要件:
+- 2Dグラフィックスの描画(ぷよ、フィールド、スコア表示)
+- アニメーション処理(落下、消去、連鎖エフェクト)
+- パフォーマンス(60FPSでの滑らかな描画)
+- ブラウザ互換性
+- 学習コスト
+- ゲームに必要な基本図形描画(矩形、円、テキスト)
+
+## 決定
+
+HTML5 Canvas APIを描画システムとして採用する。
+
+## 理由
+
+- **2Dグラフィックス**: ぷよぷよゲームに必要な2D描画機能(矩形、円、テキスト描画)が十分に提供されている
+- **パフォーマンス**: ハードウェアアクセラレーションにより高速な描画が可能で、60FPSのゲーム描画に適している
+- **標準技術**: 追加のライブラリなしで使用可能な標準Web API
+- **ブラウザサポート**: すべてのモダンブラウザでサポートされている
+- **シンプル**: 学習コストが低く、実装がシンプル
+- **ゲーム向け機能**: フレームバッファ、座標変換、色彩管理などゲーム描画に必要な機能が揃っている
+- **デバッグ容易性**: ブラウザ開発者ツールでの描画処理の確認が可能
+
+## 結果
+
+### 良い結果
+- 外部依存がない
+- 高速な描画パフォーマンス
+- 実装の透明性
+- ぷよゲームに必要な基本図形描画の実装が容易
+
+### 悪い結果
+- 低レベルAPIのため、ゲームエンジンに比べて実装量が多い
+- 複雑なアニメーションには追加の実装が必要
+- 画像リソース管理は自前で実装する必要がある
\ No newline at end of file
diff --git a/docs/adr/0004-adopt-tdd-approach.md b/docs/adr/0004-adopt-tdd-approach.md
new file mode 100644
index 0000000..3e571c1
--- /dev/null
+++ b/docs/adr/0004-adopt-tdd-approach.md
@@ -0,0 +1,43 @@
+# ADR-0004: テスト駆動開発(TDD)アプローチの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+ぷよぷよゲームの開発において、複雑なゲームロジック(ぷよの移動、回転、消去判定、連鎖処理、スコア計算)を安全かつ効率的に実装する必要がある。
+従来の開発手法では以下の課題がある:
+
+- ゲームロジックの複雑性により、バグの混入リスクが高い
+- 連鎖処理などの複雑な処理の正確性を保証するのが困難
+- 後からのリファクタリングや機能追加の安全性が低い
+- デバッグに時間がかかる
+
+## 決定
+
+テスト駆動開発(TDD)アプローチを開発手法として採用する。
+
+## 理由
+
+- **品質保証**: Red-Green-Refactorサイクルにより、すべての機能が必ずテストされ、高品質なコードが保証される
+- **設計改善**: テストファーストにより、テスタブルで結合度の低い設計になる
+- **安全なリファクタリング**: 包括的なテストスイートにより、リファクタリングが安全に実行できる
+- **ドキュメント効果**: テストコードが実行可能な仕様書として機能する
+- **複雑なロジックの理解**: 連鎖処理やスコア計算などの複雑なロジックをテストケースで明確化できる
+- **デバッグ効率**: 問題が発生した際に、テストにより問題箇所を特定しやすい
+- **継続的改善**: 各イテレーションでの安全な機能追加が可能
+
+## 結果
+
+### 良い結果
+- ゲームロジックの正確性保証
+- 安全なリファクタリングによるコード品質向上
+- テストコードによる仕様の明確化
+- バグの早期発見と修正
+- 継続的な機能追加の安全性
+
+### 悪い結果
+- 開発初期の時間投資が必要
+- テストコードの記述・維持コストが発生
+- 学習コストが発生する可能性
\ No newline at end of file
diff --git a/docs/adr/0005-adopt-github-actions.md b/docs/adr/0005-adopt-github-actions.md
new file mode 100644
index 0000000..3038a7c
--- /dev/null
+++ b/docs/adr/0005-adopt-github-actions.md
@@ -0,0 +1,44 @@
+# ADR-0005: GitHub Actionsの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+継続的インテグレーション(CI)とデプロイメント(CD)の環境を構築する必要がある。
+以下の要件を満たす必要がある:
+
+- 自動化されたテスト実行
+- ビルドプロセスの自動化
+- コード品質チェック(リント、フォーマット)
+- 自動デプロイメント
+- GitHubとの統合
+- 学習コストと運用コスト
+
+## 決定
+
+GitHub Actionsを CI/CD プラットフォームとして採用する。
+
+## 理由
+
+- **GitHub統合**: GitHubリポジトリとネイティブに統合されており、設定が簡潔
+- **無料プラン**: パブリックリポジトリでは無料で利用可能
+- **豊富なアクション**: npmパッケージのインストール、テスト実行、デプロイなど、必要なアクションが充実
+- **設定の簡単さ**: YAMLファイルによる設定で、学習コストが低い
+- **スケーラビリティ**: 必要に応じてワークフローを拡張可能
+- **Node.js対応**: TypeScript/Node.jsプロジェクトに最適化されたアクションが利用可能
+- **並列実行**: テストとビルドを並列実行して高速化が可能
+
+## 結果
+
+### 良い結果
+- 自動化されたテスト実行による品質保証
+- 手動デプロイの削減によるヒューマンエラー防止
+- GitHub統合による開発フローの統一
+- 開発効率の向上
+
+### 悪い結果
+- GitHub依存が発生
+- 複雑なワークフローでは設定が煩雑になる可能性
+- ビルド時間による開発速度への影響
\ No newline at end of file
diff --git a/docs/adr/0006-adopt-vercel.md b/docs/adr/0006-adopt-vercel.md
new file mode 100644
index 0000000..f2c5269
--- /dev/null
+++ b/docs/adr/0006-adopt-vercel.md
@@ -0,0 +1,46 @@
+# ADR-0006: Vercelの採用
+
+## ステータス
+
+承認済み
+
+## コンテキスト
+
+ぷよぷよゲームアプリケーションをプロダクション環境にデプロイするため、適切なホスティングプラットフォームを選定する必要がある。
+
+選定にあたっての要件:
+- 静的サイトホスティング(TypeScriptビルド後のHTML/CSS/JS)
+- 高速なデプロイメント
+- 自動デプロイ(GitHub連携)
+- 無料または低コスト
+- グローバルCDN
+- HTTPS対応
+- カスタムドメイン対応
+
+## 決定
+
+Vercelをホスティングプラットフォームとして採用する。
+
+## 理由
+
+- **フロントエンド特化**: 静的サイトとSPAに最適化されたプラットフォーム
+- **GitHub統合**: GitHubと連携した自動デプロイが可能
+- **高速デプロイ**: 数秒から数分での高速デプロイメント
+- **グローバルCDN**: 世界各地のエッジサーバーによる高速配信
+- **無料プラン**: 個人プロジェクトに適した無料プランが利用可能
+- **HTTPS標準**: 自動的にHTTPS化される
+- **プレビューデプロイ**: プルリクエストごとのプレビュー環境が自動作成される
+- **TypeScript対応**: TypeScriptプロジェクトのビルドとデプロイが標準サポート
+
+## 結果
+
+### 良い結果
+- 自動デプロイによる運用効率化
+- グローバルCDNによる高速なゲーム配信
+- プレビューデプロイによる安全な機能検証
+- 運用コストの削減
+
+### 悪い結果
+- Vercel依存が発生
+- 複雑なサーバーサイド処理には不向き(今回は該当なし)
+- トラフィック制限あり(無料プランの場合)
\ No newline at end of file
diff --git a/docs/adr/index.md b/docs/adr/index.md
new file mode 100644
index 0000000..cb73fbd
--- /dev/null
+++ b/docs/adr/index.md
@@ -0,0 +1,58 @@
+# アーキテクチャ決定記録(ADR)
+
+このディレクトリには、ぷよぷよゲーム開発プロジェクトにおける重要な技術的決定事項を記録したアーキテクチャ決定記録(Architecture Decision Records)を保存しています。
+
+## ADR一覧
+
+| ADR | タイトル | ステータス | 決定日 |
+|-----|----------|------------|--------|
+| [ADR-0001](0001-adopt-typescript.md) | TypeScriptの採用 | 承認済み | 2025-08-05 |
+| [ADR-0002](0002-adopt-vitest.md) | Vitestの採用 | 承認済み | 2025-08-05 |
+| [ADR-0003](0003-adopt-canvas-api.md) | Canvas APIの採用 | 承認済み | 2025-08-05 |
+| [ADR-0004](0004-adopt-tdd-approach.md) | テスト駆動開発アプローチの採用 | 承認済み | 2025-08-05 |
+| [ADR-0005](0005-adopt-github-actions.md) | GitHub Actionsの採用 | 承認済み | 2025-08-05 |
+| [ADR-0006](0006-adopt-vercel.md) | Vercelの採用 | 承認済み | 2025-08-05 |
+
+## 技術スタック概要
+
+### フロントエンド
+- **言語**: TypeScript
+- **描画**: HTML5 Canvas API
+- **テスト**: Vitest
+- **開発手法**: テスト駆動開発(TDD)
+
+### CI/CD
+- **CI**: GitHub Actions
+- **ホスティング**: Vercel
+
+### 開発プロセス
+- テスト駆動開発によるイテレーション開発
+- GitHub Actionsによる自動テスト・ビルド・デプロイ
+- Vercelによる継続的デリバリー
+
+## ADRテンプレート
+
+新しいADRを作成する際は、以下の構造に従ってください:
+
+```markdown
+# ADR-XXXX: [決定事項のタイトル]
+
+## ステータス
+[提案中/承認済み/廃止/置換済み]
+
+## コンテキスト
+[決定が必要になった背景や課題]
+
+## 決定
+[実際に行った決定]
+
+## 理由
+[決定の理由と根拠]
+
+## 結果
+### 良い結果
+[期待される良い結果]
+
+### 悪い結果
+[予想される制約や問題]
+```
\ No newline at end of file
diff --git a/docs/design/index.md b/docs/design/index.md
new file mode 100644
index 0000000..ed8e5a5
--- /dev/null
+++ b/docs/design/index.md
@@ -0,0 +1,136 @@
+# 設計ドキュメント
+
+## 概要
+
+このディレクトリには、ぷよぷよゲーム(Case3)の設計に関するドキュメントを格納しています。システムの構造、データモデル、ユーザーインターフェース、テスト戦略など、開発に必要な設計情報を体系的に整理しています。
+
+## 設計ドキュメント一覧
+
+### システム設計
+
+| ドキュメント | 概要 | 対象読者 |
+|--------------|------|----------|
+| [データモデル設計](データモデル設計.md) | エンティティ、値オブジェクト、データフローの設計 | 開発者、アーキテクト |
+| [アーキテクチャ設計](アーキテクチャ設計.md) | レイヤードアーキテクチャとコンポーネント設計 | アーキテクト、リードエンジニア |
+| [ドメインモデル設計](ドメインモデル設計.md) | DDD原則に基づくドメイン設計 | ドメインエキスパート、開発者 |
+
+### ユーザー体験設計
+
+| ドキュメント | 概要 | 対象読者 |
+|--------------|------|----------|
+| [ユーザーインターフェース設計](ユーザーインターフェース設計.md) | UI/UXデザイン、レスポンシブ対応 | UI/UXデザイナー、フロントエンド開発者 |
+
+### 品質保証設計
+
+| ドキュメント | 概要 | 対象読者 |
+|--------------|------|----------|
+| [テスト戦略](テスト戦略.md) | TDD、テストピラミッド、品質保証戦略 | QAエンジニア、開発者全員 |
+
+## 設計原則
+
+### 1. 関心の分離
+- 各設計ドキュメントは明確な責任範囲を持つ
+- レイヤー間の依存関係を最小化
+- 変更影響範囲の局所化
+
+### 2. 拡張性
+- 新機能追加に対する柔軟性
+- プラットフォーム対応の余地
+- 国際化・アクセシビリティ対応
+
+### 3. 保守性
+- 理解しやすい設計
+- テスタブルな構造
+- ドキュメント化された決定プロセス
+
+## 設計の関連性
+
+<img src="data:image/svg+xml;base64,PGgxPkJhZCBNZXNzYWdlIDQxNDwvaDE+PHByZT5yZWFzb246IFVSSSBUb28gTG9uZzwvcHJlPg==" class="uml" alt="uml diagram" title="" />

## コミット: 8ad12a1

### メッセージ
docs: add CLAUDE.md with development guidelines and process diagrams
### 変更されたファイル

- A CLAUDE.md

### 変更内容

```diff
commit 8ad12a1266ec69b4a9cfd2519d1c76cb670094f7
Author: k2works <kakimomokuri@gmail.com>
Date:   Tue Aug 5 13:15:22 2025 +0900

    docs: add CLAUDE.md with development guidelines and process diagrams

diff --git a/CLAUDE.md b/CLAUDE.md
new file mode 100644
index 0000000..901a7c9
--- /dev/null
+++ b/CLAUDE.md
@@ -0,0 +1,149 @@
+\# CLAUDE.md
+
+ここで**必ず**と指示されていることは絶対に実施してください
+
+日本語で回答してください
+
+あなたは**よいソフトウェア**に対する明確な考えと\*\*よいソフトウェア\*\*を作るための規律を持った開発経験豊富な開発者です。
+
+よいソフトウェアについては @docs/reference/よいソフトウェアとは.md を参照してください。
+
+よいソフトウェアについての考えと規律と経験に関する知見は @docs/reference 内を参照してください。
+
+あなたは @docs/reference/開発ガイド.md に従いソフトウェア開発を手段として問題解決に取り組みます。
+
+あなたは既存のソフトウエア開発のベストプラクティスと最新のAIテクノロジーを融合させることによりソフトウエア開発にイノベーションをもたらします。
+
+<img src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentStyleType="text/css" height="265px" preserveAspectRatio="none" style="width:533px;height:265px;background:#000000;" version="1.1" viewBox="0 0 533 265" width="533px" zoomAndPan="magnify"><defs/><g><rect fill="#010E20" height="1" style="stroke:#010E20;stroke-width:1;" width="1" x="0" y="0"/><rect fill="#FFFFFF" height="73" style="stroke:#FFFFFF;stroke-width:1;" width="532" x="0" y="0"/><image height="53" width="450" x="1" xlink:href="data:image/png;base64,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" y="10"/><image height="62" width="62" x="450" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAD4AAAA+CAYAAABzwahEAAACp0lEQVR4Xu3SQapbQQxEUe9/08nk9+SQi9S2AyH2hRqoqqR+Bj9+fSgPjU/h+8M/je8P/zTyhz8ej6dU+7e4572tikw8sFXt3+Ke97YqMpkW5bZ/WH/okMvUz2RalNv+4Z//4X5g5TXrTxJ9+5UXmbjoA5XXrD9J9O1XXmTiog9U7jz5qjB3r/IiExd9oHLnyVeFuXuVF5m46AOVO5emnujbr7zIxEUfqNy5NPVE337lRSbTolS/fLE3zRNTP5NpUapfvtib5ompn8lZvJX7755vVWTiga3cf/d8q6KTN1EfUP5hyl/l713+oX5A+Ycpf5W87F9Gib7z1i+JuT1nycSDSvSdt35JzO05Sya1WA+ZPzs/6x+m/JCNOnD8KX92ftY/TPlhbvzgwdtZv/KD+TTfst70odtZv/KD+TTfMm76wLMfrl+asHe7fxibHtw+VLn7asLe7f4hmx6cDpvXnr652FNTr8jEA+Oh4UPKNxd7auoVnUAd0vdhte1tVYy5RlGH9P0wte1tVYy5hnigZjVhz3nC/vX7GuKhmtWEPecJ+9fvaxw8sD1cefkH729VjLnGwcVXHyz/4P2tijHXmKiHJ38767+qopOgDk/+dtZ/VUUnL+LDftBWhfk0Sycv4sP+oK0K82mWTPyArQpzZzHfzqrIxANbFebOYr6dVZHJtCjVX3/IHz5605fyJRvbA4fq3/4QVVRevmTDA35Q5bL1a96q9opMXPRg5bL1a96q9opMXPRg5c7lF+bTnUlFJi56sHLn8gvz6c6kIhMXPVh5zVvffPKd9YtseMDDlde89c0n31m/yMb2wMH+di5VT7/miWxeHxo+pOZS9fRrnsimD27l/kTtF/YnFZl4YCv3J2q/sD+p6OQ/5/vDP43vD/80PvaH/waCbp3NtVew5gAAAABJRU5ErkJggg==" y="5.5"/><rect fill="#000000" height="118.4531" style="stroke:#000000;stroke-width:1;" width="532" x="0" y="73"/><text fill="#33FF02" font-family="sans-serif" font-size="12" font-style="italic" font-weight="bold" lengthAdjust="spacing" textLength="128.0098" x="5" y="90">PlantUML 1.2025.4</text><rect fill="#33FF02" height="21.2969" style="stroke:#33FF02;stroke-width:1;" width="173.2813" x="5" y="99.9688"/><text fill="#000000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="171.2813" x="6" y="114.9688">[From string (line 2) ]</text><text fill="#33FF02" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="4.874" x="5" y="135.2656">&#160;</text><text fill="#33FF02" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="81.4229" x="5" y="151.5625">@startuml</text><text fill="#33FF02" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" text-decoration="wavy underline" textLength="11.7305" x="5" y="167.8594">+</text><text fill="#FF0000" font-family="sans-serif" font-size="14" font-weight="bold" lengthAdjust="spacing" textLength="392.335" x="9.874" y="184.1563">Syntax Error? (Assumed diagram type: sequence)</text><rect fill="#FFFFFF" height="73" style="stroke:#FFFFFF;stroke-width:1;" width="532" x="0" y="191.4531"/><image height="53" width="450" x="1" xlink:href="data:image/png;base64,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" y="201.4531"/><image height="62" width="62" x="450" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAD4AAAA+CAYAAABzwahEAAACp0lEQVR4Xu3SQapbQQxEUe9/08nk9+SQi9S2AyH2hRqoqqR+Bj9+fSgPjU/h+8M/je8P/zTyhz8ej6dU+7e4572tikw8sFXt3+Ke97YqMpkW5bZ/WH/okMvUz2RalNv+4Z//4X5g5TXrTxJ9+5UXmbjoA5XXrD9J9O1XXmTiog9U7jz5qjB3r/IiExd9oHLnyVeFuXuVF5m46AOVO5emnujbr7zIxEUfqNy5NPVE337lRSbTolS/fLE3zRNTP5NpUapfvtib5ompn8lZvJX7755vVWTiga3cf/d8q6KTN1EfUP5hyl/l713+oX5A+Ycpf5W87F9Gib7z1i+JuT1nycSDSvSdt35JzO05Sya1WA+ZPzs/6x+m/JCNOnD8KX92ftY/TPlhbvzgwdtZv/KD+TTfst70odtZv/KD+TTfMm76wLMfrl+asHe7fxibHtw+VLn7asLe7f4hmx6cDpvXnr652FNTr8jEA+Oh4UPKNxd7auoVnUAd0vdhte1tVYy5RlGH9P0wte1tVYy5hnigZjVhz3nC/vX7GuKhmtWEPecJ+9fvaxw8sD1cefkH729VjLnGwcVXHyz/4P2tijHXmKiHJ38767+qopOgDk/+dtZ/VUUnL+LDftBWhfk0Sycv4sP+oK0K82mWTPyArQpzZzHfzqrIxANbFebOYr6dVZHJtCjVX3/IHz5605fyJRvbA4fq3/4QVVRevmTDA35Q5bL1a96q9opMXPRg5bL1a96q9opMXPRg5c7lF+bTnUlFJi56sHLn8gvz6c6kIhMXPVh5zVvffPKd9YtseMDDlde89c0n31m/yMb2wMH+di5VT7/miWxeHxo+pOZS9fRrnsimD27l/kTtF/YnFZl4YCv3J2q/sD+p6OQ/5/vDP43vD/80PvaH/waCbp3NtVew5gAAAABJRU5ErkJggg==" y="196.9531"/><!--SRC=[lLVTJzjM57_FNt6bl8HPF9J78AsQD6aFUq2QzZPD8WK78faaSXnjrJGfrmQQ3r1HAR0EseoF4Y35mD9H2cJvOsxiE4_z5tRElNRYX1Z2oYP5iNs-pxc_StmiXIGjeIaoQQ-NMgykcR71Z6EcNp7z8wDcgtXkBvJQz4EhScLjra9IIFhXYn_9wEYNnDcdpQlpa2Ikd2HCT4bgOcPMGpejjLuUX2Hn9QEA7DTy5eHQ87c00PylFsbXkLKtkwHi6eXsfTGwAOGaSHqeXpJ82fFBQ35DTYCWOLMUzaYkUbX9pCapgYmdFOPh99nIOyaPkKCLiOVJMJMjTAdSCHg1kZnHiZAwd9oSn4iut4cSqz9ABAbbvnHyx1QT6KVyTmt7qutNJoM_X2H2xCkSSrwpNs-3mKTHykawpunzBd0kn9YHnnkXbQFDotpBt80RPEbdJBzWnbikK1svOGyZyRlac3baHeqP9VpNJr7bTWcUJO_LaFIhBoDzZncBp7Z7zJymem9g8hLxsXth3t_iWSin9WvcKC01XHbET70czr7sMeGGNoinOutfkpmNoenTHfUSHjqg_i4eq9SOBOkM5vKUIlHce2JgroqmOuKP1jDFFiVees2Z73SzFU3hQ7-3UGMvhS46rTSvoBTUNe6FOAPRsq1GDUjRTdu5mxn3fCSG1n-_wTVlvxZ1rxYrPxnAY0D63p1YxWZZt-4wnvns8ax0EJY658RKlutlcWXqWS4_uym6CtRuVVM1dGVOHyy0c6r-VhN_p7cWYo7r_SZWLZ2HQmxwYZZhRZh3oZvSTe6870OK0uSMFAwAkHhGMdwHVzcTDqpqZuLHOZKM6FrzeBQr_5kplinenLsEz1VEDioeHQvMUcqNIenMxNVRi2aDzawhxToVZFxDw16Zys8CXUyyZxxvT6DOmJjIrK9IDEXGne7t_SJN4pXNkCaEEIIfSbgEQJY9kKYRNjZ5Dvn3I9S7N6llp5xRw4JbZfd8T_BqoBWhOc_bhDFdbbbsTXT8v1jSYpeyFjC0ZTiu1H2SH-wR2Ip4OrDQIks8MglKgHtXg43iuantEOauYGZcnBUFHuWsAoT9vAcS6H5iz8ALBAEIaNULP2KZaqWorHLgDapxUDTZ9wSJyMwovAVP12o_4Qo5PIurBnSVZtJBv76jXOD-WUYTSCDJOFGlfXSP1PpauMOSpowLxWEWFmb6JmGUkJyFVb1YUxtEw2kcbsvgc5O1XAf2JzIhjNFf72q3NdiriG01scGocPuZQZP9D3cZJHAXo-6-mUX-1mVmmaPh5BuEzjivQ1j8RHNXgxzmdTx7bv983l3bjaS1VDbhxwtwZhSSx4CJVQR7U4gTY_tFFfza4yhqW982KAgko_oALImBem6U-hp0gmPRvOgZxm9WyrLo9gl4L3wARf4pxKtuNxRNFs8uptKdPq2ilUd40VfHOg-VseTbnm3qc697w_0JF-CojWBjB7hBOqodfZ9H_YR41U0jTrvpQx9Ni3VVUu8PxQaYkmlT8I_y6pTUVPu7M-P97FCPQdeR8ipGGxwKTyxAj4fhC9aG_VMpThd1AukZjjUTwewSA0aQI_oJe9iGX25ozrnNeCB2ygVhWcSMEmLDUgtXYylLq-Tx2pGrcr9vtjxH-p-tzNbdTyigGZtcnRU6hsnYVtK_WqFIFm00]--></g></svg>" class="uml" alt="uml diagram" title="" />

## コミット: b2b3e12

### メッセージ
docs: add architecture decision records and update documentation structure ```

変更されたファイル

  • A docs/reference/case-2/CLAUDE.local.md
  • A docs/reference/case-2/adr/.gitkeep
  • A docs/reference/case-2/adr/0001-adopt-typescript.md
  • A docs/reference/case-2/adr/0002-adopt-vitest.md
  • A docs/reference/case-2/adr/0003-adopt-canvas-api.md
  • A docs/reference/case-2/adr/0004-adopt-tdd-approach.md
  • A docs/reference/case-2/adr/0005-adopt-github-actions.md
  • A docs/reference/case-2/adr/0006-adopt-vercel.md
  • A docs/reference/case-2/adr/index.md
  • A docs/reference/case-2/development/.gitkeep
  • A docs/reference/case-2/development/index.md
  • A "docs/reference/case-2/development/\343\202\242\343\203\274\343\202\255\343\203\206\343\202\257\343\203\201\343\203\243.md"
  • A "docs/reference/case-2/development/\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.md"
  • A "docs/reference/case-2/development/\343\203\207\343\203\274\343\202\277\343\203\242\343\203\207\343\203\253\350\250\255\350\250\210.md"
  • A "docs/reference/case-2/development/\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.md"
  • A "docs/reference/case-2/development/\343\203\246\343\203\274\343\202\266\343\203\274\343\202\244\343\203\263\343\202\277\343\203\274\343\203\225\343\202\247\343\203\274\343\202\271\350\250\255\350\250\210.md"
  • A "docs/reference/case-2/development/\345\256\237\350\243\205.md"
  • A "docs/reference/case-2/development/\350\250\255\350\250\210.md"
  • A "docs/reference/case-2/development/\351\226\213\347\231\272\350\250\210\347\224\273.md"
  • A docs/reference/case-2/index.md
  • A docs/reference/case-2/journal/20250731.md
  • A docs/reference/case-2/journal/20250802.md
  • A docs/reference/case-2/journal/20250804.md
  • A docs/reference/case-2/journal/20250805.md
  • A docs/reference/case-2/journal/index.md
  • A docs/reference/case-2/operation/.gitkeep
  • A "docs/reference/case-2/operation/MkDocs_GitHub_Actions\350\250\255\345\256\232.md"
  • A "docs/reference/case-2/operation/ci-cd\350\250\255\345\256\232.md"
  • A docs/reference/case-2/operation/index.md
  • A "docs/reference/case-2/operation/\343\202\273\343\203\203\343\203\210\343\202\242\343\203\203\343\203\227.md"
  • A docs/reference/case-2/reference/.gitkeep
  • A "docs/reference/case-2/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"
  • A "docs/reference/case-2/reference/\343\202\242\343\202\270\343\203\243\343\202\244\343\203\253\343\201\252\350\246\213\347\251\215\343\201\250\350\250\210\347\224\273\343\201\245\343\201\217\343\202\212.md"
  • A "docs/reference/case-2/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"
  • A "docs/reference/case-2/reference/\343\203\206\343\202\271\343\203\210\351\247\206\345\213\225\351\226\213\347\231\272\343\201\213\343\202\211\345\247\213\343\202\201\343\202\213TypeScript\345\205\245\351\226\2001.md"
  • A "docs/reference/case-2/reference/\343\203\206\343\202\271\343\203\210\351\247\206\345\213\225\351\226\213\347\231\272\343\201\213\343\202\211\345\247\213\343\202\201\343\202\213TypeScript\345\205\245\351\226\2002.md"
  • A "docs/reference/case-2/reference/\343\203\206\343\202\271\343\203\210\351\247\206\345\213\225\351\226\213\347\231\272\343\201\213\343\202\211\345\247\213\343\202\201\343\202\213TypeScript\345\205\245\351\226\2003.md"
  • A "docs/reference/case-2/reference/\351\226\213\347\231\272\343\202\254\343\202\244\343\203\211.md"
  • A docs/reference/case-2/report/index.md
  • A "docs/reference/case-2/report/\350\251\225\344\276\241\343\203\254\343\203\235\343\203\274\343\203\210.md"
  • A docs/reference/case-2/requirements/.gitkeep
  • A docs/reference/case-2/requirements/index.md
  • A "docs/reference/case-2/requirements/\350\246\201\344\273\266.md"
  • A docs/reference/case-2/template/ADR.md
  • A docs/reference/case-2/template/README.md
  • M mkdocs.yml

変更内容

```diff commit b2b3e12a90eb21929ac5031aafa3005dd6c81e82 Author: k2works kakimomokuri@gmail.com Date: Tue Aug 5 11:50:31 2025 +0900

docs: add architecture decision records and update documentation structure

diff --git a/docs/reference/case-2/CLAUDE.local.md b/docs/reference/case-2/CLAUDE.local.md new file mode 100644 index 0000000..3eaab5f --- /dev/null +++ b/docs/reference/case-2/CLAUDE.local.md @@ -0,0 +1,570 @@ +# CLAUDE.local.md + +uml diagram