Custom tables
If you need more custom behavior than either EuiBasicTable or EuiInMemoryTable allow, you can opt to completely construct your own table from EUI's low-level table building block components, like EuiTableHeaderΒ and EuiTableRowCell.
There are several important caveats to keep in mind while doing so:
Custom table implementations must completely handle their own selection and filtering.
You must supply a mobileOptions.header
prop equivalent to the column header on each EuiTableRowCell so that the mobile version will use that to populate the per cell headers.
Also, in order to add mobile support for selection and filtering toolbars, you will need to implement the EuiTableHeaderMobile component as a wrapper around these and use EuiTableSortMobileΒ and EuiTableSortMobileItem components to supply mobile sorting. See demo below.
Set individual props like the truncateText
prop to cells to enforce a single-line behavior and truncate their contents, or set the textOnly
prop to false
if you need the contents to be a direct descendent of the cell.
Below is one of many ways you might set up a custom table that account for all the above notes: