Skip to content

Latest commit

 

History

History
72 lines (55 loc) · 2.9 KB

CHANGELOG.md

File metadata and controls

72 lines (55 loc) · 2.9 KB

V2.0.0

New features

Most new features are centered around better typings

EventDispatcher can be restricted to certain event classes

You can now pass a generic parameter to EventDispatcher indicating which type of events it will dispatch. Besides it serving as documentation to other developers about which events to expect, it also allows this library to add more useful typings to methods like addEventListener. Example:

class Scheduler extends EventDispatcher<SchedulerEvent> {

It is now easier to create event classes

Event classes can still be created by manually extending AbstractEvent. However, this is somewhat verbose. Moreover, it is very common to want to have some kind of data property on an event. This is now possible using 2 new utilities: createEventClass and createIsomorphicEventClass. See the readme for more info.

Event classes can have isomorphic data or options

Previously an event class was either fixed to a set of options and a certain type of data, or it was typed too loosely. It is now possible to have the options and the data depend on the event type.

Changes

Static string types on Event classes

Instead of the types being available directly on the class constructor, they are now nested in a types property:

foo.addEventListener(new SomeEvent(SomeEvent.types.FOO, ...));

Private fields

A lot of private fields have been changed to protected to allow for more extensibility

Removals

Removed CommonEvent and BasicEvent

As it is now very easy to create your own strongly typed event classes, it no longer makes sense to export generic classes. Instead, we should encourage the definition of classes tailored to your project.

Removed IEventDispatcher and IEvent

These interfaces contain a lot of duplication with their corresponding classes, and were slowing down development. Typing things like so will also remove the strong typing. The rationale behind it was that we theoretically could have EventDispatcher interact with a custom implementation with the same interface, but this is rarely to never done. When wanting some kind of custom functionality, it usually suffices to extend EventDispatcher and override the methods.

It's also worth mentioning that there was no advantage to IEvent at all, as AbstractEvent only has public members. This makes it possible to create a class that implements AbstractEvent.

Removed eventTypeUtils (like generateEventTypes)

Our new createEventClass utility has a better syntax

Testing

Tests are now implemented using Jest. Additional test have been added using dtslint, allowing us to do assertions on the types in the TypeScript compiler.

Compatibility

Requires at least TypeScript 3.1, for the mapped tuple type functionality.