Merge pull request #155 from bipproduction/amalia/28-agustus-24
Amalia/28 agustus 24
This commit is contained in:
@@ -1,14 +1,8 @@
|
||||
import { CreateCalenderDivisionCaleder, NavbarCreateDivisionCalender } from '@/module/calender';
|
||||
import { CreateUserDivisionCalender, UlangiEvent, ViewCreateDivisionCalender } from '@/module/division_new';
|
||||
import { CreateCalenderDivisionCaleder } from '@/module/calender';
|
||||
import React from 'react';
|
||||
|
||||
function Page({ searchParams }: { searchParams: any }) {
|
||||
if (searchParams.page == "ulangi-event")
|
||||
return <UlangiEvent />
|
||||
if (searchParams.page == "user-calender")
|
||||
return <CreateUserDivisionCalender />
|
||||
|
||||
|
||||
return (
|
||||
<CreateCalenderDivisionCaleder />
|
||||
);
|
||||
|
||||
@@ -1,8 +0,0 @@
|
||||
import { DevisionLayout } from "@/module/division/ui/DivisionLayout";
|
||||
|
||||
|
||||
export default function Layout({ children }: { children: React.ReactNode }) {
|
||||
return <DevisionLayout>
|
||||
{children}
|
||||
</DevisionLayout>
|
||||
}
|
||||
@@ -1,22 +0,0 @@
|
||||
|
||||
import { DivisionPage } from "@/module/division/ui/DivisionPage";
|
||||
import { SimpleGrid, Skeleton, Stack } from "@mantine/core";
|
||||
import { Suspense } from "react";
|
||||
|
||||
export default function Page({ params, searchParams }: { params: any, searchParams: any }) {
|
||||
|
||||
return <Suspense fallback={<Stack gap={"md"} p={"md"}>
|
||||
<Skeleton h={75} />
|
||||
<Skeleton h={100} />
|
||||
<SimpleGrid cols={4} spacing={"md"}>
|
||||
<Skeleton h={75} />
|
||||
<Skeleton h={75} />
|
||||
<Skeleton h={75} />
|
||||
<Skeleton h={75} />
|
||||
</SimpleGrid>
|
||||
<Skeleton h={100} />
|
||||
<Skeleton h={100} />
|
||||
</Stack>}>
|
||||
<DivisionPage params={params} searchParams={searchParams} />
|
||||
</Suspense>
|
||||
}
|
||||
@@ -1,5 +0,0 @@
|
||||
import { getCountDivision } from "@/module/division/lib/division/get_count_devision"
|
||||
export async function GET() {
|
||||
const countDivision = getCountDivision()
|
||||
return Response.json({ count: countDivision })
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
import { getListAnggota } from "@/module/division/lib/division/get_list_anggota";
|
||||
|
||||
export async function GET() {
|
||||
const listAnggota = await getListAnggota()
|
||||
return Response.json(listAnggota)
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
import { getListDevision } from "@/module/division/lib/division/get_list_devision"
|
||||
|
||||
export async function GET() {
|
||||
const list_devision = await getListDevision()
|
||||
return Response.json(list_devision)
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
import { getListGroup } from "@/module/division/lib/division/get_list_group"
|
||||
|
||||
export async function GET() {
|
||||
const listGroup = await getListGroup()
|
||||
return Response.json(listGroup)
|
||||
}
|
||||
@@ -1,4 +1,7 @@
|
||||
import { prisma } from "@/module/_global";
|
||||
import { funGetUserByCookies } from "@/module/auth";
|
||||
import _ from "lodash";
|
||||
import moment from "moment";
|
||||
import { NextResponse } from "next/server";
|
||||
|
||||
|
||||
@@ -10,12 +13,45 @@ export async function GET(request: Request) {
|
||||
}
|
||||
|
||||
const { searchParams } = new URL(request.url);
|
||||
const idDivision = searchParams.get("division");
|
||||
const date = searchParams.get("date");
|
||||
|
||||
const id = searchParams.get("id");
|
||||
const awalDate = moment(date).format('YYYY-MM') + '-01'
|
||||
const akhirDate = moment(awalDate).add(1, 'M').format('YYYY-MM-DD')
|
||||
|
||||
return NextResponse.json({ success: true, data: null }, { status: 200 });
|
||||
|
||||
const cekDivision = await prisma.division.count({
|
||||
where: {
|
||||
id: String(idDivision),
|
||||
isActive: true
|
||||
}
|
||||
})
|
||||
|
||||
if (cekDivision == 0) {
|
||||
return NextResponse.json({ success: false, message: "Gagal mendapatkan divisi, data tidak ditemukan" }, { status: 404 });
|
||||
}
|
||||
|
||||
const data = await prisma.divisionCalendar.findMany({
|
||||
where: {
|
||||
isActive: true,
|
||||
idDivision: String(idDivision),
|
||||
dateStart: {
|
||||
gte: new Date(awalDate),
|
||||
lte: new Date(akhirDate),
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
const dataGroup = _.map(_.groupBy(data, "dateStart"), (v: any) => ({
|
||||
dateContent: v[0].dateStart
|
||||
}))
|
||||
|
||||
const result = dataGroup.map(a => moment(a.dateContent).format('YYYY-MM-DD'));
|
||||
|
||||
|
||||
return NextResponse.json({ success: true, message: "Berhasil mendapatkan list acara", data: result }, { status: 200 });
|
||||
} catch (error) {
|
||||
return NextResponse.json({ success: false, message: "" }, { status: 401 });
|
||||
return NextResponse.json({ success: false, message: "Gagal mendapatkan list acara" }, { status: 401 });
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
96
src/app/api/home/route.ts
Normal file
96
src/app/api/home/route.ts
Normal file
@@ -0,0 +1,96 @@
|
||||
import { prisma } from "@/module/_global";
|
||||
import { funGetUserByCookies } from "@/module/auth";
|
||||
import _, { ceil } from "lodash";
|
||||
import moment from "moment";
|
||||
import { NextResponse } from "next/server";
|
||||
|
||||
// HOME
|
||||
export async function GET(request: Request) {
|
||||
try {
|
||||
let allData
|
||||
const user = await funGetUserByCookies()
|
||||
const { searchParams } = new URL(request.url);
|
||||
const kategori = searchParams.get("cat");
|
||||
|
||||
if (user.id == undefined) {
|
||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
||||
}
|
||||
|
||||
const roleUser = user.idUserRole
|
||||
const idVillage = user.idVillage
|
||||
const idGroup = user.idGroup
|
||||
|
||||
|
||||
if (kategori == "kegiatan") {
|
||||
let kondisi
|
||||
|
||||
// klo perbekel == semua grup
|
||||
if (roleUser == "supadmin") {
|
||||
kondisi = {
|
||||
isActive: true,
|
||||
idVillage: idVillage,
|
||||
Group: {
|
||||
isActive: true,
|
||||
}
|
||||
}
|
||||
} else {
|
||||
kondisi = {
|
||||
isActive: true,
|
||||
idGroup: idGroup
|
||||
}
|
||||
}
|
||||
|
||||
const data = await prisma.project.findMany({
|
||||
skip: 0,
|
||||
take: 5,
|
||||
where: kondisi,
|
||||
select: {
|
||||
id: true,
|
||||
title: true,
|
||||
desc: true,
|
||||
status: true,
|
||||
createdAt: true,
|
||||
ProjectTask: {
|
||||
where: {
|
||||
isActive: true
|
||||
},
|
||||
select: {
|
||||
title: true,
|
||||
status: true
|
||||
}
|
||||
}
|
||||
},
|
||||
orderBy: {
|
||||
createdAt: "desc"
|
||||
}
|
||||
})
|
||||
|
||||
allData = data.map((v: any) => ({
|
||||
..._.omit(v, ["ProjectTask", "createdAt"]),
|
||||
progress: ceil((v.ProjectTask.filter((i: any) => i.status == 1).length * 100) / v.ProjectTask.length),
|
||||
createdAt: moment(v.dateStart).format("LL")
|
||||
}))
|
||||
|
||||
}
|
||||
// else if (kategori == "division") {
|
||||
|
||||
// } else if (kategori == "progress") {
|
||||
|
||||
// } else if (kategori == "dokumen") {
|
||||
|
||||
// } else if (kategori == "event") {
|
||||
|
||||
// } else if (kategori == "discussion") {
|
||||
|
||||
// }
|
||||
|
||||
return NextResponse.json({ success: true, message: "Berhasil mendapatkan data", data: allData }, { status: 200 });
|
||||
}
|
||||
|
||||
|
||||
|
||||
catch (error) {
|
||||
console.log(error);
|
||||
return NextResponse.json({ success: false, message: "Gagal mendapatkan data, coba lagi nanti", reason: (error as Error).message, }, { status: 500 });
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user