2021-06-14 09:24:21 -04:00
|
|
|
// @flow
|
|
|
|
import React from 'react';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
import type { Node } from 'react';
|
|
|
|
import useLazyLoading from 'effects/use-lazy-loading';
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
thumb: string,
|
2021-08-02 20:33:31 +08:00
|
|
|
fallback: ?string,
|
2021-06-14 09:24:21 -04:00
|
|
|
children?: Node,
|
2021-07-29 15:53:56 +08:00
|
|
|
className?: string,
|
2021-06-14 09:24:21 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
const Thumb = (props: Props) => {
|
2021-08-02 20:33:31 +08:00
|
|
|
const { thumb, fallback, children, className } = props;
|
2021-06-14 09:24:21 -04:00
|
|
|
const thumbnailRef = React.useRef(null);
|
2021-08-02 20:33:31 +08:00
|
|
|
|
|
|
|
useLazyLoading(thumbnailRef, fallback || '');
|
2021-06-14 09:24:21 -04:00
|
|
|
|
|
|
|
return (
|
2021-07-29 15:53:56 +08:00
|
|
|
<div ref={thumbnailRef} data-background-image={thumb} className={classnames('media__thumb', className)}>
|
2021-06-14 09:24:21 -04:00
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Thumb;
|