13 |
14 | @implementation AppDelegate
15 |
16 | - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
17 | {
18 | RCTBridge *bridge = [[RCTBridge alloc] initWithDelegate:self launchOptions:launchOptions];
19 | RCTRootView *rootView = [[RCTRootView alloc] initWithBridge:bridge
20 | moduleName:@"react_native_saas"
21 | initialProperties:nil];
22 |
23 | rootView.backgroundColor = [[UIColor alloc] initWithRed:1.0f green:1.0f blue:1.0f alpha:1];
24 |
25 | self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
26 | UIViewController *rootViewController = [UIViewController new];
27 | rootViewController.view = rootView;
28 | self.window.rootViewController = rootViewController;
29 | [self.window makeKeyAndVisible];
30 | return YES;
31 | }
32 |
33 | - (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
34 | {
35 | #if DEBUG
36 | return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index" fallbackResource:nil];
37 | #else
38 | return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];
39 | #endif
40 | }
41 |
42 | @end
43 |
--------------------------------------------------------------------------------
/src/components/NewTeam/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 | import { useDispatch } from 'react-redux';
3 | import PropTypes from 'prop-types';
4 |
5 | import { Text, TextInput, TouchableOpacity } from 'react-native';
6 |
7 | import { createTeamRequest } from '~/store/modules/teams/actions';
8 |
9 | import Modal from '~/components/Modal';
10 |
11 | import styles from './styles';
12 |
13 | export default function NewTeam({ visible, onRequestClose }) {
14 | const dispatch = useDispatch();
15 | const [newTeam, setNewTeam] = useState('');
16 |
17 | function handleSubmit() {
18 | dispatch(createTeamRequest(newTeam));
19 | setNewTeam('');
20 | onRequestClose();
21 | }
22 |
23 | return (
24 |
25 | NOME
26 | setNewTeam(text)}
34 | />
35 |
36 |
37 | CRIAR TIME
38 |
39 |
40 |
41 | CANCELAR
42 |
43 |
44 | );
45 | }
46 |
47 | NewTeam.propTypes = {
48 | visible: PropTypes.bool.isRequired,
49 | onRequestClose: PropTypes.func.isRequired,
50 | };
51 |
--------------------------------------------------------------------------------
/src/components/NewProject/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 | import { useDispatch } from 'react-redux';
3 | import PropTypes from 'prop-types';
4 |
5 | import { Text, TextInput, TouchableOpacity } from 'react-native';
6 |
7 | import { createProjectRequest } from '~/store/modules/projects/actions';
8 |
9 | import Modal from '~/components/Modal';
10 |
11 | import styles from './styles';
12 |
13 | export default function NewProject({ visible, onRequestClose }) {
14 | const dispatch = useDispatch();
15 | const [newProject, setNewProject] = useState('');
16 |
17 | function handleSubmit() {
18 | dispatch(createProjectRequest(newProject));
19 | setNewProject('');
20 | onRequestClose();
21 | }
22 |
23 | return (
24 |
25 | TÍTULO
26 | setNewProject(text)}
34 | />
35 |
36 |
37 | CRIAR PROJETO
38 |
39 |
40 |
41 | CANCELAR
42 |
43 |
44 | );
45 | }
46 |
47 | NewProject.propTypes = {
48 | visible: PropTypes.bool.isRequired,
49 | onRequestClose: PropTypes.func.isRequired,
50 | };
51 |
--------------------------------------------------------------------------------
/src/store/modules/teams/sagas.js:
--------------------------------------------------------------------------------
1 | import { takeLatest, call, put, all } from 'redux-saga/effects';
2 | import AsyncStorage from '@react-native-community/async-storage';
3 | import { ToastActionsCreators } from 'react-native-redux-toast';
4 | import api from '~/services/api';
5 |
6 | import { getTeamsSuccess, createTeamSuccess, closeTeamModal } from './actions';
7 | import { getProjectsRequest } from '../projects/actions';
8 | import { getMembers } from '../members/sagas';
9 | import { getPermissions } from '../auth/sagas';
10 |
11 | export function* getTeams() {
12 | const response = yield call(api.get, 'teams');
13 |
14 | yield put(getTeamsSuccess(response.data));
15 | }
16 |
17 | export function* createTeam({ payload }) {
18 | try {
19 | const { name } = payload;
20 |
21 | const response = yield call(api.post, 'teams', { name });
22 |
23 | yield put(createTeamSuccess(response.data));
24 | yield put(closeTeamModal());
25 |
26 | yield put(ToastActionsCreators.displayInfo('Time criado'));
27 | } catch (err) {
28 | yield put(ToastActionsCreators.displayError('Erro ao criar time'));
29 | }
30 | }
31 |
32 | export function* selectActiveTeam({ payload }) {
33 | const { team } = payload;
34 |
35 | yield call([AsyncStorage, 'setItem'], '@Omni:team', JSON.stringify(team));
36 |
37 | yield put(getProjectsRequest());
38 | }
39 |
40 | export default all([
41 | takeLatest('@teams/GET_TEAMS_REQUEST', getTeams),
42 | takeLatest('@teams/CREATE_TEAM_REQUEST', createTeam),
43 | takeLatest('@teams/SELECT_TEAM', selectActiveTeam),
44 | takeLatest('@teams/SELECT_TEAM', getMembers),
45 | takeLatest('@teams/SELECT_TEAM', getPermissions),
46 | ]);
47 |
--------------------------------------------------------------------------------
/ios/react_native_saas-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 |
--------------------------------------------------------------------------------
/src/components/InviteMember/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 | import { useDispatch } from 'react-redux';
3 | import PropTypes from 'prop-types';
4 |
5 | import { Text, TextInput, TouchableOpacity } from 'react-native';
6 |
7 | import { inviteMemberRequest } from '~/store/modules/members/actions';
8 |
9 | import Modal from '~/components/Modal';
10 |
11 | import styles from './styles';
12 |
13 | export default function InviteMember({ visible, onRequestClose }) {
14 | const dispatch = useDispatch();
15 | const [email, setEmail] = useState('');
16 |
17 | function handleSubmit() {
18 | dispatch(inviteMemberRequest(email));
19 | setEmail('');
20 | onRequestClose();
21 | }
22 |
23 | return (
24 |
25 | E-MAIL
26 | setEmail(text)}
37 | />
38 |
39 |
40 | CONVIDAR
41 |
42 |
43 |
44 | CANCELAR
45 |
46 |
47 | );
48 | }
49 |
50 | InviteMember.propTypes = {
51 | visible: PropTypes.bool.isRequired,
52 | onRequestClose: PropTypes.func.isRequired,
53 | };
54 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "react_native_saas",
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-native-community/async-storage": "^1.9.0",
14 | "axios": "^1.12.0",
15 | "immer": "^9.0.6",
16 | "prop-types": "^15.7.2",
17 | "react": "16.9.0",
18 | "react-native": "0.62.3",
19 | "react-native-gesture-handler": "^1.6.0",
20 | "react-native-iphone-x-helper": "^1.2.1",
21 | "react-native-redux-toast": "^1.0.3",
22 | "react-native-side-menu": "^1.1.3",
23 | "react-native-vector-icons": "^6.6.0",
24 | "react-navigation": "^4.3.1",
25 | "react-redux": "^7.2.0",
26 | "redux": "^4.0.5",
27 | "redux-saga": "^1.1.3"
28 | },
29 | "devDependencies": {
30 | "@babel/core": "^7.8.7",
31 | "@babel/runtime": "^7.26.10",
32 | "@react-native-community/eslint-config": "^0.0.7",
33 | "babel-eslint": "^10.1.0",
34 | "babel-jest": "^25.1.0",
35 | "babel-plugin-root-import": "^6.4.1",
36 | "eslint": "^6.8.0",
37 | "eslint-config-airbnb": "^18.1.0",
38 | "eslint-config-prettier": "^6.10.0",
39 | "eslint-import-resolver-babel-plugin-root-import": "^1.1.1",
40 | "eslint-plugin-import": "^2.20.1",
41 | "eslint-plugin-jsx-a11y": "^6.2.3",
42 | "eslint-plugin-prettier": "^3.1.2",
43 | "eslint-plugin-react": "^7.19.0",
44 | "eslint-plugin-react-hooks": "^2.5.0",
45 | "jest": "^25.1.0",
46 | "metro-react-native-babel-preset": "^0.58.0",
47 | "prettier": "^1.19.1",
48 | "react-test-renderer": "16.9.0"
49 | },
50 | "jest": {
51 | "preset": "react-native"
52 | }
53 | }
54 |
--------------------------------------------------------------------------------
/ios/react_native_saas/Info.plist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | CFBundleDevelopmentRegion
6 | en
7 | CFBundleDisplayName
8 | react_native_saas
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 | UIAppFonts
57 |
58 |
59 |
60 |
--------------------------------------------------------------------------------
/src/components/Projects/index.js:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { View, Text, FlatList, TouchableOpacity } from 'react-native';
3 | import { useSelector, useDispatch } from 'react-redux';
4 |
5 | import Icon from 'react-native-vector-icons/MaterialIcons';
6 |
7 | import NewProject from '~/components/NewProject';
8 | import Can from '~/components/Can';
9 |
10 | import { getProjectsRequest } from '~/store/modules/projects/actions';
11 |
12 | import styles from './styles';
13 |
14 | export default function Projects() {
15 | const dispatch = useDispatch();
16 | const projects = useSelector(state => state.projects);
17 | const activeTeam = useSelector(state => state.teams.active);
18 | const [isModalOpen, setIsModalOpen] = useState(false);
19 |
20 | useEffect(() => {
21 | if (activeTeam) {
22 | dispatch(getProjectsRequest());
23 | }
24 | // eslint-disable-next-line react-hooks/exhaustive-deps
25 | }, []);
26 |
27 | if (!activeTeam) return null;
28 |
29 | return (
30 |
31 | String(item.id)}
35 | renderItem={({ item }) => (
36 |
37 | {item.title}
38 |
39 | )}
40 | />
41 |
42 |
43 | setIsModalOpen(true)}
46 | >
47 |
48 |
49 |
50 |
51 | setIsModalOpen(false)}
54 | />
55 |
56 | );
57 | }
58 |
--------------------------------------------------------------------------------
/src/components/RoleUpdater/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState, useEffect } from 'react';
2 | import { useDispatch } from 'react-redux';
3 | import PropTypes from 'prop-types';
4 |
5 | import { View, Text, TouchableOpacity, Switch } from 'react-native';
6 | import api from '~/services/api';
7 |
8 | import { updateMemberRequest } from '~/store/modules/members/actions';
9 |
10 | import Modal from '~/components/Modal';
11 |
12 | import styles from './styles';
13 |
14 | export default function RoleUpdater({ visible, onRequestClose, member }) {
15 | const dispatch = useDispatch();
16 | const [roles, setRoles] = useState([]);
17 |
18 | useEffect(() => {
19 | async function loadRoles() {
20 | const response = await api.get('roles');
21 |
22 | setRoles(response.data);
23 | }
24 |
25 | loadRoles();
26 | }, [dispatch]);
27 |
28 | function handleRoleChange(value, role) {
29 | if (role.name === 'Administrador' && value === false) return;
30 |
31 | const roles = value
32 | ? [...member.roles, role]
33 | : member.roles.filter(memberRole => memberRole.id !== role.id);
34 |
35 | dispatch(updateMemberRequest(member.id, roles));
36 | onRequestClose();
37 | }
38 |
39 | return (
40 |
41 |
42 | {roles.map(role => (
43 |
44 | {role.name}
45 |
46 | memberRole.id === role.id)
49 | }
50 | onValueChange={value => handleRoleChange(value, role)}
51 | />
52 |
53 | ))}
54 |
55 |
56 |
57 | Voltar
58 |
59 |
60 | );
61 | }
62 |
63 | RoleUpdater.propTypes = {
64 | visible: PropTypes.bool.isRequired,
65 | onRequestClose: PropTypes.func.isRequired,
66 | };
67 |
--------------------------------------------------------------------------------
/src/store/modules/auth/sagas.js:
--------------------------------------------------------------------------------
1 | import { takeLatest, all, call, put, select } from 'redux-saga/effects';
2 | import AsyncStorage from '@react-native-community/async-storage';
3 | import { ToastActionsCreators } from 'react-native-redux-toast';
4 | import api from '~/services/api';
5 | import NavigationService from '~/services/navigation';
6 |
7 | import {
8 | signInSuccess,
9 | getPermissionsSuccess,
10 | initCheckSuccess,
11 | } from './actions';
12 |
13 | import { selectTeam } from '../teams/actions';
14 |
15 | export function* init() {
16 | const token = yield call([AsyncStorage, 'getItem'], '@Omni:token');
17 |
18 | if (token) {
19 | yield put(signInSuccess(token));
20 | }
21 |
22 | const team = yield call([AsyncStorage, 'getItem'], '@Omni:team');
23 |
24 | if (team) {
25 | yield put(selectTeam(JSON.parse(team)));
26 | }
27 |
28 | yield put(initCheckSuccess());
29 | }
30 |
31 | export function* signIn({ payload }) {
32 | try {
33 | const { email, password } = payload;
34 |
35 | const response = yield call(api.post, 'sessions', { email, password });
36 |
37 | yield call([AsyncStorage, 'setItem'], '@Omni:token', response.data.token);
38 |
39 | yield put(signInSuccess(response.data.token));
40 | NavigationService.navigate('Main');
41 | } catch (err) {
42 | yield put(ToastActionsCreators.displayError('Credenciais inválidas'));
43 | }
44 | }
45 |
46 | export function* signOut() {
47 | yield call([AsyncStorage, 'clear']);
48 | }
49 |
50 | export function* getPermissions() {
51 | const team = yield select(state => state.teams.active);
52 | const signedIn = yield select(state => state.auth.signedIn);
53 |
54 | if (!signedIn || !team) {
55 | return;
56 | }
57 |
58 | const response = yield call(api.get, 'permissions');
59 |
60 | const { roles, permissions } = response.data;
61 |
62 | yield put(getPermissionsSuccess(roles, permissions));
63 | }
64 |
65 | export default all([
66 | takeLatest('@auth/SIGN_IN_REQUEST', signIn),
67 | takeLatest('@auth/SIGN_OUT', signOut),
68 | takeLatest('@auth/INIT_CHECK_SUCCESS', getPermissions),
69 | ]);
70 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
7 |
8 | React Native - SaaS
9 |
10 |
11 |
12 | :cloud: Application using Redux, Redux-Saga, React Native Redux Toast, Immer, react-native-side-menu, React Native Async Storage, react-native-iphone-x-helper, React Native Vector Icons and consuming the features of the Node.js - SaaS API
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 | Demo | Install and run | License
29 |
30 |
31 | ## :iphone: Demo
32 |
33 | 
34 |
35 | ## :wrench: Install and run
36 |
37 | _ps: Before running the app, start the [Node.js - SaaS](https://github.com/osvaldokalvaitir/nodejs-saas) backend._
38 |
39 | Open terminal:
40 |
41 | ```sh
42 | # Clone this repo
43 | git clone https://github.com/osvaldokalvaitir/react-native-saas
44 |
45 | # Entry in folder
46 | cd react-native-saas
47 |
48 | # Install deps with npm or yarn
49 | npm install | yarn
50 |
51 | # Launch the app on android with react-native or yarn
52 | react-native run-android | yarn android
53 |
54 | # Launch the app on ios with react-native or yarn
55 | react-native run-ios | yarn ios
56 | ```
57 |
58 | ## :memo: License
59 |
60 | This project is under the MIT license. See [LICENSE](/LICENSE) for more information.
61 |
62 | ---
63 |
64 |
65 | Developed with 💚 by Osvaldo Kalvaitir Filho
66 |
67 |
--------------------------------------------------------------------------------
/src/components/TeamSwitcher/index.js:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { useSelector, useDispatch } from 'react-redux';
3 | import { View, TouchableOpacity, Image } from 'react-native';
4 |
5 | import Icon from 'react-native-vector-icons/MaterialIcons';
6 |
7 | import { getTeamsRequest, selectTeam } from '~/store/modules/teams/actions';
8 | import { signOut } from '~/store/modules/auth/actions';
9 |
10 | import NewTeam from '~/components/NewTeam';
11 |
12 | import styles from './styles';
13 |
14 | export default function TeamSwitcher() {
15 | const dispatch = useDispatch();
16 | const teams = useSelector(state => state.teams);
17 | const [isModalOpen, setIsModalOpen] = useState(false);
18 |
19 | useEffect(() => {
20 | dispatch(getTeamsRequest());
21 | // eslint-disable-next-line react-hooks/exhaustive-deps
22 | }, []);
23 |
24 | return (
25 |
26 |
27 | {teams.data.map(team => (
28 | {
32 | dispatch(selectTeam(team));
33 | }}
34 | >
35 |
41 |
42 | ))}
43 |
44 | setIsModalOpen(true)}
47 | >
48 |
49 |
50 |
51 | setIsModalOpen(false)}
54 | />
55 |
56 |
57 |
58 | {
61 | dispatch(signOut());
62 | }}
63 | >
64 |
65 |
66 |
67 |
68 | );
69 | }
70 |
--------------------------------------------------------------------------------
/src/pages/SignIn/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState, useRef } from 'react';
2 | import { useDispatch } from 'react-redux';
3 |
4 | import {
5 | View,
6 | Platform,
7 | KeyboardAvoidingView,
8 | Text,
9 | TextInput,
10 | TouchableOpacity,
11 | } from 'react-native';
12 |
13 | import { signInRequest } from '~/store/modules/auth/actions';
14 |
15 | import styles from './styles';
16 |
17 | export default function SignIn() {
18 | const dispatch = useDispatch();
19 |
20 | const [email, setEmail] = useState('');
21 | const [password, setPassword] = useState('');
22 |
23 | let refPassword = useRef(null);
24 |
25 | function handleSubmit() {
26 | dispatch(signInRequest(email, password));
27 | }
28 |
29 | return (
30 |
34 |
35 | Entrar
36 |
37 | E-MAIL
38 | setEmail(text)}
41 | style={styles.input}
42 | keyboardType="email-address"
43 | autoCapitalize="none"
44 | autoCorrect={false}
45 | underlineColorAndroid="transparent"
46 | autoFocus
47 | returnKeyType="next"
48 | onSubmitEditing={() => {
49 | refPassword.focus();
50 | }}
51 | />
52 |
53 | SENHA
54 | setPassword(text)}
57 | style={styles.input}
58 | secureTextEntry
59 | autoCapitalize="none"
60 | autoCorrect={false}
61 | underlineColorAndroid="transparent"
62 | returnKeyType="send"
63 | ref={el => {
64 | refPassword = el;
65 | }}
66 | onSubmitEditing={() => {
67 | handleSubmit();
68 | }}
69 | />
70 |
71 |
72 | Entrar
73 |
74 |
75 |
76 | );
77 | }
78 |
--------------------------------------------------------------------------------
/src/pages/Main/index.js:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 | import { View, TouchableOpacity, Text } from 'react-native';
3 | import SideMenu from 'react-native-side-menu';
4 |
5 | import { useSelector } from 'react-redux';
6 |
7 | import Icon from 'react-native-vector-icons/MaterialIcons';
8 |
9 | import TeamSwitcher from '~/components/TeamSwitcher';
10 | import Projects from '~/components/Projects';
11 | import Members from '~/components/Members';
12 |
13 | import styles from './styles';
14 |
15 | export default function Main() {
16 | const [leftOpen, setLeftOpen] = useState(false);
17 | const [rightOpen, setRightOpen] = useState(false);
18 | const activeTeam = useSelector(state => state.teams.active);
19 |
20 | return (
21 |
22 | setLeftOpen(isOpen)}
26 | openMenuOffset={70}
27 | menu={ }
28 | >
29 | setRightOpen(isOpen)}
33 | openMenuOffset={285}
34 | menuPosition="right"
35 | menu={ }
36 | >
37 |
38 |
39 | {
42 | setLeftOpen(true);
43 | }}
44 | >
45 |
46 |
47 |
48 | {activeTeam ? activeTeam.name : 'Selecione um time'}
49 |
50 | {
53 | setRightOpen(true);
54 | }}
55 | >
56 |
57 |
58 |
59 |
60 |
61 |
62 |
63 |
64 |
65 | );
66 | }
67 |
--------------------------------------------------------------------------------
/ios/react_native_saasTests/react_native_saasTests.m:
--------------------------------------------------------------------------------
1 | /**
2 | * Copyright (c) Facebook, Inc. and its affiliates.
3 | *
4 | * This source code is licensed under the MIT license found in the
5 | * LICENSE file in the root directory of this source tree.
6 | */
7 |
8 | #import
9 | #import
10 |
11 | #import
12 | #import
13 |
14 | #define TIMEOUT_SECONDS 600
15 | #define TEXT_TO_LOOK_FOR @"Welcome to React"
16 |
17 | @interface react_native_saasTests : XCTestCase
18 |
19 | @end
20 |
21 | @implementation react_native_saasTests
22 |
23 | - (BOOL)findSubviewInView:(UIView *)view matching:(BOOL(^)(UIView *view))test
24 | {
25 | if (test(view)) {
26 | return YES;
27 | }
28 | for (UIView *subview in [view subviews]) {
29 | if ([self findSubviewInView:subview matching:test]) {
30 | return YES;
31 | }
32 | }
33 | return NO;
34 | }
35 |
36 | - (void)testRendersWelcomeScreen
37 | {
38 | UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController];
39 | NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS];
40 | BOOL foundElement = NO;
41 |
42 | __block NSString *redboxError = nil;
43 | #ifdef DEBUG
44 | RCTSetLogFunction(^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) {
45 | if (level >= RCTLogLevelError) {
46 | redboxError = message;
47 | }
48 | });
49 | #endif
50 |
51 | while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) {
52 | [[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
53 | [[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]];
54 |
55 | foundElement = [self findSubviewInView:vc.view matching:^BOOL(UIView *view) {
56 | if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) {
57 | return YES;
58 | }
59 | return NO;
60 | }];
61 | }
62 |
63 | #ifdef DEBUG
64 | RCTSetLogFunction(RCTDefaultLogFunction);
65 | #endif
66 |
67 | XCTAssertNil(redboxError, @"RedBox error: %@", redboxError);
68 | XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS);
69 | }
70 |
71 |
72 | @end
73 |
--------------------------------------------------------------------------------
/.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/Libraries/react-native/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/Libraries/react-native/react-native-implementation'
40 | module.name_mapper='^react-native/\(.*\)$' -> '/node_modules/react-native/\1'
41 | 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'
42 |
43 | suppress_type=$FlowIssue
44 | suppress_type=$FlowFixMe
45 | suppress_type=$FlowFixMeProps
46 | suppress_type=$FlowFixMeState
47 |
48 | suppress_comment=\\(.\\|\n\\)*\\$FlowFixMe\\($\\|[^(]\\|(\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\)
49 | suppress_comment=\\(.\\|\n\\)*\\$FlowIssue\\((\\(\\)? *\\(site=[a-z,_]*react_native\\(_ios\\)?_\\(oss\\|fb\\)[a-z,_]*\\)?)\\)?:? #[0-9]+
50 | suppress_comment=\\(.\\|\n\\)*\\$FlowExpectedError
51 |
52 | [lints]
53 | sketchy-null-number=warn
54 | sketchy-null-mixed=warn
55 | sketchy-number=warn
56 | untyped-type-import=warn
57 | nonstrict-import=warn
58 | deprecated-type=warn
59 | unsafe-getters-setters=warn
60 | inexact-spread=warn
61 | unnecessary-invariant=warn
62 | signature-verification-failure=warn
63 | deprecated-utility=error
64 |
65 | [strict]
66 | deprecated-type
67 | nonstrict-import
68 | sketchy-null
69 | unclear-type
70 | unsafe-getters-setters
71 | untyped-import
72 | untyped-type-import
73 |
74 | [version]
75 | ^0.105.0
76 |
--------------------------------------------------------------------------------
/android/app/src/main/java/com/react_native_saas/MainApplication.java:
--------------------------------------------------------------------------------
1 | package com.react_native_saas;
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.ReactNativeHost;
8 | import com.facebook.react.ReactPackage;
9 | import com.facebook.soloader.SoLoader;
10 | import java.lang.reflect.InvocationTargetException;
11 | import java.util.List;
12 |
13 | public class MainApplication extends Application implements ReactApplication {
14 |
15 | private final ReactNativeHost mReactNativeHost =
16 | new ReactNativeHost(this) {
17 | @Override
18 | public boolean getUseDeveloperSupport() {
19 | return BuildConfig.DEBUG;
20 | }
21 |
22 | @Override
23 | protected List getPackages() {
24 | @SuppressWarnings("UnnecessaryLocalVariable")
25 | List packages = new PackageList(this).getPackages();
26 | // Packages that cannot be autolinked yet can be added manually here, for example:
27 | // packages.add(new MyReactNativePackage());
28 | return packages;
29 | }
30 |
31 | @Override
32 | protected String getJSMainModuleName() {
33 | return "index";
34 | }
35 | };
36 |
37 | @Override
38 | public ReactNativeHost getReactNativeHost() {
39 | return mReactNativeHost;
40 | }
41 |
42 | @Override
43 | public void onCreate() {
44 | super.onCreate();
45 | SoLoader.init(this, /* native exopackage */ false);
46 | initializeFlipper(this); // Remove this line if you don't want Flipper enabled
47 | }
48 |
49 | /**
50 | * Loads Flipper in React Native templates.
51 | *
52 | * @param context
53 | */
54 | private static void initializeFlipper(Context context) {
55 | if (BuildConfig.DEBUG) {
56 | try {
57 | /*
58 | We use reflection here to pick up the class that initializes Flipper,
59 | since Flipper library is not available in release mode
60 | */
61 | Class> aClass = Class.forName("com.facebook.flipper.ReactNativeFlipper");
62 | aClass.getMethod("initializeFlipper", Context.class).invoke(null, context);
63 | } catch (ClassNotFoundException e) {
64 | e.printStackTrace();
65 | } catch (NoSuchMethodException e) {
66 | e.printStackTrace();
67 | } catch (IllegalAccessException e) {
68 | e.printStackTrace();
69 | } catch (InvocationTargetException e) {
70 | e.printStackTrace();
71 | }
72 | }
73 | }
74 | }
75 |
--------------------------------------------------------------------------------
/src/components/Members/index.js:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import { View, Text, FlatList, TouchableOpacity } from 'react-native';
3 | import { useSelector, useDispatch } from 'react-redux';
4 |
5 | import Icon from 'react-native-vector-icons/MaterialIcons';
6 |
7 | import { getMembersRequest } from '~/store/modules/members/actions';
8 |
9 | import InviteMember from '~/components/InviteMember';
10 | import RoleUpdater from '~/components/RoleUpdater';
11 | import Can from '~/components/Can';
12 |
13 | import styles from './styles';
14 |
15 | export default function Members() {
16 | const dispatch = useDispatch();
17 | const members = useSelector(state => state.members);
18 | const activeTeam = useSelector(state => state.teams.active);
19 | const [isInviteModalOpen, setIsInviteModalOpen] = useState(false);
20 | const [isRoleModalOpen, setIsRoleModalOpen] = useState(false);
21 | const [memberEdit, setMemberEdit] = useState(null);
22 |
23 | useEffect(() => {
24 | if (activeTeam) {
25 | dispatch(getMembersRequest());
26 | }
27 | // eslint-disable-next-line react-hooks/exhaustive-deps
28 | }, []);
29 |
30 | return (
31 |
32 | MEMBROS
33 |
34 | String(item.id)}
38 | renderItem={({ item }) => (
39 |
40 | {item.user.name}
41 |
42 |
43 | {
46 | setIsRoleModalOpen(true);
47 | setMemberEdit(item);
48 | }}
49 | >
50 |
51 |
52 |
53 |
54 | )}
55 | ListFooterComponent={() => (
56 |
57 | setIsInviteModalOpen(true)}
60 | >
61 | Convidar
62 |
63 |
64 | )}
65 | />
66 |
67 | {memberEdit && (
68 | {
71 | setIsRoleModalOpen(false);
72 | setMemberEdit(null);
73 | }}
74 | member={memberEdit}
75 | />
76 | )}
77 |
78 |
79 | setIsInviteModalOpen(false)}
82 | />
83 |
84 |
85 | );
86 | }
87 |
--------------------------------------------------------------------------------
/ios/Podfile:
--------------------------------------------------------------------------------
1 | platform :ios, '9.0'
2 | require_relative '../node_modules/@react-native-community/cli-platform-ios/native_modules'
3 |
4 | target 'react_native_saas' do
5 | # Pods for react_native_saas
6 | pod 'FBLazyVector', :path => "../node_modules/react-native/Libraries/FBLazyVector"
7 | pod 'FBReactNativeSpec', :path => "../node_modules/react-native/Libraries/FBReactNativeSpec"
8 | pod 'RCTRequired', :path => "../node_modules/react-native/Libraries/RCTRequired"
9 | pod 'RCTTypeSafety', :path => "../node_modules/react-native/Libraries/TypeSafety"
10 | pod 'React', :path => '../node_modules/react-native/'
11 | pod 'React-Core', :path => '../node_modules/react-native/'
12 | pod 'React-CoreModules', :path => '../node_modules/react-native/React/CoreModules'
13 | pod 'React-Core/DevSupport', :path => '../node_modules/react-native/'
14 | pod 'React-RCTActionSheet', :path => '../node_modules/react-native/Libraries/ActionSheetIOS'
15 | pod 'React-RCTAnimation', :path => '../node_modules/react-native/Libraries/NativeAnimation'
16 | pod 'React-RCTBlob', :path => '../node_modules/react-native/Libraries/Blob'
17 | pod 'React-RCTImage', :path => '../node_modules/react-native/Libraries/Image'
18 | pod 'React-RCTLinking', :path => '../node_modules/react-native/Libraries/LinkingIOS'
19 | pod 'React-RCTNetwork', :path => '../node_modules/react-native/Libraries/Network'
20 | pod 'React-RCTSettings', :path => '../node_modules/react-native/Libraries/Settings'
21 | pod 'React-RCTText', :path => '../node_modules/react-native/Libraries/Text'
22 | pod 'React-RCTVibration', :path => '../node_modules/react-native/Libraries/Vibration'
23 | pod 'React-Core/RCTWebSocket', :path => '../node_modules/react-native/'
24 |
25 | pod 'React-cxxreact', :path => '../node_modules/react-native/ReactCommon/cxxreact'
26 | pod 'React-jsi', :path => '../node_modules/react-native/ReactCommon/jsi'
27 | pod 'React-jsiexecutor', :path => '../node_modules/react-native/ReactCommon/jsiexecutor'
28 | pod 'React-jsinspector', :path => '../node_modules/react-native/ReactCommon/jsinspector'
29 | pod 'ReactCommon/jscallinvoker', :path => "../node_modules/react-native/ReactCommon"
30 | pod 'ReactCommon/turbomodule/core', :path => "../node_modules/react-native/ReactCommon"
31 | pod 'Yoga', :path => '../node_modules/react-native/ReactCommon/yoga'
32 |
33 | pod 'DoubleConversion', :podspec => '../node_modules/react-native/third-party-podspecs/DoubleConversion.podspec'
34 | pod 'glog', :podspec => '../node_modules/react-native/third-party-podspecs/glog.podspec'
35 | pod 'Folly', :podspec => '../node_modules/react-native/third-party-podspecs/Folly.podspec'
36 |
37 |
38 |
39 | target 'react_native_saasTests' do
40 | inherit! :search_paths
41 | # Pods for testing
42 | end
43 |
44 | use_native_modules!
45 | end
46 |
47 | target 'react_native_saas-tvOS' do
48 | # Pods for react_native_saas-tvOS
49 |
50 | target 'react_native_saas-tvOSTests' do
51 | inherit! :search_paths
52 | # Pods for testing
53 | end
54 |
55 | end
56 |
--------------------------------------------------------------------------------
/android/gradlew.bat:
--------------------------------------------------------------------------------
1 | @rem
2 | @rem Copyright 2015 the original author or authors.
3 | @rem
4 | @rem Licensed under the Apache License, Version 2.0 (the "License");
5 | @rem you may not use this file except in compliance with the License.
6 | @rem You may obtain a copy of the License at
7 | @rem
8 | @rem http://www.apache.org/licenses/LICENSE-2.0
9 | @rem
10 | @rem Unless required by applicable law or agreed to in writing, software
11 | @rem distributed under the License is distributed on an "AS IS" BASIS,
12 | @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 | @rem See the License for the specific language governing permissions and
14 | @rem limitations under the License.
15 | @rem
16 |
17 | @if "%DEBUG%" == "" @echo off
18 | @rem ##########################################################################
19 | @rem
20 | @rem Gradle startup script for Windows
21 | @rem
22 | @rem ##########################################################################
23 |
24 | @rem Set local scope for the variables with windows NT shell
25 | if "%OS%"=="Windows_NT" setlocal
26 |
27 | set DIRNAME=%~dp0
28 | if "%DIRNAME%" == "" set DIRNAME=.
29 | set APP_BASE_NAME=%~n0
30 | set APP_HOME=%DIRNAME%
31 |
32 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
33 | set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
34 |
35 | @rem Find java.exe
36 | if defined JAVA_HOME goto findJavaFromJavaHome
37 |
38 | set JAVA_EXE=java.exe
39 | %JAVA_EXE% -version >NUL 2>&1
40 | if "%ERRORLEVEL%" == "0" goto init
41 |
42 | echo.
43 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
44 | echo.
45 | echo Please set the JAVA_HOME variable in your environment to match the
46 | echo location of your Java installation.
47 |
48 | goto fail
49 |
50 | :findJavaFromJavaHome
51 | set JAVA_HOME=%JAVA_HOME:"=%
52 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe
53 |
54 | if exist "%JAVA_EXE%" goto init
55 |
56 | echo.
57 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
58 | echo.
59 | echo Please set the JAVA_HOME variable in your environment to match the
60 | echo location of your Java installation.
61 |
62 | goto fail
63 |
64 | :init
65 | @rem Get command-line arguments, handling Windows variants
66 |
67 | if not "%OS%" == "Windows_NT" goto win9xME_args
68 |
69 | :win9xME_args
70 | @rem Slurp the command line arguments.
71 | set CMD_LINE_ARGS=
72 | set _SKIP=2
73 |
74 | :win9xME_args_slurp
75 | if "x%~1" == "x" goto execute
76 |
77 | set CMD_LINE_ARGS=%*
78 |
79 | :execute
80 | @rem Setup the command line
81 |
82 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
83 |
84 | @rem Execute Gradle
85 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
86 |
87 | :end
88 | @rem End local scope for the variables with windows NT shell
89 | if "%ERRORLEVEL%"=="0" goto mainEnd
90 |
91 | :fail
92 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
93 | rem the _cmd.exe /c_ return code!
94 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
95 | exit /b 1
96 |
97 | :mainEnd
98 | if "%OS%"=="Windows_NT" endlocal
99 |
100 | :omega
101 |
--------------------------------------------------------------------------------
/ios/react_native_saas/Base.lproj/LaunchScreen.xib:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 |
38 |
39 |
40 |
41 |
42 |
43 |
--------------------------------------------------------------------------------
/ios/react_native_saas.xcodeproj/xcshareddata/xcschemes/react_native_saas.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
29 |
35 |
36 |
37 |
43 |
49 |
50 |
51 |
52 |
53 |
58 |
59 |
61 |
67 |
68 |
69 |
70 |
71 |
77 |
78 |
79 |
80 |
81 |
82 |
92 |
94 |
100 |
101 |
102 |
103 |
104 |
105 |
111 |
113 |
119 |
120 |
121 |
122 |
124 |
125 |
128 |
129 |
130 |
--------------------------------------------------------------------------------
/ios/react_native_saas.xcodeproj/xcshareddata/xcschemes/react_native_saas-tvOS.xcscheme:
--------------------------------------------------------------------------------
1 |
2 |
5 |
8 |
9 |
15 |
21 |
22 |
23 |
29 |
35 |
36 |
37 |
43 |
49 |
50 |
51 |
52 |
53 |
58 |
59 |
61 |
67 |
68 |
69 |
70 |
71 |
77 |
78 |
79 |
80 |
81 |
82 |
92 |
94 |
100 |
101 |
102 |
103 |
104 |
105 |
111 |
113 |
119 |
120 |
121 |
122 |
124 |
125 |
128 |
129 |
130 |
--------------------------------------------------------------------------------
/android/gradlew:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env sh
2 |
3 | #
4 | # Copyright 2015 the original author or authors.
5 | #
6 | # Licensed under the Apache License, Version 2.0 (the "License");
7 | # you may not use this file except in compliance with the License.
8 | # You may obtain a copy of the License at
9 | #
10 | # http://www.apache.org/licenses/LICENSE-2.0
11 | #
12 | # Unless required by applicable law or agreed to in writing, software
13 | # distributed under the License is distributed on an "AS IS" BASIS,
14 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 | # See the License for the specific language governing permissions and
16 | # limitations under the License.
17 | #
18 |
19 | ##############################################################################
20 | ##
21 | ## Gradle start up script for UN*X
22 | ##
23 | ##############################################################################
24 |
25 | # Attempt to set APP_HOME
26 | # Resolve links: $0 may be a link
27 | PRG="$0"
28 | # Need this for relative symlinks.
29 | while [ -h "$PRG" ] ; do
30 | ls=`ls -ld "$PRG"`
31 | link=`expr "$ls" : '.*-> \(.*\)$'`
32 | if expr "$link" : '/.*' > /dev/null; then
33 | PRG="$link"
34 | else
35 | PRG=`dirname "$PRG"`"/$link"
36 | fi
37 | done
38 | SAVED="`pwd`"
39 | cd "`dirname \"$PRG\"`/" >/dev/null
40 | APP_HOME="`pwd -P`"
41 | cd "$SAVED" >/dev/null
42 |
43 | APP_NAME="Gradle"
44 | APP_BASE_NAME=`basename "$0"`
45 |
46 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47 | DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48 |
49 | # Use the maximum available, or set MAX_FD != -1 to use that value.
50 | MAX_FD="maximum"
51 |
52 | warn () {
53 | echo "$*"
54 | }
55 |
56 | die () {
57 | echo
58 | echo "$*"
59 | echo
60 | exit 1
61 | }
62 |
63 | # OS specific support (must be 'true' or 'false').
64 | cygwin=false
65 | msys=false
66 | darwin=false
67 | nonstop=false
68 | case "`uname`" in
69 | CYGWIN* )
70 | cygwin=true
71 | ;;
72 | Darwin* )
73 | darwin=true
74 | ;;
75 | MINGW* )
76 | msys=true
77 | ;;
78 | NONSTOP* )
79 | nonstop=true
80 | ;;
81 | esac
82 |
83 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84 |
85 | # Determine the Java command to use to start the JVM.
86 | if [ -n "$JAVA_HOME" ] ; then
87 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
88 | # IBM's JDK on AIX uses strange locations for the executables
89 | JAVACMD="$JAVA_HOME/jre/sh/java"
90 | else
91 | JAVACMD="$JAVA_HOME/bin/java"
92 | fi
93 | if [ ! -x "$JAVACMD" ] ; then
94 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
95 |
96 | Please set the JAVA_HOME variable in your environment to match the
97 | location of your Java installation."
98 | fi
99 | else
100 | JAVACMD="java"
101 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
102 |
103 | Please set the JAVA_HOME variable in your environment to match the
104 | location of your Java installation."
105 | fi
106 |
107 | # Increase the maximum file descriptors if we can.
108 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
109 | MAX_FD_LIMIT=`ulimit -H -n`
110 | if [ $? -eq 0 ] ; then
111 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
112 | MAX_FD="$MAX_FD_LIMIT"
113 | fi
114 | ulimit -n $MAX_FD
115 | if [ $? -ne 0 ] ; then
116 | warn "Could not set maximum file descriptor limit: $MAX_FD"
117 | fi
118 | else
119 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
120 | fi
121 | fi
122 |
123 | # For Darwin, add options to specify how the application appears in the dock
124 | if $darwin; then
125 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
126 | fi
127 |
128 | # For Cygwin, switch paths to Windows format before running java
129 | if $cygwin ; then
130 | APP_HOME=`cygpath --path --mixed "$APP_HOME"`
131 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
132 | JAVACMD=`cygpath --unix "$JAVACMD"`
133 |
134 | # We build the pattern for arguments to be converted via cygpath
135 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
136 | SEP=""
137 | for dir in $ROOTDIRSRAW ; do
138 | ROOTDIRS="$ROOTDIRS$SEP$dir"
139 | SEP="|"
140 | done
141 | OURCYGPATTERN="(^($ROOTDIRS))"
142 | # Add a user-defined pattern to the cygpath arguments
143 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then
144 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
145 | fi
146 | # Now convert the arguments - kludge to limit ourselves to /bin/sh
147 | i=0
148 | for arg in "$@" ; do
149 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
150 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
151 |
152 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
153 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
154 | else
155 | eval `echo args$i`="\"$arg\""
156 | fi
157 | i=$((i+1))
158 | done
159 | case $i in
160 | (0) set -- ;;
161 | (1) set -- "$args0" ;;
162 | (2) set -- "$args0" "$args1" ;;
163 | (3) set -- "$args0" "$args1" "$args2" ;;
164 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
165 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
166 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
167 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
168 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
169 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
170 | esac
171 | fi
172 |
173 | # Escape application args
174 | save () {
175 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
176 | echo " "
177 | }
178 | APP_ARGS=$(save "$@")
179 |
180 | # Collect all arguments for the java command, following the shell quoting and substitution rules
181 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
182 |
183 | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
184 | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
185 | cd "$(dirname "$0")"
186 | fi
187 |
188 | exec "$JAVACMD" "$@"
189 |
--------------------------------------------------------------------------------
/android/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: "com.android.application"
2 |
3 | import com.android.build.OutputFile
4 |
5 | /**
6 | * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets
7 | * and bundleReleaseJsAndAssets).
8 | * These basically call `react-native bundle` with the correct arguments during the Android build
9 | * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the
10 | * bundle directly from the development server. Below you can see all the possible configurations
11 | * and their defaults. If you decide to add a configuration block, make sure to add it before the
12 | * `apply from: "../../node_modules/react-native/react.gradle"` line.
13 | *
14 | * project.ext.react = [
15 | * // the name of the generated asset file containing your JS bundle
16 | * bundleAssetName: "index.android.bundle",
17 | *
18 | * // the entry file for bundle generation
19 | * entryFile: "index.android.js",
20 | *
21 | * // https://facebook.github.io/react-native/docs/performance#enable-the-ram-format
22 | * bundleCommand: "ram-bundle",
23 | *
24 | * // whether to bundle JS and assets in debug mode
25 | * bundleInDebug: false,
26 | *
27 | * // whether to bundle JS and assets in release mode
28 | * bundleInRelease: true,
29 | *
30 | * // whether to bundle JS and assets in another build variant (if configured).
31 | * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
32 | * // The configuration property can be in the following formats
33 | * // 'bundleIn${productFlavor}${buildType}'
34 | * // 'bundleIn${buildType}'
35 | * // bundleInFreeDebug: true,
36 | * // bundleInPaidRelease: true,
37 | * // bundleInBeta: true,
38 | *
39 | * // whether to disable dev mode in custom build variants (by default only disabled in release)
40 | * // for example: to disable dev mode in the staging build type (if configured)
41 | * devDisabledInStaging: true,
42 | * // The configuration property can be in the following formats
43 | * // 'devDisabledIn${productFlavor}${buildType}'
44 | * // 'devDisabledIn${buildType}'
45 | *
46 | * // the root of your project, i.e. where "package.json" lives
47 | * root: "../../",
48 | *
49 | * // where to put the JS bundle asset in debug mode
50 | * jsBundleDirDebug: "$buildDir/intermediates/assets/debug",
51 | *
52 | * // where to put the JS bundle asset in release mode
53 | * jsBundleDirRelease: "$buildDir/intermediates/assets/release",
54 | *
55 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
56 | * // require('./image.png')), in debug mode
57 | * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug",
58 | *
59 | * // where to put drawable resources / React Native assets, e.g. the ones you use via
60 | * // require('./image.png')), in release mode
61 | * resourcesDirRelease: "$buildDir/intermediates/res/merged/release",
62 | *
63 | * // by default the gradle tasks are skipped if none of the JS files or assets change; this means
64 | * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to
65 | * // date; if you have any other folders that you want to ignore for performance reasons (gradle
66 | * // indexes the entire tree), add them here. Alternatively, if you have JS files in android/
67 | * // for example, you might want to remove it from here.
68 | * inputExcludes: ["android/**", "ios/**"],
69 | *
70 | * // override which node gets called and with what additional arguments
71 | * nodeExecutableAndArgs: ["node"],
72 | *
73 | * // supply additional arguments to the packager
74 | * extraPackagerArgs: []
75 | * ]
76 | */
77 |
78 | project.ext.react = [
79 | entryFile: "index.js",
80 | enableHermes: false, // clean and rebuild if changing
81 | ]
82 |
83 | apply from: "../../node_modules/react-native/react.gradle"
84 |
85 | project.ext.vectoricons = [
86 | iconFontNames: [ 'MaterialIcons.ttf' ]
87 | ]
88 |
89 | apply from: "../../node_modules/react-native-vector-icons/fonts.gradle"
90 |
91 | /**
92 | * Set this to true to create two separate APKs instead of one:
93 | * - An APK that only works on ARM devices
94 | * - An APK that only works on x86 devices
95 | * The advantage is the size of the APK is reduced by about 4MB.
96 | * Upload all the APKs to the Play Store and people will download
97 | * the correct one based on the CPU architecture of their device.
98 | */
99 | def enableSeparateBuildPerCPUArchitecture = false
100 |
101 | /**
102 | * Run Proguard to shrink the Java bytecode in release builds.
103 | */
104 | def enableProguardInReleaseBuilds = false
105 |
106 | /**
107 | * The preferred build flavor of JavaScriptCore.
108 | *
109 | * For example, to use the international variant, you can use:
110 | * `def jscFlavor = 'org.webkit:android-jsc-intl:+'`
111 | *
112 | * The international variant includes ICU i18n library and necessary data
113 | * allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that
114 | * give correct results when using with locales other than en-US. Note that
115 | * this variant is about 6MiB larger per architecture than default.
116 | */
117 | def jscFlavor = 'org.webkit:android-jsc:+'
118 |
119 | /**
120 | * Whether to enable the Hermes VM.
121 | *
122 | * This should be set on project.ext.react and mirrored here. If it is not set
123 | * on project.ext.react, JavaScript will not be compiled to Hermes Bytecode
124 | * and the benefits of using Hermes will therefore be sharply reduced.
125 | */
126 | def enableHermes = project.ext.react.get("enableHermes", false);
127 |
128 | android {
129 | compileSdkVersion rootProject.ext.compileSdkVersion
130 |
131 | compileOptions {
132 | sourceCompatibility JavaVersion.VERSION_1_8
133 | targetCompatibility JavaVersion.VERSION_1_8
134 | }
135 |
136 | defaultConfig {
137 | applicationId "com.react_native_saas"
138 | minSdkVersion rootProject.ext.minSdkVersion
139 | targetSdkVersion rootProject.ext.targetSdkVersion
140 | versionCode 1
141 | versionName "1.0"
142 | }
143 | splits {
144 | abi {
145 | reset()
146 | enable enableSeparateBuildPerCPUArchitecture
147 | universalApk false // If true, also generate a universal APK
148 | include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
149 | }
150 | }
151 | signingConfigs {
152 | debug {
153 | storeFile file('debug.keystore')
154 | storePassword 'android'
155 | keyAlias 'androiddebugkey'
156 | keyPassword 'android'
157 | }
158 | }
159 | buildTypes {
160 | debug {
161 | signingConfig signingConfigs.debug
162 | }
163 | release {
164 | // Caution! In production, you need to generate your own keystore file.
165 | // see https://facebook.github.io/react-native/docs/signed-apk-android.
166 | signingConfig signingConfigs.debug
167 | minifyEnabled enableProguardInReleaseBuilds
168 | proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
169 | }
170 | }
171 | // applicationVariants are e.g. debug, release
172 | applicationVariants.all { variant ->
173 | variant.outputs.each { output ->
174 | // For each separate APK per architecture, set a unique version code as described here:
175 | // https://developer.android.com/studio/build/configure-apk-splits.html
176 | def versionCodes = ["armeabi-v7a": 1, "x86": 2, "arm64-v8a": 3, "x86_64": 4]
177 | def abi = output.getFilter(OutputFile.ABI)
178 | if (abi != null) { // null for the universal-debug, universal-release variants
179 | output.versionCodeOverride =
180 | versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
181 | }
182 |
183 | }
184 | }
185 | }
186 |
187 | dependencies {
188 | implementation fileTree(dir: "libs", include: ["*.jar"])
189 | implementation "com.facebook.react:react-native:+" // From node_modules
190 |
191 | if (enableHermes) {
192 | def hermesPath = "../../node_modules/hermes-engine/android/";
193 | debugImplementation files(hermesPath + "hermes-debug.aar")
194 | releaseImplementation files(hermesPath + "hermes-release.aar")
195 | } else {
196 | implementation jscFlavor
197 | }
198 | }
199 |
200 | // Run this once to be able to run the application with BUCK
201 | // puts all compile dependencies into folder libs for BUCK to use
202 | task copyDownloadableDepsToLibs(type: Copy) {
203 | from configurations.compile
204 | into 'libs'
205 | }
206 |
207 | apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
208 |
--------------------------------------------------------------------------------
/ios/react_native_saas.xcodeproj/project.pbxproj:
--------------------------------------------------------------------------------
1 | // !$*UTF8*$!
2 | {
3 | archiveVersion = 1;
4 | classes = {
5 | };
6 | objectVersion = 46;
7 | objects = {
8 |
9 | /* Begin PBXBuildFile section */
10 | 00E356F31AD99517003FC87E /* react_native_saasTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* react_native_saasTests.m */; };
11 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
12 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; };
13 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
14 | 13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
15 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
16 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
17 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
18 | 2DCD954D1E0B4F2C00145EB5 /* react_native_saasTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* react_native_saasTests.m */; };
19 | /* End PBXBuildFile section */
20 |
21 | /* Begin PBXContainerItemProxy section */
22 | 00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = {
23 | isa = PBXContainerItemProxy;
24 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
25 | proxyType = 1;
26 | remoteGlobalIDString = 13B07F861A680F5B00A75B9A;
27 | remoteInfo = react_native_saas;
28 | };
29 | 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */ = {
30 | isa = PBXContainerItemProxy;
31 | containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
32 | proxyType = 1;
33 | remoteGlobalIDString = 2D02E47A1E0B4A5D006451C7;
34 | remoteInfo = "react_native_saas-tvOS";
35 | };
36 | /* End PBXContainerItemProxy section */
37 |
38 | /* Begin PBXFileReference section */
39 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; };
40 | 00E356EE1AD99517003FC87E /* react_native_saasTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = react_native_saasTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
41 | 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
42 | 00E356F21AD99517003FC87E /* react_native_saasTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = react_native_saasTests.m; sourceTree = ""; };
43 | 13B07F961A680F5B00A75B9A /* react_native_saas.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = react_native_saas.app; sourceTree = BUILT_PRODUCTS_DIR; };
44 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = react_native_saas/AppDelegate.h; sourceTree = ""; };
45 | 13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = react_native_saas/AppDelegate.m; sourceTree = ""; };
46 | 13B07FB21A68108700A75B9A /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = ""; };
47 | 13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = react_native_saas/Images.xcassets; sourceTree = ""; };
48 | 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = react_native_saas/Info.plist; sourceTree = ""; };
49 | 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = react_native_saas/main.m; sourceTree = ""; };
50 | 2D02E47B1E0B4A5D006451C7 /* react_native_saas-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "react_native_saas-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
51 | 2D02E4901E0B4A5D006451C7 /* react_native_saas-tvOSTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = "react_native_saas-tvOSTests.xctest"; sourceTree = BUILT_PRODUCTS_DIR; };
52 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
53 | 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; };
54 | /* End PBXFileReference section */
55 |
56 | /* Begin PBXFrameworksBuildPhase section */
57 | 00E356EB1AD99517003FC87E /* Frameworks */ = {
58 | isa = PBXFrameworksBuildPhase;
59 | buildActionMask = 2147483647;
60 | files = (
61 | );
62 | runOnlyForDeploymentPostprocessing = 0;
63 | };
64 | 13B07F8C1A680F5B00A75B9A /* Frameworks */ = {
65 | isa = PBXFrameworksBuildPhase;
66 | buildActionMask = 2147483647;
67 | files = (
68 | );
69 | runOnlyForDeploymentPostprocessing = 0;
70 | };
71 | 2D02E4781E0B4A5D006451C7 /* Frameworks */ = {
72 | isa = PBXFrameworksBuildPhase;
73 | buildActionMask = 2147483647;
74 | files = (
75 | );
76 | runOnlyForDeploymentPostprocessing = 0;
77 | };
78 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */ = {
79 | isa = PBXFrameworksBuildPhase;
80 | buildActionMask = 2147483647;
81 | files = (
82 | );
83 | runOnlyForDeploymentPostprocessing = 0;
84 | };
85 | /* End PBXFrameworksBuildPhase section */
86 |
87 | /* Begin PBXGroup section */
88 | 00E356EF1AD99517003FC87E /* react_native_saasTests */ = {
89 | isa = PBXGroup;
90 | children = (
91 | 00E356F21AD99517003FC87E /* react_native_saasTests.m */,
92 | 00E356F01AD99517003FC87E /* Supporting Files */,
93 | );
94 | path = react_native_saasTests;
95 | sourceTree = "";
96 | };
97 | 00E356F01AD99517003FC87E /* Supporting Files */ = {
98 | isa = PBXGroup;
99 | children = (
100 | 00E356F11AD99517003FC87E /* Info.plist */,
101 | );
102 | name = "Supporting Files";
103 | sourceTree = "";
104 | };
105 | 13B07FAE1A68108700A75B9A /* react_native_saas */ = {
106 | isa = PBXGroup;
107 | children = (
108 | 008F07F21AC5B25A0029DE68 /* main.jsbundle */,
109 | 13B07FAF1A68108700A75B9A /* AppDelegate.h */,
110 | 13B07FB01A68108700A75B9A /* AppDelegate.m */,
111 | 13B07FB51A68108700A75B9A /* Images.xcassets */,
112 | 13B07FB61A68108700A75B9A /* Info.plist */,
113 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */,
114 | 13B07FB71A68108700A75B9A /* main.m */,
115 | );
116 | name = react_native_saas;
117 | sourceTree = "";
118 | };
119 | 2D16E6871FA4F8E400B85C8A /* Frameworks */ = {
120 | isa = PBXGroup;
121 | children = (
122 | ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
123 | ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
124 | );
125 | name = Frameworks;
126 | sourceTree = "";
127 | };
128 | 832341AE1AAA6A7D00B99B32 /* Libraries */ = {
129 | isa = PBXGroup;
130 | children = (
131 | );
132 | name = Libraries;
133 | sourceTree = "";
134 | };
135 | 83CBB9F61A601CBA00E9B192 = {
136 | isa = PBXGroup;
137 | children = (
138 | 13B07FAE1A68108700A75B9A /* react_native_saas */,
139 | 832341AE1AAA6A7D00B99B32 /* Libraries */,
140 | 00E356EF1AD99517003FC87E /* react_native_saasTests */,
141 | 83CBBA001A601CBA00E9B192 /* Products */,
142 | 2D16E6871FA4F8E400B85C8A /* Frameworks */,
143 | 89125F0AAABF436F98742BD6 /* Resources */,
144 | );
145 | indentWidth = 2;
146 | sourceTree = "";
147 | tabWidth = 2;
148 | usesTabs = 0;
149 | };
150 | 83CBBA001A601CBA00E9B192 /* Products */ = {
151 | isa = PBXGroup;
152 | children = (
153 | 13B07F961A680F5B00A75B9A /* react_native_saas.app */,
154 | 00E356EE1AD99517003FC87E /* react_native_saasTests.xctest */,
155 | 2D02E47B1E0B4A5D006451C7 /* react_native_saas-tvOS.app */,
156 | 2D02E4901E0B4A5D006451C7 /* react_native_saas-tvOSTests.xctest */,
157 | );
158 | name = Products;
159 | sourceTree = "";
160 | };
161 | 89125F0AAABF436F98742BD6 /* Resources */ = {
162 | isa = "PBXGroup";
163 | children = (
164 | );
165 | name = Resources;
166 | sourceTree = "";
167 | path = "";
168 | };
169 | /* End PBXGroup section */
170 |
171 | /* Begin PBXNativeTarget section */
172 | 00E356ED1AD99517003FC87E /* react_native_saasTests */ = {
173 | isa = PBXNativeTarget;
174 | buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "react_native_saasTests" */;
175 | buildPhases = (
176 | 00E356EA1AD99517003FC87E /* Sources */,
177 | 00E356EB1AD99517003FC87E /* Frameworks */,
178 | 00E356EC1AD99517003FC87E /* Resources */,
179 | );
180 | buildRules = (
181 | );
182 | dependencies = (
183 | 00E356F51AD99517003FC87E /* PBXTargetDependency */,
184 | );
185 | name = react_native_saasTests;
186 | productName = react_native_saasTests;
187 | productReference = 00E356EE1AD99517003FC87E /* react_native_saasTests.xctest */;
188 | productType = "com.apple.product-type.bundle.unit-test";
189 | };
190 | 13B07F861A680F5B00A75B9A /* react_native_saas */ = {
191 | isa = PBXNativeTarget;
192 | buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "react_native_saas" */;
193 | buildPhases = (
194 | FD10A7F022414F080027D42C /* Start Packager */,
195 | 13B07F871A680F5B00A75B9A /* Sources */,
196 | 13B07F8C1A680F5B00A75B9A /* Frameworks */,
197 | 13B07F8E1A680F5B00A75B9A /* Resources */,
198 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
199 | );
200 | buildRules = (
201 | );
202 | dependencies = (
203 | );
204 | name = react_native_saas;
205 | productName = "react_native_saas";
206 | productReference = 13B07F961A680F5B00A75B9A /* react_native_saas.app */;
207 | productType = "com.apple.product-type.application";
208 | };
209 | 2D02E47A1E0B4A5D006451C7 /* react_native_saas-tvOS */ = {
210 | isa = PBXNativeTarget;
211 | buildConfigurationList = 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "react_native_saas-tvOS" */;
212 | buildPhases = (
213 | FD10A7F122414F3F0027D42C /* Start Packager */,
214 | 2D02E4771E0B4A5D006451C7 /* Sources */,
215 | 2D02E4781E0B4A5D006451C7 /* Frameworks */,
216 | 2D02E4791E0B4A5D006451C7 /* Resources */,
217 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */,
218 | );
219 | buildRules = (
220 | );
221 | dependencies = (
222 | );
223 | name = "react_native_saas-tvOS";
224 | productName = "react_native_saas-tvOS";
225 | productReference = 2D02E47B1E0B4A5D006451C7 /* react_native_saas-tvOS.app */;
226 | productType = "com.apple.product-type.application";
227 | };
228 | 2D02E48F1E0B4A5D006451C7 /* react_native_saas-tvOSTests */ = {
229 | isa = PBXNativeTarget;
230 | buildConfigurationList = 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "react_native_saas-tvOSTests" */;
231 | buildPhases = (
232 | 2D02E48C1E0B4A5D006451C7 /* Sources */,
233 | 2D02E48D1E0B4A5D006451C7 /* Frameworks */,
234 | 2D02E48E1E0B4A5D006451C7 /* Resources */,
235 | );
236 | buildRules = (
237 | );
238 | dependencies = (
239 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */,
240 | );
241 | name = "react_native_saas-tvOSTests";
242 | productName = "react_native_saas-tvOSTests";
243 | productReference = 2D02E4901E0B4A5D006451C7 /* react_native_saas-tvOSTests.xctest */;
244 | productType = "com.apple.product-type.bundle.unit-test";
245 | };
246 | /* End PBXNativeTarget section */
247 |
248 | /* Begin PBXProject section */
249 | 83CBB9F71A601CBA00E9B192 /* Project object */ = {
250 | isa = PBXProject;
251 | attributes = {
252 | LastUpgradeCheck = 940;
253 | ORGANIZATIONNAME = Facebook;
254 | TargetAttributes = {
255 | 00E356ED1AD99517003FC87E = {
256 | CreatedOnToolsVersion = 6.2;
257 | TestTargetID = 13B07F861A680F5B00A75B9A;
258 | };
259 | 2D02E47A1E0B4A5D006451C7 = {
260 | CreatedOnToolsVersion = 8.2.1;
261 | ProvisioningStyle = Automatic;
262 | };
263 | 2D02E48F1E0B4A5D006451C7 = {
264 | CreatedOnToolsVersion = 8.2.1;
265 | ProvisioningStyle = Automatic;
266 | TestTargetID = 2D02E47A1E0B4A5D006451C7;
267 | };
268 | };
269 | };
270 | buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "react_native_saas" */;
271 | compatibilityVersion = "Xcode 3.2";
272 | developmentRegion = English;
273 | hasScannedForEncodings = 0;
274 | knownRegions = (
275 | en,
276 | Base,
277 | );
278 | mainGroup = 83CBB9F61A601CBA00E9B192;
279 | productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */;
280 | projectDirPath = "";
281 | projectRoot = "";
282 | targets = (
283 | 13B07F861A680F5B00A75B9A /* react_native_saas */,
284 | 00E356ED1AD99517003FC87E /* react_native_saasTests */,
285 | 2D02E47A1E0B4A5D006451C7 /* react_native_saas-tvOS */,
286 | 2D02E48F1E0B4A5D006451C7 /* react_native_saas-tvOSTests */,
287 | );
288 | };
289 | /* End PBXProject section */
290 |
291 | /* Begin PBXResourcesBuildPhase section */
292 | 00E356EC1AD99517003FC87E /* Resources */ = {
293 | isa = PBXResourcesBuildPhase;
294 | buildActionMask = 2147483647;
295 | files = (
296 | );
297 | runOnlyForDeploymentPostprocessing = 0;
298 | };
299 | 13B07F8E1A680F5B00A75B9A /* Resources */ = {
300 | isa = PBXResourcesBuildPhase;
301 | buildActionMask = 2147483647;
302 | files = (
303 | 13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
304 | 13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */,
305 | );
306 | runOnlyForDeploymentPostprocessing = 0;
307 | };
308 | 2D02E4791E0B4A5D006451C7 /* Resources */ = {
309 | isa = PBXResourcesBuildPhase;
310 | buildActionMask = 2147483647;
311 | files = (
312 | 2D02E4BD1E0B4A84006451C7 /* Images.xcassets in Resources */,
313 | );
314 | runOnlyForDeploymentPostprocessing = 0;
315 | };
316 | 2D02E48E1E0B4A5D006451C7 /* Resources */ = {
317 | isa = PBXResourcesBuildPhase;
318 | buildActionMask = 2147483647;
319 | files = (
320 | );
321 | runOnlyForDeploymentPostprocessing = 0;
322 | };
323 | /* End PBXResourcesBuildPhase section */
324 |
325 | /* Begin PBXShellScriptBuildPhase section */
326 | 00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = {
327 | isa = PBXShellScriptBuildPhase;
328 | buildActionMask = 2147483647;
329 | files = (
330 | );
331 | inputPaths = (
332 | );
333 | name = "Bundle React Native code and images";
334 | outputPaths = (
335 | );
336 | runOnlyForDeploymentPostprocessing = 0;
337 | shellPath = /bin/sh;
338 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
339 | };
340 | 2D02E4CB1E0B4B27006451C7 /* Bundle React Native Code And Images */ = {
341 | isa = PBXShellScriptBuildPhase;
342 | buildActionMask = 2147483647;
343 | files = (
344 | );
345 | inputPaths = (
346 | );
347 | name = "Bundle React Native Code And Images";
348 | outputPaths = (
349 | );
350 | runOnlyForDeploymentPostprocessing = 0;
351 | shellPath = /bin/sh;
352 | shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh";
353 | };
354 | FD10A7F022414F080027D42C /* Start Packager */ = {
355 | isa = PBXShellScriptBuildPhase;
356 | buildActionMask = 2147483647;
357 | files = (
358 | );
359 | inputFileListPaths = (
360 | );
361 | inputPaths = (
362 | );
363 | name = "Start Packager";
364 | outputFileListPaths = (
365 | );
366 | outputPaths = (
367 | );
368 | runOnlyForDeploymentPostprocessing = 0;
369 | shellPath = /bin/sh;
370 | 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";
371 | showEnvVarsInLog = 0;
372 | };
373 | FD10A7F122414F3F0027D42C /* Start Packager */ = {
374 | isa = PBXShellScriptBuildPhase;
375 | buildActionMask = 2147483647;
376 | files = (
377 | );
378 | inputFileListPaths = (
379 | );
380 | inputPaths = (
381 | );
382 | name = "Start Packager";
383 | outputFileListPaths = (
384 | );
385 | outputPaths = (
386 | );
387 | runOnlyForDeploymentPostprocessing = 0;
388 | shellPath = /bin/sh;
389 | 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";
390 | showEnvVarsInLog = 0;
391 | };
392 | /* End PBXShellScriptBuildPhase section */
393 |
394 | /* Begin PBXSourcesBuildPhase section */
395 | 00E356EA1AD99517003FC87E /* Sources */ = {
396 | isa = PBXSourcesBuildPhase;
397 | buildActionMask = 2147483647;
398 | files = (
399 | 00E356F31AD99517003FC87E /* react_native_saasTests.m in Sources */,
400 | );
401 | runOnlyForDeploymentPostprocessing = 0;
402 | };
403 | 13B07F871A680F5B00A75B9A /* Sources */ = {
404 | isa = PBXSourcesBuildPhase;
405 | buildActionMask = 2147483647;
406 | files = (
407 | 13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */,
408 | 13B07FC11A68108700A75B9A /* main.m in Sources */,
409 | );
410 | runOnlyForDeploymentPostprocessing = 0;
411 | };
412 | 2D02E4771E0B4A5D006451C7 /* Sources */ = {
413 | isa = PBXSourcesBuildPhase;
414 | buildActionMask = 2147483647;
415 | files = (
416 | 2D02E4BF1E0B4AB3006451C7 /* main.m in Sources */,
417 | 2D02E4BC1E0B4A80006451C7 /* AppDelegate.m in Sources */,
418 | );
419 | runOnlyForDeploymentPostprocessing = 0;
420 | };
421 | 2D02E48C1E0B4A5D006451C7 /* Sources */ = {
422 | isa = PBXSourcesBuildPhase;
423 | buildActionMask = 2147483647;
424 | files = (
425 | 2DCD954D1E0B4F2C00145EB5 /* react_native_saasTests.m in Sources */,
426 | );
427 | runOnlyForDeploymentPostprocessing = 0;
428 | };
429 | /* End PBXSourcesBuildPhase section */
430 |
431 | /* Begin PBXTargetDependency section */
432 | 00E356F51AD99517003FC87E /* PBXTargetDependency */ = {
433 | isa = PBXTargetDependency;
434 | target = 13B07F861A680F5B00A75B9A /* react_native_saas */;
435 | targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */;
436 | };
437 | 2D02E4921E0B4A5D006451C7 /* PBXTargetDependency */ = {
438 | isa = PBXTargetDependency;
439 | target = 2D02E47A1E0B4A5D006451C7 /* react_native_saas-tvOS */;
440 | targetProxy = 2D02E4911E0B4A5D006451C7 /* PBXContainerItemProxy */;
441 | };
442 | /* End PBXTargetDependency section */
443 |
444 | /* Begin PBXVariantGroup section */
445 | 13B07FB11A68108700A75B9A /* LaunchScreen.xib */ = {
446 | isa = PBXVariantGroup;
447 | children = (
448 | 13B07FB21A68108700A75B9A /* Base */,
449 | );
450 | name = LaunchScreen.xib;
451 | path = react_native_saas;
452 | sourceTree = "";
453 | };
454 | /* End PBXVariantGroup section */
455 |
456 | /* Begin XCBuildConfiguration section */
457 | 00E356F61AD99517003FC87E /* Debug */ = {
458 | isa = XCBuildConfiguration;
459 | buildSettings = {
460 | BUNDLE_LOADER = "$(TEST_HOST)";
461 | GCC_PREPROCESSOR_DEFINITIONS = (
462 | "DEBUG=1",
463 | "$(inherited)",
464 | );
465 | INFOPLIST_FILE = react_native_saasTests/Info.plist;
466 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
467 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
468 | OTHER_LDFLAGS = (
469 | "-ObjC",
470 | "-lc++",
471 | "$(inherited)",
472 | );
473 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
474 | PRODUCT_NAME = "$(TARGET_NAME)";
475 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/react_native_saas.app/react_native_saas";
476 | };
477 | name = Debug;
478 | };
479 | 00E356F71AD99517003FC87E /* Release */ = {
480 | isa = XCBuildConfiguration;
481 | buildSettings = {
482 | BUNDLE_LOADER = "$(TEST_HOST)";
483 | COPY_PHASE_STRIP = NO;
484 | INFOPLIST_FILE = react_native_saasTests/Info.plist;
485 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
486 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
487 | OTHER_LDFLAGS = (
488 | "-ObjC",
489 | "-lc++",
490 | "$(inherited)",
491 | );
492 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
493 | PRODUCT_NAME = "$(TARGET_NAME)";
494 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/react_native_saas.app/react_native_saas";
495 | };
496 | name = Release;
497 | };
498 | 13B07F941A680F5B00A75B9A /* Debug */ = {
499 | isa = XCBuildConfiguration;
500 | buildSettings = {
501 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
502 | CURRENT_PROJECT_VERSION = 1;
503 | DEAD_CODE_STRIPPING = NO;
504 | INFOPLIST_FILE = react_native_saas/Info.plist;
505 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
506 | OTHER_LDFLAGS = (
507 | "$(inherited)",
508 | "-ObjC",
509 | "-lc++",
510 | );
511 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
512 | PRODUCT_NAME = react_native_saas;
513 | VERSIONING_SYSTEM = "apple-generic";
514 | };
515 | name = Debug;
516 | };
517 | 13B07F951A680F5B00A75B9A /* Release */ = {
518 | isa = XCBuildConfiguration;
519 | buildSettings = {
520 | ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
521 | CURRENT_PROJECT_VERSION = 1;
522 | INFOPLIST_FILE = react_native_saas/Info.plist;
523 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
524 | OTHER_LDFLAGS = (
525 | "$(inherited)",
526 | "-ObjC",
527 | "-lc++",
528 | );
529 | PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)";
530 | PRODUCT_NAME = react_native_saas;
531 | VERSIONING_SYSTEM = "apple-generic";
532 | };
533 | name = Release;
534 | };
535 | 2D02E4971E0B4A5E006451C7 /* Debug */ = {
536 | isa = XCBuildConfiguration;
537 | buildSettings = {
538 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
539 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
540 | CLANG_ANALYZER_NONNULL = YES;
541 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
542 | CLANG_WARN_INFINITE_RECURSION = YES;
543 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
544 | DEBUG_INFORMATION_FORMAT = dwarf;
545 | ENABLE_TESTABILITY = YES;
546 | GCC_NO_COMMON_BLOCKS = YES;
547 | INFOPLIST_FILE = "react_native_saas-tvOS/Info.plist";
548 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
549 | OTHER_LDFLAGS = (
550 | "$(inherited)",
551 | "-ObjC",
552 | "-lc++",
553 | );
554 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.react_native_saas-tvOS";
555 | PRODUCT_NAME = "$(TARGET_NAME)";
556 | SDKROOT = appletvos;
557 | TARGETED_DEVICE_FAMILY = 3;
558 | TVOS_DEPLOYMENT_TARGET = 9.2;
559 | };
560 | name = Debug;
561 | };
562 | 2D02E4981E0B4A5E006451C7 /* Release */ = {
563 | isa = XCBuildConfiguration;
564 | buildSettings = {
565 | ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
566 | ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
567 | CLANG_ANALYZER_NONNULL = YES;
568 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
569 | CLANG_WARN_INFINITE_RECURSION = YES;
570 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
571 | COPY_PHASE_STRIP = NO;
572 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
573 | GCC_NO_COMMON_BLOCKS = YES;
574 | INFOPLIST_FILE = "react_native_saas-tvOS/Info.plist";
575 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
576 | OTHER_LDFLAGS = (
577 | "$(inherited)",
578 | "-ObjC",
579 | "-lc++",
580 | );
581 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.react_native_saas-tvOS";
582 | PRODUCT_NAME = "$(TARGET_NAME)";
583 | SDKROOT = appletvos;
584 | TARGETED_DEVICE_FAMILY = 3;
585 | TVOS_DEPLOYMENT_TARGET = 9.2;
586 | };
587 | name = Release;
588 | };
589 | 2D02E4991E0B4A5E006451C7 /* Debug */ = {
590 | isa = XCBuildConfiguration;
591 | buildSettings = {
592 | BUNDLE_LOADER = "$(TEST_HOST)";
593 | CLANG_ANALYZER_NONNULL = YES;
594 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
595 | CLANG_WARN_INFINITE_RECURSION = YES;
596 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
597 | DEBUG_INFORMATION_FORMAT = dwarf;
598 | ENABLE_TESTABILITY = YES;
599 | GCC_NO_COMMON_BLOCKS = YES;
600 | INFOPLIST_FILE = "react_native_saas-tvOSTests/Info.plist";
601 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
602 | OTHER_LDFLAGS = (
603 | "$(inherited)",
604 | "-ObjC",
605 | "-lc++",
606 | );
607 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.react_native_saas-tvOSTests";
608 | PRODUCT_NAME = "$(TARGET_NAME)";
609 | SDKROOT = appletvos;
610 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/react_native_saas-tvOS.app/react_native_saas-tvOS";
611 | TVOS_DEPLOYMENT_TARGET = 10.1;
612 | };
613 | name = Debug;
614 | };
615 | 2D02E49A1E0B4A5E006451C7 /* Release */ = {
616 | isa = XCBuildConfiguration;
617 | buildSettings = {
618 | BUNDLE_LOADER = "$(TEST_HOST)";
619 | CLANG_ANALYZER_NONNULL = YES;
620 | CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
621 | CLANG_WARN_INFINITE_RECURSION = YES;
622 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
623 | COPY_PHASE_STRIP = NO;
624 | DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
625 | GCC_NO_COMMON_BLOCKS = YES;
626 | INFOPLIST_FILE = "react_native_saas-tvOSTests/Info.plist";
627 | LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
628 | OTHER_LDFLAGS = (
629 | "$(inherited)",
630 | "-ObjC",
631 | "-lc++",
632 | );
633 | PRODUCT_BUNDLE_IDENTIFIER = "com.facebook.REACT.react_native_saas-tvOSTests";
634 | PRODUCT_NAME = "$(TARGET_NAME)";
635 | SDKROOT = appletvos;
636 | TEST_HOST = "$(BUILT_PRODUCTS_DIR)/react_native_saas-tvOS.app/react_native_saas-tvOS";
637 | TVOS_DEPLOYMENT_TARGET = 10.1;
638 | };
639 | name = Release;
640 | };
641 | 83CBBA201A601CBA00E9B192 /* Debug */ = {
642 | isa = XCBuildConfiguration;
643 | buildSettings = {
644 | ALWAYS_SEARCH_USER_PATHS = NO;
645 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
646 | CLANG_CXX_LIBRARY = "libc++";
647 | CLANG_ENABLE_MODULES = YES;
648 | CLANG_ENABLE_OBJC_ARC = YES;
649 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
650 | CLANG_WARN_BOOL_CONVERSION = YES;
651 | CLANG_WARN_COMMA = YES;
652 | CLANG_WARN_CONSTANT_CONVERSION = YES;
653 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
654 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
655 | CLANG_WARN_EMPTY_BODY = YES;
656 | CLANG_WARN_ENUM_CONVERSION = YES;
657 | CLANG_WARN_INFINITE_RECURSION = YES;
658 | CLANG_WARN_INT_CONVERSION = YES;
659 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
660 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
661 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
662 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
663 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
664 | CLANG_WARN_STRICT_PROTOTYPES = YES;
665 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
666 | CLANG_WARN_UNREACHABLE_CODE = YES;
667 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
668 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
669 | COPY_PHASE_STRIP = NO;
670 | ENABLE_STRICT_OBJC_MSGSEND = YES;
671 | ENABLE_TESTABILITY = YES;
672 | GCC_C_LANGUAGE_STANDARD = gnu99;
673 | GCC_DYNAMIC_NO_PIC = NO;
674 | GCC_NO_COMMON_BLOCKS = YES;
675 | GCC_OPTIMIZATION_LEVEL = 0;
676 | GCC_PREPROCESSOR_DEFINITIONS = (
677 | "DEBUG=1",
678 | "$(inherited)",
679 | );
680 | GCC_SYMBOLS_PRIVATE_EXTERN = NO;
681 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
682 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
683 | GCC_WARN_UNDECLARED_SELECTOR = YES;
684 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
685 | GCC_WARN_UNUSED_FUNCTION = YES;
686 | GCC_WARN_UNUSED_VARIABLE = YES;
687 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
688 | MTL_ENABLE_DEBUG_INFO = YES;
689 | ONLY_ACTIVE_ARCH = YES;
690 | SDKROOT = iphoneos;
691 | };
692 | name = Debug;
693 | };
694 | 83CBBA211A601CBA00E9B192 /* Release */ = {
695 | isa = XCBuildConfiguration;
696 | buildSettings = {
697 | ALWAYS_SEARCH_USER_PATHS = NO;
698 | CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
699 | CLANG_CXX_LIBRARY = "libc++";
700 | CLANG_ENABLE_MODULES = YES;
701 | CLANG_ENABLE_OBJC_ARC = YES;
702 | CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
703 | CLANG_WARN_BOOL_CONVERSION = YES;
704 | CLANG_WARN_COMMA = YES;
705 | CLANG_WARN_CONSTANT_CONVERSION = YES;
706 | CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
707 | CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
708 | CLANG_WARN_EMPTY_BODY = YES;
709 | CLANG_WARN_ENUM_CONVERSION = YES;
710 | CLANG_WARN_INFINITE_RECURSION = YES;
711 | CLANG_WARN_INT_CONVERSION = YES;
712 | CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
713 | CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
714 | CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
715 | CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
716 | CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
717 | CLANG_WARN_STRICT_PROTOTYPES = YES;
718 | CLANG_WARN_SUSPICIOUS_MOVE = YES;
719 | CLANG_WARN_UNREACHABLE_CODE = YES;
720 | CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
721 | "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
722 | COPY_PHASE_STRIP = YES;
723 | ENABLE_NS_ASSERTIONS = NO;
724 | ENABLE_STRICT_OBJC_MSGSEND = YES;
725 | GCC_C_LANGUAGE_STANDARD = gnu99;
726 | GCC_NO_COMMON_BLOCKS = YES;
727 | GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
728 | GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
729 | GCC_WARN_UNDECLARED_SELECTOR = YES;
730 | GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
731 | GCC_WARN_UNUSED_FUNCTION = YES;
732 | GCC_WARN_UNUSED_VARIABLE = YES;
733 | IPHONEOS_DEPLOYMENT_TARGET = 9.0;
734 | MTL_ENABLE_DEBUG_INFO = NO;
735 | SDKROOT = iphoneos;
736 | VALIDATE_PRODUCT = YES;
737 | };
738 | name = Release;
739 | };
740 | /* End XCBuildConfiguration section */
741 |
742 | /* Begin XCConfigurationList section */
743 | 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "react_native_saasTests" */ = {
744 | isa = XCConfigurationList;
745 | buildConfigurations = (
746 | 00E356F61AD99517003FC87E /* Debug */,
747 | 00E356F71AD99517003FC87E /* Release */,
748 | );
749 | defaultConfigurationIsVisible = 0;
750 | defaultConfigurationName = Release;
751 | };
752 | 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "react_native_saas" */ = {
753 | isa = XCConfigurationList;
754 | buildConfigurations = (
755 | 13B07F941A680F5B00A75B9A /* Debug */,
756 | 13B07F951A680F5B00A75B9A /* Release */,
757 | );
758 | defaultConfigurationIsVisible = 0;
759 | defaultConfigurationName = Release;
760 | };
761 | 2D02E4BA1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "react_native_saas-tvOS" */ = {
762 | isa = XCConfigurationList;
763 | buildConfigurations = (
764 | 2D02E4971E0B4A5E006451C7 /* Debug */,
765 | 2D02E4981E0B4A5E006451C7 /* Release */,
766 | );
767 | defaultConfigurationIsVisible = 0;
768 | defaultConfigurationName = Release;
769 | };
770 | 2D02E4BB1E0B4A5E006451C7 /* Build configuration list for PBXNativeTarget "react_native_saas-tvOSTests" */ = {
771 | isa = XCConfigurationList;
772 | buildConfigurations = (
773 | 2D02E4991E0B4A5E006451C7 /* Debug */,
774 | 2D02E49A1E0B4A5E006451C7 /* Release */,
775 | );
776 | defaultConfigurationIsVisible = 0;
777 | defaultConfigurationName = Release;
778 | };
779 | 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "react_native_saas" */ = {
780 | isa = XCConfigurationList;
781 | buildConfigurations = (
782 | 83CBBA201A601CBA00E9B192 /* Debug */,
783 | 83CBBA211A601CBA00E9B192 /* Release */,
784 | );
785 | defaultConfigurationIsVisible = 0;
786 | defaultConfigurationName = Release;
787 | };
788 | /* End XCConfigurationList section */
789 | };
790 | rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */;
791 | }
792 |
--------------------------------------------------------------------------------