feat: add kependudukan seeders, API routes, year filter, and navbar menu

- Add Prisma models: DataBanjar, DistribusiAgama, DistribusiUmur, MigrasiPenduduk, DinamikaPenduduk
- Create seeders for all kependudukan models with year 2026 data
- Register Kependudukan API routes in route.ts
- Update API findMany endpoints to make tahun parameter optional
- Add YearFilter reusable component for admin pages
- Update 4 kependudukan admin pages with year filter UI
- Fix Mantine color array in AdminThemeProvider (add 10th element)
- Fix invalid Mantine color scale in paguTable.tsx (gray.50 -> gray.1)
- Add Kependudukan menu to navbar-list-menu.ts
- Fix Bun JSON import resolution with loadJsonData helper
- Update 74 seeder files to use dynamic JSON loading

Co-authored-by: Qwen-Coder <qwen-coder@alibabacloud.com>
This commit is contained in:
2026-04-10 11:54:36 +08:00
parent 5e822f0b05
commit 8b14c6ce44
146 changed files with 3051 additions and 201 deletions

View File

@@ -0,0 +1,32 @@
import prisma from "@/lib/prisma";
import { loadJsonData } from "../../load-json";
const dataBanjarJson = loadJsonData("kependudukan/data-banjar/data-banjar.json");
export async function seedDataBanjar() {
console.log("Seeding Data Banjar...");
for (const item of dataBanjarJson) {
await prisma.dataBanjar.upsert({
where: { id: item.id },
update: {
nama: item.nama,
penduduk: item.penduduk,
kk: item.kk,
miskin: item.miskin,
tahun: item.tahun,
},
create: {
id: item.id,
nama: item.nama,
penduduk: item.penduduk,
kk: item.kk,
miskin: item.miskin,
tahun: item.tahun,
},
});
console.log(` Banjar: ${item.nama} (${item.penduduk} penduduk)`);
}
console.log("Data Banjar seed selesai");
}

View File

@@ -0,0 +1,32 @@
import prisma from "@/lib/prisma";
import { loadJsonData } from "../../load-json";
const dinamikaPendudukJson = loadJsonData("kependudukan/dinamika-penduduk/dinamika-penduduk.json");
export async function seedDinamikaPenduduk() {
console.log("Seeding Dinamika Penduduk...");
for (const item of dinamikaPendudukJson) {
await prisma.dinamikaPenduduk.upsert({
where: { id: item.id },
update: {
tahun: item.tahun,
kelahiran: item.kelahiran,
kematian: item.kematian,
masuk: item.masuk,
keluar: item.keluar,
},
create: {
id: item.id,
tahun: item.tahun,
kelahiran: item.kelahiran,
kematian: item.kematian,
masuk: item.masuk,
keluar: item.keluar,
},
});
console.log(` Tahun ${item.tahun}: ${item.kelahiran} kelahiran, ${item.kematian} kematian`);
}
console.log("Dinamika Penduduk seed selesai");
}

View File

@@ -0,0 +1,28 @@
import prisma from "@/lib/prisma";
import { loadJsonData } from "../../load-json";
const distribusiAgamaJson = loadJsonData("kependudukan/distribusi-agama/distribusi-agama.json");
export async function seedDistribusiAgama() {
console.log("Seeding Distribusi Agama...");
for (const item of distribusiAgamaJson) {
await prisma.distribusiAgama.upsert({
where: { id: item.id },
update: {
agama: item.agama,
jumlah: item.jumlah,
tahun: item.tahun,
},
create: {
id: item.id,
agama: item.agama,
jumlah: item.jumlah,
tahun: item.tahun,
},
});
console.log(` ${item.agama}: ${item.jumlah} penganut`);
}
console.log("Distribusi Agama seed selesai");
}

View File

@@ -0,0 +1,28 @@
import prisma from "@/lib/prisma";
import { loadJsonData } from "../../load-json";
const distribusiUmurJson = loadJsonData("kependudukan/distribusi-umur/distribusi-umur.json");
export async function seedDistribusiUmur() {
console.log("Seeding Distribusi Umur...");
for (const item of distribusiUmurJson) {
await prisma.distribusiUmur.upsert({
where: { id: item.id },
update: {
kelompok: item.kelompok,
jumlah: item.jumlah,
tahun: item.tahun,
},
create: {
id: item.id,
kelompok: item.kelompok,
jumlah: item.jumlah,
tahun: item.tahun,
},
});
console.log(` Kelompok ${item.kelompok}: ${item.jumlah} jiwa`);
}
console.log("Distribusi Umur seed selesai");
}

View File

@@ -0,0 +1,34 @@
import prisma from "@/lib/prisma";
import { loadJsonData } from "../../load-json";
const migrasiPendudukJson = loadJsonData("kependudukan/migrasi-penduduk/migrasi-penduduk.json");
export async function seedMigrasiPenduduk() {
console.log("Seeding MigrASI PENDUDUK...");
for (const item of migrasiPendudukJson) {
await prisma.migrasiPenduduk.upsert({
where: { id: item.id },
update: {
nama: item.nama,
jenis: item.jenis,
tanggal: new Date(item.tanggal),
asal: item.asal,
tujuan: item.tujuan,
alasan: item.alasan,
},
create: {
id: item.id,
nama: item.nama,
jenis: item.jenis,
tanggal: new Date(item.tanggal),
asal: item.asal,
tujuan: item.tujuan,
alasan: item.alasan,
},
});
console.log(` ${item.nama}: ${item.jenis} (${item.alasan})`);
}
console.log("Migrasi Penduduk seed selesai");
}