#### Deskripsi Umum Telah dilakukan penambahan fitur pagination pada beberapa endpoint admin mobile untuk meningkatkan kinerja dan pengalaman pengguna saat mengakses data dalam jumlah besar. #### File yang Diubah 1. **src/app/api/mobile/admin/job/route.ts** - Ditambahkan parameter dari - Diterapkan logika pagination dengan (default 10) dan - Query telah dimodifikasi untuk mendukung pagination 2. **src/app/api/mobile/admin/event/route.ts** - Diperbaiki definisi variabel untuk memastikan tipe data yang konsisten - Ditambahkan default value 1 untuk parameter - Perhitungan disesuaikan agar lebih efisien 3. **src/app/api/mobile/admin/event/[id]/participants/route.ts** - Ditambahkan parameter dari - Diterapkan logika pagination dengan (default 10) dan - Query telah dimodifikasi untuk mendukung pagination #### Tujuan Perubahan - Meningkatkan kinerja aplikasi saat mengambil data dalam jumlah besar - Memungkinkan pengguna untuk mengakses data secara bertahap melalui halaman-halaman - Mengurangi beban server saat mengambil data dalam jumlah besar - Memberikan pengalaman pengguna yang lebih baik saat mengakses data admin #### Cara Penggunaan Untuk menggunakan fitur pagination, cukup tambahkan parameter pada query string saat melakukan permintaan ke endpoint yang telah dimodifikasi. Contoh: Default jumlah data per halaman adalah 10 item. ### No Issue
194 lines
4.3 KiB
TypeScript
194 lines
4.3 KiB
TypeScript
import { prisma } from "@/lib";
|
|
import { PAGINATION_DEFAULT_TAKE } from "@/lib/constans-value/constansValue";
|
|
import _ from "lodash";
|
|
import moment from "moment";
|
|
import { NextResponse } from "next/server";
|
|
|
|
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 = Number(searchParams.get("page")) || 1;
|
|
const takeData = PAGINATION_DEFAULT_TAKE;
|
|
const skipData = page * takeData - takeData;
|
|
let fixData;
|
|
|
|
|
|
|
|
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") {
|
|
|
|
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,
|
|
tanggal: true,
|
|
tanggalSelesai: 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 },
|
|
);
|
|
}
|
|
}
|