您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 

96 行
3.2 KiB

  1. "use client";
  2. import React, { useCallback, useMemo, useState } from "react";
  3. import SearchBox, { Criterion } from "../SearchBox";
  4. import { useTranslation } from "react-i18next";
  5. import SearchResults, { Column } from "../SearchResults";
  6. import EditNote from "@mui/icons-material/EditNote";
  7. import DeleteIcon from '@mui/icons-material/Delete';
  8. import { useRouter, useSearchParams } from "next/navigation";
  9. import { deleteDialog, successDialog } from "../Swal/CustomAlerts";
  10. import { Subsidiary } from "@/app/api/subsidiary";
  11. import { deleteSubsidiary } from "@/app/api/subsidiary/actions";
  12. interface Props {
  13. subsidiaries: Subsidiary[];
  14. }
  15. type SearchQuery = Partial<Omit<Subsidiary, "id">>;
  16. type SearchParamNames = keyof SearchQuery;
  17. const SubsidiarySearch: React.FC<Props> = ({ subsidiaries }) => {
  18. const { t } = useTranslation();
  19. const router = useRouter()
  20. const searchParams = useSearchParams()
  21. const [filteredSubsidiaries, setFilteredSubsidiaries] = useState(subsidiaries);
  22. const searchCriteria: Criterion<SearchParamNames>[] = useMemo(
  23. () => [
  24. { label: t("Subsidiary Code"), paramName: "code", type: "text" },
  25. { label: t("Subsidiary Name"), paramName: "name", type: "text" },
  26. ],
  27. [t],
  28. );
  29. const onReset = useCallback(() => {
  30. setFilteredSubsidiaries(subsidiaries);
  31. }, [subsidiaries]);
  32. const onTaskClick = useCallback((subsidiary: Subsidiary) => {
  33. const params = new URLSearchParams(searchParams.toString())
  34. params.set("id", subsidiary.id.toString())
  35. router.replace(`/settings/subsidiary/edit?${params.toString()}`);
  36. }, []);
  37. const onDeleteClick = useCallback((subsidiary: Subsidiary) => {
  38. deleteDialog(async() => {
  39. await deleteSubsidiary(subsidiary.id)
  40. successDialog("Delete Success", t)
  41. setFilteredSubsidiaries((prev) => prev.filter((obj) => obj.id !== subsidiary.id))
  42. }, t)
  43. }, []);
  44. const columns = useMemo<Column<Subsidiary>[]>(
  45. () => [
  46. {
  47. name: "id",
  48. label: t("Details"),
  49. onClick: onTaskClick,
  50. buttonIcon: <EditNote />,
  51. },
  52. { name: "code", label: t("Subsidiary Code") },
  53. { name: "name", label: t("Subsidiary Name") },
  54. {
  55. name: "id",
  56. label: t("Delete"),
  57. onClick: onDeleteClick,
  58. buttonIcon: <DeleteIcon />,
  59. color: "error"
  60. },
  61. ],
  62. [onTaskClick, t],
  63. );
  64. return (
  65. <>
  66. <SearchBox
  67. criteria={searchCriteria}
  68. onSearch={(query) => {
  69. setFilteredSubsidiaries(
  70. subsidiaries.filter(
  71. (subsidiary) =>
  72. subsidiary.code.toLowerCase().includes(query.code.toLowerCase()) &&
  73. subsidiary.name.toLowerCase().includes(query.name.toLowerCase()),
  74. ),
  75. );
  76. }}
  77. onReset={onReset}
  78. />
  79. <SearchResults items={filteredSubsidiaries} columns={columns} />
  80. </>
  81. );
  82. };
  83. export default SubsidiarySearch;