React Native Beginners Workshop
Intro
Rahul Gaba
Atul R
data:image/s3,"s3://crabby-images/6848e/6848e7191483ed15ca5ee773bd168960b6c34122" alt=""
data:image/s3,"s3://crabby-images/2c27e/2c27e4451737d4adcae6e55b7dcd04caf1841ec0" alt=""
Pre-requisites
-
Install node, react-native-cli, Android studio and Xcode (click on "Building Projects with Native Code" tab): https://facebook.github.io/react-native/docs/getting-started.html
-
Make sure your emulators are working and running (either android or ios)
-
Yarn: npm install -g yarn
-
An ESLint supported IDE, preferably Atom: https://atom.io
-
Clone this repo: https://github.com/react-native-workshop/note-taker
-
Install latest version of React Native Debugger: https://github.com/jhen0409/react-native-debugger/releases
Goal
- Understand how react-native works.
- Build a native android and iOS app.
- Setup CI for automated builds.
- Conventions to manage the codebase.
Note Taker
data:image/s3,"s3://crabby-images/7601a/7601a624bb232c1bc757eaad34f398c1aecbbe7d" alt=""
data:image/s3,"s3://crabby-images/935f5/935f5f81102f55f7f20c784a82630924071514b2" alt=""
data:image/s3,"s3://crabby-images/9772f/9772f2252162bfb0d4c1a4bfb940993aabd44443" alt=""
data:image/s3,"s3://crabby-images/9c999/9c9990313daa8ac78ce3221b40623e739dc36583" alt=""
data:image/s3,"s3://crabby-images/c15ea/c15ea652b7d5d6a29c75c7187ddfc80a90480ceb" alt=""
data:image/s3,"s3://crabby-images/9a48e/9a48ed0ec9d24fba9778bb6cfc78c3c0b7a6b1ca" alt=""
react-native
Another JS framework?
data:image/s3,"s3://crabby-images/afda9/afda9fadd957ac0c55ea538fe51989d34a37ea97" alt=""
A revolutionary framework which lets you build native apps using JS*
data:image/s3,"s3://crabby-images/b8920/b892039d6e96a44ea60ac8c957d41a3446d1809e" alt=""
React-Native Architecture 🏛
-
Native Code/Modules
- JavaScript VM
React-Native Internals 🛠
data:image/s3,"s3://crabby-images/9b406/9b4068fa38fb905cb76d3f831cb11fe8162472d1" alt=""
data:image/s3,"s3://crabby-images/fc67a/fc67a09e3d792abf8414bb2551cbac89cf27da1c" alt=""
Get, Set.. Code!
git checkout chapter-1 yarn install
yarn android or yarn ios
Get, Set.. Code!
Task #1: Run Hello world app
Get, Set.. Code!
Get, Set.. Code!
Task #1: Run Hello world app
data:image/s3,"s3://crabby-images/0388b/0388b6d4c0dbea3db35c6ebfad5e02db49f98e40" alt=""
data:image/s3,"s3://crabby-images/6aebc/6aebcdbe5a09c44a2031f413ea642c608474a5c5" alt=""
Debugging
data:image/s3,"s3://crabby-images/d5003/d5003c77b16187e63c37d8c43666dfb3b5be23eb" alt=""
data:image/s3,"s3://crabby-images/3d1fe/3d1fe4ec48fa307ff20511e81d022c5c5169218d" alt=""
Mac
iOS: cmd+ctrl+z
Android: cmd+m
Windows
iOS: NA
Android: ctrl+m
The Boilerplate 🍽
Get, Set.. Code!
Start writing components
data:image/s3,"s3://crabby-images/d9b0c/d9b0c8f352a598b8f389d7692bb4e0a499a5c477" alt=""
data:image/s3,"s3://crabby-images/c163a/c163ae5341b8a290e7dec8b345a8d7bc4590f0b8" alt=""
Get, Set.. Code!
Task #2: Adding ESLint, githooks
yarn git checkout chapter-2 yarn android OR yarn ios
Get, Set.. Code!
Task #3: Adding ESLint, githooks
data:image/s3,"s3://crabby-images/fbb95/fbb95c07f9870bb96e43a8f9db90bc68b0dcf4b0" alt=""
data:image/s3,"s3://crabby-images/6f7d1/6f7d17b671a26fcb871d59f6f386320f506a6b00" alt=""
Speeding up development with some ES7 Features ⏩
- ES6 Classes
- Class properties instead of constructor
- Arrow functions instead of class methods
- Object rest spread
data:image/s3,"s3://crabby-images/b577f/b577fb50f8f20f1cd9d3b711581a37060214f658" alt=""
data:image/s3,"s3://crabby-images/abec4/abec41f720f00b238a8bef9864aa0aa4167f4312" alt=""
Using ES7 features
Testing 🙇
- What's the use of testing UI code?
- Snapshots
- Testing stateful components using Enzyme
Get, Set.. Code!
Task #3: Write test cases for the code so far
yarn git checkout chapter-3
Styling 💅
- Flexbox
- Theme variables
- Separating styles from component code
Get, Set.. Code!
Task #4: Style the components
git checkout chapter-4
Get, Set.. Code!
Task #4: Style the components
data:image/s3,"s3://crabby-images/b2e1f/b2e1f65b05e242c85219741d53542094f9555adb" alt=""
data:image/s3,"s3://crabby-images/ad246/ad246897c660009ef70e11eb2517ea64ce84bd7c" alt=""
Before
After
Using third party modules 📦
- When should I look for third party components?
- awesome-react-native: https://github.com/jondot/awesome-react-native
- How react-native link works?
- Adding react-native-vector-icons
Get, Set.. Code!
Task : Add react-native-vector-icons using react-native link
BREAK
DevOps ✈️
-
Lint and tests with coverage should run whenever a pull request is raised.
-
CI builds and publish app to the internal team testers on every merge to master.
-
Manual Building capability for developers
To see circleci build: https://goo.gl/uzgNp1
Redux 🗄
-
Why state management?
-
Reducers/Actions/Dispatch
-
Presentational Components VS Container Components
Redux 🗄
data:image/s3,"s3://crabby-images/9278a/9278a758976aee6e849f018705a9b15dbbc93d8b" alt=""
Get, Set.. Code!
Task #6: Add functionality to our app using redux
git checkout chapter-6
Get, Set.. Code!
data:image/s3,"s3://crabby-images/bdd1b/bdd1bc1c865705c038aeb86eceb362139e459ecd" alt=""
Task #6: Add functionality to our app using redux
Navigation 🛣
-
How navigation happens in native applications?
-
Types of navigators offered by react-navigation
-
Navigate using redux-actions
Navigation 🛣
data:image/s3,"s3://crabby-images/3ee27/3ee27cbe348bf0e536e86f38fa947ab67e3da972" alt=""
A Stack in native apps
Get, Set.. Code!
Task #7: Add multipage navigation to our app
git checkout chapter-7
Get, Set.. Code!
Task #7: Add multipage navigation to our app
data:image/s3,"s3://crabby-images/ca8f4/ca8f44e7df5bf520e9bfdb9b76a2706938785119" alt=""
data:image/s3,"s3://crabby-images/41d8d/41d8d592e2b89b3dcc8ebddaa95e89f731e53122" alt=""
Porting the app to web
git checkout chapter-8
Task #8: Add a Link component to our app that should show up the link passed to it on a separate tab in browser on both android and web
Custom Native Modules 🍱
- Do I need to know Java/Objective-C?
- Writing Native-wrappers of existing native modules.
- Writing a Device Module for both Android and iOS
Get, Set.. Code!
Task #9: Create a custom module which returns the device name
git checkout chapter-9
Task #11: Create a custom module which returns the device name
data:image/s3,"s3://crabby-images/f09b6/f09b69ccc4e051e8623a26d544e9e87c447eb028" alt=""
data:image/s3,"s3://crabby-images/a6099/a6099bead0620e8227181b38394713061316405c" alt=""
References
-
http://reactkungfu.com/2015/07/why-and-how-to-bind-methods-in-your-react-component-classes/
-
https://medium.com/differential/managing-configuration-in-react-native-cd2dfb5e6f7b
-
https://medium.com/the-react-native-log/comparing-the-performance-between-native-ios-swift-and-react-native-7b5490d363e2
Q&A
The End
data:image/s3,"s3://crabby-images/232f9/232f98db5761faa353635413a2d61345babda5d1" alt=""
data:image/s3,"s3://crabby-images/b1c07/b1c07bf7167b296d3fdb342d971de86a0bd22bc0" alt=""
Feedback: https://goo.gl/PXLjov
React-Native
By Rahul Gaba
React-Native
- 3,205