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
This commit is contained in:
2025-10-27 10:59:59 +08:00
32 changed files with 518 additions and 138 deletions

View File

@@ -420,6 +420,7 @@ model DivisionDisscussionComment {
isActive Boolean @default(true) isActive Boolean @default(true)
User User @relation(fields: [createdBy], references: [id]) User User @relation(fields: [createdBy], references: [id])
createdBy String createdBy String
isEdited Boolean @default(false)
createdAt DateTime @default(now()) createdAt DateTime @default(now())
updatedAt DateTime @updatedAt updatedAt DateTime @updatedAt
} }
@@ -615,6 +616,7 @@ model DiscussionComment {
idUser String idUser String
comment String @db.Text comment String @db.Text
isActive Boolean @default(true) isActive Boolean @default(true)
isEdited Boolean @default(false)
createdAt DateTime @default(now()) createdAt DateTime @default(now())
updatedAt DateTime @updatedAt updatedAt DateTime @updatedAt
} }

View File

@@ -3,8 +3,8 @@ import { funGetUserByCookies } from "@/module/auth";
import { createLogUser } from "@/module/user"; import { createLogUser } from "@/module/user";
import _ from "lodash"; import _ from "lodash";
import moment from "moment"; import moment from "moment";
import { NextResponse } from "next/server";
import "moment/locale/id"; import "moment/locale/id";
import { NextResponse } from "next/server";
// GET ONE DETAIL DISKUSI UMUM // GET ONE DETAIL DISKUSI UMUM
@@ -75,6 +75,9 @@ export async function GET(request: Request, context: { params: { id: string } })
img: true img: true
} }
} }
},
orderBy: {
createdAt: "asc"
} }
}) })

View File

@@ -74,6 +74,9 @@ export async function GET(request: Request) {
DiscussionComment: { DiscussionComment: {
select: { select: {
id: true, id: true,
},
where:{
isActive:true
} }
} }
} }

View File

@@ -60,6 +60,12 @@ export async function GET(request: Request, context: { params: { id: string } })
img: true img: true
} }
} }
},
where: {
isActive:true
},
orderBy: {
createdAt: "asc"
} }
}, },
} }

View File

@@ -64,6 +64,9 @@ export async function GET(request: Request) {
DivisionDisscussionComment: { DivisionDisscussionComment: {
select: { select: {
id: true, id: true,
},
where:{
isActive:true
} }
} }
} }

View File

@@ -1,4 +1,3 @@
import { DivisionProject } from './../../../../node_modules/.prisma/client/index.d';
import { prisma } from "@/module/_global"; import { prisma } from "@/module/_global";
import { funGetUserByCookies } from "@/module/auth"; import { funGetUserByCookies } from "@/module/auth";
import _, { ceil } from "lodash"; import _, { ceil } from "lodash";
@@ -36,22 +35,28 @@ export async function GET(request: Request) {
isActive: true, isActive: true,
} }
} }
} else if (roleUser == "admin" || roleUser == "cosupadmin") { } else {
kondisi = { kondisi = {
isActive: true, isActive: true,
idGroup: idGroup idGroup: idGroup
} }
} else {
kondisi = {
isActive: true,
idGroup: idGroup,
ProjectMember: {
some: {
idUser: user.id
}
}
}
} }
// else if (roleUser == "admin" || roleUser == "cosupadmin") {
// kondisi = {
// isActive: true,
// idGroup: idGroup
// }
// } else {
// kondisi = {
// isActive: true,
// idGroup: idGroup,
// ProjectMember: {
// some: {
// idUser: user.id
// }
// }
// }
// }
const data = await prisma.project.findMany({ const data = await prisma.project.findMany({
skip: 0, skip: 0,
@@ -74,7 +79,7 @@ export async function GET(request: Request) {
} }
}, },
orderBy: { orderBy: {
createdAt: "desc" updatedAt: "desc"
} }
}) })
@@ -96,22 +101,28 @@ export async function GET(request: Request) {
isActive: true, isActive: true,
} }
} }
} else if (roleUser == "admin" || roleUser == "cosupadmin") { } else {
kondisi = { kondisi = {
isActive: true, isActive: true,
idGroup: idGroup idGroup: idGroup
} }
} else {
kondisi = {
isActive: true,
idGroup: idGroup,
DivisionMember: {
some: {
idUser: user.id
}
}
}
} }
// else if (roleUser == "admin" || roleUser == "cosupadmin") {
// kondisi = {
// isActive: true,
// idGroup: idGroup
// }
// } else {
// kondisi = {
// isActive: true,
// idGroup: idGroup,
// DivisionMember: {
// some: {
// idUser: user.id
// }
// }
// }
// }
const data = await prisma.division.findMany({ const data = await prisma.division.findMany({
where: kondisi, where: kondisi,
@@ -134,7 +145,9 @@ export async function GET(request: Request) {
jumlah: v.DivisionProject.length, jumlah: v.DivisionProject.length,
})) }))
allData = _.orderBy(format, 'jumlah', 'desc').slice(0, 5) const filter = format.filter((v: any) => v.jumlah > 0)
allData = _.orderBy(filter, 'jumlah', 'desc').slice(0, 5)
} else if (kategori == "progress") { } else if (kategori == "progress") {
let kondisi let kondisi
@@ -143,37 +156,50 @@ export async function GET(request: Request) {
if (roleUser == "supadmin" || roleUser == "developer") { if (roleUser == "supadmin" || roleUser == "developer") {
kondisi = { kondisi = {
isActive: true, isActive: true,
Division: { idVillage: idVillage,
Group: {
isActive: true, isActive: true,
idVillage: idVillage,
Group: {
isActive: true,
}
}
}
} else if (roleUser == "admin" || roleUser == "cosupadmin") {
kondisi = {
isActive: true,
Division: {
isActive: true,
idGroup: idGroup
} }
} }
// kondisi = {
// isActive: true,
// Division: {
// isActive: true,
// idVillage: idVillage,
// Group: {
// isActive: true,
// }
// }
// }
} else { } else {
kondisi = { kondisi = {
isActive: true, isActive: true,
Division: { idGroup: idGroup
isActive: true,
DivisionMember: {
some: {
idUser: user.id
}
}
}
} }
} }
// else if (roleUser == "admin" || roleUser == "cosupadmin") {
// kondisi = {
// isActive: true,
// Division: {
// isActive: true,
// idGroup: idGroup
// }
// }
// } else {
// kondisi = {
// isActive: true,
// Division: {
// isActive: true,
// DivisionMember: {
// some: {
// idUser: user.id
// }
// }
// }
// }
// }
const data = await prisma.divisionProject.groupBy({ const data = await prisma.project.groupBy({
where: kondisi, where: kondisi,
by: ["status"], by: ["status"],
_count: true _count: true
@@ -218,7 +244,7 @@ export async function GET(request: Request) {
} }
} }
} }
} else if (roleUser == "admin" || roleUser == "cosupadmin") { } else {
kondisi = { kondisi = {
isActive: true, isActive: true,
category: 'FILE', category: 'FILE',
@@ -227,20 +253,30 @@ export async function GET(request: Request) {
idGroup: idGroup idGroup: idGroup
} }
} }
} else {
kondisi = {
isActive: true,
category: 'FILE',
Division: {
isActive: true,
DivisionMember: {
some: {
idUser: user.id
}
}
}
}
} }
// else if (roleUser == "admin" || roleUser == "cosupadmin") {
// kondisi = {
// isActive: true,
// category: 'FILE',
// Division: {
// isActive: true,
// idGroup: idGroup
// }
// }
// } else {
// kondisi = {
// isActive: true,
// category: 'FILE',
// Division: {
// isActive: true,
// DivisionMember: {
// some: {
// idUser: user.id
// }
// }
// }
// }
// }
const data = await prisma.divisionDocumentFolderFile.findMany({ const data = await prisma.divisionDocumentFolderFile.findMany({
where: kondisi, where: kondisi,
@@ -377,7 +413,7 @@ export async function GET(request: Request) {
} }
} }
} }
} else if (roleUser == "admin" || roleUser == "cosupadmin") { } else {
kondisi = { kondisi = {
isActive: true, isActive: true,
status: 1, status: 1,
@@ -386,20 +422,30 @@ export async function GET(request: Request) {
isActive: true isActive: true
} }
} }
} else {
kondisi = {
isActive: true,
status: 1,
Division: {
isActive: true,
DivisionMember: {
some: {
idUser: user.id
}
}
}
}
} }
// else if (roleUser == "admin" || roleUser == "cosupadmin") {
// kondisi = {
// isActive: true,
// status: 1,
// Division: {
// idGroup: idGroup,
// isActive: true
// }
// }
// } else {
// kondisi = {
// isActive: true,
// status: 1,
// Division: {
// isActive: true,
// DivisionMember: {
// some: {
// idUser: user.id
// }
// }
// }
// }
// }
const data = await prisma.divisionDisscussion.findMany({ const data = await prisma.divisionDisscussion.findMany({
skip: 0, skip: 0,

View File

@@ -20,6 +20,7 @@ export async function GET(request: Request, context: { params: { id: string } })
const data = await prisma.announcement.count({ const data = await prisma.announcement.count({
where: { where: {
id: id, id: id,
isActive: true,
}, },
}); });
@@ -29,7 +30,7 @@ export async function GET(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Gagal mendapatkan pengumuman, data tidak ditemukan", message: "Gagal mendapatkan pengumuman, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
@@ -173,7 +174,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Edit pengumuman gagal, data tidak ditemukan", message: "Edit pengumuman gagal, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }

View File

@@ -255,15 +255,20 @@ export async function POST(request: Request) {
const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId) const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId)
const dataNotifFilterUnique = dataNotifFilter
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const pushNotif = dataPush.filter((item) => item.subscription != undefined) const pushNotif = dataPush.filter((item) => item.subscription != undefined)
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Pengumuman Baru', body: title } }) const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Pengumuman Baru', body: title } })
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotifFilter data: dataNotifFilterUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");
await sendFCMNotificationMany({ await sendFCMNotificationMany({
token: tokenUnique, token: tokenUnique,
title: "Pengumuman Baru", title: "Pengumuman Baru",

View File

@@ -11,7 +11,7 @@ export async function GET(request: Request) {
const userMobile = searchParams.get("user") const userMobile = searchParams.get("user")
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const user = await funGetUserById({ id: userMobile }) const user = await funGetUserById({ id: userMobile })

View File

@@ -37,6 +37,29 @@ export async function POST(request: Request, context: { params: { id: string } }
} }
}) })
const dataDiscussion = await prisma.discussion.findUnique({
where: {
id
},
select: {
createdBy: true,
User: {
select: {
Subscribe: {
select: {
subscription: true
}
},
TokenDeviceUser: {
select: {
token: true
}
}
}
}
}
})
const member = await prisma.discussionMember.findMany({ const member = await prisma.discussionMember.findMany({
where: { where: {
idDiscussion: id, idDiscussion: id,
@@ -70,7 +93,10 @@ export async function POST(request: Request, context: { params: { id: string } }
} }
}) })
const memberFilter = member.filter((v: any) => v.idUser != userMobile.id) const memberFilter = [...member, { idUser: dataDiscussion?.createdBy, User: dataDiscussion?.User }].filter((v: any) => v.idUser != userMobile.id)
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t) => t.idUser === v.idUser)
);
const dataFCM = memberFilter.map((v: any) => ({ const dataFCM = memberFilter.map((v: any) => ({
..._.omit(v, ["idUser", "User", "Subscribe", "TokenDeviceUser"]), ..._.omit(v, ["idUser", "User", "Subscribe", "TokenDeviceUser"]),
@@ -121,4 +147,90 @@ export async function POST(request: Request, context: { params: { id: string } }
console.error(error) console.error(error)
return NextResponse.json({ success: false, message: "Gagal menambahkan komentar, coba lagi nanti (error: 500)" }) return NextResponse.json({ success: false, message: "Gagal menambahkan komentar, coba lagi nanti (error: 500)" })
} }
}
// EDIT KOMENTAR
export async function PUT(request: Request, context: { params: { id: string } }) {
try {
const { id } = context.params
const { desc, user } = (await request.json());
const userMobile = await funGetUserById({ id: String(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 cek = await prisma.discussionComment.count({
where: {
id,
isActive: true
}
})
if (cek == 0) {
return NextResponse.json({ success: false, message: "Gagal mengedit komentar, data tidak ditemukan" }, { status: 200 });
}
const data = await prisma.discussionComment.update({
where: {
id
},
data: {
comment: desc,
isEdited: true
}
})
// create log user
const log = await createLogUserMobile({ act: 'UPDATE', desc: 'User mengedit komentar pada diskusi umum', table: 'discussionComment', data: id, user: userMobile.id })
return NextResponse.json({ success: true, message: "Berhasil mengedit komentar" }, { status: 200 });
} catch (error) {
console.error(error)
return NextResponse.json({ success: false, message: "Gagal mengedit komentar, coba lagi nanti (error: 500)" })
}
}
// HAPUS KOMENTAR
export async function DELETE(request: Request, context: { params: { id: string } }) {
try {
const { id } = context.params
const { user } = (await request.json());
const userMobile = await funGetUserById({ id: String(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 cek = await prisma.discussionComment.count({
where: {
id,
isActive: true
}
})
if (cek == 0) {
return NextResponse.json({ success: false, message: "Gagal mengedit komentar, data tidak ditemukan" }, { status: 200 });
}
const data = await prisma.discussionComment.update({
where: {
id
},
data: {
isActive: false
}
})
// create log user
const log = await createLogUserMobile({ act: 'DELETE', desc: 'User menghapus komentar pada diskusi umum', table: 'discussionComment', data: id, user: userMobile.id })
return NextResponse.json({ success: true, message: "Berhasil mengedit komentar" }, { status: 200 });
} catch (error) {
console.error(error)
return NextResponse.json({ success: false, message: "Gagal mengedit komentar, coba lagi nanti (error: 500)" })
}
} }

View File

@@ -8,7 +8,7 @@ import { NextResponse } from "next/server";
// GET ONE DETAIL DISKUSI UMUM // 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 { try {
let dataFix let dataFix
const { id } = context.params const { id } = context.params
@@ -19,7 +19,7 @@ export async function GET(request: Request, context: { params: { id: string } })
const user = await funGetUserById({ id: String(userMobile) }) const user = await funGetUserById({ id: String(userMobile) })
if (user.id == "null" || user.id == undefined || user.id == "") { if (user.id == "null" || user.id == undefined || user.id == "") {
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: 200 });
} }
const cek = await prisma.discussion.count({ const cek = await prisma.discussion.count({
@@ -29,7 +29,7 @@ export async function GET(request: Request, context: { params: { id: string } })
}) })
if (cek == 0) { if (cek == 0) {
return NextResponse.json({ success: false, message: "Gagal mendapatkan diskusi, data tidak ditemukan" }, { status: 404 }); return NextResponse.json({ success: false, message: "Gagal mendapatkan diskusi, data tidak ditemukan" }, { status: 200 });
} }
if (kategori == "detail") { if (kategori == "detail") {
@@ -68,6 +68,8 @@ export async function GET(request: Request, context: { params: { id: string } })
id: true, id: true,
comment: true, comment: true,
createdAt: true, createdAt: true,
updatedAt: true,
isEdited: true,
idUser: true, idUser: true,
User: { User: {
select: { select: {
@@ -75,12 +77,16 @@ export async function GET(request: Request, context: { params: { id: string } })
img: true img: true
} }
} }
},
orderBy: {
createdAt: "asc"
} }
}) })
dataFix = data.map((v: any) => ({ dataFix = data.map((v: any) => ({
..._.omit(v, ["createdAt", "User",]), ..._.omit(v, ["createdAt", "User", "updatedAt"]),
createdAt: countTime(v.createdAt), createdAt: countTime(v.createdAt),
updatedAt: moment(v.updatedAt).format("ll"),
username: v.User.name, username: v.User.name,
img: v.User.img img: v.User.img
})) }))

View File

@@ -15,7 +15,7 @@ export async function GET(request: Request) {
const { searchParams } = new URL(request.url); const { searchParams } = new URL(request.url);
const user = searchParams.get("user") const user = searchParams.get("user")
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const userMobile = await funGetUserById({ id: user }) const userMobile = await funGetUserById({ id: user })
@@ -75,6 +75,9 @@ export async function GET(request: Request) {
DiscussionComment: { DiscussionComment: {
select: { select: {
id: true, id: true,
},
where: {
isActive: true
} }
} }
} }
@@ -210,9 +213,13 @@ export async function POST(request: Request) {
} }
dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId) dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId)
const dataNotifUnique = dataNotif
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotif data: dataNotifUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");

View File

@@ -5,7 +5,7 @@ import _ from "lodash";
import { NextResponse } from "next/server"; import { NextResponse } from "next/server";
import { sendFCMNotificationMany } from "../../../../../../../xsendMany"; import { sendFCMNotificationMany } from "../../../../../../../xsendMany";
// CREATE COMENT BY ID KOMENTAR // CREATE COMENT
export async function POST(request: Request, context: { params: { id: string } }) { export async function POST(request: Request, context: { params: { id: string } }) {
try { try {
const { id } = context.params const { id } = context.params
@@ -50,6 +50,21 @@ export async function POST(request: Request, context: { params: { id: string } }
}, },
select: { select: {
idDivision: true, idDivision: true,
createdBy: true,
User: {
select: {
Subscribe: {
select: {
subscription: true
}
},
TokenDeviceUser: {
select: {
token: true
}
}
}
}
} }
}) })
@@ -86,7 +101,10 @@ export async function POST(request: Request, context: { params: { id: string } }
} }
}) })
const memberFilter = member.filter((v: any) => v.idUser != userMobile.id) const memberFilter = [...member, { idUser: dataDivision?.createdBy, User: dataDivision?.User }].filter((v: any) => v.idUser != userMobile.id)
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t) => t.idUser === v.idUser)
);
const dataFCM = memberFilter.map((v: any) => ({ const dataFCM = memberFilter.map((v: any) => ({
..._.omit(v, ["idUser", "User", "Subscribe", "TokenDeviceUser"]), ..._.omit(v, ["idUser", "User", "Subscribe", "TokenDeviceUser"]),
@@ -138,4 +156,103 @@ export async function POST(request: Request, context: { params: { id: string } }
console.error(error); console.error(error);
return NextResponse.json({ success: false, message: "Gagal menambah komentar, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 }); return NextResponse.json({ success: false, message: "Gagal menambah komentar, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
} }
}
// EDIT KOMENTAR
export async function PUT(request: Request, context: { params: { id: string } }) {
try {
const { id } = context.params
const { comment, user } = (await request.json());
const userMobile = await funGetUserById({ id: String(user) })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "User tidak ditemukan" }, { status: 200 });
}
const cek = await prisma.divisionDisscussionComment.count({
where: {
id,
isActive: true
}
})
if (cek == 0) {
return NextResponse.json(
{
success: false,
message: "Edit komentar gagal, data tidak ditemukan",
},
{ status: 200 }
);
}
const data = await prisma.divisionDisscussionComment.update({
where: {
id: id
},
data: {
comment: comment,
isEdited: true
}
})
// create log user
const log = await createLogUserMobile({ act: 'UPDATE', desc: 'User mengedit komentar pada diskusi divisi', table: 'divisionDisscussionComment', data: id, user: userMobile.id })
return NextResponse.json({ success: true, message: "Berhasil mengedit komentar" }, { status: 200 });
} catch (error) {
console.error(error);
return NextResponse.json({ success: false, message: "Gagal menambah komentar, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
}
}
// HAPUS KOMENTAR
export async function DELETE(request: Request, context: { params: { id: string } }) {
try {
const { id } = context.params
const { user } = (await request.json());
const userMobile = await funGetUserById({ id: String(user) })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "User tidak ditemukan" }, { status: 200 });
}
const cek = await prisma.divisionDisscussionComment.count({
where: {
id,
isActive: true
}
})
if (cek == 0) {
return NextResponse.json(
{
success: false,
message: "Hapus komentar gagal, data tidak ditemukan",
},
{ status: 200 }
);
}
const data = await prisma.divisionDisscussionComment.update({
where: {
id: id
},
data: {
isActive: false
}
})
// create log user
const log = await createLogUserMobile({ act: 'DELETE', desc: 'User menghapus komentar pada diskusi divisi', table: 'divisionDisscussionComment', data: id, user: userMobile.id })
return NextResponse.json({ success: true, message: "Berhasil menghapus komentar" }, { status: 200 });
} catch (error) {
console.error(error);
return NextResponse.json({ success: false, message: "Gagal menghapus komentar, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
}
} }

View File

@@ -31,33 +31,42 @@ export async function GET(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Gagal mendapatkan diskusi, data tidak ditemukan", message: "Gagal mendapatkan diskusi, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
if (cat == "comment") { if (cat == "comment") {
const data = await prisma.divisionDisscussionComment.findMany({ const data = await prisma.divisionDisscussionComment.findMany({
where: { where: {
idDisscussion: id idDisscussion: id,
isActive: true
}, },
select: { select: {
id: true, id: true,
comment: true, comment: true,
createdAt: true, createdAt: true,
updatedAt: true,
isEdited: true,
createdBy: true,
User: { User: {
select: { select: {
name: true, name: true,
img: true img: true
} }
} }
},
orderBy: {
createdAt: "asc"
} }
}) })
const omitMember = data.map((v: any) => ({ const omitMember = data.map((v: any) => ({
..._.omit(v, ["User", "createdAt"]), ..._.omit(v, ["User", "createdBy", "createdAt", "updatedAt"]),
idUser: v.createdBy,
username: v.User.name, username: v.User.name,
img: v.User.img, img: v.User.img,
createdAt: countTime(v.createdAt), createdAt: countTime(v.createdAt),
updatedAt: moment(v.updatedAt).format("ll")
})) }))
return NextResponse.json({ success: true, message: "Berhasil mendapatkan komentar", data: omitMember }, { status: 200 }); return NextResponse.json({ success: true, message: "Berhasil mendapatkan komentar", data: omitMember }, { status: 200 });
@@ -128,7 +137,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
}); });
if (data == 0) { if (data == 0) {
return NextResponse.json({ success: false, message: "Gagal mendapatkan diskusi, data tidak ditemukan" }, { status: 404 }); return NextResponse.json({ success: false, message: "Gagal mendapatkan diskusi, data tidak ditemukan" }, { status: 200 });
} }
const result = await prisma.divisionDisscussion.update({ const result = await prisma.divisionDisscussion.update({

View File

@@ -35,7 +35,7 @@ export async function GET(request: Request) {
}) })
if (cekDivision == 0) { if (cekDivision == 0) {
return NextResponse.json({ success: false, message: "Gagal mendapatkan divisi, data tidak ditemukan" }, { status: 404 }); return NextResponse.json({ success: false, message: "Gagal mendapatkan divisi, data tidak ditemukan" }, { status: 200 });
} }
const data = await prisma.divisionDisscussion.findMany({ const data = await prisma.divisionDisscussion.findMany({
@@ -67,6 +67,9 @@ export async function GET(request: Request) {
DivisionDisscussionComment: { DivisionDisscussionComment: {
select: { select: {
id: true, id: true,
},
where: {
isActive: true
} }
} }
} }
@@ -118,7 +121,7 @@ export async function POST(request: Request) {
}) })
if (cekDivision == 0) { if (cekDivision == 0) {
return NextResponse.json({ success: false, message: "Gagal mendapatkan divisi, data tidak ditemukan" }, { status: 404 }); return NextResponse.json({ success: false, message: "Gagal mendapatkan divisi, data tidak ditemukan" }, { status: 200 });
} }
const data = await prisma.divisionDisscussion.create({ const data = await prisma.divisionDisscussion.create({
@@ -263,12 +266,16 @@ export async function POST(request: Request) {
} }
const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId) const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId)
const dataNotifFilterUnique = dataNotifFilter
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const pushNotif = dataPush.filter((item) => item.subscription != undefined) const pushNotif = dataPush.filter((item) => item.subscription != undefined)
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { body: deskripsiNotif, title: 'Diskusi Baru' } }) const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { body: deskripsiNotif, title: 'Diskusi Baru' } })
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotifFilter data: dataNotifFilterUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");

View File

@@ -314,12 +314,16 @@ export async function POST(request: Request) {
} }
const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId) const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId)
const dataNotifFilterUnique = dataNotifFilter
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const pushNotif = dataPush.filter((item) => item.subscription != undefined) const pushNotif = dataPush.filter((item) => item.subscription != undefined)
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Divisi Baru', body: `Divisi ${sent.data.name} telah dibuat. Silakan periksa detailnya.` } }) const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Divisi Baru', body: `Divisi ${sent.data.name} telah dibuat. Silakan periksa detailnya.` } })
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotifFilter data: dataNotifFilterUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");
@@ -338,4 +342,45 @@ export async function POST(request: Request) {
console.error(error); console.error(error);
return NextResponse.json({ success: false, message: "Gagal menambahkan divisi, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 }); return NextResponse.json({ success: false, message: "Gagal menambahkan divisi, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
} }
};
// CEK DATA DIVISI (NAME DI DESA DAN GROUP YG SAMA)
export async function PUT(request: Request) {
try {
const sent = (await request.json())
const user = sent.user
const userMobile = await funGetUserById({ id: String(user) })
if (userMobile.id == "null" || userMobile.id == undefined || userMobile.id == "") {
return NextResponse.json({ success: false, message: "Anda harus login untuk mengakses ini" }, { status: 200 });
}
let fixGroup
if (sent.data.idGroup == "null" || sent.data.idGroup == undefined || sent.data.idGroup == "") {
fixGroup = userMobile.idGroup
} else {
fixGroup = sent.data.idGroup
}
const checkData = await prisma.division.count({
where: {
name: {
equals: sent.data.name,
mode: "insensitive"
},
idGroup: fixGroup,
idVillage: String(userMobile.idVillage)
}
})
if (checkData > 0) {
return NextResponse.json({ success: true, message: "Divisi dengan nama ini sudah ada", available: false }, { status: 200 });
}
return NextResponse.json({ success: true, message: "Berhasil cek data divisi", available: true }, { status: 200 });
} catch (error) {
console.error(error);
return NextResponse.json({ success: false, message: "Gagal menambahkan divisi, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });
}
}; };

View File

@@ -12,7 +12,7 @@ export async function GET(request: Request, context: { params: { id: string } })
const userMobile = searchParams.get("user") const userMobile = searchParams.get("user")
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const { id } = context.params; const { id } = context.params;
@@ -28,7 +28,7 @@ export async function GET(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Gagal mendapatkan grup, data tidak ditemukan", message: "Gagal mendapatkan grup, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
@@ -52,7 +52,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
const { isActive, user } = (await request.json()); const { isActive, user } = (await request.json());
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const userLogin = await funGetUserById({ id: user }) const userLogin = await funGetUserById({ id: user })
@@ -68,7 +68,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
success: false, success: false,
message: "Edit grup gagal, data tidak ditemukan", message: "Edit grup gagal, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
@@ -98,7 +98,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
const { name, user } = (await request.json()); const { name, user } = (await request.json());
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const data = await prisma.group.count({ const data = await prisma.group.count({
@@ -113,7 +113,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Edit grup gagal, data tidak ditemukan", message: "Edit grup gagal, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }

View File

@@ -11,7 +11,7 @@ export async function GET(request: Request) {
const userMobile = searchParams.get("user") const userMobile = searchParams.get("user")
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const user = await funGetUserById({ id: userMobile }) const user = await funGetUserById({ id: userMobile })
@@ -51,7 +51,7 @@ export async function POST(request: Request) {
const { name, user } = (await request.json()); const { name, user } = (await request.json());
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const userMobile = await funGetUserById({ id: user }) const userMobile = await funGetUserById({ id: user })

View File

@@ -81,7 +81,7 @@ export async function GET(request: Request) {
} }
}, },
orderBy: { orderBy: {
createdAt: "desc" updatedAt: "desc"
} }
}) })
@@ -425,19 +425,19 @@ export async function GET(request: Request) {
isActive: true, isActive: true,
status: 1, status: 1,
idVillage: idVillage idVillage: idVillage
}, }
kondisi = { kondisi = {
isActive: true,
status: 1,
Division: {
isActive: true, isActive: true,
status: 1, idVillage: idVillage,
Division: { Group: {
isActive: true, isActive: true,
idVillage: idVillage,
Group: {
isActive: true,
}
} }
} }
}
} else { } else {
kondisiUmum = { kondisiUmum = {
isActive: true, isActive: true,

View File

@@ -11,7 +11,7 @@ export async function GET(request: Request) {
const userMobile = searchParams.get("user") const userMobile = searchParams.get("user")
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const userId = await funGetUserById({ id: userMobile }) const userId = await funGetUserById({ id: userMobile })

View File

@@ -11,7 +11,7 @@ export async function GET(request: Request, context: { params: { id: string } })
const { id } = context.params; const { id } = context.params;
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const data = await prisma.position.findUnique({ const data = await prisma.position.findUnique({
@@ -30,7 +30,7 @@ export async function GET(request: Request, context: { params: { id: string } })
success: false, success: false,
message: "Gagal mendapatkan jabatan, data tidak ditemukan", message: "Gagal mendapatkan jabatan, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
@@ -55,7 +55,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
const { isActive, user } = (await request.json()); const { isActive, user } = (await request.json());
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const data = await prisma.position.count({ const data = await prisma.position.count({
@@ -104,7 +104,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
const { name, idGroup, user } = await request.json(); const { name, idGroup, user } = await request.json();
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const cek = await prisma.position.count({ const cek = await prisma.position.count({

View File

@@ -16,7 +16,7 @@ export async function GET(request: Request) {
const userMobile = searchParams.get("user") const userMobile = searchParams.get("user")
if (userMobile == "null" || userMobile == undefined || userMobile == "") { if (userMobile == "null" || userMobile == undefined || userMobile == "") {
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: 200 });
} }
const user = await funGetUserById({ id: userMobile }) const user = await funGetUserById({ id: userMobile })
@@ -35,7 +35,7 @@ export async function GET(request: Request) {
}) })
if (cek == 0) { if (cek == 0) {
return NextResponse.json({ success: false, message: "Gagal mendapatkan jabatan, data tidak ditemukan", }, { status: 404 }); return NextResponse.json({ success: false, message: "Gagal mendapatkan jabatan, data tidak ditemukan", }, { status: 200 });
} }
const filter = await prisma.group.findUnique({ const filter = await prisma.group.findUnique({
@@ -93,7 +93,7 @@ export async function POST(request: Request) {
const { name, idGroup, user } = await request.json(); const { name, idGroup, user } = await request.json();
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const userMobile = await funGetUserById({ id: user }) const userMobile = await funGetUserById({ id: user })
@@ -131,7 +131,7 @@ export async function POST(request: Request) {
} else { } else {
return NextResponse.json( return NextResponse.json(
{ success: false, message: "Jabatan sudah ada" }, { success: false, message: "Jabatan sudah ada" },
{ status: 400 } { status: 200 }
); );
} }

View File

@@ -71,7 +71,7 @@ export async function GET(request: Request, context: { params: { id: string } })
createdAt: true createdAt: true
}, },
orderBy: { orderBy: {
createdAt: 'asc' dateStart: 'asc'
} }
}) })

View File

@@ -385,11 +385,15 @@ export async function POST(request: Request) {
} }
const dataNotifFilter = dataNotif.filter((item) => item.idUserTo != undefined && item.idUserTo != null && item.idUserTo != "" && item.idUserTo != userId) const dataNotifFilter = dataNotif.filter((item) => item.idUserTo != undefined && item.idUserTo != null && item.idUserTo != "" && item.idUserTo != userId)
const dataNotifFilterUnique = dataNotifFilter
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const pushNotif = dataPush.filter((item) => item.subscription != undefined) const pushNotif = dataPush.filter((item) => item.subscription != undefined)
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Kegiatan Baru', body: title } }) const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { title: 'Kegiatan Baru', body: title } })
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotifFilter data: dataNotifFilterUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");

View File

@@ -76,7 +76,7 @@ export async function GET(request: Request, context: { params: { id: string } })
dateEnd: true, dateEnd: true,
}, },
orderBy: { orderBy: {
createdAt: 'asc' dateStart: 'asc'
} }
}) })

View File

@@ -356,11 +356,15 @@ export async function POST(request: Request) {
} }
const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId) const dataNotifFilter = dataNotif.filter((v: any) => v.idUserTo != undefined && v.idUserTo != null && v.idUserTo != "" && v.idUserTo != userId)
const dataNotifFilterUnique = dataNotifFilter
.filter((v: any, index: number, self: any[]) =>
index === self.findIndex((t: any) => t.idUserTo == v.idUserTo)
)
const pushNotif = dataPush.filter((item) => item.subscription != undefined) const pushNotif = dataPush.filter((item) => item.subscription != undefined)
const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { body: title, title: 'Tugas Divisi Baru' } }) const sendWebPush = await funSendWebPush({ sub: pushNotif, message: { body: title, title: 'Tugas Divisi Baru' } })
const insertNotif = await prisma.notifications.createMany({ const insertNotif = await prisma.notifications.createMany({
data: dataNotifFilter data: dataNotifFilterUnique
}) })
const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != ""); const tokenUnique = [...new Set(tokenDup.flat())].filter((v: any) => v != undefined && v != null && v != "");

View File

@@ -87,7 +87,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
const { isActive, user } = (await request.json()); const { isActive, user } = (await request.json());
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const data = await prisma.user.count({ const data = await prisma.user.count({
@@ -102,7 +102,7 @@ export async function DELETE(request: Request, context: { params: { id: string }
success: false, success: false,
message: "Gagal mendapatkan anggota, data tidak ditemukan", message: "Gagal mendapatkan anggota, data tidak ditemukan",
}, },
{ status: 404 } { status: 200 }
); );
} }
@@ -158,7 +158,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
} = JSON.parse(data as string) } = JSON.parse(data as string)
if (user == "null" || user == undefined || user == "") { if (user == "null" || user == undefined || user == "") {
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: 200 });
} }
const cekNIK = await prisma.user.count({ const cekNIK = await prisma.user.count({
@@ -247,7 +247,7 @@ export async function PUT(request: Request, context: { params: { id: string } })
{ status: 200 } { status: 200 }
); );
} else { } else {
return Response.json({ success: false, message: "Anggota sudah ada" }, { status: 400 }); return Response.json({ success: false, message: "Anggota sudah ada" }, { status: 200 });
} }
} catch (error) { } catch (error) {
console.error(error); console.error(error);

View File

@@ -11,7 +11,7 @@ export async function GET(request: Request) {
try { try {
const user = await funGetUserByCookies() const user = await funGetUserByCookies()
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: 200 });
} }
const data = await prisma.user.findUnique({ const data = await prisma.user.findUnique({
where: { where: {

View File

@@ -68,7 +68,7 @@ export async function GET(request: Request, context: { params: { id: string } })
createdAt: true createdAt: true
}, },
orderBy: { orderBy: {
createdAt: 'asc' dateStart: 'asc'
} }
}) })
@@ -78,8 +78,8 @@ export async function GET(request: Request, context: { params: { id: string } })
dateEnd: moment(v.dateEnd).format("DD-MM-YYYY"), dateEnd: moment(v.dateEnd).format("DD-MM-YYYY"),
createdAt: moment(v.createdAt).format("DD-MM-YYYY HH:mm"), createdAt: moment(v.createdAt).format("DD-MM-YYYY HH:mm"),
})) }))
const dataFix = _.orderBy(formatData, 'createdAt', 'asc') // const dataFix = _.orderBy(formatData, 'createdAt', 'asc')
allData = dataFix allData = formatData
} else if (kategori == "file") { } else if (kategori == "file") {
const dataFile = await prisma.projectFile.findMany({ const dataFile = await prisma.projectFile.findMany({

View File

@@ -75,7 +75,7 @@ export async function GET(request: Request, context: { params: { id: string } })
dateEnd: true, dateEnd: true,
}, },
orderBy: { orderBy: {
createdAt: 'asc' dateStart: 'asc'
} }
}) })

View File

@@ -2,7 +2,7 @@ import { NextResponse } from "next/server";
export async function GET(request: Request) { export async function GET(request: Request) {
try { try {
return NextResponse.json({ success: true, version: "2.0.4", tahap: "beta", update: "-api mobile; -login tanpa otp (mobile app); -tambah laporan pada project dan tugas divisi; -tambah upload link pada project dan tugas divisi; -tambah detail tanggal dan jam pada project dan tugas divisi; -api jenna ai; -privacy policy" }, { status: 200 }); return NextResponse.json({ success: true, version: "2.1.0", tahap: "beta", update: "-api mobile; -login tanpa otp (mobile app); -tambah laporan pada project dan tugas divisi; -tambah upload link pada project dan tugas divisi; -tambah detail tanggal dan jam pada project dan tugas divisi; -api jenna ai; -privacy policy" }, { status: 200 });
} catch (error) { } catch (error) {
console.error(error); console.error(error);
return NextResponse.json({ success: false, version: "Gagal mendapatkan version, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 }); return NextResponse.json({ success: false, version: "Gagal mendapatkan version, coba lagi nanti (error: 500)", reason: (error as Error).message, }, { status: 500 });

View File

@@ -18,7 +18,7 @@ export function countTime(date: Date) {
const seconds = totalSeconds; const seconds = totalSeconds;
if (days > 0) { if (days > 0) {
return moment(date).format("ll") return String(dateNow.getFullYear()) == moment(date).format("YYYY") ? moment(date).format("DD MMM") : moment(date).format("ll")
} else if (hours > 0) { } else if (hours > 0) {
return `${hours} jam` return `${hours} jam`
} else if (minutes > 0) { } else if (minutes > 0) {