Revert "improve channel update" #4406
13 changed files with 2015 additions and 3384 deletions
|
@ -135,7 +135,7 @@
|
||||||
"imagesloaded": "^4.1.4",
|
"imagesloaded": "^4.1.4",
|
||||||
"json-loader": "^0.5.4",
|
"json-loader": "^0.5.4",
|
||||||
"lbry-format": "https://github.com/lbryio/lbry-format.git",
|
"lbry-format": "https://github.com/lbryio/lbry-format.git",
|
||||||
"lbry-redux": "lbryio/lbry-redux#d00744a8b5474f28553ed8b68ee5400a4ad84b4c",
|
"lbry-redux": "lbryio/lbry-redux#f8ac5359d9d05fba2c3a536003a9d4c64b86c9f0",
|
||||||
"lbryinc": "lbryio/lbryinc#72eee35f5181940eb4a468a27ddb2a2a4e362fb0",
|
"lbryinc": "lbryio/lbryinc#72eee35f5181940eb4a468a27ddb2a2a4e362fb0",
|
||||||
"lint-staged": "^7.0.2",
|
"lint-staged": "^7.0.2",
|
||||||
"localforage": "^1.7.1",
|
"localforage": "^1.7.1",
|
||||||
|
|
|
@ -1199,8 +1199,15 @@
|
||||||
"lbry.tv Premium - 1 month": "lbry.tv Premium - 1 month",
|
"lbry.tv Premium - 1 month": "lbry.tv Premium - 1 month",
|
||||||
"We will refund no questions asked within 30 days.": "We will refund no questions asked within 30 days.",
|
"We will refund no questions asked within 30 days.": "We will refund no questions asked within 30 days.",
|
||||||
"Your Wallet": "Your Wallet",
|
"Your Wallet": "Your Wallet",
|
||||||
|
"Buy": "Buy",
|
||||||
|
"Buy LBRY Credits": "Buy LBRY Credits",
|
||||||
|
"Country": "Country",
|
||||||
|
"Only some countries are eligible at this time. We are working to make this available to everyone.": "Only some countries are eligible at this time. We are working to make this available to everyone.",
|
||||||
|
"Select your country": "Select your country",
|
||||||
|
"LBRY, Inc. partners with Moonpay to provide the option to purchase LBC. %learn_more%.": "LBRY, Inc. partners with Moonpay to provide the option to purchase LBC. %learn_more%.",
|
||||||
"Try Anyway": "Try Anyway",
|
"Try Anyway": "Try Anyway",
|
||||||
"Purchase Amount": "Purchase Amount",
|
"Purchase Amount": "Purchase Amount",
|
||||||
|
"Your browser does not support iframes.": "Your browser does not support iframes.",
|
||||||
"Not a valid LBRY address": "Not a valid LBRY address",
|
"Not a valid LBRY address": "Not a valid LBRY address",
|
||||||
"Confirm Tip": "Confirm Tip",
|
"Confirm Tip": "Confirm Tip",
|
||||||
"Supporting": "Supporting",
|
"Supporting": "Supporting",
|
||||||
|
@ -1223,14 +1230,6 @@
|
||||||
"Sharing information with LBRY, Inc. allows us to report to publishers how their content is doing, as\n well as track basic usage and performance. This is the minimum required to earn rewards from LBRY, Inc.": "Sharing information with LBRY, Inc. allows us to report to publishers how their content is doing, as\n well as track basic usage and performance. This is the minimum required to earn rewards from LBRY, Inc.",
|
"Sharing information with LBRY, Inc. allows us to report to publishers how their content is doing, as\n well as track basic usage and performance. This is the minimum required to earn rewards from LBRY, Inc.": "Sharing information with LBRY, Inc. allows us to report to publishers how their content is doing, as\n well as track basic usage and performance. This is the minimum required to earn rewards from LBRY, Inc.",
|
||||||
"No information will be sent directly to LBRY, Inc. or third-parties about your usage. Note that as\n peer-to-peer software, your IP address and potentially other system information can be sent to other\n users, though this information is not stored permanently.": "No information will be sent directly to LBRY, Inc. or third-parties about your usage. Note that as\n peer-to-peer software, your IP address and potentially other system information can be sent to other\n users, though this information is not stored permanently.",
|
"No information will be sent directly to LBRY, Inc. or third-parties about your usage. Note that as\n peer-to-peer software, your IP address and potentially other system information can be sent to other\n users, though this information is not stored permanently.": "No information will be sent directly to LBRY, Inc. or third-parties about your usage. Note that as\n peer-to-peer software, your IP address and potentially other system information can be sent to other\n users, though this information is not stored permanently.",
|
||||||
"%view_count% Views": "%view_count% Views",
|
"%view_count% Views": "%view_count% Views",
|
||||||
"Buy": "Buy",
|
|
||||||
"Buy LBRY Credits": "Buy LBRY Credits",
|
|
||||||
"Country": "Country",
|
|
||||||
"Only some countries are eligible at this time. We are working to make this available to everyone.": "Only some countries are eligible at this time. We are working to make this available to everyone.",
|
|
||||||
"Select your country": "Select your country",
|
|
||||||
"LBRY, Inc. partners with Moonpay to provide the option to purchase LBC. %learn_more%.": "LBRY, Inc. partners with Moonpay to provide the option to purchase LBC. %learn_more%.",
|
|
||||||
"Your browser does not support iframes.": "Your browser does not support iframes.",
|
|
||||||
"There was an error. Try %refreshing_the_app_link% to fix it. If that doesn't work, try pressing Ctrl+R/Cmd+R.": "There was an error. Try %refreshing_the_app_link% to fix it. If that doesn't work, try pressing Ctrl+R/Cmd+R.",
|
|
||||||
"Tap to unmute": "Tap to unmute",
|
"Tap to unmute": "Tap to unmute",
|
||||||
"0 Bytes": "0 Bytes",
|
"0 Bytes": "0 Bytes",
|
||||||
"Bytes": "Bytes",
|
"Bytes": "Bytes",
|
||||||
|
@ -1242,8 +1241,11 @@
|
||||||
"EB": "EB",
|
"EB": "EB",
|
||||||
"ZB": "ZB",
|
"ZB": "ZB",
|
||||||
"YB": "YB",
|
"YB": "YB",
|
||||||
|
"Save": "Save",
|
||||||
|
"Saving...": "Saving...",
|
||||||
"Thanks for the feedback! You help make the app better for everyone.": "Thanks for the feedback! You help make the app better for everyone.",
|
"Thanks for the feedback! You help make the app better for everyone.": "Thanks for the feedback! You help make the app better for everyone.",
|
||||||
"Thanks for the feedback. Mark has been notified and is currently walking over to his computer to work on this.": "Thanks for the feedback. Mark has been notified and is currently walking over to his computer to work on this.",
|
"Thanks for the feedback. Mark has been notified and is currently walking over to his computer to work on this.": "Thanks for the feedback. Mark has been notified and is currently walking over to his computer to work on this.",
|
||||||
|
"Changelog": "Changelog",
|
||||||
"Supporting Content Requires LBC": "Supporting Content Requires LBC",
|
"Supporting Content Requires LBC": "Supporting Content Requires LBC",
|
||||||
"With LBC, you can send tips to your favorite creators, or help boost their content for more people to see.": "With LBC, you can send tips to your favorite creators, or help boost their content for more people to see.",
|
"With LBC, you can send tips to your favorite creators, or help boost their content for more people to see.": "With LBC, you can send tips to your favorite creators, or help boost their content for more people to see.",
|
||||||
"Boost Your Content": "Boost Your Content",
|
"Boost Your Content": "Boost Your Content",
|
||||||
|
@ -1255,11 +1257,5 @@
|
||||||
"Make this support permanent": "Make this support permanent",
|
"Make this support permanent": "Make this support permanent",
|
||||||
"Custom support amount": "Custom support amount",
|
"Custom support amount": "Custom support amount",
|
||||||
"(%lbc_balance% available)": "(%lbc_balance% available)",
|
"(%lbc_balance% available)": "(%lbc_balance% available)",
|
||||||
"Loading your channels...": "Loading your channels...",
|
"Loading your channels...": "Loading your channels..."
|
||||||
"Changelog": "Changelog",
|
|
||||||
"Thumbnail source": "Thumbnail source",
|
|
||||||
"Cover source": "Cover source",
|
|
||||||
"Save": "Save",
|
|
||||||
"Saving...": "Saving...",
|
|
||||||
"Your changes will be live in a few minutes": "Your changes will be live in a few minutes"
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,6 @@ function ChannelAbout(props: Props) {
|
||||||
<div className="card">
|
<div className="card">
|
||||||
<section className="section card--section">
|
<section className="section card--section">
|
||||||
<Fragment>
|
<Fragment>
|
||||||
<label>{__('Description')}</label>
|
|
||||||
{description && (
|
{description && (
|
||||||
<div className="media__info-text media__info-text--constrained">
|
<div className="media__info-text media__info-text--constrained">
|
||||||
<MarkdownPreview content={description} />
|
<MarkdownPreview content={description} />
|
||||||
|
|
|
@ -8,7 +8,6 @@ import {
|
||||||
doUpdateChannel,
|
doUpdateChannel,
|
||||||
makeSelectAmountForUri,
|
makeSelectAmountForUri,
|
||||||
makeSelectClaimForUri,
|
makeSelectClaimForUri,
|
||||||
selectUpdateChannelError,
|
|
||||||
} from 'lbry-redux';
|
} from 'lbry-redux';
|
||||||
import ChannelPage from './view';
|
import ChannelPage from './view';
|
||||||
|
|
||||||
|
@ -25,7 +24,6 @@ const select = (state, props) => ({
|
||||||
languages: makeSelectMetadataItemForUri(props.uri, 'languages')(state),
|
languages: makeSelectMetadataItemForUri(props.uri, 'languages')(state),
|
||||||
amount: makeSelectAmountForUri(props.uri)(state),
|
amount: makeSelectAmountForUri(props.uri)(state),
|
||||||
claim: makeSelectClaimForUri(props.uri)(state),
|
claim: makeSelectClaimForUri(props.uri)(state),
|
||||||
updateError: selectUpdateChannelError(state),
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const perform = dispatch => ({
|
const perform = dispatch => ({
|
||||||
|
|
|
@ -3,10 +3,10 @@ import React, { useState } from 'react';
|
||||||
import { FormField } from 'component/common/form';
|
import { FormField } from 'component/common/form';
|
||||||
import Button from 'component/button';
|
import Button from 'component/button';
|
||||||
import SelectAsset from 'component/selectAsset';
|
import SelectAsset from 'component/selectAsset';
|
||||||
|
import * as PAGES from 'constants/pages';
|
||||||
import { MINIMUM_PUBLISH_BID } from 'constants/claim';
|
import { MINIMUM_PUBLISH_BID } from 'constants/claim';
|
||||||
import TagsSearch from 'component/tagsSearch';
|
import TagsSearch from 'component/tagsSearch';
|
||||||
import { FF_MAX_CHARS_IN_DESCRIPTION } from 'constants/form-field';
|
import { FF_MAX_CHARS_IN_DESCRIPTION } from 'constants/form-field';
|
||||||
import ErrorText from 'component/common/error-text';
|
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
claim: ChannelClaim,
|
claim: ChannelClaim,
|
||||||
|
@ -22,11 +22,10 @@ type Props = {
|
||||||
tags: Array<string>,
|
tags: Array<string>,
|
||||||
locations: Array<string>,
|
locations: Array<string>,
|
||||||
languages: Array<string>,
|
languages: Array<string>,
|
||||||
updateChannel: any => Promise<any>,
|
updateChannel: any => void,
|
||||||
updateThumb: string => void,
|
updateThumb: string => void,
|
||||||
updateCover: string => void,
|
updateCover: string => void,
|
||||||
doneEditing: () => void,
|
setEditing: boolean => void,
|
||||||
updateError: string,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
function ChannelForm(props: Props) {
|
function ChannelForm(props: Props) {
|
||||||
|
@ -42,11 +41,10 @@ function ChannelForm(props: Props) {
|
||||||
locations,
|
locations,
|
||||||
languages,
|
languages,
|
||||||
amount,
|
amount,
|
||||||
doneEditing,
|
setEditing,
|
||||||
updateChannel,
|
updateChannel,
|
||||||
updateThumb,
|
updateThumb,
|
||||||
updateCover,
|
updateCover,
|
||||||
updateError,
|
|
||||||
} = props;
|
} = props;
|
||||||
const { claim_id: claimId } = claim;
|
const { claim_id: claimId } = claim;
|
||||||
|
|
||||||
|
@ -103,17 +101,13 @@ function ChannelForm(props: Props) {
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleSubmit = () => {
|
const handleSubmit = () => {
|
||||||
updateChannel(params).then(success => {
|
updateChannel(params);
|
||||||
if (success) {
|
setEditing(false);
|
||||||
doneEditing();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// TODO clear and bail after submit
|
// TODO clear and bail after submit
|
||||||
return (
|
return (
|
||||||
<div className="card">
|
<section className={'card--section'}>
|
||||||
<section className={'section card--section'}>
|
|
||||||
<SelectAsset
|
<SelectAsset
|
||||||
onUpdate={v => handleThumbnailChange(v)}
|
onUpdate={v => handleThumbnailChange(v)}
|
||||||
currentValue={params.thumbnailUrl}
|
currentValue={params.thumbnailUrl}
|
||||||
|
@ -205,17 +199,12 @@ function ChannelForm(props: Props) {
|
||||||
/>
|
/>
|
||||||
<div className={'section__actions'}>
|
<div className={'section__actions'}>
|
||||||
<Button button="primary" label={__('Submit')} onClick={handleSubmit} />
|
<Button button="primary" label={__('Submit')} onClick={handleSubmit} />
|
||||||
<Button button="link" label={__('Cancel')} onClick={doneEditing} />
|
<Button button="link" label={__('Cancel')} navigate={`$/${PAGES.CHANNELS}`} />
|
||||||
</div>
|
</div>
|
||||||
{updateError && updateError.length ? (
|
|
||||||
<ErrorText>{updateError}</ErrorText>
|
|
||||||
) : (
|
|
||||||
<p className="help">
|
<p className="help">
|
||||||
{__('After submitting, you will not see the changes immediately. Please check back in a few minutes.')}
|
{__('After submitting, you will not see the changes immediately. Please check back in a few minutes.')}
|
||||||
</p>
|
</p>
|
||||||
)}
|
|
||||||
</section>
|
</section>
|
||||||
</div>
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,15 +8,14 @@ type Props = {
|
||||||
doOpenModal: (string, {}) => void,
|
doOpenModal: (string, {}) => void,
|
||||||
claim: StreamClaim,
|
claim: StreamClaim,
|
||||||
abandonActionCallback: any => void,
|
abandonActionCallback: any => void,
|
||||||
iconSize: number,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function ClaimAbandonButton(props: Props) {
|
export default function ClaimAbandonButton(props: Props) {
|
||||||
const { doOpenModal, claim, abandonActionCallback, iconSize } = props;
|
const { doOpenModal, claim, abandonActionCallback } = props;
|
||||||
|
|
||||||
function abandonClaim() {
|
function abandonClaim() {
|
||||||
doOpenModal(MODALS.CONFIRM_CLAIM_REVOKE, { claim: claim, cb: abandonActionCallback });
|
doOpenModal(MODALS.CONFIRM_CLAIM_REVOKE, { claim: claim, cb: abandonActionCallback });
|
||||||
}
|
}
|
||||||
|
|
||||||
return <Button disabled={!claim} button="alt" iconSize={iconSize} icon={ICONS.DELETE} onClick={abandonClaim} />;
|
return <Button button="secondary" icon={ICONS.DELETE} onClick={abandonClaim} />;
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,7 @@ function ClaimPreviewTile(props: Props) {
|
||||||
const isRepost = claim && claim.repost_channel_url;
|
const isRepost = claim && claim.repost_channel_url;
|
||||||
const shouldFetch = claim === undefined;
|
const shouldFetch = claim === undefined;
|
||||||
const thumbnailUrl = useGetThumbnail(uri, claim, streamingUrl, getFile, placeholder) || thumbnail;
|
const thumbnailUrl = useGetThumbnail(uri, claim, streamingUrl, getFile, placeholder) || thumbnail;
|
||||||
const claimsInChannel = (claim && claim.meta && claim.meta.claims_in_channel) || 0;
|
const claimsInChannel = (claim && claim.meta.claims_in_channel) || 0;
|
||||||
const canonicalUrl = claim && claim.canonical_url;
|
const canonicalUrl = claim && claim.canonical_url;
|
||||||
const navigateUrl = formatLbryUrlForWeb(canonicalUrl || uri || '/');
|
const navigateUrl = formatLbryUrlForWeb(canonicalUrl || uri || '/');
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@ import {
|
||||||
selectCurrentChannelPage,
|
selectCurrentChannelPage,
|
||||||
makeSelectClaimForUri,
|
makeSelectClaimForUri,
|
||||||
selectChannelIsBlocked,
|
selectChannelIsBlocked,
|
||||||
makeSelectClaimIsPending,
|
|
||||||
} from 'lbry-redux';
|
} from 'lbry-redux';
|
||||||
import { selectBlackListedOutpoints, doFetchSubCount, makeSelectSubCountForUri } from 'lbryinc';
|
import { selectBlackListedOutpoints, doFetchSubCount, makeSelectSubCountForUri } from 'lbryinc';
|
||||||
import { makeSelectIsSubscribed } from 'redux/selectors/subscriptions';
|
import { makeSelectIsSubscribed } from 'redux/selectors/subscriptions';
|
||||||
|
@ -24,7 +23,6 @@ const select = (state, props) => ({
|
||||||
channelIsBlocked: selectChannelIsBlocked(props.uri)(state),
|
channelIsBlocked: selectChannelIsBlocked(props.uri)(state),
|
||||||
blackListedOutpoints: selectBlackListedOutpoints(state),
|
blackListedOutpoints: selectBlackListedOutpoints(state),
|
||||||
subCount: makeSelectSubCountForUri(props.uri)(state),
|
subCount: makeSelectSubCountForUri(props.uri)(state),
|
||||||
pending: makeSelectClaimIsPending(props.uri)(state),
|
|
||||||
});
|
});
|
||||||
|
|
||||||
const perform = dispatch => ({
|
const perform = dispatch => ({
|
||||||
|
|
|
@ -46,7 +46,6 @@ type Props = {
|
||||||
}>,
|
}>,
|
||||||
fetchSubCount: string => void,
|
fetchSubCount: string => void,
|
||||||
subCount: number,
|
subCount: number,
|
||||||
pending: boolean,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
function ChannelPage(props: Props) {
|
function ChannelPage(props: Props) {
|
||||||
|
@ -65,7 +64,6 @@ function ChannelPage(props: Props) {
|
||||||
blackListedOutpoints,
|
blackListedOutpoints,
|
||||||
fetchSubCount,
|
fetchSubCount,
|
||||||
subCount,
|
subCount,
|
||||||
pending,
|
|
||||||
} = props;
|
} = props;
|
||||||
|
|
||||||
const { channelName } = parseURI(uri);
|
const { channelName } = parseURI(uri);
|
||||||
|
@ -100,12 +98,6 @@ function ChannelPage(props: Props) {
|
||||||
history.push(`${url}${search}`);
|
history.push(`${url}${search}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
function doneEditing() {
|
|
||||||
setEditing(false);
|
|
||||||
setThumbPreview(thumbnail);
|
|
||||||
setCoverPreview(cover);
|
|
||||||
}
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
Lbryio.call('yt', 'get_youtuber', { channel_claim_id: claimId }).then(response => {
|
Lbryio.call('yt', 'get_youtuber', { channel_claim_id: claimId }).then(response => {
|
||||||
if (response.is_verified_youtuber) {
|
if (response.is_verified_youtuber) {
|
||||||
|
@ -184,28 +176,12 @@ function ChannelPage(props: Props) {
|
||||||
<HelpLink href="https://lbry.com/faq/views" />
|
<HelpLink href="https://lbry.com/faq/views" />
|
||||||
</span>
|
</span>
|
||||||
{channelIsMine && !editing && (
|
{channelIsMine && !editing && (
|
||||||
<>
|
|
||||||
{pending ? (
|
|
||||||
<span>{__('Your changes will be live in a few minutes')}</span>
|
|
||||||
) : (
|
|
||||||
<Button
|
<Button
|
||||||
button="alt"
|
button="alt"
|
||||||
title={__('Edit')}
|
title={__('Edit')}
|
||||||
onClick={() => setEditing(!editing)}
|
onClick={() => setEditing(!editing)}
|
||||||
icon={ICONS.EDIT}
|
icon={ICONS.EDIT}
|
||||||
iconSize={18}
|
iconSize={18}
|
||||||
disabled={pending}
|
|
||||||
/>
|
|
||||||
)}
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
{channelIsMine && editing && (
|
|
||||||
<Button
|
|
||||||
button="alt"
|
|
||||||
title={__('Cancel')}
|
|
||||||
onClick={() => doneEditing()}
|
|
||||||
icon={ICONS.REMOVE}
|
|
||||||
iconSize={18}
|
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
|
@ -227,7 +203,7 @@ function ChannelPage(props: Props) {
|
||||||
{editing ? (
|
{editing ? (
|
||||||
<ChannelEdit
|
<ChannelEdit
|
||||||
uri={uri}
|
uri={uri}
|
||||||
doneEditing={doneEditing}
|
setEditing={setEditing}
|
||||||
updateThumb={v => setThumbPreview(v)}
|
updateThumb={v => setThumbPreview(v)}
|
||||||
updateCover={v => setCoverPreview(v)}
|
updateCover={v => setCoverPreview(v)}
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -1,16 +1,10 @@
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import {
|
import { selectMyChannelClaims, doFetchChannelListMine, selectFetchingMyChannels } from 'lbry-redux';
|
||||||
selectMyChannelClaims,
|
|
||||||
selectMyChannelUrls,
|
|
||||||
doFetchChannelListMine,
|
|
||||||
selectFetchingMyChannels,
|
|
||||||
} from 'lbry-redux';
|
|
||||||
import { selectYoutubeChannels } from 'redux/selectors/user';
|
import { selectYoutubeChannels } from 'redux/selectors/user';
|
||||||
import { doOpenModal } from 'redux/actions/app';
|
import { doOpenModal } from 'redux/actions/app';
|
||||||
import ChannelsPage from './view';
|
import ChannelsPage from './view';
|
||||||
|
|
||||||
const select = state => ({
|
const select = state => ({
|
||||||
channelUrls: selectMyChannelUrls(state),
|
|
||||||
channels: selectMyChannelClaims(state),
|
channels: selectMyChannelClaims(state),
|
||||||
fetchingChannels: selectFetchingMyChannels(state),
|
fetchingChannels: selectFetchingMyChannels(state),
|
||||||
youtubeChannels: selectYoutubeChannels(state),
|
youtubeChannels: selectYoutubeChannels(state),
|
||||||
|
|
|
@ -11,7 +11,6 @@ import Card from 'component/common/card';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
channels: Array<ChannelClaim>,
|
channels: Array<ChannelClaim>,
|
||||||
channelUrls: Array<string>,
|
|
||||||
fetchChannelListMine: () => void,
|
fetchChannelListMine: () => void,
|
||||||
fetchingChannels: boolean,
|
fetchingChannels: boolean,
|
||||||
youtubeChannels: ?Array<any>,
|
youtubeChannels: ?Array<any>,
|
||||||
|
@ -19,19 +18,30 @@ type Props = {
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function ChannelsPage(props: Props) {
|
export default function ChannelsPage(props: Props) {
|
||||||
const { channels, channelUrls, fetchChannelListMine, fetchingChannels, youtubeChannels, openModal } = props;
|
const { channels, fetchChannelListMine, fetchingChannels, youtubeChannels, openModal } = props;
|
||||||
const hasYoutubeChannels = youtubeChannels && Boolean(youtubeChannels.length);
|
const hasYoutubeChannels = youtubeChannels && Boolean(youtubeChannels.length);
|
||||||
const hasPendingChannels = channels && channels.some(channel => channel.confirmations < 0);
|
const hasPendingChannels = channels && channels.some(channel => channel.confirmations < 0);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
fetchChannelListMine();
|
fetchChannelListMine();
|
||||||
|
|
||||||
|
let interval;
|
||||||
|
if (hasPendingChannels) {
|
||||||
|
interval = setInterval(() => {
|
||||||
|
fetchChannelListMine();
|
||||||
|
}, 5000);
|
||||||
|
}
|
||||||
|
|
||||||
|
return () => {
|
||||||
|
clearInterval(interval);
|
||||||
|
};
|
||||||
}, [fetchChannelListMine, hasPendingChannels]);
|
}, [fetchChannelListMine, hasPendingChannels]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Page>
|
<Page>
|
||||||
{hasYoutubeChannels && <YoutubeTransferStatus hideChannelLink />}
|
{hasYoutubeChannels && <YoutubeTransferStatus hideChannelLink />}
|
||||||
|
|
||||||
{channelUrls && Boolean(channelUrls.length) && (
|
{channels && Boolean(channels.length) && (
|
||||||
<Card
|
<Card
|
||||||
title={__('Your Channels')}
|
title={__('Your Channels')}
|
||||||
titleActions={
|
titleActions={
|
||||||
|
@ -43,10 +53,12 @@ export default function ChannelsPage(props: Props) {
|
||||||
/>
|
/>
|
||||||
}
|
}
|
||||||
isBodyList
|
isBodyList
|
||||||
body={<ClaimList isCardBody loading={fetchingChannels} uris={channelUrls} />}
|
body={
|
||||||
|
<ClaimList isCardBody loading={fetchingChannels} uris={channels.map(channel => channel.permanent_url)} />
|
||||||
|
}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
{!(channelUrls && channelUrls.length) && (
|
{!(channels && channels.length) && (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
{!fetchingChannels ? (
|
{!fetchingChannels ? (
|
||||||
<section className="main--empty">
|
<section className="main--empty">
|
||||||
|
|
|
@ -6,7 +6,7 @@ import {
|
||||||
batchActions,
|
batchActions,
|
||||||
selectMyClaims,
|
selectMyClaims,
|
||||||
doPublish,
|
doPublish,
|
||||||
doCheckPendingClaims,
|
doCheckPendingPublishes,
|
||||||
doCheckReflectingFiles,
|
doCheckReflectingFiles,
|
||||||
ACTIONS as LBRY_REDUX_ACTIONS,
|
ACTIONS as LBRY_REDUX_ACTIONS,
|
||||||
} from 'lbry-redux';
|
} from 'lbry-redux';
|
||||||
|
@ -101,5 +101,5 @@ export const doCheckPendingPublishesApp = () => (dispatch: Dispatch, getState: G
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
return dispatch(doCheckPendingClaims(onConfirmed));
|
return dispatch(doCheckPendingPublishes(onConfirmed));
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Reference in a new issue