/kit

ReactQL starter kit (use the CLI)

Primary LanguageJavaScriptMIT LicenseMIT

ReactQL

Travis npm license Twitter Follow

New in 2.x: Full-stack GraphQL + React v16 streaming API + SSL

Full-stack React + GraphQL, done properly.

Want to install quickly? Use the CLI - it does the heavy lifting for you.

Features

Stack

GraphQL

  • New in 2.x: Built-in GraphQL server via - just pass in your schema, and enable /graphql with a single line of code
  • GraphiQL query browser enabled by default
  • Isomorphic GraphQL client - await data via SSR before rendering HTML; query asynchronously in the browser
  • Avoid network overhead with local GraphQL querying via apollo-local-query
  • Write .gql GraphQL query files, use fragments, or type queries inline.

Server-side rendering

  • Built-in Koa 2 web server, with async/await routing
  • React v16 with streaming API - time-to-first-byte as low as 4-5ms!
  • Full route-aware server-side rendering (SSR) of initial HTML
  • Universal building - both browser + Node.js web server compile down to static files
  • Per-request Redux stores. Store state is dehydrated via SSR, and rehydrated automatically on the client
  • Declarative/dynamic <head> section, using react-helmet
  • Full page React via built-in <Html> component - every byte of your HTML is React!
  • Run plain HTTP and SSL from the same port - just config.enableSSL(sslOptions) in your app code

Real-time

  • Hot code reloading; zero refresh, real-time updates in development
  • React + Redux state preservation on hot reloading, to avoid interrupting your dev flow
  • Development web server that automatically rebuilds and restarts on code changes, for on-the-fly SSR testing with full source maps
  • Hot code reload works inside Docker too! Just docker-compose -f docker-compose.dev.yml

Code optimisation

  • Webpack v3, with tree shaking -- dead code paths are automatically eliminated
  • Separate local + vendor bundles, for better browser caching/faster builds
  • Dynamic polyfills, courtesy of babel-preset-env
  • Aggressive code minification with Uglify
  • GIF/JPEG/PNG/SVG crunching for images in production
  • CSS code is combined, minified and optimised automatically - even if you use SASS, LESS and CSS together!

Styles

  • PostCSS v6 with next-gen CSS and inline @imports
  • SASS and LESS support (also parsed through PostCSS)
  • Automatic vendor prefixing - write modern CSS, and let the compiler take care of browser compatibility
  • Mix and match SASS, LESS and regular CSS - without conflicts!
  • CSS modules - your classes are hashed automatically, to avoid namespace conflicts
  • Compatible with Foundation, Bootstrap, Material and more. Simply configure via a .global.* import to preserve class names

Highly configurable

  • New in 2.x: Userland configuration. No need to edit kit code; simply use the built-in Config singleton
  • Add a GraphQL server with one line of code
  • Add GET|POST|PUT|PATCH|DELETE routes - auto-injected with Koa context and the per-request Redux store
  • Add a custom 404 handler
  • Enable/disable POST body parsing, along with custom options
  • Enable/disable HTTP hardening
  • Mount your front-end assets anywhere (like a CDN) with a dynamic <base> tag handling (React Helmet compatible)

Production-ready

  • Production bundling, that generates optimised server and client code
  • Static bundling mode for hosting your full app on any static host -- Github pages, S3, Netlify, etc
  • Static compression using the Zopfli Gzip and Brotli algorithms for the serving of static assets as pre-compressed .gz and .br files (default vendor.js.bz goes from 380kb -> 89kb!)
  • Automatic HTTP hardening against common attack vectors via Koa Helmet (highly configurable)
  • Easily extendable webpack-config files, for modular Webpack tweaks
  • Docker support, with an optimised Dockerfile out-the-box
  • PM2-enabled Dockerfile, which auto-clusters over multi-core processes and auto-restarts on failure

Developer support

CLI tool

  • Get the ReactQL CLI tool with npm i -g reactql
  • Mac, Windows and Linux compatible
  • One command to start a new project: reactql new
  • One command to upgrade an existing one: reactql upgrade
  • Takes care of the stuff you shouldn't have to: reactql new downloads the kit, unzips the files, removes artefacts, builds your package.json, installs required NPM packages, and dumps the start-up commands in your terminal, so you can start coding right away

Usage

See the CLI tool for easily deploying this starter kit on Mac, Windows or Linux.

Then run npm start in the project root, and away you go!

Docker

An Alpine-based Dockerfile is included, that will build, optimise and bundle a production-mode ReactQL web server, your static assets and client-side code -- making it trivial to deploy to production.

Build as normal with:

docker build . -t <project>

Then run with:

docker run -p 4000:4000 <project>

Navigating to http://<docker_host>:4000 will yield the ReactQL project code.

You can also run with Docker Compose:

docker-compose -f docker-compose.dev.yml up

This will build and spawn a development environment on ports 8080 and 8081. Just like your local dev environment, both browser hot code reloading and SSR auto-restarting will work on local code changes -- even inside the Docker stack!

(You can also spawn a production-grade environment with docker-compose up, using the default docker-compose.yml)

Follow @reactql for updates

Get the latest updates by following us on Twitter: https://twitter.com/reactql

Twitter Follow

Complete documentation @ https://reactql.org

New to GraphQL? Need help?

ReactQL

Join the ReactQL slack channel here.

Watch my free 45 minute YouTube video, for a live coding walk-through of putting together a GraphQL server with a database. Learn how to write queries, mutations and handle nested/related data.

Thanks to...

Special thanks to the following providers, for proving free support:

Netlify, for hosting the https://reactql.org site

Netlify

BrowserStack, for providing cross-browser testing

BrowserStack

... and Facebook, Github, the NFL, Google, Apollo/Meteor, and the hundreds of organisations and open-source contributors that have contributed a lifetime of collective coding to make this stack possible.

Sponsor