5Sponsor

Table

Sortable, selectable, paginated data table

Terminal
table-demo
No opentui live preview is registered for this example yet.

Installation

pnpm dlx shadcn@latest add @termcn/table

Usage

import { Table } from "@/components/ui/table";
<Table
  data={[
    { name: "api-server", cpu: "24%", memory: "512 MB" },
    { name: "worker", cpu: "58%", memory: "1.2 GB" },
  ]}
  columns={[
    { key: "name", header: "Service" },
    { key: "cpu", header: "CPU", align: "right" },
    { key: "memory", header: "Memory", align: "right" },
  ]}
/>

Examples

Sortable

Enable keyboard-driven column sorting with sortable. Use arrow keys to navigate columns and press s to sort.

Terminal
table-sortable
No opentui live preview is registered for this example yet.

Selectable rows

Use selectable with onSelect to choose a row with the arrow keys and Enter.

Terminal
table-selectable
No opentui live preview is registered for this example yet.

API Reference

Table

The table draws a fixed-width grid with Unicode box-drawing characters (ā•­, ā”œ, │, …). Width follows column content; it does not stretch to the full terminal width.

PropTypeDefault
dataT[]required
columnsColumn<T>[]required
sortablebooleanfalse
selectablebooleanfalse
onSelect(row: T) => voidundefined
maxRowsnumber20
borderColorstringundefined

Column

PropTypeDefault
keykeyof T & stringrequired
headerstringrequired
widthnumberundefined
align"left" | "right" | "center""left"