A universal starter kit built with react, react-router and redux. Server rendering with react and express, bundles with Webpack with hot module reloading and hot style reloading with SCSS support. Bonus: Cordova support.
-
Node 4.2+ is recommended.
-
Webpack
npm install -g webpack
- nodemon
npm install -g nodemon
- eslint, babel-eslint
npm install -g eslint babel-eslint
npm install
npm start
Direct your browser to http://localhost:3000
.
βββ client # Client-side code.
βββ common # Shared code between client and server.
β βββ assets # All fonts, images, stylsheets.
β β βββ fonts
β β βββ images
β β βββ stylesheets # Follows the 7-1 pattern: http://sass-guidelin.es/#the-7-1-pattern
β β βββ base
β β βββ components
β β βββ layout
β β βββ pages
β β βββ shame
β β βββ utils
β β βββ vendors
β βββ config # Contains the redux store configuration. Add anything else you like.
β βββ middleware # Custom redux middleware can be placed here.
β βββ reducers # Redux reducers
| | βββ index.js # Root reducer. Imports all other reducers.
β βββ routes # Routes each have an index.js which exports a react-router Route.
β β βββ app
β β β βββ components
β β β βββ containers
β β β βββ index.js
β β βββ example # The name of route.
β β β βββ components # "Dumb" components
β β β βββ containers # "Smart" containers
β β β βββ index.js # Exports a react-router route. Uses [alternate configuration](https://github.com/rackt/react-router/blob/master/docs/guides/basics/RouteConfiguration.md#alternate-configuration)
β β βββ home
β β βββ containers
β β β βββ index.js
β βββ selectors # Memoized selectors. See https://github.com/rackt/reselect
β βββ shared # Shared actions and components and do not belong to a single route.
β β βββ actions
β β βββ components
β βββ templates # HTML templates
β βββ util # Utility methods
βββ cordova-build # Cordova build tools
β βββ config
βββ server # Server-side code.
βββ webpack # Webpack configuration files.
The default testing framework is Mocha, though you can use whatever you want. Make sure you have it installed:
npm install -g mocha
Tests should reside alongside the component/module/selector/etc that it is testing. For example:
βββ reducers
β βββ todos.js
β βββ todos.test.js
Tests can be written with ES2015, since it passes through babel-register
.
To run a single test:
npm test /path/to/single.test.js
To run a directory of tests:
npm test /path/to/test/directory
To run all tests:
npm run test:all
This will run all files that are suffixed with a .test.js
.
Just set an environment variable to point the asset host to whereever you want,
since it defaults to localhost:3001
. If using Heroku to store assets, just use
a local route. Otherwise, set it to the CDN of your choice.
heroku config:set ASSET_HOST=/dist/
# OR
heroku config:set ASSET_HOST=https://s3.amazonaws.com/mybucket/myasssets/
First, make sure you have Cordova installed:
npm install -g cordova
Initialize the Cordova app:
cordova create cordova/ com.org.appname "My App"
Add the platform(s) you want to build for:
cd cordova/
cordova platform add ios # or 'android'
Install plugins (if you don't have a /plugins
folder)
cordova prepare
npm run start:cordova # build for development with hot reloading
npm run build:cordova # build for development without hot reloading
npm run build:cordova:development # alias for above
npm run build:cordova:production # build for production without hot reloading
- iOS - CLI
Install XCode, then:
npm install -g ios-deploy
cd cordova && cordova run ios
- iOS - XCode
Open the file located in ./cordova/platforms/ios/MarcasDirectos.xcodeproj
.
- Android - CLI
Install the Android SDK, then:
cd cordova && cordova run android
You may want to distribute the app via Fabric (Crashlytics). To do so, prepare the following files (copy and rename them):
build/fabric.json.example -> build/fabric.json
build/config/release.json.example -> build/config/release.json
Fill in the fields in the JSON files properly, then run the following commands:
npm run build:cordova:production # build the source files for cordova's www
npm run dist:android # build the binary and upload to Crashlytics
# OR
npm run dist:ios
If you're debugging in a mobile browser and you want to access your project locally, do the following:
- Make sure your mobile device on the same network as your desktop/laptop.
- Run
npm start
with aHOSTNAME
environment variable set to your computer's local ip address (the computer that your dev environment is on):
HOSTNAME=10.0.1.3 npm start
- Browse to
http://10.0.1.3:3000
on your mobile device.