SlideShare a Scribd company logo
1 of 99
Download to read offline
Secretsofbuildingrobust
UIcomponents
@glnnrys
GlennReyes
Independent Software Engineer
React, GraphQL, Design Systems & TypeScript
@glnnrys
BuildingUIs
BuildingUIs
isfun
BuildingrobustUIs
ishard
BuildingrobustUIs
ishard
Whatisrobust?
🧐
Stable
Reliable
Functioneffectivelyandreliablyundera
widerangeofconditions
ConsistentUX Performance
WhatmakesrobustUIs
Stepsofbuildingnewuserinterfaces
Tooling Theming Building
Tooling
=
Bettertooling BetterDX
Bettertooling
keepsyourcodebaseclean
Bettertooling
Keepsyourcodebaseclean
withoutthehassle
Findandfixproblemsinthecode
withnoeffort
Preferdeterministiccodestyle
AutoSorting
Deterministiccodemakescode
morereliable,predictableandconsistent
✨ Separate config files per app
✅ Client: eslint-config-banana/react
✅ Server: eslint-config-banana/node
✅ Anything: eslint-config-banana (core)
✨ Enhance linting with type information
✅ More options for improved DX
ESLint
pnpm add eslint-config-banana —-dev
Prettier
@trivago/prettier-plugin-sort-imports prettier-plugin-tailwindcss
Buildcomponentsinisolation
Buildcomponentsin
isolation
with component explorers
Storybook
Styleguidist
Bit
React Cosmos
Wix Component Studio
Runautomatedtests
forUIcomponents
100%UIstatecoverageiskey
Theming
StephenHay
“We’re not designing pages,
we’re designing systems of
components.”
Designtokens
Typography Color Spacing
Designtokens
Typography
Color
Spacing
Designtokens
Download
Color
Spacings
Typography
Componentsfor
Layout&Spacing
BuildingrobustUIs
Loremipsumdolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentiumtempora architectoquibusdam.
Loremipsumdolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentiumtempora architectoquibusdam.
Loremipsumdolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentiumtempora architectoquibusdam.
Loremipsumdolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentiumtempora architectoquibusdam.
BuildingrobustUIs
Loremipsum dolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentium temporaarchitectoquibusdam.
Loremipsum dolorsitametconsecteturadipisicingelit.
Unde,doloremquemodi?Facere,aperiam.Obcaecati
laboriosam,laborumeiusvoluptatumquasieaque
maximeconsequuntur,facilisnumquamsitex,
praesentium temporaarchitectoquibusdam.
gap: 24px
BuildingrobustUIs
Building
Atomicdesign
https://bradfrost.com/blog/post/atomic-web-design
The most basic building blocks
Atoms
Button Input Select
Card
Icon
Divider
Body Text
Heading
Checkbox
A composition of atoms in its smallest fundamental unit
Molecules
Search
Search this site
Groups of molecules joined together
Organisms
Search
Search this site
Home Articles About Contact
Consist mostly of groups of organisms stitched together to form pages
Templates
Search
Search this site
Home Articles About Contact
Speci
fi
c instances of templates with real representative content
Pages
Search
Search this site
Home Articles About Contact
My thoughts on this conference
ComponentDrivenDevelopment
Buildfromthebottomup
Search
Search
Buildfromthe
bottomup
Code
✅ Try keep separate dumb & smart components
✅ Group related code parts together
✅ Build custom hooks if applicable
✅ Reduce the API surface to the bare minimum
Quickwins
ReactComponentProps
<Button primary />
<Button primary secondary />
<Button primary secondary />
<Button appearance="primary" />
Booleantypevs.Uniontype
<PrimaryButton />
<SecondaryButton />
<PrimaryButton />
<Button appearance="primary" />
<Button primary />
vs.
vs.
TypesforHTMLelementattributes
😓 😓
🤨 🤨
🤓 🤓
🤩 🤩
BanclassNameandstylein
UIcomponents
BanclassNameandstylein
UIcomponents
Reuseexisting
typesandinterfaces
Reuseexisting
typesandinterfaces
CompoundComponents
Polymorphiccomponents
Polymorphiccomponents
GenericsinReactUIcomponents
Component Usage
GenericsinReactUIcomponents
Overloadfunctioncomponents
Overloadfunctioncomponents
typevsinterface
inReactcomponentprops
typevsinterface
inReactcomponentprops
Reducedcomputationalwork
byusinginterface
Encourage type annotations.
Especially return types.
helps with faster compilation
https://github.com/microsoft/TypeScript/wiki/Performance
MoreTypeScriptthings
tohelp avoid badtypes
🚩 any → ✅ parse (eg. with zod)
🚩 Type assertions → ✅ Narrow type instead
MoreTypeScriptthings
tohelp avoid badtypes
MoreTypeScriptthings
tohelp avoid badtypes
🚩 Non-null assertions → ✅ Narrow type instead
Takeaways
Propertooling
encouragesrobustcode.
Aresilientdesignsystem
encouragesrobustcode.
Stricttypes
encouragesrobustcode.
Stricttypesencourages
robustUIcomponents.
ThekeytorobustUIis
simplicity.
UIcomponentsshouldbe
reusable.
Take good care
from the ground up.
Saves tons of headache later.
¡Gracias!
Glenn Reyes · @glnnrys ·glennreyes.com
https://speakerdeck.com/glennreyes/secrets-of-building-robust-ui-components

More Related Content

Similar to Glenn Reyes - Secrets of building robust UI components

Dinu Baby CV.pdf
Dinu Baby CV.pdfDinu Baby CV.pdf
Dinu Baby CV.pdf
DinuBaby7
 
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the CloudWSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
WSO2
 
CURRICULUM VITAE
CURRICULUM VITAECURRICULUM VITAE
CURRICULUM VITAE
Vicky Kumar
 
Consistent Development Environment with Vagrant and Chef
Consistent Development Environment with Vagrant and ChefConsistent Development Environment with Vagrant and Chef
Consistent Development Environment with Vagrant and Chef
Gerald Villorente
 

Similar to Glenn Reyes - Secrets of building robust UI components (20)

Build 2019 Recap
Build 2019 RecapBuild 2019 Recap
Build 2019 Recap
 
Dinu Baby CV.pdf
Dinu Baby CV.pdfDinu Baby CV.pdf
Dinu Baby CV.pdf
 
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the CloudWSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
WSO2Con US 2013 - Keynote: Developing Enterprise Apps In the Cloud
 
Sexy React Stack
Sexy React StackSexy React Stack
Sexy React Stack
 
OrangeScape Cool Facts That You Did Not Know!!!
OrangeScape Cool Facts That You Did Not Know!!!OrangeScape Cool Facts That You Did Not Know!!!
OrangeScape Cool Facts That You Did Not Know!!!
 
ATAGTR2017 Protractor Cucumber BDD Approach
ATAGTR2017 Protractor Cucumber BDD ApproachATAGTR2017 Protractor Cucumber BDD Approach
ATAGTR2017 Protractor Cucumber BDD Approach
 
James Turner (Caplin) - Enterprise HTML5 Patterns
James Turner (Caplin) - Enterprise HTML5 PatternsJames Turner (Caplin) - Enterprise HTML5 Patterns
James Turner (Caplin) - Enterprise HTML5 Patterns
 
Gapand 2017 - Diseñando Arquitecturas Serverless en Azure
Gapand 2017 - Diseñando Arquitecturas Serverless en AzureGapand 2017 - Diseñando Arquitecturas Serverless en Azure
Gapand 2017 - Diseñando Arquitecturas Serverless en Azure
 
technetry Broucher.pdf
technetry Broucher.pdftechnetry Broucher.pdf
technetry Broucher.pdf
 
Evolving Mobile Architectures
Evolving Mobile ArchitecturesEvolving Mobile Architectures
Evolving Mobile Architectures
 
CURRICULUM VITAE
CURRICULUM VITAECURRICULUM VITAE
CURRICULUM VITAE
 
Scaling DevSecOps Culture for Enterprise
Scaling DevSecOps Culture for EnterpriseScaling DevSecOps Culture for Enterprise
Scaling DevSecOps Culture for Enterprise
 
CWIN17 Toulouse / Safe 4.5 and agile devops-ca technologies-r.bajul
CWIN17 Toulouse / Safe 4.5 and agile devops-ca technologies-r.bajulCWIN17 Toulouse / Safe 4.5 and agile devops-ca technologies-r.bajul
CWIN17 Toulouse / Safe 4.5 and agile devops-ca technologies-r.bajul
 
Vijay_Teekinavar_Kallesh
Vijay_Teekinavar_KalleshVijay_Teekinavar_Kallesh
Vijay_Teekinavar_Kallesh
 
Consistent Development Environment with Vagrant and Chef
Consistent Development Environment with Vagrant and ChefConsistent Development Environment with Vagrant and Chef
Consistent Development Environment with Vagrant and Chef
 
de:code 2019 DT06 vs-show どっちのVSショー
de:code 2019 DT06 vs-show どっちのVSショーde:code 2019 DT06 vs-show どっちのVSショー
de:code 2019 DT06 vs-show どっちのVSショー
 
Life as a SRE at Instana
Life as a SRE at InstanaLife as a SRE at Instana
Life as a SRE at Instana
 
Mainframe as a Service: Sample a Buffet of IBM z/OS® Platform Excellence
Mainframe as a Service: Sample a Buffet of IBM z/OS® Platform ExcellenceMainframe as a Service: Sample a Buffet of IBM z/OS® Platform Excellence
Mainframe as a Service: Sample a Buffet of IBM z/OS® Platform Excellence
 
Application Experience Analytics Services: The Strategic Digital Transformati...
Application Experience Analytics Services: The Strategic Digital Transformati...Application Experience Analytics Services: The Strategic Digital Transformati...
Application Experience Analytics Services: The Strategic Digital Transformati...
 
Bhavin_Resume
Bhavin_ResumeBhavin_Resume
Bhavin_Resume
 

More from Wey Wey Web

More from Wey Wey Web (20)

Portable, secure, and lightweight: Wasm runtimes and their use-cases - Natali...
Portable, secure, and lightweight: Wasm runtimes and their use-cases - Natali...Portable, secure, and lightweight: Wasm runtimes and their use-cases - Natali...
Portable, secure, and lightweight: Wasm runtimes and their use-cases - Natali...
 
Auditing Design Systems for Accessibility - Anna E. Cook
Auditing Design Systems for Accessibility - Anna E. CookAuditing Design Systems for Accessibility - Anna E. Cook
Auditing Design Systems for Accessibility - Anna E. Cook
 
Adaptive Designs, Beyond Pixel Perfection - Stephanie Walter
Adaptive Designs, Beyond Pixel Perfection - Stephanie WalterAdaptive Designs, Beyond Pixel Perfection - Stephanie Walter
Adaptive Designs, Beyond Pixel Perfection - Stephanie Walter
 
Sharing is caring: what to know before you build a Research Repository - Juli...
Sharing is caring: what to know before you build a Research Repository - Juli...Sharing is caring: what to know before you build a Research Repository - Juli...
Sharing is caring: what to know before you build a Research Repository - Juli...
 
Unlocking collaboration: A framework for developers and designers - Alicia Ca...
Unlocking collaboration: A framework for developers and designers - Alicia Ca...Unlocking collaboration: A framework for developers and designers - Alicia Ca...
Unlocking collaboration: A framework for developers and designers - Alicia Ca...
 
3 reasons to switch to OKLCH - Anton Lovchikov
3 reasons to switch to OKLCH - Anton Lovchikov3 reasons to switch to OKLCH - Anton Lovchikov
3 reasons to switch to OKLCH - Anton Lovchikov
 
ChatGPT and AI for web developers - Maximiliano Firtman
ChatGPT and AI for web developers - Maximiliano FirtmanChatGPT and AI for web developers - Maximiliano Firtman
ChatGPT and AI for web developers - Maximiliano Firtman
 
Declarative Design - Jeremy Keith - Wey Wey Wey 2023
Declarative Design - Jeremy Keith - Wey Wey Wey 2023Declarative Design - Jeremy Keith - Wey Wey Wey 2023
Declarative Design - Jeremy Keith - Wey Wey Wey 2023
 
Form follows emotion - Isabella De Cuppis
Form follows emotion - Isabella De CuppisForm follows emotion - Isabella De Cuppis
Form follows emotion - Isabella De Cuppis
 
UX for emerging tech - Josephine Scholtes
UX for emerging tech - Josephine ScholtesUX for emerging tech - Josephine Scholtes
UX for emerging tech - Josephine Scholtes
 
Collaborative software with State Machines - Laura Kalbag
Collaborative software with State Machines -  Laura KalbagCollaborative software with State Machines -  Laura Kalbag
Collaborative software with State Machines - Laura Kalbag
 
Lessons Learned from building Session Replay - Francesco Novy
Lessons Learned from building Session Replay - Francesco NovyLessons Learned from building Session Replay - Francesco Novy
Lessons Learned from building Session Replay - Francesco Novy
 
Let's get visual. Visual testing in your project - Ramona Schwering
Let's get visual. Visual testing in your project - Ramona SchweringLet's get visual. Visual testing in your project - Ramona Schwering
Let's get visual. Visual testing in your project - Ramona Schwering
 
Solving Common Web Component Problems - Simon MacDonald
Solving Common Web Component Problems - Simon MacDonaldSolving Common Web Component Problems - Simon MacDonald
Solving Common Web Component Problems - Simon MacDonald
 
The Future is Malleable - Aleksandra Sikora
The Future is Malleable - Aleksandra SikoraThe Future is Malleable - Aleksandra Sikora
The Future is Malleable - Aleksandra Sikora
 
Trending tools & methodologies for UX - Josephine Scholtes.pdf
Trending tools & methodologies for UX - Josephine Scholtes.pdfTrending tools & methodologies for UX - Josephine Scholtes.pdf
Trending tools & methodologies for UX - Josephine Scholtes.pdf
 
Decoding Web Accessibility through Testing - Anuradha Kumari
Decoding Web Accessibility through Testing  - Anuradha KumariDecoding Web Accessibility through Testing  - Anuradha Kumari
Decoding Web Accessibility through Testing - Anuradha Kumari
 
Good Security is one question away - Wiktoria Dalach
Good Security is one  question away - Wiktoria DalachGood Security is one  question away - Wiktoria Dalach
Good Security is one question away - Wiktoria Dalach
 
Dynamic CSS Secrets - Lea Verou
Dynamic CSS Secrets - Lea Verou Dynamic CSS Secrets - Lea Verou
Dynamic CSS Secrets - Lea Verou
 
The Misty Report - Douglas Crockford
The Misty Report - Douglas CrockfordThe Misty Report - Douglas Crockford
The Misty Report - Douglas Crockford
 

Recently uploaded

+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
?#DUbAI#??##{{(☎️+971_581248768%)**%*]'#abortion pills for sale in dubai@
 

Recently uploaded (20)

Advantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your BusinessAdvantages of Hiring UIUX Design Service Providers for Your Business
Advantages of Hiring UIUX Design Service Providers for Your Business
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
presentation ICT roal in 21st century education
presentation ICT roal in 21st century educationpresentation ICT roal in 21st century education
presentation ICT roal in 21st century education
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
+971581248768>> SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHA...
 
Tech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfTech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdf
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of Brazil
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 

Glenn Reyes - Secrets of building robust UI components