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:
@@ -111,7 +111,6 @@ async function PUT(
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: true,
|
success: true,
|
||||||
|
|||||||
@@ -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 category = searchParams.get("category");
|
||||||
|
let fixData;
|
||||||
|
|
||||||
const updateData = await prisma.job.update({
|
if (category === "archive") {
|
||||||
where: {
|
const updateData = await prisma.job.update({
|
||||||
id: id,
|
where: {
|
||||||
},
|
id: id,
|
||||||
data: {
|
},
|
||||||
title: data.title,
|
data: {
|
||||||
content: data.content,
|
isArsip: data,
|
||||||
deskripsi: data.deskripsi,
|
},
|
||||||
// authorId: data.authorId,
|
});
|
||||||
imageId: data.imageId || null,
|
|
||||||
},
|
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 }
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -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 }
|
||||||
);
|
);
|
||||||
|
|||||||
116
src/app/api/mobile/voting/[id]/[status]/route.ts
Normal file
116
src/app/api/mobile/voting/[id]/[status]/route.ts
Normal 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,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
53
src/app/api/mobile/voting/[id]/route.ts
Normal file
53
src/app/api/mobile/voting/[id]/route.ts
Normal 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,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
54
src/app/api/mobile/voting/route.ts
Normal file
54
src/app/api/mobile/voting/route.ts
Normal 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 }
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user