External Store
Convert external message formats into assistant-ui's message and thread state for the external store runtime.
API Reference
getExternalStoreMessages
const getExternalStoreMessages: <T>(input: { messages: readonly ThreadMessage[]; } | ThreadMessage | ThreadMessage["content"][number]) => T[];useExternalMessageConverter
useExternalMessageConverteroptions: { callback: useExternalMessageConverter.Callback<T>; messages: T[]; isRunning: boolean; joinStrategy?: "concat-content" | "none" | undefined; metadata?: useExternalMessageConverter.Metadata | undefined; }callback: useExternalMessageConverter.Callback<T>messages: T[]isRunning: booleanjoinStrategy?: "concat-content" | "none"metadata?: useExternalMessageConverter.MetadatatoolStatuses?: Record<string, ToolExecutionStatus>error?: ReadonlyJSONValuemessageTiming?: Record<string, MessageTiming>unstable_convertExternalMessages
const unstable_convertExternalMessages: <T extends WeakKey>(messages: T[], callback: useExternalMessageConverter.Callback<T>, isRunning: boolean, metadata: useExternalMessageConverter.Metadata) => ThreadMessage[];unstable_createMessageConverter
const unstable_createMessageConverter: <T extends object>(callback: useExternalMessageConverter.Callback<T>) => { useThreadMessages: ({ messages, isRunning, joinStrategy, metadata, }: { messages: T[]; isRunning: boolean; joinStrategy?: "concat-content" | "none" | undefined; metadata?: useExternalMessageConverter.Metadata; }) => ThreadMessage[]; toThreadMessages: (messages: T[], isRunning?: boolean, metadata?: useExternalMessageConverter.Metadata) => ThreadMessage[]; toOriginalMessages: (input: ThreadState | ThreadMessage | ThreadMessage["content"][number]) => unknown[]; toOriginalMessage: (input: ThreadState | ThreadMessage | ThreadMessage["content"][number]) => {}; useOriginalMessage: () => {}; useOriginalMessages: () => unknown[]; };bindExternalStoreMessage
Deprecated: This API is experimental and may change without notice.
Attach the original external store message(s) to a ThreadMessage or message part.
This is a no-op if the target already has a bound message.
Use getExternalStoreMessages to retrieve the bound messages later.
const bindExternalStoreMessage: <T>(target: object, message: T | T[]) => void;