import { useEffect, useMemo, useState } from 'react';
import {
  ArrowLeft,
  Boxes,
  Edit3,
  Eye,
  EyeOff,
  ImagePlus,
  LogOut,
  Package,
  PackagePlus,
  Search,
  Trash2,
  X,
} from 'lucide-react';
import type { Product } from '../lib/types';

const emptyForm = {
  name: '',
  description: '',
  price: '',
  originalPrice: '',
  badge: '',
  category: '',
  stock: '',
};

export default function Dashboard() {
  const [authorized, setAuthorized] = useState(false);
  const [checking, setChecking] = useState(true);


  const [existingImages, setExistingImages] = useState<string[]>([]);
  const [products, setProducts] = useState<Product[]>([]);
  const [form, setForm] = useState(emptyForm);
  const [imageFiles, setImageFiles] = useState<File[]>([]);
  const [imagePreviews, setImagePreviews] = useState<string[]>([]);
  const [editingId, setEditingId] = useState<string | null>(null);

  const [loading, setLoading] = useState(false);
  const [loadingProducts, setLoadingProducts] = useState(true);
  const [message, setMessage] = useState('');
  const [search, setSearch] = useState('');

  useEffect(() => {
    fetch('/api/me', { credentials: 'include' })
      .then((res) => {
        if (!res.ok) throw new Error();
        return res.json();
      })
      .then(() => setAuthorized(true))
      .catch(() => {
        window.location.href = '/login';
      })
      .finally(() => setChecking(false));
  }, []);

  async function loadProducts() {
    try {
      setLoadingProducts(true);

      const res = await fetch('/api/products?all=true', {
        credentials: 'include',
      });

      const data = await res.json();

      if (!res.ok) throw new Error(data?.error || 'Failed to load products');

      setProducts(data);
    } catch (error: any) {
      alert(error?.message || 'Failed to load products');
    } finally {
      setLoadingProducts(false);
    }
  }

  useEffect(() => {
    loadProducts();
  }, []);

  const filteredProducts = useMemo(() => {
    const q = search.trim().toLowerCase();
    if (!q) return products;

    return products.filter((product) =>
      [
        product.name,
        product.description,
        product.category,
        product.badge,
      ]
        .join(' ')
        .toLowerCase()
        .includes(q)
    );
  }, [products, search]);
  function removePreviewImage(index: number) {
    const imageUrl = imagePreviews[index];

    setImagePreviews((prev) => prev.filter((_, i) => i !== index));

    if (imageUrl.startsWith('/uploads/products/')) {
      setExistingImages((prev) => prev.filter((img) => img !== imageUrl));
    } else {
      setImageFiles((prev) => prev.filter((_, i) => i !== index));
    }
  }
  const stats = useMemo(() => {
    const total = products.length;
    const active = products.filter((p) => p.active !== false).length;
    const hidden = total - active;
    const stock = products.reduce((sum, p) => sum + Number(p.stock || 0), 0);

    return { total, active, hidden, stock };
  }, [products]);

  function updateForm(key: keyof typeof form, value: string) {
    setForm((prev) => ({ ...prev, [key]: value }));
  }

  function handleImages(files: FileList | null) {
    if (!files) return;

    const selected = Array.from(files);

    const invalid = selected.find((file) => !file.type.startsWith('image/'));

    if (invalid) {
      alert('Only image files are allowed');
      return;
    }

    const totalImages = imagePreviews.length + selected.length;

    if (totalImages > 10) {
      alert('Maximum 10 images allowed');
      return;
    }

    setImageFiles((prev) => [...prev, ...selected].slice(0, 10));

    setImagePreviews((prev) => [
      ...prev,
      ...selected.map((file) => URL.createObjectURL(file)),
    ].slice(0, 10));
  }

  function resetForm() {
    setForm(emptyForm);
    setImageFiles([]);
    setImagePreviews([]);
    setExistingImages([]);
    setEditingId(null);
    setMessage('');
  }

  function editProduct(product: Product) {
    setEditingId(product.id);
    setMessage('');
    setImageFiles([]);

    const oldImages = product.images?.length ? product.images : [product.image];

    setExistingImages(oldImages);
    setImagePreviews(oldImages);

    setForm({
      name: product.name || '',
      description: product.description || '',
      price: String(product.price || ''),
      originalPrice: product.originalPrice ? String(product.originalPrice) : '',
      badge: product.badge || '',
      category: product.category || '',
      stock: product.stock ? String(product.stock) : '',
    });

    window.scrollTo({ top: 0, behavior: 'smooth' });
  }

  async function saveProduct(e: React.FormEvent) {
    e.preventDefault();

    if (!form.name.trim()) return alert('Product name required');
    if (!form.price || Number(form.price) <= 0) return alert('Price required');

    if (!editingId && imageFiles.length === 0) {
      return alert('Please upload at least 1 image');
    }

    if (editingId && imagePreviews.length === 0 && imageFiles.length === 0) {
      return alert('Product must have at least 1 image');
    }

    try {
      setLoading(true);

      const formData = new FormData();

      formData.append('name', form.name.trim());
      formData.append('description', form.description.trim());
      formData.append('price', String(Number(form.price)));

      if (form.originalPrice) {
        formData.append('originalPrice', String(Number(form.originalPrice)));
      }

      formData.append('badge', form.badge.trim());
      formData.append('category', form.category.trim());
      formData.append('stock', String(Number(form.stock || 0)));
      formData.append('active', 'true');

      // ✅ Tell backend which old images you still want to keep
      if (editingId) {
        formData.append('keepImages', JSON.stringify(existingImages));
      }

      // ✅ Send only new uploaded files
      imageFiles.forEach((file) => {
        formData.append('images', file);
      });

      const res = await fetch(
        editingId ? `/api/products/${editingId}` : '/api/products',
        {
          method: editingId ? 'PUT' : 'POST',
          credentials: 'include',
          body: formData,
        }
      );

      const data = await res.json();

      if (!res.ok) throw new Error(data?.error || 'Save failed');

      setMessage(
        editingId
          ? 'Product updated successfully.'
          : 'Product created successfully.'
      );

      resetForm();
      await loadProducts();
    } catch (err: any) {
      alert(err?.message || 'Save failed');
    } finally {
      setLoading(false);
    }
  }

  async function deleteProduct(id: string) {
    if (!confirm('Delete this product?')) return;

    try {
      const res = await fetch(`/api/products/${id}`, {
        method: 'DELETE',
        credentials: 'include',
      });

      const data = await res.json();

      if (!res.ok) throw new Error(data?.error || 'Delete failed');

      await loadProducts();
    } catch (error: any) {
      alert(error?.message || 'Delete failed');
    }
  }

  async function toggleActive(product: Product) {
    try {
      const formData = new FormData();

      formData.append('name', product.name);
      formData.append('description', product.description || '');
      formData.append('price', String(product.price));

      if (product.originalPrice) {
        formData.append('originalPrice', String(product.originalPrice));
      }

      formData.append('badge', product.badge || '');
      formData.append('category', product.category || '');
      formData.append('stock', String(product.stock || 0));
      formData.append('active', product.active === false ? 'true' : 'false');

      const res = await fetch(`/api/products/${product.id}`, {
        method: 'PUT',
        credentials: 'include',
        body: formData,
      });

      const data = await res.json();

      if (!res.ok) throw new Error(data?.error || 'Update failed');

      await loadProducts();
    } catch (error: any) {
      alert(error?.message || 'Update failed');
    }
  }

  async function logout() {
    await fetch('/api/logout', {
      method: 'POST',
      credentials: 'include',
    });

    window.location.href = '/login';
  }

  if (checking) {
    return (
      <div className="flex min-h-screen items-center justify-center bg-slate-100 p-4">
        <div className="rounded-3xl bg-white px-6 py-5 font-bold text-slate-700 shadow">
          Checking authentication...
        </div>
      </div>
    );
  }

  if (!authorized) return null;

  return (
    <div className="min-h-screen bg-[#f3f6fb] text-slate-900">
      <div className="mx-auto w-full max-w-7xl px-3 py-4 sm:px-6 lg:px-8">
        <header className="mb-5 overflow-hidden rounded-[32px] bg-gradient-to-br from-slate-950 via-slate-900 to-orange-600 p-5 text-white shadow-xl sm:p-7">
          <div className="flex flex-col gap-5 sm:flex-row sm:items-center sm:justify-between">
            <div>
              <div className="inline-flex items-center gap-2 rounded-full bg-white/15 px-3 py-1 text-xs font-bold">
                <Boxes className="h-4 w-4" />
                Admin Dashboard
              </div>

              <h1 className="mt-3 text-2xl font-black tracking-tight sm:text-4xl">
                Product Management
              </h1>

              <p className="mt-1 max-w-xl text-sm text-slate-200">
                Create, edit, hide, delete and manage product inventory.
              </p>
            </div>

            <div className="flex gap-2">
              <a
                href="/"
                className="inline-flex h-11 items-center justify-center gap-2 rounded-2xl bg-white px-4 text-sm font-black text-slate-950"
              >
                <ArrowLeft className="h-4 w-4" />
                Store
              </a>

              <button
                onClick={logout}
                className="inline-flex h-11 items-center justify-center gap-2 rounded-2xl bg-red-500 px-4 text-sm font-black text-white"
              >
                <LogOut className="h-4 w-4" />
                Logout
              </button>
            </div>
          </div>
        </header>

        <section className="mb-5 grid grid-cols-2 gap-3 lg:grid-cols-4">
          <StatCard label="Products" value={stats.total} icon={<Package />} />
          <StatCard label="Active" value={stats.active} icon={<Eye />} />
          <StatCard label="Hidden" value={stats.hidden} icon={<EyeOff />} />
          <StatCard label="Stock" value={stats.stock} icon={<Boxes />} />
        </section>

        <div className="grid gap-5 lg:grid-cols-[420px_1fr]">
          <section className="h-fit rounded-[32px] border border-slate-200 bg-white p-5 shadow-sm">
            <div className="mb-5 flex items-center justify-between gap-3">
              <div>
                <h2 className="text-xl font-black">
                  {editingId ? 'Edit Product' : 'Create Product'}
                </h2>
                <p className="text-sm text-slate-500">
                  Add product information and upload images.
                </p>
              </div>

              <div className="flex h-12 w-12 items-center justify-center rounded-2xl bg-orange-50 text-orange-600">
                <PackagePlus className="h-6 w-6" />
              </div>
            </div>

            {message && (
              <div className="mb-4 rounded-2xl bg-emerald-50 px-4 py-3 text-sm font-bold text-emerald-700">
                {message}
              </div>
            )}

            <form onSubmit={saveProduct} className="space-y-4">
              <Field label="Product Name">
                <input
                  placeholder="DJI Air 3"
                  value={form.name}
                  onChange={(e) => updateForm('name', e.target.value)}
                  className="input-pro"
                />
              </Field>

              <Field label="Description">
                <textarea
                  placeholder="Write product details..."
                  value={form.description}
                  onChange={(e) => updateForm('description', e.target.value)}
                  className="input-pro min-h-[105px] resize-none py-3"
                />
              </Field>

              <div className="grid grid-cols-2 gap-3">
                <Field label="Price">
                  <input
                    type="number"
                    step="0.01"
                    placeholder="0.00"
                    value={form.price}
                    onChange={(e) => updateForm('price', e.target.value)}
                    className="input-pro"
                  />
                </Field>

                <Field label="Original">
                  <input
                    type="number"
                    step="0.01"
                    placeholder="Optional"
                    value={form.originalPrice}
                    onChange={(e) =>
                      updateForm('originalPrice', e.target.value)
                    }
                    className="input-pro"
                  />
                </Field>
              </div>

              <div className="grid grid-cols-2 gap-3">
                <Field label="Category">
                  <input
                    placeholder="Drone"
                    value={form.category}
                    onChange={(e) => updateForm('category', e.target.value)}
                    className="input-pro"
                  />
                </Field>

                <Field label="Badge">
                  <input
                    placeholder="NEW / HOT"
                    value={form.badge}
                    onChange={(e) => updateForm('badge', e.target.value)}
                    className="input-pro"
                  />
                </Field>
              </div>

              <Field label="Stock">
                <input
                  type="number"
                  placeholder="10"
                  value={form.stock}
                  onChange={(e) => updateForm('stock', e.target.value)}
                  className="input-pro"
                />
              </Field>

              <Field label="Product Images">
                <label className="group flex min-h-[150px] cursor-pointer flex-col items-center justify-center rounded-[26px] border-2 border-dashed border-slate-300 bg-slate-50 px-4 py-6 text-center transition hover:border-orange-500 hover:bg-orange-50/40">
                  <input
                    type="file"
                    accept="image/*"
                    multiple
                    onChange={(e) => handleImages(e.target.files)}
                    className="hidden"
                  />

                  <div className="mb-3 flex h-12 w-12 items-center justify-center rounded-2xl bg-white text-slate-700 shadow-sm group-hover:text-orange-600">
                    <ImagePlus className="h-6 w-6" />
                  </div>

                  <div className="text-sm font-black text-slate-700">
                    Click to upload images
                  </div>

                  <div className="mt-1 text-xs text-slate-500">
                    Maximum 10 images, 5MB each
                  </div>
                </label>
              </Field>

              {imagePreviews.length > 0 && (
                <div className="grid grid-cols-4 gap-2">
                  {imagePreviews.slice(0, 10).map((src, index) => (
                    <div
                      key={`${src}-${index}`}
                      className="relative overflow-hidden rounded-2xl border border-slate-200 bg-slate-50"
                    >
                      <img
                        src={src}
                        alt=""
                        className="aspect-square w-full object-cover"
                      />

                      {index === 0 && (
                        <div className="absolute left-1 top-1 rounded-full bg-slate-950 px-2 py-0.5 text-[10px] font-black text-white">
                          Main
                        </div>
                      )}

                      <button
                        type="button"
                        onClick={() => removePreviewImage(index)}
                        className="absolute right-1 top-1 flex h-6 w-6 items-center justify-center rounded-full bg-red-500 text-white shadow-md hover:bg-red-600"
                      >
                        <X className="h-4 w-4" />
                      </button>
                    </div>
                  ))}
                </div>
              )}

              <div className="flex gap-2 pt-2">
                <button
                  disabled={loading}
                  className="h-12 flex-1 rounded-2xl bg-slate-950 font-black text-white shadow-lg shadow-slate-900/20 transition hover:bg-slate-800 disabled:opacity-50"
                >
                  {loading
                    ? 'Saving...'
                    : editingId
                      ? 'Update Product'
                      : 'Create Product'}
                </button>

                {editingId && (
                  <button
                    type="button"
                    onClick={resetForm}
                    className="h-12 rounded-2xl bg-slate-100 px-5 font-black text-slate-700"
                  >
                    Cancel
                  </button>
                )}
              </div>
            </form>
          </section>

          <section className="rounded-[32px] border border-slate-200 bg-white p-5 shadow-sm">
            <div className="mb-5 flex flex-col gap-3 md:flex-row md:items-center md:justify-between">
              <div>
                <h2 className="text-xl font-black">Products</h2>
                <p className="text-sm text-slate-500">
                  {filteredProducts.length} product(s) found.
                </p>
              </div>

              <div className="relative w-full md:max-w-sm">
                <Search className="absolute left-4 top-1/2 h-4 w-4 -translate-y-1/2 text-slate-400" />
                <input
                  placeholder="Search products..."
                  value={search}
                  onChange={(e) => setSearch(e.target.value)}
                  className="h-12 w-full rounded-2xl border border-slate-200 bg-slate-50 pl-11 pr-4 text-sm outline-none transition focus:border-orange-500 focus:bg-white"
                />
              </div>
            </div>

            {loadingProducts ? (
              <EmptyBox text="Loading products..." />
            ) : filteredProducts.length === 0 ? (
              <EmptyBox text="No products found." />
            ) : (
              <div className="grid gap-4 md:grid-cols-2 xl:grid-cols-3">
                {filteredProducts.map((product) => (
                  <article
                    key={product.id}
                    className="overflow-hidden rounded-[28px] border border-slate-200 bg-white shadow-sm transition hover:-translate-y-1 hover:shadow-xl"
                  >
                    <div className="relative">
                      <img
                        src={product.image}
                        alt={product.name}
                        className="h-44 w-full object-cover"
                      />

                      <div className="absolute left-3 top-3 flex gap-2">
                        <span
                          className={`rounded-full px-3 py-1 text-xs font-black ${product.active === false
                            ? 'bg-red-500 text-white'
                            : 'bg-emerald-500 text-white'
                            }`}
                        >
                          {product.active === false ? 'Hidden' : 'Active'}
                        </span>

                        {product.badge && (
                          <span className="rounded-full bg-blue-600 px-3 py-1 text-xs font-black text-white">
                            {product.badge}
                          </span>
                        )}
                      </div>
                    </div>

                    <div className="p-4">
                      <h3 className="line-clamp-1 text-lg font-black text-slate-950">
                        {product.name}
                      </h3>

                      <p className="mt-1 line-clamp-2 min-h-[40px] text-sm text-slate-500">
                        {product.description || 'No description.'}
                      </p>

                      <div className="mt-4 grid grid-cols-3 gap-2 rounded-2xl bg-slate-50 p-3 text-center text-xs">
                        <div>
                          <div className="font-black text-slate-950">
                            ${product.price.toFixed(2)}
                          </div>
                          <div className="text-slate-500">Price</div>
                        </div>

                        <div>
                          <div className="font-black text-slate-950">
                            {product.category || '-'}
                          </div>
                          <div className="text-slate-500">Category</div>
                        </div>

                        <div>
                          <div className="font-black text-slate-950">
                            {product.stock ?? 0}
                          </div>
                          <div className="text-slate-500">Stock</div>
                        </div>
                      </div>

                      <div className="mt-4 grid grid-cols-3 gap-2">
                        <button
                          onClick={() => editProduct(product)}
                          className="btn-card bg-blue-50 text-blue-700"
                        >
                          <Edit3 className="h-4 w-4" />
                          Edit
                        </button>

                        <button
                          onClick={() => toggleActive(product)}
                          className="btn-card bg-amber-50 text-amber-700"
                        >
                          {product.active === false ? (
                            <Eye className="h-4 w-4" />
                          ) : (
                            <EyeOff className="h-4 w-4" />
                          )}
                          {product.active === false ? 'Show' : 'Hide'}
                        </button>

                        <button
                          onClick={() => deleteProduct(product.id)}
                          className="btn-card bg-red-50 text-red-700"
                        >
                          <Trash2 className="h-4 w-4" />
                          Delete
                        </button>
                      </div>
                    </div>
                  </article>
                ))}
              </div>
            )}
          </section>
        </div>
      </div>
    </div>
  );
}

function StatCard({
  label,
  value,
  icon,
}: {
  label: string;
  value: number;
  icon: React.ReactNode;
}) {
  return (
    <div className="rounded-[26px] border border-slate-200 bg-white p-4 shadow-sm">
      <div className="flex items-center justify-between">
        <div className="text-sm font-bold text-slate-500">{label}</div>
        <div className="flex h-10 w-10 items-center justify-center rounded-2xl bg-slate-100 text-slate-700">
          {icon}
        </div>
      </div>
      <div className="mt-3 text-3xl font-black text-slate-950">{value}</div>
    </div>
  );
}

function Field({
  label,
  children,
}: {
  label: string;
  children: React.ReactNode;
}) {
  return (
    <label className="block">
      <div className="mb-1.5 text-sm font-black text-slate-700">{label}</div>
      {children}
    </label>
  );
}

function EmptyBox({ text }: { text: string }) {
  return (
    <div className="rounded-[28px] bg-slate-50 p-10 text-center font-bold text-slate-500">
      {text}
    </div>
  );
}