Persist chat history in your GenUI SDK application using useThreadManager and useThreadListManager hooks. This guide explains how to configure them with your app’s persistence logic.

useThreadManager

A Thread is a single conversation session, maintaining its own history and context. The ThreadManager, obtained via the useThreadManager hook, controls its state and actions.

Key configurations:

threadListManager
ThreadListManager

The ThreadListManager object. For more information on how to get this object, see useThreadListManager.

loadThread
function

Load all messages for a specific thread.

onUpdateMessage
function

Save message updates (e.g., after a form submission).

apiUrl
string

A backend endpoint (e.g., "/api/chat"). Thesys GenUI SDK does a POST request to this endpoint with the following three arguments in the request body. If you need to pass additional arguments, use the processMessage function. Provide either processMessage or apiUrl.

processMessage
function

A custom function for more control over sending messages and receiving AI responses. Provide either processMessage or apiUrl.

The useThreadManager hook uses the Response object from this function to handle streaming updates to the UI.

Application backend must use the responseId to set the final assistant’s response message ID, as it’s used for future updates to that message.

useThreadListManager

The Thread List displays multiple conversation threads, typically in a sidebar. The ThreadListManager, from the useThreadListManager hook, manages this list.

Key configurations:

fetchThreadList
function

Fetch all thread list.

createThread
function

Create a new thread when the user sends the first message.

deleteThread
function

Delete a specific thread.

updateThread
function

Update a thread’s metadata, like its title.

onSelectThread
function

UI Callback function: called when a user selects a thread from the list.

onSwitchToNew
function

UI Callback function: called to prepare for a new conversation.

By configuring these hooks with your service functions, you integrate your application’s data operations (like saving to or loading from the database) to enable persistent chat experiences.

For a detailed walkthrough of implementing service functions with a Firebase backend, see: