Contempo
Starter development environment for React. This repository is a starter development environment for creating apps(specifically for React) using webpack.
Client Rendering Demo
- For server-side rendering, clone this repo and run
npm run deploy:server
Installation
This has a client and server environment. Here are the following commands to install the environment.
- Make sure you have YARN installed in your system.
- To install yarn run
yarn install
Client-side rendering
Using Grunt Assets
npm run assets
- Runs the task that handles the assets
npm run client:dev
- Runs client-side rendering development environment.
npm run client:prod
- Runs client-side rendering production.
Server-side rendering
npm run server:dev
- Runs server-side rendering development environment.
npm run server:prod
- Runs webpack in production.
npm run server
- Runs the node server.
Access: http://localhost:4200
npm test
- Runs the jest testing.
npm run eslint
- Runs the eslint.
Flow types
npm run flow
- Runs flow type checker
Formatting
npm run format
- Runs the prettier formatter
Linting
npm run lint
- Runs the linter
Test
npm test
- Runs the test suite
Asynchronous routes / components
Asynchronously load routes or components by using the async component. Checkout react-loadable here: https://github.com/thejameskyle/react-loadable
Testing
There are two types of tests, integration and unit tests.
Checkout the src/jest-integration.config.json
and jest-unit.config.json
files to see the configurations.
Integration tests
npm run jest:integration
- run integration test.
npm run jest:integration:watch
- run integration test in watch mode.
npm run jest:integration:coverage
- run integration test in watch mode.
Unit tests
npm run jest:unit
- run unit test.
npm run jest:unit:watch
- run unit test in watch mode.
npm run jest:unit:coverage
- run unit test in watch mode.
References
Coding Guideline:
./src/
Main source Directory :Here are the descriptions of each folders:
assets
- directory for media files.
components
- directory for all of the react presentational components.
Each of this folder should consist the main presentational component files and a styles.js
.
This styles.js
file is where all of the styled-components
code is located.
containers
- directory for all of the react container components.
Ideally, you should put all of styled components code on the presentational components directry, however,
since you can basically add an inline styled-component
code from here.
config
- directory for all of the react configurations. e.g: routes, redux store and etc...
helpers
- directory for helper code snippets.
redux
- directory for all of the redux-related code(actions, reducers, action types).
styles
- directory for all of the common styled-components
code and base CSS or SCSS files.
This directory is different from the components directory's styles.js
. styles.js
from the components
directory are only specific to the react-presentational styles of the current directory.
Deployment
You have to bundle all the scripts in production mode. If you want client-side production bundle and deployment:
$ npm run deploy:client # yarn deploy:client
If you want server-side production bundle and deployment:
$ npm run deploy:prod # yarn deploy:client
Additional important directories:
client
- customizable configurations for the client-side rendering.
server
- customizable configurations for the server-side rendering.
tools
- customizable development configurations(webpack). You can add additional dev tools from here.
public
- rendered directory.