developit/mitt
 Watch   
 Star   
 Fork   
2023-07-05 01:31:06
mitt

3.0.1

What's Changed

New Contributors

Full Changelog: https://github.com/developit/mitt/compare/3.0.0...3.0.1

2021-06-24 04:46:36
mitt

3.0.0

Mitt 3.0 adds a couple nice new features.

1. Remove all handlers of a type:

Calling .off("type") with no handler argument now removes all listeners of that type (#123, #124, #129 - thanks @sealice!).

2. New, stronger typing:

It's now possible to define explicit types for events and their arguments (#114, thanks @iyegoroff & @deskoh):

import mitt from 'mitt';
const events = mitt<{ foo: string }>();
events.on('foo', e => {});  // `e` is inferred to be of type string!
events.emit('foo', 42);  // TypeError: got a number, expected a string

3. Package Exports:

As of 3.0.0, the mitt package now uses Package Exports. This shouldn't change usage or anything, it just means you're more likely to end up using the ES Module version of Mitt when running in Node.

2020-07-15 23:00:13
mitt

2.1.0

Mitt 2 is out of preview!

  • It's written in TypeScript and ships type definitions (#107, thanks again @jackfranklin!)

  • Event handlers are now stored in a Map instead of an Object.

    Upgrading: If you aren't passing an object to mitt({}), version 2 is backwards-compatible. If you were, turn your object into a map:

    -const handlers = {
    -  foo: [() => alert(1)]
    -};
    +const handlers = new Map();
    +handlers.set('foo', [() => alert(1)]);
    
    const events = mitt(handlers);
  • The event handler Map is now exposed as .all: (#105, thanks @jaylinski!)

    const events = mitt();
    events.on('foo', () => alert(1));
    events.on('bar', () => alert(2));
    
    // access handlers directly if needed:
    events.all.get('foo') // [() => alert(1)]
    
    // remove all event handlers:
    events.all.clear();
2020-05-28 01:42:51
mitt

2.0.1

This patch update for the 2.0 prerelease fixes missing type exports (#101). It also reduces size and improves performance (#100).

2020-05-27 06:43:49
mitt

2.0.0

Possible Breaking Change: mitt() previously accepted an optional Object "event map" argument. In 2.0.0, events are stored in an actual JavaScript Map rather than as properties on a plain object:

import mitt from 'mitt';
- const map = {};
+ const map = new Map();

const events = mitt(map);
const foo = () => {};
events.on('foo', foo);

- map.foo // [foo];
+ map.get('foo') // [foo];

Now the good news: if you weren't using this argument, mitt@2 isn't a breaking change for you.

Also, Mitt is now written in TypeScript! Huge thanks to @jackfranklin for doing all the work including setting up a much nicer build toolchain.

2019-10-22 00:53:47
mitt

1.2.0

It's Mitt's first release since 2017! That's the thing about a 200 byte library - there's not a lot of code here to necessitate constant updates. Take it as a sign of stability.

This release is primarily an improvement to the TypeScript definition we ship with Mitt:

  • You can now invoke mitt() with or without new in TypeScript (#60/#67 - thanks @davidkpiano)
  • .on('*', handler) now has types that pass the correct (event, data) arguments (#76, thanks @zbuttram)
  • The optional all parameter, which lets you pass your own mapping of handler Arrays to Mitt, now has correct types (#73, thanks @jesperzach)
2017-12-07 11:18:11
mitt

v1.1.3

  • Fix handler removal (.off()) during emit (#65, thanks @sqal & @farskid)
  • Fix emit and EventHandler type annotations (#47, thanks @rvikmanis)
  • more precise type annotation for WildCardEventHandler (#58, thanks @tungv)
2017-04-18 01:27:15
mitt

v1.1.2

  • Point jsnext:main entry to the ES Modules build instead of src, since src contains Flowtype annotations and a lot of comments.
2017-04-15 09:25:59
mitt

v1.1.1

  • Avoid unnecessarily creating listener arrays in off() if they don't exist (saves 4b)
2017-02-26 05:30:32
mitt

1.1.0

  • Refactor courtesy of @tunnckoCore
  • Event types have been corrected to be case-sensitive, as they are in Node's EventEmitter.