* InfoLog: fixed selection over multiple hierarchy levels (eg. deleting a child from an opened InfoLog also deleted previously selected top-level entry!)

This commit is contained in:
Ralf Becker 2014-09-02 10:34:05 +00:00
parent 4355db9d85
commit 146febd692
2 changed files with 34 additions and 29 deletions

View File

@ -181,6 +181,10 @@ var et2_dataview_selectionManager = Class.extend(
{ {
this.setSelected(key, false); this.setSelected(key, false);
} }
for(var i = 0; i < this._children.length; i++)
{
this._children[i].resetSelection();
}
}, },
setSelected: function (_uid, _selected) { setSelected: function (_uid, _selected) {
@ -453,7 +457,12 @@ var et2_dataview_selectionManager = Class.extend(
// If not "_ctrl" is set, reset the selection // If not "_ctrl" is set, reset the selection
if (!_ctrl) if (!_ctrl)
{ {
this.resetSelection(); var top = this;
while(top._parent !== null)
{
top = top._parent;
}
top.resetSelection();
this._actionObjectManager.setAllSelected(false); // needed for hirachical stuff this._actionObjectManager.setAllSelected(false); // needed for hirachical stuff
} }

View File

@ -45,24 +45,18 @@ function nm_action(_action, _senders, _target, _ids)
_action.data.nextmatch = nm; _action.data.nextmatch = nm;
} }
} }
// default action when doubleclicked contains (previous selected) ids of other hierarchy levels
// same is true (and fixable here) for right-click in sub for actions allowing no multiple entries
if (_action.default || !_action.allowOnMultiple)
{
_ids.ids = [_senders[0].id];
}
// Translate the internal uids back to server uids // Translate the internal uids back to server uids
var idsArr = _ids.ids; var idsArr = _ids.ids;
for (var i = 0; i < idsArr.length; i++) for (var i = 0; i < idsArr.length; i++)
{ {
idsArr[i] = idsArr[i].split("::").pop();
// empty placeholder gets reported --> ignore it // empty placeholder gets reported --> ignore it
if (!idsArr[i]) if (!idsArr[i])
{ {
delete idsArr[i]; idsArr.splice(i,1);
i--; continue;
} }
idsArr[i] = idsArr[i].split("::").pop();
} }
// Calculate the ids parameters // Calculate the ids parameters
@ -337,34 +331,30 @@ var nm_popup_action, nm_popup_ids = null;
* *
* Popup needs to have eTemplate name of action id plus "_popup" * Popup needs to have eTemplate name of action id plus "_popup"
* *
* @param _action * @param {egwAction} _action
* @param _ids * @param {egwActionObject[]} _selected
*/ */
function nm_open_popup(_action, _ids) function nm_open_popup(_action, _selected)
{ {
//Check if there is nextmatch on _action otherwise gets the uniqueid from _ids //Check if there is nextmatch on _action otherwise gets the uniqueid from _ids
var uid; var uid;
if (typeof _action.data.nextmatch !== 'undefined') if (typeof _action.data.nextmatch !== 'undefined')
uid = _action.data.nextmatch.getInstanceManager().uniqueId; uid = _action.data.nextmatch.getInstanceManager().uniqueId;
else if(typeof _ids[0] !== 'undefined') else if(typeof _selected[0] !== 'undefined')
uid = _ids[0].manager.data.nextmatch.getInstanceManager().uniqueId; uid = _selected[0].manager.data.nextmatch.getInstanceManager().uniqueId;
// Find the popup div // Find the popup div
var popup = jQuery("#"+(uid||"") + "_"+_action.id+"_popup").first() || jQuery("[id*='" + _action.id + "_popup']").first(); var popup = jQuery("#"+(uid||"") + "_"+_action.id+"_popup").first() || jQuery("[id*='" + _action.id + "_popup']").first();
if (popup) { if (popup) {
nm_popup_action = _action; nm_popup_action = _action;
if(_ids.length && typeof _ids[0] == 'object') if(_selected.length && typeof _selected[0] == 'object')
{ {
egw().debug("warn", 'Not proper format for IDs, should be array',_ids); _action.data.nextmatch = _selected[0]._context._widget;
_action.data.nextmatch = _ids[0]._context._widget; nm_popup_ids = _selected
nm_popup_ids = [];
for(var i = 0; i < _ids.length; i++)
{
nm_popup_ids.push(_ids[i].id);
}
} }
else else
{ {
nm_popup_ids = _ids; egw().debug("warn", 'Not proper format for IDs, should be array of egwActionObject',_ids);
nm_popup_ids = _selected;
} }
var dialog = jQuery('.action_popup-content',popup); var dialog = jQuery('.action_popup-content',popup);
@ -451,16 +441,22 @@ function nm_submit_popup(button)
} }
// Mangle senders to get IDs where nm_action() wants them // Mangle senders to get IDs where nm_action() wants them
// No idea why this is needed if(nm_popup_ids.length && typeof nm_popup_ids[0] != 'object')
{
// Legacy ID just as string
var ids = {ids:[]}; var ids = {ids:[]};
for(var i in nm_popup_ids) for(var i in nm_popup_ids)
{ {
if(nm_popup_ids[i])
ids.ids.push(nm_popup_ids[i]); ids.ids.push(nm_popup_ids[i]);
} }
}
// call regular nm_action to transmit action and senders correct // call regular nm_action to transmit action and senders correct
nm_action(nm_popup_action,nm_popup_ids, button, ids); nm_action(nm_popup_action,nm_popup_ids, button, ids );
nm_hide_popup(button, null); nm_hide_popup(button, null);
nm_popup_ids = null;
} }
/** /**