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
Section titled “Creating Nx Workspace”The easiest way to create your workspace is via npx
.
npx create-nx-workspace happynrwl \--preset=react-native \--appName=mobile
npx create-nx-workspace happynrwl
Once the command completes, the workspace will look as follows:
Directoryhappynrwl/
Directoryapps/
Directorymobile/
- app.json
- metro.config.js
Directoryandroid/
Directoryapp/
- …
Directorygradle/
- …
- build.gradle
- gradle.properties
- gradlew
- settings.gradle
Directoryios/
DirectoryMobile/
- …
DirectoryMobile.xcodeproj/
- …
DirectoryMobile.xcworkspace/
- …
- Podfile
- Podfile.lock
Directorysrc/
- main.tsx
Directoryapp/
- App.tsx
- App.spec.tsx
- .babelrc
- jest.config.ts
- test-setup.ts
- package.json
- project.json
- tsconfig.json
- tsconfig.app.json
- tsconfig.spec.json
Directorymobile-e2e/
- .detoxrc.json
Directorysrc/
- app.spec.ts
- .babelrc
- jest.config.json
- project.json
- tsconfig.e2e.json
- tsconfig.json
Directorylibs/
- …
Directorytools/
- …
- 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:
npx nx start mobile
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 mobile
to lint the applicationnx test mobile
to run unit test on the application using Jestnx sync-deps mobile
to sync app dependencies to itspackage.json
.
Release build
Section titled “Release build”Android:
npx nx build-android mobile
iOS: (Mac only)
npx nx build-ios mobile
Android:
npx nx test mobile-e2e -- --configuration="android.emu.debug"
npx nx test-android mobile-e2e
iOS: (Mac only)
npx nx test mobile-e2e -- --configuration="ios.sim.debug"
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.
Adding React Native to an Existing Workspace
Section titled “Adding React Native to an Existing Workspace”For existing Nx workspaces, install the @nx/react-native
package to add React Native capabilities to it.
nx add @nx/react-native
Generating an Application
Section titled “Generating an Application”To create additional React Native apps run:
npx nx g @nx/react-native:app apps/mobile
Generating a Library
Section titled “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
To generate a new library run:
npx nx g @nx/react-native:lib libs/shared-ui-layout
And you will see the following:
Directoryhappynrwl/
Directoryapps/
Directorymobile/
Directorymobile-e2e/
- …
Directorylibs/
Directoryshared-ui-layout/
Directorysrc/
- index.ts
- .babelrc
- jest.config.js
- project.json
- README.md
- test-setup.ts
- tsconfig.json
- tsconfig.lib.json
- tsconfig.spec.json
Directorytools/
- …
- 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-layout
to test the librarynpx nx lint shared-ui-layout
to lint the library
To generate a new component inside shared-ui-layout
run:
npx nx g @nx/react-native:component libs/shared-ui-layout/src/lib/layout/layout --export
And you will see the following updated for shared-ui-layout
:
Directoryhappynrwl/
Directorylibs/
Directoryshared-ui-layout/
Directorysrc/
- index.ts
Directorylib/
Directorylayout/
- layout.tsx
- layout.spec.tsx
Using Nx Library in your Application
Section titled “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
Section titled “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 @nx/react-native:lib libs/shared-ui-layout --publishable --importPath=@happynrwl/ui-componentsnpx nx g @nx/react-native:component libs/shared-ui-layout/src/lib/layout/layout --export
Run npx nx build shared-ui-layout
to build the library. It will generate the following:
Directorydist/libs/shared-ui-layout/
- README.md
Directoryindex.d.ts
Directorylib/
Directorylayout/
- layout.d.ts
- package.json
This dist folder is ready to be published to a registry.
Code Sharing
Section titled “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.