|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- "use client";
-
- import SearchBox, { Criterion } from "../SearchBox";
- import { useCallback, useMemo, useState, useEffect } from "react";
- import { useTranslation } from "react-i18next";
- import SearchResults, { Column } from "../SearchResults/index";
- import EditNote from "@mui/icons-material/EditNote";
- import DeleteIcon from "@mui/icons-material/Delete";
- import { useRouter } from "next/navigation";
- import { deleteDialog, successDialog } from "../Swal/CustomAlerts";
- import { PrinterResult } from "@/app/api/settings/printer";
- import { deletePrinter } from "@/app/api/settings/printer/actions";
- import PrinterSearchLoading from "./PrinterSearchLoading";
-
- interface Props {
- printers: PrinterResult[];
- }
-
- type SearchQuery = Partial<Omit<PrinterResult, "id">>;
- type SearchParamNames = keyof SearchQuery;
-
- const PrinterSearch: React.FC<Props> = ({ printers }) => {
- const { t } = useTranslation("common");
- const [filteredPrinters, setFilteredPrinters] = useState(printers);
- const [pagingController, setPagingController] = useState({
- pageNum: 1,
- pageSize: 10,
- });
- const router = useRouter();
- const [isSearching, setIsSearching] = useState(false);
-
- useEffect(() => {
- console.log("Printers prop changed:", printers);
- setFilteredPrinters(printers);
- }, [printers]);
-
- const searchCriteria: Criterion<SearchParamNames>[] = useMemo(
- () => [
- {
- label: t("Name"),
- paramName: "name",
- type: "text",
- },
- {
- label: "IP",
- paramName: "ip",
- type: "text",
- },
- {
- label: t("Type"),
- paramName: "type",
- type: "text",
- },
- ],
- [t],
- );
-
- const onPrinterClick = useCallback(
- (printer: PrinterResult) => {
- console.log(printer);
- router.push(`/settings/printer/edit?id=${printer.id}`);
- },
- [router],
- );
-
- const onDeleteClick = useCallback((printer: PrinterResult) => {
- deleteDialog(async () => {
- try {
- console.log("Deleting printer with id:", printer.id);
- const result = await deletePrinter(printer.id);
- console.log("Delete result:", result);
-
- setFilteredPrinters(prev => prev.filter(p => p.id !== printer.id));
-
- router.refresh();
-
- setTimeout(() => {
- successDialog(t("Delete Success") || "刪除成功", t);
- }, 100);
- } catch (error) {
- console.error("Failed to delete printer:", error);
- const errorMessage = error instanceof Error ? error.message : (t("Delete Failed") || "刪除失敗");
- alert(errorMessage);
- router.refresh();
- }
- }, t);
- }, [t, router]);
-
- const columns = useMemo<Column<PrinterResult>[]>(
- () => [
- {
- name: "action",
- label: t("Edit"),
- onClick: onPrinterClick,
- buttonIcon: <EditNote />,
- sx: { width: "10%", minWidth: "80px" },
- },
- {
- name: "name",
- label: t("Name"),
- align: "left",
- headerAlign: "left",
- sx: { width: "20%", minWidth: "120px" },
- },
- {
- name: "description",
- label: t("Description"),
- align: "left",
- headerAlign: "left",
- sx: { width: "20%", minWidth: "140px" },
- },
- {
- name: "ip",
- label: "IP",
- align: "left",
- headerAlign: "left",
- sx: { width: "15%", minWidth: "100px" },
- },
- {
- name: "port",
- label: "Port",
- align: "left",
- headerAlign: "left",
- sx: { width: "10%", minWidth: "80px" },
- },
- {
- name: "type",
- label: t("Type"),
- align: "left",
- headerAlign: "left",
- sx: { width: "15%", minWidth: "100px" },
- },
- {
- name: "dpi",
- label: "DPI",
- align: "left",
- headerAlign: "left",
- sx: { width: "10%", minWidth: "80px" },
- },
- {
- name: "action",
- label: t("Delete"),
- onClick: onDeleteClick,
- buttonIcon: <DeleteIcon />,
- color: "error",
- sx: { width: "10%", minWidth: "80px" },
- },
- ],
- [t, onPrinterClick, onDeleteClick],
- );
-
- console.log("PrinterSearch render - filteredPrinters:", filteredPrinters);
- console.log("PrinterSearch render - printers prop:", printers);
-
- return (
- <>
- <SearchBox
- criteria={searchCriteria}
- onReset={() => {
- setFilteredPrinters(printers);
- setPagingController({ pageNum: 1, pageSize: pagingController.pageSize });
- }}
- onSearch={async (query) => {
- setIsSearching(true);
- try {
- let results: PrinterResult[] = printers;
-
- if (query.name && query.name.trim()) {
- results = results.filter((printer) =>
- printer.name?.toLowerCase().includes(query.name?.toLowerCase() || "")
- );
- }
-
- if (query.ip && query.ip.trim()) {
- results = results.filter((printer) =>
- printer.ip?.toLowerCase().includes(query.ip?.toLowerCase() || "")
- );
- }
-
- if (query.type && query.type.trim()) {
- results = results.filter((printer) =>
- printer.type?.toLowerCase().includes(query.type?.toLowerCase() || "")
- );
- }
-
- setFilteredPrinters(results);
- setPagingController({ pageNum: 1, pageSize: pagingController.pageSize });
- } catch (error) {
- console.error("Error searching printers:", error);
- setFilteredPrinters(printers);
- } finally {
- setIsSearching(false);
- }
- }}
- />
- <SearchResults<PrinterResult>
- items={filteredPrinters}
- columns={columns}
- pagingController={pagingController}
- setPagingController={setPagingController}
- />
- </>
- );
- };
-
- export default PrinterSearch;
|