mirror of
https://github.com/filecoin-project/slate.git
synced 2025-01-06 01:13:06 +03:00
55 lines
1.3 KiB
JavaScript
55 lines
1.3 KiB
JavaScript
import * as React from "react";
|
|
import * as Validations from "~/common/validations";
|
|
|
|
import { css } from "@emotion/react";
|
|
|
|
import ObjectPlaceholder from "~/components/core/ObjectPreview/placeholders";
|
|
|
|
const STYLES_PLACEHOLDER_CONTAINER = css`
|
|
height: 100%;
|
|
width: 100%;
|
|
min-width: auto;
|
|
`;
|
|
|
|
const STYLES_PREVIEW = css`
|
|
height: 100%;
|
|
width: 100%;
|
|
background-size: cover;
|
|
overflow: hidden;
|
|
img {
|
|
height: 100%;
|
|
width: 100%;
|
|
object-fit: cover;
|
|
}
|
|
`;
|
|
|
|
export default function BlobObjectPreview({ file, css, placeholderRatio = 1, ...props }) {
|
|
const isImage = Validations.isPreviewableImage(file.type);
|
|
const [imgUrl, setImgUrl] = React.useState();
|
|
React.useLayoutEffect(() => {
|
|
if (isImage) {
|
|
const reader = new FileReader();
|
|
reader.addEventListener("load", () => setImgUrl(reader.result), false);
|
|
reader.readAsDataURL(file.blob);
|
|
}
|
|
}, []);
|
|
|
|
if (isImage) {
|
|
return (
|
|
<div css={[STYLES_PREVIEW, css]} {...props}>
|
|
{imgUrl && <img src={imgUrl} alt="File preview" />}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div css={[STYLES_PREVIEW, css]} {...props}>
|
|
<ObjectPlaceholder
|
|
ratio={placeholderRatio}
|
|
containerCss={STYLES_PLACEHOLDER_CONTAINER}
|
|
file={file}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|