1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- #import "RNNEventEmitter.h"
-
- @implementation RNNEventEmitter {
- NSInteger _appLaunchedListenerCount;
- BOOL _appLaunchedEventDeferred;
- }
-
- RCT_EXPORT_MODULE();
-
- static NSString* const onAppLaunched = @"RNN.appLaunched";
- static NSString* const componentDidAppear = @"RNN.componentDidAppear";
- static NSString* const componentDidDisappear = @"RNN.componentDidDisappear";
- static NSString* const onNavigationButtonPressed = @"RNN.navigationButtonPressed";
-
- -(NSArray<NSString *> *)supportedEvents {
- return @[onAppLaunched, componentDidAppear, componentDidDisappear, onNavigationButtonPressed];
- }
-
- # pragma mark public
-
- -(void)sendOnAppLaunched {
- if (_appLaunchedListenerCount > 0) {
- [self send:onAppLaunched body:nil];
- } else {
- _appLaunchedEventDeferred = TRUE;
- }
- }
-
- -(void)sendComponentDidAppear:(NSString *)componentId {
- [self send:componentDidAppear body:componentId];
- }
-
- -(void)sendComponentDidDisappear:(NSString *)componentId {
- [self send:componentDidDisappear body:componentId];
- }
-
- -(void)sendOnNavigationButtonPressed:(NSString *)componentId buttonId:(NSString*)buttonId {
- [self send:onNavigationButtonPressed body:@{@"componentId":componentId , @"buttonId": buttonId }];
- }
-
- - (void)addListener:(NSString *)eventName {
- [super addListener:eventName];
- if ([eventName isEqualToString:onAppLaunched]) {
- _appLaunchedListenerCount++;
- if (_appLaunchedEventDeferred) {
- _appLaunchedEventDeferred = FALSE;
- [self sendOnAppLaunched];
- }
- }
- }
-
- # pragma mark private
-
- -(void)send:(NSString *)eventName body:(id)body {
- [self sendEventWithName:eventName body:body];
- }
-
- @end
|