Merge pull request 'Integrasi API Mobile Job & Voting' (#17) from mobile/17-sep-25 into staging

Reviewed-on: bip/hipmi#17
This commit is contained in:
2025-09-17 17:33:33 +08:00
6 changed files with 342 additions and 52 deletions

View File

@@ -111,7 +111,6 @@ async function PUT(
}, },
}); });
return NextResponse.json( return NextResponse.json(
{ {
success: true, success: true,

View File

@@ -62,8 +62,6 @@ async function DELETE(
}, },
}); });
console.log("[DELETE DATA JOB]", deleteData);
return NextResponse.json( return NextResponse.json(
{ {
success: true, success: true,
@@ -87,25 +85,43 @@ async function PUT(request: Request, { params }: { params: { id: string } }) {
try { try {
const { id } = params; const { id } = params;
const { data } = await request.json(); const { data } = await request.json();
const { searchParams } = new URL(request.url);
const updateData = await prisma.job.update({ const category = searchParams.get("category");
where: { let fixData;
id: id,
}, if (category === "archive") {
data: { const updateData = await prisma.job.update({
title: data.title, where: {
content: data.content, id: id,
deskripsi: data.deskripsi, },
// authorId: data.authorId, data: {
imageId: data.imageId || null, isArsip: data,
}, },
}); });
fixData = updateData;
} else if (category === "edit") {
const updateData = await prisma.job.update({
where: {
id: id,
},
data: {
title: data.title,
content: data.content,
deskripsi: data.deskripsi,
// authorId: data.authorId,
imageId: data.imageId || null,
},
});
fixData = updateData;
}
return NextResponse.json( return NextResponse.json(
{ {
success: true, success: true,
message: "Berhasil update data", message: "Berhasil update data",
data: updateData, data: fixData,
}, },
{ status: 200 } { status: 200 }
); );

View File

@@ -40,53 +40,105 @@ async function POST(request: Request) {
async function GET(request: Request) { async function GET(request: Request) {
const { searchParams } = new URL(request.url); const { searchParams } = new URL(request.url);
const search = searchParams.get("search"); const search = searchParams.get("search");
const category = searchParams.get("category");
const authorId = searchParams.get("authorId");
let fixData;
try { try {
const data = await prisma.job.findMany({ if (category === "archive") {
where: { const data = await prisma.job.findMany({
isActive: true, where: {
isArsip: false, authorId: authorId,
MasterStatus: { isActive: true,
name: "Publish", isArsip: true,
}, MasterStatus: {
title: { name: "Publish",
contains: search || "",
mode: "insensitive",
},
},
orderBy: {
createdAt: "desc",
},
select: {
id: true,
title: true,
deskripsi: true,
authorId: true,
MasterStatus: {
select: {
name: true,
}, },
// title: {
// contains: search || "",
// mode: "insensitive",
// },
}, },
Author: { orderBy: {
select: { createdAt: "desc",
id: true, },
username: true, select: {
Profile: { id: true,
select: { title: true,
id: true, deskripsi: true,
name: true, authorId: true,
imageId: true, MasterStatus: {
select: {
name: true,
},
},
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
imageId: true,
},
}, },
}, },
}, },
}, },
}, });
});
fixData = data;
} else if (category === "beranda") {
const data = await prisma.job.findMany({
where: {
isActive: true,
isArsip: false,
MasterStatus: {
name: "Publish",
},
title: {
contains: search || "",
mode: "insensitive",
},
},
orderBy: {
createdAt: "desc",
},
select: {
id: true,
title: true,
deskripsi: true,
authorId: true,
MasterStatus: {
select: {
name: true,
},
},
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
imageId: true,
},
},
},
},
},
});
fixData = data;
}
return NextResponse.json( return NextResponse.json(
{ {
success: true, success: true,
message: "Success get data job-vacancy", message: "Success get data job-vacancy",
data: data, data: fixData,
}, },
{ status: 200 } { status: 200 }
); );

View File

@@ -0,0 +1,116 @@
import _ from "lodash";
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
export { GET, PUT };
async function GET(
request: Request,
{ params }: { params: { id: string; status: string } }
) {
try {
const { id, status } = params;
console.log("[ID]", id);
const fixStatusName = _.startCase(status);
console.log("[STATUS]", fixStatusName);
const data = await prisma.voting.findMany({
where: {
authorId: id,
Voting_Status: {
name: fixStatusName,
},
},
});
return NextResponse.json({
success: true,
message: "Success get voting",
data: data,
});
} catch (error) {
console.log("[ERROR]", error);
return NextResponse.json({
success: false,
message: "Error get voting",
reason: (error as Error).message,
});
}
}
async function PUT(
request: Request,
{ params }: { params: { id: string; status: string } }
) {
try {
const { id, status } = params;
console.log("[ID]", id);
const fixStatusName = _.startCase(status);
console.log("[STATUS]", fixStatusName);
const checkData = await prisma.voting.findFirst({
where: {
id: id,
},
select: {
id: true,
Voting_Status: {
select: {
name: true,
},
},
},
});
console.log("[CHECKDATA]", checkData);
if (!checkData)
return NextResponse.json({
success: false,
message: "Voting tidak ditemukan",
});
if (checkData?.Voting_Status?.name === "Publish") {
return NextResponse.json({
success: false,
message: "Voting telah terpublish",
});
}
const checkStatus = await prisma.masterStatus.findFirst({
where: {
name: fixStatusName,
},
});
if (!checkStatus)
return NextResponse.json({
success: false,
message: "Status tidak ditemukan",
});
const updateData = await prisma.voting.update({
where: {
id: id,
},
data: {
voting_StatusId: checkStatus.id,
},
});
console.log("[UPDATE]", updateData);
return NextResponse.json({
success: true,
message: "Success update voting",
data: updateData,
});
} catch (error) {
console.log("[ERROR]", error);
return NextResponse.json({
success: false,
message: "Error update voting",
reason: (error as Error).message,
});
}
}

View File

@@ -0,0 +1,53 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
export { GET };
async function GET(request: Request, { params }: { params: { id: string } }) {
try {
const { id } = params;
console.log("[ID]", id);
const data = await prisma.voting.findUnique({
where: {
id: id,
},
include: {
Voting_DaftarNamaVote: {
orderBy: {
createdAt: "asc",
},
where: {
isActive: true,
},
},
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
imageId: true,
},
},
},
},
},
});
return NextResponse.json({
success: true,
message: "Success get voting",
data: data,
});
} catch (error) {
console.log("[ERROR VOTING]", error);
return NextResponse.json({
success: false,
message: "Error get voting",
reason: (error as Error).message,
});
}
}

View File

@@ -0,0 +1,54 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
export { POST };
async function POST(request: Request) {
try {
const { data } = await request.json();
console.log("[DATA]", data);
const create = await prisma.voting.create({
data: {
title: data.title,
deskripsi: data.deskripsi,
awalVote: data.awalVote,
akhirVote: data.akhirVote,
authorId: data.authorId,
},
});
if (!create) return { status: 400, message: "Gagal Membuat Vote" };
for (let v of data.listVote) {
const val = v.value;
const namaVote = await prisma.voting_DaftarNamaVote.create({
data: {
value: val,
votingId: create.id,
},
});
if (!namaVote) return { status: 400, message: "Gagal Membuat List" };
}
return NextResponse.json(
{
success: true,
message: "Success create voting",
},
{ status: 201 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error create voting",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}