"use client";
import { Card, CardContent } from "@/components/ui/card";
import { Input } from "@/components/ui/input";
import { Badge } from "@/components/ui/badge";
import {
Select,
SelectContent,
SelectItem,
SelectTrigger,
SelectValue,
} from "@/components/ui/select";
import { CategoryFilterCombobox } from "@/components/ui/category-filter-combobox";
import { CategoryIcon } from "@/components/ui/category-icon";
import { Search, X, Filter } from "lucide-react";
import type { Account, Category } from "@/lib/types";
interface TransactionFiltersProps {
searchQuery: string;
onSearchChange: (query: string) => void;
selectedAccount: string;
onAccountChange: (account: string) => void;
selectedCategories: string[];
onCategoriesChange: (categories: string[]) => void;
showReconciled: string;
onReconciledChange: (value: string) => void;
accounts: Account[];
categories: Category[];
}
export function TransactionFilters({
searchQuery,
onSearchChange,
selectedAccount,
onAccountChange,
selectedCategories,
onCategoriesChange,
showReconciled,
onReconciledChange,
accounts,
categories,
}: TransactionFiltersProps) {
return (
onSearchChange("")}
selectedAccount={selectedAccount}
onClearAccount={() => onAccountChange("all")}
selectedCategories={selectedCategories}
onRemoveCategory={(id) => {
const newCategories = selectedCategories.filter((c) => c !== id);
onCategoriesChange(newCategories.length > 0 ? newCategories : ["all"]);
}}
onClearCategories={() => onCategoriesChange(["all"])}
showReconciled={showReconciled}
onClearReconciled={() => onReconciledChange("all")}
accounts={accounts}
categories={categories}
/>
);
}
function ActiveFilters({
searchQuery,
onClearSearch,
selectedAccount,
onClearAccount,
selectedCategories,
onRemoveCategory,
onClearCategories,
showReconciled,
onClearReconciled,
accounts,
categories,
}: {
searchQuery: string;
onClearSearch: () => void;
selectedAccount: string;
onClearAccount: () => void;
selectedCategories: string[];
onRemoveCategory: (id: string) => void;
onClearCategories: () => void;
showReconciled: string;
onClearReconciled: () => void;
accounts: Account[];
categories: Category[];
}) {
const hasSearch = searchQuery.trim() !== "";
const hasAccount = selectedAccount !== "all";
const hasCategories = !selectedCategories.includes("all");
const hasReconciled = showReconciled !== "all";
const hasActiveFilters = hasSearch || hasAccount || hasCategories || hasReconciled;
if (!hasActiveFilters) return null;
const account = accounts.find((a) => a.id === selectedAccount);
const selectedCats = categories.filter((c) => selectedCategories.includes(c.id));
const isUncategorized = selectedCategories.includes("uncategorized");
const clearAll = () => {
onClearSearch();
onClearAccount();
onClearCategories();
onClearReconciled();
};
return (
{hasSearch && (
Recherche: "{searchQuery}"
)}
{hasAccount && account && (
Compte: {account.name}
)}
{isUncategorized && (
Non catégorisé
)}
{selectedCats.map((cat) => (
{cat.name}
))}
{hasReconciled && (
{showReconciled === "reconciled" ? "Pointées" : "Non pointées"}
)}
);
}