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);