.str-chat {
--str-chat__image-fallback-icon: url("");
}BaseImage
BaseImage displays an image or a fallback when loading fails. It’s used internally by:
Imagecomponent - used to display image attachments inMessageGallerycomponent - used to display image gallery amongMessageattachmentsAttachmentPreviewListcomponent - used to display attachment previews inMessageInput
Best Practices
- Prefer CSS fallback customization before replacing
BaseImage. - Keep fallback visuals lightweight to avoid layout shifts on load failure.
- Use a consistent fallback icon across attachments and previews.
- Keep custom
BaseImagealigned with<img>props for compatibility. - Test fallback behavior on slow or failed network conditions.
Default fallbacks look like this:



Usage
Custom image fallback
To change the default fallback, set a new data image on the --str-chat__image-fallback-icon CSS variable within .str-chat:
To change mask size or color, target .str-chat__base-image--load-failed:
:root {
--custom-icon-fill-color: #223344;
--custom-icon-width-and-height: 4rem 4rem;
}
.str-chat__base-image--load-failed {
mask-size: var(--custom-icon-width-and-height);
-webkit-mask-size: var(--custom-icon-width-and-height);
background-color: var(--custom-icon-fill-color);
}Custom BaseImage
Override the default BaseImage by passing a custom component to Channel:
import { ComponentProps } from "react";
import { Channel } from "stream-chat-react";
const CustomBaseImage = (props: ComponentProps<"img">) => {
// your implementation...
};
export const MyUI = () => {
return (
<Channel BaseImage={CustomBaseImage}>
{
{
/* more components */
}
}
</Channel>
);
};Props
This component accepts standard <img> props.