revisi: notifikasi
Deskripsi: - membuat notifikasi jika project dan tugas divisi melewati tgl deadline NO Issues
This commit is contained in:
@@ -1,3 +1,4 @@
|
||||
import { DivisionProject } from './../../../../node_modules/.prisma/client/index.d';
|
||||
import { prisma } from "@/module/_global";
|
||||
import { funGetUserByCookies } from "@/module/auth";
|
||||
import _, { ceil } from "lodash";
|
||||
@@ -445,6 +446,134 @@ export async function GET(request: Request) {
|
||||
totalNotif: total,
|
||||
village: desa?.name
|
||||
}
|
||||
} else if (kategori == "check-late-project") {
|
||||
const supadmin = await prisma.user.findFirst({
|
||||
where: {
|
||||
idUserRole: "supadmin",
|
||||
idVillage: idVillage
|
||||
}
|
||||
})
|
||||
|
||||
const dataUmum = await prisma.projectTask.findMany({
|
||||
where: {
|
||||
Project: {
|
||||
idVillage: idVillage,
|
||||
isActive: true,
|
||||
status: {
|
||||
not: {
|
||||
in: [2, 3]
|
||||
}
|
||||
}
|
||||
},
|
||||
notifikasi: false,
|
||||
isActive: true,
|
||||
status: 0,
|
||||
dateEnd: {
|
||||
lt: new Date()
|
||||
}
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
title: true,
|
||||
dateEnd: true,
|
||||
Project: {
|
||||
select: {
|
||||
id: true,
|
||||
},
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
|
||||
for (let index = 0; index < dataUmum.length; index++) {
|
||||
await prisma.projectTask.update({
|
||||
where: {
|
||||
id: dataUmum[index].id
|
||||
},
|
||||
data: {
|
||||
notifikasi: true
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
const pertama = dataUmum.map((v: any) => ({
|
||||
..._.omit(v, ["Project", "title", "id", "dateEnd"]),
|
||||
idUserTo: String(supadmin?.id),
|
||||
idUserFrom: String(user.id),
|
||||
category: 'project',
|
||||
idContent: v.Project.id,
|
||||
title: `Tugas ${v.title} Telah Melewati Batas Waktu`,
|
||||
desc: `Tugas dengan deadline ${moment(v.dateEnd).format('DD-MM-yyyy')} telah berakhir. Silakan segera melakukan tindakan yang diperlukan.`
|
||||
}))
|
||||
|
||||
const insertNotif = await prisma.notifications.createMany({
|
||||
data: pertama
|
||||
})
|
||||
|
||||
const dataDivisi = await prisma.divisionProjectTask.findMany({
|
||||
where: {
|
||||
Division: {
|
||||
idVillage: idVillage,
|
||||
isActive: true
|
||||
},
|
||||
DivisionProject: {
|
||||
isActive: true,
|
||||
status: {
|
||||
not: {
|
||||
in: [2, 3]
|
||||
}
|
||||
}
|
||||
},
|
||||
notifikasi: false,
|
||||
isActive: true,
|
||||
status: 0,
|
||||
dateEnd: {
|
||||
lt: new Date()
|
||||
}
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
title: true,
|
||||
dateEnd: true,
|
||||
DivisionProject: {
|
||||
select: {
|
||||
id: true,
|
||||
idDivision: true
|
||||
},
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
for (let index = 0; index < dataDivisi.length; index++) {
|
||||
await prisma.divisionProjectTask.update({
|
||||
where: {
|
||||
id: dataDivisi[index].id
|
||||
},
|
||||
data: {
|
||||
notifikasi: true
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
const kedua = dataDivisi.map((v: any) => ({
|
||||
..._.omit(v, ["DivisionProject", "title", "id", "dateEnd"]),
|
||||
idUserTo: String(supadmin?.id),
|
||||
idUserFrom: String(user.id),
|
||||
category: 'division/' + v.DivisionProject.idDivision + '/task',
|
||||
idContent: v.DivisionProject.id,
|
||||
title: `Tugas ${v.title} Telah Melewati Batas Waktu`,
|
||||
desc: `Tugas dengan deadline ${moment(v.dateEnd).format('DD-MM-yyyy')} telah berakhir. Silakan segera melakukan tindakan yang diperlukan.`
|
||||
}))
|
||||
|
||||
const insertNotif2 = await prisma.notifications.createMany({
|
||||
data: kedua
|
||||
})
|
||||
|
||||
|
||||
const merge = [...pertama, ...kedua]
|
||||
|
||||
allData = merge
|
||||
|
||||
}
|
||||
|
||||
return NextResponse.json({ success: true, message: "Berhasil mendapatkan data", data: allData }, { status: 200 });
|
||||
|
||||
Reference in New Issue
Block a user