├── .github
├── ISSUE_TEMPLATE
│ ├── bug_report.md
│ └── feature_request.md
└── workflows
│ └── node.js.yml
├── .gitignore
├── .prettierrc.js
├── CONTRIBUTING.md
├── LICENSE
├── README.md
├── cli.js
├── cli.test.js
├── cliError.test.js
├── package-lock.json
├── package.json
└── react-router
├── App.js
├── pages
├── Home.js
├── ReactRouter.js
└── reactRouterLogo.js
└── router
├── index.js
├── router.android.js
├── router.ios.js
├── router.js
└── router.web.js
/.github/ISSUE_TEMPLATE/bug_report.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Bug report
3 | about: Create a report to help us improve
4 |
5 | ---
6 |
7 | **Describe the bug**
8 | A clear and concise description of what the bug is.
9 |
10 | **To Reproduce**
11 | Steps to reproduce the behavior:
12 | 1. Go to '...'
13 | 2. Click on '....'
14 | 3. Scroll down to '....'
15 | 4. See error
16 |
17 | **Expected behavior**
18 | A clear and concise description of what you expected to happen.
19 |
20 | **Screenshots**
21 | If applicable, add screenshots to help explain your problem.
22 |
23 | **Desktop (please complete the following information):**
24 | - OS: [e.g. iOS]
25 | - Browser [e.g. chrome, safari]
26 | - Version [e.g. 22]
27 |
28 | **Smartphone (please complete the following information):**
29 | - Device: [e.g. iPhone6]
30 | - OS: [e.g. iOS8.1]
31 | - Browser [e.g. stock browser, safari]
32 | - Version [e.g. 22]
33 |
34 | **Additional context**
35 | Add any other context about the problem here.
36 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/feature_request.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Feature request
3 | about: Suggest an idea for this project
4 |
5 | ---
6 |
7 | **Is your feature request related to a problem? Please describe.**
8 | A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
9 |
10 | **Describe the solution you'd like**
11 | A clear and concise description of what you want to happen.
12 |
13 | **Describe alternatives you've considered**
14 | A clear and concise description of any alternative solutions or features you've considered.
15 |
16 | **Additional context**
17 | Add any other context or screenshots about the feature request here.
18 |
--------------------------------------------------------------------------------
/.github/workflows/node.js.yml:
--------------------------------------------------------------------------------
1 | # This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node
2 | # For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
3 |
4 | name: Node.js CI
5 |
6 | on:
7 | push:
8 | branches: [ master ]
9 | pull_request:
10 | branches: [ master ]
11 |
12 | jobs:
13 | build:
14 |
15 | runs-on: ubuntu-latest
16 |
17 | strategy:
18 | matrix:
19 | node-version: [8.x, 10.x, 12.x, 14.x]
20 |
21 | steps:
22 | - uses: actions/checkout@v2
23 | - name: Use Node.js ${{ matrix.node-version }}
24 | uses: actions/setup-node@v1
25 | with:
26 | node-version: ${{ matrix.node-version }}
27 | - run: npm i
28 | - run: npm run build --if-present
29 | - run: npm test
30 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/ignore-files/ for more about ignoring files.
2 |
3 | # dependencies
4 | /node_modules
5 |
6 | # testing
7 | /coverage
8 |
9 | # production
10 | /build
11 |
12 | # misc
13 | .DS_Store
14 | .env.local
15 | .env.development.local
16 | .env.test.local
17 | .env.production.local
18 |
19 | npm-debug.log*
20 | yarn-debug.log*
21 | yarn-error.log*
22 |
23 |
24 | # ==========================================
25 | # OSX
26 | #
27 | .DS_Store
28 |
29 | # Xcode
30 | #
31 | *.pbxuser
32 | !default.pbxuser
33 | *.mode1v3
34 | !default.mode1v3
35 | *.mode2v3
36 | !default.mode2v3
37 | *.perspectivev3
38 | !default.perspectivev3
39 | xcuserdata
40 | *.xccheckout
41 | *.moved-aside
42 | DerivedData
43 | *.hmap
44 | *.ipa
45 | *.xcuserstate
46 | project.xcworkspace
47 |
48 | # Android/IntelliJ
49 | #
50 | build/
51 | .idea
52 | .gradle
53 | local.properties
54 | *.iml
55 |
56 | # node.js
57 | #
58 | node_modules/
59 | npm-debug.log
60 | npm-debug.log*
61 | yarn-error.log
62 |
63 | # BUCK
64 | buck-out/
65 | \.buckd/
66 | *.keystore
67 |
68 | # fastlane
69 | #
70 | # It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the
71 | # screenshots whenever they are needed.
72 | # For more information about the recommended setup visit:
73 | # https://docs.fastlane.tools/best-practices/source-control/
74 |
75 | */fastlane/report.xml
76 | */fastlane/Preview.html
77 | */fastlane/screenshots
78 |
79 | coverage/
80 | coverageNative/
81 | build/
82 | temp.json
83 | android/app/app-release.apk
84 | .vscode
85 | =======
86 | # Bundle artifact
87 | *.jsbundle
88 |
89 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
90 |
91 | # dependencies
92 | /node_modules
93 | /.pnp
94 | .pnp.js
95 |
96 | # testing
97 | /coverage
98 |
99 | # production
100 | /build
101 |
102 | # misc
103 | .DS_Store
104 | .env.local
105 | .env.development.local
106 | .env.test.local
107 | .env.production.local
108 |
109 | npm-debug.log*
110 | yarn-debug.log*
111 | yarn-error.log*
112 |
113 | # OSX
114 | #
115 | .DS_Store
116 |
117 | # Xcode
118 | #
119 | build/
120 | *.pbxuser
121 | !default.pbxuser
122 | *.mode1v3
123 | !default.mode1v3
124 | *.mode2v3
125 | !default.mode2v3
126 | *.perspectivev3
127 | !default.perspectivev3
128 | xcuserdata
129 | *.xccheckout
130 | *.moved-aside
131 | DerivedData
132 | *.hmap
133 | *.ipa
134 | *.xcuserstate
135 |
136 | # Android/IntelliJ
137 | #
138 | build/
139 | .idea
140 | .gradle
141 | local.properties
142 | *.iml
143 |
144 | # node.js
145 | #
146 | node_modules/
147 | npm-debug.log
148 | yarn-error.log
149 |
150 | # BUCK
151 | buck-out/
152 | \.buckd/
153 | *.keystore
154 | !debug.keystore
155 |
156 | # fastlane
157 | #
158 | # It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the
159 | # screenshots whenever they are needed.
160 | # For more information about the recommended setup visit:
161 | # https://docs.fastlane.tools/best-practices/source-control/
162 |
163 | */fastlane/report.xml
164 | */fastlane/Preview.html
165 | */fastlane/screenshots
166 |
167 | # Bundle artifact
168 | *.jsbundle
169 |
170 | # CocoaPods
171 | /template/ios/Pods/
172 |
173 |
--------------------------------------------------------------------------------
/.prettierrc.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | bracketSpacing: false,
3 | jsxBracketSameLine: true,
4 | singleQuote: true,
5 | trailingComma: 'all',
6 | };
7 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | Create an Issue and if the feature/bug is really needed and approved, create a PR :)
2 |
3 | more to come...
4 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2018 Or Yoffe
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 | [](https://github.com/vshymanskyy/StandWithUkraine/blob/main/docs/README.md)
2 |
3 | ## Warning: Project is not actively maintained
4 | # React Native Web CLI
5 |
6 | ### create-react-native-web-app
7 |
8 | [](https://npmjs.org/package/create-react-native-web-app)
9 |
10 | 
11 | 
12 | 
13 | 
14 |
15 | ### A simple CLI tool to start your React Native Web project to develop same app for IOS Android and Web
16 |
17 | **Compatibility: React Native >= 0.63**.
18 |
19 |
20 |
21 |
22 |
23 | ## Installation
24 |
25 | ```sh
26 | # Run create-react-native-web-app
27 | $ npx crnwa myApp
28 | # or
29 | $ npx create-react-native-web-app myApp
30 |
31 | # if you previously installed this package globaly run this command first to uninstall the previous version:
32 | # npm uninstall -g create-react-native-web-app
33 |
34 | # cd into your
35 | $ cd myApp
36 |
37 | # Run Web/Ios/Android development
38 | # Web
39 | $ npm run web
40 |
41 | # IOS
42 | $ npm run ios
43 |
44 | # Android
45 | $ npm run android
46 |
47 | ```
48 |
49 | - To work with IOS and Android - Install Xcode and Android studio and follow the react native instructions [under the "React Native CLI Quickstart" tab](https://reactnative.dev/docs/environment-setup)
50 |
51 | ## Folder structure
52 |
53 | ```
54 | myApp
55 | ├── android (When opening with Android studio, open this folder)
56 | │ └── android project files
57 | ├── ios (When opening with Xcode, open this folder)
58 | │ └── ios project files
59 | ├── public
60 | │ ├── favicon.ico
61 | │ ├── index.html
62 | │ └── manifest.json
63 | └── src
64 | └── project code
65 | ```
66 |
67 | ## Testing
68 |
69 | ```sh
70 | # Web and Native
71 | $ npm run test
72 |
73 | # Web
74 | $ npm run test:web
75 |
76 | # Native
77 | $ npm run test:native
78 | ```
79 |
80 | ## Debugging
81 |
82 | Open dev menu:
83 |
84 | 1. CMD+D (IOS) / CMD+M (Android)
85 | 2. Press "Enable Live-Reload"
86 |
87 | [React native docs - debugging real devices guide](http://facebook.github.io/react-native/releases/0.49/docs/running-on-device.html)
88 |
89 | [React native docs - debugging guide](http://facebook.github.io/react-native/docs/debugging.html)
90 |
91 | [Network calls in the devtools](http://www.preslav.me/2017/03/26/debugging-network-calls-in-react-native-using-the-chrome-debugger/)
92 |
93 | ## Build
94 |
95 | ```sh
96 | # Web
97 | $ npm run build
98 |
99 | # Android - upgrade the current build version in `android/app/build.gradle` file (both the `versionCode` and the `versionName`)
100 | Example:
101 | versionCode 2
102 | versionName "1.1"
103 |
104 | # And then run the build
105 | $ cd android && ./gradlew assembleRelease
106 |
107 | # Open apk folder to find the release apk
108 | $ open ./android/app/build/outputs/apk
109 | ```
110 |
111 | [React native docs - Android signed apk](http://facebook.github.io/react-native/releases/0.49/docs/signed-apk-android.html)
112 |
113 | [React native docs for IOS](http://facebook.github.io/react-native/releases/0.49/docs/running-on-device.html#building-your-app-for-production)
114 |
115 | ## Resources
116 |
117 | - [React Native for Web (react-native-web)](https://github.com/necolas/react-native-web)
118 | - [React](https://reactjs.org/)
119 | - [React Native](http://facebook.github.io/react-native/)
120 | - [Create React App](https://github.com/facebook/create-react-app)
121 | - [Create React Native App](https://github.com/react-community/create-react-native-app)
122 |
--------------------------------------------------------------------------------
/cli.js:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env node
2 |
3 | const chalk = require('chalk');
4 | const commander = require('commander');
5 | // const fs = require('fs-extra');
6 | // const path = require('path');
7 | const execSync = require('child_process').execSync;
8 | const packageJson = require('./package.json');
9 | // const copyFiles = require('./copyFiles');
10 |
11 | const nodeVersion = process.versions.node;
12 | const nodeVersionSplitted = nodeVersion.split('.');
13 | const nodeMajorVersion = nodeVersionSplitted[0];
14 |
15 | if (nodeMajorVersion < 8) {
16 | console.error(
17 | chalk.red(`
18 | You are running Node ${nodeVersion}
19 | Create React Native Web App requires Node 8 or higher.
20 | Please update your version of Node.
21 | `),
22 | );
23 | process.exit(1);
24 | }
25 |
26 | const printCyan = (text) => console.log(` ${chalk.cyan(text)}`);
27 | // const printGreen = (text) => console.log(` ${chalk.green(text)}`);
28 |
29 | let appName;
30 | const program = new commander.Command(packageJson.name)
31 | .version(packageJson.version)
32 | .arguments('')
33 | .option('-r, --router')
34 | .usage(`${chalk.green('')}`)
35 | .action((name) => {
36 | appName = name;
37 | })
38 | .on('--help', () => {
39 | console.log(` ${chalk.green('')} is required.`);
40 | console.log();
41 | console.log(
42 | ` If you have any problems, do not hesitate to file an issue:`,
43 | );
44 | printCyan(
45 | 'https://github.com/orYoffe/create-react-native-web-app/issues/new',
46 | );
47 | console.log();
48 | })
49 | .parse(process.argv);
50 |
51 | async function run() {
52 | if (appName) {
53 | printCyan(`⏳ Creating React Native Web App by the name of ${appName}`);
54 | console.log();
55 |
56 | execSync(
57 | `npx react-native init ${appName} --template react-native-template-react-native-web`,
58 | {stdio: [0, 1, 2]},
59 | );
60 |
61 | let isYarnAvailable;
62 | try {
63 | execSync('yarnpkg --version', {stdio: 'ignore'});
64 | isYarnAvailable = true;
65 | } catch (e) {
66 | isYarnAvailable = false;
67 | }
68 |
69 | try {
70 | execSync(`cd ${appName} && git init`);
71 | } catch (error) {}
72 |
73 | const packageManagerRunCommand = isYarnAvailable ? 'yarn' : 'npm run';
74 | console.log(`
75 | ${chalk.magenta('*')} ${chalk.magenta(
76 | 'change directory to your new project',
77 | )}
78 | $ ${chalk.cyan(`cd ${appName}`)}
79 |
80 | $ ${chalk.cyan('Then run the these commands to get started:')}
81 |
82 | ${chalk.magenta('*')} ${chalk.magenta('To run development Web server')}
83 | $ ${chalk.cyan(packageManagerRunCommand + ' web')}
84 |
85 | ${chalk.magenta('*')} ${chalk.magenta(
86 | 'To run Android on connected device (after installing Android Debug Bridge "adb" - https://developer.android.com/studio/releases/platform-tools)',
87 | )}
88 | $ ${chalk.cyan(packageManagerRunCommand + ' android')}
89 |
90 | ${chalk.magenta('*')} ${chalk.magenta(
91 | 'To run ios simulator (after installing Xcode - only on Apple devices)',
92 | )}
93 | $ ${chalk.cyan(packageManagerRunCommand + ' ios')}
94 |
95 | ${chalk.magenta('*')} ${chalk.magenta(
96 | 'To run tests for Native and Web',
97 | )}
98 | $ ${chalk.cyan(packageManagerRunCommand + ' test')}
99 |
100 | ${chalk.magenta('*')} ${chalk.magenta('To run build for Web')}
101 | $ ${chalk.cyan(packageManagerRunCommand + ' build')}
102 | `);
103 | } else {
104 | console.error(
105 | chalk.red(
106 | 'In order to create a new project you must give a name as an argument. ',
107 | ),
108 | chalk.cyan('Example: create-react-native-web-app AppName'),
109 | );
110 | process.exit(1);
111 | }
112 | }
113 |
114 | try {
115 | run();
116 | } catch (error) {
117 | console.error(error);
118 | }
119 |
--------------------------------------------------------------------------------
/cli.test.js:
--------------------------------------------------------------------------------
1 | const chalk = require('chalk');
2 | const execSync = require('child_process').execSync;
3 |
4 | const originalConsoleLog = console.log;
5 | console.log = jest.fn(() => true);
6 |
7 | const originalConsoleError = console.error;
8 | console.error = jest.fn();
9 |
10 | jest.mock('child_process', () => {
11 | const execSync = jest.fn();
12 |
13 | return {execSync};
14 | });
15 |
16 | jest.mock('chalk', () => {
17 | const red = jest.fn((text) => text);
18 | const cyan = jest.fn((text) => text);
19 | const green = jest.fn((text) => text);
20 | const magenta = jest.fn((text) => text);
21 |
22 | return {
23 | red,
24 | cyan,
25 | green,
26 | magenta,
27 | };
28 | });
29 |
30 | describe('cli runs properly', () => {
31 | it('cli runs with argument and logs info', (done) => {
32 | process.argv[2] = 'myFakeName';
33 | jest.requireActual('./cli');
34 |
35 | let isYarnAvailable;
36 | try {
37 | execSync('yarnpkg --version', {stdio: 'ignore'});
38 | isYarnAvailable = true;
39 | } catch (e) {
40 | isYarnAvailable = false;
41 | }
42 |
43 | const packageManagerRunCommand = isYarnAvailable ? 'yarn' : 'npm run';
44 | process.nextTick(() => {
45 | expect(chalk.red.mock.calls).toEqual([]);
46 | expect(chalk.cyan.mock.calls).toEqual([
47 | ['⏳ Creating React Native Web App by the name of myFakeName'],
48 | ['cd myFakeName'],
49 | ['Then run the these commands to get started:'],
50 | [`${packageManagerRunCommand} web`],
51 | [`${packageManagerRunCommand} android`],
52 | [`${packageManagerRunCommand} ios`],
53 | [`${packageManagerRunCommand} test`],
54 | [`${packageManagerRunCommand} build`],
55 | ]);
56 | expect(chalk.green.mock.calls).toEqual([['']]);
57 | expect(chalk.magenta.mock.calls).toEqual([
58 | ['*'],
59 | ['change directory to your new project'],
60 | ['*'],
61 | ['To run development Web server'],
62 | ['*'],
63 | [
64 | 'To run Android on connected device (after installing Android Debug Bridge "adb" - https://developer.android.com/studio/releases/platform-tools)',
65 | ],
66 | ['*'],
67 | [
68 | 'To run ios simulator (after installing Xcode - only on Apple devices)',
69 | ],
70 | ['*'],
71 | ['To run tests for Native and Web'],
72 | ['*'],
73 | ['To run build for Web'],
74 | ]);
75 |
76 | expect(execSync.mock.calls).toEqual([
77 | [
78 | 'npx react-native init myFakeName --template react-native-template-react-native-web',
79 | {stdio: [0, 1, 2]},
80 | ],
81 | ['yarnpkg --version', {stdio: 'ignore'}],
82 | ['cd myFakeName && git init'],
83 | ['yarnpkg --version', {stdio: 'ignore'}],
84 | ]);
85 | });
86 | done();
87 | });
88 | });
89 |
--------------------------------------------------------------------------------
/cliError.test.js:
--------------------------------------------------------------------------------
1 | const chalk = require('chalk');
2 | const commander = require('commander');
3 | const path = require('path');
4 | const execSync = require('child_process').execSync;
5 | const packageJson = require('./package.json');
6 |
7 | const originalConsoleLog = console.log;
8 | console.log = jest.fn();
9 |
10 | const originalConsoleError = console.error;
11 | console.error = jest.fn();
12 |
13 | jest.mock('child_process', () => {
14 | const execSync = jest.fn();
15 |
16 | return { execSync };
17 | });
18 |
19 | jest.mock('chalk', () => {
20 | const red = jest.fn(text => text);
21 | const cyan = jest.fn(text => text);
22 | const green = jest.fn(text => text);
23 | const magenta = jest.fn(text => text);
24 |
25 | return {
26 | red,
27 | cyan,
28 | green,
29 | magenta,
30 | };
31 | });
32 |
33 | describe('cli shows error', () => {
34 | it('cli runs without arguments', () => {
35 | const originalProcessExit = process.exit;
36 | process.exit = jest.fn();
37 | process.argv[2] = '';
38 | require('./cli');
39 |
40 |
41 | expect(console.error.mock.calls).toEqual([['In order to create a new project you must give a name as an argument. ', 'Example: create-react-native-web-app AppName']]);
42 | expect(process.exit.mock.calls).toEqual([[1]]);
43 | process.exit = originalProcessExit;
44 | });
45 | });
46 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "create-react-native-web-app",
3 | "version": "0.16.4",
4 | "description": "React Native Web CLI",
5 | "main": "cli.js",
6 | "scripts": {
7 | "start": "node cli.js",
8 | "test": "jest",
9 | "test-watch": "jest --watch",
10 | "precommit": "npm run test"
11 | },
12 | "engines": {
13 | "node": ">=8"
14 | },
15 | "bin": {
16 | "create-react-native-web-app": "cli.js"
17 | },
18 | "repository": {
19 | "type": "git",
20 | "url": "git+https://github.com/orYoffe/create-react-native-web-app.git"
21 | },
22 | "keywords": [
23 | "react",
24 | "native",
25 | "web",
26 | "ios",
27 | "android",
28 | "react-native",
29 | "react-native-web",
30 | "CLI"
31 | ],
32 | "author": {
33 | "name": "Or Yoffe",
34 | "url": "https://github.com/orYoffe"
35 | },
36 | "license": "MIT",
37 | "bugs": {
38 | "url": "https://github.com/orYoffe/create-react-native-web-app/issues"
39 | },
40 | "homepage": "https://github.com/orYoffe/create-react-native-web-app#readme",
41 | "devDependencies": {
42 | "husky": "^0.14.3",
43 | "jest": "^23.1.0"
44 | },
45 | "dependencies": {
46 | "chalk": "^3.0.0",
47 | "commander": "^2.15.1",
48 | "react-native-template-react-native-web": "*"
49 | },
50 | "jest": {
51 | "testEnvironment": "node",
52 | "testPathIgnorePatterns": [
53 | "./node_modules/"
54 | ]
55 | }
56 | }
57 |
--------------------------------------------------------------------------------
/react-router/App.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import Home from './pages/Home';
3 | import ReactRouter from './pages/ReactRouter';
4 | import {Router, Route, Switch} from './router';
5 |
6 | const App = () => {
7 | return (
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 | );
16 | };
17 |
18 | export default App;
19 |
--------------------------------------------------------------------------------
/react-router/pages/Home.js:
--------------------------------------------------------------------------------
1 | import React, {Component} from 'react';
2 | import {
3 | StyleSheet,
4 | Text,
5 | View,
6 | Platform,
7 | TouchableHighlight,
8 | Animated,
9 | Easing,
10 | } from 'react-native';
11 | import {Link} from '../router';
12 | import logo from '../logo.png';
13 |
14 | class Home extends Component {
15 | state = {
16 | spinValue: new Animated.Value(0),
17 | };
18 |
19 | onClick = () => {
20 | const wasRotated = this.state.spinValue._value === 1;
21 | Animated.timing(this.state.spinValue, {
22 | toValue: wasRotated ? 0 : 1,
23 | duration: 250,
24 | easing: Easing.linear,
25 | }).start();
26 | };
27 |
28 | render() {
29 | const spin = this.state.spinValue.interpolate({
30 | inputRange: [0, 1],
31 | outputRange: ['0deg', '360deg'],
32 | });
33 |
34 | return (
35 |
36 |
37 |
38 | To router route
39 |
40 |
41 |
45 | Create React Native Web App
46 |
47 | Open up src/App.js to start working on your app!
48 |
49 |
50 | Changes you make will automatically reload.
51 |
52 | {Platform.OS !== 'web' && (
53 |
54 | Shake your phone to open the developer menu.
55 |
56 | )}
57 |
61 | Rotate Logo
62 |
63 |
64 | );
65 | }
66 | }
67 |
68 | const styles = StyleSheet.create({
69 | container: {
70 | flex: 1,
71 | backgroundColor: '#282c34',
72 | alignItems: 'center',
73 | justifyContent: 'center',
74 | },
75 | logo: {
76 | width: 300,
77 | height: 300,
78 | },
79 | title: {
80 | color: '#fff',
81 | fontWeight: 'bold',
82 | fontSize: 16,
83 | },
84 | text: {
85 | color: '#fff',
86 | },
87 | button: {
88 | borderRadius: 3,
89 | padding: 20,
90 | marginVertical: 10,
91 | marginTop: 10,
92 | backgroundColor: '#1B95E0',
93 | },
94 | buttonText: {
95 | color: '#fff',
96 | fontWeight: 'bold',
97 | fontSize: 16,
98 | },
99 | });
100 |
101 | export default Home;
102 |
--------------------------------------------------------------------------------
/react-router/pages/ReactRouter.js:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import {StyleSheet, Text, View, Image, Platform, Linking} from 'react-native';
3 | import {Link} from '../router';
4 | import logo from './reactRouterLogo';
5 |
6 | const url = 'https://reacttraining.com/react-router/native/guides/quick-start';
7 | const openLink = () =>
8 | Linking.canOpenURL(url).then((supported) => {
9 | return Linking.openURL(url);
10 | });
11 |
12 | const linkProps =
13 | Platform.OS === 'web'
14 | ? {
15 | accessibilityRole: 'link',
16 | target: '_blank',
17 | href: url,
18 | }
19 | : {onPress: openLink};
20 |
21 | const ReactRouter = () => {
22 | return (
23 |
24 |
25 | To to main page
26 |
27 |
33 |
34 | Go to react-router docs
35 |
36 |
37 | );
38 | };
39 |
40 | const styles = StyleSheet.create({
41 | container: {
42 | flex: 1,
43 | backgroundColor: '#282c34',
44 | alignItems: 'center',
45 | justifyContent: 'center',
46 | },
47 | title: {
48 | color: '#fff',
49 | fontWeight: 'bold',
50 | fontSize: 16,
51 | },
52 | logo: {
53 | width: 300,
54 | height: 300,
55 | },
56 | button: {
57 | borderRadius: 3,
58 | padding: 20,
59 | marginVertical: 10,
60 | marginTop: 10,
61 | backgroundColor: '#1B95E0',
62 | },
63 | buttonText: {
64 | color: '#fff',
65 | fontWeight: 'bold',
66 | fontSize: 16,
67 | },
68 | });
69 |
70 | export default ReactRouter;
71 |
--------------------------------------------------------------------------------
/react-router/pages/reactRouterLogo.js:
--------------------------------------------------------------------------------
1 | const logo =
2 | '';
3 |
4 | export default logo;
5 |
--------------------------------------------------------------------------------
/react-router/router/index.js:
--------------------------------------------------------------------------------
1 | export {
2 | Router,
3 | Switch,
4 | Route,
5 | Link,
6 | Redirect
7 | } from './router';
8 |
--------------------------------------------------------------------------------
/react-router/router/router.android.js:
--------------------------------------------------------------------------------
1 | export {
2 | NativeRouter as Router,
3 | Switch,
4 | Route,
5 | Link,
6 | Redirect
7 | } from "react-router-native";
8 |
--------------------------------------------------------------------------------
/react-router/router/router.ios.js:
--------------------------------------------------------------------------------
1 | export {
2 | NativeRouter as Router,
3 | Switch,
4 | Route,
5 | Link,
6 | Redirect
7 | } from "react-router-native";
--------------------------------------------------------------------------------
/react-router/router/router.js:
--------------------------------------------------------------------------------
1 | export {
2 | BrowserRouter as Router,
3 | Switch,
4 | Route,
5 | Link,
6 | Redirect
7 | } from "react-router-dom";
--------------------------------------------------------------------------------
/react-router/router/router.web.js:
--------------------------------------------------------------------------------
1 | export {
2 | BrowserRouter as Router,
3 | Switch,
4 | Route,
5 | Link,
6 | Redirect
7 | } from "react-router-dom";
--------------------------------------------------------------------------------