2024-02-16 01:49:19 +00:00
|
|
|
'use server';
|
2024-02-15 02:30:10 +00:00
|
|
|
|
2024-03-21 21:15:27 +00:00
|
|
|
import { auth } from '@clerk/nextjs/server';
|
2024-02-16 01:49:19 +00:00
|
|
|
import { revalidatePath } from 'next/cache';
|
|
|
|
import { ACTION, ENTITY_TYPE } from '@prisma/client';
|
2024-02-15 02:30:10 +00:00
|
|
|
|
2024-02-16 01:49:19 +00:00
|
|
|
import { db } from '@/lib/db';
|
|
|
|
import { createAuditLog } from '@/lib/create-audit-log';
|
|
|
|
import { createSafeAction } from '@/lib/create-safe-action';
|
2024-02-15 02:30:10 +00:00
|
|
|
|
2024-02-16 01:49:19 +00:00
|
|
|
import { InputType, ReturnType } from './types';
|
|
|
|
import { DeleteCard } from './schema';
|
2024-02-15 02:30:10 +00:00
|
|
|
|
|
|
|
const handler = async (data: InputType): Promise<ReturnType> => {
|
|
|
|
const { userId, orgId } = auth();
|
|
|
|
|
2024-02-16 01:49:19 +00:00
|
|
|
if (!userId || !orgId) return { error: 'Unauthorized' };
|
2024-02-15 02:30:10 +00:00
|
|
|
|
|
|
|
const { id, boardId } = data;
|
|
|
|
let card;
|
|
|
|
|
|
|
|
try {
|
|
|
|
card = await db.card.delete({
|
|
|
|
where: {
|
|
|
|
id,
|
|
|
|
list: {
|
|
|
|
board: {
|
|
|
|
orgId,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
await createAuditLog({
|
|
|
|
entityTitle: card.title,
|
|
|
|
entityType: ENTITY_TYPE.CARD,
|
|
|
|
entityId: card.id,
|
|
|
|
action: ACTION.DELETE,
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
return {
|
2024-02-16 01:49:19 +00:00
|
|
|
error: 'Failed to delete card',
|
2024-02-15 02:30:10 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
revalidatePath(`/board/${boardId}`);
|
|
|
|
return { data: card };
|
|
|
|
};
|
|
|
|
|
|
|
|
export const deleteCard = createSafeAction(DeleteCard, handler);
|