Merge pull request 'API Mobile' (#11) from mobile/10-sep-25 into staging
Reviewed-on: bip/hipmi#11
This commit is contained in:
52
src/app/api/mobile/event/route.ts
Normal file
52
src/app/api/mobile/event/route.ts
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
import _ from "lodash";
|
||||||
|
import { NextResponse } from "next/server";
|
||||||
|
import prisma from "@/lib/prisma";
|
||||||
|
|
||||||
|
export { POST };
|
||||||
|
|
||||||
|
async function POST(request: Request) {
|
||||||
|
try {
|
||||||
|
const { data } = await request.json();
|
||||||
|
|
||||||
|
const create = await prisma.event.create({
|
||||||
|
data: {
|
||||||
|
title: _.startCase(data.title),
|
||||||
|
lokasi: data.lokasi,
|
||||||
|
deskripsi: data.deskripsi,
|
||||||
|
eventMaster_TipeAcaraId: data.eventMaster_TipeAcaraId,
|
||||||
|
tanggal: data.tanggal,
|
||||||
|
tanggalSelesai: data.tanggalSelesai,
|
||||||
|
authorId: data.authorId,
|
||||||
|
},
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
title: true,
|
||||||
|
EventMaster_Status: {
|
||||||
|
select: {
|
||||||
|
name: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
authorId: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!create) return { status: 400, message: "Gagal disimpan" };
|
||||||
|
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: true,
|
||||||
|
message: "Berhasil disimpan",
|
||||||
|
data: create,
|
||||||
|
},
|
||||||
|
{ status: 201 }
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Error create event",
|
||||||
|
},
|
||||||
|
{ status: 500 }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -22,8 +22,9 @@ async function GET(request: Request, { params }: { params: { id: string } }) {
|
|||||||
masterBidangBisnisId: true,
|
masterBidangBisnisId: true,
|
||||||
Profile: {
|
Profile: {
|
||||||
select: {
|
select: {
|
||||||
|
id: true,
|
||||||
userId: true,
|
userId: true,
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
MasterBidangBisnis: {
|
MasterBidangBisnis: {
|
||||||
select: {
|
select: {
|
||||||
@@ -204,6 +205,25 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
|
|||||||
let message;
|
let message;
|
||||||
|
|
||||||
if (category === "detail") {
|
if (category === "detail") {
|
||||||
|
console.log("UPDATE PORTOFOLIO DETAIL >>");
|
||||||
|
console.log("DATA >>", data);
|
||||||
|
|
||||||
|
const checkData = await prisma.portofolio.findUnique({
|
||||||
|
where: { id },
|
||||||
|
include: {
|
||||||
|
Portofolio_BidangDanSubBidangBisnis: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!checkData) {
|
||||||
|
return NextResponse.json({
|
||||||
|
success: false,
|
||||||
|
message: "Data tidak ditemukan",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("CHECK DATA >>", checkData);
|
||||||
|
|
||||||
const updateDetail = await prisma.portofolio.update({
|
const updateDetail = await prisma.portofolio.update({
|
||||||
where: { id },
|
where: { id },
|
||||||
data: {
|
data: {
|
||||||
@@ -214,12 +234,75 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
|
|||||||
masterBidangBisnisId: data.masterBidangBisnisId,
|
masterBidangBisnisId: data.masterBidangBisnisId,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!updateDetail) {
|
if (!updateDetail) {
|
||||||
return NextResponse.json({
|
return NextResponse.json({
|
||||||
success: false,
|
success: false,
|
||||||
message: "Gagal mengupdate detail portofolio",
|
message: "Gagal mengupdate detail portofolio",
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
message = "Berhasil mengupdate detail portofolio";
|
message = "Berhasil mengupdate detail portofolio";
|
||||||
} else if (category === "medsos") {
|
} else if (category === "medsos") {
|
||||||
const updateMedsos = await prisma.portofolio_MediaSosial.update({
|
const updateMedsos = await prisma.portofolio_MediaSosial.update({
|
||||||
|
|||||||
46
src/app/api/mobile/route.ts
Normal file
46
src/app/api/mobile/route.ts
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
import { decrypt } from "@/app/(auth)/_lib/decrypt";
|
||||||
|
import { prisma } from "@/lib";
|
||||||
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
|
export async function GET(request: Request) {
|
||||||
|
try {
|
||||||
|
const { searchParams } = new URL(request.url);
|
||||||
|
const token = searchParams.get("token");
|
||||||
|
|
||||||
|
const dataUser = await decrypt({
|
||||||
|
token: token!,
|
||||||
|
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
||||||
|
});
|
||||||
|
|
||||||
|
const id = dataUser?.id;
|
||||||
|
const user = await prisma.user.findUnique({
|
||||||
|
where: {
|
||||||
|
id: id as string,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: true,
|
||||||
|
message: "Berhasil mendapatkan data",
|
||||||
|
data: user,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
status: 200,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Gagal mendapatkan data",
|
||||||
|
reason: (error as Error).message,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
status: 500,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
} finally {
|
||||||
|
await prisma.$disconnect();
|
||||||
|
}
|
||||||
|
}
|
||||||
34
src/app/api/mobile/user/[id]/route.ts
Normal file
34
src/app/api/mobile/user/[id]/route.ts
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import { prisma } from "@/lib";
|
||||||
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
|
export async function GET(
|
||||||
|
request: Request,
|
||||||
|
{ params }: { params: { id: string } }
|
||||||
|
) {
|
||||||
|
try {
|
||||||
|
const { id } = params;
|
||||||
|
|
||||||
|
const data = await prisma.user.findUnique({
|
||||||
|
where: {
|
||||||
|
id: id,
|
||||||
|
},
|
||||||
|
include: {
|
||||||
|
Profile: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
return NextResponse.json(
|
||||||
|
{ success: true, message: "Berhasil mendapatkan data", data: data },
|
||||||
|
{ status: 200 }
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
return NextResponse.json(
|
||||||
|
{
|
||||||
|
success: false,
|
||||||
|
message: "Error get data from API ",
|
||||||
|
reason: (error as Error).message,
|
||||||
|
},
|
||||||
|
{ status: 500 }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,21 +1,45 @@
|
|||||||
import { decrypt } from "@/app/(auth)/_lib/decrypt";
|
|
||||||
import { prisma } from "@/lib";
|
import { prisma } from "@/lib";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
export async function GET(request: Request) {
|
export async function GET(request: Request) {
|
||||||
try {
|
try {
|
||||||
const { searchParams } = new URL(request.url);
|
const { searchParams } = new URL(request.url);
|
||||||
const token = searchParams.get("token");
|
const search = searchParams.get("search");
|
||||||
|
|
||||||
const dataUser = await decrypt({
|
const data = await prisma.user.findMany({
|
||||||
token: token!,
|
orderBy: {
|
||||||
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
username: "asc",
|
||||||
});
|
},
|
||||||
|
|
||||||
const id = dataUser?.id;
|
|
||||||
const user = await prisma.user.findUnique({
|
|
||||||
where: {
|
where: {
|
||||||
id: id as string,
|
username: {
|
||||||
|
contains: search || "",
|
||||||
|
mode: "insensitive",
|
||||||
|
},
|
||||||
|
active: true,
|
||||||
|
NOT: {
|
||||||
|
Profile: null,
|
||||||
|
},
|
||||||
|
OR: [
|
||||||
|
{
|
||||||
|
MasterUserRole: {
|
||||||
|
name: "User",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
MasterUserRole: {
|
||||||
|
name: "Admin",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
include: {
|
||||||
|
Profile: {
|
||||||
|
select: {
|
||||||
|
id: true,
|
||||||
|
name: true,
|
||||||
|
imageId: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -23,7 +47,7 @@ export async function GET(request: Request) {
|
|||||||
{
|
{
|
||||||
success: true,
|
success: true,
|
||||||
message: "Berhasil mendapatkan data",
|
message: "Berhasil mendapatkan data",
|
||||||
data: user,
|
data: data,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
status: 200,
|
status: 200,
|
||||||
@@ -40,7 +64,46 @@ export async function GET(request: Request) {
|
|||||||
status: 500,
|
status: 500,
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
} finally {
|
|
||||||
await prisma.$disconnect();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// try {
|
||||||
|
// const { searchParams } = new URL(request.url);
|
||||||
|
// const token = searchParams.get("token");
|
||||||
|
|
||||||
|
// const dataUser = await decrypt({
|
||||||
|
// token: token!,
|
||||||
|
// encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
||||||
|
// });
|
||||||
|
|
||||||
|
// const id = dataUser?.id;
|
||||||
|
// const user = await prisma.user.findUnique({
|
||||||
|
// where: {
|
||||||
|
// id: id as string,
|
||||||
|
// },
|
||||||
|
// });
|
||||||
|
|
||||||
|
// return NextResponse.json(
|
||||||
|
// {
|
||||||
|
// success: true,
|
||||||
|
// message: "Berhasil mendapatkan data",
|
||||||
|
// data: user,
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// status: 200,
|
||||||
|
// }
|
||||||
|
// );
|
||||||
|
// } catch (error) {
|
||||||
|
// return NextResponse.json(
|
||||||
|
// {
|
||||||
|
// success: false,
|
||||||
|
// message: "Gagal mendapatkan data",
|
||||||
|
// reason: (error as Error).message,
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// status: 500,
|
||||||
|
// }
|
||||||
|
// );
|
||||||
|
// } finally {
|
||||||
|
// await prisma.$disconnect();
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user