import { NextRequest, NextResponse } from 'next/server'
import { db } from '@/lib/db'
import { requireAuth } from '@/lib/api-auth'
import { Prisma } from '@prisma/client'

export async function GET(request: NextRequest) {
  try {
    const authResult = await requireAuth(['CUSTOMER'])(request)
    if ('error' in authResult) return authResult.error

    const { user } = authResult
    const { searchParams } = new URL(request.url)
    const status = searchParams.get('status')
    const sentiment = searchParams.get('sentiment')
    const rating = searchParams.get('rating')
    const serviceType = searchParams.get('serviceType')
    const dateFrom = searchParams.get('dateFrom')
    const dateTo = searchParams.get('dateTo')
    const page = parseInt(searchParams.get('page') || '1')
    const limit = parseInt(searchParams.get('limit') || '10')

    const where: Prisma.ReviewWhereInput = {
      customerId: user.id,
      deletedAt: null,
    }

    if (status) where.status = status as Prisma.EnumReviewStatusFilter
    if (sentiment) where.sentiment = sentiment as Prisma.EnumReviewSentimentFilter
    if (rating) where.rating = parseInt(rating)
    if (serviceType) where.serviceType = serviceType
    if (dateFrom || dateTo) {
      where.createdAt = {}
      if (dateFrom) where.createdAt.gte = new Date(dateFrom)
      if (dateTo) where.createdAt.lte = new Date(dateTo)
    }

    const [reviews, total] = await Promise.all([
      db.review.findMany({
        where,
        include: {
          assignedTo: { select: { id: true, name: true } },
          _count: { select: { photos: true, responses: true } },
        },
        orderBy: { createdAt: 'desc' },
        skip: (page - 1) * limit,
        take: limit,
      }),
      db.review.count({ where }),
    ])

    return NextResponse.json({
      reviews,
      pagination: {
        page,
        limit,
        total,
        totalPages: Math.ceil(total / limit),
      },
    })
  } catch (error) {
    console.error('Error al listar mis reseñas:', error)
    return NextResponse.json(
      { error: 'Error interno del servidor' },
      { status: 500 }
    )
  }
}
