Convert your CRA 5 project into a node library application without ejecting or losing update support of react-scripts
Please find the detail explanation of how to use it here
Here is the code for how to use this package in production application.
npm install craco-plugin-micro-frontend --save-dev
const microFrontedPlugin = require('craco-plugin-micro-frontend');
module.exports = {
plugins: [
{
plugin: microFrontedPlugin,
options: {
orgName: 'my-org',
fileName: 'my-app.js', // should same as package main
entry: 'src/index.injectable.js', //defaults to src/index.injectable.js,
orgPackagesAsExternal: false, // defaults to false. marks packages that has @my-org prefix as external so they are not included in the bundle
reactPackagesAsExternal: true, // defaults to true. marks react and react-dom as external so they are not included in the bundle
externals: ['react-router', 'react-router-dom'], // defaults to []. marks the specified modules as external so they are not included in the bundle
minimize: true, // defaults to false, sets optimization.minimize value
libraryTarget: 'commonjs2', // defaults to umd
outputPath: 'dist',
customJestConfig: {}, // custom jest configurations
},
},
],
};
package.json
as follows: ...
"scripts": {
"start": "craco start",
"build": "craco build",
"build:lib": "REACT_APP_INJECTABLE=true craco build",
"test": "craco test",
"coverage": "npm run test -- --coverage --watchAll=false --passWithNoTests",
"coverage:browser": "npm run coverage && open coverage/lcov-report/index.html",
"analyze": "REACT_APP_INTERACTIVE_ANALYZE=true npm run build",
npm run build:lib
to generate your microfrontend app bundle. The output will be located under dist
folder and named as my-app.js
craco-plugin-micro-frontend
now supports react-script: "^5.0.0"
with wepback: "^5.64.4"
"plugins": [["@babel/plugin-proposal-decorators", { "legacy": true }]]
craco-plugin-micro-frontend
is open source software licensed as MIT.