Expo SDK
37.0.0Schema URL
Properties
44 nested properties
The name of your app as it appears both within Expo and on your home screen as a standalone app.
The friendly url name for publishing. eg: expo.io/@your-username/slug.
A short description of what your app is and why it is great.
The username of the account under which this app is published. If not specified, the app is published as the currently signed-in user.
Either public or unlisted. If not provided, defaults to unlisted. In the future private will be supported. unlisted hides the experience from search results.
The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.
Your app version, use whatever versioning scheme that you like.
Platforms that your project explicitly supports. If not specified, it defaults to ["ios", "android"].
If you would like to share the source code of your app on GitHub, enter the URL for the repository here and it will be linked to from your Expo project page.
Lock your app to a specific orientation with portrait or landscape. Defaults to no lock.
Configuration to force the app to always use the light or dark user-interface appearance, such as "dark mode", or make it automatically adapt to the system preferences. If not provided, defaults to light.
The background color for your app, behind any of your React views.
On Android, this will determine the color of your app in the multitasker. Currently this is not used on iOS, but it may be used for other purposes in the future.
Local path or remote url to an image to use for your app's icon. We recommend that you use a 1024x1024 png file. This icon will appear on the home screen and within the Expo app.
Configuration for remote (push) notifications.
5 nested properties
Local path or remote url to an image to use as the icon for push notifications. 96x96 png grayscale with transparency.
Tint color for the push notification image when it appears in the notification tray.
Display the notification when the app is in foreground on iOS.
Show each push notification individually (default) or collapse into one (collapse).
If androidMode is set to collapse, this title is used for the collapsed notification message. eg: '#{unread_notifications} new interactions'.
DEPRECATED: Use splash instead. Configuration for the loading screen that users see when opening your app, while fetching & caching bundle and assets.
7 nested properties
Local path or remote url to an image to display while starting up the app. Image size and aspect ratio are up to you. Must be a .png.
If no icon is provided, we will show the Expo logo. You can choose between white and blue.
Similar to exponentIconColor but instead indicate if it should be grayscale (1) or not (0).
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Color to fill the loading screen background
By default, Expo shows some text at the bottom of the loading screen. Set this to true to disable.
DEPRECATED: was used in the past for changing the style of the iOS loading indicator.
By default, Expo looks for the application registered with the AppRegistry as main. If you would like to change this, you can specify the name in this property.
DEPRECATED. Use androidStatusBar instead.
Configuration for the status bar on Android.
2 nested properties
Configures the status bar icons to have a light or dark color.
Specifies the background color of the status bar.
Configuration for the bottom navigation bar on Android.
3 nested properties
Determines how and when the navigation bar is shown.
Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer.
Specifies the background color of the navigation bar.
Adds a notification to your standalone app with refresh button and debug info.
URL scheme to link into your app. For example, if we set this to 'demo', then demo:// URLs would open your app when tapped.
The relative path to your main JavaScript file.
Any extra fields you want to pass to your experience. Values are accessible via Expo.Constants.manifest.extra (read more)
Configuration for how and when the app should request OTA JavaScript updates
3 nested properties
If set to false, your standalone app will never download any code, and will only use code bundled locally on the device. In that case, all updates to your app must be submitted through Apple review. Defaults to true. (Note that this will not work out of the box with ExpoKit projects)
By default, Expo will check for updates every time the app is loaded. Set this to 'ON_ERROR_RECOVERY' to disable automatic checking unless recovering from an error.
How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 30000 (30 sec).
Provide overrides by locale for System Dialog prompts like Permissions Boxes
iOS standalone app specific configuration
22 nested properties
The manifest for the Android version of your app will be written to this path during publish.
The bundle for the Android version of your app will be written to this path during publish.
The bundle identifier for your iOS standalone app. You make it up, but it needs to be unique on the App Store. See this StackOverflow question.
Build number for your iOS standalone app. Must be a string that matches Apple's format for CFBundleVersion.
The background color for your iOS app, behind any of your React views. Overrides the top-level backgroundColor key if it is present.
Local path or remote URL to an image to use for your app's icon on iOS. If specified, this overrides the top-level icon key. Use a 1024x1024 icon which follows Apple's interface guidelines for icons, including color profile and transparency. Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.
Merchant ID for use with Apple Pay in your standalone app.
URL to your app on the Apple App Store, if you have deployed it there. This is used to link to your store page from your Expo project page if your app is public.
6 nested properties
Branch key to hook up Branch linking services.
Sets ITSAppUsesNonExemptEncryption in the standalone ipa's Info.plist to the given boolean value.
Google Maps iOS SDK key for your standalone app.
Google Mobile Ads App ID Google AdMob App ID.
A boolean indicating whether to initialize Google App Measurement and begin sending user-level event data to Google immediately when the app starts. The default in Expo (Client and in standalone apps) is false.
Google Sign-In iOS SDK keys for your standalone app.
DEPRECATED: use updates.enabled instead.
Firebase Configuration File GoogleService-Info.plist file for configuring Firebase.
DEPRECATED: use updates key with fallbackToCacheTimeout: 0 instead.
Whether your standalone iOS app supports tablet screen sizes. Defaults to false.
If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.
If true, indicates that your standalone iOS app does not support Slide Over and Split View on iPad. Defaults to true currently, but will change to false in a future SDK version.
Configuration to force the app to always use the light or dark user-interface appearance, such as "dark mode", or make it automatically adapt to the system preferences. If not provided, defaults to light.
Dictionary of arbitrary configuration to add to your standalone app's native Info.plist. Applied prior to all other Expo-specific configuration. No other validation is performed, so use this at your own risk of rejection from the App Store.
An array that contains Associated Domains for the standalone app.
A boolean indicating if the app uses iCloud Storage for DocumentPicker. See DocumentPicker docs for details.
A boolean indicating if the app uses Apple Sign-In. See AppleAuthentication docs for details.
A Boolean value that indicates whether the app may access the notes stored in contacts. You must receive permission from Apple before you can submit your app for review with this capability: https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes.
Configuration for loading and splash screen for standalone iOS apps.
5 nested properties
Local path to a XIB file as the loading screen. It overrides other loading screen options.
Color to fill the loading screen background
Determines how the image will be displayed in the splash loading screen. Must be one of cover or contain, defaults to contain.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Android standalone app specific configuration
14 nested properties
The manifest for the Android version of your app will be written to this path during publish.
The bundle for the Android version of your app will be written to this path during publish.
The package name for your Android standalone app. You make it up, but it needs to be unique on the Play Store. See this StackOverflow question.
Version number required by Google Play. Increment by one for each release. Must be an integer. https://developer.android.com/studio/publish/versioning.html
The background color for your Android app, behind any of your React views. Overrides the top-level backgroundColor key if it is present.
Configuration to force the app to always use the light or dark user-interface appearance, such as "dark mode", or make it automatically adapt to the system preferences. If not provided, defaults to light.
Local path or remote url to an image to use for your app's icon on Android. If specified, this overrides the top-level icon key. We recommend that you use a 1024x1024 png file (transparency is recommended for the Google Play Store). This icon will appear on the home screen and within the Expo app.
3 nested properties
Local path or remote url to an image to use for your app's icon on Android. If specified, this overrides the top-level icon and the android.icon keys. Should follow the guidelines specified at https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive. This icon will appear on the home screen.
Local path or remote url to a background image for your app's Adaptive Icon on Android. If specified, this overrides the backgroundColor key. Should follow the guidelines specified at https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive.
Color to use as the background for your app's Adaptive Icon on Android.
URL to your app on the Google Play Store, if you have deployed it there. This is used to link to your store page from your Expo project page if your app is public.
List of permissions used by the standalone app. Remove the field to use the default list of permissions.
Example: [ "CAMERA", "ACCESS_FINE_LOCATION" ].
You can specify the following permissions depending on what you need:
ACCESS_COARSE_LOCATIONACCESS_FINE_LOCATIONCAMERAMANAGE_DOCUMENTSREAD_CONTACTSREAD_EXTERNAL_STORAGEREAD_INTERNAL_STORAGEREAD_PHONE_STATERECORD_AUDIOUSE_FINGERPRINTVIBRATEWAKE_LOCKWRITE_EXTERNAL_STORAGEcom.anddoes.launcher.permission.UPDATE_COUNTcom.android.launcher.permission.INSTALL_SHORTCUTcom.google.android.c2dm.permission.RECEIVEcom.google.android.gms.permission.ACTIVITY_RECOGNITIONcom.google.android.providers.gsf.permission.READ_GSERVICEScom.htc.launcher.permission.READ_SETTINGScom.htc.launcher.permission.UPDATE_SHORTCUTcom.majeur.launcher.permission.UPDATE_BADGEcom.sec.android.provider.badge.permission.READcom.sec.android.provider.badge.permission.WRITEcom.sonyericsson.home.permission.BROADCAST_BADGE
Firebase Configuration File google-services.json file for configuring Firebase.
6 nested properties
Branch key to hook up Branch linking services.
Google Developers Fabric keys to hook up Crashlytics and other services.
Google Maps Android SDK key for your standalone app.
Google Mobile Ads App ID Google AdMob App ID.
A boolean indicating whether to initialize Google App Measurement and begin sending user-level event data to Google immediately when the app starts. The default in Expo (Client and in standalone apps) is false.
Google Sign-In Android SDK keys for your standalone app.
Configuration for loading and splash screen for standalone Android apps.
7 nested properties
Color to fill the loading screen background
Determines how the image will be displayed in the splash loading screen. Must be one of cover, contain or native, defaults to contain.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
An array of intent filters.
Web platform specific configuration
19 nested properties
Relative path of an image to use for your app's favicon.
Defines the title of the document, defaults to the outer level name
A short version of the app's name, 12 characters or fewer. Used in app launcher and new tab pages. Maps to short_name in the PWA manifest.json. Defaults to the name property.
Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.
Defines the navigation scope of this website's context. This restricts what web pages can be viewed while the manifest is applied. If the user navigates outside the scope, it returns to a normal web page inside a browser tab/window. If the scope is a relative URL, the base URL will be the URL of the manifest.
Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.
Provides a general description of what the pinned website does.
Specifies the primary text direction for the name, short_name, and description members. Together with the lang member, it helps the correct display of right-to-left languages.
Defines the developers' preferred display mode for the website.
The URL that loads when a user launches the application (e.g. when added to home screen), typically the index. Note that this has to be a relative URL, relative to the manifest URL.
Defines the default orientation for all the website's top level browsing contexts.
Defines the expected "background color" for the website. This value repeats what is already available in the site's CSS, but can be used by browsers to draw the background color of a shortcut when the manifest is available before the stylesheet has loaded. This creates a smooth transition between launching the web application and loading the site's content.
If content is set to default, the status bar appears normal. If set to black, the status bar has a black background. If set to black-translucent, the status bar is black and translucent. If set to default or black, the web content is displayed below the status bar. If set to black-translucent, the web content is displayed on the entire screen, partially obscured by the status bar.
Hints for the user agent to indicate to the user that the specified native applications (defined in expo.ios and expo.android) are recommended over the website.
DEPRECATED: Use the dedicated adapters like Next.js, Gatsby, Electron, etc...
Basic customization options for dangerously configuring the default webpack config. Please use expo customize:web to modify the versioned Webpack config directly instead.
6 nested properties
ID of the root DOM element in your index.html. By default this is "root".
DEPRECATED: Modify the Webpack config directly. Choose a custom style of source mapping to enhance the debugging process. These values can affect build and rebuild speed dramatically.
DEPRECATED: Modify the Webpack config directly. Allows you to specify the base path for all the assets within your application.
DEPRECATED: Modify the Webpack config directly. Configuration for customizing webpack report. See HtmlWebpackPlugin.Options from html-webpack-plugin.
DEPRECATED: Modify the Webpack config directly. Configuration for enabling webpack report and stats.json. See BundleAnalyzerPlugin.Options from webpack-bundle-analyzer.
DEPRECATED: Modify the Webpack config directly. Configuration for customizing the service worker. See GenerateSWOptions from workbox-webpack-plugin.
DEPRECATED. Defines the meta tag elements that will be added to the head element of your index.html.
5 nested properties
ID provided by the Google Site Verification API: https://developers.google.com/site-verification/
Apple PWA-specific meta elements. By default these values will be inferred from fields in the scope above, but you can override them here.
Twitter card protocol: https://developer.twitter.com/en/docs/tweets/optimize-with-cards/overview/markup.html
The Open Graph protocol: http://ogp.me/
X-UA protocol
Experimental features. These will break without deprecation notice.
2 nested properties
Viewport meta tag for your index.html. By default this is optimized for mobile usage, disabling zooming, and resizing for iPhone X.
Message that is rendered when the browser using your page doesn't have JS enabled.
Configuration for PWA splash screens.
3 nested properties
Color to fill the loading screen background
Determines how the image will be displayed in the splash loading screen. Must be one of cover or contain, defaults to contain.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.
Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is false.
Whether the Facebook SDK log app events automatically. If you don't set this property, Facebook's default will be used. (Applicable only to standalone apps.)
Whether the Facebook SDK should collect advertiser ID properties, like the Apple IDFA and Android Advertising ID, automatically. If you don't set this property, Facebook's default policy will be used. (Applicable only to standalone apps.)
Used for native Facebook login.
Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme at https://developers.facebook.com/docs/facebook-login/ios in the 'Configuring Your info.plist' section.
Is app detached
Extra fields needed by detached apps
Configuration for loading and splash screen for standalone apps.
3 nested properties
Color to fill the loading screen background
Determines how the image will be displayed in the splash loading screen. Must be one of cover or contain, defaults to contain.
Local path or remote url to an image to fill the background of the loading screen. Image size and aspect ratio are up to you. Must be a .png.
Configuration for scripts to run to hook into the publish process
1 nested properties
An array of file glob strings which point to assets that will be bundled within your standalone app binary. Read more in the Offline Support guide