diff --git a/packages/stack/example/.gitignore b/packages/stack/example/.gitignore
new file mode 100644
index 00000000..f98cddd5
--- /dev/null
+++ b/packages/stack/example/.gitignore
@@ -0,0 +1 @@
+ios/Pods
diff --git a/packages/stack/example/android/app/BUCK b/packages/stack/example/android/app/BUCK
new file mode 100644
index 00000000..f92de11c
--- /dev/null
+++ b/packages/stack/example/android/app/BUCK
@@ -0,0 +1,65 @@
+# To learn about Buck see [Docs](https://buckbuild.com/).
+# To run your application with Buck:
+# - install Buck
+# - `npm start` - to start the packager
+# - `cd android`
+# - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"`
+# - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck
+# - `buck install -r android/app` - compile, install and run application
+#
+
+lib_deps = []
+
+for jarfile in glob(['libs/*.jar']):
+ name = 'jars__' + jarfile[jarfile.rindex('/') + 1: jarfile.rindex('.jar')]
+ lib_deps.append(':' + name)
+ prebuilt_jar(
+ name = name,
+ binary_jar = jarfile,
+ )
+
+for aarfile in glob(['libs/*.aar']):
+ name = 'aars__' + aarfile[aarfile.rindex('/') + 1: aarfile.rindex('.aar')]
+ lib_deps.append(':' + name)
+ android_prebuilt_aar(
+ name = name,
+ aar = aarfile,
+ )
+
+android_library(
+ name = "all-libs",
+ exported_deps = lib_deps,
+)
+
+android_library(
+ name = "app-code",
+ srcs = glob([
+ "src/main/java/**/*.java",
+ ]),
+ deps = [
+ ":all-libs",
+ ":build_config",
+ ":res",
+ ],
+)
+
+android_build_config(
+ name = "build_config",
+ package = "com.stackexample",
+)
+
+android_resource(
+ name = "res",
+ package = "com.stackexample",
+ res = "src/main/res",
+)
+
+android_binary(
+ name = "app",
+ keystore = "//android/keystores:debug",
+ manifest = "src/main/AndroidManifest.xml",
+ package_type = "debug",
+ deps = [
+ ":app-code",
+ ],
+)
diff --git a/packages/stack/example/android/app/build.gradle b/packages/stack/example/android/app/build.gradle
new file mode 100644
index 00000000..e416cb1d
--- /dev/null
+++ b/packages/stack/example/android/app/build.gradle
@@ -0,0 +1,156 @@
+apply plugin: "com.android.application"
+
+import com.android.build.OutputFile
+
+/**
+ * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
+ * and bundleReleaseJsAndAssets).
+ * These basically call `react-native bundle` with the correct arguments during the Android build
+ * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
+ * bundle directly from the development server. Below you can see all the possible configurations
+ * and their defaults. If you decide to add a configuration block, make sure to add it before the
+ * `apply from: "../../node_modules/react-native/react.gradle"` line.
+ *
+ * project.ext.react = [
+ * // the name of the generated asset file containing your JS bundle
+ * bundleAssetName: "index.android.bundle",
+ *
+ * // the entry file for bundle generation
+ * entryFile: "index.android.js",
+ *
+ * // whether to bundle JS and assets in debug mode
+ * bundleInDebug: false,
+ *
+ * // whether to bundle JS and assets in release mode
+ * bundleInRelease: true,
+ *
+ * // whether to bundle JS and assets in another build variant (if configured).
+ * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
+ * // The configuration property can be in the following formats
+ * // 'bundleIn${productFlavor}${buildType}'
+ * // 'bundleIn${buildType}'
+ * // bundleInFreeDebug: true,
+ * // bundleInPaidRelease: true,
+ * // bundleInBeta: true,
+ *
+ * // whether to disable dev mode in custom build variants (by default only disabled in release)
+ * // for example: to disable dev mode in the staging build type (if configured)
+ * devDisabledInStaging: true,
+ * // The configuration property can be in the following formats
+ * // 'devDisabledIn${productFlavor}${buildType}'
+ * // 'devDisabledIn${buildType}'
+ *
+ * // the root of your project, i.e. where "package.json" lives
+ * root: "../../",
+ *
+ * // where to put the JS bundle asset in debug mode
+ * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
+ *
+ * // where to put the JS bundle asset in release mode
+ * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
+ *
+ * // where to put drawable resources / React Native assets, e.g. the ones you use via
+ * // require('./image.png')), in debug mode
+ * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
+ *
+ * // where to put drawable resources / React Native assets, e.g. the ones you use via
+ * // require('./image.png')), in release mode
+ * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
+ *
+ * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
+ * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
+ * // date; if you have any other folders that you want to ignore for performance reasons (gradle
+ * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
+ * // for example, you might want to remove it from here.
+ * inputExcludes: ["android/**", "ios/**"],
+ *
+ * // override which node gets called and with what additional arguments
+ * nodeExecutableAndArgs: ["node"],
+ *
+ * // supply additional arguments to the packager
+ * extraPackagerArgs: []
+ * ]
+ */
+
+project.ext.react = [
+ entryFile: "index.js"
+]
+
+apply from: '../../node_modules/react-native-unimodules/gradle.groovy'
+apply from: "../../node_modules/react-native/react.gradle"
+
+/**
+ * Set this to true to create two separate APKs instead of one:
+ * - An APK that only works on ARM devices
+ * - An APK that only works on x86 devices
+ * The advantage is the size of the APK is reduced by about 4MB.
+ * Upload all the APKs to the Play Store and people will download
+ * the correct one based on the CPU architecture of their device.
+ */
+def enableSeparateBuildPerCPUArchitecture = false
+
+/**
+ * Run Proguard to shrink the Java bytecode in release builds.
+ */
+def enableProguardInReleaseBuilds = false
+
+android {
+ compileSdkVersion rootProject.ext.compileSdkVersion
+ buildToolsVersion rootProject.ext.buildToolsVersion
+
+ defaultConfig {
+ applicationId "com.stackexample"
+ minSdkVersion rootProject.ext.minSdkVersion
+ targetSdkVersion rootProject.ext.targetSdkVersion
+ versionCode 1
+ versionName "1.0"
+ }
+ splits {
+ abi {
+ reset()
+ enable enableSeparateBuildPerCPUArchitecture
+ universalApk false // If true, also generate a universal APK
+ include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
+ }
+ }
+ buildTypes {
+ release {
+ minifyEnabled enableProguardInReleaseBuilds
+ proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
+ }
+ }
+ // applicationVariants are e.g. debug, release
+ applicationVariants.all { variant ->
+ variant.outputs.each { output ->
+ // For each separate APK per architecture, set a unique version code as described here:
+ // http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
+ def versionCodes = ["armeabi-v7a":1, "x86":2, "arm64-v8a": 3, "x86_64": 4]
+ def abi = output.getFilter(OutputFile.ABI)
+ if (abi != null) { // null for the universal-debug, universal-release variants
+ output.versionCodeOverride =
+ versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
+ }
+ }
+ }
+ compileOptions {
+ sourceCompatibility JavaVersion.VERSION_1_8
+ targetCompatibility JavaVersion.VERSION_1_8
+ }
+}
+
+dependencies {
+ implementation project(':react-native-webview')
+ implementation project(':react-native-reanimated')
+ implementation project(':react-native-gesture-handler')
+ implementation fileTree(dir: "libs", include: ["*.jar"])
+ implementation "com.android.support:appcompat-v7:${rootProject.ext.supportLibVersion}"
+ implementation "com.facebook.react:react-native:+" // From node_modules
+ addUnimodulesDependencies()
+}
+
+// Run this once to be able to run the application with BUCK
+// puts all compile dependencies into folder libs for BUCK to use
+task copyDownloadableDepsToLibs(type: Copy) {
+ from configurations.compile
+ into 'libs'
+}
diff --git a/packages/stack/example/android/app/build_defs.bzl b/packages/stack/example/android/app/build_defs.bzl
new file mode 100644
index 00000000..fff270f8
--- /dev/null
+++ b/packages/stack/example/android/app/build_defs.bzl
@@ -0,0 +1,19 @@
+"""Helper definitions to glob .aar and .jar targets"""
+
+def create_aar_targets(aarfiles):
+ for aarfile in aarfiles:
+ name = "aars__" + aarfile[aarfile.rindex("/") + 1:aarfile.rindex(".aar")]
+ lib_deps.append(":" + name)
+ android_prebuilt_aar(
+ name = name,
+ aar = aarfile,
+ )
+
+def create_jar_targets(jarfiles):
+ for jarfile in jarfiles:
+ name = "jars__" + jarfile[jarfile.rindex("/") + 1:jarfile.rindex(".jar")]
+ lib_deps.append(":" + name)
+ prebuilt_jar(
+ name = name,
+ binary_jar = jarfile,
+ )
diff --git a/packages/stack/example/android/app/proguard-rules.pro b/packages/stack/example/android/app/proguard-rules.pro
new file mode 100644
index 00000000..a92fa177
--- /dev/null
+++ b/packages/stack/example/android/app/proguard-rules.pro
@@ -0,0 +1,17 @@
+# Add project specific ProGuard rules here.
+# By default, the flags in this file are appended to flags specified
+# in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt
+# You can edit the include path and order by changing the proguardFiles
+# directive in build.gradle.
+#
+# For more details, see
+# http://developer.android.com/guide/developing/tools/proguard.html
+
+# Add any project specific keep options here:
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+# public *;
+#}
diff --git a/packages/stack/example/android/app/src/main/AndroidManifest.xml b/packages/stack/example/android/app/src/main/AndroidManifest.xml
new file mode 100644
index 00000000..62728673
--- /dev/null
+++ b/packages/stack/example/android/app/src/main/AndroidManifest.xml
@@ -0,0 +1,48 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/packages/stack/example/android/app/src/main/java/com/stackexample/MainActivity.java b/packages/stack/example/android/app/src/main/java/com/stackexample/MainActivity.java
new file mode 100644
index 00000000..6614f71e
--- /dev/null
+++ b/packages/stack/example/android/app/src/main/java/com/stackexample/MainActivity.java
@@ -0,0 +1,28 @@
+package com.stackexample;
+
+import com.facebook.react.ReactActivity;
+import com.facebook.react.ReactActivityDelegate;
+import com.facebook.react.ReactRootView;
+import com.swmansion.gesturehandler.react.RNGestureHandlerEnabledRootView;
+
+public class MainActivity extends ReactActivity {
+
+ /**
+ * Returns the name of the main component registered from JavaScript.
+ * This is used to schedule rendering of the component.
+ */
+ @Override
+ protected String getMainComponentName() {
+ return "StackExample";
+ }
+
+ @Override
+ protected ReactActivityDelegate createReactActivityDelegate() {
+ return new ReactActivityDelegate(this, getMainComponentName()) {
+ @Override
+ protected ReactRootView createRootView() {
+ return new RNGestureHandlerEnabledRootView(MainActivity.this);
+ }
+ };
+ }
+}
diff --git a/packages/stack/example/android/app/src/main/java/com/stackexample/MainApplication.java b/packages/stack/example/android/app/src/main/java/com/stackexample/MainApplication.java
new file mode 100644
index 00000000..767dae9a
--- /dev/null
+++ b/packages/stack/example/android/app/src/main/java/com/stackexample/MainApplication.java
@@ -0,0 +1,66 @@
+package com.stackexample;
+
+import android.app.Application;
+
+import com.facebook.react.ReactApplication;
+import com.reactnativecommunity.webview.RNCWebViewPackage;
+import com.swmansion.reanimated.ReanimatedPackage;
+import com.facebook.react.ReactNativeHost;
+import com.facebook.react.ReactPackage;
+import com.facebook.react.shell.MainReactPackage;
+import com.facebook.soloader.SoLoader;
+import com.stackexample.generated.BasePackageList;
+import com.swmansion.gesturehandler.react.RNGestureHandlerPackage;
+
+import org.unimodules.adapters.react.ReactAdapterPackage;
+import org.unimodules.adapters.react.ModuleRegistryAdapter;
+import org.unimodules.adapters.react.ReactModuleRegistryProvider;
+import org.unimodules.core.interfaces.Package;
+import org.unimodules.core.interfaces.SingletonModule;
+import expo.modules.constants.ConstantsPackage;
+import expo.modules.permissions.PermissionsPackage;
+import expo.modules.filesystem.FileSystemPackage;
+
+import java.util.Arrays;
+import java.util.List;
+
+public class MainApplication extends Application implements ReactApplication {
+ private final ReactModuleRegistryProvider mModuleRegistryProvider = new ReactModuleRegistryProvider(
+ new BasePackageList().getPackageList(),
+ Arrays.asList()
+ );
+
+ private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
+ @Override
+ public boolean getUseDeveloperSupport() {
+ return BuildConfig.DEBUG;
+ }
+
+ @Override
+ protected List getPackages() {
+ return Arrays.asList(
+ new MainReactPackage(),
+ new RNCWebViewPackage(),
+ new ReanimatedPackage(),
+ new RNGestureHandlerPackage(),
+ new ModuleRegistryAdapter(mModuleRegistryProvider)
+ );
+ }
+
+ @Override
+ protected String getJSMainModuleName() {
+ return "index";
+ }
+ };
+
+ @Override
+ public ReactNativeHost getReactNativeHost() {
+ return mReactNativeHost;
+ }
+
+ @Override
+ public void onCreate() {
+ super.onCreate();
+ SoLoader.init(this, /* native exopackage */ false);
+ }
+}
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png b/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
new file mode 100644
index 00000000..a2f59082
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png b/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
new file mode 100644
index 00000000..1b523998
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png b/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
new file mode 100644
index 00000000..ff10afd6
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png b/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
new file mode 100644
index 00000000..115a4c76
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
new file mode 100644
index 00000000..dcd3cd80
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png b/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..459ca609
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
new file mode 100644
index 00000000..8ca12fe0
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png b/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..8e19b410
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
new file mode 100644
index 00000000..b824ebdd
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png b/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..4c19a13c
Binary files /dev/null and b/packages/stack/example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png differ
diff --git a/packages/stack/example/android/app/src/main/res/values/strings.xml b/packages/stack/example/android/app/src/main/res/values/strings.xml
new file mode 100644
index 00000000..f38fef3e
--- /dev/null
+++ b/packages/stack/example/android/app/src/main/res/values/strings.xml
@@ -0,0 +1,3 @@
+
+ React Navigation Stack Example
+
diff --git a/packages/stack/example/android/app/src/main/res/values/styles.xml b/packages/stack/example/android/app/src/main/res/values/styles.xml
new file mode 100644
index 00000000..319eb0ca
--- /dev/null
+++ b/packages/stack/example/android/app/src/main/res/values/styles.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
diff --git a/packages/stack/example/android/build.gradle b/packages/stack/example/android/build.gradle
new file mode 100644
index 00000000..e643c41b
--- /dev/null
+++ b/packages/stack/example/android/build.gradle
@@ -0,0 +1,39 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+
+buildscript {
+ ext {
+ buildToolsVersion = "28.0.3"
+ minSdkVersion = 21
+ compileSdkVersion = 28
+ targetSdkVersion = 27
+ supportLibVersion = "28.0.0"
+ }
+ repositories {
+ google()
+ jcenter()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:3.3.0'
+
+ // NOTE: Do not place your application dependencies here; they belong
+ // in the individual module build.gradle files
+ }
+}
+
+allprojects {
+ repositories {
+ mavenLocal()
+ google()
+ jcenter()
+ maven {
+ // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
+ url "$rootDir/../node_modules/react-native/android"
+ }
+ }
+}
+
+
+task wrapper(type: Wrapper) {
+ gradleVersion = '4.7'
+ distributionUrl = distributionUrl.replace("bin", "all")
+}
diff --git a/packages/stack/example/android/gradle.properties b/packages/stack/example/android/gradle.properties
new file mode 100644
index 00000000..89e0d99e
--- /dev/null
+++ b/packages/stack/example/android/gradle.properties
@@ -0,0 +1,18 @@
+# Project-wide Gradle settings.
+
+# IDE (e.g. Android Studio) users:
+# Gradle settings configured through the IDE *will override*
+# any settings specified in this file.
+
+# For more details on how to configure your build environment visit
+# http://www.gradle.org/docs/current/userguide/build_environment.html
+
+# Specifies the JVM arguments used for the daemon process.
+# The setting is particularly useful for tweaking memory settings.
+# Default value: -Xmx10248m -XX:MaxPermSize=256m
+# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
+
+# When configured, Gradle will run in incubating parallel mode.
+# This option should only be used with decoupled projects. More details, visit
+# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
+# org.gradle.parallel=true
diff --git a/packages/stack/example/android/gradle/wrapper/gradle-wrapper.jar b/packages/stack/example/android/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 00000000..01b8bf6b
Binary files /dev/null and b/packages/stack/example/android/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/packages/stack/example/android/gradle/wrapper/gradle-wrapper.properties b/packages/stack/example/android/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 00000000..b10568fb
--- /dev/null
+++ b/packages/stack/example/android/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,5 @@
+distributionBase=GRADLE_USER_HOME
+distributionPath=wrapper/dists
+zipStoreBase=GRADLE_USER_HOME
+zipStorePath=wrapper/dists
+distributionUrl=https\://services.gradle.org/distributions/gradle-4.10.1-all.zip
diff --git a/packages/stack/example/android/gradlew b/packages/stack/example/android/gradlew
new file mode 100755
index 00000000..cccdd3d5
--- /dev/null
+++ b/packages/stack/example/android/gradlew
@@ -0,0 +1,172 @@
+#!/usr/bin/env sh
+
+##############################################################################
+##
+## Gradle start up script for UN*X
+##
+##############################################################################
+
+# Attempt to set APP_HOME
+# Resolve links: $0 may be a link
+PRG="$0"
+# Need this for relative symlinks.
+while [ -h "$PRG" ] ; do
+ ls=`ls -ld "$PRG"`
+ link=`expr "$ls" : '.*-> \(.*\)$'`
+ if expr "$link" : '/.*' > /dev/null; then
+ PRG="$link"
+ else
+ PRG=`dirname "$PRG"`"/$link"
+ fi
+done
+SAVED="`pwd`"
+cd "`dirname \"$PRG\"`/" >/dev/null
+APP_HOME="`pwd -P`"
+cd "$SAVED" >/dev/null
+
+APP_NAME="Gradle"
+APP_BASE_NAME=`basename "$0"`
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS=""
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD="maximum"
+
+warn () {
+ echo "$*"
+}
+
+die () {
+ echo
+ echo "$*"
+ echo
+ exit 1
+}
+
+# OS specific support (must be 'true' or 'false').
+cygwin=false
+msys=false
+darwin=false
+nonstop=false
+case "`uname`" in
+ CYGWIN* )
+ cygwin=true
+ ;;
+ Darwin* )
+ darwin=true
+ ;;
+ MINGW* )
+ msys=true
+ ;;
+ NONSTOP* )
+ nonstop=true
+ ;;
+esac
+
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
+# Determine the Java command to use to start the JVM.
+if [ -n "$JAVA_HOME" ] ; then
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+ # IBM's JDK on AIX uses strange locations for the executables
+ JAVACMD="$JAVA_HOME/jre/sh/java"
+ else
+ JAVACMD="$JAVA_HOME/bin/java"
+ fi
+ if [ ! -x "$JAVACMD" ] ; then
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+ fi
+else
+ JAVACMD="java"
+ which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+fi
+
+# Increase the maximum file descriptors if we can.
+if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
+ MAX_FD_LIMIT=`ulimit -H -n`
+ if [ $? -eq 0 ] ; then
+ if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
+ MAX_FD="$MAX_FD_LIMIT"
+ fi
+ ulimit -n $MAX_FD
+ if [ $? -ne 0 ] ; then
+ warn "Could not set maximum file descriptor limit: $MAX_FD"
+ fi
+ else
+ warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
+ fi
+fi
+
+# For Darwin, add options to specify how the application appears in the dock
+if $darwin; then
+ GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
+fi
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin ; then
+ APP_HOME=`cygpath --path --mixed "$APP_HOME"`
+ CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
+ JAVACMD=`cygpath --unix "$JAVACMD"`
+
+ # We build the pattern for arguments to be converted via cygpath
+ ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
+ SEP=""
+ for dir in $ROOTDIRSRAW ; do
+ ROOTDIRS="$ROOTDIRS$SEP$dir"
+ SEP="|"
+ done
+ OURCYGPATTERN="(^($ROOTDIRS))"
+ # Add a user-defined pattern to the cygpath arguments
+ if [ "$GRADLE_CYGPATTERN" != "" ] ; then
+ OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
+ fi
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
+ i=0
+ for arg in "$@" ; do
+ CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
+ CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
+
+ if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
+ eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
+ else
+ eval `echo args$i`="\"$arg\""
+ fi
+ i=$((i+1))
+ done
+ case $i in
+ (0) set -- ;;
+ (1) set -- "$args0" ;;
+ (2) set -- "$args0" "$args1" ;;
+ (3) set -- "$args0" "$args1" "$args2" ;;
+ (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
+ (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
+ (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
+ (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
+ (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
+ (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
+ esac
+fi
+
+# Escape application args
+save () {
+ for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
+ echo " "
+}
+APP_ARGS=$(save "$@")
+
+# Collect all arguments for the java command, following the shell quoting and substitution rules
+eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
+
+# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
+if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
+ cd "$(dirname "$0")"
+fi
+
+exec "$JAVACMD" "$@"
diff --git a/packages/stack/example/android/gradlew.bat b/packages/stack/example/android/gradlew.bat
new file mode 100644
index 00000000..f9553162
--- /dev/null
+++ b/packages/stack/example/android/gradlew.bat
@@ -0,0 +1,84 @@
+@if "%DEBUG%" == "" @echo off
+@rem ##########################################################################
+@rem
+@rem Gradle startup script for Windows
+@rem
+@rem ##########################################################################
+
+@rem Set local scope for the variables with windows NT shell
+if "%OS%"=="Windows_NT" setlocal
+
+set DIRNAME=%~dp0
+if "%DIRNAME%" == "" set DIRNAME=.
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+set DEFAULT_JVM_OPTS=
+
+@rem Find java.exe
+if defined JAVA_HOME goto findJavaFromJavaHome
+
+set JAVA_EXE=java.exe
+%JAVA_EXE% -version >NUL 2>&1
+if "%ERRORLEVEL%" == "0" goto init
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto init
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:init
+@rem Get command-line arguments, handling Windows variants
+
+if not "%OS%" == "Windows_NT" goto win9xME_args
+
+:win9xME_args
+@rem Slurp the command line arguments.
+set CMD_LINE_ARGS=
+set _SKIP=2
+
+:win9xME_args_slurp
+if "x%~1" == "x" goto execute
+
+set CMD_LINE_ARGS=%*
+
+:execute
+@rem Setup the command line
+
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
+@rem Execute Gradle
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
+
+:end
+@rem End local scope for the variables with windows NT shell
+if "%ERRORLEVEL%"=="0" goto mainEnd
+
+:fail
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
+rem the _cmd.exe /c_ return code!
+if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
+exit /b 1
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega
diff --git a/packages/stack/example/android/keystores/BUCK b/packages/stack/example/android/keystores/BUCK
new file mode 100644
index 00000000..88e4c31b
--- /dev/null
+++ b/packages/stack/example/android/keystores/BUCK
@@ -0,0 +1,8 @@
+keystore(
+ name = "debug",
+ properties = "debug.keystore.properties",
+ store = "debug.keystore",
+ visibility = [
+ "PUBLIC",
+ ],
+)
diff --git a/packages/stack/example/android/keystores/debug.keystore.properties b/packages/stack/example/android/keystores/debug.keystore.properties
new file mode 100644
index 00000000..121bfb49
--- /dev/null
+++ b/packages/stack/example/android/keystores/debug.keystore.properties
@@ -0,0 +1,4 @@
+key.store=debug.keystore
+key.alias=androiddebugkey
+key.store.password=android
+key.alias.password=android
diff --git a/packages/stack/example/android/settings.gradle b/packages/stack/example/android/settings.gradle
new file mode 100644
index 00000000..d3b9db31
--- /dev/null
+++ b/packages/stack/example/android/settings.gradle
@@ -0,0 +1,13 @@
+apply from: '../node_modules/react-native-unimodules/gradle.groovy'
+include ':react-native-webview'
+project(':react-native-webview').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-webview/android')
+include ':react-native-reanimated'
+project(':react-native-reanimated').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-reanimated/android')
+includeUnimodulesProjects()
+
+include ':react-native-gesture-handler'
+project(':react-native-gesture-handler').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-gesture-handler/android')
+
+rootProject.name = 'StackExample'
+
+include ':app'
diff --git a/packages/stack/example/app.json b/packages/stack/example/app.json
index 4396aa91..a9a824fc 100644
--- a/packages/stack/example/app.json
+++ b/packages/stack/example/app.json
@@ -9,6 +9,9 @@
"packagerOpts": {
"config": "./metro.config.js",
"projectRoots": ""
- }
- }
-}
+ },
+ "entryPoint": "node_modules/expo/AppEntry.js"
+ },
+ "displayName": "React Navigation Stack Example",
+ "name": "StackExample"
+}
\ No newline at end of file
diff --git a/packages/stack/example/index.js b/packages/stack/example/index.js
new file mode 100644
index 00000000..6336fbd7
--- /dev/null
+++ b/packages/stack/example/index.js
@@ -0,0 +1,4 @@
+import { AppRegistry } from 'react-native';
+import App from './App';
+
+AppRegistry.registerComponent('StackExample', () => App);
diff --git a/packages/stack/example/ios/Podfile b/packages/stack/example/ios/Podfile
new file mode 100644
index 00000000..0fc78214
--- /dev/null
+++ b/packages/stack/example/ios/Podfile
@@ -0,0 +1,37 @@
+platform :ios, '10.0'
+
+require_relative '../node_modules/react-native-unimodules/cocoapods'
+
+target 'StackExample' do
+ # Pods for StackExample
+ pod 'React', :path => '../node_modules/react-native', :subspecs => [
+ 'Core',
+ 'CxxBridge',
+ 'DevSupport',
+ 'RCTActionSheet',
+ 'RCTAnimation',
+ 'RCTBlob',
+ 'RCTGeolocation',
+ 'RCTImage',
+ 'RCTLinkingIOS',
+ 'RCTNetwork',
+ 'RCTSettings',
+ 'RCTText',
+ 'RCTVibration',
+ 'RCTWebSocket',
+ ]
+
+ pod 'yoga', :path => '../node_modules/react-native/ReactCommon/yoga'
+
+ pod 'DoubleConversion', :podspec => '../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec'
+ pod 'glog', :podspec => '../node_modules/react-native/third-party-podspecs/glog.podspec'
+ pod 'Folly', :podspec => '../node_modules/react-native/third-party-podspecs/Folly.podspec'
+
+ use_unimodules!
+
+ pod 'RNGestureHandler', :podspec => '../node_modules/react-native-gesture-handler/RNGestureHandler.podspec'
+ pod 'RNReanimated', :podspec => '../node_modules/react-native-reanimated/RNReanimated.podspec'
+ pod 'RNScreens', :podspec => '../node_modules/react-native-screens/RNScreens.podspec'
+ pod 'react-native-webview', :path => '../node_modules/react-native-webview'
+ pod 'react-native-maps', :path => '../node_modules/react-native-maps'
+end
diff --git a/packages/stack/example/ios/Podfile.lock b/packages/stack/example/ios/Podfile.lock
new file mode 100644
index 00000000..a1385d63
--- /dev/null
+++ b/packages/stack/example/ios/Podfile.lock
@@ -0,0 +1,301 @@
+PODS:
+ - boost-for-react-native (1.63.0)
+ - DoubleConversion (1.1.6)
+ - EXAppLoaderProvider (6.0.0)
+ - EXBarCodeScanner (6.0.0):
+ - UMCore
+ - UMImageLoaderInterface
+ - EXConstants (6.0.0):
+ - UMConstantsInterface
+ - UMCore
+ - EXFileSystem (6.0.2):
+ - UMCore
+ - UMFileSystemInterface
+ - EXFont (6.0.1):
+ - UMCore
+ - UMFontInterface
+ - EXKeepAwake (6.0.0):
+ - UMCore
+ - EXLinearGradient (6.0.0):
+ - UMCore
+ - EXLocation (6.0.0):
+ - UMCore
+ - UMPermissionsInterface
+ - UMTaskManagerInterface
+ - EXPermissions (6.0.0):
+ - UMCore
+ - UMPermissionsInterface
+ - EXSQLite (6.0.0):
+ - UMCore
+ - UMFileSystemInterface
+ - EXWebBrowser (6.0.0):
+ - UMCore
+ - Folly (2018.10.22.00):
+ - boost-for-react-native
+ - DoubleConversion
+ - glog
+ - glog (0.3.5)
+ - React (0.59.10):
+ - React/Core (= 0.59.10)
+ - react-native-maps (0.24.2):
+ - React
+ - react-native-webview (5.12.1):
+ - React
+ - React/Core (0.59.10):
+ - yoga (= 0.59.10.React)
+ - React/CxxBridge (0.59.10):
+ - Folly (= 2018.10.22.00)
+ - React/Core
+ - React/cxxreact
+ - React/jsiexecutor
+ - React/cxxreact (0.59.10):
+ - boost-for-react-native (= 1.63.0)
+ - DoubleConversion
+ - Folly (= 2018.10.22.00)
+ - glog
+ - React/jsinspector
+ - React/DevSupport (0.59.10):
+ - React/Core
+ - React/RCTWebSocket
+ - React/fishhook (0.59.10)
+ - React/jsi (0.59.10):
+ - DoubleConversion
+ - Folly (= 2018.10.22.00)
+ - glog
+ - React/jsiexecutor (0.59.10):
+ - DoubleConversion
+ - Folly (= 2018.10.22.00)
+ - glog
+ - React/cxxreact
+ - React/jsi
+ - React/jsinspector (0.59.10)
+ - React/RCTActionSheet (0.59.10):
+ - React/Core
+ - React/RCTAnimation (0.59.10):
+ - React/Core
+ - React/RCTBlob (0.59.10):
+ - React/Core
+ - React/RCTGeolocation (0.59.10):
+ - React/Core
+ - React/RCTImage (0.59.10):
+ - React/Core
+ - React/RCTNetwork
+ - React/RCTLinkingIOS (0.59.10):
+ - React/Core
+ - React/RCTNetwork (0.59.10):
+ - React/Core
+ - React/RCTSettings (0.59.10):
+ - React/Core
+ - React/RCTText (0.59.10):
+ - React/Core
+ - React/RCTVibration (0.59.10):
+ - React/Core
+ - React/RCTWebSocket (0.59.10):
+ - React/Core
+ - React/fishhook
+ - React/RCTBlob
+ - RNGestureHandler (1.3.0):
+ - React
+ - RNReanimated (1.1.0):
+ - React
+ - RNScreens (1.0.0-alpha.23):
+ - React
+ - UMBarCodeScannerInterface (3.0.0)
+ - UMCameraInterface (3.0.0)
+ - UMConstantsInterface (3.0.0)
+ - UMCore (3.0.2)
+ - UMFaceDetectorInterface (3.0.0)
+ - UMFileSystemInterface (3.0.0)
+ - UMFontInterface (3.0.0)
+ - UMImageLoaderInterface (3.0.0)
+ - UMPermissionsInterface (3.0.0)
+ - UMReactNativeAdapter (3.0.0):
+ - React
+ - UMCore
+ - UMFontInterface
+ - UMSensorsInterface (3.0.0)
+ - UMTaskManagerInterface (3.0.0)
+ - yoga (0.59.10.React)
+
+DEPENDENCIES:
+ - DoubleConversion (from `../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec`)
+ - EXAppLoaderProvider (from `../node_modules/expo-app-loader-provider/ios`)
+ - EXBarCodeScanner (from `../node_modules/expo-barcode-scanner/ios`)
+ - EXConstants (from `../node_modules/expo-constants/ios`)
+ - EXFileSystem (from `../node_modules/expo-file-system/ios`)
+ - EXFont (from `../node_modules/expo-font/ios`)
+ - EXKeepAwake (from `../node_modules/expo-keep-awake/ios`)
+ - EXLinearGradient (from `../node_modules/expo-linear-gradient/ios`)
+ - EXLocation (from `../node_modules/expo-location/ios`)
+ - EXPermissions (from `../node_modules/expo-permissions/ios`)
+ - EXSQLite (from `../node_modules/expo-sqlite/ios`)
+ - EXWebBrowser (from `../node_modules/expo-web-browser/ios`)
+ - Folly (from `../node_modules/react-native/third-party-podspecs/Folly.podspec`)
+ - glog (from `../node_modules/react-native/third-party-podspecs/glog.podspec`)
+ - react-native-maps (from `../node_modules/react-native-maps`)
+ - react-native-webview (from `../node_modules/react-native-webview`)
+ - React/Core (from `../node_modules/react-native`)
+ - React/CxxBridge (from `../node_modules/react-native`)
+ - React/DevSupport (from `../node_modules/react-native`)
+ - React/RCTActionSheet (from `../node_modules/react-native`)
+ - React/RCTAnimation (from `../node_modules/react-native`)
+ - React/RCTBlob (from `../node_modules/react-native`)
+ - React/RCTGeolocation (from `../node_modules/react-native`)
+ - React/RCTImage (from `../node_modules/react-native`)
+ - React/RCTLinkingIOS (from `../node_modules/react-native`)
+ - React/RCTNetwork (from `../node_modules/react-native`)
+ - React/RCTSettings (from `../node_modules/react-native`)
+ - React/RCTText (from `../node_modules/react-native`)
+ - React/RCTVibration (from `../node_modules/react-native`)
+ - React/RCTWebSocket (from `../node_modules/react-native`)
+ - RNGestureHandler (from `../node_modules/react-native-gesture-handler/RNGestureHandler.podspec`)
+ - RNReanimated (from `../node_modules/react-native-reanimated/RNReanimated.podspec`)
+ - RNScreens (from `../node_modules/react-native-screens/RNScreens.podspec`)
+ - UMBarCodeScannerInterface (from `../node_modules/unimodules-barcode-scanner-interface/ios`)
+ - UMCameraInterface (from `../node_modules/unimodules-camera-interface/ios`)
+ - UMConstantsInterface (from `../node_modules/unimodules-constants-interface/ios`)
+ - "UMCore (from `../node_modules/@unimodules/core/ios`)"
+ - UMFaceDetectorInterface (from `../node_modules/unimodules-face-detector-interface/ios`)
+ - UMFileSystemInterface (from `../node_modules/unimodules-file-system-interface/ios`)
+ - UMFontInterface (from `../node_modules/unimodules-font-interface/ios`)
+ - UMImageLoaderInterface (from `../node_modules/unimodules-image-loader-interface/ios`)
+ - UMPermissionsInterface (from `../node_modules/unimodules-permissions-interface/ios`)
+ - "UMReactNativeAdapter (from `../node_modules/@unimodules/react-native-adapter/ios`)"
+ - UMSensorsInterface (from `../node_modules/unimodules-sensors-interface/ios`)
+ - UMTaskManagerInterface (from `../node_modules/unimodules-task-manager-interface/ios`)
+ - yoga (from `../node_modules/react-native/ReactCommon/yoga`)
+
+SPEC REPOS:
+ https://github.com/cocoapods/specs.git:
+ - boost-for-react-native
+
+EXTERNAL SOURCES:
+ DoubleConversion:
+ :podspec: "../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec"
+ EXAppLoaderProvider:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-app-loader-provider/ios"
+ EXBarCodeScanner:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-barcode-scanner/ios"
+ EXConstants:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-constants/ios"
+ EXFileSystem:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-file-system/ios"
+ EXFont:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-font/ios"
+ EXKeepAwake:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-keep-awake/ios"
+ EXLinearGradient:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-linear-gradient/ios"
+ EXLocation:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-location/ios"
+ EXPermissions:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-permissions/ios"
+ EXSQLite:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-sqlite/ios"
+ EXWebBrowser:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/expo-web-browser/ios"
+ Folly:
+ :podspec: "../node_modules/react-native/third-party-podspecs/Folly.podspec"
+ glog:
+ :podspec: "../node_modules/react-native/third-party-podspecs/glog.podspec"
+ React:
+ :path: "../node_modules/react-native"
+ react-native-maps:
+ :path: "../node_modules/react-native-maps"
+ react-native-webview:
+ :path: "../node_modules/react-native-webview"
+ RNGestureHandler:
+ :podspec: "../node_modules/react-native-gesture-handler/RNGestureHandler.podspec"
+ RNReanimated:
+ :podspec: "../node_modules/react-native-reanimated/RNReanimated.podspec"
+ RNScreens:
+ :podspec: "../node_modules/react-native-screens/RNScreens.podspec"
+ UMBarCodeScannerInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-barcode-scanner-interface/ios"
+ UMCameraInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-camera-interface/ios"
+ UMConstantsInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-constants-interface/ios"
+ UMCore:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/@unimodules/core/ios"
+ UMFaceDetectorInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-face-detector-interface/ios"
+ UMFileSystemInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-file-system-interface/ios"
+ UMFontInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-font-interface/ios"
+ UMImageLoaderInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-image-loader-interface/ios"
+ UMPermissionsInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-permissions-interface/ios"
+ UMReactNativeAdapter:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/@unimodules/react-native-adapter/ios"
+ UMSensorsInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-sensors-interface/ios"
+ UMTaskManagerInterface:
+ :path: !ruby/object:Pathname
+ path: "../node_modules/unimodules-task-manager-interface/ios"
+ yoga:
+ :path: "../node_modules/react-native/ReactCommon/yoga"
+
+SPEC CHECKSUMS:
+ boost-for-react-native: 39c7adb57c4e60d6c5479dd8623128eb5b3f0f2c
+ DoubleConversion: bb338842f62ab1d708ceb63ec3d999f0f3d98ecd
+ EXAppLoaderProvider: 7a8185228d8ba9e689a0e2d6d957fe9bdd49c8a0
+ EXBarCodeScanner: 3b36378bfc891b6fd3518e244784eb8d3ab00653
+ EXConstants: 5d81e84ca71b9a552529889cc798b4a04e9e22b3
+ EXFileSystem: 091907902fcec9f9182b656fdead41a82f30986a
+ EXFont: c862449210fc86aa11d24a202cb22c71a0d39609
+ EXKeepAwake: e7cb6516675052b12a7d23291e33078b4239653a
+ EXLinearGradient: 40781b77e58f844c8dc4ad310dc9755b4d3792a7
+ EXLocation: 4eb76115832f08b1e78003b335c210e18fa60424
+ EXPermissions: 99e52dc3e5f8e55153f1958004f6df2a30a1f2f5
+ EXSQLite: 8dab6a5ab1b78be7925073d6071eb22095d4dda6
+ EXWebBrowser: def838b95aa9d396f9ce71ace4e614ee16e7ee30
+ Folly: de497beb10f102453a1afa9edbf8cf8a251890de
+ glog: aefd1eb5dda2ab95ba0938556f34b98e2da3a60d
+ React: 36d0768f9e93be2473b37e7fa64f92c1d5341eef
+ react-native-maps: 0316ed017dbb64b33b227751fa810e2454fcfa39
+ react-native-webview: 5036ed4a973ad1deeeff118262d2df7b60b3419d
+ RNGestureHandler: 5329a942fce3d41c68b84c2c2276ce06a696d8b0
+ RNReanimated: 7a52c90473b5e81c13408d40d797b98387eaddde
+ RNScreens: f28b48b8345f2f5f39ed6195518291515032a788
+ UMBarCodeScannerInterface: 84ea2d6b58ff0dc27ef9b68bab71286be18ee020
+ UMCameraInterface: 26b26005d1756a0d5f4f04f1e168e39ea9154535
+ UMConstantsInterface: 038bacb19de12b6fd328c589122c8dc977cccf61
+ UMCore: 733094f43f7244c60ce1f0592d00013ed68fa52c
+ UMFaceDetectorInterface: c9c3ae4cb045421283667a1698c2f31331f55e3f
+ UMFileSystemInterface: e9adc71027017de38eaf7d05fa58b2848ecb3797
+ UMFontInterface: f0c5846977ee8a93d7cfa8ae7e666772c727d195
+ UMImageLoaderInterface: 36e54e570acc4d720856f03ceebc441f73ea472c
+ UMPermissionsInterface: 938d010c74c43fcefc9bb990633a7c5a1631267e
+ UMReactNativeAdapter: 131ea2b944ade8035f0b54c6570c405f6000548d
+ UMSensorsInterface: 0ed023ce9b96f2ca6fada7bda05b7760da60b293
+ UMTaskManagerInterface: 8664abd37a00715727e60df9ecd65e42ba47b548
+ yoga: 684513b14b03201579ba3cee20218c9d1298b0cc
+
+PODFILE CHECKSUM: ba5af81bcabf9feca0e74ef3f931f99ebe73e278
+
+COCOAPODS: 1.7.5
diff --git a/packages/stack/example/ios/StackExample.xcodeproj/project.pbxproj b/packages/stack/example/ios/StackExample.xcodeproj/project.pbxproj
new file mode 100644
index 00000000..afc8c875
--- /dev/null
+++ b/packages/stack/example/ios/StackExample.xcodeproj/project.pbxproj
@@ -0,0 +1,423 @@
+// !$*UTF8*$!
+{
+ archiveVersion = 1;
+ classes = {
+ };
+ objectVersion = 46;
+ objects = {
+
+/* Begin PBXBuildFile section */
+ 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
+ 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; };
+ 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
+ 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
+ D4CE803618A24220D3A56DF3 /* libPods-StackExample.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3667441605674F798E1D6763 /* libPods-StackExample.a */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXFileReference section */
+ 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; };
+ 13B07F961A680F5B00A75B9A /* StackExample.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = StackExample.app; sourceTree = BUILT_PRODUCTS_DIR; };
+ 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = StackExample/AppDelegate.h; sourceTree = ""; };
+ 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = StackExample/AppDelegate.m; sourceTree = ""; };
+ 13B07FB21A68108700A75B9A /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; };
+ 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = StackExample/Images.xcassets; sourceTree = ""; };
+ 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = StackExample/Info.plist; sourceTree = ""; };
+ 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = StackExample/main.m; sourceTree = ""; };
+ 2D16E6891FA4F8E400B85C8A /* libReact.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; path = libReact.a; sourceTree = BUILT_PRODUCTS_DIR; };
+ 3667441605674F798E1D6763 /* libPods-StackExample.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-StackExample.a"; sourceTree = BUILT_PRODUCTS_DIR; };
+ 8942CD5730A321791ACCEECD /* Pods-StackExample.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-StackExample.debug.xcconfig"; path = "Target Support Files/Pods-StackExample/Pods-StackExample.debug.xcconfig"; sourceTree = ""; };
+ D616CF11850EEB200F584BDB /* Pods-StackExample.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-StackExample.release.xcconfig"; path = "Target Support Files/Pods-StackExample/Pods-StackExample.release.xcconfig"; sourceTree = ""; };
+ ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
+ ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+ 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ D4CE803618A24220D3A56DF3 /* libPods-StackExample.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+ 13B07FAE1A68108700A75B9A /* StackExample */ = {
+ isa = PBXGroup;
+ children = (
+ 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
+ 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
+ 13B07FB01A68108700A75B9A /* AppDelegate.m */,
+ 13B07FB51A68108700A75B9A /* Images.xcassets */,
+ 13B07FB61A68108700A75B9A /* Info.plist */,
+ 13B07FB11A68108700A75B9A /* LaunchScreen.xib */,
+ 13B07FB71A68108700A75B9A /* main.m */,
+ );
+ name = StackExample;
+ sourceTree = "";
+ };
+ 2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
+ isa = PBXGroup;
+ children = (
+ ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
+ ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
+ 2D16E6891FA4F8E400B85C8A /* libReact.a */,
+ 3667441605674F798E1D6763 /* libPods-StackExample.a */,
+ );
+ name = Frameworks;
+ sourceTree = "";
+ };
+ 4DACE704B62B6FF43F66D685 /* Pods */ = {
+ isa = PBXGroup;
+ children = (
+ 8942CD5730A321791ACCEECD /* Pods-StackExample.debug.xcconfig */,
+ D616CF11850EEB200F584BDB /* Pods-StackExample.release.xcconfig */,
+ );
+ name = Pods;
+ path = Pods;
+ sourceTree = "";
+ };
+ 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
+ isa = PBXGroup;
+ children = (
+ );
+ name = Libraries;
+ sourceTree = "";
+ };
+ 83CBB9F61A601CBA00E9B192 = {
+ isa = PBXGroup;
+ children = (
+ 13B07FAE1A68108700A75B9A /* StackExample */,
+ 832341AE1AAA6A7D00B99B32 /* Libraries */,
+ 83CBBA001A601CBA00E9B192 /* Products */,
+ 2D16E6871FA4F8E400B85C8A /* Frameworks */,
+ 4DACE704B62B6FF43F66D685 /* Pods */,
+ );
+ indentWidth = 2;
+ sourceTree = "";
+ tabWidth = 2;
+ usesTabs = 0;
+ };
+ 83CBBA001A601CBA00E9B192 /* Products */ = {
+ isa = PBXGroup;
+ children = (
+ 13B07F961A680F5B00A75B9A /* StackExample.app */,
+ );
+ name = Products;
+ sourceTree = "";
+ };
+/* End PBXGroup section */
+
+/* Begin PBXNativeTarget section */
+ 13B07F861A680F5B00A75B9A /* StackExample */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "StackExample" */;
+ buildPhases = (
+ DA6A79CEC4D642535B5AAD2D /* [CP] Check Pods Manifest.lock */,
+ FD4C38642228810C00325AF5 /* Start Packager */,
+ 13B07F871A680F5B00A75B9A /* Sources */,
+ 13B07F8C1A680F5B00A75B9A /* Frameworks */,
+ 13B07F8E1A680F5B00A75B9A /* Resources */,
+ 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = StackExample;
+ productName = "Hello World";
+ productReference = 13B07F961A680F5B00A75B9A /* StackExample.app */;
+ productType = "com.apple.product-type.application";
+ };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+ 83CBB9F71A601CBA00E9B192 /* Project object */ = {
+ isa = PBXProject;
+ attributes = {
+ LastUpgradeCheck = 0940;
+ ORGANIZATIONNAME = Facebook;
+ TargetAttributes = {
+ 00E356ED1AD99517003FC87E = {
+ CreatedOnToolsVersion = 6.2;
+ TestTargetID = 13B07F861A680F5B00A75B9A;
+ };
+ };
+ };
+ buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "StackExample" */;
+ compatibilityVersion = "Xcode 3.2";
+ developmentRegion = English;
+ hasScannedForEncodings = 0;
+ knownRegions = (
+ en,
+ Base,
+ );
+ mainGroup = 83CBB9F61A601CBA00E9B192;
+ productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
+ projectDirPath = "";
+ projectRoot = "";
+ targets = (
+ 13B07F861A680F5B00A75B9A /* StackExample */,
+ );
+ };
+/* End PBXProject section */
+
+/* Begin PBXResourcesBuildPhase section */
+ 13B07F8E1A680F5B00A75B9A /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
+ 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXResourcesBuildPhase section */
+
+/* Begin PBXShellScriptBuildPhase section */
+ 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputPaths = (
+ );
+ name = "Bundle React Native code and images";
+ outputPaths = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
+ };
+ DA6A79CEC4D642535B5AAD2D /* [CP] Check Pods Manifest.lock */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputFileListPaths = (
+ );
+ inputPaths = (
+ "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
+ "${PODS_ROOT}/Manifest.lock",
+ );
+ name = "[CP] Check Pods Manifest.lock";
+ outputFileListPaths = (
+ );
+ outputPaths = (
+ "$(DERIVED_FILE_DIR)/Pods-StackExample-checkManifestLockResult.txt",
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
+ showEnvVarsInLog = 0;
+ };
+ FD4C38642228810C00325AF5 /* Start Packager */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputFileListPaths = (
+ );
+ inputPaths = (
+ );
+ name = "Start Packager";
+ outputFileListPaths = (
+ );
+ outputPaths = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
+ showEnvVarsInLog = 0;
+ };
+/* End PBXShellScriptBuildPhase section */
+
+/* Begin PBXSourcesBuildPhase section */
+ 13B07F871A680F5B00A75B9A /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
+ 13B07FC11A68108700A75B9A /* main.m in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin PBXVariantGroup section */
+ 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = {
+ isa = PBXVariantGroup;
+ children = (
+ 13B07FB21A68108700A75B9A /* Base */,
+ );
+ name = LaunchScreen.xib;
+ path = StackExample;
+ sourceTree = "";
+ };
+/* End PBXVariantGroup section */
+
+/* Begin XCBuildConfiguration section */
+ 13B07F941A680F5B00A75B9A /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 8942CD5730A321791ACCEECD /* Pods-StackExample.debug.xcconfig */;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CURRENT_PROJECT_VERSION = 1;
+ DEAD_CODE_STRIPPING = NO;
+ INFOPLIST_FILE = StackExample/Info.plist;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ OTHER_LDFLAGS = (
+ "$(inherited)",
+ "-ObjC",
+ "-lc++",
+ );
+ PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
+ PRODUCT_NAME = StackExample;
+ VERSIONING_SYSTEM = "apple-generic";
+ };
+ name = Debug;
+ };
+ 13B07F951A680F5B00A75B9A /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = D616CF11850EEB200F584BDB /* Pods-StackExample.release.xcconfig */;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CURRENT_PROJECT_VERSION = 1;
+ INFOPLIST_FILE = StackExample/Info.plist;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ OTHER_LDFLAGS = (
+ "$(inherited)",
+ "-ObjC",
+ "-lc++",
+ );
+ PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
+ PRODUCT_NAME = StackExample;
+ VERSIONING_SYSTEM = "apple-generic";
+ };
+ name = Release;
+ };
+ 83CBBA201A601CBA00E9B192 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_COMMA = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INFINITE_RECURSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
+ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
+ CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
+ CLANG_WARN_STRICT_PROTOTYPES = YES;
+ CLANG_WARN_SUSPICIOUS_MOVE = YES;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = NO;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ ENABLE_TESTABILITY = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_DYNAMIC_NO_PIC = NO;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_OPTIMIZATION_LEVEL = 0;
+ GCC_PREPROCESSOR_DEFINITIONS = (
+ "DEBUG=1",
+ "$(inherited)",
+ );
+ GCC_SYMBOLS_PRIVATE_EXTERN = NO;
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 9.0;
+ MTL_ENABLE_DEBUG_INFO = YES;
+ ONLY_ACTIVE_ARCH = YES;
+ SDKROOT = iphoneos;
+ };
+ name = Debug;
+ };
+ 83CBBA211A601CBA00E9B192 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_COMMA = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INFINITE_RECURSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
+ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
+ CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
+ CLANG_WARN_STRICT_PROTOTYPES = YES;
+ CLANG_WARN_SUSPICIOUS_MOVE = YES;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = YES;
+ ENABLE_NS_ASSERTIONS = NO;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 9.0;
+ MTL_ENABLE_DEBUG_INFO = NO;
+ SDKROOT = iphoneos;
+ VALIDATE_PRODUCT = YES;
+ };
+ name = Release;
+ };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+ 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "StackExample" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 13B07F941A680F5B00A75B9A /* Debug */,
+ 13B07F951A680F5B00A75B9A /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "StackExample" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 83CBBA201A601CBA00E9B192 /* Debug */,
+ 83CBBA211A601CBA00E9B192 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+/* End XCConfigurationList section */
+ };
+ rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
+}
diff --git a/packages/stack/example/ios/StackExample.xcodeproj/xcshareddata/xcschemes/StackExample.xcscheme b/packages/stack/example/ios/StackExample.xcodeproj/xcshareddata/xcschemes/StackExample.xcscheme
new file mode 100644
index 00000000..fa7ae1c7
--- /dev/null
+++ b/packages/stack/example/ios/StackExample.xcodeproj/xcshareddata/xcschemes/StackExample.xcscheme
@@ -0,0 +1,129 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/packages/stack/example/ios/StackExample.xcworkspace/contents.xcworkspacedata b/packages/stack/example/ios/StackExample.xcworkspace/contents.xcworkspacedata
new file mode 100644
index 00000000..aa843897
--- /dev/null
+++ b/packages/stack/example/ios/StackExample.xcworkspace/contents.xcworkspacedata
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
diff --git a/packages/stack/example/ios/StackExample.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/packages/stack/example/ios/StackExample.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
new file mode 100644
index 00000000..18d98100
--- /dev/null
+++ b/packages/stack/example/ios/StackExample.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
@@ -0,0 +1,8 @@
+
+
+
+
+ IDEDidComputeMac32BitWarning
+
+
+
diff --git a/packages/stack/example/ios/StackExample/AppDelegate.h b/packages/stack/example/ios/StackExample/AppDelegate.h
new file mode 100644
index 00000000..78fbb4d6
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/AppDelegate.h
@@ -0,0 +1,18 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ */
+
+#import
+#import
+#import
+#import
+
+@interface AppDelegate : UMAppDelegateWrapper
+
+@property (nonatomic, strong) UMModuleRegistryAdapter *moduleRegistryAdapter;
+@property (nonatomic, strong) UIWindow *window;
+
+@end
diff --git a/packages/stack/example/ios/StackExample/AppDelegate.m b/packages/stack/example/ios/StackExample/AppDelegate.m
new file mode 100644
index 00000000..1f1cba4f
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/AppDelegate.m
@@ -0,0 +1,55 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ */
+
+#import "AppDelegate.h"
+
+#import
+#import
+
+#import
+#import
+#import
+
+@implementation AppDelegate
+
+@synthesize window = _window;
+
+- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
+{
+ self.moduleRegistryAdapter = [[UMModuleRegistryAdapter alloc] initWithModuleRegistryProvider:[[UMModuleRegistryProvider alloc] init]];
+ RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions];
+ RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge moduleName:@"StackExample" initialProperties:nil];
+ rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
+
+ self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
+ UIViewController *rootViewController = [UIViewController new];
+ rootViewController.view = rootView;
+ self.window.rootViewController = rootViewController;
+ [self.window makeKeyAndVisible];
+
+ [super application:application didFinishLaunchingWithOptions:launchOptions];
+
+ return YES;
+}
+
+- (NSArray> *)extraModulesForBridge:(RCTBridge *)bridge
+{
+ NSArray> *extraModules = [_moduleRegistryAdapter extraModulesForBridge:bridge];
+ // You can inject any extra modules that you would like here, more information at:
+ // https://facebook.github.io/react-native/docs/native-modules-ios.html#dependency-injection
+ return extraModules;
+}
+
+- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge {
+#ifdef DEBUG
+ return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
+#else
+ return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
+#endif
+}
+
+@end
diff --git a/packages/stack/example/ios/StackExample/Base.lproj/LaunchScreen.xib b/packages/stack/example/ios/StackExample/Base.lproj/LaunchScreen.xib
new file mode 100644
index 00000000..c16ccc1c
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/Base.lproj/LaunchScreen.xib
@@ -0,0 +1,42 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/packages/stack/example/ios/StackExample/Images.xcassets/AppIcon.appiconset/Contents.json b/packages/stack/example/ios/StackExample/Images.xcassets/AppIcon.appiconset/Contents.json
new file mode 100644
index 00000000..118c98f7
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/Images.xcassets/AppIcon.appiconset/Contents.json
@@ -0,0 +1,38 @@
+{
+ "images" : [
+ {
+ "idiom" : "iphone",
+ "size" : "29x29",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "iphone",
+ "size" : "29x29",
+ "scale" : "3x"
+ },
+ {
+ "idiom" : "iphone",
+ "size" : "40x40",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "iphone",
+ "size" : "40x40",
+ "scale" : "3x"
+ },
+ {
+ "idiom" : "iphone",
+ "size" : "60x60",
+ "scale" : "2x"
+ },
+ {
+ "idiom" : "iphone",
+ "size" : "60x60",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
\ No newline at end of file
diff --git a/packages/stack/example/ios/StackExample/Images.xcassets/Contents.json b/packages/stack/example/ios/StackExample/Images.xcassets/Contents.json
new file mode 100644
index 00000000..2d92bd53
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/Images.xcassets/Contents.json
@@ -0,0 +1,6 @@
+{
+ "info" : {
+ "version" : 1,
+ "author" : "xcode"
+ }
+}
diff --git a/packages/stack/example/ios/StackExample/Info.plist b/packages/stack/example/ios/StackExample/Info.plist
new file mode 100644
index 00000000..c813641c
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/Info.plist
@@ -0,0 +1,82 @@
+
+
+
+
+ CFBundleDevelopmentRegion
+ en
+ CFBundleDisplayName
+ React Navigation Stack Example
+ CFBundleExecutable
+ $(EXECUTABLE_NAME)
+ CFBundleIdentifier
+ $(PRODUCT_BUNDLE_IDENTIFIER)
+ CFBundleInfoDictionaryVersion
+ 6.0
+ CFBundleName
+ $(PRODUCT_NAME)
+ CFBundlePackageType
+ APPL
+ CFBundleShortVersionString
+ 1.0
+ CFBundleSignature
+ ????
+ CFBundleVersion
+ 1
+ LSRequiresIPhoneOS
+
+ NSLocationWhenInUseUsageDescription
+
+ UILaunchStoryboardName
+ LaunchScreen
+ UIRequiredDeviceCapabilities
+
+ armv7
+
+ UISupportedInterfaceOrientations
+
+ UIInterfaceOrientationPortrait
+ UIInterfaceOrientationLandscapeLeft
+ UIInterfaceOrientationLandscapeRight
+
+ UIViewControllerBasedStatusBarAppearance
+
+ NSLocationWhenInUseUsageDescription
+
+ NSAppTransportSecurity
+
+
+ NSAllowsArbitraryLoads
+
+ NSExceptionDomains
+
+ localhost
+
+ NSExceptionAllowsInsecureHTTPLoads
+
+
+
+
+ NSCalendarsUsageDescription
+ Allow React Navigation Stack Example to access your calendar
+ NSCameraUsageDescription
+ Allow React Navigation Stack Example to use the camera
+ NSContactsUsageDescription
+ Allow React Navigation Stack Example experiences to access your contacts
+ NSLocationAlwaysAndWhenInUseUsageDescription
+ Allow React Navigation Stack Example to use your location
+ NSLocationAlwaysUsageDescription
+ Allow React Navigation Stack Example to use your location
+ NSLocationWhenInUseUsageDescription
+ Allow React Navigation Stack Example to use your location
+ NSMicrophoneUsageDescription
+ Allow React Navigation Stack Example to access your microphone
+ NSMotionUsageDescription
+ Allow React Navigation Stack Example to access your device's accelerometer
+ NSPhotoLibraryAddUsageDescription
+ Give React Navigation Stack Example periences permission to save photos
+ NSPhotoLibraryUsageDescription
+ Give React Navigation Stack Example periences permission to access your photos
+ NSRemindersUsageDescription
+ Allow React Navigation Stack Example to access your reminders
+
+
diff --git a/packages/stack/example/ios/StackExample/main.m b/packages/stack/example/ios/StackExample/main.m
new file mode 100644
index 00000000..c316cf81
--- /dev/null
+++ b/packages/stack/example/ios/StackExample/main.m
@@ -0,0 +1,16 @@
+/**
+ * Copyright (c) Facebook, Inc. and its affiliates.
+ *
+ * This source code is licensed under the MIT license found in the
+ * LICENSE file in the root directory of this source tree.
+ */
+
+#import
+
+#import "AppDelegate.h"
+
+int main(int argc, char * argv[]) {
+ @autoreleasepool {
+ return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
+ }
+}
diff --git a/packages/stack/example/package.json b/packages/stack/example/package.json
index 27d151af..67462705 100644
--- a/packages/stack/example/package.json
+++ b/packages/stack/example/package.json
@@ -2,11 +2,10 @@
"name": "stackexample",
"version": "0.0.1",
"private": true,
- "main": "node_modules/expo/AppEntry.js",
"scripts": {
- "start": "expo start",
- "android": "expo start --android",
- "ios": "expo start --ios"
+ "start": "react-native start",
+ "android": "react-native run-android",
+ "ios": "react-native run-ios"
},
"dependencies": {
"@react-native-community/masked-view": "^0.1.1",
@@ -14,13 +13,19 @@
"@react-navigation/native": "^3.4.1",
"expo": "^34.0.0",
"expo-asset": "^6.0.0",
+ "expo-barcode-scanner": "~6.0.0",
"expo-constants": "~6.0.0",
"hoist-non-react-statics": "^3.3.0",
"react": "16.8.3",
- "react-native": "https://github.com/expo/react-native/archive/sdk-34.0.0.tar.gz",
+ "react-dom": "^16.8.6",
+ "react-native": "0.59.10",
"react-native-gesture-handler": "~1.3.0",
+ "react-native-maps": "~0.24.0",
"react-native-paper": "^2.15.2",
"react-native-reanimated": "~1.1.0",
+ "react-native-unimodules": "~0.5.2",
+ "react-native-web": "^0.11.4",
+ "react-native-webview": "~5.12.0",
"react-navigation-drawer": "^2.0.0",
"react-navigation-tabs": "2.2.0"
},
diff --git a/packages/stack/example/src/GestureInteraction.js b/packages/stack/example/src/GestureInteraction.js
index c98ac1b6..8ccac302 100644
--- a/packages/stack/example/src/GestureInteraction.js
+++ b/packages/stack/example/src/GestureInteraction.js
@@ -3,10 +3,10 @@ import {
ActivityIndicator,
Button,
InteractionManager,
- WebView,
View,
} from 'react-native';
-import { MapView } from 'expo';
+import { WebView } from 'react-native-webview';
+import MapView from 'react-native-maps';
import {
createStackNavigator,
StackGestureContext,
diff --git a/packages/stack/example/src/LifecycleInteraction.js b/packages/stack/example/src/LifecycleInteraction.js
index 580ae769..3dd83fbc 100644
--- a/packages/stack/example/src/LifecycleInteraction.js
+++ b/packages/stack/example/src/LifecycleInteraction.js
@@ -1,6 +1,6 @@
import * as React from 'react';
import { Button, Text, View, StyleSheet } from 'react-native';
-import { BarCodeScanner } from 'expo';
+import { BarCodeScanner } from 'expo-barcode-scanner';
import { withNavigationFocus } from '@react-navigation/core';
import { createStackNavigator } from 'react-navigation-stack';
diff --git a/packages/stack/example/yarn.lock b/packages/stack/example/yarn.lock
index ca7134c3..0f644361 100644
--- a/packages/stack/example/yarn.lock
+++ b/packages/stack/example/yarn.lock
@@ -955,7 +955,7 @@
resolved "https://registry.yarnpkg.com/@types/websql/-/websql-0.0.27.tgz#621a666a7f02018e7cbb4abab956a25736c27d71"
integrity sha1-Yhpman8CAY58u0q6uVaiVzbCfXE=
-"@unimodules/core@~3.0.0":
+"@unimodules/core@~3.0.0", "@unimodules/core@~3.0.2":
version "3.0.2"
resolved "https://registry.yarnpkg.com/@unimodules/core/-/core-3.0.2.tgz#a2b143fb1e743809ba17c60ae1848f82b8637901"
integrity sha512-EMZjVp+yrtoPKpDBPvj4+hyDWALl7gvpWeUsDz2Nb9MMBPLnhag1uNk3KC98StJdnjbSXKSdKrCMMidOXnyKcg==
@@ -1132,6 +1132,11 @@ array-filter@~0.0.0:
resolved "https://registry.yarnpkg.com/array-filter/-/array-filter-0.0.1.tgz#7da8cf2e26628ed732803581fd21f67cacd2eeec"
integrity sha1-fajPLiZijtcygDWB/SH2fKzS7uw=
+array-find-index@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/array-find-index/-/array-find-index-1.0.2.tgz#df010aa1287e164bbda6f9723b0a96a1ec4187a1"
+ integrity sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=
+
array-map@~0.0.0:
version "0.0.0"
resolved "https://registry.yarnpkg.com/array-map/-/array-map-0.0.0.tgz#88a2bab73d1cf7bcd5c1b118a003f66f665fa662"
@@ -1464,7 +1469,7 @@ chalk@^1.1.1:
strip-ansi "^3.0.0"
supports-color "^2.0.0"
-chalk@^2.0.0, chalk@^2.4.1:
+chalk@^2.0.0, chalk@^2.4.1, chalk@^2.4.2:
version "2.4.2"
resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424"
integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==
@@ -1724,7 +1729,7 @@ cosmiconfig@^5.0.5:
js-yaml "^3.13.1"
parse-json "^4.0.0"
-create-react-class@^15.6.3:
+create-react-class@^15.6.2, create-react-class@^15.6.3:
version "15.6.3"
resolved "https://registry.yarnpkg.com/create-react-class/-/create-react-class-15.6.3.tgz#2d73237fb3f970ae6ebe011a9e66f46dbca80036"
integrity sha512-M+/3Q6E6DLO6Yx3OwrWjwHBnvfXXYA7W+dFjt/ZDBemHO1DDZhsalX/NUtnTYclN6GfnBDRh4qRHjcDHmlJBJg==
@@ -1761,6 +1766,14 @@ cross-spawn@^6.0.0, cross-spawn@^6.0.5:
shebang-command "^1.2.0"
which "^1.2.9"
+css-in-js-utils@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/css-in-js-utils/-/css-in-js-utils-2.0.1.tgz#3b472b398787291b47cfe3e44fecfdd9e914ba99"
+ integrity sha512-PJF0SpJT+WdbVVt0AOYp9C8GnuruRlL/UFW7932nLWmFLQTaWEzTBQEx7/hn4BuV+WON75iAViSUJLiU3PKbpA==
+ dependencies:
+ hyphenate-style-name "^1.0.2"
+ isobject "^3.0.1"
+
debounce@^1.2.0:
version "1.2.0"
resolved "https://registry.yarnpkg.com/debounce/-/debounce-1.2.0.tgz#44a540abc0ea9943018dc0eaa95cce87f65cd131"
@@ -1797,6 +1810,13 @@ decode-uri-component@^0.2.0:
resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545"
integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=
+deep-assign@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/deep-assign/-/deep-assign-3.0.0.tgz#c8e4c4d401cba25550a2f0f486a2e75bc5f219a2"
+ integrity sha512-YX2i9XjJ7h5q/aQ/IM9PEwEnDqETAIYbggmdDB3HLTlSgo1CxPsj6pvhPG68rq6SVE0+p+6Ywsm5fTYNrYtBWw==
+ dependencies:
+ is-obj "^1.0.0"
+
deep-extend@^0.6.0:
version "0.6.0"
resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac"
@@ -1913,7 +1933,7 @@ escape-html@~1.0.3:
resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988"
integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=
-escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5:
+escape-string-regexp@1.0.5, escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5:
version "1.0.5"
resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4"
integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=
@@ -2017,6 +2037,14 @@ expo-asset@^6.0.0, expo-asset@~6.0.0:
path-browserify "^1.0.0"
url-parse "^1.4.4"
+expo-barcode-scanner@~6.0.0:
+ version "6.0.0"
+ resolved "https://registry.yarnpkg.com/expo-barcode-scanner/-/expo-barcode-scanner-6.0.0.tgz#ea9c907dbb403247bfe9fa4da8f50b0d05ef6e2a"
+ integrity sha512-BEAEqus5hBpcippY+/xWIM/UIWHMyAzZTwISkKovVDtiJ47bcz6Bq9nrLwFv7vjTG68Sww2e7/K8jdCc9nndyQ==
+ dependencies:
+ lodash "^4.6.0"
+ prop-types "^15.6.0"
+
expo-constants@~6.0.0:
version "6.0.0"
resolved "https://registry.yarnpkg.com/expo-constants/-/expo-constants-6.0.0.tgz#ff4598985ba006e24949be3f05be7429e5bedacf"
@@ -2024,7 +2052,7 @@ expo-constants@~6.0.0:
dependencies:
ua-parser-js "^0.7.19"
-expo-file-system@~6.0.0:
+expo-file-system@~6.0.0, expo-file-system@~6.0.1:
version "6.0.2"
resolved "https://registry.yarnpkg.com/expo-file-system/-/expo-file-system-6.0.2.tgz#e65f30eb6a7213e07933df9688116eaf4e25bbf8"
integrity sha512-s+6oQpLhcT7MQp7fcoj1E+zttMr0WX6c0FrddzqB4dUfhIggV+nb35nQMASIiTHAj8VPUanTFliY5rETHRMHRA==
@@ -2598,6 +2626,11 @@ http-errors@~1.7.2:
statuses ">= 1.5.0 < 2"
toidentifier "1.0.0"
+hyphenate-style-name@^1.0.2:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/hyphenate-style-name/-/hyphenate-style-name-1.0.3.tgz#097bb7fa0b8f1a9cf0bd5c734cf95899981a9b48"
+ integrity sha512-EcuixamT82oplpoJ2XU4pDtKGWQ7b00CD9f1ug9IaQ3p1bkHMiKCZ9ut9QDI6qsa6cpUuB+A/I+zLtdNK4n2DQ==
+
iconv-lite@^0.4.17, iconv-lite@^0.4.4, iconv-lite@~0.4.13:
version "0.4.24"
resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b"
@@ -2653,6 +2686,13 @@ ini@~1.3.0:
resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.5.tgz#eee25f56db1c9ec6085e0c22778083f596abf927"
integrity sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==
+inline-style-prefixer@^5.0.3:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/inline-style-prefixer/-/inline-style-prefixer-5.1.0.tgz#cb63195f9456dcda25cf59743e45c4d9815b0811"
+ integrity sha512-giteQHPMrApQOSjNSjteO5ZGSGMRf9gas14fRy2lg2buSc1nRnj6o6xuNds5cMTKrkncyrTu3gJn/yflFMVdmg==
+ dependencies:
+ css-in-js-utils "^2.0.0"
+
inquirer@^3.0.6:
version "3.3.0"
resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-3.3.0.tgz#9dd2f2ad765dcab1ff0443b491442a20ba227dc9"
@@ -2673,7 +2713,7 @@ inquirer@^3.0.6:
strip-ansi "^4.0.0"
through "^2.3.6"
-invariant@^2.2.2, invariant@^2.2.4:
+invariant@2.2.4, invariant@^2.2.2, invariant@^2.2.4:
version "2.2.4"
resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6"
integrity sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==
@@ -2844,6 +2884,11 @@ is-number@^4.0.0:
resolved "https://registry.yarnpkg.com/is-number/-/is-number-4.0.0.tgz#0026e37f5454d73e356dfe6564699867c6a7f0ff"
integrity sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==
+is-obj@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-1.0.1.tgz#3e4729ac1f5fde025cd7d83a896dab9f4f67db0f"
+ integrity sha1-PkcprB9f3gJc19g6iW2rn09n2w8=
+
is-plain-object@^2.0.1, is-plain-object@^2.0.3, is-plain-object@^2.0.4:
version "2.0.4"
resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677"
@@ -3729,6 +3774,11 @@ nopt@^4.0.1:
abbrev "1"
osenv "^0.1.4"
+normalize-css-color@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/normalize-css-color/-/normalize-css-color-1.0.2.tgz#02991e97cccec6623fe573afbbf0de6a1f3e9f8d"
+ integrity sha1-Apkel8zOxmI/5XOvu/Deah8+n40=
+
normalize-package-data@^2.3.2:
version "2.5.0"
resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8"
@@ -4223,6 +4273,16 @@ react-devtools-core@^3.6.0:
shell-quote "^1.6.1"
ws "^3.3.1"
+react-dom@^16.8.6:
+ version "16.9.0"
+ resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-16.9.0.tgz#5e65527a5e26f22ae3701131bcccaee9fb0d3962"
+ integrity sha512-YFT2rxO9hM70ewk9jq0y6sQk8cL02xm4+IzYBz75CQGlClQQ1Bxq0nhHF6OtSbit+AIahujJgb/CPRibFkMNJQ==
+ dependencies:
+ loose-envify "^1.1.0"
+ object-assign "^4.1.1"
+ prop-types "^15.6.2"
+ scheduler "^0.15.0"
+
react-is@^16.7.0, react-is@^16.8.1, react-is@^16.8.6:
version "16.8.6"
resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.8.6.tgz#5bbc1e2d29141c9fbdfed456343fe2bc430a6a16"
@@ -4247,6 +4307,11 @@ react-native-gesture-handler@~1.3.0:
invariant "^2.2.2"
prop-types "^15.5.10"
+react-native-maps@~0.24.0:
+ version "0.24.2"
+ resolved "https://registry.yarnpkg.com/react-native-maps/-/react-native-maps-0.24.2.tgz#19974f967cb0c2e24dab74ca879118e0932571b2"
+ integrity sha512-1iNIDikp2dkCG+8DguaEviYZiMSYyvwqYT7pO2YTZvuFRDSc/P9jXMhTUnSh4wNDlEeQ47OJ09l0pwWVBZ7wxg==
+
react-native-paper@^2.15.2:
version "2.16.0"
resolved "https://registry.yarnpkg.com/react-native-paper/-/react-native-paper-2.16.0.tgz#5a9edd5615bb010ec0d29cbfd5524c2944b2505d"
@@ -4283,14 +4348,63 @@ react-native-tab-view@^2.6.2:
resolved "https://registry.yarnpkg.com/react-native-tab-view/-/react-native-tab-view-2.7.3.tgz#fcbc5a50869f54fbdce39372addc1654e3775630"
integrity sha512-5t70BPiVZ8himmP+A7PTo9LcDlacAUtWzxghcXo2mE1vjnw2oypZanFpEl9UzJlrHfsE1Duyn8FUfLysS9PqPA==
+react-native-unimodules@~0.5.2:
+ version "0.5.4"
+ resolved "https://registry.yarnpkg.com/react-native-unimodules/-/react-native-unimodules-0.5.4.tgz#d4d779576a027f0455b14d396b0e002cb57963fe"
+ integrity sha512-47ZJzZriaVtvDJp24HLu6xcKBaDScDcx71yIDmahsKKJtbEHmXl7jPz1y/2FhAKSb174m9niu3F97Di5Bo+91g==
+ dependencies:
+ "@unimodules/core" "~3.0.2"
+ "@unimodules/react-native-adapter" "~3.0.0"
+ chalk "^2.4.2"
+ expo-app-loader-provider "~6.0.0"
+ expo-asset "~6.0.0"
+ expo-constants "~6.0.0"
+ expo-file-system "~6.0.1"
+ expo-permissions "~6.0.0"
+ unimodules-barcode-scanner-interface "~3.0.0"
+ unimodules-camera-interface "~3.0.0"
+ unimodules-constants-interface "~3.0.0"
+ unimodules-face-detector-interface "~3.0.0"
+ unimodules-file-system-interface "~3.0.0"
+ unimodules-font-interface "~3.0.0"
+ unimodules-image-loader-interface "~3.0.0"
+ unimodules-permissions-interface "~3.0.0"
+ unimodules-sensors-interface "~3.0.0"
+ unimodules-task-manager-interface "~3.0.0"
+
react-native-view-shot@2.6.0:
version "2.6.0"
resolved "https://registry.yarnpkg.com/react-native-view-shot/-/react-native-view-shot-2.6.0.tgz#3b23675826f67658366352c4b97b59a6aded2f43"
integrity sha512-yO9vWi/11m2hEJl8FrW1SMeVzFfPtMKh20MUInGqlsL0H8Ya2JGGlFfrBzx1KiFR2hFb5OdsTLYNtcVZtJ6pLQ==
-"react-native@https://github.com/expo/react-native/archive/sdk-34.0.0.tar.gz":
- version "0.59.8"
- resolved "https://github.com/expo/react-native/archive/sdk-34.0.0.tar.gz#717c25bde6007a70e9f206ef4360999dae18e7b0"
+react-native-web@^0.11.4:
+ version "0.11.7"
+ resolved "https://registry.yarnpkg.com/react-native-web/-/react-native-web-0.11.7.tgz#d173d5a9b58db23b6d442c4bc4c81e9939adac23"
+ integrity sha512-w1KAxX2FYLS2GAi3w3BnEZg/IUu7FdgHnLmFKHplRnHMV3u1OPB2EVA7ndNdfu7ds4Rn2OZjSXoNh6F61g3gkA==
+ dependencies:
+ array-find-index "^1.0.2"
+ create-react-class "^15.6.2"
+ debounce "^1.2.0"
+ deep-assign "^3.0.0"
+ fbjs "^1.0.0"
+ hyphenate-style-name "^1.0.2"
+ inline-style-prefixer "^5.0.3"
+ normalize-css-color "^1.0.2"
+ prop-types "^15.6.0"
+ react-timer-mixin "^0.13.4"
+
+react-native-webview@~5.12.0:
+ version "5.12.1"
+ resolved "https://registry.yarnpkg.com/react-native-webview/-/react-native-webview-5.12.1.tgz#5e2b124e9087d64fc40040d911c10ee5744b5d4d"
+ integrity sha512-pFYzyNUG+k7Jk2a0Z3S1+OL9qtp0VQxVP08d1ume/O6l1Xibi0K0hRZms7zPUHqQc2uWEfjZ0FOa17MIN7vruw==
+ dependencies:
+ escape-string-regexp "1.0.5"
+ invariant "2.2.4"
+
+react-native@0.59.10:
+ version "0.59.10"
+ resolved "https://registry.yarnpkg.com/react-native/-/react-native-0.59.10.tgz#352f381e382f93a0403be499c9e384bf51c2591c"
+ integrity sha512-guB9YW+pBqS1dnfZ4ntzjINopiCUAbdmshU2wMWD1W32fRczLAopi/7Q2iHKP8LTCdxuYZV3fa9Mew5PSuANAw==
dependencies:
"@babel/runtime" "^7.0.0"
"@react-native-community/cli" "^1.2.1"
@@ -4338,7 +4452,7 @@ react-native-view-shot@2.6.0:
semver "^5.0.3"
serve-static "^1.13.1"
shell-quote "1.6.1"
- stacktrace-parser "0.1.4"
+ stacktrace-parser "^0.1.3"
ws "^1.1.5"
xmldoc "^0.4.0"
yargs "^9.0.0"
@@ -4365,6 +4479,11 @@ react-proxy@^1.1.7:
lodash "^4.6.1"
react-deep-force-update "^1.0.0"
+react-timer-mixin@^0.13.4:
+ version "0.13.4"
+ resolved "https://registry.yarnpkg.com/react-timer-mixin/-/react-timer-mixin-0.13.4.tgz#75a00c3c94c13abe29b43d63b4c65a88fc8264d3"
+ integrity sha512-4+ow23tp/Tv7hBM5Az5/Be/eKKF7DIvJ09voz5LyHGQaqqz9WV8YMs31eFvcYQs7d451LSg7kDJV70XYN/Ug/Q==
+
react-transform-hmr@^1.0.4:
version "1.0.4"
resolved "https://registry.yarnpkg.com/react-transform-hmr/-/react-transform-hmr-1.0.4.tgz#e1a40bd0aaefc72e8dfd7a7cda09af85066397bb"
@@ -4648,6 +4767,14 @@ scheduler@^0.13.3:
loose-envify "^1.1.0"
object-assign "^4.1.1"
+scheduler@^0.15.0:
+ version "0.15.0"
+ resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.15.0.tgz#6bfcf80ff850b280fed4aeecc6513bc0b4f17f8e"
+ integrity sha512-xAefmSfN6jqAa7Kuq7LIJY0bwAPG3xlCj0HMEBQk1lxYiDKZscY2xJ5U/61ZTrYbmNQbXa+gc7czPkVo11tnCg==
+ dependencies:
+ loose-envify "^1.1.0"
+ object-assign "^4.1.1"
+
"semver@2 || 3 || 4 || 5", semver@^5.0.3, semver@^5.1.0, semver@^5.3.0, semver@^5.4.1, semver@^5.5.0, semver@^5.5.1, semver@^5.6.0:
version "5.7.0"
resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.0.tgz#790a7cf6fea5459bac96110b29b60412dc8ff96b"
@@ -4892,10 +5019,12 @@ sprintf-js@~1.0.2:
resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c"
integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=
-stacktrace-parser@0.1.4:
- version "0.1.4"
- resolved "https://registry.yarnpkg.com/stacktrace-parser/-/stacktrace-parser-0.1.4.tgz#01397922e5f62ecf30845522c95c4fe1d25e7d4e"
- integrity sha1-ATl5IuX2Ls8whFUiyVxP4dJefU4=
+stacktrace-parser@^0.1.3:
+ version "0.1.6"
+ resolved "https://registry.yarnpkg.com/stacktrace-parser/-/stacktrace-parser-0.1.6.tgz#c17d466d15ba51bee2f753d064f17327a886ff37"
+ integrity sha512-wXhu0Z8YgCGigUtHQq+J7pjXCppk3Um5DwH4qskOKHMlJmKwuuUSm+wDAgU7t4sbVjvuDTNGwOfFKgjMEqSflA==
+ dependencies:
+ type-fest "^0.3.0"
static-extend@^0.1.1:
version "0.1.2"
@@ -5098,6 +5227,11 @@ trim-right@^1.0.1:
resolved "https://registry.yarnpkg.com/trim-right/-/trim-right-1.0.1.tgz#cb2e1203067e0c8de1f614094b9fe45704ea6003"
integrity sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=
+type-fest@^0.3.0:
+ version "0.3.1"
+ resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.3.1.tgz#63d00d204e059474fe5e1b7c011112bbd1dc29e1"
+ integrity sha512-cUGJnCdr4STbePCgqNFbpVNCepa+kAVohJs1sLhxzdH+gnEoOd8VhbYa7pD3zZYGiURWM2xzEII3fQcRizDkYQ==
+
typedarray@^0.0.6:
version "0.0.6"
resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777"