Skip to content

Commit

Permalink
chore: refactor datatable toolbar
Browse files Browse the repository at this point in the history
  • Loading branch information
devjoaov committed Apr 18, 2024
1 parent 68d3630 commit 1bd5c5a
Show file tree
Hide file tree
Showing 5 changed files with 102 additions and 73 deletions.
68 changes: 68 additions & 0 deletions src/components/DataTable/DataTableFilters.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
import { Cross2Icon } from "@radix-ui/react-icons";
import React, { useEffect, useRef } from "react";

import { Trans } from "react-i18next";
import { Button } from "#/components/ui";

import { DataTableFacetedFilter } from "./DataTableFacetedFilter";
import { useTableContext } from "./TableContext";

export function DataTableFilters() {
// @ts-expect-error TS(2339) FIXME: Property 'table' does not exist on type '{}'.
const { table, filters } = useTableContext();

if (!table || !filters) {
return null;
}

const isFiltered =
table.getState().columnFilters.filter((filter) => filter.value.length > 0)
.length > 0;

const initialFilterSet = useRef(false);

useEffect(() => {
if (filters && !initialFilterSet.current) {
filters.map((filter) => {
const column = table.getColumn(filter.value);
if (column) {
column.setFilterValue(
filter.options
.filter((option) => option.defaultSelected)
.map((option) => option.value)
);
}
return null;
});
initialFilterSet.current = true;
}
}, [filters, table]);

return (
<div className="flex flex-1 items-start space-x-2">
<div className="flex flex-wrap gap-1">
{filters.map(
(filter) =>
table.getColumn(filter.value) && (
<DataTableFacetedFilter
key={filter.title}
column={table.getColumn(filter.value)}
title={filter.title}
options={filter.options}
/>
)
)}
</div>
{isFiltered && (
<Button
variant="ghost"
onClick={() => table.resetColumnFilters()}
className="h-8 px-2 lg:px-3"
>
<Trans>Reset</Trans>
<Cross2Icon className="ml-2 h-4 w-4" />
</Button>
)}
</div>
);
}
26 changes: 26 additions & 0 deletions src/components/DataTable/DataTableSearch.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import React from "react";

import { useTranslation } from "react-i18next";
import { Input } from "#/components/ui";

import { useTableContext } from "./TableContext";

export function DataTableSearch({ searchKey = "name" }) {
// @ts-expect-error TS(2339) FIXME: Property 'table' does not exist on type '{}'.
const { table, searchKey: TableSeachKey } = useTableContext();

const search = TableSeachKey || searchKey;

const { t } = useTranslation();

return (
<Input
placeholder={t("Search")}
value={table.getColumn(search)?.getFilterValue() ?? ""}
onChange={(event) =>
table.getColumn(search)?.setFilterValue(event.target.value)
}
className="h-8 w-[150px] lg:w-[250px] dark:border-2"
/>
);
}
77 changes: 5 additions & 72 deletions src/components/DataTable/DataTableToolbar.tsx
Original file line number Diff line number Diff line change
@@ -1,86 +1,19 @@
import { Cross2Icon } from "@radix-ui/react-icons";
import React, { useEffect, useRef } from "react";
import React from "react";

import { Trans, useTranslation } from "react-i18next";
import { Button, Input } from "#/components/ui";

import { DataTableFacetedFilter } from "./DataTableFacetedFilter";
import { DataTableViewOptions } from "./DataTableViewOptions";
import { useTableContext } from "./TableContext";
import { DataTableSearch } from "./DataTableSearch";
import { DataTableFilters } from "./DataTableFilters";

export function DataTableToolbar({
action,
showViewOptions = true,
searchKey = "name",
}) {
// @ts-expect-error TS(2339) FIXME: Property 'table' does not exist on type '{}'.
const { table, filters, searchKey: TableSeachKey } = useTableContext();

const search = TableSeachKey || searchKey;

if (!table || !filters) {
return null;
}

const isFiltered =
table.getState().columnFilters.filter((filter) => filter.value.length > 0)
.length > 0;

const initialFilterSet = useRef(false);

useEffect(() => {
if (filters && !initialFilterSet.current) {
filters.map((filter) => {
const column = table.getColumn(filter.value);
if (column) {
column.setFilterValue(
filter.options
.filter((option) => option.defaultSelected)
.map((option) => option.value)
);
}
return null;
});
initialFilterSet.current = true;
}
}, [filters, table]);

const { t } = useTranslation();

return (
<div className="flex items-start justify-between">
<div className="flex flex-1 items-start space-x-2">
<Input
placeholder={t("Search")}
value={table.getColumn(search)?.getFilterValue() ?? ""}
onChange={(event) =>
table.getColumn(search)?.setFilterValue(event.target.value)
}
className="h-8 w-[150px] lg:w-[250px] dark:border-2"
/>
<div className="flex flex-wrap gap-1">
{filters.map(
(filter) =>
table.getColumn(filter.value) && (
<DataTableFacetedFilter
key={filter.title}
column={table.getColumn(filter.value)}
title={filter.title}
options={filter.options}
/>
)
)}
</div>
{isFiltered && (
<Button
variant="ghost"
onClick={() => table.resetColumnFilters()}
className="h-8 px-2 lg:px-3"
>
<Trans>Reset</Trans>
<Cross2Icon className="ml-2 h-4 w-4" />
</Button>
)}
<DataTableSearch searchKey={searchKey} />
<DataTableFilters />
</div>
<div className="flex items-center space-x-2">
{action}
Expand Down
2 changes: 2 additions & 0 deletions src/components/DataTable/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,5 @@ export * from "./TableContext";
export * from "./useSWRDataTable";
export * from "./useTableState";
export * from "./DataTable";
export * from "./DataTableSearch";
export * from "./DataTableFilters";
2 changes: 1 addition & 1 deletion src/locales/pt-BR/translation.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"Clear filters": "Limpar filtros",
"Items per page": "Itens por página",
"Page {{currentPage}} of": "Página {{currentPage}} de",
"Search": "Buscar...",
"Search": "Pesquise por palavra chave...",
"Reset": "Remover",
"View": "Visualizar",
"Toggle columns": "Alternar colunas",
Expand Down

0 comments on commit 1bd5c5a

Please sign in to comment.