"use client"; import { Claim, ClaimSearchForm } from "@/app/api/claims"; import React, { useCallback, useMemo, useState } from "react"; import SearchBox, { Criterion } from "../SearchBox/index"; import { useTranslation } from "react-i18next"; import SearchResults, { Column } from "../SearchResults/index"; import EditNote from "@mui/icons-material/EditNote"; import { dateInRange } from "@/app/utils/commonUtil"; import { claimStatusCombo, expenseTypeCombo } from "@/app/utils/comboUtil"; import { convertDateArrayToString, convertDateToString } from "@/app/utils/formatUtil"; interface Props { claims: Claim[]; } type SearchQuery = Partial>; type SearchParamNames = keyof SearchQuery; const ClaimSearch: React.FC = ({ claims }) => { const { t } = useTranslation(); console.log(claims) // If claim searching is done on the server-side, then no need for this. const [filteredClaims, setFilteredClaims] = useState(claims); const searchCriteria: Criterion[] = useMemo( () => [ { label: t("Creation Date From"), label2: t("Creation Date To"), paramName: "created", type: "dateRange" }, // { label: t("Related Project Name"), paramName: "name", type: "text" }, { label: t("Expense Type"), paramName: "type", type: "select", options: expenseTypeCombo, }, { label: t("Status"), paramName: "status", type: "select", options: claimStatusCombo, }, ], [t], ); const onClaimClick = useCallback((claim: Claim) => { console.log(claim); }, []); const columns = useMemo[]>( () => [ // { // name: "action", // label: t("Actions"), // onClick: onClaimClick, // buttonIcon: , // }, { name: "created", label: t("Creation Date"), type: "date" }, { name: "code", label: t("Claim Code") }, // { name: "project", label: t("Related Project Name") }, { name: "amount", label: t("Amount"), type: "money" }, { name: "type", label: t("Expense Type"), needTranslation: true }, { name: "status", label: t("Status"), needTranslation: true }, { name: "remarks", label: t("Remarks") }, ], [t, onClaimClick], ); return ( <> { setFilteredClaims( claims.filter( (claim) => dateInRange(convertDateArrayToString(claim.created, "YYYY-MM-DD")!!, query.created, query.createdTo ?? undefined) && // claim.project.name.toLowerCase().includes(query.name.toLowerCase()) && (claim.type.toLowerCase().includes(query.type.toLowerCase()) || query.type.toLowerCase() === "all") && (claim.status.toLowerCase().includes(query.status.toLowerCase()) || query.status.toLowerCase() === "all") ), ); }} /> items={filteredClaims} columns={columns} /> ); }; export default ClaimSearch;