import Link from "next/link";
import { db } from "@/lib/db";
import { AdminPageHeader } from "@/components/admin/page-header";
import { Card } from "@/components/ui/card";
import { Button } from "@/components/ui/button";
import { Badge } from "@/components/ui/badge";
import { Icon } from "@/components/site/icon";
import { Plus, Pencil, GripVertical, Building2 } from "lucide-react";

export const dynamic = "force-dynamic";

export default async function AdminIndustriesPage() {
  const industries = await db.industry.findMany({
    orderBy: [{ order: "asc" }, { createdAt: "desc" }],
  });

  return (
    <>
      <AdminPageHeader title="Industries" description={`${industries.length} industries configured`}>
        <Button asChild className="brand-gradient text-white">
          <Link href="/admin/industries/new"><Plus className="size-4 mr-1.5" /> Add Industry</Link>
        </Button>
      </AdminPageHeader>

      <Card className="rounded-2xl overflow-hidden">
        <div className="divide-y divide-border">
          {industries.map((ind) => (
            <div key={ind.id} className="flex items-center gap-4 p-4 hover:bg-accent/40 transition-colors">
              <GripVertical className="size-4 text-muted-foreground/40 shrink-0" />
              <div className="grid place-items-center size-10 rounded-lg bg-[var(--brand-royal)]/10 text-[var(--brand-royal)] shrink-0">
                {ind.icon ? <Icon name={ind.icon} className="size-5" /> : <Building2 className="size-5" />}
              </div>
              <div className="min-w-0 flex-1">
                <div className="flex flex-wrap items-center gap-2">
                  <span className="font-semibold truncate">{ind.title}</span>
                  {!ind.isEnabled && <Badge variant="secondary" className="text-xs">Disabled</Badge>}
                </div>
                <div className="flex items-center gap-2 min-w-0">
                  <span className="text-xs text-muted-foreground">/{ind.slug}</span>
                  <span className="text-xs text-muted-foreground/50">·</span>
                  <p className="text-xs text-muted-foreground line-clamp-1">{ind.description}</p>
                </div>
              </div>
              <div className="hidden sm:block text-xs text-muted-foreground shrink-0">Order: {ind.order}</div>
              <Button asChild variant="outline" size="sm" className="shrink-0">
                <Link href={`/admin/industries/edit/${ind.id}`}><Pencil className="size-3.5 mr-1" /> Edit</Link>
              </Button>
            </div>
          ))}
          {industries.length === 0 && (
            <div className="p-12 text-center text-muted-foreground">No industries yet. Click &ldquo;Add Industry&rdquo; to create one.</div>
          )}
        </div>
      </Card>
    </>
  );
}
