- React Native iOS installation instructions
- Install and update Android Studio
- React Native Android installation instructions
$ npm install enx-rtc-react-native --save
$ react-native link enx-rtc-react-native
Note: Please make sure to have CocoaPods on your computer.
If you've installed this package before, you may need to edit your Podfile
and project structure because the installation process has changed.
-
In you terminal, change into the
ios
directory of your React Native project. -
Create a pod file by running:
pod init
. -
Add the following to your pod file:
target '<YourProjectName>' do
# Pods for <YourProject>
pod 'EnxRTCiOS'
pod 'Socket.IO-Client-Swift', '~> 12.0.0'
end
-
Now run,
pod install
-
After installing the EnxRTCiOS SDK, change into your root directory of your project.
-
Now run,
react-native link enx-rtc-react-native
. -
Open
<YourProjectName>.xcworkspace
contents in XCode. This file can be found in theios
folder of your React Native project. -
Click
File
andNew File
-
Add an empty swift file to your project:
- You can name this file anything i.e:
EnxInstall.swift
. This is done to set some flags in XCode so the Swift code can be used.
-
Click
Create Bridging Header
when you're prompted with the following modal:Would you like to configure an Objective-C bridging header?
-
Ensure you have enabled both camera and microphone usage by adding the following entries to your
Info.plist
file:
<key>NSCameraUsageDescription</key>
<string>Your message to user when the camera is accessed for the first time</string>
<key>NSMicrophoneUsageDescription</key>
<string>Your message to user when the microphone is accessed for the first time</string>
If you try to archive the app and it fails, please do the following:
- Go to Target
- Click on Build Phases
- Under the Link Binary With Libraries section, remove the libEnx.a and add it again
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import com.rnenxrtc.EnxRtcPackage;
to the imports at the top of the file - Add
new EnxRtcPackage()
to the list returned by thegetPackages()
method
-
Append the following lines to
android/settings.gradle
:include ':enx-rtc-react-native' project(':enx-rtc-react-native').projectDir = new File(rootProject.projectDir, '../node_modules/enx-rtc-react-native/android')
-
Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':enx-rtc-react-native')
-
Add following permisions in Android Manifest file:
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> <uses-permission android:name="android.permission.CAMERA" /> <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> <uses-permission android:name="android.permission.RECORD_AUDIO" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.BLUETOOTH" /> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
import Enx from 'enx-rtc-react-native';
// TODO: What to do with the module?
Enx;