React Native with Nx

Nx provides a holistic dev experience powered by an advanced CLI and editor plugins. It provides rich support for common tools like Detox, Storybook, Jest, and more.
In this guide we will show you how to develop React Native applications with Nx.
Creating Nx Workspace
The easiest way to create your workspace is via npx.
npx create-nx-workspace happynrwl \
--preset=react-native \
--appName=mobile
You can also run the command without arguments to go through the interactive prompts.
npx create-nx-workspace happynrwl
Once the command completes, the workspace will look as follows:
happynrwl/
├── apps/
│   ├── mobile/
│   │   ├── app.json
│   │   ├── metro.config.js
│   │   ├── android/
│   │   │   ├── app/
│   │   │   ├── gradle/
│   │   │   ├── build.gradle
│   │   │   ├── gradle.properties
│   │   │   ├── gradlew
│   │   │   ├── settings.gradle
│   │   ├── ios/
│   │   │   ├── Mobile/
│   │   │   ├── Mobile.xcodeproj/
│   │   │   ├── Mobile.xcworkspace/
│   │   │   ├── Podfile
│   │   │   ├── Podfile.lock
│   │   ├── src/
│   │   │   ├── main.tsx
│   │   │   └── app/
│   │   │       ├── App.tsx
│   │   │       └── App.spec.tsx
│   │   ├── .babelrc
│   │   ├── jest.config.ts
│   │   ├── test-setup.ts
│   │   ├── package.json
│   │   ├── project.json
│   │   ├── tsconfig.json
│   │   ├── tsconfig.app.json
│   │   └── tsconfig.spec.json
│   └── mobile-e2e/
│       ├── .detoxrc.json
│       ├── src/
│       │   └── app.spec.ts
│       ├── .babelrc
│       ├── jest.config.json
│       ├── project.json
│       ├── tsconfig.e2e.json
│       └── tsconfig.json
├── libs/
├── tools/
├── babel.config.json
├── jest.config.ts
├── jest.preset.js
├── nx.json
├── package-lock.json
├── package.json
└── tsconfig.base.json
To run the application in development mode:
On Android simulator/device:
npx nx run-android mobile
iOS simulator/device:
npx nx run-ios mobile
Try out other commands as well.
- nx lint mobileto lint the application
- nx test mobileto run unit test on the application using Jest
- nx serve mobileto serve the application Javascript bundler that communicates with connected devices. This will start the bundler at http://localhost:8081.
- nx sync-deps mobileto sync app dependencies to its- package.json.
Release build
Android:
npx nx build-android mobile
iOS: (Mac only)
No CLI support yet. Run in the Xcode project. See: https://reactnative.dev/docs/running-on-device
E2E
Android:
npx nx test-android mobile-e2e
iOS: (Mac only)
npx nx test-ios mobile-e2e
When using React Native in Nx, you get the out-of-the-box support for TypeScript, Detox, and Jest. No need to configure anything: watch mode, source maps, and typings just work.
Adding React Native to an Existing Workspace
For existing Nx workspaces, install the @nrwl/react-native package to add React Native capabilities to it.
npm install @nrwl/react-native --save-dev
 Or with yarn
yarn add @nrwl/react-native --dev
Generating an Application
To create additional React Native apps run:
npx nx g @nrwl/react-native:app
Generating a Library
Nx allows you to create libraries with just one command. Some reasons you might want to create a library include:
- Share code between applications
- Publish a package to be used outside the monorepo
- Better visualize the architecture using npx nx graph
For more information on Nx libraries, see our documentation on Creating Libraries and Library Types.
To generate a new library run:
npx nx g @nrwl/react-native:lib shared-ui-layout
And you will see the following:
happynrwl/
├── apps/
│   └── mobile/
│   └── mobile-e2e/
├── libs/
│   └── shared-ui-layout/
│       ├── src/
│       │   └── index.ts
│       ├── .babelrc
│       ├── jest.config.js
│       ├── project.json
│       ├── README.md
│       ├── test-setup.ts
│       ├── tsconfig.json
│       ├── tsconfig.lib.json
│       └── tsconfig.spec.json
├── tools/
├── babel.config.json
├── jest.config.js
├── jest.preset.js
├── nx.json
├── package-lock.json
├── package.json
└── tsconfig.base.json
Run:
- npx nx test shared-ui-layoutto test the library
- npx nx lint shared-ui-layoutto lint the library
To generate a new component inside shared-ui-layout run:
npx nx g @nrwl/react-native:component layout --project=shared-ui-layout --export
And you will see the following updated for shared-ui-layout:
happynrwl/
└── libs/
    └── shared-ui-layout/
        └── src/
            ├── index.ts
            └── lib/
                 └── layout/
                     ├── layout.tsx
                     └── layout.spec.tsx
Using Nx Library in your Application
You can import the shared-ui-layout library in your application as follows.
import React from 'react';
import { SafeAreaView } from 'react-native';
import { Layout } from '@happynrwl/shared-ui-layout';
const App = () => {
  return (
    <SafeAreaView>
      <Layout />
    </SafeAreaView>
  );
};
export default App;
That's it! There is no need to build the library prior to using it. When you update your library, the React Native application will automatically pick up the changes.
Publishable libraries
For libraries intended to be built and published to a registry (e.g. npm) you can use the --publishable and --importPath options.
npx nx g @nrwl/react-native:lib shared-ui-layout --publishable --importPath=@happynrwl/ui-components
npx nx g @nrwl/react-native:component layout --project=shared-ui-layout --export
Run npx nx build shared-ui-layout to build the library. It will generate the following:
dist/libs/shared-ui-layout/
├── README.md
├── index.d.ts
├── lib/
│   └── layout/
│       └── layout.d.ts
├── package.json
├── shared-ui-layout.esm.css
├── shared-ui-layout.esm.js
├── shared-ui-layout.umd.css
└── shared-ui-layout.umd.js
This dist folder is ready to be published to a registry.
Environment Variables
The workspace should installreact-native-config by default. To use environment variable, create a new .env file in the happynrwl/apps/mobile folder:
NX_BUILD_NUMBER=123
Then access variables defined there from your app:
import Config from 'react-native-config';
Config.NX_BUILD_NUMBER; // '123'
Code Sharing
Without Nx, creating a new shared library can take from several hours to even weeks: a new repo needs to be provisioned, CI needs to be set up, etc... In an Nx Workspace, it only takes minutes.
You can share React Native components between multiple React Native applications, share business logic code between React Native mobile applications and plain React web applications. You can even share code between the backend and the frontend. All of these can be done without any unnecessary ceremony.
Resources
Here are other resources that you may find useful to learn more about React Native and Nx.
- Blog post: Introducing React Native Support for Nx by Jack Hsu
- Blog post: Step by Step Guide on Creating a Monorepo for React Native Apps using Nx by Eimly Xiong