[interface] Collections should keep their open state on a drop.

This commit is contained in:
David Norton 2006-06-08 20:28:50 +00:00
parent 7c9b1f785c
commit 368724b7de

View file

@ -31,11 +31,11 @@ Scholar.CollectionTreeView.prototype.unregister = function()
*/ */
Scholar.CollectionTreeView.prototype.notify = function(action, type, ids) Scholar.CollectionTreeView.prototype.notify = function(action, type, ids)
{ {
ids = Scholar.flattenArguments(ids);
var madeChanges = false; var madeChanges = false;
if(action == 'remove') if(action == 'remove')
{ {
ids = Scholar.flattenArguments(ids);
//Since a remove involves shifting of rows, we have to do it in order //Since a remove involves shifting of rows, we have to do it in order
//sort the ids by row //sort the ids by row
@ -59,8 +59,31 @@ Scholar.CollectionTreeView.prototype.notify = function(action, type, ids)
} }
} }
else if(action == 'move')
{
var openCollections = new Array();
for(var i = 0; i < this.rowCount; i++)
if(this.isContainer(i) && this.isContainerOpen(i))
openCollections.push(this._getItemAtRow(i).ref.getID());
var oldCount = this.rowCount;
this._treebox.beginUpdateBatch();
this.refresh();
this._treebox.rowCountChanged(0,this.rowCount - oldCount);
for(var i = 0; i < openCollections.length; i++)
{
var row = this._collectionRowMap[openCollections[i]];
if(row != null)
this.toggleOpenState(row);
}
this._treebox.invalidate();
this._treebox.endUpdateBatch();
}
else else
{ {
ids = Scholar.flattenArguments(ids);
for (var i=0, len=ids.length; i<len; i++) for (var i=0, len=ids.length; i<len; i++)
{ {
@ -78,7 +101,6 @@ Scholar.CollectionTreeView.prototype.notify = function(action, type, ids)
madeChanges = true; madeChanges = true;
} }
} }
} }
@ -268,12 +290,8 @@ Scholar.CollectionTreeView.prototype.drop = function(row, orient)
var targetCollectionID; var targetCollectionID;
if(this._getItemAtRow(row).isCollection()) if(this._getItemAtRow(row).isCollection())
targetCollectionID = this._getItemAtRow(row).ref.getID(); targetCollectionID = this._getItemAtRow(row).ref.getID();
var droppedCollection = Scholar.Collections.get(ids[0]); var droppedCollection = Scholar.Collections.get(ids[0]);
droppedCollection.changeParent(targetCollectionID); droppedCollection.changeParent(targetCollectionID);
this.refresh();
this._treebox.rowCountChanged(0,this.rowCount-oldCount);
this._treebox.invalidate();
} }
else if(dataType == 'scholar/item' && this.canDrop(row, orient)) else if(dataType == 'scholar/item' && this.canDrop(row, orient))
{ {