tasko/actions/create-list/index.ts
Ahmad 7578b189ef Optimize performance and reduce bundle sizes
## AI Generated code and Descriptions
Improve website performance and efficiency by reducing bundle sizes and implementing caching strategies.

* **next.config.ts**: Add `compression` middleware to enable gzip compression for responses.
* **Lazy Loading**: Implement lazy loading for images in `app/(platform)/(dashboard)/board/[boardId]/_components/board-update-image.tsx` using the `loading="lazy"` attribute. Add `react-lazyload` library for lazy loading components in `app/(platform)/(dashboard)/board/[boardId]/_components/list-item.tsx` and wrap list items with `LazyLoad` component.
* **Database Query Optimization**: Optimize database queries in `actions/copy-card/index.ts`, `actions/copy-list/index.ts`, `actions/create-board/index.ts`, `actions/create-card/index.ts`, `actions/create-list/index.ts`, `actions/delete-board/index.ts`, `actions/delete-card/index.ts`, `actions/delete-list/index.ts`, `actions/stripe-redirect/index.ts`, `actions/update-board/index.ts`, `actions/update-card-order/index.ts`, `actions/update-card/index.ts`, and `actions/update-list/index.ts` by adding appropriate indexes and using `select` to fetch only required fields.
* **Dependencies**: Update `package.json` to include `compression` and `react-lazyload` dependencies.

---

For more details, open the [Copilot Workspace session](https://copilot-workspace.githubnext.com/ahmadk953/tasko?shareId=XXXX-XXXX-XXXX-XXXX).
2024-12-18 21:06:08 -05:00

67 lines
1.5 KiB
TypeScript

'use server';
import { auth } from '@clerk/nextjs/server';
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 { CreateList } from './schema';
const handler = async (data: InputType): Promise<ReturnType> => {
const { userId, orgId } = await auth();
if (!userId || !orgId) return { error: 'Unauthorized' };
const { title, boardId } = data;
let list;
try {
const board = await db.board.findUnique({
where: {
id: boardId,
orgId,
},
select: {
id: true,
},
});
if (!board) return { error: 'Board not found' };
const lastList = await db.list.findFirst({
where: { boardId: boardId },
orderBy: { order: 'desc' },
select: { order: true },
});
const newOrder = lastList ? lastList.order + 1 : 1;
list = await db.list.create({
data: {
title,
boardId,
order: newOrder,
},
});
await createAuditLog({
entityTitle: list.title,
entityType: ENTITY_TYPE.LIST,
entityId: list.id,
action: ACTION.CREATE,
});
} catch (error) {
return {
error: 'Failed to create list',
};
}
revalidatePath(`/board/${boardId}`);
return { data: list };
};
export const createList = createSafeAction(CreateList, handler);