mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-08 06:59:28 +01:00
96 lines
2.2 KiB
TypeScript
96 lines
2.2 KiB
TypeScript
|
/**
|
||
|
* EGroupware eTemplate2 - Letter Avatar widget
|
||
|
*
|
||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||
|
* @package etemplate
|
||
|
* @subpackage api
|
||
|
* @link https://www.egroupware.org
|
||
|
* @author Hadi Nategh
|
||
|
*/
|
||
|
|
||
|
import {Et2Avatar} from "./Et2Avatar";
|
||
|
import shoelace from "../Styles/shoelace";
|
||
|
import {css} from "@lion/core";
|
||
|
|
||
|
export class Et2LAvatar extends Et2Avatar
|
||
|
{
|
||
|
/**
|
||
|
* background color codes
|
||
|
*/
|
||
|
static LAVATAR_BG_COLORS : string[] = [
|
||
|
'#5a8770', '#b2b7bb', '#6fa9ab', '#f5af29',
|
||
|
'#0088b9', '#f18636', '#d93a37', '#a6b12e',
|
||
|
'#0088b9', '#f18636', '#d93a37', '#a6b12e',
|
||
|
'#5c9bbc', '#f5888d', '#9a89b5', '#407887',
|
||
|
'#9a89b5', '#5a8770', '#d33f33', '#a2b01f',
|
||
|
'#f0b126', '#0087bf', '#f18636', '#0087bf',
|
||
|
'#b2b7bb', '#72acae', '#9c8ab4', '#5a8770',
|
||
|
'#eeb424', '#407887'
|
||
|
];
|
||
|
|
||
|
static get styles()
|
||
|
{
|
||
|
return [
|
||
|
...super.styles,
|
||
|
shoelace,
|
||
|
css`
|
||
|
|
||
|
`
|
||
|
];
|
||
|
}
|
||
|
|
||
|
static get properties()
|
||
|
{
|
||
|
return {
|
||
|
...super.properties,
|
||
|
|
||
|
lname: {type: String},
|
||
|
|
||
|
fname: {type: String},
|
||
|
}
|
||
|
}
|
||
|
|
||
|
constructor()
|
||
|
{
|
||
|
super();
|
||
|
this.lname = "";
|
||
|
this.fname = "";
|
||
|
this.initials = Et2LAvatar.lavatar(this.fname, this.lname, this.contact_id).initials;
|
||
|
}
|
||
|
|
||
|
set src(_url)
|
||
|
{
|
||
|
if (_url && decodeURIComponent(_url).match("lavatar=1") && (this.options.fname || this.options.lname) && this.options.contact_id)
|
||
|
{
|
||
|
this.initials = Et2LAvatar.lavatar(this.options.fname, this.options.lname, this.options.contact_id).initials;
|
||
|
return;
|
||
|
}
|
||
|
super.src= _url;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Generate letter avatar with given data
|
||
|
* @param {type} _fname
|
||
|
* @param {type} _lname
|
||
|
* @param {type} _id
|
||
|
* @returns {string} return data url
|
||
|
*/
|
||
|
static lavatar(_fname, _lname, _id)
|
||
|
{
|
||
|
let str = _fname + _lname + _id;
|
||
|
let getBgColor = function(_str)
|
||
|
{
|
||
|
let hash = 0;
|
||
|
for (let i=0; i< _str.length; i++)
|
||
|
{
|
||
|
hash = _str[i].charCodeAt(0) + hash;
|
||
|
}
|
||
|
return Et2LAvatar.LAVATAR_BG_COLORS[hash % Et2LAvatar.LAVATAR_BG_COLORS.length];
|
||
|
};
|
||
|
let bg = getBgColor(str);
|
||
|
let text = (_fname ? _fname[0].toUpperCase() : "")+(_lname ? _lname[0].toUpperCase() : "");
|
||
|
return {background: bg, initials: text};
|
||
|
}
|
||
|
}
|
||
|
customElements.define("et2-lavatar", Et2LAvatar as any);
|