|  | /** | 
|  | * @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'; | 
|  |  | 
|  | const INTERPOLATE_URL_PATTERN = /\$\{([\w]+)\}/g; | 
|  |  | 
|  | /** | 
|  | * @appliesMixin Gerrit.DisplayNameMixin | 
|  | */ | 
|  | class GrAccountDropdown extends Polymer.mixinBehaviors( [ | 
|  | Gerrit.DisplayNameBehavior, | 
|  | ], Polymer.GestureEventListeners( | 
|  | Polymer.LegacyElementMixin( | 
|  | Polymer.Element))) { | 
|  | static get is() { return 'gr-account-dropdown'; } | 
|  |  | 
|  | static get properties() { | 
|  | return { | 
|  | account: Object, | 
|  | config: Object, | 
|  | links: { | 
|  | type: Array, | 
|  | computed: '_getLinks(_switchAccountUrl, _path)', | 
|  | }, | 
|  | topContent: { | 
|  | type: Array, | 
|  | computed: '_getTopContent(account)', | 
|  | }, | 
|  | _path: { | 
|  | type: String, | 
|  | value: '/', | 
|  | }, | 
|  | _hasAvatars: Boolean, | 
|  | _switchAccountUrl: String, | 
|  | }; | 
|  | } | 
|  |  | 
|  | attached() { | 
|  | super.attached(); | 
|  | this._handleLocationChange(); | 
|  | this.listen(window, 'location-change', '_handleLocationChange'); | 
|  | this.$.restAPI.getConfig().then(cfg => { | 
|  | this.config = cfg; | 
|  |  | 
|  | if (cfg && cfg.auth && cfg.auth.switch_account_url) { | 
|  | this._switchAccountUrl = cfg.auth.switch_account_url; | 
|  | } else { | 
|  | this._switchAccountUrl = ''; | 
|  | } | 
|  | this._hasAvatars = !!(cfg && cfg.plugin && cfg.plugin.has_avatars); | 
|  | }); | 
|  | } | 
|  |  | 
|  | detached() { | 
|  | super.detached(); | 
|  | this.unlisten(window, 'location-change', '_handleLocationChange'); | 
|  | } | 
|  |  | 
|  | _getLinks(switchAccountUrl, path) { | 
|  | // Polymer 2: check for undefined | 
|  | if ([switchAccountUrl, path].some(arg => arg === undefined)) { | 
|  | return undefined; | 
|  | } | 
|  |  | 
|  | const links = [{name: 'Settings', url: '/settings/'}]; | 
|  | if (switchAccountUrl) { | 
|  | const replacements = {path}; | 
|  | const url = this._interpolateUrl(switchAccountUrl, replacements); | 
|  | links.push({name: 'Switch account', url, external: true}); | 
|  | } | 
|  | links.push({name: 'Sign out', url: '/logout'}); | 
|  | return links; | 
|  | } | 
|  |  | 
|  | _getTopContent(account) { | 
|  | return [ | 
|  | {text: this._accountName(account), bold: true}, | 
|  | {text: account.email ? account.email : ''}, | 
|  | ]; | 
|  | } | 
|  |  | 
|  | _handleLocationChange() { | 
|  | this._path = | 
|  | window.location.pathname + | 
|  | window.location.search + | 
|  | window.location.hash; | 
|  | } | 
|  |  | 
|  | _interpolateUrl(url, replacements) { | 
|  | return url.replace(INTERPOLATE_URL_PATTERN, (match, p1) => { | 
|  | return replacements[p1] || ''; | 
|  | }); | 
|  | } | 
|  |  | 
|  | _accountName(account) { | 
|  | return this.getUserName(this.config, account, true); | 
|  | } | 
|  | } | 
|  |  | 
|  | customElements.define(GrAccountDropdown.is, GrAccountDropdown); | 
|  | })(); |