Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/hjfitz/ports-grade-calc

An attempt to learn Redux
https://github.com/hjfitz/ports-grade-calc

calculator grades jsx over-engineering portsmouth react redux universty webpack

Last synced: 10 days ago
JSON representation

An attempt to learn Redux

Awesome Lists containing this project

README

        

# PWA Boilerplate

[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0) [![David](https://img.shields.io/david/hjfitz/boilerplate-react.svg)]()

An express.js server with additional tooling set up for react.js. Ideal for starting off a personal project, or a hackathon just right

## Setup
Install the dependencies. This is done with `yarn` (recommended), or plain ol' `npm install` (also pretty good).

To streamline the entire setup, a `yarn setup` script is present. It does the following:
- Installs dependencies
- Removes the link to my git repo
- Generates some self-signed SSL certificates for local HTTPS

### React
React is set up under `src/client` with `react-router-4` for client-side routing.

- An example router is setup under `src/client/router.jsx`
- A default layout is setup under `src/client/components/layout.jsx`
- Pages can be found under `src/client/components/pages`
- Webpack is setup to resolve files with the following extensions:
- `.jsx`
- `.js`
- `.css`
- `.json`
- Files with these extensions can be imported as `import { x } from './myFile'` and webpack will worry about the extension.

## Scripts

### Running the server
This is an express server, with the HTTP server exposed (under `bin/www`). You can easily swap this out for a HTTPS server and include your certificates. Running the app is simple:

- `npm start`

#### Heroku

If you're deploying to Heroku - a Procfile is setup for you. Use `heroku local`. The package [`local-env-var`](https://www.npmjs.com/package/local-env-var) is included to load from your `.env`.

### Building
Because we're using React with JSX, the JSX has to be built. A polyfill (set up to ie >= 11) is provided.

- `npm build`

If you want to keep building after a file's saved:

- `npm run watch`

**Note:** This boilerplate includes a service worker, setup to cache the bundle and index file.

To ensure that you can view your changes, in the developer console, go to application, click 'service workers' and select 'bypass for network'.

The code for the worker is under `public/javascripts/worker.js`.