// Copyright 2018-2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import classNames from 'classnames'; import { isImageTypeSupported, isVideoTypeSupported, } from '../../../util/GoogleChrome'; import { LocalizerType } from '../../../types/Util'; import { MediaItemType } from '../../LightboxGallery'; export interface Props { mediaItem: MediaItemType; onClick?: () => void; i18n: LocalizerType; } interface 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 { window.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 render(): JSX.Element { const { onClick } = this.props; return ( ); } }