Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nohomey/event-listener-service
Universal Event Listener with testability built in
https://github.com/nohomey/event-listener-service
event-emiting eventlistener javascript nodejs test-driven-development testability
Last synced: 28 days ago
JSON representation
Universal Event Listener with testability built in
- Host: GitHub
- URL: https://github.com/nohomey/event-listener-service
- Owner: NoHomey
- License: mit
- Created: 2016-09-14T06:56:41.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-11-17T15:53:45.000Z (over 4 years ago)
- Last Synced: 2024-04-25T04:02:34.564Z (10 months ago)
- Topics: event-emiting, eventlistener, javascript, nodejs, test-driven-development, testability
- Language: TypeScript
- Homepage:
- Size: 13.7 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# event-listener-service
Universal Event Listener service with testability built in[data:image/s3,"s3://crabby-images/a000a/a000a3f2468d1d5b12c92ce8f2fbd1bb2f905bc0" alt="npm version"](https://badge.fury.io/js/event-listener-service)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="license"](https://github.com/NoHomey/event-listener-service)
[data:image/s3,"s3://crabby-images/cd1ee/cd1eed648ba408fa7f1b2244db06318c100c8281" alt="Build Status"](https://semaphoreci.com/nohomey/event-listener-service)
[data:image/s3,"s3://crabby-images/1abc2/1abc24cce5b6b40d98a7fcc4c8d676f379226716" alt="Code Climate"](https://codeclimate.com/github/NoHomey/event-listener-service)
[data:image/s3,"s3://crabby-images/5d90e/5d90e1749f3f4e0f0ed3b813f469f35a16b30d19" alt="Test Coverage"](https://codeclimate.com/github/NoHomey/event-listener-service/coverage)
[data:image/s3,"s3://crabby-images/2c728/2c728585e28a83dddeaa432cd1ebd97c0e965c51" alt="Issue Count"](https://codeclimate.com/github/NoHomey/event-listener-service)
data:image/s3,"s3://crabby-images/000cf/000cf57a4f6fe67b0c15e59b3bc707287124b10d" alt="TypeScript"
data:image/s3,"s3://crabby-images/876a0/876a019360c1ae0c4a4ea702eeef608b58bacc8b" alt="Typings"# Install
Install with npm:
```bash
$ npm install event-listener-service
```# Api
## public static useWithoutImplementation(): void
Declare usage without internal event registering implementation
## public static setImplementation(implementation: EventListenerImplementation): void
Set internal event registering implementation
## public static addListener(eventName: string, listener: (event?: any) => void, ...additional: any[]): void
Add EventListener
## public static emit(eventName: string, emitted?: any): void
Emit event using built in event emiting
## public static removeListener(eventName: string, listener: (event?: any) => void, ...additional: any[]): void
Remove EventListener
# Usage
## As stand alone EventListener
```javascript
import EventListenerService from 'event-listener-service';// Declare usage without internal event registering implementation
EventListenerService.useWithoutImplementation();function onSomeEvent(event) {
console.log('some-event', event);
}// Adding EventLisner
EventListenerService.addListener('some-event', onSomeEvent);// Emiting Events
EventListenerService.emit('some-event', { rand: 9 });// Removing EventLisnter
EventListenerService.removeListener('some-event', onSomeEvent);
```## For listening events on DOM Nodes in the Browser
```javascript
import EventListenerService from 'event-listener-service';// Seting internal event registering implementation
EventListenerService.setImplementation({
addListener: window.addEventListener.bind(window),
removeListener: window.removeEventListener.bind(window)
});function onResize() {
/* ... */
}// Adding EventLisner
EventListenerService.addListener('resize', onResize, false);// Removing EventLisnter
EventListenerService.removeListener('resize', onResize, false);// Optionaly you can manually trigger event listeners in your tests or when you need to fully simulate event
EventListenerService.emit('resize', /* [event object] */);
```## As universal EventListener API
```javascript
// Set internal implementation for registering event listeners
EventListenerService.setImplementation({
addListener: /* (eventName: string, listener: (event?: any) => void, ...additional: any[]) => void */
removeListener: /* (eventName: string, listener: (event?: any) => void, ...additional: any[]) => void */
});// And than use addListener and removeListner
EventListnerService.addListener(eventName: string, listener: (event?: any) => void, ...additional: any[]);
EventListnerService.removeListener(eventName: string, listener: (event?: any) => void, ...additional: any[]);
```# Testing
1. `npm install`
2. `npm test`
# Contributing
1. `npm install`
2. Make changes
3. If necessary add some tests to `__tests__`
4. `npm test`
5. Make a Pull Request