Merge pull request #155 from bipproduction/amalia/28-agustus-24

Amalia/28 agustus 24
This commit is contained in:
Amalia
2024-08-28 14:41:03 +08:00
committed by GitHub
63 changed files with 197 additions and 1666 deletions

View File

@@ -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 />
);

View File

@@ -1,8 +0,0 @@
import { DevisionLayout } from "@/module/division/ui/DivisionLayout";
export default function Layout({ children }: { children: React.ReactNode }) {
return <DevisionLayout>
{children}
</DevisionLayout>
}

View File

@@ -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>
}

View File

@@ -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 })
}

View File

@@ -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)
}

View File

@@ -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)
}

View File

@@ -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)
}

View File

@@ -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
View 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 });
}
}