Table

The table displays data from any record source

NameStatusRoleEmailLocationTimeStart DateBioActions
Sarah Johnson

Sarah Johnson

@sarah

Online
Software Engineersarah.johnson@skywardui.com
San Francisco, CA
21:57GMT-7May 10, 2022Passionate about coding and building innovative solutions. Enjoys hiking and exploring new technologies.
Michael Rodriguez

Michael Rodriguez

@michael

Offline
Marketing Specialistmichael.rodriguez@skywardui.com
London, UK
21:57GMT+0Sep 22, 2021Creative marketer with a knack for social media. Enjoys photography and exploring local coffee shops.
Alex Chen

Alex Chen

@alex

Busy
Data Analystalex.chen@skywardui.com
Seattle, WA
21:57GMT-7Jan 8, 2023Analytical thinker with a passion for interpreting data. Enjoys playing chess and attending tech meetups.
Olivia Thompson

Olivia Thompson

@olivia

Online
HR Coordinatorolivia.thompson@skywardui.com
Chicago, IL
21:57GMT-6Nov 14, 2020People-oriented professional with a focus on creating a positive workplace. Enjoys reading and yoga.
Ryan Patel

Ryan Patel

@ryan

Online
Sales Representativeryan.patel@skywardui.com
Miami, FL
21:57GMT-5Mar 5, 2022Results-driven salesperson with a passion for building client relationships. Enjoys water sports and traveling.
Emily Davis

Emily Davis

@emily

Away
UX/UI Designeremily.davis@skywardui.com
Los Angeles, CA
21:57GMT-7Jul 18, 2021Creative designer with an eye for user experience. Enjoys painting and attending design conferences.
Kevin Lewis

Kevin Lewis

@kevin

Offline
Financial Analystkevin.lewis@skywardui.com
Houston, TX
21:57GMT-6Sep 30, 2022Detail-oriented finance professional with a passion for number crunching. Enjoys playing guitar and hiking.
Jessica Kim

Jessica Kim

@jessica

Online
Customer Support Specialistjessica.kim@skywardui.com
Denver, CO
21:57GMT-6Apr 12, 2023Customer-focused professional with excellent problem-solving skills. Enjoys gardening and volunteering.
Brian Foster

Brian Foster

@brian

Away
Project Managerbrian.foster@skywardui.com
Atlanta, GA
21:57GMT-5Jan 25, 2021Organized project manager with a focus on delivering results. Enjoys hiking and playing golf.
Amanda Ramirez

Amanda Ramirez

@amanda

Online
Content Writeramanda.ramirez@skywardui.com
Austin, TX
21:57GMT-6Jun 7, 2022Creative writer with a passion for storytelling. Enjoys attending book clubs and exploring local breweries.

Usage

In order to make tables easier to use, we’ve created some components with pre-defined styles to allow easier implementation. You can add to or change these styles as you need.

Some components like thead and tbody do not require additional styling for our use case, so we’ve left them as the default react components but they are still required in the table structure.

You can add any component you’d like within the TableCell or TableHeaderCell components to give you the functionality you need, as shown in the other examples.

import { Table, TableCell, TableHeaderCell, TableRow } from "#/ui/components/Table"
Column 1Column 2Column 3
Cell 1Cell 2Cell 3
Cell 4Cell 5Cell 6
Cell 7Cell 8Cell 9

You’ll often want the header to follow as you scroll through the table data so you can remember the context of each column

NameStatusRoleEmailLocationTimeStart DateBioActions
Sarah Johnson

Sarah Johnson

@sarah

Online
Software Engineersarah.johnson@skywardui.com
San Francisco, CA
21:57GMT-7May 10, 2022Passionate about coding and building innovative solutions. Enjoys hiking and exploring new technologies.
Michael Rodriguez

Michael Rodriguez

@michael

Offline
Marketing Specialistmichael.rodriguez@skywardui.com
London, UK
21:57GMT+0Sep 22, 2021Creative marketer with a knack for social media. Enjoys photography and exploring local coffee shops.
Alex Chen

Alex Chen

@alex

Busy
Data Analystalex.chen@skywardui.com
Seattle, WA
21:57GMT-7Jan 8, 2023Analytical thinker with a passion for interpreting data. Enjoys playing chess and attending tech meetups.
Olivia Thompson

Olivia Thompson

@olivia

Online
HR Coordinatorolivia.thompson@skywardui.com
Chicago, IL
21:57GMT-6Nov 14, 2020People-oriented professional with a focus on creating a positive workplace. Enjoys reading and yoga.
Ryan Patel

Ryan Patel

@ryan

Online
Sales Representativeryan.patel@skywardui.com
Miami, FL
21:57GMT-5Mar 5, 2022Results-driven salesperson with a passion for building client relationships. Enjoys water sports and traveling.
Emily Davis

Emily Davis

@emily

Away
UX/UI Designeremily.davis@skywardui.com
Los Angeles, CA
21:57GMT-7Jul 18, 2021Creative designer with an eye for user experience. Enjoys painting and attending design conferences.
Kevin Lewis

Kevin Lewis

@kevin

Offline
Financial Analystkevin.lewis@skywardui.com
Houston, TX
21:57GMT-6Sep 30, 2022Detail-oriented finance professional with a passion for number crunching. Enjoys playing guitar and hiking.
Jessica Kim

Jessica Kim

@jessica

Online
Customer Support Specialistjessica.kim@skywardui.com
Denver, CO
21:57GMT-6Apr 12, 2023Customer-focused professional with excellent problem-solving skills. Enjoys gardening and volunteering.
Brian Foster

Brian Foster

@brian

Away
Project Managerbrian.foster@skywardui.com
Atlanta, GA
21:57GMT-5Jan 25, 2021Organized project manager with a focus on delivering results. Enjoys hiking and playing golf.
Amanda Ramirez

Amanda Ramirez

@amanda

Online
Content Writeramanda.ramirez@skywardui.com
Austin, TX
21:57GMT-6Jun 7, 2022Creative writer with a passion for storytelling. Enjoys attending book clubs and exploring local breweries.

Sticky first column

Sometimes you’ll want the first column to follow as you scroll through the table data so you can remember the context of each row

NameStatusRoleEmailLocationTimeStart DateBioActions
Sarah Johnson

Sarah Johnson

@sarah

Online
Software Engineersarah.johnson@skywardui.com
San Francisco, CA
21:57GMT-7May 10, 2022Passionate about coding and building innovative solutions. Enjoys hiking and exploring new technologies.
Michael Rodriguez

Michael Rodriguez

@michael

Offline
Marketing Specialistmichael.rodriguez@skywardui.com
London, UK
21:57GMT+0Sep 22, 2021Creative marketer with a knack for social media. Enjoys photography and exploring local coffee shops.
Alex Chen

Alex Chen

@alex

Busy
Data Analystalex.chen@skywardui.com
Seattle, WA
21:57GMT-7Jan 8, 2023Analytical thinker with a passion for interpreting data. Enjoys playing chess and attending tech meetups.
Olivia Thompson

Olivia Thompson

@olivia

Online
HR Coordinatorolivia.thompson@skywardui.com
Chicago, IL
21:57GMT-6Nov 14, 2020People-oriented professional with a focus on creating a positive workplace. Enjoys reading and yoga.
Ryan Patel

Ryan Patel

@ryan

Online
Sales Representativeryan.patel@skywardui.com
Miami, FL
21:57GMT-5Mar 5, 2022Results-driven salesperson with a passion for building client relationships. Enjoys water sports and traveling.
Emily Davis

Emily Davis

@emily

Away
UX/UI Designeremily.davis@skywardui.com
Los Angeles, CA
21:57GMT-7Jul 18, 2021Creative designer with an eye for user experience. Enjoys painting and attending design conferences.
Kevin Lewis

Kevin Lewis

@kevin

Offline
Financial Analystkevin.lewis@skywardui.com
Houston, TX
21:57GMT-6Sep 30, 2022Detail-oriented finance professional with a passion for number crunching. Enjoys playing guitar and hiking.
Jessica Kim

Jessica Kim

@jessica

Online
Customer Support Specialistjessica.kim@skywardui.com
Denver, CO
21:57GMT-6Apr 12, 2023Customer-focused professional with excellent problem-solving skills. Enjoys gardening and volunteering.
Brian Foster

Brian Foster

@brian

Away
Project Managerbrian.foster@skywardui.com
Atlanta, GA
21:57GMT-5Jan 25, 2021Organized project manager with a focus on delivering results. Enjoys hiking and playing golf.
Amanda Ramirez

Amanda Ramirez

@amanda

Online
Content Writeramanda.ramirez@skywardui.com
Austin, TX
21:57GMT-6Jun 7, 2022Creative writer with a passion for storytelling. Enjoys attending book clubs and exploring local breweries.

Sorting

Requires JS

Sort functionality is not built into the table, but you can add your own by passing a function to the onClick prop of the TableHeaderCell component which sorts your data.

NameStatusRoleEmailLocationTimeStart DateBioActions
Sarah Johnson

Sarah Johnson

@sarah

Online
Software Engineersarah.johnson@skywardui.com
San Francisco, CA
21:57GMT-7May 10, 2022Passionate about coding and building innovative solutions. Enjoys hiking and exploring new technologies.
Michael Rodriguez

Michael Rodriguez

@michael

Offline
Marketing Specialistmichael.rodriguez@skywardui.com
London, UK
21:57GMT+0Sep 22, 2021Creative marketer with a knack for social media. Enjoys photography and exploring local coffee shops.
Alex Chen

Alex Chen

@alex

Busy
Data Analystalex.chen@skywardui.com
Seattle, WA
21:57GMT-7Jan 8, 2023Analytical thinker with a passion for interpreting data. Enjoys playing chess and attending tech meetups.
Olivia Thompson

Olivia Thompson

@olivia

Online
HR Coordinatorolivia.thompson@skywardui.com
Chicago, IL
21:57GMT-6Nov 14, 2020People-oriented professional with a focus on creating a positive workplace. Enjoys reading and yoga.
Ryan Patel

Ryan Patel

@ryan

Online
Sales Representativeryan.patel@skywardui.com
Miami, FL
21:57GMT-5Mar 5, 2022Results-driven salesperson with a passion for building client relationships. Enjoys water sports and traveling.
Emily Davis

Emily Davis

@emily

Away
UX/UI Designeremily.davis@skywardui.com
Los Angeles, CA
21:57GMT-7Jul 18, 2021Creative designer with an eye for user experience. Enjoys painting and attending design conferences.
Kevin Lewis

Kevin Lewis

@kevin

Offline
Financial Analystkevin.lewis@skywardui.com
Houston, TX
21:57GMT-6Sep 30, 2022Detail-oriented finance professional with a passion for number crunching. Enjoys playing guitar and hiking.
Jessica Kim

Jessica Kim

@jessica

Online
Customer Support Specialistjessica.kim@skywardui.com
Denver, CO
21:57GMT-6Apr 12, 2023Customer-focused professional with excellent problem-solving skills. Enjoys gardening and volunteering.
Brian Foster

Brian Foster

@brian

Away
Project Managerbrian.foster@skywardui.com
Atlanta, GA
21:57GMT-5Jan 25, 2021Organized project manager with a focus on delivering results. Enjoys hiking and playing golf.
Amanda Ramirez

Amanda Ramirez

@amanda

Online
Content Writeramanda.ramirez@skywardui.com
Austin, TX
21:57GMT-6Jun 7, 2022Creative writer with a passion for storytelling. Enjoys attending book clubs and exploring local breweries.
// just the sorting bits
const [data, setData] = useState(employees)
const [currentSort, setCurrentSort] = useState<{
  key: string
  order: "asc" | "desc" | ""
}>()

const sortData = (key: string) => {
  const startOrder = currentSort?.key === key ? currentSort?.order : ""
  const nextOrder =
    startOrder === "" ? "asc" : startOrder === "asc" ? "desc" : ""

  setCurrentSort({
    key,
    order: nextOrder,
  })

  if (!nextOrder) {
    // reset to default order if not asc or desc
    setData(employees)
  } else {
    setData(
      // Don't mutate the original array
      [...employees].sort((a, b) => {
        if (nextOrder === "desc") return a[key] < b[key] ? 1 : -1

        return a[key] > b[key] ? 1 : -1
      })
    )
  }
}

<TableHeaderCell
  onClick={() => sortData("name")}
  className="flex justify-between items-center"
>
  Name
  <SortIcon />
</TableHeaderCell>