mirror of
https://github.com/ahmadk953/tasko.git
synced 2025-02-07 11:42:55 +00:00
54 lines
1.2 KiB
TypeScript
54 lines
1.2 KiB
TypeScript
|
"use server";
|
||
|
|
||
|
import { auth } from "@clerk/nextjs";
|
||
|
import { revalidatePath } from "next/cache";
|
||
|
import { ACTION, ENTITY_TYPE } from "@prisma/client";
|
||
|
|
||
|
import { db } from "@/lib/db";
|
||
|
import { createAuditLog } from "@/lib/create-audit-log";
|
||
|
import { createSafeAction } from "@/lib/create-safe-action";
|
||
|
|
||
|
import { InputType, ReturnType } from "./types";
|
||
|
import { UpdateCard } from "./schema";
|
||
|
|
||
|
const handler = async (data: InputType): Promise<ReturnType> => {
|
||
|
const { userId, orgId } = auth();
|
||
|
|
||
|
if (!userId || !orgId) return { error: "Unauthorized" };
|
||
|
|
||
|
const { id, boardId, ...values } = data;
|
||
|
let card;
|
||
|
|
||
|
try {
|
||
|
card = await db.card.update({
|
||
|
where: {
|
||
|
id,
|
||
|
list: {
|
||
|
board: {
|
||
|
orgId,
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
data: {
|
||
|
...values,
|
||
|
},
|
||
|
});
|
||
|
|
||
|
await createAuditLog({
|
||
|
entityTitle: card.title,
|
||
|
entityType: ENTITY_TYPE.CARD,
|
||
|
entityId: card.id,
|
||
|
action: ACTION.UPDATE,
|
||
|
});
|
||
|
} catch (error) {
|
||
|
return {
|
||
|
error: "Failed to update card",
|
||
|
};
|
||
|
}
|
||
|
|
||
|
revalidatePath(`/board/${boardId}`);
|
||
|
return { data: card };
|
||
|
};
|
||
|
|
||
|
export const updateCard = createSafeAction(UpdateCard, handler);
|