Skillshub flutter-bloc-state-management
BLoC/Cubit state management standards. ALWAYS consult when writing, modifying, reviewing, or testing any BLoC, Cubit, state, or event Dart file — even for small changes. (triggers: **_bloc.dart, **_cubit.dart, **_state.dart, **_event.dart, BlocProvider, BlocBuilder, BlocListener, Cubit, Emitter)
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/flutter-bloc-state-management" ~/.claude/skills/comeonoliver-skillshub-flutter-bloc-state-management && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/flutter-bloc-state-management/SKILL.mdsource content
BLoC State Management
Priority: P0 (CRITICAL)
You are a Flutter State Management Expert. Design predictable, testable state flows.
State Design Workflow
- Define Events: What happens? (UserTap, ApiSuccess). Use
.@freezed - Define States: What needs to show? (Initial, Loading, Data, Error).
- Implement BLoC: Map Events to States using
.on<Event> - Connect UI: Use
for rebuilds,BlocBuilder
for side effects.BlocListener
Implementation Guidelines
- States & Events: Use @freezed for union types (e.g.,
,Initial
,Loading
,Success
states).Failure - Error Handling: Emit
states with a specific error message; never throw exceptions inFailure
.on<Event> - Async Data: Use emit.forEach for streams or await with
call.emit - Concurrency: Use transformer: restartable() from
for search/typeahead to debounce and cancel previous requests.bloc_concurrency - UI Connectivity: Use BlocBuilder for UI rebuilds (e.g., loading spinner, data list, error message) and BlocListener for side effects (navigation, snackbars).
- Testing: Use blocTest for ALL states and verify the sequence of emitted states.
Verification Checklist (Mandatory)
- Initial State: Defined and tested?
- Test Coverage:
used for ALL states?blocTest - UI Logic: No complex calculation in
?BlocBuilder - Side Effects: Navigation/Snackbars in
(NOT Builder)?BlocListener
Anti-Patterns
- No .then(): Use
orawait
to emit.emit.forEach() - No BLoC-to-BLoC: Use
orStreamSubscription
, not direct refs.BlocListener - No Logic in Builder: Move valid logic to BLoC.