Data views
Leave feedbackThere are currently two built-in options for displaying the data DataTable.Table and CardView, but you can also build your own.
DataTable.Table
The Table component is meant to be rendered within a DataTableContext (provided by DataTable here).
It displays the data provided by the DataTableContext as an html table.
Any Paragon component or export may be added to the code example.
The DataTable.Table component expects to receive a react-table instance from the DataTableContext.
- captionDefaultnullstring|element
- classNamestring
- datashape{}[]Requiredspecifies the order and contents of the table's columns and provides display strings for each column's heading. It is composed of an ordered array of objects. Each object contains the following keys: - label(string or element; required) contains the display string for each column's heading.
- key(string; required) maps that label to its corresponding datum for each row in- data, to ensure table data are displayed in their appropriate columns.
- columnSortable(boolean; optional) specifies at the column-level whether the column is sortable. If- columnSortableis- true, a sort button will be rendered in the column table heading. It is only required if- tableSortableis set to- true.
- onSort(function; conditionally required) specifies what function is called when a sortable column is clicked. It is only required if the column's- columnSortableis set to- true.
- hideHeader(boolean; optional) specifies at the column-level whether the column label is visible. A column that is sortable cannot have its label be hidden.
- width(string; conditionally required) only if- hasFixedColumnWidthsis set to- true, the- <td>elements'- classattributes will be set to this value. This allows restricting columns to specific widths. See Bootstrap's grid documentation for- colclass names that can be used.
 The order of objects in columnsspecifies the order of the columns in the table.
- columnsshape{key:stringRequired,label:string|elementRequired,columnSortable:isRequiredIf(PropTypes.bool, props => props.tableSortable),onSort:isRequiredIf(PropTypes.func, props => props.columnSortable),hideHeader:bool,width:}isRequiredIf(PropTypes.string, props => props.hasFixedColumnWidths),[]Requiredspecifies the order and contents of the table's columns and provides display strings for each column's heading. It is composed of an ordered array of objects. Each object contains the following keys: - label(string or element; required) contains the display string for each column's heading.
- key(string; required) maps that label to its corresponding datum for each row in- data, to ensure table data are displayed in their appropriate columns.
- columnSortable(boolean; optional) specifies at the column-level whether the column is sortable. If- columnSortableis- true, a sort button will be rendered in the column table heading. It is only required if- tableSortableis set to- true.
- onSort(function; conditionally required) specifies what function is called when a sortable column is clicked. It is only required if the column's- columnSortableis set to- true.
- hideHeader(boolean; optional) specifies at the column-level whether the column label is visible. A column that is sortable cannot have its label be hidden.
- width(string; conditionally required) only if- hasFixedColumnWidthsis set to- true, the- <td>elements'- classattributes will be set to this value. This allows restricting columns to specific widths. See Bootstrap's grid documentation for- colclass names that can be used.
 The order of objects in columnsspecifies the order of the columns in the table.
- headingClassNamestring[]Default[]Specifies Bootstrap class names to apply to the table heading. Options are detailed in Bootstrap's docs. 
- tableSortableboolDefaultfalseSpecifies whether the table is sortable. This setting supercedes column-level sortability, so if it is false, no sortable components will be rendered.
- hasFixedColumnWidthsboolDefaultfalseSpecifies whether the table's columns have fixed widths. Every element in columnsmust define awidthif this istrue.
- defaultSortedColumnisRequiredIf(PropTypes.string, props => props.tableSortable)Specifies the key of the column that is sorted by default. It is only required if tableSortableis set totrue.
- defaultSortDirectionisRequiredIf(PropTypes.string, props => props.tableSortable)Specifies the direction the defaultSortedColumnis sorted in by default; it will typically be either 'asc' or 'desc'. It is only required iftableSortableis set totrue.
- sortButtonsScreenReaderTextisRequiredIf( PropTypes.shape({ asc: PropTypes.string, desc: PropTypes.string, defaultText: PropTypes.string, }), props => props.tableSortable, )Default{ asc: 'sort ascending', desc: 'sort descending', defaultText: 'click to sort', }Specifies the screen reader only text that accompanies the sort buttons for sortable columns. It takes the form of an object containing the following keys: - asc: (string) specifies the screen reader only text for sort buttons in the ascending state.
- desc: (string) specifies the screen reader only text for sort buttons in the descending state.
- defaultText: (string) specifies the screen reader only text for sort buttons that are not engaged.
 It is only required if tableSortableis set totrue.Default: {asc: 'sort ascending',desc: 'sort descending',defaultText: 'click to sort',}
- rowHeaderColumnKeystringSpecifies the key for the column that should act as a row header. Rather than rendering as <td>elements, cells in this column will render as<th scope="row">
Table Subcomponents
Subcomponents of DataTable.Table can be used independently of the main component. They are designed for use with a react-table instance.
- rowshape{getRowProps:funcRequired,cells:shape{}[]Required,id:stringRequired,isSelected:bool,isExpanded:} Requiredbool,Row data that is received from react-tableAPI.
- getCellPropsfuncRequiredProps for the td element 
- renderfuncRequiredFunction that renders the cell contents. Will be called with the string 'Cell' 
- columnshape{cellClassName:} Requiredstring,Table column 
- getHeaderPropsfuncRequiredReturns props for the th element 
- isSortedboolDefaultfalseIndicates whether or not a column is sorted 
- renderfuncRequiredRenders the header content. Passed the string 'Header' 
- isSortedDescboolDefaultfalseIndicates whether the column is sorted in descending order 
- getSortByTogglePropsfuncDefault() => {}Gets props related to sorting that will be passed to th 
- canSortboolDefaultfalseIndicates whether a column is sortable 
- headerClassNamestringDefaultnullClass(es) to be applied to header cells 
- headerGroupsshape{headers:shape{getHeaderProps:}funcRequired,[]Required,getHeaderGroupProps:}funcRequired,[]Required
CardView and alternate table components
You may choose to use any table component by using the following code in your display component:
const instance = useContext(DataTableContext)
The CardView takes a CardComponent that is personalized to the table in question and displays
a responsive grid of cards.
Any Paragon component or export may be added to the code example.
Sample Card component for use with CardView
The CardComponent prop on CardView represents a table row, and will receive the row that react-table
provides as props.
- classNamestringThe class name for the CardGrid component 
- columnSizesshape{xs:number,sm:number,md:number,lg:number,xl:}number,Default{ xs: 12, lg: 6, xl: 4, }An object containing the desired column size at each breakpoint, following a similar props API as react-bootstrap/Col
- CardComponentfuncRequiredYour card component must be individualized to your table. It will be called with props from the "row" of data it will display 
- selectionPlacementenum'left' | 'right'Default'right'If the Cards are selectable this prop determines from which side of the Card to show selection component. 
- SkeletonCardComponentfuncOverrides default skeleton card component for loading state in CardView 
- skeletonCardCountnumberDefault8Customize the number of loading skeleton cards to display in CardView 
const MiyazakiCard = ({ className, original }) => {const { title, director, release_date } = original;return (<Card className={className}><Card.ImageCap src="https://picsum.photos/360/200/" srcAlt="Card image" /><Card.Section title={title}><dl><dt>Director</dt><dd>{director}</dd><dt>Release Date</dt><dd>{release_date}</dd></dl></Card.Section></Card>);};
Theme Variables (SCSS)#
$data-table-background-color: $white !default;$data-table-border: 1px solid $gray-200 !default;$data-table-box-shadow: $box-shadow-sm !default;$data-table-padding-x: .75rem !default;$data-table-padding-y: .75rem !default;$data-table-padding-small: .5rem !default;$data-table-cell-padding: .5rem .75rem !default;$data-table-footer-position: center !default;$data-table-pagination-dropdown-max-height: 60vh !default;$data-table-pagination-dropdown-min-width: 6rem !default;$data-table-layout-sidebar-width: 12rem !default;
Props API#
- captionDefaultnullstring|element
- classNamestring
- datashape{}[]Requiredspecifies the order and contents of the table's columns and provides display strings for each column's heading. It is composed of an ordered array of objects. Each object contains the following keys: - label(string or element; required) contains the display string for each column's heading.
- key(string; required) maps that label to its corresponding datum for each row in- data, to ensure table data are displayed in their appropriate columns.
- columnSortable(boolean; optional) specifies at the column-level whether the column is sortable. If- columnSortableis- true, a sort button will be rendered in the column table heading. It is only required if- tableSortableis set to- true.
- onSort(function; conditionally required) specifies what function is called when a sortable column is clicked. It is only required if the column's- columnSortableis set to- true.
- hideHeader(boolean; optional) specifies at the column-level whether the column label is visible. A column that is sortable cannot have its label be hidden.
- width(string; conditionally required) only if- hasFixedColumnWidthsis set to- true, the- <td>elements'- classattributes will be set to this value. This allows restricting columns to specific widths. See Bootstrap's grid documentation for- colclass names that can be used.
 The order of objects in columnsspecifies the order of the columns in the table.
- columnsshape{key:stringRequired,label:string|elementRequired,columnSortable:isRequiredIf(PropTypes.bool, props => props.tableSortable),onSort:isRequiredIf(PropTypes.func, props => props.columnSortable),hideHeader:bool,width:}isRequiredIf(PropTypes.string, props => props.hasFixedColumnWidths),[]Requiredspecifies the order and contents of the table's columns and provides display strings for each column's heading. It is composed of an ordered array of objects. Each object contains the following keys: - label(string or element; required) contains the display string for each column's heading.
- key(string; required) maps that label to its corresponding datum for each row in- data, to ensure table data are displayed in their appropriate columns.
- columnSortable(boolean; optional) specifies at the column-level whether the column is sortable. If- columnSortableis- true, a sort button will be rendered in the column table heading. It is only required if- tableSortableis set to- true.
- onSort(function; conditionally required) specifies what function is called when a sortable column is clicked. It is only required if the column's- columnSortableis set to- true.
- hideHeader(boolean; optional) specifies at the column-level whether the column label is visible. A column that is sortable cannot have its label be hidden.
- width(string; conditionally required) only if- hasFixedColumnWidthsis set to- true, the- <td>elements'- classattributes will be set to this value. This allows restricting columns to specific widths. See Bootstrap's grid documentation for- colclass names that can be used.
 The order of objects in columnsspecifies the order of the columns in the table.
- headingClassNamestring[]Default[]Specifies Bootstrap class names to apply to the table heading. Options are detailed in Bootstrap's docs. 
- tableSortableboolDefaultfalseSpecifies whether the table is sortable. This setting supercedes column-level sortability, so if it is false, no sortable components will be rendered.
- hasFixedColumnWidthsboolDefaultfalseSpecifies whether the table's columns have fixed widths. Every element in columnsmust define awidthif this istrue.
- defaultSortedColumnisRequiredIf(PropTypes.string, props => props.tableSortable)Specifies the key of the column that is sorted by default. It is only required if tableSortableis set totrue.
- defaultSortDirectionisRequiredIf(PropTypes.string, props => props.tableSortable)Specifies the direction the defaultSortedColumnis sorted in by default; it will typically be either 'asc' or 'desc'. It is only required iftableSortableis set totrue.
- sortButtonsScreenReaderTextisRequiredIf( PropTypes.shape({ asc: PropTypes.string, desc: PropTypes.string, defaultText: PropTypes.string, }), props => props.tableSortable, )Default{ asc: 'sort ascending', desc: 'sort descending', defaultText: 'click to sort', }Specifies the screen reader only text that accompanies the sort buttons for sortable columns. It takes the form of an object containing the following keys: - asc: (string) specifies the screen reader only text for sort buttons in the ascending state.
- desc: (string) specifies the screen reader only text for sort buttons in the descending state.
- defaultText: (string) specifies the screen reader only text for sort buttons that are not engaged.
 It is only required if tableSortableis set totrue.Default: { asc: 'sort ascending', desc: 'sort descending', defaultText: 'click to sort', }
- rowHeaderColumnKeystringSpecifies the key for the column that should act as a row header. Rather than rendering as <td>elements, cells in this column will render as<th scope="row">
- getCellPropsfuncRequiredProps for the td element 
- renderfuncRequiredFunction that renders the cell contents. Will be called with the string 'Cell' 
- columnshape{cellClassName:} Requiredstring,Table column 
- getHeaderPropsfuncRequiredReturns props for the th element 
- isSortedboolDefaultfalseIndicates whether or not a column is sorted 
- renderfuncRequiredRenders the header content. Passed the string 'Header' 
- isSortedDescboolDefaultfalseIndicates whether the column is sorted in descending order 
- getSortByTogglePropsfuncDefault() => {}Gets props related to sorting that will be passed to th 
- canSortboolDefaultfalseIndicates whether a column is sortable 
- headerClassNamestringDefaultnullClass(es) to be applied to header cells 
- headerGroupsshape{headers:shape{getHeaderProps:}funcRequired,[]Required,getHeaderGroupProps:}funcRequired,[]Required
- rowshape{getRowProps:funcRequired,cells:shape{}[]Required,id:stringRequired,isSelected:bool,isExpanded:} Requiredbool,Row data that is received from react-tableAPI.
- classNamestringThe class name for the CardGrid component 
- columnSizesshape{xs:number,sm:number,md:number,lg:number,xl:}number,Default{ xs: 12, lg: 6, xl: 4, }An object containing the desired column size at each breakpoint, following a similar props API as react-bootstrap/Col
- CardComponentfuncRequiredYour card component must be individualized to your table. It will be called with props from the "row" of data it will display 
- selectionPlacementenum'left' | 'right'Default'right'If the Cards are selectable this prop determines from which side of the Card to show selection component. 
- SkeletonCardComponentfuncOverrides default skeleton card component for loading state in CardView 
- skeletonCardCountnumberDefault8Customize the number of loading skeleton cards to display in CardView 
Usage Insights#
CardView
| Project Name | Paragon Version | Instance Count | |
|---|---|---|---|
| frontend-app-admin-portal | 20.39.2 | 1 | |
| frontend-app-enterprise-public-catalog | 20.29.0 | 2 | |
| frontend-app-learning | 20.28.4 | 1 | 
Table
| Project Name | Paragon Version | Instance Count | |
|---|---|---|---|
| edx-platform | 2.6.4 | 2 | |
| frontend-app-admin-portal | 20.39.2 | 1 | |
| studio-frontend | 3.4.8 | 1 |