Award-Winning IP Management App
Vizbridge was originally a micro-app specifically for Tropicana to track their trademark registrations around the world, but it's since grown into a patent-pending application that was named a finalist in LegalWeek's 2024 Tech Law Awards.
Figma, Material 3 Color Utilities, OutSystems
Vizbridge is designed using the Material 3 Dynamic Color palette, but with some manual modifications. In addition to the standard scheme, our color system adds tonal swatch sets for Info, Warning, and Success. We also modified the values of neutral swatches to have a complementary tone to the purple: a floral white cream color derived from Yellow.
The benefit of this color system is hat it’s based on tokenized color roles. Instead of naming swatches after the hue groups like red, blue, or green (as in Tailwind), you name them after the role that color should play in the UI. By using it, you can give users the ability to customize their own themes. Unsurprisingly, the Material 3 or “Material You” color system is most popularly used on Android apps and operating systems.
Dynamic color is no mere party trick, though.
It helps us personalize the user experience and make it feel more catered to each individual client. While the original client for this project is Tropicana, we knew we would eventually want to repurpose a commercial version of the app that could be offered to many more clients. The idea is that each client’s UI would be themed according to their primary brand color.
We used GoldenType, a type system derived from applying golden ratio coefficients to a hierarchy similar to that employed in the Human Interface Guidelines. The chosen font family, Inter, leverages its creator’s letter spacing algorithm to keep tracking consistently legible and visually pleasant.
Layout scales responsively in increments of 0.129em, 0.272em, 0.618em, 1em, 1.272em, 1.618em, 2.618em, and 4.235em based on the computed line height of the text element with the largest font size among all direct children.
Within containers, we use margins to create ad hoc spacing between elements.
Margin values come from golden ratio quotients on the computed line height of the text element, not its raw size. But for Large and Extra Large margins, this results in excessively large spacing. Hence, the following values:
Firstly, the space between any. two text elements of different sizes should come from setting a margin property on the larger element.
At scale, a proper application might look like this.
When the whole layout uses relative units, it opens the door to reliable optical corrections on container spacing, giving layouts that oh-so-polished feel.
Firstly, we always organize into containers. Containers are scaled according to the largest font size within the container. Padding, gutters, and border radius within the container follow special rules for optical alignment. See the following infographic.
I used a nuclear model for component organization that organizes them from least to most complex.
Claire is a marketing assistant who needs to quickly double-check if a specific trademark is registered in the United Kingdom, then get back to work as quickly as possible.
Since she’s looking for a specific trademark, we can assume she knows the trademark’s name or ID number. Her first instinct is going to be to look for a search bar. We’ve placed one prominently for her in the toolbar.
Enter a query. The search live-filters the country list below and reveals which countries contain matching records.
Click on the record you want to view.
The trademark record she’s selected opens as a drawer from the right. Search does not auto-clear, in case Claire clicks the wrong one by accident.
Heinrich is a financial strategist who’s been asked to figure out if it’s worth maintaining a brand presence in Australia. He decides to use Vizbridge to help him kickstart his research.
Heinrich uses the interactive map to pan over to Australia.
On hover, a summary card appears that gives a very quick overview of the return on IP spend. This will help Heinrich explore, by allowing him to quickly mouse over countries to get a general idea for abnormalities.
If Heinrich clicks the country, the detail drawer opens with all of that country’s data in it.
Desmond needs to update the trademark data in the app with a more recent version of the source data.
Desmond selects the Data screen from the top app bar.
Desmond goes to the Trademarks tab and drags a new CSV onto the upload area.
Back-end functions validate the structural integrity of the uploaded CSV. It returns an error if it detects column mismatches.
Once the import is complete, updated data will now display on the main screen.
The first iteration of this app looked completely different from what we eventually released. Not only in color palette, but in overall structure.
When a user first logged in, they’d be taken to the trademarks screen.
You can see the trademarks are nested directly underneath the countries in the sidebar. At the time, we felt this combined interface saved the user a few clicks, but hiding them behind accordions wound up sort of defeating the purpose.
Notice that the Owners filter is currently set to All Owners.
Here’s what happens when you filter by a specific owner.
Version 1 of the app left a lot to be desired. Let’s take a look at this screen to dissect some of the problems.
Take a look at the top-left quadrant of the screen. Here, we have 3 different data tables: Owned Trademarks, Contested Matters, and Restrictions. So, why is Restrictions in the Nav Rail?
Although it looks like a rookie mistake, there was a certain logic to it at the time.
You see, we were experimenting with having one nav rail item for each unique data set. So, one for each table. And then we’d use the horizontal tabs to allow users to toggle between different views (Map View, List View, etc).
As you can see, the first version didn’t even have tabs at all.
Unfortunately, one stakeholder insisted upon “pre-set filters.” They felt some filters would be used so commonly that we should have baked-in shortcuts for them, instead of requiring them to manually set the “All Owners” and “All Trademarks” filters themselves. But they felt the filters still needed to stay.
As a result, we wound up with these tab links. Yes, “Trademarks” and “Contested Matters” are not different tables. They’re different pre-set filters.
Needless to say, a lot had to change.
Version 2 improved the app in numerous ways.
Ultimately, we reduced the scope of the MVP to only have a single visualization: Map View. In doing so, we removed a layer of complexity from the navigation problem and came up with this more streamlined solution.
The result offers numerous benefits.
Redesigning the fastest-growing name in private jet travel.
Redesigning the fastest-growing name in private jet travel.
Redesigning the fastest-growing name in private jet travel.
Constructing an art deco masterpiece for a longstanding cultural landmark.
Constructing an art deco masterpiece for a longstanding cultural landmark.
Constructing an art deco masterpiece for a longstanding cultural landmark.
Migrating massive, cinema-scale videos into a dynamic library with rich animations.
Migrating massive, cinema-scale videos into a dynamic library with rich animations.
Migrating massive, cinema-scale videos into a dynamic library with rich animations.
A brutalist reimagining of a brilliant LA mural shop
A brutalist reimagining of a brilliant LA mural shop
A brutalist reimagining of a brilliant LA mural shop
Design Rush's Best Health & Wellness Website of 2024
Design Rush's Best Health & Wellness Website of 2024
Design Rush's Best Health & Wellness Website of 2024
Department of Labor Compliance App
Department of Labor Compliance App
Department of Labor Compliance App
RobinHood for Real Estate
RobinHood for Real Estate
RobinHood for Real Estate
Material Theme Builder plugin for Webflow
Material Theme Builder plugin for Webflow
Material Theme Builder plugin for Webflow
A Rich Text Database with Track Changes & Version Control
A Rich Text Database with Track Changes & Version Control
A Rich Text Database with Track Changes & Version Control
An interactive quote-builder for web developers.
An interactive quote-builder for web developers.
An interactive quote-builder for web developers.
Design theory tutorial describing LiftKit's spacing theory.
Design theory tutorial describing LiftKit's spacing theory.
Design theory tutorial describing LiftKit's spacing theory.
Colors mean things. Here's why.
Colors mean things. Here's why.
Colors mean things. Here's why.
Part Two of my Spacing Series
Part Two of my Spacing Series
Part Two of my Spacing Series
A quick tutorial about how to create a modern personal website using LiftKit.
A quick tutorial about how to create a modern personal website using LiftKit.
A quick tutorial about how to create a modern personal website using LiftKit.
A Design System for Clean, Organized Layouts
A Design System for Clean, Organized Layouts
A Design System for Clean, Organized Layouts
The golden framework makes its way to Figma.
The golden framework makes its way to Figma.
The golden framework makes its way to Figma.
An evergreen cheat sheet for identifying the scope of a project.
An evergreen cheat sheet for identifying the scope of a project.
An evergreen cheat sheet for identifying the scope of a project.
Vizbridge was originally a micro-app specifically for Tropicana to track their trademark registrations around the world, but it's since grown into a patent-pending application that was named a finalist in LegalWeek's 2024 Tech Law Awards.
Figma, Material 3 Color Utilities, OutSystems