Mobile MVPs with React Native
Philip // The Bakery - @bakeryhq
# 🙋
### Let's keep this interactive
### MVP
> In product development, the minimum viable product (MVP) is a product with just enough features to gather validated learning about the product and its continued development.
source: [Wikipedia](https://en.wikipedia.org/wiki/Minimum_viable_product)
### React Native (RN)
- ~~web page inside native container~~
- ~~standard React components plugged into native containers~~
- React component model
- Native bridge
- Platform specific native components
data:image/s3,"s3://crabby-images/1ed52/1ed5266d40e88656e797d039bb27050074fee383" alt="React Native Architecture overiew"
source: [React Native @ Airbnb](https://speakerdeck.com/felipecsl/react-native-at-airbnb)
data:image/s3,"s3://crabby-images/1d6e1/1d6e146e12006619e26c70c528d304b6427de823" alt="React Native Execution model"
source: [React Native @ Airbnb](https://speakerdeck.com/felipecsl/react-native-at-airbnb)
### RN: What's inside
- basic components for Android and iOS
- networking stack
- access to native device API
- utility for connecting your own native components
- custom bundler (not webpack) + hot reload
- styling using js (flexbox + standard jazz)
### RN for MVPs
- development speed ++
- 2 platforms at a time
- js everywhere
### Pokemon Maps
data:image/s3,"s3://crabby-images/1916d/1916d06e74ebd86aab1c7e72fe1576ed91b56645" alt="TodoMVC"
### TodoMVC
data:image/s3,"s3://crabby-images/68979/68979c49cda77ca88199c57410974cfe5557f19c" alt="TodoMVC"
### Pixelinho
data:image/s3,"s3://crabby-images/9286e/9286e22371aeb06a421aea687fb8fdfacdb4cd53" alt="TodoMVC"
### Our 🌟 stack 🌟
data:image/s3,"s3://crabby-images/49575/495758e98e13dad16c8388e6c8f2eb80323374a3" alt="TodoMVC"
### Generators
- initial scaffolding
- components/containers/reducers/models/sagas etc
- ! use them past initial scaffolding
### Type less
data:image/s3,"s3://crabby-images/5aadb/5aadb1642bebba3d3965e04527ef6954b62c417b" alt="Sample generator output"
### RN
- standard stuff
- Redux for state management
- Reselect for performant selectors
- Sagas for side effects
- Mocha + Enzyme for testing
### RN: App Directory
data:image/s3,"s3://crabby-images/fb5fa/fb5faa71f5acc9da991dea6c3af3eb461e8e5809" alt="App Directory"
### RN: Component Directory
data:image/s3,"s3://crabby-images/522c8/522c880703d8b259aff608a74e60a192a5b93009" alt="Component Directory"
### RN: State Directory
data:image/s3,"s3://crabby-images/4732d/4732d5d85d6f049dc8e0aa4772944a8b75ab2a2a" alt="State Directory"
### Server
- collocate app and server for better development flow
- make it easy to run the server so everybody can do it
- use Parse Server for menial stuff
- GraphQL for defining common language between app and server
data:image/s3,"s3://crabby-images/3d18a/3d18a8bdf4ee92ab0e3e10677bbbfeeea3136295" alt="App and server code living together"
### Parse Server + Dashboard
data:image/s3,"s3://crabby-images/ee721/ee721ed7946050194cb8c421b1cc6b0a1a8701a7" alt="Parse Dashboard"
[Parse Platform on Github](https://github.com/ParsePlatform)
data:image/s3,"s3://crabby-images/dfb70/dfb704359b96880cc9f516eb4d680c67a75f1818" alt="Ship it"
#Ship it
### Ship early, ship often
- binary releases with [Fastlane](https://fastlane.tools/)
- js bundles with [Codepush](https://microsoft.github.io/code-push/)
### Fastlane
data:image/s3,"s3://crabby-images/eefc2/eefc28cbf90d77cce620cde097c5c767f78d759b" alt="Fastlane"
### Codepush
> code-push release-react MyApp ios
data:image/s3,"s3://crabby-images/f6ec0/f6ec04b0e8a90cd5575212ef70ea121170ebaf3d" alt="Bitrise workflow"
data:image/s3,"s3://crabby-images/19fc9/19fc9adc2590065bed01d4b6066970eacfd46243" alt="Github bot commit message"
data:image/s3,"s3://crabby-images/90391/90391c05162eeeae9044c2646fdb75ce9ed3115e" alt="Test flight"
### Recap
- type less, do more
- keep your server close
- ship often
- automate all the chores (CI)
### Getting there
- [Pepperoni](http://getpepperoni.com/)
- [Snowflake](https://github.com/bartonhammond/snowflake)
- [Ignite](https://github.com/infinitered/ignite)
- [🍰 Baker](http://baker.thebakery.io/)