bloc library Null safety

A predictable state management library for Dart.

Get started at 🚀


Bloc<Event, State>
Takes a Stream of Events as input and transforms them into a Stream of States as output.
An interface for the core functionality implemented by both Bloc and Cubit.
An interface for observing the behavior of Bloc instances.
This class facilitates overriding BlocObserver and EventTransformer. It should be extended by another class in client code with overrides that construct a custom implementation. The implementation in this class defaults to the base blocObserver and eventTransformer implementation. For example: [...]
A Change represents the change from one State to another. A Change consists of the currentState and nextState.
A Cubit is similar to Bloc but has no notion of events and relies on methods to emit new states. [...]
An Emitter is a class which is capable of emitting new states. [...]
Transition<Event, State>
A Transition is the change from one state to another. Consists of the currentState, an event, and the nextState.


EventHandler<Event, State> = FutureOr<void> Function(Event event, Emitter<State> emit)
An event handler is responsible for reacting to an incoming Event and can emit zero or more states via the Emitter.
EventMapper<Event> = Stream<Event> Function(Event event)
Signature for a function which converts an incoming event into an outbound stream of events. Used when defining custom EventTransformers.
EventTransformer<Event> = Stream<Event> Function(Stream<Event> events, EventMapper<Event> mapper)
Used to change how events are processed. By default events are processed concurrently.