API Mobile Job

Add:
- api/mobile/job/

Fix:
- job/_view/view_not_user_view_job.tsx: Tampilan jika user menuju ke web untuk view mon user

### No issue
This commit is contained in:
2025-09-16 17:35:07 +08:00
parent 0c3dc0e5bc
commit 1e0a1c83ba
4 changed files with 383 additions and 7 deletions

View File

@@ -0,0 +1,132 @@
import prisma from "@/lib/prisma";
import _ from "lodash";
import { NextResponse } from "next/server";
export { GET, PUT };
async function GET(
request: Request,
{ params }: { params: { id: string; status: string } }
) {
try {
const { id, status } = params;
const fixStatusName = _.startCase(status);
const data = await prisma.job.findMany({
orderBy: {
updatedAt: "desc",
},
where: {
isActive: true,
authorId: id,
isArsip: false,
MasterStatus: {
name: fixStatusName,
},
},
select: {
id: true,
title: true,
},
});
return NextResponse.json(
{
success: true,
message: "Success get job",
data: data,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error get job",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(
request: Request,
{ params }: { params: { id: string; status: string } }
) {
try {
const { id, status } = params;
const fixStatusName = _.startCase(status);
const checkData = await prisma.job.findUnique({
where: {
id: id,
},
select: {
id: true,
MasterStatus: {
select: {
name: true,
},
},
},
});
if (!checkData) {
return NextResponse.json({
success: false,
message: "Data tidak ditemukan",
status: 404,
});
}
if (checkData?.MasterStatus?.name === "Publish") {
return NextResponse.json({
success: false,
message: "Job telah terpublish",
status: 400,
});
}
const checkStatus = await prisma.masterStatus.findFirst({
where: {
name: fixStatusName,
},
});
if (!checkStatus) {
return NextResponse.json({
success: false,
message: "Status tidak ditemukan",
status: 404,
});
}
const updateData = await prisma.job.update({
where: {
id: id,
},
data: {
masterStatusId: checkStatus.id,
},
});
return NextResponse.json(
{
success: true,
message: "Update berhasil",
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error update job",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,122 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
export { GET, DELETE, PUT };
async function GET(request: Request, { params }: { params: { id: string } }) {
try {
const { id } = params;
const data = await prisma.job.findUnique({
where: {
id: id,
},
include: {
Author: {
select: {
username: true,
nomor: true,
Profile: {
select: {
name: true,
alamat: true,
},
},
},
},
MasterStatus: {
select: {
name: true,
},
},
},
});
return NextResponse.json(
{
success: true,
message: "Success get data job-vacancy",
data: data,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error get data job-vacancy",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function DELETE(
request: Request,
{ params }: { params: { id: string } }
) {
try {
const { id } = params;
const deleteData = await prisma.job.delete({
where: {
id: id,
},
});
console.log("[DELETE DATA JOB]", deleteData);
return NextResponse.json(
{
success: true,
message: "Data berhasil dihapus",
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Gagal menghapus data",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(request: Request, { params }: { params: { id: string } }) {
try {
const { id } = params;
const { data } = await request.json();
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,
},
});
return NextResponse.json(
{
success: true,
message: "Berhasil update data",
data: updateData,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Gagal update data",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,103 @@
import prisma from "@/lib/prisma";
import { NextResponse } from "next/server";
export { POST, GET };
async function POST(request: Request) {
try {
const { data } = await request.json();
const create = await prisma.job.create({
data: {
title: data.title,
content: data.content,
deskripsi: data.deskripsi,
authorId: data.authorId,
imageId: data.imageId || null,
},
});
return NextResponse.json(
{
success: true,
message: "Berhasil disimpan",
data: create,
},
{ status: 201 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error create job",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function GET(request: Request) {
const { searchParams } = new URL(request.url);
const search = searchParams.get("search");
try {
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,
},
},
},
},
},
});
return NextResponse.json(
{
success: true,
message: "Success get data job-vacancy",
data: data,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Error get data job-vacancy",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -40,13 +40,32 @@ export function Job_ViewNotUserJobVacany() {
{data.title} {data.title}
</Text> </Text>
</Center> </Center>
<Stack spacing={0}>
<Text> <Stack spacing={"lg"}>
<div dangerouslySetInnerHTML={{ __html: data.content }} /> <Stack spacing={0}>
</Text> <Text fz={16} fw={"bold"}>
<Text> Syarat & Ketentuan
<div dangerouslySetInnerHTML={{ __html: data.deskripsi }} /> </Text>
</Text> <Text>
<div
dangerouslySetInnerHTML={{
__html: data?.content.replace(/\n/g, "<br />"),
}}
/>
</Text>
</Stack>
<Stack spacing={0}>
<Text fz={16} fw={"bold"}>
Deskripsi
</Text>
<Text>
<div
dangerouslySetInnerHTML={{
__html: data.deskripsi.replace(/\n/g, "<br />"),
}}
/>
</Text>
</Stack>
</Stack> </Stack>
</Stack> </Stack>
</Stack> </Stack>