Search field now searches only selection Library/Project.

- Sort stays
 - Selection remembered

New functions: saveSelection(), rememberSelection() on ItemTreeView
This commit is contained in:
David Norton 2006-06-06 22:43:58 +00:00
parent 0753d78910
commit 098e90fea9
3 changed files with 42 additions and 19 deletions

View file

@ -288,7 +288,7 @@ Scholar.ItemGroup.prototype.getChildItems = function()
{ {
if(this.searchText) if(this.searchText)
{ {
return Scholar.Items.get(Scholar.Items.search(this.searchText)); return Scholar.Items.get(Scholar.Items.search(this.searchText,(this.isCollection() ? this.ref.getID() : null)));
} }
else else
{ {

View file

@ -1,6 +1,7 @@
Scholar.ItemTreeView = function(itemGroup) Scholar.ItemTreeView = function(itemGroup)
{ {
this._treebox = null; this._treebox = null;
this._savedSelection = null;
this._dataItems = new Array(); this._dataItems = new Array();
this.rowCount = 0; this.rowCount = 0;
this._itemGroup = itemGroup; this._itemGroup = itemGroup;
@ -88,22 +89,16 @@ Scholar.ItemTreeView.prototype.cycleHeader = function(column)
} }
} }
this.selection.selectEventsSuppressed = true;
this.saveSelection();
this.sort(); this.sort();
this.rememberSelection();
this.selection.selectEventsSuppressed = false;
this._treebox.invalidate();
} }
Scholar.ItemTreeView.prototype.sort = function() Scholar.ItemTreeView.prototype.sort = function()
{ {
this.selection.selectEventsSuppressed = true;
var selectedIDs = new Array();
var start = new Object();
var end = new Object();
for (var i=0, len=this.selection.getRangeCount(); i<len; i++)
{
this.selection.getRangeAt(i,start,end);
for (var j=start.value; j<=end.value; j++)
selectedIDs.push(this._getItemAtRow(j).getID());
}
var column = this._treebox.columns.getSortedColumn() var column = this._treebox.columns.getSortedColumn()
var order = column.element.getAttribute('sortDirection') == 'descending'; var order = column.element.getAttribute('sortDirection') == 'descending';
@ -125,13 +120,6 @@ Scholar.ItemTreeView.prototype.sort = function()
this._dataItems.sort(columnSort); this._dataItems.sort(columnSort);
this._refreshHashMap(); this._refreshHashMap();
this.selection.clearSelection();
for(var i=0; i < selectedIDs.length; i++)
{
this.selection.toggleSelect(this._itemRowMap[selectedIDs[i]]);
}
this.selection.selectEventsSuppressed = false;
this._treebox.invalidate();
} }
Scholar.ItemTreeView.prototype.deleteSelection = function() Scholar.ItemTreeView.prototype.deleteSelection = function()
@ -169,10 +157,18 @@ Scholar.ItemTreeView.prototype.deleteSelection = function()
Scholar.ItemTreeView.prototype.searchText = function(search) Scholar.ItemTreeView.prototype.searchText = function(search)
{ {
this.selection.selectEventsSuppressed = true;
this.saveSelection();
this._itemGroup.setSearch(search); this._itemGroup.setSearch(search);
var oldCount = this.rowCount; var oldCount = this.rowCount;
this.refresh(); this.refresh();
this._treebox.rowCountChanged(0,this.rowCount-oldCount); this._treebox.rowCountChanged(0,this.rowCount-oldCount);
this.sort();
this.rememberSelection();
this.selection.selectEventsSuppressed = false;
this._treebox.invalidate(); this._treebox.invalidate();
} }
@ -265,6 +261,30 @@ Scholar.ItemTreeView.prototype.notify = function(action, type, ids)
} }
} }
Scholar.ItemTreeView.prototype.saveSelection = function()
{
this._savedSelection = new Array();
var start = new Object();
var end = new Object();
for (var i=0, len=this.selection.getRangeCount(); i<len; i++)
{
this.selection.getRangeAt(i,start,end);
for (var j=start.value; j<=end.value; j++)
this._savedSelection.push(this._getItemAtRow(j).getID());
}
}
Scholar.ItemTreeView.prototype.rememberSelection = function()
{
this.selection.clearSelection();
for(var i=0; i < this._savedSelection.length; i++)
{
if(this._itemRowMap[this._savedSelection[i]] != null)
this.selection.toggleSelect(this._itemRowMap[this._savedSelection[i]]);
}
}
Scholar.ItemTreeView.prototype.canDrop = function(index, orient) Scholar.ItemTreeView.prototype.canDrop = function(index, orient)
{ {
return false; return false;

View file

@ -83,10 +83,13 @@ var ScholarPane = new function()
{ {
if(itemsView) if(itemsView)
itemsView.unregister(); itemsView.unregister();
document.getElementById('tb-search').value = "";
if(collectionsView.selection.count == 1 && collectionsView.selection.currentIndex != -1) if(collectionsView.selection.count == 1 && collectionsView.selection.currentIndex != -1)
{ {
var collection = collectionsView._getItemAtRow(collectionsView.selection.currentIndex); var collection = collectionsView._getItemAtRow(collectionsView.selection.currentIndex);
collection.setSearch('');
itemsView = new Scholar.ItemTreeView(collection); itemsView = new Scholar.ItemTreeView(collection);
document.getElementById('items-tree').view = itemsView; document.getElementById('items-tree').view = itemsView;