2020-02-26 13:39:03 -05:00
|
|
|
// @flow
|
2020-03-11 21:43:52 -04:00
|
|
|
import React, { useEffect } from 'react';
|
2020-02-26 13:39:03 -05:00
|
|
|
import ClaimListDiscover from 'component/claimListDiscover';
|
2020-02-10 14:43:24 -05:00
|
|
|
import * as CS from 'constants/claim_search';
|
2020-02-26 13:39:03 -05:00
|
|
|
import Nag from 'component/common/nag';
|
2020-03-11 21:43:52 -04:00
|
|
|
import { parseURI } from 'lbry-redux';
|
|
|
|
import Button from 'component/button';
|
2020-04-13 15:16:07 -04:00
|
|
|
import Card from 'component/common/card';
|
2020-02-26 13:39:03 -05:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
subscribedChannels: Array<Subscription>,
|
|
|
|
onContinue: () => void,
|
2020-03-11 21:43:52 -04:00
|
|
|
onBack: () => void,
|
|
|
|
channelSubscribe: (sub: Subscription) => void,
|
2020-02-26 13:39:03 -05:00
|
|
|
};
|
|
|
|
|
2020-05-26 17:49:01 -04:00
|
|
|
const LBRY_URI = 'lbry://@lbry#3fda836a92faaceedfe398225fb9b2ee2ed1f01a';
|
|
|
|
const LBRYCAST_URI = 'lbry://@lbrycast#4c29f8b013adea4d5cca1861fb2161d5089613ea';
|
|
|
|
|
2020-02-26 13:39:03 -05:00
|
|
|
function UserChannelFollowIntro(props: Props) {
|
2020-03-11 21:43:52 -04:00
|
|
|
const { subscribedChannels, channelSubscribe, onContinue, onBack } = props;
|
2020-02-26 13:39:03 -05:00
|
|
|
const followingCount = (subscribedChannels && subscribedChannels.length) || 0;
|
|
|
|
|
2020-03-11 21:43:52 -04:00
|
|
|
// subscribe to lbry
|
|
|
|
useEffect(() => {
|
|
|
|
channelSubscribe({
|
2020-05-26 17:49:01 -04:00
|
|
|
channelName: parseURI(LBRY_URI).claimName,
|
|
|
|
uri: LBRY_URI,
|
|
|
|
});
|
|
|
|
|
|
|
|
channelSubscribe({
|
|
|
|
channelName: parseURI(LBRYCAST_URI).claimName,
|
|
|
|
uri: LBRYCAST_URI,
|
2020-03-11 21:43:52 -04:00
|
|
|
});
|
|
|
|
}, []);
|
|
|
|
|
2020-02-26 13:39:03 -05:00
|
|
|
return (
|
2020-04-13 15:16:07 -04:00
|
|
|
<Card
|
|
|
|
title={__('Find Channels to Follow')}
|
|
|
|
subtitle={__(
|
|
|
|
'LBRY works better if you find and follow at least 5 creators you like. You can also block channels you never want to see.'
|
|
|
|
)}
|
|
|
|
actions={
|
|
|
|
<React.Fragment>
|
|
|
|
<div className="section__actions">
|
|
|
|
<Button button="secondary" onClick={onBack} label={__('Back')} />
|
|
|
|
<Button
|
|
|
|
button="primary"
|
|
|
|
type="Submit"
|
|
|
|
onClick={onContinue}
|
|
|
|
label={__('Continue')}
|
|
|
|
disabled={subscribedChannels.length < 2}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="section__body">
|
|
|
|
<ClaimListDiscover
|
|
|
|
defaultOrderBy={CS.ORDER_BY_TOP}
|
|
|
|
defaultFreshness={CS.FRESH_ALL}
|
|
|
|
claimType="channel"
|
|
|
|
defaultTags={CS.TAGS_FOLLOWED}
|
|
|
|
/>
|
|
|
|
{followingCount > 0 && (
|
|
|
|
<Nag
|
|
|
|
type="helpful"
|
|
|
|
message={
|
|
|
|
followingCount === 1
|
|
|
|
? __('Nice! You are currently following %followingCount% creator', { followingCount })
|
|
|
|
: __('Nice! You are currently following %followingCount% creators', { followingCount })
|
|
|
|
}
|
|
|
|
actionText={__('Continue')}
|
|
|
|
onClick={onContinue}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</React.Fragment>
|
|
|
|
}
|
|
|
|
/>
|
2020-02-26 13:39:03 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default UserChannelFollowIntro;
|