Skip to content

Commit

Permalink
fix: re-implement team filter & people filter components
Browse files Browse the repository at this point in the history
  • Loading branch information
eunjae-lee committed Jan 14, 2025
1 parent 80aac06 commit 2cf0187
Show file tree
Hide file tree
Showing 18 changed files with 396 additions and 208 deletions.
11 changes: 11 additions & 0 deletions apps/web/public/icons/sprite.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion apps/web/public/static/locales/en/common.json
Original file line number Diff line number Diff line change
Expand Up @@ -2075,7 +2075,7 @@
"looking_for_more_analytics": "Looking for more analytics?",
"looking_for_more_insights": "Looking for more Insights?",
"filters": "Filters",
"add_filter": "Add filter",
"add_filter": "Filter",
"add_rule": "Add rule",
"add_rule_group": "Add rule group",
"remove_filters": "Clear all filters",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ export function DataTableWrapper<TData, TValue>({
<DataTableToolbar.Root>
<div className="flex w-full flex-col gap-2 sm:flex-row">
<div className="flex w-full flex-wrap items-center justify-between gap-2">
<div className="flex justify-start gap-2">{ToolbarLeft}</div>
<div className="flex items-center justify-start gap-2">{ToolbarLeft}</div>
<div className="grow" />
<div className="flex justify-end gap-2">{ToolbarRight}</div>
</div>
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { useDataTable } from "@calcom/features/data-table";
import { useLocale } from "@calcom/lib/hooks/useLocale";
import { Icon, Button, Tooltip } from "@calcom/ui";

export const ClearFiltersButton = () => {
const { t } = useLocale();
const { activeFilters, clearAll } = useDataTable();

if (!activeFilters?.length) {
return null;
}

return (
<Tooltip content={t("clear_filters")}>
<Button
variant="icon"
color="secondary"
target="_blank"
rel="noreferrer"
className="min-w-24 h-[38px] border-0"
onClick={clearAll}>
<Icon name="x" className="mr-1 h-4 w-4" />
{t("clear")}
</Button>
</Tooltip>
);
};
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ export function MultiSelectFilterOptions({ column }: MultiSelectFilterOptionsPro

return (
<Command>
<CommandInput placeholder={t("search_options")} />
<CommandInput placeholder={t("search")} />
<CommandList>
<CommandEmpty>{t("no_options_found")}</CommandEmpty>
{Array.from(column.options.keys()).map((option) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ export function SingleSelectFilterOptions({ column }: SingleSelectFilterOptionsP

return (
<Command>
<CommandInput placeholder={t("search_options")} />
<CommandInput placeholder={t("search")} />
<CommandList>
<CommandEmpty>{t("no_options_found")}</CommandEmpty>
{Array.from(column.options.keys()).map((option) => {
Expand Down
42 changes: 15 additions & 27 deletions packages/features/data-table/components/filters/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,8 @@ import {
} from "@calcom/ui";

import { useDataTable } from "../../hooks";
import type { FilterableColumn, ExternalFilter } from "../../lib/types";
import type { FilterableColumn } from "../../lib/types";
import { ClearFiltersButton } from "./ClearFiltersButton";
import { FilterOptions } from "./FilterOptions";

interface ColumnVisiblityProps<TData> {
Expand Down Expand Up @@ -122,16 +123,14 @@ const ColumnVisibilityButton = forwardRef(ColumnVisibilityButtonComponent) as <T
// Filters
interface AddFilterButtonProps<TData> {
table: Table<TData>;
externalFilters?: ExternalFilter[];
}

function AddFilterButtonComponent<TData>(
{ table, externalFilters }: AddFilterButtonProps<TData>,
{ table }: AddFilterButtonProps<TData>,
ref: React.Ref<HTMLButtonElement>
) {
const { t } = useLocale();
const { activeFilters, setActiveFilters, displayedExternalFilters, setDisplayedExternalFilters } =
useDataTable();
const { activeFilters, setActiveFilters } = useDataTable();

const filterableColumns = useFilterableColumns(table);

Expand All @@ -148,14 +147,14 @@ function AddFilterButtonComponent<TData>(
<div className="flex items-center space-x-2">
<Popover>
<PopoverTrigger asChild>
<Button ref={ref} color="secondary" className="border-dashed">
<Icon name="filter" className="mr-2 h-4 w-4" />
<Button ref={ref} color="secondary">
<Icon name="sliders-horizontal" className="mr-2 h-4 w-4" />
{t("add_filter")}
</Button>
</PopoverTrigger>
<PopoverContent className="w-[200px] p-0" align="start">
<Command>
<CommandInput placeholder={t("search_columns")} />
<CommandInput placeholder={t("search")} />
<CommandList>
<CommandEmpty>{t("no_columns_found")}</CommandEmpty>
{filterableColumns.map((column) => {
Expand All @@ -169,16 +168,6 @@ function AddFilterButtonComponent<TData>(
</CommandItem>
);
})}
{(externalFilters || [])
.filter((filter) => !displayedExternalFilters.includes(filter.key))
.map((filter, index) => (
<CommandItem
key={index}
onSelect={() => setDisplayedExternalFilters((prev) => [...prev, filter.key])}
className="px-4 py-2">
{t(filter.titleKey)}
</CommandItem>
))}
</CommandList>
</Command>
</PopoverContent>
Expand Down Expand Up @@ -229,7 +218,6 @@ const AddFilterButton = forwardRef(AddFilterButtonComponent) as <TData>(
// Add the new ActiveFilters component
interface ActiveFiltersProps<TData> {
table: Table<TData>;
externalFilters?: ExternalFilter[];
}

const filterIcons = {
Expand All @@ -239,8 +227,8 @@ const filterIcons = {
single_select: "disc",
} as const;

function ActiveFilters<TData>({ table, externalFilters }: ActiveFiltersProps<TData>) {
const { activeFilters, displayedExternalFilters } = useDataTable();
function ActiveFilters<TData>({ table }: ActiveFiltersProps<TData>) {
const { activeFilters } = useDataTable();
const filterableColumns = useFilterableColumns(table);

return (
Expand All @@ -264,14 +252,14 @@ function ActiveFilters<TData>({ table, externalFilters }: ActiveFiltersProps<TDa
</Popover>
);
})}
{(displayedExternalFilters || []).map((key) => {
const filter = externalFilters?.find((filter) => filter.key === key);
if (!filter) return null;
return <Fragment key={key}>{filter.component()}</Fragment>;
})}
</>
);
}

// Update the export to include ActiveFilters
export const DataTableFilters = { ColumnVisibilityButton, AddFilterButton, ActiveFilters };
export const DataTableFilters = {
ColumnVisibilityButton,
AddFilterButton,
ActiveFilters,
ClearFiltersButton,
};
21 changes: 2 additions & 19 deletions packages/features/data-table/lib/context.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

import type { SortingState, OnChangeFn } from "@tanstack/react-table";
import { useQueryState, parseAsArrayOf, parseAsJson } from "nuqs";
import { createContext, useCallback, useState, type Dispatch, type SetStateAction } from "react";
import { createContext, useCallback } from "react";
import { z } from "zod";

import { type FilterValue, ZFilterValue, ZSorting } from "./types";
Expand All @@ -23,10 +23,6 @@ export type DataTableContextType = {

sorting: SortingState;
setSorting: OnChangeFn<SortingState>;

displayedExternalFilters: string[];
setDisplayedExternalFilters: Dispatch<SetStateAction<string[]>>;
removeDisplayedExternalFilter: (key: string) => void;
};

export const DataTableContext = createContext<DataTableContextType | null>(null);
Expand All @@ -41,19 +37,9 @@ export function DataTableProvider({ children }: { children: React.ReactNode }) {
parseAsArrayOf(parseAsJson(ZSorting.parse)).withDefault([])
);

const [displayedExternalFilters, setDisplayedExternalFilters] = useState<string[]>([]);

const removeDisplayedExternalFilter = useCallback(
(key: string) => {
setDisplayedExternalFilters((prev) => prev.filter((f) => f !== key));
},
[setDisplayedExternalFilters]
);

const clearAll = useCallback(() => {
setActiveFilters([]);
setDisplayedExternalFilters([]);
}, [setActiveFilters, setDisplayedExternalFilters]);
}, [setActiveFilters]);

const updateFilter = useCallback(
(columnId: string, value: FilterValue) => {
Expand Down Expand Up @@ -81,9 +67,6 @@ export function DataTableProvider({ children }: { children: React.ReactNode }) {
removeFilter,
sorting,
setSorting,
displayedExternalFilters,
setDisplayedExternalFilters,
removeDisplayedExternalFilter,
}}>
{children}
</DataTableContext.Provider>
Expand Down
2 changes: 1 addition & 1 deletion packages/features/data-table/lib/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export type TextFilterOperator = z.infer<typeof ZTextFilterOperator>;

export const ZSingleSelectFilterValue = z.object({
type: z.literal("single_select"),
data: z.string(),
data: z.union([z.string(), z.number()]),
});

export type SingleSelectFilterValue = z.infer<typeof ZSingleSelectFilterValue>;
Expand Down
Loading

0 comments on commit 2cf0187

Please sign in to comment.