flutter-project-init
3
总安装量
2
周安装量
#56438
全站排名
安装命令
npx skills add https://github.com/vp-k/flutter-craft --skill flutter-project-init
Agent 安装分布
cursor
2
mcpjam
1
claude-code
1
junie
1
windsurf
1
zencoder
1
Skill 文档
Flutter Project Initialization
Use when: “new project”, “create project”, “start project”, “init flutter”
Workflow Overview
Step 1: Project Info â name, org, description
Step 2: Domain Pattern â Simple/Stateful/Categorized/Tracked/Relational/Custom
Step 3: Tech Stack â State Management, Features
Step 4: Generate & Verify â create, build, analyze
Step 1: Gather Project Info
Ask user for:
| Field | Example | Required |
|---|---|---|
| Project name | my_app (snake_case) |
Yes |
| Organization | com.example |
Yes |
| Description | “Task management app” | Yes |
| Entity name | Task, Note, Expense |
Yes |
Step 2: Domain Pattern Selection (CRUD 기ë°)
Ask user to choose:
| Pattern | Examples | Generated Structure |
|---|---|---|
| Simple | Note, Memo, Bookmark | ë¨ì¼ ìí°í° CRUD |
| Stateful | Todo, Task, Order | ìí íë í¬í¨ (ìë£/ì§íì¤ ë±) |
| Categorized | Expense, Product, Recipe | ì¹´í ê³ ë¦¬ ê´ê³ í¬í¨ |
| Tracked | Habit, Workout, Study | ìê°/ë ì§ ê¸°ë° í¸ëí¹ |
| Relational | Blog (User-Post-Comment) | ë¤ì¤ ìí°í° ê´ê³ |
| Custom | – | ì¬ì©ì ì ì íë |
Patternë³ ìì± ì½ë
Simple Pattern
// Entity
sealed class Note with _$Note {
const factory Note({
required String id,
required String title,
required String content,
required DateTime createdAt,
DateTime? updatedAt,
}) = _Note;
}
Stateful Pattern
// Entity with status
sealed class Task with _$Task {
const factory Task({
required String id,
required String title,
required String description,
(TaskStatus.pending) TaskStatus status,
required DateTime createdAt,
DateTime? completedAt,
}) = _Task;
}
enum TaskStatus { pending, inProgress, completed, cancelled }
Categorized Pattern
// Entity with category relation
sealed class Expense with _$Expense {
const factory Expense({
required String id,
required String title,
required double amount,
required String categoryId,
required DateTime date,
String? note,
}) = _Expense;
}
sealed class Category with _$Category {
const factory Category({
required String id,
required String name,
required String icon,
required String color,
}) = _Category;
}
Tracked Pattern
// Entity with time tracking
sealed class Habit with _$Habit {
const factory Habit({
required String id,
required String name,
required String description,
required HabitFrequency frequency,
required List<DateTime> completedDates,
required int currentStreak,
required int bestStreak,
required DateTime createdAt,
}) = _Habit;
}
enum HabitFrequency { daily, weekly, monthly }
Relational Pattern
// Multiple related entities
sealed class User with _$User {
const factory User({
required String id,
required String name,
required String email,
required DateTime createdAt,
}) = _User;
}
sealed class Post with _$Post {
const factory Post({
required String id,
required String authorId,
required String title,
required String content,
required DateTime createdAt,
(0) int likeCount,
}) = _Post;
}
sealed class Comment with _$Comment {
const factory Comment({
required String id,
required String postId,
required String authorId,
required String content,
required DateTime createdAt,
}) = _Comment;
}
Step 3: Tech Stack Selection
State Management (íì ì í)
| Option | Description |
|---|---|
| Riverpod (Recommended) | Modern, compile-safe, testable |
| BLoC | Event-driven, enterprise-grade |
Feature Presets
| Preset | Includes |
|---|---|
| Minimal | Core only (Freezed, Drift, DI) |
| Essential | + GoRouter, Dio, Error handling |
| Full | + Auth, Localization, Responsive |
Feature Details
# Minimal preset (always included)
flutter pub add freezed_annotation
flutter pub add drift
flutter pub add get_it
flutter pub add injectable
flutter pub add dev:freezed
flutter pub add dev:build_runner
flutter pub add dev:injectable_generator
flutter pub add dev:drift_dev
# Essential preset adds
flutter pub add go_router
flutter pub add dio
flutter pub add dartz # Either type for error handling
# Full preset adds
flutter pub add easy_localization
flutter pub add responsive_framework
flutter pub add firebase_auth # Optional
Step 4: Project Generation
4.1 Create Flutter Project
flutter create --org <org> --project-name <name> <name>
cd <name>
4.2 Setup Folder Structure
lib/
âââ core/
â âââ constants/
â â âââ app_constants.dart
â âââ database/
â â âââ app_database.dart
â âââ di/
â â âââ injection.dart
â âââ errors/
â â âââ exceptions.dart
â â âââ failures.dart
â âââ router/
â â âââ app_router.dart
â âââ theme/
â â âââ app_colors.dart
â â âââ app_theme.dart
â âââ utils/
â âââ extensions.dart
âââ features/
â âââ <entity>/
â âââ domain/
â â âââ entities/
â â â âââ <entity>.dart
â â âââ repositories/
â â â âââ <entity>_repository.dart
â â âââ usecases/
â â âââ create_<entity>.dart
â â âââ delete_<entity>.dart
â â âââ get_<entity>s.dart
â â âââ update_<entity>.dart
â âââ data/
â â âââ datasources/
â â â âââ <entity>_local_datasource.dart
â â âââ models/
â â â âââ <entity>_model.dart
â â âââ repositories/
â â âââ <entity>_repository_impl.dart
â âââ presentation/
â âââ bloc/ # or providers/
â â âââ <entity>_bloc.dart
â â âââ <entity>_event.dart
â â âââ <entity>_state.dart
â âââ pages/
â â âââ <entity>_list_page.dart
â â âââ <entity>_detail_page.dart
â âââ widgets/
â âââ <entity>_card.dart
âââ shared/
â âââ widgets/
â âââ loading_widget.dart
âââ main.dart
4.3 Generate Base Files
core/errors/failures.dart
import 'package:freezed_annotation/freezed_annotation.dart';
part 'failures.freezed.dart';
sealed class Failure with _$Failure {
const factory Failure.server({required String message, int? code}) = ServerFailure;
const factory Failure.cache({required String message}) = CacheFailure;
const factory Failure.network({('No internet connection') String message}) = NetworkFailure;
const factory Failure.validation({required String message}) = ValidationFailure;
}
core/database/app_database.dart
import 'dart:io';
import 'package:drift/drift.dart';
import 'package:drift/native.dart';
import 'package:path_provider/path_provider.dart';
import 'package:path/path.dart' as p;
part 'app_database.g.dart';
// Tables will be added per domain pattern
(tables: [])
class AppDatabase extends _$AppDatabase {
AppDatabase() : super(_openConnection());
int get schemaVersion => 1;
}
LazyDatabase _openConnection() {
return LazyDatabase(() async {
final dbFolder = await getApplicationDocumentsDirectory();
final file = File(p.join(dbFolder.path, 'app.db'));
return NativeDatabase.createInBackground(file);
});
}
core/di/injection.dart
import 'package:get_it/get_it.dart';
import 'package:injectable/injectable.dart';
import 'injection.config.dart';
final getIt = GetIt.instance;
(preferRelativeImports: true)
Future<void> configureDependencies() async => getIt.init();
4.4 Update pubspec.yaml
Based on selected preset, add all required dependencies.
4.5 Run Code Generation
flutter pub get
flutter pub run build_runner build --delete-conflicting-outputs
4.6 Validation (REQUIRED)
flutter analyze
Must pass with 0 errors. Info/warning level issues are acceptable.
If errors exist:
- Fix each error
- Re-run
flutter pub run build_runner build - Re-run
flutter analyze - Repeat until 0 errors
Step 5: Initialize Git
git init
git add .
git commit -m "Initial commit: <project_name> with Clean Architecture
- Domain pattern: <selected_pattern>
- State management: <Riverpod/BLoC>
- Features: <selected_preset>
ð¤ Generated with flutter-craft"
Completion Checklist
- Project created with correct name/org
- Folder structure matches Clean Architecture
- Domain entities generated with Freezed
- Database tables created in Drift
- DI configured with injectable
-
flutter pub getsuccessful -
flutter pub run build_runner buildsuccessful -
flutter analyzereturns 0 errors - Git initialized with initial commit
Output to User
After completion, inform:
â
Project '<name>' created successfully!
ð Structure: Clean Architecture
ð¦ Pattern: <selected_pattern>
ð State: <Riverpod/BLoC>
⨠Features: <preset>
Next steps:
1. cd <name>
2. flutter run
3. Use /brainstorm to plan your first feature
References
For detailed code templates per pattern, see:
references/simple-pattern.mdreferences/stateful-pattern.mdreferences/categorized-pattern.mdreferences/tracked-pattern.mdreferences/relational-pattern.md
Note: Custom í¨í´ì ì¬ì©ì ì ì íë를 ì§ì ì¤ê³íë¯ë¡ ë³ë í íë¦¿ì´ ììµëë¤.