Skip to content

Latest commit

 

History

History
105 lines (70 loc) · 4.7 KB

README.md

File metadata and controls

105 lines (70 loc) · 4.7 KB

This webpack (V5.36.2) boilerplate supports the following:

  • SCSS preprocessor
  • To enable CSS modules (each component has it's own styles "no conflict between different components styles") => just open (webpack.common.js) and uncomment modules section in css-loader. Then open (webpack.prod.js) and comment out PurgeCSSPlugin in the plugins section. Then in every component add the required import as follow: import classes from './scss/requiredStyles'
  • Autoprefixer for CSS (it supports IE >= 11)
  • Hot reloading for JS & CSS and redux store (in development)
  • Prettier (for code format)
  • Docker setup for development

It has the following configuration for React:

  • React router dom
  • Redux & Redux thunk & & Redux logger & Redux devTool
  • Prop types
  • 2 environments {production: .env, development: .env.development}

Prerequisites:

  • nodeJS > 14.X.X or Docker

Installing / Getting Started:

Development (locally):

  • Clone repo => git clone repo-url
  • cd frontend
  • Install dependencies => yarn install
  • Start the development server => yarn start

Development (using Docker):

  • Clone repo => git clone repo-url
  • cd frontend
  • Install dependencies (required for prettier) => yarn install
  • Start the development server => docker-compose up --build

Update environment variables:

Please keep in mind that environment variables configured using webpack which means that you need to re-run the corresponding environment script (yarn start, yarn run build) if you update the environment file.

Configuring Prettier

This build relies on Prettier formatter to enforce a code style. You can find steps on how to setup prettier formatter with WebStorm/PhpStorm here. Please refer to other tutorials if you are using a different IDE.

Notes:

  • It's better to use the local node_modules version of prettier instead of a global one. This is to avoid version conflicts (in case the globally installed version does not match with the versions specified in package.json). So when setting up the file watcher when you follow the steps from the above link you can set program to $ProjectFileDir$\node_modules\.bin\prettier (warning this assumes that node_modules sits in the root of your project. This will need to change if your directory structure changes).
  • You will have to create two file watchers. One for JSX files and one for JS files. The webpack build tools are already configured to work with eslint and prettier. The only thing needed is the two file watchers.

Site meta tags:

  • This app includes facebook, twitter and regular meta tags

To update them:

  • Open constants.js file and update metaInfo object
  • Open src/assets/images and replace (favicon.png, metaImage.jpg) with your images but using the same name

Extra:

  • Private route guard => protect the given route based on a token.
  • Restricted route guard => protect the given route based on a token, and a list of permissions (can be an array or a string).
  • Restricted section => protect the given section based on a list of permissions (can be an array or a string).
  • Generic error boundary fallback component (you can customize it)
  • Cookies, local storage and sessions storage mangers to store data in the browser. (Note: the data encrypted using crypto-js package before storing it.)
  • Font awesome
  • Layout using bootstrap grid system (scss/generic/_grid.scss)
  • Basic mixins (scss/generic/_mixins.scss)
  • Normalize styles (scss/generic/_normalize.scss)
  • App typography styles (scss/generic/_typography.scss)
  • 4 break points (scss/generic/_variables.scss)

Available Scripts

In the project directory, you can run:

yarn start

Runs the app in the development mode.
It will open http://localhost:3000 automatically in the browser to see your app.

All changes will be injected automatically without reloading the page.

You will see in the console the following:

  • All redux store related changes
  • Any of the following errors:
    1. Linting errors.
    2. Code format errors (because of prettier)

yarn build

Builds the app for production to the dist folder.
It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes.
Your app is ready to be deployed!

yarn build:serve

Serves the app on http://localhost:8080/ from the dist folder to check the production version.

Note: Use this script only if you ran the build script yarn build.

yarn analyze-bundle

It allows you to analyze the bundle size.