Concept behind: this starter is an easy way to understand and ready to use ReactJS (ES6) + bootstrap + webpack starter with:
no hard core Webpack
config so it is more commonly understandable (they are numerous amazing starters with incredible webpack configs β hard core configs aren't bad things at all! β. This one is just for easier understanding for people even discovering webpack)with hot reload
(ReactJS + webpack => hot reload = WINNER)no flux
(yes, to give you freedom to add then since you may want to use something else like observables?)with JWT auth
- ReactJS Components written with
optimization tricks
(stateless, pure render...).
Looking for server side rendering? check this project with SSR added here
- add
React 16.3.x
new context API use case (you may no more need redux) - migrated to bootstrap 4
- upgrade to
React 16.3.x
- upgrade to
webpack 4
- upgrade to
react-hot-loader v4
- drop
CSS Module
in favor ofstyled-components
(scoped style, theme support, better scaling in huge applications, simplify toolchain and keep nearly SASS syntax) - add
flow types
(even a little typing at least for better dev experience) - drop
prop-types
(static and dynamic typing apart, flow type does far more so avoid writing 2 differents typing system) workbox-webpack-plugin
(service worker caching powerful tool from Google)- loadable-components (split your code: here splitted just by routes, by you can split a component level if you feel the need)
webpack-bundle-analyzer
: analyze your bundle size (maybe you should split or lazy load some part of your application: you will see clearly how to fix that)- drop
moment
fordate-fns
(since far smaller size and job's done)
- upgrade to React 16.x
react-router 4+
(read this nice article about migrating from react-router 3 to react-router 4)- add few flow types (still keep propTypes)
- updated hot reload (read hot reload starter)
- use
CSS module
(keep coding style with SASS but get benefit of css module for a more peasant coding)
- upgrade to
React 15.6.x
- upgrade to
webpack v3
- add
JWT authentication
(protected route, logout components...)
- upgrade to
react-router v4
- upgrade to
webpack 2
- remove autoprefixer in favor of
postcss
andcssnext
- upgrade
React
to15.5.4+
PropTypes
comes now fromprop-types
- upgrade dependencies
If you prefer a
webpack 1
version, version 1.1.0 is what you are looking for.
Front:
- React JS (16.3.x - github π)
- react-router (4.x- github π)
- Bootstrap (3.x - github π)
- React-Bootstrap (github π)
- font-awesome (github π)
- animate.css (github π)
- classnames (github π)
- react-motion (github π)
- Webpack 3.x (github π)
- babel 6+ (github π)
- axios (github π Why: simple, complete, isomorphic ...)
Tool chain:
- babel 6+
- eslint
- hot reload
- loaders
js
/jsx
- css
- json
- images formats
- svg and fonts formats
tests:
- Jest
- enzyme
npm install
or
yarn install
npm run dev
npm run start
npm run test
npm run prod
with server hot reload (and dev bundle):
npm run serve-dev
without hot reload (and prod bundle):
npm run serve-prod
The MIT License (MIT)
Copyright (c) 2018 Erwan DATIN
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.