refactor: accept multiple work endpoint

This commit is contained in:
Methapon2001 2024-12-16 09:51:25 +07:00
parent ccde80764a
commit 9e43679d0f

View file

@ -18,6 +18,7 @@ import { notFoundError } from "../utils/error";
import { import {
Prisma, Prisma,
RequestDataStatus, RequestDataStatus,
RequestWorkStatus,
TaskOrderStatus, TaskOrderStatus,
TaskStatus, TaskStatus,
UserTaskStatus, UserTaskStatus,
@ -252,6 +253,22 @@ export class TaskController extends Controller {
} }
await permissionCheckCompany(req.user, userAffiliatedBranch); await permissionCheckCompany(req.user, userAffiliatedBranch);
const updated = await tx.requestWorkStepStatus.updateMany({
where: {
OR: taskList,
workStatus: RequestWorkStatus.Ready,
},
data: { workStatus: RequestWorkStatus.InProgress },
});
if (updated.count !== taskList.length) {
throw new HttpError(
HttpStatus.PRECONDITION_FAILED,
"All request work to issue task order must be in ready state.",
"requestWorkMustReady",
);
}
return await tx.taskOrder.create({ return await tx.taskOrder.create({
include: { include: {
taskList: { taskList: {
@ -404,22 +421,29 @@ export class TaskController extends Controller {
@Route("/api/v1/task-order/{taskOrderId}") @Route("/api/v1/task-order/{taskOrderId}")
@Tags("Task Order") @Tags("Task Order")
export class TaskActionController extends Controller { export class TaskActionController extends Controller {
@Post("accept") @Post("accept/bulk")
@Security("keycloak") @Security("keycloak")
async acceptTaskOrder(@Request() req: RequestWithUser, @Path() taskOrderId: string) { async acceptTaskOrderBulk(
const record = await prisma.taskOrder.findFirst({ @Request() req: RequestWithUser,
@Body()
body: {
taskOrderId: string[];
},
) {
const record = await prisma.taskOrder.findMany({
include: { include: {
taskList: { taskList: {
orderBy: { step: "asc" }, orderBy: { step: "asc" },
}, },
}, },
where: { id: taskOrderId }, where: { id: { in: body.taskOrderId } },
}); });
if (!record) throw notFoundError("Task Order"); if (!record) throw notFoundError("Task Order");
await prisma.$transaction([ await prisma.$transaction(async (tx) => {
prisma.taskOrder.update({ const promises = body.taskOrderId.flatMap((taskOrderId) => [
tx.taskOrder.update({
where: { id: taskOrderId }, where: { id: taskOrderId },
data: { data: {
taskOrderStatus: TaskOrderStatus.InProgress, taskOrderStatus: TaskOrderStatus.InProgress,
@ -431,7 +455,7 @@ export class TaskActionController extends Controller {
}, },
}, },
}), }),
prisma.task.updateMany({ tx.task.updateMany({
where: { where: {
taskOrderId: taskOrderId, taskOrderId: taskOrderId,
requestWorkStep: { responsibleUserId: req.user.sub }, requestWorkStep: { responsibleUserId: req.user.sub },
@ -440,7 +464,7 @@ export class TaskActionController extends Controller {
taskStatus: TaskStatus.InProgress, taskStatus: TaskStatus.InProgress,
}, },
}), }),
prisma.requestData.updateMany({ tx.requestData.updateMany({
where: { where: {
requestWork: { requestWork: {
some: { some: {
@ -452,7 +476,7 @@ export class TaskActionController extends Controller {
}, },
data: { requestDataStatus: RequestDataStatus.InProgress }, data: { requestDataStatus: RequestDataStatus.InProgress },
}), }),
prisma.userTask.create({ tx.userTask.create({
data: { data: {
userId: req.user.sub, userId: req.user.sub,
taskOrderId: taskOrderId, taskOrderId: taskOrderId,
@ -460,6 +484,15 @@ export class TaskActionController extends Controller {
}, },
}), }),
]); ]);
await Promise.all(promises);
});
}
@Post("accept")
@Security("keycloak")
async acceptTaskOrder(@Request() req: RequestWithUser, @Path() taskOrderId: string) {
await this.acceptTaskOrderBulk(req, { taskOrderId: [taskOrderId] });
} }
@Post("set-task-status") @Post("set-task-status")