/05-pipeline

Sample project "microfrontend composition via build pipeline" of ch. 5.

Primary LanguageJavaScript

Chapter 05

Prerequisites

The following software is required to run the sample:

  • Git
  • Node.js
  • NPM

Running

Clone the repository:

git clone https://github.com/ArtOfMicrofrontends/05-pipeline.git

Go to the repository's directory and run NPM install:

npm install

Now start the application:

npm start

Steps

Follow these steps to implement the same from scratch.

  1. Initialize the repository:
npm init -y
  1. Make it a Lerna monorepo:
npx lerna init
  1. Add an application shell:
npx lerna create @aom/app --yes
  1. Add two microfrontends:
npx lerna create @aom/mife-1 --yes
npx lerna create @aom/mife-2 --yes
  1. Register the dependencies in @aom/app:
npx lerna add @aom/mife-1 --scope @aom/app
npx lerna add @aom/mife-2 --scope @aom/app
npx lerna add express  --scope @aom/app
  1. Add Express to the app:
"use strict";
const express = require("express");
const app = express();
const port = process.env.PORT || 1234;

app.listen(port, () => {
  console.log(`Running at ${port}.`);
});
  1. Add an index route for the app:
app.get("/", (_, res) => {
  res.send("index page.");
});
  1. Add an integration point in each microfrontend, e.g.,
"use strict";

module.exports = mife1;

function mife1(app) {
  app.get("/mf1", (_, res) => {
    res.send("mf1");
  });
}
  1. Integrate the microfrontend in the app:
require('@aom/mife-1')(app);
  1. Add a view engine (e.g., pug). First, install the dependency
npx lerna add pug

then set the engine in the app.

app.set('view engine', 'pug')
  1. Add views such as views/index.pug:
html
  head
    title= title
  body
    h1= message
    p In microfrontend 1.
  1. Call the views from the microfrontends. Keep the path absolute:
const page = require.resolve('../views/index.pug');
res.render(page, { title: "Sample", message: "MF1" });
  1. To add assets we need to configure static file hosting:
app.use("/mf2", express.static(path.join(__dirname, "..", "public")));