Ivan Vynnyk
Vladyslav Bezruchko, Volodymyr Fedak
Intention: show how micro frontends can be organized via monorepo yarn workspaces.
In the example following cases was covered:
- How to organize micro frontends via yarn workspaces
- Single spa as a wrapper for micro frontends which were written using different frameworks( React/ VueJS)
- Shared components organized in framework agnostic way using web components
- i18n was organized in framework agnostic way using i18next tool
- Demo application is a PWA application which supports offline mode for users service.
- Backend REST API is implemented via Nestjs. Users are stored in memory.
The key point here is that over the time WEB-UI teams should have resilient and framework agnostic Web-UI app. In our terms framework agnostic means having possibility to extend web app with a necessary framework. On the provided sample SingleSPA has been used as a shell (wrapper) for micro frontends based on Angular/React/Vue. Each micro frontend is a stand-alone SPA that knows how to bootstrap, mount, and unmount itself from the DOM using Single SPA tooling. That is the only thing which couples your micro frontend to a wrapper (Single SPA ).
Another feature of the provided sample is to have easy ability to write reusable shared UI components using any JS library/framework. It might be achieved by wrapping them with webcomponents (a suite of different technologies allowing you to create reusable custom elements — with their functionality encapsulated away from the rest of code via browser API). https://developer.mozilla.org/en-US/docs/Web/Web_Components
For i18next is used which supports all popular frameworks.
Please see diagram which represents described above solution:
It's possible to run as many applications locally as you want.
If You don't have Yarn - intall it
npm install --global yarn
- Clone the monorepo
$ git clone https://github.com/SoftServeInc/mfs-accelerator.git
- Install dependencies
$ yarn install
- Start the services ( micro frontends and backend API)
$ yarn run start-services
- Start host application
$ yarn run start-host-app
- Open your browser and go to http://localhost:9000
There are some rules when making changes to code-base of micro-frontend.
- Each of them has
<orgName-name>.ts
file in thesrc
directory(src/mfs-dashboard.tsx
) from the example above. This is the entry file, it's responsibility is to create single-spa application and export it's lifecycle methodsbootstrap, mount, unmount
. This contract is strict and shouldn't be changed root.component.tsx
from the example above is simple React component. Can be of any framework.- Webpack config is heavily extending
webpack-config-single-spa
for the base stuff. Important field there isexternals
- common libraries that we are using across applications and we do not want to bundle because it will result in multiple copies of e.g React in our app
There is PWA functionality provided by service-worker and manifest files. They can be found inside of the host-app.
In case with micro-frontends we need to deploy quite a few things.
The typical case is updating some feature inside of one micro-frontend. These things need to be deployed
- Micro-frontend
.js
file itself - New import-map file, as deploying our
.js
bundle will change the link for latest version
It's still in development but the end concept can be seen.
Env variables. Those are the default ones used in local .env
file in the host application. There is for sure more to come but these are for now.
IMPORT_MAP_URL=/import-map.json
API_SERVICE_URL=http://localhost:3000
In import-map.json you can find all dependencies to running micro fronends
- Developer pushes code to specific branches
- CI runs testing and linting process as well as builds the application
- CI copies ready-to-use bundles to S3 bucket
- CI calls import-map-deployer-service REST API to update import-map located on S3. This service needs to be used to avoid race-condition in case of each repos' ci updates import-map at the same time
- New import-map is then available in deployed host-app and it doesn't need to know about changes