Compare commits

...

9 Commits

Author SHA1 Message Date
nabillah
70849ba2a9 Event Integrasi API Mobile
Add:
src/app/api/mobile/admin/event/
src/app/api/mobile/event/[id]/confirmation/

Fix:
- src/app/api/mobile/admin/voting/route.ts
- src/app/api/mobile/event/[id]/check-participants/route.ts

### Issue: Belum menyertakan fungsi konfrimasu kehadiran
2025-10-23 17:51:56 +08:00
nabillah
aa8dec5391 chore(release): 1.5.6 2025-10-21 16:48:16 +08:00
nabillah
fd09783c19 Mobile API: Voting admin
Fix:
- src/app/api/mobile/admin/voting/[id]/route.ts
- src/app/api/mobile/admin/voting/route.ts

### No Issue
2025-10-21 16:48:08 +08:00
nabillah
23b7d6b4e4 Mobile API: Admin Voting
Add:
- src/app/api/mobile/admin/voting/

Fix:
-  src/app/api/admin/vote/status/[name]/route.ts

### No Issue
2025-10-20 17:40:50 +08:00
nabillah
9869be5af9 chore(release): 1.5.5 2025-10-20 16:28:09 +08:00
nabillah
d2ec9496e8 Mobile API: Admin Forum
Add:
src/app/api/mobile/admin/forum/[id]/report-comment/
src/app/api/mobile/admin/forum/[id]/report-posting/

Fix:
src/app/api/mobile/admin/forum/[id]/comment/route.ts
src/app/api/mobile/admin/forum/[id]/route.ts
src/app/api/mobile/admin/forum/route.ts

### No Issue
2025-10-20 16:28:00 +08:00
nabillah
02d685f1aa chore(release): 1.5.4 2025-10-17 17:45:25 +08:00
nabillah
f99ec28cc4 Mobile API:
Add:
- src/app/api/mobile/admin/forum/

Fix:
- src/app/api/mobile/admin/job/route.ts

### Issue: Reminder kalau api komen report bekum ada
2025-10-17 17:45:11 +08:00
nabillah
fdb582ee99 Mobile API: Job admin
Add:
-  src/app/api/mobile/admin/job/[id]/

### No Issue
2025-10-17 14:18:08 +08:00
16 changed files with 1606 additions and 5 deletions

View File

@@ -2,6 +2,12 @@
All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
## [1.5.6](https://wibugit.wibudev.com/bip/hipmi/compare/v1.5.5...v1.5.6) (2025-10-21)
## [1.5.5](https://wibugit.wibudev.com/bip/hipmi/compare/v1.5.4...v1.5.5) (2025-10-20)
## [1.5.4](https://wibugit.wibudev.com/bip/hipmi/compare/v1.5.3...v1.5.4) (2025-10-17)
## [1.5.3](https://wibugit.wibudev.com/bip/hipmi/compare/v1.5.2...v1.5.3) (2025-10-16)
## [1.5.2](https://wibugit.wibudev.com/bip/hipmi/compare/v1.5.1...v1.5.2) (2025-10-15)

View File

@@ -1,6 +1,6 @@
{
"name": "hipmi",
"version": "1.5.3",
"version": "1.5.6",
"private": true,
"prisma": {
"seed": "bun prisma/seed.ts"

View File

@@ -70,7 +70,7 @@ export async function GET(
for (let i of getAllData) {
if (moment(i.akhirVote).diff(moment(), "minutes") < 0) {
await prisma.event.update({
await prisma.voting.update({
where: {
id: i.id,
},

View File

@@ -0,0 +1,129 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
import _ from "lodash";
export { GET, PUT };
async function GET(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
try {
const data = await prisma.event.findUnique({
where: {
id: id,
},
include: {
Author: {
select: {
username: true,
nomor: true,
Profile: {
select: {
name: true,
alamat: true,
},
},
},
},
EventMaster_TipeAcara: {
select: {
name: true,
},
},
EventMaster_Status: true,
},
});
return NextResponse.json(
{
success: true,
message: "Success get data event",
data: data,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Failed to get data",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
const { data } = await request.json();
const { searchParams } = new URL(request.url);
const status = searchParams.get("status");
const fixStatus = _.startCase(status as string);
console.log("ID", id);
console.log("DATA", data);
console.log("FIX STATUS", fixStatus);
let fixData;
try {
const checkStatus = await prisma.eventMaster_Status.findFirst({
where: {
name: fixStatus,
},
});
if (!checkStatus)
return NextResponse.json(
{
success: false,
message: "Error update data event",
reason: "Status not found",
},
{ status: 500 }
);
if (fixStatus === "Reject") {
const updateData = await prisma.event.update({
where: {
id: id,
},
data: {
catatan: data,
eventMaster_StatusId: checkStatus.id,
},
});
fixData = updateData;
} else if (fixStatus === "Publish") {
const updateData = await prisma.event.update({
where: {
id: id,
},
data: {
eventMaster_StatusId: checkStatus.id,
},
});
fixData = updateData;
}
return NextResponse.json(
{
success: true,
message: "Success update data event",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: "Failed to update data",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,192 @@
import _ from "lodash";
import { prisma } from "@/lib";
import { NextResponse } from "next/server";
import moment from "moment";
export { GET };
async function GET(request: Request) {
const { searchParams } = new URL(request.url);
const category = searchParams.get("category");
const fixStatus = _.startCase(category || "");
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
let fixData;
console.log("[CATEGORY]", category);
// console.log("[FIX STATUS]", fixStatus);
try {
if (category === "dashboard") {
const publish = await prisma.event.count({
where: {
EventMaster_Status: {
name: "Publish",
},
isArsip: false,
},
});
const review = await prisma.event.count({
where: {
EventMaster_Status: {
name: "Review",
},
isArsip: false,
},
});
const reject = await prisma.event.count({
where: {
EventMaster_Status: {
name: "Reject",
},
isArsip: false,
},
});
const history = await prisma.event.count({
where: {
EventMaster_Status: {
name: "Publish",
},
isArsip: true,
},
});
const typeOfEvent = await prisma.eventMaster_TipeAcara.count({
where: {
active: true,
},
});
fixData = {
publish,
review,
reject,
history,
typeOfEvent,
};
} else if (category === "history") {
console.log("[HISTORY HERE]");
const data = await prisma.event.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
isArsip: true,
EventMaster_Status: {
name: "Publish",
},
title: {
contains: search || "",
mode: "insensitive",
},
},
select: {
id: true,
title: true,
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
name: true,
},
},
},
},
},
});
fixData = data;
} else {
if (fixStatus === "Publish") {
const getAllData = await prisma.event.findMany({
where: {
active: true,
EventMaster_Status: {
name: fixStatus,
},
isArsip: false,
},
});
for (let i of getAllData) {
if (moment(i.tanggalSelesai).diff(moment(), "minutes") < 0) {
await prisma.event.update({
where: {
id: i.id,
},
data: {
isArsip: true,
},
});
}
}
}
const data = await prisma.event.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
tanggal: "asc",
},
where: {
active: true,
isArsip: false,
EventMaster_Status: {
name: fixStatus,
},
title: {
contains: search || "",
mode: "insensitive",
},
},
select: {
id: true,
title: true,
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
name: true,
},
},
},
},
},
});
fixData = data;
}
return NextResponse.json(
{
success: true,
message: `Success get data event ${category}`,
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.log(`[ERROR GET DATA EVENT: ${category}]`, error);
return NextResponse.json(
{
success: false,
message: `Error get data event ${category}`,
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,114 @@
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 } }) {
const { id } = params;
const { searchParams } = new URL(request.url);
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
const category = searchParams.get("category");
let fixData;
try {
if (category === "get-all") {
const getData = await prisma.forum_Komentar.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
forum_PostingId: id,
isActive: true,
komentar: {
contains: search ?? "",
mode: "insensitive",
},
},
include: {
Forum_ReportKomentar: true,
Author: {
select: {
username: true,
},
},
},
});
fixData = getData.map((v: any) => ({
..._.omit(v, ["Forum_ReportKomentar"]),
countReport: v.Forum_ReportKomentar.length,
}));
} else if (category === "get-one") {
fixData = await prisma.forum_Komentar.findUnique({
where: {
id: id,
},
include: {
Forum_ReportKomentar: true,
Author: {
select: {
username: true,
},
},
},
});
}
return NextResponse.json(
{
success: true,
message: "Success get detail comment",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.error(`[ERROR GET ${category} COMMENT]`, error);
return NextResponse.json(
{
success: false,
message: "Error get detail data comment",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
try {
const deleteData = await prisma.forum_Komentar.update({
where: {
id: id,
},
data: {
isActive: false,
},
});
return NextResponse.json(
{
success: true,
message: "Success deactivate comment",
data: deleteData,
},
{ status: 200 }
);
} catch (error) {
console.error("[ERROR DEACTIVATE COMMENT]", error);
return NextResponse.json(
{
success: false,
message: "Error deactivate comment",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,69 @@
import prisma from "@/lib/prisma";
import { NextResponse } from "next/server";
export async function GET(
request: Request,
{ params }: { params: { id: string } }
) {
const { searchParams } = new URL(request.url);
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
try {
let fixData;
const { id } = params;
const komentarId = id;
fixData = await prisma.forum_ReportKomentar.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
forum_KomentarId: komentarId,
},
select: {
id: true,
deskripsi: true,
ForumMaster_KategoriReport: {
select: {
title: true,
deskripsi: true,
},
},
User: {
select: {
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
},
});
return NextResponse.json(
{
success: true,
message: "Success get list report comment",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.error("[ERROR GET LIST REPORT COMMENT]", error);
return NextResponse.json(
{
success: false,
message: "Error get list report comment",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,76 @@
import { NextResponse } from "next/server";
import { prisma } from "@/lib";
export async function GET(
request: Request,
{ params }: { params: { id: string } }
) {
const { id } = params;
const { searchParams } = new URL(request.url);
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
let fixData;
try {
fixData = await prisma.forum_ReportPosting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
forum_PostingId: id,
Forum_Posting: {
isActive: true,
diskusi: {
contains: search ? search : "",
mode: "insensitive",
},
},
},
select: {
id: true,
deskripsi: true,
User: {
select: {
id: true,
username: true,
Profile: {
select: {
name: true,
},
},
},
},
ForumMaster_KategoriReport: {
select: {
id: true,
title: true,
deskripsi: true,
},
},
},
});
return NextResponse.json(
{
success: true,
message: "Success get list report posting",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.error("[ERROR GET LIST REPORT POSTING]", error);
return NextResponse.json(
{
success: false,
message: "Error get list report posting",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,120 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
import _ from "lodash";
export { GET, PUT };
async function GET(request: Request, { params }: { params: { id: string } }) {
const { searchParams } = new URL(request.url);
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
const { id } = params;
try {
const data = await prisma.forum_Posting.findFirst({
where: {
id: id,
},
select: {
id: true,
isActive: true,
diskusi: true,
ForumMaster_StatusPosting: {
select: {
id: true,
status: true,
},
},
authorId: true,
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
name: true,
},
},
},
},
Forum_Komentar: {
where: {
isActive: true,
},
},
Forum_ReportPosting: {
where: {
isActive: true,
},
},
},
});
const result = {
..._.omit(data, "Forum_Komentar", "Forum_ReportPosting"),
JumlahKomentar: data?.Forum_Komentar.length,
JumlahReportPosting: data?.Forum_ReportPosting.length,
};
return NextResponse.json({
success: true,
message: "Success get data",
data: result,
});
} catch (error) {
console.error("Error get data forum", error);
return NextResponse.json(
{
success: false,
message: "Error get data forum",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
try {
const data = await prisma.forum_Posting.update({
where: {
id: id,
},
data: {
isActive: false,
},
});
const deactivateComment = await prisma.forum_Komentar.updateMany({
where: {
forum_PostingId: id,
},
data: {
isActive: false,
},
});
console.log("[DEACTIVATE COMMENT]", deactivateComment);
return NextResponse.json(
{
success: true,
message: "Success deactivate posting",
data: data,
},
{ status: 200 }
);
} catch (error) {
console.error("[ERROR DEACTIVATE POSTING]", error);
return NextResponse.json(
{
success: false,
message: "Error deactivate posting",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,193 @@
import { NextResponse } from "next/server";
import { prisma } from "@/lib";
export { GET };
async function GET(request: Request, { params }: { params: { name: string } }) {
const { searchParams } = new URL(request.url);
const category = searchParams.get("category");
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
let fixData;
try {
if (category === "dashboard") {
const posting = await prisma.forum_Posting.count({
orderBy: {
createdAt: "desc",
},
where: {
isActive: true,
},
});
const reportPosting = await prisma.forum_ReportPosting.count({
orderBy: {
createdAt: "desc",
},
where: {
Forum_Posting: {
isActive: true,
},
},
});
const reportComment = await prisma.forum_ReportKomentar.count({
orderBy: {
createdAt: "desc",
},
where: {
Forum_Komentar: {
isActive: true,
},
},
});
fixData = {
posting,
reportPosting,
reportComment,
};
} else if (category === "posting") {
fixData = await prisma.forum_Posting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
isActive: true,
diskusi: {
contains: search || "",
mode: "insensitive",
},
},
select: {
id: true,
diskusi: true,
isActive: true,
Author: {
select: {
id: true,
username: true,
Profile: true,
},
},
},
});
} else if (category === "report_posting") {
fixData = await prisma.forum_ReportPosting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
Forum_Posting: {
isActive: true,
diskusi: {
contains: search ? search : "",
mode: "insensitive",
},
},
},
select: {
id: true,
deskripsi: true,
createdAt: true,
User: {
select: {
id: true,
username: true,
Profile: {
select: {
name: true,
},
},
},
},
ForumMaster_KategoriReport: {
select: {
id: true,
title: true,
deskripsi: true,
},
},
Forum_Posting: {
select: {
id: true,
diskusi: true,
},
},
},
});
} else if (category === "report_comment") {
fixData = await prisma.forum_ReportKomentar.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
Forum_Komentar: {
isActive: true,
komentar: {
contains: search ? search : "",
mode: "insensitive",
},
},
},
include: {
ForumMaster_KategoriReport: true,
User: {
select: {
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
Forum_Komentar: {
select: {
id: true,
komentar: true,
},
},
},
});
} else {
return NextResponse.json(
{
success: false,
message: "Invalid category",
reason: "Invalid category",
},
{ status: 400 }
);
}
return NextResponse.json(
{
success: true,
message: `Success get data forum ${category}`,
data: fixData,
},
{ status: 200 }
);
} catch (error) {
return NextResponse.json(
{
success: false,
message: `Error get data forum ${category}`,
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,143 @@
import { NextResponse } from "next/server";
import prisma from "@/lib/prisma";
import _ from "lodash";
export { GET, PUT };
async function GET(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
try {
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 PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
const { data } = await request.json();
const { searchParams } = new URL(request.url);
const status = searchParams.get("status");
const fixStatus = _.startCase(status as string);
let fixData;
try {
const checkStatus = await prisma.masterStatus.findFirst({
where: {
name: fixStatus,
},
});
if (!checkStatus)
return NextResponse.json(
{
success: false,
message: "Error update data job-vacancy",
reason: "Status not found",
},
{ status: 500 }
);
if (fixStatus === "Reject") {
const updt = await prisma.job.update({
where: {
id: id,
},
data: {
masterStatusId: checkStatus.id,
catatan: data,
},
select: {
id: true,
authorId: true,
MasterStatus: {
select: {
name: true,
},
},
title: true,
},
});
fixData = updt;
} else if (fixStatus === "Publish") {
const updt = await prisma.job.update({
where: {
id: id,
},
data: {
masterStatusId: checkStatus.id,
},
select: {
id: true,
authorId: true,
MasterStatus: {
select: {
name: true,
},
},
title: true,
},
});
fixData = updt;
}
return NextResponse.json(
{
success: true,
message: "Success update data job-vacancy",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.log("[ERROR]", error);
return NextResponse.json(
{
success: false,
message: "Error update data job-vacancy",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -10,9 +10,6 @@ async function GET(request: Request, { params }: { params: { name: string } }) {
const search = searchParams.get("search");
let fixData;
console.log("[CAT]", category);
try {
if (category === "dashboard") {
const publish = await prisma.job.count({

View File

@@ -0,0 +1,109 @@
import { NextResponse } from "next/server";
import { prisma } from "@/lib";
import _ from "lodash";
export { GET , PUT};
async function GET(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
try {
const data = await prisma.voting.findUnique({
where: {
id: id,
},
include: {
Author: true,
Voting_Status: true,
Voting_DaftarNamaVote: true,
},
});
return NextResponse.json(
{
success: true,
message: "Success get data voting",
data: data,
},
{ status: 200 }
);
} catch (error) {
console.log("[ERROR GET DATA VOTING]", error);
return NextResponse.json(
{
success: false,
message: "Error get data voting",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}
async function PUT(request: Request, { params }: { params: { id: string } }) {
const { id } = params;
const { data } = await request.json();
const { searchParams } = new URL(request.url);
const status = searchParams.get("status");
const fixStatus = _.startCase(status as string);
let fixData;
try {
const checkStatus = await prisma.voting_Status.findFirst({
where: {
name: fixStatus,
},
});
if (!checkStatus)
return NextResponse.json(
{
success: false,
message: "Error update data voting",
reason: "Status not found",
},
{ status: 500 }
);
if (fixStatus === "Reject") {
const updateStatus = await prisma.voting.update({
where: {
id: id,
},
data: {
voting_StatusId: checkStatus.id,
catatan: data,
},
});
fixData = updateStatus;
} else if (fixStatus === "Publish") {
const updateStatus = await prisma.voting.update({
where: {
id: id,
},
data: {
voting_StatusId: checkStatus.id,
},
});
fixData = updateStatus;
}
return NextResponse.json(
{
success: true,
message: "Success update data voting",
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.log("[ERROR UPDATE DATA VOTING]", error);
return NextResponse.json(
{
success: false,
message: "Error update data voting",
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,249 @@
import _ from "lodash";
import moment from "moment";
import { NextResponse } from "next/server";
import { prisma } from "@/lib";
export { GET };
async function GET(request: Request) {
const { searchParams } = new URL(request.url);
const category = searchParams.get("category");
const fixToStatus = _.startCase(category || "");
const search = searchParams.get("search");
const page = searchParams.get("page");
const takeData = 10;
const skipData = Number(page) * takeData - takeData;
let fixData;
try {
if (category === "dashboard") {
const publish = await prisma.voting.count({
where: {
Voting_Status: {
name: "Publish",
},
isActive: true,
isArsip: false,
akhirVote: {
gte: new Date(),
},
},
});
const review = await prisma.voting.count({
where: {
Voting_Status: {
name: "Review",
},
isActive: true,
isArsip: false,
akhirVote: {
gte: new Date(),
},
},
});
const reject = await prisma.voting.count({
where: {
Voting_Status: {
name: "Reject",
},
isActive: true,
isArsip: false,
akhirVote: {
gte: new Date(),
},
},
});
const history = await prisma.voting.count({
where: {
Voting_Status: {
name: "Publish",
},
isActive: true,
isArsip: false,
akhirVote: {
lte: new Date(),
},
},
});
fixData = {
publish,
review,
reject,
history,
};
} else if (category === "history") {
fixData = await prisma.voting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
updatedAt: "desc",
},
where: {
Voting_Status: {
name: "Publish",
},
isActive: true,
isArsip: false,
akhirVote: {
lte: new Date(),
},
title: {
contains: search ? search : "",
mode: "insensitive",
},
},
include: {
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
Voting_Kontributor: true,
Voting_DaftarNamaVote: true,
},
});
} else {
// ====== Status Publish Start ====== //
if (fixToStatus === "Publish") {
const getAllData = await prisma.voting.findMany({
where: {
Voting_Status: {
name: "Publish",
},
isActive: true,
isArsip: false,
akhirVote: {
gte: new Date(),
},
},
});
for (let i of getAllData) {
if (moment(i.akhirVote).diff(moment(), "minutes") < 0) {
await prisma.voting.update({
where: {
id: i.id,
},
data: {
isArsip: true,
},
});
}
}
const data = await prisma.voting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
Voting_Status: {
name: "Publish",
},
isActive: true,
title: {
contains: search ? search : "",
mode: "insensitive",
},
akhirVote: {
gte: new Date(),
},
isArsip: false,
},
include: {
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
Voting_Kontributor: true,
Voting_DaftarNamaVote: true,
},
});
fixData = data;
// ====== Status Publish End ====== //
} else {
// ====== Status Other Start ====== //
const data = await prisma.voting.findMany({
take: page ? takeData : undefined,
skip: page ? skipData : undefined,
orderBy: {
createdAt: "desc",
},
where: {
Voting_Status: {
name: fixToStatus,
},
isActive: true,
title: {
contains: search ? search : "",
mode: "insensitive",
},
isArsip: false,
},
include: {
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
Voting_Kontributor: true,
Voting_DaftarNamaVote: true,
},
});
fixData = data;
// ====== Status Other End ====== //
}
}
return NextResponse.json(
{
success: true,
message: `Success get data voting ${category}`,
data: fixData,
},
{ status: 200 }
);
} catch (error) {
console.log(`[ERROR GET DATA VOTING: ${category}]`, error);
return NextResponse.json(
{
success: false,
message: `Error get data voting ${category}`,
reason: (error as Error).message,
},
{ status: 500 }
);
}
}

View File

@@ -9,6 +9,9 @@ async function GET(request: Request, { params }: { params: { id: string } }) {
const { searchParams } = new URL(request.url);
const userId = searchParams.get("userId");
console.log("id", id);
console.log("userId", userId);
let fixData
const checkParticipant = await prisma.event_Peserta.findFirst({

View File

@@ -0,0 +1,201 @@
import { prisma } from "@/lib";
import { NextResponse } from "next/server";
export async function GET(
request: Request,
{ params }: { params: { id: string } }
) {
try {
const { id } = params;
let fixData;
const { searchParams } = new URL(request.url);
const userId = searchParams.get("userId");
console.log("userId", userId);
const checkDataEvent = await prisma.event.findUnique({
where: {
id: id,
},
select: {
id: true,
title: true,
tanggal: true,
tanggalSelesai: true,
lokasi: true,
Author: {
select: {
id: true,
username: true,
Profile: {
select: {
id: true,
name: true,
},
},
},
},
},
});
if (!checkDataEvent) {
return NextResponse.json(
{ message: "Event Not Found", response: null },
{ status: 400 }
);
}
let peserta;
const checkPeserta = await prisma.event_Peserta.findFirst({
where: {
userId: userId,
eventId: id,
},
});
console.log("checkPeserta", checkPeserta);
if (checkPeserta) {
peserta = true;
} else {
peserta = false;
}
let kehadiran;
const checkKehadiran = await prisma.event_Peserta.findFirst({
where: {
userId: userId,
eventId: id,
},
select: {
isPresent: true,
},
});
if (checkKehadiran?.isPresent) {
kehadiran = true;
} else {
kehadiran = false;
}
fixData = {
dataEvent: checkDataEvent,
peserta: peserta,
kehadiran: kehadiran,
};
return NextResponse.json(
{ success: true, message: "Event Found", data: fixData },
{ status: 200 }
);
} catch (error) {
console.error("Error get confirmation event", error);
return NextResponse.json(
{
success: false,
message: "Error get confirmation event",
reason: (error as Error).message || error,
},
{ status: 500 }
);
}
}
export async function POST(
request: Request,
{ params }: { params: { id: string } }
) {
const { id } = params;
const { data } = await request.json();
const { searchParams } = new URL(request.url);
const category = searchParams.get("category");
let fixData;
try {
console.log("category", category);
console.log("id", id);
console.log("data", data);
// const checkEvent = await prisma.event.findUnique({
// where: {
// id: id,
// },
// });
// if (!checkEvent) {
// return NextResponse.json(
// { message: "Event Not Found", response: null },
// { status: 400 }
// );
// }
// const checkPeserta = await prisma.event_Peserta.findFirst({
// where: {
// userId: userId,
// eventId: id,
// },
// });
// if (!checkPeserta) {
// return NextResponse.json(
// { message: "Peserta Not Found", response: null },
// { status: 400 }
// );
// }
if (category === "join_and_confirm") {
const join = await prisma.event_Peserta.create({
data: {
eventId: id,
userId: data.userId,
isPresent: true,
},
});
console.log("join", join);
fixData = join;
} else if (category === "confirmation") {
const checkPeserta = await prisma.event_Peserta.findFirst({
where: {
userId: data.userId,
eventId: id,
isPresent: true,
},
});
if (!checkPeserta) {
return NextResponse.json(
{ message: "Peserta Not Found", response: null },
{ status: 400 }
);
}
const confirm = await prisma.event_Peserta.update({
where: {
id: checkPeserta.id,
},
data: {
isPresent: true,
},
});
console.log("confirm", confirm);
fixData = confirm;
}
return NextResponse.json(
{ success: true, message: `Success ${category}`, data: fixData },
{ status: 200 }
);
} catch (error) {
console.error("Error upsert confirmation event", error);
return NextResponse.json(
{
success: false,
message: "Error upsert confirmation event",
reason: (error as Error).message || error,
},
{ status: 500 }
);
}
}