10.4 공지/배너 등록 및 노출 설정 o
This commit is contained in:
23
src/app/api/admin/banners/[id]/route.ts
Normal file
23
src/app/api/admin/banners/[id]/route.ts
Normal file
@@ -0,0 +1,23 @@
|
||||
import { NextResponse } from "next/server";
|
||||
import prisma from "@/lib/prisma";
|
||||
|
||||
export async function PATCH(req: Request, context: { params: Promise<{ id: string }> }) {
|
||||
const { id } = await context.params;
|
||||
const body = await req.json().catch(() => ({}));
|
||||
const data: any = {};
|
||||
for (const k of ["title", "imageUrl", "linkUrl", "active", "sortOrder", "startAt", "endAt"]) {
|
||||
if (k in body) data[k] = body[k];
|
||||
}
|
||||
if (data.startAt) data.startAt = new Date(data.startAt);
|
||||
if (data.endAt) data.endAt = new Date(data.endAt);
|
||||
const banner = await prisma.banner.update({ where: { id }, data });
|
||||
return NextResponse.json({ banner });
|
||||
}
|
||||
|
||||
export async function DELETE(_: Request, context: { params: Promise<{ id: string }> }) {
|
||||
const { id } = await context.params;
|
||||
await prisma.banner.delete({ where: { id } });
|
||||
return NextResponse.json({ ok: true });
|
||||
}
|
||||
|
||||
|
||||
28
src/app/api/admin/banners/route.ts
Normal file
28
src/app/api/admin/banners/route.ts
Normal file
@@ -0,0 +1,28 @@
|
||||
import { NextResponse } from "next/server";
|
||||
import prisma from "@/lib/prisma";
|
||||
import { z } from "zod";
|
||||
|
||||
export async function GET() {
|
||||
const banners = await prisma.banner.findMany({ orderBy: [{ active: "desc" }, { sortOrder: "asc" }, { createdAt: "desc" }] });
|
||||
return NextResponse.json({ banners });
|
||||
}
|
||||
|
||||
const createSchema = z.object({
|
||||
title: z.string().min(1),
|
||||
imageUrl: z.string().url(),
|
||||
linkUrl: z.string().url().optional(),
|
||||
active: z.boolean().optional(),
|
||||
sortOrder: z.coerce.number().int().optional(),
|
||||
startAt: z.coerce.date().optional(),
|
||||
endAt: z.coerce.date().optional(),
|
||||
});
|
||||
|
||||
export async function POST(req: Request) {
|
||||
const body = await req.json().catch(() => ({}));
|
||||
const parsed = createSchema.safeParse(body);
|
||||
if (!parsed.success) return NextResponse.json({ error: parsed.error.flatten() }, { status: 400 });
|
||||
const banner = await prisma.banner.create({ data: parsed.data });
|
||||
return NextResponse.json({ banner }, { status: 201 });
|
||||
}
|
||||
|
||||
|
||||
19
src/app/api/banners/route.ts
Normal file
19
src/app/api/banners/route.ts
Normal file
@@ -0,0 +1,19 @@
|
||||
import { NextResponse } from "next/server";
|
||||
import prisma from "@/lib/prisma";
|
||||
|
||||
export async function GET() {
|
||||
const now = new Date();
|
||||
const banners = await prisma.banner.findMany({
|
||||
where: {
|
||||
active: true,
|
||||
AND: [
|
||||
{ OR: [{ startAt: null }, { startAt: { lte: now } }] },
|
||||
{ OR: [{ endAt: null }, { endAt: { gte: now } }] },
|
||||
],
|
||||
},
|
||||
orderBy: [{ sortOrder: "asc" }, { createdAt: "desc" }],
|
||||
});
|
||||
return NextResponse.json({ banners });
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user