MUI X
ChatHow errors are captured, surfaced, and recovered from across the chat runtime.
FeedbackBundle sizeFigmaSketchThe chat runtime captures errors from adapters, streams, and history loading, and surfaces them through a unified error model. You do not need to catch errors inside adapter methods — the runtime handles them for you.
The ChatError typeEvery error recorded by the runtime is represented as a ChatError:
interface ChatError {
code: ChatErrorCode;
message: string;
source: ChatErrorSource;
recoverable: boolean;
retryable?: boolean;
details?: Recordstring, unknown>;
}
CopyCopied(or $keyC)
Error codes
Code
Description
SEND_ERROR
The adapter's sendMessage() threw an error.
STREAM_ERROR
The stream failed or disconnected unexpectedly.
HISTORY_ERROR
Loading message history failed.
REALTIME_ERROR
The realtime subscription encountered an error.
Error sources
Source
Description
'send'
Error during message send.
'stream'
Error during stream processing.
'history'
Error during history loading.
'render'
Error during component rendering.
'adapter'
Generic adapter error.
recoverable vs retryable
recoverable — The runtime can potentially recover from this error automatically (for example, by reconnecting a dropped stream via reconnectToStream()).
retryable — The user can reasonably try the operation again (for example, re-sending a failed message).
Error propagationWhen an adapter method throws, the runtime:
Records a ChatError with the appropriate source and code. Surfaces it through ChatBox's built-in error UI, useChat().error, and the onError callback. Marks the error recoverable when applicable (for example, stream disconnects) and retryable when the user can try again. The onError callbackHandle errors at the application level using the onError prop on ChatBox:
ChatBox
adapter={adapter}
onError={(error) => {
console.error(`[Chat error] ${error.source}: ${error.message}`);
// Report to your error tracking service
errorTracker.capture(error);
}}
/>
CopyCopied(or $keyC)
Material UI chatStyled with your active MUI themeMar 15Material UI chatStyled with your active MUI theme
MUI AssistantHello! I am styled using your active Material UI theme. Try sending a message.
YouGreat — the bubble colors come from palette.primary and the typography from the theme.
The useChat() hook exposes the current error:
import { useChat } from '@mui/x-chat/headless';
function ErrorBanner() {
const { error, setError } = useChat();
if (!error) return null;
return (
div role="alert">
p>{error.message}p>
button onClick={() => setError(null)}>Dismissbutton>
div>
);
}
CopyCopied(or $keyC)
Retrying failed messagesWhen sendMessage() fails, the user's message is still displayed in the thread (optimistic update) and the composer is re-enabled so the user can try again.
The useChat() hook provides a retry method that re-sends the message associated with a given message ID:
import { useChat } from '@mui/x-chat/headless';
function RetryButton({ messageId }: { messageId: string }) {
const { retry } = useChat();
return button onClick={() => retry(messageId)}>Retrybutton>;
}
CopyCopied(or $keyC)
retry() looks up the original user message by ID, re-submits it through the adapter's sendMessage(), and replaces any previous error state.
Error from adapter methodsYou do not need to wrap adapter methods in try/catch — the runtime handles all thrown errors. If you want to transform or enrich an error before the runtime sees it, throw a plain Error with a custom message. The runtime wraps it in a ChatError with source 'adapter':
async sendMessage({ message, signal }) {
const res = await fetch('/api/chat', {
method: 'POST',
body: JSON.stringify({ message }),
signal,
});
if (!res.ok) {
throw new Error(`Server responded with ${res.status}`);
}
return res.body!;
},
CopyCopied(or $keyC)
Stream disconnect recoveryIf a stream closes without a terminal chunk (finish or abort), the runtime:
Records a recoverable stream error. Sets the message status to 'error'. Calls onError and onFinish with isDisconnect: true. If reconnectToStream() is implemented on the adapter, attempts to resume the stream.See Streaming—Reconnecting to streams for implementation details.
Message status and errorsThe message status field reflects error states:
Status Description 'sending' Message is being sent (optimistic update). 'streaming' Assistant response is streaming. 'sent' Message was sent and response completed. 'error' An error occurred during send or streaming. 'cancelled' The stream was aborted by the user.Components can use the status field to conditionally render error indicators:
function MessageBubble({ message }: { message: ChatMessage }) {
return (
div>
{message.parts.map((part) => /* render parts */)}
{message.status === 'error' && (
span className="error-badge">Failed to sendspan>
)}
div>
);
}
CopyCopied(or $keyC)
See also
Streaming for stream lifecycle and disconnect handling.
Adapter for the adapter interface and error propagation details.
APISee the documentation below for a complete reference to all of the props and classes available to the components mentioned here.
Edit this pageWas this page helpful?
•
Blog•
StoreContents
The ChatError typeError codesError sourcesrecoverable vs retryableError propagationThe onError callbackAccessing the error stateRetrying failed messagesError from adapter methodsStream disconnect recoveryMessage status and errorsSee alsoAPIBecome a Diamond sponsorMUI stands in solidarity with Ukraine.Error Handling - MUI X,AI智能索引,全网链接索引,智能导航,网页索引
- How errors are captured, surfaced, and recovered from across the chat runtime.