This PR fixes an issue introduced when we removed `/nx-api` pages: https://github.com/nrwl/nx/pull/31453. Most of the old `/nx-api/<plugin>` URLs should now go to `/technologies/<plugin>/introduction`, since those pages contain what was on the previous "overview" pages. The only exception are places where we explicitly link to `.../api/{generators,executors,migrations}` URLs, and the following three blog posts that we want users to land on the API index. - https://github.com/nrwl/nx/blob/master/docs/blog/2022-03-29-the-react-cli-you-always-wanted-but-didnt-know-about.md?plain=1#L132 (https://nx.dev/blog/the-react-cli-you-always-wanted-but-didnt-know-about) - https://github.com/nrwl/nx/blob/master/docs/blog/2022-04-08-what-is-new-in-nx-13-10.md?plain=1#L245 (https://nx.dev/blog/what-is-new-in-nx-13-10) - https://github.com/nrwl/nx/blob/master/docs/blog/2022-05-02-nx-v14-is-out-here-is-all-you-need-to-know.md?plain=1#L253 (https://nx.dev/blog/nx-v14-is-out-here-is-all-you-need-to-know)
301 lines
7.7 KiB
Markdown
301 lines
7.7 KiB
Markdown
---
|
|
title: React Native with Nx
|
|
description: Learn how to develop React Native applications with Nx, including workspace setup, running on simulators, testing, and leveraging Nx's powerful tooling.
|
|
---
|
|
|
|
# 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](/technologies/test-tools/detox/introduction), Storybook, Jest, and more.
|
|
|
|
In this guide we will show you how to develop [React Native](https://reactnative.dev/) applications with Nx.
|
|
|
|
## Creating Nx Workspace
|
|
|
|
The easiest way to create your workspace is via `npx`.
|
|
|
|
```shell
|
|
npx create-nx-workspace happynrwl \
|
|
--preset=react-native \
|
|
--appName=mobile
|
|
```
|
|
|
|
{% callout type="note" title="Don't know what you need?" %}
|
|
You can also run the command without arguments to go through the interactive prompts.
|
|
{% /callout %}
|
|
|
|
```shell
|
|
npx create-nx-workspace happynrwl
|
|
```
|
|
|
|
Once the command completes, the workspace will look as follows:
|
|
|
|
```text
|
|
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:
|
|
|
|
```shell
|
|
npx nx start mobile
|
|
```
|
|
|
|
On Android simulator/device:
|
|
|
|
```shell
|
|
npx nx run-android mobile
|
|
```
|
|
|
|
iOS simulator/device:
|
|
|
|
```shell
|
|
npx nx run-ios mobile
|
|
```
|
|
|
|
Try out other commands as well.
|
|
|
|
- `nx lint mobile` to lint the application
|
|
- `nx test mobile` to run unit test on the application using Jest
|
|
- `nx sync-deps mobile` to sync app dependencies to its `package.json`.
|
|
|
|
### Release build
|
|
|
|
**Android:**
|
|
|
|
```shell
|
|
npx nx build-android mobile
|
|
```
|
|
|
|
**iOS:** (Mac only)
|
|
|
|
```shell
|
|
npx nx build-ios mobile
|
|
```
|
|
|
|
### E2E
|
|
|
|
**Android:**
|
|
|
|
{% tabs %}
|
|
{% tab label="Using inferred tasks" %}
|
|
|
|
{% callout type="note" title="Inferred Tasks" %}
|
|
Since Nx 18, Nx plugins can infer tasks for your projects based on the configuration of different tools. You can read more about it at the [Inferred Tasks concept page](/concepts/inferred-tasks).
|
|
{% /callout %}
|
|
|
|
```shell
|
|
npx nx test mobile-e2e -- --configuration="android.emu.debug"
|
|
```
|
|
|
|
{% /tab %}
|
|
{% tab label="Using explicit targets with executors" %}
|
|
|
|
```shell
|
|
npx nx test-android mobile-e2e
|
|
```
|
|
|
|
{% /tab %}
|
|
|
|
**iOS:** (Mac only)
|
|
|
|
{% tabs %}
|
|
{% tab label="Using inferred tasks" %}
|
|
|
|
```shell
|
|
npx nx test mobile-e2e -- --configuration="ios.sim.debug"
|
|
```
|
|
|
|
{% /tab %}
|
|
{% tab label="Using explicit targets with executors" %}
|
|
|
|
```shell
|
|
npx nx test-ios mobile-e2e
|
|
```
|
|
|
|
{% /tab %}
|
|
|
|
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
|
|
|
|
For existing Nx workspaces, install the `@nx/react-native` package to add React Native capabilities to it.
|
|
|
|
```shell {% skipRescope=true %}
|
|
nx add @nx/react-native
|
|
```
|
|
|
|
## Generating an Application
|
|
|
|
To create additional React Native apps run:
|
|
|
|
```shell
|
|
npx nx g @nx/react-native:app apps/mobile
|
|
```
|
|
|
|
## 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:
|
|
|
|
```shell
|
|
npx nx g @nx/react-native:lib libs/shared-ui-layout
|
|
```
|
|
|
|
And you will see the following:
|
|
|
|
```text
|
|
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-layout` to test the library
|
|
- `npx nx lint shared-ui-layout` to lint the library
|
|
|
|
To generate a new component inside `shared-ui-layout` run:
|
|
|
|
```shell
|
|
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`:
|
|
|
|
```treeview
|
|
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.
|
|
|
|
```typescript jsx {% fileName="apps/mobile/src/app/App.tsx" %}
|
|
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.
|
|
|
|
```shell
|
|
npx nx g @nx/react-native:lib libs/shared-ui-layout --publishable --importPath=@happynrwl/ui-components
|
|
npx 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:
|
|
|
|
```text
|
|
dist/libs/shared-ui-layout/
|
|
├── README.md
|
|
├── index.d.ts
|
|
├── lib/
|
|
│ └── layout/
|
|
│ └── layout.d.ts
|
|
└── package.json
|
|
```
|
|
|
|
This dist folder is ready to be published to a registry.
|
|
|
|
## 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.
|