Improve column sorting speed

This commit is contained in:
Adomas Venčkauskas 2021-04-23 10:48:43 +03:00 committed by Dan Stillman
parent ff627b7d3f
commit 7ec89c44ce
2 changed files with 10 additions and 5 deletions

View file

@ -100,6 +100,8 @@ class TreeSelection {
clearSelection() { clearSelection() {
this.selected = new Set(); this.selected = new Set();
if (this.selectEventsSuppressed) return;
if (this._tree.invalidate) { if (this._tree.invalidate) {
this._tree.invalidate(); this._tree.invalidate();
} }

View file

@ -1609,13 +1609,15 @@ var ItemTree = class ItemTree extends LibraryTree {
this._rows.sort((a, b) => rowSort(a, b) * order); this._rows.sort((a, b) => rowSort(a, b) * order);
} }
this.tree && this.tree.invalidate();
this._refreshRowMap(); this._refreshRowMap();
this._rememberOpenState(openItemIDs); this._rememberOpenState(openItemIDs);
this._restoreSelection(savedSelection); this._restoreSelection(savedSelection);
if (this.tree && !this.selection.selectEventsSuppressed) {
this.tree.invalidate();
}
var numSorted = itemIDs ? itemIDs.length : this._rows.length; var numSorted = itemIDs ? itemIDs.length : this._rows.length;
Zotero.debug(`Sorted ${numSorted} ${Zotero.Utilities.pluralize(numSorted, ['item', 'items'])} ` Zotero.debug(`Sorted ${numSorted} ${Zotero.Utilities.pluralize(numSorted, ['item', 'items'])} `
+ `in ${new Date - t} ms`); + `in ${new Date - t} ms`);
@ -3154,14 +3156,15 @@ var ItemTree = class ItemTree extends LibraryTree {
} }
} }
this._storeColumnPrefs(columnSettings);
await this._refreshPromise; await this._refreshPromise;
this.selection.selectEventsSuppressed = true; this.selection.selectEventsSuppressed = true;
await this.sort(); await this.sort();
this.forceUpdate(() => { this.forceUpdate(() => {
this.tree.invalidate();
this.selection.selectEventsSuppressed = false; this.selection.selectEventsSuppressed = false;
}) // Store column prefs as a final action because it freezes the UI momentarily
// and makes the column sorting look laggy
this._storeColumnPrefs(columnSettings);
});
} }
_displayColumnPickerMenu = (event) => { _displayColumnPickerMenu = (event) => {