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

97 行
2.9 KiB

  1. "use client";
  2. import { TaskTemplate } from "@/app/api/tasks";
  3. import React, { useCallback, 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 { useRouter, useSearchParams } from "next/navigation";
  9. import DeleteIcon from '@mui/icons-material/Delete';
  10. import { deleteDialog, successDialog } from "../Swal/CustomAlerts";
  11. import { deleteTaskTemplate } from "@/app/api/tasks/actions";
  12. interface Props {
  13. taskTemplates: TaskTemplate[];
  14. }
  15. type SearchQuery = Partial<Omit<TaskTemplate, "id">>;
  16. type SearchParamNames = keyof SearchQuery;
  17. const TaskTemplateSearch: React.FC<Props> = ({ taskTemplates }) => {
  18. const { t } = useTranslation("tasks");
  19. const searchParams = useSearchParams()
  20. const router = useRouter()
  21. const [filteredTemplates, setFilteredTemplates] = useState(taskTemplates);
  22. const searchCriteria: Criterion<SearchParamNames>[] = useMemo(
  23. () => [
  24. { label: t("Task Template Code"), paramName: "code", type: "text" },
  25. { label: t("Task Template Name"), paramName: "name", type: "text" },
  26. ],
  27. [t],
  28. );
  29. const onReset = useCallback(() => {
  30. setFilteredTemplates(taskTemplates);
  31. }, [taskTemplates]);
  32. const onTaskClick = useCallback((taskTemplate: TaskTemplate) => {
  33. const params = new URLSearchParams(searchParams.toString())
  34. params.set("id", taskTemplate.id.toString())
  35. router.replace(`/tasks/edit?${params.toString()}`);
  36. }, []);
  37. const onDeleteClick = useCallback((taskTemplate: TaskTemplate) => {
  38. deleteDialog(async () => {
  39. await deleteTaskTemplate(taskTemplate.id)
  40. successDialog(t("Delete Success"), t)
  41. setFilteredTemplates((prev) => prev.filter((obj) => obj.id !== taskTemplate.id))
  42. }, t)
  43. }, []);
  44. const columns = useMemo<Column<TaskTemplate>[]>(
  45. () => [
  46. {
  47. name: "id",
  48. label: t("Details"),
  49. onClick: onTaskClick,
  50. buttonIcon: <EditNote />,
  51. },
  52. { name: "code", label: t("Task Template Code") },
  53. { name: "name", label: t("Task Template 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. setFilteredTemplates(
  70. taskTemplates.filter(
  71. (task) =>
  72. task.code.toLowerCase().includes(query.code.toLowerCase()) &&
  73. task.name.toLowerCase().includes(query.name.toLowerCase()),
  74. ),
  75. );
  76. }}
  77. onReset={onReset}
  78. />
  79. <SearchResults items={filteredTemplates} columns={columns} />
  80. </>
  81. );
  82. };
  83. export default TaskTemplateSearch;