fix edit portofolio

This commit is contained in:
2025-05-13 21:30:54 +08:00
parent 08e6708754
commit 3bc04aac3d
6 changed files with 754 additions and 20 deletions

View File

@@ -13,6 +13,18 @@ async function GET(request: Request, { params }: { params: { id: string } }) {
id: id,
},
include: {
Portofolio_BidangDanSubBidangBisnis: {
select: {
id: true,
MasterSubBidangBisnis: {
select: {
id: true,
name: true,
masterBidangBisnisId: true,
},
},
},
},
MasterBidangBisnis: {
select: {
id: true,
@@ -84,10 +96,26 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
const { data } = await request.json();
const udpateData = await prisma.portofolio.update({
where: {
id: id,
const checkData = await prisma.portofolio.findUnique({
where: { id },
include: {
Portofolio_BidangDanSubBidangBisnis: true,
},
});
if (!checkData) {
return NextResponse.json(
{
success: false,
message: "Data tidak ditemukan",
},
{ status: 404 }
);
}
// Update data utama portofolio
const updatePortofolio = await prisma.portofolio.update({
where: { id },
data: {
namaBisnis: data.namaBisnis,
alamatKantor: data.alamatKantor,
@@ -97,25 +125,77 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
},
});
if (!udpateData)
return NextResponse.json(
{
success: false,
message: "Gagal update data",
},
{ status: 400 }
const bidangBerubah =
checkData.masterBidangBisnisId !== data.masterBidangBisnisId;
if (bidangBerubah) {
// Bidang berubah → hapus semua sub bidang lama
await prisma.portofolio_BidangDanSubBidangBisnis.deleteMany({
where: { portofolioId: id },
});
// Tambahkan sub bidang baru
for (const sub of data.subBidang) {
await prisma.portofolio_BidangDanSubBidangBisnis.create({
data: {
portofolioId: id,
masterBidangBisnisId: data.masterBidangBisnisId,
masterSubBidangBisnisId: sub.MasterSubBidangBisnis.id,
},
});
}
} else {
// Bidang tidak berubah → sinkronisasi sub bidang
const existingSub = checkData.Portofolio_BidangDanSubBidangBisnis;
const incomingIds = data.subBidang.map(
(sub: any) => sub.MasterSubBidangBisnis.id
);
const existingIds = existingSub.map(
(item) => item.masterSubBidangBisnisId
);
// 1. Hapus sub bidang yang sudah tidak dipilih
const toDelete = existingSub.filter(
(item) => !incomingIds.includes(item.masterSubBidangBisnisId)
);
await prisma.portofolio_BidangDanSubBidangBisnis.deleteMany({
where: {
id: {
in: toDelete.map((item) => item.id),
},
},
});
// 2. Tambahkan sub bidang baru yang belum ada di DB
const toCreate = data.subBidang.filter(
(sub: any) => !existingIds.includes(sub.MasterSubBidangBisnis.id)
);
for (const sub of toCreate) {
await prisma.portofolio_BidangDanSubBidangBisnis.create({
data: {
portofolioId: id,
masterBidangBisnisId: data.masterBidangBisnisId,
masterSubBidangBisnisId: sub.MasterSubBidangBisnis.id,
},
});
}
}
return NextResponse.json(
{
success: true,
message: "Berhasil mendapatkan data",
data: udpateData,
message: "Berhasil update data",
data: updatePortofolio,
},
{ status: 200 }
);
} catch (error) {
backendLogger.error("Error update data portofolio", error);
return NextResponse.json(
{
success: false,
@@ -127,6 +207,8 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
}
}
async function POST(request: Request, { params }: { params: { id: string } }) {
if (request.method !== "POST") {
return NextResponse.json(
@@ -156,7 +238,6 @@ async function POST(request: Request, { params }: { params: { id: string } }) {
});
for (let i of data.subBidang) {
// console.log("sub bidang", i.id)
const createSubBidang =
await prisma.portofolio_BidangDanSubBidangBisnis.create({
data: {
@@ -166,7 +247,6 @@ async function POST(request: Request, { params }: { params: { id: string } }) {
},
});
if (!createSubBidang)
return NextResponse.json(
{