DeviceEventEmitter on iOS

General Tech Bugs & Fixes 2 years ago

0 1 0 0 0 tuteeHUB earn credit +10 pts

5 Star Rating 1 Rating

Posted on 16 Aug 2022, this text provides information on Bugs & Fixes related to General Tech. Please note that while accuracy is prioritized, the data presented might not be entirely correct or up-to-date. This information is offered for general knowledge and informational purposes only, and should not be considered as a substitute for professional advice.

Take Quiz To Earn Credits!

Turn Your Knowledge into Earnings.

tuteehub_quiz

Answers (1)

Post Answer
profilepic.png
manpreet Tuteehub forum best answer Best Answer 2 years ago

 

I'm working on a react-native app. I'm trying to emit events from native code to my react native code. This works in Android, but struggling with iOS.

I'm successfully listening to events being sent from my native Android code. The same events are however not being "picker up" by my react native app when running on iOS, and trying to figure out why.

I have code which connects to an MQTT broker. The code is written natively for iOS and Android. During the connection process, I'm sending the connection status from my native code to react-native. This is working well on Android. The event being sent from my Android code using the reactContext.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class).emit(eventName, eventString) method reaches my react native code as expected. However, in my iOS code, messages transmitted using the sendEvent() method are being sent, but I'm not picking them up in my react-native code. I even get a yellow warning in my iOS emulator stating that "Sending Statuswith no listeners registered. My Swift class which is sending the event extends the RCTEventEmitter class.

Hope this is all the details people need to help. I've not much experience using DeviceEventEmitter and very little experience with Swift and iOS. Mainly an Android guy, so this has been a little confusing. I'm guessing its actually super simple, but I'm a little lost.

this.handleMqttStatusChange = this.handleMqttStatusChange.bind(this);
DeviceEventEmitter.addListener("Status", this.handleMqttStatusChange);

The following Swift code sends the event.

self.sendEvent(withName: "Status", body: ["status":"Connecting"]);

The Swift class sending the event extends the RCTEventEmitter.

class AwsIotModule: RCTEventEmitter {

My Android Java file extends the ReactContextBaseJavaModule.

public class AwsIotModule extends ReactContextBaseJavaModule {

And the following java method is used to send the events.

private void sendEvent(ReactContext reactContext,
                           String eventName,
                           @Nullable WritableMap params) {
        reactContext.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class)
                .emit(eventName, params);
    }

No matter what stage you're at in your education or career, TuteeHub will help you reach the next level that you're aiming for. Simply,Choose a subject/topic and get started in self-paced practice sessions to improve your knowledge and scores.