"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 { 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" export function TicketsView() { const [filters, setFilters] = useState(defaultTicketFilters) const queues = useQuery(api.queues.summary, { tenantId: DEFAULT_TENANT_ID }) as TicketQueueSummary[] | undefined const ticketsRaw = useQuery(api.tickets.list, { tenantId: DEFAULT_TENANT_ID, 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, }) 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) => (
))}
) : ( )}
) }