Establishing the enterprise design system

How I built the Roofstock design system to provide a unified experience across 6 apps and to reduce dev time by 30%

Systems design | Accessibility | 6 months

Overview

The lack of a design system drove inconsistencies and wasted design and dev efforts.

Previous designers attempted to implement design systems, but they encountered difficulties in encouraging designers to embrace the library file and convincing engineers to participate in its development. Now with over 10 individual applications created with consistency issues, a design system is needed more than ever to enhance efficiency, prevent more component inconsistencies, and to strategically implement universal patterns.

Problem

Designers are pressured to produce rapid designs but are slowed down by outdated library files and the lack of guidelines.

Engineers are met with similar inefficiency issues as they face inconsistency in implementation and communication challenges with designers.

Solution

Clean up the inherited library file and implement the design system to allow enterprise designers and engineers to work more efficiently and confidently.

Set up all base components and foundations by the end of 2023 with all teams generally adopting the system.

Challenges

2 frameworks, 1 look-and-feel

In October 2022, the company reduced its workforce by 20% and continues to undergo business shifts and team reorganizations. As we transitioned from the consumer marketplace to our enterprise business lines, the need for a well-established design system became even more critical to rebrand our service and product offerings.

Mudblazor and React

With teams using differing frameworks, Mudblazor and Material UI, I worked with separate engineer teams to set up each library referencing the same design system.

Pending company vision and core product

With Roofstock switching focus from their retail marketplace for enterprise customers, the core enterprise product suite is still being shaped. The business is building the connective tissue amongst our product offerings and marketing is developing the brand.

Based on the current company status, I decided to keep the design system’s minimal styling at the moment.

Starting with foundations

We were able to quickly align on grid system and spacing scale by referencing the MUI theme. I defined 4 types of elevations and their differences in usage across cards, popovers, dialogs, and more. Previously, designers had to either source icons from the extensive Material UI library files or depend on plugins. To streamline this process, I centralized the icons into our dedicated file, and established a sizing system for small, medium, and large variants.

Sizing down typography based on feedback

In the old system, designers felt limited in the header sizes so they asked for more. I realized they were only using h5 and h6 because h1 (64px) through h4 were way too big. After scaling down the headers to more appropriate sizes and documenting the guidelines for each one, our page headers and titles became more consistent.

The library file used a different labeling convention for typography than the MUI theme, causing confusion among engineers and slowing down their process.

  • Prioritized relabeling the local styles

  • Eliminated font sizes designers were not using and were not recommended for accessibility concerns (8px and 6px)

  • Defined line heights that align with the 8px grid

Tackling accessibility issues in colors

Color palette was a huge pain point for quite some time as designers were struggling with the one that was defined by a hired agency. A few of the larger issues were:

  • Feedback colors did not meet color contrast requirements set by the Web Content Accessibility Guidelines (WCAG)

  • Accent yellow was too similar to the feedback yellow

  • Light and dark shades lacked contrast from the main

Meeting contrast standards and setting guidelines

  • New colors met or exceeded AA color contrast standards

  • Usage was defined for each shade

While these adjustments provided some stability for the moment, our map visualization tool and the upcoming work to implement data visualization charts in a few of our products quickened the need to reevaluate all colors, particularly to create a robust categorical palette.

Strategically defining the extended palette

  • I drew inspiration from Goldman Sachs' design system and divided the hue spectrum to group ranges into 12 color groups, which then became the foundation of our palette.

  • I omitted turquoise to preserve our slate palette and kept our fintech blue value untouched. Fintech blue and slate are primary and secondary colors, integral to our current products.

  • My topmost priority was to maintain compliance with the WCAG guidelines regarding contrast ratios, with a minimum requirement of 4.5:1 for small text and 3.1 for larger text.

  • Lastly, I utilized multiple online tools to identify the incremental brightness and darkness percentages, but adjusted the hue, saturation, and lightness (HSL) manually to build consistent ratios across colors.

Creating the data visualization palette

First, I identified the ten categorical colors from the new palettes. I then incorporated them into the Viz Palette, a tool developed by Susie Lu and Elijah Meeks, to assess their contrast ratio effectiveness across the entire categorical palette. I then adjusted these hues based on their color reports, which highlighted the presence of numerous thick arcs, indicating that these colors could be challenging to distinguish for individuals with specific color blindness conditions. The final hues displayed thick arcs only between yellow and lime. Consequently, I positioned them at a considerable distance in the palette, reserving their use for extremely rare instances when all 10 categorical colors would be required simultaneously.

Once these were set, I created the following:

  • 5-color combination that will be used in majority of use cases for data visualization charts

  • 5-color combination that will be used in our map visualization product

  • Sequential and diverging palettes

Creating base components

Although we are using frameworks, each component is evaluated with the following questions to build the base components that can be successfully used universally across enterprise products.

  • Does this out of the box component with its default behavior work with our product, user base, and user journeys?

  • Does this provide all the variants we need out of the box?

  • Can we easily make customizations to this component or would it be considered an entirely separate Roofstock component?

When building the components in Figma, I implemented a parent and child component structure in order to reduce the amount of variants, allowing designers to build designs more efficiently.

Customizing and adjusting the libraries

Form fields is an example of where we adjusted the framework component.

  • Kept the input label persistently stacked by enforcing shrink:true. MUI’s input labels move to the top on activate state, but there were overall usability concerns with this design from designers and users as the default state of the field label is often mistaken as a disabled value and the micro-interaction of the input label movement was more distracting than helpful.

  • Changed the color of the required asterisk to red to better emphasize it from the default slate.

  • Added a custom label variation of a trailing info icon. Designers needed the ability to provide additional details in a tooltip but MUI’s input labels only allow any additional content to be added before the required asterisk.

Defining the component variations

Cards are flexible in its implementations so designs varied in headers, CTAs, groupings, and overall structure. To create a base level of standardization, I defined the header and footer variations that were flexible yet consistent.

  • Headers can have CTAs in the form of text buttons if users are not required to complete an action to move forward.

  • If there are more than 3 text buttons needed, the header CTA transitions into an action menu button with a dropdown

  • Footers can have up to 3 CTAs

  • Section content with subheaders and dividers

Optimizing for accessibility

Ensuring that our design system prioritizes accessibility isn't just a commitment to inclusivity but also an awareness of the profound impact our products and services can have on people's lives, considering that 20% of the global population has some form of disability. Designing for accessibility is not an optional or supplementary step in a design checklist; it is an integral and inseparable part of the design process.

While addressing inadequate color contrast is a significant step towards creating a universally accessible product, there remain several areas that require auditing, research, and enhancements.

Error validation for color blind users

The basic text field component includes a helperText prop to provide feedback but it is just a simple caption sized text that changes its font color to red for error messages. I added an icon to ensure visual clarity, consistency with our feedback components, and for color blind users who cannot rely on color alone and screen readers who require appropriate alt text.

Link styling for color blind users

WCAG states that links need to be visually different from non-clickable text. Our system, like many others, had relied solely on color to indicate clickable links. To enhance accessibility for users with color blindness, I have made a simple, yet impactful update for both inline links and banner action links to be ‘underline=”always”’ to provide a visual indicator beyond color.

Distinguishable stepper states

The stepper underwent several iterations, primarily due to initial mistakes where I relied on color alone to differentiate between to-do and active steps, and designing steps that appeared too faint or disabled. Following my latest audit, I have implemented a solid vs outlined styling to differentiate to-do from an active step, and ensured mobile responsiveness.

Meaningful text for screen readers

We follow WCAG guidelines by using clear link text that conveys purpose, avoiding vague "read more" language. In cases where repeated CTAs occur, such as in card lists, I have introduced card variants with linked titles, as our system lacks selectable tile cards. If linked title cards is not suitable, we ensure the inclusion of ‘aria-label’ attributes to provide alt text for screen readers.

Results & progress

We set up 95% of base components and foundations by the end of 2023!

We prioritized the components that are most heavily used. As the remaining have not been used yet, we pivoted to audit each component in its accessibility.

Have the libraries been integrated into each product team?

Yes! Minimum viable integration has been done, but individual components have to be migrated over. My next steps is to work with engineering leadership to create a plan with actionable metrics to grow design system adoption.

Next steps

My primary emphasis is on further enhancing the system's accessibility, beginning with a comprehensive reassessment of focus states for all relevant components to drive a better keyboard navigation experience.

Accessibility

In alignment with the inherent structure of design systems, I have initiated research and pattern definition, starting with the main navigation component. Given the diverse range of navigation types already employed across our products (including navigation bars, side navigation, or a combination of both), it is imperative to gain a comprehensive understanding of these distinct product areas, their interrelationships, and the resulting hierarchical structure as we define this pattern.

Patterns

As we all know, creating is the easy part. Since the designers and I regularly discuss necessary enhancements for the system, the system is structured yet provides the flexibility our team needs.

There is no issue on general adoption by designers, evident when reviewing overall numbers on component insertion the last 60 days.

Design system adoption