Data visualizations
This section is currently being reworked to provide better guidance aligned with Polaris v12. Stay tuned!
This section outlines data visualization practices at Shopify and how to leverage them.
Data visualizations at Shopify
The data visualization process always begins with a set of data, a question, and analysis of the data to find the answer. Each visualization should focus on answering a single question about the dataset. For example, “What are my sales over time?”
By maintaining consistent styles and formats for our data visualizations, we ensure that data is presented in a truthful and accurate manner to maintain integrity with merchants.
Guidelines
Data visualization should be approached by:
Solving a problem
Have a clear question that needs to be answered. If multiple answers to multiple questions are illustrated in a visualization, it will become over complicated and hard to understand.
Testing with real data
Testing with real data will reveal the effectiveness of the visualization. Also test when there are a few data points (one or two) or many data points (100 or more).
Scaling by number of datapoints
Think about how the visualization will scale with more or fewer data points. Look out for cases where data is sparse (mostly zero) or spiky (some values are much larger than others).
Five core traits
An effective data visualization strikes the right balance between the five core traits: accuracy, intuitiveness, engagement, focus, and data granularity. It’s important to be intentional about which of these you focus on, and which are less important, in order to answer your specific question in the best way for your target audience. Understanding these traits help you choose between the many ways to visualize data by giving you a language for evaluating a visualization's effectiveness.
Accuracy
Accuracy is about how faithfully the visualization matches the original data set. How much accuracy is needed to send your message across? A high level of accuracy may not always be needed to convey a trend or a pattern.
Intuitiveness
Intuitiveness is about the ease of interpreting the visualization. Will merchants immediately understand what’s being represented, or will they need instructions? More intuitive is usually better, but sometimes it comes at the cost of flexibility.
Engagement
Engagement is about how much attention the visualization attracts at a glance. Is it the star of the show, or does it sit in the background? More engagement is not always better—sometimes the best visualization is one that plays a supporting role.
Focus
Focus is about how merchants’ attention is directed. Is one pattern or trend surfaced more prominently than others, or are there several trends that are given equal weight? Highly focused visualizations decrease cognitive overload, but restrict the breadth of the message you are able to convey.
Data Granularity
Data granularity is about the level of detail of the data set presented in the visualization. More granular means more data points, and possibly more cognitive processing, but less granular is less detailed. The right level of data granularity depends entirely on the specific question you’re trying to answer and the audience you’re communicating to.
Axis and labelling conventions
All standard charts that show quantitative data have 2 axes that should be labeled for clarity.
- Labelling should be outside and separate from the data area. This ensures the user understands the range of the data without taking focus away from the data.
- Ensure that all labels are clear and accurate in what they represent. Use simple and short language.
Granular guidelines
Axis lines
Axis lines should be used as a guideline to show quantitative data, yet be unobtrusive.
data:image/s3,"s3://crabby-images/b6b22/b6b22197fdb5d3b7a3bebbf1d3617392516af8b3" alt="A light grey chart with axis lines"
Ensure axis lines only appear where the data appears.
data:image/s3,"s3://crabby-images/cf79d/cf79db0bed2dd618081d993812036356d9a04573" alt="A chart with axis lines filling the screen"
Use bleeding axis lines to the edge of the screen.
Skipping labels
Labelling the tick marks on both the y-axis and x-axis helps the visualization become more clear in what it represents.
data:image/s3,"s3://crabby-images/36ee8/36ee8d25c3f36e30c377e7ec99b1b18e90e09b70" alt="A bar chart plotting time using 12am, 8am, 12pm, and 8pm"
Skip labels in regular intervals.
data:image/s3,"s3://crabby-images/d7926/d79264c4e66ff593ef1106845d5368716f47dce6" alt="A chart plotting time with too many axis labels"
Try to squeeze all labels together.
X-axis Abbreviations
Shopify uses standard abbreviations for months and weekdays in order to reduce clutter in visualizations.
- Use 12 hour format for time, with lowercase letters (12am, 6pm)
- Use the first three letters for days of the week (Sun, Mon)
- Use the first three letters for months (Feb, Mar)
- For specific days, use the format ‘day + month’ (10 Apr, 11 Apr)
- For specific months, use the format month + year (Apr 2011, May 2017)
data:image/s3,"s3://crabby-images/e9db5/e9db5a1ff7ca1d20b9b0c89a228ecfcb9e9e53f3" alt="A chart showing the days of the week abbreviated to Mon, Tues, and so on"
Use standard abbreviations for labeling.
data:image/s3,"s3://crabby-images/9f94f/9f94fe700d67a4dc346d70246191233b4235bbcb" alt="A chart with labels slanted at a 45 degree angle"
Slant labels to make them fit.
Y-Axis Abbreviations
Shopify uses standard monetary abbreviations for the y-axis to reduce clutter.
data:image/s3,"s3://crabby-images/79b38/79b383d4251eed0d02a7e471ce454db6360b4158" alt="A chart with a y-axis representing a thousand dollars as “$1.0k”"
Abbreviate using ‘k’ for thousand, ‘b’ for billion.
data:image/s3,"s3://crabby-images/c55d4/c55d449dcc3cbc41e44a49390d7cb02fc81ae23f" alt="A chart with a y-axis that represents the value of a thousand and one dollars as “$1.001k”"
Go over 3 numeric characters, 1 decimal, or 1 letter.
X-axis Labelling conventions
Labels should be clear and concise.
data:image/s3,"s3://crabby-images/10753/107531e6e03871201203606ddae793f60507deeb" alt="A bar chart with the abbreviated days of the week centered on the ticks which are centered on the bars that they represent"
Center all labels on the bar and the tick mark.
data:image/s3,"s3://crabby-images/d41dc/d41dc58ed3ba858b86af23fcd8fb5a2d5e8f294f" alt="A bar chart plotting numbers with decimals on the x-axis"
Use decimals on the x-axis labels.
Y-axis Labelling conventions
Labels should be clear and concise.
data:image/s3,"s3://crabby-images/92fa6/92fa6a7f21809e14f86c301dca72e5417a77c283" alt="A chart with a dollar value on the y-axis that’s aligned to the left and raised slightly from the grey axis"
Left align labels and keep them above y-axis lines.
Color palettes
Color in data visualization has a very specific meaning. The data visualization color palette provides specific colors that can be used alone or in a group, depending on the intent.
Single data series
Use when there is a single data series. For example, a bar chart, column chart, or a single line chart.
data:image/s3,"s3://crabby-images/0a434/0a434a2a0f21b5b09dd7d45aff82b06e4f3fad68" alt="A line graph with y-axis and x-axis labels and a single purple line plotting data"
data:image/s3,"s3://crabby-images/70a48/70a482b266ed0870588adeb5cbabdbc25a93da08" alt="A line chart with 2 different colors comparing current values to a past value"
Single comparison to past
This is used when the data set is being compared to to its past values. For example, total sales by month, this year, compared to last year. In this case, the current value will be purple and the past value will be grey.
Multiseries data
Used when there are multiple data sets to compare. For example, a multiseries line chart. Go down the list as the number of datasets increase.
data:image/s3,"s3://crabby-images/59286/59286a8ee655edf0646039b931320e07653e1712" alt="A line chart with multiple data points represented by different colors"
data:image/s3,"s3://crabby-images/a03c0/a03c0d89821ca9a75cab24ad33d836dcad07785a" alt="One example of an upward trend in percentage sales represented in gren and another example of a downward trend in"
Biased
Used when certain data need is displayed in a negative or positive light. For example, showing positive or negative change relative to a reference value.
Horizontal bar charts
Bar charts are used for comparing discrete categories. Use a bar chart when there is a constraint to the number of data points that can appear on the visualization, otherwise it becomes hard to scale.
Best used for
Showing discrete categories of data, like {products} vs {sales}.
Don’t use
When the number of data points can exceed 6. In this case, use a table.
Bar chart labels
Label each bar with what it’s displaying, as well as the value. For more best practices, visit axis and label conventions.
data:image/s3,"s3://crabby-images/95de0/95de01e92b3c48ad5695a60d2edbcc35766c27ab" alt="A horizontal bar chart displaying the country represented by each bar"
Include a label on each bar. If the bar is too small, include it outside of the bar.
Include a label on top of each bar to display what data it’s showing.
Color
Use one color for all bars.
data:image/s3,"s3://crabby-images/bc058/bc058c2df7ecaa55453e91fa69faa9944f5ff2ff" alt="A horizontal bar chart with solid purple positive bars and purple negative bars set to 60% opacity"
Give negative bars 60% opacity.
data:image/s3,"s3://crabby-images/9f0cc/9f0cc56191fdbff641d2105cddfe27a42d3d68d4" alt="A horizontal bar chart using a different color for each bar"
Use multiple colors for the bars.
Bar positioning
Make sure the bars are proportional in width, roughly twice the size of the space between the bars.
Make the width of each bar about twice as wide as the space between them.
Make the bars too skinny.
Vertical column charts
Column charts are used to show change over time, trends, and individual data points. Use column charts for when the number of data points is fewer than 30, or else use a line chart.
Best used for
- Showing continuous data like sales per hour, or orders per month
- Showing smaller granularities of time (hourly, daily, weekly, and monthly)
Don’t use
When the number of data points can exceed 31. In this case, use a line chart.
Color
All bars should be the same color.
data:image/s3,"s3://crabby-images/e8ae3/e8ae324f47bd5b7c99f753f8a02280baaa78e11f" alt="A bar chart showing a data trend with the same bar color"
Use one color for all bars.
data:image/s3,"s3://crabby-images/dc780/dc780be6f6687ee310dc32a623e89073701d8bd8" alt="A bar chart showing the same data point with different colors"
Use multiple colors for the bars.
Bar positioning
Make sure the bars are proportional in width, roughly twice the size of the space between the bars.
data:image/s3,"s3://crabby-images/0da95/0da9590d31458c8639fa9cb6ba139fa7efa927eb" alt="A bar chart properly formatted with spaces half the size of each bar"
Make the width of each bar about twice as wide as the space between them.
data:image/s3,"s3://crabby-images/e5d77/e5d778f308578fcc784cf8bd3355c3b8e83ad8d7" alt="A bar chart with spaces 4 times larger than the bar itself"
Make the bars too skinny.
Interactivity
Include some interactivity on the bars upon hover since users will be looking at individual data points. The top line of the tooltip should follow x-axis abbreviation and labelling guidelines, while the bottom line tooltip should follow y-axis abbreviation and labelling guidelines.
data:image/s3,"s3://crabby-images/38a52/38a52f4ec42c6ae74f474014dc79f524d2d37bd5" alt="A bar chart with a tool tip on a bar displaying the date axis point and the dollar value axis point"
Include tooltips for x-axis and y-axis values.
Line charts
A line chart is created by connecting a series of data points together with a line. Line charts are good to show change over time, comparisons, and trends. Use line charts when the number of data points is more than 30.
Best used for
- Showing continuous data like sales or orders over time
- Showing larger granularities of time (yearly, or quarterly)
- Spotting overall trends and shapes of data
Axis and labelling
Set up the chart area using the axis and labelling guidelines
Multiline charts
Line graphs work well when multiple datasets need to be compared. Use the color palette to select colors.
data:image/s3,"s3://crabby-images/b938b/b938b32b1e0b02a226ff0cf04620876b1dba467f" alt="A line chart with 2 lines using purple and teal to represent the years 2015 and 2016"
Use contrasting color and include a legend.
data:image/s3,"s3://crabby-images/e2255/e2255ab32006e0fbe3583ce9da1152e720ee6a5e" alt="A line chart with 4 lines of different colors"
Use more than 4 lines.
Display metrics
A display metric is a quantifiable measure that is used to track and display the status of a specific process. Examples include a sum, an average, or a movement in a positive or negative direction.
Best used for
Showing a single value with a base unit.
Units
Metrics should be paired with their base unit in close proximity to the number. Use concise and clear language for metrics.
Scope
Metrics should be scoped to indicate the timeline of the data.
data:image/s3,"s3://crabby-images/24261/24261e1f081c49140ba1808a11e6c8f292da3b8f" alt="Diagram showing “sales this week” with a numeric dollar value"
Include a dimension of time to scope the value.
Movement
If needed, consider including a comparison indicator, such as comparison to the previous time or average.
data:image/s3,"s3://crabby-images/5277d/5277da7b4f5e224bab406bc354ae47a5a1e6c5ce" alt="Diagram of red being used to signify a downward trend in data"
Use green for positive movement.
Use red for negative movement.
Tables
A table is a good way to showcase a large amount of information which has a variety of columns and data to show for each entity. A table should be used when multiple metrics and categories need to be presented together, and accurate lookup of the data values is more important that showing patterns in the data.
Best used for
- Showing large amounts of discrete data with many variables
- Showing values across multiple categories and measures
- Allowing for filtering and ordering when comparison is not a priority
Alignment
Consistent vertical alignment is essential for fast visual comparison between values in a table.
data:image/s3,"s3://crabby-images/7788d/7788d4932ed3eea413515a1d560a638d9d11f940" alt="A table showing product inventory with product names aligned to the left and numbers aligned to the right"
Left align non-numeric values and right align numeric values.
data:image/s3,"s3://crabby-images/45d01/45d012dc51699a8af2a843c9c7fb4bdf5511ea18" alt="A table showing product inventory data with headers, numbers, and titles centered"
Center column headers.
Separation
In order to reduce clutter and non-data ink, we prefer to subtly separate each row.
data:image/s3,"s3://crabby-images/d6fca/d6fcaadcfad417ae771037d9ba77ac3434f4f81d" alt="A table with three rows separated by light grey lines"
Use light lines to indicate separation between rows.
data:image/s3,"s3://crabby-images/b83d8/b83d8da3f4c50256205460c61d7e621e0e3021f3" alt="A table with a white background and grey lines using a darker grey every other row"
Highlight every other row to indicate separation.
Totals
Totals allow merchants to understand the data holistically and should be easy to find.
data:image/s3,"s3://crabby-images/061ab/061ab551035d3a3f874079f6dd9d6a7736b0047e" alt="A diagram showing individual product sales underneath the total sales in bold type"
Place totals as the first row beneath the headers, and bold the text.
Accessibility
An important part of designing clear visualizations is making data accessible to everyone.
Provide options
Merchants with vision issues might have trouble understanding visual presentations of data, even with assistive software.
Merchants with dexterity or motor issues might have trouble using interactive visualizations that depend on fine motor control.
Others might simply have trouble understanding data presented in a chart or graph.
To support the needs of different merchants, always provide multiple formats for data visualizations.
Let merchants access their data in multiple formats. For charts and graphs, it’s often helpful to offer the same content in a data table that’s either on the same page or on a related page that’s easy to discover.
Provide data visualizations in only one format.
Use of color
Color is critical for visualization, but can cause issues for merchants with color blindness and low vision. Color should be used in a way that supports the interpretation of visual information for all merchants, including those with visual issues.
Ensure that text, line, bar, and other colors have sufficient contrast against their background.
Use colors that can be distinguished from each other to support merchants with different forms of color blindness.
Require that merchants are able to see color to understand the information provided in the chart or graph.
To learn more, see guidance about accessible colors in Polaris.
Scalable vector graphics (SVGs)
<svg> and <canvas> elements are excellent tools for creating engaging, dynamic visualizations in HTML. However, they are frequently difficult to access using assistive technologies. Assistive technology users may not be able to access content in the correct order, find text equivalents for visual information, or access interactions with the keyboard.
In general, hide <svg> elements from screen readers using aria-hidden="true" and provide a separate text equivalent for the graph or chart. Although different visualizations may benefit from different treatments, try to prioritize creating a consistent experience.