Build process
This operation consist of transforming and combining all the application resources to make them usable in web browsers. This process is taken care of by Webpack, and can be launched with npm run dev
during development, and npm run build
for production.
"@types/react-router-dom": "^5.3.3",
"@typescript-eslint/eslint-plugin": "^8.18.0",
"@vitejs/plugin-react": "^4.2.1",
"@vitest/coverage-v8": "^2.1.2",
"autoprefixer": "^10.4.20",
"bootstrap-sass": "3.4.1",
"depcheck": "^1.4.7",
"enzyme": "3.11.0",
"enzyme-adapter-react-16": "^1.14.0",
"eslint": "^9.15.0",
"eslint-plugin-react": "^7.37.2",
"eslint-plugin-react-hooks": "^5.1.0",
"eslint-plugin-react-refresh": "^0.4.16",
"font-awesome": "4.7.0",
"globals": "^15.12.0",
"husky": "^9.1.7",
"jsdom": "^25.0.0",
"lint-staged": "^15.2.10",
"postcss": "^8.4.49",
Mainly, it will take all the JavaScript
files and combine them in a giant bundle file. Thanks to the babel
plugin for Webpack, we can make use in our code of some JavaScript
features which are not widely supported: babel
will transform the code you write to make it work in all major browsers.
Webpack will also process the main css
file to make it load faster and work consistently across browsers.
import { useOidc } from '../../../utils/oidc';
Webpack is configured via the webpack.config.js file. Refer to this file to see all the operations this configuration handle.
Webpack will transform the JavaScript
code you write, but in order to make debugging easier, it will provide source maps
to enable browsers to show the original files within the developer tools.
During development, npm run dev
will act as a background task:
- providing a simple HTTP server to serve the application assets on port
3000
; - watching for file modifications and recompiling the application accordingly;
- automatically reloading the page in the browser to take the modifications into account.
The
npm run dev
script is configured to work with a "in memory" version of the bundle file (--content-base
command line option forwebpack-dev-server
), hence theJavaScript
file served to the browsers might not be visible in thedist
folder on your hard drive.
The Webpack configuration for production is slightly different from the one used for development: it does not need the configuration related to the development web server. It should also provide other adjustments to make the code more production ready. When building code for production, Webpack will automatically minify the JavaScript
thanks to the command line option -p
.
You will find some stats about WebPack in the stats page (Attention: you need to open the page in a new tab, in order to make the redirection working)
Other NPM Script
The project also provide other NPM scripts, in order to manage its lifecycle.
- test:watch : Execute unit tests with watch mode
- dev : Launch the application with the remote API
- dev:local : Launch the application with the locale API
- dev:server : Launch scripts
npm run dev:local
andnpm run server
- server : Launch the fake NodeJS server
- build : Generate the production version of the application with the configuratio for the prod environment
- build:dev : Generate the production version of the application with the configuratio for the dev environment
- build:dv : Generate the production version of the application with the configuratio for the dv environment
- build:preprod : Generate the production version of the application with the configuratio for the preprod environment
- build:qa : Generate the production version of the application with the configuratio for the qa environment
- build:qf : Generate the production version of the application with the configuratio for the qf environment
- lint : Check the quality of the project
- lint:fix : Check the quality of the project and apply fixes automatically
- start : Launch the command
npm run dev
- e2e : Launch Integration Tests
- e2e:travis : Launch Integration Tests with the configuration for Travis
Add a new environment
If you want to add a new environment (for example qlf2), you just need to :
- Create a configuration file
config.qlf2.js
in thebuild-config/environments
folder. - Copy/Paste the configuration of another environment, and and do the adjustments
- Add a
build:qlf2
NPM script.