chore: save wip changes

This commit is contained in:
2026-06-20 16:07:12 +01:00
parent 2e6cae4d02
commit 25713ef614
11 changed files with 275 additions and 199 deletions

View File

@@ -0,0 +1,23 @@
import { FlashList } from "@shopify/flash-list";
import { useQuery } from "@tanstack/react-query";
import {
useListConversationEntriesQuery,
useDefaultConversationQuery,
useListConversationsQuery,
} from "./queries";
export function ConversationView() {
const { data: conversation } = useQuery(useDefaultConversationQuery());
const { data: entries } = useQuery(
useListConversationEntriesQuery(conversation?.id),
);
return (
<FlashList
data={entries ?? []}
keyExtractor={(item) => item.id}
renderItem={({ item }) => <div key={item.id}>{item.kind}</div>}
/>
);
}

View File

@@ -0,0 +1,15 @@
import {
ConversationEntryKind,
ConversationEntryPayload,
ConversationEntryVisibility,
} from "@freya/core"
import { type } from "arktype"
export const ConversationEntry = type({
id: "string.uuid",
sequence: "number",
kind: type.enumerated(...Object.values(ConversationEntryKind)),
visibility: type.enumerated(...Object.values(ConversationEntryVisibility)),
fileId: "string | null",
payload: ConversationEntryPayload,
})

View File

@@ -0,0 +1,41 @@
import { queryOptions, skipToken } from "@tanstack/react-query"
import { type } from "arktype"
import { useApiClient } from "@/api/client"
import { ConversationEntry } from "./conversations"
const ConversationQueryResponse = type({
entries: ConversationEntry.array(),
})
export function useListConversationsQuery() {
const api = useApiClient()
return queryOptions({
queryKey: ["conversations"],
queryFn: async () =>
api
.request("/conversations", { method: "GET" })
.then(([, json]) => ConversationQueryResponse.assert(json)),
})
}
export function useDefaultConversationQuery() {
return queryOptions({
...useListConversationsQuery(),
select: (data) => (data.entries.length === 0 ? null : data.entries[0]),
})
}
export function useListConversationEntriesQuery(id?: string) {
const api = useApiClient()
return queryOptions({
queryKey: ["conversations", id],
queryFn: id
? async () =>
api
.request(`/conversations/${id}/entries`, { method: "GET" })
.then(([, json]) => ConversationQueryResponse.assert(json).entries)
: skipToken,
})
}