Motivation
The company faced challenges with inconsistent UI elements across its products, which negatively affected efficiency and user experience. Hard-coded colors and typography resulted in longer development cycles and maintenance issues, while designers struggled with unclear specifications.
As a provider of white-label products, the company needed a streamlined approach to customize colors and typography for client branding. So far, Customer Success teams used random colors for client integrations, undermining brand consistency and accessibility.
To address these issues, the design system should:
Be easy to use by the Customer Success team who handle client integrations
Stand out to attract prospective clients
Stylistically match Angular Material library used by the development team
Design elements to include
Colors
Typography
Icons
Components
Layout grids and break points
Interactive states
Widget specifications
With a goal of
Minimizing variants to accelerate development cycles and client integrations
Bringing consistency across all products
Adhering to web accessibility standards, ensuring inclusive user experiences
Process - Colors
I created color systems for dark and light themes with an equal number of corresponding color variants, allowing developers to translate designs between themes easily. Further, I categorized colors into primary and derived. The derivation process involves darkening or lightening the default color based on the Lightness scale of HSL.
This approach simplifies integration for the Customer Success team:
For neutral colors, they only need to input the background color to generate all other colors.
For data visualization, they provide just three colors (weak, neutral, strong) to create a full spectrum.
It also ensures that products adhere to accessibility standards.
Typography
I optimized the typography system by reducing the number of text styles from 15 to 9, enhancing consistency and usability.
By working closely with the Customer Success and development teams, I established a process where:
Customer Success team only needs to specify a font and a base font size during client integration
All typography is automatically adjusted based on these inputs
Components
To promote component modularity and reusability, I:
Applied atomic design principles, organizing components hierarchically
Leveraged the company's use of Angular Material theme, utilizing its accessible and well-tested components
Created a comprehensive style guide with visual examples and responsive design rules
Next steps
Documentation
Publish the design system on Storybook or similar platform for better visibility, understanding, and adoption
Measurement and Adoption
Track adoption rates by the development teams
Assess stakeholders’ understanding and correct usage of the system
Identify gaps in accessibility
Refinement
Expand the component library to cover all use cases
Implement recurring updates based on Angular Material releases
Refine the system based on usage metrics and user feedback
(1) Design systems 101: What is a design system? Source: https://www.figma.com/blog/design-systems-101-what-is-a-design-system/.