# EventBus: Events for Dart/Flutter
[data:image/s3,"s3://crabby-images/f6c82/f6c82b8bb4a9c741a0de2aea3cc80049ed9e844b" alt="pub package"](https://pub.dev/packages/event_bus_plus)
[data:image/s3,"s3://crabby-images/b32f2/b32f2cd4a65a3d9b70276f77e82172fa6e3400e4" alt="codecov"](https://codecov.io/gh/AndrewPiterov/event_bus_plus)
[data:image/s3,"s3://crabby-images/3d3f2/3d3f2fe9354da6862275147029805e56e0d79463" alt="Dart"](https://github.com/AndrewPiterov/event_bus_plus/actions/workflows/dart.yml)
**EventBus** is an open-source library for Dart and Flutter using the **publisher/subscriber** pattern for loose coupling. **EventBus** enables central communication to decoupled classes with just a few lines of code β simplifying the code, removing dependencies, and speeding up app development.
## Your benefits using EventBus: Itβ¦
- simplifies the communication between components;
- decouples event senders and receivers;
- performs well with UI artifacts (e.g. Widgets, Controllers);
- avoids complex and error-prone dependencies and life cycle issues.
### Define the app's events
```dart
// Initialize the Service Bus
IAppEventBus eventBus = AppEventBus();
// Define your app events
final event = FollowEvent('@devcraft.ninja');
final event = CommentEvent('Awesome package π');
```
### Subscribe
```dart
// listen the latest event
final sub = eventBus.last$
.listen((AppEvent event) { /*do something*/ });
// Listen particular event
final sub2 = eventBus.on()
.listen((e) { /*do something*/ });
```
### Publish
```dart
// fire the event
eventBus.fire(event);
```
### Watch events in progress
```dart
// start watch the event till its completion
eventBus.watch(event);
// and check the progress
eventBus.isInProgress();
// or listen stream to check the processing
eventBus.inProgress$.map((List events) =>
events.whereType().isNotEmpty);
// complete
_eventBus.complete(event);
// or complete with completion event
_eventBus.complete(event, nextEvent: SomeAnotherEvent);
```
## History
```dart
final events = eventBus.history;
```
## Mapping
```dart
final eventBus = bus = EventBus(
map: {
SomeEvent: [
(e) => SomeAnotherEvent(),
],
},
);
```
## Contributing
We accept the following contributions:
* Improving the documentation
* [Reporting issues](https://github.com/AndrewPiterov/event_bus_plus/issues/new)
* Fixing bugs
## Maintainers
* [Andrew Piterov](mailto:contact@andrewpiterov.com?subject=[GitHub]%20Source%20Dart%event_bus_plus)