Shiksha Platform Frontend (Uses Module Federation)
Module
Description
core
Core features like School, Classes, Students
teacher-app
Host Application for teachers
copy module-template to packages/[module-name]
update packages/[module-name]/package.json
{
"name": "[module-name]",
"homepage": "modules/[module-name]",
...
}
Update packages/[module-name]/craco.config.js and assign a port for dev environment.
module.exports = {
devServer: {
port: 3001,
},
...
update packages/[module-name]/moduleFederation.config.js
Add Entries for exposed pages/component
Add entries for the imports
...
module.exports = {
name: "[module-name]",
...
Run All Modules and Host Application
Build Application for Production
Run Module as Standalone Application
lerna run start --scope=[module-name]
Use Module in Host Application
Add remote module url to remotes in packages/[host-app]/moduleFederation.config.js
# e.g. core module is running on localhost:3001 then
remotes: {
core: 'core@[window.appModules.core.url]/remoteEntry.js',
},
Add entry to modules.json
# e.g. core module is running on localhost:3001 then
{
"core":{
"url": "http://localhost:3001"
},
...
}
To use exposed component from remote module in react.
The lazy load component must be enclosed within <React.Suspense>
# e.g. using AppShell component from core module
const AppShell = React.lazy(() => import("core/AppShell"));
...
<React.Suspense fallback="Loading ">
<AppShell/>
</React.Suspense>
https://shiksha-platform.github.io/docs/Developer/Frontend/