egroupware_official/api/js/etemplate/Et2Url/Et2UrlPhone.ts

70 lines
2.2 KiB
TypeScript
Raw Normal View History

/**
* EGroupware eTemplate2 - Phone input widget
*
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package api
* @link https://www.egroupware.org
* @author Ralf Becker
*/
/* eslint-disable import/no-extraneous-dependencies */
import {Et2InvokerMixin} from "./Et2InvokerMixin";
import {Et2Textbox} from "../Et2Textbox/Et2Textbox";
/**
* @customElement et2-url-phone
*/
export class Et2UrlPhone extends Et2InvokerMixin(Et2Textbox)
{
constructor()
{
super();
//this.defaultValidators.push(...);
this._invokerLabel = '✆';
this._invokerTitle = 'Call';
this._invokerAction = () => {
Et2UrlPhone.action(this.value);
}
}
static action(value)
{
// 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);
value = value.replace(/[pqrs]/gi,7).replace(/[tuv]/gi,8).replace(/[wxyz]/gi,9);
// remove everything but numbers and plus, as telephon software might not like it
value = value.replace(/[^0-9+]/g, '');
// mobile Webkit (iPhone, Android) have precedence over server configuration!
if (navigator.userAgent.indexOf('AppleWebKit') !== -1 &&
(navigator.userAgent.indexOf("iPhone") !== -1 || navigator.userAgent.indexOf("Android") !== -1))
{
window.open("tel:"+value);
}
else if (egw.config("call_link"))
{
var link = egw.config("call_link")
// tel: links use no URL encoding according to rfc3966 section-5.1.4
.replace("%1", egw.config("call_link").substr(0, 4) == 'tel:' ?
value : encodeURIComponent(value))
.replace("%u",egw.user('account_lid'))
.replace("%t",egw.user('account_phone'));
var popup = egw.config("call_popup");
if (popup && popup !== '_self' || !link.match(/^https?:/)) // execute non-http(s) links eg. tel: like before
{
egw.open_link(link, '_phonecall', popup);
}
else
{
// No popup, use AJAX. We don't care about the response.
window.fetch(link, {
headers: { 'Content-Type': 'application/json'},
method: "GET",
});
}
}
}
}
// @ts-ignore TypeScript is not recognizing that this is a LitElement
customElements.define("et2-url-phone", Et2UrlPhone);