UX Flow
Change
Address
Change
Payment
Method
Change
Search
Settings
Enter your Address…
Continue
Home
Edit
Save Continue
Con
f
irm Feedback
ZIP City
Address: Universitätspl. 3,
ZIP: 8010
City: Graz
Back
Changes are saved
address lib
/address/edit /address/con
f
irm /address/feedback
Slide 11
Slide 11 text
Mobile Integration
• Integration via URL
(in-app browser)
• Authenticaton via SSO
• Same look and feel
Do X
Do Y
Change
Address
Main Menu
Enter your Address…
Continue
Edit
ZIP City
Https://change-portal.com/address/edit
…
Slide 12
Slide 12 text
Is this a Micro Frontend?
Slide 13
Slide 13 text
Scaling
…from this
Frontend
Interaction Service
Address Service Payment Service Search Service
Slide 14
Slide 14 text
Scaling
to this…
Frontend
Interaction Service
Address Service Payment Service Search Service
Frontend Frontend
Interaction Service
Interaction Service
Slide 15
Slide 15 text
Micro Frontends
Slide 16
Slide 16 text
The Big Portal
Frontend: SPA (Angular)
to rule them all…
Slide 17
Slide 17 text
Motivations
• Scalability
• Robustness
• Framework agnostic
• Smaller, less complex codebase
• Independent, specialized teams
• Independent
development / tests / deployment
…faster development…
Slide 18
Slide 18 text
Implementation approaches
to evaluate
• Build Time Integration
• URL
• Iframe
• Web Components
• … Server Side Template Composition, JavaScript
Slide 19
Slide 19 text
Challenges
to overcome
• Performance
• Payload Size
• Communication (Fragments <-> Host)
• Versioning
• Test Environment
• Governance complexity
Slide 20
Slide 20 text
Payload Size
Angular
Address
Angular
Payment
Angular
Search
Big Portal
Slide 21
Slide 21 text
Payload Size
Angular
Address
Angular
Payment
Angular
Search
Big Portal Address
Angular
Payment
Search
Module Federation by Webpack 5
Slide 22
Slide 22 text
Versioning
Address Payment Search
The Big Portal
@latest @latest @latest
Slide 23
Slide 23 text
Versioning
Design System
Address Payment Search
The Big Portal
@latest
@latest @latest @latest
@latest @latest @latest
Slide 24
Slide 24 text
Versioning
Design System
Address Payment Search
The Big Portal
@2.0.0
@latest @latest @latest
@1.8.2 @1.8.2 @1.8.2
Slide 25
Slide 25 text
@angular/elements
Slide 26
Slide 26 text
What’s this?
Angular
Component
@angular/
elements
Web Component
bundle.js
…
…
MainApp
Selector: ‘angular-component’
Slide 27
Slide 27 text
De
f
ine Custom Element
npm install @angular/elements --save
Slide 28
Slide 28 text
Example Repo
angular-web-component-example
https://github.com/marcellkiss/angular-web-component-example
Try it on Vercel!
Slide 29
Slide 29 text
Npm run start
MainApp
WcApp
http://localhost:4200
http://localhost:4210/main.js
selector: ‘wc-app’