ABOUT
Amazon Category Explorer is an interactive visualization tool built by Tom Reitz as the final project for CS765 Visualization at UW-Madison's Computer Science department in the Fall of 2020. The project was to create a visualization for Amazon's product category tree of over 27,000 categories.
STORY
The VP of Marketing at Amazon.com directs a large team of Analysts, Marketers, and Category/Product Managers who together keep the millions of items for sale on Amazon.com organized so shoppers can find what they need. She has commissioned a visualization tool to help this team navigate, understand, and manage the Amazon product category tree.
TASKS
Specific requirements for the vis tool include:
- Ability to view and navigate the category tree, both at a high-level (presenting some overall structure of the tree) and in detail (specific categories deep inside the tree).
- Ability to find all (sub)categories that match a search phrase.
- Helps Amazon associates to find the best category(ies) for a product.
- Facilitates understanding “relationships” between categories, e.g. sets of categories that share many products.
- Facilitates finding categories that share many products (candidates for merging).
- The tool must work well on both mobile and desktop devices.
DETAILS
ACE was implemented as an interactive web application using HTML, CSS, and Javascript. The radially-tidy tree is built with D3.js (which renders the tree in an SVG element). Interactions (hovering/clicking on nodes) are implemented with Javascript, specifically using the jQuery library.
Raw CSV data about Amazon product categories (given with the project specification) was preprocessed into a JSON structure via a Python script. The JSON data is then included into the web application directly. Subtrees are extracted from the JSON via various (mostly recursive) Javascript functions which process the tree data according to the parameters chosen by the app user.
CSS is used for layout and style of the app. The primary colors, orange and dark gray, were chosen to match the colors of Amazon.com’s branding. Links are blue, a familiar encoding in web browsers, indicating what’s clickable. Hovering over a node turns its text blue, which helps it stand out among many categories. Node color simply indicates whether a category has subcategories (orange) or not (gray).
Longer category names are truncated (indicated by ellipsis: “Security & Surv…”) to prevent the tree from becoming cluttered with long text, but the full category name (“Security & Surveillance”) can be seen in the Details section by hovering over it.
The size (radius) of each node encodes how many products are in its subtree, which makes approximate comparisons (“this category is about twice as big as that one”) fairly easy. Area is difficult for humans to judge, so this is not useful for precise comparisons. But the user can hover over two different categories and see the number of products in their subtrees (in the Details section) to compare exact quantities.
Some effort went into making the design mobile-friendly. On narrower screens, not only the major sections of the layout stack vertically, but other minor details improve usability. The app name is permanently abbreviated to “ace”, which leaves more space in the header. The breadcrumb path in the header is horizontally scrollable in order to make deep paths in the tree usable. The legend is moved from the upper-left corner (where it can obscure a portion of the tree on a narrow screen) to a separate section below, and can be closed/hidden entirely. The node font size is increased slightly on mobile devices. The "hover for details, click to jump in" behavior, which does not work on touch devices, is replaced by "click once for details, click again to jump in."
Built with jQuery and D3 Radial Tidy Tree