BaseImage

BaseImage displays an image or a fallback when loading fails. It’s used internally by:

  • Image component - used to display image attachments in Message
  • Gallery component - used to display image gallery among Message attachments
  • AttachmentPreviewList component - used to display attachment previews in MessageInput

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 BaseImage aligned with <img> props for compatibility.
  • Test fallback behavior on slow or failed network conditions.

Default fallbacks look like this:

BaseImage in image attachment

BaseImage in image attachment gallery

BaseImage in attachment preview

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:

.str-chat {
  --str-chat__image-fallback-icon: url("");
}

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.