diff --git a/addressbook/lang/egw_de.lang b/addressbook/lang/egw_de.lang index db83580086..def63ce122 100644 --- a/addressbook/lang/egw_de.lang +++ b/addressbook/lang/egw_de.lang @@ -451,6 +451,7 @@ select the type of conversion: addressbook de Typ der Umwandlung auswählen: select where you want to store / retrieve contacts admin de Auswählen wo Sie Adressen speichern möchten selected contacts addressbook de ausgewählte Kontakte send emailcopy to receiver addressbook de Versendet eine Kopie der E-Mail zu dem Empfänger +send fax via email by replacing fax number with an email address addressbook de Fax per Email senden durch ersetzen der Faxnummer mit einer Email Adresse send succeeded to %1 common de erfolgreich versandt an seperator addressbook de Feldtrenner set full name and file as field in contacts of all users (either all or only empty values) admin de Setzt vollen Namen und eigene Sortierung in Kontakten aller Benutzer (entweder alle oder nur leere Werte) diff --git a/addressbook/lang/egw_en.lang b/addressbook/lang/egw_en.lang index df1006285f..e0b73e70b0 100644 --- a/addressbook/lang/egw_en.lang +++ b/addressbook/lang/egw_en.lang @@ -451,6 +451,7 @@ select the type of conversion: addressbook en Select the type of conversion: select where you want to store / retrieve contacts admin en Select where contacts should be stored / retrieved. selected contacts addressbook en Selected contacts send emailcopy to receiver addressbook en Send email copy to receiver +send fax via email by replacing fax number with an email address addressbook en Send fax via email by replacing fax number with an email address send succeeded to %1 common en Send succeeded to %1 seperator addressbook en Separator set full name and file as field in contacts of all users (either all or only empty values) admin en Set full name and 'fileas' field in contacts of all users. Either all or only empty values. diff --git a/addressbook/templates/default/config.xet b/addressbook/templates/default/config.xet index 68823d81fe..cae9f0d790 100644 --- a/addressbook/templates/default/config.xet +++ b/addressbook/templates/default/config.xet @@ -20,6 +20,13 @@ + + + + + + + diff --git a/addressbook/templates/default/edit.xet b/addressbook/templates/default/edit.xet index 4cc96116b9..0fba3c2837 100644 --- a/addressbook/templates/default/edit.xet +++ b/addressbook/templates/default/edit.xet @@ -79,7 +79,7 @@ - + @@ -112,7 +112,7 @@ - + @@ -232,7 +232,7 @@ - + @@ -264,7 +264,7 @@ - + diff --git a/addressbook/templates/default/index.xet b/addressbook/templates/default/index.xet index 658a630b74..e927665cf0 100644 --- a/addressbook/templates/default/index.xet +++ b/addressbook/templates/default/index.xet @@ -142,7 +142,7 @@ - + diff --git a/api/js/etemplate/et2_widget_url.js b/api/js/etemplate/et2_widget_url.js index 7c7a2b06de..05ecb58eed 100644 --- a/api/js/etemplate/et2_widget_url.js +++ b/api/js/etemplate/et2_widget_url.js @@ -8,7 +8,6 @@ * @link http://www.egroupware.org * @author Nathan Gray * @copyright Nathan Gray 2011 - * @version $Id$ */ var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { @@ -93,6 +92,7 @@ var et2_url = /** @class */ (function (_super_1) { this._button.attr("href", _value).attr("target", "_blank").addClass("url"); break; case "url-phone": + case "url-fax": if (_value) { if (typeof _value == 'function') { this._button.click(this, _value).addClass("phone").show(); @@ -128,6 +128,12 @@ var et2_url = /** @class */ (function (_super_1) { et2_url.prototype.get_link = function (type, value) { if (!value) return false; + // convert fax numbers to email, if configured + if (type === 'url-fax' && this.egw().config('fax_email') && + (value = value.replace('♥', '').replace('(0)', '').replace(/[^0-9+]/g, ''))) { + value = value.replace(new RegExp(this.egw().config('fax_email_regexp') || '(.*)'), this.egw().config('fax_email')); + type = 'url-email'; + } switch (type) { case "url": // Silently use http if no protocol @@ -135,6 +141,7 @@ var et2_url = /** @class */ (function (_super_1) { value = "http://" + value; break; case "url-phone": + case "url-fax": // Clean number value = value.replace('♥', '').replace('(0)', ''); value = value.replace(/[abc]/gi, 2).replace(/[def]/gi, 3).replace(/[ghi]/gi, 4).replace(/[jkl]/gi, 5).replace(/[mno]/gi, 6); @@ -274,7 +281,7 @@ var et2_url = /** @class */ (function (_super_1) { et2_url.EMAIL_PREG = new RegExp(/^(([^\042',<][^,<]+|\042[^\042]+\042|\'[^\']+\'|"(?:[^"\\]|\\.)*")\s?<)?[^\x00-\x20()\xe2\x80\x8b<>@,;:\042\[\]\x80-\xff]+@([a-z0-9ÄÖÜäöüß](|[a-z0-9ÄÖÜäöüß_-]*[a-z0-9ÄÖÜäöüß])\.)+[a-z]{2,}>?$/i); return et2_url; }(et2_widget_textbox_1.et2_textbox)); -et2_core_widget_1.et2_register_widget(et2_url, ["url", "url-email", "url-phone"]); +et2_core_widget_1.et2_register_widget(et2_url, ["url", "url-email", "url-phone", "url-fax"]); /** * et2_url_ro is the readonly implementation of the url, email & phone. * It renders things as links, when possible @@ -323,6 +330,7 @@ var et2_url_ro = /** @class */ (function (_super_1) { this.span.attr("href", link).attr("target", "_blank"); break; case "url-phone": + case "url-fax": if (typeof link == 'function') { this.span.off('click.et2_url'); this.span.on('click.et2_url', link); @@ -464,5 +472,5 @@ var et2_url_ro = /** @class */ (function (_super_1) { et2_url_ro.email_cache = []; return et2_url_ro; }(et2_core_valueWidget_1.et2_valueWidget)); -et2_core_widget_1.et2_register_widget(et2_url_ro, ["url_ro", "url-email_ro", "url-phone_ro"]); +et2_core_widget_1.et2_register_widget(et2_url_ro, ["url_ro", "url-email_ro", "url-phone_ro", "url-fax_ro"]); //# sourceMappingURL=et2_widget_url.js.map \ No newline at end of file diff --git a/api/js/etemplate/et2_widget_url.ts b/api/js/etemplate/et2_widget_url.ts index 44a0e20d5f..85ef31a20b 100644 --- a/api/js/etemplate/et2_widget_url.ts +++ b/api/js/etemplate/et2_widget_url.ts @@ -7,7 +7,6 @@ * @link http://www.egroupware.org * @author Nathan Gray * @copyright Nathan Gray 2011 - * @version $Id$ */ /*egw:uses @@ -129,6 +128,7 @@ class et2_url extends et2_textbox this._button.attr("href", _value).attr("target", "_blank").addClass("url"); break; case "url-phone": + case "url-fax": if(_value) { if(typeof _value == 'function') { @@ -168,6 +168,14 @@ class et2_url extends et2_textbox get_link(type, value) { if(!value) return false; + // convert fax numbers to email, if configured + if (type === 'url-fax' && this.egw().config('fax_email') && + (value = value.replace('♥','').replace('(0)','').replace(/[^0-9+]/g, ''))) + { + value = value.replace(new RegExp(this.egw().config('fax_email_regexp')||'(.*)'), + this.egw().config('fax_email')); + type = 'url-email'; + } switch(type) { case "url": @@ -175,6 +183,7 @@ class et2_url extends et2_textbox if(value.indexOf("://") == -1) value = "http://"+value; break; case "url-phone": + case "url-fax": // Clean number value = value.replace('♥','').replace('(0)',''); value = value.replace(/[abc]/gi,2).replace(/[def]/gi,3).replace(/[ghi]/gi,4).replace(/[jkl]/gi,5).replace(/[mno]/gi,6); @@ -289,7 +298,7 @@ class et2_url extends et2_textbox return res; } } -et2_register_widget(et2_url, ["url", "url-email", "url-phone"]); +et2_register_widget(et2_url, ["url", "url-email", "url-phone", "url-fax"]); /** * et2_url_ro is the readonly implementation of the url, email & phone. @@ -363,6 +372,7 @@ class et2_url_ro extends et2_valueWidget this.span.attr("href", link).attr("target", "_blank"); break; case "url-phone": + case "url-fax": if(typeof link == 'function') { this.span.off('click.et2_url'); @@ -522,5 +532,5 @@ class et2_url_ro extends et2_valueWidget this.span.attr('title',_values.statustext ? _values.statustext : this.options.statustext); } } -et2_register_widget(et2_url_ro, ["url_ro", "url-email_ro", "url-phone_ro"]); +et2_register_widget(et2_url_ro, ["url_ro", "url-email_ro", "url-phone_ro", "url-fax_ro"]); diff --git a/api/src/Config.php b/api/src/Config.php index 8ef97323cc..bc90e47eb6 100755 --- a/api/src/Config.php +++ b/api/src/Config.php @@ -256,7 +256,7 @@ class Config 'checkfornewversion','checkappversions','email_address_format', // admin >> site config 'site_title','login_logo_file','login_logo_url','login_logo_title','favicon_file', 'markuntranslated','link_list_thumbnail','enabled_spellcheck','debug_minify', - 'call_link','call_popup','geolocation_url', // addressbook + 'call_link','call_popup','fax_email','fax_email_regexp','geolocation_url', // addressbook 'hide_birthdays','calview_no_consolidate', 'egw_tutorial_disable','fw_mobile_app_list'), // calendar 'projectmanager' => array('hours_per_workday', 'duration_units'), 'manual' => array('manual_remote_egw_url'),