feat : update search

Deskripsi:
- add api search

No Issue
This commit is contained in:
lukman
2024-08-28 17:39:53 +08:00
committed by amel
parent 2d31379382
commit 0fe48f0f30
4 changed files with 139 additions and 1 deletions

View File

@@ -0,0 +1,103 @@
// SEARCH USER, DIVISION, PROJECT
import { prisma } from "@/module/_global";
import { funGetUserByCookies } from "@/module/auth";
import { NextResponse } from "next/server";
export async function GET(request: Request) {
try {
const { searchParams } = new URL(request.url);
const search = searchParams.get("search");
const userId = await funGetUserByCookies()
if (userId.id == undefined) {
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
}
let kondisi: any, kondisiProject: any
// klo perbekel == semua grup
if (userId.idUserRole == "supadmin") {
kondisi = {
isActive: true,
idVillage: userId.idVillage,
Group: {
isActive: true,
},
name: {
contains: (search == undefined || search == null) ? "" : search,
mode: "insensitive"
}
}
kondisiProject = {
isActive: true,
idVillage: userId.idVillage,
Group: {
isActive: true,
},
title: {
contains: (search == undefined || search == null) ? "" : search,
mode: "insensitive"
}
}
} else {
kondisi = {
idVillage: userId.idVillage,
isActive: true,
idGroup: userId.idGroup,
name: {
contains: (search == undefined || search == null) ? "" : search,
mode: "insensitive"
}
}
kondisiProject = {
idVillage: userId.idVillage,
isActive: true,
idGroup: userId.idGroup,
title: {
contains: (search == undefined || search == null) ? "" : search,
mode: "insensitive"
}
}
}
const user = await prisma.user.findMany({
where: kondisi,
select: {
id: true,
name: true,
email: true
}
})
const divisions = await prisma.division.findMany({
where: kondisi,
select: {
id: true,
name: true,
desc: true
}
})
const projects = await prisma.project.findMany({
where: kondisiProject,
select: {
id: true,
title: true,
}
})
const allDataSearch = {
user: user,
division: divisions,
project: projects
}
return NextResponse.json({ success: true, data: allDataSearch }, { status: 200 });
} catch (error) {
return NextResponse.json({ success: false, message: error }, { status: 500 });
}
}