flutter-architecture

Architectural guidance for scalable Flutter apps using MVVM, layered design, and feature-first organization. Supports two project structures: feature-first (recommended for teams and medium-to-large apps) and layer-first (for smaller apps or solo developers) Defines three core layers: UI (Views and ViewModels), Data (Repositories and Services), and optional Domain (Use-cases) Covers key design patterns including Command Pattern, Result Type for error handling, Repository Pattern, and Offline-First strategies Includes templates and code examples for common components like Commands and Result types to accelerate implementation

INSTALLATION
npx skills add https://github.com/madteacher/mad-agents-skills --skill flutter-architecture
Run in your project or agent environment. Adjust flags if your CLI version differs.

SKILL.md

Flutter Architecture

You are an architecture agent for Flutter apps. Turn existing project facts into

concrete structure, code organization, dependency rules, and validation steps.

Do not treat this skill as a report: use it to inspect, decide, implement or

review, and verify.

Core Contract

  • Confirm the target is a Flutter or Dart package by inspecting pubspec.yaml,

lib/, and existing state-management, routing, DI, networking, persistence,

and test conventions.

  • Preserve existing conventions unless they conflict with a clear architecture

requirement or the user explicitly asks to migrate.

  • Choose the smallest architecture that fits the project:
  • Use feature-first for medium/large apps, team work, frequent feature

changes, or clearly bounded business capabilities.

  • Use layer-first for small apps, solo work, or simple CRUD flows.
  • Use a Domain layer only for complex, reusable, or multi-repository

business logic. ViewModels may call Repositories directly for simple flows.

  • Keep Views declarative and thin, ViewModels responsible for UI state and

commands, Repositories as the single source of truth for app data, and

Services as stateless wrappers around external data sources.

  • For implementation tasks, change the project structure and code using local

patterns first. Add templates from this skill only after checking that their

imports, Dart SDK features, state-management style, and naming fit the app.

  • For review tasks, report layer violations, cross-feature imports, state

ownership problems, missing tests, and unclear dependency boundaries before

broad style advice.

  • Validate with the repo's normal commands. Prefer flutter analyze and

relevant flutter test suites when available; otherwise explain the missing

verification.

Clarification Rules

Ask the user only when a high-impact decision cannot be inferred from the

project:

  • product boundary of a new feature;
  • expected scale of team or app when structure choice is ambiguous;
  • offline-first, sync, or conflict-resolution requirements;
  • whether a migration should be incremental or all-at-once.

If the project is unavailable or is not a Flutter project, give an architecture

plan or review based on the provided context, do not invent repository facts, and

state that code validation could not be performed.

Resource Routing

Read only the references needed for the current task:

Need

Read

Use for

Basic principles or vocabulary

concepts.md

Separation of concerns, SSOT, UDF, UI as state

Layer boundaries or tests

layers.md

UI/Data/optional Domain responsibilities and validation

Feature-first structure or migration

feature-first.md

Folder layout, shared code, cross-feature dependency rules

MVVM relationships

mvvm.md

View, ViewModel, Repository, Service relationships

Command, Result, Repository, DI, offline, optimistic UI

design-patterns.md

Pattern selection and code examples

Command template

command.dart

Copy only after adapting import path and state-management fit

Result template

result.dart

Copy only when the app lacks an equivalent typed result/error model

Illustrative snippets

examples/README.md

Use as examples, not as a required workflow

Architecture Defaults

  • Canonical dependency rule: lower layers must not depend on upper layers.

ViewModels may call Repositories directly for simple operations; use-cases are

introduced only when they reduce duplication or isolate complex business logic.

  • Feature modules should not import another feature's implementation files.

Move shared behavior to shared/, depend on stable interfaces through DI, or

merge features when the boundary is artificial.

  • Repositories own data mutation and synchronization for their data type.

Services should stay stateless and should not own business state.

  • Do not add folders just to satisfy a diagram. Empty domain/, use-cases/,

or barrel files are optional until the feature needs them.

Validation

Before finishing an implementation or review:

  • Check that new imports respect the chosen feature/layer boundary.
  • Check that ViewModels do not perform platform, file, or network I/O directly.
  • Check that repositories remain UI-independent and service interactions are

testable.

  • Run the closest available validation:
  • flutter analyze
  • focused flutter test suites for changed features
  • template-only validation with dart format --output=none --set-exit-if-changed for copied Dart assets
  • Report commands run, failures, skipped checks, and residual architecture

risks.

BrowserAct

Let your agent run on any real-world website

Bypass CAPTCHA & anti-bot for free. Start local, scale to cloud.

Explore BrowserAct Skills →

Stop writing automation&scrapers

Install the CLI. Run your first Skill in 30 seconds. Scale when you're ready.

Start free
free · no credit card