Comments (4)
Would you like to create a PR for this issue?
from event-emitter.
You can not use the OnEvent
decorator to subscribe to multiple events at once (except for when you use wildcards.
The event
argument from OnEvent
decorator is passed to the EventEmitter2.on() method - which treats the event
argument of type Array
as a namespaced event (i.e. 'foo.bar'
equals ['foo', 'bar'])
or in this case (@Kopleman ) ['some.event1', 'some.event2']
would subscribe to the event 'some.event1.some.event2'
- which I assume would never be emitted.
Note: For using wildcards or namespaces, you must activate the wildcard
option on the module.
Namespaces with Wildcards: To use namespaces/wildcards, pass the wildcard option into the EventEmitter constructor. When namespaces/wildcards are enabled, events can either be strings (foo.bar) separated by a delimiter or arrays (['foo', 'bar']). The delimiter is also configurable as a constructor option.
from event-emitter.
if we change from
@OnEvent(['some.event1', 'some.event2'])
to
@OnEvent(['some.event1'])
it will work. Should be easy to fix
from event-emitter.
In the example below doesn't work
@Injectable()
export class Indexer {
@OnEvent("auction.created")
created() {
console.log("auction created 2")
}
}
but this work as expected in my nest app
@Injectable()
export class Indexer {
constructor(
private readonly auctionContract: AuctionContract,
private readonly eventEmitter: EventEmitter2
) {
this.eventEmitter.addListener("auction.created", this.created.bind(this))
}
created() {
console.log("auction created 2")
}
}
I don't know why the first approach is not working. But I'd like to create a PR for this. I don't know where to start.
from event-emitter.
Related Issues (20)
- EventEmitterModule crash with TypeError from reflect-metadata stack when used with Proxy HOT 1
- Mitigating Event Loss Risk During NestJS Application Initialization HOT 2
- Event Emitter Exception Logging HOT 1
- Add the ability to catch errors from event listeners via ExceptionFilters HOT 2
- Event listeners are registered twice HOT 4
- @OnEvent decorators is not working when applied multiple times on same method HOT 2
- Duplicate events when using useExisting providers HOT 3
- EventEmitterModuleOptions maxListeners setting isn't applied HOT 3
- Multiple event types not handled (impossible to) HOT 4
- Exceptions in async event handlers make the app crash HOT 1
- Custom event decorators break with the latest array metadata type requirement HOT 2
- Jest Unit tests only emit events when intializing full AppModule HOT 8
- Provider EventEmitter can't not resolve when using TerserPlugin webpack HOT 3
- Using event emitter in imported npm package cannot resolve emitter HOT 3
- async function constructor name not AsyncFunction HOT 1
- Upgrade to use event emitter 3, or add an option for it HOT 1
- Suppressing errors when updating from 2.0.0 to 2.0.1 HOT 1
- Option to throw error if an event fails to process HOT 3
- Add OnSafeEvent HOT 7
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from event-emitter.