lbry-desktop/ui/component/previewLink/view.jsx

59 lines
1.8 KiB
React
Raw Normal View History

// @flow
import * as React from 'react';
import UriIndicator from 'component/uriIndicator';
import TruncatedText from 'component/common/truncated-text';
import MarkdownPreview from 'component/common/markdown-preview';
import { withRouter } from 'react-router-dom';
import { formatLbryUrlForWeb } from 'util/url';
type Props = {
uri: string,
title: ?string,
thumbnail: ?string,
description: ?string,
history: { push: string => void },
};
class PreviewLink extends React.PureComponent<Props> {
handleClick = () => {
const { uri, history } = this.props;
history.push(formatLbryUrlForWeb(uri));
};
render() {
const { uri, title, description, thumbnail } = this.props;
const placeholder = 'static/img/placeholder.png';
const thumbnailStyle = {
backgroundImage: `url(${thumbnail || placeholder})`,
};
return (
<span className="preview-link" role="button" onClick={this.handleClick}>
<span className="claim-preview">
<span style={thumbnailStyle} className="preview-link__thumbnail media__thumb" />
<span className="claim-preview-metadata">
<span className="claim-preview-info">
<span className="claim-preview__title">
2019-06-20 19:00:52 -06:00
<TruncatedText text={title} lines={1} />
</span>
</span>
<span className="media__subtitle">
2019-06-20 19:00:52 -06:00
<UriIndicator uri={uri} link />
</span>
<span className="claim-preview-properties">
<span className="preview-link__description media__subtitle">
2019-06-20 19:00:52 -06:00
<TruncatedText lines={2} showTooltip={false}>
2019-12-03 11:41:44 -05:00
<MarkdownPreview content={description} strip />
2019-06-20 19:00:52 -06:00
</TruncatedText>
</span>
</span>
</span>
</span>
</span>
);
}
}
export default withRouter(PreviewLink);