'use client'

import { useEffect, useState } from 'react'
import Link from 'next/link'
import api from '@/lib/api'

export default function SalidasPage() {
  const [salidas, setSalidas] = useState<any[]>([])
  const [loading, setLoading] = useState(true)
  const [pagination, setPagination] = useState({ page: 1, total: 0, totalPages: 1 })
  const [filters, setFilters] = useState({ startDate: '', endDate: '', projectId: '' })
  const [proyectos, setProyectos] = useState<any[]>([])

  const fetchSalidas = async (page = 1) => {
    setLoading(true)
    try {
      const r = await api.get('/salidas', {
        params: { page, limit: 20, projectId: filters.projectId || undefined, startDate: filters.startDate || undefined, endDate: filters.endDate || undefined },
      })
      setSalidas(r.data.data)
      setPagination(r.data.pagination)
    } catch (e) { console.error(e) }
    finally { setLoading(false) }
  }

  useEffect(() => {
    api.get('/projects', { params: { activeOnly: true } }).then((r) => setProyectos(r.data))
    fetchSalidas()
  }, [])

  const handleCancel = async (id: number) => {
    if (!confirm('¿Cancelar esta salida? Se revertirá el kardex.')) return
    await api.patch(`/salidas/${id}/cancel`)
    fetchSalidas(pagination.page)
  }

  const downloadPDF = async (id: number, docNumber: string) => {
    const r = await api.get(`/salidas/${id}/pdf`, { responseType: 'blob' })
    const url = URL.createObjectURL(new Blob([r.data], { type: 'application/pdf' }))
    const a = document.createElement('a')
    a.href = url
    a.download = `${docNumber}.pdf`
    a.click()
    URL.revokeObjectURL(url)
  }

  const statusBadge = (s: string) => {
    const m: any = { completed: 'bg-green-100 text-green-700', cancelled: 'bg-red-100 text-red-700' }
    const l: any = { completed: 'Completado', cancelled: 'Cancelado' }
    return <span className={`px-2 py-0.5 rounded-full text-xs font-medium ${m[s] || ''}`}>{l[s] || s}</span>
  }

  return (
    <div className="space-y-4">
      <div className="bg-white rounded-xl shadow-sm border p-4">
        <div className="flex flex-wrap gap-3 items-end justify-between">
          <div className="flex flex-wrap gap-3">
            <div>
              <label className="block text-xs text-gray-500 mb-1">Proyecto</label>
              <select className="border rounded-lg px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-indigo-400"
                value={filters.projectId} onChange={(e) => setFilters({ ...filters, projectId: e.target.value })}>
                <option value="">Todos</option>
                {proyectos.map((p) => <option key={p.id} value={p.id}>{p.name}</option>)}
              </select>
            </div>
            <div>
              <label className="block text-xs text-gray-500 mb-1">Fecha desde</label>
              <input type="date" className="border rounded-lg px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-indigo-400"
                value={filters.startDate} onChange={(e) => setFilters({ ...filters, startDate: e.target.value })} />
            </div>
            <div>
              <label className="block text-xs text-gray-500 mb-1">Fecha hasta</label>
              <input type="date" className="border rounded-lg px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-indigo-400"
                value={filters.endDate} onChange={(e) => setFilters({ ...filters, endDate: e.target.value })} />
            </div>
            <div className="flex items-end">
              <button onClick={() => fetchSalidas(1)} className="px-4 py-2 bg-gray-100 hover:bg-gray-200 rounded-lg text-sm">🔍 Buscar</button>
            </div>
          </div>
          <Link href="/salidas/nueva" className="bg-indigo-600 text-white px-4 py-2 rounded-lg text-sm hover:bg-indigo-700 transition">
            + Nueva Salida
          </Link>
        </div>
      </div>

      <div className="bg-white rounded-xl shadow-sm border overflow-hidden">
        <table className="min-w-full text-sm">
          <thead className="bg-gray-50 text-gray-500 uppercase text-xs">
            <tr>
              <th className="px-4 py-3 text-left">N° Documento</th>
              <th className="px-4 py-3 text-left">Fecha</th>
              <th className="px-4 py-3 text-left">Proyecto</th>
              <th className="px-4 py-3 text-left">Bodega</th>
              <th className="px-4 py-3 text-left">Destino / Beneficiario</th>
              <th className="px-4 py-3 text-center">Estado</th>
              <th className="px-4 py-3 text-center">Acciones</th>
            </tr>
          </thead>
          <tbody className="divide-y divide-gray-100">
            {loading ? (
              <tr><td colSpan={7} className="text-center py-10 text-gray-400">Cargando...</td></tr>
            ) : salidas.length === 0 ? (
              <tr><td colSpan={7} className="text-center py-10 text-gray-400">No hay salidas</td></tr>
            ) : salidas.map((s) => (
              <tr key={s.id} className="hover:bg-gray-50">
                <td className="px-4 py-3 font-mono text-indigo-600">
                  <Link href={`/salidas/${s.id}`} className="hover:underline">{s.docNumber}</Link>
                </td>
                <td className="px-4 py-3 text-gray-600">{new Date(s.date).toLocaleDateString('es-HN')}</td>
                <td className="px-4 py-3"><span className="bg-indigo-50 text-indigo-700 px-2 py-0.5 rounded text-xs">{s.project?.name}</span></td>
                <td className="px-4 py-3 text-gray-700">{s.warehouse?.name}</td>
                <td className="px-4 py-3 text-gray-600">{s.beneficiary || s.destination || '—'}</td>
                <td className="px-4 py-3 text-center">{statusBadge(s.status)}</td>
                <td className="px-4 py-3 text-center space-x-2">
                  <Link href={`/salidas/${s.id}`} className="text-indigo-600 hover:underline text-xs">Ver</Link>
                  {s.status === 'completed' && (
                    <>
                      <button onClick={() => downloadPDF(s.id, s.docNumber)} className="text-green-600 hover:underline text-xs">PDF</button>
                      <button onClick={() => handleCancel(s.id)} className="text-red-500 hover:underline text-xs">Cancelar</button>
                    </>
                  )}
                </td>
              </tr>
            ))}
          </tbody>
        </table>
        {pagination.totalPages > 1 && (
          <div className="flex justify-center items-center gap-3 py-4 border-t text-sm">
            <button disabled={pagination.page <= 1} onClick={() => fetchSalidas(pagination.page - 1)} className="px-3 py-1 border rounded disabled:opacity-40 hover:bg-gray-50">← Anterior</button>
            <span className="text-gray-600">Página {pagination.page} de {pagination.totalPages}</span>
            <button disabled={pagination.page >= pagination.totalPages} onClick={() => fetchSalidas(pagination.page + 1)} className="px-3 py-1 border rounded disabled:opacity-40 hover:bg-gray-50">Siguiente →</button>
          </div>
        )}
      </div>
    </div>
  )
}
