2020-02-26 19:39:03 +01:00
|
|
|
// @flow
|
2020-03-12 02:43:52 +01:00
|
|
|
import React, { useEffect } from 'react';
|
2020-02-26 19:39:03 +01:00
|
|
|
import ClaimListDiscover from 'component/claimListDiscover';
|
2020-02-10 20:43:24 +01:00
|
|
|
import * as CS from 'constants/claim_search';
|
2020-02-26 19:39:03 +01:00
|
|
|
import Nag from 'component/common/nag';
|
2021-10-08 05:47:39 +02:00
|
|
|
import { parseURI } from 'util/lbryURI';
|
2020-03-12 02:43:52 +01:00
|
|
|
import Button from 'component/button';
|
2020-04-13 21:16:07 +02:00
|
|
|
import Card from 'component/common/card';
|
2021-10-19 01:37:58 +02:00
|
|
|
import { AUTO_FOLLOW_CHANNELS, CUSTOM_HOMEPAGE, SITE_NAME } from 'config';
|
2020-02-26 19:39:03 +01:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
subscribedChannels: Array<Subscription>,
|
|
|
|
onContinue: () => void,
|
2020-03-12 02:43:52 +01:00
|
|
|
channelSubscribe: (sub: Subscription) => void,
|
2020-11-10 17:07:00 +01:00
|
|
|
homepageData: any,
|
2021-04-25 07:31:19 +02:00
|
|
|
prefsReady: boolean,
|
2020-02-26 19:39:03 +01:00
|
|
|
};
|
|
|
|
|
2020-09-21 19:28:18 +02:00
|
|
|
const channelsToSubscribe = AUTO_FOLLOW_CHANNELS.trim()
|
|
|
|
.split(' ')
|
2021-04-25 07:31:19 +02:00
|
|
|
.filter((x) => x !== '');
|
2020-05-26 23:49:01 +02:00
|
|
|
|
2020-02-26 19:39:03 +01:00
|
|
|
function UserChannelFollowIntro(props: Props) {
|
2021-07-23 05:51:29 +02:00
|
|
|
const { subscribedChannels, channelSubscribe, onContinue, homepageData, prefsReady } = props;
|
2021-09-29 21:22:46 +02:00
|
|
|
const { PRIMARY_CONTENT, LATEST } = homepageData;
|
2021-07-17 00:20:22 +02:00
|
|
|
let channelIds;
|
2021-09-29 21:22:46 +02:00
|
|
|
if (CUSTOM_HOMEPAGE) {
|
|
|
|
if (LATEST) {
|
|
|
|
channelIds = LATEST.channelIds;
|
|
|
|
} else if (PRIMARY_CONTENT) {
|
|
|
|
channelIds = PRIMARY_CONTENT.channelIds;
|
|
|
|
}
|
2021-07-17 00:20:22 +02:00
|
|
|
}
|
2020-02-26 19:39:03 +01:00
|
|
|
const followingCount = (subscribedChannels && subscribedChannels.length) || 0;
|
2021-08-11 04:35:25 +02:00
|
|
|
const followingCountIgnoringAutoFollows = (subscribedChannels || []).filter(
|
|
|
|
(channel) => !channelsToSubscribe.includes(channel.uri)
|
|
|
|
).length;
|
2020-02-26 19:39:03 +01:00
|
|
|
|
2020-03-12 02:43:52 +01:00
|
|
|
// subscribe to lbry
|
|
|
|
useEffect(() => {
|
2021-04-25 07:31:19 +02:00
|
|
|
if (channelsToSubscribe && channelsToSubscribe.length && prefsReady) {
|
|
|
|
const delayedChannelSubscribe = () => {
|
2021-10-13 19:34:23 +02:00
|
|
|
channelsToSubscribe.forEach((c) => {
|
|
|
|
let claimName;
|
|
|
|
try {
|
|
|
|
const { claimName: name } = parseURI(c);
|
|
|
|
claimName = name;
|
|
|
|
} catch (e) {}
|
|
|
|
if (claimName) {
|
|
|
|
channelSubscribe({
|
|
|
|
channelName: claimName,
|
|
|
|
uri: c,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2021-04-25 07:31:19 +02:00
|
|
|
};
|
|
|
|
setTimeout(delayedChannelSubscribe, 1000);
|
2020-08-26 23:00:10 +02:00
|
|
|
}
|
2021-04-25 07:31:19 +02:00
|
|
|
}, [prefsReady]);
|
2020-03-12 02:43:52 +01:00
|
|
|
|
2020-02-26 19:39:03 +01:00
|
|
|
return (
|
2020-04-13 21:16:07 +02:00
|
|
|
<Card
|
2020-08-26 22:28:33 +02:00
|
|
|
title={__('Find channels to follow')}
|
2020-04-13 21:16:07 +02:00
|
|
|
subtitle={__(
|
2021-07-23 05:51:29 +02:00
|
|
|
'%SITE_NAME% works better if you find and follow a couple creators you like. You can also block channels you never want to see.',
|
|
|
|
{ SITE_NAME }
|
2020-04-13 21:16:07 +02:00
|
|
|
)}
|
|
|
|
actions={
|
|
|
|
<React.Fragment>
|
|
|
|
<div className="section__body">
|
|
|
|
<ClaimListDiscover
|
2021-07-23 05:51:29 +02:00
|
|
|
meta={
|
|
|
|
<Button
|
|
|
|
button={subscribedChannels.length < 1 ? 'alt' : 'primary'}
|
|
|
|
onClick={onContinue}
|
|
|
|
label={subscribedChannels.length < 1 ? __('Skip') : __('Continue')}
|
|
|
|
/>
|
|
|
|
}
|
2021-10-19 01:37:58 +02:00
|
|
|
defaultOrderBy={CS.ORDER_BY_TRENDING}
|
2020-04-13 21:16:07 +02:00
|
|
|
defaultFreshness={CS.FRESH_ALL}
|
|
|
|
claimType="channel"
|
2021-07-17 00:20:22 +02:00
|
|
|
claimIds={CUSTOM_HOMEPAGE && channelIds ? channelIds : undefined}
|
2020-09-15 16:23:00 +02:00
|
|
|
defaultTags={followingCount > 3 ? CS.TAGS_FOLLOWED : undefined}
|
2020-04-13 21:16:07 +02:00
|
|
|
/>
|
|
|
|
{followingCount > 0 && (
|
|
|
|
<Nag
|
|
|
|
type="helpful"
|
|
|
|
message={
|
2021-08-11 04:35:25 +02:00
|
|
|
followingCountIgnoringAutoFollows === 1
|
|
|
|
? __('Nice! You are currently following %followingCount% creator', {
|
|
|
|
followingCount: followingCountIgnoringAutoFollows,
|
|
|
|
})
|
|
|
|
: __('Nice! You are currently following %followingCount% creators', {
|
|
|
|
followingCount: followingCountIgnoringAutoFollows,
|
|
|
|
})
|
2020-04-13 21:16:07 +02:00
|
|
|
}
|
|
|
|
actionText={__('Continue')}
|
|
|
|
onClick={onContinue}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</React.Fragment>
|
|
|
|
}
|
|
|
|
/>
|
2020-02-26 19:39:03 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default UserChannelFollowIntro;
|