BaseImage
The BaseImage
component's purpose is to display an image or a fallback if loading the resource has failed. The component is used internally by:
Image
component - used to display image attachments inMessage
Gallery
component - used to display image gallery amongMessage
attachmentsAttachmentPreviewList
component - used to display attachment previews inMessageInput
The default image fallbacks are rendered as follows:
Usage
Custom image fallback
The default image fallback can be changed by applying a new CSS data image to the fallback mask in the BaseImage
's <img/>
element. The data image has to be assigned to a CSS variable --str-chat__image-fallback-icon
within the scope of .str-chat
class. An example follows:
.str-chat {
--str-chat__image-fallback-icon: url("");
}
We can change the mask dimensions or color by applying the following rules to the image's class .str-chat__base-image--load-failed
, that signals the image load has 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
The default BaseImage
can be overridden by passing a custom component to Channel
props:
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
The component accepts the img
component props.