Data table
Color
Table header
Element | Property | Color token |
---|---|---|
Table header | background-color | $layer * |
Title | text-color | $text-primary |
Description | text-color | $text-secondary |
* Denotes a contextual color token that will change values based on the layer it is placed on.
![Data table header Data table header](/static/c0deb3221f9cc5db15f668ac57a2cc82/3cbba/datatable-style-11.png)
Column header
State | Property | Color token |
---|---|---|
Enabled | background-color | $layer-accent * |
text-color | $text-primary | |
svg | $icon-primary | |
Hover | background-color | $layer-accent-hover * |
text-color | $text-primary | |
Focus | border | $focus |
Active | background-color | $layer-accent-active * |
* Denotes a contextual color token that will change values based on the layer it is placed on.
![Column headers Column headers](/static/f208fdf55f44cfd52c106142360b6a7e/3cbba/datatable-style-9.png)
Row
State | Property | Color token |
---|---|---|
Enabled | background-color | $layer * |
text-color | $text-secondary | |
border-bottom | $border-subtle * | |
svg | $icon-secondary | |
Hover | background-color | $layer-hover * |
text-color | $text-primary | |
Focus | border | $focus |
Selected | background-color | $layer-selected * |
text-color | $text-primary | |
border-bottom | $border-subtle-selected * | |
svg | $icon-primary | |
Selected + hover | background-color | $layer-selected-hover * |
Expanded | background-color | $layer * |
svg | $icon-primary | |
Zebra | background-color | $layer-accent * |
* Denotes a contextual color token that will change values based on the layer it is placed on.
![Data table rows Data table rows](/static/41e5b98decdd0248ea6b6d4c3e9f3445/3cbba/datatable-style-4.png)
Toolbar
Element | Property | Color token |
---|---|---|
Toolbar | background-color | $layer * |
Icon button | See ghost button | |
Button | See primary button |
* Denotes a contextual color token that will change values based on the layer it is placed on.
![Data table toolbar Data table toolbar](/static/5e39bf2892c003993e28595230858747/3cbba/datatable-style-10.png)
Batch action bar
Element | Property | Color token |
---|---|---|
Bar | background-color | $background-brand |
Summary | text-color | $text-on-color |
Button | See primary button |
![data table batch actions data table batch actions](/static/38f1c095163fa1a0158dc42bb15c1de1/3cbba/datatable-style-12.png)
Typography
Element | Font-size (px/rem) | Font-weight | Type token |
---|---|---|---|
Table header | 20 / 1.25 | Regular / 400 | $heading-03 |
Column header | 14 / 0.875 | SemiBold / 600 | $heading-compact-01 |
Row text | 14 / 0.875 | Regular / 400 | $body-compact-01 |
Structure
Tables are a configurable and customizable component. Designers can pick and choose certain elements and interactions. The basic table style is the required base from which tables can be developed. Basic tables are composed of a header row followed by rows of data below.
Element | Property | px / rem | Spacing token |
---|---|---|---|
Table header | margin-top | 16 / 1 | $spacing-05 |
margin-bottom | 24 / 1.5 | $spacing-06 | |
padding left, padding right | 16 / 1 | $spacing-05 | |
Sort icon | padding | 8 / 0.5 | $spacing-03 |
Before and after text | padding-left, padding-right | 16 / 1 | $spacing-05 |
![Data table structure Data table structure](/static/a050ebf326b0b9631a275e923e0fda7e/3cbba/datatable-style-1.png)
Structure and spacing measurements for a basic data table | px/rem
Columns
Column widths can vary by content and only require a minimum spacing between columns. Tables require three or more columns.
Spacing between | Property | px / rem | Spacing token |
---|---|---|---|
Columns | padding | 16 /1 | $spacing-05 |
![Data table column measurements Data table column measurements](/static/ab4659d3a6e74cc9b5d7da00f35b88ec/3cbba/datatable-style-2.png)
Structure and spacing measurements for columns in a data table | px/rem
Rows
Row sizes are customizable. The column header row should always match the row
size of the table. Column header and row text is always centered in the row with
the expecption of the extra large which is offset by padding-top: 16px
. Extra
large row heights are only recommended if your data is expected to have two
lines of content in a single row.
Size | Height (px / rem) |
---|---|
Extra small (xs) | 24 / 1.5 |
Small (sm) | 32 / 2 |
Medium (md) | 40 / 2.5 |
Large (lg) | 48 / 3 |
Extra large (xl) | 64 / 4 |
![data table row sizes data table row sizes](/static/0a02ede9d8b569de0d9dfbce2e4bde01/3cbba/datatable-style-sizes.png)
Enhancements
After the simple table structure, tables can be enhanced by adding any of the following: selectable rows, expanding rows, row menus, table batch actions, overall table menu, and/or table filter.
Element | Property | px / rem | Spacing token |
---|---|---|---|
Checkbox | height, width | 20 / 1.25 | – |
padding-left, padding-right | 16 / 1 | $spacing-05 | |
Radio button | height, width | 20 / 1.25 | – |
padding-left, padding-right | 16 / 1 | $spacing-05 | |
Overflow menu (sm) | height | 32 / 2 | – |
Chevron icon | svg | 16 / 1 | – |
click target | 32 / 2 | $spacing-07 | |
padding-left, padding-right | 16 / 1 | $spacing-05 | |
Expanded panel | padding-top, padding-right | 16 / 1 | $spacing-05 |
padding-left | 48 / 3 | $spacing-09 | |
padding-bottom | 24 / 1.5 | $spacing-06 |
![Data table with selection measurements Data table with selection measurements](/static/2ad373ec7263631c74f01da9601ee66a/3cbba/datatable-style-5c.png)
Structure and spacing measurements for selected row | px/rem
![Data table expanded row measurements Data table expanded row measurements](/static/3a18b21dc78dcf5222ae6004987dbc70/3cbba/datatable-style-5.png)
Structure and spacing measurements for expanded row | px/rem
![Data table with expansion and selection measurements Data table with expansion and selection measurements](/static/6544e60bbc0766be1865c129035d3d7e/3cbba/datatable-style-5b.png)
Structure and spacing measurements for expanded and selected row | px/rem
Toolbar
The large 48px toolbar is paired with the extra large and large row sizes. The small toolbar is paired with the small and extra small row sizes.
Element | Property | px / rem | Spacing token |
---|---|---|---|
Toolbar: large | height, width | 48 / 3 | – |
margin-top, margin-bottom | 16 / 1 | $spacing-05 | |
Toolbar: small | height, width | 32 / 2 | – |
margin-top, margin-bottom | 8 / 0.5 | $spacing-03 |
![Data table toolbar measurements Data table toolbar measurements](/static/787ad1bbb0fdab8771fe1ea345b1a159/3cbba/datatable-style-7.png)
Structure and spacing measurements for toolbar | px/rem
Batch action bar
The large 48px batch action bar is paired with the extra large and large row sizes. The small batch action bar is paired with the small and extra small row sizes.
Element | Property | px / rem | Spacing token |
---|---|---|---|
Batch action bar: large | height | 48 / 3 | – |
Button | size | 48px | – |
Batch action bar: small | height | 32 / 2 | – |
Button | size | 32px | – |
Before and after text | padding-left, padding-right | 16 / 1 | $spacing-05 |
Button: icon | padding-right | 16 / 1 | $spacing-05 |
![Data table batch action bar measurements Data table batch action bar measurements](/static/1ad0d2b9243e046ebfd7854ef7a78dbf/3cbba/datatable-style-8.png)
Structure and spacing measurements for batch action bar | px/rem