Files
gerrit/polygerrit-ui/app/elements/shared/gr-account-label/gr-account-label.js
Dave Borowitz 8cdc76ba4c Add @license tags to PG HTML and JS assets
These tags are preserved by the Closure compiler and vulcanize in order
to serve the license notices embedded in the outputs. In a standalone
Gerrit server, these license are also covered in the LICENSES.txt served
with the documentation. When serving PG assets from a CDN, it's less
obvious what the corresponding LICENSES.txt file is, since the CDN is
not directly linked to a running Gerrit server. Safer to embed the
licenses in the assets themselves.

Change-Id: Id1add1451fad1baa7916882a6bda02c326ccc988
2018-03-26 10:47:55 -04:00

104 lines
2.6 KiB
JavaScript

/**
* @license
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
(function() {
'use strict';
Polymer({
is: 'gr-account-label',
properties: {
/**
* @type {{ name: string, status: string }}
*/
account: Object,
avatarImageSize: {
type: Number,
value: 32,
},
title: {
type: String,
reflectToAttribute: true,
computed: '_computeAccountTitle(account, additionalText)',
},
additionalText: String,
hasTooltip: {
type: Boolean,
reflectToAttribute: true,
computed: '_computeHasTooltip(account)',
},
hideAvatar: {
type: Boolean,
value: false,
},
_serverConfig: {
type: Object,
value: null,
},
},
behaviors: [
Gerrit.AnonymousNameBehavior,
Gerrit.TooltipBehavior,
],
ready() {
if (!this.additionalText) { this.additionalText = ''; }
this.$.restAPI.getConfig()
.then(config => { this._serverConfig = config; });
},
_computeName(account, config) {
return this.getUserName(config, account, false);
},
_computeAccountTitle(account, tooltip) {
if (!account) { return; }
let result = '';
if (this._computeName(account, this._serverConfig)) {
result += this._computeName(account, this._serverConfig);
}
if (account.email) {
result += ' <' + account.email + '>';
}
if (this.additionalText) {
return result + ' ' + this.additionalText;
}
return result;
},
_computeShowEmailClass(account) {
if (!account || account.name || !account.email) { return ''; }
return 'showEmail';
},
_computeEmailStr(account) {
if (!account || !account.email) {
return '';
}
if (account.name) {
return '(' + account.email + ')';
}
return account.email;
},
_computeHasTooltip(account) {
// If an account has loaded to fire this method, then set to true.
return !!account;
},
});
})();