@nx/expo

/nameExpo is an open-source framework for apps that run natively on Android, iOS, and the web. Expo brings together the best of mobile and the web and enables many important features for building and scaling an app.

Expo is a set of tools built on top of React Native. The Nx Plugin for Expo contains generators for managing Expo applications and libraries within an Nx workspace.

Setting Up Expo

To create a new workspace with Expo, run the following command:

โฏ

npx create-nx-workspace@latest --preset=expo --appName=your-app-name

Installation

Keep Nx Package Versions In Sync

Make sure to install the @nx/expo 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.

In any Nx workspace, you can install @nx/expo by running the following command:

โฏ

nx add @nx/expo

This will install the correct version of @nx/expo.

How @nx/expo Infers Tasks

The @nx/expo 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

In the app config file, it needs to have key expo:

1{ 2 "expo": { 3 "name": "MyProject", 4 "slug": "my-project" 5 } 6} 7

View Inferred Tasks

To view inferred tasks for a project, open the project details view in Nx Console or run nx show project my-project --web in the command line.

@nx/expo Configuration

The @nx/expo/plugin is configured in the plugins array in nx.json.

nx.json
1{ 2 "plugins": [ 3 { 4 "plugin": "@nx/expo/plugin", 5 "options": { 6 "startTargetName": "start", 7 "serveTargetName": "serve", 8 "runIosTargetName": "run-ios", 9 "runAndroidTargetName": "run-android", 10 "exportTargetName": "export", 11 "prebuildTargetName": "prebuild", 12 "installTargetName": "install", 13 "buildTargetName": "build", 14 "submitTargetName": "submit" 15 } 16 } 17 ] 18} 19

Once a Expo configuration file has been identified, the targets are created with the name you specify under startTargetName, serveTargetName, runIosTargetName, runAndroidTargetname, exportTargetName, prebuildTargetName, installTargetName, buildTargetName or submitTargetName in the nx.json plugins array. The default names for the inferred targets are start, serve, run-ios, run-anroid, export, prebuild, install, build and submit.

Creating Applications

Add a new application to your workspace with the following command:

โฏ

nx g @nx/expo:app apps/my-app

Start the application by running:

โฏ

nx start my-app

Generating Libraries

To generate a new library run:

โฏ

npx nx g @nx/expo:lib libs/your-lib-name

Generating Components

To generate a new component inside library run:

โฏ

npx nx g @nx/expo:component libs/your-lib-name/src/your-component-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

Using Expo

Start a Development Server

You can start a development server by running:

โฏ

nx start <app-name>

Compile App Locally

You can compile your app locally with run-ios and run-android commands:

Compile for iOS:

โฏ

nx run-ios <app-name>

To run these commands, you need to have your development environment setup. To run an iOS app,it can only be run on a Mac, and Xcode must be installed. Similarly, to run an Android app, it requires Android Studio and Java to be installed and configured on your computer. Setup steps: https://reactnative.dev/docs/environment-setup.

Compile Web Assets

You can build your JavaScript bundle using Metro bundler by running:

โฏ

nx export <app-name>

Compile for all platforms:

โฏ

nx export <app-name> --platform=all

Generate Native Code

To generate native code, run:

โฏ

nx prebuild <app-name>

Generate for all platforms:

โฏ

nx prebuild <app-name> --platform=all

Install Compatible NPM Packages

To install packages that is compatible with current version of Expo, run:

โฏ

nx install <app-name>

Unlike npm's install command, this install command will install the exact right version for currently installed copy of Expo.

To install a specify NPM package, run:

โฏ

nx install <app-name> --packages=<packpage-name>

โฏ

nx install <app-name> --packages=<packpage-name-1>,<packpage-name-2>,<packpage-name-3>

To check and fix package versions, run:

Check which packages needed to be updated:

โฏ

nx install <app-name> --check

Run an EAS Build

Expo Application Services (EAS) are deeply integrated cloud services for Expo and React Native apps. EAS Build is a hosted service for building app binaries for your Expo and React Native projects.

To run an EAS build:

โฏ

nx build <app-name>

If you are not signed into an EAS account, run the following command to log in:

โฏ

npx eas login

To check the details of your build status, run:

โฏ

nx build-list <app-name>

Submit an EAS Build

EAS Submit is a hosted service for uploading and submitting your app binaries to the app stores. Since it's a hosted service, you can submit your app to both stores as long as you can run EAS CLI on your machine.

To submit an EAS build:

โฏ

nx submit <app-name>

Update an EAS Build

EAS Update is a hosted service that serves updates for projects using the expo-updates library.

EAS Update makes fixing small bugs and pushing quick fixes a snap in between app store submissions. It accomplishes this by allowing an end-user's app to swap out the non-native parts of their app (for example, JS, styling, and image changes) with a new update that contains bug fixes and other updates.

To update an EAS build:

โฏ

nx update <app-name>

Testing Projects

You can run unit tests with:

โฏ

nx test <project-name>

Expo Commands

Below table is a map between expo commands and Nx commands:

Expo CommandsNx Commands
expo startnx start <app-name>
expo run:iosnx run-ios <app-name>
expo run:androidnx run-android <app-name>
expo exportnx export <app-name>
expo prebuildnx prebuild <app-name>
expo installnx install <app-name>
eas buildnx build <app-name>
eas build:listnx build-list <app-name>
eas updatenx update <app-name>
eas submitnx submit <app-name>

More Documentation

Package reference

Here is a list of all the executors, generators and migrations available from this package.

Guides

Executors

  • update

    Start an EAS update for your expo project

  • build

    Start an EAS build for your expo project

  • build-list

    List all EAS builds for your Expo project

  • run

    Run the Android app binary locally or run the iOS app binary locally

  • start

    Start a local dev server for the app or start a Webpack dev server for the web app

  • sync-deps

    Syncs dependencies to package.json (required for autolinking).

  • ensure-symlink

    Ensure workspace node_modules is symlink under app's node_modules folder.

  • prebuild

    Create native iOS and Android project files for building natively.

  • install

    Install a module or other package to a project.

  • export

    Export the JavaScript and assets for your app using Metro/webpack bundler

  • submit

    Submit app binary to App Store and/or Play Store

  • serve

    Serve up the Expo web app locally

Generators

  • initInternal

    Initialize the @nx/expo plugin

  • application

    Create an application

  • library

    Create a library

  • component

    Create a component

  • convert-to-inferred

    Convert existing Expo project(s) using @nx/expo:* executors to use @nx/expo/plugin. Defaults to migrating all projects. Pass '--project' to migrate only one target.

Migrations

  • 20.3.x

  • 20.3.0-package-updates

    Version: 20.3.0-beta.0

    Packages

    NameVersionAlways Add to package.json
    expo~52.0.11Update only
    expo-splash-screen~0.29.13Update only
    expo-status-bar~2.0.0Update only
    @expo/cli~0.21.8Update only
    babel-preset-expo~12.0.1Update only
    react~18.3.1Update only
    react-dom~18.3.1Update only
    react-test-renderer~18.3.1Update only
    @types/react~18.3.12Update only
    react-native~0.76.3Update only
    react-native-web~0.19.13Update only
    @expo/metro-config~0.19.4Update only
    @expo/metro-runtime~4.0.0Update only
    react-native-svg-transformer~1.5.0Update only
    react-native-svg~15.8.0Update only
    @testing-library/react-native~12.9.0Update only
    jest-expo~52.0.2Update only
    @babel/runtime7.26.0Update only
  • 19.7.x

  • update-19-7-0-remove-eas-pre-install

    Remove eas-build-pre-install script from app's package.json

    Version: 19.7.0-beta.4
  • 19.2.x

  • update-19-2-0-remove-webpack-config

    Remove deprecated webpack.config.js

    Version: 19.2.0-beta.2

    19.2.0-package-updates

    Version: 19.2.0-beta.2

    Packages

    NameVersionAlways Add to package.json
    expo~51.0.8Update only
    expo-splash-screen~0.27.4Update only
    expo-status-bar~1.12.1Update only
    @expo/cli~0.18.13Update only
    babel-preset-expo~11.0.0Update only
    react-native0.74.1Update only
    react-native-web~0.19.11Update only
    @expo/metro-config~0.18.1Update only
    @expo/metro-runtime~3.2.1Update only
    react-native-svg-transformer1.3.0Update only
    react-native-svg15.2.0Update only
    @testing-library/react-native~12.5.0Update only
    jest-expo~51.0.2Update only
    @babel/runtime7.24.5Update only
  • 19.0.x

  • update-19-0-0-change-webpack-to-metro

    Change webpack to metro in expo projects

    Version: 19.0.0-beta.9

    19.0.0-package-updates

    Version: 19.0.0-beta.7

    Packages

    NameVersionAlways Add to package.json
    expo~50.0.14Update only
    expo-splash-screen~0.26.4Update only
    @expo/cli~0.17.8Update only
    babel-preset-expo~10.0.1Update only
    react-native~0.73.6Update only
    react-native-web~0.19.10Update only
    @expo/metro-config~0.17.6Update only
    @expo/metro-runtime~3.1.3Update only
    react-native-svg-transformer1.3.0Update only
    react-native-svg15.1.0Update only
    @testing-library/react-native~12.4.5Update only
    jest-expo~50.0.4Update only
  • 18.0.x

  • update-18-0-0-remove-block-list

    Remove blockList in metro.config.js

    Version: 18.0.0-beta.0

    update-18-0-0-remove-symlink-target

    Remove symlink target in project.json

    Version: 18.0.0-beta.0

    update-18-0-0-remove-eas-cli

    Remove eas-cli from package.json

    Version: 18.0.0-beta.0

    update-18-0-0-remove-offset-export-outputDir

    Remove the offset from the outputDir of the export target

    Version: 18.0.0-beta.0

    18.0.0-package-updates

    Version: 18.0.0-beta.0

    Packages

    NameVersionAlways Add to package.json
    expo50.0.1Update only
    expo-splash-screen~0.26.1Update only
    expo-status-bar~1.11.1Update only
    @expo/cli~0.16.5Update only
    babel-preset-expo~10.0.0Update only
    @types/react~18.2.45Update only
    react-native~0.73.2Update only
    react-native-web~0.19.9Update only
    @expo/metro-config~0.17.3Update only
    @expo/metro-runtime~3.1.1Update only
    react-native-svg-transformer1.2.0Update only
    react-native-svg14.1.0Update only
    @testing-library/react-native~12.4.2Update only
    jest-expo~50.0.1Update only
  • 17.1.x

  • 17.1.0-package-updates

    Version: 17.1.0-beta.0

    Packages

    NameVersionAlways Add to package.json
    expo49.0.16Update only
    @expo/cli~0.10.13Update only
    react-native0.72.6Update only
    react-native-web~0.19.9Update only
    metro-resolver0.76.8Update only
    metro0.76.8Update only