2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2020-01-29 11:38:46 -05:00
|
|
|
import type { Node } from 'react';
|
2017-12-21 18:08:54 -03:00
|
|
|
import React from 'react';
|
2020-01-20 11:47:03 -05:00
|
|
|
// import FreezeframeWrapper from './FreezeframeWrapper';
|
2019-03-04 23:46:57 -05:00
|
|
|
import Placeholder from './placeholder.png';
|
2017-07-14 00:18:28 +01:00
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
type Props = {
|
|
|
|
thumbnail: ?string, // externally sourced image
|
2020-01-29 11:38:46 -05:00
|
|
|
children?: Node,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
2018-01-08 17:15:44 -08:00
|
|
|
|
2019-10-06 01:47:08 -04:00
|
|
|
const className = 'media__thumb';
|
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
class CardMedia extends React.PureComponent<Props> {
|
2017-07-14 00:18:28 +01:00
|
|
|
render() {
|
2020-01-29 11:38:46 -05:00
|
|
|
const { thumbnail, children } = this.props;
|
2017-07-14 00:18:28 +01:00
|
|
|
|
2020-01-20 11:47:03 -05:00
|
|
|
// Disabling temporarily to see if people complain
|
|
|
|
// if (thumbnail && thumbnail.endsWith('gif')) {
|
|
|
|
// return <FreezeframeWrapper src={thumbnail} className={className} />;
|
|
|
|
// }
|
2019-11-13 12:50:45 -05:00
|
|
|
let url;
|
|
|
|
// @if TARGET='web'
|
|
|
|
// Pass image urls through a compression proxy
|
2020-01-14 18:03:49 -05:00
|
|
|
url = thumbnail || Placeholder;
|
|
|
|
// url = thumbnail
|
|
|
|
// ? 'https://ext.thumbnails.lbry.com/400x,q55/' +
|
|
|
|
// // The image server will redirect if we don't remove the double slashes after http(s)
|
|
|
|
// thumbnail.replace('https://', 'https:/').replace('http://', 'http:/')
|
|
|
|
// : Placeholder;
|
2019-11-13 12:50:45 -05:00
|
|
|
// @endif
|
|
|
|
// @if TARGET='app'
|
|
|
|
url = thumbnail || Placeholder;
|
|
|
|
// @endif
|
|
|
|
|
2020-01-29 11:38:46 -05:00
|
|
|
return (
|
|
|
|
<div style={{ backgroundImage: `url('${url.replace(/'/g, "\\'")}')` }} className={className}>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
);
|
2017-07-14 00:18:28 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default CardMedia;
|