WIP: search for collections now works, but is inefficient (it re-traverses the subtree every time)
This commit is contained in:
parent
24768cdf1b
commit
b22ddf9180
|
@ -41,6 +41,7 @@ Zotero.CollectionTreeView = function()
|
||||||
this.itemTreeView = null;
|
this.itemTreeView = null;
|
||||||
this.itemToSelect = null;
|
this.itemToSelect = null;
|
||||||
this.hideSources = [];
|
this.hideSources = [];
|
||||||
|
this._searchText = '';
|
||||||
|
|
||||||
this._highlightedRows = {};
|
this._highlightedRows = {};
|
||||||
this._unregisterID = Zotero.Notifier.registerObserver(
|
this._unregisterID = Zotero.Notifier.registerObserver(
|
||||||
|
@ -1088,6 +1089,14 @@ Zotero.CollectionTreeView.prototype.selectByID = Zotero.Promise.coroutine(functi
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Zotero.CollectionTreeView.prototype.setSearch = Zotero.Promise.coroutine(function* (val) {
|
||||||
|
this._searchText = val ? val : '';
|
||||||
|
if (this.isContainerOpen(0)) {
|
||||||
|
this._closeContainer(0);
|
||||||
|
this._rows[0].isOpen = false;
|
||||||
|
}
|
||||||
|
this.toggleOpenState(0);
|
||||||
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {Integer} libraryID Library to select
|
* @param {Integer} libraryID Library to select
|
||||||
|
@ -1344,15 +1353,35 @@ Zotero.CollectionTreeView.prototype._expandRow = Zotero.Promise.coroutine(functi
|
||||||
|
|
||||||
// Add collections
|
// Add collections
|
||||||
for (var i = 0, len = collections.length; i < len; i++) {
|
for (var i = 0, len = collections.length; i < len; i++) {
|
||||||
let beforeRow = row + 1 + newRows;
|
flds = "";
|
||||||
this._addRowToArray(
|
for (field in collections[i]) { flds += ",\n " + field + " = " + collections[i][field]; }
|
||||||
rows,
|
//alert(flds);
|
||||||
new Zotero.CollectionTreeRow(this, 'collection', collections[i], level + 1),
|
var searchInChildCollections = function (collection, str) {
|
||||||
beforeRow
|
//alert(collection.name);
|
||||||
);
|
if (collection.name.toLowerCase().indexOf(str) >= 0) {
|
||||||
newRows++;
|
return true;
|
||||||
// Recursively expand child collections that should be open
|
}
|
||||||
newRows += yield this._expandRow(rows, beforeRow);
|
else {
|
||||||
|
var rcollections = collection.getChildCollections();
|
||||||
|
for (var j = 0, jlen = rcollections.length; j < jlen; j++) {
|
||||||
|
if (searchInChildCollections(rcollections[j], str)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (searchInChildCollections(collections[i], this._searchText)) {
|
||||||
|
let beforeRow = row + 1 + newRows;
|
||||||
|
this._addRowToArray(
|
||||||
|
rows,
|
||||||
|
new Zotero.CollectionTreeRow(this, 'collection', collections[i], level + 1),
|
||||||
|
beforeRow
|
||||||
|
);
|
||||||
|
newRows++;
|
||||||
|
// Recursively expand child collections that should be open
|
||||||
|
newRows += yield this._expandRow(rows, beforeRow);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isCollection) {
|
if (isCollection) {
|
||||||
|
|
|
@ -958,6 +958,27 @@ var ZoteroPane = new function()
|
||||||
var toolbarButton = document.getElementById('zotero-tb-show-collection-lookup');
|
var toolbarButton = document.getElementById('zotero-tb-show-collection-lookup');
|
||||||
toolbarButton.checked = !collectionsLookupTextbox.hidden;
|
toolbarButton.checked = !collectionsLookupTextbox.hidden;
|
||||||
};
|
};
|
||||||
|
this._collectionSearch = false;
|
||||||
|
this.onCollectionLookup = function (clear) {
|
||||||
|
var setSearch = function(val) {
|
||||||
|
this._collectionSearch = val
|
||||||
|
? val.toLowerCase().normalize()
|
||||||
|
: false;
|
||||||
|
ZoteroPane_Local.collectionsView.setSearch(_collectionSearch);
|
||||||
|
};
|
||||||
|
var collectionsLookupTextbox = document.getElementById('zotero-collection-lookup-textbox');
|
||||||
|
if (typeof clear != 'undefined') {
|
||||||
|
if (clear){
|
||||||
|
collectionsLookupTextbox.value = '';
|
||||||
|
setSearch('');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
setSearch(collectionsLookupTextbox.value);
|
||||||
|
};
|
||||||
|
|
||||||
this.importFeedsFromOPML = Zotero.Promise.coroutine(function* (event) {
|
this.importFeedsFromOPML = Zotero.Promise.coroutine(function* (event) {
|
||||||
var nsIFilePicker = Components.interfaces.nsIFilePicker;
|
var nsIFilePicker = Components.interfaces.nsIFilePicker;
|
||||||
|
|
|
@ -348,8 +348,8 @@
|
||||||
the tag selector to max height -->
|
the tag selector to max height -->
|
||||||
<textbox id="zotero-collection-lookup-textbox" flex="0" type="search" timeout="250" dir="reverse"
|
<textbox id="zotero-collection-lookup-textbox" flex="0" type="search" timeout="250" dir="reverse"
|
||||||
zotero-persist="hidden"
|
zotero-persist="hidden"
|
||||||
oncommand="document.getBindingParent(this).handleKeyPress(); event.stopPropagation()"
|
oncommand="ZoteroPane.onCollectionLookup(); event.stopPropagation()"
|
||||||
onkeypress="if (event.keyCode == event.DOM_VK_ESCAPE) { document.getBindingParent(this).handleKeyPress(true); }"/>
|
onkeypress="if (event.keyCode == event.DOM_VK_ESCAPE) { ZoteroPane.onCollectionLookup(true); }"/>
|
||||||
<tree id="zotero-collections-tree"
|
<tree id="zotero-collections-tree"
|
||||||
hidecolumnpicker="true"
|
hidecolumnpicker="true"
|
||||||
oncontextmenu="ZoteroPane.onCollectionsContextMenuOpen(event)"
|
oncontextmenu="ZoteroPane.onCollectionsContextMenuOpen(event)"
|
||||||
|
|
Loading…
Reference in New Issue
Block a user