nx/docs/shared/packages/react-native/react-native-plugin.md
Isaac Mann 61436a64ef
docs(core): inferred targets (#21167)
Co-authored-by: Katerina Skroumpelou <mandarini@users.noreply.github.com>
Co-authored-by: Colum Ferry <cferry09@gmail.com>
Co-authored-by: Emily Xiong <xiongemi@gmail.com>
Co-authored-by: Nicholas Cunningham <ndcunningham@gmail.com>
Co-authored-by: Jason Jean <jasonjean1993@gmail.com>
Co-authored-by: Victor Savkin <mail@vsavkin.com>
Co-authored-by: Jack Hsu <jack.hsu@gmail.com>
2024-02-03 00:14:05 -05:00

187 lines
5.2 KiB
Markdown

React Native brings React's declarative UI framework to iOS and Android. With React Native, you use native UI controls and have full access to the native platform.
The Nx Plugin for React Native contains generators for managing React Native applications and libraries within an Nx workspace. It provides:
- Integration with libraries such as Jest, Detox, and Storybook.
- Scaffolding for creating buildable libraries that can be published to npm.
- Utilities for automatic workspace refactoring.
## Setting Up React Native
### Create a New Workspace
To create a new workspace with React Native, run the following command:
```shell
npx create-nx-workspace@latest --preset=react-native --appName=your-app-name
```
{% 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 your-workspace-name
```
### Installation
{% callout type="note" title="Keep Nx Package Versions In Sync" %}
Make sure to install the `@nx/react-native` version that matches the version of `nx` in your repository. If the version numbers get out of sync, you can encounter some difficult to debug errors. You can [fix Nx version mismatches with this recipe](/recipes/tips-n-tricks/keep-nx-versions-in-sync).
{% /callout %}
In any Nx workspace, you can install `@nx/react-native` by running the following command:
{% tabs %}
{% tab label="Nx 18+" %}
```shell
nx add @nx/react-native
```
This will install the correct version of `@nx/react-native`.
### How @nx/react-native Infers Tasks
The `@nx/react-native` plugin will create a task for any project that has an app configuration file present. Any of the following files will be recognized as an app configuration file:
- `app.config.js`
- `app.json`
### View Inferred Tasks
To view inferred tasks for a project, open the [project details view](/concepts/inferred-tasks) in Nx Console or run `nx show project my-project --web` in the command line.
### @nx/react-native Configuration
The `@nx/react-native/plugin` is configured in the `plugins` array in `nx.json`.
```json {% fileName="nx.json" %}
{
"plugins": [
{
"plugin": "@nx/react-native/plugin",
"options": {
"startTargetName": "start",
"podInstallTargetName": "pod-install",
"bundleTargetName": "bundle",
"runIosTargetName": "run-ios",
"runAndroidTargetName": "run-android",
"buildIosTargetName": "build-ios",
"buildAndroidTargetName": "build-android"
}
}
]
}
```
Once a React Native configuration file has been identified, the targets are created with the name you specify under `startTargetName`, `podInstallTargetName`, `bundleTargetName`, `runIosTargetName`, `runAndroidTargetname`, `buildIosTargetName` or `buildAndroidTargetName` in the `nx.json` `plugins` array. The default names for the inferred targets are `start`, `pod-install`, `bundle`, `run-ios`, `run-anroid`, `build-ios` and `build-android`.
{% /tab %}
{% tab label="Nx < 18" %}
Install the `@nx/react-native` package with your package manager.
```shell
npm add -D @nx/react-native
```
### Generating Applications
To create additional React Native apps run:
```shell
nx g @nx/react-native:app <your-app-name>
```
### Generating Libraries
To generate a new library run:
```shell
nx g @nx/react-native:lib your-lib-name
```
### Generating Components
To generate a new component inside library run:
```shell
nx g @nx/react-native:component your-component-name --project=your-lib-name --export
```
Replace `your-lib-name` with the app's name as defined in your `tsconfig.base.json` file or the `name` property of your `package.json`
### Upgrade React Native
The Nx CLI provides the [`migrate` command](/features/automate-updating-dependencies) to help you stay up to date with the latest version of Nx.
#### Use upgrade-native Generator
To upgrade native iOS and Android code to latest, you can use the [upgrade-native](/nx-api/react-native/generators/upgrade-native) generator:
```shell
nx generate @nx/react-native:upgrade-native <your-app-name>
```
This is a command that will replace the iOS and Android native code folder entirely.
#### Upgrade Manually
You can also upgrade React Native iOS and Android code using the [rn-diff-purge](https://react-native-community.github.io/upgrade-helper/) project.
### Start Metro Server
To start the server that communicates with connected devices:
```shell
nx start <your-app-name>
```
### Run iOS
To build your app and start it on iOS simulator or device:
```shell
nx run-ios <your-app-name>
```
### Run Android
To build your app and start it on a connected Android emulator or device:
```shell
nx run-android <your-app-name>
```
### Build iOS
To build an iOS app:
```shell
nx build-ios <your-app-name>
```
The build artifacts will be located under `<your app folder>/ios/build`.
You can specify the build folder by setting the `buildFolder` option:
```shell
nx build-ios <your-app-name> --buildFolder="./build"
```
### Build Android
To build an Android app, run:
```shell
nx build-android <your app name>
```
The build artifacts will be located under `<your app folder>/android/app/build`.
## More Documentation
- [Using Detox](/nx-api/detox)
- [Using Jest](/nx-api/jest)