import { apiFetch } from '../../_lib/api'; interface PendingMessage { id: string; content: string; senderJid: string; senderName: string | null; tags: string[]; createdAt: string; sourceGroupId: string; sourceGroupName: string; sourceGroupPlatformId: string; } type FetchResult = { ok: true; data: T } | { ok: false; status: number; error: string }; async function fetchPending(): Promise> { try { const res = await apiFetch('/admin/messages/pending'); if (!res.ok) { const body = await res.text().catch(() => ''); return { ok: false, status: res.status, error: body.slice(0, 200) || res.statusText }; } return { ok: true, data: (await res.json()) as PendingMessage[] }; } catch (err) { return { ok: false, status: 0, error: `API unreachable: ${(err as Error).message}` }; } } export default async function PendingMessagesPage() { const result = await fetchPending(); const messages = result.ok ? result.data : []; const error = !result.ok ? (result.status === 0 ? 'API unreachable' : `API ${result.status}: ${result.error}`) : null; return (

Pending messages

Flagged messages waiting for an admin to approve. Approving forwards them to every active route from the source group and indexes them in search.

{error && (
Failed to load: {error}
)} {!error && messages.length === 0 && (
No pending messages right now. New flagged messages will appear here as they arrive.
)}
    {messages.map((m) => ( ))}
); } function PendingMessageRow({ message }: { message: PendingMessage }) { return (
  • {message.sourceGroupName}
    {new Date(message.createdAt).toLocaleString()}
    From {message.senderName ?? message.senderJid} {message.tags.length > 0 && ( {message.tags.map((t) => ( {t} ))} )}
    {message.content}
  • ); }