upd: announcement
Deskripsi: - pembatasan pengumuman - fix get all No Issues
This commit is contained in:
@@ -1,5 +1,6 @@
|
|||||||
import { prisma } from "@/module/_global";
|
import { prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserByCookies } from "@/module/auth";
|
||||||
|
import { createLogUser } from "@/module/user";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
@@ -30,7 +31,7 @@ export async function GET(request: Request, context: { params: { id: string } })
|
|||||||
},
|
},
|
||||||
{ status: 404 }
|
{ status: 404 }
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const announcement = await prisma.announcement.findUnique({
|
const announcement = await prisma.announcement.findUnique({
|
||||||
where: {
|
where: {
|
||||||
@@ -126,6 +127,9 @@ export async function DELETE(request: Request, context: { params: { id: string }
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// create log user
|
||||||
|
const log = await createLogUser({ act: 'DELETE', desc: 'User menghapus data pengumuman', table: 'announcement', data: id })
|
||||||
|
|
||||||
return NextResponse.json(
|
return NextResponse.json(
|
||||||
{
|
{
|
||||||
success: true,
|
success: true,
|
||||||
@@ -206,11 +210,14 @@ export async function PUT(request: Request, context: { params: { id: string } })
|
|||||||
data: memberDivision,
|
data: memberDivision,
|
||||||
});
|
});
|
||||||
|
|
||||||
return NextResponse.json({ success: true, message: "Berhasil mengedit pengumuman" }, { status: 200 });
|
// create log user
|
||||||
|
const log = await createLogUser({ act: 'UPDATE', desc: 'User mengupdate data pengumuman', table: 'announcement', data: id })
|
||||||
|
|
||||||
|
return NextResponse.json({ success: true, message: "Berhasil mengupdate pengumuman" }, { status: 200 });
|
||||||
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error(error);
|
console.error(error);
|
||||||
return NextResponse.json({ success: false, message: "Gagal mengedit pengumuman, coba lagi nanti", reason: (error as Error).message, }, { status: 500 });
|
return NextResponse.json({ success: false, message: "Gagal mengeupdate pengumuman, coba lagi nanti", reason: (error as Error).message, }, { status: 500 });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
import { Group } from '@mantine/core';
|
|
||||||
import { prisma } from "@/module/_global";
|
import { prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserByCookies } from "@/module/auth";
|
||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import moment from "moment";
|
import moment from "moment";
|
||||||
import "moment/locale/id";
|
import "moment/locale/id";
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
import { createLogUser } from '@/module/user';
|
||||||
|
|
||||||
export const dynamic = 'force-dynamic'
|
export const dynamic = 'force-dynamic'
|
||||||
|
|
||||||
@@ -19,17 +19,63 @@ export async function GET(request: Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const villageId = user.idVillage
|
const villageId = user.idVillage
|
||||||
|
const roleUser = user.idUserRole
|
||||||
|
const groupId = user.idGroup
|
||||||
const { searchParams } = new URL(request.url);
|
const { searchParams } = new URL(request.url);
|
||||||
const name = searchParams.get('search');
|
const name = searchParams.get('search');
|
||||||
const announcements = await prisma.announcement.findMany({
|
|
||||||
where: {
|
let kondisi: any = {
|
||||||
idVillage: String(villageId),
|
idVillage: String(villageId),
|
||||||
isActive: true,
|
isActive: true,
|
||||||
title: {
|
title: {
|
||||||
contains: (name == undefined || name == null) ? "" : name,
|
contains: (name == undefined || name == null) ? "" : name,
|
||||||
mode: "insensitive"
|
mode: "insensitive"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (roleUser != "supadmin") {
|
||||||
|
if (roleUser == "cosupadmin" || roleUser == "admin") {
|
||||||
|
kondisi = {
|
||||||
|
idVillage: String(villageId),
|
||||||
|
isActive: true,
|
||||||
|
title: {
|
||||||
|
contains: (name == undefined || name == null) ? "" : name,
|
||||||
|
mode: "insensitive"
|
||||||
|
},
|
||||||
|
AnnouncementMember: {
|
||||||
|
some: {
|
||||||
|
idGroup: String(groupId)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
},
|
} else {
|
||||||
|
kondisi = {
|
||||||
|
idVillage: String(villageId),
|
||||||
|
isActive: true,
|
||||||
|
title: {
|
||||||
|
contains: (name == undefined || name == null) ? "" : name,
|
||||||
|
mode: "insensitive"
|
||||||
|
},
|
||||||
|
AnnouncementMember: {
|
||||||
|
some: {
|
||||||
|
idGroup: String(groupId),
|
||||||
|
Division: {
|
||||||
|
DivisionMember: {
|
||||||
|
some: {
|
||||||
|
idUser: String(user.id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const announcements = await prisma.announcement.findMany({
|
||||||
|
where: kondisi,
|
||||||
select: {
|
select: {
|
||||||
id: true,
|
id: true,
|
||||||
title: true,
|
title: true,
|
||||||
@@ -98,6 +144,9 @@ export async function POST(request: Request) {
|
|||||||
data: memberDivision,
|
data: memberDivision,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// create log user
|
||||||
|
const log = await createLogUser({ act: 'CREATE', desc: 'User membuat data pengumuman baru', table: 'announcement', data: data.id })
|
||||||
|
|
||||||
return NextResponse.json({ success: true, message: "Berhasil membuat pengumuman" }, { status: 200 });
|
return NextResponse.json({ success: true, message: "Berhasil membuat pengumuman" }, { status: 200 });
|
||||||
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
import { prisma } from "@/module/_global";
|
import { prisma } from "@/module/_global";
|
||||||
import { funGetUserByCookies } from "@/module/auth";
|
import { funGetUserByCookies } from "@/module/auth";
|
||||||
import { revalidatePath, revalidateTag } from "next/cache";
|
|
||||||
import { NextResponse } from "next/server";
|
import { NextResponse } from "next/server";
|
||||||
|
|
||||||
export const dynamic = 'force-dynamic'
|
export const dynamic = 'force-dynamic'
|
||||||
@@ -11,13 +10,24 @@ export async function GET(request: Request) {
|
|||||||
if (user.id == undefined) {
|
if (user.id == undefined) {
|
||||||
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 401 });
|
||||||
}
|
}
|
||||||
|
const role = user.idUserRole
|
||||||
const villaId = user.idVillage
|
const villaId = user.idVillage
|
||||||
const data = await prisma.group.findMany({
|
const group = user.idGroup
|
||||||
where: {
|
let kondisi: any = {
|
||||||
|
isActive: true,
|
||||||
|
idVillage: String(villaId)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (role != "supadmin") {
|
||||||
|
kondisi = {
|
||||||
isActive: true,
|
isActive: true,
|
||||||
idVillage: String(villaId)
|
idVillage: String(villaId),
|
||||||
},
|
id: String(group)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const data = await prisma.group.findMany({
|
||||||
|
where: kondisi,
|
||||||
select: {
|
select: {
|
||||||
id: true,
|
id: true,
|
||||||
name: true,
|
name: true,
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ import CreateUsersAnnouncement from "./create_users_announcement";
|
|||||||
import { globalMemberAnnouncement } from "../lib/val_announcement";
|
import { globalMemberAnnouncement } from "../lib/val_announcement";
|
||||||
import { funCreateAnnouncement } from "../lib/api_announcement";
|
import { funCreateAnnouncement } from "../lib/api_announcement";
|
||||||
import { GroupData, ICreateData, IGroupData } from "../lib/type_announcement";
|
import { GroupData, ICreateData, IGroupData } from "../lib/type_announcement";
|
||||||
|
import { useRouter } from "next/navigation";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -19,6 +20,7 @@ export default function CreateAnnouncement() {
|
|||||||
const memberGroup = useHookstate(globalMemberAnnouncement)
|
const memberGroup = useHookstate(globalMemberAnnouncement)
|
||||||
const memberValue = memberGroup.get() as GroupData[]
|
const memberValue = memberGroup.get() as GroupData[]
|
||||||
const [selectedFiles, setSelectedFiles] = useState<any>([])
|
const [selectedFiles, setSelectedFiles] = useState<any>([])
|
||||||
|
const router = useRouter()
|
||||||
|
|
||||||
|
|
||||||
const [isChooseMember, setIsChooseMember] = useState(false)
|
const [isChooseMember, setIsChooseMember] = useState(false)
|
||||||
@@ -42,12 +44,13 @@ export default function CreateAnnouncement() {
|
|||||||
|
|
||||||
if (response.success) {
|
if (response.success) {
|
||||||
toast.success(response.message)
|
toast.success(response.message)
|
||||||
setisData({
|
// setisData({
|
||||||
...isData,
|
// ...isData,
|
||||||
title: "",
|
// title: "",
|
||||||
desc: "",
|
// desc: "",
|
||||||
})
|
// })
|
||||||
memberGroup.set([])
|
memberGroup.set([])
|
||||||
|
router.push('/announcement')
|
||||||
} else {
|
} else {
|
||||||
toast.error(response.message)
|
toast.error(response.message)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,20 +1,24 @@
|
|||||||
"use client"
|
"use client"
|
||||||
import { LayoutDrawer, LayoutNavbarNew, WARNA } from '@/module/_global';
|
import { globalRole, LayoutDrawer, LayoutNavbarNew, WARNA } from '@/module/_global';
|
||||||
import { ActionIcon } from '@mantine/core';
|
import { ActionIcon } from '@mantine/core';
|
||||||
import React, { useState } from 'react';
|
import React, { useState } from 'react';
|
||||||
import { HiMenu } from "react-icons/hi";
|
import { HiMenu } from "react-icons/hi";
|
||||||
import DrawerAnnouncement from './drawer_announcement';
|
import DrawerAnnouncement from './drawer_announcement';
|
||||||
|
import { useHookstate } from '@hookstate/core';
|
||||||
|
|
||||||
export default function NavbarAnnouncement() {
|
export default function NavbarAnnouncement() {
|
||||||
const [isOpen, setOpen] = useState(false)
|
const [isOpen, setOpen] = useState(false)
|
||||||
|
const roleLogin = useHookstate(globalRole)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<LayoutNavbarNew back='/home' title='pengumuman'
|
<LayoutNavbarNew back='/home' title='pengumuman'
|
||||||
menu={
|
menu={
|
||||||
<ActionIcon onClick={() => setOpen(true)} variant="light" bg={WARNA.bgIcon} size="lg" radius="lg" aria-label="Settings">
|
(roleLogin.get() != "user" && roleLogin.get() != "coadmin") ?
|
||||||
<HiMenu size={20} color='white' />
|
<ActionIcon onClick={() => setOpen(true)} variant="light" bg={WARNA.bgIcon} size="lg" radius="lg" aria-label="Settings">
|
||||||
</ActionIcon>
|
<HiMenu size={20} color='white' />
|
||||||
|
</ActionIcon>
|
||||||
|
: <></>
|
||||||
} />
|
} />
|
||||||
<LayoutDrawer opened={isOpen} title={'Menu'} onClose={() => setOpen(false)}>
|
<LayoutDrawer opened={isOpen} title={'Menu'} onClose={() => setOpen(false)}>
|
||||||
<DrawerAnnouncement />
|
<DrawerAnnouncement />
|
||||||
|
|||||||
@@ -1,21 +1,26 @@
|
|||||||
'use client'
|
'use client'
|
||||||
import { LayoutDrawer, LayoutNavbarNew, WARNA } from "@/module/_global";
|
import { globalRole, LayoutDrawer, LayoutNavbarNew, WARNA } from "@/module/_global";
|
||||||
import { ActionIcon, Box } from "@mantine/core";
|
import { ActionIcon, Box } from "@mantine/core";
|
||||||
import { HiMenu } from "react-icons/hi";
|
import { HiMenu } from "react-icons/hi";
|
||||||
import DrawerDetailAnnouncement from "./drawer_detail_announcement";
|
import DrawerDetailAnnouncement from "./drawer_detail_announcement";
|
||||||
import { useState } from "react";
|
import { useState } from "react";
|
||||||
import { useRouter } from "next/navigation";
|
import { useRouter } from "next/navigation";
|
||||||
|
import { useHookstate } from "@hookstate/core";
|
||||||
|
|
||||||
export default function NavbarDetailAnnouncement() {
|
export default function NavbarDetailAnnouncement() {
|
||||||
const [isOpenDrawer, setOpenDrawer] = useState(false)
|
const [isOpenDrawer, setOpenDrawer] = useState(false)
|
||||||
const router = useRouter()
|
const router = useRouter()
|
||||||
|
const roleLogin = useHookstate(globalRole)
|
||||||
return (
|
return (
|
||||||
<Box>
|
<Box>
|
||||||
<LayoutNavbarNew back="/announcement/" title="Pengumuman"
|
<LayoutNavbarNew back="/announcement/" title="Pengumuman"
|
||||||
menu={
|
menu={
|
||||||
<ActionIcon onClick={() => setOpenDrawer(true)} variant="light" bg={WARNA.bgIcon} size="lg" radius="lg" aria-label="Settings">
|
(roleLogin.get() != "user" && roleLogin.get() != "coadmin") ?
|
||||||
<HiMenu size={20} color='white' />
|
<ActionIcon onClick={() => setOpenDrawer(true)} variant="light" bg={WARNA.bgIcon} size="lg" radius="lg" aria-label="Settings">
|
||||||
</ActionIcon>}
|
<HiMenu size={20} color='white' />
|
||||||
|
</ActionIcon>
|
||||||
|
: <></>
|
||||||
|
}
|
||||||
/>
|
/>
|
||||||
<LayoutDrawer opened={isOpenDrawer} title={'Menu'} onClose={() => setOpenDrawer(false)}>
|
<LayoutDrawer opened={isOpenDrawer} title={'Menu'} onClose={() => setOpenDrawer(false)}>
|
||||||
<DrawerDetailAnnouncement onDeleted={(val) => {
|
<DrawerDetailAnnouncement onDeleted={(val) => {
|
||||||
|
|||||||
Reference in New Issue
Block a user