"use client" import { useMemo, useState } from "react" import { useQuery } from "convex/react" // @ts-expect-error Convex runtime API lacks TypeScript definitions import { api } from "@/convex/_generated/api" import type { Id } from "@/convex/_generated/dataModel" import { DEFAULT_TENANT_ID } from "@/lib/constants" import { mapTicketsFromServerList } from "@/lib/mappers/ticket" import type { Ticket, TicketQueueSummary } from "@/lib/schemas/ticket" import { TicketsFilters, TicketFiltersState, defaultTicketFilters } from "@/components/tickets/tickets-filters" import { TicketsTable } from "@/components/tickets/tickets-table" import { useAuth } from "@/lib/auth-client" export function TicketsView() { const [filters, setFilters] = useState(defaultTicketFilters) const { session, convexUserId } = useAuth() const tenantId = session?.user.tenantId ?? DEFAULT_TENANT_ID const queues = useQuery( convexUserId ? api.queues.summary : "skip", convexUserId ? { tenantId, viewerId: convexUserId as Id<"users"> } : "skip" ) as TicketQueueSummary[] | undefined const ticketsRaw = useQuery( api.tickets.list, convexUserId ? { tenantId, viewerId: convexUserId as Id<"users">, status: filters.status ?? undefined, priority: filters.priority ?? undefined, channel: filters.channel ?? undefined, queueId: undefined, // simplified: filter by queue name on client search: filters.search || undefined, } : "skip" ) const tickets = useMemo(() => mapTicketsFromServerList((ticketsRaw ?? []) as unknown[]), [ticketsRaw]) const filteredTickets = useMemo(() => { if (!filters.queue) return tickets return tickets.filter((t: Ticket) => t.queue === filters.queue) }, [tickets, filters.queue]) return (
q.name)} /> {ticketsRaw === undefined ? (
{Array.from({ length: 6 }).map((_, i) => (
))}
) : ( )}
) }