React-PWA
A minimal React PWA application as a Github template.
Synopsis
It's a combination of essential (and minimal) libraries/components/utils and their integrations upon CRA, which developers usually need during the process of making React application.
Motivation
We love CRA. And we think it's the right way to build a React application for most of the projects. We have been using CRA in lots of projects, and we are sure that there are lots of routines that developers don't need to care about: like webpack config.
By the same philosophy, there are other routines above the basic configuration, which are almost the same in lots of projects - like router, theme, store, etc. This project is a minimal layer upon CRA which gives you all of that out of the box as a template.
Features
- CRA
- React Router
- Material UI
- Store
- Theme
- Notifications
- Error Handling
- Service Worker
- SEO
- No IE
- Hoster
CRA
It's based on CRA, which is (of course) not ejected. It means you have full access to CRA features.
React Router
The latest version of react-router-dom
is integrated. Routes are defined in /src/routes/. In the minimal version of the template, there are demonstrated 5 routes that render 5 pages. Pages are loaded asynchronously by asyncComponentLoader utility (which is optional).
Material UI
The latest version of Material-UI is integrated. The whole layout of the application is made by Material-UI
components. In the demonstrated components/sections you can notice how MUI components can be customized. The styling system is also inherited from MUI.
Store
For store management overmind has been used. It's a simple store management tool. Here you can find its implementation and integration.
You can use useStore
hook exported from store
. It'll give you state
, actions
and effects
, which you can use.
// ...
import { useStore } from 'store';
function SomeCoolComponent() {
const { state, actions, effects } = useStore();
// ...
}
Theme
The theme system is based on MUI theme. It's integrated with store, so, see how you can use it:
// ...
import { useStore } from 'store';
function SomeCoolComponent() {
const { state, actions } = useStore();
// let's see what is the current theme mode
console.log(state.theme.mode);
// and if you want to change the theme, call appropriate action
function toggleTheme() {
actions.theme.toggle();
}
}
Also you can modify predefined theme parameters in config file.
Notifications
Here we've used notistack. It's integrated with store and to show a notification you just need to call the appropriate action; look how you can do it:
// ...
import { useStore } from 'store';
function SomeCoolComponent() {
const { actions } = useStore();
function showNiceWarning() {
actions.notifications.push({ message: 'Heeeeey, something went wrong I guess' });
}
}
Error Handling
Error Handling is based on react-error-boundary
package. There is also implemented a general fallback for the whole app.
Service Worker
In the production application there will be used service worker and workbox provided by CRA, plus we "listen" to changes, and in case of new build, the user will get a notification about the new version of the application (app is updatable).
SEO
For SEO there is used react-helmet
. The Meta component will help you to update meta tags easily. To see the simple usage of it check this.
No IE
A special script works in the index.html file for checking if the browser of the user is IE or not. And if it is the case, the execution of the application will be stopped and a special message will be shown. You may not think about the compatibility of the app and IE, plus you may not think about how broken your app will be in different versions of IE. So, all users of IE will see this message when they visit your app.
You can see the implementation of this here. It supports multiple languages. You can add your language with its translation here.
Hoster
There is a simple express server /hoster/server
, which plays the role of a static server. The script start-prod
(npm/yarn start-prod
), will build the project and start express server. For more read in Usage section.
Size
After all these integrations the biggest bundle size is ~66KB. It means even first load will be pretty fast (in my case it's 1.1s), further loads (already cached by service worker and workbox) will take ~0.25s.
Usage
You can use this template just by pressing Use this temaplte
.
Or you can fork/clone it.
Install dependencies:
yarn # or npm install
In order to run it in development, run:
yarn start # or npm run start
In order to run it in production, run:
yarn start-prod # or npm run start-prod
The last one will build your project (yarn build
) and start express server (yarn serve
) so as to serve static files.
Structure
Initial files:
index.js
App.js
Layout
Live Demo
Audit
NOTE: The performance is not 100 because of demo server. Check the results in the live demo
TODOs
- Full test coverage