"use client" import { deleteSandbox, updateSandbox } from "@/lib/actions" import { Sandbox } from "@/lib/types" import { useEffect, useMemo, useState } from "react" import { toast } from "sonner" import ProjectCard from "./projectCard" const colors: { [key: string]: number[][] } = { react: [ [71, 207, 237], [30, 126, 148], ], node: [ [86, 184, 72], [59, 112, 52], ], } export default function DashboardProjects({ sandboxes, q, }: { sandboxes: Sandbox[] q: string | null }) { const [deletingId, setDeletingId] = useState("") const onVisibilityChange = useMemo( () => async (sandbox: Pick) => { const newVisibility = sandbox.visibility === "public" ? "private" : "public" toast(`Project ${sandbox.name} is now ${newVisibility}.`) await updateSandbox({ id: sandbox.id, visibility: newVisibility, }) }, [] ) const onDelete = useMemo( () => async (sandbox: Pick) => { setDeletingId(sandbox.id) toast(`Project ${sandbox.name} deleted.`) await deleteSandbox(sandbox.id) }, [] ) useEffect(() => { if (deletingId) { setDeletingId("") } }, [sandboxes]) return (
{q && q.length > 0 ? `Showing search results for: ${q}` : "My Projects"}
{sandboxes.length > 0 ? (
{sandboxes.map((sandbox) => { if (q && q.length > 0) { if (!sandbox.name.toLowerCase().includes(q.toLowerCase())) { return null } } return ( ) })}
) : (
You don't have any projects yet. Create one to get started!
)}
) }