SlideShare a Scribd company logo
Building component-driven UIs
at Spotify
John Sundell
Lead iOS developer
@johnsundell
Music streaming service
100+ million users
100+ mobile developers
~100,000 commits on iOS
We ❤We build a lot of UI Experimenting
Optimizing for experimentation
UI should be easyto change
Code needs to be dynamic
Building new UIs should be fast
Want to launch & learn as quick as possible
What’s the problem?
Card Backend
Feature
Card Backend
Feature
CreateView Controller
Setup containerview
Register card
Load data
Handle offline
Backend request
Parse response
Handle errors ortimeouts
Caching
Bind data to cards
Handle highlights & selection
IntegrateView Controllerwith the rest ofthe app
Wait forthe next binary release
Always building UIs from scratch
made us slow and inflexible
Most ofthe time, we write code to render a state
and to handle events from state changes
Playlists
Links
Genres
"
Navigate
Header
Navigate
"
Playlists
"
Playlists
Links
Genres
State
Render
Respond
Navigate
Selection
UI = fn(state)
View Model
Playlists
Links
Genres
State
Albums
Artists
Shared data model
Component
Model
Component
Model
Component
Model
Component
Model
Component
Model
Component
Model
Render
Components
State State State State State
Rendering & event handling
UICollectionView
protocol Component {
var view: UIView? { get }
func loadView()
}
func configureWithModel(model: ComponentModel)
UICollectionView
var preferredViewSize: CGSize { get }
var layoutTraits: [LayoutTrait] { get }
UICollectionViewLayout
EntityCard
[CompactWidth]
CategoryCard
[CompactWidth]
Carousel
[FullWidth, Stackable]
NavigationRow
[FullWidth, Stackable]
SectionHeader
[FullWidth, Divider]
UI = fn(state)
state = json
json = backend
UI = fn(backend)
DEMO
Component-driven UI
Components have built-in reusability
UI as a function of state
State can be loaded from backend
We can now quickly iterate on UI
This is just the beginning ;)
@johnsundell

More Related Content

PPTX
Slideshare ppt
Mandy Suzanne
 
PDF
Backend-driven native UIs
John Sundell
 
PDF
Dynamic, native, backend-driven UIs - App Builders 2016
John Sundell
 
PDF
Swift & JSON
John Sundell
 
PDF
Component-driven UIs - Mobile Era 2016
John Sundell
 
PDF
Writing Swift code with great testability
John Sundell
 
PPTX
Doors & windows
Er Parteek Singla
 
PPTX
Deep dive into swift UI
OsamaGamal26
 
Slideshare ppt
Mandy Suzanne
 
Backend-driven native UIs
John Sundell
 
Dynamic, native, backend-driven UIs - App Builders 2016
John Sundell
 
Swift & JSON
John Sundell
 
Component-driven UIs - Mobile Era 2016
John Sundell
 
Writing Swift code with great testability
John Sundell
 
Doors & windows
Er Parteek Singla
 
Deep dive into swift UI
OsamaGamal26
 

Similar to Building component-driven UIs at Spotify (11)

PPTX
When You Can’t Go All In on SwiftUI, Build a Hybrid UI App Instead!
Vui Nguyen
 
PPTX
Enhancedpptfor_SwiftUI_Presentation.pptx
sreesanthvs77
 
PDF
Flexible UI Components for a Multi-Framework World
Kevin Ball
 
PDF
Flexible UI Components for a Multi-Framework World
FITC
 
PPTX
IOS App Development in 2025: Top Frameworks for Streamlined
Siddhiinfosoft
 
PPTX
Lessons-Learned-SwiftUI.pptx
Mohammad Azam
 
PDF
Consistent, Thin and Dumb. UA Mobile 2016.
UA Mobile
 
PPTX
Server Driven UI in iOS
Mohammad Azam
 
PPTX
Salesforce UI API (TDXGG'18)
Rahul Malhotra
 
PPTX
Introduction to Salesforce UI API
Atul Gupta(8X)
 
PDF
Backend driven UI on mobile apps
Andrea Cipriani
 
When You Can’t Go All In on SwiftUI, Build a Hybrid UI App Instead!
Vui Nguyen
 
Enhancedpptfor_SwiftUI_Presentation.pptx
sreesanthvs77
 
Flexible UI Components for a Multi-Framework World
Kevin Ball
 
Flexible UI Components for a Multi-Framework World
FITC
 
IOS App Development in 2025: Top Frameworks for Streamlined
Siddhiinfosoft
 
Lessons-Learned-SwiftUI.pptx
Mohammad Azam
 
Consistent, Thin and Dumb. UA Mobile 2016.
UA Mobile
 
Server Driven UI in iOS
Mohammad Azam
 
Salesforce UI API (TDXGG'18)
Rahul Malhotra
 
Introduction to Salesforce UI API
Atul Gupta(8X)
 
Backend driven UI on mobile apps
Andrea Cipriani
 

Recently uploaded (20)

PDF
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
PDF
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
PDF
How Open Source Changed My Career by abdelrahman ismail
a0m0rajab1
 
PDF
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
PDF
Oracle AI Vector Search- Getting Started and what's new in 2025- AIOUG Yatra ...
Sandesh Rao
 
PDF
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
PDF
Presentation about Hardware and Software in Computer
snehamodhawadiya
 
PDF
Get More from Fiori Automation - What’s New, What Works, and What’s Next.pdf
Precisely
 
PDF
AI Unleashed - Shaping the Future -Starting Today - AIOUG Yatra 2025 - For Co...
Sandesh Rao
 
PDF
How-Cloud-Computing-Impacts-Businesses-in-2025-and-Beyond.pdf
Artjoker Software Development Company
 
PDF
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
PDF
AI-Cloud-Business-Management-Platforms-The-Key-to-Efficiency-Growth.pdf
Artjoker Software Development Company
 
PDF
BLW VOCATIONAL TRAINING SUMMER INTERNSHIP REPORT
codernjn73
 
PPTX
OA presentation.pptx OA presentation.pptx
pateldhruv002338
 
PDF
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
PDF
Brief History of Internet - Early Days of Internet
sutharharshit158
 
PPTX
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
PDF
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
PDF
SparkLabs Primer on Artificial Intelligence 2025
SparkLabs Group
 
PDF
Economic Impact of Data Centres to the Malaysian Economy
flintglobalapac
 
OFFOFFBOX™ – A New Era for African Film | Startup Presentation
ambaicciwalkerbrian
 
The Evolution of KM Roles (Presented at Knowledge Summit Dublin 2025)
Enterprise Knowledge
 
How Open Source Changed My Career by abdelrahman ismail
a0m0rajab1
 
Event Presentation Google Cloud Next Extended 2025
minhtrietgect
 
Oracle AI Vector Search- Getting Started and what's new in 2025- AIOUG Yatra ...
Sandesh Rao
 
Make GenAI investments go further with the Dell AI Factory
Principled Technologies
 
Presentation about Hardware and Software in Computer
snehamodhawadiya
 
Get More from Fiori Automation - What’s New, What Works, and What’s Next.pdf
Precisely
 
AI Unleashed - Shaping the Future -Starting Today - AIOUG Yatra 2025 - For Co...
Sandesh Rao
 
How-Cloud-Computing-Impacts-Businesses-in-2025-and-Beyond.pdf
Artjoker Software Development Company
 
Responsible AI and AI Ethics - By Sylvester Ebhonu
Sylvester Ebhonu
 
AI-Cloud-Business-Management-Platforms-The-Key-to-Efficiency-Growth.pdf
Artjoker Software Development Company
 
BLW VOCATIONAL TRAINING SUMMER INTERNSHIP REPORT
codernjn73
 
OA presentation.pptx OA presentation.pptx
pateldhruv002338
 
CIFDAQ's Market Wrap : Bears Back in Control?
CIFDAQ
 
Brief History of Internet - Early Days of Internet
sutharharshit158
 
AI and Robotics for Human Well-being.pptx
JAYMIN SUTHAR
 
MASTERDECK GRAPHSUMMIT SYDNEY (Public).pdf
Neo4j
 
SparkLabs Primer on Artificial Intelligence 2025
SparkLabs Group
 
Economic Impact of Data Centres to the Malaysian Economy
flintglobalapac
 

Building component-driven UIs at Spotify