├── .babelrc ├── .buckconfig ├── .flowconfig ├── .gitattributes ├── .gitignore ├── .watchmanconfig ├── README.md ├── __tests__ ├── index.android.js └── index.ios.js ├── android ├── app │ ├── BUCK │ ├── build.gradle │ ├── proguard-rules.pro │ └── src │ │ └── main │ │ ├── AndroidManifest.xml │ │ ├── java │ │ └── com │ │ │ └── rxapp │ │ │ ├── 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 ├── dist ├── App.js ├── App.js.map ├── bundle.js ├── bundle.js.map ├── index.js └── index.js.map ├── index.android.js ├── index.html ├── index.ios.js ├── ios ├── RXApp-tvOS │ └── Info.plist ├── RXApp-tvOSTests │ └── Info.plist ├── RXApp.xcodeproj │ ├── project.pbxproj │ └── xcshareddata │ │ └── xcschemes │ │ ├── RXApp-tvOS.xcscheme │ │ └── RXApp.xcscheme ├── RXApp │ ├── AppDelegate.h │ ├── AppDelegate.m │ ├── Base.lproj │ │ └── LaunchScreen.xib │ ├── Images.xcassets │ │ └── AppIcon.appiconset │ │ │ └── Contents.json │ ├── Info.plist │ └── main.m └── RXAppTests │ ├── Info.plist │ └── RXAppTests.m ├── package.json ├── src ├── App.tsx ├── index.tsx └── typings │ ├── react-native.d.ts │ └── react.d.ts ├── tsconfig.json ├── webpack.config.ts └── yarn.lock /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": ["react-native"] 3 | } -------------------------------------------------------------------------------- /.buckconfig: -------------------------------------------------------------------------------- 1 | 2 | [android] 3 | target = Google Inc.:Google APIs:23 4 | 5 | [maven_repositories] 6 | central = https://repo1.maven.org/maven2 7 | -------------------------------------------------------------------------------- /.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 | 11 | ; Ignore duplicate module providers 12 | ; For RN Apps installed via npm, "Libraries" folder is inside 13 | ; "node_modules/react-native" but in the source repo it is in the root 14 | .*/Libraries/react-native/React.js 15 | .*/Libraries/react-native/ReactNative.js 16 | 17 | [include] 18 | 19 | [libs] 20 | node_modules/react-native/Libraries/react-native/react-native-interface.js 21 | node_modules/react-native/flow 22 | flow/ 23 | 24 | [options] 25 | emoji=true 26 | 27 | module.system=haste 28 | 29 | experimental.strict_type_args=true 30 | 31 | munge_underscores=true 32 | 33 | 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' 34 | 35 | suppress_type=$FlowIssue 36 | suppress_type=$FlowFixMe 37 | suppress_type=$FixMe 38 | 39 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(>=0\\.\\(3[0-8]\\|[1-2][0-9]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\) 40 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(>=0\\.\\(3[0-8]\\|1[0-9]\\|[1-2][0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)?:? #[0-9]+ 41 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixedInNextDeploy 42 | 43 | unsafe.enable_getters_and_setters=true 44 | 45 | [version] 46 | ^0.38.0 47 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | *.pbxproj -text 2 | -------------------------------------------------------------------------------- /.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 | -------------------------------------------------------------------------------- /.watchmanconfig: -------------------------------------------------------------------------------- 1 | {} -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # RXP 2 | 3 | This app works on React Native (iOS, Android) and web. Most of the app's code is contained in `App.tsx`. 4 | 5 | The commands in the instructions below assume you are in the root of this repo. 6 | 7 | ### Initial Setup 8 | 9 | - Run `npm install`. This fetches the dependencies. 10 | - Open `node_modules/reactxp/dist/native-common/App.js` and replace 11 | `RN.AppRegistry.registerComponent('RXApp',` 12 | with 13 | `RN.AppRegistry.registerComponent('reactXPTest',` 14 | 15 | ### Building for Web 16 | 17 | - Run `npm run web-watch`. This compiles the TypeScript code and recompiles it whenever any files are changed. 18 | - Open `index.html` in your browser to view the result. 19 | 20 | ### Building for React Native 21 | 22 | - Run `npm run rn-watch`. This compiles the TypeScript code and recompiles it whenever any files are changed. 23 | - In another command prompt run `npm start`. This starts the React Native Packager. 24 | - Use Xcode or Android Studio to build and deploy the native app code just like you would with any other React Native project. 25 | -------------------------------------------------------------------------------- /__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 | -------------------------------------------------------------------------------- /__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 | -------------------------------------------------------------------------------- /android/app/BUCK: -------------------------------------------------------------------------------- 1 | import re 2 | 3 | # To learn about Buck see [Docs](https://buckbuild.com/). 4 | # To run your application with Buck: 5 | # - install Buck 6 | # - `npm start` - to start the packager 7 | # - `cd android` 8 | # - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"` 9 | # - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck 10 | # - `buck install -r android/app` - compile, install and run application 11 | # 12 | 13 | lib_deps = [] 14 | for jarfile in glob(['libs/*.jar']): 15 | name = 'jars__' + re.sub(r'^.*/([^/]+)\.jar$', r'\1', jarfile) 16 | lib_deps.append(':' + name) 17 | prebuilt_jar( 18 | name = name, 19 | binary_jar = jarfile, 20 | ) 21 | 22 | for aarfile in glob(['libs/*.aar']): 23 | name = 'aars__' + re.sub(r'^.*/([^/]+)\.aar$', r'\1', aarfile) 24 | lib_deps.append(':' + name) 25 | android_prebuilt_aar( 26 | name = name, 27 | aar = aarfile, 28 | ) 29 | 30 | android_library( 31 | name = 'all-libs', 32 | exported_deps = lib_deps 33 | ) 34 | 35 | android_library( 36 | name = 'app-code', 37 | srcs = glob([ 38 | 'src/main/java/**/*.java', 39 | ]), 40 | deps = [ 41 | ':all-libs', 42 | ':build_config', 43 | ':res', 44 | ], 45 | ) 46 | 47 | android_build_config( 48 | name = 'build_config', 49 | package = 'com.rxapp', 50 | ) 51 | 52 | android_resource( 53 | name = 'res', 54 | res = 'src/main/res', 55 | package = 'com.rxapp', 56 | ) 57 | 58 | android_binary( 59 | name = 'app', 60 | package_type = 'debug', 61 | manifest = 'src/main/AndroidManifest.xml', 62 | keystore = '//android/keystores:debug', 63 | deps = [ 64 | ':app-code', 65 | ], 66 | ) 67 | -------------------------------------------------------------------------------- /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.rxapp" 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 fileTree(dir: "libs", include: ["*.jar"]) 130 | compile "com.android.support:appcompat-v7:23.0.1" 131 | compile "com.facebook.react:react-native:+" // From node_modules 132 | } 133 | 134 | // Run this once to be able to run the application with BUCK 135 | // puts all compile dependencies into folder libs for BUCK to use 136 | task copyDownloadableDepsToLibs(type: Copy) { 137 | from configurations.compile 138 | into 'libs' 139 | } 140 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /android/app/src/main/java/com/rxapp/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.rxapp; 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 "RXApp"; 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /android/app/src/main/java/com/rxapp/MainApplication.java: -------------------------------------------------------------------------------- 1 | package com.rxapp; 2 | 3 | import android.app.Application; 4 | 5 | import com.facebook.react.ReactApplication; 6 | import com.facebook.react.ReactNativeHost; 7 | import com.facebook.react.ReactPackage; 8 | import com.facebook.react.shell.MainReactPackage; 9 | import com.facebook.soloader.SoLoader; 10 | 11 | import java.util.Arrays; 12 | import java.util.List; 13 | 14 | public class MainApplication extends Application implements ReactApplication { 15 | 16 | private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) { 17 | @Override 18 | public boolean getUseDeveloperSupport() { 19 | return BuildConfig.DEBUG; 20 | } 21 | 22 | @Override 23 | protected List getPackages() { 24 | return Arrays.asList( 25 | new MainReactPackage() 26 | ); 27 | } 28 | }; 29 | 30 | @Override 31 | public ReactNativeHost getReactNativeHost() { 32 | return mReactNativeHost; 33 | } 34 | 35 | @Override 36 | public void onCreate() { 37 | super.onCreate(); 38 | SoLoader.init(this, /* native exopackage */ false); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/react-native-training/reactxp-starter/040cf7ed3dff0a05b45b35bd6b69691c7d8856de/android/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/react-native-training/reactxp-starter/040cf7ed3dff0a05b45b35bd6b69691c7d8856de/android/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/react-native-training/reactxp-starter/040cf7ed3dff0a05b45b35bd6b69691c7d8856de/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/react-native-training/reactxp-starter/040cf7ed3dff0a05b45b35bd6b69691c7d8856de/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /android/app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | rxapp 3 | 4 | -------------------------------------------------------------------------------- /android/app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /android/gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/react-native-training/reactxp-starter/040cf7ed3dff0a05b45b35bd6b69691c7d8856de/android/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /android/keystores/BUCK: -------------------------------------------------------------------------------- 1 | keystore( 2 | name = 'debug', 3 | store = 'debug.keystore', 4 | properties = 'debug.keystore.properties', 5 | visibility = [ 6 | 'PUBLIC', 7 | ], 8 | ) 9 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /android/settings.gradle: -------------------------------------------------------------------------------- 1 | rootProject.name = 'rxapp' 2 | 3 | include ':app' 4 | -------------------------------------------------------------------------------- /app.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rxapp", 3 | "displayName": "rxapp" 4 | } -------------------------------------------------------------------------------- /dist/App.js: -------------------------------------------------------------------------------- 1 | /* 2 | * This file demonstrates a basic ReactXP app. 3 | */ 4 | "use strict"; 5 | var __extends = (this && this.__extends) || function (d, b) { 6 | for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; 7 | function __() { this.constructor = d; } 8 | d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); 9 | }; 10 | var RX = require("reactxp"); 11 | var styles = { 12 | container: RX.Styles.createViewStyle({ 13 | flex: 1, 14 | justifyContent: 'center', 15 | alignItems: 'center', 16 | backgroundColor: '#f5fcff' 17 | }), 18 | helloWorld: RX.Styles.createTextStyle({ 19 | fontSize: 48, 20 | fontWeight: 'bold', 21 | marginBottom: 28 22 | }), 23 | welcome: RX.Styles.createTextStyle({ 24 | fontSize: 32, 25 | marginBottom: 12 26 | }), 27 | instructions: RX.Styles.createTextStyle({ 28 | fontSize: 16, 29 | color: '#aaa', 30 | marginBottom: 40 31 | }), 32 | docLink: RX.Styles.createLinkStyle({ 33 | fontSize: 16, 34 | color: 'blue' 35 | }) 36 | }; 37 | var App = (function (_super) { 38 | __extends(App, _super); 39 | function App() { 40 | var _this = _super.call(this) || this; 41 | _this._translationValue = new RX.Animated.Value(-100); 42 | _this._animatedStyle = RX.Styles.createAnimatedTextStyle({ 43 | transform: [ 44 | { 45 | translateY: _this._translationValue 46 | } 47 | ] 48 | }); 49 | return _this; 50 | } 51 | App.prototype.componentDidMount = function () { 52 | var animation = RX.Animated.timing(this._translationValue, { 53 | toValue: 0, 54 | easing: RX.Animated.Easing.OutBack(), 55 | duration: 500 56 | }); 57 | animation.start(); 58 | }; 59 | App.prototype.render = function () { 60 | return (RX.createElement(RX.View, { style: styles.container }, 61 | RX.createElement(RX.Animated.Text, { style: [styles.helloWorld, this._animatedStyle] }, "Hello World"), 62 | RX.createElement(RX.Text, { style: styles.welcome }, "Welcome to ReactXP"), 63 | RX.createElement(RX.Text, { style: styles.instructions }, "Edit App.tsx to get started"), 64 | RX.createElement(RX.Link, { style: styles.docLink, url: 'https://microsoft.github.io/reactxp/docs' }, "View ReactXP documentation"))); 65 | }; 66 | return App; 67 | }(RX.Component)); 68 | module.exports = App; 69 | //# sourceMappingURL=App.js.map -------------------------------------------------------------------------------- /dist/App.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"App.js","sourceRoot":"","sources":["../src/App.tsx"],"names":[],"mappings":"AAAA;;EAEE;;;;;;;AAEF,4BAA+B;AAE/B,IAAM,MAAM,GAAG;IACX,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC;QACjC,IAAI,EAAE,CAAC;QACP,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,QAAQ;QACpB,eAAe,EAAE,SAAS;KAC7B,CAAC;IACF,UAAU,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC;QAClC,QAAQ,EAAE,EAAE;QACZ,UAAU,EAAE,MAAM;QAClB,YAAY,EAAE,EAAE;KACnB,CAAC;IACF,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC;QAC/B,QAAQ,EAAE,EAAE;QACZ,YAAY,EAAE,EAAE;KACnB,CAAC;IACF,YAAY,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC;QACpC,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,MAAM;QACb,YAAY,EAAE,EAAE;KACnB,CAAC;IACF,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC;QAC/B,QAAQ,EAAE,EAAE;QACZ,KAAK,EAAE,MAAM;KAChB,CAAC;CACL,CAAC;AAEF;IAAkB,uBAAwB;IAItC;QAAA,YACI,iBAAO,SAUV;QARG,KAAI,CAAC,iBAAiB,GAAG,IAAI,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QACrD,KAAI,CAAC,cAAc,GAAG,EAAE,CAAC,MAAM,CAAC,uBAAuB,CAAC;YACpD,SAAS,EAAE;gBACP;oBACI,UAAU,EAAE,KAAI,CAAC,iBAAiB;iBACrC;aACJ;SACJ,CAAC,CAAC;;IACP,CAAC;IAED,+BAAiB,GAAjB;QACI,IAAI,SAAS,GAAG,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE;YACrD,OAAO,EAAE,CAAC;YACV,MAAM,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE;YACpC,QAAQ,EAAE,GAAG;SACd,CACJ,CAAC;QAEF,SAAS,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC;IAED,oBAAM,GAAN;QACI,MAAM,CAAC,CACH,iBAAC,EAAE,CAAC,IAAI,IAAC,KAAK,EAAG,MAAM,CAAC,SAAS;YAC7B,iBAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,IAAC,KAAK,EAAG,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,kBAE/C;YACnB,iBAAC,EAAE,CAAC,IAAI,IAAC,KAAK,EAAG,MAAM,CAAC,OAAO,yBAErB;YACV,iBAAC,EAAE,CAAC,IAAI,IAAC,KAAK,EAAG,MAAM,CAAC,YAAY,kCAE1B;YACV,iBAAC,EAAE,CAAC,IAAI,IAAC,KAAK,EAAG,MAAM,CAAC,OAAO,EAAG,GAAG,EAAG,0CAA0C,iCAExE,CACJ,CACb,CAAC;IACN,CAAC;IACL,UAAC;AAAD,CAAC,AA9CD,CAAkB,EAAE,CAAC,SAAS,GA8C7B;AAED,iBAAS,GAAG,CAAC"} -------------------------------------------------------------------------------- /dist/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | var RX = require("reactxp"); 3 | var App = require("./App"); 4 | RX.App.initialize(true, true); 5 | RX.UserInterface.setMainView(RX.createElement(App, null)); 6 | //# sourceMappingURL=index.js.map -------------------------------------------------------------------------------- /dist/index.js.map: -------------------------------------------------------------------------------- 1 | {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.tsx"],"names":[],"mappings":";AAAA,4BAA+B;AAC/B,2BAA8B;AAI9B,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC9B,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,iBAAC,GAAG,OAAG,CAAC,CAAC"} -------------------------------------------------------------------------------- /index.android.js: -------------------------------------------------------------------------------- 1 | require('./dist/index'); 2 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 18 | 19 | 20 |
21 | 22 | 23 | -------------------------------------------------------------------------------- /index.ios.js: -------------------------------------------------------------------------------- 1 | require('./dist/index'); 2 | -------------------------------------------------------------------------------- /ios/RXApp-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 | -------------------------------------------------------------------------------- /ios/RXApp-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 | -------------------------------------------------------------------------------- /ios/RXApp.xcodeproj/project.pbxproj: -------------------------------------------------------------------------------- 1 | // !$*UTF8*$! 2 | { 3 | archiveVersion = 1; 4 | classes = { 5 | }; 6 | objectVersion = 46; 7 | objects = { 8 | 9 | /* Begin PBXBuildFile section */ 10 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */; }; 11 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */; }; 12 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */; }; 13 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */; }; 14 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */; }; 15 | 00E356F31AD99517003FC87E /* rxappTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* rxappTests.m */; }; 16 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 78C398B91ACF4ADC00677621 /* libRCTLinking.a */; }; 17 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */; }; 18 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */; }; 19 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; }; 20 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; }; 21 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; 22 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; 23 | 140ED2AC1D01E1AD002B40FF /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 146834041AC3E56700842450 /* libReact.a */; }; 24 | 146834051AC3E58100842450 /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 146834041AC3E56700842450 /* libReact.a */; }; 25 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; }; 26 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; 27 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; 28 | 2D02E4C21E0B4AEC006451C7 /* libRCTAnimation-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */; }; 29 | 2D02E4C31E0B4AEC006451C7 /* libRCTImage-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */; }; 30 | 2D02E4C41E0B4AEC006451C7 /* libRCTLinking-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */; }; 31 | 2D02E4C51E0B4AEC006451C7 /* libRCTNetwork-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */; }; 32 | 2D02E4C61E0B4AEC006451C7 /* libRCTSettings-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */; }; 33 | 2D02E4C71E0B4AEC006451C7 /* libRCTText-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */; }; 34 | 2D02E4C81E0B4AEC006451C7 /* libRCTWebSocket-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */; }; 35 | 2D02E4C91E0B4AEC006451C7 /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3DAD3EA31DF850E9000B6D8A /* libReact.a */; }; 36 | 2DCD954D1E0B4F2C00145EB5 /* rxappTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* rxappTests.m */; }; 37 | 5E9157361DD0AC6A00FF2AA8 /* libRCTAnimation.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */; }; 38 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 832341B51AAA6A8300B99B32 /* libRCTText.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 = rxapp; 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 = "rxapp-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 /* rxappTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = rxappTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; 241 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; 242 | 00E356F21AD99517003FC87E /* rxappTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = rxappTests.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 /* rxapp.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = rxapp.app; sourceTree = BUILT_PRODUCTS_DIR; }; 246 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = rxapp/AppDelegate.h; sourceTree = ""; }; 247 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = rxapp/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 = rxapp/Images.xcassets; sourceTree = ""; }; 250 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = rxapp/Info.plist; sourceTree = ""; }; 251 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = rxapp/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 /* rxapp-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "rxapp-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; }; 254 | 2D02E4901E0B4A5D006451C7 /* rxapp-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "rxapp-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 | /* End PBXFileReference section */ 259 | 260 | /* Begin PBXFrameworksBuildPhase section */ 261 | 00E356EB1AD99517003FC87E /* Frameworks */ = { 262 | isa = PBXFrameworksBuildPhase; 263 | buildActionMask = 2147483647; 264 | files = ( 265 | 140ED2AC1D01E1AD002B40FF /* libReact.a in Frameworks */, 266 | ); 267 | runOnlyForDeploymentPostprocessing = 0; 268 | }; 269 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = { 270 | isa = PBXFrameworksBuildPhase; 271 | buildActionMask = 2147483647; 272 | files = ( 273 | 146834051AC3E58100842450 /* libReact.a in Frameworks */, 274 | 5E9157361DD0AC6A00FF2AA8 /* libRCTAnimation.a in Frameworks */, 275 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */, 276 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */, 277 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */, 278 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */, 279 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */, 280 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */, 281 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */, 282 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */, 283 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */, 284 | ); 285 | runOnlyForDeploymentPostprocessing = 0; 286 | }; 287 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = { 288 | isa = PBXFrameworksBuildPhase; 289 | buildActionMask = 2147483647; 290 | files = ( 291 | 2D02E4C91E0B4AEC006451C7 /* libReact.a in Frameworks */, 292 | 2D02E4C21E0B4AEC006451C7 /* libRCTAnimation-tvOS.a in Frameworks */, 293 | 2D02E4C31E0B4AEC006451C7 /* libRCTImage-tvOS.a in Frameworks */, 294 | 2D02E4C41E0B4AEC006451C7 /* libRCTLinking-tvOS.a in Frameworks */, 295 | 2D02E4C51E0B4AEC006451C7 /* libRCTNetwork-tvOS.a in Frameworks */, 296 | 2D02E4C61E0B4AEC006451C7 /* libRCTSettings-tvOS.a in Frameworks */, 297 | 2D02E4C71E0B4AEC006451C7 /* libRCTText-tvOS.a in Frameworks */, 298 | 2D02E4C81E0B4AEC006451C7 /* libRCTWebSocket-tvOS.a in Frameworks */, 299 | ); 300 | runOnlyForDeploymentPostprocessing = 0; 301 | }; 302 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = { 303 | isa = PBXFrameworksBuildPhase; 304 | buildActionMask = 2147483647; 305 | files = ( 306 | ); 307 | runOnlyForDeploymentPostprocessing = 0; 308 | }; 309 | /* End PBXFrameworksBuildPhase section */ 310 | 311 | /* Begin PBXGroup section */ 312 | 00C302A81ABCB8CE00DB3ED1 /* Products */ = { 313 | isa = PBXGroup; 314 | children = ( 315 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */, 316 | ); 317 | name = Products; 318 | sourceTree = ""; 319 | }; 320 | 00C302B61ABCB90400DB3ED1 /* Products */ = { 321 | isa = PBXGroup; 322 | children = ( 323 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */, 324 | ); 325 | name = Products; 326 | sourceTree = ""; 327 | }; 328 | 00C302BC1ABCB91800DB3ED1 /* Products */ = { 329 | isa = PBXGroup; 330 | children = ( 331 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */, 332 | 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */, 333 | ); 334 | name = Products; 335 | sourceTree = ""; 336 | }; 337 | 00C302D41ABCB9D200DB3ED1 /* Products */ = { 338 | isa = PBXGroup; 339 | children = ( 340 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */, 341 | 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */, 342 | ); 343 | name = Products; 344 | sourceTree = ""; 345 | }; 346 | 00C302E01ABCB9EE00DB3ED1 /* Products */ = { 347 | isa = PBXGroup; 348 | children = ( 349 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */, 350 | ); 351 | name = Products; 352 | sourceTree = ""; 353 | }; 354 | 00E356EF1AD99517003FC87E /* rxappTests */ = { 355 | isa = PBXGroup; 356 | children = ( 357 | 00E356F21AD99517003FC87E /* rxappTests.m */, 358 | 00E356F01AD99517003FC87E /* Supporting Files */, 359 | ); 360 | path = rxappTests; 361 | sourceTree = ""; 362 | }; 363 | 00E356F01AD99517003FC87E /* Supporting Files */ = { 364 | isa = PBXGroup; 365 | children = ( 366 | 00E356F11AD99517003FC87E /* Info.plist */, 367 | ); 368 | name = "Supporting Files"; 369 | sourceTree = ""; 370 | }; 371 | 139105B71AF99BAD00B5F7CC /* Products */ = { 372 | isa = PBXGroup; 373 | children = ( 374 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */, 375 | 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */, 376 | ); 377 | name = Products; 378 | sourceTree = ""; 379 | }; 380 | 139FDEE71B06529A00C62182 /* Products */ = { 381 | isa = PBXGroup; 382 | children = ( 383 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */, 384 | 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */, 385 | ); 386 | name = Products; 387 | sourceTree = ""; 388 | }; 389 | 13B07FAE1A68108700A75B9A /* rxapp */ = { 390 | isa = PBXGroup; 391 | children = ( 392 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */, 393 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */, 394 | 13B07FB01A68108700A75B9A /* AppDelegate.m */, 395 | 13B07FB51A68108700A75B9A /* Images.xcassets */, 396 | 13B07FB61A68108700A75B9A /* Info.plist */, 397 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */, 398 | 13B07FB71A68108700A75B9A /* main.m */, 399 | ); 400 | name = rxapp; 401 | sourceTree = ""; 402 | }; 403 | 146834001AC3E56700842450 /* Products */ = { 404 | isa = PBXGroup; 405 | children = ( 406 | 146834041AC3E56700842450 /* libReact.a */, 407 | 3DAD3EA31DF850E9000B6D8A /* libReact.a */, 408 | 3DAD3EA51DF850E9000B6D8A /* libyoga.a */, 409 | 3DAD3EA71DF850E9000B6D8A /* libyoga.a */, 410 | 3DAD3EA91DF850E9000B6D8A /* libcxxreact.a */, 411 | 3DAD3EAB1DF850E9000B6D8A /* libcxxreact.a */, 412 | 3DAD3EAD1DF850E9000B6D8A /* libjschelpers.a */, 413 | 3DAD3EAF1DF850E9000B6D8A /* libjschelpers.a */, 414 | ); 415 | name = Products; 416 | sourceTree = ""; 417 | }; 418 | 5E91572E1DD0AC6500FF2AA8 /* Products */ = { 419 | isa = PBXGroup; 420 | children = ( 421 | 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */, 422 | 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */, 423 | ); 424 | name = Products; 425 | sourceTree = ""; 426 | }; 427 | 78C398B11ACF4ADC00677621 /* Products */ = { 428 | isa = PBXGroup; 429 | children = ( 430 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */, 431 | 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */, 432 | ); 433 | name = Products; 434 | sourceTree = ""; 435 | }; 436 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = { 437 | isa = PBXGroup; 438 | children = ( 439 | 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */, 440 | 146833FF1AC3E56700842450 /* React.xcodeproj */, 441 | 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */, 442 | 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */, 443 | 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */, 444 | 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */, 445 | 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */, 446 | 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */, 447 | 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */, 448 | 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */, 449 | 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */, 450 | ); 451 | name = Libraries; 452 | sourceTree = ""; 453 | }; 454 | 832341B11AAA6A8300B99B32 /* Products */ = { 455 | isa = PBXGroup; 456 | children = ( 457 | 832341B51AAA6A8300B99B32 /* libRCTText.a */, 458 | 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */, 459 | ); 460 | name = Products; 461 | sourceTree = ""; 462 | }; 463 | 83CBB9F61A601CBA00E9B192 = { 464 | isa = PBXGroup; 465 | children = ( 466 | 13B07FAE1A68108700A75B9A /* rxapp */, 467 | 832341AE1AAA6A7D00B99B32 /* Libraries */, 468 | 00E356EF1AD99517003FC87E /* rxappTests */, 469 | 83CBBA001A601CBA00E9B192 /* Products */, 470 | ); 471 | indentWidth = 2; 472 | sourceTree = ""; 473 | tabWidth = 2; 474 | }; 475 | 83CBBA001A601CBA00E9B192 /* Products */ = { 476 | isa = PBXGroup; 477 | children = ( 478 | 13B07F961A680F5B00A75B9A /* rxapp.app */, 479 | 00E356EE1AD99517003FC87E /* rxappTests.xctest */, 480 | 2D02E47B1E0B4A5D006451C7 /* rxapp-tvOS.app */, 481 | 2D02E4901E0B4A5D006451C7 /* rxapp-tvOSTests.xctest */, 482 | ); 483 | name = Products; 484 | sourceTree = ""; 485 | }; 486 | /* End PBXGroup section */ 487 | 488 | /* Begin PBXNativeTarget section */ 489 | 00E356ED1AD99517003FC87E /* rxappTests */ = { 490 | isa = PBXNativeTarget; 491 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "rxappTests" */; 492 | buildPhases = ( 493 | 00E356EA1AD99517003FC87E /* Sources */, 494 | 00E356EB1AD99517003FC87E /* Frameworks */, 495 | 00E356EC1AD99517003FC87E /* Resources */, 496 | ); 497 | buildRules = ( 498 | ); 499 | dependencies = ( 500 | 00E356F51AD99517003FC87E /* PBXTargetDependency */, 501 | ); 502 | name = rxappTests; 503 | productName = rxappTests; 504 | productReference = 00E356EE1AD99517003FC87E /* rxappTests.xctest */; 505 | productType = "com.apple.product-type.bundle.unit-test"; 506 | }; 507 | 13B07F861A680F5B00A75B9A /* rxapp */ = { 508 | isa = PBXNativeTarget; 509 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "rxapp" */; 510 | buildPhases = ( 511 | 13B07F871A680F5B00A75B9A /* Sources */, 512 | 13B07F8C1A680F5B00A75B9A /* Frameworks */, 513 | 13B07F8E1A680F5B00A75B9A /* Resources */, 514 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */, 515 | ); 516 | buildRules = ( 517 | ); 518 | dependencies = ( 519 | ); 520 | name = rxapp; 521 | productName = "Hello World"; 522 | productReference = 13B07F961A680F5B00A75B9A /* rxapp.app */; 523 | productType = "com.apple.product-type.application"; 524 | }; 525 | 2D02E47A1E0B4A5D006451C7 /* rxapp-tvOS */ = { 526 | isa = PBXNativeTarget; 527 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "rxapp-tvOS" */; 528 | buildPhases = ( 529 | 2D02E4771E0B4A5D006451C7 /* Sources */, 530 | 2D02E4781E0B4A5D006451C7 /* Frameworks */, 531 | 2D02E4791E0B4A5D006451C7 /* Resources */, 532 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */, 533 | ); 534 | buildRules = ( 535 | ); 536 | dependencies = ( 537 | ); 538 | name = "rxapp-tvOS"; 539 | productName = "rxapp-tvOS"; 540 | productReference = 2D02E47B1E0B4A5D006451C7 /* rxapp-tvOS.app */; 541 | productType = "com.apple.product-type.application"; 542 | }; 543 | 2D02E48F1E0B4A5D006451C7 /* rxapp-tvOSTests */ = { 544 | isa = PBXNativeTarget; 545 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "rxapp-tvOSTests" */; 546 | buildPhases = ( 547 | 2D02E48C1E0B4A5D006451C7 /* Sources */, 548 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */, 549 | 2D02E48E1E0B4A5D006451C7 /* Resources */, 550 | ); 551 | buildRules = ( 552 | ); 553 | dependencies = ( 554 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */, 555 | ); 556 | name = "rxapp-tvOSTests"; 557 | productName = "rxapp-tvOSTests"; 558 | productReference = 2D02E4901E0B4A5D006451C7 /* rxapp-tvOSTests.xctest */; 559 | productType = "com.apple.product-type.bundle.unit-test"; 560 | }; 561 | /* End PBXNativeTarget section */ 562 | 563 | /* Begin PBXProject section */ 564 | 83CBB9F71A601CBA00E9B192 /* Project object */ = { 565 | isa = PBXProject; 566 | attributes = { 567 | LastUpgradeCheck = 0610; 568 | ORGANIZATIONNAME = Facebook; 569 | TargetAttributes = { 570 | 00E356ED1AD99517003FC87E = { 571 | CreatedOnToolsVersion = 6.2; 572 | TestTargetID = 13B07F861A680F5B00A75B9A; 573 | }; 574 | 2D02E47A1E0B4A5D006451C7 = { 575 | CreatedOnToolsVersion = 8.2.1; 576 | ProvisioningStyle = Automatic; 577 | }; 578 | 2D02E48F1E0B4A5D006451C7 = { 579 | CreatedOnToolsVersion = 8.2.1; 580 | ProvisioningStyle = Automatic; 581 | TestTargetID = 2D02E47A1E0B4A5D006451C7; 582 | }; 583 | }; 584 | }; 585 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "rxapp" */; 586 | compatibilityVersion = "Xcode 3.2"; 587 | developmentRegion = English; 588 | hasScannedForEncodings = 0; 589 | knownRegions = ( 590 | en, 591 | Base, 592 | ); 593 | mainGroup = 83CBB9F61A601CBA00E9B192; 594 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */; 595 | projectDirPath = ""; 596 | projectReferences = ( 597 | { 598 | ProductGroup = 00C302A81ABCB8CE00DB3ED1 /* Products */; 599 | ProjectRef = 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */; 600 | }, 601 | { 602 | ProductGroup = 5E91572E1DD0AC6500FF2AA8 /* Products */; 603 | ProjectRef = 5E91572D1DD0AC6500FF2AA8 /* RCTAnimation.xcodeproj */; 604 | }, 605 | { 606 | ProductGroup = 00C302B61ABCB90400DB3ED1 /* Products */; 607 | ProjectRef = 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */; 608 | }, 609 | { 610 | ProductGroup = 00C302BC1ABCB91800DB3ED1 /* Products */; 611 | ProjectRef = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */; 612 | }, 613 | { 614 | ProductGroup = 78C398B11ACF4ADC00677621 /* Products */; 615 | ProjectRef = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */; 616 | }, 617 | { 618 | ProductGroup = 00C302D41ABCB9D200DB3ED1 /* Products */; 619 | ProjectRef = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */; 620 | }, 621 | { 622 | ProductGroup = 139105B71AF99BAD00B5F7CC /* Products */; 623 | ProjectRef = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */; 624 | }, 625 | { 626 | ProductGroup = 832341B11AAA6A8300B99B32 /* Products */; 627 | ProjectRef = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */; 628 | }, 629 | { 630 | ProductGroup = 00C302E01ABCB9EE00DB3ED1 /* Products */; 631 | ProjectRef = 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */; 632 | }, 633 | { 634 | ProductGroup = 139FDEE71B06529A00C62182 /* Products */; 635 | ProjectRef = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */; 636 | }, 637 | { 638 | ProductGroup = 146834001AC3E56700842450 /* Products */; 639 | ProjectRef = 146833FF1AC3E56700842450 /* React.xcodeproj */; 640 | }, 641 | ); 642 | projectRoot = ""; 643 | targets = ( 644 | 13B07F861A680F5B00A75B9A /* rxapp */, 645 | 00E356ED1AD99517003FC87E /* rxappTests */, 646 | 2D02E47A1E0B4A5D006451C7 /* rxapp-tvOS */, 647 | 2D02E48F1E0B4A5D006451C7 /* rxapp-tvOSTests */, 648 | ); 649 | }; 650 | /* End PBXProject section */ 651 | 652 | /* Begin PBXReferenceProxy section */ 653 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */ = { 654 | isa = PBXReferenceProxy; 655 | fileType = archive.ar; 656 | path = libRCTActionSheet.a; 657 | remoteRef = 00C302AB1ABCB8CE00DB3ED1 /* PBXContainerItemProxy */; 658 | sourceTree = BUILT_PRODUCTS_DIR; 659 | }; 660 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */ = { 661 | isa = PBXReferenceProxy; 662 | fileType = archive.ar; 663 | path = libRCTGeolocation.a; 664 | remoteRef = 00C302B91ABCB90400DB3ED1 /* PBXContainerItemProxy */; 665 | sourceTree = BUILT_PRODUCTS_DIR; 666 | }; 667 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */ = { 668 | isa = PBXReferenceProxy; 669 | fileType = archive.ar; 670 | path = libRCTImage.a; 671 | remoteRef = 00C302BF1ABCB91800DB3ED1 /* PBXContainerItemProxy */; 672 | sourceTree = BUILT_PRODUCTS_DIR; 673 | }; 674 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */ = { 675 | isa = PBXReferenceProxy; 676 | fileType = archive.ar; 677 | path = libRCTNetwork.a; 678 | remoteRef = 00C302DB1ABCB9D200DB3ED1 /* PBXContainerItemProxy */; 679 | sourceTree = BUILT_PRODUCTS_DIR; 680 | }; 681 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */ = { 682 | isa = PBXReferenceProxy; 683 | fileType = archive.ar; 684 | path = libRCTVibration.a; 685 | remoteRef = 00C302E31ABCB9EE00DB3ED1 /* PBXContainerItemProxy */; 686 | sourceTree = BUILT_PRODUCTS_DIR; 687 | }; 688 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */ = { 689 | isa = PBXReferenceProxy; 690 | fileType = archive.ar; 691 | path = libRCTSettings.a; 692 | remoteRef = 139105C01AF99BAD00B5F7CC /* PBXContainerItemProxy */; 693 | sourceTree = BUILT_PRODUCTS_DIR; 694 | }; 695 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */ = { 696 | isa = PBXReferenceProxy; 697 | fileType = archive.ar; 698 | path = libRCTWebSocket.a; 699 | remoteRef = 139FDEF31B06529B00C62182 /* PBXContainerItemProxy */; 700 | sourceTree = BUILT_PRODUCTS_DIR; 701 | }; 702 | 146834041AC3E56700842450 /* libReact.a */ = { 703 | isa = PBXReferenceProxy; 704 | fileType = archive.ar; 705 | path = libReact.a; 706 | remoteRef = 146834031AC3E56700842450 /* PBXContainerItemProxy */; 707 | sourceTree = BUILT_PRODUCTS_DIR; 708 | }; 709 | 3DAD3E841DF850E9000B6D8A /* libRCTImage-tvOS.a */ = { 710 | isa = PBXReferenceProxy; 711 | fileType = archive.ar; 712 | path = "libRCTImage-tvOS.a"; 713 | remoteRef = 3DAD3E831DF850E9000B6D8A /* PBXContainerItemProxy */; 714 | sourceTree = BUILT_PRODUCTS_DIR; 715 | }; 716 | 3DAD3E881DF850E9000B6D8A /* libRCTLinking-tvOS.a */ = { 717 | isa = PBXReferenceProxy; 718 | fileType = archive.ar; 719 | path = "libRCTLinking-tvOS.a"; 720 | remoteRef = 3DAD3E871DF850E9000B6D8A /* PBXContainerItemProxy */; 721 | sourceTree = BUILT_PRODUCTS_DIR; 722 | }; 723 | 3DAD3E8C1DF850E9000B6D8A /* libRCTNetwork-tvOS.a */ = { 724 | isa = PBXReferenceProxy; 725 | fileType = archive.ar; 726 | path = "libRCTNetwork-tvOS.a"; 727 | remoteRef = 3DAD3E8B1DF850E9000B6D8A /* PBXContainerItemProxy */; 728 | sourceTree = BUILT_PRODUCTS_DIR; 729 | }; 730 | 3DAD3E901DF850E9000B6D8A /* libRCTSettings-tvOS.a */ = { 731 | isa = PBXReferenceProxy; 732 | fileType = archive.ar; 733 | path = "libRCTSettings-tvOS.a"; 734 | remoteRef = 3DAD3E8F1DF850E9000B6D8A /* PBXContainerItemProxy */; 735 | sourceTree = BUILT_PRODUCTS_DIR; 736 | }; 737 | 3DAD3E941DF850E9000B6D8A /* libRCTText-tvOS.a */ = { 738 | isa = PBXReferenceProxy; 739 | fileType = archive.ar; 740 | path = "libRCTText-tvOS.a"; 741 | remoteRef = 3DAD3E931DF850E9000B6D8A /* PBXContainerItemProxy */; 742 | sourceTree = BUILT_PRODUCTS_DIR; 743 | }; 744 | 3DAD3E991DF850E9000B6D8A /* libRCTWebSocket-tvOS.a */ = { 745 | isa = PBXReferenceProxy; 746 | fileType = archive.ar; 747 | path = "libRCTWebSocket-tvOS.a"; 748 | remoteRef = 3DAD3E981DF850E9000B6D8A /* PBXContainerItemProxy */; 749 | sourceTree = BUILT_PRODUCTS_DIR; 750 | }; 751 | 3DAD3EA31DF850E9000B6D8A /* libReact.a */ = { 752 | isa = PBXReferenceProxy; 753 | fileType = archive.ar; 754 | path = libReact.a; 755 | remoteRef = 3DAD3EA21DF850E9000B6D8A /* PBXContainerItemProxy */; 756 | sourceTree = BUILT_PRODUCTS_DIR; 757 | }; 758 | 3DAD3EA51DF850E9000B6D8A /* libyoga.a */ = { 759 | isa = PBXReferenceProxy; 760 | fileType = archive.ar; 761 | path = libyoga.a; 762 | remoteRef = 3DAD3EA41DF850E9000B6D8A /* PBXContainerItemProxy */; 763 | sourceTree = BUILT_PRODUCTS_DIR; 764 | }; 765 | 3DAD3EA71DF850E9000B6D8A /* libyoga.a */ = { 766 | isa = PBXReferenceProxy; 767 | fileType = archive.ar; 768 | path = libyoga.a; 769 | remoteRef = 3DAD3EA61DF850E9000B6D8A /* PBXContainerItemProxy */; 770 | sourceTree = BUILT_PRODUCTS_DIR; 771 | }; 772 | 3DAD3EA91DF850E9000B6D8A /* libcxxreact.a */ = { 773 | isa = PBXReferenceProxy; 774 | fileType = archive.ar; 775 | path = libcxxreact.a; 776 | remoteRef = 3DAD3EA81DF850E9000B6D8A /* PBXContainerItemProxy */; 777 | sourceTree = BUILT_PRODUCTS_DIR; 778 | }; 779 | 3DAD3EAB1DF850E9000B6D8A /* libcxxreact.a */ = { 780 | isa = PBXReferenceProxy; 781 | fileType = archive.ar; 782 | path = libcxxreact.a; 783 | remoteRef = 3DAD3EAA1DF850E9000B6D8A /* PBXContainerItemProxy */; 784 | sourceTree = BUILT_PRODUCTS_DIR; 785 | }; 786 | 3DAD3EAD1DF850E9000B6D8A /* libjschelpers.a */ = { 787 | isa = PBXReferenceProxy; 788 | fileType = archive.ar; 789 | path = libjschelpers.a; 790 | remoteRef = 3DAD3EAC1DF850E9000B6D8A /* PBXContainerItemProxy */; 791 | sourceTree = BUILT_PRODUCTS_DIR; 792 | }; 793 | 3DAD3EAF1DF850E9000B6D8A /* libjschelpers.a */ = { 794 | isa = PBXReferenceProxy; 795 | fileType = archive.ar; 796 | path = libjschelpers.a; 797 | remoteRef = 3DAD3EAE1DF850E9000B6D8A /* PBXContainerItemProxy */; 798 | sourceTree = BUILT_PRODUCTS_DIR; 799 | }; 800 | 5E9157331DD0AC6500FF2AA8 /* libRCTAnimation.a */ = { 801 | isa = PBXReferenceProxy; 802 | fileType = archive.ar; 803 | path = libRCTAnimation.a; 804 | remoteRef = 5E9157321DD0AC6500FF2AA8 /* PBXContainerItemProxy */; 805 | sourceTree = BUILT_PRODUCTS_DIR; 806 | }; 807 | 5E9157351DD0AC6500FF2AA8 /* libRCTAnimation-tvOS.a */ = { 808 | isa = PBXReferenceProxy; 809 | fileType = archive.ar; 810 | path = "libRCTAnimation-tvOS.a"; 811 | remoteRef = 5E9157341DD0AC6500FF2AA8 /* PBXContainerItemProxy */; 812 | sourceTree = BUILT_PRODUCTS_DIR; 813 | }; 814 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */ = { 815 | isa = PBXReferenceProxy; 816 | fileType = archive.ar; 817 | path = libRCTLinking.a; 818 | remoteRef = 78C398B81ACF4ADC00677621 /* PBXContainerItemProxy */; 819 | sourceTree = BUILT_PRODUCTS_DIR; 820 | }; 821 | 832341B51AAA6A8300B99B32 /* libRCTText.a */ = { 822 | isa = PBXReferenceProxy; 823 | fileType = archive.ar; 824 | path = libRCTText.a; 825 | remoteRef = 832341B41AAA6A8300B99B32 /* PBXContainerItemProxy */; 826 | sourceTree = BUILT_PRODUCTS_DIR; 827 | }; 828 | /* End PBXReferenceProxy section */ 829 | 830 | /* Begin PBXResourcesBuildPhase section */ 831 | 00E356EC1AD99517003FC87E /* Resources */ = { 832 | isa = PBXResourcesBuildPhase; 833 | buildActionMask = 2147483647; 834 | files = ( 835 | ); 836 | runOnlyForDeploymentPostprocessing = 0; 837 | }; 838 | 13B07F8E1A680F5B00A75B9A /* Resources */ = { 839 | isa = PBXResourcesBuildPhase; 840 | buildActionMask = 2147483647; 841 | files = ( 842 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */, 843 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */, 844 | ); 845 | runOnlyForDeploymentPostprocessing = 0; 846 | }; 847 | 2D02E4791E0B4A5D006451C7 /* Resources */ = { 848 | isa = PBXResourcesBuildPhase; 849 | buildActionMask = 2147483647; 850 | files = ( 851 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */, 852 | ); 853 | runOnlyForDeploymentPostprocessing = 0; 854 | }; 855 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = { 856 | isa = PBXResourcesBuildPhase; 857 | buildActionMask = 2147483647; 858 | files = ( 859 | ); 860 | runOnlyForDeploymentPostprocessing = 0; 861 | }; 862 | /* End PBXResourcesBuildPhase section */ 863 | 864 | /* Begin PBXShellScriptBuildPhase section */ 865 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = { 866 | isa = PBXShellScriptBuildPhase; 867 | buildActionMask = 2147483647; 868 | files = ( 869 | ); 870 | inputPaths = ( 871 | ); 872 | name = "Bundle React Native code and images"; 873 | outputPaths = ( 874 | ); 875 | runOnlyForDeploymentPostprocessing = 0; 876 | shellPath = /bin/sh; 877 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/packager/react-native-xcode.sh"; 878 | }; 879 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = { 880 | isa = PBXShellScriptBuildPhase; 881 | buildActionMask = 2147483647; 882 | files = ( 883 | ); 884 | inputPaths = ( 885 | ); 886 | name = "Bundle React Native Code And Images"; 887 | outputPaths = ( 888 | ); 889 | runOnlyForDeploymentPostprocessing = 0; 890 | shellPath = /bin/sh; 891 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/packager/react-native-xcode.sh"; 892 | }; 893 | /* End PBXShellScriptBuildPhase section */ 894 | 895 | /* Begin PBXSourcesBuildPhase section */ 896 | 00E356EA1AD99517003FC87E /* Sources */ = { 897 | isa = PBXSourcesBuildPhase; 898 | buildActionMask = 2147483647; 899 | files = ( 900 | 00E356F31AD99517003FC87E /* rxappTests.m in Sources */, 901 | ); 902 | runOnlyForDeploymentPostprocessing = 0; 903 | }; 904 | 13B07F871A680F5B00A75B9A /* Sources */ = { 905 | isa = PBXSourcesBuildPhase; 906 | buildActionMask = 2147483647; 907 | files = ( 908 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */, 909 | 13B07FC11A68108700A75B9A /* main.m in Sources */, 910 | ); 911 | runOnlyForDeploymentPostprocessing = 0; 912 | }; 913 | 2D02E4771E0B4A5D006451C7 /* Sources */ = { 914 | isa = PBXSourcesBuildPhase; 915 | buildActionMask = 2147483647; 916 | files = ( 917 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */, 918 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */, 919 | ); 920 | runOnlyForDeploymentPostprocessing = 0; 921 | }; 922 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = { 923 | isa = PBXSourcesBuildPhase; 924 | buildActionMask = 2147483647; 925 | files = ( 926 | 2DCD954D1E0B4F2C00145EB5 /* rxappTests.m in Sources */, 927 | ); 928 | runOnlyForDeploymentPostprocessing = 0; 929 | }; 930 | /* End PBXSourcesBuildPhase section */ 931 | 932 | /* Begin PBXTargetDependency section */ 933 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = { 934 | isa = PBXTargetDependency; 935 | target = 13B07F861A680F5B00A75B9A /* rxapp */; 936 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */; 937 | }; 938 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = { 939 | isa = PBXTargetDependency; 940 | target = 2D02E47A1E0B4A5D006451C7 /* rxapp-tvOS */; 941 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */; 942 | }; 943 | /* End PBXTargetDependency section */ 944 | 945 | /* Begin PBXVariantGroup section */ 946 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = { 947 | isa = PBXVariantGroup; 948 | children = ( 949 | 13B07FB21A68108700A75B9A /* Base */, 950 | ); 951 | name = LaunchScreen.xib; 952 | path = rxapp; 953 | sourceTree = ""; 954 | }; 955 | /* End PBXVariantGroup section */ 956 | 957 | /* Begin XCBuildConfiguration section */ 958 | 00E356F61AD99517003FC87E /* Debug */ = { 959 | isa = XCBuildConfiguration; 960 | buildSettings = { 961 | BUNDLE_LOADER = "$(TEST_HOST)"; 962 | GCC_PREPROCESSOR_DEFINITIONS = ( 963 | "DEBUG=1", 964 | "$(inherited)", 965 | ); 966 | INFOPLIST_FILE = rxappTests/Info.plist; 967 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 968 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 969 | OTHER_LDFLAGS = ( 970 | "-ObjC", 971 | "-lc++", 972 | ); 973 | PRODUCT_NAME = "$(TARGET_NAME)"; 974 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/rxapp.app/rxapp"; 975 | }; 976 | name = Debug; 977 | }; 978 | 00E356F71AD99517003FC87E /* Release */ = { 979 | isa = XCBuildConfiguration; 980 | buildSettings = { 981 | BUNDLE_LOADER = "$(TEST_HOST)"; 982 | COPY_PHASE_STRIP = NO; 983 | INFOPLIST_FILE = rxappTests/Info.plist; 984 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 985 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 986 | OTHER_LDFLAGS = ( 987 | "-ObjC", 988 | "-lc++", 989 | ); 990 | PRODUCT_NAME = "$(TARGET_NAME)"; 991 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/rxapp.app/rxapp"; 992 | }; 993 | name = Release; 994 | }; 995 | 13B07F941A680F5B00A75B9A /* Debug */ = { 996 | isa = XCBuildConfiguration; 997 | buildSettings = { 998 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 999 | CURRENT_PROJECT_VERSION = 1; 1000 | DEAD_CODE_STRIPPING = NO; 1001 | INFOPLIST_FILE = rxapp/Info.plist; 1002 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1003 | OTHER_LDFLAGS = ( 1004 | "$(inherited)", 1005 | "-ObjC", 1006 | "-lc++", 1007 | ); 1008 | PRODUCT_NAME = rxapp; 1009 | VERSIONING_SYSTEM = "apple-generic"; 1010 | }; 1011 | name = Debug; 1012 | }; 1013 | 13B07F951A680F5B00A75B9A /* Release */ = { 1014 | isa = XCBuildConfiguration; 1015 | buildSettings = { 1016 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 1017 | CURRENT_PROJECT_VERSION = 1; 1018 | INFOPLIST_FILE = rxapp/Info.plist; 1019 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1020 | OTHER_LDFLAGS = ( 1021 | "$(inherited)", 1022 | "-ObjC", 1023 | "-lc++", 1024 | ); 1025 | PRODUCT_NAME = rxapp; 1026 | VERSIONING_SYSTEM = "apple-generic"; 1027 | }; 1028 | name = Release; 1029 | }; 1030 | 2D02E4971E0B4A5E006451C7 /* Debug */ = { 1031 | isa = XCBuildConfiguration; 1032 | buildSettings = { 1033 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 1034 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1035 | CLANG_ANALYZER_NONNULL = YES; 1036 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1037 | CLANG_WARN_INFINITE_RECURSION = YES; 1038 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1039 | DEBUG_INFORMATION_FORMAT = dwarf; 1040 | ENABLE_TESTABILITY = YES; 1041 | GCC_NO_COMMON_BLOCKS = YES; 1042 | INFOPLIST_FILE = "rxapp-tvOS/Info.plist"; 1043 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1044 | OTHER_LDFLAGS = ( 1045 | "-ObjC", 1046 | "-lc++", 1047 | ); 1048 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.rxapp-tvOS"; 1049 | PRODUCT_NAME = "$(TARGET_NAME)"; 1050 | SDKROOT = appletvos; 1051 | TARGETED_DEVICE_FAMILY = 3; 1052 | TVOS_DEPLOYMENT_TARGET = 9.2; 1053 | }; 1054 | name = Debug; 1055 | }; 1056 | 2D02E4981E0B4A5E006451C7 /* Release */ = { 1057 | isa = XCBuildConfiguration; 1058 | buildSettings = { 1059 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 1060 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 1061 | CLANG_ANALYZER_NONNULL = YES; 1062 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1063 | CLANG_WARN_INFINITE_RECURSION = YES; 1064 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1065 | COPY_PHASE_STRIP = NO; 1066 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 1067 | GCC_NO_COMMON_BLOCKS = YES; 1068 | INFOPLIST_FILE = "rxapp-tvOS/Info.plist"; 1069 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 1070 | OTHER_LDFLAGS = ( 1071 | "-ObjC", 1072 | "-lc++", 1073 | ); 1074 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.rxapp-tvOS"; 1075 | PRODUCT_NAME = "$(TARGET_NAME)"; 1076 | SDKROOT = appletvos; 1077 | TARGETED_DEVICE_FAMILY = 3; 1078 | TVOS_DEPLOYMENT_TARGET = 9.2; 1079 | }; 1080 | name = Release; 1081 | }; 1082 | 2D02E4991E0B4A5E006451C7 /* Debug */ = { 1083 | isa = XCBuildConfiguration; 1084 | buildSettings = { 1085 | BUNDLE_LOADER = "$(TEST_HOST)"; 1086 | CLANG_ANALYZER_NONNULL = YES; 1087 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1088 | CLANG_WARN_INFINITE_RECURSION = YES; 1089 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1090 | DEBUG_INFORMATION_FORMAT = dwarf; 1091 | ENABLE_TESTABILITY = YES; 1092 | GCC_NO_COMMON_BLOCKS = YES; 1093 | INFOPLIST_FILE = "rxapp-tvOSTests/Info.plist"; 1094 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 1095 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.rxapp-tvOSTests"; 1096 | PRODUCT_NAME = "$(TARGET_NAME)"; 1097 | SDKROOT = appletvos; 1098 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/rxapp-tvOS.app/rxapp-tvOS"; 1099 | TVOS_DEPLOYMENT_TARGET = 10.1; 1100 | }; 1101 | name = Debug; 1102 | }; 1103 | 2D02E49A1E0B4A5E006451C7 /* Release */ = { 1104 | isa = XCBuildConfiguration; 1105 | buildSettings = { 1106 | BUNDLE_LOADER = "$(TEST_HOST)"; 1107 | CLANG_ANALYZER_NONNULL = YES; 1108 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 1109 | CLANG_WARN_INFINITE_RECURSION = YES; 1110 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 1111 | COPY_PHASE_STRIP = NO; 1112 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 1113 | GCC_NO_COMMON_BLOCKS = YES; 1114 | INFOPLIST_FILE = "rxapp-tvOSTests/Info.plist"; 1115 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 1116 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.rxapp-tvOSTests"; 1117 | PRODUCT_NAME = "$(TARGET_NAME)"; 1118 | SDKROOT = appletvos; 1119 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/rxapp-tvOS.app/rxapp-tvOS"; 1120 | TVOS_DEPLOYMENT_TARGET = 10.1; 1121 | }; 1122 | name = Release; 1123 | }; 1124 | 83CBBA201A601CBA00E9B192 /* Debug */ = { 1125 | isa = XCBuildConfiguration; 1126 | buildSettings = { 1127 | ALWAYS_SEARCH_USER_PATHS = NO; 1128 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 1129 | CLANG_CXX_LIBRARY = "libc++"; 1130 | CLANG_ENABLE_MODULES = YES; 1131 | CLANG_ENABLE_OBJC_ARC = YES; 1132 | CLANG_WARN_BOOL_CONVERSION = YES; 1133 | CLANG_WARN_CONSTANT_CONVERSION = YES; 1134 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 1135 | CLANG_WARN_EMPTY_BODY = YES; 1136 | CLANG_WARN_ENUM_CONVERSION = YES; 1137 | CLANG_WARN_INT_CONVERSION = YES; 1138 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 1139 | CLANG_WARN_UNREACHABLE_CODE = YES; 1140 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 1141 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 1142 | COPY_PHASE_STRIP = NO; 1143 | ENABLE_STRICT_OBJC_MSGSEND = YES; 1144 | GCC_C_LANGUAGE_STANDARD = gnu99; 1145 | GCC_DYNAMIC_NO_PIC = NO; 1146 | GCC_OPTIMIZATION_LEVEL = 0; 1147 | GCC_PREPROCESSOR_DEFINITIONS = ( 1148 | "DEBUG=1", 1149 | "$(inherited)", 1150 | ); 1151 | GCC_SYMBOLS_PRIVATE_EXTERN = NO; 1152 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 1153 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 1154 | GCC_WARN_UNDECLARED_SELECTOR = YES; 1155 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 1156 | GCC_WARN_UNUSED_FUNCTION = YES; 1157 | GCC_WARN_UNUSED_VARIABLE = YES; 1158 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 1159 | MTL_ENABLE_DEBUG_INFO = YES; 1160 | ONLY_ACTIVE_ARCH = YES; 1161 | SDKROOT = iphoneos; 1162 | }; 1163 | name = Debug; 1164 | }; 1165 | 83CBBA211A601CBA00E9B192 /* Release */ = { 1166 | isa = XCBuildConfiguration; 1167 | buildSettings = { 1168 | ALWAYS_SEARCH_USER_PATHS = NO; 1169 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 1170 | CLANG_CXX_LIBRARY = "libc++"; 1171 | CLANG_ENABLE_MODULES = YES; 1172 | CLANG_ENABLE_OBJC_ARC = YES; 1173 | CLANG_WARN_BOOL_CONVERSION = YES; 1174 | CLANG_WARN_CONSTANT_CONVERSION = YES; 1175 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 1176 | CLANG_WARN_EMPTY_BODY = YES; 1177 | CLANG_WARN_ENUM_CONVERSION = YES; 1178 | CLANG_WARN_INT_CONVERSION = YES; 1179 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 1180 | CLANG_WARN_UNREACHABLE_CODE = YES; 1181 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 1182 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 1183 | COPY_PHASE_STRIP = YES; 1184 | ENABLE_NS_ASSERTIONS = NO; 1185 | ENABLE_STRICT_OBJC_MSGSEND = YES; 1186 | GCC_C_LANGUAGE_STANDARD = gnu99; 1187 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 1188 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 1189 | GCC_WARN_UNDECLARED_SELECTOR = YES; 1190 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 1191 | GCC_WARN_UNUSED_FUNCTION = YES; 1192 | GCC_WARN_UNUSED_VARIABLE = YES; 1193 | IPHONEOS_DEPLOYMENT_TARGET = 8.0; 1194 | MTL_ENABLE_DEBUG_INFO = NO; 1195 | SDKROOT = iphoneos; 1196 | VALIDATE_PRODUCT = YES; 1197 | }; 1198 | name = Release; 1199 | }; 1200 | /* End XCBuildConfiguration section */ 1201 | 1202 | /* Begin XCConfigurationList section */ 1203 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "rxappTests" */ = { 1204 | isa = XCConfigurationList; 1205 | buildConfigurations = ( 1206 | 00E356F61AD99517003FC87E /* Debug */, 1207 | 00E356F71AD99517003FC87E /* Release */, 1208 | ); 1209 | defaultConfigurationIsVisible = 0; 1210 | defaultConfigurationName = Release; 1211 | }; 1212 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "rxapp" */ = { 1213 | isa = XCConfigurationList; 1214 | buildConfigurations = ( 1215 | 13B07F941A680F5B00A75B9A /* Debug */, 1216 | 13B07F951A680F5B00A75B9A /* Release */, 1217 | ); 1218 | defaultConfigurationIsVisible = 0; 1219 | defaultConfigurationName = Release; 1220 | }; 1221 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "rxapp-tvOS" */ = { 1222 | isa = XCConfigurationList; 1223 | buildConfigurations = ( 1224 | 2D02E4971E0B4A5E006451C7 /* Debug */, 1225 | 2D02E4981E0B4A5E006451C7 /* Release */, 1226 | ); 1227 | defaultConfigurationIsVisible = 0; 1228 | defaultConfigurationName = Release; 1229 | }; 1230 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "rxapp-tvOSTests" */ = { 1231 | isa = XCConfigurationList; 1232 | buildConfigurations = ( 1233 | 2D02E4991E0B4A5E006451C7 /* Debug */, 1234 | 2D02E49A1E0B4A5E006451C7 /* Release */, 1235 | ); 1236 | defaultConfigurationIsVisible = 0; 1237 | defaultConfigurationName = Release; 1238 | }; 1239 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "rxapp" */ = { 1240 | isa = XCConfigurationList; 1241 | buildConfigurations = ( 1242 | 83CBBA201A601CBA00E9B192 /* Debug */, 1243 | 83CBBA211A601CBA00E9B192 /* Release */, 1244 | ); 1245 | defaultConfigurationIsVisible = 0; 1246 | defaultConfigurationName = Release; 1247 | }; 1248 | /* End XCConfigurationList section */ 1249 | }; 1250 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */; 1251 | } 1252 | -------------------------------------------------------------------------------- /ios/RXApp.xcodeproj/xcshareddata/xcschemes/RXApp-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 | -------------------------------------------------------------------------------- /ios/RXApp.xcodeproj/xcshareddata/xcschemes/RXApp.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 | -------------------------------------------------------------------------------- /ios/RXApp/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 | -------------------------------------------------------------------------------- /ios/RXApp/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:@"RXApp" 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 | -------------------------------------------------------------------------------- /ios/RXApp/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 | -------------------------------------------------------------------------------- /ios/RXApp/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 | } -------------------------------------------------------------------------------- /ios/RXApp/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleDisplayName 8 | rxapp 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 | -------------------------------------------------------------------------------- /ios/RXApp/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 | -------------------------------------------------------------------------------- /ios/RXAppTests/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 | -------------------------------------------------------------------------------- /ios/RXAppTests/RXAppTests.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 rxappTests : XCTestCase 20 | 21 | @end 22 | 23 | @implementation rxappTests 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 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rxapp", 3 | "version": "0.0.1", 4 | "private": true, 5 | "scripts": { 6 | "web-watch": "webpack --progress --colors --watch", 7 | "rn-watch": "tsc --watch", 8 | "start": "node node_modules/react-native/local-cli/cli.js start", 9 | "install-deps": "npm i" 10 | }, 11 | "devDependencies": { 12 | "@types/node": "^7.0.12", 13 | "@types/webpack": "^2.2.14", 14 | "awesome-typescript-loader": "3.1.2", 15 | "source-map-loader": "^0.1.6", 16 | "ts-node": "^3.0.2", 17 | "typescript": "2.1.6", 18 | "webpack": "2.2.1" 19 | }, 20 | "dependencies": { 21 | "reactxp": "0.42.0-rc.3", 22 | "react": "^15.4.1", 23 | "react-native": "^0.42.0", 24 | "react-addons-perf": "15.5.0-rc.2", 25 | "react-addons-test-utils": "15.5.1", 26 | "react-dom": "15.5.3", 27 | "react-native-windows": "^0.33.0" 28 | }, 29 | "jest": { 30 | "preset": "react-native" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /src/App.tsx: -------------------------------------------------------------------------------- 1 | /* 2 | * This file demonstrates a basic ReactXP app. 3 | */ 4 | 5 | import RX = require('reactxp'); 6 | 7 | const styles = { 8 | container: RX.Styles.createViewStyle({ 9 | flex: 1, 10 | justifyContent: 'center', 11 | alignItems: 'center', 12 | backgroundColor: '#f5fcff' 13 | }), 14 | helloWorld: RX.Styles.createTextStyle({ 15 | fontSize: 48, 16 | fontWeight: 'bold', 17 | marginBottom: 28 18 | }), 19 | welcome: RX.Styles.createTextStyle({ 20 | fontSize: 32, 21 | marginBottom: 12 22 | }), 23 | instructions: RX.Styles.createTextStyle({ 24 | fontSize: 16, 25 | color: '#aaa', 26 | marginBottom: 40 27 | }), 28 | docLink: RX.Styles.createLinkStyle({ 29 | fontSize: 16, 30 | color: 'blue' 31 | }) 32 | }; 33 | 34 | class App extends RX.Component { 35 | private _translationValue: RX.Animated.Value; 36 | private _animatedStyle: RX.Types.AnimatedTextStyleRuleSet; 37 | 38 | constructor() { 39 | super(); 40 | 41 | this._translationValue = new RX.Animated.Value(-100); 42 | this._animatedStyle = RX.Styles.createAnimatedTextStyle({ 43 | transform: [ 44 | { 45 | translateY: this._translationValue 46 | } 47 | ] 48 | }); 49 | } 50 | 51 | componentDidMount() { 52 | let animation = RX.Animated.timing(this._translationValue, { 53 | toValue: 0, 54 | easing: RX.Animated.Easing.OutBack(), 55 | duration: 500 56 | } 57 | ); 58 | 59 | animation.start(); 60 | } 61 | 62 | render(): JSX.Element | null { 63 | return ( 64 | 65 | 66 | Hello World 67 | 68 | 69 | Welcome to ReactXP 70 | 71 | 72 | Edit App.tsx to get started 73 | 74 | 75 | View ReactXP documentation 76 | 77 | 78 | ); 79 | } 80 | } 81 | 82 | export = App; 83 | -------------------------------------------------------------------------------- /src/index.tsx: -------------------------------------------------------------------------------- 1 | import RX = require('reactxp'); 2 | import App = require('./App'); 3 | 4 | import { AppRegistry } from 'react-native'; 5 | 6 | RX.App.initialize(true, true); 7 | RX.UserInterface.setMainView(); 8 | -------------------------------------------------------------------------------- /src/typings/react-native.d.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * react-native.d.ts 3 | * 4 | * Copyright (c) Microsoft Corporation. All rights reserved. 5 | * Licensed under the MIT license. 6 | * 7 | * Type definition file for React Native, based on the React.js definition file on https://github.com/borisyankov/DefinitelyTyped. 8 | */ 9 | 10 | declare module 'react-native' { 11 | // 12 | // React 13 | // ---------------------------------------------------------------------- 14 | 15 | import React = require('react'); 16 | 17 | // BT: Adding ProgressBarAndroid. It's not part of the DefinitelyTyped definitions. 18 | class ProgressBarAndroid extends React.Component {} 19 | 20 | type ReactElement = React.ReactElement; 21 | type ReactNode = React.ReactNode; 22 | 23 | function createElement

( 24 | type: string, 25 | props?: P, 26 | ...children: React.ReactNode[]): React.ReactElement

; 27 | 28 | function cloneElement

( 29 | element: P, 30 | props ?: any 31 | ): React.ReactElement

; 32 | 33 | interface SyntheticEvent extends React.SyntheticEvent {} 34 | 35 | function isValidElement(object: {}): boolean; 36 | function findNodeHandle(componentOrHandle: any): number; 37 | 38 | var Children: React.ReactChildren; 39 | 40 | type PlatformString = 'android'|'ios'|'windows'; 41 | var Platform: { 42 | OS: PlatformString, 43 | Version?: number 44 | }; 45 | 46 | // 47 | // Component base 48 | // ---------------------------------------------------------------------- 49 | 50 | abstract class ReactNativeBaseComponent extends React.Component { 51 | setNativeProps(nativeProps: P): void; 52 | focus(): void; 53 | blur(): void; 54 | measure(callback: ((x: number, y: number, width: number, height: number, pageX: number, pageY: number) => void)): void; 55 | measureLayout(relativeToNativeNode: number, onSuccess: ((x: number, y: number, width: number, height: number, pageX: number, pageY: number) => void), onFail: () => void): void; 56 | refs: { 57 | [key: string]: ReactNativeBaseComponent; 58 | } 59 | } 60 | 61 | // 62 | // Style rules 63 | // ---------------------------------------------------------------------- 64 | 65 | type StyleRuleSet = Object | Object[]; 66 | 67 | // 68 | // Specific components 69 | // ---------------------------------------------------------------------- 70 | 71 | interface ComponentPropsBase { 72 | ref?: string | ((obj: ReactNativeBaseComponent) => void); 73 | key?: string | number; 74 | } 75 | 76 | interface ComponentPropsStyleBase extends ComponentPropsBase { 77 | style?: StyleRuleSet | StyleRuleSet[]; 78 | } 79 | 80 | interface ImageSource { 81 | uri: string; 82 | headers?: {[header: string]: string}; 83 | } 84 | 85 | interface ImageProps extends ComponentPropsStyleBase { 86 | onLayout?: Function; 87 | resizeMode?: string; 88 | resizeMethod?: string; // android only prop: 'auto' | 'resize' | 'scale' 89 | source?: ImageSource | number; 90 | testID?: string; 91 | 92 | // iOS 93 | accessibilityLabel?: string; 94 | shouldRasterizeIOS?: boolean; 95 | accessible?: boolean; 96 | capInsets?: Object; 97 | defaultSource?: Object; 98 | onError?: Function; 99 | onLoad?: Function; 100 | onLoadEnd?: (e: SyntheticEvent) => void; 101 | onLoadStart?: Function; 102 | onProgress?: Function; 103 | } 104 | 105 | interface ActivityIndicatorProps extends ComponentPropsBase { 106 | animating?: boolean; 107 | color?: string; 108 | onLayout?: Function; 109 | size?: string; // enum { 'small', 'large' } 110 | } 111 | 112 | interface TextProps extends ComponentPropsStyleBase { 113 | importantForAccessibility?: string; // 'auto' | 'yes' | 'no' | 'no-hide-descendants'; 114 | allowFontScaling?: boolean; 115 | children? : React.ReactNode; 116 | numberOfLines? : number; 117 | ellipsizeMode? : 'head' | 'middle' | 'tail' // There's also 'clip' but it is iOS only 118 | onLayout? : Function; 119 | onPress? : Function; 120 | selectable? : boolean; // only on android, windows 121 | testID? : string; 122 | 123 | // iOS 124 | suppressHighlighting?: boolean; 125 | 126 | // Android 127 | textBreakStrategy?: 'highQuality' | 'simple'| 'balanced'; 128 | elevation?: number; 129 | } 130 | 131 | export interface PickerProps extends ComponentPropsStyleBase { 132 | 133 | /** 134 | * Callback for when an item is selected. This is called with the 135 | * following parameters: 136 | * - itemValue: the value prop of the item that was selected 137 | * - itemPosition: the index of the selected item in this picker 138 | * @param itemValue 139 | * @param itemPosition 140 | */ 141 | onValueChange?: ( itemValue: any, itemPosition: number ) => void 142 | 143 | /** 144 | * Value matching value of one of the items. 145 | * Can be a string or an integer. 146 | */ 147 | selectedValue?: any 148 | 149 | style?: StyleRuleSet | StyleRuleSet[] 150 | 151 | /** 152 | * Used to locate this view in end-to-end tests. 153 | */ 154 | testId?: string 155 | 156 | ref?: string | ((obj: ReactNativeBaseComponent) => void); 157 | } 158 | 159 | interface TouchableWithoutFeedbackProps extends ComponentPropsBase { 160 | accessibilityComponentType? : string; //enum ( 'none', 'button', 'radiobutton_checked', 'radiobutton_unchecked' ) 161 | accessibilityTraits?: string | string[]; //enum( 'none', 'button', 'link', 'header', 'search', 'image', 'selected', 'plays', 'key', 'text', 'summary', 'disabled', 'frequentUpdates', 'startsMedia', 'adjustable', 'allowsDirectInteraction', 'pageTurn' ) 162 | accessible?: boolean; 163 | delayLongPress?: number; 164 | delayPressIn?: number; 165 | delayPressOut?: number; 166 | onLayout?: Function; 167 | onLongPress?: Function; 168 | onPress?: Function; 169 | onPressIn?: Function; 170 | onPressOut?: Function 171 | } 172 | 173 | interface TouchableHighlightProps extends TouchableWithoutFeedbackProps, ComponentPropsStyleBase { 174 | activeOpacity? : number; 175 | children? : React.ReactNode; 176 | onHideUnderlay?: Function; 177 | onShowUnderlay?: Function; 178 | underlayColor? : string; 179 | } 180 | 181 | interface ResponderProps { 182 | onMoveShouldSetResponder? : Function; 183 | onResponderGrant? : Function; 184 | onResponderMove? : Function; 185 | onResponderReject? : Function; 186 | onResponderRelease? : Function; 187 | onResponderTerminate? : Function; 188 | onResponderTerminationRequest? : Function; 189 | onStartShouldSetResponder? : Function; 190 | onStartShouldSetResponderCapture?: Function; 191 | } 192 | 193 | interface ViewOnLayoutEvent { 194 | nativeEvent: { 195 | layout: { 196 | x: number, 197 | y: number, 198 | width: number, 199 | height: number 200 | } 201 | } 202 | } 203 | 204 | type ViewLayerType = 'none' | 'software' | 'hardware'; 205 | 206 | interface CommonAccessibilityProps { 207 | accessibilityLabel? : string; 208 | accessible? : boolean; 209 | onAcccessibilityTap? : Function; 210 | 211 | // android 212 | accessibilityComponentType? : string; //enum ( 'none', 'button', 'radiobutton_checked', 'radiobutton_unchecked' ) 213 | accessibilityLiveRegion? : string; //enum ( 'none', 'polite', 'assertive' ) 214 | importantForAccessibility? : string; //enum( 'auto', 'yes', 'no', 'no-hide-descendants' ) 215 | 216 | // iOS 217 | accessibilityTraits?: string | string[]; //enum( 'none', 'button', 'link', 'header', 'search', 'image', 'selected', 'plays', 'key', 'text', 'summary', 'disabled', 'frequentUpdates', 'startsMedia', 'adjustable', 'allowsDirectInteraction', 'pageTurn' ) 218 | } 219 | 220 | interface ViewProps extends ComponentPropsBase, ResponderProps, ComponentPropsStyleBase, CommonAccessibilityProps { 221 | children? : any; 222 | onLayout? : ((ev: ViewOnLayoutEvent) => void); 223 | onMagicTap? : Function; 224 | pointerEvents? : string; //enum( 'box-none', 'none', 'box-only', 'auto' ); 225 | removeClippedSubviews? : boolean; 226 | testID? : string; 227 | 228 | // android 229 | collapsable? : boolean; 230 | needsOffscreenAlphaCompositing?: boolean; 231 | renderToHardwareTextureAndroid?: boolean; 232 | viewLayerTypeAndroid? : ViewLayerType; 233 | elevation? : number; 234 | 235 | // iOS 236 | shouldRasterizeIOS? : boolean; 237 | } 238 | 239 | interface ScrollViewProps extends ViewProps { 240 | children?: any; 241 | 242 | contentContainerStyle?: StyleRuleSet | StyleRuleSet[]; 243 | horizontal?: boolean; 244 | keyboardDismissMode?: string; // enum( 'none', 'interactive', 'on-drag' ) 245 | keyboardShouldPersistTaps?: boolean; 246 | onScroll?: Function; 247 | onScrollBeginDrag?: Function; 248 | onScrollEndDrag?: Function; 249 | onContentSizeChange?: (width: number, height: number) => void; 250 | showsHorizontalScrollIndicator?: boolean; 251 | showsVerticalScrollIndicator?: boolean; 252 | removeClippedSubviews?: boolean; 253 | 254 | // iOS 255 | automaticallyAdjustContentInsets?: boolean; 256 | //contentInset?: EdgeInsetsPropType; 257 | //contentOffset?: PointPropType; 258 | bounces?: boolean; 259 | bouncesZoom?: boolean; 260 | alwaysBounceHorizontal?: boolean; 261 | alwaysBounceVertical?: boolean; 262 | centerContent?: boolean; 263 | decelerationRate?: number; 264 | directionalLockEnabled?: boolean; 265 | canCancelContentTouches?: boolean; 266 | maximumZoomScale?: number; 267 | minimumZoomScale?: number; 268 | onScrollAnimationEnd?: Function; 269 | pagingEnabled?: boolean; 270 | scrollEnabled?: boolean; 271 | scrollEventThrottle?: number; 272 | scrollsToTop?: boolean; 273 | stickyHeaderIndices?: [number]; 274 | snapToInterval?: number; 275 | snapToAlignment?: string; // enum( 'start', 'center', 'end' ) 276 | zoomScale?: number; 277 | overScrollMode?: string; //enum( 'always', 'always-if-content-scrolls', 'never' ) 278 | // iOS 279 | scrollIndicatorInsets?: {top: number, left: number, bottom: number, right: number }; 280 | } 281 | 282 | interface ListViewDataSourceCallback { 283 | rowHasChanged: (r1: T, r2: T) => boolean; 284 | } 285 | 286 | interface ListViewDataSource { 287 | new (onAsset: ListViewDataSourceCallback): ListViewDataSource; 288 | cloneWithRows(rowList: T[]): void; 289 | } 290 | 291 | interface ListViewProps extends ScrollViewProps { 292 | dataSource: Object; //PropTypes.instanceOf(ListViewDataSource).isRequired 293 | renderSeparator?: Function; 294 | renderRow: Function; 295 | initialListSize?: number; 296 | onEndReached?: (e: React.SyntheticEvent) => void; 297 | onEndReachedThreshold?: number; 298 | pageSize?: number; 299 | renderFooter?: Function; 300 | renderHeader?: Function; 301 | renderSectionHeader?: Function; 302 | renderScrollComponent: Function; 303 | scrollRenderAheadDistance?: number; 304 | onChangeVisibleRows?: Function; 305 | removeClippedSubviews?: boolean; 306 | } 307 | 308 | interface ModalProps extends ComponentPropsBase { 309 | animationType?: string; // enum( 'none', 'slide', 'fade' ) 310 | onDismiss?: Function; 311 | transparent?: boolean; 312 | onRequestClose: () => void; 313 | } 314 | 315 | interface TextInputProps extends ComponentPropsStyleBase, CommonAccessibilityProps { 316 | autoCapitalize?: string; // enum('none', 'sentences', 'words', 'characters') 317 | autoCorrect?: boolean; 318 | autoFocus?: boolean; 319 | blurOnSubmit?: boolean; 320 | defaultValue?: string; 321 | editable?: boolean; 322 | keyboardType?: string; // enum("default", 'numeric', 'email-address', "ascii-capable", 'numbers-and-punctuation', 'url', 'number-pad', 'phone-pad', 'name-phone-pad', 'decimal-pad', 'twitter', 'web-search') 323 | multiline?: boolean; 324 | onBlur?: ((e: React.FocusEvent) => void); 325 | onKeyPress?: (e: SyntheticEvent) => void; 326 | onChange?: Function; 327 | onChangeText?: ((changedText: string) => void); 328 | onSelectionChange?: ((selection: SyntheticEvent) => void); 329 | onEndEditing?: Function; 330 | onFocus?: ((e: React.FocusEvent) => void); 331 | onLayout?: ((props: { x: number, y: number, width: number, height: number }) => void); 332 | onSubmitEditing?: Function; 333 | onScroll?: Function; 334 | placeholder?: string; 335 | placeholderTextColor?: string; 336 | returnKeyType?: string; // enum('default', 'go', 'google', 'join', 'next', 'route', 'search', 'send', 'yahoo', 'done', 'emergency-call') 337 | secureTextEntry?: boolean; 338 | testID?: string; 339 | textAlign?: string; // enum('auto' | 'left' | 'right' | 'center' | 'justify') 340 | allowFontScaling?: boolean; 341 | selection?: { start: number, end: number }; 342 | 343 | //iOS and android 344 | selectionColor?: string; 345 | 346 | value: string; 347 | //iOS 348 | clearButtonMode?: string; // enum('never', 'while-editing', 'unless-editing', 'always') 349 | clearTextOnFocus?: boolean; 350 | enablesReturnKeyAutomatically?: boolean; 351 | keyboardAppearance?: string; // enum ('default', 'light', 'dark') 352 | maxLength?: number; 353 | numberOfLines?: number; 354 | selectTextOnFocus?: boolean; 355 | selectionState?: any; // see DocumentSelectionState.js 356 | spellCheck?: boolean; 357 | //android 358 | textAlignVertical?: string; // enum('top', 'center', 'bottom') 359 | textAlignVerticalAndroid?: string; // enum('top', 'center', 'bottom') 360 | textAlignAndroid?: string; 361 | underlineColorAndroid?: string; 362 | disableFullscreenUI?: boolean; 363 | textBreakStrategy?: 'highQuality' | 'simple' | 'balanced'; 364 | } 365 | 366 | interface TextInputState { 367 | currentlyFocusedField(): number; 368 | focusTextInput(textFieldID?: number): void; 369 | blurTextInput(textFieldID?: number): void; 370 | } 371 | 372 | interface WebViewProps extends ComponentPropsStyleBase { 373 | automaticallyAdjustContentInsets?: boolean; 374 | bounces?: boolean; 375 | contentInset?: {top: number, left: number, bottom: number, right: number }; 376 | injectedJavaScript?: string; 377 | javaScriptEnabled?: boolean; 378 | domStorageEnabled?: boolean; 379 | onShouldStartLoadWithRequest?: Function; 380 | onNavigationStateChange?: Function; 381 | onLoad?: (e: SyntheticEvent) => void; 382 | onLoadStart?: Function; 383 | renderError?: Function; 384 | onError?: Function; 385 | renderLoading?: Function; 386 | scalesPageToFit?: boolean; 387 | scrollEnabled?: boolean; 388 | startInLoadingState?: boolean; 389 | source?: { uri: string; method?: string; headers?: Object; body?: string; } | { html: string; baseUrl?: string; }; 390 | } 391 | 392 | interface NavigatorProps extends ComponentPropsBase { 393 | configureScene?: Function; 394 | initialRoute?: any; 395 | initialRouteStack?: any[]; 396 | navigatorBar?: any; 397 | navigator?: Navigator; 398 | onDidFocus?: Function; //deprecated 399 | onWillFocus?: Function; //deprecated 400 | renderScene: Function; 401 | sceneStyle?: StyleRuleSet | StyleRuleSet[]; 402 | } 403 | 404 | interface DatePickerIOSProps extends ComponentPropsStyleBase { 405 | date?: Date; 406 | maximumDate?: Date; 407 | minimumDate?: Date; 408 | minuteInterval?: number; 409 | mode?: string; 410 | timeZoneOffsetInMinutes?: number; 411 | 412 | onDateChange?: (newDate: Date) => void; 413 | } 414 | 415 | class DatePickerIOS extends ReactNativeBaseComponent { 416 | } 417 | 418 | interface DatePickerAndroidProps extends ComponentPropsStyleBase { 419 | date?: Date; 420 | maxDate?: Date; 421 | minDate?: Date; 422 | 423 | onDateChange?: (newDate: Date) => void; 424 | } 425 | 426 | class DatePickerAndroid extends ReactNativeBaseComponent { 427 | static open(options: { date: Date, maxDate: Date, minDate: Date }): Promise; 428 | static dateSetAction: Function; 429 | static dismissedAction: Function; 430 | } 431 | 432 | interface TimePickerAndroidProps extends ComponentPropsStyleBase { 433 | date?: Date; 434 | maxDate?: Date; 435 | minDate?: Date; 436 | 437 | onDateChange?: (newDate: Date) => void; 438 | } 439 | 440 | class TimePickerAndroid extends ReactNativeBaseComponent { 441 | static open(options: { hour: number, minute: number, is24Hour: boolean }): Promise; 442 | static timeSetAction: Function; 443 | static dismissedAction: Function; 444 | } 445 | 446 | type DatePickerAction = { 447 | action: Function; 448 | day: number; 449 | month: number; 450 | year: number; 451 | } 452 | 453 | type TimePickerAction = { 454 | action: Function; 455 | hour: number; 456 | minute: number; 457 | } 458 | 459 | class Image extends ReactNativeBaseComponent { 460 | static prefetch(url: string): Promise; 461 | } 462 | class ActivityIndicator extends ReactNativeBaseComponent { } 463 | class Text extends ReactNativeBaseComponent { } 464 | class Picker extends ReactNativeBaseComponent { 465 | static Item: any; 466 | } 467 | class TouchableHighlight extends ReactNativeBaseComponent { } 468 | class TouchableWithoutFeedback extends ReactNativeBaseComponent { } 469 | class View extends ReactNativeBaseComponent { } 470 | class ScrollView extends ReactNativeBaseComponent { 471 | getInnerViewNode(): number; 472 | // TODO: Define ScrollResponder type 473 | scrollTo(val: { x?: number; y?: number; animated?: boolean; }): void; 474 | scrollBy(val: { deltaX?: number; deltaY?: number; animated?: boolean; }): void; 475 | } 476 | class ListView extends ReactNativeBaseComponent { 477 | static DataSource: ListViewDataSource; 478 | } 479 | class Modal extends ReactNativeBaseComponent { } 480 | class TextInput extends ReactNativeBaseComponent { 481 | static State: TextInputState; 482 | } 483 | class WebView extends ReactNativeBaseComponent { 484 | reload() : void; 485 | goBack() : void; 486 | goForward() : void; 487 | } 488 | class Navigator extends ReactNativeBaseComponent { 489 | static SceneConfigs: { 490 | PushFromRight: any; 491 | FloatFromRight: any; 492 | FloatFromLeft: any; 493 | FloatFromBottom: any; 494 | FloatFromBottomAndroid: any; 495 | FadeAndroid: any; 496 | HorizontalSwipeJump:any; 497 | }; 498 | getCurrentRoutes(): any[]; 499 | jumpBack(): void; 500 | jumpForward(): void; 501 | jumpTo(route: any): void; 502 | push(route: any): void; 503 | pop(): void; 504 | replace(route: any): void; 505 | replaceAtIndex(route: any, index: number): void; 506 | replacePrevious(route: any): void; 507 | immediatelyResetRouteStack(routeStack: any[]): void; 508 | popToRoute(route: any): void; 509 | popToTop(): void; 510 | } 511 | 512 | interface ActionSheetOptions { 513 | options: string[]; 514 | cancelButtonIndex?: number; 515 | destructiveButtonIndex?: number; 516 | title?: string; 517 | message?: string; 518 | } 519 | 520 | interface ShareActionSheetOptions { 521 | message?: string; 522 | url?: string; 523 | subject?: string; 524 | excludedActivityTypes?: string[]; 525 | } 526 | 527 | class ActionSheetIOS { 528 | static showActionSheetWithOptions(options: ActionSheetOptions, callback: (buttonIndex: number) => void): void; 529 | static showShareActionSheetWithOptions(options: ShareActionSheetOptions, failureCallback: (error: string) => void, successCallback: (success: boolean, method: string) => void): void; 530 | } 531 | 532 | class BackAndroid { 533 | static addEventListener(eventName: string, callback: () => boolean): void; 534 | static removeEventListener(eventName: string, callback: () => boolean): void; 535 | } 536 | 537 | interface NavigatorIOSRoute { 538 | component: any; 539 | title: string; 540 | passProps?: any; 541 | backButtonTitle?: string; 542 | backButtonIcon?: any; 543 | leftButtonTitle?: string; 544 | leftButtonIcon?: any; 545 | onLeftButtonPress?: () => void; 546 | rightButtonTitle?: string; 547 | rightButtonIcon?: any; 548 | onRightButtonPress?: () => void; 549 | wrapperStyle?: any; 550 | } 551 | 552 | interface NavigatorIOSProps extends ComponentPropsBase { 553 | barTintColor?: string; 554 | initialRoute: NavigatorIOSRoute; 555 | itemWrapperStyle?: StyleRuleSet | StyleRuleSet[]; 556 | navigationBarHidden?: boolean; 557 | shadowHidden?: boolean; 558 | style?:any; 559 | tintColor?: string; 560 | titleTextColor?: string; 561 | translucent?: boolean; 562 | interactivePopGestureEnabled?: boolean; 563 | } 564 | 565 | class StatusBar { 566 | // Native 567 | static setHidden(hidden: boolean, animation?: string): void; //'none'|'fade'|'slide'; 568 | 569 | // iOS 570 | static setBarStyle(barStyle: string, animated: boolean): void; //'default'|'light-content'; 571 | static setNetworkActivityIndicatorVisible(value: boolean): void; 572 | 573 | // Android 574 | static setBackgroundColor(color: string, animated?: boolean): void; 575 | static setTranslucent(translucent: boolean): void; 576 | } 577 | 578 | interface EventSubscription { 579 | remove(): void; 580 | } 581 | 582 | interface NavigatorIOSNavigationContext { 583 | addListener(event: string, callback: (route: NavigatorIOSRoute) => void): EventSubscription; 584 | } 585 | 586 | interface NavigatorIOSState { 587 | observedTopOfStack: number; 588 | requestedTopOfStack: number; 589 | routeStack: NavigatorIOSRoute[]; 590 | } 591 | 592 | class NavigatorIOS extends ReactNativeBaseComponent { 593 | navigationContext: NavigatorIOSNavigationContext; 594 | push(route: NavigatorIOSRoute): void; 595 | pop(): void; 596 | popN(n: number): void; 597 | replace(route: NavigatorIOSRoute): void; 598 | replacePrevious(route: NavigatorIOSRoute): void; 599 | replacePreviousAndPop(route: NavigatorIOSRoute): void; 600 | resetTo(route: NavigatorIOSRoute): void; 601 | popToRoute(route: NavigatorIOSRoute): void; 602 | popToTop(): void; 603 | } 604 | 605 | // StyleSheet 606 | class StyleSheet { 607 | static create(obj: { [key: string]: any }): any; 608 | static flatten: (s: StyleSheet) => { [key: string]: any }; 609 | } 610 | 611 | class AppRegistry { 612 | static registerComponent(appKey: string, getComponentFunc: Function): any; 613 | } 614 | 615 | type CameraRollProps = { 616 | /** 617 | * The number of photos wanted in reverse order of the photo application 618 | * (i.e. most recent first for SavedPhotos). 619 | */ 620 | first: number, 621 | 622 | /** 623 | * A cursor that matches `page_info { end_cursor }` returned from a previous 624 | * call to `getPhotos` 625 | */ 626 | after?: string, 627 | 628 | /** 629 | * Specifies which group types to filter the results to. 630 | */ 631 | groupTypes?: string, // enum { 'Album', 'All', 'Event', 'Faces', 'Library', 'PhotoStream', 'SavedPhotos', // default }, 632 | 633 | /** 634 | * Specifies filter on group names, like 'Recent Photos' or custom album 635 | * titles. 636 | */ 637 | groupName?: string, 638 | 639 | /** 640 | * Specifies filter on asset type 641 | */ 642 | assetType?: string; // enum { 'All', 'Videos', 'Photos', // default }, 643 | 644 | } 645 | 646 | type GetPhotosCallbackPropNode = { 647 | node: { 648 | type: string, 649 | group_name: string, 650 | image: { 651 | uri: string, 652 | height: number, 653 | width: number, 654 | isStored?: boolean, 655 | }, 656 | timestamp: number, 657 | location?: { 658 | latitude?: number, 659 | longitude?: number, 660 | altitude?: number, 661 | heading?: number, 662 | speed?: number, 663 | } 664 | } 665 | } 666 | 667 | type GetPhotosCallbackProps = { 668 | edges: GetPhotosCallbackPropNode[], 669 | page_info: { 670 | has_next_page: boolean, 671 | start_cursor?: string, 672 | end_cursor?: string, 673 | } 674 | } 675 | 676 | class Clipboard { 677 | static setString(content: string): void; 678 | static getString(): Promise; 679 | } 680 | 681 | class CameraRoll { 682 | static saveImageWithTag(tag: string, successCallback: Function, errorCallback: Function): void; 683 | static getPhotos(params: CameraRollProps, callback: ((props: GetPhotosCallbackProps) => void), errorCallback: Function): void; 684 | } 685 | 686 | class Linking { 687 | static getInitialURL(): Promise; 688 | static openURL(url: string): Promise; 689 | static canOpenURL(url: string): Promise; 690 | static addEventListener(type: string, handler: (event: any) => void): void; 691 | static removeEventListener(type: string, handler: (event: any) => void): void; 692 | } 693 | 694 | class AccessibilityInfo { 695 | static fetch: () => Promise; 696 | static addEventListener(type: string, handler: (event: any) => void): void; 697 | static removeEventListener(type: string, handler: (event: any) => void): void; 698 | static announceForAccessibility(announcement: string): void; 699 | } 700 | 701 | interface AlertButtonSpec { 702 | text?: string; 703 | onPress?: () => void; 704 | style?: string; // enum {default', 'cancel', 'destructive'} 705 | } 706 | 707 | class Alert { 708 | static alert( 709 | title: string, 710 | message?: string, 711 | buttons?: AlertButtonSpec[], 712 | type?: string // enum { 'default', 'plain-text', 'secure-text', 'login-password'} 713 | ): void; 714 | } 715 | 716 | class PushNotificationIOS { 717 | static presentLocalNotification(details: { category: string, alertBody: string, soundName?: string}): void; 718 | static scheduleLocalNotification(details: {alertBody: string, fireDate: Date}): void; 719 | 720 | static getApplicationIconBadgeNumber(callback: (badgeCount:number) => void): void; 721 | static setApplicationIconBadgeNumber(number: number): void; 722 | 723 | static addEventListener(type: string, handler: (event: any) => void): void; 724 | 725 | static requestPermissions(permissions?: {alert?: boolean, badge?: boolean, sound?: boolean}): void; 726 | static abandonPermissions(): void; 727 | static checkPermissions(callback: (permissions: {alert: boolean, badge: boolean, sound: boolean}) => void): void; 728 | 729 | static getInitialNotification(): Promise; 730 | 731 | getMessage(): string; 732 | getSound(): string; 733 | getAlert(): any; 734 | getBadgeCount(): number; 735 | getData(): any; 736 | } 737 | 738 | interface PanResponderGestureState { 739 | stateID: number; 740 | moveX: number; 741 | moveY: number; 742 | x0: number; 743 | y0: number; 744 | dx: number; 745 | dy: number; 746 | vx: number; 747 | vy: number; 748 | numberActiveTouches: number; 749 | } 750 | 751 | interface ResponderSyntheticEvent extends React.SyntheticEvent { 752 | touchHistory: Function; 753 | } 754 | 755 | type PanResponderCreateConfig = { 756 | onMoveShouldSetPanResponder?: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 757 | onMoveShouldSetPanResponderCapture?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 758 | onStartShouldSetPanResponder?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 759 | onStartShouldSetPanResponderCapture?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 760 | onPanResponderReject?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 761 | onPanResponderGrant?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 762 | onPanResponderStart?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 763 | onPanResponderEnd?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 764 | onPanResponderRelease?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 765 | onPanResponderMove?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 766 | onPanResponderTerminate?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 767 | onPanResponderTerminationRequest?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), 768 | onShouldBlockNativeResponder?: ((e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean), // android only 769 | onStartShouldSetResponderCapture?: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void, 770 | 771 | } 772 | 773 | class PanResponder { 774 | static create(config: PanResponderCreateConfig): PanResponder; 775 | panHandlers: ResponderProps; 776 | } 777 | 778 | type DimensionType = { 779 | width: number, 780 | height: number, 781 | scale: number, 782 | fontScale: number, 783 | } 784 | 785 | class Dimensions { 786 | static set(obj: any): boolean; 787 | static get(key: string): DimensionType; 788 | } 789 | 790 | type RCTAppStateData = { app_state: string } 791 | type RCTAppState = { 792 | getCurrentAppState(successCallback: (appStateData: RCTAppStateData) => void, failureCallback: () => void): void; 793 | } 794 | 795 | type FileInput = { 796 | selectImage: Function; 797 | } 798 | 799 | type SnapshotOptions = { 800 | width?: number; 801 | height?: number; 802 | format?: string; // enum { 'png', 'jpeg' } 803 | quality?: number; 804 | } 805 | 806 | type UIManager = { 807 | measure: Function; 808 | measureInWindow: Function; 809 | measureLayout: Function; 810 | measureLayoutRelativeToParent: Function; 811 | dispatchViewManagerCommand: Function; 812 | 813 | getContentSizeMultiplier: Function; 814 | 815 | // ios 816 | takeSnapshot: (view: any, options?: SnapshotOptions) => Promise; 817 | 818 | // Android 819 | sendAccessibilityEvent: Function; 820 | } 821 | 822 | type AccessibilityManager = { 823 | getMultiplier: Function; 824 | announceForAccessibility (announcement: string): void; 825 | } 826 | 827 | // We don't use this module, but need to be able to check its existance 828 | type NativeAnimatedModule = { 829 | 830 | }; 831 | 832 | class ImagePickerManager { 833 | showImagePicker: Function; 834 | launchCamera: Function; 835 | launchImageLibrary: Function; 836 | } 837 | 838 | class NativeModules { 839 | static AppState: RCTAppState; 840 | static FileInput: FileInput; 841 | static UIManager: UIManager; 842 | static AccessibilityManager: AccessibilityManager; 843 | static ImagePickerManager: ImagePickerManager; 844 | static Networking: { 845 | clearCookies(callback: (success: boolean) => void): void; 846 | } 847 | static ContextMenuAndroid: { 848 | show(buttons: any, callback: (command: string) => void): void; 849 | } 850 | static NativeAnimation: NativeAnimatedModule; 851 | } 852 | 853 | class AsyncStorage { 854 | static getItem(key: string, callback: (error: any, result: string) => void): void; 855 | static setItem(key: string, value: string, callback: (error: any) => void): void; 856 | static removeItem(key: string, callback: (error: any) => void): void; 857 | static clear(callback: (error: any) => void): void; 858 | } 859 | 860 | class NetInfo { 861 | static isConnected: { 862 | addEventListener: (eventName: string, handler: (isConnected: boolean) => void) => void; 863 | removeEventListener: (eventName: string, handler: (isConnected: boolean) => void) => void; 864 | fetch: () => Promise; 865 | } 866 | static fetch(): Promise; 867 | } 868 | 869 | class PixelRatio { 870 | static get(): number; 871 | } 872 | 873 | class Easing { 874 | static bezier(x1: number, y1: number, x2: number, y2: number): ((input: number) => number); 875 | static linear(): ((input: number) => number); 876 | } 877 | 878 | interface AnimationConfig { 879 | isInteraction?: boolean; 880 | useNativeDriver?: boolean; 881 | } 882 | 883 | interface AnimatedTimingConfig extends AnimationConfig { 884 | toValue: number; 885 | duration?: number; 886 | delay?: number 887 | easing?: (input: number) => number; 888 | } 889 | 890 | interface CompositeAnimation { 891 | start(callback?: AnimatedEndCallback): void; 892 | stop: () => void; 893 | } 894 | 895 | type AnimatedEndResult = { finished: boolean }; 896 | type AnimatedEndCallback = (result: AnimatedEndResult) => void; 897 | 898 | module Animated { 899 | function createAnimatedComponent(Component: any, notCollapsable?: boolean): any; 900 | function delay(time: number): CompositeAnimation; 901 | function timing(value: Animated.Value, config: AnimatedTimingConfig): CompositeAnimation; 902 | function parallel(animations: CompositeAnimation[]): CompositeAnimation 903 | function sequence(animations: CompositeAnimation[]): CompositeAnimation 904 | class Value { 905 | constructor(val: number); 906 | setValue(value: number): void; 907 | addListener(callback: any): number; 908 | removeListener(id: string): void; 909 | removeAllListeners(): void; 910 | interpolate(config: any): Value; 911 | } 912 | class View extends ReactNativeBaseComponent { } 913 | class Image extends ReactNativeBaseComponent { } 914 | class Text extends ReactNativeBaseComponent { } 915 | } 916 | 917 | interface IUpdateLayoutAnimationConfig { 918 | duration?: number; 919 | delay?: number; 920 | 921 | springDamping?: number; 922 | initialVelocity?: number; 923 | 924 | type?: string; 925 | } 926 | 927 | interface ICreateLayoutAnimationConfig extends IUpdateLayoutAnimationConfig { 928 | property?: string; 929 | } 930 | 931 | interface ILayoutAnimationConfig { 932 | duration: number; 933 | create?: ICreateLayoutAnimationConfig; 934 | update?: IUpdateLayoutAnimationConfig; 935 | } 936 | 937 | module LayoutAnimation { 938 | function configureNext(config: ILayoutAnimationConfig): void; 939 | 940 | module Types { 941 | var spring: string; 942 | var linear: string; 943 | var easeInEaseOut: string; 944 | var easeIn: string; 945 | var easeOut: string; 946 | var keyboard: string; 947 | } 948 | 949 | module Properties { 950 | var opacity: string; 951 | var scaleXY: string; 952 | } 953 | } 954 | 955 | module NavigationExperimental { 956 | type NavigationAnimatedValue = Animated.Value; 957 | 958 | // Value & Structs. 959 | type NavigationGestureDirection = 'horizontal' | 'vertical' | 'fade'; 960 | 961 | interface NavigationRoute { 962 | key: string; 963 | title?: string; 964 | } 965 | 966 | interface NavigationState { 967 | index: number; 968 | routes: NavigationRoute[]; 969 | } 970 | 971 | type NavigationLayout = { 972 | height: NavigationAnimatedValue, 973 | initHeight: number, 974 | initWidth: number, 975 | isMeasured: boolean, 976 | width: NavigationAnimatedValue, 977 | }; 978 | 979 | type NavigationScene = { 980 | index: number, 981 | isActive: boolean, 982 | isStale: boolean, 983 | key: string, 984 | route: NavigationRoute, 985 | }; 986 | 987 | type NavigationTransitionProps = { 988 | // The layout of the transitioner of the scenes. 989 | layout: NavigationLayout, 990 | 991 | // The navigation state of the transitioner. 992 | navigationState: NavigationState, 993 | 994 | // The progressive index of the transitioner's navigation state. 995 | position: NavigationAnimatedValue, 996 | 997 | // The value that represents the progress of the transition when navigation 998 | // state changes from one to another. Its numberic value will range from 0 999 | // to 1. 1000 | // progress.__getAnimatedValue() < 1 : transtion is happening. 1001 | // progress.__getAnimatedValue() == 1 : transtion completes. 1002 | progress: NavigationAnimatedValue, 1003 | 1004 | // All the scenes of the transitioner. 1005 | scenes: NavigationScene[], 1006 | 1007 | // The active scene, corresponding to the route at 1008 | // `navigationState.routes[navigationState.index]`. 1009 | scene: NavigationScene, 1010 | 1011 | // The gesture distance for `horizontal` and `vertical` transitions 1012 | gestureResponseDistance?: number|null, 1013 | }; 1014 | 1015 | type NavigationSceneRendererProps = NavigationTransitionProps; 1016 | 1017 | type NavigationPanPanHandlers = { 1018 | onMoveShouldSetResponder: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1019 | onMoveShouldSetResponderCapture: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1020 | onResponderEnd: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1021 | onResponderGrant: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1022 | onResponderMove: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1023 | onResponderReject: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1024 | onResponderRelease: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1025 | onResponderStart: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1026 | onResponderTerminate: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1027 | onResponderTerminationRequest: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void | boolean, 1028 | onStartShouldSetResponder: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void, 1029 | onStartShouldSetResponderCapture: (e: ResponderSyntheticEvent, gestureState: PanResponderGestureState) => void, 1030 | }; 1031 | 1032 | type NavigationTransitionSpec = { 1033 | duration?: number, 1034 | // An easing function from `Easing`. 1035 | easing?: (input: number) => number, 1036 | // A timing function such as `Animated.timing`. 1037 | timing?: (value: NavigationAnimatedValue, config: any) => any, 1038 | }; 1039 | 1040 | type SceneDimensions = { 1041 | height: number, 1042 | width: number, 1043 | }; 1044 | 1045 | type NavigationTransitionStyleConfig = { 1046 | // By default input range is defined as [index - 1, index, index + 1]; 1047 | // Input and output ranges must contain the same number of elements 1048 | inputRange?: number[]; 1049 | opacityOutput: number | number[]; 1050 | scaleOutput: number | number[]; 1051 | translateXOutput: number | number[]; 1052 | translateYOutput: number | number[]; 1053 | } 1054 | 1055 | type NavigationCustomTransitionConfig = { 1056 | // Optional transition styles 1057 | transitionStyle?: (sceneIndex: number, sceneDimensions: SceneDimensions) => NavigationTransitionStyleConfig; 1058 | // Optional overrides for duration, easing, and timing 1059 | transitionSpec?: NavigationTransitionSpec; 1060 | // Optionally present the associated below the previous scene 1061 | presentBelowPrevious?: boolean; 1062 | } 1063 | 1064 | // Functions. 1065 | type NavigationAnimationSetter = ( 1066 | position: NavigationAnimatedValue, 1067 | newState: NavigationState, 1068 | lastState: NavigationState 1069 | ) => void; 1070 | 1071 | type NavigationSceneRenderer = ( 1072 | props: NavigationSceneRendererProps 1073 | ) => ReactElement; 1074 | 1075 | type NavigationStyleInterpolator = ( 1076 | props: NavigationSceneRendererProps 1077 | ) => Object; 1078 | 1079 | module StateUtils { 1080 | 1081 | /** 1082 | * Searches for state with given key inside of given ParentNavigationState 1083 | * returns null in case nothing found or getParent(state) == null 1084 | */ 1085 | function get(state: NavigationState, key: string): NavigationRoute|undefined|null; 1086 | 1087 | /** 1088 | * returns index of the state with key in given ParentNavigationState 1089 | * returns null if key not found of getParent(state) == null 1090 | */ 1091 | function indexOf(state: NavigationState, key: string): number; 1092 | 1093 | /** 1094 | * Returns `true` at which a given route's key can be found in the 1095 | * routes of the navigation state. 1096 | */ 1097 | function has(state: NavigationState, key: string): boolean; 1098 | 1099 | /** 1100 | * Pushes newChildState into parent state 1101 | */ 1102 | function push(state: NavigationState, newChildState: NavigationRoute): NavigationState; 1103 | 1104 | /** 1105 | * pops out latest state in the existing Parent 1106 | */ 1107 | function pop(state: NavigationState): NavigationState; 1108 | 1109 | /** 1110 | * If this function gets the same index as currently set it returns the same state 1111 | * in other case it would clone previous state and updates the index 1112 | * 1113 | * it looks like it designed to get NavigationParentState only as otherwise it just will return corrupted object without 1114 | * key attribute or even crash depending on how ... operator would work with null value 1115 | */ 1116 | function jumpToIndex(state: NavigationState, index: number): NavigationState; 1117 | 1118 | /** 1119 | * Same as the previous function but search index by the key first 1120 | * 1121 | * would crash if given key is not found 1122 | */ 1123 | function jumpTo(state: NavigationState, key: string): NavigationState; 1124 | 1125 | /** 1126 | * Sets the focused route to the previous route. 1127 | */ 1128 | function back(state: NavigationState): NavigationState; 1129 | 1130 | /** 1131 | * Sets the focused route to the next route. 1132 | */ 1133 | function forward(state: NavigationState): NavigationState; 1134 | 1135 | /** 1136 | * This function wouldn't modify your state unless it's NavigationParentState 1137 | * if this is a parent state it would clone the children array 1138 | * and will try to relplace item in this array by the newState 1139 | * 1140 | * if there is no item with such key it would crash 1141 | */ 1142 | function replaceAt(state: NavigationState, key: string, newState: NavigationState): NavigationState; 1143 | 1144 | /** 1145 | * the same as the previous function but it replaces item directly by the index 1146 | */ 1147 | function replaceAtIndex(state: NavigationState, index: number, route: NavigationRoute): NavigationState; 1148 | 1149 | /** 1150 | * if nextChildren is null parentState.children would be used 1151 | * if nextIndex is null, parent nextIndex would be used 1152 | */ 1153 | function reset(state: NavigationState, nextChildren?: NavigationRoute[], index?: number): NavigationState; 1154 | } 1155 | 1156 | type NavigationTransitionerProps = { 1157 | configureTransition: ( 1158 | a: NavigationTransitionProps, 1159 | b?: NavigationTransitionProps 1160 | ) => NavigationTransitionSpec, 1161 | navigationState: NavigationState, 1162 | onTransitionEnd: () => void, 1163 | onTransitionStart: (transitionProps: NavigationTransitionProps, prevTransitionProps?: NavigationTransitionProps) => void, 1164 | render: (transitionProps: NavigationTransitionProps, prevTransitionProps?: NavigationTransitionProps) => ReactElement, 1165 | style: any, 1166 | }; 1167 | 1168 | type NavigationTransitionerState = { 1169 | layout: NavigationLayout, 1170 | position: NavigationAnimatedValue, 1171 | progress: NavigationAnimatedValue, 1172 | scenes: NavigationScene[], 1173 | }; 1174 | 1175 | class NavigationTransitioner extends React.Component { 1176 | } 1177 | 1178 | type SceneViewProps = { 1179 | sceneRenderer: NavigationSceneRenderer, 1180 | sceneRendererProps: NavigationSceneRendererProps, 1181 | }; 1182 | 1183 | class SceneView extends React.Component { 1184 | } 1185 | 1186 | type NavigationCardProps = NavigationSceneRendererProps & { 1187 | onComponentRef: (ref: any) => void, 1188 | onNavigateBack?: (action: any) => void, 1189 | panHandlers?: NavigationPanPanHandlers, 1190 | pointerEvents: string, 1191 | renderScene: NavigationSceneRenderer, 1192 | style: any, 1193 | }; 1194 | 1195 | class Card extends React.Component { 1196 | 1197 | } 1198 | 1199 | type NavigationCardStackProps = { 1200 | direction: NavigationGestureDirection, 1201 | customTransitionConfig?: NavigationCustomTransitionConfig, 1202 | navigationState: NavigationState, 1203 | onNavigateBack?: (action: any) => void, 1204 | onTransitionStart?: (transitionProps: NavigationTransitionProps, prevTransitionProps?: NavigationTransitionProps) => void, 1205 | onTransitionEnd?: () => void, 1206 | renderHeader?: NavigationSceneRenderer, 1207 | renderScene: NavigationSceneRenderer, 1208 | cardStyle?: any, 1209 | hideShadow?: boolean, 1210 | style?: any, 1211 | gestureResponseDistance?: number|null, 1212 | enableGestures? : boolean 1213 | }; 1214 | 1215 | class CardStack extends React.Component { 1216 | 1217 | } 1218 | 1219 | type NavigationHeaderProps = NavigationSceneRendererProps & { 1220 | onNavigateBack?: (action: any) => void, 1221 | renderLeftComponent: NavigationSceneRenderer, 1222 | renderRightComponent: NavigationSceneRenderer, 1223 | renderTitleComponent: NavigationSceneRenderer, 1224 | style?: any, 1225 | viewProps?: any, 1226 | statusBarHeight: number | Animated.Value, 1227 | }; 1228 | 1229 | class NavigationHeader extends React.Component { 1230 | 1231 | } 1232 | } 1233 | 1234 | class DeviceEventSubscription { 1235 | remove(): void; 1236 | } 1237 | 1238 | class NativeAppEventEmitter { 1239 | static addListener(eventId: string, callback: Function): DeviceEventSubscription; 1240 | } 1241 | 1242 | module DeviceEventEmitter{ 1243 | function addListener(name: string, callback: Function): void; 1244 | } 1245 | 1246 | module AppState { 1247 | var currentState: string; 1248 | function addEventListener(type: string, handler: Function): void; 1249 | function removeEventListener(type: string, handler: Function): void; 1250 | } 1251 | 1252 | module AppStateIOS { 1253 | var currentState: string; 1254 | function addEventListener(type: string, handler: Function): void; 1255 | function removeEventListener(type: string, handler: Function): void; 1256 | } 1257 | 1258 | module Touchable { 1259 | type RectOffset = { 1260 | top: number, 1261 | left: number, 1262 | right: number, 1263 | bottom: number 1264 | } 1265 | 1266 | interface State { 1267 | touchable: any 1268 | } 1269 | 1270 | interface TouchableMixin extends React.Mixin { 1271 | touchableGetInitialState: () => State 1272 | touchableHandleStartShouldSetResponder: () => {} 1273 | touchableHandleResponderTerminationRequest: () => {} 1274 | touchableHandleResponderGrant: (e: React.SyntheticEvent, dispatchID: string) => {} 1275 | touchableHandleResponderMove: (e: React.SyntheticEvent) => {} 1276 | touchableHandleResponderRelease: (e: React.SyntheticEvent) => {} 1277 | touchableHandleResponderTerminate: (e: React.SyntheticEvent) => {} 1278 | touchableHandleActivePressIn?: (e: React.SyntheticEvent) => {} 1279 | touchableHandleActivePressOut?: (e: React.SyntheticEvent) => {} 1280 | touchableHandlePress?: (e: React.SyntheticEvent) => {} 1281 | touchableHandleLongPress?: (e: React.SyntheticEvent) => {} 1282 | touchableGetHighlightDelayMS?: () => number 1283 | touchableGetPressRectOffset?: () => RectOffset 1284 | } 1285 | 1286 | var Mixin: TouchableMixin; 1287 | } 1288 | 1289 | class EmitterSubscription { 1290 | remove(): void; 1291 | } 1292 | 1293 | module Keyboard { 1294 | function addListener(eventType: string, listener: Function, context?: any): EmitterSubscription; 1295 | function removeAllListeners(eventType: string): void; 1296 | function removeSubscription(subscription: EmitterSubscription): void; 1297 | } 1298 | 1299 | interface IncrementalProps extends ComponentPropsStyleBase { 1300 | onDone?: () => void; 1301 | name: string; 1302 | children?: any; 1303 | } 1304 | 1305 | interface IncrementalPresenterProps extends ComponentPropsStyleBase { 1306 | name: string; 1307 | disabled?: boolean; 1308 | onDone?: () => void; 1309 | onLayout?: (event: Object) => void; 1310 | style?: any; 1311 | children?: any; 1312 | } 1313 | 1314 | class Incremental extends ReactNativeBaseComponent { 1315 | } 1316 | 1317 | class IncrementalGroup extends ReactNativeBaseComponent{ 1318 | } 1319 | 1320 | class IncrementalPresenter extends ReactNativeBaseComponent { 1321 | } 1322 | 1323 | module JSEventLoopWatchdog { 1324 | function install(obj: any): void; 1325 | } 1326 | 1327 | module InteractionManager { 1328 | function setDeadline(deadline: number): void; 1329 | } 1330 | } 1331 | 1332 | interface GeoConfiguration { 1333 | skipPermissionRequests: boolean; 1334 | } 1335 | 1336 | interface Geolocation { 1337 | // React Native addition to navigator.geolocation 1338 | setRNConfiguration(config: GeoConfiguration): void; 1339 | } -------------------------------------------------------------------------------- /src/typings/react.d.ts: -------------------------------------------------------------------------------- 1 | // Type definitions for React v0.14 2 | // Project: http://facebook.github.io/react/ 3 | // Definitions by: Asana , AssureSign , Microsoft 4 | // Definitions: https://github.com/borisyankov/DefinitelyTyped 5 | 6 | declare namespace __React { 7 | // 8 | // React Elements 9 | // ---------------------------------------------------------------------- 10 | 11 | type ReactType = ComponentClass | string; 12 | 13 | interface ReactElement

{ 14 | type: string | ComponentClass

; 15 | props: P; 16 | key: string | number; 17 | ref: string | ((component: Component) => any); 18 | } 19 | 20 | interface ClassicElement

extends ReactElement

{ 21 | type: string | ClassicComponentClass

; 22 | ref: string | ((component: ClassicComponent) => any); 23 | } 24 | 25 | interface DOMElement

extends ClassicElement

{ 26 | type: string; 27 | ref: string | ((component: DOMComponent

) => any); 28 | } 29 | 30 | type HTMLElement = DOMElement; 31 | type SVGElement = DOMElement; 32 | 33 | // 34 | // Factories 35 | // ---------------------------------------------------------------------- 36 | 37 | interface Factory

{ 38 | (props?: P, ...children: ReactNode[]): ReactElement

; 39 | } 40 | 41 | interface ClassicFactory

extends Factory

{ 42 | (props?: P, ...children: ReactNode[]): ClassicElement

; 43 | } 44 | 45 | interface DOMFactory

extends ClassicFactory

{ 46 | (props?: P, ...children: ReactNode[]): DOMElement

; 47 | } 48 | 49 | type HTMLFactory = DOMFactory; 50 | type SVGFactory = DOMFactory; 51 | type SVGElementFactory = DOMFactory; 52 | 53 | // 54 | // React Nodes 55 | // http://facebook.github.io/react/docs/glossary.html 56 | // ---------------------------------------------------------------------- 57 | 58 | type ReactText = string | number; 59 | type ReactChild = ReactElement | ReactText; 60 | 61 | // Should be Array but type aliases cannot be recursive 62 | type ReactFragment = {} | Array; 63 | type ReactNode = ReactChild | ReactFragment | boolean; 64 | 65 | // 66 | // Top Level API 67 | // ---------------------------------------------------------------------- 68 | 69 | function createClass(spec: ComponentSpec): ClassicComponentClass

; 70 | 71 | function createFactory

(type: string): DOMFactory

; 72 | function createFactory

(type: ClassicComponentClass

| string): ClassicFactory

; 73 | function createFactory

(type: ComponentClass

): Factory

; 74 | 75 | function createElement

( 76 | type: string, 77 | props?: P, 78 | ...children: ReactNode[]): DOMElement

; 79 | function createElement

( 80 | type: ClassicComponentClass

| string, 81 | props?: P, 82 | ...children: ReactNode[]): ClassicElement

; 83 | function createElement

( 84 | type: ComponentClass

, 85 | props?: P, 86 | ...children: ReactNode[]): ReactElement

; 87 | 88 | function cloneElement

( 89 | element: DOMElement

, 90 | props?: P, 91 | ...children: ReactNode[]): DOMElement

; 92 | function cloneElement

( 93 | element: ClassicElement

, 94 | props?: P, 95 | ...children: ReactNode[]): ClassicElement

; 96 | function cloneElement

( 97 | element: ReactElement

, 98 | props?: P, 99 | ...children: ReactNode[]): ReactElement

; 100 | 101 | function isValidElement(object: {}): boolean; 102 | 103 | var DOM: ReactDOM; 104 | var PropTypes: ReactPropTypes; 105 | var Children: ReactChildren; 106 | 107 | // 108 | // Component API 109 | // ---------------------------------------------------------------------- 110 | 111 | // Base component for plain JS classes 112 | class Component implements ComponentLifecycle { 113 | static propTypes: ValidationMap; 114 | static contextTypes: ValidationMap; 115 | static childContextTypes: ValidationMap; 116 | static defaultProps: Props; 117 | 118 | constructor(props?: P, context?: any); 119 | setState(f: (prevState: S, props: P) => S, callback?: () => any): void; 120 | setState(state: S, callback?: () => any): void; 121 | forceUpdate(callBack?: () => any): void; 122 | render(): JSX.Element; 123 | props: P; 124 | state: S; 125 | context: {}; 126 | refs: { 127 | [key: string]: Component 128 | }; 129 | } 130 | 131 | interface ClassicComponent extends Component { 132 | replaceState(nextState: S, callback?: () => any): void; 133 | isMounted(): boolean; 134 | getInitialState?(): S; 135 | } 136 | 137 | interface DOMComponent

extends ClassicComponent { 138 | tagName: string; 139 | } 140 | 141 | type HTMLComponent = DOMComponent; 142 | type SVGComponent = DOMComponent; 143 | 144 | interface ChildContextProvider { 145 | getChildContext(): CC; 146 | } 147 | 148 | // 149 | // Class Interfaces 150 | // ---------------------------------------------------------------------- 151 | 152 | interface ComponentClass

{ 153 | new(props?: P, context?: any): Component; 154 | propTypes?: ValidationMap

; 155 | contextTypes?: ValidationMap; 156 | childContextTypes?: ValidationMap; 157 | defaultProps?: P; 158 | } 159 | 160 | interface ClassicComponentClass

extends ComponentClass

{ 161 | new(props?: P, context?: any): ClassicComponent; 162 | getDefaultProps?(): P; 163 | displayName?: string; 164 | } 165 | 166 | // 167 | // Component Specs and Lifecycle 168 | // ---------------------------------------------------------------------- 169 | 170 | interface ComponentLifecycle { 171 | componentWillMount?(): void; 172 | componentDidMount?(): void; 173 | componentWillReceiveProps?(nextProps: P, nextContext: any): void; 174 | shouldComponentUpdate?(nextProps: P, nextState: S, nextContext: any): boolean; 175 | componentWillUpdate?(nextProps: P, nextState: S, nextContext: any): void; 176 | componentDidUpdate?(prevProps: P, prevState: S, prevContext: any): void; 177 | componentWillUnmount?(): void; 178 | } 179 | 180 | interface Mixin extends ComponentLifecycle { 181 | mixins?: Mixin; 182 | statics?: { 183 | [key: string]: any; 184 | }; 185 | 186 | displayName?: string; 187 | propTypes?: ValidationMap; 188 | contextTypes?: ValidationMap; 189 | childContextTypes?: ValidationMap 190 | 191 | getDefaultProps?(): P; 192 | getInitialState?(): S; 193 | } 194 | 195 | interface ComponentSpec extends Mixin { 196 | render(): ReactElement; 197 | 198 | [propertyName: string]: any; 199 | } 200 | 201 | // 202 | // Event System 203 | // ---------------------------------------------------------------------- 204 | 205 | interface SyntheticEvent { 206 | bubbles: boolean; 207 | cancelable: boolean; 208 | currentTarget: EventTarget; 209 | defaultPrevented: boolean; 210 | eventPhase: number; 211 | isTrusted: boolean; 212 | nativeEvent: Event; 213 | preventDefault(): void; 214 | stopPropagation(): void; 215 | persist(): void; 216 | target: EventTarget; 217 | timeStamp: Date; 218 | type: string; 219 | } 220 | 221 | interface DragEvent extends SyntheticEvent { 222 | dataTransfer: DataTransfer; 223 | } 224 | 225 | interface ClipboardEvent extends SyntheticEvent { 226 | clipboardData: DataTransfer; 227 | } 228 | 229 | interface KeyboardEvent extends SyntheticEvent { 230 | altKey: boolean; 231 | charCode: number; 232 | ctrlKey: boolean; 233 | getModifierState(key: string): boolean; 234 | key: string; 235 | keyCode: number; 236 | locale: string; 237 | location: number; 238 | metaKey: boolean; 239 | repeat: boolean; 240 | shiftKey: boolean; 241 | which: number; 242 | } 243 | 244 | interface FocusEvent extends SyntheticEvent { 245 | relatedTarget: EventTarget; 246 | } 247 | 248 | interface FormEvent extends SyntheticEvent { 249 | } 250 | 251 | interface MouseEvent extends SyntheticEvent { 252 | altKey: boolean; 253 | button: number; 254 | buttons: number; 255 | clientX: number; 256 | clientY: number; 257 | ctrlKey: boolean; 258 | getModifierState(key: string): boolean; 259 | metaKey: boolean; 260 | pageX: number; 261 | pageY: number; 262 | relatedTarget: EventTarget; 263 | screenX: number; 264 | screenY: number; 265 | shiftKey: boolean; 266 | } 267 | 268 | interface TouchEvent extends SyntheticEvent { 269 | altKey: boolean; 270 | changedTouches: TouchList; 271 | ctrlKey: boolean; 272 | getModifierState(key: string): boolean; 273 | metaKey: boolean; 274 | shiftKey: boolean; 275 | targetTouches: TouchList; 276 | locationX?: number; 277 | locationY?: number; 278 | pageX?: number; 279 | pageY?: number; 280 | touches: TouchList; 281 | } 282 | 283 | interface UIEvent extends SyntheticEvent { 284 | detail: number; 285 | view: AbstractView; 286 | } 287 | 288 | interface WheelEvent extends MouseEvent { 289 | deltaMode: number; 290 | deltaX: number; 291 | deltaY: number; 292 | deltaZ: number; 293 | } 294 | 295 | // 296 | // Event Handler Types 297 | // ---------------------------------------------------------------------- 298 | 299 | interface EventHandler { 300 | (event: E): void; 301 | } 302 | 303 | interface DragEventHandler extends EventHandler {} 304 | interface ClipboardEventHandler extends EventHandler {} 305 | interface KeyboardEventHandler extends EventHandler {} 306 | interface FocusEventHandler extends EventHandler {} 307 | interface FormEventHandler extends EventHandler {} 308 | interface MouseEventHandler extends EventHandler {} 309 | interface TouchEventHandler extends EventHandler {} 310 | interface UIEventHandler extends EventHandler {} 311 | interface WheelEventHandler extends EventHandler {} 312 | 313 | // 314 | // Props / DOM Attributes 315 | // ---------------------------------------------------------------------- 316 | 317 | interface Props { 318 | children?: ReactNode; 319 | key?: string | number; 320 | ref?: string | ((component: T) => any); 321 | } 322 | 323 | interface DOMAttributesBase extends Props { 324 | onCopy?: ClipboardEventHandler; 325 | onCut?: ClipboardEventHandler; 326 | onPaste?: ClipboardEventHandler; 327 | onKeyDown?: KeyboardEventHandler; 328 | onKeyPress?: KeyboardEventHandler; 329 | onKeyUp?: KeyboardEventHandler; 330 | onFocus?: FocusEventHandler; 331 | onBlur?: FocusEventHandler; 332 | onChange?: FormEventHandler; 333 | onInput?: FormEventHandler; 334 | onSubmit?: FormEventHandler; 335 | onClick?: MouseEventHandler; 336 | onContextMenu?: MouseEventHandler; 337 | onDoubleClick?: MouseEventHandler; 338 | onDrag?: DragEventHandler; 339 | onDragEnd?: DragEventHandler; 340 | onDragEnter?: DragEventHandler; 341 | onDragExit?: DragEventHandler; 342 | onDragLeave?: DragEventHandler; 343 | onDragOver?: DragEventHandler; 344 | onDragStart?: DragEventHandler; 345 | onDrop?: DragEventHandler; 346 | onMouseDown?: MouseEventHandler; 347 | onMouseEnter?: MouseEventHandler; 348 | onMouseLeave?: MouseEventHandler; 349 | onMouseMove?: MouseEventHandler; 350 | onMouseOut?: MouseEventHandler; 351 | onMouseOver?: MouseEventHandler; 352 | onMouseUp?: MouseEventHandler; 353 | onTouchCancel?: TouchEventHandler; 354 | onTouchEnd?: TouchEventHandler; 355 | onTouchMove?: TouchEventHandler; 356 | onTouchStart?: TouchEventHandler; 357 | onScroll?: UIEventHandler; 358 | onWheel?: WheelEventHandler; 359 | 360 | className?: string; 361 | id?: string; 362 | 363 | dangerouslySetInnerHTML?: { 364 | __html: string; 365 | }; 366 | } 367 | 368 | interface DOMAttributes extends DOMAttributesBase> { 369 | } 370 | 371 | // This interface is not complete. Only properties accepting 372 | // unitless numbers are listed here (see CSSProperty.js in React) 373 | interface CSSProperties { 374 | boxFlex?: number; 375 | boxFlexGroup?: number; 376 | columnCount?: number; 377 | flex?: number | string; 378 | flexGrow?: number; 379 | flexShrink?: number; 380 | fontWeight?: number | string; 381 | lineClamp?: number; 382 | lineHeight?: number | string; 383 | opacity?: number; 384 | order?: number; 385 | orphans?: number; 386 | widows?: number; 387 | zIndex?: number; 388 | zoom?: number; 389 | 390 | fontSize?: number | string; 391 | 392 | // SVG-related properties 393 | fillOpacity?: number; 394 | strokeOpacity?: number; 395 | strokeWidth?: number; 396 | 397 | [propertyName: string]: any; 398 | } 399 | 400 | interface HTMLAttributesBase extends DOMAttributesBase { 401 | accept?: string; 402 | acceptCharset?: string; 403 | accessKey?: string; 404 | action?: string; 405 | allowFullScreen?: boolean; 406 | allowTransparency?: boolean; 407 | alt?: string; 408 | async?: boolean; 409 | autoComplete?: boolean; 410 | autoFocus?: boolean; 411 | autoPlay?: boolean; 412 | cellPadding?: number | string; 413 | cellSpacing?: number | string; 414 | charSet?: string; 415 | checked?: boolean; 416 | classID?: string; 417 | cols?: number; 418 | colSpan?: number; 419 | content?: string; 420 | contentEditable?: boolean; 421 | contextMenu?: string; 422 | controls?: any; 423 | coords?: string; 424 | crossOrigin?: string; 425 | data?: string; 426 | dateTime?: string; 427 | defaultChecked?: boolean; 428 | defaultValue?: string; 429 | defer?: boolean; 430 | dir?: string; 431 | disabled?: boolean; 432 | download?: any; 433 | draggable?: boolean; 434 | encType?: string; 435 | form?: string; 436 | formAction?: string; 437 | formEncType?: string; 438 | formMethod?: string; 439 | formNoValidate?: boolean; 440 | formTarget?: string; 441 | frameBorder?: number | string; 442 | headers?: string; 443 | height?: number | string; 444 | hidden?: boolean; 445 | high?: number; 446 | href?: string; 447 | hrefLang?: string; 448 | htmlFor?: string; 449 | httpEquiv?: string; 450 | icon?: string; 451 | label?: string; 452 | lang?: string; 453 | list?: string; 454 | loop?: boolean; 455 | low?: number; 456 | manifest?: string; 457 | marginHeight?: number; 458 | marginWidth?: number; 459 | max?: number | string; 460 | maxLength?: number; 461 | media?: string; 462 | mediaGroup?: string; 463 | method?: string; 464 | min?: number | string; 465 | multiple?: boolean; 466 | muted?: boolean; 467 | name?: string; 468 | noValidate?: boolean; 469 | open?: boolean; 470 | optimum?: number; 471 | pattern?: string; 472 | placeholder?: string; 473 | poster?: string; 474 | preload?: string; 475 | radioGroup?: string; 476 | readOnly?: boolean; 477 | rel?: string; 478 | required?: boolean; 479 | role?: string; 480 | rows?: number; 481 | rowSpan?: number; 482 | sandbox?: string; 483 | scope?: string; 484 | scoped?: boolean; 485 | scrolling?: string; 486 | seamless?: boolean; 487 | selected?: boolean; 488 | shape?: string; 489 | size?: number; 490 | sizes?: string; 491 | span?: number; 492 | spellCheck?: boolean; 493 | src?: string; 494 | srcDoc?: string; 495 | srcSet?: string; 496 | start?: number; 497 | step?: number | string; 498 | style?: any; 499 | tabIndex?: number; 500 | target?: string; 501 | title?: string; 502 | type?: string; 503 | useMap?: string; 504 | value?: string; 505 | width?: number | string; 506 | wmode?: string; 507 | 508 | // Non-standard Attributes 509 | autoCapitalize?: boolean; 510 | autoCorrect?: boolean; 511 | property?: string; 512 | itemProp?: string; 513 | itemScope?: boolean; 514 | itemType?: string; 515 | unselectable?: boolean; 516 | } 517 | 518 | interface HTMLAttributes extends HTMLAttributesBase { 519 | } 520 | 521 | interface MediaHTMLAttributes extends HTMLAttributes { 522 | onLoad?: EventHandler; 523 | onError?: EventHandler; 524 | } 525 | 526 | interface VideoHTMLAttributes extends HTMLAttributes { 527 | onLoadedData?: EventHandler; 528 | onError?: EventHandler; 529 | 530 | onLoadStart?: () => void; 531 | onCanPlay?: () => void; 532 | onCanPlayThrough?: () => void; 533 | onEnded?: () => void; 534 | onWaiting?: () => void; 535 | onPlaying?: () => void; 536 | onTimeUpdate?: () => void; 537 | } 538 | 539 | interface IframeHTMLAttributes extends HTMLAttributes { 540 | onLoad?: EventHandler; 541 | } 542 | 543 | interface InputHTMLAttributes extends HTMLAttributes { 544 | editable?: boolean; 545 | } 546 | 547 | interface SVGElementAttributes extends HTMLAttributes { 548 | viewBox?: string; 549 | preserveAspectRatio?: string; 550 | } 551 | 552 | interface SVGAttributes extends DOMAttributes { 553 | ref?: string | ((component: SVGComponent) => void); 554 | 555 | cx?: number | string; 556 | cy?: number | string; 557 | d?: string; 558 | dx?: number | string; 559 | dy?: number | string; 560 | fill?: string; 561 | fillOpacity?: number | string; 562 | fontFamily?: string; 563 | fontSize?: number | string; 564 | fx?: number | string; 565 | fy?: number | string; 566 | gradientTransform?: string; 567 | gradientUnits?: string; 568 | height?: number | string; 569 | markerEnd?: string; 570 | markerMid?: string; 571 | markerStart?: string; 572 | offset?: number | string; 573 | opacity?: number | string; 574 | patternContentUnits?: string; 575 | patternUnits?: string; 576 | points?: string; 577 | preserveAspectRatio?: string; 578 | r?: number | string; 579 | rx?: number | string; 580 | ry?: number | string; 581 | spreadMethod?: string; 582 | stopColor?: string; 583 | stopOpacity?: number | string; 584 | stroke?: string; 585 | strokeDasharray?: string; 586 | strokeLinecap?: string; 587 | strokeMiterlimit?: string; 588 | strokeOpacity?: number | string; 589 | strokeWidth?: number | string; 590 | textAnchor?: string; 591 | transform?: string; 592 | version?: string; 593 | viewBox?: string; 594 | width?: number | string; 595 | x1?: number | string; 596 | x2?: number | string; 597 | x?: number | string; 598 | y1?: number | string; 599 | y2?: number | string 600 | y?: number | string; 601 | } 602 | 603 | // 604 | // React.DOM 605 | // ---------------------------------------------------------------------- 606 | 607 | interface ReactDOM { 608 | // HTML 609 | a: HTMLFactory; 610 | abbr: HTMLFactory; 611 | address: HTMLFactory; 612 | area: HTMLFactory; 613 | article: HTMLFactory; 614 | aside: HTMLFactory; 615 | audio: HTMLFactory; 616 | b: HTMLFactory; 617 | base: HTMLFactory; 618 | bdi: HTMLFactory; 619 | bdo: HTMLFactory; 620 | big: HTMLFactory; 621 | blockquote: HTMLFactory; 622 | body: HTMLFactory; 623 | br: HTMLFactory; 624 | button: HTMLFactory; 625 | canvas: HTMLFactory; 626 | caption: HTMLFactory; 627 | cite: HTMLFactory; 628 | code: HTMLFactory; 629 | col: HTMLFactory; 630 | colgroup: HTMLFactory; 631 | data: HTMLFactory; 632 | datalist: HTMLFactory; 633 | dd: HTMLFactory; 634 | del: HTMLFactory; 635 | details: HTMLFactory; 636 | dfn: HTMLFactory; 637 | dialog: HTMLFactory; 638 | div: HTMLFactory; 639 | dl: HTMLFactory; 640 | dt: HTMLFactory; 641 | em: HTMLFactory; 642 | embed: HTMLFactory; 643 | fieldset: HTMLFactory; 644 | figcaption: HTMLFactory; 645 | figure: HTMLFactory; 646 | footer: HTMLFactory; 647 | form: HTMLFactory; 648 | h1: HTMLFactory; 649 | h2: HTMLFactory; 650 | h3: HTMLFactory; 651 | h4: HTMLFactory; 652 | h5: HTMLFactory; 653 | h6: HTMLFactory; 654 | head: HTMLFactory; 655 | header: HTMLFactory; 656 | hr: HTMLFactory; 657 | html: HTMLFactory; 658 | i: HTMLFactory; 659 | iframe: HTMLFactory; 660 | img: HTMLFactory; 661 | input: HTMLFactory; 662 | ins: HTMLFactory; 663 | kbd: HTMLFactory; 664 | keygen: HTMLFactory; 665 | label: HTMLFactory; 666 | legend: HTMLFactory; 667 | li: HTMLFactory; 668 | link: HTMLFactory; 669 | main: HTMLFactory; 670 | map: HTMLFactory; 671 | mark: HTMLFactory; 672 | menu: HTMLFactory; 673 | menuitem: HTMLFactory; 674 | meta: HTMLFactory; 675 | meter: HTMLFactory; 676 | nav: HTMLFactory; 677 | noscript: HTMLFactory; 678 | object: HTMLFactory; 679 | ol: HTMLFactory; 680 | optgroup: HTMLFactory; 681 | option: HTMLFactory; 682 | output: HTMLFactory; 683 | p: HTMLFactory; 684 | param: HTMLFactory; 685 | picture: HTMLFactory; 686 | pre: HTMLFactory; 687 | progress: HTMLFactory; 688 | q: HTMLFactory; 689 | rp: HTMLFactory; 690 | rt: HTMLFactory; 691 | ruby: HTMLFactory; 692 | s: HTMLFactory; 693 | samp: HTMLFactory; 694 | script: HTMLFactory; 695 | section: HTMLFactory; 696 | select: HTMLFactory; 697 | small: HTMLFactory; 698 | source: HTMLFactory; 699 | span: HTMLFactory; 700 | strong: HTMLFactory; 701 | style: HTMLFactory; 702 | sub: HTMLFactory; 703 | summary: HTMLFactory; 704 | sup: HTMLFactory; 705 | table: HTMLFactory; 706 | tbody: HTMLFactory; 707 | td: HTMLFactory; 708 | textarea: HTMLFactory; 709 | tfoot: HTMLFactory; 710 | th: HTMLFactory; 711 | thead: HTMLFactory; 712 | time: HTMLFactory; 713 | title: HTMLFactory; 714 | tr: HTMLFactory; 715 | track: HTMLFactory; 716 | u: HTMLFactory; 717 | ul: HTMLFactory; 718 | "var": HTMLFactory; 719 | video: HTMLFactory; 720 | wbr: HTMLFactory; 721 | 722 | // SVG 723 | svg: SVGElementFactory; 724 | circle: SVGFactory; 725 | defs: SVGFactory; 726 | ellipse: SVGFactory; 727 | g: SVGFactory; 728 | line: SVGFactory; 729 | linearGradient: SVGFactory; 730 | mask: SVGFactory; 731 | path: SVGFactory; 732 | pattern: SVGFactory; 733 | polygon: SVGFactory; 734 | polyline: SVGFactory; 735 | radialGradient: SVGFactory; 736 | rect: SVGFactory; 737 | stop: SVGFactory; 738 | text: SVGFactory; 739 | tspan: SVGFactory; 740 | } 741 | 742 | // 743 | // React.PropTypes 744 | // ---------------------------------------------------------------------- 745 | 746 | interface Validator { 747 | (object: T, key: string, componentName: string): Error; 748 | } 749 | 750 | interface Requireable extends Validator { 751 | isRequired: Validator; 752 | } 753 | 754 | interface ValidationMap { 755 | [key: string]: Validator; 756 | } 757 | 758 | interface ReactPropTypes { 759 | any: Requireable; 760 | array: Requireable; 761 | bool: Requireable; 762 | func: Requireable; 763 | number: Requireable; 764 | object: Requireable; 765 | string: Requireable; 766 | node: Requireable; 767 | element: Requireable; 768 | instanceOf(expectedClass: {}): Requireable; 769 | oneOf(types: any[]): Requireable; 770 | oneOfType(types: Validator[]): Requireable; 771 | arrayOf(type: Validator): Requireable; 772 | objectOf(type: Validator): Requireable; 773 | shape(type: ValidationMap): Requireable; 774 | } 775 | 776 | // 777 | // React.Children 778 | // ---------------------------------------------------------------------- 779 | 780 | interface ReactChildren { 781 | map(children: ReactNode, fn: (child: ReactChild, index: number) => T): { [key:string]: T }; 782 | forEach(children: ReactNode, fn: (child: ReactChild, index: number) => any): void; 783 | count(children: ReactNode): number; 784 | only(children: ReactNode): ReactElement; 785 | toArray(children: ReactNode): ReactChild[]; 786 | } 787 | 788 | // 789 | // Browser Interfaces 790 | // https://github.com/nikeee/2048-typescript/blob/master/2048/js/touch.d.ts 791 | // ---------------------------------------------------------------------- 792 | 793 | interface AbstractView { 794 | styleMedia: StyleMedia; 795 | document: Document; 796 | } 797 | 798 | interface Touch { 799 | identifier: number; 800 | target: EventTarget; 801 | locationX: number; 802 | locationY: number; 803 | pageX: number; 804 | pageY: number; 805 | timestamp: number; 806 | } 807 | 808 | interface TouchList { 809 | [index: number]: Touch; 810 | length: number; 811 | item(index: number): Touch; 812 | identifiedTouch(identifier: number): Touch; 813 | } 814 | } 815 | 816 | declare module "react" { 817 | export = __React; 818 | } 819 | 820 | declare namespace JSX { 821 | import React = __React; 822 | 823 | interface Element extends React.ReactElement { } 824 | interface ElementClass extends React.Component { 825 | render(): JSX.Element; 826 | } 827 | interface ElementAttributesProperty { props: {}; } 828 | 829 | interface IntrinsicElements { 830 | // HTML 831 | a: React.HTMLAttributes; 832 | abbr: React.HTMLAttributes; 833 | address: React.HTMLAttributes; 834 | area: React.HTMLAttributes; 835 | article: React.HTMLAttributes; 836 | aside: React.HTMLAttributes; 837 | audio: React.HTMLAttributes; 838 | b: React.HTMLAttributes; 839 | base: React.HTMLAttributes; 840 | bdi: React.HTMLAttributes; 841 | bdo: React.HTMLAttributes; 842 | big: React.HTMLAttributes; 843 | blockquote: React.HTMLAttributes; 844 | body: React.HTMLAttributes; 845 | br: React.HTMLAttributes; 846 | button: React.HTMLAttributes; 847 | canvas: React.HTMLAttributes; 848 | caption: React.HTMLAttributes; 849 | cite: React.HTMLAttributes; 850 | code: React.HTMLAttributes; 851 | col: React.HTMLAttributes; 852 | colgroup: React.HTMLAttributes; 853 | data: React.HTMLAttributes; 854 | datalist: React.HTMLAttributes; 855 | dd: React.HTMLAttributes; 856 | del: React.HTMLAttributes; 857 | details: React.HTMLAttributes; 858 | dfn: React.HTMLAttributes; 859 | dialog: React.HTMLAttributes; 860 | div: React.HTMLAttributes; 861 | dl: React.HTMLAttributes; 862 | dt: React.HTMLAttributes; 863 | em: React.HTMLAttributes; 864 | embed: React.HTMLAttributes; 865 | fieldset: React.HTMLAttributes; 866 | figcaption: React.HTMLAttributes; 867 | figure: React.HTMLAttributes; 868 | footer: React.HTMLAttributes; 869 | form: React.HTMLAttributes; 870 | h1: React.HTMLAttributes; 871 | h2: React.HTMLAttributes; 872 | h3: React.HTMLAttributes; 873 | h4: React.HTMLAttributes; 874 | h5: React.HTMLAttributes; 875 | h6: React.HTMLAttributes; 876 | head: React.HTMLAttributes; 877 | header: React.HTMLAttributes; 878 | hr: React.HTMLAttributes; 879 | html: React.HTMLAttributes; 880 | i: React.HTMLAttributes; 881 | iframe: React.IframeHTMLAttributes; 882 | img: React.MediaHTMLAttributes; 883 | input: React.InputHTMLAttributes; 884 | ins: React.HTMLAttributes; 885 | kbd: React.HTMLAttributes; 886 | keygen: React.HTMLAttributes; 887 | label: React.HTMLAttributes; 888 | legend: React.HTMLAttributes; 889 | li: React.HTMLAttributes; 890 | link: React.HTMLAttributes; 891 | main: React.HTMLAttributes; 892 | map: React.HTMLAttributes; 893 | mark: React.HTMLAttributes; 894 | menu: React.HTMLAttributes; 895 | menuitem: React.HTMLAttributes; 896 | meta: React.HTMLAttributes; 897 | meter: React.HTMLAttributes; 898 | nav: React.HTMLAttributes; 899 | noscript: React.HTMLAttributes; 900 | object: React.HTMLAttributes; 901 | ol: React.HTMLAttributes; 902 | optgroup: React.HTMLAttributes; 903 | option: React.HTMLAttributes; 904 | output: React.HTMLAttributes; 905 | p: React.HTMLAttributes; 906 | param: React.HTMLAttributes; 907 | picture: React.HTMLAttributes; 908 | pre: React.HTMLAttributes; 909 | progress: React.HTMLAttributes; 910 | q: React.HTMLAttributes; 911 | rp: React.HTMLAttributes; 912 | rt: React.HTMLAttributes; 913 | ruby: React.HTMLAttributes; 914 | s: React.HTMLAttributes; 915 | samp: React.HTMLAttributes; 916 | script: React.HTMLAttributes; 917 | section: React.HTMLAttributes; 918 | select: React.HTMLAttributes; 919 | small: React.HTMLAttributes; 920 | source: React.HTMLAttributes; 921 | span: React.HTMLAttributes; 922 | strong: React.HTMLAttributes; 923 | style: React.HTMLAttributes; 924 | sub: React.HTMLAttributes; 925 | summary: React.HTMLAttributes; 926 | sup: React.HTMLAttributes; 927 | table: React.HTMLAttributes; 928 | tbody: React.HTMLAttributes; 929 | td: React.HTMLAttributes; 930 | textarea: React.InputHTMLAttributes; 931 | tfoot: React.HTMLAttributes; 932 | th: React.HTMLAttributes; 933 | thead: React.HTMLAttributes; 934 | time: React.HTMLAttributes; 935 | title: React.HTMLAttributes; 936 | tr: React.HTMLAttributes; 937 | track: React.HTMLAttributes; 938 | u: React.HTMLAttributes; 939 | ul: React.HTMLAttributes; 940 | "var": React.HTMLAttributes; 941 | video: React.VideoHTMLAttributes; 942 | wbr: React.HTMLAttributes; 943 | 944 | // SVG 945 | svg: React.SVGElementAttributes; 946 | 947 | circle: React.SVGAttributes; 948 | defs: React.SVGAttributes; 949 | ellipse: React.SVGAttributes; 950 | g: React.SVGAttributes; 951 | line: React.SVGAttributes; 952 | linearGradient: React.SVGAttributes; 953 | mask: React.SVGAttributes; 954 | path: React.SVGAttributes; 955 | pattern: React.SVGAttributes; 956 | polygon: React.SVGAttributes; 957 | polyline: React.SVGAttributes; 958 | radialGradient: React.SVGAttributes; 959 | rect: React.SVGAttributes; 960 | stop: React.SVGAttributes; 961 | text: React.SVGAttributes; 962 | tspan: React.SVGAttributes; 963 | } 964 | } 965 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "exclude": [ 3 | "node_modules" 4 | ], 5 | "compilerOptions": { 6 | "declaration": false, 7 | "noResolve": false, 8 | "jsx": "react", 9 | "reactNamespace": "RX", 10 | "module": "commonjs", 11 | "target": "es6", 12 | "experimentalDecorators": true, 13 | "sourceMap": true, 14 | "noImplicitAny": true, 15 | "noImplicitReturns": true, 16 | "outDir": "./dist/", 17 | "lib": ["es2015", "dom"], 18 | "types": [ 19 | "node" 20 | ] 21 | }, 22 | "include": [ 23 | "./src/**/*" 24 | ] 25 | } -------------------------------------------------------------------------------- /webpack.config.ts: -------------------------------------------------------------------------------- 1 | import * as webpack from 'webpack'; 2 | 3 | const config: webpack.Configuration = { 4 | entry: "./src/index.tsx", 5 | output: { 6 | filename: "bundle.js", 7 | path: __dirname + "/dist" 8 | }, 9 | 10 | // Enable sourcemaps for debugging webpack's output. 11 | devtool: "source-map", 12 | 13 | resolve: { 14 | // Add '.ts' and '.tsx' as resolvable extensions. 15 | extensions: [".webpack.js", ".web.js", ".ts", ".tsx", ".js"] 16 | }, 17 | 18 | module: { 19 | loaders: [ 20 | // All files with a '.ts' or '.tsx' extension will be handled by 'awesome-typescript-loader'. 21 | { test: /\.tsx?$/, loader: "awesome-typescript-loader" }, 22 | ] 23 | }, 24 | }; 25 | 26 | export default config; 27 | --------------------------------------------------------------------------------