├── .watchmanconfig
├── watch.sh
├── android
├── settings.gradle
├── app
│ ├── src
│ │ └── main
│ │ │ ├── res
│ │ │ ├── values
│ │ │ │ ├── strings.xml
│ │ │ │ └── styles.xml
│ │ │ ├── mipmap-hdpi
│ │ │ │ └── ic_launcher.png
│ │ │ ├── mipmap-mdpi
│ │ │ │ └── ic_launcher.png
│ │ │ ├── mipmap-xhdpi
│ │ │ │ └── ic_launcher.png
│ │ │ └── mipmap-xxhdpi
│ │ │ │ └── ic_launcher.png
│ │ │ ├── AndroidManifest.xml
│ │ │ └── java
│ │ │ └── com
│ │ │ └── purescriptsampleapp
│ │ │ └── MainActivity.java
│ ├── proguard-rules.pro
│ └── build.gradle
├── gradle
│ └── wrapper
│ │ ├── gradle-wrapper.jar
│ │ └── gradle-wrapper.properties
├── build.gradle
├── gradle.properties
├── gradlew.bat
└── gradlew
├── index.android.js
├── screenshot.png
├── .gitignore
├── src
├── Main.js
└── Main.purs
├── package.json
├── ios
├── main.jsbundle
├── PureScriptSampleApp
│ ├── AppDelegate.h
│ ├── main.m
│ ├── Images.xcassets
│ │ └── AppIcon.appiconset
│ │ │ └── Contents.json
│ ├── Info.plist
│ ├── AppDelegate.m
│ └── Base.lproj
│ │ └── LaunchScreen.xib
├── PureScriptSampleAppTests
│ ├── Info.plist
│ └── PureScriptSampleAppTests.m
└── PureScriptSampleApp.xcodeproj
│ ├── xcshareddata
│ └── xcschemes
│ │ └── PureScriptSampleApp.xcscheme
│ └── project.pbxproj
├── bower.json
├── README.md
├── UNLICENSE
├── index.ios.js
└── .flowconfig
/.watchmanconfig:
--------------------------------------------------------------------------------
1 | {}
--------------------------------------------------------------------------------
/watch.sh:
--------------------------------------------------------------------------------
1 | #!/bin/sh
2 | pulp --watch build --require-path '../'
3 |
--------------------------------------------------------------------------------
/android/settings.gradle:
--------------------------------------------------------------------------------
1 | rootProject.name = 'PureScriptSampleApp'
2 |
3 | include ':app'
4 |
--------------------------------------------------------------------------------
/index.android.js:
--------------------------------------------------------------------------------
1 | React = require('react-native')
2 | require('./output/Main').main();
3 |
--------------------------------------------------------------------------------
/screenshot.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/screenshot.png
--------------------------------------------------------------------------------
/android/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 | PureScriptSampleApp
3 |
4 |
--------------------------------------------------------------------------------
/android/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/android/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/hoodunit/purescript-react-native-todomvc/HEAD/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | /bower_components/
2 | /node_modules/
3 | /output/
4 | /.psci*
5 | /src/.webpack.js
6 | android/app/build
7 | android/build
8 | psc.tix
9 | psc-bundle.tix
10 | android/.gradle
--------------------------------------------------------------------------------
/android/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/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.4-all.zip
6 |
--------------------------------------------------------------------------------
/src/Main.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | // module Main
4 |
5 | exports.unsafeLog = function(data){
6 | return function(){
7 | console.log(data);
8 | }
9 | }
10 |
11 | exports.unsafeLog2 = function(data){
12 | console.log(data);
13 | return data;
14 | }
15 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "PureScriptSampleApp",
3 | "version": "0.0.1",
4 | "private": true,
5 | "scripts": {
6 | "start": "node_modules/react-native/packager/packager.sh"
7 | },
8 | "dependencies": {
9 | "react-native": "^0.12.0-rc"
10 | }
11 | }
12 |
--------------------------------------------------------------------------------
/ios/main.jsbundle:
--------------------------------------------------------------------------------
1 | // Offline JS
2 | // To re-generate the offline bundle, run this from the root of your project:
3 | //
4 | // $ react-native bundle --minify
5 | //
6 | // See http://facebook.github.io/react-native/docs/runningondevice.html for more details.
7 |
8 | throw new Error('Offline JS file is empty. See iOS/main.jsbundle for instructions');
9 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp/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/PureScriptSampleApp/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 |
--------------------------------------------------------------------------------
/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:1.3.1'
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 | jcenter {
20 | url "http://dl.bintray.com/mkonicek/maven"
21 | }
22 | }
23 | }
24 |
--------------------------------------------------------------------------------
/bower.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "purescript-react-native-todomvc",
3 | "keywords": [
4 | "purescript"
5 | ],
6 | "version": "1.0.0",
7 | "moduleType": [
8 | "node"
9 | ],
10 | "ignore": [
11 | "**/.*",
12 | "node_modules",
13 | "bower_components",
14 | "output"
15 | ],
16 | "dependencies": {
17 | "purescript-console": "^0.1.0",
18 | "purescript-react": "~0.4.1",
19 | "purescript-react-native": "130d26ff00d6856a7cbc89225dac4eef35b3063f",
20 | "purescript-arrays": "~0.4.2",
21 | "purescript-integers": "~0.2.1",
22 | "purescript-maybe": "~0.3.4",
23 | "purescript-generics": "~0.6.1"
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/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 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp/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 | }
--------------------------------------------------------------------------------
/android/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: 'com.android.application'
2 |
3 | android {
4 | compileSdkVersion 23
5 | buildToolsVersion "23.0.1"
6 |
7 | defaultConfig {
8 | applicationId "com.purescriptsampleapp"
9 | minSdkVersion 16
10 | targetSdkVersion 22
11 | versionCode 1
12 | versionName "1.0"
13 | ndk {
14 | abiFilters "armeabi-v7a", "x86"
15 | }
16 | }
17 | buildTypes {
18 | release {
19 | minifyEnabled false
20 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
21 | }
22 | }
23 | }
24 |
25 | dependencies {
26 | compile fileTree(dir: 'libs', include: ['*.jar'])
27 | compile 'com.android.support:appcompat-v7:23.0.1'
28 | compile 'com.facebook.react:react-native:0.12.+'
29 | }
30 |
--------------------------------------------------------------------------------
/android/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
11 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleAppTests/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 |
--------------------------------------------------------------------------------
/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 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | ## PureScript on React Native - TodoMVC
2 |
3 | This is a todo app for Android in the style of [TodoMVC](http://todomvc.com) using PureScript wrappers for React Native. It has only been tested on Android but may, in theory, work for iOS with small changes.
4 |
5 |
6 |
7 | To install and run the app:
8 |
9 | 1. Install React Native and the Android SDK tools.
10 | 1. Install dependencies and set up project:
11 |
12 | ```
13 | npm install
14 | react-native android
15 | bower update
16 | ```
17 |
18 | 1. Start Pulp to compile PureScript source (and recompile on changes):
19 |
20 | `./watch.sh`
21 |
22 | 1. Start server for serving JS files to the app.
23 |
24 | `react-native start`
25 |
26 | 1. Plug in Android device (or load up emulator).
27 | 1. Set up a reverse socket connection so your app grabs JavaScript sources from the correct place.
28 |
29 | `adb reverse tcp:8081 tcp:8081`
30 |
31 | 1. Build app and push it to the device. Enable auto-refresh in the app options.
32 |
33 | `react-native run-android`
34 |
--------------------------------------------------------------------------------
/UNLICENSE:
--------------------------------------------------------------------------------
1 | This is free and unencumbered software released into the public domain.
2 |
3 | Anyone is free to copy, modify, publish, use, compile, sell, or
4 | distribute this software, either in source code form or as a compiled
5 | binary, for any purpose, commercial or non-commercial, and by any
6 | means.
7 |
8 | In jurisdictions that recognize copyright laws, the author or authors
9 | of this software dedicate any and all copyright interest in the
10 | software to the public domain. We make this dedication for the benefit
11 | of the public at large and to the detriment of our heirs and
12 | successors. We intend this dedication to be an overt act of
13 | relinquishment in perpetuity of all present and future rights to this
14 | software under copyright law.
15 |
16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19 | IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 | OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 | ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 | OTHER DEALINGS IN THE SOFTWARE.
23 |
24 | For more information, please refer to
25 |
--------------------------------------------------------------------------------
/index.ios.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Sample React Native App
3 | * https://github.com/facebook/react-native
4 | */
5 | 'use strict';
6 |
7 | var React = require('react-native');
8 | var {
9 | AppRegistry,
10 | StyleSheet,
11 | Text,
12 | View,
13 | } = React;
14 |
15 | var PureScriptSampleApp = React.createClass({
16 | render: function() {
17 | return (
18 |
19 |
20 | Welcome to React Native!
21 |
22 |
23 | To get started, edit index.ios.js
24 |
25 |
26 | Press Cmd+R to reload,{'\n'}
27 | Cmd+D or shake for dev menu
28 |
29 |
30 | );
31 | }
32 | });
33 |
34 | var styles = StyleSheet.create({
35 | container: {
36 | flex: 1,
37 | justifyContent: 'center',
38 | alignItems: 'center',
39 | backgroundColor: '#F5FCFF',
40 | },
41 | welcome: {
42 | fontSize: 20,
43 | textAlign: 'center',
44 | margin: 10,
45 | },
46 | instructions: {
47 | textAlign: 'center',
48 | color: '#333333',
49 | marginBottom: 5,
50 | },
51 | });
52 |
53 | AppRegistry.registerComponent('PureScriptSampleApp', () => PureScriptSampleApp);
54 |
--------------------------------------------------------------------------------
/.flowconfig:
--------------------------------------------------------------------------------
1 | [ignore]
2 |
3 | # We fork some components by platform.
4 | .*/*.web.js
5 | .*/*.android.js
6 |
7 | # Some modules have their own node_modules with overlap
8 | .*/node_modules/node-haste/.*
9 |
10 | # Ignore react-tools where there are overlaps, but don't ignore anything that
11 | # react-native relies on
12 | .*/node_modules/react-tools/src/React.js
13 | .*/node_modules/react-tools/src/renderers/shared/event/EventPropagators.js
14 | .*/node_modules/react-tools/src/renderers/shared/event/eventPlugins/ResponderEventPlugin.js
15 | .*/node_modules/react-tools/src/shared/vendor/core/ExecutionEnvironment.js
16 |
17 | # Ignore commoner tests
18 | .*/node_modules/commoner/test/.*
19 |
20 | # See https://github.com/facebook/flow/issues/442
21 | .*/react-tools/node_modules/commoner/lib/reader.js
22 |
23 | # Ignore jest
24 | .*/node_modules/jest-cli/.*
25 |
26 | # Ignore Website
27 | .*/website/.*
28 |
29 | [include]
30 |
31 | [libs]
32 | node_modules/react-native/Libraries/react-native/react-native-interface.js
33 |
34 | [options]
35 | module.system=haste
36 |
37 | munge_underscores=true
38 |
39 | module.name_mapper='^image![a-zA-Z0-9$_-]+$' -> 'GlobalImageStub'
40 | module.name_mapper='^[./a-zA-Z0-9$_-]+\.png$' -> 'RelativeImageStub'
41 |
42 | suppress_type=$FlowIssue
43 | suppress_type=$FlowFixMe
44 | suppress_type=$FixMe
45 |
46 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(>=0\\.\\(1[0-6]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)
47 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(>=0\\.\\(1[0-6]\\|[0-9]\\).[0-9]\\)? *\\(site=[a-z,_]*react_native[a-z,_]*\\)?)\\)? #[0-9]+
48 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixedInNextDeploy
49 |
50 | [version]
51 | 0.16.0
52 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp/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 | NSAllowsArbitraryLoads
45 |
46 |
47 |
48 |
49 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp/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 "RCTRootView.h"
13 |
14 | @implementation AppDelegate
15 |
16 | - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
17 | {
18 | NSURL *jsCodeLocation;
19 |
20 | /**
21 | * Loading JavaScript code - uncomment the one you want.
22 | *
23 | * OPTION 1
24 | * Load from development server. Start the server from the repository root:
25 | *
26 | * $ npm start
27 | *
28 | * To run on device, change `localhost` to the IP address of your computer
29 | * (you can get this by typing `ifconfig` into the terminal and selecting the
30 | * `inet` value under `en0:`) and make sure your computer and iOS device are
31 | * on the same Wi-Fi network.
32 | */
33 |
34 | jsCodeLocation = [NSURL URLWithString:@"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"];
35 |
36 | /**
37 | * OPTION 2
38 | * Load from pre-bundled file on disk. To re-generate the static bundle
39 | * from the root of your project directory, run
40 | *
41 | * $ react-native bundle --minify
42 | *
43 | * see http://facebook.github.io/react-native/docs/runningondevice.html
44 | */
45 |
46 | // jsCodeLocation = [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
47 |
48 | RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
49 | moduleName:@"PureScriptSampleApp"
50 | initialProperties:nil
51 | launchOptions:launchOptions];
52 |
53 | self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
54 | UIViewController *rootViewController = [[UIViewController alloc] init];
55 | rootViewController.view = rootView;
56 | self.window.rootViewController = rootViewController;
57 | [self.window makeKeyAndVisible];
58 | return YES;
59 | }
60 |
61 | @end
62 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleAppTests/PureScriptSampleAppTests.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 "RCTLog.h"
14 | #import "RCTRootView.h"
15 |
16 | #define TIMEOUT_SECONDS 240
17 | #define TEXT_TO_LOOK_FOR @"Welcome to React Native!"
18 |
19 | @interface PureScriptSampleAppTests : XCTestCase
20 |
21 | @end
22 |
23 | @implementation PureScriptSampleAppTests
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, 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 |
--------------------------------------------------------------------------------
/android/app/src/main/java/com/purescriptsampleapp/MainActivity.java:
--------------------------------------------------------------------------------
1 | package com.purescriptsampleapp;
2 |
3 | import android.app.Activity;
4 | import android.os.Bundle;
5 | import android.view.KeyEvent;
6 |
7 | import com.facebook.react.LifecycleState;
8 | import com.facebook.react.ReactInstanceManager;
9 | import com.facebook.react.ReactRootView;
10 | import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler;
11 | import com.facebook.react.shell.MainReactPackage;
12 | import com.facebook.soloader.SoLoader;
13 |
14 | public class MainActivity extends Activity implements DefaultHardwareBackBtnHandler {
15 |
16 | private ReactInstanceManager mReactInstanceManager;
17 | private ReactRootView mReactRootView;
18 |
19 | @Override
20 | protected void onCreate(Bundle savedInstanceState) {
21 | super.onCreate(savedInstanceState);
22 | mReactRootView = new ReactRootView(this);
23 |
24 | mReactInstanceManager = ReactInstanceManager.builder()
25 | .setApplication(getApplication())
26 | .setBundleAssetName("index.android.bundle")
27 | .setJSMainModuleName("index.android")
28 | .addPackage(new MainReactPackage())
29 | .setUseDeveloperSupport(BuildConfig.DEBUG)
30 | .setInitialLifecycleState(LifecycleState.RESUMED)
31 | .build();
32 |
33 | mReactRootView.startReactApplication(mReactInstanceManager, "PureScriptSampleApp", null);
34 |
35 | setContentView(mReactRootView);
36 | }
37 |
38 | @Override
39 | public boolean onKeyUp(int keyCode, KeyEvent event) {
40 | if (keyCode == KeyEvent.KEYCODE_MENU && mReactInstanceManager != null) {
41 | mReactInstanceManager.showDevOptionsDialog();
42 | return true;
43 | }
44 | return super.onKeyUp(keyCode, event);
45 | }
46 |
47 | @Override
48 | public void onBackPressed() {
49 | if (mReactInstanceManager != null) {
50 | mReactInstanceManager.onBackPressed();
51 | } else {
52 | super.onBackPressed();
53 | }
54 | }
55 |
56 | @Override
57 | public void invokeDefaultOnBackPressed() {
58 | super.onBackPressed();
59 | }
60 |
61 | @Override
62 | protected void onPause() {
63 | super.onPause();
64 |
65 | if (mReactInstanceManager != null) {
66 | mReactInstanceManager.onPause();
67 | }
68 | }
69 |
70 | @Override
71 | protected void onResume() {
72 | super.onResume();
73 |
74 | if (mReactInstanceManager != null) {
75 | mReactInstanceManager.onResume(this);
76 | }
77 | }
78 | }
79 |
--------------------------------------------------------------------------------
/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 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp/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/PureScriptSampleApp.xcodeproj/xcshareddata/xcschemes/PureScriptSampleApp.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
29 |
35 |
36 |
37 |
38 |
39 |
44 |
45 |
47 |
53 |
54 |
55 |
56 |
57 |
63 |
64 |
65 |
66 |
75 |
77 |
83 |
84 |
85 |
86 |
87 |
88 |
94 |
96 |
102 |
103 |
104 |
105 |
107 |
108 |
111 |
112 |
113 |
--------------------------------------------------------------------------------
/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 |
--------------------------------------------------------------------------------
/src/Main.purs:
--------------------------------------------------------------------------------
1 | module Main where
2 |
3 | import Prelude
4 | import Control.Monad.Eff (Eff())
5 | import Control.Monad.Eff.Console (CONSOLE(), log)
6 | import Data.Array ((:), concat, filter, findIndex, length, modifyAt, range, sortBy, zip)
7 | import Data.Generic (Generic, gEq)
8 | import Data.Int (fromString)
9 | import Data.Maybe (Maybe(), fromMaybe)
10 | import Data.Tuple (fst, snd)
11 | import React (ReactElement(), ReactThis(), Render(), createClass, readState, spec, transformState, writeState)
12 | import ReactNative (registerComponent)
13 | import ReactNative.Components (ListViewDataSource(), cloneWithRows, listView, listViewDataSource, text, textInput, touchableHighlight, view)
14 |
15 | import qualified ReactNative.Props as N
16 | import qualified React.DOM.Props as P
17 | import qualified ReactNative.Styles as S
18 |
19 | data AppState = AppState {
20 | nextId :: Int,
21 | newTodo :: String,
22 | todos :: Array Todo,
23 | dataSource :: ListViewDataSource,
24 | filter :: Filter
25 | }
26 |
27 | data Todo = Todo Int String Boolean
28 |
29 | derive instance genericTodo :: Generic Todo
30 |
31 | instance eqTodo :: Eq Todo where
32 | eq = gEq
33 |
34 | getTodoId :: Todo -> Int
35 | getTodoId (Todo id _ _) = id
36 |
37 | data Filter = All | Active | Completed
38 | instance eqFilter :: Eq Filter where
39 | eq All All = true
40 | eq Active Active = true
41 | eq Completed Completed = true
42 | eq _ _ = false
43 |
44 | initialTodos = [
45 | Todo 1 "Hack PureScript into Android (using JS mostly)" true,
46 | Todo 2 "Display text field using purescript-react" true,
47 | Todo 3 "Port SampleApp to PureScript" true,
48 | Todo 4 "Pull out bindings as separate library" true,
49 | Todo 5 "Add support for ListViews" true,
50 | Todo 6 "Display list of todo items" true,
51 | Todo 7 "Fix wrapping of long todos" true,
52 | Todo 8 "Display completed items as completed" true,
53 | Todo 9 "Make items highlightable" true,
54 | Todo 10 "Make items completable" true,
55 | Todo 12 "Add new todos" true,
56 | Todo 13 "Clear completed todos" true,
57 | Todo 14 "Filter All/Active/Completed todos" true,
58 | Todo 15 "Delete todos" false,
59 | Todo 16 "Clean up styling" false,
60 | Todo 17 "Re-focus input field when adding todo" false
61 | ]
62 |
63 | appStyleSheet :: S.StyleSheet
64 | appStyleSheet = S.createStyleSheet [
65 | S.Style "container" [
66 | S.flex 1.0,
67 | S.flexDirection S.Column,
68 | S.backgroundColor backgroundColor
69 | ],
70 | S.Style "title" [
71 | S.fontSize 50.0,
72 | S.color "rgba(175, 47, 47, 0.15)",
73 | S.textAlign S.TextAlignCenter
74 | ],
75 | S.Style "todoList" [
76 | S.flex 1.0,
77 | S.flexDirection S.Column
78 | ],
79 | S.Style "newTodoContainer" [
80 | S.fontSize 18.0,
81 | S.paddingHorizontal 10.0,
82 | S.height 56.0,
83 | S.backgroundColor todoBackgroundColor,
84 | S.textDecorationColor fontColorFaded,
85 | S.borderTopColor borderColor,
86 | S.borderTopWidth 1.0,
87 | S.borderBottomColor borderColor,
88 | S.borderBottomWidth 1.0
89 | ],
90 | S.Style "newTodo" [
91 | S.fontSize 18.0,
92 | S.paddingHorizontal 10.0,
93 | S.flex 1.0,
94 | S.backgroundColor todoBackgroundColor,
95 | S.textDecorationColor fontColorFaded
96 | ],
97 | S.Style "todo" [
98 | S.paddingHorizontal 10.0,
99 | S.paddingVertical 15.0,
100 | S.backgroundColor todoBackgroundColor
101 | ],
102 | S.Style "todoText" [
103 | S.fontSize 18.0,
104 | S.color fontColorDefault
105 | ],
106 | S.Style "todoTextCompleted" [
107 | S.color fontColorFaded
108 | ],
109 | S.Style "separator" [
110 | S.backgroundColor borderColor,
111 | S.height 1.0
112 | ],
113 | S.Style "bottomBar" [
114 | S.paddingVertical 10.0,
115 | S.paddingHorizontal 15.0,
116 | S.borderTopColor borderColor,
117 | S.borderTopWidth 1.0,
118 | S.flexDirection S.Row,
119 | S.alignItems S.AlignItemsStretch,
120 | S.backgroundColor todoBackgroundColor
121 | ],
122 | S.Style "filters" [
123 | S.flexDirection S.Row,
124 | S.alignItems S.AlignItemsStretch,
125 | S.flex 1.0
126 | ],
127 | S.Style "filter" [
128 | S.marginHorizontal 5.0,
129 | S.padding 5.0
130 | ],
131 | S.Style "activeFilter" [
132 | S.borderWidth 1.0,
133 | S.borderColor "rgba(175, 47, 47, 0.2)",
134 | S.borderStyle S.BorderSolid,
135 | S.borderRadius 3.0
136 | ],
137 | S.Style "clearCompleted" [
138 | S.margin 5.0
139 | ]
140 | ]
141 |
142 | fontColorDefault = "#000000"
143 | fontColorFaded = "#D9D9D9"
144 | backgroundColor = "#F5F5F5"
145 | todoBackgroundColor = "#FFFFFF"
146 | borderColor = "#EDEDED"
147 |
148 | style :: String -> P.Props
149 | style key = S.style $ S.getStyleId appStyleSheet key
150 |
151 | styles :: Array String -> P.Props
152 | styles keys = S.styles $ map (S.getStyleId appStyleSheet) keys
153 |
154 |
155 | toggleTodoWithId :: Int -> AppState -> AppState
156 | toggleTodoWithId id (AppState state) = fromMaybe (AppState state) $ do
157 | index <- findIndex (((==) id) <<< getTodoId) state.todos
158 | newTodos <- modifyAt (unsafeLog2 index) toggleTodo state.todos
159 | return $ updateDataSource $ AppState $ state { todos = newTodos }
160 |
161 | toggleTodo :: Todo -> Todo
162 | toggleTodo (Todo id s complete) = Todo id s (not complete)
163 |
164 | addTodo :: AppState -> AppState
165 | addTodo (AppState state) = updateDataSource $ AppState $ state { nextId = state.nextId + 1, newTodo = "", todos = newTodos }
166 | where newTodos = (Todo state.nextId state.newTodo false) : state.todos
167 |
168 | updateNewTodo :: String -> AppState -> AppState
169 | updateNewTodo newTodo (AppState state) = AppState state { newTodo = newTodo }
170 |
171 | clearCompleted :: AppState -> AppState
172 | clearCompleted (AppState state) = updateDataSource $ AppState $ state { todos = newTodos }
173 | where newTodos = filter notCompleted state.todos
174 | notCompleted (Todo _ _ completed) = not completed
175 |
176 | filterTodos :: Filter -> AppState -> AppState
177 | filterTodos filter (AppState state) = updateDataSource $ AppState $ state { filter = filter }
178 |
179 |
180 | todoOrdering :: Todo -> Todo -> Ordering
181 | todoOrdering (Todo _ _ true) (Todo _ _ false) = GT
182 | todoOrdering (Todo _ _ false) (Todo _ _ true) = LT
183 | todoOrdering (Todo id1 _ _) (Todo id2 _ _) = if id1 < id2 then LT else GT
184 |
185 | updateDataSource :: AppState -> AppState
186 | updateDataSource (AppState state) = AppState $ state { dataSource = cloneWithRows state.dataSource filteredTodos }
187 | where filteredTodos = sortBy todoOrdering $ filter (applyFilter state.filter) state.todos
188 |
189 | applyFilter :: Filter -> Todo -> Boolean
190 | applyFilter All _ = true
191 | applyFilter Active (Todo _ _ c) = not c
192 | applyFilter Completed (Todo _ _ c) = c
193 |
194 | todoSeparator :: N.RenderSeparatorFn
195 | todoSeparator sectionId rowId adjacentHighlighted = view [style "separator"] []
196 |
197 | filterButton :: forall props. ReactThis props AppState -> Filter -> Filter -> ReactElement
198 | filterButton ctx activeFilter filter =
199 | view [styles (if activeFilter == filter then ["filter", "activeFilter"] else ["filter"])] [
200 | text [N.onPress \_ -> transformState ctx (filterTodos filter)] filterText]
201 | where filterText = case filter of
202 | All -> "All"
203 | Active -> "Active"
204 | Completed -> "Completed"
205 |
206 | todoRow ctx (Todo id item completed) _ _ _ = touchableHighlight [N.onPress onPressFn] $ rowView
207 | where
208 | rowView = view [style "todo"] [todoText]
209 | todoText = text [styles (if completed then ["todoText", "todoTextCompleted"] else ["todoText"])] item
210 | onPressFn _ = transformState ctx (toggleTodoWithId (unsafeLog2 id))
211 |
212 | render :: forall props eff. Render props AppState eff
213 | render ctx = do
214 | (AppState state) <- readState ctx
215 | return $
216 | view [(style "container")] [
217 | text [style "title"] "todos",
218 | view [style "newTodoContainer"] [
219 | textInput [style "newTodo",
220 | P.value state.newTodo,
221 | P.placeholder "What needs to be done?",
222 | N.onChangeText \newTodo -> transformState ctx (updateNewTodo newTodo),
223 | N.onSubmitEditing \_ -> transformState ctx addTodo]],
224 | listView [style "todoList",
225 | N.renderRow $ todoRow ctx,
226 | N.renderSeparator todoSeparator,
227 | N.renderHeader $ view [style "separator"] [],
228 | N.dataSource state.dataSource],
229 | view [style "bottomBar"] [
230 | view [style "filters"] [
231 | filterButton ctx state.filter All,
232 | filterButton ctx state.filter Active,
233 | filterButton ctx state.filter Completed],
234 | text [style "clearCompleted",
235 | N.onPress \_ -> transformState ctx clearCompleted]
236 | "Clear completed"]]
237 |
238 | foreign import unsafeLog :: forall p e. p -> Eff e Unit
239 | foreign import unsafeLog2 :: forall p. p -> p
240 |
241 | main :: Eff (console :: CONSOLE) Unit
242 | main = do
243 | log "Running app"
244 | registerComponent "PureScriptSampleApp" component
245 | where
246 | component = createClass $ spec initialState render
247 | dataSource = listViewDataSource initialTodos
248 | initialState = updateDataSource $ AppState { nextId: 18,
249 | newTodo: "",
250 | todos: initialTodos,
251 | dataSource: dataSource,
252 | filter: All }
253 |
--------------------------------------------------------------------------------
/ios/PureScriptSampleApp.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 46;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 008F07F31AC5B25A0029DE68 /* main.jsbundle in Resources */ = {isa = PBXBuildFile; fileRef = 008F07F21AC5B25A0029DE68 /* main.jsbundle */; };
11 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */; };
12 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */; };
13 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */; };
14 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */; };
15 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */; };
16 | 00E356F31AD99517003FC87E /* PureScriptSampleAppTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* PureScriptSampleAppTests.m */; };
17 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 78C398B91ACF4ADC00677621 /* libRCTLinking.a */; };
18 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */; };
19 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */; };
20 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
21 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; };
22 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
23 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
24 | 146834051AC3E58100842450 /* libReact.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 146834041AC3E56700842450 /* libReact.a */; };
25 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 832341B51AAA6A8300B99B32 /* libRCTText.a */; };
26 | /* End PBXBuildFile section */
27 |
28 | /* Begin PBXContainerItemProxy section */
29 | 00C302AB1ABCB8CE00DB3ED1 /* PBXContainerItemProxy */ = {
30 | isa = PBXContainerItemProxy;
31 | containerPortal = 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */;
32 | proxyType = 2;
33 | remoteGlobalIDString = 134814201AA4EA6300B7C361;
34 | remoteInfo = RCTActionSheet;
35 | };
36 | 00C302B91ABCB90400DB3ED1 /* PBXContainerItemProxy */ = {
37 | isa = PBXContainerItemProxy;
38 | containerPortal = 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */;
39 | proxyType = 2;
40 | remoteGlobalIDString = 134814201AA4EA6300B7C361;
41 | remoteInfo = RCTGeolocation;
42 | };
43 | 00C302BF1ABCB91800DB3ED1 /* PBXContainerItemProxy */ = {
44 | isa = PBXContainerItemProxy;
45 | containerPortal = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */;
46 | proxyType = 2;
47 | remoteGlobalIDString = 58B5115D1A9E6B3D00147676;
48 | remoteInfo = RCTImage;
49 | };
50 | 00C302DB1ABCB9D200DB3ED1 /* PBXContainerItemProxy */ = {
51 | isa = PBXContainerItemProxy;
52 | containerPortal = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */;
53 | proxyType = 2;
54 | remoteGlobalIDString = 58B511DB1A9E6C8500147676;
55 | remoteInfo = RCTNetwork;
56 | };
57 | 00C302E31ABCB9EE00DB3ED1 /* PBXContainerItemProxy */ = {
58 | isa = PBXContainerItemProxy;
59 | containerPortal = 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */;
60 | proxyType = 2;
61 | remoteGlobalIDString = 832C81801AAF6DEF007FA2F7;
62 | remoteInfo = RCTVibration;
63 | };
64 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = {
65 | isa = PBXContainerItemProxy;
66 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
67 | proxyType = 1;
68 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A;
69 | remoteInfo = PureScriptSampleApp;
70 | };
71 | 139105C01AF99BAD00B5F7CC /* PBXContainerItemProxy */ = {
72 | isa = PBXContainerItemProxy;
73 | containerPortal = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */;
74 | proxyType = 2;
75 | remoteGlobalIDString = 134814201AA4EA6300B7C361;
76 | remoteInfo = RCTSettings;
77 | };
78 | 139FDEF31B06529B00C62182 /* PBXContainerItemProxy */ = {
79 | isa = PBXContainerItemProxy;
80 | containerPortal = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */;
81 | proxyType = 2;
82 | remoteGlobalIDString = 3C86DF461ADF2C930047B81A;
83 | remoteInfo = RCTWebSocket;
84 | };
85 | 146834031AC3E56700842450 /* PBXContainerItemProxy */ = {
86 | isa = PBXContainerItemProxy;
87 | containerPortal = 146833FF1AC3E56700842450 /* React.xcodeproj */;
88 | proxyType = 2;
89 | remoteGlobalIDString = 83CBBA2E1A601D0E00E9B192;
90 | remoteInfo = React;
91 | };
92 | 78C398B81ACF4ADC00677621 /* PBXContainerItemProxy */ = {
93 | isa = PBXContainerItemProxy;
94 | containerPortal = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */;
95 | proxyType = 2;
96 | remoteGlobalIDString = 134814201AA4EA6300B7C361;
97 | remoteInfo = RCTLinking;
98 | };
99 | 832341B41AAA6A8300B99B32 /* PBXContainerItemProxy */ = {
100 | isa = PBXContainerItemProxy;
101 | containerPortal = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */;
102 | proxyType = 2;
103 | remoteGlobalIDString = 58B5119B1A9E6C1200147676;
104 | remoteInfo = RCTText;
105 | };
106 | /* End PBXContainerItemProxy section */
107 |
108 | /* Begin PBXFileReference section */
109 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = main.jsbundle; path = main.jsbundle; sourceTree = ""; };
110 | 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTActionSheet.xcodeproj; path = ../node_modules/react-native/Libraries/ActionSheetIOS/RCTActionSheet.xcodeproj; sourceTree = ""; };
111 | 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTGeolocation.xcodeproj; path = ../node_modules/react-native/Libraries/Geolocation/RCTGeolocation.xcodeproj; sourceTree = ""; };
112 | 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTImage.xcodeproj; path = ../node_modules/react-native/Libraries/Image/RCTImage.xcodeproj; sourceTree = ""; };
113 | 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTNetwork.xcodeproj; path = ../node_modules/react-native/Libraries/Network/RCTNetwork.xcodeproj; sourceTree = ""; };
114 | 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTVibration.xcodeproj; path = ../node_modules/react-native/Libraries/Vibration/RCTVibration.xcodeproj; sourceTree = ""; };
115 | 00E356EE1AD99517003FC87E /* PureScriptSampleAppTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = PureScriptSampleAppTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
116 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
117 | 00E356F21AD99517003FC87E /* PureScriptSampleAppTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = PureScriptSampleAppTests.m; sourceTree = ""; };
118 | 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTSettings.xcodeproj; path = ../node_modules/react-native/Libraries/Settings/RCTSettings.xcodeproj; sourceTree = ""; };
119 | 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTWebSocket.xcodeproj; path = ../node_modules/react-native/Libraries/WebSocket/RCTWebSocket.xcodeproj; sourceTree = ""; };
120 | 13B07F961A680F5B00A75B9A /* PureScriptSampleApp.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = PureScriptSampleApp.app; sourceTree = BUILT_PRODUCTS_DIR; };
121 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = PureScriptSampleApp/AppDelegate.h; sourceTree = ""; };
122 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = PureScriptSampleApp/AppDelegate.m; sourceTree = ""; };
123 | 13B07FB21A68108700A75B9A /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; };
124 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = PureScriptSampleApp/Images.xcassets; sourceTree = ""; };
125 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = PureScriptSampleApp/Info.plist; sourceTree = ""; };
126 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = PureScriptSampleApp/main.m; sourceTree = ""; };
127 | 146833FF1AC3E56700842450 /* React.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = React.xcodeproj; path = ../node_modules/react-native/React/React.xcodeproj; sourceTree = ""; };
128 | 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTLinking.xcodeproj; path = ../node_modules/react-native/Libraries/LinkingIOS/RCTLinking.xcodeproj; sourceTree = ""; };
129 | 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = RCTText.xcodeproj; path = ../node_modules/react-native/Libraries/Text/RCTText.xcodeproj; sourceTree = ""; };
130 | /* End PBXFileReference section */
131 |
132 | /* Begin PBXFrameworksBuildPhase section */
133 | 00E356EB1AD99517003FC87E /* Frameworks */ = {
134 | isa = PBXFrameworksBuildPhase;
135 | buildActionMask = 2147483647;
136 | files = (
137 | );
138 | runOnlyForDeploymentPostprocessing = 0;
139 | };
140 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
141 | isa = PBXFrameworksBuildPhase;
142 | buildActionMask = 2147483647;
143 | files = (
144 | 146834051AC3E58100842450 /* libReact.a in Frameworks */,
145 | 00C302E51ABCBA2D00DB3ED1 /* libRCTActionSheet.a in Frameworks */,
146 | 00C302E71ABCBA2D00DB3ED1 /* libRCTGeolocation.a in Frameworks */,
147 | 00C302E81ABCBA2D00DB3ED1 /* libRCTImage.a in Frameworks */,
148 | 133E29F31AD74F7200F7D852 /* libRCTLinking.a in Frameworks */,
149 | 00C302E91ABCBA2D00DB3ED1 /* libRCTNetwork.a in Frameworks */,
150 | 139105C61AF99C1200B5F7CC /* libRCTSettings.a in Frameworks */,
151 | 832341BD1AAA6AB300B99B32 /* libRCTText.a in Frameworks */,
152 | 00C302EA1ABCBA2D00DB3ED1 /* libRCTVibration.a in Frameworks */,
153 | 139FDEF61B0652A700C62182 /* libRCTWebSocket.a in Frameworks */,
154 | );
155 | runOnlyForDeploymentPostprocessing = 0;
156 | };
157 | /* End PBXFrameworksBuildPhase section */
158 |
159 | /* Begin PBXGroup section */
160 | 00C302A81ABCB8CE00DB3ED1 /* Products */ = {
161 | isa = PBXGroup;
162 | children = (
163 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */,
164 | );
165 | name = Products;
166 | sourceTree = "";
167 | };
168 | 00C302B61ABCB90400DB3ED1 /* Products */ = {
169 | isa = PBXGroup;
170 | children = (
171 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */,
172 | );
173 | name = Products;
174 | sourceTree = "";
175 | };
176 | 00C302BC1ABCB91800DB3ED1 /* Products */ = {
177 | isa = PBXGroup;
178 | children = (
179 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */,
180 | );
181 | name = Products;
182 | sourceTree = "";
183 | };
184 | 00C302D41ABCB9D200DB3ED1 /* Products */ = {
185 | isa = PBXGroup;
186 | children = (
187 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */,
188 | );
189 | name = Products;
190 | sourceTree = "";
191 | };
192 | 00C302E01ABCB9EE00DB3ED1 /* Products */ = {
193 | isa = PBXGroup;
194 | children = (
195 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */,
196 | );
197 | name = Products;
198 | sourceTree = "";
199 | };
200 | 00E356EF1AD99517003FC87E /* PureScriptSampleAppTests */ = {
201 | isa = PBXGroup;
202 | children = (
203 | 00E356F21AD99517003FC87E /* PureScriptSampleAppTests.m */,
204 | 00E356F01AD99517003FC87E /* Supporting Files */,
205 | );
206 | path = PureScriptSampleAppTests;
207 | sourceTree = "";
208 | };
209 | 00E356F01AD99517003FC87E /* Supporting Files */ = {
210 | isa = PBXGroup;
211 | children = (
212 | 00E356F11AD99517003FC87E /* Info.plist */,
213 | );
214 | name = "Supporting Files";
215 | sourceTree = "";
216 | };
217 | 139105B71AF99BAD00B5F7CC /* Products */ = {
218 | isa = PBXGroup;
219 | children = (
220 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */,
221 | );
222 | name = Products;
223 | sourceTree = "";
224 | };
225 | 139FDEE71B06529A00C62182 /* Products */ = {
226 | isa = PBXGroup;
227 | children = (
228 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */,
229 | );
230 | name = Products;
231 | sourceTree = "";
232 | };
233 | 13B07FAE1A68108700A75B9A /* PureScriptSampleApp */ = {
234 | isa = PBXGroup;
235 | children = (
236 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
237 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
238 | 13B07FB01A68108700A75B9A /* AppDelegate.m */,
239 | 13B07FB51A68108700A75B9A /* Images.xcassets */,
240 | 13B07FB61A68108700A75B9A /* Info.plist */,
241 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */,
242 | 13B07FB71A68108700A75B9A /* main.m */,
243 | );
244 | name = PureScriptSampleApp;
245 | sourceTree = "";
246 | };
247 | 146834001AC3E56700842450 /* Products */ = {
248 | isa = PBXGroup;
249 | children = (
250 | 146834041AC3E56700842450 /* libReact.a */,
251 | );
252 | name = Products;
253 | sourceTree = "";
254 | };
255 | 78C398B11ACF4ADC00677621 /* Products */ = {
256 | isa = PBXGroup;
257 | children = (
258 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */,
259 | );
260 | name = Products;
261 | sourceTree = "";
262 | };
263 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
264 | isa = PBXGroup;
265 | children = (
266 | 146833FF1AC3E56700842450 /* React.xcodeproj */,
267 | 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */,
268 | 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */,
269 | 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */,
270 | 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */,
271 | 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */,
272 | 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */,
273 | 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */,
274 | 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */,
275 | 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */,
276 | );
277 | name = Libraries;
278 | sourceTree = "";
279 | };
280 | 832341B11AAA6A8300B99B32 /* Products */ = {
281 | isa = PBXGroup;
282 | children = (
283 | 832341B51AAA6A8300B99B32 /* libRCTText.a */,
284 | );
285 | name = Products;
286 | sourceTree = "";
287 | };
288 | 83CBB9F61A601CBA00E9B192 = {
289 | isa = PBXGroup;
290 | children = (
291 | 13B07FAE1A68108700A75B9A /* PureScriptSampleApp */,
292 | 832341AE1AAA6A7D00B99B32 /* Libraries */,
293 | 00E356EF1AD99517003FC87E /* PureScriptSampleAppTests */,
294 | 83CBBA001A601CBA00E9B192 /* Products */,
295 | );
296 | indentWidth = 2;
297 | sourceTree = "";
298 | tabWidth = 2;
299 | };
300 | 83CBBA001A601CBA00E9B192 /* Products */ = {
301 | isa = PBXGroup;
302 | children = (
303 | 13B07F961A680F5B00A75B9A /* PureScriptSampleApp.app */,
304 | 00E356EE1AD99517003FC87E /* PureScriptSampleAppTests.xctest */,
305 | );
306 | name = Products;
307 | sourceTree = "";
308 | };
309 | /* End PBXGroup section */
310 |
311 | /* Begin PBXNativeTarget section */
312 | 00E356ED1AD99517003FC87E /* PureScriptSampleAppTests */ = {
313 | isa = PBXNativeTarget;
314 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "PureScriptSampleAppTests" */;
315 | buildPhases = (
316 | 00E356EA1AD99517003FC87E /* Sources */,
317 | 00E356EB1AD99517003FC87E /* Frameworks */,
318 | 00E356EC1AD99517003FC87E /* Resources */,
319 | );
320 | buildRules = (
321 | );
322 | dependencies = (
323 | 00E356F51AD99517003FC87E /* PBXTargetDependency */,
324 | );
325 | name = PureScriptSampleAppTests;
326 | productName = PureScriptSampleAppTests;
327 | productReference = 00E356EE1AD99517003FC87E /* PureScriptSampleAppTests.xctest */;
328 | productType = "com.apple.product-type.bundle.unit-test";
329 | };
330 | 13B07F861A680F5B00A75B9A /* PureScriptSampleApp */ = {
331 | isa = PBXNativeTarget;
332 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "PureScriptSampleApp" */;
333 | buildPhases = (
334 | 13B07F871A680F5B00A75B9A /* Sources */,
335 | 13B07F8C1A680F5B00A75B9A /* Frameworks */,
336 | 13B07F8E1A680F5B00A75B9A /* Resources */,
337 | );
338 | buildRules = (
339 | );
340 | dependencies = (
341 | );
342 | name = PureScriptSampleApp;
343 | productName = "Hello World";
344 | productReference = 13B07F961A680F5B00A75B9A /* PureScriptSampleApp.app */;
345 | productType = "com.apple.product-type.application";
346 | };
347 | /* End PBXNativeTarget section */
348 |
349 | /* Begin PBXProject section */
350 | 83CBB9F71A601CBA00E9B192 /* Project object */ = {
351 | isa = PBXProject;
352 | attributes = {
353 | LastUpgradeCheck = 0610;
354 | ORGANIZATIONNAME = Facebook;
355 | TargetAttributes = {
356 | 00E356ED1AD99517003FC87E = {
357 | CreatedOnToolsVersion = 6.2;
358 | TestTargetID = 13B07F861A680F5B00A75B9A;
359 | };
360 | };
361 | };
362 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "PureScriptSampleApp" */;
363 | compatibilityVersion = "Xcode 3.2";
364 | developmentRegion = English;
365 | hasScannedForEncodings = 0;
366 | knownRegions = (
367 | en,
368 | Base,
369 | );
370 | mainGroup = 83CBB9F61A601CBA00E9B192;
371 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
372 | projectDirPath = "";
373 | projectReferences = (
374 | {
375 | ProductGroup = 00C302A81ABCB8CE00DB3ED1 /* Products */;
376 | ProjectRef = 00C302A71ABCB8CE00DB3ED1 /* RCTActionSheet.xcodeproj */;
377 | },
378 | {
379 | ProductGroup = 00C302B61ABCB90400DB3ED1 /* Products */;
380 | ProjectRef = 00C302B51ABCB90400DB3ED1 /* RCTGeolocation.xcodeproj */;
381 | },
382 | {
383 | ProductGroup = 00C302BC1ABCB91800DB3ED1 /* Products */;
384 | ProjectRef = 00C302BB1ABCB91800DB3ED1 /* RCTImage.xcodeproj */;
385 | },
386 | {
387 | ProductGroup = 78C398B11ACF4ADC00677621 /* Products */;
388 | ProjectRef = 78C398B01ACF4ADC00677621 /* RCTLinking.xcodeproj */;
389 | },
390 | {
391 | ProductGroup = 00C302D41ABCB9D200DB3ED1 /* Products */;
392 | ProjectRef = 00C302D31ABCB9D200DB3ED1 /* RCTNetwork.xcodeproj */;
393 | },
394 | {
395 | ProductGroup = 139105B71AF99BAD00B5F7CC /* Products */;
396 | ProjectRef = 139105B61AF99BAD00B5F7CC /* RCTSettings.xcodeproj */;
397 | },
398 | {
399 | ProductGroup = 832341B11AAA6A8300B99B32 /* Products */;
400 | ProjectRef = 832341B01AAA6A8300B99B32 /* RCTText.xcodeproj */;
401 | },
402 | {
403 | ProductGroup = 00C302E01ABCB9EE00DB3ED1 /* Products */;
404 | ProjectRef = 00C302DF1ABCB9EE00DB3ED1 /* RCTVibration.xcodeproj */;
405 | },
406 | {
407 | ProductGroup = 139FDEE71B06529A00C62182 /* Products */;
408 | ProjectRef = 139FDEE61B06529A00C62182 /* RCTWebSocket.xcodeproj */;
409 | },
410 | {
411 | ProductGroup = 146834001AC3E56700842450 /* Products */;
412 | ProjectRef = 146833FF1AC3E56700842450 /* React.xcodeproj */;
413 | },
414 | );
415 | projectRoot = "";
416 | targets = (
417 | 13B07F861A680F5B00A75B9A /* PureScriptSampleApp */,
418 | 00E356ED1AD99517003FC87E /* PureScriptSampleAppTests */,
419 | );
420 | };
421 | /* End PBXProject section */
422 |
423 | /* Begin PBXReferenceProxy section */
424 | 00C302AC1ABCB8CE00DB3ED1 /* libRCTActionSheet.a */ = {
425 | isa = PBXReferenceProxy;
426 | fileType = archive.ar;
427 | path = libRCTActionSheet.a;
428 | remoteRef = 00C302AB1ABCB8CE00DB3ED1 /* PBXContainerItemProxy */;
429 | sourceTree = BUILT_PRODUCTS_DIR;
430 | };
431 | 00C302BA1ABCB90400DB3ED1 /* libRCTGeolocation.a */ = {
432 | isa = PBXReferenceProxy;
433 | fileType = archive.ar;
434 | path = libRCTGeolocation.a;
435 | remoteRef = 00C302B91ABCB90400DB3ED1 /* PBXContainerItemProxy */;
436 | sourceTree = BUILT_PRODUCTS_DIR;
437 | };
438 | 00C302C01ABCB91800DB3ED1 /* libRCTImage.a */ = {
439 | isa = PBXReferenceProxy;
440 | fileType = archive.ar;
441 | path = libRCTImage.a;
442 | remoteRef = 00C302BF1ABCB91800DB3ED1 /* PBXContainerItemProxy */;
443 | sourceTree = BUILT_PRODUCTS_DIR;
444 | };
445 | 00C302DC1ABCB9D200DB3ED1 /* libRCTNetwork.a */ = {
446 | isa = PBXReferenceProxy;
447 | fileType = archive.ar;
448 | path = libRCTNetwork.a;
449 | remoteRef = 00C302DB1ABCB9D200DB3ED1 /* PBXContainerItemProxy */;
450 | sourceTree = BUILT_PRODUCTS_DIR;
451 | };
452 | 00C302E41ABCB9EE00DB3ED1 /* libRCTVibration.a */ = {
453 | isa = PBXReferenceProxy;
454 | fileType = archive.ar;
455 | path = libRCTVibration.a;
456 | remoteRef = 00C302E31ABCB9EE00DB3ED1 /* PBXContainerItemProxy */;
457 | sourceTree = BUILT_PRODUCTS_DIR;
458 | };
459 | 139105C11AF99BAD00B5F7CC /* libRCTSettings.a */ = {
460 | isa = PBXReferenceProxy;
461 | fileType = archive.ar;
462 | path = libRCTSettings.a;
463 | remoteRef = 139105C01AF99BAD00B5F7CC /* PBXContainerItemProxy */;
464 | sourceTree = BUILT_PRODUCTS_DIR;
465 | };
466 | 139FDEF41B06529B00C62182 /* libRCTWebSocket.a */ = {
467 | isa = PBXReferenceProxy;
468 | fileType = archive.ar;
469 | path = libRCTWebSocket.a;
470 | remoteRef = 139FDEF31B06529B00C62182 /* PBXContainerItemProxy */;
471 | sourceTree = BUILT_PRODUCTS_DIR;
472 | };
473 | 146834041AC3E56700842450 /* libReact.a */ = {
474 | isa = PBXReferenceProxy;
475 | fileType = archive.ar;
476 | path = libReact.a;
477 | remoteRef = 146834031AC3E56700842450 /* PBXContainerItemProxy */;
478 | sourceTree = BUILT_PRODUCTS_DIR;
479 | };
480 | 78C398B91ACF4ADC00677621 /* libRCTLinking.a */ = {
481 | isa = PBXReferenceProxy;
482 | fileType = archive.ar;
483 | path = libRCTLinking.a;
484 | remoteRef = 78C398B81ACF4ADC00677621 /* PBXContainerItemProxy */;
485 | sourceTree = BUILT_PRODUCTS_DIR;
486 | };
487 | 832341B51AAA6A8300B99B32 /* libRCTText.a */ = {
488 | isa = PBXReferenceProxy;
489 | fileType = archive.ar;
490 | path = libRCTText.a;
491 | remoteRef = 832341B41AAA6A8300B99B32 /* PBXContainerItemProxy */;
492 | sourceTree = BUILT_PRODUCTS_DIR;
493 | };
494 | /* End PBXReferenceProxy section */
495 |
496 | /* Begin PBXResourcesBuildPhase section */
497 | 00E356EC1AD99517003FC87E /* Resources */ = {
498 | isa = PBXResourcesBuildPhase;
499 | buildActionMask = 2147483647;
500 | files = (
501 | );
502 | runOnlyForDeploymentPostprocessing = 0;
503 | };
504 | 13B07F8E1A680F5B00A75B9A /* Resources */ = {
505 | isa = PBXResourcesBuildPhase;
506 | buildActionMask = 2147483647;
507 | files = (
508 | 008F07F31AC5B25A0029DE68 /* main.jsbundle in Resources */,
509 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
510 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */,
511 | );
512 | runOnlyForDeploymentPostprocessing = 0;
513 | };
514 | /* End PBXResourcesBuildPhase section */
515 |
516 | /* Begin PBXSourcesBuildPhase section */
517 | 00E356EA1AD99517003FC87E /* Sources */ = {
518 | isa = PBXSourcesBuildPhase;
519 | buildActionMask = 2147483647;
520 | files = (
521 | 00E356F31AD99517003FC87E /* PureScriptSampleAppTests.m in Sources */,
522 | );
523 | runOnlyForDeploymentPostprocessing = 0;
524 | };
525 | 13B07F871A680F5B00A75B9A /* Sources */ = {
526 | isa = PBXSourcesBuildPhase;
527 | buildActionMask = 2147483647;
528 | files = (
529 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
530 | 13B07FC11A68108700A75B9A /* main.m in Sources */,
531 | );
532 | runOnlyForDeploymentPostprocessing = 0;
533 | };
534 | /* End PBXSourcesBuildPhase section */
535 |
536 | /* Begin PBXTargetDependency section */
537 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = {
538 | isa = PBXTargetDependency;
539 | target = 13B07F861A680F5B00A75B9A /* PureScriptSampleApp */;
540 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */;
541 | };
542 | /* End PBXTargetDependency section */
543 |
544 | /* Begin PBXVariantGroup section */
545 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = {
546 | isa = PBXVariantGroup;
547 | children = (
548 | 13B07FB21A68108700A75B9A /* Base */,
549 | );
550 | name = LaunchScreen.xib;
551 | path = PureScriptSampleApp;
552 | sourceTree = "";
553 | };
554 | /* End PBXVariantGroup section */
555 |
556 | /* Begin XCBuildConfiguration section */
557 | 00E356F61AD99517003FC87E /* Debug */ = {
558 | isa = XCBuildConfiguration;
559 | buildSettings = {
560 | BUNDLE_LOADER = "$(TEST_HOST)";
561 | FRAMEWORK_SEARCH_PATHS = (
562 | "$(SDKROOT)/Developer/Library/Frameworks",
563 | "$(inherited)",
564 | );
565 | GCC_PREPROCESSOR_DEFINITIONS = (
566 | "DEBUG=1",
567 | "$(inherited)",
568 | );
569 | INFOPLIST_FILE = PureScriptSampleAppTests/Info.plist;
570 | IPHONEOS_DEPLOYMENT_TARGET = 8.2;
571 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
572 | PRODUCT_NAME = "$(TARGET_NAME)";
573 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/PureScriptSampleApp.app/PureScriptSampleApp";
574 | };
575 | name = Debug;
576 | };
577 | 00E356F71AD99517003FC87E /* Release */ = {
578 | isa = XCBuildConfiguration;
579 | buildSettings = {
580 | BUNDLE_LOADER = "$(TEST_HOST)";
581 | COPY_PHASE_STRIP = NO;
582 | FRAMEWORK_SEARCH_PATHS = (
583 | "$(SDKROOT)/Developer/Library/Frameworks",
584 | "$(inherited)",
585 | );
586 | INFOPLIST_FILE = PureScriptSampleAppTests/Info.plist;
587 | IPHONEOS_DEPLOYMENT_TARGET = 8.2;
588 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
589 | PRODUCT_NAME = "$(TARGET_NAME)";
590 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/PureScriptSampleApp.app/PureScriptSampleApp";
591 | };
592 | name = Release;
593 | };
594 | 13B07F941A680F5B00A75B9A /* Debug */ = {
595 | isa = XCBuildConfiguration;
596 | buildSettings = {
597 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
598 | DEAD_CODE_STRIPPING = NO;
599 | HEADER_SEARCH_PATHS = (
600 | "$(inherited)",
601 | /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include,
602 | "$(SRCROOT)/../node_modules/react-native/React/**",
603 | );
604 | INFOPLIST_FILE = "PureScriptSampleApp/Info.plist";
605 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
606 | OTHER_LDFLAGS = "-ObjC";
607 | PRODUCT_NAME = PureScriptSampleApp;
608 | };
609 | name = Debug;
610 | };
611 | 13B07F951A680F5B00A75B9A /* Release */ = {
612 | isa = XCBuildConfiguration;
613 | buildSettings = {
614 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
615 | HEADER_SEARCH_PATHS = (
616 | "$(inherited)",
617 | /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include,
618 | "$(SRCROOT)/../node_modules/react-native/React/**",
619 | );
620 | INFOPLIST_FILE = "PureScriptSampleApp/Info.plist";
621 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
622 | OTHER_LDFLAGS = "-ObjC";
623 | PRODUCT_NAME = PureScriptSampleApp;
624 | };
625 | name = Release;
626 | };
627 | 83CBBA201A601CBA00E9B192 /* Debug */ = {
628 | isa = XCBuildConfiguration;
629 | buildSettings = {
630 | ALWAYS_SEARCH_USER_PATHS = NO;
631 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
632 | CLANG_CXX_LIBRARY = "libc++";
633 | CLANG_ENABLE_MODULES = YES;
634 | CLANG_ENABLE_OBJC_ARC = YES;
635 | CLANG_WARN_BOOL_CONVERSION = YES;
636 | CLANG_WARN_CONSTANT_CONVERSION = YES;
637 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
638 | CLANG_WARN_EMPTY_BODY = YES;
639 | CLANG_WARN_ENUM_CONVERSION = YES;
640 | CLANG_WARN_INT_CONVERSION = YES;
641 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
642 | CLANG_WARN_UNREACHABLE_CODE = YES;
643 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
644 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
645 | COPY_PHASE_STRIP = NO;
646 | ENABLE_STRICT_OBJC_MSGSEND = YES;
647 | GCC_C_LANGUAGE_STANDARD = gnu99;
648 | GCC_DYNAMIC_NO_PIC = NO;
649 | GCC_OPTIMIZATION_LEVEL = 0;
650 | GCC_PREPROCESSOR_DEFINITIONS = (
651 | "DEBUG=1",
652 | "$(inherited)",
653 | );
654 | GCC_SYMBOLS_PRIVATE_EXTERN = NO;
655 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
656 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
657 | GCC_WARN_UNDECLARED_SELECTOR = YES;
658 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
659 | GCC_WARN_UNUSED_FUNCTION = YES;
660 | GCC_WARN_UNUSED_VARIABLE = YES;
661 | HEADER_SEARCH_PATHS = (
662 | "$(inherited)",
663 | /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include,
664 | "$(SRCROOT)/../node_modules/react-native/React/**",
665 | );
666 | IPHONEOS_DEPLOYMENT_TARGET = 7.0;
667 | MTL_ENABLE_DEBUG_INFO = YES;
668 | ONLY_ACTIVE_ARCH = YES;
669 | SDKROOT = iphoneos;
670 | };
671 | name = Debug;
672 | };
673 | 83CBBA211A601CBA00E9B192 /* Release */ = {
674 | isa = XCBuildConfiguration;
675 | buildSettings = {
676 | ALWAYS_SEARCH_USER_PATHS = NO;
677 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
678 | CLANG_CXX_LIBRARY = "libc++";
679 | CLANG_ENABLE_MODULES = YES;
680 | CLANG_ENABLE_OBJC_ARC = YES;
681 | CLANG_WARN_BOOL_CONVERSION = YES;
682 | CLANG_WARN_CONSTANT_CONVERSION = YES;
683 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
684 | CLANG_WARN_EMPTY_BODY = YES;
685 | CLANG_WARN_ENUM_CONVERSION = YES;
686 | CLANG_WARN_INT_CONVERSION = YES;
687 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
688 | CLANG_WARN_UNREACHABLE_CODE = YES;
689 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
690 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
691 | COPY_PHASE_STRIP = YES;
692 | ENABLE_NS_ASSERTIONS = NO;
693 | ENABLE_STRICT_OBJC_MSGSEND = YES;
694 | GCC_C_LANGUAGE_STANDARD = gnu99;
695 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
696 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
697 | GCC_WARN_UNDECLARED_SELECTOR = YES;
698 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
699 | GCC_WARN_UNUSED_FUNCTION = YES;
700 | GCC_WARN_UNUSED_VARIABLE = YES;
701 | HEADER_SEARCH_PATHS = (
702 | "$(inherited)",
703 | /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/include,
704 | "$(SRCROOT)/../node_modules/react-native/React/**",
705 | );
706 | IPHONEOS_DEPLOYMENT_TARGET = 7.0;
707 | MTL_ENABLE_DEBUG_INFO = NO;
708 | SDKROOT = iphoneos;
709 | VALIDATE_PRODUCT = YES;
710 | };
711 | name = Release;
712 | };
713 | /* End XCBuildConfiguration section */
714 |
715 | /* Begin XCConfigurationList section */
716 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "PureScriptSampleAppTests" */ = {
717 | isa = XCConfigurationList;
718 | buildConfigurations = (
719 | 00E356F61AD99517003FC87E /* Debug */,
720 | 00E356F71AD99517003FC87E /* Release */,
721 | );
722 | defaultConfigurationIsVisible = 0;
723 | defaultConfigurationName = Release;
724 | };
725 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "PureScriptSampleApp" */ = {
726 | isa = XCConfigurationList;
727 | buildConfigurations = (
728 | 13B07F941A680F5B00A75B9A /* Debug */,
729 | 13B07F951A680F5B00A75B9A /* Release */,
730 | );
731 | defaultConfigurationIsVisible = 0;
732 | defaultConfigurationName = Release;
733 | };
734 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "PureScriptSampleApp" */ = {
735 | isa = XCConfigurationList;
736 | buildConfigurations = (
737 | 83CBBA201A601CBA00E9B192 /* Debug */,
738 | 83CBBA211A601CBA00E9B192 /* Release */,
739 | );
740 | defaultConfigurationIsVisible = 0;
741 | defaultConfigurationName = Release;
742 | };
743 | /* End XCConfigurationList section */
744 | };
745 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
746 | }
747 |
--------------------------------------------------------------------------------