Fix notifikasi server action to API

This commit is contained in:
2024-12-19 06:34:12 +08:00
parent 6bb690e0b5
commit 2322ab8444
43 changed files with 507 additions and 1031 deletions

View File

@@ -0,0 +1,20 @@
import { prisma } from "@/app/lib";
import backendLogger from "@/util/backendLogger";
import { NextResponse } from "next/server";
export const dynamic = "force-dynamic";
export async function GET(request: Request) {
try {
const data = await prisma.projectCollaborationMaster_Industri.findMany({});
return NextResponse.json(
{ success: true, message: "Berhasil mendapatkan data", data: data },
{ status: 200 }
);
} catch (error) {
backendLogger.error("Master Collaboration:=========>", error);
return NextResponse.json(
{ success: false, message: "Gagal mendapatkan data" },
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,28 @@
import { prisma } from "@/app/lib";
import { newFunGetUserId } from "@/app/lib/new_fun_user_id";
import backendLogger from "@/util/backendLogger";
import { NextResponse } from "next/server";
export const dynamic = "force-dynamic";
export async function GET(request: Request) {
try {
const userLoginId = await newFunGetUserId();
const count = await prisma.notifikasi.findMany({
where: {
userId: userLoginId,
isRead: false,
userRoleId: "1",
},
});
return NextResponse.json({ success: true, data: count.length });
} catch (error) {
backendLogger.error("Gagal mendapatkan data count notifikasi", error);
return NextResponse.json(
{ success: false, message: "Gagal mendapatkan data" },
{ status: 500 }
);
}
}

View File

@@ -7,37 +7,34 @@ import { NextResponse } from "next/server";
export const dynamic = "force-dynamic";
export async function GET(request: Request) {
if (request.method === "GET") {
try {
const { searchParams } = new URL(request.url);
const category = searchParams.get("category") as ICategoryapp;
const page = searchParams.get("page");
try {
let fixData;
const { searchParams } = new URL(request.url);
const category = searchParams.get("category") as ICategoryapp;
const page = searchParams.get("page");
const userLoginId = await newFunGetUserId();
const fixPage = _.toNumber(page);
const takeData = 10;
const skipData = fixPage * takeData - takeData;
const userLoginId = await newFunGetUserId();
const fixPage = _.toNumber(page);
const takeData = 10;
const skipData = fixPage * takeData - takeData;
if (category === "Semua") {
const data = await prisma.notifikasi.findMany({
take: takeData,
skip: skipData,
orderBy: [
{
isRead: "asc",
},
{ createdAt: "desc" },
],
where: {
userId: userLoginId,
userRoleId: "1",
if (category === "Semua") {
fixData = await prisma.notifikasi.findMany({
take: takeData,
skip: skipData,
orderBy: [
{
isRead: "asc",
},
});
return NextResponse.json({ success: true, data });
}
const allData = await prisma.notifikasi.findMany({
{ createdAt: "desc" },
],
where: {
userId: userLoginId,
userRoleId: "1",
},
});
} else {
fixData = await prisma.notifikasi.findMany({
take: takeData,
skip: skipData,
orderBy: [
@@ -52,12 +49,17 @@ export async function GET(request: Request) {
kategoriApp: _.upperCase(category),
},
});
return NextResponse.json({ success: true, data: allData });
} catch (error) {
backendLogger.error("Error get data notifikasi: " + error);
}
} else {
return NextResponse.json({ success: false, message: "Method not allowed" });
return NextResponse.json(
{ success: true, data: fixData, message: "Berhasil mendapatkan data" },
{ status: 200 }
);
} catch (error) {
backendLogger.error("Error get data notifikasi: " + error);
return NextResponse.json(
{ success: false, message: "Gagal mendapatkan data" },
{ status: 500 }
);
}
}

View File

@@ -0,0 +1,35 @@
import { prisma } from "@/app/lib";
import backendLogger from "@/util/backendLogger";
import { NextResponse } from "next/server";
export const dynamic = "force-dynamic";
export async function GET(request: Request) {
try {
const data = await prisma.masterKategoriApp.findMany({
where: {
isActive: true,
},
});
data.unshift({
id: "0",
isActive: true,
createdAt: new Date(),
updatedAt: new Date(),
name: "Semua",
value: null,
});
return NextResponse.json(
{ success: true, data, message: "Berhasil mendapatkan data" },
{ status: 200 }
);
} catch (error) {
backendLogger.error("Master Notifikasi:", error);
return NextResponse.json(
{ success: false, message: "Gagal mendapatkan data" },
{ status: 500 }
);
}
}

View File

@@ -15,7 +15,7 @@ export default async function PageHome() {
dataJob={dataJob as any}
countNotifikasi={countNotifikasi}
/> */}
<HomeViewNew countNotifikasi={countNotifikasi} />
<HomeViewNew countNotifikasi={countNotifikasi}/>
</>
);
}

View File

@@ -1,12 +1,9 @@
import { Colab_Create } from "@/app_modules/colab";
import colab_funGetMasterIndustri from "@/app_modules/colab/fun/master/fun_get_master_industri";
export default async function Page() {
const listIndustri = await colab_funGetMasterIndustri();
return (
<>
<Colab_Create listIndustri={listIndustri as any} />
<Colab_Create />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiCollaboration } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Collaboration",
});
return (
<>
<Notifikasi_UiCollaboration listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiDonasi } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Donasi",
});
return (
<>
<Notifikasi_UiDonasi listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,11 +1,9 @@
import { Notifikasi_UiEvent } from "@/app_modules/notifikasi/_ui";
import Notifikasi_UiMain from "@/app_modules/notifikasi/_ui/ui_notifikasi";
export default async function Page() {
//
return (
<>
<Notifikasi_UiEvent />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiForum } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Forum",
});
return (
<>
<Notifikasi_UiForum listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiDonasi, Notifikasi_UiInvestasi } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Investasi",
});
return (
<>
<Notifikasi_UiInvestasi listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiJob } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Job",
});
return (
<>
<Notifikasi_UiJob listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,19 +1,15 @@
import { UIGlobal_LayoutHeaderTamplate } from "@/app_modules/_global/ui";
import { Notifikasi_UiNewLayout } from "@/app_modules/notifikasi/_ui";
import { notifikasi_funGetKategoriApp } from "@/app_modules/notifikasi/fun/get/fun_get_kategori_app";
export default async function Layout({
children,
}: {
children: React.ReactNode;
}) {
const masterKategori = await notifikasi_funGetKategoriApp();
return (
<>
<Notifikasi_UiNewLayout
header={<UIGlobal_LayoutHeaderTamplate title="Notifikasi" />}
masterKategori={masterKategori}
>
{children}
</Notifikasi_UiNewLayout>

View File

@@ -1,9 +1,9 @@
import { Notifikasi_UiAll } from "@/app_modules/notifikasi/_ui";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
return (
<>
<Notifikasi_UiAll />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -1,15 +1,9 @@
import { Notifikasi_UiVoting } from "@/app_modules/notifikasi/_ui";
import notifikasi_getByUserId from "@/app_modules/notifikasi/fun/get/get_notifiaksi_by_id";
import { Notifikasi_UiMain } from "@/app_modules/notifikasi/_ui";
export default async function Page() {
const listNotifikasi = await notifikasi_getByUserId({
page: 1,
kategoriApp: "Voting",
});
return (
<>
<Notifikasi_UiVoting listNotifikasi={listNotifikasi} />
<Notifikasi_UiMain />
</>
);
}

View File

@@ -8,4 +8,8 @@ export const API_RouteNotifikasi = {
category: ICategoryapp;
page: number;
}) => `/api/notifikasi/get-all-by-category?category=${category}&page=${page}`,
get_master_kategori: () => `/api/notifikasi/master`,
get_count_by_id: () => `/api/notifikasi/count`,
};

View File

@@ -42,7 +42,7 @@ export type IRealtimeData = {
export const gs_realtimeData = atom<IRealtimeData | null>(null);
export const gs_admin_ntf = atom<number>(0);
export const gs_user_ntf = atom<number>(0);
export const gs_count_ntf = atom<number>(0);
export const gs_count_ntf = atom<number | null>(null);
// job
export const gs_adminJob_triggerReview = atom<boolean>(false);

View File

@@ -25,6 +25,6 @@ process.on("SIGINT", async () => {
process.exit(0);
});
// console.log("==> Test prisma");
console.log("==> Test prisma");
export default prisma;