FPSMS-frontend
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

71 lines
2.0 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. interface Props {
  9. taskTemplates: TaskTemplate[];
  10. }
  11. type SearchQuery = Partial<Omit<TaskTemplate, "id">>;
  12. type SearchParamNames = keyof SearchQuery;
  13. const TaskTemplateSearch: React.FC<Props> = ({ taskTemplates }) => {
  14. const { t } = useTranslation("tasks");
  15. const [filteredTemplates, setFilteredTemplates] = useState(taskTemplates);
  16. const searchCriteria: Criterion<SearchParamNames>[] = useMemo(
  17. () => [
  18. { label: t("Task Template Code"), paramName: "code", type: "text" },
  19. { label: t("Task Template Name"), paramName: "name", type: "text" },
  20. ],
  21. [t],
  22. );
  23. const onReset = useCallback(() => {
  24. setFilteredTemplates(taskTemplates);
  25. }, [taskTemplates]);
  26. const onTaskClick = useCallback((taskTemplate: TaskTemplate) => {
  27. console.log(taskTemplate);
  28. }, []);
  29. const columns = useMemo<Column<TaskTemplate>[]>(
  30. () => [
  31. {
  32. name: "id",
  33. label: t("Details"),
  34. onClick: onTaskClick,
  35. buttonIcon: <EditNote />,
  36. },
  37. { name: "code", label: t("Task Template Code") },
  38. { name: "name", label: t("Task Template Name") },
  39. ],
  40. [onTaskClick, t],
  41. );
  42. return (
  43. <>
  44. <SearchBox
  45. criteria={searchCriteria}
  46. onSearch={(query) => {
  47. setFilteredTemplates(
  48. taskTemplates.filter(
  49. (task) =>
  50. task.code.toLowerCase().includes(query.code.toLowerCase()) &&
  51. task.name.toLowerCase().includes(query.name.toLowerCase()),
  52. ),
  53. );
  54. }}
  55. onReset={onReset}
  56. />
  57. <SearchResults items={filteredTemplates} columns={columns} />
  58. </>
  59. );
  60. };
  61. export default TaskTemplateSearch;