6 Commits

Author SHA1 Message Date
e5b95a828d upd: diskusi divisi
deskripsi:
- schema db
- api tambah detail dan update diskusi divisi

NO Issues'
2026-01-19 10:21:56 +08:00
1f6791e9bd Merge pull request 'upd: api diskusi umum' (#3) from amalia/15-jan-26 into join
Reviewed-on: http://wibugit.wibudev.com/wibu/sistem-desa-mandiri/pulls/3
2026-01-15 17:37:15 +08:00
968202e34b upd: api diskusi umum
Deskripsi:
- tambah file pada data diskusi umum
- detail file pada get one diskusi umum

No Issues
2026-01-15 17:34:51 +08:00
0ce94e0e2b Merge pull request 'req: pengumuman' (#2) from amalia/14-jan-26 into join
Reviewed-on: http://wibugit.wibudev.com/wibu/sistem-desa-mandiri/pulls/2
2026-01-14 17:44:14 +08:00
9f3acf306e req: pengumuman
Deskripsi:
- struktur db pengumuman
- api tambah pengumuman
- api detail pengumuman
- api update pengumuman

No Issues
2026-01-14 15:02:43 +08:00
3d2a35446c Merge pull request 'amalia/16-okt-25' (#1) from amalia/16-okt-25 into join
Reviewed-on: http://wibugit.wibudev.com/wibu/sistem-desa-mandiri/pulls/1
2025-10-27 10:59:59 +08:00
8 changed files with 269 additions and 18 deletions

View File

@@ -168,6 +168,7 @@ model Announcement {
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
AnnouncementMember AnnouncementMember[]
AnnouncementFile AnnouncementFile[]
}
model AnnouncementMember {
@@ -183,6 +184,18 @@ model AnnouncementMember {
updatedAt DateTime @updatedAt
}
model AnnouncementFile {
id String @id @default(cuid())
Announcement Announcement @relation(fields: [idAnnouncement], references: [id])
idAnnouncement String
name String
extension String
idStorage String?
isActive Boolean @default(true)
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model Project {
id String @id @default(cuid())
Village Village @relation(fields: [idVillage], references: [id])
@@ -410,6 +423,7 @@ model DivisionDisscussion {
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
DivisionDisscussionComment DivisionDisscussionComment[]
DivisionDiscussionFile DivisionDiscussionFile[]
}
model DivisionDisscussionComment {
@@ -424,6 +438,17 @@ model DivisionDisscussionComment {
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model DivisionDiscussionFile {
id String @id @default(cuid())
DivisionDisscussion DivisionDisscussion @relation(fields: [idDiscussion], references: [id])
idDiscussion String
name String
extension String
idStorage String?
isActive Boolean @default(true)
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model DivisionDocumentFolderFile {
id String @id @default(cuid())
@@ -595,6 +620,7 @@ model Discussion {
updatedAt DateTime @updatedAt
DiscussionMember DiscussionMember[]
DiscussionComment DiscussionComment[]
DiscussionFile DiscussionFile[]
}
model DiscussionMember {
@@ -620,3 +646,15 @@ model DiscussionComment {
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model DiscussionFile {
id String @id @default(cuid())
Discussion Discussion @relation(fields: [idDiscussion], references: [id])
idDiscussion String
name String
extension String
idStorage String?
isActive Boolean @default(true)
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}

View File

@@ -1,4 +1,4 @@
import { prisma } from "@/module/_global";
import { DIR, funUploadFile, prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from "@/module/user";
import _ from "lodash";
@@ -76,13 +76,26 @@ export async function GET(request: Request, context: { params: { id: string } })
// const fixMember = Object.groupBy(formatMember, ({ group }) => group);
const fixMember = _.groupBy(formatMember, ({ group }) => group);
const file = await prisma.announcementFile.findMany({
where: {
idAnnouncement: id
},
select: {
id: true,
idStorage: true,
name: true,
extension: true
}
})
return NextResponse.json(
{
success: true,
message: "Berhasil mendapatkan pengumuman",
data: announcement,
member: fixMember
member: fixMember,
file: file
},
{ status: 200 }
);
@@ -154,7 +167,12 @@ export async function DELETE(request: Request, context: { params: { id: string }
// EDIT PENGUMUMAN
export async function PUT(request: Request, context: { params: { id: string } }) {
try {
const { title, desc, groups, user } = (await request.json());
const body = await request.formData()
const dataBody = body.get("data")
const cekFile = body.has("file0")
// const { title, desc, groups, user } = (await request.json());
const { title, desc, groups, user, oldFile } = JSON.parse(dataBody as string)
const { id } = context.params;
const userMobile = await funGetUserById({ id: String(user) })
@@ -214,6 +232,41 @@ export async function PUT(request: Request, context: { params: { id: string } })
data: memberDivision,
});
if (oldFile.length > 0) {
for (let index = 0; index < oldFile.length; index++) {
const element = oldFile[index];
if (element.delete) {
await prisma.announcementFile.delete({
where: {
id: element.id
}
})
}
}
}
if (cekFile) {
body.delete("data")
for (var pair of body.entries()) {
if (String(pair[0]).substring(0, 4) == "file") {
const file = body.get(pair[0]) as File
const fExt = file.name.split(".").pop()
const fName = decodeURIComponent(file.name.replace("." + fExt, ""))
const upload = await funUploadFile({ file: file, dirId: DIR.announcement })
if (upload.success) {
await prisma.announcementFile.create({
data: {
idStorage: upload.data.id,
idAnnouncement: id,
name: fName,
extension: String(fExt)
}
})
}
}
}
}
// create log user
const log = await createLogUserMobile({ act: 'UPDATE', desc: 'User mengupdate data pengumuman', table: 'announcement', data: id, user: userMobile.id })

View File

@@ -1,4 +1,4 @@
import { funSendWebPush, prisma } from "@/module/_global";
import { DIR, funSendWebPush, funUploadFile, prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from '@/module/user';
import _ from "lodash";
@@ -113,7 +113,12 @@ export async function GET(request: Request) {
// CREATE PENGUMUMAN
export async function POST(request: Request) {
try {
const { title, desc, groups, user } = (await request.json());
const body = await request.formData()
const dataBody = body.get("data")
const cekFile = body.has("file0")
// const { title, desc, groups, user } = (await request.json());
const { title, desc, groups, user } = JSON.parse(dataBody as string)
const userMobile = await funGetUserById({ id: String(user) })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
@@ -152,6 +157,29 @@ export async function POST(request: Request) {
}
}
if (cekFile) {
body.delete("data")
for (var pair of body.entries()) {
if (String(pair[0]).substring(0, 4) == "file") {
const file = body.get(pair[0]) as File
const fExt = file.name.split(".").pop()
const fName = decodeURIComponent(file.name.replace("." + fExt, ""))
const upload = await funUploadFile({ file: file, dirId: DIR.announcement })
if (upload.success) {
await prisma.announcementFile.create({
data: {
idStorage: upload.data.id,
idAnnouncement: data.id,
name: fName,
extension: String(fExt)
}
})
}
}
}
}
const announcementMember = await prisma.announcementMember.createMany({
data: memberDivision,
});

View File

@@ -1,4 +1,4 @@
import { countTime, prisma } from "@/module/_global";
import { countTime, DIR, funUploadFile, prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from "@/module/user";
import _ from "lodash";
@@ -8,7 +8,7 @@ import { NextResponse } from "next/server";
// GET ONE DETAIL DISKUSI UMUM
export async function GET(request : Request, context: { params: { id: string } }) {
export async function GET(request: Request, context: { params: { id: string } }) {
try {
let dataFix
const { id } = context.params
@@ -127,8 +127,21 @@ export async function GET(request : Request, context: { params: { id: string } }
} else {
dataFix = false
}
}
} else if (kategori == "file") {
const data = await prisma.discussionFile.findMany({
where: {
idDiscussion: id
},
select: {
id: true,
idStorage: true,
name: true,
extension: true
}
})
dataFix = data
}
return NextResponse.json({ success: true, message: "Berhasil mendapatkan diskusi", data: dataFix }, { status: 200 });
@@ -247,7 +260,12 @@ export async function DELETE(request: Request, context: { params: { id: string }
export async function PUT(request: Request, context: { params: { id: string } }) {
try {
const { id } = context.params
const { title, desc, user } = (await request.json());
const body = await request.formData()
const dataBody = body.get("data")
const cekFile = body.has("file0")
// const { title, desc, user } = (await request.json());
const { title, desc, user, oldFile } = JSON.parse(dataBody as string)
const userMobile = await funGetUserById({ id: String(user) })
@@ -275,6 +293,41 @@ export async function PUT(request: Request, context: { params: { id: string } })
}
});
if (oldFile.length > 0) {
for (let index = 0; index < oldFile.length; index++) {
const element = oldFile[index];
if (element.delete) {
await prisma.discussionFile.delete({
where: {
id: element.id
}
})
}
}
}
if (cekFile) {
body.delete("data")
for (var pair of body.entries()) {
if (String(pair[0]).substring(0, 4) == "file") {
const file = body.get(pair[0]) as File
const fExt = file.name.split(".").pop()
const fName = decodeURIComponent(file.name.replace("." + fExt, ""))
const upload = await funUploadFile({ file: file, dirId: DIR.discussion })
if (upload.success) {
await prisma.discussionFile.create({
data: {
idStorage: upload.data.id,
idDiscussion: id,
name: fName,
extension: String(fExt)
}
})
}
}
}
}
// create log user
const log = await createLogUserMobile({ act: 'UPDATE', desc: 'User mengupdate data diskusi umum', table: 'discussion', data: id, user: userMobile.id })
return NextResponse.json({ success: true, message: "Berhasil mengedit diskusi umum" }, { status: 200 });

View File

@@ -1,4 +1,4 @@
import { prisma } from "@/module/_global";
import { DIR, funUploadFile, prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from "@/module/user";
import _ from "lodash";
@@ -112,13 +112,20 @@ export async function GET(request: Request) {
// CREATE DISCUSSION GENERALE
export async function POST(request: Request) {
try {
const { idGroup, user, title, desc, member } = await request.json();
if (user == "null" || user == undefined || user == "") {
const body = await request.formData()
const dataBody = body.get("data")
const cekFile = body.has("file0")
// const { idGroup, user, title, desc, member } = await request.json();
const { idGroup, user, title, desc, member } = JSON.parse(dataBody as string)
const userMobile = await funGetUserById({ id: user })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
}
const userMobile = await funGetUserById({ id: user })
const userId = user
const userRoleLogin = userMobile.idUserRole
@@ -145,6 +152,29 @@ export async function POST(request: Request) {
data: dataMember
})
if (cekFile) {
body.delete("data")
for (var pair of body.entries()) {
if (String(pair[0]).substring(0, 4) == "file") {
const file = body.get(pair[0]) as File
const fExt = file.name.split(".").pop()
const fName = decodeURIComponent(file.name.replace("." + fExt, ""))
const upload = await funUploadFile({ file: file, dirId: DIR.discussion })
if (upload.success) {
await prisma.discussionFile.create({
data: {
idStorage: upload.data.id,
idDiscussion: data.id,
name: fName,
extension: String(fExt)
}
})
}
}
}
}
const memberNotifMobile = await prisma.discussionMember.findMany({
where: {
idDiscussion: data.id

View File

@@ -70,6 +70,21 @@ export async function GET(request: Request, context: { params: { id: string } })
}))
return NextResponse.json({ success: true, message: "Berhasil mendapatkan komentar", data: omitMember }, { status: 200 });
} else if (cat == "file") {
const data = await prisma.divisionDiscussionFile.findMany({
where: {
idDiscussion: id,
isActive: true
},
select: {
id: true,
idStorage: true,
name: true,
extension: true
}
})
return NextResponse.json({ success: true, message: "Berhasil mendapatkan file", data: data }, { status: 200 });
} else {
const data = await prisma.divisionDisscussion.findUnique({
where: {

View File

@@ -1,4 +1,5 @@
import { funSendWebPush, prisma } from "@/module/_global";
import { DivisionDiscussionFile } from './../../../../../node_modules/.prisma/client/index.d';
import { DIR, funSendWebPush, funUploadFile, prisma } from "@/module/_global";
import { funGetUserById } from "@/module/auth";
import { createLogUserMobile } from "@/module/user";
import _ from "lodash";
@@ -102,7 +103,14 @@ export async function GET(request: Request) {
// CREATE DISCUSSION
export async function POST(request: Request) {
try {
const { idDivision, desc, user } = (await request.json());
const body = await request.formData()
const dataBody = body.get("data")
const cekFile = body.has("file0")
// const { idDivision, desc, user } = (await request.json());
const { idDivision, desc, user } = JSON.parse(String(dataBody));
const userMobile = await funGetUserById({ id: String(user) })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
@@ -135,6 +143,29 @@ export async function POST(request: Request) {
}
});
if (cekFile) {
body.delete("data")
for (var pair of body.entries()) {
if (String(pair[0]).substring(0, 4) == "file") {
const file = body.get(pair[0]) as File
const fExt = file.name.split(".").pop()
const fName = decodeURIComponent(file.name.replace("." + fExt, ""))
const upload = await funUploadFile({ file: file, dirId: DIR.discussionDivision })
if (upload.success) {
await prisma.divisionDiscussionFile.create({
data: {
idStorage: upload.data.id,
idDiscussion: data.id,
name: fName,
extension: String(fExt)
}
})
}
}
}
}
const memberDivision = await prisma.divisionMember.findMany({
where: {
idDivision: idDivision

View File

@@ -1,6 +1,6 @@
import { hookstate } from "@hookstate/core"
import { IGlobalTema } from './type_global';
import { hookstate } from "@hookstate/core";
import { RefObject } from "react";
import { IGlobalTema } from './type_global';
export const pwd_key_config = "fchgvjknlmdfnbvghhujlaknsdvjbhknlkmsdbdyu567t8y9u30r4587638y9uipkoeghjvuyi89ipkoefmnrjbhtiu4or9ipkoemnjfbhjiuoijdklnjhbviufojkejnshbiuojijknehgruyu"
export const globalRole = hookstate<string>('')
@@ -11,7 +11,10 @@ export const DIR = {
document: "cm0xhbkf50009acbbtw03qo4l",
village: "cm0xhb91o0007acbbkx8rk8hj",
user: "cm0x8dbwn0005bp5tgmfcthzw",
banner: "cm1sxex19004938bjvyaq8vta"
banner: "cm1sxex19004938bjvyaq8vta",
announcement: "cmkdfkze4005hkhjgunsroi4t",
discussion: "cmkf5h7ic006jkhjgyrkog7ut",
discussionDivision: "cmkdfktfm005fkhjggjvnqly5"
}
export const keyWibu = 'padahariminggukuturutayahkekotanaikdelmanistimewakududukdimuka'