Collection tree: Keep editing state through refresh (#4556)
Some checks are pending
CI / Build, Upload, Test (push) Waiting to run

This commit is contained in:
Abe Jellinek 2024-08-12 14:43:49 -06:00 committed by GitHub
parent 51fe17c13d
commit 16bb95ad3f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -277,6 +277,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
stopEditing = () => { stopEditing = () => {
this._editing = null; this._editing = null;
this._editingInput = null;
// Returning focus to the tree container // Returning focus to the tree container
this.tree.invalidate(); this.tree.invalidate();
this.tree.focus(); this.tree.focus();
@ -366,24 +367,35 @@ var CollectionTree = class CollectionTree extends LibraryTree {
// Editing input // Editing input
div.classList.toggle('editing', treeRow == this._editing); div.classList.toggle('editing', treeRow == this._editing);
if (treeRow == this._editing) { if (treeRow == this._editing) {
label = document.createElement('input'); if (this._editingInput
label.className = 'cell-text'; && this._editingInput.dataset.rowId === treeRow.id
label.setAttribute("size", 5); && this._editingInput.value === treeRow.editingName) {
label.toggleAttribute("no-windows-native", true); label = this._editingInput;
label.value = treeRow.editingName; // Feels like a bit of a hack, but it gets the job done
label.addEventListener('input', e => this.handleEditingChange(e, index)); setTimeout(() => {
label.addEventListener('mousedown', (e) => e.stopImmediatePropagation()); label.focus();
label.addEventListener('mouseup', (e) => e.stopImmediatePropagation()); });
label.addEventListener('dblclick', (e) => e.stopImmediatePropagation()); }
label.addEventListener('blur', async (e) => { else {
await this.commitEditingName(); label = this._editingInput = document.createElement('input');
this.stopEditing(); label.className = 'cell-text';
}); label.dataset.rowId = treeRow.id;
// Feels like a bit of a hack, but it gets the job done label.setAttribute("size", 5);
setTimeout(() => { label.toggleAttribute("no-windows-native", true);
label.focus(); label.value = treeRow.editingName;
label.select(); label.addEventListener('input', e => this.handleEditingChange(e, index));
}); label.addEventListener('mousedown', (e) => e.stopImmediatePropagation());
label.addEventListener('mouseup', (e) => e.stopImmediatePropagation());
label.addEventListener('dblclick', (e) => e.stopImmediatePropagation());
label.addEventListener('blur', async (e) => {
await this.commitEditingName();
this.stopEditing();
});
setTimeout(() => {
label.focus();
label.select();
});
}
} }
cell.appendChild(twisty); cell.appendChild(twisty);
@ -564,6 +576,14 @@ var CollectionTree = class CollectionTree extends LibraryTree {
} }
this._rows = newRows; this._rows = newRows;
this._refreshRowMap(); this._refreshRowMap();
if (this._editing) {
let editingName = this._editing.editingName;
let editingIdx = this._rowMap[this._editing.id];
if (editingIdx !== undefined) {
this._editing = this.getRow(editingIdx);
this._editing.editingName = editingName;
}
}
} catch (e) { } catch (e) {
Zotero.logError(e); Zotero.logError(e);
window.ZoteroPane.displayErrorMessage(); window.ZoteroPane.displayErrorMessage();
@ -776,6 +796,8 @@ var CollectionTree = class CollectionTree extends LibraryTree {
// Actions that can change the selection // Actions that can change the selection
// //
var currentTreeRow = this.getRow(this.selection.focused); var currentTreeRow = this.getRow(this.selection.focused);
// Set to true if selectByID()/selectWait() is awaited
var skipWait = false;
this.selection.selectEventsSuppressed = true; this.selection.selectEventsSuppressed = true;
if (action == 'delete') { if (action == 'delete') {
@ -887,6 +909,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
else { else {
await this._addSortedRow('collection', id); await this._addSortedRow('collection', id);
await this.selectByID(currentTreeRow.id); await this.selectByID(currentTreeRow.id);
skipWait = true;
if (reopen) { if (reopen) {
let newRow = this.getRowIndexByID(rowID); let newRow = this.getRowIndexByID(rowID);
if (!this.isContainerOpen(newRow)) { if (!this.isContainerOpen(newRow)) {
@ -900,6 +923,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
else if (!collection.deleted) { else if (!collection.deleted) {
await this._addSortedRow('collection', id); await this._addSortedRow('collection', id);
await this.selectByID(currentTreeRow.id); await this.selectByID(currentTreeRow.id);
skipWait = true;
// Invalidate parent in case it's become non-empty // Invalidate parent in case it's become non-empty
if (collection.parentID) { if (collection.parentID) {
let parentRow = this.getRowIndexByID("C" + collection.parentID); let parentRow = this.getRowIndexByID("C" + collection.parentID);
@ -928,6 +952,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
else { else {
await this._addSortedRow('search', id); await this._addSortedRow('search', id);
await this.selectByID(currentTreeRow.id); await this.selectByID(currentTreeRow.id);
skipWait = true;
} }
} }
// If search isn't currently visible and it isn't in the trash (because it was // If search isn't currently visible and it isn't in the trash (because it was
@ -935,6 +960,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
else if (!search.deleted) { else if (!search.deleted) {
await this._addSortedRow('search', id); await this._addSortedRow('search', id);
await this.selectByID(currentTreeRow.id); await this.selectByID(currentTreeRow.id);
skipWait = true;
// Invalidate parent in case it's become non-empty // Invalidate parent in case it's become non-empty
// NOTE: Not currently used, because searches can't yet have parents // NOTE: Not currently used, because searches can't yet have parents
if (search.parentID) { if (search.parentID) {
@ -953,6 +979,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
default: default:
await this.reload(); await this.reload();
await this.selectByID(currentTreeRow.id); await this.selectByID(currentTreeRow.id);
skipWait = true;
break; break;
} }
} }
@ -971,13 +998,16 @@ var CollectionTree = class CollectionTree extends LibraryTree {
if (selectRow) { if (selectRow) {
if (type == 'collection') { if (type == 'collection') {
await this.selectByID("C" + id); await this.selectByID("C" + id);
skipWait = true;
} }
else if (type == 'search') { else if (type == 'search') {
await this.selectByID("S" + id); await this.selectByID("S" + id);
skipWait = true;
} }
} }
else if (addedIndex !== false && addedIndex <= this.selection.focused) { else if (addedIndex !== false && addedIndex <= this.selection.focused) {
await this.selectWait(this.selection.focused+1); await this.selectWait(this.selection.focused+1);
skipWait = true;
} }
break; break;
@ -995,6 +1025,7 @@ var CollectionTree = class CollectionTree extends LibraryTree {
? "L" + id ? "L" + id
: currentTreeRow.id : currentTreeRow.id
); );
skipWait = true;
break; break;
} }
} }
@ -1020,7 +1051,8 @@ var CollectionTree = class CollectionTree extends LibraryTree {
} }
this.forceUpdate(); this.forceUpdate();
var promise = this.waitForSelect(); // Only wait for select if we didn't already do that above
var promise = skipWait ? Promise.resolve() : this.waitForSelect();
this.selection.selectEventsSuppressed = false; this.selection.selectEventsSuppressed = false;
return promise; return promise;
} }