Design Systems
Engineering-centric design standards and systems that focus on reusable components and easy to access documentation with it’s roots based in Atomic methodology.
As the sole designer on both engineering teams, I set the design standards for all platforms.
Core Platform
When I joined the team, the tech stack was showing its age with many inconsistent elements from page to page. My task was to create universal design standards. The software had an internal version for admins and another for agents. Our team decided to first start with the internal one to test it and then roll out the client-facing version. The first iteration was dubbed "Blue."
Blue
The first step was an audit of the admin side. After a few weeks, the spreadsheet of elements and inconsistencies became quite large. Despite the recommendations to get a full accounting before starting, I opted to move forward with 80% coverage to keep the project momentum.
After analyzing the audit results and interviewing the stakeholders and engineers, it was clear that they wanted a complete custom system that needed to be flexible enough to be used with multiple languages, including Ruby, Rails, Mithril, React, JQuery, and several bootstrap-type frameworks.
From these requirements, I mapped out the project's scope, planned the design strategies, and began writing the CSS/SCSS samples for the engineers in CodePen for testing and feedback.
The Framework
Testing on the older Ruby pages revealed a need for more spacing increments.
Knowing we needed to scale the framework to include the "Green" version, the colors were strict standard primary, secondary, text, and alert vars. This planning helped ease the conversion of client custom branding for the Enterprise-level stores and make future updates easier.
More testing on the older Ruby pages revealed a need for more increments. More layout spacing vars were added.
After testing, we scheduled the page conversions and created a page template section in the code library.
Complete documentation lived in Confluence, along with several cheat sheets. These helped reduce the learning curve. Feedback from the engineers was that it was easy to understand, helped speed up build times significantly, and made onboarding easier even for overseas contractors.
Challenges and Outcomes
Ultimately, the system included a full range of elements with variant props, layouts, and many common patterns.
We added React-based page templates to the library for the new features. These additions speed up development time and increased adoption.
We did such a thorough job with Blue that when it came time to release Green we only had to make a few minor updates before rolling it out.
Example of code provided in the CodePen
Confluence documentation for typography
Documentation for colors
Example of a Cheatsheet
DoubleGDP Platform
For this engineering team, they were already using Material UI for their front end when I joined but they were using it in a non-uniform way with lots of one-off customizations and the pages lacked cohesion. After talking to the team and discovering that they already had Storybook installed, I opted to use Figma for the UI design because of their integration with Storybook.
Figma with Storybook
After reviewing the entire app to see how exactly the elements were being used form page to page, I decided that the fastest and easiest way to create cohesion was create a solid color strategy, use only standard Material UI components as much as possible for at least the next 6 months and to make all of the inputs the style.
The Framework
We purchased a Material UI kit for Figma which made things much faster and I began to create the strategy for the colors. The challenge with this was that the software was white labeled for the different cities and the colors used in the UI were 100% controlled by the city admins so the usage had to account for every color combo possible.
In order to minimize the possibility for color clashing and readability issues, I restricted the color usage to a primary and secondary color. Usually the logo colors were used for this. The primary color was solely used for clickable objects like buttons, links menus, etc. This was purposefully done to help train the user to our system so they would see the color and know it was clickable. There were text labels and tool tips for the color blind users. The secondary color was used for decoration like borders, rollovers, etc.
Additionally I worked with the 4 alert colors (success/green, error/red, info/blue, and caution/yellow) and created a muted pallet that would work with most color combinations. These colors were hard coded and not controlled by the admins so they had to work with most color combinations.
Challenges and Outcomes
I created Figma pages for the elements for Storybook and documented the philosophy and usage in the company‘s Gitlab handbook. The initial testing with Storybook went well but after several updates it became problematic and was a time hindrance. Eventually Storybook was abandoned.
The system I put in place did ultimately serve the team even though Storybook did not. We ended up using the documentation I set up in Gitlab with direct links to the Figma pages. We ended up expanding the components to include pages right before the company closed. These pages really went a long way to creating uniformity in the app and sped up the page builds.
Example of Figma page for Storybook — Typography
Example of Figma page for Storybook — Page as React Component
GitLab Documentation
GitLab Documentation
Learnings
Buy-In is Critical
I knew going into these projects that the upper management would need to be on board with the allocation of the resources and understand how long the process can take. But I learned that the engineers need to want it and participate in the format so the adoption will be high. It was only after I got the engineers’s buy-in did either project really gain momentum and ultimately prove it self by making it easier and faster for them.
Functional not Formal
I’m a big fan of “meet people where they are at.” The Atomic methodology made a lot of sense in the class room but when the resources were few and time is applying pressure, I ended up taking a step back from the formality of the system I was taught and literally met the engineers where they were at to create materials that worked for them. This informality worked for these teams.
I do believe that the essence of the Atomic methodology worked for both systems in that these systems documented the small elements, the most likely combinations and made it faster for the engineers create pages and complete tickets. If I were tasked with creating another system I would spend more time upfront talking to the engineers about what they really wanted and how they would use it.