--- name: dart-flutter-patterns description: 本番環境対応のDartおよびFlutterパターンは、null安全性、不変状態、非同期構成、ウィジェットアーキテクチャ、人気のある状態管理フレームワーク(BLoC、Riverpod、Provider)、GoRouterナビゲーション、Dioネットワーキング、Freezedコード生成、クリーンアーキテクチャをカバー。 origin: ECC --- # Dart/Flutterパターン ## 使用時期 次の場合にこのスキルを使用: - 新しいFlutter機能を開始し、状態管理、ナビゲーション、またはデータアクセスのイディオマティックパターンが必要 - Dartコードのレビューまたは作成とnull安全性、シール型、非同期構成のガイダンスが必要 - 新しいFlutterプロジェクトをセットアップしBLoC、Riverpod、またはProviderのうち選択 - 安全なHTTPクライアント、WebView統合、ローカルストレージを実装 - FlutterウィジェットEt、Cubit、またはRiverpodプロバイダーのテストを作成 - GoRouterを認証ガードでワイヤリング ## 動作方法 このスキルは、懸念事項で整理されたコピーペーストの準備ができたDart/Flutterコードパターンを提供: 1. **Null安全性** — `!`を避ける、`?.`/`??`/パターンマッチングを好む 2. **不変状態** — シール型、`freezed`、`copyWith` 3. **非同期構成** — 並行`Future.wait`、`await`後の安全な`BuildContext` 4. **ウィジェットアーキテクチャ** — クラスに抽出(メソッドではなく)、`const`伝播、スコープ付きリビルド 5. **状態管理** — BLoC/Cubityベント、Riverpodノーティファイアおよび派生プロバイダー 6. **ナビゲーション** — `refreshListenable`経由の反応型認証ガード付きGoRouter 7. **ネットワーキング** — インターセプタ付きDio、ワンタイム再試行ガード付きトークンリフレッシュ 8. **エラーハンドリング** — グローバルキャプチャ、`ErrorWidget.builder`、crashlyticsワイヤリング 9. **テスト** — ユニット(BLoC test)、ウィジェット(ProviderScopeオーバーライド)、モック上のフェイク ## 例 ```dart // シール状態 — 不可能な状態を防止 sealed class AsyncState {} final class Loading extends AsyncState {} final class Success extends AsyncState { final T data; const Success(this.data); } final class Failure extends AsyncState { final Object error; const Failure(this.error); } // 反応型認証リダイレクト付きGoRouter final router = GoRouter( refreshListenable: GoRouterRefreshStream(authCubit.stream), redirect: (context, state) { final authed = context.read().state is AuthAuthenticated; if (!authed && !state.matchedLocation.startsWith('/login')) return '/login'; return null; }, routes: [...], ); ``` 詳細については、ドキュメントを参照してください。