forked from extern/egroupware
Fix bug where nextmatch selection manager was holding onto selected rows
This commit is contained in:
parent
dee750fb9c
commit
74edbe227d
@ -148,6 +148,9 @@ var et2_dataview_controller = (function(){ "use strict"; return Class.extend({
|
|||||||
// Free selection manager
|
// Free selection manager
|
||||||
this._selectionMgr.clear();
|
this._selectionMgr.clear();
|
||||||
|
|
||||||
|
// Clear object manager
|
||||||
|
this._objectManager.clear();
|
||||||
|
|
||||||
// Clear the map
|
// Clear the map
|
||||||
this._indexMap = {}
|
this._indexMap = {}
|
||||||
// Update selection manager, it uses this by reference
|
// Update selection manager, it uses this by reference
|
||||||
|
@ -108,6 +108,10 @@ var et2_dataview_selectionManager = (function(){ "use strict"; return Class.exte
|
|||||||
this.unregisterRow(key, this._registeredRows[key].tr);
|
this.unregisterRow(key, this._registeredRows[key].tr);
|
||||||
delete this._registeredRows[key];
|
delete this._registeredRows[key];
|
||||||
}
|
}
|
||||||
|
if(this._actionObjectManager)
|
||||||
|
{
|
||||||
|
this._actionObjectManager.clear();
|
||||||
|
}
|
||||||
this._indexMap = {};
|
this._indexMap = {};
|
||||||
this._total = 0;
|
this._total = 0;
|
||||||
this._focusedEntry = null;
|
this._focusedEntry = null;
|
||||||
@ -234,6 +238,10 @@ var et2_dataview_selectionManager = (function(){ "use strict"; return Class.exte
|
|||||||
|
|
||||||
this._selectAll = true;
|
this._selectAll = true;
|
||||||
|
|
||||||
|
if(Object.keys(this._registeredRows).length != this._total)
|
||||||
|
{
|
||||||
|
this._selectRange(0, this._total);
|
||||||
|
}
|
||||||
// Tell action manager to do all
|
// Tell action manager to do all
|
||||||
this._actionObjectManager.setAllSelected(true);
|
this._actionObjectManager.setAllSelected(true);
|
||||||
|
|
||||||
|
@ -489,6 +489,7 @@ var et2_nextmatch = (function(){ "use strict"; return et2_DOMWidget.extend([et2_
|
|||||||
changed = true;
|
changed = true;
|
||||||
keep_selection = true;
|
keep_selection = true;
|
||||||
this.controller._selectionMgr.resetSelection();
|
this.controller._selectionMgr.resetSelection();
|
||||||
|
this.controller._objectManager.clear();
|
||||||
for(var i in _set.selected)
|
for(var i in _set.selected)
|
||||||
{
|
{
|
||||||
this.controller._selectionMgr.setSelected(_set.selected[i].indexOf('::') > 0 ? _set.selected[i] : this.controller.dataStorePrefix + '::'+_set.selected[i],true);
|
this.controller._selectionMgr.setSelected(_set.selected[i].indexOf('::') > 0 ? _set.selected[i] : this.controller.dataStorePrefix + '::'+_set.selected[i],true);
|
||||||
@ -514,6 +515,8 @@ var et2_nextmatch = (function(){ "use strict"; return et2_DOMWidget.extend([et2_
|
|||||||
{
|
{
|
||||||
// Do not keep selection
|
// Do not keep selection
|
||||||
this.controller._selectionMgr.resetSelection();
|
this.controller._selectionMgr.resetSelection();
|
||||||
|
this.controller._objectManager.clear();
|
||||||
|
this.controller.keepSelection();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update the filters in the grid controller
|
// Update the filters in the grid controller
|
||||||
|
Loading…
Reference in New Issue
Block a user