Skip to content

The Pimon Portal from the Microfrontends Meetup in August, 2023. Demonstrates several capabilities of the Piral Feed Service.

License

Notifications You must be signed in to change notification settings

piral-samples/pimon-portal

Repository files navigation

Piral Logo

Pimon Portal

⚡ The Pimon Portal from the Microfrontends Meetup in August, 2023. Demonstrates several capabilities of the Piral Feed Service.

📹 Watch the Video:
You can watch a recording of the meetup where this portal was demonstrated on YouTube. If you do not know what the Pimon Portal is about, we recommend watching the corresponding section (starting ~43:15) of the meetup.

⚠️ Important:
Be aware that the code in this repository is, at the moment, in a "non-production, tuned-for-presentations" state, meaning that there are several locations which are not optimal, to say the least. The focus of this portal lies on demonstrating several features of the Piral Feed Service. No explicit focus was put on developing production-ready code or top-quality backend services.

If you want to help improve the quality of the code and/or add cool new features that improve this demo portal, feel free to open a pull request! ♥️

Getting Started

To clone and initialize the repository, execute the following steps:

# Clone the repository (you can also use HTTPS here).
git clone [email protected]:piral-samples/pimon-portal.git
cd pimon-portal

# Install git submodules.
# The repository includes https://github.com/PokeAPI/sprites as a submodule.
git submodule init
git submodule update

# Install dependencies.
npm i

Next, you need to make the portal/code aware of the feed service that you are using. The code contains several locations with the YOUR_FEED_URL_HERE template. You can use your favorite editor's "Find and Replace All" functionality to replace this placeholder with the URL of your feed service (for example, https://feed.piral.cloud). You should find and replace the following locations:

Replacements

The portal assumes that it is deployed into a feed called pimon-portal. When you create a feed in the feed service, ensure that you name it accordingly. For reference, this is how a reference feed creation screen looks like:

Feed Creation

To publish the portal's assets into the feed service, you must first create an API key. This can be done via the feed service's UI. You can use the following image as reference:

API Key Creation

The created API key can be stored in a .piralrc file. Storing it inside this file makes it accessible to the Piral CLI (and transitively, to all deployment related commands). To do so, create a .piralrc file in the repository's root directory. The file should contain the following content:

{
  "apiKey": "YOUR_API_KEY_HERE"
}

With the API key in place, the portal can now be built and published. To do so, run the following commands, in order:

# To build all packages.
npm run build

# To pack all micro frontends into .tar files which can be uploaded to the feed service.
npm run pack

# To publish the packed files.
npm run publish

If everything went right, your feed should now contain a list of all micro frontends:

All MFs

At last, you need to upload the portal's app shell's static files. This can be easily be done manually via the feed service's UI. Navigate to your feed and click on "Configure Static Page":

Static Page

On the following page, select "Custom", enter an unused version (the default, 1.0.0, is typically fine) and upload all files contained in packages/frontend/portal-shell/dist/release on the following steps.

If everything went well, the portal can now be accessed! 🎉

The only thing you need is the backend services running locally. Run npm run start:be and, once all processes have started, navigate to http://localhost:3000.

Portal Accounts

The portal contains the following user accounts which you can use for logging in:

Username Password Role
admin Admin123 admin
brock Brock123 gym-leader
misty Misty123 gym-leader
ash Ash123 trainer

Local Development

Local development happens without the feed service, but still leverages the proxy service. To make the proxy service use the local dev server instead of the feed service, navigate to the packages/backend/proxy-service/src/index.ts file and change the const useDevServer = false; line to const useDevServer = true;. This will make the service forward asset-related requests to to localhost:1234, i.e., the default port on which a Piral application is started locally. Once changed, simply run npm start to begin your local dev session.

License

Piral and this sample code is released using the MIT license. For more information see the license file.

About

The Pimon Portal from the Microfrontends Meetup in August, 2023. Demonstrates several capabilities of the Piral Feed Service.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published