2019-06-09 00:57:51 -06:00
|
|
|
// @flow
|
|
|
|
import * as React from 'react';
|
|
|
|
import Button from 'component/button';
|
2019-06-12 20:26:40 -06:00
|
|
|
import PreviewLink from 'component/previewLink';
|
2019-10-14 17:05:19 -06:00
|
|
|
import UriIndicator from 'component/uriIndicator';
|
2019-06-09 00:57:51 -06:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
uri: string,
|
|
|
|
title: ?string,
|
|
|
|
claim: StreamClaim,
|
|
|
|
children: React.Node,
|
2019-06-20 19:00:52 -06:00
|
|
|
className: ?string,
|
2019-06-09 00:57:51 -06:00
|
|
|
autoEmbed: ?boolean,
|
|
|
|
description: ?string,
|
|
|
|
isResolvingUri: boolean,
|
|
|
|
resolveUri: string => void,
|
|
|
|
blackListedOutpoints: Array<{
|
|
|
|
txid: string,
|
|
|
|
nout: number,
|
|
|
|
}>,
|
|
|
|
};
|
|
|
|
|
2019-06-20 14:59:01 -06:00
|
|
|
class ClaimLink extends React.Component<Props> {
|
2019-06-09 00:57:51 -06:00
|
|
|
static defaultProps = {
|
|
|
|
href: null,
|
2019-06-20 19:00:52 -06:00
|
|
|
link: false,
|
2019-06-09 00:57:51 -06:00
|
|
|
title: null,
|
2019-06-12 22:18:35 -06:00
|
|
|
thumbnail: null,
|
|
|
|
autoEmbed: false,
|
|
|
|
description: null,
|
|
|
|
isResolvingUri: false,
|
|
|
|
};
|
|
|
|
|
2019-06-21 00:04:02 -06:00
|
|
|
componentDidMount() {
|
|
|
|
this.resolve(this.props);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidUpdate() {
|
|
|
|
this.resolve(this.props);
|
|
|
|
}
|
|
|
|
|
2019-06-09 00:57:51 -06:00
|
|
|
isClaimBlackListed() {
|
|
|
|
const { claim, blackListedOutpoints } = this.props;
|
2019-08-28 21:39:21 -04:00
|
|
|
const signingChannel = claim && claim.signing_channel;
|
2019-06-09 00:57:51 -06:00
|
|
|
if (claim && blackListedOutpoints) {
|
|
|
|
let blackListed = false;
|
|
|
|
|
2019-08-28 21:39:21 -04:00
|
|
|
blackListed = blackListedOutpoints.some(
|
|
|
|
outpoint =>
|
|
|
|
(signingChannel && outpoint.txid === signingChannel.txid && outpoint.nout === signingChannel.nout) ||
|
|
|
|
(outpoint.txid === claim.txid && outpoint.nout === claim.nout)
|
|
|
|
);
|
2019-06-09 00:57:51 -06:00
|
|
|
return blackListed;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-21 00:04:02 -06:00
|
|
|
resolve = (props: Props) => {
|
|
|
|
const { isResolvingUri, resolveUri, claim, uri } = props;
|
2019-06-09 00:57:51 -06:00
|
|
|
|
2019-06-21 00:04:02 -06:00
|
|
|
if (!isResolvingUri && claim === undefined && uri) {
|
2019-06-09 00:57:51 -06:00
|
|
|
resolveUri(uri);
|
|
|
|
}
|
2019-06-21 00:04:02 -06:00
|
|
|
};
|
2019-06-09 00:57:51 -06:00
|
|
|
|
|
|
|
render() {
|
2019-06-24 10:56:37 -06:00
|
|
|
const { uri, claim, title, className, autoEmbed, children, isResolvingUri } = this.props;
|
2019-06-12 22:18:35 -06:00
|
|
|
const isUnresolved = (!isResolvingUri && !claim) || !claim;
|
|
|
|
const isBlacklisted = this.isClaimBlackListed();
|
|
|
|
|
|
|
|
if (isBlacklisted || isUnresolved) {
|
|
|
|
return <span>{children}</span>;
|
|
|
|
}
|
|
|
|
|
2019-10-14 17:05:19 -06:00
|
|
|
const { name: claimName, value_type: valueType } = claim;
|
|
|
|
const isChannel = valueType === 'channel';
|
2019-06-12 22:18:35 -06:00
|
|
|
const showPreview = autoEmbed === true && !isUnresolved;
|
2019-06-20 14:59:01 -06:00
|
|
|
|
2019-10-14 17:05:19 -06:00
|
|
|
if(isChannel){
|
|
|
|
return <UriIndicator uri={uri} link addTooltip />
|
|
|
|
}
|
|
|
|
|
2019-06-09 00:57:51 -06:00
|
|
|
return (
|
|
|
|
<React.Fragment>
|
2019-06-24 10:56:37 -06:00
|
|
|
<Button label={children} title={title || claimName} button={'link'} navigate={uri} className={className} />
|
2019-06-12 20:26:40 -06:00
|
|
|
{showPreview && <PreviewLink uri={uri} />}
|
2019-06-09 00:57:51 -06:00
|
|
|
</React.Fragment>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ClaimLink;
|