├── device ├── .babelrc ├── .buckconfig ├── .flowconfig ├── .gitattributes ├── .gitignore ├── .watchmanconfig ├── __tests__ │ ├── index.android.js │ └── index.ios.js ├── android │ ├── app │ │ ├── BUCK │ │ ├── build.gradle │ │ ├── proguard-rules.pro │ │ └── src │ │ │ └── main │ │ │ ├── AndroidManifest.xml │ │ │ ├── java │ │ │ └── com │ │ │ │ └── device │ │ │ │ ├── MainActivity.java │ │ │ │ └── MainApplication.java │ │ │ └── res │ │ │ ├── mipmap-hdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-mdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-xhdpi │ │ │ └── ic_launcher.png │ │ │ ├── mipmap-xxhdpi │ │ │ └── ic_launcher.png │ │ │ └── values │ │ │ ├── strings.xml │ │ │ └── styles.xml │ ├── build.gradle │ ├── gradle.properties │ ├── gradle │ │ └── wrapper │ │ │ ├── gradle-wrapper.jar │ │ │ └── gradle-wrapper.properties │ ├── gradlew │ ├── gradlew.bat │ ├── keystores │ │ ├── BUCK │ │ └── debug.keystore.properties │ └── settings.gradle ├── app.json ├── index.android.js ├── index.ios.js ├── ios │ ├── device-tvOS │ │ └── Info.plist │ ├── device-tvOSTests │ │ └── Info.plist │ ├── device.xcodeproj │ │ ├── project.pbxproj │ │ └── xcshareddata │ │ │ └── xcschemes │ │ │ ├── device-tvOS.xcscheme │ │ │ └── device.xcscheme │ ├── device │ │ ├── AppDelegate.h │ │ ├── AppDelegate.m │ │ ├── Base.lproj │ │ │ └── LaunchScreen.xib │ │ ├── Images.xcassets │ │ │ └── AppIcon.appiconset │ │ │ │ └── Contents.json │ │ ├── Info.plist │ │ └── main.m │ └── deviceTests │ │ ├── Info.plist │ │ └── deviceTests.m ├── package.json ├── src │ ├── actions │ │ ├── Graphs.js │ │ └── index.js │ ├── components │ │ ├── Main.js │ │ ├── Navigation.js │ │ ├── Router.js │ │ ├── graphs │ │ │ └── LineGraph.js │ │ ├── index.js │ │ └── markets │ │ │ ├── Market.js │ │ │ ├── MarketDepth.js │ │ │ ├── MarketHeader.js │ │ │ ├── PriceLine.js │ │ │ └── VolumeLine.js │ ├── index.js │ ├── reducers │ │ ├── graphs.js │ │ ├── index.js │ │ └── navigation.js │ └── store.js └── yarn.lock ├── package.json └── server ├── api ├── schema.js ├── server.js └── websocket.js ├── deploy.js ├── evm ├── build │ └── contracts │ │ ├── Migrations.json │ │ ├── SafeAddSub.json │ │ └── Token.json ├── contracts │ ├── Migrations.sol │ ├── SafeAddSub.sol │ └── Token.sol ├── migrations │ ├── 1_initial_migration.js │ └── 2_deploy_contracts.js ├── test │ ├── TestMetacoin.sol │ └── metacoin.js └── truffle.js ├── exAgent └── ExAgent.js ├── gauss ├── data.js ├── simulation.js └── utils.js ├── markets └── Market.js └── test ├── random_trading.js └── test.js /device/.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": ["react-native", "flow"] 3 | } 4 | -------------------------------------------------------------------------------- /device/.buckconfig: -------------------------------------------------------------------------------- 1 | 2 | [android] 3 | target = Google Inc.:Google APIs:23 4 | 5 | [maven_repositories] 6 | central = https://repo1.maven.org/maven2 7 | -------------------------------------------------------------------------------- /device/.flowconfig: -------------------------------------------------------------------------------- 1 | [ignore] 2 | ; We fork some components by platform 3 | .*/*[.]android.js 4 | 5 | ; Ignore "BUCK" generated dirs 6 | /\.buckd/ 7 | 8 | ; Ignore unexpected extra "@providesModule" 9 | .*/node_modules/.*/node_modules/fbjs/.* 10 | .*/node_modules/react-native/.* 11 | 12 | ; Ignore duplicate module providers 13 | ; For RN Apps installed via npm, "Libraries" folder is inside 14 | ; "node_modules/react-native" but in the source repo it is in the root 15 | .*/Libraries/react-native/React.js 16 | .*/Libraries/react-native/ReactNative.js 17 | 18 | [include] 19 | 20 | [libs] 21 | node_modules/react-native/Libraries/react-native/react-native-interface.js 22 | node_modules/react-native/flow 23 | flow/ 24 | 25 | [options] 26 | emoji=true 27 | 28 | module.system=haste 29 | 30 | experimental.strict_type_args=true 31 | 32 | munge_underscores=true 33 | 34 | 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' 35 | 36 | suppress_type=$FlowIssue 37 | suppress_type=$FlowFixMe 38 | suppress_type=$FixMe 39 | 40 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(>=0\\.\\(4[0-0]\\|[1-3][0-9]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\) 41 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(>=0\\.\\(4[0-0]\\|[1-3][0-9]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)?:? #[0-9]+ 42 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixedInNextDeploy 43 | suppress_comment=\\(.\\|\n\\)*\\$FlowExpectedError 44 | 45 | unsafe.enable_getters_and_setters=true 46 | 47 | [version] 48 | ^0.43.1 49 | -------------------------------------------------------------------------------- /device/.gitattributes: -------------------------------------------------------------------------------- 1 | *.pbxproj -text 2 | -------------------------------------------------------------------------------- /device/.gitignore: -------------------------------------------------------------------------------- 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 54 | -------------------------------------------------------------------------------- /device/.watchmanconfig: -------------------------------------------------------------------------------- 1 | {} -------------------------------------------------------------------------------- /device/__tests__/index.android.js: -------------------------------------------------------------------------------- 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 | 11 | ); 12 | }); 13 | -------------------------------------------------------------------------------- /device/__tests__/index.ios.js: -------------------------------------------------------------------------------- 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 | 11 | ); 12 | }); 13 | -------------------------------------------------------------------------------- /device/android/app/BUCK: -------------------------------------------------------------------------------- 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.device", 49 | ) 50 | 51 | android_resource( 52 | name = "res", 53 | package = "com.device", 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 | ) 66 | -------------------------------------------------------------------------------- /device/android/app/build.gradle: -------------------------------------------------------------------------------- 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 | * // the root of your project, i.e. where "package.json" lives 37 | * root: "../../", 38 | * 39 | * // where to put the JS bundle asset in debug mode 40 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug", 41 | * 42 | * // where to put the JS bundle asset in release mode 43 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release", 44 | * 45 | * // where to put drawable resources / React Native assets, e.g. the ones you use via 46 | * // require('./image.png')), in debug mode 47 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug", 48 | * 49 | * // where to put drawable resources / React Native assets, e.g. the ones you use via 50 | * // require('./image.png')), in release mode 51 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release", 52 | * 53 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means 54 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to 55 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle 56 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/ 57 | * // for example, you might want to remove it from here. 58 | * inputExcludes: ["android/**", "ios/**"], 59 | * 60 | * // override which node gets called and with what additional arguments 61 | * nodeExecutableAndArgs: ["node"] 62 | * 63 | * // supply additional arguments to the packager 64 | * extraPackagerArgs: [] 65 | * ] 66 | */ 67 | 68 | apply from: "../../node_modules/react-native/react.gradle" 69 | 70 | /** 71 | * Set this to true to create two separate APKs instead of one: 72 | * - An APK that only works on ARM devices 73 | * - An APK that only works on x86 devices 74 | * The advantage is the size of the APK is reduced by about 4MB. 75 | * Upload all the APKs to the Play Store and people will download 76 | * the correct one based on the CPU architecture of their device. 77 | */ 78 | def enableSeparateBuildPerCPUArchitecture = false 79 | 80 | /** 81 | * Run Proguard to shrink the Java bytecode in release builds. 82 | */ 83 | def enableProguardInReleaseBuilds = false 84 | 85 | android { 86 | compileSdkVersion 23 87 | buildToolsVersion "23.0.1" 88 | 89 | defaultConfig { 90 | applicationId "com.device" 91 | minSdkVersion 16 92 | targetSdkVersion 22 93 | versionCode 1 94 | versionName "1.0" 95 | ndk { 96 | abiFilters "armeabi-v7a", "x86" 97 | } 98 | } 99 | splits { 100 | abi { 101 | reset() 102 | enable enableSeparateBuildPerCPUArchitecture 103 | universalApk false // If true, also generate a universal APK 104 | include "armeabi-v7a", "x86" 105 | } 106 | } 107 | buildTypes { 108 | release { 109 | minifyEnabled enableProguardInReleaseBuilds 110 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" 111 | } 112 | } 113 | // applicationVariants are e.g. debug, release 114 | applicationVariants.all { variant -> 115 | variant.outputs.each { output -> 116 | // For each separate APK per architecture, set a unique version code as described here: 117 | // http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits 118 | def versionCodes = ["armeabi-v7a":1, "x86":2] 119 | def abi = output.getFilter(OutputFile.ABI) 120 | if (abi != null) { // null for the universal-debug, universal-release variants 121 | output.versionCodeOverride = 122 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode 123 | } 124 | } 125 | } 126 | } 127 | 128 | dependencies { 129 | compile project(':react-native-svg') 130 | compile fileTree(dir: "libs", include: ["*.jar"]) 131 | compile "com.android.support:appcompat-v7:23.0.1" 132 | compile "com.facebook.react:react-native:+" // From node_modules 133 | } 134 | 135 | // Run this once to be able to run the application with BUCK 136 | // puts all compile dependencies into folder libs for BUCK to use 137 | task copyDownloadableDepsToLibs(type: Copy) { 138 | from configurations.compile 139 | into 'libs' 140 | } 141 | -------------------------------------------------------------------------------- /device/android/app/proguard-rules.pro: -------------------------------------------------------------------------------- 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 ; } 47 | -keepclassmembers class * { @com.facebook.react.uimanager.UIProp ; } 48 | -keepclassmembers class * { @com.facebook.react.uimanager.annotations.ReactProp ; } 49 | -keepclassmembers class * { @com.facebook.react.uimanager.annotations.ReactPropGroup ; } 50 | 51 | -dontwarn com.facebook.react.** 52 | 53 | # okhttp 54 | 55 | -keepattributes Signature 56 | -keepattributes *Annotation* 57 | -keep class okhttp3.** { *; } 58 | -keep interface okhttp3.** { *; } 59 | -dontwarn okhttp3.** 60 | 61 | # okio 62 | 63 | -keep class sun.misc.Unsafe { *; } 64 | -dontwarn java.nio.file.* 65 | -dontwarn org.codehaus.mojo.animal_sniffer.IgnoreJRERequirement 66 | -dontwarn okio.** 67 | -------------------------------------------------------------------------------- /device/android/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 5 | 6 | 7 | 8 | 9 | 12 | 13 | 19 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | -------------------------------------------------------------------------------- /device/android/app/src/main/java/com/device/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.device; 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 "device"; 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /device/android/app/src/main/java/com/device/MainApplication.java: -------------------------------------------------------------------------------- 1 | package com.device; 2 | 3 | import android.app.Application; 4 | 5 | import com.facebook.react.ReactApplication; 6 | import com.horcrux.svg.SvgPackage; 7 | import com.facebook.react.ReactNativeHost; 8 | import com.facebook.react.ReactPackage; 9 | import com.facebook.react.shell.MainReactPackage; 10 | import com.facebook.soloader.SoLoader; 11 | 12 | import java.util.Arrays; 13 | import java.util.List; 14 | 15 | public class MainApplication extends Application implements ReactApplication { 16 | 17 | private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) { 18 | @Override 19 | public boolean getUseDeveloperSupport() { 20 | return BuildConfig.DEBUG; 21 | } 22 | 23 | @Override 24 | protected List getPackages() { 25 | return Arrays.asList( 26 | new MainReactPackage(), 27 | new SvgPackage() 28 | ); 29 | } 30 | }; 31 | 32 | @Override 33 | public ReactNativeHost getReactNativeHost() { 34 | return mReactNativeHost; 35 | } 36 | 37 | @Override 38 | public void onCreate() { 39 | super.onCreate(); 40 | SoLoader.init(this, /* native exopackage */ false); 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /device/android/app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/android/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /device/android/app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/android/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /device/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /device/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /device/android/app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | device 3 | 4 | -------------------------------------------------------------------------------- /device/android/app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /device/android/build.gradle: -------------------------------------------------------------------------------- 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 | } 25 | -------------------------------------------------------------------------------- /device/android/gradle.properties: -------------------------------------------------------------------------------- 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 21 | -------------------------------------------------------------------------------- /device/android/gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/android/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /device/android/gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 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 6 | -------------------------------------------------------------------------------- /device/android/gradlew: -------------------------------------------------------------------------------- 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 "$@" 165 | -------------------------------------------------------------------------------- /device/android/gradlew.bat: -------------------------------------------------------------------------------- 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 91 | -------------------------------------------------------------------------------- /device/android/keystores/BUCK: -------------------------------------------------------------------------------- 1 | keystore( 2 | name = "debug", 3 | properties = "debug.keystore.properties", 4 | store = "debug.keystore", 5 | visibility = [ 6 | "PUBLIC", 7 | ], 8 | ) 9 | -------------------------------------------------------------------------------- /device/android/keystores/debug.keystore.properties: -------------------------------------------------------------------------------- 1 | key.store=debug.keystore 2 | key.alias=androiddebugkey 3 | key.store.password=android 4 | key.alias.password=android 5 | -------------------------------------------------------------------------------- /device/android/settings.gradle: -------------------------------------------------------------------------------- 1 | rootProject.name = 'device' 2 | include ':react-native-svg' 3 | project(':react-native-svg').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-svg/android') 4 | 5 | include ':app' 6 | -------------------------------------------------------------------------------- /device/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "device", 3 | "displayName": "device" 4 | } -------------------------------------------------------------------------------- /device/index.android.js: -------------------------------------------------------------------------------- 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 device extends Component { 16 | render() { 17 | return ( 18 | 19 | 20 | Welcome to React Native! 21 | 22 | 23 | To get started, edit index.android.js 24 | 25 | 26 | Double tap R on your keyboard to reload,{'\n'} 27 | Shake or press menu button for dev menu 28 | 29 | 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('device', () => device); 54 | -------------------------------------------------------------------------------- /device/index.ios.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Sample React Native App 3 | * https://github.com/facebook/react-native 4 | * @flow 5 | */ 6 | import { Navigation, Market } from './src/components/index' 7 | import Router from './src/components/Router' 8 | import store from './src/store' 9 | import { Provider, connect } from 'react-redux'; 10 | import React, { Component } from 'react'; 11 | import { 12 | AppRegistry, 13 | StyleSheet, 14 | Text, 15 | View, 16 | } from 'react-native'; 17 | 18 | export default class device extends Component { 19 | render() { 20 | return ( 21 | 22 | 23 | 24 | 25 | 26 | ); 27 | } 28 | } 29 | 30 | const styles = StyleSheet.create({ 31 | container: { 32 | flex: 1, 33 | justifyContent: 'center', 34 | alignItems: 'center', 35 | backgroundColor: "hsl(220, 10%, 40%)", 36 | color: "#E8E8EE", 37 | }, 38 | }); 39 | 40 | AppRegistry.registerComponent('device', () => device); 41 | -------------------------------------------------------------------------------- /device/ios/device-tvOS/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleExecutable 8 | $(EXECUTABLE_NAME) 9 | CFBundleIdentifier 10 | org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier) 11 | CFBundleInfoDictionaryVersion 12 | 6.0 13 | CFBundleName 14 | $(PRODUCT_NAME) 15 | CFBundlePackageType 16 | APPL 17 | CFBundleShortVersionString 18 | 1.0 19 | CFBundleSignature 20 | ???? 21 | CFBundleVersion 22 | 1 23 | LSRequiresIPhoneOS 24 | 25 | UILaunchStoryboardName 26 | LaunchScreen 27 | UIRequiredDeviceCapabilities 28 | 29 | armv7 30 | 31 | UISupportedInterfaceOrientations 32 | 33 | UIInterfaceOrientationPortrait 34 | UIInterfaceOrientationLandscapeLeft 35 | UIInterfaceOrientationLandscapeRight 36 | 37 | UIViewControllerBasedStatusBarAppearance 38 | 39 | NSLocationWhenInUseUsageDescription 40 | 41 | NSAppTransportSecurity 42 | 43 | 44 | NSExceptionDomains 45 | 46 | localhost 47 | 48 | NSExceptionAllowsInsecureHTTPLoads 49 | 50 | 51 | 52 | 53 | 54 | 55 | -------------------------------------------------------------------------------- /device/ios/device-tvOSTests/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleExecutable 8 | $(EXECUTABLE_NAME) 9 | CFBundleIdentifier 10 | org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier) 11 | CFBundleInfoDictionaryVersion 12 | 6.0 13 | CFBundleName 14 | $(PRODUCT_NAME) 15 | CFBundlePackageType 16 | BNDL 17 | CFBundleShortVersionString 18 | 1.0 19 | CFBundleSignature 20 | ???? 21 | CFBundleVersion 22 | 1 23 | 24 | 25 | -------------------------------------------------------------------------------- /device/ios/device.xcodeproj/project.pbxproj: -------------------------------------------------------------------------------- 1 | // !$*UTF8*$! 2 | { 3 | archiveVersion = 1; 4 | classes = { 5 | }; 6 | objectVersion = 46; 7 | objects = { 8 | /* Begin PBXBuildFile section */ 9 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */; }; 10 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */; }; 11 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */; }; 12 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */; }; 13 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */; }; 14 | 00E356F31AD99517003FC87E /* deviceTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* deviceTests.m */; }; 15 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 78C398B91ACF4ADC00677621 /* libRCTLinking.a */; }; 16 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */; }; 17 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */; }; 18 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; }; 19 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; }; 20 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; 21 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; 22 | 140ED2AC1D01E1AD002B40FF /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 146834041AC3E56700842450 /* libReact.a */; }; 23 | 146834051AC3E58100842450 /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 146834041AC3E56700842450 /* libReact.a */; }; 24 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; }; 25 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; 26 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; 27 | 2D02E4C21E0B4AEC006451C7 /* libRCTAnimation-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */; }; 28 | 2D02E4C31E0B4AEC006451C7 /* libRCTImage-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */; }; 29 | 2D02E4C41E0B4AEC006451C7 /* libRCTLinking-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */; }; 30 | 2D02E4C51E0B4AEC006451C7 /* libRCTNetwork-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */; }; 31 | 2D02E4C61E0B4AEC006451C7 /* libRCTSettings-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */; }; 32 | 2D02E4C71E0B4AEC006451C7 /* libRCTText-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */; }; 33 | 2D02E4C81E0B4AEC006451C7 /* libRCTWebSocket-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */; }; 34 | 2D02E4C91E0B4AEC006451C7 /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3EA31DF850E9000B6D8A /* libReact.a */; }; 35 | 2DCD954D1E0B4F2C00145EB5 /* deviceTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* deviceTests.m */; }; 36 | 5E9157361DD0AC6A00FF2AA8 /* libRCTAnimation.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */; }; 37 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 832341B51AAA6A8300B99B32 /* libRCTText.a */; }; 38 | 9590E3077481453E878EAB5C /* libRNSVG.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 539EAC96AFEE4E44991B0E97 /* libRNSVG.a */; }; 39 | /* End PBXBuildFile section */ 40 | 41 | /* Begin PBXContainerItemProxy section */ 42 | 00C302AB1ABCB8CE00DB3ED1 /* PBXContainerItemProxy */ = { 43 | isa = PBXContainerItemProxy; 44 | containerPortal = 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */; 45 | proxyType = 2; 46 | remoteGlobalIDString = 134814201AA4EA6300B7C361; 47 | remoteInfo = RCTActionSheet; 48 | }; 49 | 00C302B91ABCB90400DB3ED1 /* PBXContainerItemProxy */ = { 50 | isa = PBXContainerItemProxy; 51 | containerPortal = 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */; 52 | proxyType = 2; 53 | remoteGlobalIDString = 134814201AA4EA6300B7C361; 54 | remoteInfo = RCTGeolocation; 55 | }; 56 | 00C302BF1ABCB91800DB3ED1 /* PBXContainerItemProxy */ = { 57 | isa = PBXContainerItemProxy; 58 | containerPortal = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */; 59 | proxyType = 2; 60 | remoteGlobalIDString = 58B5115D1A9E6B3D00147676; 61 | remoteInfo = RCTImage; 62 | }; 63 | 00C302DB1ABCB9D200DB3ED1 /* PBXContainerItemProxy */ = { 64 | isa = PBXContainerItemProxy; 65 | containerPortal = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */; 66 | proxyType = 2; 67 | remoteGlobalIDString = 58B511DB1A9E6C8500147676; 68 | remoteInfo = RCTNetwork; 69 | }; 70 | 00C302E31ABCB9EE00DB3ED1 /* PBXContainerItemProxy */ = { 71 | isa = PBXContainerItemProxy; 72 | containerPortal = 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */; 73 | proxyType = 2; 74 | remoteGlobalIDString = 832C81801AAF6DEF007FA2F7; 75 | remoteInfo = RCTVibration; 76 | }; 77 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = { 78 | isa = PBXContainerItemProxy; 79 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */; 80 | proxyType = 1; 81 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A; 82 | remoteInfo = device; 83 | }; 84 | 139105C01AF99BAD00B5F7CC /* PBXContainerItemProxy */ = { 85 | isa = PBXContainerItemProxy; 86 | containerPortal = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */; 87 | proxyType = 2; 88 | remoteGlobalIDString = 134814201AA4EA6300B7C361; 89 | remoteInfo = RCTSettings; 90 | }; 91 | 139FDEF31B06529B00C62182 /* PBXContainerItemProxy */ = { 92 | isa = PBXContainerItemProxy; 93 | containerPortal = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */; 94 | proxyType = 2; 95 | remoteGlobalIDString = 3C86DF461ADF2C930047B81A; 96 | remoteInfo = RCTWebSocket; 97 | }; 98 | 146834031AC3E56700842450 /* PBXContainerItemProxy */ = { 99 | isa = PBXContainerItemProxy; 100 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 101 | proxyType = 2; 102 | remoteGlobalIDString = 83CBBA2E1A601D0E00E9B192; 103 | remoteInfo = React; 104 | }; 105 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = { 106 | isa = PBXContainerItemProxy; 107 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */; 108 | proxyType = 1; 109 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7; 110 | remoteInfo = "device-tvOS"; 111 | }; 112 | 3DAD3E831DF850E9000B6D8A /* PBXContainerItemProxy */ = { 113 | isa = PBXContainerItemProxy; 114 | containerPortal = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */; 115 | proxyType = 2; 116 | remoteGlobalIDString = 2D2A283A1D9B042B00D4039D; 117 | remoteInfo = "RCTImage-tvOS"; 118 | }; 119 | 3DAD3E871DF850E9000B6D8A /* PBXContainerItemProxy */ = { 120 | isa = PBXContainerItemProxy; 121 | containerPortal = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */; 122 | proxyType = 2; 123 | remoteGlobalIDString = 2D2A28471D9B043800D4039D; 124 | remoteInfo = "RCTLinking-tvOS"; 125 | }; 126 | 3DAD3E8B1DF850E9000B6D8A /* PBXContainerItemProxy */ = { 127 | isa = PBXContainerItemProxy; 128 | containerPortal = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */; 129 | proxyType = 2; 130 | remoteGlobalIDString = 2D2A28541D9B044C00D4039D; 131 | remoteInfo = "RCTNetwork-tvOS"; 132 | }; 133 | 3DAD3E8F1DF850E9000B6D8A /* PBXContainerItemProxy */ = { 134 | isa = PBXContainerItemProxy; 135 | containerPortal = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */; 136 | proxyType = 2; 137 | remoteGlobalIDString = 2D2A28611D9B046600D4039D; 138 | remoteInfo = "RCTSettings-tvOS"; 139 | }; 140 | 3DAD3E931DF850E9000B6D8A /* PBXContainerItemProxy */ = { 141 | isa = PBXContainerItemProxy; 142 | containerPortal = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */; 143 | proxyType = 2; 144 | remoteGlobalIDString = 2D2A287B1D9B048500D4039D; 145 | remoteInfo = "RCTText-tvOS"; 146 | }; 147 | 3DAD3E981DF850E9000B6D8A /* PBXContainerItemProxy */ = { 148 | isa = PBXContainerItemProxy; 149 | containerPortal = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */; 150 | proxyType = 2; 151 | remoteGlobalIDString = 2D2A28881D9B049200D4039D; 152 | remoteInfo = "RCTWebSocket-tvOS"; 153 | }; 154 | 3DAD3EA21DF850E9000B6D8A /* PBXContainerItemProxy */ = { 155 | isa = PBXContainerItemProxy; 156 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 157 | proxyType = 2; 158 | remoteGlobalIDString = 2D2A28131D9B038B00D4039D; 159 | remoteInfo = "React-tvOS"; 160 | }; 161 | 3DAD3EA41DF850E9000B6D8A /* PBXContainerItemProxy */ = { 162 | isa = PBXContainerItemProxy; 163 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 164 | proxyType = 2; 165 | remoteGlobalIDString = 3D3C059A1DE3340900C268FA; 166 | remoteInfo = yoga; 167 | }; 168 | 3DAD3EA61DF850E9000B6D8A /* PBXContainerItemProxy */ = { 169 | isa = PBXContainerItemProxy; 170 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 171 | proxyType = 2; 172 | remoteGlobalIDString = 3D3C06751DE3340C00C268FA; 173 | remoteInfo = "yoga-tvOS"; 174 | }; 175 | 3DAD3EA81DF850E9000B6D8A /* PBXContainerItemProxy */ = { 176 | isa = PBXContainerItemProxy; 177 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 178 | proxyType = 2; 179 | remoteGlobalIDString = 3D3CD9251DE5FBEC00167DC4; 180 | remoteInfo = cxxreact; 181 | }; 182 | 3DAD3EAA1DF850E9000B6D8A /* PBXContainerItemProxy */ = { 183 | isa = PBXContainerItemProxy; 184 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 185 | proxyType = 2; 186 | remoteGlobalIDString = 3D3CD9321DE5FBEE00167DC4; 187 | remoteInfo = "cxxreact-tvOS"; 188 | }; 189 | 3DAD3EAC1DF850E9000B6D8A /* PBXContainerItemProxy */ = { 190 | isa = PBXContainerItemProxy; 191 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 192 | proxyType = 2; 193 | remoteGlobalIDString = 3D3CD90B1DE5FBD600167DC4; 194 | remoteInfo = jschelpers; 195 | }; 196 | 3DAD3EAE1DF850E9000B6D8A /* PBXContainerItemProxy */ = { 197 | isa = PBXContainerItemProxy; 198 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */; 199 | proxyType = 2; 200 | remoteGlobalIDString = 3D3CD9181DE5FBD800167DC4; 201 | remoteInfo = "jschelpers-tvOS"; 202 | }; 203 | 5E9157321DD0AC6500FF2AA8 /* PBXContainerItemProxy */ = { 204 | isa = PBXContainerItemProxy; 205 | containerPortal = 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */; 206 | proxyType = 2; 207 | remoteGlobalIDString = 134814201AA4EA6300B7C361; 208 | remoteInfo = RCTAnimation; 209 | }; 210 | 5E9157341DD0AC6500FF2AA8 /* PBXContainerItemProxy */ = { 211 | isa = PBXContainerItemProxy; 212 | containerPortal = 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */; 213 | proxyType = 2; 214 | remoteGlobalIDString = 2D2A28201D9B03D100D4039D; 215 | remoteInfo = "RCTAnimation-tvOS"; 216 | }; 217 | 78C398B81ACF4ADC00677621 /* PBXContainerItemProxy */ = { 218 | isa = PBXContainerItemProxy; 219 | containerPortal = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */; 220 | proxyType = 2; 221 | remoteGlobalIDString = 134814201AA4EA6300B7C361; 222 | remoteInfo = RCTLinking; 223 | }; 224 | 832341B41AAA6A8300B99B32 /* PBXContainerItemProxy */ = { 225 | isa = PBXContainerItemProxy; 226 | containerPortal = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */; 227 | proxyType = 2; 228 | remoteGlobalIDString = 58B5119B1A9E6C1200147676; 229 | remoteInfo = RCTText; 230 | }; 231 | /* End PBXContainerItemProxy section */ 232 | 233 | /* Begin PBXFileReference section */ 234 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; }; 235 | 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTActionSheet.xcodeproj; path = "../node_modules/react-native/Libraries/ActionSheetIOS/RCTActionSheet.xcodeproj"; sourceTree = ""; }; 236 | 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTGeolocation.xcodeproj; path = "../node_modules/react-native/Libraries/Geolocation/RCTGeolocation.xcodeproj"; sourceTree = ""; }; 237 | 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTImage.xcodeproj; path = "../node_modules/react-native/Libraries/Image/RCTImage.xcodeproj"; sourceTree = ""; }; 238 | 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTNetwork.xcodeproj; path = "../node_modules/react-native/Libraries/Network/RCTNetwork.xcodeproj"; sourceTree = ""; }; 239 | 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTVibration.xcodeproj; path = "../node_modules/react-native/Libraries/Vibration/RCTVibration.xcodeproj"; sourceTree = ""; }; 240 | 00E356EE1AD99517003FC87E /* deviceTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = deviceTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; 241 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; 242 | 00E356F21AD99517003FC87E /* deviceTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = deviceTests.m; sourceTree = ""; }; 243 | 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTSettings.xcodeproj; path = "../node_modules/react-native/Libraries/Settings/RCTSettings.xcodeproj"; sourceTree = ""; }; 244 | 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTWebSocket.xcodeproj; path = "../node_modules/react-native/Libraries/WebSocket/RCTWebSocket.xcodeproj"; sourceTree = ""; }; 245 | 13B07F961A680F5B00A75B9A /* device.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = device.app; sourceTree = BUILT_PRODUCTS_DIR; }; 246 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = device/AppDelegate.h; sourceTree = ""; }; 247 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = device/AppDelegate.m; sourceTree = ""; }; 248 | 13B07FB21A68108700A75B9A /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; }; 249 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = device/Images.xcassets; sourceTree = ""; }; 250 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = device/Info.plist; sourceTree = ""; }; 251 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = device/main.m; sourceTree = ""; }; 252 | 146833FF1AC3E56700842450 /* React.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = React.xcodeproj; path = "../node_modules/react-native/React/React.xcodeproj"; sourceTree = ""; }; 253 | 2D02E47B1E0B4A5D006451C7 /* device-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "device-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; }; 254 | 2D02E4901E0B4A5D006451C7 /* device-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "device-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; }; 255 | 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTAnimation.xcodeproj; path = "../node_modules/react-native/Libraries/NativeAnimation/RCTAnimation.xcodeproj"; sourceTree = ""; }; 256 | 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTLinking.xcodeproj; path = "../node_modules/react-native/Libraries/LinkingIOS/RCTLinking.xcodeproj"; sourceTree = ""; }; 257 | 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTText.xcodeproj; path = "../node_modules/react-native/Libraries/Text/RCTText.xcodeproj"; sourceTree = ""; }; 258 | 9EC0D4051DC54FD79054ED93 /* RNSVG.xcodeproj */ = {isa = PBXFileReference; name = "RNSVG.xcodeproj"; path = "../node_modules/react-native-svg/ios/RNSVG.xcodeproj"; sourceTree = ""; fileEncoding = undefined; lastKnownFileType = wrapper.pb-project; explicitFileType = undefined; includeInIndex = 0; }; 259 | 539EAC96AFEE4E44991B0E97 /* libRNSVG.a */ = {isa = PBXFileReference; name = "libRNSVG.a"; path = "libRNSVG.a"; sourceTree = ""; fileEncoding = undefined; lastKnownFileType = archive.ar; explicitFileType = undefined; includeInIndex = 0; }; 260 | /* End PBXFileReference section */ 261 | 262 | /* Begin PBXFrameworksBuildPhase section */ 263 | 00E356EB1AD99517003FC87E /* Frameworks */ = { 264 | isa = PBXFrameworksBuildPhase; 265 | buildActionMask = 2147483647; 266 | files = ( 267 | 140ED2AC1D01E1AD002B40FF /* libReact.a in Frameworks */, 268 | ); 269 | runOnlyForDeploymentPostprocessing = 0; 270 | }; 271 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = { 272 | isa = PBXFrameworksBuildPhase; 273 | buildActionMask = 2147483647; 274 | files = ( 275 | 146834051AC3E58100842450 /* libReact.a in Frameworks */, 276 | 5E9157361DD0AC6A00FF2AA8 /* libRCTAnimation.a in Frameworks */, 277 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */, 278 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */, 279 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */, 280 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */, 281 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */, 282 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */, 283 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */, 284 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */, 285 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */, 286 | 9590E3077481453E878EAB5C /* libRNSVG.a in Frameworks */, 287 | ); 288 | runOnlyForDeploymentPostprocessing = 0; 289 | }; 290 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = { 291 | isa = PBXFrameworksBuildPhase; 292 | buildActionMask = 2147483647; 293 | files = ( 294 | 2D02E4C91E0B4AEC006451C7 /* libReact.a in Frameworks */, 295 | 2D02E4C21E0B4AEC006451C7 /* libRCTAnimation-tvOS.a in Frameworks */, 296 | 2D02E4C31E0B4AEC006451C7 /* libRCTImage-tvOS.a in Frameworks */, 297 | 2D02E4C41E0B4AEC006451C7 /* libRCTLinking-tvOS.a in Frameworks */, 298 | 2D02E4C51E0B4AEC006451C7 /* libRCTNetwork-tvOS.a in Frameworks */, 299 | 2D02E4C61E0B4AEC006451C7 /* libRCTSettings-tvOS.a in Frameworks */, 300 | 2D02E4C71E0B4AEC006451C7 /* libRCTText-tvOS.a in Frameworks */, 301 | 2D02E4C81E0B4AEC006451C7 /* libRCTWebSocket-tvOS.a in Frameworks */, 302 | ); 303 | runOnlyForDeploymentPostprocessing = 0; 304 | }; 305 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = { 306 | isa = PBXFrameworksBuildPhase; 307 | buildActionMask = 2147483647; 308 | files = ( 309 | ); 310 | runOnlyForDeploymentPostprocessing = 0; 311 | }; 312 | /* End PBXFrameworksBuildPhase section */ 313 | 314 | /* Begin PBXGroup section */ 315 | 00C302A81ABCB8CE00DB3ED1 /* Products */ = { 316 | isa = PBXGroup; 317 | children = ( 318 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */, 319 | ); 320 | name = Products; 321 | sourceTree = ""; 322 | }; 323 | 00C302B61ABCB90400DB3ED1 /* Products */ = { 324 | isa = PBXGroup; 325 | children = ( 326 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */, 327 | ); 328 | name = Products; 329 | sourceTree = ""; 330 | }; 331 | 00C302BC1ABCB91800DB3ED1 /* Products */ = { 332 | isa = PBXGroup; 333 | children = ( 334 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */, 335 | 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */, 336 | ); 337 | name = Products; 338 | sourceTree = ""; 339 | }; 340 | 00C302D41ABCB9D200DB3ED1 /* Products */ = { 341 | isa = PBXGroup; 342 | children = ( 343 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */, 344 | 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */, 345 | ); 346 | name = Products; 347 | sourceTree = ""; 348 | }; 349 | 00C302E01ABCB9EE00DB3ED1 /* Products */ = { 350 | isa = PBXGroup; 351 | children = ( 352 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */, 353 | ); 354 | name = Products; 355 | sourceTree = ""; 356 | }; 357 | 00E356EF1AD99517003FC87E /* deviceTests */ = { 358 | isa = PBXGroup; 359 | children = ( 360 | 00E356F21AD99517003FC87E /* deviceTests.m */, 361 | 00E356F01AD99517003FC87E /* Supporting Files */, 362 | ); 363 | path = deviceTests; 364 | sourceTree = ""; 365 | }; 366 | 00E356F01AD99517003FC87E /* Supporting Files */ = { 367 | isa = PBXGroup; 368 | children = ( 369 | 00E356F11AD99517003FC87E /* Info.plist */, 370 | ); 371 | name = "Supporting Files"; 372 | sourceTree = ""; 373 | }; 374 | 139105B71AF99BAD00B5F7CC /* Products */ = { 375 | isa = PBXGroup; 376 | children = ( 377 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */, 378 | 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */, 379 | ); 380 | name = Products; 381 | sourceTree = ""; 382 | }; 383 | 139FDEE71B06529A00C62182 /* Products */ = { 384 | isa = PBXGroup; 385 | children = ( 386 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */, 387 | 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */, 388 | ); 389 | name = Products; 390 | sourceTree = ""; 391 | }; 392 | 13B07FAE1A68108700A75B9A /* device */ = { 393 | isa = PBXGroup; 394 | children = ( 395 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */, 396 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */, 397 | 13B07FB01A68108700A75B9A /* AppDelegate.m */, 398 | 13B07FB51A68108700A75B9A /* Images.xcassets */, 399 | 13B07FB61A68108700A75B9A /* Info.plist */, 400 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */, 401 | 13B07FB71A68108700A75B9A /* main.m */, 402 | ); 403 | name = device; 404 | sourceTree = ""; 405 | }; 406 | 146834001AC3E56700842450 /* Products */ = { 407 | isa = PBXGroup; 408 | children = ( 409 | 146834041AC3E56700842450 /* libReact.a */, 410 | 3DAD3EA31DF850E9000B6D8A /* libReact.a */, 411 | 3DAD3EA51DF850E9000B6D8A /* libyoga.a */, 412 | 3DAD3EA71DF850E9000B6D8A /* libyoga.a */, 413 | 3DAD3EA91DF850E9000B6D8A /* libcxxreact.a */, 414 | 3DAD3EAB1DF850E9000B6D8A /* libcxxreact.a */, 415 | 3DAD3EAD1DF850E9000B6D8A /* libjschelpers.a */, 416 | 3DAD3EAF1DF850E9000B6D8A /* libjschelpers.a */, 417 | ); 418 | name = Products; 419 | sourceTree = ""; 420 | }; 421 | 5E91572E1DD0AC6500FF2AA8 /* Products */ = { 422 | isa = PBXGroup; 423 | children = ( 424 | 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */, 425 | 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */, 426 | ); 427 | name = Products; 428 | sourceTree = ""; 429 | }; 430 | 78C398B11ACF4ADC00677621 /* Products */ = { 431 | isa = PBXGroup; 432 | children = ( 433 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */, 434 | 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */, 435 | ); 436 | name = Products; 437 | sourceTree = ""; 438 | }; 439 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = { 440 | isa = PBXGroup; 441 | children = ( 442 | 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */, 443 | 146833FF1AC3E56700842450 /* React.xcodeproj */, 444 | 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */, 445 | 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */, 446 | 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */, 447 | 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */, 448 | 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */, 449 | 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */, 450 | 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */, 451 | 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */, 452 | 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */, 453 | 9EC0D4051DC54FD79054ED93 /* RNSVG.xcodeproj */, 454 | ); 455 | name = Libraries; 456 | sourceTree = ""; 457 | }; 458 | 832341B11AAA6A8300B99B32 /* Products */ = { 459 | isa = PBXGroup; 460 | children = ( 461 | 832341B51AAA6A8300B99B32 /* libRCTText.a */, 462 | 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */, 463 | ); 464 | name = Products; 465 | sourceTree = ""; 466 | }; 467 | 83CBB9F61A601CBA00E9B192 = { 468 | isa = PBXGroup; 469 | children = ( 470 | 13B07FAE1A68108700A75B9A /* device */, 471 | 832341AE1AAA6A7D00B99B32 /* Libraries */, 472 | 00E356EF1AD99517003FC87E /* deviceTests */, 473 | 83CBBA001A601CBA00E9B192 /* Products */, 474 | ); 475 | indentWidth = 2; 476 | sourceTree = ""; 477 | tabWidth = 2; 478 | }; 479 | 83CBBA001A601CBA00E9B192 /* Products */ = { 480 | isa = PBXGroup; 481 | children = ( 482 | 13B07F961A680F5B00A75B9A /* device.app */, 483 | 00E356EE1AD99517003FC87E /* deviceTests.xctest */, 484 | 2D02E47B1E0B4A5D006451C7 /* device-tvOS.app */, 485 | 2D02E4901E0B4A5D006451C7 /* device-tvOSTests.xctest */, 486 | ); 487 | name = Products; 488 | sourceTree = ""; 489 | }; 490 | /* End PBXGroup section */ 491 | 492 | /* Begin PBXNativeTarget section */ 493 | 00E356ED1AD99517003FC87E /* deviceTests */ = { 494 | isa = PBXNativeTarget; 495 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "deviceTests" */; 496 | buildPhases = ( 497 | 00E356EA1AD99517003FC87E /* Sources */, 498 | 00E356EB1AD99517003FC87E /* Frameworks */, 499 | 00E356EC1AD99517003FC87E /* Resources */, 500 | ); 501 | buildRules = ( 502 | ); 503 | dependencies = ( 504 | 00E356F51AD99517003FC87E /* PBXTargetDependency */, 505 | ); 506 | name = deviceTests; 507 | productName = deviceTests; 508 | productReference = 00E356EE1AD99517003FC87E /* deviceTests.xctest */; 509 | productType = "com.apple.product-type.bundle.unit-test"; 510 | }; 511 | 13B07F861A680F5B00A75B9A /* device */ = { 512 | isa = PBXNativeTarget; 513 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "device" */; 514 | buildPhases = ( 515 | 13B07F871A680F5B00A75B9A /* Sources */, 516 | 13B07F8C1A680F5B00A75B9A /* Frameworks */, 517 | 13B07F8E1A680F5B00A75B9A /* Resources */, 518 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */, 519 | ); 520 | buildRules = ( 521 | ); 522 | dependencies = ( 523 | ); 524 | name = device; 525 | productName = "Hello World"; 526 | productReference = 13B07F961A680F5B00A75B9A /* device.app */; 527 | productType = "com.apple.product-type.application"; 528 | }; 529 | 2D02E47A1E0B4A5D006451C7 /* device-tvOS */ = { 530 | isa = PBXNativeTarget; 531 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "device-tvOS" */; 532 | buildPhases = ( 533 | 2D02E4771E0B4A5D006451C7 /* Sources */, 534 | 2D02E4781E0B4A5D006451C7 /* Frameworks */, 535 | 2D02E4791E0B4A5D006451C7 /* Resources */, 536 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */, 537 | ); 538 | buildRules = ( 539 | ); 540 | dependencies = ( 541 | ); 542 | name = "device-tvOS"; 543 | productName = "device-tvOS"; 544 | productReference = 2D02E47B1E0B4A5D006451C7 /* device-tvOS.app */; 545 | productType = "com.apple.product-type.application"; 546 | }; 547 | 2D02E48F1E0B4A5D006451C7 /* device-tvOSTests */ = { 548 | isa = PBXNativeTarget; 549 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "device-tvOSTests" */; 550 | buildPhases = ( 551 | 2D02E48C1E0B4A5D006451C7 /* Sources */, 552 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */, 553 | 2D02E48E1E0B4A5D006451C7 /* Resources */, 554 | ); 555 | buildRules = ( 556 | ); 557 | dependencies = ( 558 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */, 559 | ); 560 | name = "device-tvOSTests"; 561 | productName = "device-tvOSTests"; 562 | productReference = 2D02E4901E0B4A5D006451C7 /* device-tvOSTests.xctest */; 563 | productType = "com.apple.product-type.bundle.unit-test"; 564 | }; 565 | /* End PBXNativeTarget section */ 566 | 567 | /* Begin PBXProject section */ 568 | 83CBB9F71A601CBA00E9B192 /* Project object */ = { 569 | isa = PBXProject; 570 | attributes = { 571 | LastUpgradeCheck = 610; 572 | ORGANIZATIONNAME = Facebook; 573 | TargetAttributes = { 574 | 00E356ED1AD99517003FC87E = { 575 | CreatedOnToolsVersion = 6.2; 576 | TestTargetID = 13B07F861A680F5B00A75B9A; 577 | }; 578 | 2D02E47A1E0B4A5D006451C7 = { 579 | CreatedOnToolsVersion = 8.2.1; 580 | ProvisioningStyle = Automatic; 581 | }; 582 | 2D02E48F1E0B4A5D006451C7 = { 583 | CreatedOnToolsVersion = 8.2.1; 584 | ProvisioningStyle = Automatic; 585 | TestTargetID = 2D02E47A1E0B4A5D006451C7; 586 | }; 587 | }; 588 | }; 589 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "device" */; 590 | compatibilityVersion = "Xcode 3.2"; 591 | developmentRegion = English; 592 | hasScannedForEncodings = 0; 593 | knownRegions = ( 594 | en, 595 | Base, 596 | ); 597 | mainGroup = 83CBB9F61A601CBA00E9B192; 598 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */; 599 | projectDirPath = ""; 600 | projectReferences = ( 601 | { 602 | ProductGroup = 00C302A81ABCB8CE00DB3ED1 /* Products */; 603 | ProjectRef = 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */; 604 | }, 605 | { 606 | ProductGroup = 5E91572E1DD0AC6500FF2AA8 /* Products */; 607 | ProjectRef = 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */; 608 | }, 609 | { 610 | ProductGroup = 00C302B61ABCB90400DB3ED1 /* Products */; 611 | ProjectRef = 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */; 612 | }, 613 | { 614 | ProductGroup = 00C302BC1ABCB91800DB3ED1 /* Products */; 615 | ProjectRef = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */; 616 | }, 617 | { 618 | ProductGroup = 78C398B11ACF4ADC00677621 /* Products */; 619 | ProjectRef = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */; 620 | }, 621 | { 622 | ProductGroup = 00C302D41ABCB9D200DB3ED1 /* Products */; 623 | ProjectRef = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */; 624 | }, 625 | { 626 | ProductGroup = 139105B71AF99BAD00B5F7CC /* Products */; 627 | ProjectRef = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */; 628 | }, 629 | { 630 | ProductGroup = 832341B11AAA6A8300B99B32 /* Products */; 631 | ProjectRef = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */; 632 | }, 633 | { 634 | ProductGroup = 00C302E01ABCB9EE00DB3ED1 /* Products */; 635 | ProjectRef = 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */; 636 | }, 637 | { 638 | ProductGroup = 139FDEE71B06529A00C62182 /* Products */; 639 | ProjectRef = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */; 640 | }, 641 | { 642 | ProductGroup = 146834001AC3E56700842450 /* Products */; 643 | ProjectRef = 146833FF1AC3E56700842450 /* React.xcodeproj */; 644 | }, 645 | ); 646 | projectRoot = ""; 647 | targets = ( 648 | 13B07F861A680F5B00A75B9A /* device */, 649 | 00E356ED1AD99517003FC87E /* deviceTests */, 650 | 2D02E47A1E0B4A5D006451C7 /* device-tvOS */, 651 | 2D02E48F1E0B4A5D006451C7 /* device-tvOSTests */, 652 | ); 653 | }; 654 | /* End PBXProject section */ 655 | 656 | /* Begin PBXReferenceProxy section */ 657 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */ = { 658 | isa = PBXReferenceProxy; 659 | fileType = archive.ar; 660 | path = libRCTActionSheet.a; 661 | remoteRef = 00C302AB1ABCB8CE00DB3ED1 /* PBXContainerItemProxy */; 662 | sourceTree = BUILT_PRODUCTS_DIR; 663 | }; 664 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */ = { 665 | isa = PBXReferenceProxy; 666 | fileType = archive.ar; 667 | path = libRCTGeolocation.a; 668 | remoteRef = 00C302B91ABCB90400DB3ED1 /* PBXContainerItemProxy */; 669 | sourceTree = BUILT_PRODUCTS_DIR; 670 | }; 671 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */ = { 672 | isa = PBXReferenceProxy; 673 | fileType = archive.ar; 674 | path = libRCTImage.a; 675 | remoteRef = 00C302BF1ABCB91800DB3ED1 /* PBXContainerItemProxy */; 676 | sourceTree = BUILT_PRODUCTS_DIR; 677 | }; 678 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */ = { 679 | isa = PBXReferenceProxy; 680 | fileType = archive.ar; 681 | path = libRCTNetwork.a; 682 | remoteRef = 00C302DB1ABCB9D200DB3ED1 /* PBXContainerItemProxy */; 683 | sourceTree = BUILT_PRODUCTS_DIR; 684 | }; 685 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */ = { 686 | isa = PBXReferenceProxy; 687 | fileType = archive.ar; 688 | path = libRCTVibration.a; 689 | remoteRef = 00C302E31ABCB9EE00DB3ED1 /* PBXContainerItemProxy */; 690 | sourceTree = BUILT_PRODUCTS_DIR; 691 | }; 692 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */ = { 693 | isa = PBXReferenceProxy; 694 | fileType = archive.ar; 695 | path = libRCTSettings.a; 696 | remoteRef = 139105C01AF99BAD00B5F7CC /* PBXContainerItemProxy */; 697 | sourceTree = BUILT_PRODUCTS_DIR; 698 | }; 699 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */ = { 700 | isa = PBXReferenceProxy; 701 | fileType = archive.ar; 702 | path = libRCTWebSocket.a; 703 | remoteRef = 139FDEF31B06529B00C62182 /* PBXContainerItemProxy */; 704 | sourceTree = BUILT_PRODUCTS_DIR; 705 | }; 706 | 146834041AC3E56700842450 /* libReact.a */ = { 707 | isa = PBXReferenceProxy; 708 | fileType = archive.ar; 709 | path = libReact.a; 710 | remoteRef = 146834031AC3E56700842450 /* PBXContainerItemProxy */; 711 | sourceTree = BUILT_PRODUCTS_DIR; 712 | }; 713 | 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */ = { 714 | isa = PBXReferenceProxy; 715 | fileType = archive.ar; 716 | path = "libRCTImage-tvOS.a"; 717 | remoteRef = 3DAD3E831DF850E9000B6D8A /* PBXContainerItemProxy */; 718 | sourceTree = BUILT_PRODUCTS_DIR; 719 | }; 720 | 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */ = { 721 | isa = PBXReferenceProxy; 722 | fileType = archive.ar; 723 | path = "libRCTLinking-tvOS.a"; 724 | remoteRef = 3DAD3E871DF850E9000B6D8A /* PBXContainerItemProxy */; 725 | sourceTree = BUILT_PRODUCTS_DIR; 726 | }; 727 | 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */ = { 728 | isa = PBXReferenceProxy; 729 | fileType = archive.ar; 730 | path = "libRCTNetwork-tvOS.a"; 731 | remoteRef = 3DAD3E8B1DF850E9000B6D8A /* PBXContainerItemProxy */; 732 | sourceTree = BUILT_PRODUCTS_DIR; 733 | }; 734 | 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */ = { 735 | isa = PBXReferenceProxy; 736 | fileType = archive.ar; 737 | path = "libRCTSettings-tvOS.a"; 738 | remoteRef = 3DAD3E8F1DF850E9000B6D8A /* PBXContainerItemProxy */; 739 | sourceTree = BUILT_PRODUCTS_DIR; 740 | }; 741 | 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */ = { 742 | isa = PBXReferenceProxy; 743 | fileType = archive.ar; 744 | path = "libRCTText-tvOS.a"; 745 | remoteRef = 3DAD3E931DF850E9000B6D8A /* PBXContainerItemProxy */; 746 | sourceTree = BUILT_PRODUCTS_DIR; 747 | }; 748 | 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */ = { 749 | isa = PBXReferenceProxy; 750 | fileType = archive.ar; 751 | path = "libRCTWebSocket-tvOS.a"; 752 | remoteRef = 3DAD3E981DF850E9000B6D8A /* PBXContainerItemProxy */; 753 | sourceTree = BUILT_PRODUCTS_DIR; 754 | }; 755 | 3DAD3EA31DF850E9000B6D8A /* libReact.a */ = { 756 | isa = PBXReferenceProxy; 757 | fileType = archive.ar; 758 | path = libReact.a; 759 | remoteRef = 3DAD3EA21DF850E9000B6D8A /* PBXContainerItemProxy */; 760 | sourceTree = BUILT_PRODUCTS_DIR; 761 | }; 762 | 3DAD3EA51DF850E9000B6D8A /* libyoga.a */ = { 763 | isa = PBXReferenceProxy; 764 | fileType = archive.ar; 765 | path = libyoga.a; 766 | remoteRef = 3DAD3EA41DF850E9000B6D8A /* PBXContainerItemProxy */; 767 | sourceTree = BUILT_PRODUCTS_DIR; 768 | }; 769 | 3DAD3EA71DF850E9000B6D8A /* libyoga.a */ = { 770 | isa = PBXReferenceProxy; 771 | fileType = archive.ar; 772 | path = libyoga.a; 773 | remoteRef = 3DAD3EA61DF850E9000B6D8A /* PBXContainerItemProxy */; 774 | sourceTree = BUILT_PRODUCTS_DIR; 775 | }; 776 | 3DAD3EA91DF850E9000B6D8A /* libcxxreact.a */ = { 777 | isa = PBXReferenceProxy; 778 | fileType = archive.ar; 779 | path = libcxxreact.a; 780 | remoteRef = 3DAD3EA81DF850E9000B6D8A /* PBXContainerItemProxy */; 781 | sourceTree = BUILT_PRODUCTS_DIR; 782 | }; 783 | 3DAD3EAB1DF850E9000B6D8A /* libcxxreact.a */ = { 784 | isa = PBXReferenceProxy; 785 | fileType = archive.ar; 786 | path = libcxxreact.a; 787 | remoteRef = 3DAD3EAA1DF850E9000B6D8A /* PBXContainerItemProxy */; 788 | sourceTree = BUILT_PRODUCTS_DIR; 789 | }; 790 | 3DAD3EAD1DF850E9000B6D8A /* libjschelpers.a */ = { 791 | isa = PBXReferenceProxy; 792 | fileType = archive.ar; 793 | path = libjschelpers.a; 794 | remoteRef = 3DAD3EAC1DF850E9000B6D8A /* PBXContainerItemProxy */; 795 | sourceTree = BUILT_PRODUCTS_DIR; 796 | }; 797 | 3DAD3EAF1DF850E9000B6D8A /* libjschelpers.a */ = { 798 | isa = PBXReferenceProxy; 799 | fileType = archive.ar; 800 | path = libjschelpers.a; 801 | remoteRef = 3DAD3EAE1DF850E9000B6D8A /* PBXContainerItemProxy */; 802 | sourceTree = BUILT_PRODUCTS_DIR; 803 | }; 804 | 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */ = { 805 | isa = PBXReferenceProxy; 806 | fileType = archive.ar; 807 | path = libRCTAnimation.a; 808 | remoteRef = 5E9157321DD0AC6500FF2AA8 /* PBXContainerItemProxy */; 809 | sourceTree = BUILT_PRODUCTS_DIR; 810 | }; 811 | 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */ = { 812 | isa = PBXReferenceProxy; 813 | fileType = archive.ar; 814 | path = "libRCTAnimation-tvOS.a"; 815 | remoteRef = 5E9157341DD0AC6500FF2AA8 /* PBXContainerItemProxy */; 816 | sourceTree = BUILT_PRODUCTS_DIR; 817 | }; 818 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */ = { 819 | isa = PBXReferenceProxy; 820 | fileType = archive.ar; 821 | path = libRCTLinking.a; 822 | remoteRef = 78C398B81ACF4ADC00677621 /* PBXContainerItemProxy */; 823 | sourceTree = BUILT_PRODUCTS_DIR; 824 | }; 825 | 832341B51AAA6A8300B99B32 /* libRCTText.a */ = { 826 | isa = PBXReferenceProxy; 827 | fileType = archive.ar; 828 | path = libRCTText.a; 829 | remoteRef = 832341B41AAA6A8300B99B32 /* PBXContainerItemProxy */; 830 | sourceTree = BUILT_PRODUCTS_DIR; 831 | }; 832 | /* End PBXReferenceProxy section */ 833 | 834 | /* Begin PBXResourcesBuildPhase section */ 835 | 00E356EC1AD99517003FC87E /* Resources */ = { 836 | isa = PBXResourcesBuildPhase; 837 | buildActionMask = 2147483647; 838 | files = ( 839 | ); 840 | runOnlyForDeploymentPostprocessing = 0; 841 | }; 842 | 13B07F8E1A680F5B00A75B9A /* Resources */ = { 843 | isa = PBXResourcesBuildPhase; 844 | buildActionMask = 2147483647; 845 | files = ( 846 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */, 847 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */, 848 | ); 849 | runOnlyForDeploymentPostprocessing = 0; 850 | }; 851 | 2D02E4791E0B4A5D006451C7 /* Resources */ = { 852 | isa = PBXResourcesBuildPhase; 853 | buildActionMask = 2147483647; 854 | files = ( 855 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */, 856 | ); 857 | runOnlyForDeploymentPostprocessing = 0; 858 | }; 859 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = { 860 | isa = PBXResourcesBuildPhase; 861 | buildActionMask = 2147483647; 862 | files = ( 863 | ); 864 | runOnlyForDeploymentPostprocessing = 0; 865 | }; 866 | /* End PBXResourcesBuildPhase section */ 867 | 868 | /* Begin PBXShellScriptBuildPhase section */ 869 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = { 870 | isa = PBXShellScriptBuildPhase; 871 | buildActionMask = 2147483647; 872 | files = ( 873 | ); 874 | inputPaths = ( 875 | ); 876 | name = "Bundle React Native code and images"; 877 | outputPaths = ( 878 | ); 879 | runOnlyForDeploymentPostprocessing = 0; 880 | shellPath = /bin/sh; 881 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/packager/react-native-xcode.sh"; 882 | }; 883 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = { 884 | isa = PBXShellScriptBuildPhase; 885 | buildActionMask = 2147483647; 886 | files = ( 887 | ); 888 | inputPaths = ( 889 | ); 890 | name = "Bundle React Native Code And Images"; 891 | outputPaths = ( 892 | ); 893 | runOnlyForDeploymentPostprocessing = 0; 894 | shellPath = /bin/sh; 895 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/packager/react-native-xcode.sh"; 896 | }; 897 | /* End PBXShellScriptBuildPhase section */ 898 | 899 | /* Begin PBXSourcesBuildPhase section */ 900 | 00E356EA1AD99517003FC87E /* Sources */ = { 901 | isa = PBXSourcesBuildPhase; 902 | buildActionMask = 2147483647; 903 | files = ( 904 | 00E356F31AD99517003FC87E /* deviceTests.m in Sources */, 905 | ); 906 | runOnlyForDeploymentPostprocessing = 0; 907 | }; 908 | 13B07F871A680F5B00A75B9A /* Sources */ = { 909 | isa = PBXSourcesBuildPhase; 910 | buildActionMask = 2147483647; 911 | files = ( 912 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */, 913 | 13B07FC11A68108700A75B9A /* main.m in Sources */, 914 | ); 915 | runOnlyForDeploymentPostprocessing = 0; 916 | }; 917 | 2D02E4771E0B4A5D006451C7 /* Sources */ = { 918 | isa = PBXSourcesBuildPhase; 919 | buildActionMask = 2147483647; 920 | files = ( 921 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */, 922 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */, 923 | ); 924 | runOnlyForDeploymentPostprocessing = 0; 925 | }; 926 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = { 927 | isa = PBXSourcesBuildPhase; 928 | buildActionMask = 2147483647; 929 | files = ( 930 | 2DCD954D1E0B4F2C00145EB5 /* deviceTests.m in Sources */, 931 | ); 932 | runOnlyForDeploymentPostprocessing = 0; 933 | }; 934 | /* End PBXSourcesBuildPhase section */ 935 | 936 | /* Begin PBXTargetDependency section */ 937 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = { 938 | isa = PBXTargetDependency; 939 | target = 13B07F861A680F5B00A75B9A /* device */; 940 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */; 941 | }; 942 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = { 943 | isa = PBXTargetDependency; 944 | target = 2D02E47A1E0B4A5D006451C7 /* device-tvOS */; 945 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */; 946 | }; 947 | /* End PBXTargetDependency section */ 948 | 949 | /* Begin PBXVariantGroup section */ 950 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = { 951 | isa = PBXVariantGroup; 952 | children = ( 953 | 13B07FB21A68108700A75B9A /* Base */, 954 | ); 955 | name = LaunchScreen.xib; 956 | path = device; 957 | sourceTree = ""; 958 | }; 959 | /* End PBXVariantGroup section */ 960 | 961 | /* Begin XCBuildConfiguration section */ 962 | 00E356F61AD99517003FC87E /* Debug */ = { 963 | isa = XCBuildConfiguration; 964 | buildSettings = { 965 | BUNDLE_LOADER = "$(TEST_HOST)"; 966 | GCC_PREPROCESSOR_DEFINITIONS = ( 967 | "DEBUG=1", 968 | "$(inherited)", 969 | ); 970 | INFOPLIST_FILE = deviceTests/Info.plist; 971 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 972 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 973 | OTHER_LDFLAGS = ( 974 | "-ObjC", 975 | "-lc++", 976 | ); 977 | PRODUCT_NAME = "$(TARGET_NAME)"; 978 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/device.app/device"; 979 | LIBRARY_SEARCH_PATHS = ( 980 | "$(inherited)", 981 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 982 | ); 983 | HEADER_SEARCH_PATHS = ( 984 | "$(inherited)", 985 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 986 | ); 987 | }; 988 | name = Debug; 989 | }; 990 | 00E356F71AD99517003FC87E /* Release */ = { 991 | isa = XCBuildConfiguration; 992 | buildSettings = { 993 | BUNDLE_LOADER = "$(TEST_HOST)"; 994 | COPY_PHASE_STRIP = NO; 995 | INFOPLIST_FILE = deviceTests/Info.plist; 996 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 997 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 998 | OTHER_LDFLAGS = ( 999 | "-ObjC", 1000 | "-lc++", 1001 | ); 1002 | PRODUCT_NAME = "$(TARGET_NAME)"; 1003 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/device.app/device"; 1004 | LIBRARY_SEARCH_PATHS = ( 1005 | "$(inherited)", 1006 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 1007 | ); 1008 | HEADER_SEARCH_PATHS = ( 1009 | "$(inherited)", 1010 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 1011 | ); 1012 | }; 1013 | name = Release; 1014 | }; 1015 | 13B07F941A680F5B00A75B9A /* Debug */ = { 1016 | isa = XCBuildConfiguration; 1017 | buildSettings = { 1018 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 1019 | CURRENT_PROJECT_VERSION = 1; 1020 | DEAD_CODE_STRIPPING = NO; 1021 | INFOPLIST_FILE = device/Info.plist; 1022 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1023 | OTHER_LDFLAGS = ( 1024 | "$(inherited)", 1025 | "-ObjC", 1026 | "-lc++", 1027 | ); 1028 | PRODUCT_NAME = device; 1029 | VERSIONING_SYSTEM = "apple-generic"; 1030 | HEADER_SEARCH_PATHS = ( 1031 | "$(inherited)", 1032 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 1033 | ); 1034 | }; 1035 | name = Debug; 1036 | }; 1037 | 13B07F951A680F5B00A75B9A /* Release */ = { 1038 | isa = XCBuildConfiguration; 1039 | buildSettings = { 1040 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 1041 | CURRENT_PROJECT_VERSION = 1; 1042 | INFOPLIST_FILE = device/Info.plist; 1043 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1044 | OTHER_LDFLAGS = ( 1045 | "$(inherited)", 1046 | "-ObjC", 1047 | "-lc++", 1048 | ); 1049 | PRODUCT_NAME = device; 1050 | VERSIONING_SYSTEM = "apple-generic"; 1051 | HEADER_SEARCH_PATHS = ( 1052 | "$(inherited)", 1053 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 1054 | ); 1055 | }; 1056 | name = Release; 1057 | }; 1058 | 2D02E4971E0B4A5E006451C7 /* Debug */ = { 1059 | isa = XCBuildConfiguration; 1060 | buildSettings = { 1061 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 1062 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1063 | CLANG_ANALYZER_NONNULL = YES; 1064 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1065 | CLANG_WARN_INFINITE_RECURSION = YES; 1066 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1067 | DEBUG_INFORMATION_FORMAT = dwarf; 1068 | ENABLE_TESTABILITY = YES; 1069 | GCC_NO_COMMON_BLOCKS = YES; 1070 | INFOPLIST_FILE = "device-tvOS/Info.plist"; 1071 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1072 | OTHER_LDFLAGS = ( 1073 | "-ObjC", 1074 | "-lc++", 1075 | ); 1076 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.device-tvOS"; 1077 | PRODUCT_NAME = "$(TARGET_NAME)"; 1078 | SDKROOT = appletvos; 1079 | TARGETED_DEVICE_FAMILY = 3; 1080 | TVOS_DEPLOYMENT_TARGET = 9.2; 1081 | LIBRARY_SEARCH_PATHS = ( 1082 | "$(inherited)", 1083 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 1084 | ); 1085 | HEADER_SEARCH_PATHS = ( 1086 | "$(inherited)", 1087 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 1088 | ); 1089 | }; 1090 | name = Debug; 1091 | }; 1092 | 2D02E4981E0B4A5E006451C7 /* Release */ = { 1093 | isa = XCBuildConfiguration; 1094 | buildSettings = { 1095 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 1096 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1097 | CLANG_ANALYZER_NONNULL = YES; 1098 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1099 | CLANG_WARN_INFINITE_RECURSION = YES; 1100 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1101 | COPY_PHASE_STRIP = NO; 1102 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 1103 | GCC_NO_COMMON_BLOCKS = YES; 1104 | INFOPLIST_FILE = "device-tvOS/Info.plist"; 1105 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1106 | OTHER_LDFLAGS = ( 1107 | "-ObjC", 1108 | "-lc++", 1109 | ); 1110 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.device-tvOS"; 1111 | PRODUCT_NAME = "$(TARGET_NAME)"; 1112 | SDKROOT = appletvos; 1113 | TARGETED_DEVICE_FAMILY = 3; 1114 | TVOS_DEPLOYMENT_TARGET = 9.2; 1115 | LIBRARY_SEARCH_PATHS = ( 1116 | "$(inherited)", 1117 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 1118 | ); 1119 | HEADER_SEARCH_PATHS = ( 1120 | "$(inherited)", 1121 | "$(SRCROOT)/../node_modules/react-native-svg/ios/**", 1122 | ); 1123 | }; 1124 | name = Release; 1125 | }; 1126 | 2D02E4991E0B4A5E006451C7 /* Debug */ = { 1127 | isa = XCBuildConfiguration; 1128 | buildSettings = { 1129 | BUNDLE_LOADER = "$(TEST_HOST)"; 1130 | CLANG_ANALYZER_NONNULL = YES; 1131 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1132 | CLANG_WARN_INFINITE_RECURSION = YES; 1133 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1134 | DEBUG_INFORMATION_FORMAT = dwarf; 1135 | ENABLE_TESTABILITY = YES; 1136 | GCC_NO_COMMON_BLOCKS = YES; 1137 | INFOPLIST_FILE = "device-tvOSTests/Info.plist"; 1138 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 1139 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.device-tvOSTests"; 1140 | PRODUCT_NAME = "$(TARGET_NAME)"; 1141 | SDKROOT = appletvos; 1142 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/device-tvOS.app/device-tvOS"; 1143 | TVOS_DEPLOYMENT_TARGET = 10.1; 1144 | LIBRARY_SEARCH_PATHS = ( 1145 | "$(inherited)", 1146 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 1147 | ); 1148 | }; 1149 | name = Debug; 1150 | }; 1151 | 2D02E49A1E0B4A5E006451C7 /* Release */ = { 1152 | isa = XCBuildConfiguration; 1153 | buildSettings = { 1154 | BUNDLE_LOADER = "$(TEST_HOST)"; 1155 | CLANG_ANALYZER_NONNULL = YES; 1156 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1157 | CLANG_WARN_INFINITE_RECURSION = YES; 1158 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1159 | COPY_PHASE_STRIP = NO; 1160 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 1161 | GCC_NO_COMMON_BLOCKS = YES; 1162 | INFOPLIST_FILE = "device-tvOSTests/Info.plist"; 1163 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 1164 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.device-tvOSTests"; 1165 | PRODUCT_NAME = "$(TARGET_NAME)"; 1166 | SDKROOT = appletvos; 1167 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/device-tvOS.app/device-tvOS"; 1168 | TVOS_DEPLOYMENT_TARGET = 10.1; 1169 | LIBRARY_SEARCH_PATHS = ( 1170 | "$(inherited)", 1171 | "\"$(SRCROOT)/$(TARGET_NAME)\"", 1172 | ); 1173 | }; 1174 | name = Release; 1175 | }; 1176 | 83CBBA201A601CBA00E9B192 /* Debug */ = { 1177 | isa = XCBuildConfiguration; 1178 | buildSettings = { 1179 | ALWAYS_SEARCH_USER_PATHS = NO; 1180 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 1181 | CLANG_CXX_LIBRARY = "libc++"; 1182 | CLANG_ENABLE_MODULES = YES; 1183 | CLANG_ENABLE_OBJC_ARC = YES; 1184 | CLANG_WARN_BOOL_CONVERSION = YES; 1185 | CLANG_WARN_CONSTANT_CONVERSION = YES; 1186 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 1187 | CLANG_WARN_EMPTY_BODY = YES; 1188 | CLANG_WARN_ENUM_CONVERSION = YES; 1189 | CLANG_WARN_INT_CONVERSION = YES; 1190 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 1191 | CLANG_WARN_UNREACHABLE_CODE = YES; 1192 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 1193 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 1194 | COPY_PHASE_STRIP = NO; 1195 | ENABLE_STRICT_OBJC_MSGSEND = YES; 1196 | GCC_C_LANGUAGE_STANDARD = gnu99; 1197 | GCC_DYNAMIC_NO_PIC = NO; 1198 | GCC_OPTIMIZATION_LEVEL = 0; 1199 | GCC_PREPROCESSOR_DEFINITIONS = ( 1200 | "DEBUG=1", 1201 | "$(inherited)", 1202 | ); 1203 | GCC_SYMBOLS_PRIVATE_EXTERN = NO; 1204 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 1205 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 1206 | GCC_WARN_UNDECLARED_SELECTOR = YES; 1207 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 1208 | GCC_WARN_UNUSED_FUNCTION = YES; 1209 | GCC_WARN_UNUSED_VARIABLE = YES; 1210 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 1211 | MTL_ENABLE_DEBUG_INFO = YES; 1212 | ONLY_ACTIVE_ARCH = YES; 1213 | SDKROOT = iphoneos; 1214 | }; 1215 | name = Debug; 1216 | }; 1217 | 83CBBA211A601CBA00E9B192 /* Release */ = { 1218 | isa = XCBuildConfiguration; 1219 | buildSettings = { 1220 | ALWAYS_SEARCH_USER_PATHS = NO; 1221 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 1222 | CLANG_CXX_LIBRARY = "libc++"; 1223 | CLANG_ENABLE_MODULES = YES; 1224 | CLANG_ENABLE_OBJC_ARC = YES; 1225 | CLANG_WARN_BOOL_CONVERSION = YES; 1226 | CLANG_WARN_CONSTANT_CONVERSION = YES; 1227 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 1228 | CLANG_WARN_EMPTY_BODY = YES; 1229 | CLANG_WARN_ENUM_CONVERSION = YES; 1230 | CLANG_WARN_INT_CONVERSION = YES; 1231 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 1232 | CLANG_WARN_UNREACHABLE_CODE = YES; 1233 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 1234 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 1235 | COPY_PHASE_STRIP = YES; 1236 | ENABLE_NS_ASSERTIONS = NO; 1237 | ENABLE_STRICT_OBJC_MSGSEND = YES; 1238 | GCC_C_LANGUAGE_STANDARD = gnu99; 1239 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 1240 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 1241 | GCC_WARN_UNDECLARED_SELECTOR = YES; 1242 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 1243 | GCC_WARN_UNUSED_FUNCTION = YES; 1244 | GCC_WARN_UNUSED_VARIABLE = YES; 1245 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 1246 | MTL_ENABLE_DEBUG_INFO = NO; 1247 | SDKROOT = iphoneos; 1248 | VALIDATE_PRODUCT = YES; 1249 | }; 1250 | name = Release; 1251 | }; 1252 | /* End XCBuildConfiguration section */ 1253 | 1254 | /* Begin XCConfigurationList section */ 1255 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "deviceTests" */ = { 1256 | isa = XCConfigurationList; 1257 | buildConfigurations = ( 1258 | 00E356F61AD99517003FC87E /* Debug */, 1259 | 00E356F71AD99517003FC87E /* Release */, 1260 | ); 1261 | defaultConfigurationIsVisible = 0; 1262 | defaultConfigurationName = Release; 1263 | }; 1264 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "device" */ = { 1265 | isa = XCConfigurationList; 1266 | buildConfigurations = ( 1267 | 13B07F941A680F5B00A75B9A /* Debug */, 1268 | 13B07F951A680F5B00A75B9A /* Release */, 1269 | ); 1270 | defaultConfigurationIsVisible = 0; 1271 | defaultConfigurationName = Release; 1272 | }; 1273 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "device-tvOS" */ = { 1274 | isa = XCConfigurationList; 1275 | buildConfigurations = ( 1276 | 2D02E4971E0B4A5E006451C7 /* Debug */, 1277 | 2D02E4981E0B4A5E006451C7 /* Release */, 1278 | ); 1279 | defaultConfigurationIsVisible = 0; 1280 | defaultConfigurationName = Release; 1281 | }; 1282 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "device-tvOSTests" */ = { 1283 | isa = XCConfigurationList; 1284 | buildConfigurations = ( 1285 | 2D02E4991E0B4A5E006451C7 /* Debug */, 1286 | 2D02E49A1E0B4A5E006451C7 /* Release */, 1287 | ); 1288 | defaultConfigurationIsVisible = 0; 1289 | defaultConfigurationName = Release; 1290 | }; 1291 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "device" */ = { 1292 | isa = XCConfigurationList; 1293 | buildConfigurations = ( 1294 | 83CBBA201A601CBA00E9B192 /* Debug */, 1295 | 83CBBA211A601CBA00E9B192 /* Release */, 1296 | ); 1297 | defaultConfigurationIsVisible = 0; 1298 | defaultConfigurationName = Release; 1299 | }; 1300 | /* End XCConfigurationList section */ 1301 | }; 1302 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */; 1303 | } 1304 | -------------------------------------------------------------------------------- /device/ios/device.xcodeproj/xcshareddata/xcschemes/device-tvOS.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 29 | 35 | 36 | 37 | 43 | 49 | 50 | 51 | 52 | 53 | 58 | 59 | 61 | 67 | 68 | 69 | 70 | 71 | 77 | 78 | 79 | 80 | 81 | 82 | 92 | 94 | 100 | 101 | 102 | 103 | 104 | 105 | 111 | 113 | 119 | 120 | 121 | 122 | 124 | 125 | 128 | 129 | 130 | -------------------------------------------------------------------------------- /device/ios/device.xcodeproj/xcshareddata/xcschemes/device.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 29 | 35 | 36 | 37 | 43 | 49 | 50 | 51 | 52 | 53 | 58 | 59 | 61 | 67 | 68 | 69 | 70 | 71 | 77 | 78 | 79 | 80 | 81 | 82 | 92 | 94 | 100 | 101 | 102 | 103 | 104 | 105 | 111 | 113 | 119 | 120 | 121 | 122 | 124 | 125 | 128 | 129 | 130 | -------------------------------------------------------------------------------- /device/ios/device/AppDelegate.h: -------------------------------------------------------------------------------- 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 11 | 12 | @interface AppDelegate : UIResponder 13 | 14 | @property (nonatomic, strong) UIWindow *window; 15 | 16 | @end 17 | -------------------------------------------------------------------------------- /device/ios/device/AppDelegate.m: -------------------------------------------------------------------------------- 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 13 | #import 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:@"device" 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 38 | -------------------------------------------------------------------------------- /device/ios/device/Base.lproj/LaunchScreen.xib: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 21 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | -------------------------------------------------------------------------------- /device/ios/device/Images.xcassets/AppIcon.appiconset/Contents.json: -------------------------------------------------------------------------------- 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 | } -------------------------------------------------------------------------------- /device/ios/device/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleDisplayName 8 | device 9 | CFBundleExecutable 10 | $(EXECUTABLE_NAME) 11 | CFBundleIdentifier 12 | org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier) 13 | CFBundleInfoDictionaryVersion 14 | 6.0 15 | CFBundleName 16 | $(PRODUCT_NAME) 17 | CFBundlePackageType 18 | APPL 19 | CFBundleShortVersionString 20 | 1.0 21 | CFBundleSignature 22 | ???? 23 | CFBundleVersion 24 | 1 25 | LSRequiresIPhoneOS 26 | 27 | UILaunchStoryboardName 28 | LaunchScreen 29 | UIRequiredDeviceCapabilities 30 | 31 | armv7 32 | 33 | UISupportedInterfaceOrientations 34 | 35 | UIInterfaceOrientationPortrait 36 | UIInterfaceOrientationLandscapeLeft 37 | UIInterfaceOrientationLandscapeRight 38 | 39 | UIViewControllerBasedStatusBarAppearance 40 | 41 | NSLocationWhenInUseUsageDescription 42 | 43 | NSAppTransportSecurity 44 | 45 | 46 | NSExceptionDomains 47 | 48 | localhost 49 | 50 | NSExceptionAllowsInsecureHTTPLoads 51 | 52 | 53 | 54 | 55 | 56 | 57 | -------------------------------------------------------------------------------- /device/ios/device/main.m: -------------------------------------------------------------------------------- 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 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 | } 19 | -------------------------------------------------------------------------------- /device/ios/deviceTests/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleExecutable 8 | $(EXECUTABLE_NAME) 9 | CFBundleIdentifier 10 | org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier) 11 | CFBundleInfoDictionaryVersion 12 | 6.0 13 | CFBundleName 14 | $(PRODUCT_NAME) 15 | CFBundlePackageType 16 | BNDL 17 | CFBundleShortVersionString 18 | 1.0 19 | CFBundleSignature 20 | ???? 21 | CFBundleVersion 22 | 1 23 | 24 | 25 | -------------------------------------------------------------------------------- /device/ios/deviceTests/deviceTests.m: -------------------------------------------------------------------------------- 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 11 | #import 12 | 13 | #import 14 | #import 15 | 16 | #define TIMEOUT_SECONDS 600 17 | #define TEXT_TO_LOOK_FOR @"Welcome to React Native!" 18 | 19 | @interface deviceTests : XCTestCase 20 | 21 | @end 22 | 23 | @implementation deviceTests 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 = [[[[UIApplication sharedApplication] 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 71 | -------------------------------------------------------------------------------- /device/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "device", 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 | "flow": "node_modules/.bin/flow" 9 | }, 10 | "dependencies": { 11 | "bluebird": "^3.5.0", 12 | "react": "16.0.0-alpha.6", 13 | "react-native": "0.43.3", 14 | "react-native-simple-router": "^0.12.0", 15 | "react-native-svg": "^5.1.7", 16 | "react-native-swipe-gestures": "^1.0.2", 17 | "react-redux": "^5.0.4", 18 | "redux": "^3.6.0", 19 | "redux-thunk": "^2.2.0", 20 | "socket.io-client": "^1.7.3", 21 | "victory-native": "^0.7.2" 22 | }, 23 | "devDependencies": { 24 | "babel-cli": "^6.24.1", 25 | "babel-jest": "19.0.0", 26 | "babel-preset-flow": "^6.23.0", 27 | "babel-preset-react-native": "1.9.1", 28 | "flow-bin": "^0.43.1", 29 | "jest": "19.0.2", 30 | "react-test-renderer": "16.0.0-alpha.6" 31 | }, 32 | "jest": { 33 | "preset": "react-native" 34 | }, 35 | "description": "FX trading ERC20 tokens on a mobile dapp", 36 | "main": "src/index.js", 37 | "author": "Sean Francis", 38 | "license": "MIT" 39 | } 40 | -------------------------------------------------------------------------------- /device/src/actions/Graphs.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird' 2 | import SocketIOClient from 'socket.io-client' 3 | 4 | export default class Graphs { 5 | constructor() { 6 | this.socket = SocketIOClient('http://localhost:3000', {jsonp: false}); 7 | this.socket.on('connected', () => { 8 | console.log('device connected to server') 9 | }) 10 | } 11 | 12 | priceDataFeed() { 13 | return (dispatch) => { 14 | this.socket.on('price', (price_obj) => { 15 | console.log('price_obj(device)', price_obj) 16 | dispatch({ type: 'UPDATE_PRICE_HISTORY', result: price_obj}) 17 | }) 18 | } 19 | } 20 | 21 | volumeDataFeed() { 22 | return (dispatch) => { 23 | this.socket.on('volume', (volume_obj) => { 24 | console.log('volume_obj(device)', volume_obj) 25 | dispatch({ type: 'UPDATE_VOLUME_HISTORY', result: volume_obj }) 26 | }) 27 | } 28 | } 29 | marketDepthDataFeed() { 30 | return (dispatch) => { 31 | this.socket.on('market_depth', (depth_obj) => { 32 | console.log('depth_obj(device)', depth_obj) 33 | dispatch({ type: 'UPDATE_MARKET_DEPTH', result: depth_obj}) 34 | }) 35 | } 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /device/src/actions/index.js: -------------------------------------------------------------------------------- 1 | import Graphs from './Graphs' 2 | 3 | module.exports = { 4 | Graphs: new Graphs() 5 | } 6 | -------------------------------------------------------------------------------- /device/src/components/Main.js: -------------------------------------------------------------------------------- 1 | import Router from './Router' 2 | import Navigation from './Navigation' 3 | 4 | import React, { Component } from 'react' 5 | import { 6 | View, 7 | StyleSheet, 8 | Text 9 | } from 'react-native' 10 | 11 | export default class Main extends Component { 12 | constructor(props) { 13 | super(props) 14 | } 15 | 16 | render() { 17 | return( 18 | 19 | 20 | 21 | ) 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /device/src/components/Navigation.js: -------------------------------------------------------------------------------- 1 | import { Main } from './index' 2 | // import Router from './Router' 3 | // console.log('Router', Router) 4 | import store from '../store' 5 | import GestureRecognizer, { swipeDirections } from 'react-native-swipe-gestures' 6 | import { stackNavigator } from 'react-navigation' 7 | import React, { Component } from 'react' 8 | import { 9 | View, 10 | StyleSheet, 11 | Text, 12 | } from 'react-native' 13 | import { connect } from 'react-redux' 14 | 15 | class NavigationComponent extends Component { 16 | constructor(props) { 17 | super(props) 18 | } 19 | 20 | onSwipe(direction, state) { 21 | const { dispatch } = this.props 22 | console.log('direction', direction) 23 | // switch (direction) { 24 | // case 'SWIPE_DOWN': 25 | // dispatch({type: 'SWIPE_DOWN'}) 26 | // break; 27 | // case 'SWIPE_UP': 28 | // dispatch({type: 'SWIPE_UP'}) 29 | // break; 30 | // case 'SWIPE_RIGHT': 31 | // dispatch({type: 'SWIPE_RIGHT'}) 32 | // break; 33 | // case 'SWIPE_LEFT': 34 | // dispatch({type: 'SWIPE_LEFT'}) 35 | // break; 36 | // default: 37 | // break; 38 | // } 39 | } 40 | 41 | render() { 42 | const config = { 43 | velocityThreshold: 0.1, 44 | directionalOffsetThreshold: 150 45 | }; 46 | console.log('this.props.x', this.props) 47 | return ( 48 | this.onSwipe(direction, state)} 50 | config={config} 51 | style={{ 52 | flex: 1, 53 | }} 54 | > 55 | X-axis{this.props.navigation.x} 56 | Y-axis{this.props.navigation.y} 57 | 58 | 59 | ) 60 | } 61 | } 62 | 63 | const mapStoreToProps = (store) => { 64 | let mappedProps = new Object() 65 | mappedProps.navigation = store.navigation 66 | return mappedProps 67 | } 68 | 69 | const Navigation = connect(mapStoreToProps)(NavigationComponent) 70 | 71 | export default Navigation 72 | -------------------------------------------------------------------------------- /device/src/components/Router.js: -------------------------------------------------------------------------------- 1 | // import components 2 | import React, { PropTypes } from 'react' 3 | import { addNavigationHelpers, StackNavigator } from 'react-navigation' 4 | import { 5 | View, 6 | StyleSheet, 7 | } from 'react-native' 8 | import { connect } from 'react-redux' 9 | import { Market } from './index' 10 | console.log('Market', Market) 11 | 12 | export const Router = StackNavigator({ 13 | Market: { screen: Market} 14 | }) 15 | 16 | // const NavigationState = ({ dispatch, nav }) => ( 17 | // 18 | // ) 19 | // 20 | // const mapStoreToProps = (store) => { 21 | // let mappedProps = new Object() 22 | // mappedProps.navigation = store.navigation 23 | // return mappedProps 24 | // } 25 | // 26 | // const Router = connect(mapStoreToProps)(NavigationState) 27 | // 28 | // export default Router 29 | -------------------------------------------------------------------------------- /device/src/components/graphs/LineGraph.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { VictoryLine } from 'victory-native' 3 | import { connect } from 'react-redux' 4 | import { Graphs } from '../../actions/index' 5 | 6 | import { 7 | View, 8 | StyleSheet, 9 | } from 'react-native' 10 | 11 | class LineGraphComponent extends Component { 12 | constructor(props) { 13 | super(props) 14 | this.entries = 0 15 | } 16 | 17 | componentWillMount() { 18 | const { dispatch } = this.props; 19 | dispatch(Graphs.priceDataFeed()) 20 | } 21 | 22 | render() { 23 | const { price_history } = this.props.graphs 24 | this.entries = price_history.length; 25 | if (this.entries >= 3) { 26 | return ( 27 | 35 | ) 36 | } else { 37 | return 38 | } 39 | } 40 | } 41 | 42 | const mapStoreToProps = (store) => { 43 | let mappedProps = new Object() 44 | mappedProps.graphs = store.graphs 45 | return mappedProps 46 | } 47 | 48 | const LineGraph = connect(mapStoreToProps)(LineGraphComponent) 49 | 50 | export default LineGraph 51 | -------------------------------------------------------------------------------- /device/src/components/index.js: -------------------------------------------------------------------------------- 1 | // navigation 2 | import Main from './Main' 3 | import Navigation from './Navigation' 4 | 5 | // market 6 | import Market from './markets/Market' 7 | import VolumeLine from './markets/VolumeLine' 8 | import MarketDepth from './markets/MarketDepth' 9 | 10 | // graphs 11 | import LineGraph from './graphs/LineGraph' 12 | 13 | export { 14 | Main, 15 | Navigation, 16 | Market, 17 | LineGraph, 18 | VolumeLine, 19 | MarketDepth, 20 | } 21 | -------------------------------------------------------------------------------- /device/src/components/markets/Market.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { LineGraph, VolumeLine, MarketDepth } from '../index' 3 | import MarketHeader from './MarketHeader' 4 | import { 5 | View, 6 | Text, 7 | } from 'react-native' 8 | 9 | 10 | export default class Market extends Component { 11 | constructor() { 12 | super() 13 | } 14 | 15 | render() { 16 | return ( 17 | 18 | 19 | 20 | 21 | ) 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /device/src/components/markets/MarketDepth.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { 3 | View, 4 | } from 'react-native' 5 | import { 6 | VictoryBar, 7 | } from 'victory-native' 8 | import { connect } from 'react-redux' 9 | 10 | export class MarketDepthComponent extends Component { 11 | constructor() { 12 | super() 13 | } 14 | 15 | render() { 16 | return ( 17 | 20 | ) 21 | } 22 | } 23 | 24 | const mapStoreToProps = (store) => { 25 | return store.graphs 26 | } 27 | 28 | export default MarketDepth = connect(mapStoreToProps)(MarketDepthComponent) 29 | -------------------------------------------------------------------------------- /device/src/components/markets/MarketHeader.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { 3 | View, 4 | Text, 5 | } from 'react-native' 6 | 7 | export default class MarketHeader extends Component { 8 | constructor() { 9 | super() 10 | } 11 | 12 | render() { 13 | return ( 14 | 15 | DEX/GNO 16 | 17 | ) 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /device/src/components/markets/PriceLine.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { 3 | View, 4 | } from 'rect-native' 5 | 6 | export default class Graph extends Component { 7 | constructor() { 8 | 9 | } 10 | 11 | render() { 12 | return ( 13 | 14 | ) 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /device/src/components/markets/VolumeLine.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react' 2 | import { 3 | VictoryLine 4 | } from 'victory-native' 5 | import { 6 | View, 7 | } from 'react-native' 8 | import { connect } from 'react-redux' 9 | import { Graphs } from '../../actions/index' 10 | 11 | class VolumeLineComponent extends Component { 12 | constructor() { 13 | super() 14 | this.entries = 0 15 | } 16 | 17 | componentWillMount() { 18 | const { dispatch } = this.props 19 | dispatch(Graphs.volumeDataFeed()) 20 | } 21 | 22 | render() { 23 | const { volume_history } = this.props.graphs 24 | this.entries = volume_history.length 25 | if(this.entries >=3) { 26 | return ( 27 | 35 | ) 36 | } else { 37 | return ( 38 | 39 | ) 40 | } 41 | } 42 | } 43 | 44 | const mapStoreToProps = (store) => { 45 | let mappedProps = new Object() 46 | mappedProps.graphs = store.graphs 47 | return mappedProps 48 | } 49 | 50 | const VolumeLine = connect(mapStoreToProps)(VolumeLineComponent) 51 | 52 | export default VolumeLine 53 | -------------------------------------------------------------------------------- /device/src/index.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/device/src/index.js -------------------------------------------------------------------------------- /device/src/reducers/graphs.js: -------------------------------------------------------------------------------- 1 | const INITIAL_STATE = { 2 | price_history: [], 3 | volume_history: [], 4 | market_depth: [] 5 | } 6 | 7 | export default function graphs(state = INITIAL_STATE, action) { 8 | switch(action.type) { 9 | case 'UPDATE_PRICE_HISTORY': 10 | return { 11 | ...state, 12 | price_history: state.price_history.concat(JSON.parse(action.result)) 13 | } 14 | break 15 | case 'UPDATE_VOLUME_HISTORY': 16 | return { 17 | ...state, 18 | volume_history: state.volume_history.concat(JSON.parse(action.result)) 19 | } 20 | case 'UPDATE_MARKET_DEPTH': 21 | return { 22 | ...state, 23 | market_depth: state.market_depth.concat(JSON.parse(action.result)) 24 | } 25 | default: 26 | return state 27 | break 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /device/src/reducers/index.js: -------------------------------------------------------------------------------- 1 | import navigation from './navigation' 2 | import graphs from './graphs' 3 | 4 | export { 5 | navigation, 6 | graphs, 7 | } 8 | -------------------------------------------------------------------------------- /device/src/reducers/navigation.js: -------------------------------------------------------------------------------- 1 | const INITIAL_STATE = { 2 | grid_x: 4, 3 | grid_y: 4, 4 | x: 0, 5 | y: 0, 6 | } 7 | 8 | export default function navigation(state = INITIAL_STATE, action) { 9 | switch(action.type) { 10 | case 'SWIPE_RIGHT': 11 | console.log('hit reducer') 12 | return { 13 | ...state, 14 | x: state.x + 1 15 | } 16 | break 17 | case 'SWIPE_LEFT': 18 | console.log('hit reducer') 19 | return { 20 | ...state, 21 | x: state.x - 1 22 | } 23 | break 24 | case 'SWIPE_UP': 25 | return { 26 | ...state, 27 | y: state.y + 1 28 | } 29 | break 30 | case 'SWIPE_DOWN': 31 | return { 32 | ...state, 33 | y: state.y - 1 34 | } 35 | break 36 | default: 37 | return state 38 | break 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /device/src/store.js: -------------------------------------------------------------------------------- 1 | import * as reducers from './reducers/index' 2 | import thunk from 'redux-thunk' 3 | import { createStore, applyMiddleware, combineReducers } from 'redux' 4 | 5 | const reducer = combineReducers({...reducers}) 6 | const store = createStore(reducer, applyMiddleware(thunk)) 7 | 8 | export default store 9 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "dex-mobile", 3 | "version": "0.0.1", 4 | "description": "FX trading ERC20 tokens on mobile dapp", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "babel-node ./server/test/test.js --presets es2015", 8 | "random-trading": "babel-node ./server/test/random_trading.js --presets es2015", 9 | "gauss-sim": "babel-node ./server/gauss/simulation.js --presets es2015", 10 | "server": "babel-node ./server/api/server.js --presets es2015", 11 | "schema": "babel-node ./server/api/Schema.js --presets es2015" 12 | }, 13 | "keywords": [ 14 | "forex", 15 | "erc20", 16 | "react-native", 17 | "react", 18 | "solidity", 19 | "javascript" 20 | ], 21 | "author": "Sean Francis", 22 | "license": "ISC", 23 | "dependencies": { 24 | "babel-cli": "^6.24.1", 25 | "babel-preset-es2015": "^6.24.1", 26 | "bluebird": "^3.5.0", 27 | "body-parser": "^1.17.1", 28 | "express": "^4.15.2", 29 | "gaussian": "^1.1.0", 30 | "graphql": "^0.9.5", 31 | "graphql-server-express": "^0.7.2", 32 | "http": "0.0.0", 33 | "level": "^1.6.0", 34 | "request": "^2.81.0", 35 | "request-promise": "^4.2.0", 36 | "socket.io": "^1.7.3" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /server/api/schema.js: -------------------------------------------------------------------------------- 1 | import { buildSchema } from 'grqphql' 2 | 3 | export const schema = buildSchema(` 4 | type Query { 5 | hello: String 6 | } 7 | `) 8 | 9 | export const root = { 10 | hello: () => { 11 | return 'yo yo, whats happenin' 12 | }, 13 | } 14 | -------------------------------------------------------------------------------- /server/api/server.js: -------------------------------------------------------------------------------- 1 | import express from 'express' 2 | import http from 'http' 3 | import socketio from 'socket.io' 4 | import bodyparser from 'body-parser' 5 | // import { graphqlExpress } from 'graphql-server-express' 6 | // import { schema, root } from './schema' 7 | 8 | const app = express(); 9 | app.use(bodyparser.json()) 10 | const server = http.Server(app) 11 | const websocket = socketio(server) 12 | 13 | 14 | // set up graphql config 15 | // app.use('/graphql', bodyParser.json(), graphqlExpress({ 16 | // schema: schema, 17 | // rootValue: root, 18 | // graphiql: true, 19 | // })) 20 | 21 | 22 | // The event will be called when a client is connected. 23 | websocket.on('connection', (socket) => { 24 | console.log('A client just joined on', socket.id); 25 | }); 26 | 27 | // restful endpoints 28 | app.get('/price', (req, res) => { 29 | console.log('req', JSON.stringify(req.body)) 30 | websocket.emit('price', JSON.stringify(req.body)) 31 | res.end('sent new price obj', res) 32 | }) 33 | 34 | app.get('/volume', (req, res) => { 35 | console.log('hit volume endpoint') 36 | websocket.emit('volume', JSON.stringify(req.body)) 37 | res.end('sent new volume obj', res) 38 | }) 39 | 40 | server.listen(3000, () => console.log('listening on *:3000')) 41 | -------------------------------------------------------------------------------- /server/api/websocket.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/server/api/websocket.js -------------------------------------------------------------------------------- /server/deploy.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/server/deploy.js -------------------------------------------------------------------------------- /server/evm/build/contracts/Migrations.json: -------------------------------------------------------------------------------- 1 | { 2 | "contract_name": "Migrations", 3 | "abi": [ 4 | { 5 | "constant": false, 6 | "inputs": [ 7 | { 8 | "name": "new_address", 9 | "type": "address" 10 | } 11 | ], 12 | "name": "upgrade", 13 | "outputs": [], 14 | "payable": false, 15 | "type": "function" 16 | }, 17 | { 18 | "constant": true, 19 | "inputs": [], 20 | "name": "last_completed_migration", 21 | "outputs": [ 22 | { 23 | "name": "", 24 | "type": "uint256" 25 | } 26 | ], 27 | "payable": false, 28 | "type": "function" 29 | }, 30 | { 31 | "constant": true, 32 | "inputs": [], 33 | "name": "owner", 34 | "outputs": [ 35 | { 36 | "name": "", 37 | "type": "address" 38 | } 39 | ], 40 | "payable": false, 41 | "type": "function" 42 | }, 43 | { 44 | "constant": false, 45 | "inputs": [ 46 | { 47 | "name": "completed", 48 | "type": "uint256" 49 | } 50 | ], 51 | "name": "setCompleted", 52 | "outputs": [], 53 | "payable": false, 54 | "type": "function" 55 | }, 56 | { 57 | "inputs": [], 58 | "payable": false, 59 | "type": "constructor" 60 | } 61 | ], 62 | "unlinked_binary": "0x606060405234610000575b60008054600160a060020a03191633600160a060020a03161790555b5b610190806100366000396000f300606060405263ffffffff60e060020a6000350416630900f0108114610045578063445df0ac146100605780638da5cb5b1461007f578063fdacd576146100a8575b610000565b346100005761005e600160a060020a03600435166100ba565b005b346100005761006d61012d565b60408051918252519081900360200190f35b346100005761008c610133565b60408051600160a060020a039092168252519081900360200190f35b346100005761005e600435610142565b005b6000805433600160a060020a03908116911614156101275781905080600160a060020a031663fdacd5766001546040518263ffffffff1660e060020a02815260040180828152602001915050600060405180830381600087803b156100005760325a03f115610000575050505b5b5b5050565b60015481565b600054600160a060020a031681565b60005433600160a060020a039081169116141561015f5760018190555b5b5b505600a165627a7a72305820bcc3a4515f003be8626524b757cac4196fcf9a4101b82b2e9e01874976c4dd3c0029", 63 | "networks": { 64 | "1494544805387": { 65 | "events": {}, 66 | "links": {}, 67 | "address": "0x65d4a2e73019229c7abf68735af4d9ef17bc2926", 68 | "updated_at": 1494610996807 69 | } 70 | }, 71 | "schema_version": "0.0.5", 72 | "updated_at": 1494610996807 73 | } -------------------------------------------------------------------------------- /server/evm/build/contracts/SafeAddSub.json: -------------------------------------------------------------------------------- 1 | { 2 | "contract_name": "SafeAddSub", 3 | "abi": [], 4 | "unlinked_binary": "0x6060604052346000575b60358060166000396000f30060606040525b60005600a165627a7a7230582061c3e9d14584ba6a0115f849d7c2a83c17e0ea9f56b3767b5117db229f319bec0029", 5 | "networks": { 6 | "1494544805387": { 7 | "events": {}, 8 | "links": {}, 9 | "address": "0x17c65ea800afb9c76667c2ee9c305717cf2cd11c", 10 | "updated_at": 1494610996798 11 | } 12 | }, 13 | "schema_version": "0.0.5", 14 | "updated_at": 1494612165638 15 | } -------------------------------------------------------------------------------- /server/evm/build/contracts/Token.json: -------------------------------------------------------------------------------- 1 | { 2 | "contract_name": "Token", 3 | "abi": [ 4 | { 5 | "constant": true, 6 | "inputs": [], 7 | "name": "supply", 8 | "outputs": [ 9 | { 10 | "name": "", 11 | "type": "uint256" 12 | } 13 | ], 14 | "payable": false, 15 | "type": "function" 16 | }, 17 | { 18 | "constant": true, 19 | "inputs": [], 20 | "name": "name", 21 | "outputs": [ 22 | { 23 | "name": "", 24 | "type": "string" 25 | } 26 | ], 27 | "payable": false, 28 | "type": "function" 29 | }, 30 | { 31 | "constant": false, 32 | "inputs": [ 33 | { 34 | "name": "spender", 35 | "type": "address" 36 | }, 37 | { 38 | "name": "value", 39 | "type": "uint256" 40 | } 41 | ], 42 | "name": "approve", 43 | "outputs": [ 44 | { 45 | "name": "", 46 | "type": "bool" 47 | } 48 | ], 49 | "payable": false, 50 | "type": "function" 51 | }, 52 | { 53 | "constant": false, 54 | "inputs": [ 55 | { 56 | "name": "from", 57 | "type": "address" 58 | }, 59 | { 60 | "name": "to", 61 | "type": "address" 62 | }, 63 | { 64 | "name": "value", 65 | "type": "uint256" 66 | } 67 | ], 68 | "name": "transferFrom", 69 | "outputs": [ 70 | { 71 | "name": "", 72 | "type": "bool" 73 | } 74 | ], 75 | "payable": false, 76 | "type": "function" 77 | }, 78 | { 79 | "constant": true, 80 | "inputs": [], 81 | "name": "date", 82 | "outputs": [ 83 | { 84 | "name": "", 85 | "type": "uint256" 86 | } 87 | ], 88 | "payable": false, 89 | "type": "function" 90 | }, 91 | { 92 | "constant": true, 93 | "inputs": [ 94 | { 95 | "name": "who", 96 | "type": "address" 97 | } 98 | ], 99 | "name": "balanceOf", 100 | "outputs": [ 101 | { 102 | "name": "", 103 | "type": "uint256" 104 | } 105 | ], 106 | "payable": false, 107 | "type": "function" 108 | }, 109 | { 110 | "constant": false, 111 | "inputs": [ 112 | { 113 | "name": "to", 114 | "type": "address" 115 | }, 116 | { 117 | "name": "value", 118 | "type": "uint256" 119 | } 120 | ], 121 | "name": "transfer", 122 | "outputs": [ 123 | { 124 | "name": "", 125 | "type": "bool" 126 | } 127 | ], 128 | "payable": false, 129 | "type": "function" 130 | }, 131 | { 132 | "constant": false, 133 | "inputs": [ 134 | { 135 | "name": "_supply", 136 | "type": "uint256" 137 | }, 138 | { 139 | "name": "_name", 140 | "type": "string" 141 | } 142 | ], 143 | "name": "Credit", 144 | "outputs": [], 145 | "payable": false, 146 | "type": "function" 147 | }, 148 | { 149 | "constant": true, 150 | "inputs": [ 151 | { 152 | "name": "owner", 153 | "type": "address" 154 | }, 155 | { 156 | "name": "spender", 157 | "type": "address" 158 | } 159 | ], 160 | "name": "allowance", 161 | "outputs": [ 162 | { 163 | "name": "", 164 | "type": "uint256" 165 | } 166 | ], 167 | "payable": false, 168 | "type": "function" 169 | }, 170 | { 171 | "anonymous": false, 172 | "inputs": [ 173 | { 174 | "indexed": true, 175 | "name": "from", 176 | "type": "address" 177 | }, 178 | { 179 | "indexed": true, 180 | "name": "to", 181 | "type": "address" 182 | }, 183 | { 184 | "indexed": false, 185 | "name": "value", 186 | "type": "uint256" 187 | } 188 | ], 189 | "name": "Transfer", 190 | "type": "event" 191 | }, 192 | { 193 | "anonymous": false, 194 | "inputs": [ 195 | { 196 | "indexed": true, 197 | "name": "owner", 198 | "type": "address" 199 | }, 200 | { 201 | "indexed": true, 202 | "name": "spender", 203 | "type": "address" 204 | }, 205 | { 206 | "indexed": false, 207 | "name": "value", 208 | "type": "uint256" 209 | } 210 | ], 211 | "name": "Approval", 212 | "type": "event" 213 | } 214 | ], 215 | "unlinked_binary": "0x606060405234610000575b6106b5806100196000396000f3006060604052361561007d5763ffffffff60e060020a600035041663047fc9aa811461008257806306fdde03146100a1578063095ea7b31461012e57806323b872dd1461015e578063323046b11461019457806370a08231146101b3578063a9059cbb146101de578063c153fa721461020e578063dd62ed3e14610264575b610000565b346100005761008f610295565b60408051918252519081900360200190f35b34610000576100ae61029b565b6040805160208082528351818301528351919283929083019185019080838382156100f4575b8051825260208311156100f457601f1990920191602091820191016100d4565b505050905090810190601f1680156101205780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b346100005761014a600160a060020a0360043516602435610329565b604080519115158252519081900360200190f35b346100005761014a600160a060020a0360043581169060243516604435610394565b604080519115158252519081900360200190f35b346100005761008f610484565b60408051918252519081900360200190f35b346100005761008f600160a060020a036004351661048a565b60408051918252519081900360200190f35b346100005761014a600160a060020a03600435166024356104a9565b604080519115158252519081900360200190f35b346100005760408051602060046024803582810135601f8101859004850286018501909652858552610262958335959394604494939290920191819084018382808284375094965061056c95505050505050565b005b346100005761008f600160a060020a036004358116906024351661064e565b60408051918252519081900360200190f35b60025481565b6003805460408051602060026001851615610100026000190190941693909304601f810184900484028201840190925281815292918301828280156103215780601f106102f657610100808354040283529160200191610321565b820191906000526020600020905b81548152906001019060200180831161030457829003601f168201915b505050505081565b600160a060020a03338116600081815260016020908152604080832094871680845294825280832086905580518681529051929493927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35060015b92915050565b600160a060020a03808416600090815260016020908152604080832033909416835292905290812054829010156103ca57610000565b600160a060020a0383166000908152602081905260409020546103ed908361067b565b15156103f857610000565b600160a060020a038085166000818152600160209081526040808320338616845282528083208054889003905583835282825280832080548890039055938716808352918490208054870190558351868152935191937fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929081900390910190a35060015b9392505050565b60045481565b600160a060020a0381166000908152602081905260409020545b919050565b600160a060020a033316600090815260208190526040812054829010156104cf57610000565b600160a060020a0383166000908152602081905260409020546104f2908361067b565b15156104fd57610000565b600160a060020a0333811660008181526020818152604080832080548890039055938716808352918490208054870190558351868152935191937fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929081900390910190a35060015b92915050565b33600160a060020a03166000908152602081815260408220849055600284815583516003805494819052937fc2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b6001821615610100026000190190911692909204601f9081018490048301939192918601908390106105f557805160ff1916838001178555610622565b82800160010185558215610622579182015b82811115610622578251825591602001919060010190610607565b5b506106439291505b8082111561063f576000815560010161062b565b5090565b5050426004555b5050565b600160a060020a038083166000908152600160209081526040808320938516835292905220545b92915050565b808201829010155b929150505600a165627a7a72305820f4d55b0520dbf3652e00a07a7f803f869cd302065f97743cd9a62e14b9aaa8d00029", 216 | "networks": {}, 217 | "schema_version": "0.0.5", 218 | "updated_at": 1494612165637 219 | } -------------------------------------------------------------------------------- /server/evm/contracts/Migrations.sol: -------------------------------------------------------------------------------- 1 | pragma solidity ^0.4.4; 2 | 3 | contract Migrations { 4 | address public owner; 5 | uint public last_completed_migration; 6 | 7 | modifier restricted() { 8 | if (msg.sender == owner) _; 9 | } 10 | 11 | function Migrations() { 12 | owner = msg.sender; 13 | } 14 | 15 | function setCompleted(uint completed) restricted { 16 | last_completed_migration = completed; 17 | } 18 | 19 | function upgrade(address new_address) restricted { 20 | Migrations upgraded = Migrations(new_address); 21 | upgraded.setCompleted(last_completed_migration); 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /server/evm/contracts/SafeAddSub.sol: -------------------------------------------------------------------------------- 1 | pragma solidity ^0.4.2; 2 | 3 | contract SafeAddSub { 4 | function safeToAdd(uint a, uint b) internal returns (bool) { 5 | return (a + b >= a); 6 | } 7 | function safeAdd(uint a, uint b) internal returns (uint) { 8 | if (!safeToAdd(a, b)) throw; 9 | return a + b; 10 | } 11 | 12 | function safeToSubtract(uint a, uint b) internal returns (bool) { 13 | return (b <= a); 14 | } 15 | function safeSub(uint a, uint b) internal returns (uint) { 16 | if (!safeToSubtract(a, b)) throw; 17 | return a - b; 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /server/evm/contracts/Token.sol: -------------------------------------------------------------------------------- 1 | pragma solidity ^0.4.4; 2 | 3 | import "./SafeAddSub.sol"; 4 | 5 | contract Token is SafeAddSub { 6 | event Transfer(address indexed from, address indexed to, uint value); 7 | event Approval( address indexed owner, address indexed spender, uint value); 8 | 9 | mapping( address => uint ) balances; 10 | mapping( address => mapping( address => uint ) ) approvals; 11 | uint public supply; 12 | string public ticker; 13 | string public name; 14 | uint public date; 15 | 16 | function Token( uint _supply, string _name) { 17 | balances[msg.sender] = _supply; 18 | supply = _supply; 19 | name = _name; 20 | date = now; 21 | } 22 | 23 | function transfer( address to, uint value) returns (bool) { 24 | if( balances[msg.sender] < value ) { 25 | throw; 26 | } 27 | if( !safeToAdd(balances[to], value) ) { 28 | throw; 29 | } 30 | balances[msg.sender] -= value; 31 | balances[to] += value; 32 | Transfer( msg.sender, to, value ); 33 | return true; 34 | } 35 | 36 | function transferFrom( address from, address to, uint value) returns (bool) { 37 | if( approvals[from][msg.sender] < value ) { 38 | throw; 39 | } 40 | if( !safeToAdd(balances[to], value) ) { 41 | throw; 42 | } 43 | approvals[from][msg.sender] -= value; 44 | balances[from] -= value; 45 | balances[to] += value; 46 | Transfer( from, to, value ); 47 | return true; 48 | } 49 | 50 | function approve(address spender, uint value) returns (bool) { 51 | approvals[msg.sender][spender] = value; 52 | Approval( msg.sender, spender, value ); 53 | return true; 54 | } 55 | 56 | function allowance(address owner, address spender) constant returns (uint) { 57 | return approvals[owner][spender]; 58 | } 59 | 60 | function balanceOf(address who) constant returns (uint) { 61 | return balances[who]; 62 | } 63 | } 64 | -------------------------------------------------------------------------------- /server/evm/migrations/1_initial_migration.js: -------------------------------------------------------------------------------- 1 | var Migrations = artifacts.require("./Migrations.sol"); 2 | 3 | module.exports = function(deployer) { 4 | deployer.deploy(Migrations); 5 | }; 6 | -------------------------------------------------------------------------------- /server/evm/migrations/2_deploy_contracts.js: -------------------------------------------------------------------------------- 1 | var Promise = require('bluebird') 2 | var SafeAddSub = artifacts.require("./SafeAddSub.sol"); 3 | var Token = artifacts.require("./Token.sol") 4 | 5 | const tokens = [ 6 | { 7 | name: 'Gnosis', 8 | ticker: 'GNO', 9 | }, 10 | { 11 | name: 'Brave', 12 | ticker: 'BAT', 13 | }, 14 | { 15 | name: 'Golem', 16 | ticker: 'GNT', 17 | }, 18 | { 19 | name: 'Steemit', 20 | ticker: 'STEEM', 21 | } 22 | ] 23 | module.exports = function(deployer) { 24 | // deployer.deploy(ConvertLib); 25 | // deployer.link(ConvertLib, MetaCoin); 26 | // deployer.deploy(MetaCoin); 27 | return new Promise((resolve, reject) => { 28 | return Promise.delay(0) 29 | .then(() => { 30 | return deployer.deploy(SafeAddSub) 31 | }).then(() => { 32 | deployer.link(SafeAddSub, Token) 33 | return tokens 34 | }).map((token) => { 35 | console.log('token') 36 | // return token.new() 37 | }) 38 | }) 39 | // deployer.link(SafeAddSub, Token) 40 | // deployer.deploy(Token) 41 | }; 42 | -------------------------------------------------------------------------------- /server/evm/test/TestMetacoin.sol: -------------------------------------------------------------------------------- 1 | pragma solidity ^0.4.2; 2 | 3 | import "truffle/Assert.sol"; 4 | import "truffle/DeployedAddresses.sol"; 5 | import "../contracts/MetaCoin.sol"; 6 | 7 | contract TestMetacoin { 8 | 9 | function testInitialBalanceUsingDeployedContract() { 10 | MetaCoin meta = MetaCoin(DeployedAddresses.MetaCoin()); 11 | 12 | uint expected = 10000; 13 | 14 | Assert.equal(meta.getBalance(tx.origin), expected, "Owner should have 10000 MetaCoin initially"); 15 | } 16 | 17 | function testInitialBalanceWithNewMetaCoin() { 18 | MetaCoin meta = new MetaCoin(); 19 | 20 | uint expected = 10000; 21 | 22 | Assert.equal(meta.getBalance(tx.origin), expected, "Owner should have 10000 MetaCoin initially"); 23 | } 24 | 25 | } 26 | -------------------------------------------------------------------------------- /server/evm/test/metacoin.js: -------------------------------------------------------------------------------- 1 | var MetaCoin = artifacts.require("./MetaCoin.sol"); 2 | 3 | contract('MetaCoin', function(accounts) { 4 | it("should put 10000 MetaCoin in the first account", function() { 5 | return MetaCoin.deployed().then(function(instance) { 6 | return instance.getBalance.call(accounts[0]); 7 | }).then(function(balance) { 8 | assert.equal(balance.valueOf(), 10000, "10000 wasn't in the first account"); 9 | }); 10 | }); 11 | it("should call a function that depends on a linked library", function() { 12 | var meta; 13 | var metaCoinBalance; 14 | var metaCoinEthBalance; 15 | 16 | return MetaCoin.deployed().then(function(instance) { 17 | meta = instance; 18 | return meta.getBalance.call(accounts[0]); 19 | }).then(function(outCoinBalance) { 20 | metaCoinBalance = outCoinBalance.toNumber(); 21 | return meta.getBalanceInEth.call(accounts[0]); 22 | }).then(function(outCoinBalanceEth) { 23 | metaCoinEthBalance = outCoinBalanceEth.toNumber(); 24 | }).then(function() { 25 | assert.equal(metaCoinEthBalance, 2 * metaCoinBalance, "Library function returned unexpected function, linkage may be broken"); 26 | }); 27 | }); 28 | it("should send coin correctly", function() { 29 | var meta; 30 | 31 | // Get initial balances of first and second account. 32 | var account_one = accounts[0]; 33 | var account_two = accounts[1]; 34 | 35 | var account_one_starting_balance; 36 | var account_two_starting_balance; 37 | var account_one_ending_balance; 38 | var account_two_ending_balance; 39 | 40 | var amount = 10; 41 | 42 | return MetaCoin.deployed().then(function(instance) { 43 | meta = instance; 44 | return meta.getBalance.call(account_one); 45 | }).then(function(balance) { 46 | account_one_starting_balance = balance.toNumber(); 47 | return meta.getBalance.call(account_two); 48 | }).then(function(balance) { 49 | account_two_starting_balance = balance.toNumber(); 50 | return meta.sendCoin(account_two, amount, {from: account_one}); 51 | }).then(function() { 52 | return meta.getBalance.call(account_one); 53 | }).then(function(balance) { 54 | account_one_ending_balance = balance.toNumber(); 55 | return meta.getBalance.call(account_two); 56 | }).then(function(balance) { 57 | account_two_ending_balance = balance.toNumber(); 58 | 59 | assert.equal(account_one_ending_balance, account_one_starting_balance - amount, "Amount wasn't correctly taken from the sender"); 60 | assert.equal(account_two_ending_balance, account_two_starting_balance + amount, "Amount wasn't correctly sent to the receiver"); 61 | }); 62 | }); 63 | }); 64 | -------------------------------------------------------------------------------- /server/evm/truffle.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | networks: { 3 | development: { 4 | host: "localhost", 5 | port: 8545, 6 | network_id: "*" // Match any network id 7 | } 8 | } 9 | }; 10 | -------------------------------------------------------------------------------- /server/exAgent/ExAgent.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird' 2 | import levelup from 'levelup' 3 | export default class ExAgent { 4 | constructor(params) { 5 | this.settlement = levelup('../settlement') 6 | this.market = params.market 7 | this.tokenA = params.tokenA 8 | this.tokenB = params.tokenB 9 | console.log('created ExAgent instance', this.market) 10 | // this.continuos() 11 | } 12 | 13 | continuous() { 14 | return new Promise((resolve, reject) => { 15 | return Promise.delay(0).then(() => { 16 | 17 | }) 18 | }) 19 | } 20 | 21 | // matching function adheres to ACID transaction principles 22 | match() { 23 | 24 | } 25 | 26 | 27 | } 28 | -------------------------------------------------------------------------------- /server/gauss/data.js: -------------------------------------------------------------------------------- 1 | /* 2 | line_grpah_data 3 | params: 4 | time: (unix timestamp) 5 | price: (market price) 6 | */ 7 | export let line_graph_data = []; 8 | 9 | export function appendLineGraph(time, price) { 10 | console.log('appending data point', time, price) 11 | line_graph_data.push({ 12 | time: time, 13 | prie: price 14 | }) 15 | } 16 | -------------------------------------------------------------------------------- /server/gauss/simulation.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird' 2 | import gaussian from 'gaussian' 3 | import rp from 'request-promise' 4 | import Market from '../markets/Market.js' 5 | 6 | // globals 7 | const tokenA = '0x692a70d2e424a56d2c6c27aa97d1a86395877b3a' 8 | const tokenB = '0xbbf289d846208c16edc8474705c748aff07732db' 9 | let market = new Market({ 10 | tokenA: tokenA, 11 | tokenB: tokenB, 12 | }) 13 | let volume = 5 14 | let temp_volume 15 | let price = 1 16 | let price_variance = .1 17 | let volume_variance = 1 18 | let sellA_obj = {} 19 | let sellB_obj = {} 20 | 21 | /* 22 | /////////////////////////////////////////////////////////// 23 | SIMULATION LOOP 24 | /////////////////////////////////////////////////////////// 25 | */ 26 | // export function simulationLoop() { 27 | // return Promise.delay(5000) 28 | // .then(() => { 29 | // return calculateMarketParams() 30 | // }).then(() => { 31 | // temp_volume = volume 32 | // return shotgun() 33 | // }).then(() => { 34 | // console.log('made it here') 35 | // return simulationLoop() 36 | // }).catch((error) => { 37 | // console.log('error', error) 38 | // Promise.delay(5000) 39 | // .then(() => { 40 | // return simulationLoop() 41 | // }) 42 | // }) 43 | // } 44 | 45 | export function simulationLoop() { 46 | return new Promise((resolve, reject) => { 47 | return Promise.delay(5000) 48 | .then(() => { 49 | return calculateMarketParams() 50 | }).then(() => { 51 | temp_volume = volume 52 | return shotgun() 53 | }).then(() => { 54 | return simulationLoop() 55 | }).catch((err) => { 56 | return simulationLoop() 57 | }) 58 | }) 59 | } 60 | 61 | /* 62 | /////////////////////////////////////////////////////////// 63 | CALCULATE BATCH PARAMETERS 64 | /////////////////////////////////////////////////////////// 65 | */ 66 | 67 | export default function calculateMarketParams() { 68 | return new Promise((resolve, reject) => { 69 | return Promise.delay(0) 70 | .then(() => { 71 | return marketPrice() 72 | }).then(() => { 73 | return batchVolume() 74 | }).then(() => { 75 | resolve(true) 76 | }).catch((err) => { 77 | reject(err) 78 | }) 79 | }) 80 | } 81 | 82 | export function marketPrice() { 83 | return new Promise((resolve, reject) => { 84 | Promise.resolve(bellRandom(price, price_variance)) 85 | .then((p) => { 86 | console.log('### Market Price:', p) 87 | price = p 88 | let send_obj = { 89 | method: 'GET', 90 | uri: 'http://localhost:3000/price', 91 | body: { 92 | price: p, 93 | date: new Date().getTime(), 94 | }, 95 | json: true 96 | } 97 | return rp(send_obj) 98 | }).then((result) => { 99 | resolve(true) 100 | }).catch((error) => { 101 | reject(error) 102 | }) 103 | }) 104 | } 105 | 106 | export function batchVolume() { 107 | return new Promise((resolve, rejct) => { 108 | Promise.resolve(bellRandom(volume, volume_variance)) 109 | .then((v) => { 110 | volume = Math.round(v) 111 | console.log('Batch Volume:', volume) 112 | return v 113 | }).then((v) => { 114 | let send_obj = { 115 | method: 'GET', 116 | uri: 'http://localhost:3000/volume', 117 | body: { 118 | volume: v, 119 | date: new Date().getTime(), 120 | }, 121 | json: true 122 | } 123 | console.log('send_obj.body', send_obj.body) 124 | return rp(send_obj) 125 | }).then(() => { 126 | resolve(true) 127 | }).catch((error) => { 128 | reject(error) 129 | }) 130 | }) 131 | } 132 | 133 | /* 134 | /////////////////////////////////////////////////////////// 135 | SHOTGUN: TRADING BATCH 136 | /////////////////////////////////////////////////////////// 137 | */ 138 | 139 | export function shotgun() { 140 | return new Promise((resolve, reject) => { 141 | return Promise.delay(1000) 142 | .then(() => { 143 | temp_volume-- 144 | return tradingEvent() 145 | }).then(() => { 146 | if(temp_volume <= 0) { 147 | console.log('hit resolve in shotgun') 148 | return true 149 | } else { 150 | return shotgun() 151 | } 152 | }).then(() => { 153 | resolve(true) 154 | }).catch((err) => { 155 | reject(err) 156 | }) 157 | }) 158 | } 159 | 160 | export function tradingEvent() { 161 | return new Promise((resolve, reject) => { 162 | Promise.resolve(tradeDirection()) 163 | .then((d) => { 164 | if (d == 0) { 165 | return sellA(market) 166 | } else { 167 | return sellB(market) 168 | } 169 | }).then(() => { 170 | resolve(true) 171 | }).catch((error) => { 172 | reject(error) 173 | }) 174 | }) 175 | } 176 | 177 | export function sellA(market) { 178 | return new Promise((resolve, reject) => { 179 | return Promise.delay(0) 180 | .then(() => { 181 | return bellRandom(price, price_variance) 182 | }).then((p) => { 183 | sellA_obj['price'] = p 184 | return flatRandom() 185 | }).then((q) => { 186 | sellA_obj['quantity'] = q 187 | console.log('### sellA order:', sellA_obj['price'], sellA_obj['quantity']) 188 | return market.sellA(sellA_obj) 189 | }).then(() => { 190 | resolve(true) 191 | }).catch((err) => { 192 | reject(err) 193 | }) 194 | }) 195 | } 196 | 197 | export function sellB(market) { 198 | return new Promise((resolve, reject) => { 199 | return Promise.delay(0) 200 | .then(() => { 201 | return bellRandom(price, price_variance) 202 | }).then((p) => { 203 | sellB_obj['price'] = p 204 | return flatRandom() 205 | }).then((q) => { 206 | sellB_obj['quantity'] = q 207 | console.log('### sellB order:', sellB_obj['price'], sellB_obj['quantity']) 208 | return market.sellB(sellB_obj) 209 | }).then(() => { 210 | resolve(true) 211 | }).catch((err) => { 212 | reject(err) 213 | }) 214 | }) 215 | } 216 | 217 | /* 218 | /////////////////////////////////////////////////////////// 219 | MATH UTILIITES 220 | /////////////////////////////////////////////////////////// 221 | */ 222 | export function bellRandom(mean, variance) { 223 | const distribution = gaussian(mean, variance) 224 | // Take a random sample using inverse transform sampling method. 225 | const sample = distribution.ppf(Math.random()) 226 | return sample 227 | } 228 | 229 | export function flatRandom(mean) { 230 | return Math.floor(Math.random() * 100) 231 | } 232 | 233 | export function tradeDirection() { 234 | return Math.round(Math.random()) 235 | } 236 | 237 | simulationLoop() 238 | -------------------------------------------------------------------------------- /server/gauss/utils.js: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ConsenSysMesh/dex-mobile/a639d0e4a7ef6321881f994acb5e0bbd066162f5/server/gauss/utils.js -------------------------------------------------------------------------------- /server/markets/Market.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird' 2 | 3 | /** 4 | * Market 5 | * microservice container for Mob instance 6 | */ 7 | export default class Market { 8 | constructor(params) { 9 | this.tokenA = params.tokenA 10 | this.tokenB = params.tokenB 11 | this.bookA = [] 12 | this.bookB = [] 13 | } 14 | 15 | sellA(sell_obj) { 16 | return new Promise((resolve, reject) => { 17 | return Promise.delay(0) 18 | .then(() => { 19 | return this.bookA.splice(this.insertA(sell_obj) + 1, 0, sell_obj) 20 | }).then(() => { 21 | resolve(true) 22 | }).catch((err) => { 23 | reject(err) 24 | }) 25 | }) 26 | } 27 | 28 | sellB(sell_obj) { 29 | return new Promise((resolve, reject) => { 30 | return Promise.delay(0) 31 | .then(() => { 32 | return this.bookB.splice(this.insertB(sell_obj) + 1, 0, sell_obj) 33 | }).then(() => { 34 | resolve(true) 35 | }).catch((err) => { 36 | reject(err) 37 | }) 38 | }) 39 | } 40 | 41 | insertA(sell_obj) { 42 | let i = 0 43 | for(i; i < this.bookA.length; i++) { 44 | if (sell_obj.price < this.bookA[i]) { 45 | break 46 | } 47 | } 48 | return i 49 | } 50 | 51 | insertB(sell_obj) { 52 | let i = 0 53 | for(i; i < this.bookB.length; i++) { 54 | if (sell_obj.price < this.bookB[i]) { 55 | break 56 | } 57 | } 58 | return i 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /server/test/random_trading.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird' 2 | import { simulationLoop } from '../gauss/simulation' 3 | import Market from '../markets/Market' 4 | 5 | let market 6 | 7 | const tokenA = '0x692a70d2e424a56d2c6c27aa97d1a86395877b3a' 8 | const tokenB = '0xbbf289d846208c16edc8474705c748aff07732db' 9 | 10 | export function runSimulation() { 11 | return new Promise((resolve, reject) => { 12 | return Promise.delay(0).then(() => { 13 | return market = new Market ({ 14 | tokenA: tokenA, 15 | tokenB: tokenB, 16 | }) 17 | }).then(() => { 18 | return simulationLoop() 19 | }).then(() => { 20 | resolve(true) 21 | }).catch((err) => { 22 | reject(true) 23 | }) 24 | }) 25 | } 26 | 27 | runSimulation() 28 | -------------------------------------------------------------------------------- /server/test/test.js: -------------------------------------------------------------------------------- 1 | import Market from '../markets/Market' 2 | import Promise from 'bluebird' 3 | import ExAgent from '../exAgent/ExAgent' 4 | 5 | let exAgent 6 | let market 7 | let sellA_obj = { 8 | amount: 3000, 9 | price: 1.25, 10 | } 11 | let sellB_obj = { 12 | amount: 5000, 13 | price: 1.15, 14 | } 15 | const tokenA = '0x692a70d2e424a56d2c6c27aa97d1a86395877b3a' 16 | const tokenB = '0xbbf289d846208c16edc8474705c748aff07732db' 17 | 18 | export function createMarket(tokenA, tokenB) { 19 | return new Promise((resolve, reject) => { 20 | return Promise.delay(0).then(() => { 21 | return market = new Market({ 22 | tokenA: tokenB, 23 | tokenB: tokenB, 24 | }) 25 | }).then(() => { 26 | return exAgent = new ExAgent({ 27 | market: market 28 | tokenA: tokenA, 29 | tokenB: tokenB, 30 | }) 31 | .then(() => { 32 | resolve(true) 33 | }).catch((error) => { 34 | reject(error) 35 | }) 36 | }) 37 | } 38 | 39 | export function submitSell() { 40 | console.log('hit submit sell') 41 | return new Promise((resolve, reject) => { 42 | return market.sellA(sellA_obj) 43 | .then(() => { 44 | return market.sellB(sellB_obj) 45 | }).then(() => { 46 | console.log('market', market) 47 | resolve(true) 48 | }).catch((err) => { 49 | reject(err) 50 | }) 51 | }) 52 | } 53 | 54 | export function test() { 55 | return new Promise((resolve, reject) => { 56 | return Promise.delay(0).then(() => { 57 | return createMarket() 58 | }).then(() => { 59 | return submitSell() 60 | }).then(() => { 61 | resolve(true) 62 | }).catch((error) => { 63 | reject(error) 64 | }) 65 | }) 66 | } 67 | 68 | test() 69 | --------------------------------------------------------------------------------