FPSMS-frontend
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 

122 Zeilen
3.4 KiB

  1. "use client";
  2. import { Html5QrcodeResult, Html5QrcodeScanner, QrcodeErrorCallback, QrcodeSuccessCallback } from "html5-qrcode";
  3. import React, { useCallback, useEffect, useMemo, useState } from "react";
  4. import SearchBox, { Criterion } from "../SearchBox";
  5. import { useTranslation } from "react-i18next";
  6. import SearchResults, { Column } from "../SearchResults";
  7. import EditNote from "@mui/icons-material/EditNote";
  8. import { QcItemResult } from "@/app/api/settings/qcItem";
  9. import { usePathname, useRouter } from "next/navigation";
  10. import QrCodeScanner from "../QrCodeScanner";
  11. import { Button } from "@mui/material";
  12. import { Delete } from "@mui/icons-material";
  13. import { deleteDialog, successDialog } from "../Swal/CustomAlerts";
  14. import { deleteQcItem } from "@/app/api/settings/qcItem/actions";
  15. interface Props {
  16. qcItems: QcItemResult[];
  17. }
  18. type SearchQuery = Partial<Omit<QcItemResult, "id">>;
  19. type SearchParamNames = keyof SearchQuery;
  20. const qcItemSearch: React.FC<Props> = ({ qcItems }) => {
  21. const { t } = useTranslation("qcItems");
  22. const router = useRouter();
  23. const pathname = usePathname()
  24. // If qcItem searching is done on the server-side, then no need for this.
  25. const [filteredQcItems, setFilteredQcItems] = useState(qcItems);
  26. const searchCriteria: Criterion<SearchParamNames>[] = useMemo(
  27. () => [
  28. { label: t("Code"), paramName: "code", type: "text" },
  29. { label: t("Name"), paramName: "name", type: "text" },
  30. ],
  31. [t]
  32. );
  33. const onReset = useCallback(
  34. () => {
  35. setFilteredQcItems(qcItems);
  36. }, [qcItems]
  37. );
  38. const onQcItemClick = useCallback(
  39. (qcItem: QcItemResult) => {
  40. router.push(`${pathname}/edit?id=${qcItem.id}`);
  41. },
  42. [router]
  43. );
  44. const handleDelete = useCallback(
  45. (qcItem: QcItemResult) => {
  46. deleteDialog(async () => {
  47. qcItems = await deleteQcItem(qcItem.id);
  48. setFilteredQcItems(qcItems)
  49. await successDialog(
  50. t("Delete Success"),
  51. t
  52. );
  53. }, t);
  54. }, [])
  55. const columns = useMemo<Column<QcItemResult>[]>(
  56. () => [
  57. {
  58. name: "id",
  59. label: t("Details"),
  60. onClick: onQcItemClick,
  61. buttonIcon: <EditNote />,
  62. },
  63. { name: "code", label: t("Code") },
  64. { name: "name", label: t("Name") },
  65. {
  66. name: "id",
  67. label: t("Delete"),
  68. onClick: handleDelete,
  69. buttonIcon: <Delete />,
  70. buttonColor: "error"
  71. }
  72. ],
  73. [t, onQcItemClick]
  74. );
  75. // const [isOpenScanner, setOpenScanner] = useState(false)
  76. // const onOpenScanner = useCallback(() => {
  77. // setOpenScanner(true)
  78. // }, [])
  79. // const onCloseScanner = useCallback(() => {
  80. // setOpenScanner(false)
  81. // }, [])
  82. // const handleScanSuccess = useCallback((result: string) => {
  83. // console.log(result)
  84. // }, [])
  85. return (
  86. <>
  87. {/* <QrCodeScanner isOpen={isOpenScanner} onClose={onCloseScanner} onScanSuccess={handleScanSuccess} />
  88. <Button onClick={onOpenScanner}>abc</Button> */}
  89. <SearchBox
  90. criteria={searchCriteria}
  91. onSearch={(query) => {
  92. setFilteredQcItems(
  93. qcItems.filter(
  94. (qi) =>
  95. qi.code.toLowerCase().includes(query.code.toLowerCase()) &&
  96. qi.name.toLowerCase().includes(query.name.toLowerCase())
  97. )
  98. );
  99. }}
  100. onReset={onReset}
  101. />
  102. <SearchResults<QcItemResult> items={filteredQcItems} columns={columns} />
  103. </>
  104. )
  105. };
  106. export default qcItemSearch;