quadratic/ui

Table

A responsive table component.

NameStatusTypeDomainTagsEnvsTeamsUptimeLast Modified
User Login
OK

Browser

www.notion.so/login
p0
prod
Authentication100%3 Years Ago
Sign-Up Flow
Paused

Browser

www.notion.so/signup
p1
staging
Onboarding95%23 Months Ago
User Data API
OK

API

api.notion.so/user
p0
prod
Backend90.7%23 Months Ago
Document Creation
OK

Browser

www.notion.so/create-document
p2
prod
staging
Editor100%20 Months Ago
Mobile Login
OK

Mobile

m.notion.so/login
p0
prod
Mobile99.9%22 Months Ago
WebSocket Connection
Alert

WebSocket

ws.notion.so/connect
p1
prod
Realtime97.3%2 Years Ago
Payment Gateway
OK

API

api.notion.so/payment
p0
prod
Payments100%20 Months Ago
SSL Certificate Check
OK

SSL

www.notion.so
p0
prod
SecurityNo uptime data23 Months Ago
gRPC User Service
OK

gRPC

api.notion.so/user
p1
prod
Backend99.2%22 Months Ago
User Profile Load
OK

Browser

www.notion.so/profile
p2
prod
Frontend99.8%20 Months Ago

Installation

Copy and paste the following code into your project.

import { cn } from "~/utils/tailwind";

function Table({ className, ...props }: React.ComponentProps<"table">) {
  return (
    <div className="relative w-full overflow-auto">
      <table
        className={cn("text-3-5 w-full caption-bottom", className)}
        {...props}
      />
    </div>
  );
}

function TableHeader({ className, ...props }: React.ComponentProps<"thead">) {
  return <thead className={cn("[&_tr]:border-b", className)} {...props} />;
}

function TableBody({ className, ...props }: React.ComponentProps<"tbody">) {
  return (
    <tbody className={cn("[&_tr:last-child]:border-0", className)} {...props} />
  );
}

function TableFooter({ className, ...props }: React.ComponentProps<"tfoot">) {
  return (
    <tfoot
      className={cn(
        "bg-accent/50 border-t font-medium last:[&>tr]:border-b-0",
        className,
      )}
      {...props}
    />
  );
}

function TableRow({ className, ...props }: React.ComponentProps<"tr">) {
  return (
    <tr
      className={cn(
        "hover:bg-accent/50 data-[state=selected]:bg-accent/50 border-b transition-colors",
        className,
      )}
      {...props}
    />
  );
}

function TableHead({ className, ...props }: React.ComponentProps<"th">) {
  return (
    <th
      className={cn(
        "text-muted-foreground h-9 pl-3 text-left align-middle font-medium",
        "last:pr-3",
        "[&:has([role=checkbox])]:pr-0",
        className,
      )}
      {...props}
    />
  );
}

function TableCell({ className, ...props }: React.ComponentProps<"td">) {
  return (
    <td
      className={cn(
        "h-11 pl-3 align-middle",
        "last:pr-3",
        "[&:has([role=checkbox])]:pr-0",
        className,
      )}
      {...props}
    />
  );
}

function TableCaption({
  className,
  ...props
}: React.ComponentProps<"caption">) {
  return (
    <caption
      className={cn("text-muted-foreground mt-3", className)}
      {...props}
    />
  );
}

export {
  Table,
  TableHeader,
  TableBody,
  TableFooter,
  TableHead,
  TableRow,
  TableCell,
  TableCaption,
};

Update the import paths to match your project setup.

Usage

import {
  Table,
  TableBody,
  TableCaption,
  TableCell,
  TableHead,
  TableHeader,
  TableRow,
} from "~/components/ui/Table";
<Table>
  <TableCaption>A list of your recent invoices.</TableCaption>
  <TableHeader>
    <TableRow>
      <TableHead className="w-[100px]">Invoice</TableHead>
      <TableHead>Status</TableHead>
      <TableHead>Method</TableHead>
      <TableHead className="text-right">Amount</TableHead>
    </TableRow>
  </TableHeader>
  <TableBody>
    <TableRow>
      <TableCell className="font-medium">INV001</TableCell>
      <TableCell>Paid</TableCell>
      <TableCell>Credit Card</TableCell>
      <TableCell className="text-right">$250.00</TableCell>
    </TableRow>
  </TableBody>
</Table>