-
Notifications
You must be signed in to change notification settings - Fork 94
Manifest (app.json)
Contents
We use app.json
to configure what gets bundled with the app and declare all
the entry points on the home screen. The manifest must be bundled together with
all your JS assets. It is usually found in res/raw/
in the APK, and in
assets/
in the .app
bundle.
Example app.json
file:
{
"name": "Example",
"displayName": "Example",
"bundleRoot": "main",
"components": [
{
"appKey": "Example",
"displayName": "App"
}
],
"resources": {
"android": [
"dist/res",
"dist/main.android.jsbundle"
],
"ios": [
"dist/assets",
"dist/main.ios.jsbundle"
],
"macos": [
"dist/assets",
"dist/main.macos.jsbundle"
],
"windows": [
"dist/assets",
"dist/main.windows.bundle"
]
},
"android": {
"package": "com.react.reacttestapp"
},
"ios": {
"bundleIdentifier": "com.react.ReactTestApp"
},
"macos": {
"bundleIdentifier": "com.react.ReactTestApp"
},
"windows": {
"appxManifest": "windows/Package.appxmanifest"
}
}
version |
The app version shown to users. The required format is three period-separated integers, such as 1.3.11.
Introduced in 1.4.0. |
bundleRoot |
Specifies the root of the bundle file name. E.g., if the bundle file is
Defaults to When set, the test app will look for the following files on startup:
Introduced in 0.9.0. |
singleApp |
In single-app mode, the component with the specified slug gets launched automatically, essentially behaving as a normal app. Defaults to multi-app mode. For more details, see its dedicated page. Introduced in 1.3.0. |
components |
All components that should be accessible from the home screen should be declared
under this property. Each component must have AppRegistry.registerComponent("Example", () => Example); For each entry, you can declare additional (optional) properties: {
"components": [
{
// The app key passed to `AppRegistry.registerComponent()`
"appKey": "Example",
// [Optional] Name to be displayed on home screen
"displayName": "App",
// [Optional] Properties that should be passed to your component
"initialProperties": {
"concurrentRoot": false
},
// [Optional] The style in which to present your component.
// Valid values are: "modal"
"presentationStyle": "",
// [Optional] URL slug that uniquely identifies this component.
// Used for deep linking.
"slug": ""
}
]
} If you're on React Native 0.69 and want to enable
Concurrent React,
set On Android, you can add fragments to the home screen by using their fully
qualified class names, e.g. "components": [
{
"appKey": "com.example.app.MyFragment",
"displayName": "App"
}
] If you need to get the @Override
@SuppressLint("WrongConstant")
public void onAttach(@NonNull Context context) {
super.onAttach(context);
ReactNativeHost reactNativeHost = (ReactNativeHost)
context.getSystemService("service:reactNativeHostService");
ReactInstanceManager reactInstanceManager =
reactNativeHost.getReactInstanceManager();
} On iOS/macOS, you can have native view controllers on the home screen by using
their Objective-C names as app key (Swift classes can declare Objective-C names
with the
"components": [
{
"appKey": "RTAMyViewController",
"displayName": "App"
}
] The view controller must implement an initializer that accepts a
@interface MyViewController : NSObject
- (nonnull instancetype)initWithHost:(nonnull ReactNativeHost *)host;
@end |
resources |
Here you should declare all resources that should be bundled with the app. The property can be a list of paths to resources: "resources": [
"dist/assets",
"dist/main.jsbundle"
] Or you can declare platform specific resources using platform names as key: "resources": {
"android": [
"dist/res",
"dist/main.android.jsbundle"
],
"ios": [
"dist/assets",
"dist/main.ios.jsbundle"
],
"macos": [
"dist/assets",
"dist/main.macos.jsbundle"
],
"windows": [
"dist/assets",
"dist/main.windows.bundle"
]
} A path must be relative to the path of |
android |
Android specific properties go here. |
.package |
Use this property to set the application ID of the APK. The value is set to |
.versionCode |
A positive integer used as an internal version number. Google uses this number
to determine whether one version is more recent than another. See
Version your app
for more on how it is used and how it differs from Introduced in 1.4.0. |
.icons |
Path to resources folder containing launcher icons for the app. If you're configuring icons for the first time, set this property to the path where you want to store your icons, then use Image Asset Studio to generate the assets. You can read more about Android adaptive icons in the Android documentation. Introduced in 1.6.0. |
.signingConfigs |
Use this to set the signing configurations for the app. The JSON schema follows the Gradle DSL very closely. Below is what one would add for the debug and release flavors: {
"android": {
"signingConfigs": {
"debug": { // optional
"keyAlias": "androiddebugkey", // defaults to "androiddebugkey"
"keyPassword": "android", // defaults to "android
"storeFile": "debug.keystore", // required
"storePassword": "android" // defaults to "android
},
"release": { // optional
"keyAlias": "androiddebugkey", // defaults to "androiddebugkey"
"keyPassword": "android", // defaults to "android
"storeFile": "release.keystore", // required
"storePassword": "android" // defaults to "android
}
}
}
} Introduced in 0.11.0. |
..debug |
Use this property for the debug signing config for the app. The value |
...keyAlias |
Use this property to specify the alias of key to use in the store |
...keyPassword |
Use this property to specify the password of key in the store |
...storeFile |
Use this property to specify the relative file path to the key store file |
...storePassword |
Use this property to specify the password of the key store |
..release |
Use this property for the release signing config for the app. The value |
...keyAlias |
Use this property to specify the alias of key to use in the store |
...keyPassword |
Use this property to specify the password of key in the store |
...storeFile |
Use this property to specify the relative file path to the key store file |
...storePassword |
Use this property to specify the password of the key store |
ios |
iOS specific properties go here. |
.bundleIdentifier |
Use this property to set the bundle identifier of the final app bundle. This is the same as setting |
.buildNumber |
Similar to The equivalent key in Introduced in 1.4.0. |
.icons |
Information about all of the icons used by the app. Icons for all sizes and scales are generated for you so long as you provide PNGs measuring 1024x1024 pixels here. You can read more about app icons in the Human Interface Guidelines. The equivalent key in Introduced in 1.6.0. |
..primaryIcon |
The primary icon for the Home screen and Settings app, among others. The equivalent key in |
..alternateIcons |
The primary icon for the Home screen and Settings app, among others. The equivalent key in |
.codeSignEntitlements |
Specifies the path to a custom
Entitlements
file. The path should be relative to This is the same as setting Introduced in 0.9.7. |
.codeSignIdentity |
Sets the code signing identity to use when signing code. This is the same as setting Introduced in 0.9.7. |
.developmentTeam |
Sets the development team that the app should be assigned to. This is the same as setting Introduced in 0.9.7. |
.reactNativePath |
Sets a custom path to React Native. Useful for when |
macos |
macOS specific properties go here. |
.bundleIdentifier |
Use this property to set the bundle identifier of the final app bundle. This is the same as setting |
.buildNumber |
Similar to The equivalent key in Introduced in 1.4.0. |
.icons |
Information about all of the icons used by the app. Icons for all sizes and scales are generated for you so long as you provide PNGs measuring 1024x1024 pixels here. You can read more about app icons in the Human Interface Guidelines. The equivalent key in Introduced in 1.6.0. |
..primaryIcon |
The primary icon for the Home screen and Settings app, among others. The equivalent key in |
..alternateIcons |
The primary icon for the Home screen and Settings app, among others. The equivalent key in |
.codeSignEntitlements |
Specifies the path to a custom
Entitlements
file. The path should be relative to This is the same as setting Introduced in 0.9.7. |
.codeSignIdentity |
Sets the code signing identity to use when signing code. This is the same as setting Introduced in 0.9.7. |
.developmentTeam |
Sets the development team that the app should be assigned to. This is the same as setting Introduced in 0.9.7. |
.reactNativePath |
Sets a custom path to React Native for macOS. Useful for when |
windows |
Windows specific properties go here. |
.appxManifest |
Sets the path to your
app
package manifest. If none is set, a default manifest will be provided.
Changes to this property will not be automatically be picked up; you need to
re-run Introduced in 0.5.5. |
.certificateKeyFile |
The path to the certificate to use. If specified, it will also enable package
signing. Changes to this property will not be automatically be picked up; you
need to re-run Introduced in 1.1.0. |
.certificatePassword |
The password for the private key in the certificate. Leave unset if no password.
Changes to this property will not be automatically be picked up; you need to
re-run Introduced in 1.1.0. |
.certificateThumbprint |
This value must match the thumbprint in the signing certificate, or be unset.
Changes to this property will not be automatically be picked up; you need to
re-run Introduced in 1.1.0. |