Jump-start your react
-powered Universal App
Designed for Veterans
dev-toolkit
provides you with an easy and quick way to get started with a pre-rendered & server-rendered app. After creating your starting point with the init
command, you get full customisability out of the box.
Note: Please be aware that this project will be phased out as by 2020 and I'm only making minor additions at this time. I'm happy for you to keep using dev-toolkit
if you wish and will respond to important Issues or PR-requests but they won't be my top-priority. I suggest you switch to an alternative such as Next.js or razzle.
$ npm install -g dev-toolkit
# Initialise a project with optional name, template, comments
# The comments explain how the `dev-toolkit` works with the template
$ dev-toolkit init [project_name] [--template template_name] [--skip-comments]
* used by default when initialising a new project
dev-toolkit
is intentionally minimalist on features. It's meant to get you started quickly with a project where you will need customisability instead of mandating which technologies that you must use (such as Jest).
- SSR by default
- Ability to pre-render after webpack creates a build
- Complete control over client & server
see template docs - Start your project without bloat or guidance if you like it rough
dev-toolkit init --template minimal --skip-comments
- Full control over your server-rendered template
no webpack lock-in such as with html-webpack-plugin unless you choose to - hot-reload on client & server, opt-in for both
- Easy way to integrate any nodeHooks for SSR usage
using/nodeHooks.js
- Easy way to add webpack plugins and presets
using/dev-toolkit.config.js
- use select environment variables on client
usingimport { sharedEnvs } from 'dev-toolkit/settings'
- you can use sane if-statements, jsx-control-statements
<If condition={true}> ... </If>
will compile down to&&
-syntax
Node.js 8.9.4
or higher suggested. You can use lower versions but you might not have arrow-functions or async/await support available. See Node.js compatibility table for more information.
The aim of dev-toolkit is to be unopinionated so that it can be useful in many different scenarios. Therefore only the most necessary dependencies are included and other additions may be provided by yourself (see the other template examples for guidance).
With CSS-in-JS solutions on the rise, it would be unwise to include dependencies for css-modules
, sass
or less
in every project that has dev-toolkit
as a dependency, it would introduce additional installation time and bloat.
See Contributing.md