// @flow
import React from 'react';
import Card from 'component/common/card';
import ErrorText from 'component/common/error-text';

type Props = {
  source: string,
};

function ImageViewer(props: Props) {
  const { source } = props;
  const [loadingError, setLoadingError] = React.useState(false);

  return (
    <React.Fragment>
      {loadingError && (
        <Card
          title={__('Error Displaying Image')}
          actions={<ErrorText>There was an error displaying the image. You may still download it.</ErrorText>}
        />
      )}
      {!loadingError && (
        <div className="file-render__viewer">
          <img src={source} onError={() => setLoadingError(true)} />
        </div>
      )}
    </React.Fragment>
  );
}

export default ImageViewer;