// @flow import * as PAGES from 'constants/pages'; import React, { useEffect } from 'react'; import { useParams } from 'react-router'; import Button from 'component/button'; import ClaimPreview from 'component/claimPreview'; import Card from 'component/common/card'; import { parseURI } from 'lbry-redux'; import { rewards as REWARDS, ERRORS } from 'lbryinc'; type Props = { user: any, fetchUser: () => void, claimReward: () => void, setReferrer: string => void, referrerSetPending: boolean, referrerSetError: string, channelSubscribe: (sub: Subscription) => void, history: { push: string => void }, rewards: Array, }; function Invited(props: Props) { const { user, fetchUser, claimReward, setReferrer, referrerSetPending, referrerSetError, channelSubscribe, history, rewards, } = props; // useParams requires react-router-dom ^v5.1.0 const { referrer } = useParams(); const refUri = 'lbry://' + referrer.replace(':', '#'); const referrerIsChannel = parseURI(refUri).isChannel; const rewardsApproved = user && user.is_reward_approved; const hasVerifiedEmail = user && user.has_verified_email; const referredRewardAvailable = rewards && rewards.some(reward => reward.reward_type === REWARDS.TYPE_REFEREE); useEffect(() => { fetchUser(); }, []); useEffect(() => { if (!referrerSetPending && hasVerifiedEmail) { claimReward(); } }, [referrerSetPending, hasVerifiedEmail]); useEffect(() => { if (referrer) { setReferrer(referrer.replace(':', '#')); } }, [referrer]); // if they land here due to a referrer but already claimed, make them follow anyway useEffect(() => { if (!referredRewardAvailable && referrerIsChannel) { channelSubscribe({ channelName: parseURI(refUri).claimName, uri: refUri, }); } }, [referredRewardAvailable, referrerIsChannel]); function handleDone() { if (hasVerifiedEmail && referrerIsChannel) { channelSubscribe({ channelName: parseURI(refUri).claimName, uri: refUri, }); } history.push(`/$/${PAGES.DISCOVER}`); } if (referrerSetError === ERRORS.ALREADY_CLAIMED) { return ( {referrerIsChannel && (
)}
} /> ); } if (referrerSetError && referredRewardAvailable) { return (

{__('Not a valid referral')}

} /> ); } if (!rewardsApproved) { return ( {referrerIsChannel && (
)}
} /> ); } return ( {referrerIsChannel && (
)}
} /> ); } export default Invited;