├── .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 | [![SWUbanner](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/banner2-direct.svg)](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 | [![NPM](https://nodei.co/npm/create-react-native-web-app.png)](https://npmjs.org/package/create-react-native-web-app) 9 | 10 | ![GitHub issues](https://img.shields.io/github/issues/orYoffe/create-react-native-web-app.svg) 11 | ![license](https://img.shields.io/github/license/orYoffe/create-react-native-web-app.svg) 12 | ![GitHub top language](https://img.shields.io/github/languages/top/orYoffe/create-react-native-web-app.svg) 13 | ![npm](https://img.shields.io/npm/v/create-react-native-web-app.svg) 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"; --------------------------------------------------------------------------------