Skip to content

Instantly share code, notes, and snippets.

@charleswvs
Created December 13, 2021 14:48
Show Gist options
  • Save charleswvs/03355ca39c92cea7f2fbe89cc73093ac to your computer and use it in GitHub Desktop.
Save charleswvs/03355ca39c92cea7f2fbe89cc73093ac to your computer and use it in GitHub Desktop.
Visual Studio Code Settings Sync Gist
{"lastUpload":"2021-12-13T14:48:45.200Z","extensionVersion":"v3.4.3"}
[
{
"metadata": {
"id": "d3836729-9cc1-42c1-b2af-d50071f57d29",
"publisherId": "formulahendry.auto-close-tag",
"publisherDisplayName": "formulahendry"
},
"name": "auto-close-tag",
"publisher": "formulahendry",
"version": "0.5.13"
},
{
"metadata": {
"id": "6e440e71-8ed9-4f25-bb78-4b13096b8a03",
"publisherId": "formulahendry.auto-rename-tag",
"publisherDisplayName": "formulahendry"
},
"name": "auto-rename-tag",
"publisher": "formulahendry",
"version": "0.1.9"
},
{
"metadata": {
"id": "697255a9-3f36-44c8-b084-d3b91edfb23a",
"publisherId": "HookyQR.beautify",
"publisherDisplayName": "HookyQR"
},
"name": "beautify",
"publisher": "HookyQR",
"version": "1.5.0"
},
{
"metadata": {
"id": "b689fcc8-d494-4dbf-a228-2c694a578afc",
"publisherId": "alefragnani.Bookmarks",
"publisherDisplayName": "alefragnani"
},
"name": "Bookmarks",
"publisher": "alefragnani",
"version": "13.2.2"
},
{
"metadata": {
"id": "e337c67b-55c2-4fef-8949-eb260e7fb7fd",
"publisherId": "Shan.code-settings-sync",
"publisherDisplayName": "Shan"
},
"name": "code-settings-sync",
"publisher": "Shan",
"version": "3.4.3"
},
{
"metadata": {
"id": "121396ad-85a1-45ec-9fd1-d95028a847f5",
"publisherId": "naumovs.color-highlight",
"publisherDisplayName": "naumovs"
},
"name": "color-highlight",
"publisher": "naumovs",
"version": "2.5.0"
},
{
"metadata": {
"id": "23c4aeee-f844-43cd-b53e-1113e483f1a6",
"publisherId": "GitHub.copilot",
"publisherDisplayName": "GitHub"
},
"name": "copilot",
"publisher": "GitHub",
"version": "1.7.4016"
},
{
"metadata": {
"id": "f57f68ea-9ee8-42b5-9a97-041d3e4278c4",
"publisherId": "Dart-Code.dart-code",
"publisherDisplayName": "Dart-Code"
},
"name": "dart-code",
"publisher": "Dart-Code",
"version": "3.29.0"
},
{
"metadata": {
"id": "532533c9-a894-4a58-9eee-bbfbe7c06f71",
"publisherId": "mikestead.dotenv",
"publisherDisplayName": "mikestead"
},
"name": "dotenv",
"publisher": "mikestead",
"version": "1.0.1"
},
{
"metadata": {
"id": "f60a60a6-95ba-42d4-b41c-3d24c1b89588",
"publisherId": "EditorConfig.EditorConfig",
"publisherDisplayName": "EditorConfig"
},
"name": "EditorConfig",
"publisher": "EditorConfig",
"version": "0.16.4"
},
{
"metadata": {
"id": "9d8c32ab-354c-4daf-a9bf-20b633734435",
"publisherId": "usernamehw.errorlens",
"publisherDisplayName": "usernamehw"
},
"name": "errorlens",
"publisher": "usernamehw",
"version": "3.4.1"
},
{
"metadata": {
"id": "19804510-b475-4dae-b0f7-6ca08fd1af0c",
"publisherId": "dsznajder.es7-react-js-snippets",
"publisherDisplayName": "dsznajder"
},
"name": "es7-react-js-snippets",
"publisher": "dsznajder",
"version": "3.1.1"
},
{
"metadata": {
"id": "438221f8-1107-4ccd-a6fe-f3b7fe0856b7",
"publisherId": "mhutchie.git-graph",
"publisherDisplayName": "mhutchie"
},
"name": "git-graph",
"publisher": "mhutchie",
"version": "1.30.0"
},
{
"metadata": {
"id": "4de763bd-505d-4978-9575-2b7696ecf94e",
"publisherId": "eamodio.gitlens",
"publisherDisplayName": "eamodio"
},
"name": "gitlens",
"publisher": "eamodio",
"version": "11.7.0"
},
{
"metadata": {
"id": "9cd87837-c82a-4817-9b79-1c84775aa158",
"publisherId": "DigitalBrainstem.javascript-ejs-support",
"publisherDisplayName": "DigitalBrainstem"
},
"name": "javascript-ejs-support",
"publisher": "DigitalBrainstem",
"version": "1.3.1"
},
{
"metadata": {
"id": "a2cec723-5349-460d-9de9-0fd1f8d3456f",
"publisherId": "xabikos.JavaScriptSnippets",
"publisherDisplayName": "xabikos"
},
"name": "JavaScriptSnippets",
"publisher": "xabikos",
"version": "1.8.0"
},
{
"metadata": {
"id": "b63c44fd-0457-4696-99e9-dbfdf70d77de",
"publisherId": "ritwickdey.LiveServer",
"publisherDisplayName": "ritwickdey"
},
"name": "LiveServer",
"publisher": "ritwickdey",
"version": "5.6.1"
},
{
"metadata": {
"id": "98790d67-10fa-497c-9113-f6c7489207b2",
"publisherId": "yzhang.markdown-all-in-one",
"publisherDisplayName": "yzhang"
},
"name": "markdown-all-in-one",
"publisher": "yzhang",
"version": "3.4.0"
},
{
"metadata": {
"id": "5db78037-f674-459f-a236-db622c427c5b",
"publisherId": "PKief.material-icon-theme",
"publisherDisplayName": "PKief"
},
"name": "material-icon-theme",
"publisher": "PKief",
"version": "4.11.0"
},
{
"metadata": {
"id": "dff6b801-247e-40e9-82e8-8c9b1d19d1b8",
"publisherId": "christian-kohler.npm-intellisense",
"publisherDisplayName": "christian-kohler"
},
"name": "npm-intellisense",
"publisher": "christian-kohler",
"version": "1.4.0"
},
{
"metadata": {
"id": "a41c1549-4053-44d4-bf30-60fc809b4a86",
"publisherId": "christian-kohler.path-intellisense",
"publisherDisplayName": "christian-kohler"
},
"name": "path-intellisense",
"publisher": "christian-kohler",
"version": "2.6.0"
},
{
"metadata": {
"id": "96fa4707-6983-4489-b7c5-d5ffdfdcce90",
"publisherId": "esbenp.prettier-vscode",
"publisherDisplayName": "esbenp"
},
"name": "prettier-vscode",
"publisher": "esbenp",
"version": "9.0.0"
},
{
"metadata": {
"id": "1b747f06-3789-4ebd-ac99-f1fe430c3347",
"publisherId": "alefragnani.project-manager",
"publisherDisplayName": "alefragnani"
},
"name": "project-manager",
"publisher": "alefragnani",
"version": "12.4.0"
},
{
"metadata": {
"id": "aae0701b-111f-49c1-9000-abd37a442f28",
"publisherId": "WallabyJs.quokka-vscode",
"publisherDisplayName": "WallabyJs"
},
"name": "quokka-vscode",
"publisher": "WallabyJs",
"version": "1.0.432"
},
{
"metadata": {
"id": "797a79de-a0fd-4349-9034-bec47be9a941",
"publisherId": "2gua.rainbow-brackets",
"publisherDisplayName": "2gua"
},
"name": "rainbow-brackets",
"publisher": "2gua",
"version": "0.0.6"
},
{
"metadata": {
"id": "e8b469bd-915d-4070-bfc2-05c9b546f8ee",
"publisherId": "jakob101.RelativePath",
"publisherDisplayName": "jakob101"
},
"name": "RelativePath",
"publisher": "jakob101",
"version": "1.4.0"
},
{
"metadata": {
"id": "e8e6c9a6-cbd0-4812-b617-50ab45b749e4",
"publisherId": "rocketseat.rocketseatreactjs",
"publisherDisplayName": "rocketseat"
},
"name": "rocketseatreactjs",
"publisher": "rocketseat",
"version": "3.0.2"
},
{
"metadata": {
"id": "00b0e9ab-d798-487b-a542-8304240d0da4",
"publisherId": "rocketseat.rocketseatreactnative",
"publisherDisplayName": "rocketseat"
},
"name": "rocketseatreactnative",
"publisher": "rocketseat",
"version": "3.0.1"
},
{
"metadata": {
"id": "ce4fb505-c12b-486e-b608-8d390b179755",
"publisherId": "debens.sort-js-object",
"publisherDisplayName": "debens"
},
"name": "sort-js-object",
"publisher": "debens",
"version": "0.1.2"
},
{
"metadata": {
"id": "75da638c-c45a-44ea-aa3b-8570a3559810",
"publisherId": "TabNine.tabnine-vscode",
"publisherDisplayName": "TabNine"
},
"name": "tabnine-vscode",
"publisher": "TabNine",
"version": "3.5.5"
},
{
"metadata": {
"id": "4e44877c-1c8d-4f9c-ba86-1372d0fbeeb1",
"publisherId": "dracula-theme.theme-dracula",
"publisherDisplayName": "dracula-theme"
},
"name": "theme-dracula",
"publisher": "dracula-theme",
"version": "2.24.0"
},
{
"metadata": {
"id": "261cac81-cd7b-4555-bb41-0c2d2bcd3e70",
"publisherId": "Gruntfuggly.todo-tree",
"publisherDisplayName": "Gruntfuggly"
},
"name": "todo-tree",
"publisher": "Gruntfuggly",
"version": "0.0.214"
},
{
"metadata": {
"id": "b6b26bce-33f4-4bce-bf92-89812388ed0a",
"publisherId": "vivaxy.vscode-conventional-commits",
"publisherDisplayName": "vivaxy"
},
"name": "vscode-conventional-commits",
"publisher": "vivaxy",
"version": "1.23.0"
},
{
"metadata": {
"id": "ea6a6046-2132-421f-a984-664909fcf0b8",
"publisherId": "hediet.vscode-drawio",
"publisherDisplayName": "hediet"
},
"name": "vscode-drawio",
"publisher": "hediet",
"version": "1.6.3"
},
{
"metadata": {
"id": "583b2b34-2c1e-4634-8c0b-0b82e283ea3a",
"publisherId": "dbaeumer.vscode-eslint",
"publisherDisplayName": "dbaeumer"
},
"name": "vscode-eslint",
"publisher": "dbaeumer",
"version": "2.2.2"
},
{
"metadata": {
"id": "c46b0018-f317-4b6c-a785-d2039b27338f",
"publisherId": "wix.vscode-import-cost",
"publisherDisplayName": "wix"
},
"name": "vscode-import-cost",
"publisher": "wix",
"version": "2.15.0"
},
{
"metadata": {
"id": "daf8b44d-8aae-4da2-80c5-1f770219f643",
"publisherId": "DavidAnson.vscode-markdownlint",
"publisherDisplayName": "DavidAnson"
},
"name": "vscode-markdownlint",
"publisher": "DavidAnson",
"version": "0.45.0"
},
{
"metadata": {
"id": "ae9e3eb0-3357-4cc0-90ee-598d2d384757",
"publisherId": "eg2.vscode-npm-script",
"publisherDisplayName": "eg2"
},
"name": "vscode-npm-script",
"publisher": "eg2",
"version": "0.3.23"
},
{
"metadata": {
"id": "8e355385-0d4d-4908-aca4-c36da7282a6d",
"publisherId": "henriiik.vscode-sort",
"publisherDisplayName": "henriiik"
},
"name": "vscode-sort",
"publisher": "henriiik",
"version": "0.2.5"
},
{
"metadata": {
"id": "06cc3e44-aedb-41b8-a4ea-29ebf3c491fd",
"publisherId": "jpoissonnier.vscode-styled-components",
"publisherDisplayName": "jpoissonnier"
},
"name": "vscode-styled-components",
"publisher": "jpoissonnier",
"version": "1.7.0"
},
{
"metadata": {
"id": "a62050f5-0d1a-4503-bcfe-cc1a6129a9f7",
"publisherId": "cancerberosgx.vscode-typescript-refactors",
"publisherDisplayName": "cancerberosgx"
},
"name": "vscode-typescript-refactors",
"publisher": "cancerberosgx",
"version": "0.0.22"
},
{
"metadata": {
"id": "90a37ca1-92a2-488a-b196-7a8c0b0127ea",
"publisherId": "ms-vscode.vscode-typescript-tslint-plugin",
"publisherDisplayName": "ms-vscode"
},
"name": "vscode-typescript-tslint-plugin",
"publisher": "ms-vscode",
"version": "1.3.3"
},
{
"metadata": {
"id": "f2fd462f-f1bd-4c62-b54f-59a4e5ffc6a3",
"publisherId": "WakaTime.vscode-wakatime",
"publisherDisplayName": "WakaTime"
},
"name": "vscode-wakatime",
"publisher": "WakaTime",
"version": "17.1.0"
},
{
"metadata": {
"id": "0cb81da2-1880-4755-9995-0ae9cc728e20",
"publisherId": "DotJoshJohnson.xml",
"publisherDisplayName": "DotJoshJohnson"
},
"name": "xml",
"publisher": "DotJoshJohnson",
"version": "2.5.1"
}
]
{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","version":"39.0.0","additionalProperties":true,"required":["expo"],"definitions":{"AndroidIntentFiltersData":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}},"properties":{"expo":{"type":"object","properties":{"name":{"description":"The name of your app as it appears both within Expo client and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`","type":"string","meta":{"bareWorkflow":"To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"markdownDescription":"The name of your app as it appears both within Expo client and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"description":{"description":"A short description of what your app is and why it is great.","type":"string","markdownDescription":"A short description of what your app is and why it is great."},"slug":{"description":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project.","type":"string","pattern":"^[a-zA-Z0-9_\\-]+$","markdownDescription":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project."},"owner":{"description":"The Expo account name of the team owner, only applicable if you are enrolled in Expo Developer Services. If not provided, defaults to the username of the current user.","type":"string","minLength":1,"markdownDescription":"The Expo account name of the team owner, only applicable if you are enrolled in Expo Developer Services. If not provided, defaults to the username of the current user."},"privacy":{"description":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`.","enum":["public","unlisted","hidden"],"type":"string","fallback":"unlisted","markdownDescription":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`."},"sdkVersion":{"description":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.","type":"string","pattern":"^(\\d+\\.\\d+\\.\\d+)|(UNVERSIONED)$","markdownDescription":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json."},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml.","type":"string","pattern":"^[0-9\\.]+$","markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml."},"version":{"description":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`","type":"string","meta":{"bareWorkflow":"To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"markdownDescription":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"platforms":{"description":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`.","example":["ios","android","web"],"type":"array","uniqueItems":true,"items":{"type":"string","enum":["android","ios","web"]},"markdownDescription":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`."},"githubUrl":{"description":"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.","pattern":"^https://github\\.com/","example":"https://github.com/expo/expo","type":["string"],"markdownDescription":"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."},"orientation":{"description":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`","enum":["default","portrait","landscape"],"type":"string","markdownDescription":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"backgroundColor":{"description":"The background color for your app, behind any of your React views. This is also known as the root view background color.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`. Default is white: `'#ffffff'`"},"markdownDescription":"The background color for your app, behind any of your React views. This is also known as the root view background color."},"primaryColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"icon":{"description":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true,"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"markdownDescription":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"notification":{"description":"Configuration for remote (push) notifications.","type":"object","properties":{"icon":{"description":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon."},"color":{"description":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`"},"iosDisplayInForeground":{"description":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`.","type":"boolean","markdownDescription":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`."},"androidMode":{"description":"Show each push notification individually (`default`) or collapse into one (`collapse`).","enum":["default","collapse"],"type":"string","markdownDescription":"Show each push notification individually (`default`) or collapse into one (`collapse`)."},"androidCollapsedTitle":{"description":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`.","type":"string","markdownDescription":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`."}},"additionalProperties":false,"markdownDescription":"Configuration for remote (push) notifications."},"loading":{"description":"@deprecated Use `splash` instead. Configuration for the loading screen that users see when opening your app, while fetching & caching bundle and assets.","type":"object","properties":{"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"exponentIconColor":{"description":"If no icon is provided, we will show the Expo logo. You can choose between `white` and `blue`.","enum":["white","blue"],"type":"string","markdownDescription":"If no icon is provided, we will show the Expo logo. You can choose between `white` and `blue`."},"exponentIconGrayscale":{"description":"Similar to `exponentIconColor` but instead indicate if it should be grayscale (`1`) or not (`0`).","type":"number","minimum":0,"maximum":1,"markdownDescription":"Similar to `exponentIconColor` but instead indicate if it should be grayscale (`1`) or not (`0`)."},"backgroundImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"hideExponentText":{"description":"By default, Expo shows some text at the bottom of the loading screen. Set this to `true` to disable.","type":"boolean","markdownDescription":"By default, Expo shows some text at the bottom of the loading screen. Set this to `true` to disable."},"loadingIndicatorStyleExperimental":{"description":"@deprecated Previously used for changing the style of the iOS loading indicator.","type":"string","pattern":"^light$","meta":{"autogenerated":true},"markdownDescription":"@deprecated Previously used for changing the style of the iOS loading indicator."}},"meta":{"deprecated":true},"additionalProperties":false,"markdownDescription":"@deprecated Use `splash` instead. Configuration for the loading screen that users see when opening your app, while fetching & caching bundle and assets."},"appKey":{"description":"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.","type":"string","markdownDescription":"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."},"androidStatusBarColor":{"description":"@deprecated Use `androidStatusBar` instead.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"deprecated":true,"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"@deprecated Use `androidStatusBar` instead."},"androidStatusBar":{"description":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/).","type":"object","properties":{"barStyle":{"description":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`"},"backgroundColor":{"description":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string `'#RRGGBBAA'`, for example, `'#000000'` for black. Or 8 character long hex color string `'#RRGGBBAA'`, for example, `'#00000088'` for semi-transparent black."},"markdownDescription":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style"},"hidden":{"description":"Instructs the system whether the status bar should be visible or not. Defaults to `false`","type":"boolean","markdownDescription":"Instructs the system whether the status bar should be visible or not. Defaults to `false`"},"translucent":{"description":"Specifies whether the status bar should be translucent (whether it should be treated as a block element that will take up space on the device's screen and limit space available for the rest of your app to be rendered, or be treated as an element with `'position = absolute'` that is rendered above your app's content). Defaults to `true` (default iOS behavior, the iOS status bar cannot be set translucent by the system)","type":"boolean","markdownDescription":"Specifies whether the status bar should be translucent (whether it should be treated as a block element that will take up space on the device's screen and limit space available for the rest of your app to be rendered, or be treated as an element with `'position = absolute'` that is rendered above your app's content). Defaults to `true` (default iOS behavior, the iOS status bar cannot be set translucent by the system)"}},"additionalProperties":false,"markdownDescription":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/)."},"androidNavigationBar":{"description":"Configuration for the bottom navigation bar on Android.","type":"object","properties":{"visible":{"description":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time","type":"string","enum":["leanback","immersive","sticky-immersive"],"markdownDescription":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time"},"barStyle":{"description":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`"},"backgroundColor":{"description":"Specifies the background color of the navigation bar.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Specifies the background color of the navigation bar."}},"additionalProperties":false,"markdownDescription":"Configuration for the bottom navigation bar on Android."},"androidShowExponentNotificationInShellApp":{"description":"Adds a notification to your standalone app with refresh button and debug info.","type":"boolean","markdownDescription":"Adds a notification to your standalone app with refresh button and debug info."},"developmentClient":{"description":"Settings that apply specifically to running this app in a development client","type":"object","properties":{"silentLaunch":{"description":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app.","type":"boolean","fallback":false,"markdownDescription":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app."}},"additionalProperties":false,"markdownDescription":"Settings that apply specifically to running this app in a development client"},"scheme":{"description":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`","type":"string","pattern":"^[a-z][a-z0-9+.-]*$","meta":{"regexHuman":"String beginning with a **lowercase** letter followed by any combination of **lowercase** letters, digits, \"+\", \".\" or \"-\"","standaloneOnly":true,"bareWorkflow":"To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"markdownDescription":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"entryPoint":{"description":"The relative path to your main JavaScript file.","type":"string","markdownDescription":"The relative path to your main JavaScript file."},"extra":{"description":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))"},"rnCliPath":{"type":"string"},"packagerOpts":{"type":"object","properties":{},"additionalProperties":true},"ignoreNodeModulesValidation":{"type":"boolean"},"nodeModulesPath":{"type":"string"},"updates":{"description":"Configuration for how and when the app should request OTA JavaScript updates","type":"object","properties":{"enabled":{"description":"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: This will not work out of the box with ExpoKit projects)","type":"boolean","markdownDescription":"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: This will not work out of the box with ExpoKit projects)"},"checkAutomatically":{"description":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`","enum":["ON_ERROR_RECOVERY","ON_LOAD"],"type":"string","markdownDescription":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`"},"fallbackToCacheTimeout":{"description":"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). Must be between 0 and 300000 (5 minutes).","type":"number","minimum":0,"maximum":300000,"markdownDescription":"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). Must be between 0 and 300000 (5 minutes)."}},"additionalProperties":false,"markdownDescription":"Configuration for how and when the app should request OTA JavaScript updates"},"locales":{"description":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode.","type":"object","properties":{},"meta":{"bareWorkflow":"To add or change language and localization information in your iOS app, you need to use Xcode."},"additionalProperties":{"type":["string","object"]},"markdownDescription":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode."},"ios":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\-\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"isRemoteJSEnabled":{"description":"@deprecated Use `updates.enabled` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates.enabled` instead."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"loadJSInBackgroundExperimental":{"description":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/uikit/core_app/allowing_apps_and_websites_to_link_to_your_content/enabling_universal_links). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/uikit/inter-process_communication/allowing_apps_and_websites_to_link_to_your_content/enabling_universal_links) for details.","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. See [Apple's docs for details](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_associated-domains)","bareWorkflow":"Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/uikit/inter-process_communication/allowing_apps_and_websites_to_link_to_your_content/enabling_universal_links) for details."},"markdownDescription":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/uikit/core_app/allowing_apps_and_websites_to_link_to_your_content/enabling_universal_links). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/uikit/inter-process_communication/allowing_apps_and_websites_to_link_to_your_content/enabling_universal_links) for details."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode to set this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode to set this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo client.","type":"string","meta":{"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo client."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"userInterfaceStyle":{"description":"Supported user interface styles. If left blank, `light` will be used. Use `automatic` if you would like to support either `light` or `dark` depending on iOS settings.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"Supported user interface styles. If left blank, `light` will be used. Use `automatic` if you would like to support either `light` or `dark` depending on iOS settings."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"enableDangerousExperimentalLeanBuilds":{"description":"If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependecies","type":"boolean","markdownDescription":"If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependecies"},"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be an integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be an integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"description":"A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n","type":"array","bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n"},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.","type":"string","bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"$ref":"#/definitions/AndroidIntentFiltersData"},{"type":["array"],"items":{"$ref":"#/definitions/AndroidIntentFiltersData"}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."},"facebookAppId":{"description":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^[0-9]+$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAutoInitEnabled":{"description":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`.","type":"boolean","markdownDescription":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`."},"facebookAutoLogAppEventsEnabled":{"description":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAdvertiserIDCollectionEnabled":{"description":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookDisplayName":{"description":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookScheme":{"description":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo clients).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^fb[0-9]+[A-Za-z]*$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo clients).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"isDetached":{"description":"Is app detached","type":"boolean","meta":{"autogenerated":true},"markdownDescription":"Is app detached"},"detach":{"description":"Extra fields needed by detached apps","type":"object","properties":{},"meta":{"autogenerated":true},"additionalProperties":true,"markdownDescription":"Extra fields needed by detached apps"},"splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"hooks":{"description":"Configuration for scripts to run to hook into the publish process","type":"object","additionalProperties":false,"properties":{"postPublish":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}},"postExport":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}}},"markdownDescription":"Configuration for scripts to run to hook into the publish process"},"assetBundlePatterns":{"description":"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](https://docs.expo.io/guides/offline-support/)","type":"array","items":{"type":"string"},"markdownDescription":"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](https://docs.expo.io/guides/offline-support/)"},"experiments":{"description":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices.","type":"object","additionalProperties":false,"properties":{"turboModules":{"description":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging.","type":"boolean","fallback":false,"markdownDescription":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging."}},"markdownDescription":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices."}},"additionalProperties":false,"required":["name","slug"]}}}
{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","version":"40.0.0","additionalProperties":true,"required":["expo"],"definitions":{"Android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"enableDangerousExperimentalLeanBuilds":{"description":"If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependecies","type":"boolean","markdownDescription":"If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependecies"},"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"description":"A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n","type":"array","bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n"},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.","type":"string","bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"$ref":"#/definitions/AndroidIntentFiltersData"},{"type":["array"],"items":{"$ref":"#/definitions/AndroidIntentFiltersData"}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"AndroidIntentFiltersData":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},"IOS":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\-\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"isRemoteJSEnabled":{"description":"@deprecated Use `updates.enabled` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates.enabled` instead."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"loadJSInBackgroundExperimental":{"description":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details.","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. See [Apple's docs for details](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)","bareWorkflow":"Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"markdownDescription":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in Expo Go.","type":"string","meta":{"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"userInterfaceStyle":{"description":"Supported user interface styles. If left blank, `light` will be used. Use `automatic` if you would like to support either `light` or `dark` depending on iOS settings.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"Supported user interface styles. If left blank, `light` will be used. Use `automatic` if you would like to support either `light` or `dark` depending on iOS settings."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"Splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"PublishHook":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}},"Web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."}},"properties":{"expo":{"type":"object","properties":{"name":{"description":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`","type":"string","meta":{"bareWorkflow":"To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"markdownDescription":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"description":{"description":"A short description of what your app is and why it is great.","type":"string","markdownDescription":"A short description of what your app is and why it is great."},"slug":{"description":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project.","type":"string","pattern":"^[a-zA-Z0-9_\\-]+$","markdownDescription":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project."},"owner":{"description":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user.","type":"string","minLength":1,"markdownDescription":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user."},"privacy":{"description":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`.","enum":["public","unlisted","hidden"],"type":"string","fallback":"unlisted","markdownDescription":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`."},"sdkVersion":{"description":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.","type":"string","pattern":"^(\\d+\\.\\d+\\.\\d+)|(UNVERSIONED)$","markdownDescription":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json."},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml.","type":"string","pattern":"^[0-9\\.]+$","markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml."},"version":{"description":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`","type":"string","meta":{"bareWorkflow":"To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"markdownDescription":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"platforms":{"description":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`.","example":["ios","android","web"],"type":"array","uniqueItems":true,"items":{"type":"string","enum":["android","ios","web"]},"markdownDescription":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`."},"githubUrl":{"description":"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.","pattern":"^https://github\\.com/","example":"https://github.com/expo/expo","type":["string"],"markdownDescription":"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."},"orientation":{"description":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`","enum":["default","portrait","landscape"],"type":"string","markdownDescription":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"backgroundColor":{"description":"The background color for your app, behind any of your React views. This is also known as the root view background color.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`. Default is white: `'#ffffff'`"},"markdownDescription":"The background color for your app, behind any of your React views. This is also known as the root view background color."},"primaryColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"icon":{"description":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true,"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"markdownDescription":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"notification":{"description":"Configuration for remote (push) notifications.","type":"object","properties":{"icon":{"description":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon."},"color":{"description":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`"},"iosDisplayInForeground":{"description":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`.","type":"boolean","markdownDescription":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`."},"androidMode":{"description":"Show each push notification individually (`default`) or collapse into one (`collapse`).","enum":["default","collapse"],"type":"string","markdownDescription":"Show each push notification individually (`default`) or collapse into one (`collapse`)."},"androidCollapsedTitle":{"description":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`.","type":"string","markdownDescription":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`."}},"additionalProperties":false,"markdownDescription":"Configuration for remote (push) notifications."},"appKey":{"description":"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.","type":"string","markdownDescription":"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."},"androidStatusBarColor":{"description":"@deprecated Use `androidStatusBar` instead.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"deprecated":true,"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"@deprecated Use `androidStatusBar` instead."},"androidStatusBar":{"description":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/).","type":"object","properties":{"barStyle":{"description":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`"},"backgroundColor":{"description":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string `'#RRGGBB'`, for example, `'#000000'` for black. Or 8 character long hex color string `'#RRGGBBAA'`, for example, `'#00000088'` for semi-transparent black."},"markdownDescription":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style"},"hidden":{"description":"Instructs the system whether the status bar should be visible or not. Defaults to `false`","type":"boolean","markdownDescription":"Instructs the system whether the status bar should be visible or not. Defaults to `false`"},"translucent":{"description":"Specifies whether the status bar should be translucent (whether it should be treated as a block element that will take up space on the device's screen and limit space available for the rest of your app to be rendered, or be treated as an element with `'position = absolute'` that is rendered above your app's content). Defaults to `true` (default iOS behavior, the iOS status bar cannot be set translucent by the system)","type":"boolean","markdownDescription":"Specifies whether the status bar should be translucent (whether it should be treated as a block element that will take up space on the device's screen and limit space available for the rest of your app to be rendered, or be treated as an element with `'position = absolute'` that is rendered above your app's content). Defaults to `true` (default iOS behavior, the iOS status bar cannot be set translucent by the system)"}},"additionalProperties":false,"markdownDescription":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/)."},"androidNavigationBar":{"description":"Configuration for the bottom navigation bar on Android.","type":"object","properties":{"visible":{"description":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time","type":"string","enum":["leanback","immersive","sticky-immersive"],"markdownDescription":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time"},"barStyle":{"description":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`"},"backgroundColor":{"description":"Specifies the background color of the navigation bar.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Specifies the background color of the navigation bar."}},"additionalProperties":false,"markdownDescription":"Configuration for the bottom navigation bar on Android."},"developmentClient":{"description":"Settings that apply specifically to running this app in a development client","type":"object","properties":{"silentLaunch":{"description":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app.","type":"boolean","fallback":false,"markdownDescription":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app."}},"additionalProperties":false,"markdownDescription":"Settings that apply specifically to running this app in a development client"},"scheme":{"description":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`","type":"string","pattern":"^[a-z][a-z0-9+.-]*$","meta":{"regexHuman":"String beginning with a **lowercase** letter followed by any combination of **lowercase** letters, digits, \"+\", \".\" or \"-\"","standaloneOnly":true,"bareWorkflow":"To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"markdownDescription":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"entryPoint":{"description":"The relative path to your main JavaScript file.","type":"string","markdownDescription":"The relative path to your main JavaScript file."},"extra":{"description":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))"},"packagerOpts":{"description":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)","meta":{"deprecated":true,"autogenerated":true},"type":"object","properties":{},"additionalProperties":true,"markdownDescription":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)"},"ignoreNodeModulesValidation":{"type":"boolean"},"nodeModulesPath":{"type":"string"},"updates":{"description":"Configuration for how and when the app should request OTA JavaScript updates","type":"object","properties":{"enabled":{"description":"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: This will not work out of the box with ExpoKit projects)","type":"boolean","markdownDescription":"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: This will not work out of the box with ExpoKit projects)"},"checkAutomatically":{"description":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`","enum":["ON_ERROR_RECOVERY","ON_LOAD"],"type":"string","markdownDescription":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`"},"fallbackToCacheTimeout":{"description":"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). Must be between 0 and 300000 (5 minutes).","type":"number","minimum":0,"maximum":300000,"markdownDescription":"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). Must be between 0 and 300000 (5 minutes)."}},"additionalProperties":false,"markdownDescription":"Configuration for how and when the app should request OTA JavaScript updates"},"locales":{"description":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode.","type":"object","properties":{},"meta":{"bareWorkflow":"To add or change language and localization information in your iOS app, you need to use Xcode."},"additionalProperties":{"type":["string","object"]},"markdownDescription":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode."},"facebookAppId":{"description":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^[0-9]+$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAutoInitEnabled":{"description":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`.","type":"boolean","markdownDescription":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`."},"facebookAutoLogAppEventsEnabled":{"description":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAdvertiserIDCollectionEnabled":{"description":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookDisplayName":{"description":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookScheme":{"description":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^fb[0-9]+[A-Za-z]*$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"isDetached":{"description":"Is app detached","type":"boolean","meta":{"autogenerated":true},"markdownDescription":"Is app detached"},"detach":{"description":"Extra fields needed by detached apps","type":"object","properties":{},"meta":{"autogenerated":true},"additionalProperties":true,"markdownDescription":"Extra fields needed by detached apps"},"assetBundlePatterns":{"description":"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](https://docs.expo.io/guides/offline-support/)","type":"array","items":{"type":"string"},"markdownDescription":"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](https://docs.expo.io/guides/offline-support/)"},"splash":{"$ref":"#/definitions/Splash"},"ios":{"$ref":"#/definitions/IOS"},"android":{"$ref":"#/definitions/Android"},"web":{"$ref":"#/definitions/Web"},"hooks":{"description":"Configuration for scripts to run to hook into the publish process","type":"object","additionalProperties":false,"properties":{"postPublish":{"type":"array","items":{"$ref":"#/definitions/PublishHook"}},"postExport":{"type":"array","items":{"$ref":"#/definitions/PublishHook"}}},"markdownDescription":"Configuration for scripts to run to hook into the publish process"},"experiments":{"description":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices.","type":"object","additionalProperties":false,"properties":{"turboModules":{"description":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging.","type":"boolean","fallback":false,"markdownDescription":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging."}},"markdownDescription":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices."}},"additionalProperties":false,"required":["name","slug"]}}}
{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","version":"41.0.0","additionalProperties":true,"required":["expo"],"definitions":{"Android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"enableDangerousExperimentalLeanBuilds":{"description":"@deprecated Use EAS Build or compile locally instead. If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependencies","type":"boolean","markdownDescription":"@deprecated Use EAS Build or compile locally instead. If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependencies"},"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"description":"A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n","type":"array","bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n"},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.","type":"string","bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"AndroidIntentFiltersData":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},"IOS":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"isRemoteJSEnabled":{"description":"@deprecated Use `updates.enabled` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates.enabled` instead."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"loadJSInBackgroundExperimental":{"description":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details.","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. See [Apple's docs for details](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)","bareWorkflow":"Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"markdownDescription":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"Splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"PublishHook":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}},"Web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."}},"properties":{"expo":{"type":"object","properties":{"name":{"description":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`","type":"string","meta":{"bareWorkflow":"To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"markdownDescription":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"description":{"description":"A short description of what your app is and why it is great.","type":"string","markdownDescription":"A short description of what your app is and why it is great."},"slug":{"description":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project.","type":"string","pattern":"^[a-zA-Z0-9_\\-]+$","markdownDescription":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project."},"owner":{"description":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user.","type":"string","minLength":1,"markdownDescription":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user."},"currentFullName":{"description":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed.","type":"string","autogenerated":true,"markdownDescription":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed."},"originalFullName":{"description":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed.","type":"string","autogenerated":true,"markdownDescription":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed."},"privacy":{"description":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`.","enum":["public","unlisted","hidden"],"type":"string","fallback":"unlisted","markdownDescription":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`."},"sdkVersion":{"description":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.","type":"string","pattern":"^(\\d+\\.\\d+\\.\\d+)|(UNVERSIONED)$","markdownDescription":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json."},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml.","type":"string","pattern":"^[0-9\\.]+$","markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml."},"version":{"description":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`","type":"string","meta":{"bareWorkflow":"To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"markdownDescription":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"platforms":{"description":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`.","example":["ios","android","web"],"type":"array","uniqueItems":true,"items":{"type":"string","enum":["android","ios","web"]},"markdownDescription":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`."},"githubUrl":{"description":"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.","pattern":"^https://github\\.com/","example":"https://github.com/expo/expo","type":["string"],"markdownDescription":"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."},"orientation":{"description":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`","enum":["default","portrait","landscape"],"type":"string","markdownDescription":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"backgroundColor":{"description":"The background color for your app, behind any of your React views. This is also known as the root view background color.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`. Default is white: `'#ffffff'`"},"markdownDescription":"The background color for your app, behind any of your React views. This is also known as the root view background color."},"primaryColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"icon":{"description":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true,"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"markdownDescription":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"notification":{"description":"Configuration for remote (push) notifications.","type":"object","properties":{"icon":{"description":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon."},"color":{"description":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`"},"iosDisplayInForeground":{"description":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`.","type":"boolean","markdownDescription":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`."},"androidMode":{"description":"Show each push notification individually (`default`) or collapse into one (`collapse`).","enum":["default","collapse"],"type":"string","markdownDescription":"Show each push notification individually (`default`) or collapse into one (`collapse`)."},"androidCollapsedTitle":{"description":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`.","type":"string","markdownDescription":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`."}},"additionalProperties":false,"markdownDescription":"Configuration for remote (push) notifications."},"appKey":{"description":"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.","type":"string","markdownDescription":"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."},"androidStatusBarColor":{"description":"@deprecated Use `androidStatusBar` instead.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"deprecated":true,"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"@deprecated Use `androidStatusBar` instead."},"androidStatusBar":{"description":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/).","type":"object","properties":{"barStyle":{"description":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`"},"backgroundColor":{"description":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string `'#RRGGBB'`, for example, `'#000000'` for black. Or 8 character long hex color string `'#RRGGBBAA'`, for example, `'#00000088'` for semi-transparent black."},"markdownDescription":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style"},"hidden":{"description":"Instructs the system whether the status bar should be visible or not. Defaults to `false`","type":"boolean","markdownDescription":"Instructs the system whether the status bar should be visible or not. Defaults to `false`"},"translucent":{"description":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content).","type":"boolean","markdownDescription":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content)."}},"additionalProperties":false,"markdownDescription":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/)."},"androidNavigationBar":{"description":"Configuration for the bottom navigation bar on Android.","type":"object","properties":{"visible":{"description":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time","type":"string","enum":["leanback","immersive","sticky-immersive"],"markdownDescription":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time"},"barStyle":{"description":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`"},"backgroundColor":{"description":"Specifies the background color of the navigation bar.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Specifies the background color of the navigation bar."}},"additionalProperties":false,"markdownDescription":"Configuration for the bottom navigation bar on Android."},"developmentClient":{"description":"Settings that apply specifically to running this app in a development client","type":"object","properties":{"silentLaunch":{"description":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app.","type":"boolean","fallback":false,"markdownDescription":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app."}},"additionalProperties":false,"markdownDescription":"Settings that apply specifically to running this app in a development client"},"scheme":{"description":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`","type":"string","pattern":"^[a-z][a-z0-9+.-]*$","meta":{"regexHuman":"String beginning with a **lowercase** letter followed by any combination of **lowercase** letters, digits, \"+\", \".\" or \"-\"","standaloneOnly":true,"bareWorkflow":"To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"markdownDescription":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"entryPoint":{"description":"The relative path to your main JavaScript file.","type":"string","markdownDescription":"The relative path to your main JavaScript file."},"extra":{"description":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))"},"packagerOpts":{"description":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)","meta":{"deprecated":true,"autogenerated":true},"type":"object","properties":{},"additionalProperties":true,"markdownDescription":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)"},"updates":{"description":"Configuration for how and when the app should request OTA JavaScript updates","type":"object","properties":{"enabled":{"description":"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: This will not work out of the box with ExpoKit projects)","type":"boolean","markdownDescription":"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: This will not work out of the box with ExpoKit projects)"},"checkAutomatically":{"description":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`","enum":["ON_ERROR_RECOVERY","ON_LOAD"],"type":"string","markdownDescription":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`"},"fallbackToCacheTimeout":{"description":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes).","type":"number","minimum":0,"maximum":300000,"markdownDescription":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes)."}},"additionalProperties":false,"markdownDescription":"Configuration for how and when the app should request OTA JavaScript updates"},"locales":{"description":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode.","type":"object","properties":{},"meta":{"bareWorkflow":"To add or change language and localization information in your iOS app, you need to use Xcode."},"additionalProperties":{"type":["string","object"]},"markdownDescription":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode."},"facebookAppId":{"description":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^[0-9]+$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAutoInitEnabled":{"description":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`.","type":"boolean","markdownDescription":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`."},"facebookAutoLogAppEventsEnabled":{"description":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAdvertiserIDCollectionEnabled":{"description":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookDisplayName":{"description":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookScheme":{"description":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^fb[0-9]+[A-Za-z]*$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"isDetached":{"description":"Is app detached","type":"boolean","meta":{"autogenerated":true},"markdownDescription":"Is app detached"},"detach":{"description":"Extra fields needed by detached apps","type":"object","properties":{},"meta":{"autogenerated":true},"additionalProperties":true,"markdownDescription":"Extra fields needed by detached apps"},"assetBundlePatterns":{"description":"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](https://docs.expo.io/guides/offline-support/)","type":"array","items":{"type":"string"},"markdownDescription":"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](https://docs.expo.io/guides/offline-support/)"},"plugins":{"description":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.io/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build","meta":{"bareWorkflow":"Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"type":"array","items":{"anyOf":[{"type":["string"]},{"type":"array","items":[{"type":["string"]},{}],"additionalItems":false}]},"markdownDescription":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.io/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"ios":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"isRemoteJSEnabled":{"description":"@deprecated Use `updates.enabled` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates.enabled` instead."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"loadJSInBackgroundExperimental":{"description":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead.","type":"boolean","meta":{"deprecated":true},"markdownDescription":"@deprecated Use `updates` key with `fallbackToCacheTimeout: 0` instead."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details.","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. See [Apple's docs for details](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)","bareWorkflow":"Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"markdownDescription":"An array that contains Associated Domains for the standalone app. See [Apple's docs for config](https://developer.apple.com/documentation/safariservices/supporting_associated_domains). \n\n**Bare workflow** - Use Xcode to set this. See [Apple's documentation](https://developer.apple.com/documentation/safariservices/supporting_associated_domains) for details."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"enableDangerousExperimentalLeanBuilds":{"description":"@deprecated Use EAS Build or compile locally instead. If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependencies","type":"boolean","markdownDescription":"@deprecated Use EAS Build or compile locally instead. If set to true, APK will contain only unimodules that are explicitly added in package.json and their dependencies"},"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"description":"A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n","type":"array","bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n"},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.","type":"string","bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."},"hooks":{"description":"Configuration for scripts to run to hook into the publish process","type":"object","additionalProperties":false,"properties":{"postPublish":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}},"postExport":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}}},"markdownDescription":"Configuration for scripts to run to hook into the publish process"},"experiments":{"description":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices.","type":"object","additionalProperties":false,"properties":{"turboModules":{"description":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging.","type":"boolean","fallback":false,"markdownDescription":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging."}},"markdownDescription":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices."},"_internal":{"description":"Internal properties for developer tools","type":"object","properties":{"pluginHistory":{"description":"List of plugins already run on the config","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"List of plugins already run on the config"}},"additionalProperties":true,"markdownDescription":"Internal properties for developer tools"}},"additionalProperties":false,"required":["name","slug"]}}}
{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","version":"42.0.0","additionalProperties":true,"required":["expo"],"definitions":{"Android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"deprecated":true,"description":"@deprecated A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"@deprecated A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","type":"array","meta":{"bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`","type":"string","meta":{"bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`"},"markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`"},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."},"jsEngine":{"description":"Specifies the JavaScript engine. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"markdownDescription":"Specifies the JavaScript engine. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"AndroidIntentFiltersData":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},"IOS":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleVersion`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","bareWorkflow":"Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"markdownDescription":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"Splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"PublishHook":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}},"Web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."}},"properties":{"expo":{"type":"object","properties":{"name":{"description":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`","type":"string","meta":{"bareWorkflow":"To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"markdownDescription":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"description":{"description":"A short description of what your app is and why it is great.","type":"string","markdownDescription":"A short description of what your app is and why it is great."},"slug":{"description":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project.","type":"string","pattern":"^[a-zA-Z0-9_\\-]+$","markdownDescription":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.io/@project-owner/myAppName` project."},"owner":{"description":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user.","type":"string","minLength":1,"markdownDescription":"The Expo account name of the team owner, only applicable if you are enrolled in the EAS Priority Plan. If not provided, defaults to the username of the current user."},"currentFullName":{"description":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed."},"originalFullName":{"description":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed."},"privacy":{"description":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`.","enum":["public","unlisted","hidden"],"type":"string","fallback":"unlisted","markdownDescription":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`."},"sdkVersion":{"description":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.","type":"string","pattern":"^(\\d+\\.\\d+\\.\\d+)|(UNVERSIONED)$","markdownDescription":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json."},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml.","type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\" or \"-\". Example: \"1.0.3a+\"."},"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for bare workflow projects. If provided, this must match the version set in Expo.plist or AndroidManifest.xml."},"version":{"description":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`","type":"string","meta":{"bareWorkflow":"To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"markdownDescription":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.io/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"platforms":{"description":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`.","example":["ios","android","web"],"type":"array","uniqueItems":true,"items":{"type":"string","enum":["android","ios","web"]},"markdownDescription":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`."},"githubUrl":{"description":"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.","pattern":"^https://github\\.com/","example":"https://github.com/expo/expo","type":["string"],"markdownDescription":"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."},"orientation":{"description":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`","enum":["default","portrait","landscape"],"type":"string","markdownDescription":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"backgroundColor":{"description":"The background color for your app, behind any of your React views. This is also known as the root view background color.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`. Default is white: `'#ffffff'`"},"markdownDescription":"The background color for your app, behind any of your React views. This is also known as the root view background color."},"primaryColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"icon":{"description":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true,"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"markdownDescription":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"notification":{"description":"Configuration for remote (push) notifications.","type":"object","properties":{"icon":{"description":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon."},"color":{"description":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`"},"iosDisplayInForeground":{"description":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`.","type":"boolean","markdownDescription":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.io/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`."},"androidMode":{"description":"Show each push notification individually (`default`) or collapse into one (`collapse`).","enum":["default","collapse"],"type":"string","markdownDescription":"Show each push notification individually (`default`) or collapse into one (`collapse`)."},"androidCollapsedTitle":{"description":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`.","type":"string","markdownDescription":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`."}},"additionalProperties":false,"markdownDescription":"Configuration for remote (push) notifications."},"appKey":{"description":"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.","type":"string","markdownDescription":"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."},"androidStatusBar":{"description":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/).","type":"object","properties":{"barStyle":{"description":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`"},"backgroundColor":{"description":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string `'#RRGGBB'`, for example, `'#000000'` for black. Or 8 character long hex color string `'#RRGGBBAA'`, for example, `'#00000088'` for semi-transparent black."},"markdownDescription":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style"},"hidden":{"description":"Instructs the system whether the status bar should be visible or not. Defaults to `false`","type":"boolean","markdownDescription":"Instructs the system whether the status bar should be visible or not. Defaults to `false`"},"translucent":{"description":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content).","type":"boolean","markdownDescription":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content)."}},"additionalProperties":false,"markdownDescription":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.io/guides/configuring-statusbar/)."},"androidNavigationBar":{"description":"Configuration for the bottom navigation bar on Android.","type":"object","properties":{"visible":{"description":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time","type":"string","enum":["leanback","immersive","sticky-immersive"],"markdownDescription":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time"},"barStyle":{"description":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`"},"backgroundColor":{"description":"Specifies the background color of the navigation bar.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Specifies the background color of the navigation bar."}},"additionalProperties":false,"markdownDescription":"Configuration for the bottom navigation bar on Android."},"developmentClient":{"description":"Settings that apply specifically to running this app in a development client","type":"object","properties":{"silentLaunch":{"description":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app.","type":"boolean","fallback":false,"markdownDescription":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app."}},"additionalProperties":false,"markdownDescription":"Settings that apply specifically to running this app in a development client"},"scheme":{"description":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`","type":"string","pattern":"^[a-z][a-z0-9+.-]*$","meta":{"regexHuman":"String beginning with a **lowercase** letter followed by any combination of **lowercase** letters, digits, \"+\", \".\" or \"-\"","standaloneOnly":true,"bareWorkflow":"To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"markdownDescription":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"entryPoint":{"description":"The relative path to your main JavaScript file.","type":"string","markdownDescription":"The relative path to your main JavaScript file."},"extra":{"description":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.io/versions/latest/sdk/constants/#constantsmanifest))"},"packagerOpts":{"description":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)","meta":{"deprecated":true,"autogenerated":true},"type":"object","properties":{},"additionalProperties":true,"markdownDescription":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.io/guides/customizing-metro/)"},"updates":{"description":"Configuration for how and when the app should request OTA JavaScript updates","type":"object","properties":{"enabled":{"description":"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 app store review. Defaults to true. (Note: This will not work out of the box with ExpoKit projects)","type":"boolean","markdownDescription":"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 app store review. Defaults to true. (Note: This will not work out of the box with ExpoKit projects)"},"checkAutomatically":{"description":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`","enum":["ON_ERROR_RECOVERY","ON_LOAD"],"type":"string","markdownDescription":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`"},"fallbackToCacheTimeout":{"description":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes).","type":"number","minimum":0,"maximum":300000,"markdownDescription":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes)."},"url":{"description":"URL from which expo-updates will fetch update manifests","type":"string","markdownDescription":"URL from which expo-updates will fetch update manifests"}},"additionalProperties":false,"markdownDescription":"Configuration for how and when the app should request OTA JavaScript updates"},"locales":{"description":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode.","type":"object","properties":{},"meta":{"bareWorkflow":"To add or change language and localization information in your iOS app, you need to use Xcode."},"additionalProperties":{"type":["string","object"]},"markdownDescription":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode."},"facebookAppId":{"description":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^[0-9]+$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAutoInitEnabled":{"description":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`.","type":"boolean","markdownDescription":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`."},"facebookAutoLogAppEventsEnabled":{"description":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAdvertiserIDCollectionEnabled":{"description":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookDisplayName":{"description":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookScheme":{"description":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^fb[0-9]+[A-Za-z]*$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"isDetached":{"description":"Is app detached","type":"boolean","meta":{"autogenerated":true},"markdownDescription":"Is app detached"},"detach":{"description":"Extra fields needed by detached apps","type":"object","properties":{},"meta":{"autogenerated":true},"additionalProperties":true,"markdownDescription":"Extra fields needed by detached apps"},"assetBundlePatterns":{"description":"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](https://docs.expo.io/guides/offline-support/)","type":"array","items":{"type":"string"},"markdownDescription":"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](https://docs.expo.io/guides/offline-support/)"},"plugins":{"description":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.io/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build","meta":{"bareWorkflow":"Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"type":"array","items":{"anyOf":[{"type":["string"]},{"type":"array","items":[{"type":["string"]},{}],"additionalItems":false}]},"markdownDescription":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.io/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"ios":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleVersion`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"Merchant ID for use with Apple Pay in your standalone app.","type":"string","markdownDescription":"Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"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.\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","bareWorkflow":"Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"markdownDescription":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"useNextNotificationsApi":{"deprecated":true,"description":"@deprecated A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"@deprecated A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","type":"array","meta":{"bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`","type":"string","meta":{"bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`"},"markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`"},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.expo.io"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.expo.io\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"the scheme of the URL, e.g. `https`","type":"string","markdownDescription":"the scheme of the URL, e.g. `https`"},"host":{"description":"the hostname, e.g. `myapp.io`","type":"string","markdownDescription":"the hostname, e.g. `myapp.io`"},"port":{"description":"the port, e.g. `3000`","type":"string","markdownDescription":"the port, e.g. `3000`"},"path":{"description":"an exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"an exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":" a regex for paths that should be matched by the filter, e.g. `.*`","type":"string","markdownDescription":" a regex for paths that should be matched by the filter, e.g. `.*`"},"pathPrefix":{"description":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"a prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"a MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"a MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."},"jsEngine":{"description":"Specifies the JavaScript engine. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"markdownDescription":"Specifies the JavaScript engine. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."},"hooks":{"description":"Configuration for scripts to run to hook into the publish process","type":"object","additionalProperties":false,"properties":{"postPublish":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}},"postExport":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}}},"markdownDescription":"Configuration for scripts to run to hook into the publish process"},"experiments":{"description":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices.","type":"object","additionalProperties":false,"properties":{"turboModules":{"description":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging.","type":"boolean","fallback":false,"markdownDescription":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging."}},"markdownDescription":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices."},"_internal":{"description":"Internal properties for developer tools","type":"object","properties":{"pluginHistory":{"description":"List of plugins already run on the config","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"List of plugins already run on the config"}},"additionalProperties":true,"meta":{"autogenerated":true},"markdownDescription":"Internal properties for developer tools"}},"additionalProperties":false,"required":["name","slug"]}}}
{"$schema":"http://json-schema.org/draft-07/schema#","type":"object","version":"43.0.0","additionalProperties":true,"definitions":{"Android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`. Requires `expo-system-ui` be installed in your project to work on Android.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`. Requires `expo-system-ui` be installed in your project to work on Android."},"useNextNotificationsApi":{"deprecated":true,"description":"@deprecated A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"@deprecated A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","type":"array","meta":{"bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`","type":"string","meta":{"bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`"},"markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`"},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.example.com"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.example.com\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"Scheme of the URL, e.g. `https`","type":"string","markdownDescription":"Scheme of the URL, e.g. `https`"},"host":{"description":"Hostname, e.g. `myapp.io`","type":"string","markdownDescription":"Hostname, e.g. `myapp.io`"},"port":{"description":"Port, e.g. `3000`","type":"string","markdownDescription":"Port, e.g. `3000`"},"path":{"description":"Exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"Exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`","type":"string","markdownDescription":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`"},"pathPrefix":{"description":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"Scheme of the URL, e.g. `https`","type":"string","markdownDescription":"Scheme of the URL, e.g. `https`"},"host":{"description":"Hostname, e.g. `myapp.io`","type":"string","markdownDescription":"Hostname, e.g. `myapp.io`"},"port":{"description":"Port, e.g. `3000`","type":"string","markdownDescription":"Port, e.g. `3000`"},"path":{"description":"Exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"Exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`","type":"string","markdownDescription":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`"},"pathPrefix":{"description":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."},"jsEngine":{"description":"Specifies the JavaScript engine for Android apps. Supported only on EAS Build and in Expo Go. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"markdownDescription":"Specifies the JavaScript engine for Android apps. Supported only on EAS Build and in Expo Go. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the Android platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically.","oneOf":[{"type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+()-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\",\"(\",\")\" or \"-\". Example: \"1.0.3a+\"."}},{"type":"string","pattern":"^exposdk:((\\d+\\.\\d+\\.\\d+)|(UNVERSIONED))$","meta":{"regexHuman":"An 'exposdk:' prefix followed by the SDK version of your project. Example: \"exposdk:44.0.0\"."}},{"type":"object","properties":{"policy":{"type":"string","enum":["nativeVersion","sdkVersion"]}},"required":["policy"],"additionalProperties":false}],"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the Android platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"AndroidIntentFiltersData":{"type":"object","properties":{"scheme":{"description":"Scheme of the URL, e.g. `https`","type":"string","markdownDescription":"Scheme of the URL, e.g. `https`"},"host":{"description":"Hostname, e.g. `myapp.io`","type":"string","markdownDescription":"Hostname, e.g. `myapp.io`"},"port":{"description":"Port, e.g. `3000`","type":"string","markdownDescription":"Port, e.g. `3000`"},"path":{"description":"Exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"Exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`","type":"string","markdownDescription":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`"},"pathPrefix":{"description":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},"IOS":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleVersion`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"@deprecated Merchant ID for use with Apple Pay in your standalone app.","type":"string","meta":{"deprecated":true},"markdownDescription":"@deprecated Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"If true, indicates that your standalone iOS app does not support Slide Over and Split View on iPad. Defaults to `false`\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support Slide Over and Split View on iPad. Defaults to `false`\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","bareWorkflow":"Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"markdownDescription":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."},"jsEngine":{"description":"Specifies the JavaScript engine for iOS apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`"},"markdownDescription":"Specifies the JavaScript engine for iOS apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`"},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the iOS platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically.","oneOf":[{"type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+()-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\",\"(\",\")\" or \"-\". Example: \"1.0.3a+\"."}},{"type":"string","pattern":"^exposdk:((\\d+\\.\\d+\\.\\d+)|(UNVERSIONED))$","meta":{"regexHuman":"An 'exposdk:' prefix followed by the SDK version of your project. Example: \"exposdk:44.0.0\"."}},{"type":"object","properties":{"policy":{"type":"string","enum":["nativeVersion","sdkVersion"]}},"required":["policy"],"additionalProperties":false}],"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the iOS platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"Splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"PublishHook":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}},"Web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."}},"properties":{"expo":{"type":"object","properties":{"name":{"description":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`","type":"string","meta":{"bareWorkflow":"To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"markdownDescription":"The name of your app as it appears both within Expo Go and on your home screen as a standalone app.\n\n**Bare workflow** - To change the name of your app, edit the 'Display Name' field in Xcode and the `app_name` string in `android/app/src/main/res/values/strings.xml`"},"description":{"description":"A short description of what your app is and why it is great.","type":"string","markdownDescription":"A short description of what your app is and why it is great."},"slug":{"description":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.dev/@project-owner/myAppName` project.","type":"string","pattern":"^[a-zA-Z0-9_\\-]+$","markdownDescription":"The friendly URL name for publishing. For example, `myAppName` will refer to the `expo.dev/@project-owner/myAppName` project."},"owner":{"description":"The name of the Expo account that owns the project. This is useful for teams collaborating on a project. If not provided, the owner defaults to the username of the current user.","type":"string","minLength":1,"markdownDescription":"The name of the Expo account that owns the project. This is useful for teams collaborating on a project. If not provided, the owner defaults to the username of the current user."},"currentFullName":{"description":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The auto generated Expo account name and slug used for display purposes. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value may change when a project is transferred between accounts or renamed."},"originalFullName":{"description":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The auto generated Expo account name and slug used for services like Notifications and AuthSession proxy. Formatted like `@username/slug`. When unauthenticated, the username is `@anonymous`. For published projects, this value will not change when a project is transferred between accounts or renamed."},"privacy":{"description":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`.","enum":["public","unlisted","hidden"],"type":"string","fallback":"unlisted","markdownDescription":"Defaults to `unlisted`. `unlisted` hides the project from search results. `hidden` restricts access to the project page to only the owner and other users that have been granted access. Valid values: `public`, `unlisted`, `hidden`."},"sdkVersion":{"description":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json.","type":"string","pattern":"^(\\d+\\.\\d+\\.\\d+)|(UNVERSIONED)$","markdownDescription":"The Expo sdkVersion to run the project on. This should line up with the version specified in your package.json."},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically.","oneOf":[{"type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+()-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\",\"(\",\")\" or \"-\". Example: \"1.0.3a+\"."}},{"type":"string","pattern":"^exposdk:((\\d+\\.\\d+\\.\\d+)|(UNVERSIONED))$","meta":{"regexHuman":"An 'exposdk:' prefix followed by the SDK version of your project. Example: \"exposdk:44.0.0\"."}},{"type":"object","properties":{"policy":{"type":"string","enum":["nativeVersion","sdkVersion"]}},"required":["policy"],"additionalProperties":false}],"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically."},"version":{"description":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.dev/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`","type":"string","meta":{"bareWorkflow":"To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"markdownDescription":"Your app version. In addition to this field, you'll also use `ios.buildNumber` and `android.versionCode` — read more about how to version your app [here](https://docs.expo.dev/distribution/app-stores/#versioning-your-app). On iOS this corresponds to `CFBundleShortVersionString`, and on Android, this corresponds to `versionName`. The required format can be found [here](https://developer.apple.com/documentation/bundleresources/information_property_list/cfbundleshortversionstring).\n\n**Bare workflow** - To change your app version, edit the 'Version' field in Xcode and the `versionName` string in `android/app/build.gradle`"},"platforms":{"description":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`.","example":["ios","android","web"],"type":"array","uniqueItems":true,"items":{"type":"string","enum":["android","ios","web"]},"markdownDescription":"Platforms that your project explicitly supports. If not specified, it defaults to `[\"ios\", \"android\"]`."},"githubUrl":{"description":"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.","pattern":"^https://github\\.com/","example":"https://github.com/expo/expo","type":["string"],"markdownDescription":"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."},"orientation":{"description":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`","enum":["default","portrait","landscape"],"type":"string","markdownDescription":"Locks your app to a specific orientation with portrait or landscape. Defaults to no lock. Valid values: `default`, `portrait`, `landscape`"},"userInterfaceStyle":{"description":"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`. Requires `expo-system-ui` be installed in your project to work on Android.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`. Requires `expo-system-ui` be installed in your project to work on Android."},"backgroundColor":{"description":"The background color for your app, behind any of your React views. This is also known as the root view background color.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`. Default is white: `'#ffffff'`"},"markdownDescription":"The background color for your app, behind any of your React views. This is also known as the root view background color."},"primaryColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"icon":{"description":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true,"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"markdownDescription":"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.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>`. Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each existing size."},"notification":{"description":"Configuration for remote (push) notifications.","type":"object","properties":{"icon":{"description":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"(Android only) Local path or remote URL to an image to use as the icon for push notifications. 96x96 png grayscale with transparency. We recommend following [Google's design guidelines](https://material.io/design/iconography/product-icons.html#design-principles). If not provided, defaults to your app icon."},"color":{"description":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"(Android only) Tint color for the push notification image when it appears in the notification tray. Defaults to `#ffffff`"},"iosDisplayInForeground":{"description":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.dev/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`.","type":"boolean","markdownDescription":"Whether or not to display notifications when the app is in the foreground on iOS. `_displayInForeground` option in the individual push notification message overrides this option. [Learn more.](https://docs.expo.dev/push-notifications/receiving-notifications/#foreground-notification-behavior) Defaults to `false`."},"androidMode":{"description":"Show each push notification individually (`default`) or collapse into one (`collapse`).","enum":["default","collapse"],"type":"string","markdownDescription":"Show each push notification individually (`default`) or collapse into one (`collapse`)."},"androidCollapsedTitle":{"description":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`.","type":"string","markdownDescription":"If `androidMode` is set to `collapse`, this title is used for the collapsed notification message. For example, `'#{unread_notifications} new interactions'`."}},"additionalProperties":false,"markdownDescription":"Configuration for remote (push) notifications."},"appKey":{"description":"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.","type":"string","markdownDescription":"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."},"androidStatusBar":{"description":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.dev/guides/configuring-statusbar/).","type":"object","properties":{"barStyle":{"description":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configures the status bar icons to have a light or dark color. Valid values: `light-content`, `dark-content`. Defaults to `dark-content`"},"backgroundColor":{"description":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string `'#RRGGBB'`, for example, `'#000000'` for black. Or 8 character long hex color string `'#RRGGBBAA'`, for example, `'#00000088'` for semi-transparent black."},"markdownDescription":"Specifies the background color of the status bar. Defaults to `#00000000` (transparent) for `dark-content` bar style and `#00000088` (semi-transparent black) for `light-content` bar style"},"hidden":{"description":"Instructs the system whether the status bar should be visible or not. Defaults to `false`","type":"boolean","markdownDescription":"Instructs the system whether the status bar should be visible or not. Defaults to `false`"},"translucent":{"description":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content).","type":"boolean","markdownDescription":"Sets `android:windowTranslucentStatus` in `styles.xml`. When false, the system status bar pushes the content of your app down (similar to `position: relative`). When true, the status bar floats above the content in your app (similar to `position: absolute`). Defaults to `true` to match the iOS status bar behavior (which can only float above content)."}},"additionalProperties":false,"markdownDescription":"Configuration for the status bar on Android. For more details please navigate to [Configuring StatusBar](https://docs.expo.dev/guides/configuring-statusbar/)."},"androidNavigationBar":{"description":"Configuration for the bottom navigation bar on Android. Can be used to configure the `expo-navigation-bar` module in EAS Build.","type":"object","properties":{"visible":{"description":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Requires `expo-navigation-bar` be installed in your project. Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time.","type":"string","enum":["leanback","immersive","sticky-immersive"],"markdownDescription":"Determines how and when the navigation bar is shown. [Learn more](https://developer.android.com/training/system-ui/immersive). Requires `expo-navigation-bar` be installed in your project. Valid values: `leanback`, `immersive`, `sticky-immersive` \n\n `leanback` results in the navigation bar being hidden until the first touch gesture is registered. \n\n `immersive` results in the navigation bar being hidden until the user swipes up from the edge where the navigation bar is hidden. \n\n `sticky-immersive` is identical to `'immersive'` except that the navigation bar will be semi-transparent and will be hidden again after a short period of time."},"barStyle":{"description":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`","type":"string","enum":["light-content","dark-content"],"markdownDescription":"Configure the navigation bar icons to have a light or dark color. Supported on Android Oreo and newer. Valid values: `'light-content'`, `'dark-content'`"},"backgroundColor":{"description":"Specifies the background color of the navigation bar.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Specifies the background color of the navigation bar."}},"additionalProperties":false,"markdownDescription":"Configuration for the bottom navigation bar on Android. Can be used to configure the `expo-navigation-bar` module in EAS Build."},"developmentClient":{"description":"Settings that apply specifically to running this app in a development client","type":"object","properties":{"silentLaunch":{"description":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app.","type":"boolean","fallback":false,"markdownDescription":"If true, the app will launch in a development client with no additional dialogs or progress indicators, just like in a standalone app."}},"additionalProperties":false,"markdownDescription":"Settings that apply specifically to running this app in a development client"},"scheme":{"description":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`","type":"string","pattern":"^[a-z][a-z0-9+.-]*$","meta":{"regexHuman":"String beginning with a **lowercase** letter followed by any combination of **lowercase** letters, digits, \"+\", \".\" or \"-\"","standaloneOnly":true,"bareWorkflow":"To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"markdownDescription":"**Standalone Apps Only**. URL scheme to link into your app. For example, if we set this to `'demo'`, then demo:// URLs would open your app when tapped.\n\n**Bare workflow** - To change your app's scheme, replace all occurrences of the old scheme in `Info.plist` and `AndroidManifest.xml`"},"entryPoint":{"description":"The relative path to your main JavaScript file.","type":"string","markdownDescription":"The relative path to your main JavaScript file."},"extra":{"description":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.dev/versions/latest/sdk/constants/#constantsmanifest))","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Any extra fields you want to pass to your experience. Values are accessible via `Expo.Constants.manifest.extra` ([Learn more](https://docs.expo.dev/versions/latest/sdk/constants/#constantsmanifest))"},"packagerOpts":{"description":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.dev/guides/customizing-metro/)","meta":{"deprecated":true,"autogenerated":true},"type":"object","properties":{},"additionalProperties":true,"markdownDescription":"@deprecated Use a `metro.config.js` file instead. [Learn more](https://docs.expo.dev/guides/customizing-metro/)"},"updates":{"description":"Configuration for how and when the app should request OTA JavaScript updates","type":"object","properties":{"enabled":{"description":"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 app store review. Defaults to true. (Note: This will not work out of the box with ExpoKit projects)","type":"boolean","markdownDescription":"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 app store review. Defaults to true. (Note: This will not work out of the box with ExpoKit projects)"},"checkAutomatically":{"description":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`","enum":["ON_ERROR_RECOVERY","ON_LOAD"],"type":"string","markdownDescription":"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. Must be one of `ON_LOAD` or `ON_ERROR_RECOVERY`"},"fallbackToCacheTimeout":{"description":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes).","type":"number","minimum":0,"maximum":300000,"markdownDescription":"How long (in ms) to allow for fetching OTA updates before falling back to a cached version of the app. Defaults to 0. Must be between 0 and 300000 (5 minutes)."},"url":{"description":"URL from which expo-updates will fetch update manifests","type":"string","markdownDescription":"URL from which expo-updates will fetch update manifests"}},"additionalProperties":false,"markdownDescription":"Configuration for how and when the app should request OTA JavaScript updates"},"locales":{"description":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode.","type":"object","properties":{},"meta":{"bareWorkflow":"To add or change language and localization information in your iOS app, you need to use Xcode."},"additionalProperties":{"type":["string","object"]},"markdownDescription":"Provide overrides by locale for System Dialog prompts like Permissions Boxes\n\n**Bare workflow** - To add or change language and localization information in your iOS app, you need to use Xcode."},"facebookAppId":{"description":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^[0-9]+$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for all Facebook libraries. Set up your Facebook App ID at https://developers.facebook.com.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAutoInitEnabled":{"description":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`.","type":"boolean","markdownDescription":"Whether the Facebook SDK should be initialized automatically. The default in Expo (Client and in standalone apps) is `false`."},"facebookAutoLogAppEventsEnabled":{"description":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.) Note: The Facebook SDK must be initialized for app events to work. You may autoinitialize Facebook SDK by setting `facebookAutoInitEnabled` to `true`\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookAdvertiserIDCollectionEnabled":{"description":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"boolean","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"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.)\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookDisplayName":{"description":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for native Facebook login.\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"facebookScheme":{"description":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)","type":"string","pattern":"^fb[0-9]+[A-Za-z]*$","meta":{"bareWorkflow":"For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"markdownDescription":"Used for Facebook native login. Starts with 'fb' and followed by a string of digits, like 'fb1234567890'. You can find your scheme [here](https://developers.facebook.com/docs/facebook-login/ios)in the 'Configuring Your info.plist' section (only applicable to standalone apps and custom Expo Go apps).\n\n**Bare workflow** - For details, check the [Facebook iOS SDK documentation](https://developers.facebook.com/docs/facebook-login/ios/#4--configure-your-project) and [Android SDK documentation](https://developers.facebook.com/docs/facebook-login/android#manifest)"},"isDetached":{"description":"Is app detached","type":"boolean","meta":{"autogenerated":true},"markdownDescription":"Is app detached"},"detach":{"description":"Extra fields needed by detached apps","type":"object","properties":{},"meta":{"autogenerated":true},"additionalProperties":true,"markdownDescription":"Extra fields needed by detached apps"},"assetBundlePatterns":{"description":"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](https://docs.expo.dev/guides/offline-support/)","type":"array","items":{"type":"string"},"markdownDescription":"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](https://docs.expo.dev/guides/offline-support/)"},"plugins":{"description":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.dev/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build","meta":{"bareWorkflow":"Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"type":"array","items":{"anyOf":[{"type":["string"]},{"type":"array","items":[{"type":["string"]},{}],"additionalItems":false}]},"markdownDescription":"Config plugins for adding extra functionality to your project. [Learn more](https://docs.expo.dev/guides/config-plugins/).\n\n**Bare workflow** - Plugins that add modifications can only be used with [prebuilding](https://expo.fyi/prebuilding) and managed EAS Build"},"splash":{"description":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"markdownDescription":"Color to fill the loading screen background\n\n**Bare workflow** - For Android, edit the `colorPrimary` item in `android/app/src/main/res/values/colors.xml`"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"markdownDescription":"Configuration for loading and splash screen for standalone apps.\n\n**Bare workflow** - To change your app's icon, edit or replace the files in `ios/<PROJECT-NAME>/Assets.xcassets/AppIcon.appiconset` (we recommend using Xcode), and `android/app/src/main/res/mipmap-<RESOLUTION>` (Android Studio can [generate the appropriate image files for you](https://developer.android.com/studio/write/image-asset-studio)). Be sure to follow the guidelines for each platform ([iOS](https://developer.apple.com/design/human-interface-guidelines/ios/icons-and-images/app-icon/), [Android 7.1 and below](https://material.io/design/iconography/#icon-treatments), and [Android 8+](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)) and to provide your new icon in each required size."},"jsEngine":{"description":"Specifies the JavaScript engine for apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json` or `android/gradle.properties`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json` or `android/gradle.properties`"},"markdownDescription":"Specifies the JavaScript engine for apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json` or `android/gradle.properties`"},"ios":{"description":"Configuration that is specific to the iOS platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the iOS version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the iOS version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the iOS version of your app will be written to this path during publish."},"bundleIdentifier":{"description":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`","type":"string","pattern":"^[a-zA-Z0-9.-]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleIdentifier`","regexHuman":"iOS bundle identifier notation unique name for your app. For example, `host.exp.expo`, where `exp.host` is our domain and `expo` is our app name."},"markdownDescription":"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](http://stackoverflow.com/questions/11347470/what-does-bundle-identifier-mean-in-the-ios-project).\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleIdentifier`"},"buildNumber":{"description":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`","type":"string","pattern":"^[A-Za-z0-9\\.]+$","meta":{"bareWorkflow":"Set this value in `info.plist` under `CFBundleVersion`"},"markdownDescription":"Build number for your iOS standalone app. Corresponds to `CFBundleVersion` and must match Apple's [specified format](https://developer.apple.com/library/content/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102364). (Note: Transporter will pull the value for `Version Number` from `expo.version` and NOT from `expo.ios.buildNumber`.)\n\n**Bare workflow** - Set this value in `info.plist` under `CFBundleVersion`"},"backgroundColor":{"description":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"The background color for your iOS app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present."},"icon":{"description":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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. \n\n Expo will generate the other required sizes. This icon will appear on the home screen and within the Expo app."},"merchantId":{"description":"@deprecated Merchant ID for use with Apple Pay in your standalone app.","type":"string","meta":{"deprecated":true},"markdownDescription":"@deprecated Merchant ID for use with Apple Pay in your standalone app."},"appStoreUrl":{"description":"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.","pattern":"^https://(itunes|apps)\\.apple\\.com/.*?\\d+","example":"https://apps.apple.com/us/app/expo-client/id982107779","type":["string"],"markdownDescription":"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."},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"usesNonExemptEncryption":{"description":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value.","type":"boolean","markdownDescription":"Sets `ITSAppUsesNonExemptEncryption` in the standalone ipa's Info.plist to the given boolean value."},"googleMapsApiKey":{"description":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app.","type":"string","markdownDescription":"[Google Maps iOS SDK](https://developers.google.com/maps/documentation/ios-sdk/start) key for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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 (Go and in standalone apps) is `false`. [Sets the opposite of the given value to the following key in `Info.plist`.](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"description":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app.","type":"object","properties":{"reservedClientId":{"description":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`.","type":"string","markdownDescription":"The reserved client ID URL scheme. Can be found in `GoogleService-Info.plist`."}},"additionalProperties":false,"markdownDescription":"[Google Sign-In iOS SDK](https://developers.google.com/identity/sign-in/ios/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase.","type":"string","markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase."},"supportsTablet":{"description":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"markdownDescription":"Whether your standalone iOS app supports tablet screen sizes. Defaults to `false`.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations~ipad`"},"isTabletOnly":{"description":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`","type":"boolean","meta":{"bareWorkflow":"Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support handsets, and only supports tablets.\n\n**Bare workflow** - Set this value in `info.plist` under `UISupportedInterfaceOrientations`"},"requireFullScreen":{"description":"If true, indicates that your standalone iOS app does not support Slide Over and Split View on iPad. Defaults to `false`\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`","type":"boolean","meta":{"bareWorkflow":"Use Xcode to set `UIRequiresFullScreen`"},"markdownDescription":"If true, indicates that your standalone iOS app does not support Slide Over and Split View on iPad. Defaults to `false`\n\n**Bare workflow** - Use Xcode to set `UIRequiresFullScreen`"},"userInterfaceStyle":{"description":"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`.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`."},"infoPlist":{"description":"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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"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."},"entitlements":{"description":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Dictionary of arbitrary configuration to add to your standalone app's native *.entitlements (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."},"associatedDomains":{"description":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","type":"array","uniqueItems":true,"items":{"type":"string"},"meta":{"regexHuman":"Entries must follow the format `applinks:<fully qualified domain>[:port number]`. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).","bareWorkflow":"Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"markdownDescription":"An array that contains Associated Domains for the standalone app. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains).\n\n**Bare workflow** - Build with EAS, or use Xcode to enable this capability manually. [Learn more](https://developer.apple.com/documentation/safariservices/supporting_associated_domains)."},"usesIcloudStorage":{"description":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this.","type":"boolean","meta":{"bareWorkflow":"Use Xcode, or ios.entitlements to configure this."},"markdownDescription":"A boolean indicating if the app uses iCloud Storage for `DocumentPicker`. See `DocumentPicker` docs for details.\n\n**Bare workflow** - Use Xcode, or ios.entitlements to configure this."},"usesAppleSignIn":{"description":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details.","type":"boolean","fallback":false,"markdownDescription":"A boolean indicating if the app uses Apple Sign-In. See `AppleAuthentication` docs for details."},"accessesContactNotes":{"description":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability.","type":"boolean","fallback":false,"markdownDescription":"A Boolean value that indicates whether the app may access the notes stored in contacts. You must [receive permission from Apple](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_developer_contacts_notes) before you can submit your app for review with this capability."},"splash":{"description":"Configuration for loading and splash screen for standalone iOS apps.","type":"object","properties":{"xib":{"description":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go.","type":"string","meta":{"deprecated":true,"asset":true,"contentTypePattern":"^text/xml$","contentTypeHuman":".xib interface builder document"},"markdownDescription":"@deprecated Apple has deprecated `.xib` splash screens in favor of `.storyboard` files. Local path to a XIB file as the loading screen. It overrides other loading screen options. Note: This will only be used in the standalone app (i.e., after you build the app). It will not be used in the Expo Go."},"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"tabletImage":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"markdownDescription":"Configuration for loading and splash screen for standalone iOS apps."},"jsEngine":{"description":"Specifies the JavaScript engine for iOS apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`"},"markdownDescription":"Specifies the JavaScript engine for iOS apps. Supported only on EAS Build. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `ios/Podfile.properties.json`"},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the iOS platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically.","oneOf":[{"type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+()-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\",\"(\",\")\" or \"-\". Example: \"1.0.3a+\"."}},{"type":"string","pattern":"^exposdk:((\\d+\\.\\d+\\.\\d+)|(UNVERSIONED))$","meta":{"regexHuman":"An 'exposdk:' prefix followed by the SDK version of your project. Example: \"exposdk:44.0.0\"."}},{"type":"object","properties":{"policy":{"type":"string","enum":["nativeVersion","sdkVersion"]}},"required":["policy"],"additionalProperties":false}],"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the iOS platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the iOS platform."},"android":{"description":"Configuration that is specific to the Android platform.","type":"object","meta":{"standaloneOnly":true},"properties":{"publishManifestPath":{"description":"The manifest for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The manifest for the Android version of your app will be written to this path during publish."},"publishBundlePath":{"description":"The bundle for the Android version of your app will be written to this path during publish.","type":"string","meta":{"autogenerated":true},"markdownDescription":"The bundle for the Android version of your app will be written to this path during publish."},"package":{"description":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places).","type":"string","pattern":"^[a-zA-Z][a-zA-Z0-9\\_]*(\\.[a-zA-Z][a-zA-Z0-9\\_]*)+$","meta":{"regexHuman":"Reverse DNS notation unique name for your app. Valid Android Application ID. For example, `com.example.app`, where `com.example` is our domain and `app` is our app. The name may only contain lowercase and uppercase letters (a-z, A-Z), numbers (0-9) and underscores (_), separated by periods (.). Each component of the name should start with a lowercase letter.","bareWorkflow":"This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"markdownDescription":"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](http://stackoverflow.com/questions/6273892/android-package-name-convention).\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `applicationId` as well as in your `AndroidManifest.xml` file (multiple places)."},"versionCode":{"description":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`","type":"integer","minimum":0,"maximum":2100000000,"meta":{"bareWorkflow":"This is set in `android/app/build.gradle` as `versionCode`"},"markdownDescription":"Version number required by Google Play. Increment by one for each release. Must be a positive integer. [Learn more](https://developer.android.com/studio/publish/versioning.html)\n\n**Bare workflow** - This is set in `android/app/build.gradle` as `versionCode`"},"backgroundColor":{"description":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`","bareWorkflow":"This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"markdownDescription":"The background color for your Android app, behind any of your React views. Overrides the top-level `backgroundColor` key if it is present.\n\n**Bare workflow** - This is set in `android/app/src/main/AndroidManifest.xml` under `android:windowBackground`"},"userInterfaceStyle":{"description":"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`. Requires `expo-system-ui` be installed in your project to work on Android.","type":"string","fallback":"light","enum":["light","dark","automatic"],"markdownDescription":"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`. Requires `expo-system-ui` be installed in your project to work on Android."},"useNextNotificationsApi":{"deprecated":true,"description":"@deprecated A Boolean value that indicates whether the app should use the new notifications API.","type":"boolean","fallback":false,"markdownDescription":"@deprecated A Boolean value that indicates whether the app should use the new notifications API."},"icon":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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."},"adaptiveIcon":{"description":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)","type":"object","properties":{"foregroundImage":{"description":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"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 [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive). This icon will appear on the home screen."},"backgroundImage":{"description":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive).","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image","square":true},"markdownDescription":"Local path or remote URL to a background image for your app's Adaptive Icon on Android. If specified, this overrides the `backgroundColor` key. Must have the same dimensions as foregroundImage`, and has no effect if `foregroundImage` is not specified. Should follow the [specified guidelines](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)."},"backgroundColor":{"description":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to use as the background for your app's Adaptive Icon on Android. Defaults to white, `#FFFFFF`. Has no effect if `foregroundImage` is not specified."}},"additionalProperties":false,"markdownDescription":"Settings for an Adaptive Launcher Icon on Android. [Learn more](https://developer.android.com/guide/practices/ui_guidelines/icon_design_adaptive)"},"playStoreUrl":{"description":"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.","pattern":"^https://play\\.google\\.com/","example":"https://play.google.com/store/apps/details?id=host.exp.exponent","type":["string"],"markdownDescription":"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."},"permissions":{"description":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag.","type":"array","meta":{"bareWorkflow":"To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"items":{"type":"string"},"markdownDescription":"List of permissions used by the standalone app. \n\n To use ONLY the following minimum necessary permissions and none of the extras supported by Expo in a default managed app, set `permissions` to `[]`. The minimum necessary permissions do not require a Privacy Policy when uploading to Google Play Store and are: \n• receive data from Internet \n• view network connections \n• full network access \n• change your audio settings \n• prevent device from sleeping \n\n To use ALL permissions supported by Expo by default, do not specify the `permissions` key. \n\n To use the minimum necessary permissions ALONG with certain additional permissions, specify those extras in `permissions`, e.g.\n\n `[ \"CAMERA\", \"ACCESS_FINE_LOCATION\" ]`.\n\n You can specify the following permissions depending on what you need:\n\n- `ACCESS_COARSE_LOCATION`\n- `ACCESS_FINE_LOCATION`\n- `ACCESS_BACKGROUND_LOCATION`\n- `CAMERA`\n- `RECORD_AUDIO`\n- `READ_CONTACTS`\n- `WRITE_CONTACTS`\n- `READ_CALENDAR`\n- `WRITE_CALENDAR`\n- `READ_EXTERNAL_STORAGE`\n- `WRITE_EXTERNAL_STORAGE`\n- `USE_FINGERPRINT`\n- `USE_BIOMETRIC`\n- `WRITE_SETTINGS`\n- `VIBRATE`\n- `READ_PHONE_STATE`\n- `com.anddoes.launcher.permission.UPDATE_COUNT`\n- `com.android.launcher.permission.INSTALL_SHORTCUT`\n- `com.google.android.c2dm.permission.RECEIVE`\n- `com.google.android.gms.permission.ACTIVITY_RECOGNITION`\n- `com.google.android.providers.gsf.permission.READ_GSERVICES`\n- `com.htc.launcher.permission.READ_SETTINGS`\n- `com.htc.launcher.permission.UPDATE_SHORTCUT`\n- `com.majeur.launcher.permission.UPDATE_BADGE`\n- `com.sec.android.provider.badge.permission.READ`\n- `com.sec.android.provider.badge.permission.WRITE`\n- `com.sonyericsson.home.permission.BROADCAST_BADGE`\n\n\n**Bare workflow** - To change the permissions your app requests, you'll need to edit `AndroidManifest.xml` manually. To prevent your app from requesting one of the permissions listed below, you'll need to explicitly add it to `AndroidManifest.xml` along with a `tools:node=\"remove\"` tag."},"googleServicesFile":{"description":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`","type":"string","meta":{"bareWorkflow":"Add or edit the file directly at `android/app/google-services.json`"},"markdownDescription":"[Firebase Configuration File](https://support.google.com/firebase/answer/7015592) Location of the `GoogleService-Info.plist` file for configuring Firebase. Including this key automatically enables FCM in your standalone app.\n\n**Bare workflow** - Add or edit the file directly at `android/app/google-services.json`"},"config":{"type":"object","description":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private.","properties":{"branch":{"description":"[Branch](https://branch.io/) key to hook up Branch linking services.","type":"object","properties":{"apiKey":{"description":"Your Branch API key","type":"string","markdownDescription":"Your Branch API key"}},"additionalProperties":false,"markdownDescription":"[Branch](https://branch.io/) key to hook up Branch linking services."},"googleMaps":{"description":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app.","type":"object","properties":{"apiKey":{"description":"Your Google Maps Android SDK API key","type":"string","markdownDescription":"Your Google Maps Android SDK API key"}},"additionalProperties":false,"markdownDescription":"[Google Maps Android SDK](https://developers.google.com/maps/documentation/android-api/signup) configuration for your standalone app."},"googleMobileAdsAppId":{"description":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. ","type":"string","markdownDescription":"[Google Mobile Ads App ID](https://support.google.com/admob/answer/6232340) Google AdMob App ID. "},"googleMobileAdsAutoInit":{"description":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)","type":"boolean","fallback":false,"markdownDescription":"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`. [Sets the opposite of the given value to the following key in `Info.plist`](https://developers.google.com/admob/ios/eu-consent#delay_app_measurement_optional)"},"googleSignIn":{"deprecated":true,"meta":{"deprecated":true},"description":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app.","type":"object","properties":{"apiKey":{"description":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`.","type":"string","markdownDescription":"The Android API key. Can be found in the credentials section of the developer console or in `google-services.json`."},"certificateHash":{"description":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth","type":"string","markdownDescription":"The SHA-1 hash of the signing certificate used to build the APK without any separator (`:`). Can be found in `google-services.json`. https://developers.google.com/android/guides/client-auth"}},"additionalProperties":false,"markdownDescription":"@deprecated Use `googleServicesFile` instead. [Google Sign-In Android SDK](https://developers.google.com/identity/sign-in/android/start-integrating) keys for your standalone app."}},"additionalProperties":false,"markdownDescription":"Note: This property key is not included in the production manifest and will evaluate to `undefined`. It is used internally only in the build process, because it contains API keys that some may want to keep private."},"splash":{"description":"Configuration for loading and splash screen for managed and standalone Android apps.","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`.","enum":["cover","contain","native"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover`, `contain` or `native`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."},"mdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Natural sized image (baseline)`"},"hdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 1.5x`"},"xhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 2x`"},"xxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 3x`"},"xxxhdpi":{"description":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"Local path or remote URL to an image to fill the background of the loading screen in \"native\" mode. Image size and aspect ratio are up to you. [Learn more]( https://developer.android.com/training/multiscreen/screendensities) \n\n `Scale 4x`"}},"markdownDescription":"Configuration for loading and splash screen for managed and standalone Android apps."},"intentFilters":{"description":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)","example":[{"autoVerify":true,"action":"VIEW","data":{"scheme":"https","host":"*.example.com"},"category":["BROWSABLE","DEFAULT"]}],"exampleString":"\n [{ \n \"autoVerify\": true, \n \"action\": \"VIEW\", \n \"data\": { \n \"scheme\": \"https\", \n \"host\": \"*.example.com\" \n }, \n \"category\": [\"BROWSABLE\", \"DEFAULT\"] \n }]","type":"array","uniqueItems":true,"items":{"type":"object","properties":{"autoVerify":{"description":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)","type":"boolean","markdownDescription":"You may also use an intent filter to set your app as the default handler for links (without showing the user a dialog with options). To do so use `true` and then configure your server to serve a JSON file verifying that you own the domain. [Learn more](developer.android.com/training/app-links)"},"action":{"type":"string"},"data":{"anyOf":[{"type":"object","properties":{"scheme":{"description":"Scheme of the URL, e.g. `https`","type":"string","markdownDescription":"Scheme of the URL, e.g. `https`"},"host":{"description":"Hostname, e.g. `myapp.io`","type":"string","markdownDescription":"Hostname, e.g. `myapp.io`"},"port":{"description":"Port, e.g. `3000`","type":"string","markdownDescription":"Port, e.g. `3000`"},"path":{"description":"Exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"Exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`","type":"string","markdownDescription":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`"},"pathPrefix":{"description":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"MIME type for URLs that should be matched by the filter"}},"additionalProperties":false},{"type":["array"],"items":{"type":"object","properties":{"scheme":{"description":"Scheme of the URL, e.g. `https`","type":"string","markdownDescription":"Scheme of the URL, e.g. `https`"},"host":{"description":"Hostname, e.g. `myapp.io`","type":"string","markdownDescription":"Hostname, e.g. `myapp.io`"},"port":{"description":"Port, e.g. `3000`","type":"string","markdownDescription":"Port, e.g. `3000`"},"path":{"description":"Exact path for URLs that should be matched by the filter, e.g. `/records`","type":"string","markdownDescription":"Exact path for URLs that should be matched by the filter, e.g. `/records`"},"pathPattern":{"description":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`","type":"string","markdownDescription":"Pattern for paths that should be matched by the filter, e.g. `.*`. Must begin with `/`"},"pathPrefix":{"description":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`","type":"string","markdownDescription":"Prefix for paths that should be matched by the filter, e.g. `/records/` will match `/records/123`"},"mimeType":{"description":"MIME type for URLs that should be matched by the filter","type":"string","markdownDescription":"MIME type for URLs that should be matched by the filter"}},"additionalProperties":false}}]},"category":{"anyOf":[{"type":["string"]},{"type":"array","items":{"type":"string"}}]}},"additionalProperties":false,"required":["action"]},"meta":{"bareWorkflow":"This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"markdownDescription":"Configuration for setting an array of custom intent filters in Android manifest. [Learn more](https://developer.android.com/guide/components/intents-filters)\n\n**Bare workflow** - This is set in `AndroidManifest.xml` directly. [Learn more.](developer.android.com/guide/components/intents-filters)"},"allowBackup":{"description":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`.","fallback":true,"type":"boolean","markdownDescription":"Allows your user's app data to be automatically backed up to their Google Drive. If this is set to false, no backup or restore of the application will ever be performed (this is useful if your app deals with sensitive information). Defaults to the Android default, which is `true`."},"softwareKeyboardLayoutMode":{"description":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`.","enum":["resize","pan"],"type":"string","fallback":"resize","markdownDescription":"Determines how the software keyboard will impact the layout of your application. This maps to the `android:windowSoftInputMode` property. Defaults to `resize`. Valid values: `resize`, `pan`."},"jsEngine":{"description":"Specifies the JavaScript engine for Android apps. Supported only on EAS Build and in Expo Go. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`","type":"string","fallback":"jsc","enum":["hermes","jsc"],"meta":{"bareWorkflow":"To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"markdownDescription":"Specifies the JavaScript engine for Android apps. Supported only on EAS Build and in Expo Go. Defaults to `jsc`. Valid values: `hermes`, `jsc`.\n\n**Bare workflow** - To change the JavaScript engine, update the `expo.jsEngine` value in `android/gradle.properties`"},"runtimeVersion":{"description":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the Android platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically.","oneOf":[{"type":"string","pattern":"^[a-zA-Z\\d][a-zA-Z\\d._+()-]*$","meta":{"regexHuman":"A string beginning with an alphanumeric character followed by any combination of alphanumeric character, \"_\", \"+\", \".\",\"(\",\")\" or \"-\". Example: \"1.0.3a+\"."}},{"type":"string","pattern":"^exposdk:((\\d+\\.\\d+\\.\\d+)|(UNVERSIONED))$","meta":{"regexHuman":"An 'exposdk:' prefix followed by the SDK version of your project. Example: \"exposdk:44.0.0\"."}},{"type":"object","properties":{"policy":{"type":"string","enum":["nativeVersion","sdkVersion"]}},"required":["policy"],"additionalProperties":false}],"markdownDescription":"**Note: Don't use this property unless you are sure what you're doing** \n\nThe runtime version associated with this manifest for the Android platform. If provided, this will override the top level runtimeVersion key.\nSet this to `{\"policy\": \"nativeVersion\"}` to generate it automatically."}},"additionalProperties":false,"markdownDescription":"Configuration that is specific to the Android platform."},"web":{"description":"Configuration that is specific to the web platform.","type":"object","additionalProperties":true,"properties":{"favicon":{"description":"Relative path of an image to use for your app's favicon.","type":"string","markdownDescription":"Relative path of an image to use for your app's favicon."},"name":{"description":"Defines the title of the document, defaults to the outer level name","type":"string","meta":{"pwa":"name"},"markdownDescription":"Defines the title of the document, defaults to the outer level name"},"shortName":{"description":"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.","type":"string","meta":{"pwa":"short_name","regexHuman":"Maximum 12 characters long"},"markdownDescription":"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."},"lang":{"description":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag.","type":"string","fallback":"en","meta":{"pwa":"lang"},"markdownDescription":"Specifies the primary language for the values in the name and short_name members. This value is a string containing a single language tag."},"scope":{"description":"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.","type":"string","meta":{"pwa":"scope"},"markdownDescription":"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."},"themeColor":{"description":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"theme_color","html":"theme-color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Defines the color of the Android tool bar, and may be reflected in the app's preview in task switchers."},"description":{"description":"Provides a general description of what the pinned website does.","type":"string","meta":{"html":"description","pwa":"description"},"markdownDescription":"Provides a general description of what the pinned website does."},"dir":{"description":"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.","enum":["auto","ltr","rtl"],"type":"string","meta":{"pwa":"dir"},"markdownDescription":"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."},"display":{"description":"Defines the developers’ preferred display mode for the website.","enum":["fullscreen","standalone","minimal-ui","browser"],"type":"string","meta":{"pwa":"display"},"markdownDescription":"Defines the developers’ preferred display mode for the website."},"startUrl":{"description":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL.","type":"string","meta":{"pwa":"start_url"},"markdownDescription":"The URL that loads when a user launches the application (e.g., when added to home screen), typically the index. Note: This has to be a relative URL, relative to the manifest URL."},"orientation":{"description":"Defines the default orientation for all the website's top level browsing contexts.","enum":["any","natural","landscape","landscape-primary","landscape-secondary","portrait","portrait-primary","portrait-secondary"],"type":"string","meta":{"pwa":"orientation"},"markdownDescription":"Defines the default orientation for all the website's top level browsing contexts."},"backgroundColor":{"description":"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.","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"pwa":"background_color","regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"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."},"barStyle":{"description":"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.","enum":["default","black","black-translucent"],"type":"string","fallback":"black-translucent","meta":{"html":"apple-mobile-web-app-status-bar-style","pwa":"name"},"markdownDescription":"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."},"preferRelatedApplications":{"description":"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.","type":"boolean","fallback":true,"meta":{"pwa":"prefer_related_applications"},"markdownDescription":"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."},"dangerous":{"description":"Experimental features. These will break without deprecation notice.","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"Experimental features. These will break without deprecation notice."},"splash":{"description":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)","type":"object","properties":{"backgroundColor":{"description":"Color to fill the loading screen background","type":"string","pattern":"^#|(&#x23;)\\d{6}$","meta":{"regexHuman":"6 character long hex color string, for example, `'#000000'`"},"markdownDescription":"Color to fill the loading screen background"},"resizeMode":{"description":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`.","enum":["cover","contain"],"type":"string","markdownDescription":"Determines how the `image` will be displayed in the splash loading screen. Must be one of `cover` or `contain`, defaults to `contain`."},"image":{"description":"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.","type":"string","meta":{"asset":true,"contentTypePattern":"^image/png$","contentTypeHuman":".png image"},"markdownDescription":"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."}},"meta":{"bareWorkflow":"Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"markdownDescription":"Configuration for PWA splash screens.\n\n**Bare workflow** - Use [expo-splash-screen](https://github.com/expo/expo/tree/master/packages/expo-splash-screen#expo-splash-screen)"},"config":{"description":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)","type":"object","properties":{"firebase":{"type":"object","properties":{"apiKey":{"type":"string"},"authDomain":{"type":"string"},"databaseURL":{"type":"string"},"projectId":{"type":"string"},"storageBucket":{"type":"string"},"messagingSenderId":{"type":"string"},"appId":{"type":"string"},"measurementId":{"type":"string"}}}},"markdownDescription":"Firebase web configuration. Used by the expo-firebase packages on both web and native. [Learn more](https://firebase.google.com/docs/reference/js/firebase.html#initializeapp)"}},"markdownDescription":"Configuration that is specific to the web platform."},"hooks":{"description":"Configuration for scripts to run to hook into the publish process","type":"object","additionalProperties":false,"properties":{"postPublish":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}},"postExport":{"type":"array","items":{"type":"object","additionalProperties":true,"properties":{"file":{"type":"string"},"config":{"type":"object","additionalProperties":true,"properties":{}}}}}},"markdownDescription":"Configuration for scripts to run to hook into the publish process"},"experiments":{"description":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices.","type":"object","additionalProperties":false,"properties":{"turboModules":{"description":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging.","type":"boolean","fallback":false,"markdownDescription":"Enables Turbo Modules, which are a type of native modules that use a different way of communicating between JS and platform code. When installing a Turbo Module you will need to enable this experimental option (the library still needs to be a part of Expo SDK already, like react-native-reanimated v2). Turbo Modules do not support remote debugging and enabling this option will disable remote debugging."}},"markdownDescription":"Enable experimental features that may be unstable, unsupported, or removed without deprecation notices."},"_internal":{"description":"Internal properties for developer tools","type":"object","properties":{"pluginHistory":{"description":"List of plugins already run on the config","type":"object","properties":{},"additionalProperties":true,"markdownDescription":"List of plugins already run on the config"}},"additionalProperties":true,"meta":{"autogenerated":true},"markdownDescription":"Internal properties for developer tools"}},"additionalProperties":false,"required":["name","slug"]}}}
This file has been truncated, but you can view the full file.
{
"lastUpdated": 1629307479951,
"packages": {
"dataType": "Map",
"value": [
[
"http",
null
],
[
"provider",
null
],
[
"shared_preferences",
null
],
[
"url_launcher",
null
],
[
"image_picker",
null
],
[
"dio",
null
],
[
"google_fonts",
null
],
[
"pedantic",
null
],
[
"path",
null
],
[
"flutter_bloc",
null
],
[
"geolocator",
null
],
[
"uuid",
null
],
[
"crypto",
null
],
[
"video_player",
null
],
[
"fluttertoast",
null
],
[
"equatable",
null
],
[
"connectivity",
null
],
[
"google_sign_in",
null
],
[
"bloc",
null
],
[
"flutter_blurhash",
null
],
[
"get_it",
null
],
[
"file_picker",
null
],
[
"hive",
null
],
[
"photo_view",
null
],
[
"wakelock",
null
],
[
"flutter_staggered_grid_view",
null
],
[
"shimmer",
null
],
[
"chewie",
null
],
[
"octo_image",
null
],
[
"animations",
null
],
[
"pull_to_refresh",
null
],
[
"logger",
null
],
[
"lottie",
null
],
[
"percent_indicator",
null
],
[
"flutter_rating_bar",
null
],
[
"audioplayers",
null
],
[
"flutter_screenutil",
null
],
[
"pin_code_fields",
null
],
[
"badges",
null
],
[
"simple_animations",
null
],
[
"animated_text_kit",
null
],
[
"supercharged",
null
],
[
"qr_flutter",
null
],
[
"table_calendar",
null
],
[
"flutter_native_splash",
null
],
[
"easy_localization",
null
],
[
"nested",
null
],
[
"page_transition",
null
],
[
"flutter_typeahead",
null
],
[
"sliding_up_panel",
null
],
[
"riverpod",
null
],
[
"expandable",
null
],
[
"just_audio",
null
],
[
"synchronized",
null
],
[
"uni_links",
null
],
[
"pdf",
null
],
[
"flutter_layout_grid",
null
],
[
"flutter_hooks",
null
],
[
"syncfusion_flutter_charts",
null
],
[
"email_validator",
null
],
[
"rflutter_alert",
null
],
[
"dotted_border",
null
],
[
"package_info_plus",
null
],
[
"flutter_riverpod",
null
],
[
"country_code_picker",
null
],
[
"flutter_facebook_auth",
null
],
[
"shelf",
null
],
[
"get_storage",
null
],
[
"xml",
null
],
[
"connectivity_plus",
null
],
[
"flutter_mobx",
null
],
[
"flutter_markdown",
null
],
[
"dots_indicator",
null
],
[
"dropdown_search",
null
],
[
"retrofit",
null
],
[
"encrypt",
null
],
[
"mockito",
null
],
[
"responsive_builder",
null
],
[
"curved_navigation_bar",
null
],
[
"share_plus",
null
],
[
"built_collection",
null
],
[
"flutter_form_builder",
null
],
[
"flutter_speed_dial",
null
],
[
"english_words",
null
],
[
"petitparser",
null
],
[
"numberpicker",
null
],
[
"flutter_signin_button",
null
],
[
"sembast",
null
],
[
"injectable",
null
],
[
"event_bus",
null
],
[
"syncfusion_flutter_datepicker",
null
],
[
"sentry",
null
],
[
"mime",
null
],
[
"infinite_scroll_pagination",
null
],
[
"socket_io_client",
null
],
[
"fluro",
null
],
[
"persistent_bottom_nav_bar",
null
],
[
"date_format",
null
],
[
"printing",
null
],
[
"device_info_plus",
null
],
[
"pinput",
null
],
[
"sliver_tools",
null
],
[
"awesome_dialog",
null
],
[
"flash",
null
],
[
"convex_bottom_bar",
null
],
[
"flutter_widget_from_html_core",
null
],
[
"liquid_swipe",
null
],
[
"intl_phone_number_input",
null
],
[
"state_notifier",
null
],
[
"responsive_framework",
null
],
[
"material_floating_search_bar",
null
],
[
"yaml",
null
],
[
"lint",
null
],
[
"path_drawing",
null
],
[
"grouped_list",
null
],
[
"audio_service",
null
],
[
"sizer",
null
],
[
"flutter_tts",
null
],
[
"scroll_to_index",
null
],
[
"enum_to_string",
null
],
[
"velocity_x",
null
],
[
"flutter_sound",
null
],
[
"http_parser",
null
],
[
"universal_html",
null
],
[
"barcode",
null
],
[
"syncfusion_flutter_calendar",
null
],
[
"getwidget",
null
],
[
"flutter_switch",
null
],
[
"line_icons",
null
],
[
"flutter_sticky_header",
null
],
[
"clipboard",
null
],
[
"speech_to_text",
null
],
[
"stream_transform",
null
],
[
"like_button",
null
],
[
"flip_card",
null
],
[
"marquee",
null
],
[
"syncfusion_flutter_pdf",
null
],
[
"sentry_flutter",
null
],
[
"syncfusion_flutter_gauges",
null
],
[
"implicitly_animated_reorderable_list",
null
],
[
"flutter_custom_clippers",
null
],
[
"native_pdf_view",
null
],
[
"signature",
null
],
[
"flutter_login",
null
],
[
"toggle_switch",
null
],
[
"dartx",
null
],
[
"mocktail",
null
],
[
"form_field_validator",
null
],
[
"flutter_lints",
null
],
[
"step_progress_indicator",
null
],
[
"pin_input_text_field",
null
],
[
"random_string",
null
],
[
"adaptive_dialog",
null
],
[
"syncfusion_flutter_pdfviewer",
null
],
[
"maps_launcher",
null
],
[
"faker",
null
],
[
"url_strategy",
null
],
[
"formz",
null
],
[
"hexcolor",
null
],
[
"readmore",
null
],
[
"date_time_picker",
null
],
[
"syncfusion_flutter_sliders",
null
],
[
"syncfusion_flutter_core",
null
],
[
"oktoast",
null
],
[
"bloc_test",
null
],
[
"animated_bottom_navigation_bar",
null
],
[
"catcher",
null
],
[
"retry",
null
],
[
"flutter_multi_formatter",
null
],
[
"bubble_tab_indicator",
null
],
[
"lazy_load_scrollview",
null
],
[
"intro_views_flutter",
null
],
[
"expansion_tile_card",
null
],
[
"brasil_fields",
null
],
[
"decimal",
null
],
[
"flick_video_player",
null
],
[
"audio_session",
null
],
[
"html_unescape",
null
],
[
"palette_generator",
null
],
[
"skeleton_text",
null
],
[
"pin_code_text_field",
null
],
[
"translator",
null
],
[
"circular_countdown_timer",
null
],
[
"pub_semver",
null
],
[
"youtube_player_iframe",
null
],
[
"mqtt_client",
null
],
[
"syncfusion_flutter_datagrid",
null
],
[
"auto_animated",
null
],
[
"flutter_styled_toast",
null
],
[
"extended_image_library",
null
],
[
"flutter_parsed_text",
null
],
[
"dash_chat",
null
],
[
"ansicolor",
null
],
[
"dotted_line",
null
],
[
"devicelocale",
null
],
[
"linkify",
null
],
[
"version",
null
],
[
"double_back_to_close_app",
null
],
[
"data_table_2",
null
],
[
"flutter_sms",
null
],
[
"reactive_forms",
null
],
[
"flutter_inner_drawer",
null
],
[
"diacritic",
null
],
[
"horizontal_data_table",
null
],
[
"youtube_explode_dart",
null
],
[
"native_pdf_renderer",
null
],
[
"matrix4_transform",
null
],
[
"google_place",
null
],
[
"snapping_sheet",
null
],
[
"rxdart",
null
],
[
"algolia",
null
],
[
"salomon_bottom_bar",
null
],
[
"styled_text",
null
],
[
"math_expressions",
null
],
[
"focus_detector",
null
],
[
"ionicons",
null
],
[
"common_utils",
null
],
[
"effective_dart",
null
],
[
"shimmer_animation",
null
],
[
"sqflite_common_ffi",
null
],
[
"convert",
null
],
[
"flutter_translate",
null
],
[
"beamer",
null
],
[
"platform_device_id",
null
],
[
"backdrop",
null
],
[
"delayed_display",
null
],
[
"location",
null
],
[
"bordered_text",
null
],
[
"pattern_formatter",
null
],
[
"barcode_widget",
null
],
[
"flutter_flavor",
null
],
[
"flutter_chat_ui",
null
],
[
"very_good_analysis",
null
],
[
"loadmore",
null
],
[
"supercharged_dart",
null
],
[
"simple_gesture_detector",
null
],
[
"extended_nested_scroll_view",
null
],
[
"sqflite_common",
null
],
[
"record",
null
],
[
"substring_highlight",
null
],
[
"kt_dart",
null
],
[
"extended_text",
null
],
[
"custom_refresh_indicator",
null
],
[
"flow_builder",
null
],
[
"flutter_animated_dialog",
null
],
[
"flutter_custom_tabs",
null
],
[
"scratcher",
null
],
[
"timer_count_down",
null
],
[
"ndialog",
null
],
[
"kiwi",
null
],
[
"inview_notifier_list",
null
],
[
"theme_provider",
null
],
[
"filesize",
null
],
[
"group_button",
null
],
[
"top_snackbar_flutter",
null
],
[
"custom_navigation_bar",
null
],
[
"syncfusion_flutter_xlsio",
null
],
[
"maps_toolkit",
null
],
[
"reflectable",
null
],
[
"crop",
null
],
[
"ferry",
null
],
[
"graphs",
null
],
[
"flutter_animator",
null
],
[
"ezanimation",
null
],
[
"stop_watch_timer",
null
],
[
"circular_reveal_animation",
null
],
[
"filter_list",
null
],
[
"google_maps_cluster_manager",
null
],
[
"charcode",
null
],
[
"lpinyin",
null
],
[
"usage",
null
],
[
"syncfusion_flutter_maps",
null
],
[
"flutter_swipe_action_cell",
null
],
[
"search_choices",
null
],
[
"flex_color_picker",
null
],
[
"pinch_zoom",
null
],
[
"dart_json_mapper",
null
],
[
"fluttercontactpicker",
null
],
[
"expand_widget",
null
],
[
"timer_builder",
null
],
[
"adaptive_breakpoints",
null
],
[
"preload_page_view",
null
],
[
"flutter_slider_drawer",
null
],
[
"latlong2",
null
],
[
"flutter_tagging",
null
],
[
"web3dart",
null
],
[
"pointer_interceptor",
null
],
[
"progressive_image",
null
],
[
"easy_mask",
null
],
[
"web_scraper",
null
],
[
"mailto",
null
],
[
"characters",
null
],
[
"buttons_tabbar",
null
],
[
"flutter_sound_lite",
null
],
[
"division",
null
],
[
"extended_text_field",
null
],
[
"supabase",
null
],
[
"flutter_link_previewer",
null
],
[
"fluster",
null
],
[
"whatsapp_unilink",
null
],
[
"shelf_router",
null
],
[
"popover",
null
],
[
"rating_dialog",
null
],
[
"gap",
null
],
[
"flex_color_scheme",
null
],
[
"wiredash",
null
],
[
"flutter_form_bloc",
null
],
[
"rect_getter",
null
],
[
"map",
null
],
[
"jaguar_jwt",
null
],
[
"json_rpc_2",
null
],
[
"direct_select_flutter",
null
],
[
"shamsi_date",
null
],
[
"country_picker",
null
],
[
"streaming_shared_preferences",
null
],
[
"crop_your_image",
null
],
[
"circular_menu",
null
],
[
"sensors_plus",
null
],
[
"flutter_onboard",
null
],
[
"simple_html_css",
null
],
[
"observable_ish",
null
],
[
"network_info_plus",
null
],
[
"duration",
null
],
[
"form_bloc",
null
],
[
"googleapis",
null
],
[
"intercom_flutter",
null
],
[
"oauth2_client",
null
],
[
"fimber",
null
],
[
"darq",
null
],
[
"drag_and_drop_lists",
null
],
[
"textfield_tags",
null
],
[
"audio_video_progress_bar",
null
],
[
"dio_cache_interceptor",
null
],
[
"search_page",
null
],
[
"copy_with_extension",
null
],
[
"hidden_drawer_menu",
null
],
[
"shelf_proxy",
null
],
[
"auth_buttons",
null
],
[
"card_swiper",
null
],
[
"one_context",
null
],
[
"jose",
null
],
[
"email_auth",
null
],
[
"routemaster",
null
],
[
"simple_logger",
null
],
[
"animated_size_and_fade",
null
],
[
"flinq",
null
],
[
"sn_progress_dialog",
null
],
[
"skeleton_loader",
null
],
[
"date_field",
null
],
[
"pluto_grid",
null
],
[
"youtube_plyr_iframe",
null
],
[
"easy_rich_text",
null
],
[
"auto_size_text_pk",
null
],
[
"dart_date",
null
],
[
"painter",
null
],
[
"redux_thunk",
null
],
[
"flutter_conditional_rendering",
null
],
[
"select_form_field",
null
],
[
"flutter_state_notifier",
null
],
[
"easy_dynamic_theme",
null
],
[
"miniplayer",
null
],
[
"objectdb",
null
],
[
"currency_text_input_formatter",
null
],
[
"contained_tab_bar_view",
null
],
[
"day_night_switcher",
null
],
[
"syncfusion_flutter_signaturepad",
null
],
[
"flutter_tex",
null
],
[
"persian_number_utility",
null
],
[
"group_list_view",
null
],
[
"animated_icon_button",
null
],
[
"material_dialogs",
null
],
[
"checked_yaml",
null
],
[
"flutter_simple_dependency_injection",
null
],
[
"hashtagable",
null
],
[
"flutter_intro",
null
],
[
"flutter_localized_locales",
null
],
[
"flutter_spinbox",
null
],
[
"bottom_sheet",
null
],
[
"http_auth",
null
],
[
"responsive_sizer",
null
],
[
"battery_plus",
null
],
[
"stomp_dart_client",
null
],
[
"ai_barcode",
null
],
[
"list_tile_switch",
null
],
[
"flutter_app_lock",
null
],
[
"dart_ipify",
null
],
[
"cupertino_stepper",
null
],
[
"blur",
null
],
[
"feedback",
null
],
[
"stream_chat",
null
],
[
"otp",
null
],
[
"biometric_storage",
null
],
[
"path_provider",
null
],
[
"intl",
null
],
[
"bouncing_widget",
null
],
[
"firebase_core",
null
],
[
"gzx_dropdown_menu",
null
],
[
"sqflite",
null
],
[
"sanitize_html",
null
],
[
"rx_shared_preferences",
null
],
[
"flutter_svg",
null
],
[
"firebase_auth",
null
],
[
"cached_network_image",
null
],
[
"metadata_fetch",
null
],
[
"html2md",
null
],
[
"expandable_bottom_bar",
null
],
[
"password_strength",
null
],
[
"file_saver",
null
],
[
"eventify",
null
],
[
"weekday_selector",
null
],
[
"cloud_firestore",
null
],
[
"firebase_messaging",
null
],
[
"webview_flutter",
null
],
[
"audio_manager",
null
],
[
"permission_handler",
null
],
[
"flutter_local_notifications",
null
],
[
"font_awesome_flutter",
null
],
[
"carousel_slider",
null
],
[
"google_maps_flutter",
null
],
[
"flutter_week_view",
null
],
[
"get",
null
],
[
"zefyrka",
null
],
[
"package_info",
null
],
[
"flutter_cache_manager",
null
],
[
"dropdown_below",
null
],
[
"share",
null
],
[
"injector",
null
],
[
"device_info",
null
],
[
"flutter_slidable",
null
],
[
"sp_util",
null
],
[
"image",
null
],
[
"collection",
null
],
[
"flutter_secure_storage",
null
],
[
"spreadsheet_decoder",
null
],
[
"lumberdash",
null
],
[
"postgrest",
null
],
[
"firebase_storage",
null
],
[
"weather_icons",
null
],
[
"win32",
null
],
[
"drawerbehavior",
null
],
[
"fl_chart",
null
],
[
"firebase_analytics",
null
],
[
"pretty_json",
null
],
[
"sticky_and_expandable_list",
null
],
[
"http_interceptor",
null
],
[
"modal_bottom_sheet",
null
],
[
"numeric_keyboard",
null
],
[
"twilio_flutter",
null
],
[
"json_annotation",
null
],
[
"flutter_verification_code",
null
],
[
"sembast_web",
null
],
[
"flutter_screen_lock",
null
],
[
"flutter_inappwebview",
null
],
[
"cloudinary_public",
null
],
[
"async",
null
],
[
"story",
null
],
[
"show_up_animation",
null
],
[
"quiver",
null
],
[
"adaptive_action_sheet",
null
],
[
"list_ext",
null
],
[
"charts_flutter",
null
],
[
"tcard",
null
],
[
"dot_navigation_bar",
null
],
[
"built_value",
null
],
[
"web_socket_channel",
null
],
[
"local_auth",
null
],
[
"layout",
null
],
[
"archive",
null
],
[
"qr_code_scanner",
null
],
[
"steel_crypt",
null
],
[
"groovin_widgets",
null
],
[
"sign_in_with_apple",
null
],
[
"stream_chat_flutter_core",
null
],
[
"mobx",
null
],
[
"geocode",
null
],
[
"google_directions_api",
null
],
[
"mutex",
null
],
[
"slide_to_act",
null
],
[
"firebase_dynamic_links",
null
],
[
"xml2json",
null
],
[
"extended_image",
null
],
[
"flutter_breadcrumb",
null
],
[
"day_night_time_picker",
null
],
[
"extended_sliver",
null
],
[
"youtube_player_flutter",
null
],
[
"flutter_image_slideshow",
null
],
[
"steps_indicator",
null
],
[
"sprung",
null
],
[
"flutter_keyboard_visibility",
null
],
[
"flutter_image_compress",
null
],
[
"js",
null
],
[
"platform_info",
null
],
[
"flutter_easyloading",
null
],
[
"vxstate",
null
],
[
"visibility_detector",
null
],
[
"introduction_screen",
null
],
[
"flutter_circle_color_picker",
null
],
[
"mask_text_input_formatter",
null
],
[
"about",
null
],
[
"concentric_transition",
null
],
[
"google_polyline_algorithm",
null
],
[
"nil",
null
],
[
"in_app_purchase",
null
],
[
"auto_route",
null
],
[
"fresh",
null
],
[
"fcm_config",
null
],
[
"selectable_autolink_text",
null
],
[
"envify",
null
],
[
"flutter_lorem",
null
],
[
"string_scanner",
null
],
[
"flutter_barcode_scanner",
null
],
[
"after_layout",
null
],
[
"decorated_icon",
null
],
[
"queue",
null
],
[
"loading_gifs",
null
],
[
"flutter_staggered_animations",
null
],
[
"file",
null
],
[
"bottom_bar_with_sheet",
null
],
[
"flutter_dotenv",
null
],
[
"stacked",
null
],
[
"flutter_linkify",
null
],
[
"diffutil_dart",
null
],
[
"timeline_tile",
null
],
[
"moor_db_viewer",
null
],
[
"chat_bubbles",
null
],
[
"path_to_regexp",
null
],
[
"web_browser",
null
],
[
"in_app_review",
null
],
[
"flutter_circular_text",
null
],
[
"disposebag",
null
],
[
"jiffy",
null
],
[
"rive",
null
],
[
"address_search_field",
null
],
[
"sticky_headers",
null
],
[
"glass_kit",
null
],
[
"we_slide",
null
],
[
"ordered_set",
null
],
[
"intro_slider",
null
],
[
"flutter_sliding_up_panel",
null
],
[
"image_gallery_saver",
null
],
[
"moor",
null
],
[
"animate_do",
null
],
[
"flutter_widget_from_html",
null
],
[
"keyboard_actions",
null
],
[
"screenshot",
null
],
[
"better_player",
null
],
[
"flutter_modular",
null
],
[
"cloud_functions",
null
],
[
"scidart",
null
],
[
"overlay_support",
null
],
[
"ffi",
null
],
[
"fzregex",
null
],
[
"rate_my_app",
null
],
[
"flutter_cupertino_datetime_picker",
null
],
[
"bot_toast",
null
],
[
"localstorage",
null
],
[
"hooks_riverpod",
null
],
[
"flutter_polyline_points",
null
],
[
"fpdart",
null
],
[
"http_mock_adapter",
null
],
[
"bottom_navy_bar",
null
],
[
"flutter_bounce",
null
],
[
"pedantic_mono",
null
],
[
"photo_manager",
null
],
[
"another_flushbar",
null
],
[
"flutter_google_places",
null
],
[
"sensors",
null
],
[
"datetime_picker_formfield",
null
],
[
"flutter_credit_card",
null
],
[
"awesome_dropdown",
null
],
[
"flutter_redux",
null
],
[
"freezed_annotation",
null
],
[
"timelines",
null
],
[
"launch_review",
null
],
[
"workmanager",
null
],
[
"avatar_glow",
null
],
[
"material_tag_editor",
null
],
[
"background_fetch",
null
],
[
"google_nav_bar",
null
],
[
"realtime_client",
null
],
[
"localstore",
null
],
[
"text_editor",
null
],
[
"qr",
null
],
[
"flutter_smart_dialog",
null
],
[
"showcaseview",
null
],
[
"crypto_keys",
null
],
[
"flutter_fadein",
null
],
[
"awesome_notifications",
null
],
[
"reorderables",
null
],
[
"universal_io",
null
],
[
"pull_to_refresh_notification",
null
],
[
"pointycastle",
null
],
[
"flutter_picker",
null
],
[
"flutter_webrtc",
null
],
[
"flutter_easyrefresh",
null
],
[
"app_links",
null
],
[
"tap_debouncer",
null
],
[
"shrink_sidemenu",
null
],
[
"gesture_x_detector",
null
],
[
"rubber",
null
],
[
"entry",
null
],
[
"code_builder",
null
],
[
"fast_i18n",
null
],
[
"flutter_phoenix",
null
],
[
"bonfire",
null
],
[
"states_rebuilder",
null
],
[
"settings_ui",
null
],
[
"spotify_sdk",
null
],
[
"string_validator",
null
],
[
"holding_gesture",
null
],
[
"basic_utils",
null
],
[
"adobe_xd",
null
],
[
"country_provider",
null
],
[
"upgrader",
null
],
[
"flare_splash_screen",
null
],
[
"multi_select_flutter",
null
],
[
"stacked_services",
null
],
[
"time",
null
],
[
"rounded_loading_button",
null
],
[
"tutorial_coach_mark",
null
],
[
"jwt_decoder",
null
],
[
"syncfusion_localizations",
null
],
[
"protobuf",
null
],
[
"tint",
null
],
[
"flutter_ffmpeg",
null
],
[
"geoflutterfire",
null
],
[
"phone_numbers_parser",
null
],
[
"blurhash_dart",
null
],
[
"optional",
null
],
[
"swipable_stack",
null
],
[
"draggable_widget",
null
],
[
"hydrated_bloc",
null
],
[
"mvc_pattern",
null
],
[
"wc_form_validators",
null
],
[
"animated_splash_screen",
null
],
[
"country_pickers",
null
],
[
"wave",
null
],
[
"detectable_text_field",
null
],
[
"flutter_firebase_chat_core",
null
],
[
"adaptive_navigation",
null
],
[
"pie_chart",
null
],
[
"wechat_assets_picker",
null
],
[
"animator",
null
],
[
"flutter_portal",
null
],
[
"battery",
null
],
[
"circular_countdown",
null
],
[
"fab_circular_menu",
null
],
[
"flutter_auth_ui",
null
],
[
"purchases_flutter",
null
],
[
"location_permissions",
null
],
[
"google_ml_kit",
null
],
[
"back_button_interceptor",
null
],
[
"syncfusion_officechart",
null
],
[
"quick_actions",
null
],
[
"relative_scale",
null
],
[
"infinite_listview",
null
],
[
"asn1lib",
null
],
[
"plaid_flutter",
null
],
[
"sliding_sheet",
null
],
[
"jitsi_meet",
null
],
[
"adaptive_theme",
null
],
[
"flutter_stripe",
null
],
[
"cross_file",
null
],
[
"liquid_pull_to_refresh",
null
],
[
"cool_alert",
null
],
[
"vs_scrollbar",
null
],
[
"fresh_dio",
null
],
[
"chewie_audio",
null
],
[
"empty_widget",
null
],
[
"internet_connection_checker",
null
],
[
"sqlite3",
null
],
[
"store_redirect",
null
],
[
"duration_picker",
null
],
[
"google_maps_utils",
null
],
[
"need_resume",
null
],
[
"profanity_filter",
null
],
[
"loading_overlay",
null
],
[
"flutter_chat_types",
null
],
[
"i18n",
null
],
[
"draggable_scrollbar",
null
],
[
"flutter_sliding_tutorial",
null
],
[
"loading_indicator",
null
],
[
"fancy_drawer",
null
],
[
"im_stepper",
null
],
[
"image_downloader",
null
],
[
"liquid_progress_indicator",
null
],
[
"latlng",
null
],
[
"i18n_extension",
null
],
[
"container_tab_indicator",
null
],
[
"new_version",
null
],
[
"progress_indicators",
null
],
[
"syncfusion_flutter_treemap",
null
],
[
"date_picker_timeline",
null
],
[
"flutter_login_facebook",
null
],
[
"flutter_background_geolocation",
null
],
[
"intl_phone_field",
null
],
[
"gql_link",
null
],
[
"image_crop",
null
],
[
"flutter_appauth",
null
],
[
"city_pickers",
null
],
[
"flutter_pagewise",
null
],
[
"pausable_timer",
null
],
[
"image_stack",
null
],
[
"flutter_keyboard_size",
null
],
[
"flutter_isolate",
null
],
[
"json_path",
null
],
[
"sticky_infinite_list",
null
],
[
"alphabet_scroll_view",
null
],
[
"eva_icons_flutter",
null
],
[
"render_metrics",
null
],
[
"keframe",
null
],
[
"rational",
null
],
[
"loading_animations",
null
],
[
"nepali_utils",
null
],
[
"dbcrypt",
null
],
[
"feature_discovery",
null
],
[
"pay",
null
],
[
"link_text",
null
],
[
"typicons_flutter",
null
],
[
"share_extend",
null
],
[
"shifting_tabbar",
null
],
[
"facebook_app_events",
null
],
[
"easy_debounce",
null
],
[
"replay_bloc",
null
],
[
"numerus",
null
],
[
"functional_listener",
null
],
[
"searchfield",
null
],
[
"cron",
null
],
[
"cell_calendar",
null
],
[
"flutter_zoom_drawer",
null
],
[
"oauth2",
null
],
[
"infinite_carousel",
null
],
[
"split_view",
null
],
[
"slugid",
null
],
[
"executor",
null
],
[
"googleapis_auth",
null
],
[
"numeral",
null
],
[
"flutter_reaction_button",
null
],
[
"flutter_i18n",
null
],
[
"tiktoklikescroller",
null
],
[
"flutter_ringtone_player",
null
],
[
"mysql1",
null
],
[
"get_it_mixin",
null
],
[
"objectid",
null
],
[
"process_run",
null
],
[
"motion_toast",
null
],
[
"wordpress_api",
null
],
[
"objectbox",
null
],
[
"widget_circular_animator",
null
],
[
"html_editor_enhanced",
null
],
[
"flutter_meedu",
null
],
[
"more",
null
],
[
"scroll_snap_list",
null
],
[
"linked_scroll_controller",
null
],
[
"ntp",
null
],
[
"svg_path_parser",
null
],
[
"date_time_format",
null
],
[
"stream_chat_flutter",
null
],
[
"rate_limiter",
null
],
[
"date_range_form_field",
null
],
[
"flutter_grid_button",
null
],
[
"page_indicator",
null
],
[
"paginate_firestore",
null
],
[
"image_cropper",
null
],
[
"cryptography",
null
],
[
"hijri_picker",
null
],
[
"argon_buttons_flutter",
null
],
[
"either_dart",
null
],
[
"onboarding",
null
],
[
"animated_theme_switcher",
null
],
[
"quick_log",
null
],
[
"keyboard_dismisser",
null
],
[
"google_api_headers",
null
],
[
"lazy_data_table",
null
],
[
"draggable_home",
null
],
[
"styled_widget",
null
],
[
"line_awesome_flutter",
null
],
[
"qlevar_router",
null
],
[
"flutter_snake_navigationbar",
null
],
[
"checkbox_grouped",
null
],
[
"assorted_layout_widgets",
null
],
[
"timeago",
null
],
[
"super_tooltip",
null
],
[
"move_to_background",
null
],
[
"mongo_dart",
null
],
[
"gql_http_link",
null
],
[
"fwfh_webview",
null
],
[
"rules",
null
],
[
"vrouter",
null
],
[
"dio_cookie_manager",
null
],
[
"chunked_stream",
null
],
[
"gpx",
null
],
[
"video_trimmer",
null
],
[
"alice",
null
],
[
"oauth_dio",
null
],
[
"flutter_webview_plugin",
null
],
[
"basics",
null
],
[
"http_client",
null
],
[
"money2",
null
],
[
"geoflutterfire2",
null
],
[
"soundpool",
null
],
[
"flutter_material_color_picker",
null
],
[
"barcode_scan2",
null
],
[
"flutter_mailer",
null
],
[
"route_transitions",
null
],
[
"forge2d",
null
],
[
"elastic_client",
null
],
[
"lints",
null
],
[
"progress_state_button",
null
],
[
"align_positioned",
null
],
[
"fading_edge_scrollview",
null
],
[
"flutter_feather_icons",
null
],
[
"intersperse",
null
],
[
"google_static_maps_controller",
null
],
[
"splash_screen_view",
null
],
[
"route_observer_mixin",
null
],
[
"stats",
null
],
[
"firestore_ui",
null
],
[
"flutter_branch_sdk",
null
],
[
"phone_number",
null
],
[
"bottom_bar",
null
],
[
"geocoding",
null
],
[
"community_material_icon",
null
],
[
"money_formatter",
null
],
[
"country_list_pick",
null
],
[
"clay_containers",
null
],
[
"flutter_date_pickers",
null
],
[
"mixpanel_analytics",
null
],
[
"xterm",
null
],
[
"time_picker_widget",
null
],
[
"pool",
null
],
[
"health",
null
],
[
"week_of_year",
null
],
[
"just_audio_background",
null
],
[
"mwwm",
null
],
[
"pagination_view",
null
],
[
"dismissible_page",
null
],
[
"throttling",
null
],
[
"show_more_text_popup",
null
],
[
"responsive_ui",
null
],
[
"remove_emoji",
null
],
[
"waterfall_flow",
null
],
[
"solid_bottom_sheet",
null
],
[
"currency_picker",
null
],
[
"flutter_braintree",
null
],
[
"json_table",
null
],
[
"flutter_statusbarcolor_ns",
null
],
[
"flustars",
null
],
[
"webview_flutter_plus",
null
],
[
"macos_ui",
null
],
[
"bezier",
null
],
[
"helpers",
null
],
[
"amplify_flutter",
null
],
[
"flutter_config",
null
],
[
"sqlparser",
null
],
[
"emoji_picker_flutter",
null
],
[
"barcode_image",
null
],
[
"lazy_loading_list",
null
],
[
"custom_radio_grouped_button",
null
],
[
"flutter_libphonenumber",
null
],
[
"async_button_builder",
null
],
[
"flutter_chips_input",
null
],
[
"flutter_date_picker_timeline",
null
],
[
"expandable_bottom_sheet",
null
],
[
"flutter_time_picker_spinner",
null
],
[
"flutter_rating_stars",
null
],
[
"stash",
null
],
[
"extended_masked_text",
null
],
[
"local_image_provider",
null
],
[
"pedometer",
null
],
[
"deep_pick",
null
],
[
"shake",
null
],
[
"select_dialog",
null
],
[
"overlay_tutorial",
null
],
[
"spannable_grid",
null
],
[
"expandable_text",
null
],
[
"stack_trace",
null
],
[
"signalr_core",
null
],
[
"golden_toolkit",
null
],
[
"flutter_animated_button",
null
],
[
"accordion",
null
],
[
"http_multi_server",
null
],
[
"shelf_web_socket",
null
],
[
"selection_menu",
null
],
[
"flutter_udid",
null
],
[
"flutter_exif_rotation",
null
],
[
"tab_indicator_styler",
null
],
[
"loader_overlay",
null
],
[
"marquee_text",
null
],
[
"rainbow_color",
null
],
[
"morphable_shape",
null
],
[
"typed_data",
null
],
[
"wifi_iot",
null
],
[
"material_segmented_control",
null
],
[
"fijkplayer",
null
],
[
"redux",
null
],
[
"firestore_cache",
null
],
[
"just_debounce_it",
null
],
[
"sqlite3_flutter_libs",
null
],
[
"nine_grid_view",
null
],
[
"queen_validators",
null
],
[
"wechat_camera_picker",
null
],
[
"flutter_archive",
null
],
[
"sized_context",
null
],
[
"menu_button",
null
],
[
"sign_button",
null
],
[
"amplify_core",
null
],
[
"yaru",
null
],
[
"jwt_decode",
null
],
[
"dynamic_widget",
null
],
[
"flutter_treeview",
null
],
[
"multi_image_picker2",
null
],
[
"flutter_svg_provider",
null
],
[
"recase",
null
],
[
"zoom_pinch_overlay",
null
],
[
"flutter_map_marker_popup",
null
],
[
"pdf_render",
null
],
[
"weather",
null
],
[
"indexed_list_view",
null
],
[
"webviewx",
null
],
[
"nfc_manager",
null
],
[
"webview_cookie_manager",
null
],
[
"extension",
null
],
[
"shelf_static",
null
],
[
"fake_async",
null
],
[
"ars_dialog",
null
],
[
"epub_viewer",
null
],
[
"gql_dio_link",
null
],
[
"flutter_menu",
null
],
[
"flutter_hsvcolor_picker",
null
],
[
"animate_icons",
null
],
[
"animated_background",
null
],
[
"base32",
null
],
[
"flutter_map_marker_cluster",
null
],
[
"pref",
null
],
[
"firebase_auth_oauth",
null
],
[
"cbor",
null
],
[
"scroll_navigation",
null
],
[
"hashids2",
null
],
[
"fraction",
null
],
[
"time_range_picker",
null
],
[
"function_tree",
null
],
[
"dotted_decoration",
null
],
[
"keyboard_service",
null
],
[
"vm_service",
null
],
[
"rx_bloc",
null
],
[
"stream_channel",
null
],
[
"exif",
null
],
[
"async_redux",
null
],
[
"cross_local_storage",
null
],
[
"direct_select",
null
],
[
"matcher",
null
],
[
"slugify",
null
],
[
"flutter_gherkin",
null
],
[
"number_display",
null
],
[
"flutter_google_places_hoc081098",
null
],
[
"geojson_vi",
null
],
[
"momentum",
null
],
[
"credit_card_validator",
null
],
[
"extension_google_sign_in_as_googleapis_auth",
null
],
[
"mock_data",
null
],
[
"loading_more_list",
null
],
[
"thumbnailer",
null
],
[
"giphy_picker",
null
],
[
"get_time_ago",
null
],
[
"expandable_page_view",
null
],
[
"custom_pop_up_menu",
null
],
[
"boolean_selector",
null
],
[
"another_transformer_page_view",
null
],
[
"syncfusion_flutter_barcodes",
null
],
[
"horizontal_blocked_scroll_physics",
null
],
[
"flutter_toggle_tab",
null
],
[
"stacked_themes",
null
],
[
"floating_bottom_navigation_bar",
null
],
[
"secure_application",
null
],
[
"connectivity_wrapper",
null
],
[
"dropdown_plus",
null
],
[
"multiple_localization",
null
],
[
"extended_tabs",
null
],
[
"flutter_clean_calendar",
null
],
[
"filepicker_windows",
null
],
[
"pretty_qr_code",
null
],
[
"find_dropdown",
null
],
[
"flutter_arc_speed_dial",
null
],
[
"app_review",
null
],
[
"overflow_view",
null
],
[
"hovering",
null
],
[
"editable",
null
],
[
"circular_clip_route",
null
],
[
"table_sticky_headers",
null
],
[
"snack",
null
],
[
"random_password_generator",
null
],
[
"localize_and_translate",
null
],
[
"redux_saga",
null
],
[
"flutter_mentions",
null
],
[
"dbus",
null
],
[
"glass",
null
],
[
"flutter_scroll_to_top",
null
],
[
"backdrop_modal_route",
null
],
[
"flutter_overlay_loader",
null
],
[
"breakpoint",
null
],
[
"animated_flip_counter",
null
],
[
"country_icons",
null
],
[
"custom_clippers",
null
],
[
"anim_search_bar",
null
],
[
"csc_picker",
null
],
[
"simple_url_preview",
null
],
[
"skeleton_animation",
null
],
[
"cross_connectivity",
null
],
[
"angles",
null
],
[
"environment_config",
null
],
[
"dart_console",
null
],
[
"puppeteer",
null
],
[
"charset_converter",
null
],
[
"multiselect",
null
],
[
"flutter_mapbox_navigation",
null
],
[
"drag_select_grid_view",
null
],
[
"hand_signature",
null
],
[
"radar_chart",
null
],
[
"keyboard_attachable",
null
],
[
"flutter_triple",
null
],
[
"flutter_iconpicker",
null
],
[
"cupertino_list_tile",
null
],
[
"io",
null
],
[
"slide_to_confirm",
null
],
[
"flutter_rx_bloc",
null
],
[
"sembast_sqflite",
null
],
[
"flutter_advanced_avatar",
null
],
[
"flutter_contacts",
null
],
[
"prefs",
null
],
[
"matrix_api_lite",
null
],
[
"statsfl",
null
],
[
"socket_io",
null
],
[
"confirm_dialog",
null
],
[
"folding_cell",
null
],
[
"home_widget",
null
],
[
"http_client_helper",
null
],
[
"flutter_bootstrap",
null
],
[
"relation",
null
],
[
"black_hole_flutter",
null
],
[
"nanoid",
null
],
[
"country_code",
null
],
[
"idb_sqflite",
null
],
[
"shared_value",
null
],
[
"rx_notifier",
null
],
[
"highlight_text",
null
],
[
"appwrite",
null
],
[
"in_app_notification",
null
],
[
"list_tile_more_customizable",
null
],
[
"cupertino_icons",
null
],
[
"string_similarity",
null
],
[
"mouse_parallax",
null
],
[
"storybook_flutter",
null
],
[
"glassmorphism_ui",
null
],
[
"flutter_color",
null
],
[
"webcrypto",
null
],
[
"auto_size_text",
null
],
[
"pixel_perfect",
null
],
[
"simple_rich_text",
null
],
[
"flutter_html",
null
],
[
"onboarding_overlay",
null
],
[
"otp_text_field",
null
],
[
"github",
null
],
[
"widgets_visibility_provider",
null
],
[
"pubspec_parse",
null
],
[
"flutter_fortune_wheel",
null
],
[
"json_serializable",
null
],
[
"camera",
null
],
[
"flutter_barcode_sdk",
null
],
[
"camcode",
null
],
[
"flutter_advanced_switch",
null
],
[
"humanizer",
null
],
[
"flutter_advanced_drawer",
null
],
[
"i69n",
null
],
[
"firebase_crashlytics",
null
],
[
"flutter_swiper",
null
],
[
"dart_geohash",
null
],
[
"sortedmap",
null
],
[
"calendar_time",
null
],
[
"flutter_playout",
null
],
[
"clickable_list_wheel_view",
null
],
[
"code_editor",
null
],
[
"meta",
null
],
[
"candlesticks",
null
],
[
"advanced_datatable",
null
],
[
"neat_periodic_task",
null
],
[
"firebase_app_check",
null
],
[
"hijri",
null
],
[
"screen_recorder",
null
],
[
"flame_forge2d",
null
],
[
"custom_timer",
null
],
[
"crypt",
null
],
[
"blobs",
null
],
[
"openpgp",
null
],
[
"cool_stepper",
null
],
[
"jalali_calendar",
null
],
[
"odoo_rpc",
null
],
[
"transition",
null
],
[
"html",
null
],
[
"vertical_card_pager",
null
],
[
"smooth_page_indicator",
null
],
[
"yeet",
null
],
[
"logging",
null
],
[
"google_mobile_ads",
null
],
[
"flutter_datetime_picker",
null
],
[
"dart_jsonwebtoken",
null
],
[
"flutter_update_dialog",
null
],
[
"chat_list",
null
],
[
"marquee_widget",
null
],
[
"scrollable_positioned_list",
null
],
[
"oauth1",
null
],
[
"slide_drawer",
null
],
[
"dartz",
null
],
[
"theme_mode_handler",
null
],
[
"dependency_validator",
null
],
[
"tuple",
null
],
[
"unsplash_client",
null
],
[
"syncfusion_officecore",
null
],
[
"firebase_database",
null
],
[
"url_launcher_windows",
null
],
[
"ai_awesome_message",
null
],
[
"colorful_safe_area",
null
],
[
"ulid",
null
],
[
"open_file",
null
],
[
"roller_list",
null
],
[
"flutter_downloader",
null
],
[
"client_information",
null
],
[
"onesignal_flutter",
null
],
[
"args",
null
],
[
"persian_datetime_picker",
null
],
[
"roundcheckbox",
null
],
[
"signal_strength_indicator",
null
],
[
"auto_direction",
null
],
[
"google_geocoding",
null
],
[
"device_preview",
null
],
[
"multiple_result",
null
],
[
"sound_stream",
null
],
[
"hive_flutter",
null
],
[
"openid_client",
null
],
[
"scroll_app_bar",
null
],
[
"transparent_image",
null
],
[
"flutter_balloon_slider",
null
],
[
"test",
null
],
[
"firebase_remote_config",
null
],
[
"flutter_map",
null
],
[
"focus_widget",
null
],
[
"flutter_radar_chart",
null
],
[
"multiple_stream_builder",
null
],
[
"country_state_city_picker",
null
],
[
"flutter_qiblah",
null
],
[
"uiblock",
null
],
[
"flutter_colorpicker",
null
],
[
"appmetrica_sdk",
null
],
[
"flutter_swiper_null_safety",
null
],
[
"geojson",
null
],
[
"vector_math",
null
],
[
"app_settings",
null
],
[
"flutter_overboard",
null
],
[
"asset_cache",
null
],
[
"extended_text_library",
null
],
[
"freezed",
null
],
[
"simple_icons",
null
],
[
"video_viewer",
null
],
[
"loadany",
null
],
[
"redux_persist",
null
],
[
"selectable_container",
null
],
[
"fluent_ui",
null
],
[
"flutter_dialogs",
null
],
[
"bmprogresshud",
null
],
[
"fvm",
null
],
[
"chart_sparkline",
null
],
[
"page_flip_builder",
null
],
[
"unicons",
null
],
[
"collection_ext",
null
],
[
"undo",
null
],
[
"json_api",
null
],
[
"redux_epics",
null
],
[
"highlight",
null
],
[
"dough",
null
],
[
"animated_rotation",
null
],
[
"assets_audio_player",
null
],
[
"string_to_hex",
null
],
[
"json_theme",
null
],
[
"icalendar_parser",
null
],
[
"android_intent",
null
],
[
"http_retry",
null
],
[
"favorite_button",
null
],
[
"flutter_tesseract_ocr",
null
],
[
"flutter_pay",
null
],
[
"giphy_get",
null
],
[
"vibration",
null
],
[
"rsa_encrypt",
null
],
[
"contacts_service",
null
],
[
"flutter_remix",
null
],
[
"responsive_util",
null
],
[
"openapi_generator",
null
],
[
"draw_graph",
null
],
[
"open_settings",
null
],
[
"crypton",
null
],
[
"tobias",
null
],
[
"mercadopago_sdk",
null
],
[
"flutter_osm_plugin",
null
],
[
"navigation_history_observer",
null
],
[
"boxy",
null
],
[
"cherry_toast",
null
],
[
"agora_rtc_engine",
null
],
[
"flutter_calendar_carousel",
null
],
[
"completion",
null
],
[
"flutter_local_notifications_platform_interface",
null
],
[
"incrementally_loading_listview",
null
],
[
"universal_platform",
null
],
[
"bubble",
null
],
[
"bubble_showcase",
null
],
[
"riverbloc",
null
],
[
"enough_convert",
null
],
[
"map_launcher",
null
],
[
"custom_info_window",
null
],
[
"deeply",
null
],
[
"scoped_model",
null
],
[
"uni_links2",
null
],
[
"icon_picker",
null
],
[
"bottom_sheet_bar",
null
],
[
"razorpay_flutter",
null
],
[
"heic_to_jpg",
null
],
[
"video_thumbnail",
null
],
[
"fast_rsa",
null
],
[
"memoize",
null
],
[
"touchable_opacity",
null
],
[
"flutter_neumorphic",
null
],
[
"flutter_platform_widgets",
null
],
[
"ez_localization",
null
],
[
"search_app_bar_page",
null
],
[
"sleek_circular_slider",
null
],
[
"circle_list",
null
],
[
"cupertino_back_gesture",
null
],
[
"double_back_to_close",
null
],
[
"l",
null
],
[
"watcher",
null
],
[
"g_json",
null
],
[
"r_upgrade",
null
],
[
"chopper",
null
],
[
"dart_extensions",
null
],
[
"polls",
null
],
[
"statemachine",
null
],
[
"node_preamble",
null
],
[
"flutter_email_sender",
null
],
[
"flutter_line_sdk",
null
],
[
"truncate",
null
],
[
"flutter_stream_listener",
null
],
[
"direct_link",
null
],
[
"floor",
null
],
[
"markdown",
null
],
[
"flutter_beacon",
null
],
[
"responsive_navigation_bar",
null
],
[
"linkedin_login",
null
],
[
"confetti",
null
],
[
"simple_fontellico_progress_dialog",
null
],
[
"ftpconnect",
null
],
[
"fluid_kit",
null
],
[
"mustache_template",
null
],
[
"messagepack",
null
],
[
"flappy_search_bar_ns",
null
],
[
"geo",
null
],
[
"async_task",
null
],
[
"agora_uikit",
null
],
[
"bip39",
null
],
[
"smooth_sort",
null
],
[
"noise_meter",
null
],
[
"video_compress",
null
],
[
"copy_with_extension_gen",
null
],
[
"diffutil_sliverlist",
null
],
[
"gallery_saver",
null
],
[
"water_drop_nav_bar",
null
],
[
"rxdart_ext",
null
],
[
"validators",
null
],
[
"just_audio_platform_interface",
null
],
[
"sliding_clipped_nav_bar",
null
],
[
"moor_flutter",
null
],
[
"photo_gallery",
null
],
[
"persian",
null
],
[
"disposable_provider",
null
],
[
"future_progress_dialog",
null
],
[
"get_ip_address",
null
],
[
"flutter_tags",
null
],
[
"loading_overlay_pro",
null
],
[
"linkable",
null
],
[
"phonenumbers",
null
],
[
"value_layout_builder",
null
],
[
"chips_input",
null
],
[
"fixnum",
null
],
[
"functional_data",
null
],
[
"app_tracking_transparency",
null
],
[
"csv",
null
],
[
"bloc_provider",
null
],
[
"clock",
null
],
[
"firebase_performance",
null
],
[
"flutter_vector_icons",
null
],
[
"dart_code_metrics",
null
],
[
"desktop_notifications",
null
],
[
"flutter_native_timezone",
null
],
[
"chart_components",
null
],
[
"tflite",
null
],
[
"daylight",
null
],
[
"flutter_quill",
null
],
[
"linkwell",
null
],
[
"flutter_inapp_purchase",
null
],
[
"simple_grid",
null
],
[
"flutter_share",
null
],
[
"receive_sharing_intent",
null
],
[
"safe_device",
null
],
[
"record_mp3",
null
],
[
"paged_vertical_calendar",
null
],
[
"animated_clipper",
null
],
[
"flowder",
null
],
[
"quran",
null
],
[
"star_menu",
null
],
[
"mobx_codegen",
null
],
[
"lat_lng_to_timezone",
null
],
[
"version_tracker",
null
],
[
"passcode_screen",
null
],
[
"grpc",
null
],
[
"flutter_hud",
null
],
[
"extended_list",
null
],
[
"media_info",
null
],
[
"cubes",
null
],
[
"device_apps",
null
],
[
"unity_ads_plugin",
null
],
[
"nepali_date_picker",
null
],
[
"flutter_offline",
null
],
[
"cupertino_listview",
null
],
[
"flutter_paystack",
null
],
[
"flutter_rounded_date_picker",
null
],
[
"flutter_cart",
null
],
[
"jaguar",
null
],
[
"fluttericon",
null
],
[
"intl_utils",
null
],
[
"scroll_bottom_navigation_bar",
null
],
[
"sprintf",
null
],
[
"fresh_graphql",
null
],
[
"flutter_command",
null
],
[
"page_view_dot_indicator",
null
],
[
"expansion_widget",
null
],
[
"flutter_colorful_tab",
null
],
[
"fancy_bar",
null
],
[
"native_device_orientation",
null
],
[
"odometer",
null
],
[
"fancy_bottom_navigation",
null
],
[
"idb_shim",
null
],
[
"result_type",
null
],
[
"mapbox_gl",
null
],
[
"flutter_appcenter_bundle",
null
],
[
"customizable_space_bar",
null
],
[
"android_alarm_manager",
null
],
[
"wechat_kit",
null
],
[
"number_slide_animation",
null
],
[
"yandex_geocoder",
null
],
[
"is_first_run",
null
],
[
"functions_framework",
null
],
[
"flutter_pw_validator",
null
],
[
"prompt_dialog",
null
],
[
"flutter_cupertino_date_picker",
null
],
[
"firebase_in_app_messaging",
null
],
[
"swipe",
null
],
[
"us_states",
null
],
[
"notification_permissions",
null
],
[
"focused_menu",
null
],
[
"flutter_dynamic_icon",
null
],
[
"fullscreen",
null
],
[
"fhir_yaml",
null
],
[
"signalr_flutter",
null
],
[
"dio_log",
null
],
[
"instabug_flutter",
null
],
[
"background_app_bar",
null
],
[
"flutter_chat_bubble",
null
],
[
"simple_autocomplete_formfield",
null
],
[
"braze_plugin",
null
],
[
"multiline",
null
],
[
"expressions",
null
],
[
"subtitle_wrapper_package",
null
],
[
"azlistview",
null
],
[
"flutter_placeholder_textlines",
null
],
[
"flutter_genius_scan",
null
],
[
"tflite_flutter",
null
],
[
"flutter_vlc_player",
null
],
[
"dnd",
null
],
[
"resizable_widget",
null
],
[
"analytics",
null
],
[
"flutter_point_tab_bar",
null
],
[
"flutter_spinkit",
null
],
[
"cupertino_rounded_corners",
null
],
[
"r_scan",
null
],
[
"animated_button_bar",
null
],
[
"pdf_text",
null
],
[
"kana_kit",
null
],
[
"flutter_decorated_text",
null
],
[
"device_frame",
null
],
[
"text_style_editor",
null
],
[
"dart_ping",
null
],
[
"background_location",
null
],
[
"flutter_unity_widget",
null
],
[
"flutter_sequence_animation",
null
],
[
"swiss_knife",
null
],
[
"dart_jts",
null
],
[
"nb_utils",
null
],
[
"horizontal_card_pager",
null
],
[
"dart_nats",
null
],
[
"flutter_charts",
null
],
[
"flutter_fawry_pay",
null
],
[
"timing",
null
],
[
"ffigen",
null
],
[
"jovial_svg",
null
],
[
"flutter_animation_progress_bar",
null
],
[
"simple_timer",
null
],
[
"playing_cards",
null
],
[
"expansion_card",
null
],
[
"auth",
null
],
[
"dart_phonetics",
null
],
[
"flutter_vpn",
null
],
[
"animated_widgets",
null
],
[
"stretchy_header",
null
],
[
"input_with_keyboard_control",
null
],
[
"dashed_circle",
null
],
[
"day",
null
],
[
"tinkoff_acquiring",
null
],
[
"time_ago_provider",
null
],
[
"multiselect_formfield",
null
],
[
"responsive_layout_builder",
null
],
[
"flutter_lock_screen",
null
],
[
"zoom_widget",
null
],
[
"animated_radio_buttons",
null
],
[
"device_information",
null
],
[
"flutter_boxicons",
null
],
[
"file_picker_cross",
null
],
[
"scroll_date_picker",
null
],
[
"page_view_indicators",
null
],
[
"gender_picker",
null
],
[
"flutter_neat_and_clean_calendar",
null
],
[
"network_to_file_image",
null
],
[
"bloc_pattern",
null
],
[
"month_picker_dialog",
null
],
[
"storyboard",
null
],
[
"otp_autofill",
null
],
[
"swipeable_tile",
null
],
[
"animated_stack",
null
],
[
"flutter_map_tappable_polyline",
null
],
[
"redux_persist_flutter",
null
],
[
"spotify",
null
],
[
"xxtea",
null
],
[
"slider_button",
null
],
[
"dynamic_themes",
null
],
[
"light_compressor",
null
],
[
"flutter_reactive_ble",
null
],
[
"configurable_expansion_tile",
null
],
[
"native_shared_preferences",
null
],
[
"openapi_generator_annotations",
null
],
[
"flutter_fancy_tree_view",
null
],
[
"mad_pay",
null
],
[
"volume_watcher",
null
],
[
"jdenticon_dart",
null
],
[
"objectbox_flutter_libs",
null
],
[
"calendar_appbar",
null
],
[
"camerawesome",
null
],
[
"flutter_signature_pad",
null
],
[
"images_picker",
null
],
[
"bottom_bar_page_transition",
null
],
[
"spider",
null
],
[
"flutter_windowmanager",
null
],
[
"multi_split_view",
null
],
[
"pem",
null
],
[
"flutter_web_browser",
null
],
[
"fl_toast",
null
],
[
"flutter_automation",
null
],
[
"sealed_flutter_bloc",
null
],
[
"flutter_advanced_segment",
null
],
[
"rx_storage",
null
],
[
"banner_carousel",
null
],
[
"local_hero",
null
],
[
"activity_recognition_flutter",
null
],
[
"flutter_otp_text_field",
null
],
[
"interval_tree",
null
],
[
"flutter_hooks_bloc",
null
],
[
"debounce_throttle",
null
],
[
"image_picker_web",
null
],
[
"material",
null
],
[
"flutter_compass",
null
],
[
"dart_amqp",
null
],
[
"flare_loading",
null
],
[
"video_editor",
null
],
[
"shadow",
null
],
[
"document_scanner",
null
],
[
"meedu",
null
],
[
"camera_camera",
null
],
[
"switcher_button",
null
],
[
"http_methods",
null
],
[
"flutter_math_fork",
null
],
[
"amplify_auth_cognito",
null
],
[
"flutter_initicon",
null
],
[
"particles_flutter",
null
],
[
"seo_renderer",
null
],
[
"native_admob_flutter",
null
],
[
"dimension",
null
],
[
"libphonenumber",
null
],
[
"directed_graph",
null
],
[
"flutter_share_me",
null
],
[
"snapping_page_scroll",
null
],
[
"fake_cloud_firestore",
null
],
[
"flutter_sheet_localization",
null
],
[
"platform_detect",
null
],
[
"triple",
null
],
[
"postgres",
null
],
[
"auto_size_text_field",
null
],
[
"dart_twitter_api",
null
],
[
"stack",
null
],
[
"cookie_jar",
null
],
[
"gradient_widgets",
null
],
[
"flutter_login_vk",
null
],
[
"cli_util",
null
],
[
"complex",
null
],
[
"listenable_stream",
null
],
[
"crisp",
null
],
[
"liquid_progress_indicator_ns",
null
],
[
"flutter_dropdown_alert",
null
],
[
"html_character_entities",
null
],
[
"alphabet_list_scroll_view",
null
],
[
"time_planner",
null
],
[
"group_radio_button",
null
],
[
"cupertino_will_pop_scope",
null
],
[
"esewa_pnp",
null
],
[
"graphql",
null
],
[
"sorted_list",
null
],
[
"gql",
null
],
[
"gato",
null
],
[
"webfeed",
null
],
[
"resize",
null
],
[
"sqflite_sqlcipher",
null
],
[
"flutter_progress_hud",
null
],
[
"flutter_holo_date_picker",
null
],
[
"app_installer",
null
],
[
"blurhash",
null
],
[
"colorize_text_avatar",
null
],
[
"surf_mwwm",
null
],
[
"rich_text_controller",
null
],
[
"openfoodfacts",
null
],
[
"csslib",
null
],
[
"iban",
null
],
[
"stripe",
null
],
[
"redux_remote_devtools",
null
],
[
"flutter_social_content_share",
null
],
[
"refresh_loadmore",
null
],
[
"bottom_navigation_bar",
null
],
[
"computer",
null
],
[
"flutter_speech",
null
],
[
"flutter_json_view",
null
],
[
"turkish",
null
],
[
"telephony",
null
],
[
"flutter_html_to_pdf",
null
],
[
"wc_flutter_share",
null
],
[
"swipe_to",
null
],
[
"path_parsing",
null
],
[
"carp_background_location",
null
],
[
"libphonenumber_plugin",
null
],
[
"backendless_sdk",
null
],
[
"ml_linalg",
null
],
[
"kakao_flutter_sdk",
null
],
[
"network_image_mock",
null
],
[
"bs_flutter_datatable",
null
],
[
"rabbit_converter",
null
],
[
"surf_lint_rules",
null
],
[
"simple_tooltip",
null
],
[
"cli_dialog",
null
],
[
"fluentui_system_icons",
null
],
[
"canonical_json",
null
],
[
"credit_card_type_detector",
null
],
[
"flutter_shimmer",
null
],
[
"ota_update",
null
],
[
"rx_command",
null
],
[
"flutter_highlight",
null
],
[
"buffer",
null
],
[
"new_gradient_app_bar",
null
],
[
"upi_pay",
null
],
[
"hydrated",
null
],
[
"quds_ui_kit",
null
],
[
"alfred",
null
],
[
"flutter_scatter",
null
],
[
"flutter_arc_text",
null
],
[
"flutter_exoplayer",
null
],
[
"icon_badge",
null
],
[
"touchable",
null
],
[
"elastic_drawer",
null
],
[
"worker_manager",
null
],
[
"fleasy",
null
],
[
"random_color_scheme",
null
],
[
"cpf_cnpj_validator",
null
],
[
"stacked_hooks",
null
],
[
"asuka",
null
],
[
"hue_rotation",
null
],
[
"tweet_ui",
null
],
[
"shake_flutter",
null
],
[
"o_color_picker",
null
],
[
"open_store",
null
],
[
"f_logs",
null
],
[
"multicast_dns",
null
],
[
"ms_undraw",
null
],
[
"translit",
null
],
[
"flutter_jailbreak_detection",
null
],
[
"qrscan",
null
],
[
"json_dynamic_widget",
null
],
[
"left_scroll_actions",
null
],
[
"sqfentity",
null
],
[
"flutter_data",
null
],
[
"uri",
null
],
[
"firedart",
null
],
[
"bluetooth_thermal_printer",
null
],
[
"iso",
null
],
[
"matrix_gesture_detector",
null
],
[
"assets_audio_player_web",
null
],
[
"gsheets",
null
],
[
"flutter_settings_screens",
null
],
[
"console",
null
],
[
"import_sorter",
null
],
[
"arrow_path",
null
],
[
"flutter_clean_architecture",
null
],
[
"glassmorphism",
null
],
[
"optimized_cached_image",
null
],
[
"simple_gradient_text",
null
],
[
"sticky_grouped_list",
null
],
[
"from_css_color",
null
],
[
"measured_size",
null
],
[
"awesome_card",
null
],
[
"dio_http2_adapter",
null
],
[
"android_alarm_manager_plus",
null
],
[
"just_the_tooltip",
null
],
[
"validators2",
null
],
[
"password_validated_field",
null
],
[
"dash",
null
],
[
"flutter_phosphor_icons",
null
],
[
"advance_image_picker",
null
],
[
"after_init",
null
],
[
"data_tables",
null
],
[
"phoenix_socket",
null
],
[
"volume_controller",
null
],
[
"flutter_background_service",
null
],
[
"country_calling_code_picker",
null
],
[
"yaml_edit",
null
],
[
"modal_progress_hud_nsn",
null
],
[
"flutter_js",
null
],
[
"system_settings",
null
],
[
"flutter_gen",
null
],
[
"dialog_flowtter",
null
],
[
"time_chart",
null
],
[
"the_validator",
null
],
[
"osm_nominatim",
null
],
[
"at_common_flutter",
null
],
[
"response",
null
],
[
"code_fields",
null
],
[
"flutter_add_to_cart_button",
null
],
[
"progress_indicator",
null
],
[
"aligned_dialog",
null
],
[
"flutter_facebook_sdk",
null
],
[
"carrier_info",
null
],
[
"flutter_beep",
null
],
[
"clevertap_plugin",
null
],
[
"scroll_when_needed",
null
],
[
"push_notification",
null
],
[
"item_selector",
null
],
[
"parallax_animation",
null
],
[
"papercups_flutter",
null
],
[
"sendbird_sdk",
null
],
[
"file_sizes",
null
],
[
"open_mail_app",
null
],
[
"field_suggestion",
null
],
[
"flutter_story_list",
null
],
[
"image_pixels",
null
],
[
"mercury_client",
null
],
[
"async_builder",
null
],
[
"pigeon",
null
],
[
"the_apple_sign_in",
null
],
[
"zxing2",
null
],
[
"ink_page_indicator",
null
],
[
"collapsible_sidebar",
null
],
[
"notifications",
null
],
[
"multi_charts",
null
],
[
"animated_card",
null
],
[
"azblob",
null
],
[
"flamingo",
null
],
[
"simple_mustache",
null
],
[
"swagger_dart_code_generator",
null
],
[
"loggy",
null
],
[
"country_codes",
null
],
[
"simple_moment",
null
],
[
"stacked_bar_chart",
null
],
[
"markdown_editable_textinput",
null
],
[
"twitter_login",
null
],
[
"flutter_carousel_slider",
null
],
[
"google_ml_vision",
null
],
[
"no_context_navigation",
null
],
[
"shadowed_image",
null
],
[
"fluentui_icons",
null
],
[
"svgaplayer_flutter",
null
],
[
"flutter_stories",
null
],
[
"currency_textfield",
null
],
[
"scan",
null
],
[
"ios_utsname_ext",
null
],
[
"toml",
null
],
[
"card_settings",
null
],
[
"super_form",
null
],
[
"connectivity_for_web",
null
],
[
"auto_localized",
null
],
[
"horizontal_picker",
null
],
[
"cyclop",
null
],
[
"normalize",
null
],
[
"sliver_fab",
null
],
[
"bs_flutter",
null
],
[
"simple_gravatar",
null
],
[
"full_screen_menu",
null
],
[
"audio_streamer",
null
],
[
"autocomplete_textfield_ns",
null
],
[
"edge_detection",
null
],
[
"safemap",
null
],
[
"form_builder_fields",
null
],
[
"firebase_image",
null
],
[
"eosdart_ecc",
null
],
[
"animated_toggle_switch",
null
],
[
"flutter_color_models",
null
],
[
"very_good_infinite_list",
null
],
[
"functional_widget_annotation",
null
],
[
"android_intent_plus",
null
],
[
"flutter_multiselect",
null
],
[
"flutter_gravatar",
null
],
[
"dio_http_formatter",
null
],
[
"oxidized",
null
],
[
"freshchat_sdk",
null
],
[
"epubx",
null
],
[
"tree_view",
null
],
[
"equations",
null
],
[
"dds",
null
],
[
"list_treeview",
null
],
[
"flutter_background",
null
],
[
"flutter_segment",
null
],
[
"floating_bubbles",
null
],
[
"stream_feed",
null
],
[
"swipeable_page_route",
null
],
[
"flutter_animarker",
null
],
[
"amplify_storage_s3",
null
],
[
"animated_stack_widget",
null
],
[
"carbon_icons",
null
],
[
"sliver_header_delegate",
null
],
[
"reorderableitemsview",
null
],
[
"icon",
null
],
[
"flutter_redux_navigation",
null
],
[
"o_popup",
null
],
[
"swipebuttonflutter",
null
],
[
"rest_client",
null
],
[
"animated_button",
null
],
[
"snapshot",
null
],
[
"xdg_directories",
null
],
[
"speed_dial_fab",
null
],
[
"image_picker_gallery_camera",
null
],
[
"version_migration",
null
],
[
"mpesa",
null
],
[
"persian_tools",
null
],
[
"gradient_ui_widgets",
null
],
[
"charts_painter",
null
],
[
"flutter_iconly",
null
],
[
"dart_strapi",
null
],
[
"google_api_availability",
null
],
[
"flutter_fimber",
null
],
[
"screen_state",
null
],
[
"tiengviet",
null
],
[
"pluto_filtered_list",
null
],
[
"unorm_dart",
null
],
[
"animated_rail",
null
],
[
"iso_countries",
null
],
[
"rotated_corner_decoration",
null
],
[
"flutter_custom_theme",
null
],
[
"flutter_search_bar",
null
],
[
"manage_calendar_events",
null
],
[
"yandex_mapkit",
null
],
[
"flutter_wall_layout",
null
],
[
"aws_cloudwatch",
null
],
[
"grinder",
null
],
[
"mocktail_image_network",
null
],
[
"builders",
null
],
[
"okito",
null
],
[
"flutter_voximplant",
null
],
[
"device_simulator",
null
],
[
"neon",
null
],
[
"msix",
null
],
[
"spring",
null
],
[
"sign_in_with_apple_js",
null
],
[
"libserialport",
null
],
[
"multilevel_drawer",
null
],
[
"flutter_glow",
null
],
[
"animated_search_bar",
null
],
[
"regexpattern",
null
],
[
"file_manager",
null
],
[
"process",
null
],
[
"dashbook",
null
],
[
"flutter_funding_choices",
null
],
[
"firebase",
null
],
[
"conditional_questions",
null
],
[
"ticket_material",
null
],
[
"instagram_public_api",
null
],
[
"dynamic_fonts",
null
],
[
"event",
null
],
[
"collapsible",
null
],
[
"flutter_sodium",
null
],
[
"platform_maps_flutter",
null
],
[
"curved_drawer_fork",
null
],
[
"countdown_progress_indicator",
null
],
[
"adhan",
null
],
[
"easy_signature_pad",
null
],
[
"page_turn",
null
],
[
"flutter_dynamic_forms",
null
],
[
"parallax_image",
null
],
[
"form_validation",
null
],
[
"pinch_zoom_image_last",
null
],
[
"catex",
null
],
[
"mqtt5_client",
null
],
[
"fade_shimmer",
null
],
[
"super_editor",
null
],
[
"tflite_flutter_helper",
null
],
[
"bubble_box",
null
],
[
"flutter_splash_screen",
null
],
[
"crypto_font_icons",
null
],
[
"isolate_handler",
null
],
[
"update_available",
null
],
[
"bluetooth_print",
null
],
[
"cupertino_tabbar",
null
],
[
"mmkv",
null
],
[
"fancy_shimmer_image",
null
],
[
"demoji",
null
],
[
"firestore_ref",
null
],
[
"flutter_summernote",
null
],
[
"curved_animation_controller",
null
],
[
"fluintl",
null
],
[
"overlay_container",
null
],
[
"linter",
null
],
[
"boardview",
null
],
[
"timezone",
null
],
[
"splashscreen",
null
],
[
"rx_widgets",
null
],
[
"sqlbrite",
null
],
[
"modal_progress_hud",
null
],
[
"isoweek",
null
],
[
"flutter_pickers",
null
],
[
"wifi_info_flutter",
null
],
[
"funvas",
null
],
[
"flutter_dropdown",
null
],
[
"internet_speed_test",
null
],
[
"mason",
null
],
[
"flutter_spinning_wheel",
null
],
[
"flutter_esc_pos_utils",
null
],
[
"gviz",
null
],
[
"widget_loading",
null
],
[
"either_option",
null
],
[
"oscilloscope",
null
],
[
"data_connection_checker",
null
],
[
"another_xlider",
null
],
[
"stripe_payment",
null
],
[
"tar",
null
],
[
"nice_button",
null
],
[
"huawei_push",
null
],
[
"mask_input_formatter",
null
],
[
"simple_auth_flutter",
null
],
[
"animated",
null
],
[
"carousel_images",
null
],
[
"dropbox_client",
null
],
[
"declarative_animated_list",
null
],
[
"nextcloud",
null
],
[
"vsync_provider",
null
],
[
"color",
null
],
[
"row_item",
null
],
[
"spincircle_bottom_bar",
null
],
[
"smooth_star_rating",
null
],
[
"distinct_value_connectable_stream",
null
],
[
"fast_barcode_scanner",
null
],
[
"animated_text",
null
],
[
"bitmap",
null
],
[
"fialogs",
null
],
[
"node_interop",
null
],
[
"xml_parser",
null
],
[
"flutter_mapbox_autocomplete",
null
],
[
"ink_widget",
null
],
[
"flutter_advanced_calendar",
null
],
[
"expire_cache",
null
],
[
"string_extensions",
null
],
[
"flutter_fgbg",
null
],
[
"swipe_back_detector",
null
],
[
"home_indicator",
null
],
[
"trust_location",
null
],
[
"libsignal_protocol_dart",
null
],
[
"flutter_swipe_button",
null
],
[
"animation_wrappers",
null
],
[
"flutter_video_info",
null
],
[
"redux_logging",
null
],
[
"rich_editor",
null
],
[
"firebase_phone_auth_handler",
null
],
[
"flutter_app_badger",
null
],
[
"flutter_file_dialog",
null
],
[
"enhance_stepper",
null
],
[
"ethereum",
null
],
[
"voyager",
null
],
[
"uuid_type",
null
],
[
"fast_immutable_collections",
null
],
[
"load",
null
],
[
"dcli",
null
],
[
"interactive_chart",
null
],
[
"easy_dialog",
null
],
[
"digit_to_persian_word",
null
],
[
"hawk_fab_menu",
null
],
[
"speech_bubble",
null
],
[
"teledart",
null
],
[
"universe",
null
],
[
"web_browser_detect",
null
],
[
"build_context",
null
],
[
"fluid_bottom_nav_bar",
null
],
[
"advance_pdf_viewer",
null
],
[
"flutter_native_image",
null
],
[
"deep_collection",
null
],
[
"smart_select",
null
],
[
"vertical_weight_slider",
null
],
[
"screen_brightness",
null
],
[
"callkeep",
null
],
[
"audiotagger",
null
],
[
"scrollable_list_tabview",
null
],
[
"sliding_panel",
null
],
[
"image_picker_for_web",
null
],
[
"sealed_annotations",
null
],
[
"source_helper",
null
],
[
"maps_curved_line",
null
],
[
"flutter_xlider",
null
],
[
"woozy_search",
null
],
[
"geofence_service",
null
],
[
"on_audio_query",
null
],
[
"flutter_pdfview",
null
],
[
"sqlite_viewer",
null
],
[
"pretty_dio_logger",
null
],
[
"text",
null
],
[
"passwordfield",
null
],
[
"outline_gradient_button",
null
],
[
"json2yaml",
null
],
[
"flutter_syntax_view",
null
],
[
"mailer",
null
],
[
"dart_appwrite",
null
],
[
"custom_text",
null
],
[
"country_currency_pickers",
null
],
[
"barcode_scanner",
null
],
[
"tonic",
null
],
[
"pattern_lock",
null
],
[
"story_view",
null
],
[
"floating_pullup_card",
null
],
[
"geocoder_offline",
null
],
[
"global_configuration",
null
],
[
"flutter_insta",
null
],
[
"prometheus_client",
null
],
[
"scrollable_clean_calendar",
null
],
[
"image_compare",
null
],
[
"flutter_countdown_timer",
null
],
[
"time_range",
null
],
[
"flutter_plugin_android_lifecycle",
null
],
[
"mobx_triple",
null
],
[
"flutter_stripe_payment",
null
],
[
"drop_cap_text",
null
],
[
"age_calculator",
null
],
[
"simple_vertical_calendar",
null
],
[
"autocomplete_textfield",
null
],
[
"excel",
null
],
[
"file_picker_desktop",
null
],
[
"flutter_admin_scaffold",
null
],
[
"colour",
null
],
[
"form_builder_validators",
null
],
[
"chess_vectors_flutter",
null
],
[
"flutter_map_tile_caching",
null
],
[
"downloads_path_provider_28",
null
],
[
"amplify_datastore",
null
],
[
"flutter_slider_indicator",
null
],
[
"clean_framework",
null
],
[
"gherkin",
null
],
[
"crdt",
null
],
[
"flutter_password_strength",
null
],
[
"math_keyboard",
null
],
[
"firebase_auth_mocks",
null
],
[
"sweetsheet",
null
],
[
"list_diff",
null
],
[
"flutter_hls_parser",
null
],
[
"giffy_dialog",
null
],
[
"dart_style",
null
],
[
"es_compression",
null
],
[
"customizable_multiselect_field",
null
],
[
"azure_application_insights",
null
],
[
"livechatt",
null
],
[
"stacked_firebase_auth",
null
],
[
"trotter",
null
],
[
"api_manager",
null
],
[
"flutter_jscore",
null
],
[
"flutter_star_prnt",
null
],
[
"video_player_web_hls",
null
],
[
"easy_folder_picker",
null
],
[
"moor_inspector",
null
],
[
"secp256k1",
null
],
[
"flutter_radio_group",
null
],
[
"reactive_validator",
null
],
[
"flat",
null
],
[
"linkfy_text",
null
],
[
"apple_maps_flutter",
null
],
[
"bech32",
null
],
[
"japx",
null
],
[
"cielo_ecommerce",
null
],
[
"number_to_word_arabic",
null
],
[
"flutter_fluid_slider",
null
],
[
"shelf_plus",
null
],
[
"interactiveviewer_gallery",
null
],
[
"chaleno",
null
],
[
"social_share",
null
],
[
"jpush_flutter",
null
],
[
"export_video_frame",
null
],
[
"firebase_auth_rest",
null
],
[
"term_glyph",
null
],
[
"nested_scroll_controller",
null
],
[
"tabbed_view",
null
],
[
"tflite_audio",
null
],
[
"flutter_text_drawable",
null
],
[
"hive_generator",
null
],
[
"flutter_badged",
null
],
[
"date_range_picker",
null
],
[
"msal_js",
null
],
[
"form_floating_action_button",
null
],
[
"http_services",
null
],
[
"cli_repl",
null
],
[
"davinci",
null
],
[
"amplify_api",
null
],
[
"simple_speed_dial",
null
],
[
"native_screenshot",
null
],
[
"public_suffix",
null
],
[
"path_morph",
null
],
[
"browser_launcher",
null
],
[
"configurable_expansion_tile_null_safety",
null
],
[
"enough_mail",
null
],
[
"ibm_watson_assistant",
null
],
[
"spring_button",
null
],
[
"bonsoir",
null
],
[
"dynamic_theme",
null
],
[
"window_location_href",
null
],
[
"flutter_geofence",
null
],
[
"chips_choice",
null
],
[
"animated_splash",
null
],
[
"skeletons",
null
],
[
"image_editor",
null
],
[
"paging",
null
],
[
"google_maps_flutter_web",
null
],
[
"draggable_bottom_sheet",
null
],
[
"stacked_card_carousel",
null
],
[
"simple_tags",
null
],
[
"high_chart",
null
],
[
"lite_rolling_switch",
null
],
[
"switcher",
null
],
[
"flutter_material_pickers",
null
],
[
"liquid_ui",
null
],
[
"google_maps",
null
],
[
"flutter_phone_direct_caller",
null
],
[
"single_item_storage",
null
],
[
"flutter_polygon",
null
],
[
"rainbow_vis",
null
],
[
"flutter_session",
null
],
[
"gettext_parser",
null
],
[
"loading_transition_button",
null
],
[
"tus_client",
null
],
[
"validated",
null
],
[
"flutter_progress_dialog",
null
],
[
"vimeo_player_flutter",
null
],
[
"grouped_buttons",
null
],
[
"reorderable_grid_view",
null
],
[
"dashed_line",
null
],
[
"conduit",
null
],
[
"scanbot_sdk",
null
],
[
"draw",
null
],
[
"dartlin",
null
],
[
"amazon_cognito_identity_dart_2",
null
],
[
"weak_map",
null
],
[
"flutter_google_places_web",
null
],
[
"animated_radial_menu",
null
],
[
"flutter_bluetooth_serial",
null
],
[
"amplify_analytics_pinpoint",
null
],
[
"background_locator",
null
],
[
"add_2_calendar",
null
],
[
"pretty_gauge",
null
],
[
"bottom_nav_layout",
null
],
[
"appium_driver",
null
],
[
"http_certificate_pinning",
null
],
[
"scaffold_gradient_background",
null
],
[
"niddler_dart",
null
],
[
"dropdown_formfield",
null
],
[
"faker_dart",
null
],
[
"motion_sensors",
null
],
[
"lazy_evaluation",
null
],
[
"flutter_awesome_alert_box",
null
],
[
"swipe_to_action",
null
],
[
"nik_validator",
null
],
[
"flutter_xupdate",
null
],
[
"generic_bloc_provider",
null
],
[
"keyboard_avoider",
null
],
[
"drag_ball",
null
],
[
"flutter_login_template",
null
],
[
"pmvvm",
null
],
[
"flutter_web_auth",
null
],
[
"bottom_loader",
null
],
[
"app_popup_menu",
null
],
[
"expandable_sliver_list",
null
],
[
"number_inc_dec",
null
],
[
"drop_shadow_image",
null
],
[
"android_play_install_referrer",
null
],
[
"persian_fonts",
null
],
[
"validatorless",
null
],
[
"simple_image_cropper",
null
],
[
"tenor",
null
],
[
"websafe_svg",
null
],
[
"maze",
null
],
[
"json_patch",
null
],
[
"mixpanel_flutter",
null
],
[
"custom_sliding_segmented_control",
null
],
[
"global_configs",
null
],
[
"swipe_cards",
null
],
[
"splash",
null
],
[
"platform",
null
],
[
"before_after",
null
],
[
"outline_material_icons",
null
],
[
"checkdigit",
null
],
[
"twilio_programmable_chat",
null
],
[
"edit_distance",
null
],
[
"timer_button",
null
],
[
"flutter_echarts",
null
],
[
"reading_time",
null
],
[
"snapkit",
null
],
[
"colorize_lumberdash",
null
],
[
"responsive_grid",
null
],
[
"ai_progress",
null
],
[
"flutter_fft",
null
],
[
"async_extension",
null
],
[
"cloudpayments",
null
],
[
"instant",
null
],
[
"data_channel",
null
],
[
"orientation",
null
],
[
"path_provider_windows",
null
],
[
"easy_dialogs",
null
],
[
"get_server",
null
],
[
"reviews_slider",
null
],
[
"flag",
null
],
[
"horizontal_center_date_picker",
null
],
[
"research_package",
null
],
[
"currency_icons",
null
],
[
"flutter_multi_carousel",
null
],
[
"rebloc",
null
],
[
"pdftron_flutter",
null
],
[
"sound_mode",
null
],
[
"userleap_flutter",
null
],
[
"webview_windows",
null
],
[
"avatars",
null
],
[
"flutter_logs",
null
],
[
"arabic_numbers",
null
],
[
"ini",
null
],
[
"morphing_text",
null
],
[
"file_selector",
null
],
[
"airoute",
null
],
[
"flutter_weather_bg_null_safety",
null
],
[
"bezier_chart",
null
],
[
"i18next",
null
],
[
"flutter_tindercard",
null
],
[
"ssl_pinning_plugin",
null
],
[
"event_taxi",
null
],
[
"my_fatoorah",
null
],
[
"username_generator",
null
],
[
"fcharts",
null
],
[
"easy_web_view2",
null
],
[
"masonry_grid",
null
],
[
"audio_wave",
null
],
[
"advertising_id",
null
],
[
"photofilters",
null
],
[
"parse_server_sdk",
null
],
[
"flutter_custom_dialog",
null
],
[
"amazon_s3_cognito",
null
],
[
"tapioca",
null
],
[
"kakaomap_webview",
null
],
[
"dropdown_banner",
null
],
[
"gql_dedupe_link",
null
],
[
"flutter_interactive_keyboard",
null
],
[
"flutter_parse",
null
],
[
"flutter_simple_treeview",
null
],
[
"slimy_card",
null
],
[
"automated_testing_framework",
null
],
[
"ringtone_player",
null
],
[
"gs1_barcode_parser",
null
],
[
"dynatrace_flutter_plugin",
null
],
[
"opencv_4",
null
],
[
"flutter_tabler_icons",
null
],
[
"virtual_keyboard",
null
],
[
"md2_tab_indicator",
null
],
[
"cider",
null
],
[
"rrule",
null
],
[
"sms_user_consent",
null
],
[
"a_star_algorithm",
null
],
[
"beacons_plugin",
null
],
[
"carousel_pro",
null
],
[
"contextualactionbar",
null
],
[
"open_url",
null
],
[
"epub_view",
null
],
[
"client_cookie",
null
],
[
"bottomreveal",
null
],
[
"parser_error",
null
],
[
"gauges",
null
],
[
"omise_flutter",
null
],
[
"fl_paging",
null
],
[
"dfunc",
null
],
[
"flutter_page_view_indicator",
null
],
[
"slide_button",
null
],
[
"nearby_connections",
null
],
[
"glob",
null
],
[
"cashfree_pg",
null
],
[
"flutter_ume",
null
],
[
"sse_client",
null
],
[
"woosignal",
null
],
[
"scrollable_panel",
null
],
[
"cached_video_player",
null
],
[
"draggable_fab",
null
],
[
"file_icon",
null
],
[
"provider_architecture",
null
],
[
"logging_appenders",
null
],
[
"enough_serialization",
null
],
[
"artemis",
null
],
[
"blue_thermal_printer",
null
],
[
"flutter_redux_dev_tools",
null
],
[
"flutter_sparkline",
null
],
[
"kind",
null
],
[
"flutter_ble_peripheral",
null
],
[
"document_scanner_flutter",
null
],
[
"flutter_cupertino_settings",
null
],
[
"ssh_key",
null
],
[
"visibility_aware_state",
null
],
[
"blinking_text",
null
],
[
"flutter_nearby_connections",
null
],
[
"inspection",
null
],
[
"appodeal_flutter",
null
],
[
"code_text_field",
null
],
[
"flutter_instagram_stories",
null
],
[
"flutter_absolute_path",
null
],
[
"flutter_linear_datepicker",
null
],
[
"pinenacl",
null
],
[
"wonderpush_flutter",
null
],
[
"battery_info",
null
],
[
"flutter_reorderable_list",
null
],
[
"alt_bloc",
null
],
[
"what3words",
null
],
[
"floating_action_bubble",
null
],
[
"photo_editor_sdk",
null
],
[
"build_config",
null
],
[
"checkbox_formfield",
null
],
[
"flutter_ble_lib",
null
],
[
"flutter_vibrate",
null
],
[
"titled_navigation_bar",
null
],
[
"fwfh_svg",
null
],
[
"hasura_connect",
null
],
[
"fuzzywuzzy",
null
],
[
"email_launcher",
null
],
[
"navme",
null
],
[
"progress_timeline",
null
],
[
"flutter_google_maps",
null
],
[
"aws_request",
null
],
[
"adhara_socket_io",
null
],
[
"dotenv",
null
],
[
"cool_nav",
null
],
[
"route_animation_helper",
null
],
[
"credit_card_number_validator",
null
],
[
"flutter_emoji",
null
],
[
"file_selector_macos",
null
],
[
"qr_mobile_vision",
null
],
[
"mgrs_dart",
null
],
[
"amplitude_flutter",
null
],
[
"file_selector_windows",
null
],
[
"image_editor_pro",
null
],
[
"highlighter_coachmark",
null
],
[
"add_to_gallery",
null
],
[
"shape_of_view",
null
],
[
"sliding_number",
null
],
[
"flutter_whatsapp_stickers",
null
],
[
"shared_preferences_windows",
null
],
[
"dropdownfield",
null
],
[
"simple_gql",
null
],
[
"platform_date_picker",
null
],
[
"adv_fab",
null
],
[
"motion_tab_bar",
null
],
[
"twilio_programmable_video",
null
],
[
"sum_types",
null
],
[
"flutter_ameno_ipsum",
null
],
[
"flutter_activity_recognition",
null
],
[
"dart_meteor",
null
],
[
"flutter_svprogresshud",
null
],
[
"geolocation",
null
],
[
"floating_search_bar",
null
],
[
"appsflyer_sdk",
null
],
[
"remove_from_coverage",
null
],
[
"flutter_range_slider",
null
],
[
"esc_pos_utils",
null
],
[
"connectycube_flutter_call_kit",
null
],
[
"euc",
null
],
[
"esc_pos_utils_plus",
null
],
[
"statusbarz",
null
],
[
"localized",
null
],
[
"rx_bloc_list",
null
],
[
"devtools_shared",
null
],
[
"built_redux",
null
],
[
"at_persistence_spec",
null
],
[
"source_span",
null
],
[
"bottom_drawer",
null
],
[
"pub_api_client",
null
],
[
"flutter_local_auth_invisible",
null
],
[
"dart_des",
null
],
[
"flutter_apns",
null
],
[
"datadog_flutter",
null
],
[
"context_menus",
null
],
[
"nfc_in_flutter",
null
],
[
"getbloc",
null
],
[
"fhir_at_rest",
null
],
[
"vertical_tab_bar_view",
null
],
[
"sendgrid_mailer",
null
],
[
"theme_manager",
null
],
[
"cpfcnpj",
null
],
[
"shelf_router_generator",
null
],
[
"flutter_candlesticks",
null
],
[
"glitters",
null
],
[
"tencent_kit",
null
],
[
"calendar_timeline",
null
],
[
"flutter_ion",
null
],
[
"moengage_flutter",
null
],
[
"auto_orientation",
null
],
[
"firebase_cloud_messaging_interop",
null
],
[
"network_logger",
null
],
[
"measure_size",
null
],
[
"pangle_flutter",
null
],
[
"flutter_typeahead_web",
null
],
[
"katex_flutter",
null
],
[
"carp_mobile_sensing",
null
],
[
"health_kit_reporter",
null
],
[
"_discoveryapis_commons",
null
],
[
"media_scanner",
null
],
[
"platform_alert_dialog",
null
],
[
"kdgaugeview",
null
],
[
"fish_redux",
null
],
[
"slide_countdown_clock",
null
],
[
"bubble_overlay",
null
],
[
"proste_route_animation",
null
],
[
"air_quality",
null
],
[
"flutter_bcrypt",
null
],
[
"verbal_expressions",
null
],
[
"stacked_page_view",
null
],
[
"native_webview",
null
],
[
"paytm",
null
],
[
"flutter_social_textfield",
null
],
[
"delayed_widget",
null
],
[
"enough_ascii_art",
null
],
[
"sudoku_solver_generator",
null
],
[
"flutter_geofire",
null
],
[
"flutter_focus_watcher",
null
],
[
"dynamic_treeview",
null
],
[
"flutter_contact",
null
],
[
"crop_image",
null
],
[
"lat_lon_grid_plugin",
null
],
[
"supabase_flutter",
null
],
[
"universal_disk_space",
null
],
[
"heroicons",
null
],
[
"http2",
null
],
[
"gallery_view",
null
],
[
"im_animations",
null
],
[
"dart_json_mapper_mobx",
null
],
[
"fhir",
null
],
[
"time_machine",
null
],
[
"widget_arrows",
null
],
[
"big_tip",
null
],
[
"android_path_provider",
null
],
[
"iqplayer",
null
],
[
"cloudinary_sdk",
null
],
[
"color_models",
null
],
[
"fitted_text_field_container",
null
],
[
"sumup",
null
],
[
"source_map_stack_trace",
null
],
[
"flutter_flavorizr",
null
],
[
"vertical_tabs",
null
],
[
"pandabar",
null
],
[
"regex_router",
null
],
[
"injectable_generator",
null
],
[
"dart_json_mapper_flutter",
null
],
[
"ping_discover_network",
null
],
[
"os_detect",
null
],
[
"keyboard_visibility",
null
],
[
"flutter_weather_bg",
null
],
[
"flutter_kakao_login",
null
],
[
"floor_annotation",
null
],
[
"superellipse_shape",
null
],
[
"proste_bezier_curve",
null
],
[
"user_profile_avatar",
null
],
[
"progresso",
null
],
[
"comment_tree",
null
],
[
"ar_flutter_plugin",
null
],
[
"flutter_map_location",
null
],
[
"fbutton",
null
],
[
"smartstruct",
null
],
[
"explorer",
null
],
[
"cube_transition",
null
],
[
"flashy_tab_bar2",
null
],
[
"amap_flutter_location",
null
],
[
"flutter_pin_code_fields",
null
],
[
"hsluv",
null
],
[
"form_validator",
null
],
[
"ola_like_country_picker",
null
],
[
"flutter_local_notifications_linux",
null
],
[
"sailor",
null
],
[
"file_selector_linux",
null
],
[
"grizzly_io",
null
],
[
"nav",
null
],
[
"gotrue",
null
],
[
"storage_client",
null
],
[
"imgly_sdk",
null
],
[
"faunadb_http",
null
],
[
"extended_list_library",
null
],
[
"circle_flags",
null
],
[
"enhanced_future_builder",
null
],
[
"expandable_tree_menu",
null
],
[
"password_credential",
null
],
[
"fingerprintjs",
null
],
[
"separated_column",
null
],
[
"snap_scroll_physics",
null
],
[
"dart_countries",
null
],
[
"x509",
null
],
[
"flutter_video_compress",
null
],
[
"brotli",
null
],
[
"reselect",
null
],
[
"polygon_clipper",
null
],
[
"adaptive_scrollbar",
null
],
[
"rive_splash_screen",
null
],
[
"distance",
null
],
[
"json_object_mapper",
null
],
[
"geodesy",
null
],
[
"icofont_flutter",
null
],
[
"flutter_camera_ml_vision",
null
],
[
"interpolation",
null
],
[
"wasm_interop",
null
],
[
"flutter_midi",
null
],
[
"rating_bar",
null
],
[
"stamp_image",
null
],
[
"flutter_document_picker",
null
],
[
"id3",
null
],
[
"input_calculator",
null
],
[
"volume_control",
null
],
[
"parallax_rain",
null
],
[
"myfatoorah_flutter",
null
],
[
"flutter_foreground_task",
null
],
[
"simple_json_persistence",
null
],
[
"normal",
null
],
[
"file_picker_writable",
null
],
[
"localregex",
null
],
[
"sass_builder",
null
],
[
"flutter_icmp_ping",
null
],
[
"drishya_picker",
null
],
[
"kf_drawer",
null
],
[
"mobile_number",
null
],
[
"stream_loader",
null
],
[
"image_size_getter",
null
],
[
"status_alert",
null
],
[
"great_list_view",
null
],
[
"dia",
null
],
[
"custom_check_box",
null
],
[
"torch_controller",
null
],
[
"timetable",
null
],
[
"socket_io_common",
null
],
[
"flutter_shapes",
null
],
[
"at_commons",
null
],
[
"flextras",
null
],
[
"progress_loader_overlay",
null
],
[
"flutter_chip_tags",
null
],
[
"lifecycle",
null
],
[
"date_count_down",
null
],
[
"fast_color_picker",
null
],
[
"dropdown_date_picker",
null
],
[
"draw_your_image",
null
],
[
"alert",
null
],
[
"bs_flutter_selectbox",
null
],
[
"sawo",
null
],
[
"bottom_navigation_badge",
null
],
[
"expandable_widgets",
null
],
[
"flutter_tab_indicator_styler",
null
],
[
"app_usage",
null
],
[
"flutter_app_icon_badge",
null
],
[
"zendesk2",
null
],
[
"eo_color",
null
],
[
"gooey_carousel",
null
],
[
"flutter_launcher_icons",
null
],
[
"super_easy_in_app_purchase",
null
],
[
"get_smart",
null
],
[
"cr_calendar",
null
],
[
"beautiful_soup_dart",
null
],
[
"date_utils",
null
],
[
"popup_card",
null
],
[
"sse",
null
],
[
"flutter_luban",
null
],
[
"neumorphic",
null
],
[
"persian_utils",
null
],
[
"getsocial_flutter_sdk",
null
],
[
"flutter_foreground_plugin",
null
],
[
"radio_player",
null
],
[
"recursive_regex",
null
],
[
"git",
null
],
[
"cryptography_flutter",
null
],
[
"delta_e",
null
],
[
"multiavatar",
null
],
[
"wallpaper_manager",
null
],
[
"responsive_grid_list",
null
],
[
"flutter_web_data_table",
null
],
[
"aad_oauth",
null
],
[
"fuzzy",
null
],
[
"floating_navbar",
null
],
[
"usb_serial",
null
],
[
"flutter_otp",
null
],
[
"double_tap_player_view",
null
],
[
"pix_flutter",
null
],
[
"surf_util",
null
],
[
"zendesk_plugin",
null
],
[
"arkit_plugin",
null
],
[
"meilisearch",
null
],
[
"hexagon",
null
],
[
"local_auth_device_credentials",
null
],
[
"mongol",
null
],
[
"easy_pip",
null
],
[
"matrix2d",
null
],
[
"paulonia_utils",
null
],
[
"address",
null
],
[
"flutter_callkit_voximplant",
null
],
[
"screwdriver",
null
],
[
"flutter_video_newfeed",
null
],
[
"floating_text",
null
],
[
"panorama",
null
],
[
"full_text_search",
null
],
[
"square_in_app_payments",
null
],
[
"infinite_widgets",
null
],
[
"wave_slider",
null
],
[
"fluent_appbar",
null
],
[
"bottom_picker",
null
],
[
"books_finder",
null
],
[
"upi_india",
null
],
[
"storyly_flutter",
null
],
[
"audiofileplayer",
null
],
[
"mdi",
null
],
[
"flutter_json_viewer",
null
],
[
"flare_flutter",
null
],
[
"qonversion_flutter",
null
],
[
"blur_bottom_bar",
null
],
[
"speech_balloon",
null
],
[
"flutter_screen_scaler",
null
],
[
"contextmenu",
null
],
[
"openapi_generator_cli",
null
],
[
"line_chart",
null
],
[
"build_runner",
null
],
[
"formdator",
null
],
[
"flutter_disposebag",
null
],
[
"quill_delta",
null
],
[
"input_slider",
null
],
[
"binder",
null
],
[
"svg_to_paint",
null
],
[
"flutter_cache",
null
],
[
"flutter_plot",
null
],
[
"outline_search_bar",
null
],
[
"proj4dart",
null
],
[
"wave_drawer",
null
],
[
"forme",
null
],
[
"image_painter",
null
],
[
"animated_check",
null
],
[
"tmdb_api",
null
],
[
"kpostal",
null
],
[
"lit_firebase_auth",
null
],
[
"page_view_indicator",
null
],
[
"georange",
null
],
[
"isar",
null
],
[
"cached_network_marker",
null
],
[
"twemoji",
null
],
[
"native_updater",
null
],
[
"data",
null
],
[
"storage_space",
null
],
[
"easy_container",
null
],
[
"flutter_image",
null
],
[
"keyboard_utils",
null
],
[
"rolling_switch",
null
],
[
"responsive_widgets",
null
],
[
"auto_search",
null
],
[
"ej_selector",
null
],
[
"flutter_facebook_login",
null
],
[
"ably_flutter",
null
],
[
"flux_validator_dart",
null
],
[
"social_embed_webview",
null
],
[
"flutter_brand_palettes",
null
],
[
"process_runner",
null
],
[
"install_plugin",
null
],
[
"fluwx",
null
],
[
"graphite",
null
],
[
"tap_builder",
null
],
[
"flutter_better_camera",
null
],
[
"kenburns",
null
],
[
"flutter_gradient_colors",
null
],
[
"flutter_masked_text2",
null
],
[
"google_maps_controller",
null
],
[
"bit_array",
null
],
[
"polymaker",
null
],
[
"execution_queue",
null
],
[
"app_launcher",
null
],
[
"sticky_footer_scrollview",
null
],
[
"foil",
null
],
[
"flutter_provider",
null
],
[
"fontisto_flutter",
null
],
[
"ext_video_player",
null
],
[
"stream_chat_persistence",
null
],
[
"reactive_date_time_picker",
null
],
[
"flutter_ticket_widget",
null
],
[
"hsv_color_pickers",
null
],
[
"nuts_activity_indicator",
null
],
[
"curtain",
null
],
[
"material_design_icons_flutter",
null
],
[
"diff_match_patch",
null
],
[
"segment_display",
null
],
[
"adaptive_components",
null
],
[
"flutter_voip_kit",
null
],
[
"is_lock_screen",
null
],
[
"future_button",
null
],
[
"animated_floatactionbuttons",
null
],
[
"flutter_gen_runner",
null
],
[
"bagel_db",
null
],
[
"ferry_cache",
null
],
[
"ffloat",
null
],
[
"row_collection",
null
],
[
"format",
null
],
[
"popup_window",
null
],
[
"dapackages",
null
],
[
"colours",
null
],
[
"m3u_nullsafe",
null
],
[
"status_change",
null
],
[
"creamy_field",
null
],
[
"filling_slider",
null
],
[
"nhost_sdk",
null
],
[
"floating_action_row",
null
],
[
"ntlm",
null
],
[
"sms_autofill",
null
],
[
"carp_core",
null
],
[
"bubble_timeline",
null
],
[
"reactive_dropdown_search",
null
],
[
"flutter_custom_cards",
null
],
[
"multiselect_scope",
null
],
[
"mime_type",
null
],
[
"flutter_filereader",
null
],
[
"data_connection_checker_tv",
null
],
[
"flutter_vant_kit",
null
],
[
"lzma",
null
],
[
"blinkid_flutter",
null
],
[
"fbroadcast",
null
],
[
"twilio_voice",
null
],
[
"flutter_animated_theme",
null
],
[
"flutter_shortcuts",
null
],
[
"slack_notifier",
null
],
[
"flutter_circular_slider",
null
],
[
"gcloud",
null
],
[
"pdf_merger",
null
],
[
"surf_logger",
null
],
[
"dart_vlc",
null
],
[
"insta_public_api",
null
],
[
"level_map",
null
],
[
"dylib",
null
],
[
"brick_offline_first",
null
],
[
"charts_common",
null
],
[
"gesture_password_widget",
null
],
[
"yahoofin",
null
],
[
"simple_s3",
null
],
[
"rfc_6901",
null
],
[
"rx",
null
],
[
"fluri",
null
],
[
"awesome_extensions",
null
],
[
"dartdap",
null
],
[
"geopoint",
null
],
[
"cupertino_stackview",
null
],
[
"image_pickers",
null
],
[
"image_slider",
null
],
[
"system_shortcuts",
null
],
[
"build_daemon",
null
],
[
"tinycolor2",
null
],
[
"xmlstream",
null
],
[
"survey_kit",
null
],
[
"perfect_volume_control",
null
],
[
"flutter_blue",
null
],
[
"tap_canvas",
null
],
[
"k_chart",
null
],
[
"cli_notify",
null
],
[
"flutter_keychain",
null
],
[
"call_log",
null
],
[
"let_log",
null
],
[
"transformer_page_view",
null
],
[
"state_persistence",
null
],
[
"iphone_has_notch",
null
],
[
"uploadcare_client",
null
],
[
"contact_picker",
null
],
[
"huawei_analytics",
null
],
[
"flip_box_bar",
null
],
[
"flutter_swipable",
null
],
[
"flutter_sim_country_code",
null
],
[
"signalr_netcore",
null
],
[
"jwt_io",
null
],
[
"pfile_picker",
null
],
[
"google_maps_webservice",
null
],
[
"floodfill_image",
null
],
[
"rx_bloc_test",
null
],
[
"full_screen_date_picker",
null
],
[
"wkt_parser",
null
],
[
"connection_status_bar",
null
],
[
"analyzer",
null
],
[
"cool_ui",
null
],
[
"device_info_plus_windows",
null
],
[
"flutter_vlc_player_platform_interface",
null
],
[
"flutter_overlay",
null
],
[
"seafarer",
null
],
[
"flip_panel",
null
],
[
"hex",
null
],
[
"rx_redux",
null
],
[
"mercado_pago_mobile_checkout",
null
],
[
"light",
null
],
[
"fdottedline",
null
],
[
"mdc_web",
null
],
[
"niku",
null
],
[
"flutter_qr_bar_scanner",
null
],
[
"flutter_displaymode",
null
],
[
"video_editor_sdk",
null
],
[
"ed25519_edwards",
null
],
[
"uploadcare_flutter",
null
],
[
"google_speech",
null
],
[
"cupertino_radio_choice",
null
],
[
"sk_onboarding_screen",
null
],
[
"searchable_dropdown",
null
],
[
"change_app_package_name",
null
],
[
"enhanced_drop_down",
null
],
[
"in_app_update",
null
],
[
"instana_agent",
null
],
[
"in_date_utils",
null
],
[
"gettext",
null
],
[
"flutter_qr_reader",
null
],
[
"on_toast_widget",
null
],
[
"pubspec",
null
],
[
"ms_map_utils",
null
],
[
"extra_pedantic",
null
],
[
"paulonia_cache_image",
null
],
[
"vector_map",
null
],
[
"youtube_parser",
null
],
[
"dart_notification_center",
null
],
[
"flutter_qjs",
null
],
[
"flame",
null
],
[
"expression_language",
null
],
[
"flutter_acrylic",
null
],
[
"docx_template",
null
],
[
"flutter_khalti",
null
],
[
"kochava_tracker",
null
],
[
"navigator_manager",
null
],
[
"bubble_chart",
null
],
[
"bdd_widget_test",
null
],
[
"achievement_view",
null
],
[
"icapps_license",
null
],
[
"toggle_bar",
null
],
[
"quiz_view",
null
],
[
"just_audio_web",
null
],
[
"modbus",
null
],
[
"loop_page_view",
null
],
[
"fps_monitor",
null
],
[
"dynamic_text_highlighting",
null
],
[
"responsive_context",
null
],
[
"cupertino_progress_bar",
null
],
[
"zego_express_engine",
null
],
[
"flutter_bugly",
null
],
[
"resource_portable",
null
],
[
"curved_splash_screen",
null
],
[
"ansi_logger",
null
],
[
"kuzzle",
null
],
[
"vexana",
null
],
[
"widget_to_image",
null
],
[
"safe_url_check",
null
],
[
"map_polyline_draw",
null
],
[
"material_color_generator",
null
],
[
"multi_select_item",
null
],
[
"persian_flutter",
null
],
[
"flutter_calendar_week",
null
],
[
"mapbox_search_flutter",
null
],
[
"pusher_client",
null
],
[
"lipsum",
null
],
[
"random_color",
null
],
[
"square_percent_indicater",
null
],
[
"actors",
null
],
[
"aws_lambda_dart_runtime",
null
],
[
"circle_wheel_scroll",
null
],
[
"facebook_audience_network",
null
],
[
"swipe_refresh",
null
],
[
"metadata_extract",
null
],
[
"unleash",
null
],
[
"flutter_audio_recorder2",
null
],
[
"fluttermoji",
null
],
[
"finite_coverflow",
null
],
[
"websocket_manager",
null
],
[
"proximity_sensor",
null
],
[
"invoiceninja",
null
],
[
"evil_icons_flutter",
null
],
[
"loader_skeleton",
null
],
[
"footer",
null
],
[
"mvu_layer",
null
],
[
"sliding_card",
null
],
[
"cqrs",
null
],
[
"bs_flutter_buttons",
null
],
[
"stemmer",
null
],
[
"exception_templates",
null
],
[
"flutter_class_parser",
null
],
[
"flutter_full_pdf_viewer",
null
],
[
"credit_card_input_form",
null
],
[
"flutter_palette",
null
],
[
"flip",
null
],
[
"wilt",
null
],
[
"googleapis_beta",
null
],
[
"scroll_bars_common",
null
],
[
"source_gen",
null
],
[
"iconsax",
null
],
[
"pubnub",
null
],
[
"doc_widget",
null
],
[
"advanced_search",
null
],
[
"restart_app",
null
],
[
"cbl",
null
],
[
"scrolls_to_top",
null
],
[
"json_helpers",
null
],
[
"wifi_info_plugin",
null
],
[
"amplify_auth_plugin_interface",
null
],
[
"search_cep",
null
],
[
"flutter_skeleton",
null
],
[
"phosphor_flutter",
null
],
[
"drag_down_to_pop",
null
],
[
"dio_http_cache",
null
],
[
"at_client",
null
],
[
"onboarding_screen",
null
],
[
"rename",
null
],
[
"google_maps_widget",
null
],
[
"joystick",
null
],
[
"dart_mappable",
null
],
[
"modal_progress_hud_alt",
null
],
[
"user_messaging_platform",
null
],
[
"contactus",
null
],
[
"simple_observable",
null
],
[
"flutter_horizontal_featured_list",
null
],
[
"flutter_cached_pdfview",
null
],
[
"rich_alert",
null
],
[
"storybook_device_preview",
null
],
[
"remote_state",
null
],
[
"ext_storage",
null
],
[
"hypertrack_plugin",
null
],
[
"juno_direct_checkout",
null
],
[
"streams_channel",
null
],
[
"postgres_pool",
null
],
[
"duration_picker_dialog_box",
null
],
[
"super_easy_permissions",
null
],
[
"rolling_nav_bar",
null
],
[
"multi_value_listenable_builder",
null
],
[
"textfield_state",
null
],
[
"gradients",
null
],
[
"codemod",
null
],
[
"query",
null
],
[
"flutter_nfc_kit",
null
],
[
"text_parser",
null
],
[
"coast",
null
],
[
"transitioner",
null
],
[
"string_splitter",
null
],
[
"latlong_to_osgrid",
null
],
[
"poly_geofence_service",
null
],
[
"clip_shadow",
null
],
[
"ecdsa",
null
],
[
"flutter_duration_picker",
null
],
[
"customgauge",
null
],
[
"super_hero",
null
],
[
"localizely_sdk",
null
],
[
"csv_localizations",
null
],
[
"quickblox_sdk",
null
],
[
"super_enum",
null
],
[
"ml_algo",
null
],
[
"prompts",
null
],
[
"geocore",
null
],
[
"flutter_tinder_swipe",
null
],
[
"encrypted_shared_preferences",
null
],
[
"dxf",
null
],
[
"flutter_naver_login",
null
],
[
"image_compression_flutter",
null
],
[
"flutter_simple_calculator",
null
],
[
"autotrie",
null
],
[
"flutter_titled_container",
null
],
[
"mobility_features",
null
],
[
"flutter_elegant_number_button",
null
],
[
"eyro_toast",
null
],
[
"humanize",
null
],
[
"sorted",
null
],
[
"frideos",
null
],
[
"smoothie",
null
],
[
"flutter_user_agentx",
null
],
[
"loading_skeleton",
null
],
[
"flutter_admob_app_open",
null
],
[
"local_assets_server",
null
],
[
"flutter_toastr",
null
],
[
"notion_api",
null
],
[
"ant_icons",
null
],
[
"imageview360",
null
],
[
"login_client",
null
],
[
"nhost_flutter_auth",
null
],
[
"screen_ratio_adapter",
null
],
[
"detect_testflight",
null
],
[
"system_theme",
null
],
[
"floatingpanel",
null
],
[
"pip_view",
null
],
[
"flutter_audio_recorder",
null
],
[
"functional_widget",
null
],
[
"vector_map_tiles",
null
],
[
"image_viewer",
null
],
[
"cuberto_bottom_bar",
null
],
[
"bitsdojo_window",
null
],
[
"bubble_bottom_bar",
null
],
[
"minio",
null
],
[
"animated_progress_button",
null
],
[
"flutter_villains",
null
],
[
"supabase_addons",
null
],
[
"fast_gbk",
null
],
[
"animated_overflow",
null
],
[
"adaptive_layout",
null
],
[
"number_paginator",
null
],
[
"flutter_math",
null
],
[
"hive_listener",
null
],
[
"rich_text_widget",
null
],
[
"markdown_widget",
null
],
[
"desktop_window",
null
],
[
"flutter_beautiful_popup",
null
],
[
"image_sequence_animator",
null
],
[
"simple_auth",
null
],
[
"tween_image_widget",
null
],
[
"anchored_popups",
null
],
[
"action_broadcast",
null
],
[
"quantity",
null
],
[
"fs_shim",
null
],
[
"flutter_neumorphic_null_safety",
null
],
[
"xml_rpc",
null
],
[
"flutter_crashlytics",
null
],
[
"database",
null
],
[
"clippy_flutter",
null
],
[
"pspdfkit_flutter",
null
],
[
"paytm_allinonesdk",
null
],
[
"icon_font_generator",
null
],
[
"flutter_loggy",
null
],
[
"firestore_collection",
null
],
[
"flutter_media_notification",
null
],
[
"dio_smart_retry",
null
],
[
"infinite_scroll_tab_view",
null
],
[
"textless",
null
],
[
"emoji_picker",
null
],
[
"mvc_application",
null
],
[
"share_files_and_screenshot_widgets",
null
],
[
"playify",
null
],
[
"flusmic",
null
],
[
"control_pad",
null
],
[
"build_resolvers",
null
],
[
"animated_neumorphic",
null
],
[
"objectbox_generator",
null
],
[
"form_builder_extra_fields",
null
],
[
"regexed_validator",
null
],
[
"ocarina",
null
],
[
"dynamic_color_theme",
null
],
[
"json_intl",
null
],
[
"sodium",
null
],
[
"pdf_viewer_jk",
null
],
[
"linalg",
null
],
[
"chart_engine",
null
],
[
"dashed_container",
null
],
[
"icons_helper",
null
],
[
"flutter_fb_news",
null
],
[
"dio_flutter_transformer",
null
],
[
"scroll_indicator",
null
],
[
"places_service",
null
],
[
"flutter_aws_s3_client",
null
],
[
"provider_for_redux",
null
],
[
"proximity_hash",
null
],
[
"flutter_payu_unofficial",
null
],
[
"static_translations",
null
],
[
"avoid_keyboard",
null
],
[
"lazy_data_table_plus",
null
],
[
"cloud_firestore_web",
null
],
[
"flutter_keyboard_visibility_platform_interface",
null
],
[
"automap",
null
],
[
"json_schema2",
null
],
[
"contentful",
null
],
[
"adapty_flutter",
null
],
[
"color_thief_flutter",
null
],
[
"wave_loading_indicator",
null
],
[
"flutter_horizontal_date_picker",
null
],
[
"raw_sound",
null
],
[
"root_access",
null
],
[
"flexible",
null
],
[
"multi_masked_formatter",
null
],
[
"pkce",
null
],
[
"gql_build",
null
],
[
"unique_identifier",
null
],
[
"ff_navigation_bar",
null
],
[
"smooth_scroll_web",
null
],
[
"vicodin",
null
],
[
"thememode_selector",
null
],
[
"pubspec_lock",
null
],
[
"amplify_datastore_plugin_interface",
null
],
[
"build",
null
],
[
"flutter_image_utilities",
null
],
[
"circular_profile_avatar",
null
],
[
"beacon_broadcast",
null
],
[
"pagination",
null
],
[
"touch_indicator",
null
],
[
"kotlin_flavor",
null
],
[
"flutter_plus",
null
],
[
"built_value_generator",
null
],
[
"retrofit_generator",
null
],
[
"device_calendar",
null
],
[
"your_splash",
null
],
[
"color_palette_generator",
null
],
[
"flutter_icons",
null
],
[
"ads",
null
],
[
"bs_flutter_alert",
null
],
[
"flutter_midi_command",
null
],
[
"bidirectional_listview",
null
],
[
"tabbar",
null
],
[
"pref_dessert",
null
],
[
"alert_dialog",
null
],
[
"secure_random",
null
],
[
"dateable",
null
],
[
"kdtree",
null
],
[
"kartal",
null
],
[
"flutter_money_formatter",
null
],
[
"vertical_barchart",
null
],
[
"progress_indicator_button",
null
],
[
"pytorch_mobile",
null
],
[
"tiled",
null
],
[
"zefyr",
null
],
[
"cupertino_setting_control",
null
],
[
"mapbox_api",
null
],
[
"popup_menu",
null
],
[
"full_screen_image_null_safe",
null
],
[
"flutter_widgets",
null
],
[
"tabnavigator",
null
],
[
"enough_html_editor",
null
],
[
"sass",
null
],
[
"fast_noise",
null
],
[
"loading",
null
],
[
"dialogflow_grpc",
null
],
[
"custom_splash",
null
],
[
"min_id",
null
],
[
"linear_step_indicator",
null
],
[
"powers",
null
],
[
"fwfh_cached_network_image",
null
],
[
"layoutr",
null
],
[
"flutter_group_sliver",
null
],
[
"dart_countries_states",
null
],
[
"gql_websocket_link",
null
],
[
"conditioned",
null
],
[
"hardware_buttons",
null
],
[
"timeago_flutter",
null
],
[
"huawei_account",
null
],
[
"poly",
null
],
[
"iso_calendar",
null
],
[
"mysql_utils",
null
],
[
"sliver_calendar",
null
],
[
"positioned_tap_detector_2",
null
],
[
"phone_form_field",
null
],
[
"flutter_web_router",
null
],
[
"persona_flutter",
null
],
[
"apollovm",
null
],
[
"very_good_cli",
null
],
[
"image_capture_field",
null
],
[
"advance_pdf_viewer_fork",
null
],
[
"notus",
null
],
[
"r_dotted_line_border",
null
],
[
"f_datetimerangepicker",
null
],
[
"word_search",
null
],
[
"firebase_database_rest",
null
],
[
"flutter_statusbar_manager",
null
],
[
"kosher_dart",
null
],
[
"rounded_expansion_tile",
null
],
[
"nonce",
null
],
[
"flutter_dialpad",
null
],
[
"separated_row",
null
],
[
"flutter_nano_ffi",
null
],
[
"side_menu_animation",
null
],
[
"reorderable_carousel",
null
],
[
"dime",
null
],
[
"xlive_switch",
null
],
[
"at_server_status",
null
],
[
"webkit_inspection_protocol",
null
],
[
"wasm",
null
],
[
"pull_to_reveal",
null
],
[
"sunrise_sunset_calc",
null
],
[
"dart_service_announcement",
null
],
[
"spaces",
null
],
[
"flutter_gradients",
null
],
[
"heatmap_calendar",
null
],
[
"banners",
null
],
[
"jdate",
null
],
[
"proste_indexed_stack",
null
],
[
"random_string_generator",
null
],
[
"gsettings",
null
],
[
"image_compression",
null
],
[
"error_notifier_for_provider",
null
],
[
"firebase_helpers",
null
],
[
"color_logger",
null
],
[
"sura_flutter",
null
],
[
"flutter_chess_board",
null
],
[
"flutter_speed_dial_material_design",
null
],
[
"libao",
null
],
[
"locally",
null
],
[
"byte_flow",
null
],
[
"flutter_fader",
null
],
[
"parallax_swiper",
null
],
[
"flutter_graphql_client",
null
],
[
"stash_dio",
null
],
[
"fancy_text_reveal",
null
],
[
"easy_logger",
null
],
[
"iugu",
null
],
[
"overlapping_time",
null
],
[
"pdf_flutter",
null
],
[
"flutter_cupertino_date_picker_fork",
null
],
[
"slide_digital_clock",
null
],
[
"automatic_animated_list",
null
],
[
"bdaya_repository_pattern",
null
],
[
"flutter_locker",
null
],
[
"mp3_info",
null
],
[
"clipboard_monitor",
null
],
[
"sqflite_migration",
null
],
[
"presentation_displays",
null
],
[
"flutter_charset_detector",
null
],
[
"coverage",
null
],
[
"geohash",
null
],
[
"web_ffi",
null
],
[
"graphql_flutter",
null
],
[
"firebase_core_web",
null
],
[
"g_faraday",
null
],
[
"flutter_appavailability",
null
],
[
"statistics",
null
],
[
"unicorndial",
null
],
[
"localization",
null
],
[
"share_plus_windows",
null
],
[
"naver_map_plugin",
null
],
[
"kiwi_generator",
null
],
[
"any_base",
null
],
[
"language_pickers",
null
],
[
"flutter_page_indicator",
null
],
[
"save_in_gallery",
null
],
[
"link_preview_generator",
null
],
[
"flutter_link_preview",
null
],
[
"system_proxy",
null
],
[
"scratch_space",
null
],
[
"pdf_image_renderer",
null
],
[
"integration_test",
null
],
[
"pokemon_tcg",
null
],
[
"moving_average",
null
],
[
"cast",
null
],
[
"barcode_flutter",
null
],
[
"flutter_card_scanner_latest",
null
],
[
"bubble_lens",
null
],
[
"flutter_gifimage",
null
],
[
"flutter_des",
null
],
[
"draggable_floating_button",
null
],
[
"mock_web_server",
null
],
[
"polar",
null
],
[
"flutter_to_airplay",
null
],
[
"shaped_bottom_bar",
null
],
[
"flutter_translator",
null
],
[
"listentocontacts",
null
],
[
"comment_box",
null
],
[
"bouncer",
null
],
[
"fl_location",
null
],
[
"custom_switch",
null
],
[
"rsa_pkcs",
null
],
[
"conventional_commit",
null
],
[
"gradient_app_bar",
null
],
[
"event_hub",
null
],
[
"flutter_device_type",
null
],
[
"qr_code_tools",
null
],
[
"marquee_flutter",
null
],
[
"flutter_simple_rating_bar",
null
],
[
"intent",
null
],
[
"vm_snapshot_analysis",
null
],
[
"decorated_text",
null
],
[
"koin",
null
],
[
"flutter_pollfish",
null
],
[
"source_gen_test",
null
],
[
"indent",
null
],
[
"ruby_text",
null
],
[
"image_picker_widget",
null
],
[
"native_state",
null
],
[
"flutter_youtube_downloader",
null
],
[
"snappable",
null
],
[
"flutter_anywhere_menus",
null
],
[
"gizmos_settings_screen",
null
],
[
"flutter_nord_theme",
null
],
[
"streams_provider",
null
],
[
"prometheus_client_shelf",
null
],
[
"curved_drawer",
null
],
[
"eneural_net",
null
],
[
"espresso",
null
],
[
"to_string",
null
],
[
"native_stack_traces",
null
],
[
"platform_device_id_platform_interface",
null
],
[
"simple_kalman",
null
],
[
"flutter_flipperkit",
null
],
[
"platform_device_id_windows",
null
],
[
"implicitly_animated_list",
null
],
[
"map_elevation",
null
],
[
"serial_port_win32",
null
],
[
"angel_route",
null
],
[
"graphview",
null
],
[
"js_wrapping",
null
],
[
"full_screen_image",
null
],
[
"bip32",
null
],
[
"lazy_load_refresh_indicator",
null
],
[
"getxfire",
null
],
[
"slowly_moving_widgets_field",
null
],
[
"simple_database",
null
],
[
"slide_popup_dialog",
null
],
[
"shared_preferences_dtx",
null
],
[
"responsive",
null
],
[
"slide_container",
null
],
[
"language_picker",
null
],
[
"screen_loader",
null
],
[
"currency_pickers",
null
],
[
"listview_utils",
null
],
[
"flutter_parallax",
null
],
[
"pin_entry_text_field",
null
],
[
"flutter_material_showcase",
null
],
[
"morpheus",
null
],
[
"get_phone_number",
null
],
[
"bottom_indicator_bar",
null
],
[
"amap_flutter_map",
null
],
[
"lzstring",
null
],
[
"riverpod_navigation",
null
],
[
"float_column",
null
],
[
"sacco",
null
],
[
"splash_tap",
null
],
[
"browser_detector",
null
],
[
"span_builder",
null
],
[
"account_picker",
null
],
[
"ez_flutter",
null
],
[
"headset_connection_event",
null
],
[
"list_wheel_scroll_view_x",
null
],
[
"flavor_text",
null
],
[
"snap",
null
],
[
"scrolling_years_calendar",
null
],
[
"flutter_number_picker",
null
],
[
"pricing_cards",
null
],
[
"twitch_api",
null
],
[
"clipboard_listener",
null
],
[
"scale_button",
null
],
[
"disk_space",
null
],
[
"qrcode_flutter",
null
],
[
"isolator",
null
],
[
"ninja",
null
],
[
"carp_context_package",
null
],
[
"mapbox_gl_dart",
null
],
[
"google_ui",
null
],
[
"microphone",
null
],
[
"disposables",
null
],
[
"flutter_collapse",
null
],
[
"mapbox_search",
null
],
[
"intro_screen_onboarding_flutter",
null
],
[
"wp_json_api",
null
],
[
"unique_ids",
null
],
[
"credit_card_slider",
null
],
[
"ripple_backdrop_animate_route",
null
],
[
"flutterlifecyclehooks",
null
],
[
"palette",
null
],
[
"sweetalert",
null
],
[
"parse_server_sdk_flutter",
null
],
[
"api_cache_manager",
null
],
[
"flavor",
null
],
[
"timezone_to_country",
null
],
[
"molten_navigationbar_flutter",
null
],
[
"flutter_boom_menu",
null
],
[
"spinner_input",
null
],
[
"code_input",
null
],
[
"social_media_widgets",
null
],
[
"instagram_share",
null
],
[
"expanding_bottom_bar",
null
],
[
"jumping_dot",
null
],
[
"the_country_number_widgets",
null
],
[
"shrine_images",
null
],
[
"shared_themes",
null
],
[
"connectivity_wall",
null
],
[
"hetu_script",
null
],
[
"flutter_fab_dialer",
null
],
[
"quds_db",
null
],
[
"google_language_fonts",
null
],
[
"flutter_stetho",
null
],
[
"image_save",
null
],
[
"google_places_picker",
null
],
[
"yaz",
null
],
[
"frefresh",
null
],
[
"flutter_advanced_progress",
null
],
[
"analyzer_plugin",
null
],
[
"consumer",
null
],
[
"timeline_status",
null
],
[
"image_fade",
null
],
[
"flutter_awesome_buttons",
null
],
[
"esptouch_smartconfig",
null
],
[
"intervalprogressbar",
null
],
[
"darty_commons",
null
],
[
"dio_logger",
null
],
[
"number_to_words",
null
],
[
"gender_selection",
null
],
[
"flutter_mobx_form_validation_kit",
null
],
[
"esptouch_flutter",
null
],
[
"color_picker_field",
null
],
[
"gradient_progress",
null
],
[
"floating_ribbon",
null
],
[
"flutter_rounded_progress_bar",
null
],
[
"peanut",
null
],
[
"slidable_bar",
null
],
[
"crossplat_objectid",
null
],
[
"file_cryptor",
null
],
[
"atlas",
null
],
[
"custom_bottom_navigation_bar",
null
],
[
"meet_network_image",
null
],
[
"firestore_search",
null
],
[
"universal_widget",
null
],
[
"flutter_analog_clock",
null
],
[
"image_picker_type",
null
],
[
"fimber_io",
null
],
[
"sync",
null
],
[
"fast_flutter_driver_tool",
null
],
[
"custom_navigator",
null
],
[
"firebase_messaging_web",
null
],
[
"flutter_dropzone",
null
],
[
"dart_vlc_ffi",
null
],
[
"calc",
null
],
[
"countdown_flutter",
null
],
[
"news_api_flutter_package",
null
],
[
"objectbox_sync_flutter_libs",
null
],
[
"material_dialog",
null
],
[
"emojis",
null
],
[
"flutter_hex_color",
null
],
[
"custom_searchable_dropdown",
null
],
[
"flutter_gallery_assets",
null
],
[
"framy_annotation",
null
],
[
"flutter_cmoon_icons",
null
],
[
"flutter_credit_card_brazilian",
null
],
[
"change",
null
],
[
"flutter_dipnav",
null
],
[
"flutter_sequencer",
null
],
[
"multiple_select",
null
],
[
"awesome_loader",
null
],
[
"m3u",
null
],
[
"draggable_container",
null
],
[
"flutter_plugin_record",
null
],
[
"debug_logger",
null
],
[
"flutter_section_list",
null
],
[
"css_text",
null
],
[
"obs_websocket",
null
],
[
"stilo",
null
],
[
"dropdown_search2",
null
],
[
"appbar_textfield",
null
],
[
"cupertino_date_textbox",
null
],
[
"drag_and_drop_gridview",
null
],
[
"get_cli",
null
],
[
"rounded_tabbar_widget",
null
],
[
"pdf_viewer_plugin",
null
],
[
"validadores",
null
],
[
"expandable_card",
null
],
[
"animated_drawer",
null
],
[
"responsive_x",
null
],
[
"pixabay_picker",
null
],
[
"flame_audio",
null
],
[
"favicon",
null
],
[
"quds_popup_menu",
null
],
[
"sha3",
null
],
[
"vrchat_dart_generated",
null
],
[
"mp_chart",
null
],
[
"derived_colors",
null
],
[
"pluto_menu_bar",
null
],
[
"sliding_panel_pro",
null
],
[
"stash_hive",
null
],
[
"bangla_utilities",
null
],
[
"sms_retriever",
null
],
[
"nordic_dfu",
null
],
[
"device_display_brightness",
null
],
[
"line_awesome_icons",
null
],
[
"arctium",
null
],
[
"devtools",
null
],
[
"themed",
null
],
[
"adjust_sdk",
null
],
[
"audioplayer",
null
],
[
"easy_splash_screen",
null
],
[
"collision",
null
],
[
"dhttpd",
null
],
[
"ffcache",
null
],
[
"fluent_result",
null
],
[
"bottom_animation",
null
],
[
"scroll_to_id",
null
],
[
"opus_flutter",
null
],
[
"navigation_action_bar",
null
],
[
"simple_mapper",
null
],
[
"ferry_flutter",
null
],
[
"firebase_ml_custom",
null
],
[
"brick_core",
null
],
[
"foldable_sidebar",
null
],
[
"international_system_of_units",
null
],
[
"just_throttle_it",
null
],
[
"cbl_flutter",
null
],
[
"flutter_cache_manager_firebase",
null
],
[
"quds_provider",
null
],
[
"flutter_unicons",
null
],
[
"flutter_image_stack",
null
],
[
"dom_builder",
null
],
[
"calendar_strip",
null
],
[
"flutter_libserialport",
null
],
[
"video_thumbnail_generator",
null
],
[
"wired_elements",
null
],
[
"at_utils",
null
],
[
"image_crop_widget",
null
],
[
"flutter_city_picker",
null
],
[
"animated_tree_view",
null
],
[
"nuvigator",
null
],
[
"css_colors",
null
],
[
"imagebutton",
null
],
[
"r_flutter",
null
],
[
"flutter_deep_linking",
null
],
[
"dart_rss",
null
],
[
"multi_sort",
null
],
[
"bs_flutter_utils",
null
],
[
"binary",
null
],
[
"float_bubble",
null
],
[
"file_support",
null
],
[
"rich_input",
null
],
[
"webdriver",
null
],
[
"jinja",
null
],
[
"icloud_storage",
null
],
[
"firestore_helpers",
null
],
[
"custom_line_indicator_bottom_navbar",
null
],
[
"breathing_collection",
null
],
[
"camerax",
null
],
[
"side_navigation",
null
],
[
"yoyo_player",
null
],
[
"easy_onvif",
null
],
[
"flutter_annual_task",
null
],
[
"flutter_carrotquest",
null
],
[
"dio_retry_fixed",
null
],
[
"dart_minecraft",
null
],
[
"logging_config",
null
],
[
"selector",
null
],
[
"aes_crypt",
null
],
[
"flutter_sizer",
null
],
[
"textstyle_extensions",
null
],
[
"age",
null
],
[
"flutter_3des",
null
],
[
"simple_image_crop",
null
],
[
"bloc_stream",
null
],
[
"glyphicon",
null
],
[
"flutter_sinusoidals",
null
],
[
"property_change_notifier",
null
],
[
"simple_currency_format",
null
],
[
"syntax_highlighter",
null
],
[
"eggnstone_amazon_chime",
null
],
[
"match",
null
],
[
"laravel_echo",
null
],
[
"sketcher",
null
],
[
"flutter_locales",
null
],
[
"flutter_screwdriver",
null
],
[
"store_checker",
null
],
[
"media_picker_builder",
null
],
[
"ussd_service",
null
],
[
"external_app_launcher",
null
],
[
"ackee_dart",
null
],
[
"sentry_lumberdash",
null
],
[
"countup",
null
],
[
"convex_bottom_navigation",
null
],
[
"grouped_checkbox",
null
],
[
"read_pdf_text",
null
],
[
"sliverbar_with_card",
null
],
[
"dart_3des",
null
],
[
"keep_keyboard_popup_menu",
null
],
[
"kumi_popup_window",
null
],
[
"simple_cluster",
null
],
[
"simple_connectivity",
null
],
[
"vin_decoder",
null
],
[
"dcache",
null
],
[
"domain_objects",
null
],
[
"installer_info",
null
],
[
"adv_camera",
null
],
[
"path_icon",
null
],
[
"graphx",
null
],
[
"gdpr_dialog",
null
],
[
"stream_listener",
null
],
[
"dropdown_menu",
null
],
[
"flutter_string_encryption",
null
],
[
"whiteboard",
null
],
[
"rest_api_client",
null
],
[
"easy_localization_loader",
null
],
[
"autoequal",
null
],
[
"ftoast",
null
],
[
"gradient_text",
null
],
[
"at_persistence_secondary_server",
null
],
[
"timeline_widget",
null
],
[
"atlassian_apis",
null
],
[
"eva_color",
null
],
[
"time_elapsed",
null
],
[
"pushable_button",
null
],
[
"flutter_shine",
null
],
[
"matomo",
null
],
[
"beacon_monitoring",
null
],
[
"extended_math",
null
],
[
"ssh2",
null
],
[
"volume",
null
],
[
"simple_timetable",
null
],
[
"photo_card_swiper",
null
],
[
"flutter_custom_tab_bar",
null
],
[
"customtogglebuttons",
null
],
[
"dart_airtable",
null
],
[
"appspector",
null
],
[
"flutter_twitter_login",
null
],
[
"bugsnag_crashlytics",
null
],
[
"dart_fcm",
null
],
[
"neuomorphic_container",
null
],
[
"flutter_acrcloud",
null
],
[
"slidable_button",
null
],
[
"ali_auth",
null
],
[
"apple_sign_in_safety",
null
],
[
"circle_bottom_navigation_bar",
null
],
[
"environment_sensors",
null
],
[
"flutter_checkout_payment",
null
],
[
"firebase_auth_ui",
null
],
[
"flutter_sidebar",
null
],
[
"dart_snmp",
null
],
[
"udp",
null
],
[
"cli_pkg",
null
],
[
"appdynamics_mobilesdk",
null
],
[
"flutter_freshchat",
null
],
[
"chaquopy",
null
],
[
"animated_counter",
null
],
[
"flutter_keyboard_aware_dialog",
null
],
[
"subscription_holder",
null
],
[
"lan_scanner",
null
],
[
"finance",
null
],
[
"fragment_navigate",
null
],
[
"flip_board",
null
],
[
"bugbattle_sdk",
null
],
[
"galileo_mysql",
null
],
[
"flutter_guid",
null
],
[
"awesome_bottom_navigation",
null
],
[
"rocket_chat_connector_flutter",
null
],
[
"declarative_refresh_indicator",
null
],
[
"es_drawer_controller",
null
],
[
"flutter_mobile_carousel",
null
],
[
"trust_fall",
null
],
[
"launchdarkly_flutter",
null
],
[
"flutter_bugfender",
null
],
[
"custom_radio",
null
],
[
"rtmp_publisher",
null
],
[
"kraken",
null
],
[
"flutter_qrcode_scanner",
null
],
[
"aws_dynamodb_api",
null
],
[
"app_group_directory",
null
],
[
"cross_platform",
null
],
[
"edge_alert",
null
],
[
"time_span",
null
],
[
"flutter_phone_state",
null
],
[
"tencent_im_sdk_plugin",
null
],
[
"toast",
null
],
[
"dart_rut_validator",
null
],
[
"ui_helper",
null
],
[
"condition",
null
],
[
"bottom_sheet_expandable_bar",
null
],
[
"interact",
null
],
[
"flutter_page_transition",
null
],
[
"boost",
null
],
[
"late_init",
null
],
[
"subtitle",
null
],
[
"application_icon",
null
],
[
"back_pressed",
null
],
[
"angular_bloc",
null
],
[
"t_stats",
null
],
[
"any_link_preview",
null
],
[
"dio_cache_interceptor_hive_store",
null
],
[
"dart_periphery",
null
],
[
"ripple_effect",
null
],
[
"flutter_app_name",
null
],
[
"get_mac",
null
],
[
"blurrycontainer",
null
],
[
"phone_state_i",
null
],
[
"flutter_expandable_table",
null
],
[
"flutter_time_range",
null
],
[
"dcdg",
null
],
[
"connectycube_sdk",
null
],
[
"bs58check",
null
],
[
"snaplist",
null
],
[
"aps_navigator",
null
],
[
"dio_cache_interceptor_db_store",
null
],
[
"build_test",
null
],
[
"gradient_bottom_navigation_bar",
null
],
[
"flutter_wifi_connect",
null
],
[
"flutter_dropzone_platform_interface",
null
],
[
"getbloc_test",
null
],
[
"context_holder",
null
],
[
"flutuate_mixpanel",
null
],
[
"bootstrap_icons",
null
],
[
"fling_units",
null
],
[
"md5_plugin",
null
],
[
"version_check",
null
],
[
"countdown",
null
],
[
"amazon_cognito_identity_dart",
null
],
[
"flutter_animated_play_button",
null
],
[
"installed_apps",
null
],
[
"porcupine",
null
],
[
"countly_flutter",
null
],
[
"firebase_analytics_web",
null
],
[
"open_iconic_flutter",
null
],
[
"dialog_switcher",
null
],
[
"shared_preference_app_group",
null
],
[
"dartarabic",
null
],
[
"flutter_screen_wake",
null
],
[
"picovoice",
null
],
[
"nylo_framework",
null
],
[
"replay_kit_launcher",
null
],
[
"category_picker",
null
],
[
"pigment",
null
],
[
"redux_compact",
null
],
[
"function_types",
null
],
[
"techgrains",
null
],
[
"fk_user_agent",
null
],
[
"hive_crdt",
null
],
[
"flutter_json_widget",
null
],
[
"flutter_onfido",
null
],
[
"global_bottom_navigation_bar",
null
],
[
"underline_indicator",
null
],
[
"sqlite3_library_windows",
null
],
[
"disable_screenshots",
null
],
[
"super_rich_text",
null
],
[
"spinner",
null
],
[
"tinycolor",
null
],
[
"nayuta_sensors",
null
],
[
"ud_design",
null
],
[
"flutter_security_checker",
null
],
[
"glassmorphism_kit",
null
],
[
"flutter_barcode_listener",
null
],
[
"download_assets",
null
],
[
"dart_mssql",
null
],
[
"curve25519_vrf",
null
],
[
"battery_indicator",
null
],
[
"slidy",
null
],
[
"flutter_youtube_view",
null
],
[
"scaling_header",
null
],
[
"esys_flutter_share",
null
],
[
"admob_flutter",
null
],
[
"sync_http",
null
],
[
"flutter_mjpeg",
null
],
[
"aws_sns_api",
null
],
[
"enx_flutter_plugin",
null
],
[
"easycartanimation",
null
],
[
"system_alert_window",
null
],
[
"json_class",
null
],
[
"flutter_credit_card_detector",
null
],
[
"date_time_picker_widget",
null
],
[
"dynamic_value",
null
],
[
"ripple_animation",
null
],
[
"image_ink_well",
null
],
[
"roam_flutter",
null
],
[
"k_responsive",
null
],
[
"text_to_speech",
null
],
[
"data_size",
null
],
[
"card_selector",
null
],
[
"flutter_bloc_pattern",
null
],
[
"chat_ui_kit",
null
],
[
"bubbled_navigation_bar",
null
],
[
"momo_vn",
null
],
[
"torch_compat",
null
],
[
"flutter_tex_js",
null
],
[
"twilio_programmable_video_platform_interface",
null
],
[
"hotreloader",
null
],
[
"destiny",
null
],
[
"stringr",
null
],
[
"update_app",
null
],
[
"equalizer",
null
],
[
"flutter_android",
null
],
[
"smart_flare",
null
],
[
"redux_dev_tools",
null
],
[
"assets_scanner",
null
],
[
"jaguar_serializer",
null
],
[
"chess",
null
],
[
"loader",
null
],
[
"frino_icons",
null
],
[
"simple_animated_icon",
null
],
[
"flutter_sensors",
null
],
[
"argon2",
null
],
[
"flutter_audio_capture",
null
],
[
"textfield_search",
null
],
[
"flutter_tree",
null
],
[
"jovial_misc",
null
],
[
"flamingo_annotation",
null
],
[
"auto_data",
null
],
[
"flutter_progress_button",
null
],
[
"via_cep_flutter",
null
],
[
"stacked_listview",
null
],
[
"stories_for_flutter",
null
],
[
"animated_onboarding",
null
],
[
"build_version",
null
],
[
"emoji_feedback",
null
],
[
"time_formatter",
null
],
[
"dartemis",
null
],
[
"path_provider_ex",
null
],
[
"paynow",
null
],
[
"flutter_timeline",
null
],
[
"persian_datepicker",
null
],
[
"swipeable",
null
],
[
"merge_map",
null
],
[
"tencent_im_plugin",
null
],
[
"carousel_indicator",
null
],
[
"number_selection",
null
],
[
"flutter_client_sse",
null
],
[
"firebase_storage_web",
null
],
[
"system_tray",
null
],
[
"easy_permission_validator",
null
],
[
"credit_card",
null
],
[
"hb_check_code",
null
],
[
"flashy_tab_bar",
null
],
[
"hue_dart",
null
],
[
"flutter_exif_plugin",
null
],
[
"timer_controller",
null
],
[
"system",
null
],
[
"web_node",
null
],
[
"uic",
null
],
[
"on_connectivity_widget",
null
],
[
"simple_result",
null
],
[
"keycloak_flutter",
null
],
[
"flutter_shimmer_widget",
null
],
[
"paulonia_error_service",
null
],
[
"flutter_expandable",
null
],
[
"keyboard_info",
null
],
[
"swipe_gesture_recognizer",
null
],
[
"color_parser",
null
],
[
"the_country_number",
null
],
[
"geira_icons",
null
],
[
"block_ui",
null
],
[
"pimp_my_button",
null
],
[
"build_web_compilers",
null
],
[
"benchmark",
null
],
[
"flimer",
null
],
[
"ews",
null
],
[
"nhost_graphql_adapter",
null
],
[
"dart_telegram_bot",
null
],
[
"ftpclient",
null
],
[
"flutter_inapp_notifications",
null
],
[
"openapi_dart_common",
null
],
[
"realtime_pagination",
null
],
[
"fswitch",
null
],
[
"flutter_tab_bar_no_ripple",
null
],
[
"wifi_flutter",
null
],
[
"power",
null
],
[
"thumbnails",
null
],
[
"dart_extensions_methods",
null
],
[
"dropdown_selection",
null
],
[
"hypersnapsdk_flutter",
null
],
[
"adaptive_scaffold",
null
],
[
"flutter_section_list_view",
null
],
[
"simple",
null
],
[
"wizard_builder",
null
],
[
"foreground_service",
null
],
[
"stripe_sdk",
null
],
[
"delta_markdown",
null
],
[
"flutter_tts_improved",
null
],
[
"flutter_screenshot_switcher",
null
],
[
"flutter_dash",
null
],
[
"feather_icons",
null
],
[
"cnav",
null
],
[
"flutter_lokalise",
null
],
[
"flutter_particles",
null
],
[
"facebook_video_download",
null
],
[
"search",
null
],
[
"measures",
null
],
[
"bluez",
null
],
[
"rolling_bottom_bar",
null
],
[
"flutter_ui_toolkit",
null
],
[
"firebase_mlkit_language",
null
],
[
"khmer_fonts",
null
],
[
"scrolling_page_indicator",
null
],
[
"misc_utilities",
null
],
[
"screen",
null
],
[
"responsive_scaffold",
null
],
[
"fl_animated_linechart",
null
],
[
"payfort_plugin",
null
],
[
"videos_player",
null
],
[
"router_management",
null
],
[
"custom_image_crop",
null
],
[
"figma",
null
],
[
"ios_platform_images",
null
],
[
"flutter_mongodb_realm",
null
],
[
"namefully",
null
],
[
"flutter_test_ui",
null
],
[
"livestream",
null
],
[
"flutter_touch_spin",
null
],
[
"image_res",
null
],
[
"flutter_color_plugin",
null
],
[
"argo",
null
],
[
"attributes",
null
],
[
"newsapi",
null
],
[
"pinch_zoom_image_updated",
null
],
[
"flutter_guards",
null
],
[
"rpi_gpio",
null
],
[
"youtube_api",
null
],
[
"build_verify",
null
],
[
"flutter_aad_oauth",
null
],
[
"dragablegridview_flutter",
null
],
[
"geomag",
null
],
[
"futuristic",
null
],
[
"ktx",
null
],
[
"sentiment_dart",
null
],
[
"fluent_query_builder",
null
],
[
"firebase_auth_web",
null
],
[
"password",
null
],
[
"sort",
null
],
[
"flutter_sfsymbols",
null
],
[
"owlbot_dart",
null
],
[
"flutter_siri_suggestions",
null
],
[
"flutter_translate_annotations",
null
],
[
"optimus",
null
],
[
"filesize_plus",
null
],
[
"ripple_button",
null
],
[
"flutter_paginator",
null
],
[
"xrange",
null
],
[
"mockingjay",
null
],
[
"ff_annotation_route_library",
null
],
[
"flutter_nfc_reader",
null
],
[
"spreadsheet_table",
null
],
[
"android_sms_retriever",
null
],
[
"common_ui_toolkit",
null
],
[
"string_stats",
null
],
[
"emoji_alert",
null
],
[
"path_tree",
null
],
[
"sharesdk_plugin",
null
],
[
"r_crypto",
null
],
[
"dime_flutter",
null
],
[
"state_machine",
null
],
[
"flutter_oss_licenses",
null
],
[
"override_text_scale_factor",
null
],
[
"fsuper",
null
],
[
"shake_event",
null
],
[
"ua_client_hints",
null
],
[
"enumerable",
null
],
[
"flick",
null
],
[
"neat_cache",
null
],
[
"painter2",
null
],
[
"all_sensors2",
null
],
[
"flutter_hidden_drawer",
null
],
[
"adhan_dart",
null
],
[
"flutter_showcase",
null
],
[
"slyverin",
null
],
[
"fancy_bottom_bar",
null
],
[
"super_string",
null
],
[
"custom_dialog",
null
],
[
"coinbase_commerce",
null
],
[
"alfreed",
null
],
[
"json_store",
null
],
[
"code_field",
null
],
[
"todo",
null
],
[
"camera_with_rtmp",
null
],
[
"flukit",
null
],
[
"control_button",
null
],
[
"flutter_cursor",
null
],
[
"umeng_analytics_push",
null
],
[
"scaled_list",
null
],
[
"otp_screen",
null
],
[
"fsearch",
null
],
[
"yt",
null
],
[
"input_validator",
null
],
[
"drawer_swipe",
null
],
[
"expandable_group",
null
],
[
"map_controller",
null
],
[
"enough_mail_html",
null
],
[
"stopper",
null
],
[
"flutter_zoom_sdk",
null
],
[
"i18n_localizations",
null
],
[
"kvalifika_sdk",
null
],
[
"flutter_speedometer",
null
],
[
"invert_colors",
null
],
[
"dynamic_form",
null
],
[
"firebase_notifications_handler",
null
],
[
"head_image_cropper",
null
],
[
"dependency_injection_flutter",
null
],
[
"notificare_push_lib",
null
],
[
"node_io",
null
],
[
"music",
null
],
[
"steam_login",
null
],
[
"common_bloc",
null
],
[
"animated_styled_widget",
null
],
[
"package_info_plus_windows",
null
],
[
"frontend_server_client",
null
],
[
"flutter_control",
null
],
[
"units_converter",
null
],
[
"intl_translation",
null
],
[
"monarch",
null
],
[
"sealed_unions",
null
],
[
"enough_media",
null
],
[
"zarinpal",
null
],
[
"wake_on_lan",
null
],
[
"macos_secure_bookmarks",
null
],
[
"pub_release",
null
],
[
"route_parser",
null
],
[
"learning",
null
],
[
"adcolony_flutter",
null
],
[
"sqflite_migration_plan",
null
],
[
"flutter_star",
null
],
[
"speech_recognition",
null
],
[
"flutter_paystack_client",
null
],
[
"widget_mask",
null
],
[
"fast_base58",
null
],
[
"bs_flutter_modal",
null
],
[
"camera_roll_uploader",
null
],
[
"presentation",
null
],
[
"spider_chart",
null
],
[
"flutter_slidable_list_view",
null
],
[
"nav_router",
null
],
[
"day_picker",
null
],
[
"smart_timer",
null
],
[
"bs_flutter_inputtext",
null
],
[
"here_maps_webservice",
null
],
[
"headup_loading",
null
],
[
"esense_flutter",
null
],
[
"animated_image_list",
null
],
[
"measurer",
null
],
[
"iso_duration_parser",
null
],
[
"dart_otp",
null
],
[
"flutter_spotlight",
null
],
[
"realm",
null
],
[
"flutter_fullpdfview",
null
],
[
"place_picker",
null
],
[
"icapps_architecture",
null
],
[
"flutter_spinwheel",
null
],
[
"expand_tap_area",
null
],
[
"overscroll_pop",
null
],
[
"schedulers",
null
],
[
"postgresql2",
null
],
[
"custom_image_picker",
null
],
[
"steps",
null
],
[
"statistical_dart",
null
],
[
"round_spot",
null
],
[
"radial_menu",
null
],
[
"pdf_compressor",
null
],
[
"image_native_resizer",
null
],
[
"asx",
null
],
[
"intl_messages",
null
],
[
"flutter_open_whatsapp",
null
],
[
"chat_pickers",
null
],
[
"gson",
null
],
[
"short_uuids",
null
],
[
"productbarcode",
null
],
[
"ansi_styles",
null
],
[
"flutter_weather_icons",
null
],
[
"connection_verify",
null
],
[
"apptive_grid_form",
null
],
[
"typeweight",
null
],
[
"standard_dialogs",
null
],
[
"weibo_kit",
null
],
[
"flutter_process_text",
null
],
[
"buddhist_datetime_dateformat",
null
],
[
"flutter_web_frame",
null
],
[
"license_plate_number",
null
],
[
"enough_icalendar",
null
],
[
"fitness",
null
],
[
"feather_icons_flutter",
null
],
[
"woocommerce_api",
null
],
[
"google_tag_manager",
null
],
[
"internationalization",
null
],
[
"modern_charts",
null
],
[
"easy_web_view",
null
],
[
"clean_settings",
null
],
[
"location_platform_interface",
null
],
[
"unofficial_jisho_api",
null
],
[
"flusmic_ui",
null
],
[
"flutter_web3",
null
],
[
"monarch_annotations",
null
],
[
"mongo_dart_query",
null
],
[
"native_exif",
null
],
[
"marker",
null
],
[
"circular_buffer",
null
],
[
"angular",
null
],
[
"flutter_nordic_dfu",
null
],
[
"raygun4flutter",
null
],
[
"matrix",
null
],
[
"enough_mail_flutter",
null
],
[
"slider_side_menu",
null
],
[
"animated_stream_list",
null
],
[
"smartlook",
null
],
[
"enume",
null
],
[
"screenshot_callback",
null
],
[
"flutter_text_styled",
null
],
[
"flutter_colored_progress_indicators",
null
],
[
"asset_button",
null
],
[
"bluetooth_enable",
null
],
[
"rx_bloc_generator",
null
],
[
"is_device_secure",
null
],
[
"flutter_progress_status",
null
],
[
"amdjs",
null
],
[
"open_simplex_2",
null
],
[
"awesome_button",
null
],
[
"getsocket",
null
],
[
"tcp_scanner",
null
],
[
"very_good_performance",
null
],
[
"sms",
null
],
[
"image_picker_modern",
null
],
[
"reference_parser",
null
],
[
"flutter_super_state",
null
],
[
"shelf_cors_headers",
null
],
[
"input_country",
null
],
[
"flutter_chat",
null
],
[
"mdns_plugin",
null
],
[
"downloads_path_provider",
null
],
[
"snowplow_flutter_tracker",
null
],
[
"geocoder",
null
],
[
"flutter_shortener",
null
],
[
"mrz_parser",
null
],
[
"desktoasts",
null
],
[
"angel_framework",
null
],
[
"flutter_particle_background",
null
],
[
"eval_ex",
null
],
[
"facebook_analytics",
null
],
[
"awsome_video_player",
null
],
[
"acyclic_steps",
null
],
[
"sqlcipher_flutter_libs",
null
],
[
"color_converter",
null
],
[
"rongcloud_im_plugin",
null
],
[
"custom_rounded_rectangle_border",
null
],
[
"auth0",
null
],
[
"admob_consent",
null
],
[
"hash",
null
],
[
"imei_plugin",
null
],
[
"search_widget",
null
],
[
"acr_cloud_sdk",
null
],
[
"progress_hud",
null
],
[
"flutter_circle_chart",
null
],
[
"progress_bars",
null
],
[
"delayed_consumer_hud",
null
],
[
"flutter_dtmf",
null
],
[
"flutter_time_button",
null
],
[
"flutter_scandit_plugin",
null
],
[
"flutter_circular_chart",
null
],
[
"former",
null
],
[
"dart_mongo_lite",
null
],
[
"rive_loading",
null
],
[
"camerakit",
null
],
[
"version_manipulation",
null
],
[
"fhir_db",
null
],
[
"chopper_built_value",
null
],
[
"tiledjsonreader",
null
],
[
"web_date_picker",
null
],
[
"random_pk",
null
],
[
"flutex",
null
],
[
"legacy_progress_dialog",
null
],
[
"adv_image_cache",
null
],
[
"spinner_button",
null
],
[
"analytics_event",
null
],
[
"flutter_twitter",
null
],
[
"wave_progress_widget",
null
],
[
"flutter_scrolling_fab_animated",
null
],
[
"filesystem_picker",
null
],
[
"flutter_sunmi_printer",
null
],
[
"smart_grid_view",
null
],
[
"blinking_point",
null
],
[
"reactive_segmented_control",
null
],
[
"doc_widget_annotation",
null
],
[
"google_sign_in_mocks",
null
],
[
"diff_image",
null
],
[
"wheel_chooser",
null
],
[
"toggle_rotate",
null
],
[
"flutter_package_manager",
null
],
[
"flutter_waya",
null
],
[
"pass_flutter",
null
],
[
"aspose_words_cloud",
null
],
[
"sounds",
null
],
[
"at_lookup",
null
],
[
"drop_zone",
null
],
[
"known_extents_list_view_builder",
null
],
[
"speech_to_text_platform_interface",
null
],
[
"strcolor",
null
],
[
"keybinder",
null
],
[
"permission_asker",
null
],
[
"storage_wrapper",
null
],
[
"progress_builder",
null
],
[
"flutter_secure_keyboard",
null
],
[
"art_sweetalert",
null
],
[
"sqfentity_gen",
null
],
[
"calendar_views",
null
],
[
"easy_alert",
null
],
[
"ticketview",
null
],
[
"rosetta",
null
],
[
"juxtapose",
null
],
[
"r_calendar",
null
],
[
"zoom",
null
],
[
"responsive_image",
null
],
[
"algorand_dart",
null
],
[
"fast_qr_reader_view",
null
],
[
"bottom_personalized_dot_bar",
null
],
[
"oxygen",
null
],
[
"flutter_snow_base",
null
],
[
"app_center_bundle_sdk",
null
],
[
"rich_code_editor",
null
],
[
"hover_effect",
null
],
[
"currency_decimal_formatter",
null
],
[
"flutter_onboarding_screen",
null
],
[
"on_upgrade",
null
],
[
"wallpaper_manager_flutter",
null
],
[
"sensors_analytics_flutter_plugin",
null
],
[
"selectable_circle",
null
],
[
"flutter_video_cast",
null
],
[
"fluttering_phrases",
null
],
[
"flutter_socket_plugin",
null
],
[
"flutter_appauth_platform_interface",
null
],
[
"disposable_object",
null
],
[
"swipeable_card",
null
],
[
"gtin_toolkit",
null
],
[
"day_night_switch",
null
],
[
"sdp_transform",
null
],
[
"leak_detector",
null
],
[
"flutter_is_emulator",
null
],
[
"toml_localizations",
null
],
[
"master_detail_scaffold",
null
],
[
"flutter_ip",
null
],
[
"lit_relative_date_time",
null
],
[
"video_player_360",
null
],
[
"conduit_open_api",
null
],
[
"pls",
null
],
[
"schedule_controller",
null
],
[
"opus_dart",
null
],
[
"window_paint",
null
],
[
"video_box",
null
],
[
"flutter_uxcam",
null
],
[
"epub_kitty_lib",
null
],
[
"fast_marquee",
null
],
[
"screen_size_test",
null
],
[
"conduit_password_hash",
null
],
[
"media_gallery",
null
],
[
"rx_bloc_cli",
null
],
[
"screens",
null
],
[
"nuid",
null
],
[
"ss_bottom_navbar",
null
],
[
"flutter_acpcore",
null
],
[
"sms_advanced",
null
],
[
"testsweets",
null
],
[
"liquid_engine",
null
],
[
"posthog_flutter",
null
],
[
"flutter_turtle",
null
],
[
"lakos",
null
],
[
"rsa_identification",
null
],
[
"flutter_socket_io",
null
],
[
"flutter_sms_inbox",
null
],
[
"flutter_datepicker_single",
null
],
[
"flutter_cube",
null
],
[
"truecaller_sdk",
null
],
[
"flrx_validator",
null
],
[
"expandable_slider",
null
],
[
"moor_generator",
null
],
[
"mews_pedantic",
null
],
[
"stepo",
null
],
[
"queen_alerts",
null
],
[
"diagram_editor",
null
],
[
"pubspec_generator",
null
],
[
"ping_discover_network_forked",
null
],
[
"flutter_image_slider",
null
],
[
"string_ext",
null
],
[
"health_kit",
null
],
[
"flutter_mobile_vision",
null
],
[
"easy_onboarding",
null
],
[
"cupertino_range_slider",
null
],
[
"elapsed",
null
],
[
"strict_analyzer",
null
],
[
"text_chunk_styling",
null
],
[
"git_hooks",
null
],
[
"twitter_api",
null
],
[
"class_to_map",
null
],
[
"simple_json_mapper",
null
],
[
"async_field",
null
],
[
"oboe",
null
],
[
"glutton",
null
],
[
"firebase_picture_uploader",
null
],
[
"games_services",
null
],
[
"number_animation",
null
],
[
"angel_validate",
null
],
[
"flutter_verification_box",
null
],
[
"data_usage",
null
],
[
"medcorder_audio",
null
],
[
"flutter_hms_gms_availability",
null
],
[
"simple_shadow",
null
],
[
"notifier",
null
],
[
"inherited_state",
null
],
[
"file_cache",
null
],
[
"flutter_acpanalytics",
null
],
[
"dartin",
null
],
[
"mobile_sidebar",
null
],
[
"country_currency_chooser",
null
],
[
"connectivity_alert_widget",
null
],
[
"phonenumbers_core",
null
],
[
"app_wrapper",
null
],
[
"simple_drawer",
null
],
[
"sup",
null
],
[
"midpay",
null
],
[
"ed25519_hd_key",
null
],
[
"msal_flutter",
null
],
[
"location_web",
null
],
[
"international_phone_input",
null
],
[
"boxicons",
null
],
[
"outlined_text",
null
],
[
"reactives",
null
],
[
"mc",
null
],
[
"barcode_scan_fix",
null
],
[
"tailwind_colors",
null
],
[
"activity_ring",
null
],
[
"test_cov",
null
],
[
"podcast_search",
null
],
[
"base58check",
null
],
[
"monnify_flutter_sdk",
null
],
[
"nice_buttons",
null
],
[
"youtube_metadata",
null
],
[
"animated_digit",
null
],
[
"page_slider",
null
],
[
"colored_print",
null
],
[
"state_queue",
null
],
[
"is_pirated",
null
],
[
"flutter_responsive",
null
],
[
"zxcvbn",
null
],
[
"flutter_voice_processor",
null
],
[
"all_sensors",
null
],
[
"widget_animator",
null
],
[
"cli_menu",
null
],
[
"posix",
null
],
[
"search_app_bar",
null
],
[
"notustohtml",
null
],
[
"statusbarmanager",
null
],
[
"scale_monk",
null
],
[
"grafpix",
null
],
[
"expandable_widget",
null
],
[
"dumble",
null
],
[
"sliver_animated_list",
null
],
[
"google_maps_flutter_heatmap",
null
],
[
"speed_up_flutter",
null
],
[
"area",
null
],
[
"stepper_counter_swipe",
null
],
[
"json_serializable_immutable_collections",
null
],
[
"shape_of_view_null_safe",
null
],
[
"flavor_config",
null
],
[
"shelf_hotreload",
null
],
[
"flutter_gauge",
null
],
[
"fsm2",
null
],
[
"font_awesome",
null
],
[
"plain_optional",
null
],
[
"circular_bottom_navigation",
null
],
[
"flutter_openvpn",
null
],
[
"sms_otp_auto_verify",
null
],
[
"decorative_app_bar",
null
],
[
"nice_intro",
null
],
[
"elegant_notification",
null
],
[
"flutter_audio_query",
null
],
[
"expandable_bottom_bar_new",
null
],
[
"universal_ui",
null
],
[
"flutter_emoji_keyboard",
null
],
[
"linkfo",
null
],
[
"gallerize",
null
],
[
"flutter_tableview",
null
],
[
"open_appstore",
null
],
[
"shared_ui_components",
null
],
[
"combos",
null
],
[
"flt_worker",
null
],
[
"at_backupkey_flutter",
null
],
[
"emoji_lumberdash",
null
],
[
"flutter_flip_view",
null
],
[
"easy_animated_tabbar",
null
],
[
"cnpj_cpf_formatter",
null
],
[
"flutter_proxy",
null
],
[
"flutter_native_admob",
null
],
[
"sqlcool",
null
],
[
"fancy_on_boarding",
null
],
[
"coordinator_layout",
null
],
[
"bugly_crash",
null
],
[
"parent_child_checkbox",
null
],
[
"learning_face_detection",
null
],
[
"cloud_functions_web",
null
],
[
"flutter_payments_stripe_sdk",
null
],
[
"fluwx_no_pay",
null
],
[
"json_object_lite",
null
],
[
"persian_datetimepickers",
null
],
[
"webdav_client",
null
],
[
"mobile_web_view",
null
],
[
"blockquote",
null
],
[
"just_audio_cache",
null
],
[
"cool_stepper_reloaded",
null
],
[
"dio_flutter_transformer2",
null
],
[
"rsa_scan",
null
],
[
"openmhealth_schemas",
null
],
[
"volume_regulator",
null
],
[
"swipe_up",
null
],
[
"wizard_router",
null
],
[
"animated_list_view_scroll",
null
],
[
"outline_material_icons_tv",
null
],
[
"firebase_dart",
null
],
[
"bson",
null
],
[
"flutter_walkthrough_screen",
null
],
[
"dot_pagination_swiper",
null
],
[
"awesome_emojis",
null
],
[
"native_video_view",
null
],
[
"contactor_picker",
null
],
[
"proste_dialog",
null
],
[
"signalr_client",
null
],
[
"pragmatic_navigation",
null
],
[
"flutter95",
null
],
[
"snippet_coder_utils",
null
],
[
"circular_custom_loader",
null
],
[
"animated_widgets_ns",
null
],
[
"codemirror",
null
],
[
"benchmark_harness",
null
],
[
"derry",
null
],
[
"bart",
null
],
[
"nyxx_interactions",
null
],
[
"scheduled_date_picker",
null
],
[
"isolate_json",
null
],
[
"easy_dispose",
null
],
[
"string_literal_finder",
null
],
[
"fff",
null
],
[
"multipart_request",
null
],
[
"animated_horizontal_calendar",
null
],
[
"custom_picker",
null
],
[
"apptive_grid_core",
null
],
[
"autolist",
null
],
[
"timeline_list",
null
],
[
"true_time",
null
],
[
"sasl_scram",
null
],
[
"google_mobile_ads_ext",
null
],
[
"firebase_admin_interop",
null
],
[
"map_pin_picker",
null
],
[
"side_sheet",
null
],
[
"get_version",
null
],
[
"circle_color_picker_view",
null
],
[
"dart_numerics",
null
],
[
"flutter_section_table_view",
null
],
[
"flutter_ijkplayer",
null
],
[
"scaled_animated_scaffold",
null
],
[
"flutter_circular_chart_two",
null
],
[
"flutter_bluetooth_basic",
null
],
[
"logger_flutter",
null
],
[
"user_profile",
null
],
[
"flutter_cupertino_data_picker",
null
],
[
"angel3_static",
null
],
[
"awesome_slider",
null
],
[
"agora_rtm",
null
],
[
"junitreport",
null
],
[
"flutter_foreground_service",
null
],
[
"dartis",
null
],
[
"huawei_iap",
null
],
[
"isolate_bloc",
null
],
[
"side_header_list_view",
null
],
[
"nordigen_integration",
null
],
[
"pin_code_view",
null
],
[
"conditional_builder",
null
],
[
"draggable_flutter_list",
null
],
[
"flutter_google_places_sdk",
null
],
[
"utility",
null
],
[
"intrinsic_grid_view",
null
],
[
"catalyst_builder",
null
],
[
"base_x",
null
],
[
"root_check",
null
],
[
"flutter_persistent_queue",
null
],
[
"flutter_superchat",
null
],
[
"pana",
null
],
[
"patterns_canvas",
null
],
[
"responsive_flutter",
null
],
[
"material_snackbar",
null
],
[
"stripe_native",
null
],
[
"route_handler",
null
],
[
"fradio",
null
],
[
"flutter_responsive_breakpoints",
null
],
[
"qrcode",
null
],
[
"did_change_dependencies",
null
],
[
"vimeoplayer",
null
],
[
"eventhandler",
null
],
[
"no_glow_scroll",
null
],
[
"flutter_biometrics",
null
],
[
"motion_tab_bar_v2",
null
],
[
"nv_tooling",
null
],
[
"draw_on",
View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment