Table

<p-table> | PTable
Since 1.1.15 stable

The Table component is used to display data in a table format.

<p-table
  class="table-example"
  limit="2"
>

</p-table>
<script>
  const table = document.querySelector('.table-example');

  table.loading = true;

  table.options = {
    paginate: true,
    selectable: true,
    columns: [{field: 'name',
    id: 'name',
    headerName: 'Full name',
    alignItems: 'center',
    justifyContent: 'flex-start',
    resizable: true,
    width: '150px',
    minWidth: '120px',
    maxWidth: '300px'
  },{field: 'age',
    id: 'age',
    headerName: 'Age',
  },{field: 'address.street',
    id: 'street',
    headerName: 'Street',
    maxWidth: '400px',
  },{field: 'address.department',
    id: 'department',
    headerName: 'Department',
  },{field: 'address.city',
    id: 'city',
    headerName: 'City',
  },{field: 'address.country',
    id: 'country',
    headerName: 'Country',
  }, {field: 'status',
    id: 'status',
    headerName: 'Status',
    render: (row) => `${String(row.status) == '1' ? 'Active' : 'Inactive'}`,
    justifyContent: 'center',
  }
  ]
  }

  setTimeout(() => {
    table.data = [{
    "name": "Alice",
    "age": "28",
    "address": {
      "street": "2 Elm Street",
      "department": "Greenwood",
      "city": "Portland",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Bob",
    "age": "35",
    "address": {
      "street": "3 Oak Street",
      "department": "Lakeside",
      "city": "Chicago",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Charlie",
    "age": "22",
    "address": {
      "street": "4 Pine Street",
      "department": "Downtown",
      "city": "San Francisco",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "David",
    "age": "40",
    "address": {
      "street": "5 Maple Street",
      "department": "Westside",
      "city": "Los Angeles",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Eva",
    "age": "31",
    "address": {
      "street": "6 Birch Street",
      "department": "Riverside",
      "city": "Austin",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Frank",
    "age": "29",
    "address": {
      "street": "7 Cedar Street",
      "department": "Northside",
      "city": "Denver",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Grace",
    "age": "33",
    "address": {
      "street": "8 Willow Street",
      "department": "Southside",
      "city": "Miami",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Hannah",
    "age": "25",
    "address": {
      "street": "9 Walnut Street",
      "department": "Eastside",
      "city": "Boston",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Ivy",
    "age": "27",
    "address": {
      "street": "10 Chestnut Street",
      "department": "Central",
      "city": "Philadelphia",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Jack",
    "age": "32",
    "address": {
      "street": "11 Ash Street",
      "department": "Uptown",
      "city": "Atlanta",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Karen",
    "age": "36",
    "address": {
      "street": "12 Fir Street",
      "department": "Midtown",
      "city": "Seattle",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Leo",
    "age": "24",
    "address": {
      "street": "13 Poplar Street",
      "department": "Parkside",
      "city": "San Diego",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Mia",
    "age": "26",
    "address": {
      "street": "14 Sycamore Street",
      "department": "Harbor",
      "city": "San Jose",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Nina",
    "age": "29",
    "address": {
      "street": "15 Magnolia Street",
      "department": "Hilltop",
      "city": "Las Vegas",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Oliver",
    "age": "31",
    "address": {
      "street": "16 Hickory Street",
      "department": "Downtown",
      "city": "Orlando",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Paula",
    "age": "37",
    "address": {
      "street": "17 Locust Street",
      "department": "Sunset",
      "city": "Honolulu",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Quinn",
    "age": "23",
    "address": {
      "street": "18 Elm Street",
      "department": "Springfield",
      "city": "New York",
      "country": "USA"
    },
    "status": 1
  },
  {
    "name": "Rachel",
    "age": "34",
    "address": {
      "street": "19 Redwood Street",
      "department": "Elmwood",
      "city": "Washington",
      "country": "USA"
    },
    "status": 0
  },
  {
    "name": "Steve",
    "age": "38",
    "address": {
      "street": "20 Oak Street",
      "department": "Creekside",
      "city": "Dallas",
      "country": "USA"
    },
    "status": 1
  }]

  table.options = JSON.parse(JSON.stringify(table.options));

  table.loading = false;

  }, 3000);

</script>


TableOptions Interface

The TableOptions<T> interface defines the configuration options for the table component. Below is a breakdown of each property:

export interface TableOptions<T> {
  columns: ColumnConfig[];
  minHeight?: string;
  maxHeight?: string;
  selectable?: boolean;
  hideHeader?: boolean;
  hideFooter?: boolean;
  paginate?: boolean;
}

columns

  • Type: ColumnConfig[]
  • Required: Yes
  • Description: Defines the structure of columns in the table. The ColumnConfig array specifies how each column should be displayed, including options like the field (the data property associated with the column), headerName (the display name of the column), and other layout-related properties like width.

getSelectedRows

  • Type: () => T[]
  • Required: No
  • Description: A callback function that returns an array of selected rows. This is useful when the table has the selectable option enabled, allowing you to retrieve the selected rows programmatically.

minHeight

  • Type: string
  • Required: No
  • Description: Sets a minimum height for the table. The value can be provided in any valid CSS unit such as px, %, em, rem, etc. Ensures that the table will not shrink smaller than this height even if it contains little content.

maxHeight

  • Type: string
  • Required: No
  • Description: Sets a maximum height for the table. When the table’s content exceeds this height, a scrollbar will appear to allow vertical scrolling. The value can be defined using any CSS height unit.

selectable

  • Type: boolean
  • Required: No
  • Default: false
  • Description: When set to true, rows in the table become selectable. This allows users to select one or multiple rows, which can later be retrieved using the getSelectedRows method.

hideHeader

  • Type: boolean
  • Required: No
  • Default: false
  • Description: When set to true, the header row (the row that displays column titles) is hidden from view. This can be useful when displaying minimalistic tables or when the header information is not required.

hideFooter

  • Type: boolean
  • Required: No
  • Default: false
  • Description: When set to true, the footer row is hidden from view. This is useful for tables that do not require a footer for pagination or summary information.

paginate

  • Type: boolean
  • Required: No
  • Default: false
  • Description: Enables pagination in the table. When set to true, the table will only display a limited number of rows per page, and users can navigate between different pages of data.

ColumnConfig Properties

The TableOptions<T> interface defines the configuration options for the table component. Below is a breakdown of each property:

export interface ColumnConfig {
  field?: string;
  hide?: boolean;
  resizable?: boolean;
  headerName?: string;
  width?: string;
  minWidth?: string;
  maxWidth?: string;
  render?: (T: unknown) => string;
  alignItems?: "flex-start" | "flex-end" | "center";
  justifyContent?: "flex-start" | "flex-end" | "center";
  justifyItems?: "flex-start" | "flex-end" | "center";
  classes?: string;
  truncate?: boolean;
  sticky?: "start" | "end";
  stickyOffset?: number;
}

field

  • Type: string
  • Required: No
  • Description: The key in the data object that corresponds to the column’s value. This maps the column to the specific field in the data.

hide

  • Type: boolean
  • Required: No
  • Description: When set to true, this column will be hidden from the table.

resizable

  • Type: boolean
  • Required: No
  • Description: Makes the column resizable, allowing users to adjust the width of the column by dragging.

headerName

  • Type: string
  • Required: No
  • Description: The display name of the column in the header.

width

  • Type: string
  • Required: No
  • Description: Defines the width of the column. Can be set in any valid CSS unit like px, em, %, etc.

minWidth

  • Type: string
  • Required: No
  • Description: Sets the minimum width of the column in any valid CSS unit.

maxWidth

  • Type: string
  • Required: No
  • Description: Sets the maximum width of the column in any valid CSS unit.

render

  • Type: (T: unknown) => string
  • Required: No
  • Description: A custom render function that returns the HTML content as a string for each cell in the column.

alignItems

  • Type: "flex-start" | "flex-end" | "center"
  • Required: No
  • Description: Controls how the column content is aligned along the cross-axis (vertical) inside the column. Aligns to start, end, or center.

justifyContent

  • Type: "flex-start" | "flex-end" | "center"
  • Required: No
  • Description: Defines how the column content is aligned along the main axis (horizontal) inside the column.

justifyItems

  • Type: "flex-start" | "flex-end" | "center"
  • Required: No
  • Description: Defines the alignment of items inside the cell, aligning the content within the cell based on the specified value.

classes

  • Type: string
  • Required: No
  • Description: Additional CSS classes to apply to the column cells.

truncate

  • Type: boolean
  • Required: No
  • Description: If set to true, cell content that overflows will be truncated with ellipsis (...). This is useful for managing long content in limited column width.

sticky

  • Type: "start" | "end"
  • Required: No
  • Description: Makes the column sticky, so it stays in place when scrolling. start sticks the column to the left, and end sticks the column to the right.

stickyOffset

  • Type: number
  • Required: No
  • Description: Defines the offset (in pixels) for the sticky column from the edge (left or right) when the sticky option is used.

Importing

If you’re using the autoloader or the traditional loader, you can ignore this section. Otherwise, feel free to use any of the following snippets to cherry pick this component.

Script Import Bundler React

To import this component from the CDN using a script tag:

<script type="module" src="https://cdn.jsdelivr.net/npm/pure-uikit@1.5.11/cdn/components/table/table.js"></script>

To import this component from the CDN using a JavaScript import:

import 'https://cdn.jsdelivr.net/npm/pure-uikit@1.5.11/cdn/components/table/table.js';

To import this component using a bundler:

import 'pure-uikit/dist/components/table/table.js';

To import this component as a React component:

import PTable from 'pure-uikit/dist/react/table';

Slots

Name Description
(default) The default slot.
paginate An optional slot for paginate element.

Learn more about using slots.

Properties

Name Description Reflects Type Default
disabled Indicates that the element is disabled. boolean false
options The options for the table. TableOptions { columns: [], paginate: true, draggable: false, hideHeader: false, hideFooter: false, expandable: false, selectable: false, }
data The data to display in the table. This property is an array of objects, where each object represents a row in the table. The properties of each object will be used to populate the columns in the table. The column headers will be determined by the options.columns property. TableRowData[] []
loading Whether the table is currently loading data. boolean false
page The current page of items based on the current limit and total. number 1
limit The number of items to display per page. number 10
total The total number of items in the table. number 0
currentItems Returns the current page of items based on the current page, page size, and total items. If the table is not local paginated, all items are returned. - -
updateComplete A read-only promise that resolves when the component has finished updating.

Learn more about attributes and properties.

Events

Name React Event Description Event Detail
p-change onPChange Emitted when the current page value changes. -
p-table-row-select onPTableRowSelect Emitted when the rows selected changed. -

Learn more about events.

Custom Properties

Name Description Default
--table-header-cell-padding Set padding for header cell.
--table-body-cell-padding Set padding for body cell.
--table-footer-padding Set padding for footer cell.
--table-border-horizontal-width Set border width horizontal.
--table-border-horizontal-style Set border style horizontal.
--table-border-horizontal-color Set border color horizontal.
--table-border-vertical-width Set border width vertical.
--table-border-vertical-style Set border style vertical.
--table-border-vertical-color Set border color vertical.
--table-border-width Set table border width.
--table-border-color Set table border color.
--table-border-style Set table border style.
--table-border-radius Set table border radius.
--table-row-hover-background-color Set table row hover background color.
--table-cell-background-color Set table cell background color.
--table-cell-hover-background-color Set table cell hover background color.
--table-cell-min-height Set table cell min height.
--table-cell-max-height Set table cell max height.
--table-cell-min-width Set table cell min width.
--table-cell-max-width Set table cell max width.

Learn more about customizing CSS custom properties.

Parts

Name Description
table-wrapper The component’s table wrapper.
table-header The component’s table header wrapper.
table-body The component’s table body wrapper.
table-loading The component’s table loading wrapper.
table-empty The component’s table empty wrapper.
table-footer The component’s table footer wrapper.

Learn more about customizing CSS parts.

Dependencies

This component automatically imports the following dependencies.

  • <p-button>
  • <p-icon>
  • <p-icon-button>
  • <p-paginate>
  • <p-spinner>
  • <p-tag>