buzz 0.1.1 copy "buzz: ^0.1.1" to clipboard
buzz: ^0.1.1 copied to clipboard

An opinionated scalable framework for modern mobile apps

Buzz #

Opinionated modern event-based application development framework.

Built on top of dart-event-bus.

Installation #

buzz: 0.1.0

Initialization #

Buzz.init(
  navigator: MyAppNavigator(),
  rootAppRoute: '/',
);

Learn more how to create the required instance of the Navigator component.

Fire Events #

By default the framework supports firing three base class events:

  • UiEvent
  • Command
    • NavigationCommand
  • AppEvent

Find pre-defined out-of-the-box supported events here.

UiEvents #

The library comes with a few pre-defined UiEvents you can find here.

For example, when a button/label is tapped:

ElevatedButton(
  onPressed: () {
    Buzz.fire(OnTapped());
  },
  child: Text('Tap me!'),
)

Commands #

TODO: Add

AppEvents #

TODO: Add

Listen Events #

Use the on method from the Buzz instance to get a Stream to listen events of a specific class type.

Here is how you can add a listener for NavigationCommand's:

Buzz.on<NavigationCommand>().listen((navigationCommand) {
  //TODO: Implement navigation command handler
  print(navigationCommand);
});

Customization #

Include the Buzz events dashboard #

First enable the withDebugDashboard flag from the init method:

Buzz.init(
  withDebugDashboard: true,
  navigator: MyAppNavigator(),
  rootAppRoute: '/',
);

Now you can use the EventsDashboardPage widget. Here is an example on how to declare a route when using Get:

GetPage(
  name: EventsDashboardPage.routeName,
  page: () => const EventsDashboardPage(),
  transition: Transition.fadeIn,
),

Finally, navigate to the events dashboard by running:

Buzz.fire(GoToBuzzEventsDashboard());

or add a custom button that fires the UiEvent already setup during library initialization:

Buzz.fire(GoToBuzzDashboardButtonTapped());

Upcoming Features #

  • Default navigator using Flutter Navigator 2.0 instead of Get.

Test Coverage #

brew install lcov
flutter test --coverage
genhtml coverage/lcov.info -o coverage/html
open coverage/html/index.html
0
likes
120
points
69
downloads

Publisher

unverified uploader

Weekly Downloads

An opinionated scalable framework for modern mobile apps

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

event_bus, flutter, get, google_fonts, neopop, rxdart

More

Packages that depend on buzz