From ef8bd5f986aa3e96c51d57fb839a81315c3a40cd Mon Sep 17 00:00:00 2001 From: 6ea86b96 <6ea86b96@gmail.com> Date: Thu, 29 Jun 2017 14:58:15 +0700 Subject: [PATCH] Cancel resolving URis when unmounting discover/file list pages --- ui/js/actions/content.js | 31 ++++++++++++++++++++++++++ ui/js/constants/action_types.js | 1 + ui/js/page/discover/index.js | 3 ++- ui/js/page/discover/view.jsx | 8 ++++++- ui/js/page/fileListDownloaded/index.js | 2 ++ ui/js/page/fileListDownloaded/view.jsx | 7 ++++-- ui/js/page/fileListPublished/index.js | 2 ++ ui/js/page/fileListPublished/view.jsx | 9 ++++++-- ui/js/reducers/content.js | 8 +++---- 9 files changed, 60 insertions(+), 11 deletions(-) diff --git a/ui/js/actions/content.js b/ui/js/actions/content.js index 0839518c8..b80f8fc0c 100644 --- a/ui/js/actions/content.js +++ b/ui/js/actions/content.js @@ -50,6 +50,37 @@ export function doResolveUri(uri) { }; } +export function doCancelResolveUri(uri) { + return function(dispatch, getState) { + uri = lbryuri.normalize(uri); + + const state = getState(); + const alreadyResolving = selectResolvingUris(state).indexOf(uri) !== -1; + + if (alreadyResolving) { + lbry.cancelResolve({ uri }); + dispatch({ + type: types.RESOLVE_URI_CANCELED, + data: { + uri, + }, + }); + } + }; +} + +export function doCancelAllResolvingUris() { + return function(dispatch, getState) { + const state = getState(); + const resolvingUris = selectResolvingUris(state); + const actions = []; + + resolvingUris.forEach(uri => actions.push(doCancelResolveUri(uri))); + + dispatch(batchActions(...actions)); + }; +} + export function doFetchFeaturedUris() { return function(dispatch, getState) { const state = getState(); diff --git a/ui/js/constants/action_types.js b/ui/js/constants/action_types.js index e622787e0..a66ae5874 100644 --- a/ui/js/constants/action_types.js +++ b/ui/js/constants/action_types.js @@ -40,6 +40,7 @@ export const FETCH_FEATURED_CONTENT_COMPLETED = "FETCH_FEATURED_CONTENT_COMPLETED"; export const RESOLVE_URI_STARTED = "RESOLVE_URI_STARTED"; export const RESOLVE_URI_COMPLETED = "RESOLVE_URI_COMPLETED"; +export const RESOLVE_URI_CANCELED = "RESOLVE_URI_CANCELED"; export const FETCH_CHANNEL_CLAIMS_STARTED = "FETCH_CHANNEL_CLAIMS_STARTED"; export const FETCH_CHANNEL_CLAIMS_COMPLETED = "FETCH_CHANNEL_CLAIMS_COMPLETED"; export const FETCH_CLAIM_LIST_MINE_STARTED = "FETCH_CLAIM_LIST_MINE_STARTED"; diff --git a/ui/js/page/discover/index.js b/ui/js/page/discover/index.js index 01f9add5e..be49b892d 100644 --- a/ui/js/page/discover/index.js +++ b/ui/js/page/discover/index.js @@ -1,6 +1,6 @@ import React from "react"; import { connect } from "react-redux"; -import { doFetchFeaturedUris } from "actions/content"; +import { doFetchFeaturedUris, doCancelAllResolvingUris } from "actions/content"; import { selectFeaturedUris, selectFetchingFeaturedUris, @@ -14,6 +14,7 @@ const select = state => ({ const perform = dispatch => ({ fetchFeaturedUris: () => dispatch(doFetchFeaturedUris()), + cancelResolvingUris: () => dispatch(doCancelAllResolvingUris()), }); export default connect(select, perform)(DiscoverPage); diff --git a/ui/js/page/discover/view.jsx b/ui/js/page/discover/view.jsx index 22f5f2b80..d6c506dfd 100644 --- a/ui/js/page/discover/view.jsx +++ b/ui/js/page/discover/view.jsx @@ -39,6 +39,10 @@ class DiscoverPage extends React.PureComponent { this.props.fetchFeaturedUris(); } + componentWillUnmount() { + this.props.cancelResolvingUris(); + } + render() { const { featuredUris, fetchingFeaturedUris } = this.props; const failedToLoad = @@ -62,7 +66,9 @@ class DiscoverPage extends React.PureComponent { : "" )} {failedToLoad && -
{__("Failed to load landing content.")}
} +
+ {__("Failed to load landing content.")} +
} ); } diff --git a/ui/js/page/fileListDownloaded/index.js b/ui/js/page/fileListDownloaded/index.js index 7aebe1adb..86d26d851 100644 --- a/ui/js/page/fileListDownloaded/index.js +++ b/ui/js/page/fileListDownloaded/index.js @@ -6,6 +6,7 @@ import { selectFileListDownloadedOrPublishedIsPending, } from "selectors/file_info"; import { doNavigate } from "actions/app"; +import { doCancelAllResolvingUris } from "actions/content"; import FileListDownloaded from "./view"; const select = state => ({ @@ -17,6 +18,7 @@ const perform = dispatch => ({ navigate: path => dispatch(doNavigate(path)), fetchFileInfosDownloaded: () => dispatch(doFetchFileInfosAndPublishedClaims()), + cancelResolvingUris: () => dispatch(doCancelAllResolvingUris()), }); export default connect(select, perform)(FileListDownloaded); diff --git a/ui/js/page/fileListDownloaded/view.jsx b/ui/js/page/fileListDownloaded/view.jsx index 77f1091db..03665847c 100644 --- a/ui/js/page/fileListDownloaded/view.jsx +++ b/ui/js/page/fileListDownloaded/view.jsx @@ -15,6 +15,10 @@ class FileListDownloaded extends React.PureComponent { if (!this.props.isPending) this.props.fetchFileInfosDownloaded(); } + componentWillUnmount() { + this.props.cancelResolvingUris(); + } + render() { const { fileInfos, isPending, navigate } = this.props; @@ -27,8 +31,7 @@ class FileListDownloaded extends React.PureComponent { } else { content = ( - {__("You haven't downloaded anything from LBRY yet. Go")} - {" "} + {__("You haven't downloaded anything from LBRY yet. Go")}{" "} navigate("/discover")} label={__("search for your first download")} diff --git a/ui/js/page/fileListPublished/index.js b/ui/js/page/fileListPublished/index.js index 948b81c7e..7e5e349c3 100644 --- a/ui/js/page/fileListPublished/index.js +++ b/ui/js/page/fileListPublished/index.js @@ -8,6 +8,7 @@ import { } from "selectors/file_info"; import { doClaimRewardType } from "actions/rewards"; import { doNavigate } from "actions/app"; +import { doCancelAllResolvingUris } from "actions/content"; import FileListPublished from "./view"; const select = state => ({ @@ -20,6 +21,7 @@ const perform = dispatch => ({ fetchFileListPublished: () => dispatch(doFetchFileInfosAndPublishedClaims()), claimFirstPublishReward: () => dispatch(doClaimRewardType(rewards.TYPE_FIRST_PUBLISH)), + cancelResolvingUris: () => dispatch(doCancelAllResolvingUris()), }); export default connect(select, perform)(FileListPublished); diff --git a/ui/js/page/fileListPublished/view.jsx b/ui/js/page/fileListPublished/view.jsx index 3af905a51..822cfeb7d 100644 --- a/ui/js/page/fileListPublished/view.jsx +++ b/ui/js/page/fileListPublished/view.jsx @@ -19,6 +19,10 @@ class FileListPublished extends React.PureComponent { if (this.props.fileInfos.length > 0) this.props.claimFirstPublishReward(); } + componentWillUnmount() { + this.props.cancelResolvingUris(); + } + render() { const { fileInfos, isPending, navigate } = this.props; @@ -38,8 +42,9 @@ class FileListPublished extends React.PureComponent { } else { content = ( - {__("It looks like you haven't published anything to LBRY yet. Go")} - {" "} + {__( + "It looks like you haven't published anything to LBRY yet. Go" + )}{" "} navigate("/publish")} label={__("share your beautiful cats with the world")} diff --git a/ui/js/reducers/content.js b/ui/js/reducers/content.js index 868525298..f346e2d27 100644 --- a/ui/js/reducers/content.js +++ b/ui/js/reducers/content.js @@ -31,7 +31,9 @@ reducers[types.RESOLVE_URI_STARTED] = function(state, action) { }); }; -reducers[types.RESOLVE_URI_COMPLETED] = function(state, action) { +reducers[types.RESOLVE_URI_CANCELED] = reducers[ + types.RESOLVE_URI_COMPLETED +] = function(state, action) { const { uri } = action.data; const resolvingUris = state.resolvingUris; const index = state.resolvingUris.indexOf(uri); @@ -45,10 +47,6 @@ reducers[types.RESOLVE_URI_COMPLETED] = function(state, action) { }); }; -reducers[types.RESOLVE_URI_CANCELED] = function(state, action) { - return reducers[types.RESOLVE_URI_COMPLETED](state, action); -}; - export default function reducer(state = defaultState, action) { const handler = reducers[action.type]; if (handler) return handler(state, action);