SurfSense/surfsense_web/hooks/use-messages-electric.ts
CREDO23 5ad25d10ea feat: rewrite use-messages-electric hook from Electric to Zero
Replace PGlite sync+live query with Zero useQuery. Maps camelCase
output to snake_case to preserve consumer contract. 162 → 38 lines.
2026-03-23 19:00:20 +02:00

38 lines
1 KiB
TypeScript

"use client";
import { useEffect, useRef } from "react";
import type { RawMessage } from "@/contracts/types/chat-messages.types";
import { queries } from "@/zero/queries";
import { useQuery } from "@rocicorp/zero/react";
/**
* Syncs chat messages for a thread via Zero.
* Calls onMessagesUpdate when messages change.
*/
export function useMessagesElectric(
threadId: number | null,
onMessagesUpdate: (messages: RawMessage[]) => void
) {
const onMessagesUpdateRef = useRef(onMessagesUpdate);
useEffect(() => {
onMessagesUpdateRef.current = onMessagesUpdate;
}, [onMessagesUpdate]);
const [messages] = useQuery(queries.messages.byThread({ threadId: threadId ?? -1 }));
useEffect(() => {
if (!threadId || !messages) return;
const mapped: RawMessage[] = messages.map((msg) => ({
id: msg.id,
thread_id: msg.threadId,
role: msg.role,
content: msg.content,
author_id: msg.authorId ?? null,
created_at: String(msg.createdAt),
}));
onMessagesUpdateRef.current(mapped);
}, [threadId, messages]);
}