├── .gitignore
├── LICENSE
├── README.md
├── demoApp
├── .buckconfig
├── .eslintrc.js
├── .flowconfig
├── .gitattributes
├── .gitignore
├── .prettierrc.js
├── .watchmanconfig
├── App.js
├── __tests__
│ └── App-test.js
├── android
│ ├── app
│ │ ├── BUCK
│ │ ├── build.gradle
│ │ ├── build_defs.bzl
│ │ ├── proguard-rules.pro
│ │ └── src
│ │ │ ├── debug
│ │ │ └── AndroidManifest.xml
│ │ │ └── main
│ │ │ ├── AndroidManifest.xml
│ │ │ ├── java
│ │ │ └── com
│ │ │ │ └── demoapp
│ │ │ │ ├── MainActivity.java
│ │ │ │ └── MainApplication.java
│ │ │ └── res
│ │ │ ├── mipmap-hdpi
│ │ │ ├── ic_launcher.png
│ │ │ └── ic_launcher_round.png
│ │ │ ├── mipmap-mdpi
│ │ │ ├── ic_launcher.png
│ │ │ └── ic_launcher_round.png
│ │ │ ├── mipmap-xhdpi
│ │ │ ├── ic_launcher.png
│ │ │ └── ic_launcher_round.png
│ │ │ ├── mipmap-xxhdpi
│ │ │ ├── ic_launcher.png
│ │ │ └── ic_launcher_round.png
│ │ │ ├── mipmap-xxxhdpi
│ │ │ ├── ic_launcher.png
│ │ │ └── ic_launcher_round.png
│ │ │ └── values
│ │ │ ├── strings.xml
│ │ │ └── styles.xml
│ ├── build.gradle
│ ├── gradle.properties
│ ├── gradle
│ │ └── wrapper
│ │ │ ├── gradle-wrapper.jar
│ │ │ └── gradle-wrapper.properties
│ ├── gradlew
│ ├── gradlew.bat
│ └── settings.gradle
├── app.json
├── babel.config.js
├── components
│ └── FormInput.js
├── index.js
├── ios
│ ├── Podfile
│ ├── Podfile.lock
│ ├── demoApp-tvOS
│ │ └── Info.plist
│ ├── demoApp-tvOSTests
│ │ └── Info.plist
│ ├── demoApp.xcodeproj
│ │ ├── project.pbxproj
│ │ └── xcshareddata
│ │ │ └── xcschemes
│ │ │ ├── demoApp-tvOS.xcscheme
│ │ │ └── demoApp.xcscheme
│ ├── demoApp.xcworkspace
│ │ └── contents.xcworkspacedata
│ ├── demoApp
│ │ ├── AppDelegate.h
│ │ ├── AppDelegate.m
│ │ ├── Base.lproj
│ │ │ └── LaunchScreen.xib
│ │ ├── Images.xcassets
│ │ │ ├── AppIcon.appiconset
│ │ │ │ └── Contents.json
│ │ │ └── Contents.json
│ │ ├── Info.plist
│ │ └── main.m
│ └── demoAppTests
│ │ ├── Info.plist
│ │ └── demoAppTests.m
├── metro.config.js
├── package.json
├── react-native-form-helpers
│ ├── dictionary.js
│ └── index.js
└── yarn.lock
├── package.json
├── src
└── index.js
└── yarn.lock
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) LawnStarter
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # react-native-form-helpers
2 | [](https://badge.fury.io/js/react-native-form-helpers)
3 |
4 | **Step 1:**
5 | `npm install react-native-form-helpers`
6 |
7 | **Step 2:**
8 | Create a dictionary file ([example dictionary](demoApp/react-native-form-helpers/dictionary.js))
9 |
10 | **Step 3:**
11 |
12 | ```js
13 | import RNFormHelpers from "./react-native-form-helpers";
14 | import { validationDictionary } from "./dictionary.js"; // location of your dictionary file
15 |
16 | export const validationService = RNFormHelpers({
17 | dictionary: validationDictionary
18 | });
19 | ```
20 |
21 | **Step 4:**
22 | Import into your form and utilize the built-in methods. See below tutorial or [sample app](demoApp/App.js) for more details.
23 |
24 | ## Tutorial Series:
25 |
26 | https://medium.com/lawnstarter-engineering/how-to-create-custom-forms-with-validation-and-scroll-to-invalid-logic-in-react-native-part-one-43e5f7cdf807
27 |
28 | https://medium.com/lawnstarter-engineering/how-to-create-custom-forms-with-validation-and-scroll-to-invalid-logic-in-react-native-part-two-9834849d4d78
29 |
30 | https://medium.com/lawnstarter-engineering/how-to-create-custom-forms-with-validation-and-scroll-to-invalid-logic-in-react-native-f6a4cc049095
31 |
--------------------------------------------------------------------------------
/demoApp/.buckconfig:
--------------------------------------------------------------------------------
1 |
2 | [android]
3 | target = Google Inc.:Google APIs:23
4 |
5 | [maven_repositories]
6 | central = https://repo1.maven.org/maven2
7 |
--------------------------------------------------------------------------------
/demoApp/.eslintrc.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | root: true,
3 | extends: '@react-native-community',
4 | };
5 |
--------------------------------------------------------------------------------
/demoApp/.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 | node_modules/react-native/Libraries/react-native/React.js
15 |
16 | ; Ignore polyfills
17 | node_modules/react-native/Libraries/polyfills/.*
18 |
19 | ; These should not be required directly
20 | ; require from fbjs/lib instead: require('fbjs/lib/warning')
21 | node_modules/warning/.*
22 |
23 | ; Flow doesn't support platforms
24 | .*/Libraries/Utilities/HMRLoadingView.js
25 |
26 | [untyped]
27 | .*/node_modules/@react-native-community/cli/.*/.*
28 |
29 | [include]
30 |
31 | [libs]
32 | node_modules/react-native/Libraries/react-native/react-native-interface.js
33 | node_modules/react-native/flow/
34 |
35 | [options]
36 | emoji=true
37 |
38 | esproposal.optional_chaining=enable
39 | esproposal.nullish_coalescing=enable
40 |
41 | module.file_ext=.js
42 | module.file_ext=.json
43 | module.file_ext=.ios.js
44 |
45 | module.system=haste
46 | module.system.haste.use_name_reducers=true
47 | # get basename
48 | module.system.haste.name_reducers='^.*/\([a-zA-Z0-9$_.-]+\.js\(\.flow\)?\)$' -> '\1'
49 | # strip .js or .js.flow suffix
50 | module.system.haste.name_reducers='^\(.*\)\.js\(\.flow\)?$' -> '\1'
51 | # strip .ios suffix
52 | module.system.haste.name_reducers='^\(.*\)\.ios$' -> '\1'
53 | module.system.haste.name_reducers='^\(.*\)\.android$' -> '\1'
54 | module.system.haste.name_reducers='^\(.*\)\.native$' -> '\1'
55 | module.system.haste.paths.blacklist=.*/__tests__/.*
56 | module.system.haste.paths.blacklist=.*/__mocks__/.*
57 | module.system.haste.paths.whitelist=/node_modules/react-native/Libraries/.*
58 | module.system.haste.paths.whitelist=/node_modules/react-native/RNTester/.*
59 | module.system.haste.paths.whitelist=/node_modules/react-native/IntegrationTests/.*
60 | module.system.haste.paths.blacklist=/node_modules/react-native/Libraries/react-native/react-native-implementation.js
61 | module.system.haste.paths.blacklist=/node_modules/react-native/Libraries/Animated/src/polyfills/.*
62 |
63 | munge_underscores=true
64 |
65 | 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'
66 |
67 | suppress_type=$FlowIssue
68 | suppress_type=$FlowFixMe
69 | suppress_type=$FlowFixMeProps
70 | suppress_type=$FlowFixMeState
71 |
72 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\)
73 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\)?:? #[0-9]+
74 | suppress_comment=\\(.\\|\n\\)*\\$FlowExpectedError
75 |
76 | [lints]
77 | sketchy-null-number=warn
78 | sketchy-null-mixed=warn
79 | sketchy-number=warn
80 | untyped-type-import=warn
81 | nonstrict-import=warn
82 | deprecated-type=warn
83 | unsafe-getters-setters=warn
84 | inexact-spread=warn
85 | unnecessary-invariant=warn
86 | signature-verification-failure=warn
87 | deprecated-utility=error
88 |
89 | [strict]
90 | deprecated-type
91 | nonstrict-import
92 | sketchy-null
93 | unclear-type
94 | unsafe-getters-setters
95 | untyped-import
96 | untyped-type-import
97 |
98 | [version]
99 | ^0.98.0
100 |
--------------------------------------------------------------------------------
/demoApp/.gitattributes:
--------------------------------------------------------------------------------
1 | *.pbxproj -text
2 |
--------------------------------------------------------------------------------
/demoApp/.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://docs.fastlane.tools/best-practices/source-control/
50 |
51 | */fastlane/report.xml
52 | */fastlane/Preview.html
53 | */fastlane/screenshots
54 |
55 | # Bundle artifact
56 | *.jsbundle
57 |
58 | # CocoaPods
59 | /ios/Pods/
60 |
--------------------------------------------------------------------------------
/demoApp/.prettierrc.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | bracketSpacing: false,
3 | jsxBracketSameLine: true,
4 | singleQuote: true,
5 | trailingComma: 'all',
6 | };
7 |
--------------------------------------------------------------------------------
/demoApp/.watchmanconfig:
--------------------------------------------------------------------------------
1 | {}
--------------------------------------------------------------------------------
/demoApp/App.js:
--------------------------------------------------------------------------------
1 | import React, {Component, Fragment} from 'react';
2 | import {
3 | Button,
4 | View,
5 | StyleSheet,
6 | Text,
7 | ScrollView,
8 | KeyboardAvoidingView,
9 | Switch,
10 | } from 'react-native';
11 | import {validationService} from './index';
12 | import FormInput from './components/FormInput';
13 |
14 | export default class App extends Component {
15 | constructor(props) {
16 | super(props);
17 | this.state = {
18 | inputs: {
19 | first_name: {
20 | type: 'generic',
21 | value: '',
22 | },
23 | last_name: {
24 | type: 'generic',
25 | value: '',
26 | },
27 | birthday_month: {
28 | type: 'month',
29 | value: '',
30 | },
31 | birthday_day: {
32 | type: 'day',
33 | value: '',
34 | },
35 | birthday_year: {
36 | type: 'year',
37 | value: '',
38 | },
39 | state: {
40 | type: 'state',
41 | value: '',
42 | },
43 | zip: {
44 | type: 'zip',
45 | value: '',
46 | },
47 | tos: {
48 | type: 'bool',
49 | value: false,
50 | },
51 | },
52 | };
53 |
54 | this.onInputChange = validationService.onInputChange.bind(this);
55 | this.getFormValidation = validationService.getFormValidation.bind(this);
56 | this.setInputPosition = validationService.setInputPosition.bind(this);
57 | this.submit = this.submit.bind(this);
58 |
59 | this.scrollView = React.createRef();
60 | }
61 |
62 | submit() {
63 | const firstInvalidCoordinate = this.getFormValidation();
64 |
65 | if (firstInvalidCoordinate !== null) {
66 | this.scrollView.current.scrollTo({
67 | x: 0,
68 | y: firstInvalidCoordinate,
69 | animated: true,
70 | });
71 | return;
72 | }
73 |
74 | // if we make it to this point, we can actually submit the form
75 | }
76 |
77 | renderError(id) {
78 | const {inputs} = this.state;
79 | if (inputs[id].errorLabel) {
80 | return {inputs[id].errorLabel};
81 | }
82 | return null;
83 | }
84 |
85 | render() {
86 | const {inputs} = this.state;
87 |
88 | return (
89 |
90 |
91 | {
94 | this.onInputChange({id: 'first_name', value});
95 | }}
96 | errorLabel={inputs.first_name.errorLabel}
97 | touched={inputs.first_name.touched}
98 | onLayout={({nativeEvent}) => {
99 | this.setInputPosition({
100 | ids: ['first_name'],
101 | value: nativeEvent.layout.y,
102 | });
103 | }}
104 | />
105 |
106 | {
109 | this.onInputChange({id: 'last_name', value});
110 | }}
111 | errorLabel={inputs.last_name.errorLabel}
112 | touched={inputs.last_name.touched}
113 | onLayout={({nativeEvent}) => {
114 | this.setInputPosition({
115 | ids: ['last_name'],
116 | value: nativeEvent.layout.y,
117 | });
118 | }}
119 | />
120 |
121 |
122 | Birthday?
123 | {
125 | this.setInputPosition({
126 | ids: ['birthday_month', 'birthday_day'],
127 | value: nativeEvent.layout.y,
128 | });
129 | }}
130 | style={styles.split}>
131 |
132 | {
134 | this.onInputChange({id: 'birthday_month', value});
135 | }}
136 | errorLabel={inputs.birthday_month.errorLabel}
137 | touched={inputs.birthday_month.touched}
138 | placeholder="Month"
139 | keyboardType="number-pad"
140 | />
141 |
142 |
143 | {
145 | this.onInputChange({id: 'birthday_day', value});
146 | }}
147 | errorLabel={inputs.birthday_day.errorLabel}
148 | touched={inputs.birthday_day.touched}
149 | placeholder="Day"
150 | keyboardType="number-pad"
151 | />
152 |
153 |
154 | {
156 | this.onInputChange({id: 'birthday_year', value});
157 | }}
158 | errorLabel={inputs.birthday_year.errorLabel}
159 | touched={inputs.birthday_year.touched}
160 | placeholder="Year"
161 | keyboardType="number-pad"
162 | />
163 |
164 |
165 | {
168 | this.onInputChange({id: 'state', value});
169 | }}
170 | errorLabel={inputs.state.errorLabel}
171 | touched={inputs.state.touched}
172 | onLayout={({nativeEvent}) => {
173 | this.setInputPosition({
174 | ids: ['state'],
175 | value: nativeEvent.layout.y,
176 | });
177 | }}
178 | autoCapitalize="characters"
179 | maxLength={2}
180 | />
181 |
182 | {
185 | this.onInputChange({id: 'zip', value});
186 | }}
187 | errorLabel={inputs.zip.errorLabel}
188 | touched={inputs.zip.touched}
189 | onLayout={({nativeEvent}) => {
190 | this.setInputPosition({
191 | ids: ['zip'],
192 | value: nativeEvent.layout.y,
193 | });
194 | }}
195 | maxLength={5}
196 | keyboardType="number-pad"
197 | />
198 |
199 | {
201 | this.setInputPosition({
202 | ids: ['tos'],
203 | value: nativeEvent.layout.y,
204 | });
205 | }}>
206 |
212 | {
215 | this.onInputChange({id: 'tos', value});
216 | }}
217 | />
218 | Do you agree to the TOS?
219 |
220 | {this.renderError('tos')}
221 |
222 |
223 |
224 |
225 |
226 |
227 |
228 | );
229 | }
230 | }
231 |
232 | const styles = StyleSheet.create({
233 | container: {
234 | flex: 1,
235 | padding: 8,
236 | paddingTop: 50,
237 | paddingBottom: 10,
238 | },
239 | split: {
240 | flexDirection: 'row',
241 | },
242 | button: {
243 | flex: 0,
244 | justifyContent: 'flex-end',
245 | },
246 | error: {
247 | position: 'absolute',
248 | bottom: 0,
249 | color: 'red',
250 | fontSize: 12,
251 | },
252 | });
253 |
--------------------------------------------------------------------------------
/demoApp/__tests__/App-test.js:
--------------------------------------------------------------------------------
1 | /**
2 | * @format
3 | */
4 |
5 | import 'react-native';
6 | import React from 'react';
7 | import App from '../App';
8 |
9 | // Note: test renderer must be required after react-native.
10 | import renderer from 'react-test-renderer';
11 |
12 | it('renders correctly', () => {
13 | renderer.create();
14 | });
15 |
--------------------------------------------------------------------------------
/demoApp/android/app/BUCK:
--------------------------------------------------------------------------------
1 | # To learn about Buck see [Docs](https://buckbuild.com/).
2 | # To run your application with Buck:
3 | # - install Buck
4 | # - `npm start` - to start the packager
5 | # - `cd android`
6 | # - `keytool -genkey -v -keystore keystores/debug.keystore -storepass android -alias androiddebugkey -keypass android -dname "CN=Android Debug,O=Android,C=US"`
7 | # - `./gradlew :app:copyDownloadableDepsToLibs` - make all Gradle compile dependencies available to Buck
8 | # - `buck install -r android/app` - compile, install and run application
9 | #
10 |
11 | load(":build_defs.bzl", "create_aar_targets", "create_jar_targets")
12 |
13 | lib_deps = []
14 |
15 | create_aar_targets(glob(["libs/*.aar"]))
16 |
17 | create_jar_targets(glob(["libs/*.jar"]))
18 |
19 | android_library(
20 | name = "all-libs",
21 | exported_deps = lib_deps,
22 | )
23 |
24 | android_library(
25 | name = "app-code",
26 | srcs = glob([
27 | "src/main/java/**/*.java",
28 | ]),
29 | deps = [
30 | ":all-libs",
31 | ":build_config",
32 | ":res",
33 | ],
34 | )
35 |
36 | android_build_config(
37 | name = "build_config",
38 | package = "com.demoapp",
39 | )
40 |
41 | android_resource(
42 | name = "res",
43 | package = "com.demoapp",
44 | res = "src/main/res",
45 | )
46 |
47 | android_binary(
48 | name = "app",
49 | keystore = "//android/keystores:debug",
50 | manifest = "src/main/AndroidManifest.xml",
51 | package_type = "debug",
52 | deps = [
53 | ":app-code",
54 | ],
55 | )
56 |
--------------------------------------------------------------------------------
/demoApp/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 | * // https://facebook.github.io/react-native/docs/performance#enable-the-ram-format
22 | * bundleCommand: "ram-bundle",
23 | *
24 | * // whether to bundle JS and assets in debug mode
25 | * bundleInDebug: false,
26 | *
27 | * // whether to bundle JS and assets in release mode
28 | * bundleInRelease: true,
29 | *
30 | * // whether to bundle JS and assets in another build variant (if configured).
31 | * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
32 | * // The configuration property can be in the following formats
33 | * // 'bundleIn${productFlavor}${buildType}'
34 | * // 'bundleIn${buildType}'
35 | * // bundleInFreeDebug: true,
36 | * // bundleInPaidRelease: true,
37 | * // bundleInBeta: true,
38 | *
39 | * // whether to disable dev mode in custom build variants (by default only disabled in release)
40 | * // for example: to disable dev mode in the staging build type (if configured)
41 | * devDisabledInStaging: true,
42 | * // The configuration property can be in the following formats
43 | * // 'devDisabledIn${productFlavor}${buildType}'
44 | * // 'devDisabledIn${buildType}'
45 | *
46 | * // the root of your project, i.e. where "package.json" lives
47 | * root: "../../",
48 | *
49 | * // where to put the JS bundle asset in debug mode
50 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
51 | *
52 | * // where to put the JS bundle asset in release mode
53 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
54 | *
55 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
56 | * // require('./image.png')), in debug mode
57 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
58 | *
59 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
60 | * // require('./image.png')), in release mode
61 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
62 | *
63 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
64 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
65 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle
66 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
67 | * // for example, you might want to remove it from here.
68 | * inputExcludes: ["android/**", "ios/**"],
69 | *
70 | * // override which node gets called and with what additional arguments
71 | * nodeExecutableAndArgs: ["node"],
72 | *
73 | * // supply additional arguments to the packager
74 | * extraPackagerArgs: []
75 | * ]
76 | */
77 |
78 | project.ext.react = [
79 | entryFile: "index.js",
80 | enableHermes: false, // clean and rebuild if changing
81 | ]
82 |
83 | apply from: "../../node_modules/react-native/react.gradle"
84 |
85 | /**
86 | * Set this to true to create two separate APKs instead of one:
87 | * - An APK that only works on ARM devices
88 | * - An APK that only works on x86 devices
89 | * The advantage is the size of the APK is reduced by about 4MB.
90 | * Upload all the APKs to the Play Store and people will download
91 | * the correct one based on the CPU architecture of their device.
92 | */
93 | def enableSeparateBuildPerCPUArchitecture = false
94 |
95 | /**
96 | * Run Proguard to shrink the Java bytecode in release builds.
97 | */
98 | def enableProguardInReleaseBuilds = false
99 |
100 | /**
101 | * The preferred build flavor of JavaScriptCore.
102 | *
103 | * For example, to use the international variant, you can use:
104 | * `def jscFlavor = 'org.webkit:android-jsc-intl:+'`
105 | *
106 | * The international variant includes ICU i18n library and necessary data
107 | * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that
108 | * give correct results when using with locales other than en-US. Note that
109 | * this variant is about 6MiB larger per architecture than default.
110 | */
111 | def jscFlavor = 'org.webkit:android-jsc:+'
112 |
113 | /**
114 | * Whether to enable the Hermes VM.
115 | *
116 | * This should be set on project.ext.react and mirrored here. If it is not set
117 | * on project.ext.react, JavaScript will not be compiled to Hermes Bytecode
118 | * and the benefits of using Hermes will therefore be sharply reduced.
119 | */
120 | def enableHermes = project.ext.react.get("enableHermes", false);
121 |
122 | android {
123 | compileSdkVersion rootProject.ext.compileSdkVersion
124 |
125 | compileOptions {
126 | sourceCompatibility JavaVersion.VERSION_1_8
127 | targetCompatibility JavaVersion.VERSION_1_8
128 | }
129 |
130 | defaultConfig {
131 | applicationId "com.demoapp"
132 | minSdkVersion rootProject.ext.minSdkVersion
133 | targetSdkVersion rootProject.ext.targetSdkVersion
134 | versionCode 1
135 | versionName "1.0"
136 | }
137 | splits {
138 | abi {
139 | reset()
140 | enable enableSeparateBuildPerCPUArchitecture
141 | universalApk false // If true, also generate a universal APK
142 | include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
143 | }
144 | }
145 | signingConfigs {
146 | debug {
147 | storeFile file('debug.keystore')
148 | storePassword 'android'
149 | keyAlias 'androiddebugkey'
150 | keyPassword 'android'
151 | }
152 | }
153 | buildTypes {
154 | debug {
155 | signingConfig signingConfigs.debug
156 | }
157 | release {
158 | // Caution! In production, you need to generate your own keystore file.
159 | // see https://facebook.github.io/react-native/docs/signed-apk-android.
160 | signingConfig signingConfigs.debug
161 | minifyEnabled enableProguardInReleaseBuilds
162 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
163 | }
164 | }
165 | // applicationVariants are e.g. debug, release
166 | applicationVariants.all { variant ->
167 | variant.outputs.each { output ->
168 | // For each separate APK per architecture, set a unique version code as described here:
169 | // https://developer.android.com/studio/build/configure-apk-splits.html
170 | def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
171 | def abi = output.getFilter(OutputFile.ABI)
172 | if (abi != null) { // null for the universal-debug, universal-release variants
173 | output.versionCodeOverride =
174 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
175 | }
176 |
177 | }
178 | }
179 |
180 | packagingOptions {
181 | pickFirst '**/armeabi-v7a/libc++_shared.so'
182 | pickFirst '**/x86/libc++_shared.so'
183 | pickFirst '**/arm64-v8a/libc++_shared.so'
184 | pickFirst '**/x86_64/libc++_shared.so'
185 | pickFirst '**/x86/libjsc.so'
186 | pickFirst '**/armeabi-v7a/libjsc.so'
187 | }
188 | }
189 |
190 | dependencies {
191 | implementation fileTree(dir: "libs", include: ["*.jar"])
192 | implementation "com.facebook.react:react-native:+" // From node_modules
193 |
194 | if (enableHermes) {
195 | def hermesPath = "../../node_modules/hermesvm/android/";
196 | debugImplementation files(hermesPath + "hermes-debug.aar")
197 | releaseImplementation files(hermesPath + "hermes-release.aar")
198 | } else {
199 | implementation jscFlavor
200 | }
201 | }
202 |
203 | // Run this once to be able to run the application with BUCK
204 | // puts all compile dependencies into folder libs for BUCK to use
205 | task copyDownloadableDepsToLibs(type: Copy) {
206 | from configurations.compile
207 | into 'libs'
208 | }
209 |
210 | apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
211 |
--------------------------------------------------------------------------------
/demoApp/android/app/build_defs.bzl:
--------------------------------------------------------------------------------
1 | """Helper definitions to glob .aar and .jar targets"""
2 |
3 | def create_aar_targets(aarfiles):
4 | for aarfile in aarfiles:
5 | name = "aars__" + aarfile[aarfile.rindex("/") + 1:aarfile.rindex(".aar")]
6 | lib_deps.append(":" + name)
7 | android_prebuilt_aar(
8 | name = name,
9 | aar = aarfile,
10 | )
11 |
12 | def create_jar_targets(jarfiles):
13 | for jarfile in jarfiles:
14 | name = "jars__" + jarfile[jarfile.rindex("/") + 1:jarfile.rindex(".jar")]
15 | lib_deps.append(":" + name)
16 | prebuilt_jar(
17 | name = name,
18 | binary_jar = jarfile,
19 | )
20 |
--------------------------------------------------------------------------------
/demoApp/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 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/debug/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
4 |
5 |
6 |
7 |
8 |
9 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
3 |
4 |
5 |
6 |
13 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/java/com/demoapp/MainActivity.java:
--------------------------------------------------------------------------------
1 | package com.demoapp;
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 "demoApp";
14 | }
15 | }
16 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/java/com/demoapp/MainApplication.java:
--------------------------------------------------------------------------------
1 | package com.demoapp;
2 |
3 | import android.app.Application;
4 | import android.util.Log;
5 |
6 | import com.facebook.react.PackageList;
7 | import com.facebook.hermes.reactexecutor.HermesExecutorFactory;
8 | import com.facebook.react.bridge.JavaScriptExecutorFactory;
9 | import com.facebook.react.ReactApplication;
10 | import com.facebook.react.ReactNativeHost;
11 | import com.facebook.react.ReactPackage;
12 | import com.facebook.soloader.SoLoader;
13 |
14 | import java.util.List;
15 |
16 | public class MainApplication extends Application implements ReactApplication {
17 |
18 | private final ReactNativeHost mReactNativeHost = new ReactNativeHost(this) {
19 | @Override
20 | public boolean getUseDeveloperSupport() {
21 | return BuildConfig.DEBUG;
22 | }
23 |
24 | @Override
25 | protected List getPackages() {
26 | @SuppressWarnings("UnnecessaryLocalVariable")
27 | List packages = new PackageList(this).getPackages();
28 | // Packages that cannot be autolinked yet can be added manually here, for example:
29 | // packages.add(new MyReactNativePackage());
30 | return packages;
31 | }
32 |
33 | @Override
34 | protected String getJSMainModuleName() {
35 | return "index";
36 | }
37 | };
38 |
39 | @Override
40 | public ReactNativeHost getReactNativeHost() {
41 | return mReactNativeHost;
42 | }
43 |
44 | @Override
45 | public void onCreate() {
46 | super.onCreate();
47 | SoLoader.init(this, /* native exopackage */ false);
48 | }
49 | }
50 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 | demoApp
3 |
4 |
--------------------------------------------------------------------------------
/demoApp/android/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
8 |
9 |
10 |
--------------------------------------------------------------------------------
/demoApp/android/build.gradle:
--------------------------------------------------------------------------------
1 | // Top-level build file where you can add configuration options common to all sub-projects/modules.
2 |
3 | buildscript {
4 | ext {
5 | buildToolsVersion = "28.0.3"
6 | minSdkVersion = 16
7 | compileSdkVersion = 28
8 | targetSdkVersion = 28
9 | supportLibVersion = "28.0.0"
10 | }
11 | repositories {
12 | google()
13 | jcenter()
14 | }
15 | dependencies {
16 | classpath("com.android.tools.build:gradle:3.4.1")
17 |
18 | // NOTE: Do not place your application dependencies here; they belong
19 | // in the individual module build.gradle files
20 | }
21 | }
22 |
23 | allprojects {
24 | repositories {
25 | mavenLocal()
26 | maven {
27 | // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm
28 | url("$rootDir/../node_modules/react-native/android")
29 | }
30 | maven {
31 | // Android JSC is installed from npm
32 | url("$rootDir/../node_modules/jsc-android/dist")
33 | }
34 |
35 | google()
36 | jcenter()
37 | }
38 | }
39 |
--------------------------------------------------------------------------------
/demoApp/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.useAndroidX=true
21 | android.enableJetifier=true
22 |
--------------------------------------------------------------------------------
/demoApp/android/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/lawnstarter/react-native-form-helpers/fe51d02e8ace0520e0a32a532e677a93101ea29a/demoApp/android/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/demoApp/android/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | distributionBase=GRADLE_USER_HOME
2 | distributionPath=wrapper/dists
3 | distributionUrl=https\://services.gradle.org/distributions/gradle-5.4.1-all.zip
4 | zipStoreBase=GRADLE_USER_HOME
5 | zipStorePath=wrapper/dists
6 |
--------------------------------------------------------------------------------
/demoApp/android/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env sh
2 |
3 | #
4 | # Copyright 2015 the original author or authors.
5 | #
6 | # Licensed under the Apache License, Version 2.0 (the "License");
7 | # you may not use this file except in compliance with the License.
8 | # You may obtain a copy of the License at
9 | #
10 | # http://www.apache.org/licenses/LICENSE-2.0
11 | #
12 | # Unless required by applicable law or agreed to in writing, software
13 | # distributed under the License is distributed on an "AS IS" BASIS,
14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 | # See the License for the specific language governing permissions and
16 | # limitations under the License.
17 | #
18 |
19 | ##############################################################################
20 | ##
21 | ## Gradle start up script for UN*X
22 | ##
23 | ##############################################################################
24 |
25 | # Attempt to set APP_HOME
26 | # Resolve links: $0 may be a link
27 | PRG="$0"
28 | # Need this for relative symlinks.
29 | while [ -h "$PRG" ] ; do
30 | ls=`ls -ld "$PRG"`
31 | link=`expr "$ls" : '.*-> \(.*\)$'`
32 | if expr "$link" : '/.*' > /dev/null; then
33 | PRG="$link"
34 | else
35 | PRG=`dirname "$PRG"`"/$link"
36 | fi
37 | done
38 | SAVED="`pwd`"
39 | cd "`dirname \"$PRG\"`/" >/dev/null
40 | APP_HOME="`pwd -P`"
41 | cd "$SAVED" >/dev/null
42 |
43 | APP_NAME="Gradle"
44 | APP_BASE_NAME=`basename "$0"`
45 |
46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48 |
49 | # Use the maximum available, or set MAX_FD != -1 to use that value.
50 | MAX_FD="maximum"
51 |
52 | warn () {
53 | echo "$*"
54 | }
55 |
56 | die () {
57 | echo
58 | echo "$*"
59 | echo
60 | exit 1
61 | }
62 |
63 | # OS specific support (must be 'true' or 'false').
64 | cygwin=false
65 | msys=false
66 | darwin=false
67 | nonstop=false
68 | case "`uname`" in
69 | CYGWIN* )
70 | cygwin=true
71 | ;;
72 | Darwin* )
73 | darwin=true
74 | ;;
75 | MINGW* )
76 | msys=true
77 | ;;
78 | NONSTOP* )
79 | nonstop=true
80 | ;;
81 | esac
82 |
83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84 |
85 | # Determine the Java command to use to start the JVM.
86 | if [ -n "$JAVA_HOME" ] ; then
87 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
88 | # IBM's JDK on AIX uses strange locations for the executables
89 | JAVACMD="$JAVA_HOME/jre/sh/java"
90 | else
91 | JAVACMD="$JAVA_HOME/bin/java"
92 | fi
93 | if [ ! -x "$JAVACMD" ] ; then
94 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
95 |
96 | Please set the JAVA_HOME variable in your environment to match the
97 | location of your Java installation."
98 | fi
99 | else
100 | JAVACMD="java"
101 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
102 |
103 | Please set the JAVA_HOME variable in your environment to match the
104 | location of your Java installation."
105 | fi
106 |
107 | # Increase the maximum file descriptors if we can.
108 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
109 | MAX_FD_LIMIT=`ulimit -H -n`
110 | if [ $? -eq 0 ] ; then
111 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
112 | MAX_FD="$MAX_FD_LIMIT"
113 | fi
114 | ulimit -n $MAX_FD
115 | if [ $? -ne 0 ] ; then
116 | warn "Could not set maximum file descriptor limit: $MAX_FD"
117 | fi
118 | else
119 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
120 | fi
121 | fi
122 |
123 | # For Darwin, add options to specify how the application appears in the dock
124 | if $darwin; then
125 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
126 | fi
127 |
128 | # For Cygwin, switch paths to Windows format before running java
129 | if $cygwin ; then
130 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
131 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
132 | JAVACMD=`cygpath --unix "$JAVACMD"`
133 |
134 | # We build the pattern for arguments to be converted via cygpath
135 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
136 | SEP=""
137 | for dir in $ROOTDIRSRAW ; do
138 | ROOTDIRS="$ROOTDIRS$SEP$dir"
139 | SEP="|"
140 | done
141 | OURCYGPATTERN="(^($ROOTDIRS))"
142 | # Add a user-defined pattern to the cygpath arguments
143 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
144 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
145 | fi
146 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
147 | i=0
148 | for arg in "$@" ; do
149 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
150 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
151 |
152 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
153 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
154 | else
155 | eval `echo args$i`="\"$arg\""
156 | fi
157 | i=$((i+1))
158 | done
159 | case $i in
160 | (0) set -- ;;
161 | (1) set -- "$args0" ;;
162 | (2) set -- "$args0" "$args1" ;;
163 | (3) set -- "$args0" "$args1" "$args2" ;;
164 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
165 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
166 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
167 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
168 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
169 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
170 | esac
171 | fi
172 |
173 | # Escape application args
174 | save () {
175 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
176 | echo " "
177 | }
178 | APP_ARGS=$(save "$@")
179 |
180 | # Collect all arguments for the java command, following the shell quoting and substitution rules
181 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
182 |
183 | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
184 | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
185 | cd "$(dirname "$0")"
186 | fi
187 |
188 | exec "$JAVACMD" "$@"
189 |
--------------------------------------------------------------------------------
/demoApp/android/gradlew.bat:
--------------------------------------------------------------------------------
1 | @rem
2 | @rem Copyright 2015 the original author or authors.
3 | @rem
4 | @rem Licensed under the Apache License, Version 2.0 (the "License");
5 | @rem you may not use this file except in compliance with the License.
6 | @rem You may obtain a copy of the License at
7 | @rem
8 | @rem http://www.apache.org/licenses/LICENSE-2.0
9 | @rem
10 | @rem Unless required by applicable law or agreed to in writing, software
11 | @rem distributed under the License is distributed on an "AS IS" BASIS,
12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | @rem See the License for the specific language governing permissions and
14 | @rem limitations under the License.
15 | @rem
16 |
17 | @if "%DEBUG%" == "" @echo off
18 | @rem ##########################################################################
19 | @rem
20 | @rem Gradle startup script for Windows
21 | @rem
22 | @rem ##########################################################################
23 |
24 | @rem Set local scope for the variables with windows NT shell
25 | if "%OS%"=="Windows_NT" setlocal
26 |
27 | set DIRNAME=%~dp0
28 | if "%DIRNAME%" == "" set DIRNAME=.
29 | set APP_BASE_NAME=%~n0
30 | set APP_HOME=%DIRNAME%
31 |
32 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
33 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
34 |
35 | @rem Find java.exe
36 | if defined JAVA_HOME goto findJavaFromJavaHome
37 |
38 | set JAVA_EXE=java.exe
39 | %JAVA_EXE% -version >NUL 2>&1
40 | if "%ERRORLEVEL%" == "0" goto init
41 |
42 | echo.
43 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
44 | echo.
45 | echo Please set the JAVA_HOME variable in your environment to match the
46 | echo location of your Java installation.
47 |
48 | goto fail
49 |
50 | :findJavaFromJavaHome
51 | set JAVA_HOME=%JAVA_HOME:"=%
52 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
53 |
54 | if exist "%JAVA_EXE%" goto init
55 |
56 | echo.
57 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
58 | echo.
59 | echo Please set the JAVA_HOME variable in your environment to match the
60 | echo location of your Java installation.
61 |
62 | goto fail
63 |
64 | :init
65 | @rem Get command-line arguments, handling Windows variants
66 |
67 | if not "%OS%" == "Windows_NT" goto win9xME_args
68 |
69 | :win9xME_args
70 | @rem Slurp the command line arguments.
71 | set CMD_LINE_ARGS=
72 | set _SKIP=2
73 |
74 | :win9xME_args_slurp
75 | if "x%~1" == "x" goto execute
76 |
77 | set CMD_LINE_ARGS=%*
78 |
79 | :execute
80 | @rem Setup the command line
81 |
82 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
83 |
84 | @rem Execute Gradle
85 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
86 |
87 | :end
88 | @rem End local scope for the variables with windows NT shell
89 | if "%ERRORLEVEL%"=="0" goto mainEnd
90 |
91 | :fail
92 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
93 | rem the _cmd.exe /c_ return code!
94 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
95 | exit /b 1
96 |
97 | :mainEnd
98 | if "%OS%"=="Windows_NT" endlocal
99 |
100 | :omega
101 |
--------------------------------------------------------------------------------
/demoApp/android/settings.gradle:
--------------------------------------------------------------------------------
1 | rootProject.name = 'demoApp'
2 | apply from: file("../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesSettingsGradle(settings)
3 | include ':app'
4 |
--------------------------------------------------------------------------------
/demoApp/app.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "demoApp",
3 | "displayName": "demoApp"
4 | }
--------------------------------------------------------------------------------
/demoApp/babel.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | presets: ['module:metro-react-native-babel-preset'],
3 | };
4 |
--------------------------------------------------------------------------------
/demoApp/components/FormInput.js:
--------------------------------------------------------------------------------
1 | import React, {Component, Fragment} from 'react';
2 | import {StyleSheet, Text, TextInput, View} from 'react-native';
3 |
4 | export default class FormInput extends Component {
5 | constructor(props) {
6 | super(props);
7 | this.state = {
8 | touched: false,
9 | };
10 |
11 | this.onBlur = this.onBlur.bind(this);
12 | }
13 |
14 | renderError() {
15 | const {errorLabel, touched} = this.props;
16 | if (errorLabel && (touched || this.state.touched)) {
17 | return (
18 |
19 | {errorLabel}
20 |
21 | );
22 | }
23 | return null;
24 | }
25 |
26 | onBlur() {
27 | this.setState({
28 | touched: true,
29 | });
30 | }
31 |
32 | render() {
33 | const {label} = this.props;
34 | return (
35 |
36 | {label}
37 |
38 | {this.renderError()}
39 |
40 | );
41 | }
42 | }
43 |
44 | const styles = StyleSheet.create({
45 | input: {
46 | borderWidth: 1,
47 | borderColor: 'black',
48 | padding: 10,
49 | marginBottom: 15,
50 | alignSelf: 'stretch',
51 | },
52 | error: {
53 | position: 'absolute',
54 | bottom: 0,
55 | color: 'red',
56 | fontSize: 12,
57 | },
58 | });
59 |
--------------------------------------------------------------------------------
/demoApp/index.js:
--------------------------------------------------------------------------------
1 | /**
2 | * @format
3 | */
4 |
5 | import {AppRegistry} from 'react-native';
6 | import App from './App';
7 | import {name as appName} from './app.json';
8 |
9 | import RNFormHelpers from './react-native-form-helpers';
10 | import {validationDictionary} from './react-native-form-helpers/dictionary';
11 |
12 | export const validationService = RNFormHelpers({
13 | dictionary: validationDictionary,
14 | });
15 |
16 | AppRegistry.registerComponent(appName, () => App);
17 |
--------------------------------------------------------------------------------
/demoApp/ios/Podfile:
--------------------------------------------------------------------------------
1 | platform :ios, '9.0'
2 | require_relative '../node_modules/@react-native-community/cli-platform-ios/native_modules'
3 |
4 | target 'demoApp' do
5 | # Pods for demoApp
6 | pod 'React', :path => '../node_modules/react-native/'
7 | pod 'React-Core', :path => '../node_modules/react-native/React'
8 | pod 'React-DevSupport', :path => '../node_modules/react-native/React'
9 | pod 'React-RCTActionSheet', :path => '../node_modules/react-native/Libraries/ActionSheetIOS'
10 | pod 'React-RCTAnimation', :path => '../node_modules/react-native/Libraries/NativeAnimation'
11 | pod 'React-RCTBlob', :path => '../node_modules/react-native/Libraries/Blob'
12 | pod 'React-RCTImage', :path => '../node_modules/react-native/Libraries/Image'
13 | pod 'React-RCTLinking', :path => '../node_modules/react-native/Libraries/LinkingIOS'
14 | pod 'React-RCTNetwork', :path => '../node_modules/react-native/Libraries/Network'
15 | pod 'React-RCTSettings', :path => '../node_modules/react-native/Libraries/Settings'
16 | pod 'React-RCTText', :path => '../node_modules/react-native/Libraries/Text'
17 | pod 'React-RCTVibration', :path => '../node_modules/react-native/Libraries/Vibration'
18 | pod 'React-RCTWebSocket', :path => '../node_modules/react-native/Libraries/WebSocket'
19 |
20 | pod 'React-cxxreact', :path => '../node_modules/react-native/ReactCommon/cxxreact'
21 | pod 'React-jsi', :path => '../node_modules/react-native/ReactCommon/jsi'
22 | pod 'React-jsiexecutor', :path => '../node_modules/react-native/ReactCommon/jsiexecutor'
23 | pod 'React-jsinspector', :path => '../node_modules/react-native/ReactCommon/jsinspector'
24 | pod 'yoga', :path => '../node_modules/react-native/ReactCommon/yoga'
25 |
26 | pod 'DoubleConversion', :podspec => '../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec'
27 | pod 'glog', :podspec => '../node_modules/react-native/third-party-podspecs/glog.podspec'
28 | pod 'Folly', :podspec => '../node_modules/react-native/third-party-podspecs/Folly.podspec'
29 |
30 | target 'demoAppTests' do
31 | inherit! :search_paths
32 | # Pods for testing
33 | end
34 |
35 | use_native_modules!
36 | end
37 |
38 | target 'demoApp-tvOS' do
39 | # Pods for demoApp-tvOS
40 |
41 | target 'demoApp-tvOSTests' do
42 | inherit! :search_paths
43 | # Pods for testing
44 | end
45 |
46 | end
47 |
--------------------------------------------------------------------------------
/demoApp/ios/Podfile.lock:
--------------------------------------------------------------------------------
1 | PODS:
2 | - boost-for-react-native (1.63.0)
3 | - DoubleConversion (1.1.6)
4 | - Folly (2018.10.22.00):
5 | - boost-for-react-native
6 | - DoubleConversion
7 | - Folly/Default (= 2018.10.22.00)
8 | - glog
9 | - Folly/Default (2018.10.22.00):
10 | - boost-for-react-native
11 | - DoubleConversion
12 | - glog
13 | - glog (0.3.5)
14 | - React (0.60.5):
15 | - React-Core (= 0.60.5)
16 | - React-DevSupport (= 0.60.5)
17 | - React-RCTActionSheet (= 0.60.5)
18 | - React-RCTAnimation (= 0.60.5)
19 | - React-RCTBlob (= 0.60.5)
20 | - React-RCTImage (= 0.60.5)
21 | - React-RCTLinking (= 0.60.5)
22 | - React-RCTNetwork (= 0.60.5)
23 | - React-RCTSettings (= 0.60.5)
24 | - React-RCTText (= 0.60.5)
25 | - React-RCTVibration (= 0.60.5)
26 | - React-RCTWebSocket (= 0.60.5)
27 | - React-Core (0.60.5):
28 | - Folly (= 2018.10.22.00)
29 | - React-cxxreact (= 0.60.5)
30 | - React-jsiexecutor (= 0.60.5)
31 | - yoga (= 0.60.5.React)
32 | - React-cxxreact (0.60.5):
33 | - boost-for-react-native (= 1.63.0)
34 | - DoubleConversion
35 | - Folly (= 2018.10.22.00)
36 | - glog
37 | - React-jsinspector (= 0.60.5)
38 | - React-DevSupport (0.60.5):
39 | - React-Core (= 0.60.5)
40 | - React-RCTWebSocket (= 0.60.5)
41 | - React-jsi (0.60.5):
42 | - boost-for-react-native (= 1.63.0)
43 | - DoubleConversion
44 | - Folly (= 2018.10.22.00)
45 | - glog
46 | - React-jsi/Default (= 0.60.5)
47 | - React-jsi/Default (0.60.5):
48 | - boost-for-react-native (= 1.63.0)
49 | - DoubleConversion
50 | - Folly (= 2018.10.22.00)
51 | - glog
52 | - React-jsiexecutor (0.60.5):
53 | - DoubleConversion
54 | - Folly (= 2018.10.22.00)
55 | - glog
56 | - React-cxxreact (= 0.60.5)
57 | - React-jsi (= 0.60.5)
58 | - React-jsinspector (0.60.5)
59 | - React-RCTActionSheet (0.60.5):
60 | - React-Core (= 0.60.5)
61 | - React-RCTAnimation (0.60.5):
62 | - React-Core (= 0.60.5)
63 | - React-RCTBlob (0.60.5):
64 | - React-Core (= 0.60.5)
65 | - React-RCTNetwork (= 0.60.5)
66 | - React-RCTWebSocket (= 0.60.5)
67 | - React-RCTImage (0.60.5):
68 | - React-Core (= 0.60.5)
69 | - React-RCTNetwork (= 0.60.5)
70 | - React-RCTLinking (0.60.5):
71 | - React-Core (= 0.60.5)
72 | - React-RCTNetwork (0.60.5):
73 | - React-Core (= 0.60.5)
74 | - React-RCTSettings (0.60.5):
75 | - React-Core (= 0.60.5)
76 | - React-RCTText (0.60.5):
77 | - React-Core (= 0.60.5)
78 | - React-RCTVibration (0.60.5):
79 | - React-Core (= 0.60.5)
80 | - React-RCTWebSocket (0.60.5):
81 | - React-Core (= 0.60.5)
82 | - yoga (0.60.5.React)
83 |
84 | DEPENDENCIES:
85 | - DoubleConversion (from `../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec`)
86 | - Folly (from `../node_modules/react-native/third-party-podspecs/Folly.podspec`)
87 | - glog (from `../node_modules/react-native/third-party-podspecs/glog.podspec`)
88 | - React (from `../node_modules/react-native/`)
89 | - React-Core (from `../node_modules/react-native/React`)
90 | - React-cxxreact (from `../node_modules/react-native/ReactCommon/cxxreact`)
91 | - React-DevSupport (from `../node_modules/react-native/React`)
92 | - React-jsi (from `../node_modules/react-native/ReactCommon/jsi`)
93 | - React-jsiexecutor (from `../node_modules/react-native/ReactCommon/jsiexecutor`)
94 | - React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`)
95 | - React-RCTActionSheet (from `../node_modules/react-native/Libraries/ActionSheetIOS`)
96 | - React-RCTAnimation (from `../node_modules/react-native/Libraries/NativeAnimation`)
97 | - React-RCTBlob (from `../node_modules/react-native/Libraries/Blob`)
98 | - React-RCTImage (from `../node_modules/react-native/Libraries/Image`)
99 | - React-RCTLinking (from `../node_modules/react-native/Libraries/LinkingIOS`)
100 | - React-RCTNetwork (from `../node_modules/react-native/Libraries/Network`)
101 | - React-RCTSettings (from `../node_modules/react-native/Libraries/Settings`)
102 | - React-RCTText (from `../node_modules/react-native/Libraries/Text`)
103 | - React-RCTVibration (from `../node_modules/react-native/Libraries/Vibration`)
104 | - React-RCTWebSocket (from `../node_modules/react-native/Libraries/WebSocket`)
105 | - yoga (from `../node_modules/react-native/ReactCommon/yoga`)
106 |
107 | SPEC REPOS:
108 | https://github.com/cocoapods/specs.git:
109 | - boost-for-react-native
110 |
111 | EXTERNAL SOURCES:
112 | DoubleConversion:
113 | :podspec: "../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec"
114 | Folly:
115 | :podspec: "../node_modules/react-native/third-party-podspecs/Folly.podspec"
116 | glog:
117 | :podspec: "../node_modules/react-native/third-party-podspecs/glog.podspec"
118 | React:
119 | :path: "../node_modules/react-native/"
120 | React-Core:
121 | :path: "../node_modules/react-native/React"
122 | React-cxxreact:
123 | :path: "../node_modules/react-native/ReactCommon/cxxreact"
124 | React-DevSupport:
125 | :path: "../node_modules/react-native/React"
126 | React-jsi:
127 | :path: "../node_modules/react-native/ReactCommon/jsi"
128 | React-jsiexecutor:
129 | :path: "../node_modules/react-native/ReactCommon/jsiexecutor"
130 | React-jsinspector:
131 | :path: "../node_modules/react-native/ReactCommon/jsinspector"
132 | React-RCTActionSheet:
133 | :path: "../node_modules/react-native/Libraries/ActionSheetIOS"
134 | React-RCTAnimation:
135 | :path: "../node_modules/react-native/Libraries/NativeAnimation"
136 | React-RCTBlob:
137 | :path: "../node_modules/react-native/Libraries/Blob"
138 | React-RCTImage:
139 | :path: "../node_modules/react-native/Libraries/Image"
140 | React-RCTLinking:
141 | :path: "../node_modules/react-native/Libraries/LinkingIOS"
142 | React-RCTNetwork:
143 | :path: "../node_modules/react-native/Libraries/Network"
144 | React-RCTSettings:
145 | :path: "../node_modules/react-native/Libraries/Settings"
146 | React-RCTText:
147 | :path: "../node_modules/react-native/Libraries/Text"
148 | React-RCTVibration:
149 | :path: "../node_modules/react-native/Libraries/Vibration"
150 | React-RCTWebSocket:
151 | :path: "../node_modules/react-native/Libraries/WebSocket"
152 | yoga:
153 | :path: "../node_modules/react-native/ReactCommon/yoga"
154 |
155 | SPEC CHECKSUMS:
156 | boost-for-react-native: 39c7adb57c4e60d6c5479dd8623128eb5b3f0f2c
157 | DoubleConversion: 5805e889d232975c086db112ece9ed034df7a0b2
158 | Folly: 30e7936e1c45c08d884aa59369ed951a8e68cf51
159 | glog: 1f3da668190260b06b429bb211bfbee5cd790c28
160 | React: c438ccc7e14e86d4702bb92d7e262f549ffaa995
161 | React-Core: c76495f5c14e73c0f803b89c3fa83f804da61bd6
162 | React-cxxreact: f64bc64cf4682d6ea5a064f6017da72482858682
163 | React-DevSupport: 30336bca00f72681eac995d21a31b963e7d5cfec
164 | React-jsi: 40f467ff088c811c6630acccb4aea57ea7ccb1b5
165 | React-jsiexecutor: e4b4717060a0cd8d0270323b5655a68c95432efd
166 | React-jsinspector: 044105eea064aec81adc5e4d777a8f6589e7d094
167 | React-RCTActionSheet: 08864c609d9f959abf3d51fdd93f8bc6e91f21eb
168 | React-RCTAnimation: a4547e9fac2627ded3df9d302f5558b475faf819
169 | React-RCTBlob: 62d5c263a2adb8f7a2cafd601beba18a2d99cbbb
170 | React-RCTImage: 963859de2b05d2037d1b7842cdbddc8d7f3a2f3b
171 | React-RCTLinking: 5998a7db9a6156ed112b006d01f76b2d1cc83d98
172 | React-RCTNetwork: 0b676e8194f3f893db813007d37e37e9820173a3
173 | React-RCTSettings: fdd7606f1b6050eced69fc6046d5db6768aefd57
174 | React-RCTText: 36c0532feb5521cb295ba80e7e44b70cf1c36fc7
175 | React-RCTVibration: dabb8d59bb47e1d9124b3f77bfdc1b33d42b0a74
176 | React-RCTWebSocket: 2e7f6e98fd6d2bf447d145e499c3a235cc13e350
177 | yoga: 88c514f310aff89b94a14c5fbf44b95735af0cb7
178 |
179 | PODFILE CHECKSUM: df9767fd38238d6f81dbc23cc839895c4264018c
180 |
181 | COCOAPODS: 1.5.3
182 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp-tvOS/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | $(EXECUTABLE_NAME)
9 | CFBundleIdentifier
10 | $(PRODUCT_BUNDLE_IDENTIFIER)
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 | NSAppTransportSecurity
26 |
27 | NSExceptionDomains
28 |
29 | localhost
30 |
31 | NSExceptionAllowsInsecureHTTPLoads
32 |
33 |
34 |
35 |
36 | NSLocationWhenInUseUsageDescription
37 |
38 | UILaunchStoryboardName
39 | LaunchScreen
40 | UIRequiredDeviceCapabilities
41 |
42 | armv7
43 |
44 | UISupportedInterfaceOrientations
45 |
46 | UIInterfaceOrientationPortrait
47 | UIInterfaceOrientationLandscapeLeft
48 | UIInterfaceOrientationLandscapeRight
49 |
50 | UIViewControllerBasedStatusBarAppearance
51 |
52 |
53 |
54 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp-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 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 46;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 00E356F31AD99517003FC87E /* demoAppTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* demoAppTests.m */; };
11 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
12 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; };
13 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
14 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
15 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
16 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
17 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
18 | 2DCD954D1E0B4F2C00145EB5 /* demoAppTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* demoAppTests.m */; };
19 | C9E93A301DD272D0291597A8 /* libPods-demoApp-tvOSTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 1C5C4986B9E357AD2FF8C005 /* libPods-demoApp-tvOSTests.a */; };
20 | DE7C389D21AFC7B7EC22723E /* libPods-demoAppTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5FDA0FFBECB7BB1D7ACC0297 /* libPods-demoAppTests.a */; };
21 | FB1CD28D31A40630C8501D66 /* libPods-demoApp-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = FA41D6B2A6E7CBF14B735AD7 /* libPods-demoApp-tvOS.a */; };
22 | FC56921294AF0C3315D253F4 /* libPods-demoApp.a in Frameworks */ = {isa = PBXBuildFile; fileRef = EB18472B73EB90B55151F414 /* libPods-demoApp.a */; };
23 | /* End PBXBuildFile section */
24 |
25 | /* Begin PBXContainerItemProxy section */
26 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = {
27 | isa = PBXContainerItemProxy;
28 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
29 | proxyType = 1;
30 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A;
31 | remoteInfo = demoApp;
32 | };
33 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = {
34 | isa = PBXContainerItemProxy;
35 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
36 | proxyType = 1;
37 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7;
38 | remoteInfo = "demoApp-tvOS";
39 | };
40 | /* End PBXContainerItemProxy section */
41 |
42 | /* Begin PBXFileReference section */
43 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; };
44 | 00E356EE1AD99517003FC87E /* demoAppTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = demoAppTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
45 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
46 | 00E356F21AD99517003FC87E /* demoAppTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = demoAppTests.m; sourceTree = ""; };
47 | 0757A94DC2FC107540F2B998 /* Pods-demoApp-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp-tvOS.release.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp-tvOS/Pods-demoApp-tvOS.release.xcconfig"; sourceTree = ""; };
48 | 13B07F961A680F5B00A75B9A /* demoApp.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = demoApp.app; sourceTree = BUILT_PRODUCTS_DIR; };
49 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = demoApp/AppDelegate.h; sourceTree = ""; };
50 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = demoApp/AppDelegate.m; sourceTree = ""; };
51 | 13B07FB21A68108700A75B9A /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; };
52 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = demoApp/Images.xcassets; sourceTree = ""; };
53 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = demoApp/Info.plist; sourceTree = ""; };
54 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = demoApp/main.m; sourceTree = ""; };
55 | 1C5C4986B9E357AD2FF8C005 /* libPods-demoApp-tvOSTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-demoApp-tvOSTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
56 | 2D02E47B1E0B4A5D006451C7 /* demoApp-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "demoApp-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
57 | 2D02E4901E0B4A5D006451C7 /* demoApp-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "demoApp-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
58 | 535CFF906A6788517BEE0EEA /* Pods-demoApp.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp.debug.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp/Pods-demoApp.debug.xcconfig"; sourceTree = ""; };
59 | 5D32FB188007D539DA1D14E1 /* Pods-demoApp-tvOSTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp-tvOSTests.debug.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp-tvOSTests/Pods-demoApp-tvOSTests.debug.xcconfig"; sourceTree = ""; };
60 | 5F7B9F7452771AFF0B396318 /* Pods-demoAppTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoAppTests.debug.xcconfig"; path = "Pods/Target Support Files/Pods-demoAppTests/Pods-demoAppTests.debug.xcconfig"; sourceTree = ""; };
61 | 5FDA0FFBECB7BB1D7ACC0297 /* libPods-demoAppTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-demoAppTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
62 | 74F2BC51EE8F75737B2F11A3 /* Pods-demoApp-tvOSTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp-tvOSTests.release.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp-tvOSTests/Pods-demoApp-tvOSTests.release.xcconfig"; sourceTree = ""; };
63 | 807E26B040F4C94FBB5226C2 /* Pods-demoAppTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoAppTests.release.xcconfig"; path = "Pods/Target Support Files/Pods-demoAppTests/Pods-demoAppTests.release.xcconfig"; sourceTree = ""; };
64 | 9D1724A9547A558C0BAA3372 /* Pods-demoApp-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp-tvOS.debug.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp-tvOS/Pods-demoApp-tvOS.debug.xcconfig"; sourceTree = ""; };
65 | D2A1AFB5E669517459562948 /* Pods-demoApp.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-demoApp.release.xcconfig"; path = "Pods/Target Support Files/Pods-demoApp/Pods-demoApp.release.xcconfig"; sourceTree = ""; };
66 | EB18472B73EB90B55151F414 /* libPods-demoApp.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-demoApp.a"; sourceTree = BUILT_PRODUCTS_DIR; };
67 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
68 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; };
69 | FA41D6B2A6E7CBF14B735AD7 /* libPods-demoApp-tvOS.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-demoApp-tvOS.a"; sourceTree = BUILT_PRODUCTS_DIR; };
70 | /* End PBXFileReference section */
71 |
72 | /* Begin PBXFrameworksBuildPhase section */
73 | 00E356EB1AD99517003FC87E /* Frameworks */ = {
74 | isa = PBXFrameworksBuildPhase;
75 | buildActionMask = 2147483647;
76 | files = (
77 | DE7C389D21AFC7B7EC22723E /* libPods-demoAppTests.a in Frameworks */,
78 | );
79 | runOnlyForDeploymentPostprocessing = 0;
80 | };
81 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
82 | isa = PBXFrameworksBuildPhase;
83 | buildActionMask = 2147483647;
84 | files = (
85 | FC56921294AF0C3315D253F4 /* libPods-demoApp.a in Frameworks */,
86 | );
87 | runOnlyForDeploymentPostprocessing = 0;
88 | };
89 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = {
90 | isa = PBXFrameworksBuildPhase;
91 | buildActionMask = 2147483647;
92 | files = (
93 | FB1CD28D31A40630C8501D66 /* libPods-demoApp-tvOS.a in Frameworks */,
94 | );
95 | runOnlyForDeploymentPostprocessing = 0;
96 | };
97 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = {
98 | isa = PBXFrameworksBuildPhase;
99 | buildActionMask = 2147483647;
100 | files = (
101 | C9E93A301DD272D0291597A8 /* libPods-demoApp-tvOSTests.a in Frameworks */,
102 | );
103 | runOnlyForDeploymentPostprocessing = 0;
104 | };
105 | /* End PBXFrameworksBuildPhase section */
106 |
107 | /* Begin PBXGroup section */
108 | 00E356EF1AD99517003FC87E /* demoAppTests */ = {
109 | isa = PBXGroup;
110 | children = (
111 | 00E356F21AD99517003FC87E /* demoAppTests.m */,
112 | 00E356F01AD99517003FC87E /* Supporting Files */,
113 | );
114 | path = demoAppTests;
115 | sourceTree = "";
116 | };
117 | 00E356F01AD99517003FC87E /* Supporting Files */ = {
118 | isa = PBXGroup;
119 | children = (
120 | 00E356F11AD99517003FC87E /* Info.plist */,
121 | );
122 | name = "Supporting Files";
123 | sourceTree = "";
124 | };
125 | 13B07FAE1A68108700A75B9A /* demoApp */ = {
126 | isa = PBXGroup;
127 | children = (
128 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
129 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
130 | 13B07FB01A68108700A75B9A /* AppDelegate.m */,
131 | 13B07FB51A68108700A75B9A /* Images.xcassets */,
132 | 13B07FB61A68108700A75B9A /* Info.plist */,
133 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */,
134 | 13B07FB71A68108700A75B9A /* main.m */,
135 | );
136 | name = demoApp;
137 | sourceTree = "";
138 | };
139 | 2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
140 | isa = PBXGroup;
141 | children = (
142 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
143 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
144 | EB18472B73EB90B55151F414 /* libPods-demoApp.a */,
145 | FA41D6B2A6E7CBF14B735AD7 /* libPods-demoApp-tvOS.a */,
146 | 1C5C4986B9E357AD2FF8C005 /* libPods-demoApp-tvOSTests.a */,
147 | 5FDA0FFBECB7BB1D7ACC0297 /* libPods-demoAppTests.a */,
148 | );
149 | name = Frameworks;
150 | sourceTree = "";
151 | };
152 | 5044875D68E69F3CA2B56A3B /* Pods */ = {
153 | isa = PBXGroup;
154 | children = (
155 | 535CFF906A6788517BEE0EEA /* Pods-demoApp.debug.xcconfig */,
156 | D2A1AFB5E669517459562948 /* Pods-demoApp.release.xcconfig */,
157 | 9D1724A9547A558C0BAA3372 /* Pods-demoApp-tvOS.debug.xcconfig */,
158 | 0757A94DC2FC107540F2B998 /* Pods-demoApp-tvOS.release.xcconfig */,
159 | 5D32FB188007D539DA1D14E1 /* Pods-demoApp-tvOSTests.debug.xcconfig */,
160 | 74F2BC51EE8F75737B2F11A3 /* Pods-demoApp-tvOSTests.release.xcconfig */,
161 | 5F7B9F7452771AFF0B396318 /* Pods-demoAppTests.debug.xcconfig */,
162 | 807E26B040F4C94FBB5226C2 /* Pods-demoAppTests.release.xcconfig */,
163 | );
164 | name = Pods;
165 | sourceTree = "";
166 | };
167 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
168 | isa = PBXGroup;
169 | children = (
170 | );
171 | name = Libraries;
172 | sourceTree = "";
173 | };
174 | 83CBB9F61A601CBA00E9B192 = {
175 | isa = PBXGroup;
176 | children = (
177 | 13B07FAE1A68108700A75B9A /* demoApp */,
178 | 832341AE1AAA6A7D00B99B32 /* Libraries */,
179 | 00E356EF1AD99517003FC87E /* demoAppTests */,
180 | 83CBBA001A601CBA00E9B192 /* Products */,
181 | 2D16E6871FA4F8E400B85C8A /* Frameworks */,
182 | 5044875D68E69F3CA2B56A3B /* Pods */,
183 | );
184 | indentWidth = 2;
185 | sourceTree = "";
186 | tabWidth = 2;
187 | usesTabs = 0;
188 | };
189 | 83CBBA001A601CBA00E9B192 /* Products */ = {
190 | isa = PBXGroup;
191 | children = (
192 | 13B07F961A680F5B00A75B9A /* demoApp.app */,
193 | 00E356EE1AD99517003FC87E /* demoAppTests.xctest */,
194 | 2D02E47B1E0B4A5D006451C7 /* demoApp-tvOS.app */,
195 | 2D02E4901E0B4A5D006451C7 /* demoApp-tvOSTests.xctest */,
196 | );
197 | name = Products;
198 | sourceTree = "";
199 | };
200 | /* End PBXGroup section */
201 |
202 | /* Begin PBXNativeTarget section */
203 | 00E356ED1AD99517003FC87E /* demoAppTests */ = {
204 | isa = PBXNativeTarget;
205 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "demoAppTests" */;
206 | buildPhases = (
207 | 2E789CE1C8821D15423D297E /* [CP] Check Pods Manifest.lock */,
208 | 00E356EA1AD99517003FC87E /* Sources */,
209 | 00E356EB1AD99517003FC87E /* Frameworks */,
210 | 00E356EC1AD99517003FC87E /* Resources */,
211 | );
212 | buildRules = (
213 | );
214 | dependencies = (
215 | 00E356F51AD99517003FC87E /* PBXTargetDependency */,
216 | );
217 | name = demoAppTests;
218 | productName = demoAppTests;
219 | productReference = 00E356EE1AD99517003FC87E /* demoAppTests.xctest */;
220 | productType = "com.apple.product-type.bundle.unit-test";
221 | };
222 | 13B07F861A680F5B00A75B9A /* demoApp */ = {
223 | isa = PBXNativeTarget;
224 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "demoApp" */;
225 | buildPhases = (
226 | 008926B2D049652C8B79D9C3 /* [CP] Check Pods Manifest.lock */,
227 | FD10A7F022414F080027D42C /* Start Packager */,
228 | 13B07F871A680F5B00A75B9A /* Sources */,
229 | 13B07F8C1A680F5B00A75B9A /* Frameworks */,
230 | 13B07F8E1A680F5B00A75B9A /* Resources */,
231 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
232 | );
233 | buildRules = (
234 | );
235 | dependencies = (
236 | );
237 | name = demoApp;
238 | productName = demoApp;
239 | productReference = 13B07F961A680F5B00A75B9A /* demoApp.app */;
240 | productType = "com.apple.product-type.application";
241 | };
242 | 2D02E47A1E0B4A5D006451C7 /* demoApp-tvOS */ = {
243 | isa = PBXNativeTarget;
244 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "demoApp-tvOS" */;
245 | buildPhases = (
246 | BD763AFD2E3B50C87196B11A /* [CP] Check Pods Manifest.lock */,
247 | FD10A7F122414F3F0027D42C /* Start Packager */,
248 | 2D02E4771E0B4A5D006451C7 /* Sources */,
249 | 2D02E4781E0B4A5D006451C7 /* Frameworks */,
250 | 2D02E4791E0B4A5D006451C7 /* Resources */,
251 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */,
252 | );
253 | buildRules = (
254 | );
255 | dependencies = (
256 | );
257 | name = "demoApp-tvOS";
258 | productName = "demoApp-tvOS";
259 | productReference = 2D02E47B1E0B4A5D006451C7 /* demoApp-tvOS.app */;
260 | productType = "com.apple.product-type.application";
261 | };
262 | 2D02E48F1E0B4A5D006451C7 /* demoApp-tvOSTests */ = {
263 | isa = PBXNativeTarget;
264 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "demoApp-tvOSTests" */;
265 | buildPhases = (
266 | 211B0254356DE5EE7EE656C6 /* [CP] Check Pods Manifest.lock */,
267 | 2D02E48C1E0B4A5D006451C7 /* Sources */,
268 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */,
269 | 2D02E48E1E0B4A5D006451C7 /* Resources */,
270 | );
271 | buildRules = (
272 | );
273 | dependencies = (
274 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */,
275 | );
276 | name = "demoApp-tvOSTests";
277 | productName = "demoApp-tvOSTests";
278 | productReference = 2D02E4901E0B4A5D006451C7 /* demoApp-tvOSTests.xctest */;
279 | productType = "com.apple.product-type.bundle.unit-test";
280 | };
281 | /* End PBXNativeTarget section */
282 |
283 | /* Begin PBXProject section */
284 | 83CBB9F71A601CBA00E9B192 /* Project object */ = {
285 | isa = PBXProject;
286 | attributes = {
287 | LastUpgradeCheck = 0940;
288 | ORGANIZATIONNAME = Facebook;
289 | TargetAttributes = {
290 | 00E356ED1AD99517003FC87E = {
291 | CreatedOnToolsVersion = 6.2;
292 | TestTargetID = 13B07F861A680F5B00A75B9A;
293 | };
294 | 2D02E47A1E0B4A5D006451C7 = {
295 | CreatedOnToolsVersion = 8.2.1;
296 | ProvisioningStyle = Automatic;
297 | };
298 | 2D02E48F1E0B4A5D006451C7 = {
299 | CreatedOnToolsVersion = 8.2.1;
300 | ProvisioningStyle = Automatic;
301 | TestTargetID = 2D02E47A1E0B4A5D006451C7;
302 | };
303 | };
304 | };
305 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "demoApp" */;
306 | compatibilityVersion = "Xcode 3.2";
307 | developmentRegion = English;
308 | hasScannedForEncodings = 0;
309 | knownRegions = (
310 | en,
311 | Base,
312 | );
313 | mainGroup = 83CBB9F61A601CBA00E9B192;
314 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
315 | projectDirPath = "";
316 | projectRoot = "";
317 | targets = (
318 | 13B07F861A680F5B00A75B9A /* demoApp */,
319 | 00E356ED1AD99517003FC87E /* demoAppTests */,
320 | 2D02E47A1E0B4A5D006451C7 /* demoApp-tvOS */,
321 | 2D02E48F1E0B4A5D006451C7 /* demoApp-tvOSTests */,
322 | );
323 | };
324 | /* End PBXProject section */
325 |
326 | /* Begin PBXResourcesBuildPhase section */
327 | 00E356EC1AD99517003FC87E /* Resources */ = {
328 | isa = PBXResourcesBuildPhase;
329 | buildActionMask = 2147483647;
330 | files = (
331 | );
332 | runOnlyForDeploymentPostprocessing = 0;
333 | };
334 | 13B07F8E1A680F5B00A75B9A /* Resources */ = {
335 | isa = PBXResourcesBuildPhase;
336 | buildActionMask = 2147483647;
337 | files = (
338 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
339 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */,
340 | );
341 | runOnlyForDeploymentPostprocessing = 0;
342 | };
343 | 2D02E4791E0B4A5D006451C7 /* Resources */ = {
344 | isa = PBXResourcesBuildPhase;
345 | buildActionMask = 2147483647;
346 | files = (
347 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */,
348 | );
349 | runOnlyForDeploymentPostprocessing = 0;
350 | };
351 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = {
352 | isa = PBXResourcesBuildPhase;
353 | buildActionMask = 2147483647;
354 | files = (
355 | );
356 | runOnlyForDeploymentPostprocessing = 0;
357 | };
358 | /* End PBXResourcesBuildPhase section */
359 |
360 | /* Begin PBXShellScriptBuildPhase section */
361 | 008926B2D049652C8B79D9C3 /* [CP] Check Pods Manifest.lock */ = {
362 | isa = PBXShellScriptBuildPhase;
363 | buildActionMask = 2147483647;
364 | files = (
365 | );
366 | inputFileListPaths = (
367 | );
368 | inputPaths = (
369 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
370 | "${PODS_ROOT}/Manifest.lock",
371 | );
372 | name = "[CP] Check Pods Manifest.lock";
373 | outputFileListPaths = (
374 | );
375 | outputPaths = (
376 | "$(DERIVED_FILE_DIR)/Pods-demoApp-checkManifestLockResult.txt",
377 | );
378 | runOnlyForDeploymentPostprocessing = 0;
379 | shellPath = /bin/sh;
380 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
381 | showEnvVarsInLog = 0;
382 | };
383 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = {
384 | isa = PBXShellScriptBuildPhase;
385 | buildActionMask = 2147483647;
386 | files = (
387 | );
388 | inputPaths = (
389 | );
390 | name = "Bundle React Native code and images";
391 | outputPaths = (
392 | );
393 | runOnlyForDeploymentPostprocessing = 0;
394 | shellPath = /bin/sh;
395 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
396 | };
397 | 211B0254356DE5EE7EE656C6 /* [CP] Check Pods Manifest.lock */ = {
398 | isa = PBXShellScriptBuildPhase;
399 | buildActionMask = 2147483647;
400 | files = (
401 | );
402 | inputFileListPaths = (
403 | );
404 | inputPaths = (
405 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
406 | "${PODS_ROOT}/Manifest.lock",
407 | );
408 | name = "[CP] Check Pods Manifest.lock";
409 | outputFileListPaths = (
410 | );
411 | outputPaths = (
412 | "$(DERIVED_FILE_DIR)/Pods-demoApp-tvOSTests-checkManifestLockResult.txt",
413 | );
414 | runOnlyForDeploymentPostprocessing = 0;
415 | shellPath = /bin/sh;
416 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
417 | showEnvVarsInLog = 0;
418 | };
419 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = {
420 | isa = PBXShellScriptBuildPhase;
421 | buildActionMask = 2147483647;
422 | files = (
423 | );
424 | inputPaths = (
425 | );
426 | name = "Bundle React Native Code And Images";
427 | outputPaths = (
428 | );
429 | runOnlyForDeploymentPostprocessing = 0;
430 | shellPath = /bin/sh;
431 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
432 | };
433 | 2E789CE1C8821D15423D297E /* [CP] Check Pods Manifest.lock */ = {
434 | isa = PBXShellScriptBuildPhase;
435 | buildActionMask = 2147483647;
436 | files = (
437 | );
438 | inputFileListPaths = (
439 | );
440 | inputPaths = (
441 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
442 | "${PODS_ROOT}/Manifest.lock",
443 | );
444 | name = "[CP] Check Pods Manifest.lock";
445 | outputFileListPaths = (
446 | );
447 | outputPaths = (
448 | "$(DERIVED_FILE_DIR)/Pods-demoAppTests-checkManifestLockResult.txt",
449 | );
450 | runOnlyForDeploymentPostprocessing = 0;
451 | shellPath = /bin/sh;
452 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
453 | showEnvVarsInLog = 0;
454 | };
455 | BD763AFD2E3B50C87196B11A /* [CP] Check Pods Manifest.lock */ = {
456 | isa = PBXShellScriptBuildPhase;
457 | buildActionMask = 2147483647;
458 | files = (
459 | );
460 | inputFileListPaths = (
461 | );
462 | inputPaths = (
463 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
464 | "${PODS_ROOT}/Manifest.lock",
465 | );
466 | name = "[CP] Check Pods Manifest.lock";
467 | outputFileListPaths = (
468 | );
469 | outputPaths = (
470 | "$(DERIVED_FILE_DIR)/Pods-demoApp-tvOS-checkManifestLockResult.txt",
471 | );
472 | runOnlyForDeploymentPostprocessing = 0;
473 | shellPath = /bin/sh;
474 | shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
475 | showEnvVarsInLog = 0;
476 | };
477 | FD10A7F022414F080027D42C /* Start Packager */ = {
478 | isa = PBXShellScriptBuildPhase;
479 | buildActionMask = 2147483647;
480 | files = (
481 | );
482 | inputFileListPaths = (
483 | );
484 | inputPaths = (
485 | );
486 | name = "Start Packager";
487 | outputFileListPaths = (
488 | );
489 | outputPaths = (
490 | );
491 | runOnlyForDeploymentPostprocessing = 0;
492 | shellPath = /bin/sh;
493 | shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
494 | showEnvVarsInLog = 0;
495 | };
496 | FD10A7F122414F3F0027D42C /* Start Packager */ = {
497 | isa = PBXShellScriptBuildPhase;
498 | buildActionMask = 2147483647;
499 | files = (
500 | );
501 | inputFileListPaths = (
502 | );
503 | inputPaths = (
504 | );
505 | name = "Start Packager";
506 | outputFileListPaths = (
507 | );
508 | outputPaths = (
509 | );
510 | runOnlyForDeploymentPostprocessing = 0;
511 | shellPath = /bin/sh;
512 | shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
513 | showEnvVarsInLog = 0;
514 | };
515 | /* End PBXShellScriptBuildPhase section */
516 |
517 | /* Begin PBXSourcesBuildPhase section */
518 | 00E356EA1AD99517003FC87E /* Sources */ = {
519 | isa = PBXSourcesBuildPhase;
520 | buildActionMask = 2147483647;
521 | files = (
522 | 00E356F31AD99517003FC87E /* demoAppTests.m in Sources */,
523 | );
524 | runOnlyForDeploymentPostprocessing = 0;
525 | };
526 | 13B07F871A680F5B00A75B9A /* Sources */ = {
527 | isa = PBXSourcesBuildPhase;
528 | buildActionMask = 2147483647;
529 | files = (
530 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
531 | 13B07FC11A68108700A75B9A /* main.m in Sources */,
532 | );
533 | runOnlyForDeploymentPostprocessing = 0;
534 | };
535 | 2D02E4771E0B4A5D006451C7 /* Sources */ = {
536 | isa = PBXSourcesBuildPhase;
537 | buildActionMask = 2147483647;
538 | files = (
539 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */,
540 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */,
541 | );
542 | runOnlyForDeploymentPostprocessing = 0;
543 | };
544 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = {
545 | isa = PBXSourcesBuildPhase;
546 | buildActionMask = 2147483647;
547 | files = (
548 | 2DCD954D1E0B4F2C00145EB5 /* demoAppTests.m in Sources */,
549 | );
550 | runOnlyForDeploymentPostprocessing = 0;
551 | };
552 | /* End PBXSourcesBuildPhase section */
553 |
554 | /* Begin PBXTargetDependency section */
555 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = {
556 | isa = PBXTargetDependency;
557 | target = 13B07F861A680F5B00A75B9A /* demoApp */;
558 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */;
559 | };
560 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = {
561 | isa = PBXTargetDependency;
562 | target = 2D02E47A1E0B4A5D006451C7 /* demoApp-tvOS */;
563 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */;
564 | };
565 | /* End PBXTargetDependency section */
566 |
567 | /* Begin PBXVariantGroup section */
568 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = {
569 | isa = PBXVariantGroup;
570 | children = (
571 | 13B07FB21A68108700A75B9A /* Base */,
572 | );
573 | name = LaunchScreen.xib;
574 | path = demoApp;
575 | sourceTree = "";
576 | };
577 | /* End PBXVariantGroup section */
578 |
579 | /* Begin XCBuildConfiguration section */
580 | 00E356F61AD99517003FC87E /* Debug */ = {
581 | isa = XCBuildConfiguration;
582 | baseConfigurationReference = 5F7B9F7452771AFF0B396318 /* Pods-demoAppTests.debug.xcconfig */;
583 | buildSettings = {
584 | BUNDLE_LOADER = "$(TEST_HOST)";
585 | GCC_PREPROCESSOR_DEFINITIONS = (
586 | "DEBUG=1",
587 | "$(inherited)",
588 | );
589 | INFOPLIST_FILE = demoAppTests/Info.plist;
590 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
591 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
592 | OTHER_LDFLAGS = (
593 | "-ObjC",
594 | "-lc++",
595 | "$(inherited)",
596 | );
597 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
598 | PRODUCT_NAME = "$(TARGET_NAME)";
599 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/demoApp.app/demoApp";
600 | };
601 | name = Debug;
602 | };
603 | 00E356F71AD99517003FC87E /* Release */ = {
604 | isa = XCBuildConfiguration;
605 | baseConfigurationReference = 807E26B040F4C94FBB5226C2 /* Pods-demoAppTests.release.xcconfig */;
606 | buildSettings = {
607 | BUNDLE_LOADER = "$(TEST_HOST)";
608 | COPY_PHASE_STRIP = NO;
609 | INFOPLIST_FILE = demoAppTests/Info.plist;
610 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
611 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
612 | OTHER_LDFLAGS = (
613 | "-ObjC",
614 | "-lc++",
615 | "$(inherited)",
616 | );
617 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
618 | PRODUCT_NAME = "$(TARGET_NAME)";
619 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/demoApp.app/demoApp";
620 | };
621 | name = Release;
622 | };
623 | 13B07F941A680F5B00A75B9A /* Debug */ = {
624 | isa = XCBuildConfiguration;
625 | baseConfigurationReference = 535CFF906A6788517BEE0EEA /* Pods-demoApp.debug.xcconfig */;
626 | buildSettings = {
627 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
628 | CURRENT_PROJECT_VERSION = 1;
629 | DEAD_CODE_STRIPPING = NO;
630 | INFOPLIST_FILE = demoApp/Info.plist;
631 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
632 | OTHER_LDFLAGS = (
633 | "$(inherited)",
634 | "-ObjC",
635 | "-lc++",
636 | );
637 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
638 | PRODUCT_NAME = demoApp;
639 | VERSIONING_SYSTEM = "apple-generic";
640 | };
641 | name = Debug;
642 | };
643 | 13B07F951A680F5B00A75B9A /* Release */ = {
644 | isa = XCBuildConfiguration;
645 | baseConfigurationReference = D2A1AFB5E669517459562948 /* Pods-demoApp.release.xcconfig */;
646 | buildSettings = {
647 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
648 | CURRENT_PROJECT_VERSION = 1;
649 | INFOPLIST_FILE = demoApp/Info.plist;
650 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
651 | OTHER_LDFLAGS = (
652 | "$(inherited)",
653 | "-ObjC",
654 | "-lc++",
655 | );
656 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
657 | PRODUCT_NAME = demoApp;
658 | VERSIONING_SYSTEM = "apple-generic";
659 | };
660 | name = Release;
661 | };
662 | 2D02E4971E0B4A5E006451C7 /* Debug */ = {
663 | isa = XCBuildConfiguration;
664 | baseConfigurationReference = 9D1724A9547A558C0BAA3372 /* Pods-demoApp-tvOS.debug.xcconfig */;
665 | buildSettings = {
666 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
667 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
668 | CLANG_ANALYZER_NONNULL = YES;
669 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
670 | CLANG_WARN_INFINITE_RECURSION = YES;
671 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
672 | DEBUG_INFORMATION_FORMAT = dwarf;
673 | ENABLE_TESTABILITY = YES;
674 | GCC_NO_COMMON_BLOCKS = YES;
675 | INFOPLIST_FILE = "demoApp-tvOS/Info.plist";
676 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
677 | OTHER_LDFLAGS = (
678 | "$(inherited)",
679 | "-ObjC",
680 | "-lc++",
681 | );
682 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.demoApp-tvOS";
683 | PRODUCT_NAME = "$(TARGET_NAME)";
684 | SDKROOT = appletvos;
685 | TARGETED_DEVICE_FAMILY = 3;
686 | TVOS_DEPLOYMENT_TARGET = 9.2;
687 | };
688 | name = Debug;
689 | };
690 | 2D02E4981E0B4A5E006451C7 /* Release */ = {
691 | isa = XCBuildConfiguration;
692 | baseConfigurationReference = 0757A94DC2FC107540F2B998 /* Pods-demoApp-tvOS.release.xcconfig */;
693 | buildSettings = {
694 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
695 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
696 | CLANG_ANALYZER_NONNULL = YES;
697 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
698 | CLANG_WARN_INFINITE_RECURSION = YES;
699 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
700 | COPY_PHASE_STRIP = NO;
701 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
702 | GCC_NO_COMMON_BLOCKS = YES;
703 | INFOPLIST_FILE = "demoApp-tvOS/Info.plist";
704 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
705 | OTHER_LDFLAGS = (
706 | "$(inherited)",
707 | "-ObjC",
708 | "-lc++",
709 | );
710 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.demoApp-tvOS";
711 | PRODUCT_NAME = "$(TARGET_NAME)";
712 | SDKROOT = appletvos;
713 | TARGETED_DEVICE_FAMILY = 3;
714 | TVOS_DEPLOYMENT_TARGET = 9.2;
715 | };
716 | name = Release;
717 | };
718 | 2D02E4991E0B4A5E006451C7 /* Debug */ = {
719 | isa = XCBuildConfiguration;
720 | baseConfigurationReference = 5D32FB188007D539DA1D14E1 /* Pods-demoApp-tvOSTests.debug.xcconfig */;
721 | buildSettings = {
722 | BUNDLE_LOADER = "$(TEST_HOST)";
723 | CLANG_ANALYZER_NONNULL = YES;
724 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
725 | CLANG_WARN_INFINITE_RECURSION = YES;
726 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
727 | DEBUG_INFORMATION_FORMAT = dwarf;
728 | ENABLE_TESTABILITY = YES;
729 | GCC_NO_COMMON_BLOCKS = YES;
730 | INFOPLIST_FILE = "demoApp-tvOSTests/Info.plist";
731 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
732 | OTHER_LDFLAGS = (
733 | "$(inherited)",
734 | "-ObjC",
735 | "-lc++",
736 | );
737 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.demoApp-tvOSTests";
738 | PRODUCT_NAME = "$(TARGET_NAME)";
739 | SDKROOT = appletvos;
740 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/demoApp-tvOS.app/demoApp-tvOS";
741 | TVOS_DEPLOYMENT_TARGET = 10.1;
742 | };
743 | name = Debug;
744 | };
745 | 2D02E49A1E0B4A5E006451C7 /* Release */ = {
746 | isa = XCBuildConfiguration;
747 | baseConfigurationReference = 74F2BC51EE8F75737B2F11A3 /* Pods-demoApp-tvOSTests.release.xcconfig */;
748 | buildSettings = {
749 | BUNDLE_LOADER = "$(TEST_HOST)";
750 | CLANG_ANALYZER_NONNULL = YES;
751 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
752 | CLANG_WARN_INFINITE_RECURSION = YES;
753 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
754 | COPY_PHASE_STRIP = NO;
755 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
756 | GCC_NO_COMMON_BLOCKS = YES;
757 | INFOPLIST_FILE = "demoApp-tvOSTests/Info.plist";
758 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
759 | OTHER_LDFLAGS = (
760 | "$(inherited)",
761 | "-ObjC",
762 | "-lc++",
763 | );
764 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.demoApp-tvOSTests";
765 | PRODUCT_NAME = "$(TARGET_NAME)";
766 | SDKROOT = appletvos;
767 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/demoApp-tvOS.app/demoApp-tvOS";
768 | TVOS_DEPLOYMENT_TARGET = 10.1;
769 | };
770 | name = Release;
771 | };
772 | 83CBBA201A601CBA00E9B192 /* Debug */ = {
773 | isa = XCBuildConfiguration;
774 | buildSettings = {
775 | ALWAYS_SEARCH_USER_PATHS = NO;
776 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
777 | CLANG_CXX_LIBRARY = "libc++";
778 | CLANG_ENABLE_MODULES = YES;
779 | CLANG_ENABLE_OBJC_ARC = YES;
780 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
781 | CLANG_WARN_BOOL_CONVERSION = YES;
782 | CLANG_WARN_COMMA = YES;
783 | CLANG_WARN_CONSTANT_CONVERSION = YES;
784 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
785 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
786 | CLANG_WARN_EMPTY_BODY = YES;
787 | CLANG_WARN_ENUM_CONVERSION = YES;
788 | CLANG_WARN_INFINITE_RECURSION = YES;
789 | CLANG_WARN_INT_CONVERSION = YES;
790 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
791 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
792 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
793 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
794 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
795 | CLANG_WARN_STRICT_PROTOTYPES = YES;
796 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
797 | CLANG_WARN_UNREACHABLE_CODE = YES;
798 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
799 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
800 | COPY_PHASE_STRIP = NO;
801 | ENABLE_STRICT_OBJC_MSGSEND = YES;
802 | ENABLE_TESTABILITY = YES;
803 | GCC_C_LANGUAGE_STANDARD = gnu99;
804 | GCC_DYNAMIC_NO_PIC = NO;
805 | GCC_NO_COMMON_BLOCKS = YES;
806 | GCC_OPTIMIZATION_LEVEL = 0;
807 | GCC_PREPROCESSOR_DEFINITIONS = (
808 | "DEBUG=1",
809 | "$(inherited)",
810 | );
811 | GCC_SYMBOLS_PRIVATE_EXTERN = NO;
812 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
813 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
814 | GCC_WARN_UNDECLARED_SELECTOR = YES;
815 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
816 | GCC_WARN_UNUSED_FUNCTION = YES;
817 | GCC_WARN_UNUSED_VARIABLE = YES;
818 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
819 | MTL_ENABLE_DEBUG_INFO = YES;
820 | ONLY_ACTIVE_ARCH = YES;
821 | SDKROOT = iphoneos;
822 | };
823 | name = Debug;
824 | };
825 | 83CBBA211A601CBA00E9B192 /* Release */ = {
826 | isa = XCBuildConfiguration;
827 | buildSettings = {
828 | ALWAYS_SEARCH_USER_PATHS = NO;
829 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
830 | CLANG_CXX_LIBRARY = "libc++";
831 | CLANG_ENABLE_MODULES = YES;
832 | CLANG_ENABLE_OBJC_ARC = YES;
833 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
834 | CLANG_WARN_BOOL_CONVERSION = YES;
835 | CLANG_WARN_COMMA = YES;
836 | CLANG_WARN_CONSTANT_CONVERSION = YES;
837 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
838 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
839 | CLANG_WARN_EMPTY_BODY = YES;
840 | CLANG_WARN_ENUM_CONVERSION = YES;
841 | CLANG_WARN_INFINITE_RECURSION = YES;
842 | CLANG_WARN_INT_CONVERSION = YES;
843 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
844 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
845 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
846 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
847 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
848 | CLANG_WARN_STRICT_PROTOTYPES = YES;
849 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
850 | CLANG_WARN_UNREACHABLE_CODE = YES;
851 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
852 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
853 | COPY_PHASE_STRIP = YES;
854 | ENABLE_NS_ASSERTIONS = NO;
855 | ENABLE_STRICT_OBJC_MSGSEND = YES;
856 | GCC_C_LANGUAGE_STANDARD = gnu99;
857 | GCC_NO_COMMON_BLOCKS = YES;
858 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
859 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
860 | GCC_WARN_UNDECLARED_SELECTOR = YES;
861 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
862 | GCC_WARN_UNUSED_FUNCTION = YES;
863 | GCC_WARN_UNUSED_VARIABLE = YES;
864 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
865 | MTL_ENABLE_DEBUG_INFO = NO;
866 | SDKROOT = iphoneos;
867 | VALIDATE_PRODUCT = YES;
868 | };
869 | name = Release;
870 | };
871 | /* End XCBuildConfiguration section */
872 |
873 | /* Begin XCConfigurationList section */
874 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "demoAppTests" */ = {
875 | isa = XCConfigurationList;
876 | buildConfigurations = (
877 | 00E356F61AD99517003FC87E /* Debug */,
878 | 00E356F71AD99517003FC87E /* Release */,
879 | );
880 | defaultConfigurationIsVisible = 0;
881 | defaultConfigurationName = Release;
882 | };
883 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "demoApp" */ = {
884 | isa = XCConfigurationList;
885 | buildConfigurations = (
886 | 13B07F941A680F5B00A75B9A /* Debug */,
887 | 13B07F951A680F5B00A75B9A /* Release */,
888 | );
889 | defaultConfigurationIsVisible = 0;
890 | defaultConfigurationName = Release;
891 | };
892 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "demoApp-tvOS" */ = {
893 | isa = XCConfigurationList;
894 | buildConfigurations = (
895 | 2D02E4971E0B4A5E006451C7 /* Debug */,
896 | 2D02E4981E0B4A5E006451C7 /* Release */,
897 | );
898 | defaultConfigurationIsVisible = 0;
899 | defaultConfigurationName = Release;
900 | };
901 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "demoApp-tvOSTests" */ = {
902 | isa = XCConfigurationList;
903 | buildConfigurations = (
904 | 2D02E4991E0B4A5E006451C7 /* Debug */,
905 | 2D02E49A1E0B4A5E006451C7 /* Release */,
906 | );
907 | defaultConfigurationIsVisible = 0;
908 | defaultConfigurationName = Release;
909 | };
910 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "demoApp" */ = {
911 | isa = XCConfigurationList;
912 | buildConfigurations = (
913 | 83CBBA201A601CBA00E9B192 /* Debug */,
914 | 83CBBA211A601CBA00E9B192 /* Release */,
915 | );
916 | defaultConfigurationIsVisible = 0;
917 | defaultConfigurationName = Release;
918 | };
919 | /* End XCConfigurationList section */
920 | };
921 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
922 | }
923 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp.xcodeproj/xcshareddata/xcschemes/demoApp-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 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp.xcodeproj/xcshareddata/xcschemes/demoApp.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 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp.xcworkspace/contents.xcworkspacedata:
--------------------------------------------------------------------------------
1 |
2 |
4 |
6 |
7 |
9 |
10 |
11 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/AppDelegate.h:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the
5 | * LICENSE file in the root directory of this source tree.
6 | */
7 |
8 | #import
9 | #import
10 |
11 | @interface AppDelegate : UIResponder
12 |
13 | @property (nonatomic, strong) UIWindow *window;
14 |
15 | @end
16 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/AppDelegate.m:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the
5 | * LICENSE file in the root directory of this source tree.
6 | */
7 |
8 | #import "AppDelegate.h"
9 |
10 | #import
11 | #import
12 | #import
13 |
14 | @implementation AppDelegate
15 |
16 | - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
17 | {
18 | RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions];
19 | RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge
20 | moduleName:@"demoApp"
21 | initialProperties:nil];
22 |
23 | rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
24 |
25 | self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
26 | UIViewController *rootViewController = [UIViewController new];
27 | rootViewController.view = rootView;
28 | self.window.rootViewController = rootViewController;
29 | [self.window makeKeyAndVisible];
30 | return YES;
31 | }
32 |
33 | - (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
34 | {
35 | #if DEBUG
36 | return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
37 | #else
38 | return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
39 | #endif
40 | }
41 |
42 | @end
43 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/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 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/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 | }
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/Images.xcassets/Contents.json:
--------------------------------------------------------------------------------
1 | {
2 | "info" : {
3 | "version" : 1,
4 | "author" : "xcode"
5 | }
6 | }
7 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleDisplayName
8 | demoApp
9 | CFBundleExecutable
10 | $(EXECUTABLE_NAME)
11 | CFBundleIdentifier
12 | $(PRODUCT_BUNDLE_IDENTIFIER)
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 | NSAppTransportSecurity
28 |
29 | NSAllowsArbitraryLoads
30 |
31 | NSExceptionDomains
32 |
33 | localhost
34 |
35 | NSExceptionAllowsInsecureHTTPLoads
36 |
37 |
38 |
39 |
40 | NSLocationWhenInUseUsageDescription
41 |
42 | UILaunchStoryboardName
43 | LaunchScreen
44 | UIRequiredDeviceCapabilities
45 |
46 | armv7
47 |
48 | UISupportedInterfaceOrientations
49 |
50 | UIInterfaceOrientationPortrait
51 | UIInterfaceOrientationLandscapeLeft
52 | UIInterfaceOrientationLandscapeRight
53 |
54 | UIViewControllerBasedStatusBarAppearance
55 |
56 |
57 |
58 |
--------------------------------------------------------------------------------
/demoApp/ios/demoApp/main.m:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the
5 | * LICENSE file in the root directory of this source tree.
6 | */
7 |
8 | #import
9 |
10 | #import "AppDelegate.h"
11 |
12 | int main(int argc, char * argv[]) {
13 | @autoreleasepool {
14 | return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
15 | }
16 | }
17 |
--------------------------------------------------------------------------------
/demoApp/ios/demoAppTests/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleExecutable
8 | $(EXECUTABLE_NAME)
9 | CFBundleIdentifier
10 | $(PRODUCT_BUNDLE_IDENTIFIER)
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 |
--------------------------------------------------------------------------------
/demoApp/ios/demoAppTests/demoAppTests.m:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the
5 | * LICENSE file in the root directory of this source tree.
6 | */
7 |
8 | #import
9 | #import
10 |
11 | #import
12 | #import
13 |
14 | #define TIMEOUT_SECONDS 600
15 | #define TEXT_TO_LOOK_FOR @"Welcome to React Native!"
16 |
17 | @interface demoAppTests : XCTestCase
18 |
19 | @end
20 |
21 | @implementation demoAppTests
22 |
23 | - (BOOL)findSubviewInView:(UIView *)view matching:(BOOL(^)(UIView *view))test
24 | {
25 | if (test(view)) {
26 | return YES;
27 | }
28 | for (UIView *subview in [view subviews]) {
29 | if ([self findSubviewInView:subview matching:test]) {
30 | return YES;
31 | }
32 | }
33 | return NO;
34 | }
35 |
36 | - (void)testRendersWelcomeScreen
37 | {
38 | UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController];
39 | NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS];
40 | BOOL foundElement = NO;
41 |
42 | __block NSString *redboxError = nil;
43 | RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) {
44 | if (level >= RCTLogLevelError) {
45 | redboxError = message;
46 | }
47 | });
48 |
49 | while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) {
50 | [[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
51 | [[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
52 |
53 | foundElement = [self findSubviewInView:vc.view matching:^BOOL(UIView *view) {
54 | if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) {
55 | return YES;
56 | }
57 | return NO;
58 | }];
59 | }
60 |
61 | RCTSetLogFunction(RCTDefaultLogFunction);
62 |
63 | XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
64 | XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS);
65 | }
66 |
67 |
68 | @end
69 |
--------------------------------------------------------------------------------
/demoApp/metro.config.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Metro configuration for React Native
3 | * https://github.com/facebook/react-native
4 | *
5 | * @format
6 | */
7 |
8 | module.exports = {
9 | transformer: {
10 | getTransformOptions: async () => ({
11 | transform: {
12 | experimentalImportSupport: false,
13 | inlineRequires: false,
14 | },
15 | }),
16 | },
17 | };
18 |
--------------------------------------------------------------------------------
/demoApp/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "demoApp",
3 | "version": "0.0.1",
4 | "private": true,
5 | "scripts": {
6 | "start": "react-native start",
7 | "test": "jest",
8 | "lint": "eslint .",
9 | "iphone": "react-native run-ios --simulator='iPhone SE'"
10 | },
11 | "dependencies": {
12 | "react": "16.8.6",
13 | "react-native": "0.60.5",
14 | "validate.js": "^0.13.1"
15 | },
16 | "devDependencies": {
17 | "@babel/core": "^7.6.0",
18 | "@babel/runtime": "^7.6.0",
19 | "@react-native-community/eslint-config": "^0.0.5",
20 | "babel-jest": "^24.9.0",
21 | "eslint": "^6.3.0",
22 | "jest": "^24.9.0",
23 | "metro-react-native-babel-preset": "^0.56.0",
24 | "react-test-renderer": "16.8.6"
25 | },
26 | "jest": {
27 | "preset": "react-native"
28 | }
29 | }
30 |
--------------------------------------------------------------------------------
/demoApp/react-native-form-helpers/dictionary.js:
--------------------------------------------------------------------------------
1 | export const validationDictionary = {
2 | bool: {
3 | inclusion: {
4 | within: [true],
5 | message: '^This is required',
6 | },
7 | },
8 |
9 | day: {
10 | presence: {
11 | allowEmpty: false,
12 | message: '^This is required',
13 | },
14 | numericality: {
15 | greaterThan: 0,
16 | lessThanOrEqualTo: 31,
17 | message: '^Must be valid',
18 | },
19 | },
20 |
21 | email: {
22 | presence: {
23 | allowEmpty: false,
24 | message: '^This is required',
25 | },
26 | email: {
27 | message: '^Email address must be valid',
28 | },
29 | },
30 |
31 | generic: {
32 | presence: {
33 | allowEmpty: false,
34 | message: '^This is required',
35 | },
36 | },
37 |
38 | integer: {
39 | presence: {
40 | allowEmpty: false,
41 | message: '^This is required',
42 | },
43 | numericality: {
44 | greaterThan: 0,
45 | onlyInteger: true,
46 | message: '^Must be valid',
47 | },
48 | },
49 |
50 | month: {
51 | presence: {
52 | allowEmpty: false,
53 | message: '^This is required',
54 | },
55 | numericality: {
56 | greaterThan: 0,
57 | lessThanOrEqualTo: 12,
58 | message: '^Must be valid',
59 | },
60 | },
61 |
62 | password: {
63 | presence: {
64 | allowEmpty: false,
65 | message: '^This is required',
66 | },
67 | length: {
68 | minimum: 6,
69 | message: '^Password must be at least 6 characters long',
70 | },
71 | },
72 |
73 | phone: {
74 | presence: {
75 | allowEmpty: false,
76 | message: '^This is required',
77 | },
78 | format: {
79 | pattern: /^[2-9]\d{2}-\d{3}-\d{4}$/,
80 | message: '^Phone number must be valid',
81 | },
82 | },
83 |
84 | state: {
85 | presence: {
86 | allowEmpty: false,
87 | message: '^This is required',
88 | },
89 | inclusion: {
90 | within: [
91 | 'AK',
92 | 'AL',
93 | 'AR',
94 | 'AZ',
95 | 'CA',
96 | 'CO',
97 | 'CT',
98 | 'DC',
99 | 'DE',
100 | 'FL',
101 | 'GA',
102 | 'HI',
103 | 'IA',
104 | 'ID',
105 | 'IL',
106 | 'IN',
107 | 'KS',
108 | 'KY',
109 | 'LA',
110 | 'MA',
111 | 'MD',
112 | 'ME',
113 | 'MI',
114 | 'MN',
115 | 'MO',
116 | 'MS',
117 | 'MT',
118 | 'NC',
119 | 'ND',
120 | 'NE',
121 | 'NH',
122 | 'NJ',
123 | 'NM',
124 | 'NV',
125 | 'NY',
126 | 'OH',
127 | 'OK',
128 | 'OR',
129 | 'PA',
130 | 'RI',
131 | 'SC',
132 | 'SD',
133 | 'TN',
134 | 'TX',
135 | 'UT',
136 | 'VA',
137 | 'VT',
138 | 'WA',
139 | 'WI',
140 | 'WV',
141 | 'WY',
142 | ],
143 | message: '^Must be valid',
144 | },
145 | },
146 |
147 | year: {
148 | presence: {
149 | allowEmpty: false,
150 | message: '^This is required',
151 | },
152 | numericality: {
153 | greaterThan: 1900,
154 | lessThanOrEqualTo: new Date().getFullYear(),
155 | message: '^Must be valid',
156 | },
157 | },
158 |
159 | zip: {
160 | presence: {
161 | allowEmpty: false,
162 | message: '^This is required',
163 | },
164 | length: {
165 | is: 5,
166 | message: '^Zip must be 5 digits long',
167 | },
168 | },
169 | };
170 |
--------------------------------------------------------------------------------
/demoApp/react-native-form-helpers/index.js:
--------------------------------------------------------------------------------
1 | import validatejs from 'validate.js';
2 |
3 | export default function RNFormHelpers({dictionary}) {
4 | const service = {
5 | onInputChange,
6 | getInputValidationState,
7 | validateInput,
8 | getFormValidation,
9 | setInputPosition,
10 | getFirstInvalidInput,
11 | };
12 |
13 | function onInputChange({id, value, cb = () => {}}) {
14 | const {inputs} = this.state;
15 | this.setState(
16 | {
17 | inputs: {
18 | ...inputs,
19 | [id]: getInputValidationState({
20 | input: inputs[id],
21 | value,
22 | }),
23 | },
24 | },
25 | cb,
26 | );
27 | }
28 |
29 | function getInputValidationState({input, value, touched}) {
30 | return {
31 | ...input,
32 | value,
33 | errorLabel: input.optional
34 | ? null
35 | : validateInput({type: input.type, value}),
36 | touched: touched || input.touched,
37 | };
38 | }
39 |
40 | function validateInput({type, value}) {
41 | const result = validatejs(
42 | {
43 | [type]: value,
44 | },
45 | {
46 | [type]: dictionary[type],
47 | },
48 | );
49 |
50 | if (result) {
51 | return result[type][0];
52 | }
53 |
54 | return null;
55 | }
56 |
57 | function getFormValidation() {
58 | const {inputs} = this.state;
59 |
60 | const updatedInputs = {};
61 |
62 | for (const [key, input] of Object.entries(inputs)) {
63 | updatedInputs[key] = getInputValidationState({
64 | input,
65 | value: input.value,
66 | touched: true,
67 | });
68 | }
69 |
70 | this.setState({
71 | inputs: updatedInputs,
72 | });
73 |
74 | return getFirstInvalidInput({inputs: updatedInputs});
75 | }
76 |
77 | function setInputPosition({ids, value}) {
78 | const {inputs} = this.state;
79 |
80 | const updatedInputs = {
81 | ...inputs,
82 | };
83 |
84 | ids.forEach(id => {
85 | updatedInputs[id].yCoordinate = value;
86 | });
87 |
88 | this.setState({
89 | inputs: updatedInputs,
90 | });
91 | }
92 |
93 | function getFirstInvalidInput({inputs}) {
94 | let firstInvalidCoordinate = Infinity;
95 |
96 | for (const [key, input] of Object.entries(inputs)) {
97 | if (input.errorLabel && input.yCoordinate < firstInvalidCoordinate) {
98 | firstInvalidCoordinate = input.yCoordinate;
99 | }
100 | }
101 |
102 | if (firstInvalidCoordinate === Infinity) {
103 | firstInvalidCoordinate = null;
104 | }
105 |
106 | return firstInvalidCoordinate;
107 | }
108 |
109 | return service;
110 | }
111 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "react-native-form-helpers",
3 | "version": "0.1.0",
4 | "description": "React Native tutorials, helpers, and demo app for form validation and scroll to invalid logic",
5 | "license": "MIT",
6 | "author": "Michael Lefkowitz ",
7 | "repository": {
8 | "type": "git",
9 | "url": "https://github.com/lawnstarter/react-native-form-helpers.git"
10 | },
11 | "main": "src/index.js",
12 | "keywords": [
13 | "expo",
14 | "form",
15 | "react",
16 | "react native",
17 | "react-native",
18 | "validation"
19 | ],
20 | "files": [
21 | "/src"
22 | ],
23 | "dependencies": {
24 | "validate.js": "^0.13.1"
25 | },
26 | "scripts": {}
27 | }
28 |
--------------------------------------------------------------------------------
/src/index.js:
--------------------------------------------------------------------------------
1 | import validatejs from "validate.js";
2 |
3 | export default function RNFormHelpers({ dictionary }) {
4 | const service = {
5 | onInputChange,
6 | getInputValidationState,
7 | validateInput,
8 | getFormValidation,
9 | setInputPosition,
10 | getFirstInvalidInput
11 | };
12 |
13 | function onInputChange({ id, value, cb = () => {} }) {
14 | const { inputs } = this.state;
15 | this.setState(
16 | {
17 | inputs: {
18 | ...inputs,
19 | [id]: getInputValidationState({
20 | input: inputs[id],
21 | value
22 | })
23 | }
24 | },
25 | cb
26 | );
27 | }
28 |
29 | function getInputValidationState({ input, value, touched }) {
30 | return {
31 | ...input,
32 | value,
33 | errorLabel: input.optional
34 | ? null
35 | : validateInput({ type: input.type, value }),
36 | touched: touched || input.touched
37 | };
38 | }
39 |
40 | function validateInput({ type, value }) {
41 | const result = validatejs(
42 | {
43 | [type]: value
44 | },
45 | {
46 | [type]: dictionary[type]
47 | }
48 | );
49 |
50 | if (result) {
51 | return result[type][0];
52 | }
53 |
54 | return null;
55 | }
56 |
57 | function getFormValidation() {
58 | const { inputs } = this.state;
59 |
60 | const updatedInputs = {};
61 |
62 | for (const [key, input] of Object.entries(inputs)) {
63 | updatedInputs[key] = getInputValidationState({
64 | input,
65 | value: input.value,
66 | touched: true
67 | });
68 | }
69 |
70 | this.setState({
71 | inputs: updatedInputs
72 | });
73 |
74 | return getFirstInvalidInput({ inputs: updatedInputs });
75 | }
76 |
77 | function setInputPosition({ ids, value }) {
78 | const { inputs } = this.state;
79 |
80 | const updatedInputs = {
81 | ...inputs
82 | };
83 |
84 | ids.forEach(id => {
85 | updatedInputs[id].yCoordinate = value;
86 | });
87 |
88 | this.setState({
89 | inputs: updatedInputs
90 | });
91 | }
92 |
93 | function getFirstInvalidInput({ inputs }) {
94 | let firstInvalidCoordinate = Infinity;
95 |
96 | for (const [key, input] of Object.entries(inputs)) {
97 | if (input.errorLabel && input.yCoordinate < firstInvalidCoordinate) {
98 | firstInvalidCoordinate = input.yCoordinate;
99 | }
100 | }
101 |
102 | if (firstInvalidCoordinate === Infinity) {
103 | firstInvalidCoordinate = null;
104 | }
105 |
106 | return firstInvalidCoordinate;
107 | }
108 |
109 | return service;
110 | }
111 |
--------------------------------------------------------------------------------
/yarn.lock:
--------------------------------------------------------------------------------
1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
2 | # yarn lockfile v1
3 |
4 |
5 | validate.js@^0.13.1:
6 | version "0.13.1"
7 | resolved "https://registry.yarnpkg.com/validate.js/-/validate.js-0.13.1.tgz#b58bfac04a0f600a340f62e5227e70d95971e92a"
8 | integrity sha512-PnFM3xiZ+kYmLyTiMgTYmU7ZHkjBZz2/+F0DaALc/uUtVzdCt1wAosvYJ5hFQi/hz8O4zb52FQhHZRC+uVkJ+g==
9 |
--------------------------------------------------------------------------------