// Copyright 2018 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import classNames from 'classnames'; import type { ReadonlyDeep } from 'type-fest'; import { isImageTypeSupported, isVideoTypeSupported, } from '../../../util/GoogleChrome'; import type { LocalizerType } from '../../../types/Util'; import type { MediaItemType } from '../../../types/MediaItem'; import * as log from '../../../logging/log'; export type Props = { mediaItem: ReadonlyDeep; onClick?: () => void; i18n: LocalizerType; }; type State = { imageBroken: boolean; }; export class MediaGridItem extends React.Component { private readonly onImageErrorBound: () => void; constructor(props: Props) { super(props); this.state = { imageBroken: false, }; this.onImageErrorBound = this.onImageError.bind(this); } public onImageError(): void { log.info( 'MediaGridItem: Image failed to load; failing over to placeholder' ); this.setState({ imageBroken: true, }); } public renderContent(): JSX.Element | null { const { mediaItem, i18n } = this.props; const { imageBroken } = this.state; const { attachment, contentType } = mediaItem; if (!attachment) { return null; } if (contentType && isImageTypeSupported(contentType)) { if (imageBroken || !mediaItem.thumbnailObjectUrl) { return (
); } return ( {i18n('lightboxImageAlt')} ); } if (contentType && isVideoTypeSupported(contentType)) { if (imageBroken || !mediaItem.thumbnailObjectUrl) { return (
); } return (
{i18n('lightboxImageAlt')}
); } return (
); } public override render(): JSX.Element { const { onClick } = this.props; return ( ); } }