├── .gitignore ├── .npmignore ├── ComparisonTable.js ├── ComparisonTableRow.js ├── ComparisonTableSection.js ├── LICENSE ├── README.md ├── examples ├── .buckconfig ├── .eslintrc.js ├── .flowconfig ├── .gitattributes ├── .gitignore ├── .watchmanconfig ├── App.js ├── __tests__ │ └── App-test.js ├── android │ ├── app │ │ ├── _BUCK │ │ ├── build.gradle │ │ ├── build_defs.bzl │ │ ├── debug.keystore │ │ ├── proguard-rules.pro │ │ └── src │ │ │ ├── debug │ │ │ ├── AndroidManifest.xml │ │ │ └── java │ │ │ │ └── com │ │ │ │ └── examples │ │ │ │ └── ReactNativeFlipper.java │ │ │ └── main │ │ │ ├── AndroidManifest.xml │ │ │ ├── java │ │ │ └── com │ │ │ │ └── examples │ │ │ │ ├── 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 ├── images │ ├── iphone11.jpg │ ├── iphone11_cam.jpg │ ├── iphone11_pro.jpg │ ├── iphone11_pro_cam.jpg │ ├── iphoneSE.jpg │ └── iphoneSE_cam.jpg ├── index.js ├── ios │ ├── Podfile │ ├── Podfile.lock │ ├── examples-tvOS │ │ └── Info.plist │ ├── examples-tvOSTests │ │ └── Info.plist │ ├── examples.xcodeproj │ │ ├── project.pbxproj │ │ └── xcshareddata │ │ │ └── xcschemes │ │ │ ├── examples-tvOS.xcscheme │ │ │ └── examples.xcscheme │ ├── examples.xcworkspace │ │ └── contents.xcworkspacedata │ ├── examples │ │ ├── AppDelegate.h │ │ ├── AppDelegate.m │ │ ├── Images.xcassets │ │ │ ├── AppIcon.appiconset │ │ │ │ └── Contents.json │ │ │ └── Contents.json │ │ ├── Info.plist │ │ ├── LaunchScreen.storyboard │ │ └── main.m │ └── examplesTests │ │ ├── Info.plist │ │ └── examplesTests.m ├── metro.config.js ├── package-lock.json ├── package.json └── phones.js ├── index.js ├── package-lock.json ├── package.json └── prettierrc.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | *.log 2 | node_modules 3 | examples 4 | -------------------------------------------------------------------------------- /ComparisonTable.js: -------------------------------------------------------------------------------- 1 | import React, { useRef } from 'react'; 2 | import PropTypes from 'prop-types'; 3 | import { Animated, Dimensions, Platform, View, StyleSheet } from 'react-native'; 4 | 5 | const ComparisonTable = (props) => { 6 | const { 7 | children, 8 | isHighlightBest = true, 9 | headerCellWidth = 90, 10 | cellWidth = 156, 11 | height = 400 12 | } = props; 13 | const innerScrollX = useRef(new Animated.Value(0)).current; 14 | const scrollY = useRef(new Animated.Value(0)).current; 15 | 16 | return ( 17 | 18 | 29 | 30 | 39 | 40 | {React.Children.map(children, (child, index) => 41 | child 42 | ? React.cloneElement(child, { 43 | isHighlightBest, 44 | innerScrollX, 45 | scrollY, 46 | headerCellWidth, 47 | cellWidth 48 | }) 49 | : null 50 | )} 51 | 52 | 53 | 54 | 55 | 56 | ); 57 | }; 58 | 59 | ComparisonTable.propTypes = { 60 | cellWidth: PropTypes.number, 61 | headerCellWidth: PropTypes.number, 62 | height: PropTypes.number, 63 | isHighlightBest: PropTypes.bool 64 | }; 65 | 66 | const styles = StyleSheet.create({ 67 | fixedHeader: { 68 | borderBottomWidth: 1, 69 | borderColor: '#CBCBCB', 70 | position: 'absolute', 71 | width: Dimensions.get('window').width, 72 | top: 0, 73 | height: 40, 74 | flexDirection: 'row', 75 | justifyContent: 'space-between', 76 | alignItems: 'center', 77 | paddingHorizontal: 12, 78 | zIndex: 1 79 | }, 80 | headerText: { 81 | fontWeight: 'bold' 82 | } 83 | }); 84 | 85 | export default ComparisonTable; 86 | -------------------------------------------------------------------------------- /ComparisonTableRow.js: -------------------------------------------------------------------------------- 1 | import React, { useState, useRef, useEffect } from 'react'; 2 | import PropTypes from 'prop-types'; 3 | import { Animated, Dimensions, Text, View, StyleSheet } from 'react-native'; 4 | import get from 'lodash.get'; 5 | // import { getFormattedCurrency } from '~/utils/units' 6 | 7 | const ComparisonTableRow = (props) => { 8 | const { 9 | data = [], 10 | comparing, 11 | getBestBy, 12 | fixed, 13 | cellTextAlign, 14 | headerCellContent, 15 | headerCellStyle, 16 | cellContent, 17 | cellStyle, 18 | rowStyle, 19 | bestCellStyle, 20 | bestCellTextStyle, 21 | mergeCells, 22 | 23 | isHighlightBest, 24 | headerCellWidth, 25 | cellWidth, 26 | innerScrollX, 27 | scrollY 28 | } = props; 29 | 30 | let bestValueIndices = []; 31 | // Only sort them if user provide getBestBy order string/comparison function to sort the values 32 | if (comparing && getBestBy) { 33 | const valuesOriginal = 34 | typeof comparing === 'function' 35 | ? comparing(data) 36 | : data.map((item) => getComparingValue(item, comparing)); 37 | 38 | const valuesSorted = getSortedValues(valuesOriginal, getBestBy); 39 | 40 | // if bestValueIndices is -1, either there is no best or getBestBy is null 41 | bestValueIndices = getBestValueIndices(valuesOriginal, valuesSorted); 42 | } 43 | 44 | const isAllValuesEqual = bestValueIndices.length === data.length; 45 | 46 | const mergedBestCellStyle = { 47 | ...styles.bestCell, 48 | ...bestCellStyle 49 | }; 50 | 51 | const mergedBestCellTextStyle = { 52 | ...styles.bestCellText, 53 | ...bestCellTextStyle 54 | }; 55 | 56 | function getComparingValue(item, comparing) { 57 | return get(item, comparing); 58 | } 59 | 60 | function getSortedValues(valuesOriginal, getBestBy) { 61 | let valuesSorted = [...valuesOriginal]; 62 | console.log('valuesSorted: ', valuesSorted); 63 | if (typeof getBestBy === 'function') { 64 | valuesSorted.sort(getBestBy); 65 | } else if (getBestBy === 'asc') { 66 | valuesSorted.sort((a, b) => a - b); 67 | } else if (getBestBy === 'desc') { 68 | valuesSorted.sort((a, b) => b - a); 69 | } 70 | return valuesSorted; 71 | } 72 | 73 | function getBestValueIndices(valuesOriginal, valuesSorted) { 74 | const [bestValue] = valuesSorted; 75 | let bestValueIndices = []; 76 | if (bestValue !== undefined) { 77 | valuesOriginal.forEach((value, i) => { 78 | if (value === bestValue) { 79 | bestValueIndices.push(i); 80 | } 81 | }); 82 | } else { 83 | bestValueIndices = [-1]; 84 | } 85 | return bestValueIndices; 86 | } 87 | 88 | function renderHeaderCellContent() { 89 | return ( 90 | 108 | {typeof headerCellContent === 'function' ? ( 109 | headerCellContent() 110 | ) : ( 111 | {headerCellContent} 112 | )} 113 | 114 | ); 115 | } 116 | 117 | function renderTemplateCellContent(cellContent, item) { 118 | const comparingValue = getComparingValue(item, comparing); 119 | if (comparing && !comparingValue) { 120 | return '-'; 121 | } 122 | 123 | return comparingValue; 124 | } 125 | 126 | function renderCustomCellContent( 127 | cellContent, 128 | index, 129 | item, 130 | isBest, 131 | mergedBestCellTextStyle 132 | ) { 133 | let customCellContent = cellContent({ 134 | item, 135 | index, 136 | isBest, 137 | cellTextStyle: styles.cellText, 138 | bestCellTextStyle: mergedBestCellTextStyle 139 | }); 140 | 141 | if (React.isValidElement(customCellContent)) { 142 | return customCellContent; 143 | } 144 | 145 | return ( 146 | 153 | {renderTemplateCellContent(customCellContent, item)} 154 | 155 | ); 156 | } 157 | 158 | return ( 159 | 178 | {headerCellContent !== undefined && renderHeaderCellContent()} 179 | {mergeCells ? ( 180 | 198 | {cellContent && typeof cellContent === 'function' 199 | ? cellContent({ data }) 200 | : null} 201 | 202 | ) : ( 203 | data.map((item, index) => { 204 | const isBest = 205 | bestValueIndices.includes(index) && 206 | isHighlightBest && 207 | !isAllValuesEqual; 208 | return ( 209 | 218 | {typeof cellContent === 'function' ? ( 219 | renderCustomCellContent( 220 | cellContent, 221 | index, 222 | item, 223 | isBest, 224 | mergedBestCellTextStyle 225 | ) 226 | ) : ( 227 | 234 | {renderTemplateCellContent(cellContent, item)} 235 | 236 | )} 237 | 238 | ); 239 | }) 240 | )} 241 | 242 | ); 243 | }; 244 | 245 | const styles = StyleSheet.create({ 246 | row: { 247 | borderTopWidth: 1, 248 | borderColor: '#E5E5E5', 249 | flexDirection: 'row' 250 | }, 251 | fixedRow: { 252 | position: 'relative', 253 | zIndex: 100 254 | }, 255 | headerCell: { 256 | position: 'relative', 257 | zIndex: 10, 258 | backgroundColor: '#F9F9FB', 259 | paddingVertical: 11, 260 | paddingHorizontal: 12, 261 | borderRightWidth: 1, 262 | borderColor: '#E5E5E5' 263 | }, 264 | cell: { 265 | backgroundColor: '#FFF', 266 | paddingVertical: 10, 267 | paddingHorizontal: 14, 268 | borderRightWidth: 1, 269 | borderColor: '#E5E5E5' 270 | }, 271 | mergedCell: { 272 | justifyContent: 'center', 273 | paddingVertical: 10, 274 | paddingHorizontal: 12 275 | }, 276 | headerCellText: { 277 | fontSize: 20 278 | }, 279 | cellText: { 280 | fontSize: 20 281 | }, 282 | bestCell: { 283 | backgroundColor: 'rgba(255,236,170,0.2)' 284 | }, 285 | bestCellText: { 286 | color: '#F6571A', 287 | fontWeight: 'bold' 288 | } 289 | }); 290 | 291 | ComparisonTableRow.propTypes = { 292 | data: PropTypes.array, 293 | comparing: PropTypes.oneOfType([PropTypes.string, PropTypes.func]), 294 | getBestBy: PropTypes.oneOfType([ 295 | PropTypes.oneOf(['asc', 'desc']), 296 | PropTypes.func 297 | ]), 298 | headerCellContent: PropTypes.oneOfType([PropTypes.string, PropTypes.func]), 299 | headerCellStyle: PropTypes.object, 300 | cellContent: PropTypes.oneOfType([PropTypes.string, PropTypes.func]), 301 | cellStyle: PropTypes.object, 302 | rowStyle: PropTypes.object, 303 | bestCellStyle: PropTypes.object, 304 | bestCellTextStyle: PropTypes.object, 305 | isHighlightBest: PropTypes.bool, 306 | innerScrollX: PropTypes.object 307 | }; 308 | 309 | ComparisonTableRow.defaultProps = {}; 310 | 311 | export default ComparisonTableRow; 312 | -------------------------------------------------------------------------------- /ComparisonTableSection.js: -------------------------------------------------------------------------------- 1 | import React, { useState } from 'react'; 2 | import { 3 | Animated, 4 | Dimensions, 5 | Text, 6 | TouchableOpacity, 7 | View, 8 | StyleSheet 9 | } from 'react-native'; 10 | 11 | const ComparisonTableSection = (props) => { 12 | const { 13 | children, 14 | title, 15 | isHighlightBest, 16 | innerScrollX, 17 | scrollY, 18 | headerCellWidth, 19 | cellWidth 20 | } = props; 21 | 22 | return ( 23 | 24 | 40 | {title} 41 | 42 | {React.Children.map(children, (child, index) => 43 | child 44 | ? React.cloneElement(child, { 45 | isHighlightBest, 46 | innerScrollX, 47 | scrollY, 48 | headerCellWidth, 49 | cellWidth 50 | }) 51 | : null 52 | )} 53 | 54 | ); 55 | }; 56 | 57 | const styles = StyleSheet.create({ 58 | container: { flex: 1 }, 59 | header: { 60 | borderTopWidth: 1, 61 | borderColor: '#E5E5E5', 62 | width: Dimensions.get('window').width, 63 | height: 40, 64 | flexDirection: 'row', 65 | justifyContent: 'space-between', 66 | alignItems: 'center', 67 | paddingHorizontal: 12 68 | }, 69 | headerText: { 70 | fontWeight: 'bold' 71 | }, 72 | upIcon: { 73 | width: 24, 74 | height: 24 75 | } 76 | }); 77 | 78 | export default ComparisonTableSection; 79 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 Darold So 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-comparison-table` 2 | 3 | ![MIT License](https://img.shields.io/npm/l/@react-native-community/checkbox.svg) [![npm version](https://img.shields.io/npm/v/@react-native-community/checkbox.svg?style=flat)](https://www.npmjs.com/package/@react-native-community/checkbox) 4 | 5 | Comparison table with fixed header for React Native 6 | 7 | 8 | 9 | ## Getting started 10 | 11 | `yarn add react-native-comparison-table` 12 | 13 | or 14 | 15 | `npm install react-native-comparison-table --save` 16 | 17 | ## Usage 18 | 19 | ```js 20 | import { 21 | ComparisonTable, 22 | ComparisonTableSection, 23 | ComparisonTableRow 24 | } from 'react-native-comparison-table'; 25 | ``` 26 | 27 | ```js 28 | const phones = [ 29 | { 30 | id: 1, 31 | name: 'iPhone 11 Pro', 32 | image: require('./images/iphone11_pro.jpg'), 33 | screenSize: '5.8', 34 | display: 'Super Retina XDR display', 35 | height: '144.0', 36 | width: '71.4', 37 | depth: '8.1', 38 | weight: '188', 39 | videoPlayback: '18', 40 | audioPlayback: '65' 41 | }, 42 | { 43 | id: 2, 44 | name: 'iPhone 11', 45 | image: require('./images/iphone11.jpg'), 46 | screenSize: '6.1', 47 | display: 'Liquid Retina HD display', 48 | height: '150.9', 49 | width: '75.7', 50 | depth: '8.3', 51 | weight: '194', 52 | videoPlayback: '17', 53 | audioPlayback: '65' 54 | }, 55 | { 56 | id: 3, 57 | name: 'iPhone SE (2nd generation)', 58 | image: require('./images/iphoneSE.jpg'), 59 | screenSize: '4.7', 60 | display: 'Retina HD display', 61 | height: '138.4', 62 | width: '67.3', 63 | depth: '7.3', 64 | weight: '148', 65 | videoPlayback: '13', 66 | audioPlayback: '40' 67 | } 68 | ] 69 | 70 | 75 | 82 | ( 86 | 94 | )} 95 | cellStyle={styles.alignCenter} 96 | /> 97 | 98 | 103 | 108 | 114 | 115 | 116 | ``` 117 | 118 | Check out the [example project](examples) for more examples. 119 | 120 | ## Props 121 | 122 | ### `` 123 | 124 | | Prop name | Type | Description | Default | 125 | | --------------- | ------- | ------------------------------------------------------------------------------ | ------- | 126 | | isHighlightBest | boolean | If false the cell with the best compared value won't be highlighted | true | 127 | | headerCellWidth | number | Width of the header cell | 90 | 128 | | cellWidth | number | Width of the body cell | 156 | 129 | | height | number | The height of the table. It is required if the top ComparisonTableRow is fixed | 400 | 130 | 131 | ### `` 132 | 133 | | Prop name | Type | Description | Default | 134 | | --------- | ------ | ------------------------ | ------- | 135 | | title | string | The title of the section | | 136 | 137 | ### `` 138 | 139 | | Prop name | Type | Description | Default | 140 | | ----------------- | --------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------- | 141 | | data | array | Array of objects to compare. Data structure can refer to the example above. **Required** | | 142 | | comparing | string/function | string: The key of the object to compare.
function: need to return an array of data to compare, e.g. (data) => data.map(item => item.count).
**Required** if the best value need to be highlighted | | 143 | | getBestBy | string/function | string: **asc** or **desc**. The values will be sorted in specified order and the first item would be the best.
function: custom compare function be passed to `array.sort()`. The first item will be the best.
**Required** if the best value need to be highlighted | | 144 | | fixed | boolean | Fixes the row position. Normally would apply to the first row | false | 145 | | cellTextAlign | string | Setting the `textAlign` of the body cell text | left | 146 | | headerCellContent | string/function | The content of the header cell. Use function to render custom content. You can pass empty string if you want the header cell to be empty | | 147 | | headerCellStyle | object | The style of the header cell. | | 148 | | cellContent | function | Customise the content of body cell. By default the body cell will display the comparing value
`({ item, index, isBest, cellTextStyle, bestCellTextStyle }) => {}` | | 149 | | cellStyle | object | The style of the body cell. | | 150 | | rowStyle | object | The style of the row. | | 151 | | bestCellStyle | object | The style of the cell containing best value. Expected to apply to `` | | 152 | | bestCellTextStyle | object | The text style of the cell containing best value. Expected to apply to `` | | 153 | | mergeCells | boolean | Merges the body cells. Combining with empty `headerCellContent` and custom `cellContent`, you can create a row with custom content | false | 154 | 155 | ## Contributors 156 | 157 | Issues and pull requests are welcomed. For issues, please attach a screenshot showing the bug along with code snippet. 158 | 159 | ## License 160 | 161 | The library is released under the MIT licence. 162 | -------------------------------------------------------------------------------- /examples/.buckconfig: -------------------------------------------------------------------------------- 1 | 2 | [android] 3 | target = Google Inc.:Google APIs:23 4 | 5 | [maven_repositories] 6 | central = https://repo1.maven.org/maven2 7 | -------------------------------------------------------------------------------- /examples/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | extends: '@react-native-community', 4 | }; 5 | -------------------------------------------------------------------------------- /examples/.flowconfig: -------------------------------------------------------------------------------- 1 | [ignore] 2 | ; We fork some components by platform 3 | .*/*[.]android.js 4 | 5 | ; Ignore "BUCK" generated dirs 6 | /\.buckd/ 7 | 8 | ; Ignore polyfills 9 | node_modules/react-native/Libraries/polyfills/.* 10 | 11 | ; These should not be required directly 12 | ; require from fbjs/lib instead: require('fbjs/lib/warning') 13 | node_modules/warning/.* 14 | 15 | ; Flow doesn't support platforms 16 | .*/Libraries/Utilities/LoadingView.js 17 | 18 | [untyped] 19 | .*/node_modules/@react-native-community/cli/.*/.* 20 | 21 | [include] 22 | 23 | [libs] 24 | node_modules/react-native/interface.js 25 | node_modules/react-native/flow/ 26 | 27 | [options] 28 | emoji=true 29 | 30 | esproposal.optional_chaining=enable 31 | esproposal.nullish_coalescing=enable 32 | 33 | module.file_ext=.js 34 | module.file_ext=.json 35 | module.file_ext=.ios.js 36 | 37 | munge_underscores=true 38 | 39 | module.name_mapper='^react-native/\(.*\)$' -> '/node_modules/react-native/\1' 40 | 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\)$' -> '/node_modules/react-native/Libraries/Image/RelativeImageStub' 41 | 42 | suppress_type=$FlowIssue 43 | suppress_type=$FlowFixMe 44 | suppress_type=$FlowFixMeProps 45 | suppress_type=$FlowFixMeState 46 | 47 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\) 48 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\)?:? #[0-9]+ 49 | suppress_comment=\\(.\\|\n\\)*\\$FlowExpectedError 50 | 51 | [lints] 52 | sketchy-null-number=warn 53 | sketchy-null-mixed=warn 54 | sketchy-number=warn 55 | untyped-type-import=warn 56 | nonstrict-import=warn 57 | deprecated-type=warn 58 | unsafe-getters-setters=warn 59 | unnecessary-invariant=warn 60 | signature-verification-failure=warn 61 | deprecated-utility=error 62 | 63 | [strict] 64 | deprecated-type 65 | nonstrict-import 66 | sketchy-null 67 | unclear-type 68 | unsafe-getters-setters 69 | untyped-import 70 | untyped-type-import 71 | 72 | [version] 73 | ^0.122.0 74 | -------------------------------------------------------------------------------- /examples/.gitattributes: -------------------------------------------------------------------------------- 1 | *.pbxproj -text 2 | -------------------------------------------------------------------------------- /examples/.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 | 24 | # Android/IntelliJ 25 | # 26 | build/ 27 | .idea 28 | .gradle 29 | local.properties 30 | *.iml 31 | 32 | # node.js 33 | # 34 | node_modules/ 35 | npm-debug.log 36 | yarn-error.log 37 | 38 | # BUCK 39 | buck-out/ 40 | \.buckd/ 41 | *.keystore 42 | !debug.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 | -------------------------------------------------------------------------------- /examples/.watchmanconfig: -------------------------------------------------------------------------------- 1 | {} -------------------------------------------------------------------------------- /examples/App.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import { 3 | Image, 4 | SafeAreaView, 5 | StyleSheet, 6 | ScrollView, 7 | View, 8 | Text, 9 | useWindowDimensions 10 | } from 'react-native'; 11 | 12 | import { 13 | ComparisonTable, 14 | ComparisonTableSection, 15 | ComparisonTableRow 16 | } from 'react-native-comparison-table'; 17 | 18 | import phones from './phones'; 19 | 20 | const App = () => { 21 | const dimension = useWindowDimensions(); 22 | 23 | return ( 24 | 25 | Compare iPhones 26 | 27 | 32 | 39 | ( 43 | 51 | )} 52 | cellStyle={styles.alignCenter} 53 | /> 54 | 55 | ( 66 | 67 | 76 | {item.screenSize} 77 | 78 | 84 | {item.display} 85 | 86 | 87 | )} 88 | /> 89 | ( 93 | 94 | 99 | {item.cameraDesc} 100 | 101 | )} 102 | /> 103 | 104 | 105 | 110 | 115 | 120 | 126 | 127 | 128 | 134 | 140 | 141 | 142 | 143 | 144 | ); 145 | }; 146 | 147 | const styles = StyleSheet.create({ 148 | sectionContainer: { 149 | flex: 1 150 | }, 151 | sectionTitle: { 152 | fontSize: 24, 153 | fontWeight: '600', 154 | marginTop: 24, 155 | paddingHorizontal: 12 156 | }, 157 | tableContainer: { 158 | marginTop: 12 159 | }, 160 | rowShadow: { 161 | backgroundColor: '#fff', 162 | shadowColor: '#000', 163 | shadowOffset: { 164 | width: 0, 165 | height: 3 166 | }, 167 | shadowOpacity: 0.2, 168 | shadowRadius: 4, 169 | elevation: 4 170 | }, 171 | alignCenter: { 172 | alignItems: 'center' 173 | }, 174 | cameraImage: { 175 | width: 80, 176 | height: 100 177 | }, 178 | cameraDesc: { 179 | fontSize: 18, 180 | textAlign: 'center', 181 | marginVertical: 6 182 | } 183 | }); 184 | 185 | export default App; 186 | -------------------------------------------------------------------------------- /examples/__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 | -------------------------------------------------------------------------------- /examples/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.examples", 39 | ) 40 | 41 | android_resource( 42 | name = "res", 43 | package = "com.examples", 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 | -------------------------------------------------------------------------------- /examples/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. If none specified and 19 | * // "index.android.js" exists, it will be used. Otherwise "index.js" is 20 | * // default. Can be overridden with ENTRY_FILE environment variable. 21 | * entryFile: "index.android.js", 22 | * 23 | * // https://reactnative.dev/docs/performance#enable-the-ram-format 24 | * bundleCommand: "ram-bundle", 25 | * 26 | * // whether to bundle JS and assets in debug mode 27 | * bundleInDebug: false, 28 | * 29 | * // whether to bundle JS and assets in release mode 30 | * bundleInRelease: true, 31 | * 32 | * // whether to bundle JS and assets in another build variant (if configured). 33 | * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants 34 | * // The configuration property can be in the following formats 35 | * // 'bundleIn${productFlavor}${buildType}' 36 | * // 'bundleIn${buildType}' 37 | * // bundleInFreeDebug: true, 38 | * // bundleInPaidRelease: true, 39 | * // bundleInBeta: true, 40 | * 41 | * // whether to disable dev mode in custom build variants (by default only disabled in release) 42 | * // for example: to disable dev mode in the staging build type (if configured) 43 | * devDisabledInStaging: true, 44 | * // The configuration property can be in the following formats 45 | * // 'devDisabledIn${productFlavor}${buildType}' 46 | * // 'devDisabledIn${buildType}' 47 | * 48 | * // the root of your project, i.e. where "package.json" lives 49 | * root: "../../", 50 | * 51 | * // where to put the JS bundle asset in debug mode 52 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug", 53 | * 54 | * // where to put the JS bundle asset in release mode 55 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release", 56 | * 57 | * // where to put drawable resources / React Native assets, e.g. the ones you use via 58 | * // require('./image.png')), in debug mode 59 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug", 60 | * 61 | * // where to put drawable resources / React Native assets, e.g. the ones you use via 62 | * // require('./image.png')), in release mode 63 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release", 64 | * 65 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means 66 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to 67 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle 68 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/ 69 | * // for example, you might want to remove it from here. 70 | * inputExcludes: ["android/**", "ios/**"], 71 | * 72 | * // override which node gets called and with what additional arguments 73 | * nodeExecutableAndArgs: ["node"], 74 | * 75 | * // supply additional arguments to the packager 76 | * extraPackagerArgs: [] 77 | * ] 78 | */ 79 | 80 | project.ext.react = [ 81 | enableHermes: false, // clean and rebuild if changing 82 | ] 83 | 84 | apply from: "../../node_modules/react-native/react.gradle" 85 | 86 | /** 87 | * Set this to true to create two separate APKs instead of one: 88 | * - An APK that only works on ARM devices 89 | * - An APK that only works on x86 devices 90 | * The advantage is the size of the APK is reduced by about 4MB. 91 | * Upload all the APKs to the Play Store and people will download 92 | * the correct one based on the CPU architecture of their device. 93 | */ 94 | def enableSeparateBuildPerCPUArchitecture = false 95 | 96 | /** 97 | * Run Proguard to shrink the Java bytecode in release builds. 98 | */ 99 | def enableProguardInReleaseBuilds = false 100 | 101 | /** 102 | * The preferred build flavor of JavaScriptCore. 103 | * 104 | * For example, to use the international variant, you can use: 105 | * `def jscFlavor = 'org.webkit:android-jsc-intl:+'` 106 | * 107 | * The international variant includes ICU i18n library and necessary data 108 | * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that 109 | * give correct results when using with locales other than en-US. Note that 110 | * this variant is about 6MiB larger per architecture than default. 111 | */ 112 | def jscFlavor = 'org.webkit:android-jsc:+' 113 | 114 | /** 115 | * Whether to enable the Hermes VM. 116 | * 117 | * This should be set on project.ext.react and mirrored here. If it is not set 118 | * on project.ext.react, JavaScript will not be compiled to Hermes Bytecode 119 | * and the benefits of using Hermes will therefore be sharply reduced. 120 | */ 121 | def enableHermes = project.ext.react.get("enableHermes", false); 122 | 123 | android { 124 | compileSdkVersion rootProject.ext.compileSdkVersion 125 | 126 | compileOptions { 127 | sourceCompatibility JavaVersion.VERSION_1_8 128 | targetCompatibility JavaVersion.VERSION_1_8 129 | } 130 | 131 | defaultConfig { 132 | applicationId "com.examples" 133 | minSdkVersion rootProject.ext.minSdkVersion 134 | targetSdkVersion rootProject.ext.targetSdkVersion 135 | versionCode 1 136 | versionName "1.0" 137 | } 138 | splits { 139 | abi { 140 | reset() 141 | enable enableSeparateBuildPerCPUArchitecture 142 | universalApk false // If true, also generate a universal APK 143 | include "armeabi-v7a", "x86", "arm64-v8a", "x86_64" 144 | } 145 | } 146 | signingConfigs { 147 | debug { 148 | storeFile file('debug.keystore') 149 | storePassword 'android' 150 | keyAlias 'androiddebugkey' 151 | keyPassword 'android' 152 | } 153 | } 154 | buildTypes { 155 | debug { 156 | signingConfig signingConfigs.debug 157 | } 158 | release { 159 | // Caution! In production, you need to generate your own keystore file. 160 | // see https://reactnative.dev/docs/signed-apk-android. 161 | signingConfig signingConfigs.debug 162 | minifyEnabled enableProguardInReleaseBuilds 163 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" 164 | } 165 | } 166 | 167 | // applicationVariants are e.g. debug, release 168 | applicationVariants.all { variant -> 169 | variant.outputs.each { output -> 170 | // For each separate APK per architecture, set a unique version code as described here: 171 | // https://developer.android.com/studio/build/configure-apk-splits.html 172 | def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4] 173 | def abi = output.getFilter(OutputFile.ABI) 174 | if (abi != null) { // null for the universal-debug, universal-release variants 175 | output.versionCodeOverride = 176 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode 177 | } 178 | 179 | } 180 | } 181 | } 182 | 183 | dependencies { 184 | implementation fileTree(dir: "libs", include: ["*.jar"]) 185 | //noinspection GradleDynamicVersion 186 | implementation "com.facebook.react:react-native:+" // From node_modules 187 | 188 | implementation "androidx.swiperefreshlayout:swiperefreshlayout:1.0.0" 189 | 190 | debugImplementation("com.facebook.flipper:flipper:${FLIPPER_VERSION}") { 191 | exclude group:'com.facebook.fbjni' 192 | } 193 | 194 | debugImplementation("com.facebook.flipper:flipper-network-plugin:${FLIPPER_VERSION}") { 195 | exclude group:'com.facebook.flipper' 196 | } 197 | 198 | debugImplementation("com.facebook.flipper:flipper-fresco-plugin:${FLIPPER_VERSION}") { 199 | exclude group:'com.facebook.flipper' 200 | } 201 | 202 | if (enableHermes) { 203 | def hermesPath = "../../node_modules/hermes-engine/android/"; 204 | debugImplementation files(hermesPath + "hermes-debug.aar") 205 | releaseImplementation files(hermesPath + "hermes-release.aar") 206 | } else { 207 | implementation jscFlavor 208 | } 209 | } 210 | 211 | // Run this once to be able to run the application with BUCK 212 | // puts all compile dependencies into folder libs for BUCK to use 213 | task copyDownloadableDepsToLibs(type: Copy) { 214 | from configurations.compile 215 | into 'libs' 216 | } 217 | 218 | apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project) 219 | -------------------------------------------------------------------------------- /examples/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 | -------------------------------------------------------------------------------- /examples/android/app/debug.keystore: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/debug.keystore -------------------------------------------------------------------------------- /examples/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 | -------------------------------------------------------------------------------- /examples/android/app/src/debug/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /examples/android/app/src/debug/java/com/examples/ReactNativeFlipper.java: -------------------------------------------------------------------------------- 1 | /** 2 | * Copyright (c) Facebook, Inc. and its affiliates. 3 | * 4 | *

This source code is licensed under the MIT license found in the LICENSE file in the root 5 | * directory of this source tree. 6 | */ 7 | package com.examples; 8 | 9 | import android.content.Context; 10 | import com.facebook.flipper.android.AndroidFlipperClient; 11 | import com.facebook.flipper.android.utils.FlipperUtils; 12 | import com.facebook.flipper.core.FlipperClient; 13 | import com.facebook.flipper.plugins.crashreporter.CrashReporterPlugin; 14 | import com.facebook.flipper.plugins.databases.DatabasesFlipperPlugin; 15 | import com.facebook.flipper.plugins.fresco.FrescoFlipperPlugin; 16 | import com.facebook.flipper.plugins.inspector.DescriptorMapping; 17 | import com.facebook.flipper.plugins.inspector.InspectorFlipperPlugin; 18 | import com.facebook.flipper.plugins.network.FlipperOkhttpInterceptor; 19 | import com.facebook.flipper.plugins.network.NetworkFlipperPlugin; 20 | import com.facebook.flipper.plugins.react.ReactFlipperPlugin; 21 | import com.facebook.flipper.plugins.sharedpreferences.SharedPreferencesFlipperPlugin; 22 | import com.facebook.react.ReactInstanceManager; 23 | import com.facebook.react.bridge.ReactContext; 24 | import com.facebook.react.modules.network.NetworkingModule; 25 | import okhttp3.OkHttpClient; 26 | 27 | public class ReactNativeFlipper { 28 | public static void initializeFlipper(Context context, ReactInstanceManager reactInstanceManager) { 29 | if (FlipperUtils.shouldEnableFlipper(context)) { 30 | final FlipperClient client = AndroidFlipperClient.getInstance(context); 31 | 32 | client.addPlugin(new InspectorFlipperPlugin(context, DescriptorMapping.withDefaults())); 33 | client.addPlugin(new ReactFlipperPlugin()); 34 | client.addPlugin(new DatabasesFlipperPlugin(context)); 35 | client.addPlugin(new SharedPreferencesFlipperPlugin(context)); 36 | client.addPlugin(CrashReporterPlugin.getInstance()); 37 | 38 | NetworkFlipperPlugin networkFlipperPlugin = new NetworkFlipperPlugin(); 39 | NetworkingModule.setCustomClientBuilder( 40 | new NetworkingModule.CustomClientBuilder() { 41 | @Override 42 | public void apply(OkHttpClient.Builder builder) { 43 | builder.addNetworkInterceptor(new FlipperOkhttpInterceptor(networkFlipperPlugin)); 44 | } 45 | }); 46 | client.addPlugin(networkFlipperPlugin); 47 | client.start(); 48 | 49 | // Fresco Plugin needs to ensure that ImagePipelineFactory is initialized 50 | // Hence we run if after all native modules have been initialized 51 | ReactContext reactContext = reactInstanceManager.getCurrentReactContext(); 52 | if (reactContext == null) { 53 | reactInstanceManager.addReactInstanceEventListener( 54 | new ReactInstanceManager.ReactInstanceEventListener() { 55 | @Override 56 | public void onReactContextInitialized(ReactContext reactContext) { 57 | reactInstanceManager.removeReactInstanceEventListener(this); 58 | reactContext.runOnNativeModulesQueueThread( 59 | new Runnable() { 60 | @Override 61 | public void run() { 62 | client.addPlugin(new FrescoFlipperPlugin()); 63 | } 64 | }); 65 | } 66 | }); 67 | } else { 68 | client.addPlugin(new FrescoFlipperPlugin()); 69 | } 70 | } 71 | } 72 | } 73 | -------------------------------------------------------------------------------- /examples/android/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 3 | 4 | 5 | 6 | 13 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | -------------------------------------------------------------------------------- /examples/android/app/src/main/java/com/examples/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.examples; 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. This is used to schedule 9 | * rendering of the component. 10 | */ 11 | @Override 12 | protected String getMainComponentName() { 13 | return "examples"; 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /examples/android/app/src/main/java/com/examples/MainApplication.java: -------------------------------------------------------------------------------- 1 | package com.examples; 2 | 3 | import android.app.Application; 4 | import android.content.Context; 5 | import com.facebook.react.PackageList; 6 | import com.facebook.react.ReactApplication; 7 | import com.facebook.react.ReactInstanceManager; 8 | import com.facebook.react.ReactNativeHost; 9 | import com.facebook.react.ReactPackage; 10 | import com.facebook.soloader.SoLoader; 11 | import java.lang.reflect.InvocationTargetException; 12 | import java.util.List; 13 | 14 | public class MainApplication extends Application implements ReactApplication { 15 | 16 | private final ReactNativeHost mReactNativeHost = 17 | new ReactNativeHost(this) { 18 | @Override 19 | public boolean getUseDeveloperSupport() { 20 | return BuildConfig.DEBUG; 21 | } 22 | 23 | @Override 24 | protected List getPackages() { 25 | @SuppressWarnings("UnnecessaryLocalVariable") 26 | List packages = new PackageList(this).getPackages(); 27 | // Packages that cannot be autolinked yet can be added manually here, for example: 28 | // packages.add(new MyReactNativePackage()); 29 | return packages; 30 | } 31 | 32 | @Override 33 | protected String getJSMainModuleName() { 34 | return "index"; 35 | } 36 | }; 37 | 38 | @Override 39 | public ReactNativeHost getReactNativeHost() { 40 | return mReactNativeHost; 41 | } 42 | 43 | @Override 44 | public void onCreate() { 45 | super.onCreate(); 46 | SoLoader.init(this, /* native exopackage */ false); 47 | initializeFlipper(this, getReactNativeHost().getReactInstanceManager()); 48 | } 49 | 50 | /** 51 | * Loads Flipper in React Native templates. Call this in the onCreate method with something like 52 | * initializeFlipper(this, getReactNativeHost().getReactInstanceManager()); 53 | * 54 | * @param context 55 | * @param reactInstanceManager 56 | */ 57 | private static void initializeFlipper( 58 | Context context, ReactInstanceManager reactInstanceManager) { 59 | if (BuildConfig.DEBUG) { 60 | try { 61 | /* 62 | We use reflection here to pick up the class that initializes Flipper, 63 | since Flipper library is not available in release mode 64 | */ 65 | Class aClass = Class.forName("com.examples.ReactNativeFlipper"); 66 | aClass 67 | .getMethod("initializeFlipper", Context.class, ReactInstanceManager.class) 68 | .invoke(null, context, reactInstanceManager); 69 | } catch (ClassNotFoundException e) { 70 | e.printStackTrace(); 71 | } catch (NoSuchMethodException e) { 72 | e.printStackTrace(); 73 | } catch (IllegalAccessException e) { 74 | e.printStackTrace(); 75 | } catch (InvocationTargetException e) { 76 | e.printStackTrace(); 77 | } 78 | } 79 | } 80 | } 81 | -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png -------------------------------------------------------------------------------- /examples/android/app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | examples 3 | 4 | -------------------------------------------------------------------------------- /examples/android/app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 8 | 9 | 10 | -------------------------------------------------------------------------------- /examples/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 = "29.0.2" 6 | minSdkVersion = 16 7 | compileSdkVersion = 29 8 | targetSdkVersion = 29 9 | } 10 | repositories { 11 | google() 12 | jcenter() 13 | } 14 | dependencies { 15 | classpath("com.android.tools.build:gradle:3.5.3") 16 | // NOTE: Do not place your application dependencies here; they belong 17 | // in the individual module build.gradle files 18 | } 19 | } 20 | 21 | allprojects { 22 | repositories { 23 | mavenLocal() 24 | maven { 25 | // All of React Native (JS, Obj-C sources, Android binaries) is installed from npm 26 | url("$rootDir/../node_modules/react-native/android") 27 | } 28 | maven { 29 | // Android JSC is installed from npm 30 | url("$rootDir/../node_modules/jsc-android/dist") 31 | } 32 | 33 | google() 34 | jcenter() 35 | maven { url 'https://www.jitpack.io' } 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /examples/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 | # AndroidX package structure to make it clearer which packages are bundled with the 21 | # Android operating system, and which are packaged with your app's APK 22 | # https://developer.android.com/topic/libraries/support-library/androidx-rn 23 | android.useAndroidX=true 24 | # Automatically convert third-party libraries to use AndroidX 25 | android.enableJetifier=true 26 | 27 | # Version of flipper SDK to use with React Native 28 | FLIPPER_VERSION=0.37.0 29 | -------------------------------------------------------------------------------- /examples/android/gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/android/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /examples/android/gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | distributionBase=GRADLE_USER_HOME 2 | distributionPath=wrapper/dists 3 | distributionUrl=https\://services.gradle.org/distributions/gradle-6.2-all.zip 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | -------------------------------------------------------------------------------- /examples/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 | # https://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 or MSYS, switch paths to Windows format before running java 129 | if [ "$cygwin" = "true" -o "$msys" = "true" ] ; 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=`expr $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 | exec "$JAVACMD" "$@" 184 | -------------------------------------------------------------------------------- /examples/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 https://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 Resolve any "." and ".." in APP_HOME to make it shorter. 33 | for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi 34 | 35 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 36 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" 37 | 38 | @rem Find java.exe 39 | if defined JAVA_HOME goto findJavaFromJavaHome 40 | 41 | set JAVA_EXE=java.exe 42 | %JAVA_EXE% -version >NUL 2>&1 43 | if "%ERRORLEVEL%" == "0" goto init 44 | 45 | echo. 46 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 47 | echo. 48 | echo Please set the JAVA_HOME variable in your environment to match the 49 | echo location of your Java installation. 50 | 51 | goto fail 52 | 53 | :findJavaFromJavaHome 54 | set JAVA_HOME=%JAVA_HOME:"=% 55 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 56 | 57 | if exist "%JAVA_EXE%" goto init 58 | 59 | echo. 60 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 61 | echo. 62 | echo Please set the JAVA_HOME variable in your environment to match the 63 | echo location of your Java installation. 64 | 65 | goto fail 66 | 67 | :init 68 | @rem Get command-line arguments, handling Windows variants 69 | 70 | if not "%OS%" == "Windows_NT" goto win9xME_args 71 | 72 | :win9xME_args 73 | @rem Slurp the command line arguments. 74 | set CMD_LINE_ARGS= 75 | set _SKIP=2 76 | 77 | :win9xME_args_slurp 78 | if "x%~1" == "x" goto execute 79 | 80 | set CMD_LINE_ARGS=%* 81 | 82 | :execute 83 | @rem Setup the command line 84 | 85 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 86 | 87 | @rem Execute Gradle 88 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% 89 | 90 | :end 91 | @rem End local scope for the variables with windows NT shell 92 | if "%ERRORLEVEL%"=="0" goto mainEnd 93 | 94 | :fail 95 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 96 | rem the _cmd.exe /c_ return code! 97 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 98 | exit /b 1 99 | 100 | :mainEnd 101 | if "%OS%"=="Windows_NT" endlocal 102 | 103 | :omega 104 | -------------------------------------------------------------------------------- /examples/android/settings.gradle: -------------------------------------------------------------------------------- 1 | rootProject.name = 'examples' 2 | apply from: file("../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesSettingsGradle(settings) 3 | include ':app' 4 | -------------------------------------------------------------------------------- /examples/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "examples", 3 | "displayName": "examples" 4 | } -------------------------------------------------------------------------------- /examples/babel.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | presets: ['module:metro-react-native-babel-preset'], 3 | }; 4 | -------------------------------------------------------------------------------- /examples/images/iphone11.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphone11.jpg -------------------------------------------------------------------------------- /examples/images/iphone11_cam.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphone11_cam.jpg -------------------------------------------------------------------------------- /examples/images/iphone11_pro.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphone11_pro.jpg -------------------------------------------------------------------------------- /examples/images/iphone11_pro_cam.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphone11_pro_cam.jpg -------------------------------------------------------------------------------- /examples/images/iphoneSE.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphoneSE.jpg -------------------------------------------------------------------------------- /examples/images/iphoneSE_cam.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/daroldso/react-native-comparison-table/5fbb5f67f280c848a8cfd4154abcfbd98ef03509/examples/images/iphoneSE_cam.jpg -------------------------------------------------------------------------------- /examples/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 | AppRegistry.registerComponent(appName, () => App); 10 | -------------------------------------------------------------------------------- /examples/ios/Podfile: -------------------------------------------------------------------------------- 1 | require_relative '../node_modules/react-native/scripts/react_native_pods' 2 | require_relative '../node_modules/@react-native-community/cli-platform-ios/native_modules' 3 | 4 | platform :ios, '10.0' 5 | 6 | target 'examples' do 7 | config = use_native_modules! 8 | 9 | use_react_native!(:path => config["reactNativePath"]) 10 | 11 | target 'examplesTests' do 12 | inherit! :complete 13 | # Pods for testing 14 | end 15 | 16 | # Enables Flipper. 17 | # 18 | # Note that if you have use_frameworks! enabled, Flipper will not work and 19 | # you should disable these next few lines. 20 | use_flipper! 21 | post_install do |installer| 22 | flipper_post_install(installer) 23 | end 24 | end 25 | 26 | target 'examples-tvOS' do 27 | # Pods for examples-tvOS 28 | 29 | target 'examples-tvOSTests' do 30 | inherit! :search_paths 31 | # Pods for testing 32 | end 33 | end 34 | -------------------------------------------------------------------------------- /examples/ios/Podfile.lock: -------------------------------------------------------------------------------- 1 | PODS: 2 | - boost-for-react-native (1.63.0) 3 | - CocoaAsyncSocket (7.6.4) 4 | - CocoaLibEvent (1.0.0) 5 | - DoubleConversion (1.1.6) 6 | - FBLazyVector (0.63.0) 7 | - FBReactNativeSpec (0.63.0): 8 | - Folly (= 2020.01.13.00) 9 | - RCTRequired (= 0.63.0) 10 | - RCTTypeSafety (= 0.63.0) 11 | - React-Core (= 0.63.0) 12 | - React-jsi (= 0.63.0) 13 | - ReactCommon/turbomodule/core (= 0.63.0) 14 | - Flipper (0.41.5): 15 | - Flipper-Folly (~> 2.2) 16 | - Flipper-RSocket (~> 1.1) 17 | - Flipper-DoubleConversion (1.1.7) 18 | - Flipper-Folly (2.2.0): 19 | - boost-for-react-native 20 | - CocoaLibEvent (~> 1.0) 21 | - Flipper-DoubleConversion 22 | - Flipper-Glog 23 | - OpenSSL-Universal (= 1.0.2.19) 24 | - Flipper-Glog (0.3.6) 25 | - Flipper-PeerTalk (0.0.4) 26 | - Flipper-RSocket (1.1.0): 27 | - Flipper-Folly (~> 2.2) 28 | - FlipperKit (0.41.5): 29 | - FlipperKit/Core (= 0.41.5) 30 | - FlipperKit/Core (0.41.5): 31 | - Flipper (~> 0.41.5) 32 | - FlipperKit/CppBridge 33 | - FlipperKit/FBCxxFollyDynamicConvert 34 | - FlipperKit/FBDefines 35 | - FlipperKit/FKPortForwarding 36 | - FlipperKit/CppBridge (0.41.5): 37 | - Flipper (~> 0.41.5) 38 | - FlipperKit/FBCxxFollyDynamicConvert (0.41.5): 39 | - Flipper-Folly (~> 2.2) 40 | - FlipperKit/FBDefines (0.41.5) 41 | - FlipperKit/FKPortForwarding (0.41.5): 42 | - CocoaAsyncSocket (~> 7.6) 43 | - Flipper-PeerTalk (~> 0.0.4) 44 | - FlipperKit/FlipperKitHighlightOverlay (0.41.5) 45 | - FlipperKit/FlipperKitLayoutPlugin (0.41.5): 46 | - FlipperKit/Core 47 | - FlipperKit/FlipperKitHighlightOverlay 48 | - FlipperKit/FlipperKitLayoutTextSearchable 49 | - YogaKit (~> 1.18) 50 | - FlipperKit/FlipperKitLayoutTextSearchable (0.41.5) 51 | - FlipperKit/FlipperKitNetworkPlugin (0.41.5): 52 | - FlipperKit/Core 53 | - FlipperKit/FlipperKitReactPlugin (0.41.5): 54 | - FlipperKit/Core 55 | - FlipperKit/FlipperKitUserDefaultsPlugin (0.41.5): 56 | - FlipperKit/Core 57 | - FlipperKit/SKIOSNetworkPlugin (0.41.5): 58 | - FlipperKit/Core 59 | - FlipperKit/FlipperKitNetworkPlugin 60 | - Folly (2020.01.13.00): 61 | - boost-for-react-native 62 | - DoubleConversion 63 | - Folly/Default (= 2020.01.13.00) 64 | - glog 65 | - Folly/Default (2020.01.13.00): 66 | - boost-for-react-native 67 | - DoubleConversion 68 | - glog 69 | - glog (0.3.5) 70 | - OpenSSL-Universal (1.0.2.19): 71 | - OpenSSL-Universal/Static (= 1.0.2.19) 72 | - OpenSSL-Universal/Static (1.0.2.19) 73 | - RCTRequired (0.63.0) 74 | - RCTTypeSafety (0.63.0): 75 | - FBLazyVector (= 0.63.0) 76 | - Folly (= 2020.01.13.00) 77 | - RCTRequired (= 0.63.0) 78 | - React-Core (= 0.63.0) 79 | - React (0.63.0): 80 | - React-Core (= 0.63.0) 81 | - React-Core/DevSupport (= 0.63.0) 82 | - React-Core/RCTWebSocket (= 0.63.0) 83 | - React-RCTActionSheet (= 0.63.0) 84 | - React-RCTAnimation (= 0.63.0) 85 | - React-RCTBlob (= 0.63.0) 86 | - React-RCTImage (= 0.63.0) 87 | - React-RCTLinking (= 0.63.0) 88 | - React-RCTNetwork (= 0.63.0) 89 | - React-RCTSettings (= 0.63.0) 90 | - React-RCTText (= 0.63.0) 91 | - React-RCTVibration (= 0.63.0) 92 | - React-callinvoker (0.63.0) 93 | - React-Core (0.63.0): 94 | - Folly (= 2020.01.13.00) 95 | - glog 96 | - React-Core/Default (= 0.63.0) 97 | - React-cxxreact (= 0.63.0) 98 | - React-jsi (= 0.63.0) 99 | - React-jsiexecutor (= 0.63.0) 100 | - Yoga 101 | - React-Core/CoreModulesHeaders (0.63.0): 102 | - Folly (= 2020.01.13.00) 103 | - glog 104 | - React-Core/Default 105 | - React-cxxreact (= 0.63.0) 106 | - React-jsi (= 0.63.0) 107 | - React-jsiexecutor (= 0.63.0) 108 | - Yoga 109 | - React-Core/Default (0.63.0): 110 | - Folly (= 2020.01.13.00) 111 | - glog 112 | - React-cxxreact (= 0.63.0) 113 | - React-jsi (= 0.63.0) 114 | - React-jsiexecutor (= 0.63.0) 115 | - Yoga 116 | - React-Core/DevSupport (0.63.0): 117 | - Folly (= 2020.01.13.00) 118 | - glog 119 | - React-Core/Default (= 0.63.0) 120 | - React-Core/RCTWebSocket (= 0.63.0) 121 | - React-cxxreact (= 0.63.0) 122 | - React-jsi (= 0.63.0) 123 | - React-jsiexecutor (= 0.63.0) 124 | - React-jsinspector (= 0.63.0) 125 | - Yoga 126 | - React-Core/RCTActionSheetHeaders (0.63.0): 127 | - Folly (= 2020.01.13.00) 128 | - glog 129 | - React-Core/Default 130 | - React-cxxreact (= 0.63.0) 131 | - React-jsi (= 0.63.0) 132 | - React-jsiexecutor (= 0.63.0) 133 | - Yoga 134 | - React-Core/RCTAnimationHeaders (0.63.0): 135 | - Folly (= 2020.01.13.00) 136 | - glog 137 | - React-Core/Default 138 | - React-cxxreact (= 0.63.0) 139 | - React-jsi (= 0.63.0) 140 | - React-jsiexecutor (= 0.63.0) 141 | - Yoga 142 | - React-Core/RCTBlobHeaders (0.63.0): 143 | - Folly (= 2020.01.13.00) 144 | - glog 145 | - React-Core/Default 146 | - React-cxxreact (= 0.63.0) 147 | - React-jsi (= 0.63.0) 148 | - React-jsiexecutor (= 0.63.0) 149 | - Yoga 150 | - React-Core/RCTImageHeaders (0.63.0): 151 | - Folly (= 2020.01.13.00) 152 | - glog 153 | - React-Core/Default 154 | - React-cxxreact (= 0.63.0) 155 | - React-jsi (= 0.63.0) 156 | - React-jsiexecutor (= 0.63.0) 157 | - Yoga 158 | - React-Core/RCTLinkingHeaders (0.63.0): 159 | - Folly (= 2020.01.13.00) 160 | - glog 161 | - React-Core/Default 162 | - React-cxxreact (= 0.63.0) 163 | - React-jsi (= 0.63.0) 164 | - React-jsiexecutor (= 0.63.0) 165 | - Yoga 166 | - React-Core/RCTNetworkHeaders (0.63.0): 167 | - Folly (= 2020.01.13.00) 168 | - glog 169 | - React-Core/Default 170 | - React-cxxreact (= 0.63.0) 171 | - React-jsi (= 0.63.0) 172 | - React-jsiexecutor (= 0.63.0) 173 | - Yoga 174 | - React-Core/RCTSettingsHeaders (0.63.0): 175 | - Folly (= 2020.01.13.00) 176 | - glog 177 | - React-Core/Default 178 | - React-cxxreact (= 0.63.0) 179 | - React-jsi (= 0.63.0) 180 | - React-jsiexecutor (= 0.63.0) 181 | - Yoga 182 | - React-Core/RCTTextHeaders (0.63.0): 183 | - Folly (= 2020.01.13.00) 184 | - glog 185 | - React-Core/Default 186 | - React-cxxreact (= 0.63.0) 187 | - React-jsi (= 0.63.0) 188 | - React-jsiexecutor (= 0.63.0) 189 | - Yoga 190 | - React-Core/RCTVibrationHeaders (0.63.0): 191 | - Folly (= 2020.01.13.00) 192 | - glog 193 | - React-Core/Default 194 | - React-cxxreact (= 0.63.0) 195 | - React-jsi (= 0.63.0) 196 | - React-jsiexecutor (= 0.63.0) 197 | - Yoga 198 | - React-Core/RCTWebSocket (0.63.0): 199 | - Folly (= 2020.01.13.00) 200 | - glog 201 | - React-Core/Default (= 0.63.0) 202 | - React-cxxreact (= 0.63.0) 203 | - React-jsi (= 0.63.0) 204 | - React-jsiexecutor (= 0.63.0) 205 | - Yoga 206 | - React-CoreModules (0.63.0): 207 | - FBReactNativeSpec (= 0.63.0) 208 | - Folly (= 2020.01.13.00) 209 | - RCTTypeSafety (= 0.63.0) 210 | - React-Core/CoreModulesHeaders (= 0.63.0) 211 | - React-jsi (= 0.63.0) 212 | - React-RCTImage (= 0.63.0) 213 | - ReactCommon/turbomodule/core (= 0.63.0) 214 | - React-cxxreact (0.63.0): 215 | - boost-for-react-native (= 1.63.0) 216 | - DoubleConversion 217 | - Folly (= 2020.01.13.00) 218 | - glog 219 | - React-callinvoker (= 0.63.0) 220 | - React-jsinspector (= 0.63.0) 221 | - React-jsi (0.63.0): 222 | - boost-for-react-native (= 1.63.0) 223 | - DoubleConversion 224 | - Folly (= 2020.01.13.00) 225 | - glog 226 | - React-jsi/Default (= 0.63.0) 227 | - React-jsi/Default (0.63.0): 228 | - boost-for-react-native (= 1.63.0) 229 | - DoubleConversion 230 | - Folly (= 2020.01.13.00) 231 | - glog 232 | - React-jsiexecutor (0.63.0): 233 | - DoubleConversion 234 | - Folly (= 2020.01.13.00) 235 | - glog 236 | - React-cxxreact (= 0.63.0) 237 | - React-jsi (= 0.63.0) 238 | - React-jsinspector (0.63.0) 239 | - React-RCTActionSheet (0.63.0): 240 | - React-Core/RCTActionSheetHeaders (= 0.63.0) 241 | - React-RCTAnimation (0.63.0): 242 | - FBReactNativeSpec (= 0.63.0) 243 | - Folly (= 2020.01.13.00) 244 | - RCTTypeSafety (= 0.63.0) 245 | - React-Core/RCTAnimationHeaders (= 0.63.0) 246 | - React-jsi (= 0.63.0) 247 | - ReactCommon/turbomodule/core (= 0.63.0) 248 | - React-RCTBlob (0.63.0): 249 | - FBReactNativeSpec (= 0.63.0) 250 | - Folly (= 2020.01.13.00) 251 | - React-Core/RCTBlobHeaders (= 0.63.0) 252 | - React-Core/RCTWebSocket (= 0.63.0) 253 | - React-jsi (= 0.63.0) 254 | - React-RCTNetwork (= 0.63.0) 255 | - ReactCommon/turbomodule/core (= 0.63.0) 256 | - React-RCTImage (0.63.0): 257 | - FBReactNativeSpec (= 0.63.0) 258 | - Folly (= 2020.01.13.00) 259 | - RCTTypeSafety (= 0.63.0) 260 | - React-Core/RCTImageHeaders (= 0.63.0) 261 | - React-jsi (= 0.63.0) 262 | - React-RCTNetwork (= 0.63.0) 263 | - ReactCommon/turbomodule/core (= 0.63.0) 264 | - React-RCTLinking (0.63.0): 265 | - FBReactNativeSpec (= 0.63.0) 266 | - React-Core/RCTLinkingHeaders (= 0.63.0) 267 | - React-jsi (= 0.63.0) 268 | - ReactCommon/turbomodule/core (= 0.63.0) 269 | - React-RCTNetwork (0.63.0): 270 | - FBReactNativeSpec (= 0.63.0) 271 | - Folly (= 2020.01.13.00) 272 | - RCTTypeSafety (= 0.63.0) 273 | - React-Core/RCTNetworkHeaders (= 0.63.0) 274 | - React-jsi (= 0.63.0) 275 | - ReactCommon/turbomodule/core (= 0.63.0) 276 | - React-RCTSettings (0.63.0): 277 | - FBReactNativeSpec (= 0.63.0) 278 | - Folly (= 2020.01.13.00) 279 | - RCTTypeSafety (= 0.63.0) 280 | - React-Core/RCTSettingsHeaders (= 0.63.0) 281 | - React-jsi (= 0.63.0) 282 | - ReactCommon/turbomodule/core (= 0.63.0) 283 | - React-RCTText (0.63.0): 284 | - React-Core/RCTTextHeaders (= 0.63.0) 285 | - React-RCTVibration (0.63.0): 286 | - FBReactNativeSpec (= 0.63.0) 287 | - Folly (= 2020.01.13.00) 288 | - React-Core/RCTVibrationHeaders (= 0.63.0) 289 | - React-jsi (= 0.63.0) 290 | - ReactCommon/turbomodule/core (= 0.63.0) 291 | - ReactCommon/turbomodule/core (0.63.0): 292 | - DoubleConversion 293 | - Folly (= 2020.01.13.00) 294 | - glog 295 | - React-callinvoker (= 0.63.0) 296 | - React-Core (= 0.63.0) 297 | - React-cxxreact (= 0.63.0) 298 | - React-jsi (= 0.63.0) 299 | - Yoga (1.14.0) 300 | - YogaKit (1.18.1): 301 | - Yoga (~> 1.14) 302 | 303 | DEPENDENCIES: 304 | - DoubleConversion (from `../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec`) 305 | - FBLazyVector (from `../node_modules/react-native/Libraries/FBLazyVector`) 306 | - FBReactNativeSpec (from `../node_modules/react-native/Libraries/FBReactNativeSpec`) 307 | - Flipper (~> 0.41.1) 308 | - Flipper-DoubleConversion (= 1.1.7) 309 | - Flipper-Folly (~> 2.2) 310 | - Flipper-Glog (= 0.3.6) 311 | - Flipper-PeerTalk (~> 0.0.4) 312 | - Flipper-RSocket (~> 1.1) 313 | - FlipperKit (~> 0.41.1) 314 | - FlipperKit/Core (~> 0.41.1) 315 | - FlipperKit/CppBridge (~> 0.41.1) 316 | - FlipperKit/FBCxxFollyDynamicConvert (~> 0.41.1) 317 | - FlipperKit/FBDefines (~> 0.41.1) 318 | - FlipperKit/FKPortForwarding (~> 0.41.1) 319 | - FlipperKit/FlipperKitHighlightOverlay (~> 0.41.1) 320 | - FlipperKit/FlipperKitLayoutPlugin (~> 0.41.1) 321 | - FlipperKit/FlipperKitLayoutTextSearchable (~> 0.41.1) 322 | - FlipperKit/FlipperKitNetworkPlugin (~> 0.41.1) 323 | - FlipperKit/FlipperKitReactPlugin (~> 0.41.1) 324 | - FlipperKit/FlipperKitUserDefaultsPlugin (~> 0.41.1) 325 | - FlipperKit/SKIOSNetworkPlugin (~> 0.41.1) 326 | - Folly (from `../node_modules/react-native/third-party-podspecs/Folly.podspec`) 327 | - glog (from `../node_modules/react-native/third-party-podspecs/glog.podspec`) 328 | - RCTRequired (from `../node_modules/react-native/Libraries/RCTRequired`) 329 | - RCTTypeSafety (from `../node_modules/react-native/Libraries/TypeSafety`) 330 | - React (from `../node_modules/react-native/`) 331 | - React-callinvoker (from `../node_modules/react-native/ReactCommon/callinvoker`) 332 | - React-Core (from `../node_modules/react-native/`) 333 | - React-Core/DevSupport (from `../node_modules/react-native/`) 334 | - React-Core/RCTWebSocket (from `../node_modules/react-native/`) 335 | - React-CoreModules (from `../node_modules/react-native/React/CoreModules`) 336 | - React-cxxreact (from `../node_modules/react-native/ReactCommon/cxxreact`) 337 | - React-jsi (from `../node_modules/react-native/ReactCommon/jsi`) 338 | - React-jsiexecutor (from `../node_modules/react-native/ReactCommon/jsiexecutor`) 339 | - React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`) 340 | - React-RCTActionSheet (from `../node_modules/react-native/Libraries/ActionSheetIOS`) 341 | - React-RCTAnimation (from `../node_modules/react-native/Libraries/NativeAnimation`) 342 | - React-RCTBlob (from `../node_modules/react-native/Libraries/Blob`) 343 | - React-RCTImage (from `../node_modules/react-native/Libraries/Image`) 344 | - React-RCTLinking (from `../node_modules/react-native/Libraries/LinkingIOS`) 345 | - React-RCTNetwork (from `../node_modules/react-native/Libraries/Network`) 346 | - React-RCTSettings (from `../node_modules/react-native/Libraries/Settings`) 347 | - React-RCTText (from `../node_modules/react-native/Libraries/Text`) 348 | - React-RCTVibration (from `../node_modules/react-native/Libraries/Vibration`) 349 | - ReactCommon/turbomodule/core (from `../node_modules/react-native/ReactCommon`) 350 | - Yoga (from `../node_modules/react-native/ReactCommon/yoga`) 351 | 352 | SPEC REPOS: 353 | trunk: 354 | - boost-for-react-native 355 | - CocoaAsyncSocket 356 | - CocoaLibEvent 357 | - Flipper 358 | - Flipper-DoubleConversion 359 | - Flipper-Folly 360 | - Flipper-Glog 361 | - Flipper-PeerTalk 362 | - Flipper-RSocket 363 | - FlipperKit 364 | - OpenSSL-Universal 365 | - YogaKit 366 | 367 | EXTERNAL SOURCES: 368 | DoubleConversion: 369 | :podspec: "../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec" 370 | FBLazyVector: 371 | :path: "../node_modules/react-native/Libraries/FBLazyVector" 372 | FBReactNativeSpec: 373 | :path: "../node_modules/react-native/Libraries/FBReactNativeSpec" 374 | Folly: 375 | :podspec: "../node_modules/react-native/third-party-podspecs/Folly.podspec" 376 | glog: 377 | :podspec: "../node_modules/react-native/third-party-podspecs/glog.podspec" 378 | RCTRequired: 379 | :path: "../node_modules/react-native/Libraries/RCTRequired" 380 | RCTTypeSafety: 381 | :path: "../node_modules/react-native/Libraries/TypeSafety" 382 | React: 383 | :path: "../node_modules/react-native/" 384 | React-callinvoker: 385 | :path: "../node_modules/react-native/ReactCommon/callinvoker" 386 | React-Core: 387 | :path: "../node_modules/react-native/" 388 | React-CoreModules: 389 | :path: "../node_modules/react-native/React/CoreModules" 390 | React-cxxreact: 391 | :path: "../node_modules/react-native/ReactCommon/cxxreact" 392 | React-jsi: 393 | :path: "../node_modules/react-native/ReactCommon/jsi" 394 | React-jsiexecutor: 395 | :path: "../node_modules/react-native/ReactCommon/jsiexecutor" 396 | React-jsinspector: 397 | :path: "../node_modules/react-native/ReactCommon/jsinspector" 398 | React-RCTActionSheet: 399 | :path: "../node_modules/react-native/Libraries/ActionSheetIOS" 400 | React-RCTAnimation: 401 | :path: "../node_modules/react-native/Libraries/NativeAnimation" 402 | React-RCTBlob: 403 | :path: "../node_modules/react-native/Libraries/Blob" 404 | React-RCTImage: 405 | :path: "../node_modules/react-native/Libraries/Image" 406 | React-RCTLinking: 407 | :path: "../node_modules/react-native/Libraries/LinkingIOS" 408 | React-RCTNetwork: 409 | :path: "../node_modules/react-native/Libraries/Network" 410 | React-RCTSettings: 411 | :path: "../node_modules/react-native/Libraries/Settings" 412 | React-RCTText: 413 | :path: "../node_modules/react-native/Libraries/Text" 414 | React-RCTVibration: 415 | :path: "../node_modules/react-native/Libraries/Vibration" 416 | ReactCommon: 417 | :path: "../node_modules/react-native/ReactCommon" 418 | Yoga: 419 | :path: "../node_modules/react-native/ReactCommon/yoga" 420 | 421 | SPEC CHECKSUMS: 422 | boost-for-react-native: 39c7adb57c4e60d6c5479dd8623128eb5b3f0f2c 423 | CocoaAsyncSocket: 694058e7c0ed05a9e217d1b3c7ded962f4180845 424 | CocoaLibEvent: 2fab71b8bd46dd33ddb959f7928ec5909f838e3f 425 | DoubleConversion: cde416483dac037923206447da6e1454df403714 426 | FBLazyVector: 6f1045c66f816849b33c4ff28930b611e89059a0 427 | FBReactNativeSpec: e856d5103d749483f86f53afafd8df4ed8a776bd 428 | Flipper: 33585e2d9810fe5528346be33bcf71b37bb7ae13 429 | Flipper-DoubleConversion: 38631e41ef4f9b12861c67d17cb5518d06badc41 430 | Flipper-Folly: c12092ea368353b58e992843a990a3225d4533c3 431 | Flipper-Glog: 1dfd6abf1e922806c52ceb8701a3599a79a200a6 432 | Flipper-PeerTalk: 116d8f857dc6ef55c7a5a75ea3ceaafe878aadc9 433 | Flipper-RSocket: 64e7431a55835eb953b0bf984ef3b90ae9fdddd7 434 | FlipperKit: bc68102cd4952a258a23c9c1b316c7bec1fecf83 435 | Folly: b73c3869541e86821df3c387eb0af5f65addfab4 436 | glog: 40a13f7840415b9a77023fbcae0f1e6f43192af3 437 | OpenSSL-Universal: 8b48cc0d10c1b2923617dfe5c178aa9ed2689355 438 | RCTRequired: e46bb77db03887b3e200d34b08515c804669db99 439 | RCTTypeSafety: 270fed6675c42f80fb87b47d626ef3cede1505e6 440 | React: e008906ff1328f9bccb345ff4f7826397ad223fc 441 | React-callinvoker: f547824e0a626f4bce516ee65f548004b0784e7e 442 | React-Core: 1c28d2ecde60ded3fe42d8db4f684afb8709757b 443 | React-CoreModules: 8e6139e59f5347e2cf3ceb63e4532fb5b4b39a2d 444 | React-cxxreact: 98fef06e1ca59eb075ef5bc4c6f256d5c6840936 445 | React-jsi: 254710f3a97e587427bfbf3011dacec2af66a1fc 446 | React-jsiexecutor: 0e0cb4e170ca72d4bb1179843d08dcbea3d100ac 447 | React-jsinspector: fc661eff8edbfb7e22119382c13f33bcadde0f3c 448 | React-RCTActionSheet: aadd91a1d6cbfae50dd41f140004f816e9e47ade 449 | React-RCTAnimation: 7fa2ef6c0ef1e3f0b7d2261c827ec94412deb5e6 450 | React-RCTBlob: ccbbc70295aee3a76a70323b48f63fb7a7fcffd6 451 | React-RCTImage: d94eb3080b37a4527ade4dd5f9f1289b7ba68089 452 | React-RCTLinking: ddd2a1ddb699bade352d4747d5652f4c425c747a 453 | React-RCTNetwork: 4590b11cc6e99eb01a48f1c03bcadfb8b792d005 454 | React-RCTSettings: 9197a492268a088c5213ef8a08cfc60b7a141369 455 | React-RCTText: ba503bf4cce41881ca258ba789c33e017955efdd 456 | React-RCTVibration: 77ab1cf4a5eb854b88ad5ed3e9d8509ed124525e 457 | ReactCommon: f63556ee9e41e9802257228237e5e660451a03cf 458 | Yoga: 7d2edc5b410474191962e6dee88ee67f9b328b6b 459 | YogaKit: f782866e155069a2cca2517aafea43200b01fd5a 460 | 461 | PODFILE CHECKSUM: f4ad0707faa25d6f276955a41091c7b56d9b4cba 462 | 463 | COCOAPODS: 1.8.4 464 | -------------------------------------------------------------------------------- /examples/ios/examples-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 | -------------------------------------------------------------------------------- /examples/ios/examples-tvOSTests/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 | -------------------------------------------------------------------------------- /examples/ios/examples.xcodeproj/project.pbxproj: -------------------------------------------------------------------------------- 1 | // !$*UTF8*$! 2 | { 3 | archiveVersion = 1; 4 | classes = { 5 | }; 6 | objectVersion = 46; 7 | objects = { 8 | 9 | /* Begin PBXBuildFile section */ 10 | 00E356F31AD99517003FC87E /* examplesTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* examplesTests.m */; }; 11 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; }; 12 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; 13 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; 14 | 29102BFE0EAF4A472C64CC2E /* libPods-examples-tvOS.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 3EE2159382BEC829FA146FF6 /* libPods-examples-tvOS.a */; }; 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 /* examplesTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* examplesTests.m */; }; 19 | 409E294197F3A02346D8E0DB /* libPods-examples-examplesTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 875C4CB5567D2AD12ABD553C /* libPods-examples-examplesTests.a */; }; 20 | 535BC09C2F0EF03EE85A04A9 /* libPods-examples-tvOSTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5BC38833EAB11C985DE4E622 /* libPods-examples-tvOSTests.a */; }; 21 | 68DAB7852BDAADCA8AE39C8A /* libPods-examples.a in Frameworks */ = {isa = PBXBuildFile; fileRef = CD8A2FADA477D186C662D743 /* libPods-examples.a */; }; 22 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; }; 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 = examples; 32 | }; 33 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = { 34 | isa = PBXContainerItemProxy; 35 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */; 36 | proxyType = 1; 37 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7; 38 | remoteInfo = "examples-tvOS"; 39 | }; 40 | /* End PBXContainerItemProxy section */ 41 | 42 | /* Begin PBXFileReference section */ 43 | 00043398B9140A7BEC7E3A0F /* Pods-examples.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples.debug.xcconfig"; path = "Target Support Files/Pods-examples/Pods-examples.debug.xcconfig"; sourceTree = ""; }; 44 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; }; 45 | 00E356EE1AD99517003FC87E /* examplesTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = examplesTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; 46 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; 47 | 00E356F21AD99517003FC87E /* examplesTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = examplesTests.m; sourceTree = ""; }; 48 | 13B07F961A680F5B00A75B9A /* examples.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = examples.app; sourceTree = BUILT_PRODUCTS_DIR; }; 49 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = examples/AppDelegate.h; sourceTree = ""; }; 50 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = examples/AppDelegate.m; sourceTree = ""; }; 51 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = examples/Images.xcassets; sourceTree = ""; }; 52 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = examples/Info.plist; sourceTree = ""; }; 53 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = examples/main.m; sourceTree = ""; }; 54 | 2D02E47B1E0B4A5D006451C7 /* examples-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "examples-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; }; 55 | 2D02E4901E0B4A5D006451C7 /* examples-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "examples-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; }; 56 | 3EE2159382BEC829FA146FF6 /* libPods-examples-tvOS.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-examples-tvOS.a"; sourceTree = BUILT_PRODUCTS_DIR; }; 57 | 49948BCC3ACBD83D52694AFF /* Pods-examples-tvOS.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-tvOS.release.xcconfig"; path = "Target Support Files/Pods-examples-tvOS/Pods-examples-tvOS.release.xcconfig"; sourceTree = ""; }; 58 | 5BC38833EAB11C985DE4E622 /* libPods-examples-tvOSTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-examples-tvOSTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; 59 | 653F7C31E4457475E7CE4BDC /* Pods-examples-tvOSTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-tvOSTests.release.xcconfig"; path = "Target Support Files/Pods-examples-tvOSTests/Pods-examples-tvOSTests.release.xcconfig"; sourceTree = ""; }; 60 | 6A76F2906F048B5A5F58AACD /* Pods-examples-tvOS.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-tvOS.debug.xcconfig"; path = "Target Support Files/Pods-examples-tvOS/Pods-examples-tvOS.debug.xcconfig"; sourceTree = ""; }; 61 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = examples/LaunchScreen.storyboard; sourceTree = ""; }; 62 | 875C4CB5567D2AD12ABD553C /* libPods-examples-examplesTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-examples-examplesTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; 63 | 8DA463FD9DF40F8C2A407268 /* Pods-examples-examplesTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-examplesTests.release.xcconfig"; path = "Target Support Files/Pods-examples-examplesTests/Pods-examples-examplesTests.release.xcconfig"; sourceTree = ""; }; 64 | B21FF51AEFAA3E59185083CB /* Pods-examples.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples.release.xcconfig"; path = "Target Support Files/Pods-examples/Pods-examples.release.xcconfig"; sourceTree = ""; }; 65 | CD8A2FADA477D186C662D743 /* libPods-examples.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-examples.a"; sourceTree = BUILT_PRODUCTS_DIR; }; 66 | D943940B766581660A020FBD /* Pods-examples-tvOSTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-tvOSTests.debug.xcconfig"; path = "Target Support Files/Pods-examples-tvOSTests/Pods-examples-tvOSTests.debug.xcconfig"; sourceTree = ""; }; 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 | FF43D554F4F05D2ECA5FE984 /* Pods-examples-examplesTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-examples-examplesTests.debug.xcconfig"; path = "Target Support Files/Pods-examples-examplesTests/Pods-examples-examplesTests.debug.xcconfig"; sourceTree = ""; }; 70 | /* End PBXFileReference section */ 71 | 72 | /* Begin PBXFrameworksBuildPhase section */ 73 | 00E356EB1AD99517003FC87E /* Frameworks */ = { 74 | isa = PBXFrameworksBuildPhase; 75 | buildActionMask = 2147483647; 76 | files = ( 77 | 409E294197F3A02346D8E0DB /* libPods-examples-examplesTests.a in Frameworks */, 78 | ); 79 | runOnlyForDeploymentPostprocessing = 0; 80 | }; 81 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = { 82 | isa = PBXFrameworksBuildPhase; 83 | buildActionMask = 2147483647; 84 | files = ( 85 | 68DAB7852BDAADCA8AE39C8A /* libPods-examples.a in Frameworks */, 86 | ); 87 | runOnlyForDeploymentPostprocessing = 0; 88 | }; 89 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = { 90 | isa = PBXFrameworksBuildPhase; 91 | buildActionMask = 2147483647; 92 | files = ( 93 | 29102BFE0EAF4A472C64CC2E /* libPods-examples-tvOS.a in Frameworks */, 94 | ); 95 | runOnlyForDeploymentPostprocessing = 0; 96 | }; 97 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = { 98 | isa = PBXFrameworksBuildPhase; 99 | buildActionMask = 2147483647; 100 | files = ( 101 | 535BC09C2F0EF03EE85A04A9 /* libPods-examples-tvOSTests.a in Frameworks */, 102 | ); 103 | runOnlyForDeploymentPostprocessing = 0; 104 | }; 105 | /* End PBXFrameworksBuildPhase section */ 106 | 107 | /* Begin PBXGroup section */ 108 | 00E356EF1AD99517003FC87E /* examplesTests */ = { 109 | isa = PBXGroup; 110 | children = ( 111 | 00E356F21AD99517003FC87E /* examplesTests.m */, 112 | 00E356F01AD99517003FC87E /* Supporting Files */, 113 | ); 114 | path = examplesTests; 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 | 0533CA236D6F6CE1B0E91C8B /* Pods */ = { 126 | isa = PBXGroup; 127 | children = ( 128 | 00043398B9140A7BEC7E3A0F /* Pods-examples.debug.xcconfig */, 129 | B21FF51AEFAA3E59185083CB /* Pods-examples.release.xcconfig */, 130 | FF43D554F4F05D2ECA5FE984 /* Pods-examples-examplesTests.debug.xcconfig */, 131 | 8DA463FD9DF40F8C2A407268 /* Pods-examples-examplesTests.release.xcconfig */, 132 | 6A76F2906F048B5A5F58AACD /* Pods-examples-tvOS.debug.xcconfig */, 133 | 49948BCC3ACBD83D52694AFF /* Pods-examples-tvOS.release.xcconfig */, 134 | D943940B766581660A020FBD /* Pods-examples-tvOSTests.debug.xcconfig */, 135 | 653F7C31E4457475E7CE4BDC /* Pods-examples-tvOSTests.release.xcconfig */, 136 | ); 137 | name = Pods; 138 | path = Pods; 139 | sourceTree = ""; 140 | }; 141 | 13B07FAE1A68108700A75B9A /* examples */ = { 142 | isa = PBXGroup; 143 | children = ( 144 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */, 145 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */, 146 | 13B07FB01A68108700A75B9A /* AppDelegate.m */, 147 | 13B07FB51A68108700A75B9A /* Images.xcassets */, 148 | 13B07FB61A68108700A75B9A /* Info.plist */, 149 | 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */, 150 | 13B07FB71A68108700A75B9A /* main.m */, 151 | ); 152 | name = examples; 153 | sourceTree = ""; 154 | }; 155 | 2D16E6871FA4F8E400B85C8A /* Frameworks */ = { 156 | isa = PBXGroup; 157 | children = ( 158 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */, 159 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */, 160 | CD8A2FADA477D186C662D743 /* libPods-examples.a */, 161 | 875C4CB5567D2AD12ABD553C /* libPods-examples-examplesTests.a */, 162 | 3EE2159382BEC829FA146FF6 /* libPods-examples-tvOS.a */, 163 | 5BC38833EAB11C985DE4E622 /* libPods-examples-tvOSTests.a */, 164 | ); 165 | name = Frameworks; 166 | sourceTree = ""; 167 | }; 168 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = { 169 | isa = PBXGroup; 170 | children = ( 171 | ); 172 | name = Libraries; 173 | sourceTree = ""; 174 | }; 175 | 83CBB9F61A601CBA00E9B192 = { 176 | isa = PBXGroup; 177 | children = ( 178 | 13B07FAE1A68108700A75B9A /* examples */, 179 | 832341AE1AAA6A7D00B99B32 /* Libraries */, 180 | 00E356EF1AD99517003FC87E /* examplesTests */, 181 | 83CBBA001A601CBA00E9B192 /* Products */, 182 | 2D16E6871FA4F8E400B85C8A /* Frameworks */, 183 | 0533CA236D6F6CE1B0E91C8B /* Pods */, 184 | ); 185 | indentWidth = 2; 186 | sourceTree = ""; 187 | tabWidth = 2; 188 | usesTabs = 0; 189 | }; 190 | 83CBBA001A601CBA00E9B192 /* Products */ = { 191 | isa = PBXGroup; 192 | children = ( 193 | 13B07F961A680F5B00A75B9A /* examples.app */, 194 | 00E356EE1AD99517003FC87E /* examplesTests.xctest */, 195 | 2D02E47B1E0B4A5D006451C7 /* examples-tvOS.app */, 196 | 2D02E4901E0B4A5D006451C7 /* examples-tvOSTests.xctest */, 197 | ); 198 | name = Products; 199 | sourceTree = ""; 200 | }; 201 | /* End PBXGroup section */ 202 | 203 | /* Begin PBXNativeTarget section */ 204 | 00E356ED1AD99517003FC87E /* examplesTests */ = { 205 | isa = PBXNativeTarget; 206 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "examplesTests" */; 207 | buildPhases = ( 208 | BC8E936AAFB5A219F5C6EB2F /* [CP] Check Pods Manifest.lock */, 209 | 00E356EA1AD99517003FC87E /* Sources */, 210 | 00E356EB1AD99517003FC87E /* Frameworks */, 211 | 00E356EC1AD99517003FC87E /* Resources */, 212 | 8B234DCB6C7C4C1416676404 /* [CP] Copy Pods Resources */, 213 | ); 214 | buildRules = ( 215 | ); 216 | dependencies = ( 217 | 00E356F51AD99517003FC87E /* PBXTargetDependency */, 218 | ); 219 | name = examplesTests; 220 | productName = examplesTests; 221 | productReference = 00E356EE1AD99517003FC87E /* examplesTests.xctest */; 222 | productType = "com.apple.product-type.bundle.unit-test"; 223 | }; 224 | 13B07F861A680F5B00A75B9A /* examples */ = { 225 | isa = PBXNativeTarget; 226 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "examples" */; 227 | buildPhases = ( 228 | B54BA6F5850D9CF543C4F54C /* [CP] Check Pods Manifest.lock */, 229 | FD10A7F022414F080027D42C /* Start Packager */, 230 | 13B07F871A680F5B00A75B9A /* Sources */, 231 | 13B07F8C1A680F5B00A75B9A /* Frameworks */, 232 | 13B07F8E1A680F5B00A75B9A /* Resources */, 233 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */, 234 | BAC4418A044DD2BDAD874365 /* [CP] Copy Pods Resources */, 235 | ); 236 | buildRules = ( 237 | ); 238 | dependencies = ( 239 | ); 240 | name = examples; 241 | productName = examples; 242 | productReference = 13B07F961A680F5B00A75B9A /* examples.app */; 243 | productType = "com.apple.product-type.application"; 244 | }; 245 | 2D02E47A1E0B4A5D006451C7 /* examples-tvOS */ = { 246 | isa = PBXNativeTarget; 247 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "examples-tvOS" */; 248 | buildPhases = ( 249 | 333E82ECCA61D9549960953D /* [CP] Check Pods Manifest.lock */, 250 | FD10A7F122414F3F0027D42C /* Start Packager */, 251 | 2D02E4771E0B4A5D006451C7 /* Sources */, 252 | 2D02E4781E0B4A5D006451C7 /* Frameworks */, 253 | 2D02E4791E0B4A5D006451C7 /* Resources */, 254 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */, 255 | ); 256 | buildRules = ( 257 | ); 258 | dependencies = ( 259 | ); 260 | name = "examples-tvOS"; 261 | productName = "examples-tvOS"; 262 | productReference = 2D02E47B1E0B4A5D006451C7 /* examples-tvOS.app */; 263 | productType = "com.apple.product-type.application"; 264 | }; 265 | 2D02E48F1E0B4A5D006451C7 /* examples-tvOSTests */ = { 266 | isa = PBXNativeTarget; 267 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "examples-tvOSTests" */; 268 | buildPhases = ( 269 | F1F20833B644E87214AA3904 /* [CP] Check Pods Manifest.lock */, 270 | 2D02E48C1E0B4A5D006451C7 /* Sources */, 271 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */, 272 | 2D02E48E1E0B4A5D006451C7 /* Resources */, 273 | ); 274 | buildRules = ( 275 | ); 276 | dependencies = ( 277 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */, 278 | ); 279 | name = "examples-tvOSTests"; 280 | productName = "examples-tvOSTests"; 281 | productReference = 2D02E4901E0B4A5D006451C7 /* examples-tvOSTests.xctest */; 282 | productType = "com.apple.product-type.bundle.unit-test"; 283 | }; 284 | /* End PBXNativeTarget section */ 285 | 286 | /* Begin PBXProject section */ 287 | 83CBB9F71A601CBA00E9B192 /* Project object */ = { 288 | isa = PBXProject; 289 | attributes = { 290 | LastUpgradeCheck = 1130; 291 | TargetAttributes = { 292 | 00E356ED1AD99517003FC87E = { 293 | CreatedOnToolsVersion = 6.2; 294 | TestTargetID = 13B07F861A680F5B00A75B9A; 295 | }; 296 | 13B07F861A680F5B00A75B9A = { 297 | LastSwiftMigration = 1120; 298 | }; 299 | 2D02E47A1E0B4A5D006451C7 = { 300 | CreatedOnToolsVersion = 8.2.1; 301 | ProvisioningStyle = Automatic; 302 | }; 303 | 2D02E48F1E0B4A5D006451C7 = { 304 | CreatedOnToolsVersion = 8.2.1; 305 | ProvisioningStyle = Automatic; 306 | TestTargetID = 2D02E47A1E0B4A5D006451C7; 307 | }; 308 | }; 309 | }; 310 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "examples" */; 311 | compatibilityVersion = "Xcode 3.2"; 312 | developmentRegion = en; 313 | hasScannedForEncodings = 0; 314 | knownRegions = ( 315 | en, 316 | Base, 317 | ); 318 | mainGroup = 83CBB9F61A601CBA00E9B192; 319 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */; 320 | projectDirPath = ""; 321 | projectRoot = ""; 322 | targets = ( 323 | 13B07F861A680F5B00A75B9A /* examples */, 324 | 00E356ED1AD99517003FC87E /* examplesTests */, 325 | 2D02E47A1E0B4A5D006451C7 /* examples-tvOS */, 326 | 2D02E48F1E0B4A5D006451C7 /* examples-tvOSTests */, 327 | ); 328 | }; 329 | /* End PBXProject section */ 330 | 331 | /* Begin PBXResourcesBuildPhase section */ 332 | 00E356EC1AD99517003FC87E /* Resources */ = { 333 | isa = PBXResourcesBuildPhase; 334 | buildActionMask = 2147483647; 335 | files = ( 336 | ); 337 | runOnlyForDeploymentPostprocessing = 0; 338 | }; 339 | 13B07F8E1A680F5B00A75B9A /* Resources */ = { 340 | isa = PBXResourcesBuildPhase; 341 | buildActionMask = 2147483647; 342 | files = ( 343 | 81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */, 344 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */, 345 | ); 346 | runOnlyForDeploymentPostprocessing = 0; 347 | }; 348 | 2D02E4791E0B4A5D006451C7 /* Resources */ = { 349 | isa = PBXResourcesBuildPhase; 350 | buildActionMask = 2147483647; 351 | files = ( 352 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */, 353 | ); 354 | runOnlyForDeploymentPostprocessing = 0; 355 | }; 356 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = { 357 | isa = PBXResourcesBuildPhase; 358 | buildActionMask = 2147483647; 359 | files = ( 360 | ); 361 | runOnlyForDeploymentPostprocessing = 0; 362 | }; 363 | /* End PBXResourcesBuildPhase section */ 364 | 365 | /* Begin PBXShellScriptBuildPhase section */ 366 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = { 367 | isa = PBXShellScriptBuildPhase; 368 | buildActionMask = 2147483647; 369 | files = ( 370 | ); 371 | inputPaths = ( 372 | ); 373 | name = "Bundle React Native code and images"; 374 | outputPaths = ( 375 | ); 376 | runOnlyForDeploymentPostprocessing = 0; 377 | shellPath = /bin/sh; 378 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh"; 379 | }; 380 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = { 381 | isa = PBXShellScriptBuildPhase; 382 | buildActionMask = 2147483647; 383 | files = ( 384 | ); 385 | inputPaths = ( 386 | ); 387 | name = "Bundle React Native Code And Images"; 388 | outputPaths = ( 389 | ); 390 | runOnlyForDeploymentPostprocessing = 0; 391 | shellPath = /bin/sh; 392 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh"; 393 | }; 394 | 333E82ECCA61D9549960953D /* [CP] Check Pods Manifest.lock */ = { 395 | isa = PBXShellScriptBuildPhase; 396 | buildActionMask = 2147483647; 397 | files = ( 398 | ); 399 | inputFileListPaths = ( 400 | ); 401 | inputPaths = ( 402 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock", 403 | "${PODS_ROOT}/Manifest.lock", 404 | ); 405 | name = "[CP] Check Pods Manifest.lock"; 406 | outputFileListPaths = ( 407 | ); 408 | outputPaths = ( 409 | "$(DERIVED_FILE_DIR)/Pods-examples-tvOS-checkManifestLockResult.txt", 410 | ); 411 | runOnlyForDeploymentPostprocessing = 0; 412 | shellPath = /bin/sh; 413 | 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"; 414 | showEnvVarsInLog = 0; 415 | }; 416 | 8B234DCB6C7C4C1416676404 /* [CP] Copy Pods Resources */ = { 417 | isa = PBXShellScriptBuildPhase; 418 | buildActionMask = 2147483647; 419 | files = ( 420 | ); 421 | inputPaths = ( 422 | "${PODS_ROOT}/Target Support Files/Pods-examples-examplesTests/Pods-examples-examplesTests-resources.sh", 423 | "${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle", 424 | ); 425 | name = "[CP] Copy Pods Resources"; 426 | outputPaths = ( 427 | "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle", 428 | ); 429 | runOnlyForDeploymentPostprocessing = 0; 430 | shellPath = /bin/sh; 431 | shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-examples-examplesTests/Pods-examples-examplesTests-resources.sh\"\n"; 432 | showEnvVarsInLog = 0; 433 | }; 434 | B54BA6F5850D9CF543C4F54C /* [CP] Check Pods Manifest.lock */ = { 435 | isa = PBXShellScriptBuildPhase; 436 | buildActionMask = 2147483647; 437 | files = ( 438 | ); 439 | inputFileListPaths = ( 440 | ); 441 | inputPaths = ( 442 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock", 443 | "${PODS_ROOT}/Manifest.lock", 444 | ); 445 | name = "[CP] Check Pods Manifest.lock"; 446 | outputFileListPaths = ( 447 | ); 448 | outputPaths = ( 449 | "$(DERIVED_FILE_DIR)/Pods-examples-checkManifestLockResult.txt", 450 | ); 451 | runOnlyForDeploymentPostprocessing = 0; 452 | shellPath = /bin/sh; 453 | 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"; 454 | showEnvVarsInLog = 0; 455 | }; 456 | BAC4418A044DD2BDAD874365 /* [CP] Copy Pods Resources */ = { 457 | isa = PBXShellScriptBuildPhase; 458 | buildActionMask = 2147483647; 459 | files = ( 460 | ); 461 | inputPaths = ( 462 | "${PODS_ROOT}/Target Support Files/Pods-examples/Pods-examples-resources.sh", 463 | "${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle", 464 | ); 465 | name = "[CP] Copy Pods Resources"; 466 | outputPaths = ( 467 | "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle", 468 | ); 469 | runOnlyForDeploymentPostprocessing = 0; 470 | shellPath = /bin/sh; 471 | shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-examples/Pods-examples-resources.sh\"\n"; 472 | showEnvVarsInLog = 0; 473 | }; 474 | BC8E936AAFB5A219F5C6EB2F /* [CP] Check Pods Manifest.lock */ = { 475 | isa = PBXShellScriptBuildPhase; 476 | buildActionMask = 2147483647; 477 | files = ( 478 | ); 479 | inputFileListPaths = ( 480 | ); 481 | inputPaths = ( 482 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock", 483 | "${PODS_ROOT}/Manifest.lock", 484 | ); 485 | name = "[CP] Check Pods Manifest.lock"; 486 | outputFileListPaths = ( 487 | ); 488 | outputPaths = ( 489 | "$(DERIVED_FILE_DIR)/Pods-examples-examplesTests-checkManifestLockResult.txt", 490 | ); 491 | runOnlyForDeploymentPostprocessing = 0; 492 | shellPath = /bin/sh; 493 | 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"; 494 | showEnvVarsInLog = 0; 495 | }; 496 | F1F20833B644E87214AA3904 /* [CP] Check Pods Manifest.lock */ = { 497 | isa = PBXShellScriptBuildPhase; 498 | buildActionMask = 2147483647; 499 | files = ( 500 | ); 501 | inputFileListPaths = ( 502 | ); 503 | inputPaths = ( 504 | "${PODS_PODFILE_DIR_PATH}/Podfile.lock", 505 | "${PODS_ROOT}/Manifest.lock", 506 | ); 507 | name = "[CP] Check Pods Manifest.lock"; 508 | outputFileListPaths = ( 509 | ); 510 | outputPaths = ( 511 | "$(DERIVED_FILE_DIR)/Pods-examples-tvOSTests-checkManifestLockResult.txt", 512 | ); 513 | runOnlyForDeploymentPostprocessing = 0; 514 | shellPath = /bin/sh; 515 | 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"; 516 | showEnvVarsInLog = 0; 517 | }; 518 | FD10A7F022414F080027D42C /* Start Packager */ = { 519 | isa = PBXShellScriptBuildPhase; 520 | buildActionMask = 2147483647; 521 | files = ( 522 | ); 523 | inputFileListPaths = ( 524 | ); 525 | inputPaths = ( 526 | ); 527 | name = "Start Packager"; 528 | outputFileListPaths = ( 529 | ); 530 | outputPaths = ( 531 | ); 532 | runOnlyForDeploymentPostprocessing = 0; 533 | shellPath = /bin/sh; 534 | 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"; 535 | showEnvVarsInLog = 0; 536 | }; 537 | FD10A7F122414F3F0027D42C /* Start Packager */ = { 538 | isa = PBXShellScriptBuildPhase; 539 | buildActionMask = 2147483647; 540 | files = ( 541 | ); 542 | inputFileListPaths = ( 543 | ); 544 | inputPaths = ( 545 | ); 546 | name = "Start Packager"; 547 | outputFileListPaths = ( 548 | ); 549 | outputPaths = ( 550 | ); 551 | runOnlyForDeploymentPostprocessing = 0; 552 | shellPath = /bin/sh; 553 | 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"; 554 | showEnvVarsInLog = 0; 555 | }; 556 | /* End PBXShellScriptBuildPhase section */ 557 | 558 | /* Begin PBXSourcesBuildPhase section */ 559 | 00E356EA1AD99517003FC87E /* Sources */ = { 560 | isa = PBXSourcesBuildPhase; 561 | buildActionMask = 2147483647; 562 | files = ( 563 | 00E356F31AD99517003FC87E /* examplesTests.m in Sources */, 564 | ); 565 | runOnlyForDeploymentPostprocessing = 0; 566 | }; 567 | 13B07F871A680F5B00A75B9A /* Sources */ = { 568 | isa = PBXSourcesBuildPhase; 569 | buildActionMask = 2147483647; 570 | files = ( 571 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */, 572 | 13B07FC11A68108700A75B9A /* main.m in Sources */, 573 | ); 574 | runOnlyForDeploymentPostprocessing = 0; 575 | }; 576 | 2D02E4771E0B4A5D006451C7 /* Sources */ = { 577 | isa = PBXSourcesBuildPhase; 578 | buildActionMask = 2147483647; 579 | files = ( 580 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */, 581 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */, 582 | ); 583 | runOnlyForDeploymentPostprocessing = 0; 584 | }; 585 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = { 586 | isa = PBXSourcesBuildPhase; 587 | buildActionMask = 2147483647; 588 | files = ( 589 | 2DCD954D1E0B4F2C00145EB5 /* examplesTests.m in Sources */, 590 | ); 591 | runOnlyForDeploymentPostprocessing = 0; 592 | }; 593 | /* End PBXSourcesBuildPhase section */ 594 | 595 | /* Begin PBXTargetDependency section */ 596 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = { 597 | isa = PBXTargetDependency; 598 | target = 13B07F861A680F5B00A75B9A /* examples */; 599 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */; 600 | }; 601 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = { 602 | isa = PBXTargetDependency; 603 | target = 2D02E47A1E0B4A5D006451C7 /* examples-tvOS */; 604 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */; 605 | }; 606 | /* End PBXTargetDependency section */ 607 | 608 | /* Begin XCBuildConfiguration section */ 609 | 00E356F61AD99517003FC87E /* Debug */ = { 610 | isa = XCBuildConfiguration; 611 | baseConfigurationReference = FF43D554F4F05D2ECA5FE984 /* Pods-examples-examplesTests.debug.xcconfig */; 612 | buildSettings = { 613 | BUNDLE_LOADER = "$(TEST_HOST)"; 614 | GCC_PREPROCESSOR_DEFINITIONS = ( 615 | "DEBUG=1", 616 | "$(inherited)", 617 | ); 618 | INFOPLIST_FILE = examplesTests/Info.plist; 619 | IPHONEOS_DEPLOYMENT_TARGET = 10.0; 620 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 621 | OTHER_LDFLAGS = ( 622 | "-ObjC", 623 | "-lc++", 624 | "$(inherited)", 625 | ); 626 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; 627 | PRODUCT_NAME = "$(TARGET_NAME)"; 628 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/examples.app/examples"; 629 | }; 630 | name = Debug; 631 | }; 632 | 00E356F71AD99517003FC87E /* Release */ = { 633 | isa = XCBuildConfiguration; 634 | baseConfigurationReference = 8DA463FD9DF40F8C2A407268 /* Pods-examples-examplesTests.release.xcconfig */; 635 | buildSettings = { 636 | BUNDLE_LOADER = "$(TEST_HOST)"; 637 | COPY_PHASE_STRIP = NO; 638 | INFOPLIST_FILE = examplesTests/Info.plist; 639 | IPHONEOS_DEPLOYMENT_TARGET = 10.0; 640 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 641 | OTHER_LDFLAGS = ( 642 | "-ObjC", 643 | "-lc++", 644 | "$(inherited)", 645 | ); 646 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; 647 | PRODUCT_NAME = "$(TARGET_NAME)"; 648 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/examples.app/examples"; 649 | }; 650 | name = Release; 651 | }; 652 | 13B07F941A680F5B00A75B9A /* Debug */ = { 653 | isa = XCBuildConfiguration; 654 | baseConfigurationReference = 00043398B9140A7BEC7E3A0F /* Pods-examples.debug.xcconfig */; 655 | buildSettings = { 656 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 657 | CLANG_ENABLE_MODULES = YES; 658 | CURRENT_PROJECT_VERSION = 1; 659 | ENABLE_BITCODE = NO; 660 | INFOPLIST_FILE = examples/Info.plist; 661 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 662 | OTHER_LDFLAGS = ( 663 | "$(inherited)", 664 | "-ObjC", 665 | "-lc++", 666 | ); 667 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; 668 | PRODUCT_NAME = examples; 669 | SWIFT_OPTIMIZATION_LEVEL = "-Onone"; 670 | SWIFT_VERSION = 5.0; 671 | VERSIONING_SYSTEM = "apple-generic"; 672 | }; 673 | name = Debug; 674 | }; 675 | 13B07F951A680F5B00A75B9A /* Release */ = { 676 | isa = XCBuildConfiguration; 677 | baseConfigurationReference = B21FF51AEFAA3E59185083CB /* Pods-examples.release.xcconfig */; 678 | buildSettings = { 679 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; 680 | CLANG_ENABLE_MODULES = YES; 681 | CURRENT_PROJECT_VERSION = 1; 682 | INFOPLIST_FILE = examples/Info.plist; 683 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 684 | OTHER_LDFLAGS = ( 685 | "$(inherited)", 686 | "-ObjC", 687 | "-lc++", 688 | ); 689 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; 690 | PRODUCT_NAME = examples; 691 | SWIFT_VERSION = 5.0; 692 | VERSIONING_SYSTEM = "apple-generic"; 693 | }; 694 | name = Release; 695 | }; 696 | 2D02E4971E0B4A5E006451C7 /* Debug */ = { 697 | isa = XCBuildConfiguration; 698 | baseConfigurationReference = 6A76F2906F048B5A5F58AACD /* Pods-examples-tvOS.debug.xcconfig */; 699 | buildSettings = { 700 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 701 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 702 | CLANG_ANALYZER_NONNULL = YES; 703 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 704 | CLANG_WARN_INFINITE_RECURSION = YES; 705 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 706 | DEBUG_INFORMATION_FORMAT = dwarf; 707 | ENABLE_TESTABILITY = YES; 708 | GCC_NO_COMMON_BLOCKS = YES; 709 | INFOPLIST_FILE = "examples-tvOS/Info.plist"; 710 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 711 | OTHER_LDFLAGS = ( 712 | "$(inherited)", 713 | "-ObjC", 714 | "-lc++", 715 | ); 716 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.examples-tvOS"; 717 | PRODUCT_NAME = "$(TARGET_NAME)"; 718 | SDKROOT = appletvos; 719 | TARGETED_DEVICE_FAMILY = 3; 720 | TVOS_DEPLOYMENT_TARGET = 10.0; 721 | }; 722 | name = Debug; 723 | }; 724 | 2D02E4981E0B4A5E006451C7 /* Release */ = { 725 | isa = XCBuildConfiguration; 726 | baseConfigurationReference = 49948BCC3ACBD83D52694AFF /* Pods-examples-tvOS.release.xcconfig */; 727 | buildSettings = { 728 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image"; 729 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage; 730 | CLANG_ANALYZER_NONNULL = YES; 731 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 732 | CLANG_WARN_INFINITE_RECURSION = YES; 733 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 734 | COPY_PHASE_STRIP = NO; 735 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 736 | GCC_NO_COMMON_BLOCKS = YES; 737 | INFOPLIST_FILE = "examples-tvOS/Info.plist"; 738 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; 739 | OTHER_LDFLAGS = ( 740 | "$(inherited)", 741 | "-ObjC", 742 | "-lc++", 743 | ); 744 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.examples-tvOS"; 745 | PRODUCT_NAME = "$(TARGET_NAME)"; 746 | SDKROOT = appletvos; 747 | TARGETED_DEVICE_FAMILY = 3; 748 | TVOS_DEPLOYMENT_TARGET = 10.0; 749 | }; 750 | name = Release; 751 | }; 752 | 2D02E4991E0B4A5E006451C7 /* Debug */ = { 753 | isa = XCBuildConfiguration; 754 | baseConfigurationReference = D943940B766581660A020FBD /* Pods-examples-tvOSTests.debug.xcconfig */; 755 | buildSettings = { 756 | BUNDLE_LOADER = "$(TEST_HOST)"; 757 | CLANG_ANALYZER_NONNULL = YES; 758 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 759 | CLANG_WARN_INFINITE_RECURSION = YES; 760 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 761 | DEBUG_INFORMATION_FORMAT = dwarf; 762 | ENABLE_TESTABILITY = YES; 763 | GCC_NO_COMMON_BLOCKS = YES; 764 | INFOPLIST_FILE = "examples-tvOSTests/Info.plist"; 765 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 766 | OTHER_LDFLAGS = ( 767 | "$(inherited)", 768 | "-ObjC", 769 | "-lc++", 770 | ); 771 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.examples-tvOSTests"; 772 | PRODUCT_NAME = "$(TARGET_NAME)"; 773 | SDKROOT = appletvos; 774 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/examples-tvOS.app/examples-tvOS"; 775 | TVOS_DEPLOYMENT_TARGET = 10.1; 776 | }; 777 | name = Debug; 778 | }; 779 | 2D02E49A1E0B4A5E006451C7 /* Release */ = { 780 | isa = XCBuildConfiguration; 781 | baseConfigurationReference = 653F7C31E4457475E7CE4BDC /* Pods-examples-tvOSTests.release.xcconfig */; 782 | buildSettings = { 783 | BUNDLE_LOADER = "$(TEST_HOST)"; 784 | CLANG_ANALYZER_NONNULL = YES; 785 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES; 786 | CLANG_WARN_INFINITE_RECURSION = YES; 787 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 788 | COPY_PHASE_STRIP = NO; 789 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; 790 | GCC_NO_COMMON_BLOCKS = YES; 791 | INFOPLIST_FILE = "examples-tvOSTests/Info.plist"; 792 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; 793 | OTHER_LDFLAGS = ( 794 | "$(inherited)", 795 | "-ObjC", 796 | "-lc++", 797 | ); 798 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.examples-tvOSTests"; 799 | PRODUCT_NAME = "$(TARGET_NAME)"; 800 | SDKROOT = appletvos; 801 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/examples-tvOS.app/examples-tvOS"; 802 | TVOS_DEPLOYMENT_TARGET = 10.1; 803 | }; 804 | name = Release; 805 | }; 806 | 83CBBA201A601CBA00E9B192 /* Debug */ = { 807 | isa = XCBuildConfiguration; 808 | buildSettings = { 809 | ALWAYS_SEARCH_USER_PATHS = NO; 810 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; 811 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 812 | CLANG_CXX_LIBRARY = "libc++"; 813 | CLANG_ENABLE_MODULES = YES; 814 | CLANG_ENABLE_OBJC_ARC = YES; 815 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; 816 | CLANG_WARN_BOOL_CONVERSION = YES; 817 | CLANG_WARN_COMMA = YES; 818 | CLANG_WARN_CONSTANT_CONVERSION = YES; 819 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; 820 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 821 | CLANG_WARN_EMPTY_BODY = YES; 822 | CLANG_WARN_ENUM_CONVERSION = YES; 823 | CLANG_WARN_INFINITE_RECURSION = YES; 824 | CLANG_WARN_INT_CONVERSION = YES; 825 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; 826 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; 827 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; 828 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 829 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; 830 | CLANG_WARN_STRICT_PROTOTYPES = YES; 831 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 832 | CLANG_WARN_UNREACHABLE_CODE = YES; 833 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 834 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 835 | COPY_PHASE_STRIP = NO; 836 | ENABLE_STRICT_OBJC_MSGSEND = YES; 837 | ENABLE_TESTABILITY = YES; 838 | GCC_C_LANGUAGE_STANDARD = gnu99; 839 | GCC_DYNAMIC_NO_PIC = NO; 840 | GCC_NO_COMMON_BLOCKS = YES; 841 | GCC_OPTIMIZATION_LEVEL = 0; 842 | GCC_PREPROCESSOR_DEFINITIONS = ( 843 | "DEBUG=1", 844 | "$(inherited)", 845 | ); 846 | GCC_SYMBOLS_PRIVATE_EXTERN = NO; 847 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 848 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 849 | GCC_WARN_UNDECLARED_SELECTOR = YES; 850 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 851 | GCC_WARN_UNUSED_FUNCTION = YES; 852 | GCC_WARN_UNUSED_VARIABLE = YES; 853 | IPHONEOS_DEPLOYMENT_TARGET = 10.0; 854 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; 855 | LIBRARY_SEARCH_PATHS = ( 856 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", 857 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"", 858 | "\"$(inherited)\"", 859 | ); 860 | MTL_ENABLE_DEBUG_INFO = YES; 861 | ONLY_ACTIVE_ARCH = YES; 862 | SDKROOT = iphoneos; 863 | }; 864 | name = Debug; 865 | }; 866 | 83CBBA211A601CBA00E9B192 /* Release */ = { 867 | isa = XCBuildConfiguration; 868 | buildSettings = { 869 | ALWAYS_SEARCH_USER_PATHS = NO; 870 | CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; 871 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; 872 | CLANG_CXX_LIBRARY = "libc++"; 873 | CLANG_ENABLE_MODULES = YES; 874 | CLANG_ENABLE_OBJC_ARC = YES; 875 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; 876 | CLANG_WARN_BOOL_CONVERSION = YES; 877 | CLANG_WARN_COMMA = YES; 878 | CLANG_WARN_CONSTANT_CONVERSION = YES; 879 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; 880 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; 881 | CLANG_WARN_EMPTY_BODY = YES; 882 | CLANG_WARN_ENUM_CONVERSION = YES; 883 | CLANG_WARN_INFINITE_RECURSION = YES; 884 | CLANG_WARN_INT_CONVERSION = YES; 885 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; 886 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; 887 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; 888 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; 889 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; 890 | CLANG_WARN_STRICT_PROTOTYPES = YES; 891 | CLANG_WARN_SUSPICIOUS_MOVE = YES; 892 | CLANG_WARN_UNREACHABLE_CODE = YES; 893 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; 894 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; 895 | COPY_PHASE_STRIP = YES; 896 | ENABLE_NS_ASSERTIONS = NO; 897 | ENABLE_STRICT_OBJC_MSGSEND = YES; 898 | GCC_C_LANGUAGE_STANDARD = gnu99; 899 | GCC_NO_COMMON_BLOCKS = YES; 900 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES; 901 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; 902 | GCC_WARN_UNDECLARED_SELECTOR = YES; 903 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; 904 | GCC_WARN_UNUSED_FUNCTION = YES; 905 | GCC_WARN_UNUSED_VARIABLE = YES; 906 | IPHONEOS_DEPLOYMENT_TARGET = 10.0; 907 | LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; 908 | LIBRARY_SEARCH_PATHS = ( 909 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", 910 | "\"$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)\"", 911 | "\"$(inherited)\"", 912 | ); 913 | MTL_ENABLE_DEBUG_INFO = NO; 914 | SDKROOT = iphoneos; 915 | VALIDATE_PRODUCT = YES; 916 | }; 917 | name = Release; 918 | }; 919 | /* End XCBuildConfiguration section */ 920 | 921 | /* Begin XCConfigurationList section */ 922 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "examplesTests" */ = { 923 | isa = XCConfigurationList; 924 | buildConfigurations = ( 925 | 00E356F61AD99517003FC87E /* Debug */, 926 | 00E356F71AD99517003FC87E /* Release */, 927 | ); 928 | defaultConfigurationIsVisible = 0; 929 | defaultConfigurationName = Release; 930 | }; 931 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "examples" */ = { 932 | isa = XCConfigurationList; 933 | buildConfigurations = ( 934 | 13B07F941A680F5B00A75B9A /* Debug */, 935 | 13B07F951A680F5B00A75B9A /* Release */, 936 | ); 937 | defaultConfigurationIsVisible = 0; 938 | defaultConfigurationName = Release; 939 | }; 940 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "examples-tvOS" */ = { 941 | isa = XCConfigurationList; 942 | buildConfigurations = ( 943 | 2D02E4971E0B4A5E006451C7 /* Debug */, 944 | 2D02E4981E0B4A5E006451C7 /* Release */, 945 | ); 946 | defaultConfigurationIsVisible = 0; 947 | defaultConfigurationName = Release; 948 | }; 949 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "examples-tvOSTests" */ = { 950 | isa = XCConfigurationList; 951 | buildConfigurations = ( 952 | 2D02E4991E0B4A5E006451C7 /* Debug */, 953 | 2D02E49A1E0B4A5E006451C7 /* Release */, 954 | ); 955 | defaultConfigurationIsVisible = 0; 956 | defaultConfigurationName = Release; 957 | }; 958 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "examples" */ = { 959 | isa = XCConfigurationList; 960 | buildConfigurations = ( 961 | 83CBBA201A601CBA00E9B192 /* Debug */, 962 | 83CBBA211A601CBA00E9B192 /* Release */, 963 | ); 964 | defaultConfigurationIsVisible = 0; 965 | defaultConfigurationName = Release; 966 | }; 967 | /* End XCConfigurationList section */ 968 | }; 969 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */; 970 | } 971 | -------------------------------------------------------------------------------- /examples/ios/examples.xcodeproj/xcshareddata/xcschemes/examples-tvOS.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 24 | 25 | 30 | 31 | 33 | 39 | 40 | 41 | 42 | 43 | 53 | 55 | 61 | 62 | 63 | 64 | 70 | 72 | 78 | 79 | 80 | 81 | 83 | 84 | 87 | 88 | 89 | -------------------------------------------------------------------------------- /examples/ios/examples.xcodeproj/xcshareddata/xcschemes/examples.xcscheme: -------------------------------------------------------------------------------- 1 | 2 | 5 | 8 | 9 | 15 | 21 | 22 | 23 | 24 | 25 | 30 | 31 | 33 | 39 | 40 | 41 | 42 | 43 | 53 | 55 | 61 | 62 | 63 | 64 | 70 | 72 | 78 | 79 | 80 | 81 | 83 | 84 | 87 | 88 | 89 | -------------------------------------------------------------------------------- /examples/ios/examples.xcworkspace/contents.xcworkspacedata: -------------------------------------------------------------------------------- 1 | 2 | 4 | 6 | 7 | 9 | 10 | 11 | -------------------------------------------------------------------------------- /examples/ios/examples/AppDelegate.h: -------------------------------------------------------------------------------- 1 | #import 2 | #import 3 | 4 | @interface AppDelegate : UIResponder 5 | 6 | @property (nonatomic, strong) UIWindow *window; 7 | 8 | @end 9 | -------------------------------------------------------------------------------- /examples/ios/examples/AppDelegate.m: -------------------------------------------------------------------------------- 1 | #import "AppDelegate.h" 2 | 3 | #import 4 | #import 5 | #import 6 | 7 | #ifdef FB_SONARKIT_ENABLED 8 | #import 9 | #import 10 | #import 11 | #import 12 | #import 13 | #import 14 | 15 | static void InitializeFlipper(UIApplication *application) { 16 | FlipperClient *client = [FlipperClient sharedClient]; 17 | SKDescriptorMapper *layoutDescriptorMapper = [[SKDescriptorMapper alloc] initWithDefaults]; 18 | [client addPlugin:[[FlipperKitLayoutPlugin alloc] initWithRootNode:application withDescriptorMapper:layoutDescriptorMapper]]; 19 | [client addPlugin:[[FKUserDefaultsPlugin alloc] initWithSuiteName:nil]]; 20 | [client addPlugin:[FlipperKitReactPlugin new]]; 21 | [client addPlugin:[[FlipperKitNetworkPlugin alloc] initWithNetworkAdapter:[SKIOSNetworkAdapter new]]]; 22 | [client start]; 23 | } 24 | #endif 25 | 26 | @implementation AppDelegate 27 | 28 | - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 29 | { 30 | #ifdef FB_SONARKIT_ENABLED 31 | InitializeFlipper(application); 32 | #endif 33 | 34 | RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions]; 35 | RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge 36 | moduleName:@"examples" 37 | initialProperties:nil]; 38 | 39 | rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1]; 40 | 41 | self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds]; 42 | UIViewController *rootViewController = [UIViewController new]; 43 | rootViewController.view = rootView; 44 | self.window.rootViewController = rootViewController; 45 | [self.window makeKeyAndVisible]; 46 | return YES; 47 | } 48 | 49 | - (NSURL *)sourceURLForBridge:(RCTBridge *)bridge 50 | { 51 | #if DEBUG 52 | return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil]; 53 | #else 54 | return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"]; 55 | #endif 56 | } 57 | 58 | @end 59 | -------------------------------------------------------------------------------- /examples/ios/examples/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 | } -------------------------------------------------------------------------------- /examples/ios/examples/Images.xcassets/Contents.json: -------------------------------------------------------------------------------- 1 | { 2 | "info" : { 3 | "version" : 1, 4 | "author" : "xcode" 5 | } 6 | } 7 | -------------------------------------------------------------------------------- /examples/ios/examples/Info.plist: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | CFBundleDevelopmentRegion 6 | en 7 | CFBundleDisplayName 8 | examples 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 | -------------------------------------------------------------------------------- /examples/ios/examples/LaunchScreen.storyboard: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 25 | 31 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | -------------------------------------------------------------------------------- /examples/ios/examples/main.m: -------------------------------------------------------------------------------- 1 | #import 2 | 3 | #import "AppDelegate.h" 4 | 5 | int main(int argc, char * argv[]) { 6 | @autoreleasepool { 7 | return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /examples/ios/examplesTests/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 | -------------------------------------------------------------------------------- /examples/ios/examplesTests/examplesTests.m: -------------------------------------------------------------------------------- 1 | #import 2 | #import 3 | 4 | #import 5 | #import 6 | 7 | #define TIMEOUT_SECONDS 600 8 | #define TEXT_TO_LOOK_FOR @"Welcome to React" 9 | 10 | @interface examplesTests : XCTestCase 11 | 12 | @end 13 | 14 | @implementation examplesTests 15 | 16 | - (BOOL)findSubviewInView:(UIView *)view matching:(BOOL(^)(UIView *view))test 17 | { 18 | if (test(view)) { 19 | return YES; 20 | } 21 | for (UIView *subview in [view subviews]) { 22 | if ([self findSubviewInView:subview matching:test]) { 23 | return YES; 24 | } 25 | } 26 | return NO; 27 | } 28 | 29 | - (void)testRendersWelcomeScreen 30 | { 31 | UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController]; 32 | NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS]; 33 | BOOL foundElement = NO; 34 | 35 | __block NSString *redboxError = nil; 36 | #ifdef DEBUG 37 | RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) { 38 | if (level >= RCTLogLevelError) { 39 | redboxError = message; 40 | } 41 | }); 42 | #endif 43 | 44 | while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) { 45 | [[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]]; 46 | [[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]]; 47 | 48 | foundElement = [self findSubviewInView:vc.view matching:^BOOL(UIView *view) { 49 | if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) { 50 | return YES; 51 | } 52 | return NO; 53 | }]; 54 | } 55 | 56 | #ifdef DEBUG 57 | RCTSetLogFunction(RCTDefaultLogFunction); 58 | #endif 59 | 60 | XCTAssertNil(redboxError, @"RedBox error: %@", redboxError); 61 | XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS); 62 | } 63 | 64 | 65 | @end 66 | -------------------------------------------------------------------------------- /examples/metro.config.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Metro configuration for React Native 3 | * https://github.com/facebook/react-native 4 | * 5 | * @format 6 | */ 7 | 8 | const path = require('path'); 9 | const blacklist = require('metro-config/src/defaults/blacklist'); 10 | 11 | const packageRoot = path.resolve(__dirname, '..'); 12 | const examplesNodeModules = path.resolve(__dirname, 'node_modules'); 13 | 14 | module.exports = { 15 | transformer: { 16 | getTransformOptions: async () => ({ 17 | transform: { 18 | experimentalImportSupport: false, 19 | inlineRequires: false, 20 | }, 21 | }), 22 | }, 23 | watchFolders: [examplesNodeModules, packageRoot], 24 | resolver: { 25 | blacklistRE: blacklist([ 26 | new RegExp(`${packageRoot}/node_modules/react-native/.*`), 27 | ]), 28 | extraNodeModules: { 29 | react: path.resolve(examplesNodeModules, 'react'), 30 | 'react-native': path.resolve(examplesNodeModules, 'react-native'), 31 | }, 32 | }, 33 | }; 34 | -------------------------------------------------------------------------------- /examples/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-native-comparison-table-examples", 3 | "version": "0.0.1", 4 | "private": true, 5 | "scripts": { 6 | "android": "react-native run-android", 7 | "ios": "react-native run-ios", 8 | "start": "react-native start", 9 | "test": "jest", 10 | "lint": "eslint ." 11 | }, 12 | "dependencies": { 13 | "react": "16.13.1", 14 | "react-native": "0.63.0" 15 | }, 16 | "devDependencies": { 17 | "@babel/core": "^7.8.4", 18 | "@babel/runtime": "^7.8.4", 19 | "@react-native-community/eslint-config": "^1.1.0", 20 | "babel-jest": "^25.1.0", 21 | "eslint": "^6.5.1", 22 | "jest": "^25.1.0", 23 | "metro-react-native-babel-preset": "^0.59.0", 24 | "react-test-renderer": "16.13.1" 25 | }, 26 | "jest": { 27 | "preset": "react-native" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /examples/phones.js: -------------------------------------------------------------------------------- 1 | export default [ 2 | { 3 | id: 1, 4 | name: 'iPhone 11 Pro', 5 | image: require('./images/iphone11_pro.jpg'), 6 | cameraImage: require('./images/iphone11_pro_cam.jpg'), 7 | cameraDesc: 8 | 'Triple 12MP Ultra Wide, Wide, and Telephoto cameras with Night mode', 9 | capacity: ['64', '256', '512'], 10 | screenSize: '5.8', 11 | display: 'Super Retina XDR display', 12 | height: '144.0', 13 | width: '71.4', 14 | depth: '8.1', 15 | weight: '188', 16 | videoPlayback: '18', 17 | audioPlayback: '65' 18 | }, 19 | { 20 | id: 2, 21 | name: 'iPhone 11', 22 | image: require('./images/iphone11.jpg'), 23 | cameraImage: require('./images/iphone11_cam.jpg'), 24 | cameraDesc: 'Dual 12MP Ultra Wide and Wide cameras with Night mode', 25 | capacity: ['64', '128', '256'], 26 | screenSize: '6.1', 27 | display: 'Liquid Retina HD display', 28 | height: '150.9', 29 | width: '75.7', 30 | depth: '8.3', 31 | weight: '194', 32 | videoPlayback: '17', 33 | audioPlayback: '65' 34 | }, 35 | { 36 | id: 3, 37 | name: 'iPhone SE (2nd generation)', 38 | image: require('./images/iphoneSE.jpg'), 39 | cameraImage: require('./images/iphoneSE_cam.jpg'), 40 | cameraDesc: 'Single 12MP Wide camera', 41 | capacity: ['64', '128', '256'], 42 | screenSize: '4.7', 43 | display: 'Retina HD display', 44 | height: '138.4', 45 | width: '67.3', 46 | depth: '7.3', 47 | weight: '148', 48 | videoPlayback: '13', 49 | audioPlayback: '40' 50 | } 51 | ]; 52 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | export ComparisonTable from './ComparisonTable' 2 | export ComparisonTableSection from './ComparisonTableSection' 3 | export ComparisonTableRow from './ComparisonTableRow' 4 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-native-comparison-table", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.10.4", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz", 10 | "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.10.4" 14 | } 15 | }, 16 | "@babel/core": { 17 | "version": "7.10.4", 18 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.10.4.tgz", 19 | "integrity": "sha512-3A0tS0HWpy4XujGc7QtOIHTeNwUgWaZc/WuS5YQrfhU67jnVmsD6OGPc1AKHH0LJHQICGncy3+YUjIhVlfDdcA==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/code-frame": "^7.10.4", 23 | "@babel/generator": "^7.10.4", 24 | "@babel/helper-module-transforms": "^7.10.4", 25 | "@babel/helpers": "^7.10.4", 26 | "@babel/parser": "^7.10.4", 27 | "@babel/template": "^7.10.4", 28 | "@babel/traverse": "^7.10.4", 29 | "@babel/types": "^7.10.4", 30 | "convert-source-map": "^1.7.0", 31 | "debug": "^4.1.0", 32 | "gensync": "^1.0.0-beta.1", 33 | "json5": "^2.1.2", 34 | "lodash": "^4.17.13", 35 | "resolve": "^1.3.2", 36 | "semver": "^5.4.1", 37 | "source-map": "^0.5.0" 38 | } 39 | }, 40 | "@babel/generator": { 41 | "version": "7.10.4", 42 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.10.4.tgz", 43 | "integrity": "sha512-toLIHUIAgcQygFZRAQcsLQV3CBuX6yOIru1kJk/qqqvcRmZrYe6WavZTSG+bB8MxhnL9YPf+pKQfuiP161q7ng==", 44 | "dev": true, 45 | "requires": { 46 | "@babel/types": "^7.10.4", 47 | "jsesc": "^2.5.1", 48 | "lodash": "^4.17.13", 49 | "source-map": "^0.5.0" 50 | } 51 | }, 52 | "@babel/helper-annotate-as-pure": { 53 | "version": "7.10.4", 54 | "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.10.4.tgz", 55 | "integrity": "sha512-XQlqKQP4vXFB7BN8fEEerrmYvHp3fK/rBkRFz9jaJbzK0B1DSfej9Kc7ZzE8Z/OnId1jpJdNAZ3BFQjWG68rcA==", 56 | "dev": true, 57 | "requires": { 58 | "@babel/types": "^7.10.4" 59 | } 60 | }, 61 | "@babel/helper-builder-binary-assignment-operator-visitor": { 62 | "version": "7.10.4", 63 | "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.10.4.tgz", 64 | "integrity": "sha512-L0zGlFrGWZK4PbT8AszSfLTM5sDU1+Az/En9VrdT8/LmEiJt4zXt+Jve9DCAnQcbqDhCI+29y/L93mrDzddCcg==", 65 | "dev": true, 66 | "requires": { 67 | "@babel/helper-explode-assignable-expression": "^7.10.4", 68 | "@babel/types": "^7.10.4" 69 | } 70 | }, 71 | "@babel/helper-builder-react-jsx": { 72 | "version": "7.10.4", 73 | "resolved": "https://registry.npmjs.org/@babel/helper-builder-react-jsx/-/helper-builder-react-jsx-7.10.4.tgz", 74 | "integrity": "sha512-5nPcIZ7+KKDxT1427oBivl9V9YTal7qk0diccnh7RrcgrT/pGFOjgGw1dgryyx1GvHEpXVfoDF6Ak3rTiWh8Rg==", 75 | "dev": true, 76 | "requires": { 77 | "@babel/helper-annotate-as-pure": "^7.10.4", 78 | "@babel/types": "^7.10.4" 79 | } 80 | }, 81 | "@babel/helper-builder-react-jsx-experimental": { 82 | "version": "7.10.4", 83 | "resolved": "https://registry.npmjs.org/@babel/helper-builder-react-jsx-experimental/-/helper-builder-react-jsx-experimental-7.10.4.tgz", 84 | "integrity": "sha512-LyacH/kgQPgLAuaWrvvq1+E7f5bLyT8jXCh7nM67sRsy2cpIGfgWJ+FCnAKQXfY+F0tXUaN6FqLkp4JiCzdK8Q==", 85 | "dev": true, 86 | "requires": { 87 | "@babel/helper-annotate-as-pure": "^7.10.4", 88 | "@babel/helper-module-imports": "^7.10.4", 89 | "@babel/types": "^7.10.4" 90 | } 91 | }, 92 | "@babel/helper-create-class-features-plugin": { 93 | "version": "7.10.4", 94 | "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.10.4.tgz", 95 | "integrity": "sha512-9raUiOsXPxzzLjCXeosApJItoMnX3uyT4QdM2UldffuGApNrF8e938MwNpDCK9CPoyxrEoCgT+hObJc3mZa6lQ==", 96 | "dev": true, 97 | "requires": { 98 | "@babel/helper-function-name": "^7.10.4", 99 | "@babel/helper-member-expression-to-functions": "^7.10.4", 100 | "@babel/helper-optimise-call-expression": "^7.10.4", 101 | "@babel/helper-plugin-utils": "^7.10.4", 102 | "@babel/helper-replace-supers": "^7.10.4", 103 | "@babel/helper-split-export-declaration": "^7.10.4" 104 | } 105 | }, 106 | "@babel/helper-create-regexp-features-plugin": { 107 | "version": "7.10.4", 108 | "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.10.4.tgz", 109 | "integrity": "sha512-2/hu58IEPKeoLF45DBwx3XFqsbCXmkdAay4spVr2x0jYgRxrSNp+ePwvSsy9g6YSaNDcKIQVPXk1Ov8S2edk2g==", 110 | "dev": true, 111 | "requires": { 112 | "@babel/helper-annotate-as-pure": "^7.10.4", 113 | "@babel/helper-regex": "^7.10.4", 114 | "regexpu-core": "^4.7.0" 115 | } 116 | }, 117 | "@babel/helper-define-map": { 118 | "version": "7.10.4", 119 | "resolved": "https://registry.npmjs.org/@babel/helper-define-map/-/helper-define-map-7.10.4.tgz", 120 | "integrity": "sha512-nIij0oKErfCnLUCWaCaHW0Bmtl2RO9cN7+u2QT8yqTywgALKlyUVOvHDElh+b5DwVC6YB1FOYFOTWcN/+41EDA==", 121 | "dev": true, 122 | "requires": { 123 | "@babel/helper-function-name": "^7.10.4", 124 | "@babel/types": "^7.10.4", 125 | "lodash": "^4.17.13" 126 | } 127 | }, 128 | "@babel/helper-explode-assignable-expression": { 129 | "version": "7.10.4", 130 | "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.10.4.tgz", 131 | "integrity": "sha512-4K71RyRQNPRrR85sr5QY4X3VwG4wtVoXZB9+L3r1Gp38DhELyHCtovqydRi7c1Ovb17eRGiQ/FD5s8JdU0Uy5A==", 132 | "dev": true, 133 | "requires": { 134 | "@babel/traverse": "^7.10.4", 135 | "@babel/types": "^7.10.4" 136 | } 137 | }, 138 | "@babel/helper-function-name": { 139 | "version": "7.10.4", 140 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz", 141 | "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==", 142 | "dev": true, 143 | "requires": { 144 | "@babel/helper-get-function-arity": "^7.10.4", 145 | "@babel/template": "^7.10.4", 146 | "@babel/types": "^7.10.4" 147 | } 148 | }, 149 | "@babel/helper-get-function-arity": { 150 | "version": "7.10.4", 151 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz", 152 | "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==", 153 | "dev": true, 154 | "requires": { 155 | "@babel/types": "^7.10.4" 156 | } 157 | }, 158 | "@babel/helper-member-expression-to-functions": { 159 | "version": "7.10.4", 160 | "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.10.4.tgz", 161 | "integrity": "sha512-m5j85pK/KZhuSdM/8cHUABQTAslV47OjfIB9Cc7P+PvlAoBzdb79BGNfw8RhT5Mq3p+xGd0ZfAKixbrUZx0C7A==", 162 | "dev": true, 163 | "requires": { 164 | "@babel/types": "^7.10.4" 165 | } 166 | }, 167 | "@babel/helper-module-imports": { 168 | "version": "7.10.4", 169 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.10.4.tgz", 170 | "integrity": "sha512-nEQJHqYavI217oD9+s5MUBzk6x1IlvoS9WTPfgG43CbMEeStE0v+r+TucWdx8KFGowPGvyOkDT9+7DHedIDnVw==", 171 | "dev": true, 172 | "requires": { 173 | "@babel/types": "^7.10.4" 174 | } 175 | }, 176 | "@babel/helper-module-transforms": { 177 | "version": "7.10.4", 178 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.10.4.tgz", 179 | "integrity": "sha512-Er2FQX0oa3nV7eM1o0tNCTx7izmQtwAQsIiaLRWtavAAEcskb0XJ5OjJbVrYXWOTr8om921Scabn4/tzlx7j1Q==", 180 | "dev": true, 181 | "requires": { 182 | "@babel/helper-module-imports": "^7.10.4", 183 | "@babel/helper-replace-supers": "^7.10.4", 184 | "@babel/helper-simple-access": "^7.10.4", 185 | "@babel/helper-split-export-declaration": "^7.10.4", 186 | "@babel/template": "^7.10.4", 187 | "@babel/types": "^7.10.4", 188 | "lodash": "^4.17.13" 189 | } 190 | }, 191 | "@babel/helper-optimise-call-expression": { 192 | "version": "7.10.4", 193 | "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz", 194 | "integrity": "sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==", 195 | "dev": true, 196 | "requires": { 197 | "@babel/types": "^7.10.4" 198 | } 199 | }, 200 | "@babel/helper-plugin-utils": { 201 | "version": "7.10.4", 202 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.10.4.tgz", 203 | "integrity": "sha512-O4KCvQA6lLiMU9l2eawBPMf1xPP8xPfB3iEQw150hOVTqj/rfXz0ThTb4HEzqQfs2Bmo5Ay8BzxfzVtBrr9dVg==", 204 | "dev": true 205 | }, 206 | "@babel/helper-regex": { 207 | "version": "7.10.4", 208 | "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.10.4.tgz", 209 | "integrity": "sha512-inWpnHGgtg5NOF0eyHlC0/74/VkdRITY9dtTpB2PrxKKn+AkVMRiZz/Adrx+Ssg+MLDesi2zohBW6MVq6b4pOQ==", 210 | "dev": true, 211 | "requires": { 212 | "lodash": "^4.17.13" 213 | } 214 | }, 215 | "@babel/helper-replace-supers": { 216 | "version": "7.10.4", 217 | "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.10.4.tgz", 218 | "integrity": "sha512-sPxZfFXocEymYTdVK1UNmFPBN+Hv5mJkLPsYWwGBxZAxaWfFu+xqp7b6qWD0yjNuNL2VKc6L5M18tOXUP7NU0A==", 219 | "dev": true, 220 | "requires": { 221 | "@babel/helper-member-expression-to-functions": "^7.10.4", 222 | "@babel/helper-optimise-call-expression": "^7.10.4", 223 | "@babel/traverse": "^7.10.4", 224 | "@babel/types": "^7.10.4" 225 | } 226 | }, 227 | "@babel/helper-simple-access": { 228 | "version": "7.10.4", 229 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.10.4.tgz", 230 | "integrity": "sha512-0fMy72ej/VEvF8ULmX6yb5MtHG4uH4Dbd6I/aHDb/JVg0bbivwt9Wg+h3uMvX+QSFtwr5MeItvazbrc4jtRAXw==", 231 | "dev": true, 232 | "requires": { 233 | "@babel/template": "^7.10.4", 234 | "@babel/types": "^7.10.4" 235 | } 236 | }, 237 | "@babel/helper-split-export-declaration": { 238 | "version": "7.10.4", 239 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.10.4.tgz", 240 | "integrity": "sha512-pySBTeoUff56fL5CBU2hWm9TesA4r/rOkI9DyJLvvgz09MB9YtfIYe3iBriVaYNaPe+Alua0vBIOVOLs2buWhg==", 241 | "dev": true, 242 | "requires": { 243 | "@babel/types": "^7.10.4" 244 | } 245 | }, 246 | "@babel/helper-validator-identifier": { 247 | "version": "7.10.4", 248 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz", 249 | "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==", 250 | "dev": true 251 | }, 252 | "@babel/helpers": { 253 | "version": "7.10.4", 254 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.10.4.tgz", 255 | "integrity": "sha512-L2gX/XeUONeEbI78dXSrJzGdz4GQ+ZTA/aazfUsFaWjSe95kiCuOZ5HsXvkiw3iwF+mFHSRUfJU8t6YavocdXA==", 256 | "dev": true, 257 | "requires": { 258 | "@babel/template": "^7.10.4", 259 | "@babel/traverse": "^7.10.4", 260 | "@babel/types": "^7.10.4" 261 | } 262 | }, 263 | "@babel/highlight": { 264 | "version": "7.10.4", 265 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz", 266 | "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==", 267 | "dev": true, 268 | "requires": { 269 | "@babel/helper-validator-identifier": "^7.10.4", 270 | "chalk": "^2.0.0", 271 | "js-tokens": "^4.0.0" 272 | } 273 | }, 274 | "@babel/parser": { 275 | "version": "7.10.4", 276 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.10.4.tgz", 277 | "integrity": "sha512-8jHII4hf+YVDsskTF6WuMB3X4Eh+PsUkC2ljq22so5rHvH+T8BzyL94VOdyFLNR8tBSVXOTbNHOKpR4TfRxVtA==", 278 | "dev": true 279 | }, 280 | "@babel/plugin-proposal-class-properties": { 281 | "version": "7.10.4", 282 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.10.4.tgz", 283 | "integrity": "sha512-vhwkEROxzcHGNu2mzUC0OFFNXdZ4M23ib8aRRcJSsW8BZK9pQMD7QB7csl97NBbgGZO7ZyHUyKDnxzOaP4IrCg==", 284 | "dev": true, 285 | "requires": { 286 | "@babel/helper-create-class-features-plugin": "^7.10.4", 287 | "@babel/helper-plugin-utils": "^7.10.4" 288 | } 289 | }, 290 | "@babel/plugin-proposal-export-default-from": { 291 | "version": "7.10.4", 292 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-default-from/-/plugin-proposal-export-default-from-7.10.4.tgz", 293 | "integrity": "sha512-G1l00VvDZ7Yk2yRlC5D8Ybvu3gmeHS3rCHoUYdjrqGYUtdeOBoRypnvDZ5KQqxyaiiGHWnVDeSEzA5F9ozItig==", 294 | "dev": true, 295 | "requires": { 296 | "@babel/helper-plugin-utils": "^7.10.4", 297 | "@babel/plugin-syntax-export-default-from": "^7.10.4" 298 | } 299 | }, 300 | "@babel/plugin-proposal-nullish-coalescing-operator": { 301 | "version": "7.10.4", 302 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.10.4.tgz", 303 | "integrity": "sha512-wq5n1M3ZUlHl9sqT2ok1T2/MTt6AXE0e1Lz4WzWBr95LsAZ5qDXe4KnFuauYyEyLiohvXFMdbsOTMyLZs91Zlw==", 304 | "dev": true, 305 | "requires": { 306 | "@babel/helper-plugin-utils": "^7.10.4", 307 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.0" 308 | } 309 | }, 310 | "@babel/plugin-proposal-object-rest-spread": { 311 | "version": "7.10.4", 312 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.10.4.tgz", 313 | "integrity": "sha512-6vh4SqRuLLarjgeOf4EaROJAHjvu9Gl+/346PbDH9yWbJyfnJ/ah3jmYKYtswEyCoWZiidvVHjHshd4WgjB9BA==", 314 | "dev": true, 315 | "requires": { 316 | "@babel/helper-plugin-utils": "^7.10.4", 317 | "@babel/plugin-syntax-object-rest-spread": "^7.8.0", 318 | "@babel/plugin-transform-parameters": "^7.10.4" 319 | } 320 | }, 321 | "@babel/plugin-proposal-optional-catch-binding": { 322 | "version": "7.10.4", 323 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.10.4.tgz", 324 | "integrity": "sha512-LflT6nPh+GK2MnFiKDyLiqSqVHkQnVf7hdoAvyTnnKj9xB3docGRsdPuxp6qqqW19ifK3xgc9U5/FwrSaCNX5g==", 325 | "dev": true, 326 | "requires": { 327 | "@babel/helper-plugin-utils": "^7.10.4", 328 | "@babel/plugin-syntax-optional-catch-binding": "^7.8.0" 329 | } 330 | }, 331 | "@babel/plugin-proposal-optional-chaining": { 332 | "version": "7.10.4", 333 | "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.10.4.tgz", 334 | "integrity": "sha512-ZIhQIEeavTgouyMSdZRap4VPPHqJJ3NEs2cuHs5p0erH+iz6khB0qfgU8g7UuJkG88+fBMy23ZiU+nuHvekJeQ==", 335 | "dev": true, 336 | "requires": { 337 | "@babel/helper-plugin-utils": "^7.10.4", 338 | "@babel/plugin-syntax-optional-chaining": "^7.8.0" 339 | } 340 | }, 341 | "@babel/plugin-syntax-dynamic-import": { 342 | "version": "7.8.3", 343 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", 344 | "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", 345 | "dev": true, 346 | "requires": { 347 | "@babel/helper-plugin-utils": "^7.8.0" 348 | } 349 | }, 350 | "@babel/plugin-syntax-export-default-from": { 351 | "version": "7.10.4", 352 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-default-from/-/plugin-syntax-export-default-from-7.10.4.tgz", 353 | "integrity": "sha512-79V6r6Pgudz0RnuMGp5xidu6Z+bPFugh8/Q9eDHonmLp4wKFAZDwygJwYgCzuDu8lFA/sYyT+mc5y2wkd7bTXA==", 354 | "dev": true, 355 | "requires": { 356 | "@babel/helper-plugin-utils": "^7.10.4" 357 | } 358 | }, 359 | "@babel/plugin-syntax-flow": { 360 | "version": "7.10.4", 361 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.10.4.tgz", 362 | "integrity": "sha512-yxQsX1dJixF4qEEdzVbst3SZQ58Nrooz8NV9Z9GL4byTE25BvJgl5lf0RECUf0fh28rZBb/RYTWn/eeKwCMrZQ==", 363 | "dev": true, 364 | "requires": { 365 | "@babel/helper-plugin-utils": "^7.10.4" 366 | } 367 | }, 368 | "@babel/plugin-syntax-jsx": { 369 | "version": "7.10.4", 370 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.10.4.tgz", 371 | "integrity": "sha512-KCg9mio9jwiARCB7WAcQ7Y1q+qicILjoK8LP/VkPkEKaf5dkaZZK1EcTe91a3JJlZ3qy6L5s9X52boEYi8DM9g==", 372 | "dev": true, 373 | "requires": { 374 | "@babel/helper-plugin-utils": "^7.10.4" 375 | } 376 | }, 377 | "@babel/plugin-syntax-nullish-coalescing-operator": { 378 | "version": "7.8.3", 379 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", 380 | "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", 381 | "dev": true, 382 | "requires": { 383 | "@babel/helper-plugin-utils": "^7.8.0" 384 | } 385 | }, 386 | "@babel/plugin-syntax-object-rest-spread": { 387 | "version": "7.8.3", 388 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", 389 | "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", 390 | "dev": true, 391 | "requires": { 392 | "@babel/helper-plugin-utils": "^7.8.0" 393 | } 394 | }, 395 | "@babel/plugin-syntax-optional-catch-binding": { 396 | "version": "7.8.3", 397 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", 398 | "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", 399 | "dev": true, 400 | "requires": { 401 | "@babel/helper-plugin-utils": "^7.8.0" 402 | } 403 | }, 404 | "@babel/plugin-syntax-optional-chaining": { 405 | "version": "7.8.3", 406 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", 407 | "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", 408 | "dev": true, 409 | "requires": { 410 | "@babel/helper-plugin-utils": "^7.8.0" 411 | } 412 | }, 413 | "@babel/plugin-syntax-typescript": { 414 | "version": "7.10.4", 415 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.10.4.tgz", 416 | "integrity": "sha512-oSAEz1YkBCAKr5Yiq8/BNtvSAPwkp/IyUnwZogd8p+F0RuYQQrLeRUzIQhueQTTBy/F+a40uS7OFKxnkRvmvFQ==", 417 | "dev": true, 418 | "requires": { 419 | "@babel/helper-plugin-utils": "^7.10.4" 420 | } 421 | }, 422 | "@babel/plugin-transform-arrow-functions": { 423 | "version": "7.10.4", 424 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.10.4.tgz", 425 | "integrity": "sha512-9J/oD1jV0ZCBcgnoFWFq1vJd4msoKb/TCpGNFyyLt0zABdcvgK3aYikZ8HjzB14c26bc7E3Q1yugpwGy2aTPNA==", 426 | "dev": true, 427 | "requires": { 428 | "@babel/helper-plugin-utils": "^7.10.4" 429 | } 430 | }, 431 | "@babel/plugin-transform-block-scoping": { 432 | "version": "7.10.4", 433 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.10.4.tgz", 434 | "integrity": "sha512-J3b5CluMg3hPUii2onJDRiaVbPtKFPLEaV5dOPY5OeAbDi1iU/UbbFFTgwb7WnanaDy7bjU35kc26W3eM5Qa0A==", 435 | "dev": true, 436 | "requires": { 437 | "@babel/helper-plugin-utils": "^7.10.4", 438 | "lodash": "^4.17.13" 439 | } 440 | }, 441 | "@babel/plugin-transform-classes": { 442 | "version": "7.10.4", 443 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.10.4.tgz", 444 | "integrity": "sha512-2oZ9qLjt161dn1ZE0Ms66xBncQH4In8Sqw1YWgBUZuGVJJS5c0OFZXL6dP2MRHrkU/eKhWg8CzFJhRQl50rQxA==", 445 | "dev": true, 446 | "requires": { 447 | "@babel/helper-annotate-as-pure": "^7.10.4", 448 | "@babel/helper-define-map": "^7.10.4", 449 | "@babel/helper-function-name": "^7.10.4", 450 | "@babel/helper-optimise-call-expression": "^7.10.4", 451 | "@babel/helper-plugin-utils": "^7.10.4", 452 | "@babel/helper-replace-supers": "^7.10.4", 453 | "@babel/helper-split-export-declaration": "^7.10.4", 454 | "globals": "^11.1.0" 455 | } 456 | }, 457 | "@babel/plugin-transform-computed-properties": { 458 | "version": "7.10.4", 459 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.10.4.tgz", 460 | "integrity": "sha512-JFwVDXcP/hM/TbyzGq3l/XWGut7p46Z3QvqFMXTfk6/09m7xZHJUN9xHfsv7vqqD4YnfI5ueYdSJtXqqBLyjBw==", 461 | "dev": true, 462 | "requires": { 463 | "@babel/helper-plugin-utils": "^7.10.4" 464 | } 465 | }, 466 | "@babel/plugin-transform-destructuring": { 467 | "version": "7.10.4", 468 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.10.4.tgz", 469 | "integrity": "sha512-+WmfvyfsyF603iPa6825mq6Qrb7uLjTOsa3XOFzlYcYDHSS4QmpOWOL0NNBY5qMbvrcf3tq0Cw+v4lxswOBpgA==", 470 | "dev": true, 471 | "requires": { 472 | "@babel/helper-plugin-utils": "^7.10.4" 473 | } 474 | }, 475 | "@babel/plugin-transform-exponentiation-operator": { 476 | "version": "7.10.4", 477 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.10.4.tgz", 478 | "integrity": "sha512-S5HgLVgkBcRdyQAHbKj+7KyuWx8C6t5oETmUuwz1pt3WTWJhsUV0WIIXuVvfXMxl/QQyHKlSCNNtaIamG8fysw==", 479 | "dev": true, 480 | "requires": { 481 | "@babel/helper-builder-binary-assignment-operator-visitor": "^7.10.4", 482 | "@babel/helper-plugin-utils": "^7.10.4" 483 | } 484 | }, 485 | "@babel/plugin-transform-flow-strip-types": { 486 | "version": "7.10.4", 487 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.10.4.tgz", 488 | "integrity": "sha512-XTadyuqNst88UWBTdLjM+wEY7BFnY2sYtPyAidfC7M/QaZnSuIZpMvLxqGT7phAcnGyWh/XQFLKcGf04CnvxSQ==", 489 | "dev": true, 490 | "requires": { 491 | "@babel/helper-plugin-utils": "^7.10.4", 492 | "@babel/plugin-syntax-flow": "^7.10.4" 493 | } 494 | }, 495 | "@babel/plugin-transform-for-of": { 496 | "version": "7.10.4", 497 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.10.4.tgz", 498 | "integrity": "sha512-ItdQfAzu9AlEqmusA/65TqJ79eRcgGmpPPFvBnGILXZH975G0LNjP1yjHvGgfuCxqrPPueXOPe+FsvxmxKiHHQ==", 499 | "dev": true, 500 | "requires": { 501 | "@babel/helper-plugin-utils": "^7.10.4" 502 | } 503 | }, 504 | "@babel/plugin-transform-function-name": { 505 | "version": "7.10.4", 506 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.10.4.tgz", 507 | "integrity": "sha512-OcDCq2y5+E0dVD5MagT5X+yTRbcvFjDI2ZVAottGH6tzqjx/LKpgkUepu3hp/u4tZBzxxpNGwLsAvGBvQ2mJzg==", 508 | "dev": true, 509 | "requires": { 510 | "@babel/helper-function-name": "^7.10.4", 511 | "@babel/helper-plugin-utils": "^7.10.4" 512 | } 513 | }, 514 | "@babel/plugin-transform-literals": { 515 | "version": "7.10.4", 516 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.10.4.tgz", 517 | "integrity": "sha512-Xd/dFSTEVuUWnyZiMu76/InZxLTYilOSr1UlHV+p115Z/Le2Fi1KXkJUYz0b42DfndostYlPub3m8ZTQlMaiqQ==", 518 | "dev": true, 519 | "requires": { 520 | "@babel/helper-plugin-utils": "^7.10.4" 521 | } 522 | }, 523 | "@babel/plugin-transform-modules-commonjs": { 524 | "version": "7.10.4", 525 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.10.4.tgz", 526 | "integrity": "sha512-Xj7Uq5o80HDLlW64rVfDBhao6OX89HKUmb+9vWYaLXBZOma4gA6tw4Ni1O5qVDoZWUV0fxMYA0aYzOawz0l+1w==", 527 | "dev": true, 528 | "requires": { 529 | "@babel/helper-module-transforms": "^7.10.4", 530 | "@babel/helper-plugin-utils": "^7.10.4", 531 | "@babel/helper-simple-access": "^7.10.4", 532 | "babel-plugin-dynamic-import-node": "^2.3.3" 533 | } 534 | }, 535 | "@babel/plugin-transform-object-assign": { 536 | "version": "7.10.4", 537 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-assign/-/plugin-transform-object-assign-7.10.4.tgz", 538 | "integrity": "sha512-6zccDhYEICfMeQqIjuY5G09/yhKzG30DKHJeYBQUHIsJH7c2jXSGvgwRalufLAXAq432OSlsEfAOLlzEsQzxVw==", 539 | "dev": true, 540 | "requires": { 541 | "@babel/helper-plugin-utils": "^7.10.4" 542 | } 543 | }, 544 | "@babel/plugin-transform-parameters": { 545 | "version": "7.10.4", 546 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.10.4.tgz", 547 | "integrity": "sha512-RurVtZ/D5nYfEg0iVERXYKEgDFeesHrHfx8RT05Sq57ucj2eOYAP6eu5fynL4Adju4I/mP/I6SO0DqNWAXjfLQ==", 548 | "dev": true, 549 | "requires": { 550 | "@babel/helper-get-function-arity": "^7.10.4", 551 | "@babel/helper-plugin-utils": "^7.10.4" 552 | } 553 | }, 554 | "@babel/plugin-transform-react-display-name": { 555 | "version": "7.10.4", 556 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.10.4.tgz", 557 | "integrity": "sha512-Zd4X54Mu9SBfPGnEcaGcOrVAYOtjT2on8QZkLKEq1S/tHexG39d9XXGZv19VfRrDjPJzFmPfTAqOQS1pfFOujw==", 558 | "dev": true, 559 | "requires": { 560 | "@babel/helper-plugin-utils": "^7.10.4" 561 | } 562 | }, 563 | "@babel/plugin-transform-react-jsx": { 564 | "version": "7.10.4", 565 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.10.4.tgz", 566 | "integrity": "sha512-L+MfRhWjX0eI7Js093MM6MacKU4M6dnCRa/QPDwYMxjljzSCzzlzKzj9Pk4P3OtrPcxr2N3znR419nr3Xw+65A==", 567 | "dev": true, 568 | "requires": { 569 | "@babel/helper-builder-react-jsx": "^7.10.4", 570 | "@babel/helper-builder-react-jsx-experimental": "^7.10.4", 571 | "@babel/helper-plugin-utils": "^7.10.4", 572 | "@babel/plugin-syntax-jsx": "^7.10.4" 573 | } 574 | }, 575 | "@babel/plugin-transform-react-jsx-self": { 576 | "version": "7.10.4", 577 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.10.4.tgz", 578 | "integrity": "sha512-yOvxY2pDiVJi0axdTWHSMi5T0DILN+H+SaeJeACHKjQLezEzhLx9nEF9xgpBLPtkZsks9cnb5P9iBEi21En3gg==", 579 | "dev": true, 580 | "requires": { 581 | "@babel/helper-plugin-utils": "^7.10.4", 582 | "@babel/plugin-syntax-jsx": "^7.10.4" 583 | } 584 | }, 585 | "@babel/plugin-transform-react-jsx-source": { 586 | "version": "7.10.4", 587 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.10.4.tgz", 588 | "integrity": "sha512-FTK3eQFrPv2aveerUSazFmGygqIdTtvskG50SnGnbEUnRPcGx2ylBhdFIzoVS1ty44hEgcPoCAyw5r3VDEq+Ug==", 589 | "dev": true, 590 | "requires": { 591 | "@babel/helper-plugin-utils": "^7.10.4", 592 | "@babel/plugin-syntax-jsx": "^7.10.4" 593 | } 594 | }, 595 | "@babel/plugin-transform-regenerator": { 596 | "version": "7.10.4", 597 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.10.4.tgz", 598 | "integrity": "sha512-3thAHwtor39A7C04XucbMg17RcZ3Qppfxr22wYzZNcVIkPHfpM9J0SO8zuCV6SZa265kxBJSrfKTvDCYqBFXGw==", 599 | "dev": true, 600 | "requires": { 601 | "regenerator-transform": "^0.14.2" 602 | } 603 | }, 604 | "@babel/plugin-transform-runtime": { 605 | "version": "7.10.4", 606 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.10.4.tgz", 607 | "integrity": "sha512-8ULlGv8p+Vuxu+kz2Y1dk6MYS2b/Dki+NO6/0ZlfSj5tMalfDL7jI/o/2a+rrWLqSXvnadEqc2WguB4gdQIxZw==", 608 | "dev": true, 609 | "requires": { 610 | "@babel/helper-module-imports": "^7.10.4", 611 | "@babel/helper-plugin-utils": "^7.10.4", 612 | "resolve": "^1.8.1", 613 | "semver": "^5.5.1" 614 | } 615 | }, 616 | "@babel/plugin-transform-shorthand-properties": { 617 | "version": "7.10.4", 618 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.10.4.tgz", 619 | "integrity": "sha512-AC2K/t7o07KeTIxMoHneyX90v3zkm5cjHJEokrPEAGEy3UCp8sLKfnfOIGdZ194fyN4wfX/zZUWT9trJZ0qc+Q==", 620 | "dev": true, 621 | "requires": { 622 | "@babel/helper-plugin-utils": "^7.10.4" 623 | } 624 | }, 625 | "@babel/plugin-transform-spread": { 626 | "version": "7.10.4", 627 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.10.4.tgz", 628 | "integrity": "sha512-1e/51G/Ni+7uH5gktbWv+eCED9pP8ZpRhZB3jOaI3mmzfvJTWHkuyYTv0Z5PYtyM+Tr2Ccr9kUdQxn60fI5WuQ==", 629 | "dev": true, 630 | "requires": { 631 | "@babel/helper-plugin-utils": "^7.10.4" 632 | } 633 | }, 634 | "@babel/plugin-transform-sticky-regex": { 635 | "version": "7.10.4", 636 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.10.4.tgz", 637 | "integrity": "sha512-Ddy3QZfIbEV0VYcVtFDCjeE4xwVTJWTmUtorAJkn6u/92Z/nWJNV+mILyqHKrUxXYKA2EoCilgoPePymKL4DvQ==", 638 | "dev": true, 639 | "requires": { 640 | "@babel/helper-plugin-utils": "^7.10.4", 641 | "@babel/helper-regex": "^7.10.4" 642 | } 643 | }, 644 | "@babel/plugin-transform-template-literals": { 645 | "version": "7.10.4", 646 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.10.4.tgz", 647 | "integrity": "sha512-4NErciJkAYe+xI5cqfS8pV/0ntlY5N5Ske/4ImxAVX7mk9Rxt2bwDTGv1Msc2BRJvWQcmYEC+yoMLdX22aE4VQ==", 648 | "dev": true, 649 | "requires": { 650 | "@babel/helper-annotate-as-pure": "^7.10.4", 651 | "@babel/helper-plugin-utils": "^7.10.4" 652 | } 653 | }, 654 | "@babel/plugin-transform-typescript": { 655 | "version": "7.10.4", 656 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.10.4.tgz", 657 | "integrity": "sha512-3WpXIKDJl/MHoAN0fNkSr7iHdUMHZoppXjf2HJ9/ed5Xht5wNIsXllJXdityKOxeA3Z8heYRb1D3p2H5rfCdPw==", 658 | "dev": true, 659 | "requires": { 660 | "@babel/helper-create-class-features-plugin": "^7.10.4", 661 | "@babel/helper-plugin-utils": "^7.10.4", 662 | "@babel/plugin-syntax-typescript": "^7.10.4" 663 | } 664 | }, 665 | "@babel/plugin-transform-unicode-regex": { 666 | "version": "7.10.4", 667 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.10.4.tgz", 668 | "integrity": "sha512-wNfsc4s8N2qnIwpO/WP2ZiSyjfpTamT2C9V9FDH/Ljub9zw6P3SjkXcFmc0RQUt96k2fmIvtla2MMjgTwIAC+A==", 669 | "dev": true, 670 | "requires": { 671 | "@babel/helper-create-regexp-features-plugin": "^7.10.4", 672 | "@babel/helper-plugin-utils": "^7.10.4" 673 | } 674 | }, 675 | "@babel/runtime": { 676 | "version": "7.10.4", 677 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.10.4.tgz", 678 | "integrity": "sha512-UpTN5yUJr9b4EX2CnGNWIvER7Ab83ibv0pcvvHc4UOdrBI5jb8bj+32cCwPX6xu0mt2daFNjYhoi+X7beH0RSw==", 679 | "dev": true, 680 | "requires": { 681 | "regenerator-runtime": "^0.13.4" 682 | } 683 | }, 684 | "@babel/template": { 685 | "version": "7.10.4", 686 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz", 687 | "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==", 688 | "dev": true, 689 | "requires": { 690 | "@babel/code-frame": "^7.10.4", 691 | "@babel/parser": "^7.10.4", 692 | "@babel/types": "^7.10.4" 693 | } 694 | }, 695 | "@babel/traverse": { 696 | "version": "7.10.4", 697 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.10.4.tgz", 698 | "integrity": "sha512-aSy7p5THgSYm4YyxNGz6jZpXf+Ok40QF3aA2LyIONkDHpAcJzDUqlCKXv6peqYUs2gmic849C/t2HKw2a2K20Q==", 699 | "dev": true, 700 | "requires": { 701 | "@babel/code-frame": "^7.10.4", 702 | "@babel/generator": "^7.10.4", 703 | "@babel/helper-function-name": "^7.10.4", 704 | "@babel/helper-split-export-declaration": "^7.10.4", 705 | "@babel/parser": "^7.10.4", 706 | "@babel/types": "^7.10.4", 707 | "debug": "^4.1.0", 708 | "globals": "^11.1.0", 709 | "lodash": "^4.17.13" 710 | } 711 | }, 712 | "@babel/types": { 713 | "version": "7.10.4", 714 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.10.4.tgz", 715 | "integrity": "sha512-UTCFOxC3FsFHb7lkRMVvgLzaRVamXuAs2Tz4wajva4WxtVY82eZeaUBtC2Zt95FU9TiznuC0Zk35tsim8jeVpg==", 716 | "dev": true, 717 | "requires": { 718 | "@babel/helper-validator-identifier": "^7.10.4", 719 | "lodash": "^4.17.13", 720 | "to-fast-properties": "^2.0.0" 721 | } 722 | }, 723 | "ansi-styles": { 724 | "version": "3.2.1", 725 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 726 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 727 | "dev": true, 728 | "requires": { 729 | "color-convert": "^1.9.0" 730 | } 731 | }, 732 | "babel-plugin-dynamic-import-node": { 733 | "version": "2.3.3", 734 | "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz", 735 | "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==", 736 | "dev": true, 737 | "requires": { 738 | "object.assign": "^4.1.0" 739 | } 740 | }, 741 | "chalk": { 742 | "version": "2.4.2", 743 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 744 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 745 | "dev": true, 746 | "requires": { 747 | "ansi-styles": "^3.2.1", 748 | "escape-string-regexp": "^1.0.5", 749 | "supports-color": "^5.3.0" 750 | } 751 | }, 752 | "color-convert": { 753 | "version": "1.9.3", 754 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 755 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 756 | "dev": true, 757 | "requires": { 758 | "color-name": "1.1.3" 759 | } 760 | }, 761 | "color-name": { 762 | "version": "1.1.3", 763 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 764 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 765 | "dev": true 766 | }, 767 | "convert-source-map": { 768 | "version": "1.7.0", 769 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 770 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 771 | "dev": true, 772 | "requires": { 773 | "safe-buffer": "~5.1.1" 774 | } 775 | }, 776 | "debug": { 777 | "version": "4.1.1", 778 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 779 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 780 | "dev": true, 781 | "requires": { 782 | "ms": "^2.1.1" 783 | } 784 | }, 785 | "define-properties": { 786 | "version": "1.1.3", 787 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 788 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 789 | "dev": true, 790 | "requires": { 791 | "object-keys": "^1.0.12" 792 | } 793 | }, 794 | "escape-string-regexp": { 795 | "version": "1.0.5", 796 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 797 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 798 | "dev": true 799 | }, 800 | "function-bind": { 801 | "version": "1.1.1", 802 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 803 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 804 | "dev": true 805 | }, 806 | "gensync": { 807 | "version": "1.0.0-beta.1", 808 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", 809 | "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==", 810 | "dev": true 811 | }, 812 | "globals": { 813 | "version": "11.12.0", 814 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 815 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 816 | "dev": true 817 | }, 818 | "has-flag": { 819 | "version": "3.0.0", 820 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 821 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 822 | "dev": true 823 | }, 824 | "has-symbols": { 825 | "version": "1.0.1", 826 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 827 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 828 | "dev": true 829 | }, 830 | "js-tokens": { 831 | "version": "4.0.0", 832 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 833 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 834 | "dev": true 835 | }, 836 | "jsesc": { 837 | "version": "2.5.2", 838 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 839 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 840 | "dev": true 841 | }, 842 | "json5": { 843 | "version": "2.1.3", 844 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", 845 | "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", 846 | "dev": true, 847 | "requires": { 848 | "minimist": "^1.2.5" 849 | } 850 | }, 851 | "lodash": { 852 | "version": "4.17.19", 853 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 854 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 855 | "dev": true 856 | }, 857 | "lodash.get": { 858 | "version": "4.4.2", 859 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 860 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 861 | }, 862 | "loose-envify": { 863 | "version": "1.4.0", 864 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 865 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 866 | "dev": true, 867 | "requires": { 868 | "js-tokens": "^3.0.0 || ^4.0.0" 869 | } 870 | }, 871 | "metro-react-native-babel-preset": { 872 | "version": "0.59.0", 873 | "resolved": "https://registry.npmjs.org/metro-react-native-babel-preset/-/metro-react-native-babel-preset-0.59.0.tgz", 874 | "integrity": "sha512-BoO6ncPfceIDReIH8pQ5tQptcGo5yRWQXJGVXfANbiKLq4tfgdZB1C1e2rMUJ6iypmeJU9dzl+EhPmIFKtgREg==", 875 | "dev": true, 876 | "requires": { 877 | "@babel/plugin-proposal-class-properties": "^7.0.0", 878 | "@babel/plugin-proposal-export-default-from": "^7.0.0", 879 | "@babel/plugin-proposal-nullish-coalescing-operator": "^7.0.0", 880 | "@babel/plugin-proposal-object-rest-spread": "^7.0.0", 881 | "@babel/plugin-proposal-optional-catch-binding": "^7.0.0", 882 | "@babel/plugin-proposal-optional-chaining": "^7.0.0", 883 | "@babel/plugin-syntax-dynamic-import": "^7.0.0", 884 | "@babel/plugin-syntax-export-default-from": "^7.0.0", 885 | "@babel/plugin-syntax-flow": "^7.2.0", 886 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.0.0", 887 | "@babel/plugin-syntax-optional-chaining": "^7.0.0", 888 | "@babel/plugin-transform-arrow-functions": "^7.0.0", 889 | "@babel/plugin-transform-block-scoping": "^7.0.0", 890 | "@babel/plugin-transform-classes": "^7.0.0", 891 | "@babel/plugin-transform-computed-properties": "^7.0.0", 892 | "@babel/plugin-transform-destructuring": "^7.0.0", 893 | "@babel/plugin-transform-exponentiation-operator": "^7.0.0", 894 | "@babel/plugin-transform-flow-strip-types": "^7.0.0", 895 | "@babel/plugin-transform-for-of": "^7.0.0", 896 | "@babel/plugin-transform-function-name": "^7.0.0", 897 | "@babel/plugin-transform-literals": "^7.0.0", 898 | "@babel/plugin-transform-modules-commonjs": "^7.0.0", 899 | "@babel/plugin-transform-object-assign": "^7.0.0", 900 | "@babel/plugin-transform-parameters": "^7.0.0", 901 | "@babel/plugin-transform-react-display-name": "^7.0.0", 902 | "@babel/plugin-transform-react-jsx": "^7.0.0", 903 | "@babel/plugin-transform-react-jsx-self": "^7.0.0", 904 | "@babel/plugin-transform-react-jsx-source": "^7.0.0", 905 | "@babel/plugin-transform-regenerator": "^7.0.0", 906 | "@babel/plugin-transform-runtime": "^7.0.0", 907 | "@babel/plugin-transform-shorthand-properties": "^7.0.0", 908 | "@babel/plugin-transform-spread": "^7.0.0", 909 | "@babel/plugin-transform-sticky-regex": "^7.0.0", 910 | "@babel/plugin-transform-template-literals": "^7.0.0", 911 | "@babel/plugin-transform-typescript": "^7.5.0", 912 | "@babel/plugin-transform-unicode-regex": "^7.0.0", 913 | "@babel/template": "^7.0.0", 914 | "react-refresh": "^0.4.0" 915 | } 916 | }, 917 | "minimist": { 918 | "version": "1.2.5", 919 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 920 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 921 | "dev": true 922 | }, 923 | "ms": { 924 | "version": "2.1.2", 925 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 926 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 927 | "dev": true 928 | }, 929 | "object-assign": { 930 | "version": "4.1.1", 931 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 932 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 933 | "dev": true 934 | }, 935 | "object-keys": { 936 | "version": "1.1.1", 937 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 938 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 939 | "dev": true 940 | }, 941 | "object.assign": { 942 | "version": "4.1.0", 943 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 944 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 945 | "dev": true, 946 | "requires": { 947 | "define-properties": "^1.1.2", 948 | "function-bind": "^1.1.1", 949 | "has-symbols": "^1.0.0", 950 | "object-keys": "^1.0.11" 951 | } 952 | }, 953 | "path-parse": { 954 | "version": "1.0.6", 955 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 956 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 957 | "dev": true 958 | }, 959 | "prop-types": { 960 | "version": "15.7.2", 961 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", 962 | "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", 963 | "dev": true, 964 | "requires": { 965 | "loose-envify": "^1.4.0", 966 | "object-assign": "^4.1.1", 967 | "react-is": "^16.8.1" 968 | } 969 | }, 970 | "react-is": { 971 | "version": "16.13.1", 972 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 973 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 974 | "dev": true 975 | }, 976 | "react-refresh": { 977 | "version": "0.4.3", 978 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.4.3.tgz", 979 | "integrity": "sha512-Hwln1VNuGl/6bVwnd0Xdn1e84gT/8T9aYNL+HAKDArLCS7LWjwr7StE30IEYbIkx0Vi3vs+coQxe+SQDbGbbpA==", 980 | "dev": true 981 | }, 982 | "react-test-renderer": { 983 | "version": "16.13.1", 984 | "resolved": "https://registry.npmjs.org/react-test-renderer/-/react-test-renderer-16.13.1.tgz", 985 | "integrity": "sha512-Sn2VRyOK2YJJldOqoh8Tn/lWQ+ZiKhyZTPtaO0Q6yNj+QDbmRkVFap6pZPy3YQk8DScRDfyqm/KxKYP9gCMRiQ==", 986 | "dev": true, 987 | "requires": { 988 | "object-assign": "^4.1.1", 989 | "prop-types": "^15.6.2", 990 | "react-is": "^16.8.6", 991 | "scheduler": "^0.19.1" 992 | } 993 | }, 994 | "regenerate": { 995 | "version": "1.4.1", 996 | "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.1.tgz", 997 | "integrity": "sha512-j2+C8+NtXQgEKWk49MMP5P/u2GhnahTtVkRIHr5R5lVRlbKvmQ+oS+A5aLKWp2ma5VkT8sh6v+v4hbH0YHR66A==", 998 | "dev": true 999 | }, 1000 | "regenerate-unicode-properties": { 1001 | "version": "8.2.0", 1002 | "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-8.2.0.tgz", 1003 | "integrity": "sha512-F9DjY1vKLo/tPePDycuH3dn9H1OTPIkVD9Kz4LODu+F2C75mgjAJ7x/gwy6ZcSNRAAkhNlJSOHRe8k3p+K9WhA==", 1004 | "dev": true, 1005 | "requires": { 1006 | "regenerate": "^1.4.0" 1007 | } 1008 | }, 1009 | "regenerator-runtime": { 1010 | "version": "0.13.5", 1011 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz", 1012 | "integrity": "sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==", 1013 | "dev": true 1014 | }, 1015 | "regenerator-transform": { 1016 | "version": "0.14.5", 1017 | "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.14.5.tgz", 1018 | "integrity": "sha512-eOf6vka5IO151Jfsw2NO9WpGX58W6wWmefK3I1zEGr0lOD0u8rwPaNqQL1aRxUaxLeKO3ArNh3VYg1KbaD+FFw==", 1019 | "dev": true, 1020 | "requires": { 1021 | "@babel/runtime": "^7.8.4" 1022 | } 1023 | }, 1024 | "regexpu-core": { 1025 | "version": "4.7.0", 1026 | "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.7.0.tgz", 1027 | "integrity": "sha512-TQ4KXRnIn6tz6tjnrXEkD/sshygKH/j5KzK86X8MkeHyZ8qst/LZ89j3X4/8HEIfHANTFIP/AbXakeRhWIl5YQ==", 1028 | "dev": true, 1029 | "requires": { 1030 | "regenerate": "^1.4.0", 1031 | "regenerate-unicode-properties": "^8.2.0", 1032 | "regjsgen": "^0.5.1", 1033 | "regjsparser": "^0.6.4", 1034 | "unicode-match-property-ecmascript": "^1.0.4", 1035 | "unicode-match-property-value-ecmascript": "^1.2.0" 1036 | } 1037 | }, 1038 | "regjsgen": { 1039 | "version": "0.5.2", 1040 | "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.2.tgz", 1041 | "integrity": "sha512-OFFT3MfrH90xIW8OOSyUrk6QHD5E9JOTeGodiJeBS3J6IwlgzJMNE/1bZklWz5oTg+9dCMyEetclvCVXOPoN3A==", 1042 | "dev": true 1043 | }, 1044 | "regjsparser": { 1045 | "version": "0.6.4", 1046 | "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.4.tgz", 1047 | "integrity": "sha512-64O87/dPDgfk8/RQqC4gkZoGyyWFIEUTTh80CU6CWuK5vkCGyekIx+oKcEIYtP/RAxSQltCZHCNu/mdd7fqlJw==", 1048 | "dev": true, 1049 | "requires": { 1050 | "jsesc": "~0.5.0" 1051 | }, 1052 | "dependencies": { 1053 | "jsesc": { 1054 | "version": "0.5.0", 1055 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", 1056 | "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", 1057 | "dev": true 1058 | } 1059 | } 1060 | }, 1061 | "resolve": { 1062 | "version": "1.17.0", 1063 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz", 1064 | "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==", 1065 | "dev": true, 1066 | "requires": { 1067 | "path-parse": "^1.0.6" 1068 | } 1069 | }, 1070 | "safe-buffer": { 1071 | "version": "5.1.2", 1072 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1073 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1074 | "dev": true 1075 | }, 1076 | "scheduler": { 1077 | "version": "0.19.1", 1078 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.19.1.tgz", 1079 | "integrity": "sha512-n/zwRWRYSUj0/3g/otKDRPMh6qv2SYMWNq85IEa8iZyAv8od9zDYpGSnpBEjNgcMNq6Scbu5KfIPxNF72R/2EA==", 1080 | "dev": true, 1081 | "requires": { 1082 | "loose-envify": "^1.1.0", 1083 | "object-assign": "^4.1.1" 1084 | } 1085 | }, 1086 | "semver": { 1087 | "version": "5.7.1", 1088 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1089 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1090 | "dev": true 1091 | }, 1092 | "source-map": { 1093 | "version": "0.5.7", 1094 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 1095 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 1096 | "dev": true 1097 | }, 1098 | "supports-color": { 1099 | "version": "5.5.0", 1100 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1101 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1102 | "dev": true, 1103 | "requires": { 1104 | "has-flag": "^3.0.0" 1105 | } 1106 | }, 1107 | "to-fast-properties": { 1108 | "version": "2.0.0", 1109 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 1110 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 1111 | "dev": true 1112 | }, 1113 | "unicode-canonical-property-names-ecmascript": { 1114 | "version": "1.0.4", 1115 | "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", 1116 | "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==", 1117 | "dev": true 1118 | }, 1119 | "unicode-match-property-ecmascript": { 1120 | "version": "1.0.4", 1121 | "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", 1122 | "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", 1123 | "dev": true, 1124 | "requires": { 1125 | "unicode-canonical-property-names-ecmascript": "^1.0.4", 1126 | "unicode-property-aliases-ecmascript": "^1.0.4" 1127 | } 1128 | }, 1129 | "unicode-match-property-value-ecmascript": { 1130 | "version": "1.2.0", 1131 | "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.2.0.tgz", 1132 | "integrity": "sha512-wjuQHGQVofmSJv1uVISKLE5zO2rNGzM/KCYZch/QQvez7C1hUhBIuZ701fYXExuufJFMPhv2SyL8CyoIfMLbIQ==", 1133 | "dev": true 1134 | }, 1135 | "unicode-property-aliases-ecmascript": { 1136 | "version": "1.1.0", 1137 | "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.1.0.tgz", 1138 | "integrity": "sha512-PqSoPh/pWetQ2phoj5RLiaqIk4kCNwoV3CI+LfGmWLKI3rE3kl1h59XpX2BjgDrmbxD9ARtQobPGU1SguCYuQg==", 1139 | "dev": true 1140 | } 1141 | } 1142 | } 1143 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-native-comparison-table", 3 | "version": "1.0.0", 4 | "description": "Comparison table with fixed header for React Native", 5 | "main": "index.js", 6 | "nativePackage": true, 7 | "scripts": { 8 | "test": "echo \"Error: no test specified\" && exit 1" 9 | }, 10 | "repository": { 11 | "type": "git", 12 | "url": "git+https://github.com/daroldso/react-native-comparison-table.git" 13 | }, 14 | "keywords": [ 15 | "react-native", 16 | "react-component", 17 | "react-native-component", 18 | "comparison-table", 19 | "react-native-table", 20 | "fixed-header" 21 | ], 22 | "author": { 23 | "name": "Darold So", 24 | "email": "daroldso@gmail.com" 25 | }, 26 | "license": "MIT", 27 | "homepage": "https://github.com/daroldso/react-native-comparison-table", 28 | "dependencies": { 29 | "lodash.get": "^4.4.2" 30 | }, 31 | "devDependencies": { 32 | "@babel/core": "^7.8.4", 33 | "@babel/runtime": "^7.8.4", 34 | "metro-react-native-babel-preset": "^0.59.0", 35 | "prop-types": "^15.7.2", 36 | "react-test-renderer": "16.13.1" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /prettierrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | bracketSpacing: false, 3 | jsxBracketSameLine: false, 4 | singleQuote: true, 5 | trailingComma: 'none' 6 | }; 7 | --------------------------------------------------------------------------------