/** * 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 = ""; } /** * Handle changes that have to happen based on changes to properties * */ updated(changedProperties) { super.updated(changedProperties); if(changedProperties.has("lname") || changedProperties.has("fname") || changedProperties.has("contact_id") || changedProperties.has("src")) { if(!this.src || decodeURIComponent(this.src).match("lavatar=1") && (this.fname || this.lname) && this.contact_id) { let lavatar = Et2LAvatar.lavatar(this.fname, this.lname, this.contact_id); this.initials = lavatar.initials; this._baseNode.style.backgroundColor = lavatar.background; } else if(this.src) { this.image = this.src; } if(this.lname || this.fname) { // Update tooltip - we don't have enough info for more than name but we can put it in the right order let label = (this.egw().preference("account_display", "common") || "firstname").includes("first") || !this.lname || !this.fname ? this.fname + " " + this.lname : this.lname + ", " + this.fname; if(label != this.statustext) { this.statustext = label.trim(); } } } } /** * */ getDetachedAttributes(_attrs : string[]) { super.getDetachedAttributes(_attrs); _attrs.push("lname", "fname"); } /** * 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);