2018-09-12 12:42:15 -04:00
|
|
|
// @flow
|
2018-11-25 20:21:25 -05:00
|
|
|
import * as ICONS from 'constants/icons';
|
|
|
|
import React from 'react';
|
2018-09-12 12:42:15 -04:00
|
|
|
import Button from 'component/button';
|
2018-10-04 09:39:14 -04:00
|
|
|
import CopyableText from 'component/copyableText';
|
2019-12-30 14:54:53 -05:00
|
|
|
import EmbedTextArea from 'component/embedTextArea';
|
2018-09-12 12:42:15 -04:00
|
|
|
|
|
|
|
type Props = {
|
2019-06-28 03:33:07 -04:00
|
|
|
claim: Claim,
|
2019-10-29 12:23:56 -04:00
|
|
|
webShareable: boolean,
|
2018-11-09 10:34:48 -05:00
|
|
|
isChannel: boolean,
|
2020-01-14 15:44:07 -05:00
|
|
|
referralCode: string,
|
|
|
|
user: any,
|
2018-09-12 12:42:15 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
class SocialShare extends React.PureComponent<Props> {
|
2018-11-09 10:34:48 -05:00
|
|
|
static defaultProps = {
|
|
|
|
isChannel: false,
|
|
|
|
};
|
|
|
|
|
2018-09-12 12:42:15 -04:00
|
|
|
constructor(props: Props) {
|
|
|
|
super(props);
|
|
|
|
|
|
|
|
this.input = undefined;
|
|
|
|
}
|
|
|
|
|
|
|
|
input: ?HTMLInputElement;
|
|
|
|
|
|
|
|
render() {
|
2020-01-14 15:44:07 -05:00
|
|
|
const { claim, isChannel, referralCode, user } = this.props;
|
2019-09-20 10:54:43 -04:00
|
|
|
const { canonical_url: canonicalUrl, permanent_url: permanentUrl } = claim;
|
2019-11-22 16:13:00 -05:00
|
|
|
const { webShareable } = this.props;
|
2020-01-14 15:44:07 -05:00
|
|
|
const rewardsApproved = user && user.is_reward_approved;
|
2019-10-01 10:00:23 -04:00
|
|
|
const OPEN_URL = 'https://open.lbry.com/';
|
|
|
|
const lbryUrl = canonicalUrl ? canonicalUrl.split('lbry://')[1] : permanentUrl.split('lbry://')[1];
|
|
|
|
const lbryWebUrl = lbryUrl.replace(/#/g, ':');
|
|
|
|
const encodedLbryURL: string = `${OPEN_URL}${encodeURIComponent(lbryWebUrl)}`;
|
2020-01-14 15:44:07 -05:00
|
|
|
const referralParam: string = referralCode && rewardsApproved ? `?r=${referralCode}` : '';
|
|
|
|
const lbryURL: string = `${OPEN_URL}${lbryWebUrl}${referralParam}`;
|
2019-03-21 12:44:07 -04:00
|
|
|
|
2019-06-28 03:33:07 -04:00
|
|
|
const shareOnFb = __('Share on Facebook');
|
|
|
|
const shareOnTwitter = __('Share On Twitter');
|
2018-10-04 09:39:14 -04:00
|
|
|
|
2018-09-12 12:42:15 -04:00
|
|
|
return (
|
2019-01-14 13:40:06 -05:00
|
|
|
<React.Fragment>
|
2019-12-26 19:00:07 -05:00
|
|
|
<CopyableText label={__('LBRY Link')} copyable={lbryURL} noSnackbar />
|
2019-11-22 16:13:00 -05:00
|
|
|
<div className="">
|
2019-07-21 17:31:22 -04:00
|
|
|
<Button
|
|
|
|
icon={ICONS.FACEBOOK}
|
|
|
|
button="link"
|
|
|
|
description={shareOnFb}
|
|
|
|
href={`https://facebook.com/sharer/sharer.php?u=${encodedLbryURL}`}
|
2019-11-22 16:13:00 -05:00
|
|
|
/>{' '}
|
2019-07-21 17:31:22 -04:00
|
|
|
<Button
|
|
|
|
icon={ICONS.TWITTER}
|
|
|
|
button="link"
|
|
|
|
description={shareOnTwitter}
|
2019-07-23 16:16:37 -04:00
|
|
|
href={`https://twitter.com/intent/tweet?text=${encodedLbryURL}`}
|
2019-07-21 17:31:22 -04:00
|
|
|
/>
|
2018-09-26 13:48:07 -04:00
|
|
|
</div>
|
2019-12-30 14:54:53 -05:00
|
|
|
{webShareable && !isChannel && <EmbedTextArea label={__('Embedded')} claim={claim} noSnackbar />}
|
2019-01-14 13:40:06 -05:00
|
|
|
</React.Fragment>
|
2018-09-12 12:42:15 -04:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SocialShare;
|