Integrating React Native into a Native Android Application: A Step-by-Step Guide

React Native is a powerful framework that allows developers to build cross-platform applications using JavaScript and React. One of the biggest benefits of using React Native is the ability to reuse code across both iOS and Android apps, reducing development time and cost. In this article, we will explore how to integrate React Native components into a native Android application.

Prerequisites

Before we begin, make sure you have the following setup:

  • A React Native development environment (React Native CLI)
  • An Android development environment (Android Studio)

Setting Up the Project Directories

First, create a new React Native project using the React Native CLI. Then, create a new Android folder in the root directory of your React Native project. This folder will hold your native Android application.

Configuring Maven

Maven is a powerful tool for managing and building our project. To start, open the build.gradle file in your native Android application’s directory. Add the following lines of code to the dependencies section:

dependencies {
implementation 'com.facebook.react:react-native:+'
}

This will enable autolinking, which allows our application to access native modules and use native modules provided by React Native libraries.

Allowing Permission to Access the Internet

To enable internet permissions, add the following code to the AndroidManifest.xml file:

<uses-permission android:name="android.permission.INTERNET" />

Enabling Cleartext in Debug Builds

Due to changes introduced in Android 9 (API level 28), cleartext traffic is disabled by default. To enable cleartext in debug builds, add the following code to the AndroidManifest.xml file:

<application
...
android:usesCleartextTraffic="true"
...>

Integrating React Native Code into the Native Android App

To integrate React Native code into the native Android app, create an index.js file in the root directory of your React Native project. Add the following code to the index.js file:
“`
import React from ‘react’;
import { AppRegistry } from ‘react-native’;
import App from ‘./App’;

AppRegistry.registerComponent(‘App’, () => App);
“`
Writing Native Code

To start the React Native runtime and tell it to render our JS component, create a file called ReactActivity in your Android Studio project. Add the following code to the ReactActivity.java file:
“`
import android.app.Activity;
import android.os.Bundle;
import com.facebook.react.ReactRootView;

public class ReactActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ReactRootView reactRootView = new ReactRootView(this);
reactRootView.startReactApplication();
setContentView(reactRootView);
}
}
“`
Conclusion

Integrating React Native components into a native Android application can be a complex task, but the benefits of code reuse and faster development make it worth the effort. With this guide, you should now have a basic understanding of how to integrate React Native into a native Android app.

Leave a Reply