fix edit portofolio
This commit is contained in:
@@ -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(
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user