From 304b53e99450daf6d96b26e8483f3e078932dd2c Mon Sep 17 00:00:00 2001 From: Alex Liebowitz Date: Tue, 3 Jan 2017 19:09:46 -0500 Subject: [PATCH 1/2] Simplify sorting logic in My Files --- js/page/my_files.js | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/js/page/my_files.js b/js/page/my_files.js index 58f662c55..ed33e9fc0 100644 --- a/js/page/my_files.js +++ b/js/page/my_files.js @@ -175,7 +175,6 @@ var MyFilesPage = React.createClass({ }, title: function(filesInfo) { return filesInfo.sort(function(a, b) { - console.log('in title sort. a is', a, '; b is', b) return ((a.metadata ? a.metadata.title.toLowerCase() : a.name) > (b.metadata ? b.metadata.title.toLowerCase() : b.name)); }); @@ -236,15 +235,9 @@ var MyFilesPage = React.createClass({ clearTimeout(this._fileTimeout); } }, - setFilesInfo: function(filesInfo) { - this.setState({ - filesInfo: this._sortFunctions[this.state.sortBy](filesInfo), - }); - }, handleSortChanged: function(event) { this.setState({ sortBy: event.target.value, - filesInfo: this._sortFunctions[event.target.value](this.state.filesInfo), }); }, updateFilesInfo: function() { @@ -263,7 +256,9 @@ var MyFilesPage = React.createClass({ newFilesInfo.push(fileInfo); } if (claimInfoProcessedCount >= claimsInfo.length) { - this.setFilesInfo(newFilesInfo); + this.setState({ + filesInfo: newFilesInfo, + }); this._fileTimeout = setTimeout(() => { this.updateFilesInfo() }, 1000); } @@ -274,9 +269,11 @@ var MyFilesPage = React.createClass({ // We're in the Downloaded tab, so populate this.state.filesInfo with files the user has in // lbrynet, with published files filtered out. lbry.getFilesInfo((filesInfo) => { - this.setFilesInfo(filesInfo.filter(({sd_hash}) => { - return this.state.publishedFilesSdHashes.indexOf(sd_hash) == -1; - })); + this.setState({ + filesInfo: filesInfo.filter(({sd_hash}) => { + return this.state.publishedFilesSdHashes.indexOf(sd_hash) == -1; + }), + }); let newFilesAvailable; if (!(this._fileInfoCheckNum % this._fileInfoCheckRate)) { @@ -320,7 +317,8 @@ var MyFilesPage = React.createClass({ var content = [], seenUris = {}; - for (let fileInfo of this.state.filesInfo) { + const filesInfoSorted = this._sortFunctions[this.state.sortBy](this.state.filesInfo); + for (let fileInfo of filesInfoSorted) { let {completed, written_bytes, total_bytes, lbry_uri, file_name, download_path, stopped, metadata, sd_hash} = fileInfo; From 863758ba541fd7bc7c1767071587dfc0f054c4d5 Mon Sep 17 00:00:00 2001 From: Alex Liebowitz Date: Tue, 3 Jan 2017 19:41:32 -0500 Subject: [PATCH 2/2] My Files: Preserve order of claims returned by daemon --- js/page/my_files.js | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/js/page/my_files.js b/js/page/my_files.js index ed33e9fc0..fb55a7f23 100644 --- a/js/page/my_files.js +++ b/js/page/my_files.js @@ -246,18 +246,28 @@ var MyFilesPage = React.createClass({ if (this.props.show == 'published') { // We're in the Published tab, so populate this.state.filesInfo with data from the user's claims lbry.getMyClaims((claimsInfo) => { - let newFilesInfo = []; + /** + * Build newFilesInfo as a sparse array and drop elements in at the same position they + * occur in claimsInfo, so the order is preserved even if the API calls inside this loop + * return out of order. + */ + + let newFilesInfo = Array(claimsInfo.length); let claimInfoProcessedCount = 0; - for (let claimInfo of claimsInfo) { + for (let [i, claimInfo] of claimsInfo.entries()) { let metadata = JSON.parse(claimInfo.value); lbry.getFileInfoBySdHash(metadata.sources.lbry_sd_hash, (fileInfo) => { claimInfoProcessedCount++; if (fileInfo !== false) { - newFilesInfo.push(fileInfo); + newFilesInfo[i] = fileInfo; } if (claimInfoProcessedCount >= claimsInfo.length) { + /** + * newFilesInfo may have gaps from claims that don't have associated files in + * lbrynet, so filter out any missing elements + */ this.setState({ - filesInfo: newFilesInfo, + filesInfo: newFilesInfo.filter(function() { return true }), }); this._fileTimeout = setTimeout(() => { this.updateFilesInfo() }, 1000);