Data Table
This is a data table built with Shadcn UI components and Tanstack Table.
The table has been built following the excellent tutorial and examples found on Shadcn documentation, and extended.
data:image/s3,"s3://crabby-images/bc039/bc039f1b05d2cd46b8a5468e14cf9db0a6276fc9" alt="screenshot"
Configuration
The project is built on React-Vite and uses TypeScript.
- Install React Vite and follow instructions create the project:
$ npx shadcn-ui@latest add dropdown-menu
$ npx shadcn-ui@latest add button
Data
The table shows a fictional list of employees.
Data is simply fake data in an array in the project itself, rather than fetched from a real database.
Features
These are features of the table:
TOOLBAR:
-
Search field: Dynamic search by name.
-
Faceted filters: Filtering by column values (location, status); values are dynamically listed based on column values.
-
Filter tags to show active filters and clear filters - button.
-
Column visibility: A button to choose which columns are visible.
-
Reset: Clears all filters and selections.
TABLE:
-
Sorting: Selected columns can be sorted ascending or descending.
-
Row select: First column's checkbox selects the row.
-
Extra actions dropdown: Each row displays extra actions at the end of the row. Only the first one is currently functional, and it copies the employee ID to clipboard and displays a toast-message.
-
Column reorder: The last row features arrows that move columns right or left.
FOOTER:
-
Info on selected rows: Shows how many rows have been selected.
-
Dynamic rows per page button: The use can increase or decrease rows per page by steps of 5.
-
Pagination buttons: To go forward, backward, to last or first page.
Column visibility:
data:image/s3,"s3://crabby-images/327e3/327e30c93acf64cf72264437b5876edeadb7626d" alt="screenshot"
Faceted-filter dropdown:
data:image/s3,"s3://crabby-images/39d05/39d05b153921df8a6c8f7ba450e446817cc853a6" alt=""
Filter tags and clear button:
data:image/s3,"s3://crabby-images/79a0b/79a0b0fa5e91219e79f5a4d5a165caf137b1a743" alt=""
More actions:
data:image/s3,"s3://crabby-images/c3128/c31281719714a8d96b650c516a4e15864bfe715d" alt=""
Footer:
data:image/s3,"s3://crabby-images/d0a54/d0a5480779e5ac2f734f559e2624c57c4a685c4c" alt="screenshot"
Structure ?
The Table is made up of 3 main parts:
- Page component that fetches data and renders Table component.
- Table component.
- Columns variable which contains the structure and styling of individual column content.
Reusable components:
- Pagination is its on component and can be reused for other tables.
- The faceted filters require lengthy code and it is separated into its own component. It can be reused for other tables.
- Little pop-up toast is its own reusable component.
Next steps ?
➡️ Abstract the table component into a reusable one, and split it into smaller components.
➡️ Introduce context to avoid passing table data as prop -> Easier to handle data manipulation methods as they may happen in different components.
Tech
- React-Vite
- Shadcn UI
- Tanstack-table
- React icons
- Tailwind
- Typescript