import { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow, } from "@/components/ui/table"; import { auth } from "@/lib/auth"; import prisma from "@/lib/db"; import { headers } from "next/headers"; import Link from "next/link"; import AddDevicesToCartButton from "./add-devices-to-cart-button"; import BlockDeviceButton from "./block-device-button"; import Pagination from "./pagination"; export async function DevicesTable({ searchParams, parentalControl }: { searchParams: Promise<{ query: string; page: number; sortBy: string; }>; parentalControl?: boolean; }) { const session = await auth.api.getSession({ headers: await headers() }) const query = (await searchParams)?.query || ""; const page = (await searchParams)?.page; const sortBy = (await searchParams)?.sortBy || "asc"; const totalDevices = await prisma.device.count({ where: { userId: session?.session.userId, OR: [ { name: { contains: query || "", mode: "insensitive", }, }, { mac: { contains: query || "", mode: "insensitive", }, }, ], NOT: { payment: { paid: false } }, isActive: parentalControl ? parentalControl : undefined, }, }); const totalPages = Math.ceil(totalDevices / 10); const limit = 10; const offset = (Number(page) - 1) * limit || 0; const devices = await prisma.device.findMany({ where: { userId: session?.session.userId, OR: [ { name: { contains: query || "", mode: "insensitive", }, }, { mac: { contains: query || "", mode: "insensitive", }, }, ], NOT: { payment: { paid: false } }, isActive: parentalControl, }, skip: offset, take: limit, orderBy: { name: `${sortBy}` as "asc" | "desc", }, }); return (
{devices.length === 0 ? (

No devices yet.

) : ( <> Table of all devices. Device Name MAC Address Actions {devices.map((device) => (
{device.name} Active until{" "} {new Date().toLocaleDateString("en-US", { month: "short", day: "2-digit", year: "numeric", })}
{device.mac} {!parentalControl ? ( ) : ( )}
))}
{query.length > 0 && (

Showing {devices.length} locations for "{query} "

)}
{totalDevices} devices
)}
); }