"use client";
import { Html5QrcodeResult, Html5QrcodeScanner, QrcodeErrorCallback, QrcodeSuccessCallback } from "html5-qrcode";
import React, { useCallback, useEffect, useMemo, useState } from "react";
import SearchBox, { Criterion } from "../SearchBox";
import { useTranslation } from "react-i18next";
import SearchResults, { Column } from "../SearchResults";
import EditNote from "@mui/icons-material/EditNote";
import { QcItemResult } from "@/app/api/settings/qcItem";
import { usePathname, useRouter } from "next/navigation";
import QrCodeScanner from "../QrCodeScanner";
import { Button } from "@mui/material";
import { Delete } from "@mui/icons-material";
import { deleteDialog, successDialog } from "../Swal/CustomAlerts";
import { deleteQcItem } from "@/app/api/settings/qcItem/actions";
interface Props {
qcItems: QcItemResult[];
}
type SearchQuery = Partial>;
type SearchParamNames = keyof SearchQuery;
const qcItemSearch: React.FC = ({ qcItems }) => {
const { t } = useTranslation("qcItems");
const router = useRouter();
const pathname = usePathname()
// If qcItem searching is done on the server-side, then no need for this.
const [filteredQcItems, setFilteredQcItems] = useState(qcItems);
const searchCriteria: Criterion[] = useMemo(
() => [
{ label: t("Code"), paramName: "code", type: "text" },
{ label: t("Name"), paramName: "name", type: "text" },
],
[t]
);
const onReset = useCallback(
() => {
setFilteredQcItems(qcItems);
}, [qcItems]
);
const onQcItemClick = useCallback(
(qcItem: QcItemResult) => {
router.push(`${pathname}/edit?id=${qcItem.id}`);
},
[router]
);
const handleDelete = useCallback(
(qcItem: QcItemResult) => {
deleteDialog(async () => {
qcItems = await deleteQcItem(qcItem.id);
setFilteredQcItems(qcItems)
await successDialog(
t("Delete Success"),
t
);
}, t);
}, [])
const columns = useMemo[]>(
() => [
{
name: "id",
label: t("Details"),
onClick: onQcItemClick,
buttonIcon: ,
},
{ name: "code", label: t("Code") },
{ name: "name", label: t("Name") },
{
name: "id",
label: t("Delete"),
onClick: handleDelete,
buttonIcon: ,
buttonColor: "error"
}
],
[t, onQcItemClick]
);
// const [isOpenScanner, setOpenScanner] = useState(false)
// const onOpenScanner = useCallback(() => {
// setOpenScanner(true)
// }, [])
// const onCloseScanner = useCallback(() => {
// setOpenScanner(false)
// }, [])
// const handleScanSuccess = useCallback((result: string) => {
// console.log(result)
// }, [])
return (
<>
{/*
*/}
{
setFilteredQcItems(
qcItems.filter(
(qi) =>
qi.code.toLowerCase().includes(query.code.toLowerCase()) &&
qi.name.toLowerCase().includes(query.name.toLowerCase())
)
);
}}
onReset={onReset}
/>
items={filteredQcItems} columns={columns} />
>
)
};
export default qcItemSearch;