From 5d727fc528754d45d32f224ec9265d66cf0f63b8 Mon Sep 17 00:00:00 2001 From: Joao Correia Date: Thu, 30 Jan 2025 11:07:13 +0000 Subject: [PATCH] implement delete workflow --- .../api/approval-workflows/[id]/index.ts | 27 +++++++++++++++++++ src/pages/approval-workflows/index.tsx | 18 ++++++++----- src/utils/approval.workflows.be.ts | 10 ++++--- 3 files changed, 45 insertions(+), 10 deletions(-) create mode 100644 src/pages/api/approval-workflows/[id]/index.ts diff --git a/src/pages/api/approval-workflows/[id]/index.ts b/src/pages/api/approval-workflows/[id]/index.ts new file mode 100644 index 00000000..16efab91 --- /dev/null +++ b/src/pages/api/approval-workflows/[id]/index.ts @@ -0,0 +1,27 @@ +// Next.js API route support: https://nextjs.org/docs/api-routes/introduction +import { ApprovalWorkflow } from "@/interfaces/approval.workflow"; +import { sessionOptions } from "@/lib/session"; +import { requestUser } from "@/utils/api"; +import { createApprovalWorkflows, deleteApprovalWorkflow, updateApprovalWorkflow } from "@/utils/approval.workflows.be"; +import { withIronSessionApiRoute } from "iron-session/next"; +import type { NextApiRequest, NextApiResponse } from "next"; + +export default withIronSessionApiRoute(handler, sessionOptions); + +async function handler(req: NextApiRequest, res: NextApiResponse) { + if (req.method === "DELETE") return await del(req, res); +} + +async function del(req: NextApiRequest, res: NextApiResponse) { + const user = await requestUser(req, res); + if (!user) return res.status(401).json({ ok: false }); + + if (!["admin", "developer", "corporate", "mastercorporate"].includes(user.type)) { + return res.status(403).json({ ok: false }); + } + + const { id } = req.query as { id?: string }; + + if (id) + return res.status(200).json(await deleteApprovalWorkflow(id)); +} diff --git a/src/pages/approval-workflows/index.tsx b/src/pages/approval-workflows/index.tsx index a109fd52..ac042851 100644 --- a/src/pages/approval-workflows/index.tsx +++ b/src/pages/approval-workflows/index.tsx @@ -113,33 +113,33 @@ export default function ApprovalWorkflows({ user, workflows, workflowsAssignees, useEffect(() => { const filters: Array<(workflow: ApprovalWorkflow) => boolean> = []; - + if (statusFilter && statusFilter !== undefined) { const statusOption = STATUS_OPTIONS.find((x) => x.value === statusFilter); if (statusOption && statusOption.filter) { filters.push(statusOption.filter); } } - + if (entityFilter && entityFilter !== undefined) { const entityOption = ENTITY_OPTIONS.find((x) => x.value === entityFilter); if (entityOption && entityOption.filter) { filters.push(entityOption.filter); } } - + if (nameFilter.trim() !== "") { const nameFilterFunction = (workflow: ApprovalWorkflow) => workflow.name.toLowerCase().includes(nameFilter.toLowerCase()); filters.push(nameFilterFunction); } - + // Apply all filters const filtered = workflows.filter(workflow => filters.every(filterFn => filterFn(workflow))); setFilteredWorkflows(filtered); // eslint-disable-next-line react-hooks/exhaustive-deps }, [workflows, statusFilter, entityFilter, nameFilter]); - + const handleNameFilterChange = (name: ApprovalWorkflow["name"]) => { setNameFilter(name); @@ -150,7 +150,12 @@ export default function ApprovalWorkflows({ user, workflows, workflowsAssignees, axios .delete(`/api/approval-workflows/${id}`) - .then(() => toast.success(`Deleted ${name} Approval Workflow.`)) + .then(() => { + toast.success(`Successfully deleted ${name} Approval Workflow.`); + setTimeout(() => { + window.location.reload(); + }, 2000); + }) .catch((reason) => { if (reason.response.status === 404) { toast.error("Approval Workflow not found!"); @@ -164,7 +169,6 @@ export default function ApprovalWorkflows({ user, workflows, workflowsAssignees, toast.error("Something went wrong, please try again later."); }) - /* .finally(reload); */ }; const columns = [ diff --git a/src/utils/approval.workflows.be.ts b/src/utils/approval.workflows.be.ts index b163e9d0..a09489a2 100644 --- a/src/utils/approval.workflows.be.ts +++ b/src/utils/approval.workflows.be.ts @@ -15,14 +15,18 @@ export const getApprovalWorkflow = async (id: string) => { }; export const createApprovalWorkflow = async (workflow: ApprovalWorkflow) => { - await db.collection("approval-workflows").insertOne(workflow); + return await db.collection("approval-workflows").insertOne(workflow); }; export const createApprovalWorkflows = async (workflows: ApprovalWorkflow[]) => { if (workflows.length === 0) return; - await db.collection("approval-workflows").insertMany(workflows); + return await db.collection("approval-workflows").insertMany(workflows); }; export const updateApprovalWorkflow = async (id: string, workflow: ApprovalWorkflow) => { - await db.collection("approval-workflows").replaceOne({ id }, workflow); + return await db.collection("approval-workflows").replaceOne({ id }, workflow); }; + +export const deleteApprovalWorkflow = async (id: string) => { + return await db.collection("approval-workflows").deleteOne({ id }); +}; \ No newline at end of file