Why build a design system instead of fixing existing components?
Consistency
The team needed a single source of truth that all 4 portals could inherit.
Efficiency
Designers spent too long recreating patterns, and devs rebuilt the same components in different ways.
Scalability
Accessibility & Responsiveness
We baked in WCAG 2.2 AA compliance and responsive compoments from day one to serve a diverse user base.
1. Auditing existing designs
I began with a comprehensive inventory of Trellis's interface elements across all four portals—Issuer, Fiduciary, Digital Locker, and the Admin Portal.
Through this audit I:
• Cataloged 34 instances of the same UI element being used differently across different portals.
• Identified 12 different button styles with inconsistent states.
• Mapped 15 different typography styles for headings and body content.
This audit was my evidence to leadership that a design system wasn't just nice-to-have - it was business critical.
2. Understanding team needs
I started by gathering team pain points. Speaking to the engineers, I realized that there is no one source of truth when it comes to referencing design components during development.
I realized while creating designs for different portals, UI elements were being duplicated and changed as needed and developers were unsure which components to reuse.
This also meant wasted efforts designing components every time without consistency in their designs.
3. Not reinventing the wheel.
Rather than starting from scratch, I chose to build our new design system using Material UI as the foundation. It allowing me to leverage proven components while customizing for Trellis's unique needs.
I established:
• A semantic color system derived from brand colors but optimized for digital interfaces and accessibility
• Typography scales based on responsive principles (16px base with modular scaling).
• Spacing tokens using an 8px grid system for consistent rhythm throughout interfaces
4. Component Creation
Following Atomic Design methodology, I built the system layer by layer:
Atoms: Semantic colors, typography scales, spacing values, and icons established our most basic building blocks.
Molecules: Reusable form fields, button sets, and label-input combos tailored for Trellis branding.
Organisms: Larger UI segments like cards, nav bars, and complex tables for each portal’s unique needs.
Documentation: Pattern usage “dos and don’ts,” accessibility notes, and responsive design rules for each component.
For each component, I defined responsive behaviors for mobile, tablet, and desktop breakpoints, ensuring a seamless experience regardless of device.
5. Bridging the design to development gap
I didn't just design components, I made sure they were built to specification and had accompanying documentation for designers and engineers.
I worked with engineers to translate designs into React components in Storybook. We established naming conventions that aligned between both design and code.
The entire design system development process was done in an Agile manner with Jira workflows set up to track current design status, component development and QA.
Impact and Takeaways