kseo / event_kit

Simple library for implementing and consuming evented APIs

Home Page:https://pub.dartlang.org/packages/event_kit

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

event_kit

This is a simple library for implementing event subscription APIs. This project is inspired by event-kit.

Build Status Coverage Status

Implementing Event Subscription APIs

import 'package:event_kit/event_kit.dart';

class User {
  final Emitter<String> _emitter = new Emitter<String>();

  String _name = '';

  Disposable onDidChangeName(void handler(String name)) =>
      _emitter.on('did-change-name', handler);

  void set name(String name) {
    if (_name != name) {
      _name = name;
      _emitter.emit('did-change-name', [name]);
    }
  }
}

In the example above, we implement onDidChangeName on the user object, which will register callbacks to be invoked whenever the user's name changes. To do so, we make use of an internal Emitter instance. We use on to subscribe the given callback in onDidChangeName, and emit in setName to notify subscribers. Finally, when the User instance is destroyed we call dispose on the emitter to unsubscribe all subscribers.

Consuming Event Subscription APIs

Emitter.on returns a Disposable instance, which has a dispose method. To unsubscribe, simply call dispose on the returned object.

import 'package:event_kit/event_kit.dart';

var subscription = user.onDidChangeName((name) => print('My name is ${name}'));
// Later, to unsubscribe...
subscription.dispose();

You can also use CompositeDisposable to combine disposable instances together.

import 'package:event_kit/event_kit.dart';

var subscriptions = new CompositeDisposable();
subscriptions.add(user1.onDidChangeName((name) => print('User 1: ${name}')));
subscriptions.add(user2.onDidChangeName((name) => print('User 2: ${name}')));

// Later, to unsubscribe from *both*...
subscriptions.dispose();

Features and bugs

Please file feature requests and bugs at the issue tracker.

About

Simple library for implementing and consuming evented APIs

https://pub.dartlang.org/packages/event_kit

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:Dart 92.0%Language:Shell 8.0%