8.8 제휴업소 요청: 요청 생성/승인/상태 관리/이력 o

This commit is contained in:
koreacomp5
2025-10-09 17:45:34 +09:00
parent 66a68c2bfa
commit 8f4446a87a
7 changed files with 93 additions and 2 deletions

View File

@@ -0,0 +1,12 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
export async function POST(_: Request, context: { params: Promise<{ id: string }> }) {
const { id } = await context.params;
const reqItem = await prisma.partnerRequest.update({ where: { id }, data: { status: "approved", approvedAt: new Date() } });
// 승인 시 실제 파트너 등록
await prisma.partner.create({ data: { name: reqItem.name, category: reqItem.category, latitude: reqItem.latitude, longitude: reqItem.longitude, address: reqItem.address ?? undefined } });
return NextResponse.json({ request: reqItem });
}

View File

@@ -0,0 +1,20 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
import { z } from "zod";
const schema = z.object({ name: z.string().min(1), category: z.string().min(1), latitude: z.coerce.number(), longitude: z.coerce.number(), address: z.string().optional(), contact: z.string().optional() });
export async function POST(req: Request) {
const body = await req.json().catch(() => ({}));
const parsed = schema.safeParse(body);
if (!parsed.success) return NextResponse.json({ error: parsed.error.flatten() }, { status: 400 });
const created = await prisma.partnerRequest.create({ data: parsed.data });
return NextResponse.json({ request: created }, { status: 201 });
}
export async function GET() {
const items = await prisma.partnerRequest.findMany({ orderBy: { createdAt: "desc" } });
return NextResponse.json({ requests: items });
}

View File

@@ -0,0 +1,26 @@
"use client";
import { useState } from "react";
export default function PartnerRequestPage() {
const [form, setForm] = useState({ name: "", category: "spa", latitude: "", longitude: "", address: "", contact: "" });
const [done, setDone] = useState(false);
async function submit() {
const r = await fetch("/api/partner-requests", { method: "POST", headers: { "content-type": "application/json" }, body: JSON.stringify({ ...form, latitude: Number(form.latitude), longitude: Number(form.longitude) }) });
setDone(r.ok);
}
if (done) return <div> . .</div>;
return (
<div style={{ display: "flex", flexDirection: "column", gap: 8 }}>
<h1> </h1>
<input placeholder="업체명" value={form.name} onChange={(e) => setForm({ ...form, name: e.target.value })} />
<input placeholder="카테고리(spa/gym 등)" value={form.category} onChange={(e) => setForm({ ...form, category: e.target.value })} />
<input placeholder="위도" value={form.latitude} onChange={(e) => setForm({ ...form, latitude: e.target.value })} />
<input placeholder="경도" value={form.longitude} onChange={(e) => setForm({ ...form, longitude: e.target.value })} />
<input placeholder="주소(선택)" value={form.address} onChange={(e) => setForm({ ...form, address: e.target.value })} />
<input placeholder="연락처(선택)" value={form.contact} onChange={(e) => setForm({ ...form, contact: e.target.value })} />
<button onClick={submit}></button>
</div>
);
}