罗广聪

first

Showing 53 changed files with 1876 additions and 0 deletions
  1 +{
  2 + "presets": ["react-native"]
  3 +}
  1 +
  2 +[android]
  3 + target = Google Inc.:Google APIs:23
  4 +
  5 +[maven_repositories]
  6 + central = https://repo1.maven.org/maven2
  1 +[ignore]
  2 +; We fork some components by platform
  3 +.*/*[.]android.js
  4 +
  5 +; Ignore "BUCK" generated dirs
  6 +<PROJECT_ROOT>/\.buckd/
  7 +
  8 +; Ignore unexpected extra "@providesModule"
  9 +.*/node_modules/.*/node_modules/fbjs/.*
  10 +
  11 +; Ignore duplicate module providers
  12 +; For RN Apps installed via npm, "Libraries" folder is inside
  13 +; "node_modules/react-native" but in the source repo it is in the root
  14 +.*/Libraries/react-native/React.js
  15 +.*/Libraries/react-native/ReactNative.js
  16 +
  17 +[include]
  18 +
  19 +[libs]
  20 +node_modules/react-native/Libraries/react-native/react-native-interface.js
  21 +node_modules/react-native/flow
  22 +flow/
  23 +
  24 +[options]
  25 +emoji=true
  26 +
  27 +module.system=haste
  28 +
  29 +munge_underscores=true
  30 +
  31 +module.name_mapper='^[./a-zA-Z0-9$_-]+\.\(bmp\|gif\|jpg\|jpeg\|png\|psd\|svg\|webp\|m4v\|mov\|mp4\|mpeg\|mpg\|webm\|aac\|aiff\|caf\|m4a\|mp3\|wav\|html\|pdf\)$' -> 'RelativeImageStub'
  32 +
  33 +suppress_type=$FlowIssue
  34 +suppress_type=$FlowFixMe
  35 +suppress_type=$FixMe
  36 +
  37 +suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(>=0\\.\\(4[0-9]\\|[1-3][0-9]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)
  38 +suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(>=0\\.\\(4[0-9]\\|[1-3][0-9]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)?:? #[0-9]+
  39 +suppress_comment=\\(.\\|\n\\)*\\$FlowFixedInNextDeploy
  40 +suppress_comment=\\(.\\|\n\\)*\\$FlowExpectedError
  41 +
  42 +unsafe.enable_getters_and_setters=true
  43 +
  44 +[version]
  45 +^0.49.1
  1 +*.pbxproj -text
  1 +# OSX
  2 +#
  3 +.DS_Store
  4 +
  5 +# Xcode
  6 +#
  7 +build/
  8 +*.pbxuser
  9 +!default.pbxuser
  10 +*.mode1v3
  11 +!default.mode1v3
  12 +*.mode2v3
  13 +!default.mode2v3
  14 +*.perspectivev3
  15 +!default.perspectivev3
  16 +xcuserdata
  17 +*.xccheckout
  18 +*.moved-aside
  19 +DerivedData
  20 +*.hmap
  21 +*.ipa
  22 +*.xcuserstate
  23 +project.xcworkspace
  24 +
  25 +# Android/IntelliJ
  26 +#
  27 +build/
  28 +.idea
  29 +.gradle
  30 +local.properties
  31 +*.iml
  32 +
  33 +# node.js
  34 +#
  35 +node_modules/
  36 +npm-debug.log
  37 +yarn-error.log
  38 +
  39 +# BUCK
  40 +buck-out/
  41 +\.buckd/
  42 +*.keystore
  43 +
  44 +# fastlane
  45 +#
  46 +# It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the
  47 +# screenshots whenever they are needed.
  48 +# For more information about the recommended setup visit:
  49 +# https://github.com/fastlane/fastlane/blob/master/fastlane/docs/Gitignore.md
  50 +
  51 +fastlane/report.xml
  52 +fastlane/Preview.html
  53 +fastlane/screenshots
  1 +import 'react-native';
  2 +import React from 'react';
  3 +import Index from '../index.android.js';
  4 +
  5 +// Note: test renderer must be required after react-native.
  6 +import renderer from 'react-test-renderer';
  7 +
  8 +it('renders correctly', () => {
  9 + const tree = renderer.create(
  10 + <Index />
  11 + );
  12 +});
  1 +import 'react-native';
  2 +import React from 'react';
  3 +import Index from '../index.ios.js';
  4 +
  5 +// Note: test renderer must be required after react-native.
  6 +import renderer from 'react-test-renderer';
  7 +
  8 +it('renders correctly', () => {
  9 + const tree = renderer.create(
  10 + <Index />
  11 + );
  12 +});
  1 +# To learn about Buck see [Docs](https://buckbuild.com/).
  2 +# To run your application with Buck:
  3 +# - install Buck
  4 +# - `npm start` - to start the packager
  5 +# - `cd android`
  6 +# - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"`
  7 +# - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck
  8 +# - `buck install -r android/app` - compile, install and run application
  9 +#
  10 +
  11 +lib_deps = []
  12 +
  13 +for jarfile in glob(['libs/*.jar']):
  14 + name = 'jars__' + jarfile[jarfile.rindex('/') + 1: jarfile.rindex('.jar')]
  15 + lib_deps.append(':' + name)
  16 + prebuilt_jar(
  17 + name = name,
  18 + binary_jar = jarfile,
  19 + )
  20 +
  21 +for aarfile in glob(['libs/*.aar']):
  22 + name = 'aars__' + aarfile[aarfile.rindex('/') + 1: aarfile.rindex('.aar')]
  23 + lib_deps.append(':' + name)
  24 + android_prebuilt_aar(
  25 + name = name,
  26 + aar = aarfile,
  27 + )
  28 +
  29 +android_library(
  30 + name = "all-libs",
  31 + exported_deps = lib_deps,
  32 +)
  33 +
  34 +android_library(
  35 + name = "app-code",
  36 + srcs = glob([
  37 + "src/main/java/**/*.java",
  38 + ]),
  39 + deps = [
  40 + ":all-libs",
  41 + ":build_config",
  42 + ":res",
  43 + ],
  44 +)
  45 +
  46 +android_build_config(
  47 + name = "build_config",
  48 + package = "com.protectgod",
  49 +)
  50 +
  51 +android_resource(
  52 + name = "res",
  53 + package = "com.protectgod",
  54 + res = "src/main/res",
  55 +)
  56 +
  57 +android_binary(
  58 + name = "app",
  59 + keystore = "//android/keystores:debug",
  60 + manifest = "src/main/AndroidManifest.xml",
  61 + package_type = "debug",
  62 + deps = [
  63 + ":app-code",
  64 + ],
  65 +)
  1 +apply plugin: "com.android.application"
  2 +
  3 +import com.android.build.OutputFile
  4 +
  5 +/**
  6 + * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
  7 + * and bundleReleaseJsAndAssets).
  8 + * These basically call `react-native bundle` with the correct arguments during the Android build
  9 + * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
  10 + * bundle directly from the development server. Below you can see all the possible configurations
  11 + * and their defaults. If you decide to add a configuration block, make sure to add it before the
  12 + * `apply from: "../../node_modules/react-native/react.gradle"` line.
  13 + *
  14 + * project.ext.react = [
  15 + * // the name of the generated asset file containing your JS bundle
  16 + * bundleAssetName: "index.android.bundle",
  17 + *
  18 + * // the entry file for bundle generation
  19 + * entryFile: "index.android.js",
  20 + *
  21 + * // whether to bundle JS and assets in debug mode
  22 + * bundleInDebug: false,
  23 + *
  24 + * // whether to bundle JS and assets in release mode
  25 + * bundleInRelease: true,
  26 + *
  27 + * // whether to bundle JS and assets in another build variant (if configured).
  28 + * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
  29 + * // The configuration property can be in the following formats
  30 + * // 'bundleIn${productFlavor}${buildType}'
  31 + * // 'bundleIn${buildType}'
  32 + * // bundleInFreeDebug: true,
  33 + * // bundleInPaidRelease: true,
  34 + * // bundleInBeta: true,
  35 + *
  36 + * // whether to disable dev mode in custom build variants (by default only disabled in release)
  37 + * // for example: to disable dev mode in the staging build type (if configured)
  38 + * devDisabledInStaging: true,
  39 + * // The configuration property can be in the following formats
  40 + * // 'devDisabledIn${productFlavor}${buildType}'
  41 + * // 'devDisabledIn${buildType}'
  42 + *
  43 + * // the root of your project, i.e. where "package.json" lives
  44 + * root: "../../",
  45 + *
  46 + * // where to put the JS bundle asset in debug mode
  47 + * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
  48 + *
  49 + * // where to put the JS bundle asset in release mode
  50 + * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
  51 + *
  52 + * // where to put drawable resources / React Native assets, e.g. the ones you use via
  53 + * // require('./image.png')), in debug mode
  54 + * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
  55 + *
  56 + * // where to put drawable resources / React Native assets, e.g. the ones you use via
  57 + * // require('./image.png')), in release mode
  58 + * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
  59 + *
  60 + * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
  61 + * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
  62 + * // date; if you have any other folders that you want to ignore for performance reasons (gradle
  63 + * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
  64 + * // for example, you might want to remove it from here.
  65 + * inputExcludes: ["android/**", "ios/**"],
  66 + *
  67 + * // override which node gets called and with what additional arguments
  68 + * nodeExecutableAndArgs: ["node"],
  69 + *
  70 + * // supply additional arguments to the packager
  71 + * extraPackagerArgs: []
  72 + * ]
  73 + */
  74 +
  75 +apply from: "../../node_modules/react-native/react.gradle"
  76 +
  77 +/**
  78 + * Set this to true to create two separate APKs instead of one:
  79 + * - An APK that only works on ARM devices
  80 + * - An APK that only works on x86 devices
  81 + * The advantage is the size of the APK is reduced by about 4MB.
  82 + * Upload all the APKs to the Play Store and people will download
  83 + * the correct one based on the CPU architecture of their device.
  84 + */
  85 +def enableSeparateBuildPerCPUArchitecture = false
  86 +
  87 +/**
  88 + * Run Proguard to shrink the Java bytecode in release builds.
  89 + */
  90 +def enableProguardInReleaseBuilds = false
  91 +
  92 +android {
  93 + compileSdkVersion 23
  94 + buildToolsVersion "23.0.1"
  95 +
  96 + defaultConfig {
  97 + applicationId "com.protectgod"
  98 + minSdkVersion 16
  99 + targetSdkVersion 22
  100 + versionCode 1
  101 + versionName "1.0"
  102 + ndk {
  103 + abiFilters "armeabi-v7a", "x86"
  104 + }
  105 + }
  106 + splits {
  107 + abi {
  108 + reset()
  109 + enable enableSeparateBuildPerCPUArchitecture
  110 + universalApk false // If true, also generate a universal APK
  111 + include "armeabi-v7a", "x86"
  112 + }
  113 + }
  114 + buildTypes {
  115 + release {
  116 + minifyEnabled enableProguardInReleaseBuilds
  117 + proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
  118 + }
  119 + }
  120 + // applicationVariants are e.g. debug, release
  121 + applicationVariants.all { variant ->
  122 + variant.outputs.each { output ->
  123 + // For each separate APK per architecture, set a unique version code as described here:
  124 + // http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
  125 + def versionCodes = ["armeabi-v7a":1, "x86":2]
  126 + def abi = output.getFilter(OutputFile.ABI)
  127 + if (abi != null) { // null for the universal-debug, universal-release variants
  128 + output.versionCodeOverride =
  129 + versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
  130 + }
  131 + }
  132 + }
  133 +}
  134 +
  135 +dependencies {
  136 + compile fileTree(dir: "libs", include: ["*.jar"])
  137 + compile "com.android.support:appcompat-v7:23.0.1"
  138 + compile "com.facebook.react:react-native:+" // From node_modules
  139 +}
  140 +
  141 +// Run this once to be able to run the application with BUCK
  142 +// puts all compile dependencies into folder libs for BUCK to use
  143 +task copyDownloadableDepsToLibs(type: Copy) {
  144 + from configurations.compile
  145 + into 'libs'
  146 +}
  1 +# Add project specific ProGuard rules here.
  2 +# By default, the flags in this file are appended to flags specified
  3 +# in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt
  4 +# You can edit the include path and order by changing the proguardFiles
  5 +# directive in build.gradle.
  6 +#
  7 +# For more details, see
  8 +# http://developer.android.com/guide/developing/tools/proguard.html
  9 +
  10 +# Add any project specific keep options here:
  11 +
  12 +# If your project uses WebView with JS, uncomment the following
  13 +# and specify the fully qualified class name to the JavaScript interface
  14 +# class:
  15 +#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
  16 +# public *;
  17 +#}
  18 +
  19 +# Disabling obfuscation is useful if you collect stack traces from production crashes
  20 +# (unless you are using a system that supports de-obfuscate the stack traces).
  21 +-dontobfuscate
  22 +
  23 +# React Native
  24 +
  25 +# Keep our interfaces so they can be used by other ProGuard rules.
  26 +# See http://sourceforge.net/p/proguard/bugs/466/
  27 +-keep,allowobfuscation @interface com.facebook.proguard.annotations.DoNotStrip
  28 +-keep,allowobfuscation @interface com.facebook.proguard.annotations.KeepGettersAndSetters
  29 +-keep,allowobfuscation @interface com.facebook.common.internal.DoNotStrip
  30 +
  31 +# Do not strip any method/class that is annotated with @DoNotStrip
  32 +-keep @com.facebook.proguard.annotations.DoNotStrip class *
  33 +-keep @com.facebook.common.internal.DoNotStrip class *
  34 +-keepclassmembers class * {
  35 + @com.facebook.proguard.annotations.DoNotStrip *;
  36 + @com.facebook.common.internal.DoNotStrip *;
  37 +}
  38 +
  39 +-keepclassmembers @com.facebook.proguard.annotations.KeepGettersAndSetters class * {
  40 + void set*(***);
  41 + *** get*();
  42 +}
  43 +
  44 +-keep class * extends com.facebook.react.bridge.JavaScriptModule { *; }
  45 +-keep class * extends com.facebook.react.bridge.NativeModule { *; }
  46 +-keepclassmembers,includedescriptorclasses class * { native <methods>; }
  47 +-keepclassmembers class * { @com.facebook.react.uimanager.UIProp <fields>; }
  48 +-keepclassmembers class * { @com.facebook.react.uimanager.annotations.ReactProp <methods>; }
  49 +-keepclassmembers class * { @com.facebook.react.uimanager.annotations.ReactPropGroup <methods>; }
  50 +
  51 +-dontwarn com.facebook.react.**
  52 +
  53 +# TextLayoutBuilder uses a non-public Android constructor within StaticLayout.
  54 +# See libs/proxy/src/main/java/com/facebook/fbui/textlayoutbuilder/proxy for details.
  55 +-dontwarn android.text.StaticLayout
  56 +
  57 +# okhttp
  58 +
  59 +-keepattributes Signature
  60 +-keepattributes *Annotation*
  61 +-keep class okhttp3.** { *; }
  62 +-keep interface okhttp3.** { *; }
  63 +-dontwarn okhttp3.**
  64 +
  65 +# okio
  66 +
  67 +-keep class sun.misc.Unsafe { *; }
  68 +-dontwarn java.nio.file.*
  69 +-dontwarn org.codehaus.mojo.animal_sniffer.IgnoreJRERequirement
  70 +-dontwarn okio.**
  1 +<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  2 + package="com.protectgod"
  3 + android:versionCode="1"
  4 + android:versionName="1.0">
  5 +
  6 + <uses-permission android:name="android.permission.INTERNET" />
  7 + <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
  8 +
  9 + <uses-sdk
  10 + android:minSdkVersion="16"
  11 + android:targetSdkVersion="22" />
  12 +
  13 + <application
  14 + android:name=".MainApplication"
  15 + android:allowBackup="true"
  16 + android:label="@string/app_name"
  17 + android:icon="@mipmap/ic_launcher"
  18 + android:theme="@style/AppTheme">
  19 + <activity
  20 + android:name=".MainActivity"
  21 + android:label="@string/app_name"
  22 + android:configChanges="keyboard|keyboardHidden|orientation|screenSize"
  23 + android:windowSoftInputMode="adjustResize">
  24 + <intent-filter>
  25 + <action android:name="android.intent.action.MAIN" />
  26 + <category android:name="android.intent.category.LAUNCHER" />
  27 + </intent-filter>
  28 + </activity>
  29 + <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />
  30 + </application>
  31 +
  32 +</manifest>
  1 +package com.protectgod;
  2 +
  3 +import com.facebook.react.ReactActivity;
  4 +
  5 +public class MainActivity extends ReactActivity {
  6 +
  7 + /**
  8 + * Returns the name of the main component registered from JavaScript.
  9 + * This is used to schedule rendering of the component.
  10 + */
  11 + @Override
  12 + protected String getMainComponentName() {
  13 + return "ProtectGod";
  14 + }
  15 +}
  1 +package com.protectgod;
  2 +
  3 +import android.app.Application;
  4 +
  5 +import com.facebook.react.ReactApplication;
  6 +import com.facebook.react.ReactNativeHost;
  7 +import com.facebook.react.ReactPackage;
  8 +import com.facebook.react.shell.MainReactPackage;
  9 +import com.facebook.soloader.SoLoader;
  10 +
  11 +import java.util.Arrays;
  12 +import java.util.List;
  13 +
  14 +public class MainApplication extends Application implements ReactApplication {
  15 +
  16 + private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
  17 + @Override
  18 + public boolean getUseDeveloperSupport() {
  19 + return BuildConfig.DEBUG;
  20 + }
  21 +
  22 + @Override
  23 + protected List<ReactPackage> getPackages() {
  24 + return Arrays.<ReactPackage>asList(
  25 + new MainReactPackage()
  26 + );
  27 + }
  28 + };
  29 +
  30 + @Override
  31 + public ReactNativeHost getReactNativeHost() {
  32 + return mReactNativeHost;
  33 + }
  34 +
  35 + @Override
  36 + public void onCreate() {
  37 + super.onCreate();
  38 + SoLoader.init(this, /* native exopackage */ false);
  39 + }
  40 +}
  1 +<resources>
  2 + <string name="app_name">ProtectGod</string>
  3 +</resources>
  1 +<resources>
  2 +
  3 + <!-- Base application theme. -->
  4 + <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
  5 + <!-- Customize your theme here. -->
  6 + </style>
  7 +
  8 +</resources>
  1 +// Top-level build file where you can add configuration options common to all sub-projects/modules.
  2 +
  3 +buildscript {
  4 + repositories {
  5 + jcenter()
  6 + }
  7 + dependencies {
  8 + classpath 'com.android.tools.build:gradle:2.2.3'
  9 +
  10 + // NOTE: Do not place your application dependencies here; they belong
  11 + // in the individual module build.gradle files
  12 + }
  13 +}
  14 +
  15 +allprojects {
  16 + repositories {
  17 + mavenLocal()
  18 + jcenter()
  19 + maven {
  20 + // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
  21 + url "$rootDir/../node_modules/react-native/android"
  22 + }
  23 + }
  24 +}
  1 +# Project-wide Gradle settings.
  2 +
  3 +# IDE (e.g. Android Studio) users:
  4 +# Gradle settings configured through the IDE *will override*
  5 +# any settings specified in this file.
  6 +
  7 +# For more details on how to configure your build environment visit
  8 +# http://www.gradle.org/docs/current/userguide/build_environment.html
  9 +
  10 +# Specifies the JVM arguments used for the daemon process.
  11 +# The setting is particularly useful for tweaking memory settings.
  12 +# Default value: -Xmx10248m -XX:MaxPermSize=256m
  13 +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
  14 +
  15 +# When configured, Gradle will run in incubating parallel mode.
  16 +# This option should only be used with decoupled projects. More details, visit
  17 +# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
  18 +# org.gradle.parallel=true
  19 +
  20 +android.useDeprecatedNdk=true
No preview for this file type
  1 +distributionBase=GRADLE_USER_HOME
  2 +distributionPath=wrapper/dists
  3 +zipStoreBase=GRADLE_USER_HOME
  4 +zipStorePath=wrapper/dists
  5 +distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-all.zip
  1 +#!/usr/bin/env bash
  2 +
  3 +##############################################################################
  4 +##
  5 +## Gradle start up script for UN*X
  6 +##
  7 +##############################################################################
  8 +
  9 +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
  10 +DEFAULT_JVM_OPTS=""
  11 +
  12 +APP_NAME="Gradle"
  13 +APP_BASE_NAME=`basename "$0"`
  14 +
  15 +# Use the maximum available, or set MAX_FD != -1 to use that value.
  16 +MAX_FD="maximum"
  17 +
  18 +warn ( ) {
  19 + echo "$*"
  20 +}
  21 +
  22 +die ( ) {
  23 + echo
  24 + echo "$*"
  25 + echo
  26 + exit 1
  27 +}
  28 +
  29 +# OS specific support (must be 'true' or 'false').
  30 +cygwin=false
  31 +msys=false
  32 +darwin=false
  33 +case "`uname`" in
  34 + CYGWIN* )
  35 + cygwin=true
  36 + ;;
  37 + Darwin* )
  38 + darwin=true
  39 + ;;
  40 + MINGW* )
  41 + msys=true
  42 + ;;
  43 +esac
  44 +
  45 +# For Cygwin, ensure paths are in UNIX format before anything is touched.
  46 +if $cygwin ; then
  47 + [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
  48 +fi
  49 +
  50 +# Attempt to set APP_HOME
  51 +# Resolve links: $0 may be a link
  52 +PRG="$0"
  53 +# Need this for relative symlinks.
  54 +while [ -h "$PRG" ] ; do
  55 + ls=`ls -ld "$PRG"`
  56 + link=`expr "$ls" : '.*-> \(.*\)$'`
  57 + if expr "$link" : '/.*' > /dev/null; then
  58 + PRG="$link"
  59 + else
  60 + PRG=`dirname "$PRG"`"/$link"
  61 + fi
  62 +done
  63 +SAVED="`pwd`"
  64 +cd "`dirname \"$PRG\"`/" >&-
  65 +APP_HOME="`pwd -P`"
  66 +cd "$SAVED" >&-
  67 +
  68 +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
  69 +
  70 +# Determine the Java command to use to start the JVM.
  71 +if [ -n "$JAVA_HOME" ] ; then
  72 + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
  73 + # IBM's JDK on AIX uses strange locations for the executables
  74 + JAVACMD="$JAVA_HOME/jre/sh/java"
  75 + else
  76 + JAVACMD="$JAVA_HOME/bin/java"
  77 + fi
  78 + if [ ! -x "$JAVACMD" ] ; then
  79 + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
  80 +
  81 +Please set the JAVA_HOME variable in your environment to match the
  82 +location of your Java installation."
  83 + fi
  84 +else
  85 + JAVACMD="java"
  86 + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
  87 +
  88 +Please set the JAVA_HOME variable in your environment to match the
  89 +location of your Java installation."
  90 +fi
  91 +
  92 +# Increase the maximum file descriptors if we can.
  93 +if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
  94 + MAX_FD_LIMIT=`ulimit -H -n`
  95 + if [ $? -eq 0 ] ; then
  96 + if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
  97 + MAX_FD="$MAX_FD_LIMIT"
  98 + fi
  99 + ulimit -n $MAX_FD
  100 + if [ $? -ne 0 ] ; then
  101 + warn "Could not set maximum file descriptor limit: $MAX_FD"
  102 + fi
  103 + else
  104 + warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
  105 + fi
  106 +fi
  107 +
  108 +# For Darwin, add options to specify how the application appears in the dock
  109 +if $darwin; then
  110 + GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
  111 +fi
  112 +
  113 +# For Cygwin, switch paths to Windows format before running java
  114 +if $cygwin ; then
  115 + APP_HOME=`cygpath --path --mixed "$APP_HOME"`
  116 + CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
  117 +
  118 + # We build the pattern for arguments to be converted via cygpath
  119 + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
  120 + SEP=""
  121 + for dir in $ROOTDIRSRAW ; do
  122 + ROOTDIRS="$ROOTDIRS$SEP$dir"
  123 + SEP="|"
  124 + done
  125 + OURCYGPATTERN="(^($ROOTDIRS))"
  126 + # Add a user-defined pattern to the cygpath arguments
  127 + if [ "$GRADLE_CYGPATTERN" != "" ] ; then
  128 + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
  129 + fi
  130 + # Now convert the arguments - kludge to limit ourselves to /bin/sh
  131 + i=0
  132 + for arg in "$@" ; do
  133 + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
  134 + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
  135 +
  136 + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
  137 + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
  138 + else
  139 + eval `echo args$i`="\"$arg\""
  140 + fi
  141 + i=$((i+1))
  142 + done
  143 + case $i in
  144 + (0) set -- ;;
  145 + (1) set -- "$args0" ;;
  146 + (2) set -- "$args0" "$args1" ;;
  147 + (3) set -- "$args0" "$args1" "$args2" ;;
  148 + (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
  149 + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
  150 + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
  151 + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
  152 + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
  153 + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
  154 + esac
  155 +fi
  156 +
  157 +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
  158 +function splitJvmOpts() {
  159 + JVM_OPTS=("$@")
  160 +}
  161 +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
  162 +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
  163 +
  164 +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
  1 +@if "%DEBUG%" == "" @echo off
  2 +@rem ##########################################################################
  3 +@rem
  4 +@rem Gradle startup script for Windows
  5 +@rem
  6 +@rem ##########################################################################
  7 +
  8 +@rem Set local scope for the variables with windows NT shell
  9 +if "%OS%"=="Windows_NT" setlocal
  10 +
  11 +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
  12 +set DEFAULT_JVM_OPTS=
  13 +
  14 +set DIRNAME=%~dp0
  15 +if "%DIRNAME%" == "" set DIRNAME=.
  16 +set APP_BASE_NAME=%~n0
  17 +set APP_HOME=%DIRNAME%
  18 +
  19 +@rem Find java.exe
  20 +if defined JAVA_HOME goto findJavaFromJavaHome
  21 +
  22 +set JAVA_EXE=java.exe
  23 +%JAVA_EXE% -version >NUL 2>&1
  24 +if "%ERRORLEVEL%" == "0" goto init
  25 +
  26 +echo.
  27 +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
  28 +echo.
  29 +echo Please set the JAVA_HOME variable in your environment to match the
  30 +echo location of your Java installation.
  31 +
  32 +goto fail
  33 +
  34 +:findJavaFromJavaHome
  35 +set JAVA_HOME=%JAVA_HOME:"=%
  36 +set JAVA_EXE=%JAVA_HOME%/bin/java.exe
  37 +
  38 +if exist "%JAVA_EXE%" goto init
  39 +
  40 +echo.
  41 +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
  42 +echo.
  43 +echo Please set the JAVA_HOME variable in your environment to match the
  44 +echo location of your Java installation.
  45 +
  46 +goto fail
  47 +
  48 +:init
  49 +@rem Get command-line arguments, handling Windowz variants
  50 +
  51 +if not "%OS%" == "Windows_NT" goto win9xME_args
  52 +if "%@eval[2+2]" == "4" goto 4NT_args
  53 +
  54 +:win9xME_args
  55 +@rem Slurp the command line arguments.
  56 +set CMD_LINE_ARGS=
  57 +set _SKIP=2
  58 +
  59 +:win9xME_args_slurp
  60 +if "x%~1" == "x" goto execute
  61 +
  62 +set CMD_LINE_ARGS=%*
  63 +goto execute
  64 +
  65 +:4NT_args
  66 +@rem Get arguments from the 4NT Shell from JP Software
  67 +set CMD_LINE_ARGS=%$
  68 +
  69 +:execute
  70 +@rem Setup the command line
  71 +
  72 +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
  73 +
  74 +@rem Execute Gradle
  75 +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
  76 +
  77 +:end
  78 +@rem End local scope for the variables with windows NT shell
  79 +if "%ERRORLEVEL%"=="0" goto mainEnd
  80 +
  81 +:fail
  82 +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
  83 +rem the _cmd.exe /c_ return code!
  84 +if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
  85 +exit /b 1
  86 +
  87 +:mainEnd
  88 +if "%OS%"=="Windows_NT" endlocal
  89 +
  90 +:omega
  1 +keystore(
  2 + name = "debug",
  3 + properties = "debug.keystore.properties",
  4 + store = "debug.keystore",
  5 + visibility = [
  6 + "PUBLIC",
  7 + ],
  8 +)
  1 +key.store=debug.keystore
  2 +key.alias=androiddebugkey
  3 +key.store.password=android
  4 +key.alias.password=android
  1 +rootProject.name = 'ProtectGod'
  2 +
  3 +include ':app'
  1 +{
  2 + "name": "ProtectGod",
  3 + "displayName": "ProtectGod"
  4 +}
  1 +/**
  2 + * Sample React Native App
  3 + * https://github.com/facebook/react-native
  4 + * @flow
  5 + */
  6 +
  7 +import React, { Component } from 'react';
  8 +import {
  9 + AppRegistry,
  10 + StyleSheet,
  11 + Text,
  12 + View
  13 +} from 'react-native';
  14 +
  15 +export default class ProtectGod extends Component {
  16 + render() {
  17 + return (
  18 + <View style={styles.container}>
  19 + <Text style={styles.welcome}>
  20 + Welcome to React Native!
  21 + </Text>
  22 + <Text style={styles.instructions}>
  23 + To get started, edit index.android.js
  24 + </Text>
  25 + <Text style={styles.instructions}>
  26 + Double tap R on your keyboard to reload,{'\n'}
  27 + Shake or press menu button for dev menu
  28 + </Text>
  29 + </View>
  30 + );
  31 + }
  32 +}
  33 +
  34 +const styles = StyleSheet.create({
  35 + container: {
  36 + flex: 1,
  37 + justifyContent: 'center',
  38 + alignItems: 'center',
  39 + backgroundColor: '#F5FCFF',
  40 + },
  41 + welcome: {
  42 + fontSize: 20,
  43 + textAlign: 'center',
  44 + margin: 10,
  45 + },
  46 + instructions: {
  47 + textAlign: 'center',
  48 + color: '#333333',
  49 + marginBottom: 5,
  50 + },
  51 +});
  52 +
  53 +AppRegistry.registerComponent('ProtectGod', () => ProtectGod);
  1 +/**
  2 + * Sample React Native App
  3 + * https://github.com/facebook/react-native
  4 + * @flow
  5 + */
  6 +
  7 +import React, { Component } from 'react';
  8 +import {
  9 + AppRegistry,
  10 + StyleSheet,
  11 + Text,
  12 + View
  13 +} from 'react-native';
  14 +import Main from './src/pages/main';
  15 +
  16 +export default class ProtectGod extends Component {
  17 + render() {
  18 + return (
  19 + <Main />
  20 + );
  21 + }
  22 +}
  23 +
  24 +const styles = StyleSheet.create({
  25 + container: {
  26 + flex: 1,
  27 + justifyContent: 'center',
  28 + alignItems: 'center',
  29 + backgroundColor: '#F5FCFF',
  30 + },
  31 + welcome: {
  32 + fontSize: 20,
  33 + textAlign: 'center',
  34 + margin: 10,
  35 + },
  36 + instructions: {
  37 + textAlign: 'center',
  38 + color: '#333333',
  39 + marginBottom: 5,
  40 + },
  41 +});
  42 +
  43 +AppRegistry.registerComponent('ProtectGod', () => ProtectGod);
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  3 +<plist version="1.0">
  4 +<dict>
  5 + <key>CFBundleDevelopmentRegion</key>
  6 + <string>en</string>
  7 + <key>CFBundleExecutable</key>
  8 + <string>$(EXECUTABLE_NAME)</string>
  9 + <key>CFBundleIdentifier</key>
  10 + <string>org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)</string>
  11 + <key>CFBundleInfoDictionaryVersion</key>
  12 + <string>6.0</string>
  13 + <key>CFBundleName</key>
  14 + <string>$(PRODUCT_NAME)</string>
  15 + <key>CFBundlePackageType</key>
  16 + <string>APPL</string>
  17 + <key>CFBundleShortVersionString</key>
  18 + <string>1.0</string>
  19 + <key>CFBundleSignature</key>
  20 + <string>????</string>
  21 + <key>CFBundleVersion</key>
  22 + <string>1</string>
  23 + <key>LSRequiresIPhoneOS</key>
  24 + <true/>
  25 + <key>UILaunchStoryboardName</key>
  26 + <string>LaunchScreen</string>
  27 + <key>UIRequiredDeviceCapabilities</key>
  28 + <array>
  29 + <string>armv7</string>
  30 + </array>
  31 + <key>UISupportedInterfaceOrientations</key>
  32 + <array>
  33 + <string>UIInterfaceOrientationPortrait</string>
  34 + <string>UIInterfaceOrientationLandscapeLeft</string>
  35 + <string>UIInterfaceOrientationLandscapeRight</string>
  36 + </array>
  37 + <key>UIViewControllerBasedStatusBarAppearance</key>
  38 + <false/>
  39 + <key>NSLocationWhenInUseUsageDescription</key>
  40 + <string></string>
  41 + <key>NSAppTransportSecurity</key>
  42 + <!--See http://ste.vn/2015/06/10/configuring-app-transport-security-ios-9-osx-10-11/ -->
  43 + <dict>
  44 + <key>NSExceptionDomains</key>
  45 + <dict>
  46 + <key>localhost</key>
  47 + <dict>
  48 + <key>NSExceptionAllowsInsecureHTTPLoads</key>
  49 + <true/>
  50 + </dict>
  51 + </dict>
  52 + </dict>
  53 +</dict>
  54 +</plist>
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  3 +<plist version="1.0">
  4 +<dict>
  5 + <key>CFBundleDevelopmentRegion</key>
  6 + <string>en</string>
  7 + <key>CFBundleExecutable</key>
  8 + <string>$(EXECUTABLE_NAME)</string>
  9 + <key>CFBundleIdentifier</key>
  10 + <string>org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)</string>
  11 + <key>CFBundleInfoDictionaryVersion</key>
  12 + <string>6.0</string>
  13 + <key>CFBundleName</key>
  14 + <string>$(PRODUCT_NAME)</string>
  15 + <key>CFBundlePackageType</key>
  16 + <string>BNDL</string>
  17 + <key>CFBundleShortVersionString</key>
  18 + <string>1.0</string>
  19 + <key>CFBundleSignature</key>
  20 + <string>????</string>
  21 + <key>CFBundleVersion</key>
  22 + <string>1</string>
  23 +</dict>
  24 +</plist>
This diff is collapsed. Click to expand it.
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<Scheme
  3 + LastUpgradeVersion = "0820"
  4 + version = "1.3">
  5 + <BuildAction
  6 + parallelizeBuildables = "NO"
  7 + buildImplicitDependencies = "YES">
  8 + <BuildActionEntries>
  9 + <BuildActionEntry
  10 + buildForTesting = "YES"
  11 + buildForRunning = "YES"
  12 + buildForProfiling = "YES"
  13 + buildForArchiving = "YES"
  14 + buildForAnalyzing = "YES">
  15 + <BuildableReference
  16 + BuildableIdentifier = "primary"
  17 + BlueprintIdentifier = "2D2A28121D9B038B00D4039D"
  18 + BuildableName = "libReact.a"
  19 + BlueprintName = "React-tvOS"
  20 + ReferencedContainer = "container:../node_modules/react-native/React/React.xcodeproj">
  21 + </BuildableReference>
  22 + </BuildActionEntry>
  23 + <BuildActionEntry
  24 + buildForTesting = "YES"
  25 + buildForRunning = "YES"
  26 + buildForProfiling = "YES"
  27 + buildForArchiving = "YES"
  28 + buildForAnalyzing = "YES">
  29 + <BuildableReference
  30 + BuildableIdentifier = "primary"
  31 + BlueprintIdentifier = "2D02E47A1E0B4A5D006451C7"
  32 + BuildableName = "ProtectGod-tvOS.app"
  33 + BlueprintName = "ProtectGod-tvOS"
  34 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  35 + </BuildableReference>
  36 + </BuildActionEntry>
  37 + <BuildActionEntry
  38 + buildForTesting = "YES"
  39 + buildForRunning = "YES"
  40 + buildForProfiling = "NO"
  41 + buildForArchiving = "NO"
  42 + buildForAnalyzing = "YES">
  43 + <BuildableReference
  44 + BuildableIdentifier = "primary"
  45 + BlueprintIdentifier = "2D02E48F1E0B4A5D006451C7"
  46 + BuildableName = "ProtectGod-tvOSTests.xctest"
  47 + BlueprintName = "ProtectGod-tvOSTests"
  48 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  49 + </BuildableReference>
  50 + </BuildActionEntry>
  51 + </BuildActionEntries>
  52 + </BuildAction>
  53 + <TestAction
  54 + buildConfiguration = "Debug"
  55 + selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
  56 + selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
  57 + shouldUseLaunchSchemeArgsEnv = "YES">
  58 + <Testables>
  59 + <TestableReference
  60 + skipped = "NO">
  61 + <BuildableReference
  62 + BuildableIdentifier = "primary"
  63 + BlueprintIdentifier = "2D02E48F1E0B4A5D006451C7"
  64 + BuildableName = "ProtectGod-tvOSTests.xctest"
  65 + BlueprintName = "ProtectGod-tvOSTests"
  66 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  67 + </BuildableReference>
  68 + </TestableReference>
  69 + </Testables>
  70 + <MacroExpansion>
  71 + <BuildableReference
  72 + BuildableIdentifier = "primary"
  73 + BlueprintIdentifier = "2D02E47A1E0B4A5D006451C7"
  74 + BuildableName = "ProtectGod-tvOS.app"
  75 + BlueprintName = "ProtectGod-tvOS"
  76 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  77 + </BuildableReference>
  78 + </MacroExpansion>
  79 + <AdditionalOptions>
  80 + </AdditionalOptions>
  81 + </TestAction>
  82 + <LaunchAction
  83 + buildConfiguration = "Debug"
  84 + selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
  85 + selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
  86 + launchStyle = "0"
  87 + useCustomWorkingDirectory = "NO"
  88 + ignoresPersistentStateOnLaunch = "NO"
  89 + debugDocumentVersioning = "YES"
  90 + debugServiceExtension = "internal"
  91 + allowLocationSimulation = "YES">
  92 + <BuildableProductRunnable
  93 + runnableDebuggingMode = "0">
  94 + <BuildableReference
  95 + BuildableIdentifier = "primary"
  96 + BlueprintIdentifier = "2D02E47A1E0B4A5D006451C7"
  97 + BuildableName = "ProtectGod-tvOS.app"
  98 + BlueprintName = "ProtectGod-tvOS"
  99 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  100 + </BuildableReference>
  101 + </BuildableProductRunnable>
  102 + <AdditionalOptions>
  103 + </AdditionalOptions>
  104 + </LaunchAction>
  105 + <ProfileAction
  106 + buildConfiguration = "Release"
  107 + shouldUseLaunchSchemeArgsEnv = "YES"
  108 + savedToolIdentifier = ""
  109 + useCustomWorkingDirectory = "NO"
  110 + debugDocumentVersioning = "YES">
  111 + <BuildableProductRunnable
  112 + runnableDebuggingMode = "0">
  113 + <BuildableReference
  114 + BuildableIdentifier = "primary"
  115 + BlueprintIdentifier = "2D02E47A1E0B4A5D006451C7"
  116 + BuildableName = "ProtectGod-tvOS.app"
  117 + BlueprintName = "ProtectGod-tvOS"
  118 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  119 + </BuildableReference>
  120 + </BuildableProductRunnable>
  121 + </ProfileAction>
  122 + <AnalyzeAction
  123 + buildConfiguration = "Debug">
  124 + </AnalyzeAction>
  125 + <ArchiveAction
  126 + buildConfiguration = "Release"
  127 + revealArchiveInOrganizer = "YES">
  128 + </ArchiveAction>
  129 +</Scheme>
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<Scheme
  3 + LastUpgradeVersion = "0620"
  4 + version = "1.3">
  5 + <BuildAction
  6 + parallelizeBuildables = "NO"
  7 + buildImplicitDependencies = "YES">
  8 + <BuildActionEntries>
  9 + <BuildActionEntry
  10 + buildForTesting = "YES"
  11 + buildForRunning = "YES"
  12 + buildForProfiling = "YES"
  13 + buildForArchiving = "YES"
  14 + buildForAnalyzing = "YES">
  15 + <BuildableReference
  16 + BuildableIdentifier = "primary"
  17 + BlueprintIdentifier = "83CBBA2D1A601D0E00E9B192"
  18 + BuildableName = "libReact.a"
  19 + BlueprintName = "React"
  20 + ReferencedContainer = "container:../node_modules/react-native/React/React.xcodeproj">
  21 + </BuildableReference>
  22 + </BuildActionEntry>
  23 + <BuildActionEntry
  24 + buildForTesting = "YES"
  25 + buildForRunning = "YES"
  26 + buildForProfiling = "YES"
  27 + buildForArchiving = "YES"
  28 + buildForAnalyzing = "YES">
  29 + <BuildableReference
  30 + BuildableIdentifier = "primary"
  31 + BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
  32 + BuildableName = "ProtectGod.app"
  33 + BlueprintName = "ProtectGod"
  34 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  35 + </BuildableReference>
  36 + </BuildActionEntry>
  37 + <BuildActionEntry
  38 + buildForTesting = "YES"
  39 + buildForRunning = "YES"
  40 + buildForProfiling = "NO"
  41 + buildForArchiving = "NO"
  42 + buildForAnalyzing = "YES">
  43 + <BuildableReference
  44 + BuildableIdentifier = "primary"
  45 + BlueprintIdentifier = "00E356ED1AD99517003FC87E"
  46 + BuildableName = "ProtectGodTests.xctest"
  47 + BlueprintName = "ProtectGodTests"
  48 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  49 + </BuildableReference>
  50 + </BuildActionEntry>
  51 + </BuildActionEntries>
  52 + </BuildAction>
  53 + <TestAction
  54 + buildConfiguration = "Debug"
  55 + selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
  56 + selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
  57 + shouldUseLaunchSchemeArgsEnv = "YES">
  58 + <Testables>
  59 + <TestableReference
  60 + skipped = "NO">
  61 + <BuildableReference
  62 + BuildableIdentifier = "primary"
  63 + BlueprintIdentifier = "00E356ED1AD99517003FC87E"
  64 + BuildableName = "ProtectGodTests.xctest"
  65 + BlueprintName = "ProtectGodTests"
  66 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  67 + </BuildableReference>
  68 + </TestableReference>
  69 + </Testables>
  70 + <MacroExpansion>
  71 + <BuildableReference
  72 + BuildableIdentifier = "primary"
  73 + BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
  74 + BuildableName = "ProtectGod.app"
  75 + BlueprintName = "ProtectGod"
  76 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  77 + </BuildableReference>
  78 + </MacroExpansion>
  79 + <AdditionalOptions>
  80 + </AdditionalOptions>
  81 + </TestAction>
  82 + <LaunchAction
  83 + buildConfiguration = "Debug"
  84 + selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
  85 + selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
  86 + launchStyle = "0"
  87 + useCustomWorkingDirectory = "NO"
  88 + ignoresPersistentStateOnLaunch = "NO"
  89 + debugDocumentVersioning = "YES"
  90 + debugServiceExtension = "internal"
  91 + allowLocationSimulation = "YES">
  92 + <BuildableProductRunnable
  93 + runnableDebuggingMode = "0">
  94 + <BuildableReference
  95 + BuildableIdentifier = "primary"
  96 + BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
  97 + BuildableName = "ProtectGod.app"
  98 + BlueprintName = "ProtectGod"
  99 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  100 + </BuildableReference>
  101 + </BuildableProductRunnable>
  102 + <AdditionalOptions>
  103 + </AdditionalOptions>
  104 + </LaunchAction>
  105 + <ProfileAction
  106 + buildConfiguration = "Release"
  107 + shouldUseLaunchSchemeArgsEnv = "YES"
  108 + savedToolIdentifier = ""
  109 + useCustomWorkingDirectory = "NO"
  110 + debugDocumentVersioning = "YES">
  111 + <BuildableProductRunnable
  112 + runnableDebuggingMode = "0">
  113 + <BuildableReference
  114 + BuildableIdentifier = "primary"
  115 + BlueprintIdentifier = "13B07F861A680F5B00A75B9A"
  116 + BuildableName = "ProtectGod.app"
  117 + BlueprintName = "ProtectGod"
  118 + ReferencedContainer = "container:ProtectGod.xcodeproj">
  119 + </BuildableReference>
  120 + </BuildableProductRunnable>
  121 + </ProfileAction>
  122 + <AnalyzeAction
  123 + buildConfiguration = "Debug">
  124 + </AnalyzeAction>
  125 + <ArchiveAction
  126 + buildConfiguration = "Release"
  127 + revealArchiveInOrganizer = "YES">
  128 + </ArchiveAction>
  129 +</Scheme>
  1 +/**
  2 + * Copyright (c) 2015-present, Facebook, Inc.
  3 + * All rights reserved.
  4 + *
  5 + * This source code is licensed under the BSD-style license found in the
  6 + * LICENSE file in the root directory of this source tree. An additional grant
  7 + * of patent rights can be found in the PATENTS file in the same directory.
  8 + */
  9 +
  10 +#import <UIKit/UIKit.h>
  11 +
  12 +@interface AppDelegate : UIResponder <UIApplicationDelegate>
  13 +
  14 +@property (nonatomic, strong) UIWindow *window;
  15 +
  16 +@end
  1 +/**
  2 + * Copyright (c) 2015-present, Facebook, Inc.
  3 + * All rights reserved.
  4 + *
  5 + * This source code is licensed under the BSD-style license found in the
  6 + * LICENSE file in the root directory of this source tree. An additional grant
  7 + * of patent rights can be found in the PATENTS file in the same directory.
  8 + */
  9 +
  10 +#import "AppDelegate.h"
  11 +
  12 +#import <React/RCTBundleURLProvider.h>
  13 +#import <React/RCTRootView.h>
  14 +
  15 +@implementation AppDelegate
  16 +
  17 +- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
  18 +{
  19 + NSURL *jsCodeLocation;
  20 +
  21 + jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];
  22 +
  23 + RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
  24 + moduleName:@"ProtectGod"
  25 + initialProperties:nil
  26 + launchOptions:launchOptions];
  27 + rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
  28 +
  29 + self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
  30 + UIViewController *rootViewController = [UIViewController new];
  31 + rootViewController.view = rootView;
  32 + self.window.rootViewController = rootViewController;
  33 + [self.window makeKeyAndVisible];
  34 + return YES;
  35 +}
  36 +
  37 +@end
  1 +<?xml version="1.0" encoding="UTF-8" standalone="no"?>
  2 +<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="7702" systemVersion="14D136" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES">
  3 + <dependencies>
  4 + <deployment identifier="iOS"/>
  5 + <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="7701"/>
  6 + <capability name="Constraints with non-1.0 multipliers" minToolsVersion="5.1"/>
  7 + </dependencies>
  8 + <objects>
  9 + <placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
  10 + <placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
  11 + <view contentMode="scaleToFill" id="iN0-l3-epB">
  12 + <rect key="frame" x="0.0" y="0.0" width="480" height="480"/>
  13 + <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
  14 + <subviews>
  15 + <label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Powered by React Native" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" minimumFontSize="9" translatesAutoresizingMaskIntoConstraints="NO" id="8ie-xW-0ye">
  16 + <rect key="frame" x="20" y="439" width="441" height="21"/>
  17 + <fontDescription key="fontDescription" type="system" pointSize="17"/>
  18 + <color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
  19 + <nil key="highlightedColor"/>
  20 + </label>
  21 + <label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="ProtectGod" textAlignment="center" lineBreakMode="middleTruncation" baselineAdjustment="alignBaselines" minimumFontSize="18" translatesAutoresizingMaskIntoConstraints="NO" id="kId-c2-rCX">
  22 + <rect key="frame" x="20" y="140" width="441" height="43"/>
  23 + <fontDescription key="fontDescription" type="boldSystem" pointSize="36"/>
  24 + <color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
  25 + <nil key="highlightedColor"/>
  26 + </label>
  27 + </subviews>
  28 + <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/>
  29 + <constraints>
  30 + <constraint firstItem="kId-c2-rCX" firstAttribute="centerY" secondItem="iN0-l3-epB" secondAttribute="bottom" multiplier="1/3" constant="1" id="5cJ-9S-tgC"/>
  31 + <constraint firstAttribute="centerX" secondItem="kId-c2-rCX" secondAttribute="centerX" id="Koa-jz-hwk"/>
  32 + <constraint firstAttribute="bottom" secondItem="8ie-xW-0ye" secondAttribute="bottom" constant="20" id="Kzo-t9-V3l"/>
  33 + <constraint firstItem="8ie-xW-0ye" firstAttribute="leading" secondItem="iN0-l3-epB" secondAttribute="leading" constant="20" symbolic="YES" id="MfP-vx-nX0"/>
  34 + <constraint firstAttribute="centerX" secondItem="8ie-xW-0ye" secondAttribute="centerX" id="ZEH-qu-HZ9"/>
  35 + <constraint firstItem="kId-c2-rCX" firstAttribute="leading" secondItem="iN0-l3-epB" secondAttribute="leading" constant="20" symbolic="YES" id="fvb-Df-36g"/>
  36 + </constraints>
  37 + <nil key="simulatedStatusBarMetrics"/>
  38 + <freeformSimulatedSizeMetrics key="simulatedDestinationMetrics"/>
  39 + <point key="canvasLocation" x="548" y="455"/>
  40 + </view>
  41 + </objects>
  42 +</document>
  1 +{
  2 + "images" : [
  3 + {
  4 + "idiom" : "iphone",
  5 + "size" : "29x29",
  6 + "scale" : "2x"
  7 + },
  8 + {
  9 + "idiom" : "iphone",
  10 + "size" : "29x29",
  11 + "scale" : "3x"
  12 + },
  13 + {
  14 + "idiom" : "iphone",
  15 + "size" : "40x40",
  16 + "scale" : "2x"
  17 + },
  18 + {
  19 + "idiom" : "iphone",
  20 + "size" : "40x40",
  21 + "scale" : "3x"
  22 + },
  23 + {
  24 + "idiom" : "iphone",
  25 + "size" : "60x60",
  26 + "scale" : "2x"
  27 + },
  28 + {
  29 + "idiom" : "iphone",
  30 + "size" : "60x60",
  31 + "scale" : "3x"
  32 + }
  33 + ],
  34 + "info" : {
  35 + "version" : 1,
  36 + "author" : "xcode"
  37 + }
  38 +}
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  3 +<plist version="1.0">
  4 +<dict>
  5 + <key>CFBundleDevelopmentRegion</key>
  6 + <string>en</string>
  7 + <key>CFBundleDisplayName</key>
  8 + <string>ProtectGod</string>
  9 + <key>CFBundleExecutable</key>
  10 + <string>$(EXECUTABLE_NAME)</string>
  11 + <key>CFBundleIdentifier</key>
  12 + <string>org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)</string>
  13 + <key>CFBundleInfoDictionaryVersion</key>
  14 + <string>6.0</string>
  15 + <key>CFBundleName</key>
  16 + <string>$(PRODUCT_NAME)</string>
  17 + <key>CFBundlePackageType</key>
  18 + <string>APPL</string>
  19 + <key>CFBundleShortVersionString</key>
  20 + <string>1.0</string>
  21 + <key>CFBundleSignature</key>
  22 + <string>????</string>
  23 + <key>CFBundleVersion</key>
  24 + <string>1</string>
  25 + <key>LSRequiresIPhoneOS</key>
  26 + <true/>
  27 + <key>UILaunchStoryboardName</key>
  28 + <string>LaunchScreen</string>
  29 + <key>UIRequiredDeviceCapabilities</key>
  30 + <array>
  31 + <string>armv7</string>
  32 + </array>
  33 + <key>UISupportedInterfaceOrientations</key>
  34 + <array>
  35 + <string>UIInterfaceOrientationPortrait</string>
  36 + <string>UIInterfaceOrientationLandscapeLeft</string>
  37 + <string>UIInterfaceOrientationLandscapeRight</string>
  38 + </array>
  39 + <key>UIViewControllerBasedStatusBarAppearance</key>
  40 + <false/>
  41 + <key>NSLocationWhenInUseUsageDescription</key>
  42 + <string></string>
  43 + <key>NSAppTransportSecurity</key>
  44 + <!--See http://ste.vn/2015/06/10/configuring-app-transport-security-ios-9-osx-10-11/ -->
  45 + <dict>
  46 + <key>NSExceptionDomains</key>
  47 + <dict>
  48 + <key>localhost</key>
  49 + <dict>
  50 + <key>NSExceptionAllowsInsecureHTTPLoads</key>
  51 + <true/>
  52 + </dict>
  53 + </dict>
  54 + </dict>
  55 +</dict>
  56 +</plist>
  1 +/**
  2 + * Copyright (c) 2015-present, Facebook, Inc.
  3 + * All rights reserved.
  4 + *
  5 + * This source code is licensed under the BSD-style license found in the
  6 + * LICENSE file in the root directory of this source tree. An additional grant
  7 + * of patent rights can be found in the PATENTS file in the same directory.
  8 + */
  9 +
  10 +#import <UIKit/UIKit.h>
  11 +
  12 +#import "AppDelegate.h"
  13 +
  14 +int main(int argc, char * argv[]) {
  15 + @autoreleasepool {
  16 + return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
  17 + }
  18 +}
  1 +<?xml version="1.0" encoding="UTF-8"?>
  2 +<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
  3 +<plist version="1.0">
  4 +<dict>
  5 + <key>CFBundleDevelopmentRegion</key>
  6 + <string>en</string>
  7 + <key>CFBundleExecutable</key>
  8 + <string>$(EXECUTABLE_NAME)</string>
  9 + <key>CFBundleIdentifier</key>
  10 + <string>org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)</string>
  11 + <key>CFBundleInfoDictionaryVersion</key>
  12 + <string>6.0</string>
  13 + <key>CFBundleName</key>
  14 + <string>$(PRODUCT_NAME)</string>
  15 + <key>CFBundlePackageType</key>
  16 + <string>BNDL</string>
  17 + <key>CFBundleShortVersionString</key>
  18 + <string>1.0</string>
  19 + <key>CFBundleSignature</key>
  20 + <string>????</string>
  21 + <key>CFBundleVersion</key>
  22 + <string>1</string>
  23 +</dict>
  24 +</plist>
  1 +/**
  2 + * Copyright (c) 2015-present, Facebook, Inc.
  3 + * All rights reserved.
  4 + *
  5 + * This source code is licensed under the BSD-style license found in the
  6 + * LICENSE file in the root directory of this source tree. An additional grant
  7 + * of patent rights can be found in the PATENTS file in the same directory.
  8 + */
  9 +
  10 +#import <UIKit/UIKit.h>
  11 +#import <XCTest/XCTest.h>
  12 +
  13 +#import <React/RCTLog.h>
  14 +#import <React/RCTRootView.h>
  15 +
  16 +#define TIMEOUT_SECONDS 600
  17 +#define TEXT_TO_LOOK_FOR @"Welcome to React Native!"
  18 +
  19 +@interface ProtectGodTests : XCTestCase
  20 +
  21 +@end
  22 +
  23 +@implementation ProtectGodTests
  24 +
  25 +- (BOOL)findSubviewInView:(UIView *)view matching:(BOOL(^)(UIView *view))test
  26 +{
  27 + if (test(view)) {
  28 + return YES;
  29 + }
  30 + for (UIView *subview in [view subviews]) {
  31 + if ([self findSubviewInView:subview matching:test]) {
  32 + return YES;
  33 + }
  34 + }
  35 + return NO;
  36 +}
  37 +
  38 +- (void)testRendersWelcomeScreen
  39 +{
  40 + UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController];
  41 + NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS];
  42 + BOOL foundElement = NO;
  43 +
  44 + __block NSString *redboxError = nil;
  45 + RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) {
  46 + if (level >= RCTLogLevelError) {
  47 + redboxError = message;
  48 + }
  49 + });
  50 +
  51 + while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) {
  52 + [[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
  53 + [[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
  54 +
  55 + foundElement = [self findSubviewInView:vc.view matching:^BOOL(UIView *view) {
  56 + if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) {
  57 + return YES;
  58 + }
  59 + return NO;
  60 + }];
  61 + }
  62 +
  63 + RCTSetLogFunction(RCTDefaultLogFunction);
  64 +
  65 + XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
  66 + XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS);
  67 +}
  68 +
  69 +
  70 +@end
  1 +{
  2 + "compilerOptions": {
  3 + "allowJs": true,
  4 + "allowSyntheticDefaultImports": true
  5 + },
  6 + "exclude": [
  7 + "node_modules"
  8 + ]
  9 +}
  1 +{
  2 + "name": "ProtectGod",
  3 + "version": "0.0.1",
  4 + "private": true,
  5 + "scripts": {
  6 + "start": "node node_modules/react-native/local-cli/cli.js start",
  7 + "test": "jest"
  8 + },
  9 + "dependencies": {
  10 + "react": "16.0.0-alpha.12",
  11 + "react-native": "0.48.1"
  12 + },
  13 + "devDependencies": {
  14 + "babel-jest": "20.0.3",
  15 + "babel-preset-react-native": "3.0.2",
  16 + "jest": "20.0.4",
  17 + "react-test-renderer": "16.0.0-alpha.12"
  18 + },
  19 + "jest": {
  20 + "preset": "react-native"
  21 + }
  22 +}
  1 +import React, { Component } from "react";
  2 +import { AppRegistry, StyleSheet, Text, View } from "react-native";
  3 +// import Swiper from "react-native-swiper";
  4 +
  5 +export default class Main extends Component {
  6 + render() {
  7 + return (
  8 + <View style={styles.container}>
  9 + <Text style={styles.welcome}>首页</Text>
  10 + {/* <Swiper style={styles.wrapper} showsButtons={true}>
  11 + <View style={styles.slide1}>
  12 + <Text style={styles.text}>Hello Swiper</Text>
  13 + </View>
  14 + <View style={styles.slide2}>
  15 + <Text style={styles.text}>Beautiful</Text>
  16 + </View>
  17 + <View style={styles.slide3}>
  18 + <Text style={styles.text}>And simple</Text>
  19 + </View>
  20 + </Swiper> */}
  21 + </View>
  22 + );
  23 + }
  24 +}
  25 +
  26 +const styles = StyleSheet.create({
  27 + container: {
  28 + flex: 1,
  29 + justifyContent: "center",
  30 + alignItems: "center",
  31 + backgroundColor: "#F5FCFF"
  32 + },
  33 + welcome: {
  34 + fontSize: 20,
  35 + textAlign: "center",
  36 + margin: 10
  37 + },
  38 + // wrapper: {
  39 + // },
  40 + // slide1: {
  41 + // flex: 1,
  42 + // justifyContent: 'center',
  43 + // alignItems: 'center',
  44 + // backgroundColor: '#9DD6EB',
  45 + // },
  46 + // slide2: {
  47 + // flex: 1,
  48 + // justifyContent: 'center',
  49 + // alignItems: 'center',
  50 + // backgroundColor: '#97CAE5',
  51 + // },
  52 + // slide3: {
  53 + // flex: 1,
  54 + // justifyContent: 'center',
  55 + // alignItems: 'center',
  56 + // backgroundColor: '#92BBD9',
  57 + // },
  58 +});
  1 +
  2 +import React, { Component } from 'react';
  3 +import {
  4 + AppRegistry,
  5 + StyleSheet,
  6 + Text,
  7 + View
  8 +} from 'react-native';
  9 +
  10 +
  11 +
  12 +export default class InsuranceChurch extends Component {
  13 + render() {
  14 + return (
  15 + <View style={styles.container}>
  16 + <Text style={styles.welcome}>
  17 + 保堂
  18 + </Text>
  19 + </View>
  20 + );
  21 + }
  22 +}
  23 +
  24 +const styles = StyleSheet.create({
  25 + container: {
  26 + flex: 1,
  27 + justifyContent: 'center',
  28 + alignItems: 'center',
  29 + backgroundColor: '#F5FCFF',
  30 + },
  31 + welcome: {
  32 + fontSize: 20,
  33 + textAlign: 'center',
  34 + margin: 10,
  35 + },
  36 +});
  37 +
  1 +
  2 +import React, { Component } from 'react';
  3 +import {
  4 + AppRegistry,
  5 + StyleSheet,
  6 + Text,
  7 + View
  8 +} from 'react-native';
  9 +
  10 +
  11 +
  12 +export default class InsuranceCircle extends Component {
  13 + render() {
  14 + return (
  15 + <View style={styles.container}>
  16 + <Text style={styles.welcome}>
  17 + 保圈
  18 + </Text>
  19 + </View>
  20 + );
  21 + }
  22 +}
  23 +
  24 +const styles = StyleSheet.create({
  25 + container: {
  26 + flex: 1,
  27 + justifyContent: 'center',
  28 + alignItems: 'center',
  29 + backgroundColor: '#F5FCFF',
  30 + },
  31 + welcome: {
  32 + fontSize: 20,
  33 + textAlign: 'center',
  34 + margin: 10,
  35 + },
  36 +});
  37 +
  1 +
  2 +import React, { Component } from 'react';
  3 +import {
  4 + AppRegistry,
  5 + StyleSheet,
  6 + Text,
  7 + View
  8 +} from 'react-native';
  9 +
  10 +
  11 +
  12 +export default class Mine extends Component {
  13 + render() {
  14 + return (
  15 + <View style={styles.container}>
  16 + <Text style={styles.welcome}>
  17 + 我的
  18 + </Text>
  19 + </View>
  20 + );
  21 + }
  22 +}
  23 +
  24 +const styles = StyleSheet.create({
  25 + container: {
  26 + flex: 1,
  27 + justifyContent: 'center',
  28 + alignItems: 'center',
  29 + backgroundColor: '#F5FCFF',
  30 + },
  31 + welcome: {
  32 + fontSize: 20,
  33 + textAlign: 'center',
  34 + margin: 10,
  35 + },
  36 +});
  37 +
  1 +import React, { Component } from "react";
  2 +import {
  3 + AppRegistry,
  4 + StyleSheet,
  5 + Text,
  6 + View,
  7 + TabBarIOS,
  8 + NavigatorIOS
  9 +} from "react-native";
  10 +
  11 +import Home from "./Home/index";
  12 +import InsuranceCircle from "./InsuranceCircle/index";
  13 +import InsuranceChurch from "./InsuranceChurch/index";
  14 +import Mine from "./Mine/index";
  15 +
  16 +export default class Main extends Component {
  17 + constructor(props) {
  18 + super(props);
  19 + this.state = {
  20 + selectedItem: "home"
  21 + }
  22 + }
  23 +
  24 + render() {
  25 + return (
  26 + <TabBarIOS tintColor="#08CC6A" barTintColor="white">
  27 + <TabBarIOS.Item
  28 + title="首页"
  29 + selected={this.state.selectedItem == "home"}
  30 + onPress={() => {
  31 + this.setState({
  32 + selectedItem: "home"
  33 + });
  34 + }}
  35 + >
  36 + <NavigatorIOS
  37 + style={{ flex: 1 }}
  38 + initialRoute={{
  39 + component: Home,
  40 + title: "首页"
  41 + }}
  42 + />
  43 + {/* <Home /> */}
  44 + </TabBarIOS.Item>
  45 + <TabBarIOS.Item
  46 + title="保圈"
  47 + selected={this.state.selectedItem == "insuranceCircle"}
  48 + onPress={() => {
  49 + this.setState({
  50 + selectedItem: "insuranceCircle"
  51 + });
  52 + }}
  53 + >
  54 + <NavigatorIOS
  55 + style={{ flex: 1 }}
  56 + initialRoute={{
  57 + component: InsuranceCircle,
  58 + title: "保圈",
  59 + rightButtonTitle: 'Add',
  60 + }}
  61 + />
  62 + </TabBarIOS.Item>
  63 + <TabBarIOS.Item
  64 + title="保堂"
  65 + selected={this.state.selectedItem == "insuranceChurch"}
  66 + onPress={() => {
  67 + this.setState({
  68 + selectedItem: "insuranceChurch"
  69 + });
  70 + }}
  71 + >
  72 + <NavigatorIOS
  73 + style={{ flex: 1 }}
  74 + initialRoute={{
  75 + component: InsuranceChurch,
  76 + title: "保堂"
  77 + }}
  78 + />
  79 + </TabBarIOS.Item>
  80 + <TabBarIOS.Item
  81 + title="我的"
  82 + selected={this.state.selectedItem == "mine"}
  83 + onPress={() => {
  84 + this.setState({
  85 + selectedItem: "mine"
  86 + });
  87 + }}
  88 + >
  89 + <NavigatorIOS
  90 + style={{ flex: 1 }}
  91 + initialRoute={{
  92 + component: Mine,
  93 + title: "我的"
  94 + }}
  95 + />
  96 + </TabBarIOS.Item>
  97 + </TabBarIOS>
  98 + );
  99 + }
  100 +}
  101 +
  102 +const styles = StyleSheet.create({
  103 + container: {
  104 + flex: 1,
  105 + justifyContent: "center",
  106 + alignItems: "center",
  107 + backgroundColor: "#F5FCFF"
  108 + }
  109 +});
This diff could not be displayed because it is too large.