beta/components/task-table/data-table-toolbar.tsx
Christopher Arraya 53c3cd3d6e initial commit
2023-11-04 14:57:25 -04:00

79 lines
2.5 KiB
TypeScript

"use client";
import type {
DataTableFilterableColumn,
DataTableSearchableColumn,
} from "@/types";
import { Cross2Icon } from "@radix-ui/react-icons";
import type { Table } from "@tanstack/react-table";
import { Button } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import { DataTableFacetedFilter } from "@/components/task-table/data-table-faceted-filter";
import { DataTableViewOptions } from "@/components/task-table/data-table-view-options";
interface DataTableToolbarProps<TData> {
table: Table<TData>;
filterableColumns?: DataTableFilterableColumn<TData>[];
searchableColumns?: DataTableSearchableColumn<TData>[];
}
export function DataTableToolbar<TData>({
table,
filterableColumns = [],
searchableColumns = [],
}: DataTableToolbarProps<TData>) {
const isFiltered = table.getState().columnFilters.length > 0;
return (
<div className="flex items-center justify-between p-1">
<div className="flex flex-1 items-center space-x-2">
{searchableColumns.length > 0 &&
searchableColumns.map(
(column) =>
table.getColumn(column.id ? String(column.id) : "") && (
<Input
key={String(column.id)}
placeholder={`Filter ${column.title}...`}
value={
(table
.getColumn(String(column.id))
?.getFilterValue() as string) ?? ""
}
onChange={(event) =>
table
.getColumn(String(column.id))
?.setFilterValue(event.target.value)
}
className="h-8 w-[150px] lg:w-[250px]"
/>
)
)}
{filterableColumns.length > 0 &&
filterableColumns.map(
(column) =>
table.getColumn(column.id ? String(column.id) : "") && (
<DataTableFacetedFilter
key={String(column.id)}
column={table.getColumn(column.id ? String(column.id) : "")}
title={column.title}
options={column.options}
/>
)
)}
{isFiltered && (
<Button
variant="ghost"
onClick={() => table.resetColumnFilters()}
className="h-8 px-2 lg:px-3"
>
Reset
<Cross2Icon className="ml-2 h-4 w-4" />
</Button>
)}
</div>
<DataTableViewOptions table={table} />
</div>
);
}