From 8525d55080d7cd271821b52f1a2a9a6498e242fb Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Thu, 13 Feb 2014 10:06:18 +0000 Subject: [PATCH] fixed phone popup (opening on [More...]) does not show always shown numbers (work, cell, home, fax) and if they are prefered, also changes made to them get not propagated back --- addressbook/js/app.js | 84 ++++++++++++++++---------- addressbook/templates/default/edit.xet | 40 ++++++------ 2 files changed, 71 insertions(+), 53 deletions(-) diff --git a/addressbook/js/app.js b/addressbook/js/app.js index 0cb0fdd26b..8fcb94755a 100644 --- a/addressbook/js/app.js +++ b/addressbook/js/app.js @@ -157,45 +157,63 @@ app.classes.addressbook = AppJS.extend( nm_action(_action, _senders); }, - showphones: function(form) + /** + * [More...] in phones clicked: copy allways shown phone numbers to phone popup + * + * @param {jQuery.event} _event + * @param {et2_widget} _widget + */ + showphones: function(_event, _widget) { - if (form) { - copyvalues(form,"tel_home","tel_home2"); - copyvalues(form,"tel_work","tel_work2"); - copyvalues(form,"tel_cell","tel_cell2"); - copyvalues(form,"tel_fax","tel_fax2"); - } + this._copyvalues({ + tel_home: 'tel_home2', + tel_work: 'tel_work2', + tel_cell: 'tel_cell2', + tel_fax: 'tel_fax2', + }); + jQuery('table.editphones').css('display','inline'); + + _event.stopPropagation(); + return false; }, - hidephones: function(form) + /** + * [OK] in phone popup clicked: copy phone numbers back to always shown ones + * + * @param {jQuery.event} _event + * @param {et2_widget} _widget + */ + hidephones: function(_event, _widget) { - if (form) { - copyvalues(form,"tel_home2","tel_home"); - copyvalues(form,"tel_work2","tel_work"); - copyvalues(form,"tel_cell2","tel_cell"); - copyvalues(form,"tel_fax2","tel_fax"); - } + this._copyvalues({ + tel_home2: 'tel_home', + tel_work2: 'tel_work', + tel_cell2: 'tel_cell', + tel_fax2: 'tel_fax', + }); + jQuery('table.editphones').css('display','none'); + + _event.stopPropagation(); + return false; }, - copyvalues: function(form,src,dst) + /** + * Copy content of multiple fields + * + * @param {object} what object with src: dst pairs + */ + _copyvalues: function(what) { - var srcelement = getElement(form,src); //ById("exec["+src+"]"); - var dstelement = getElement(form,dst); //ById("exec["+dst+"]"); - if (srcelement && dstelement) { - dstelement.value = srcelement.value; - } - }, - - getElement: function(form,pattern) - { - for (i = 0; i < form.length; i++){ - if(form.elements[i].name){ - var found = form.elements[i].name.search("\\["+pattern+"\\]"); - if (found != -1){ - return form.elements[i]; - } - } + for(var name in what) + { + var src = this.et2.getWidgetById(name); + var dst = this.et2.getWidgetById(what[name]); + if (src && dst) dst.set_value(src.get_value()); } + // change tel_prefer according to what + var tel_prefer = this.et2.getWidgetById('tel_prefer'); + if (tel_prefer && typeof what[tel_prefer.get_value()] != 'undefined') + tel_prefer.set_value(what[tel_prefer.get_value()]); }, /** @@ -257,7 +275,7 @@ app.classes.addressbook = AppJS.extend( } } }, - + /** * * @param {widget} widget widget @@ -282,7 +300,7 @@ app.classes.addressbook = AppJS.extend( var name = template.widgetContainer.getWidgetById("n_fn"); if (typeof name != 'undefined') name.set_value(value); } - + egw.json('addressbook.addressbook_ui.ajax_check_values', [values, widget.id, own_id],this._confirmdialog_callback,this,true,this).sendRequest(); }, diff --git a/addressbook/templates/default/edit.xet b/addressbook/templates/default/edit.xet index 79f79b3528..3f1d6ca02c 100644 --- a/addressbook/templates/default/edit.xet +++ b/addressbook/templates/default/edit.xet @@ -52,11 +52,11 @@ - +