Files
gerrit/polygerrit-ui/app/elements/core/gr-account-dropdown/gr-account-dropdown.js
Becky Siegel f8fb4c982d Introduce gr-dropdown element
Creates a new element based on the gr-account-dropdown that can also be
used to replace the css-only version in the main header.  gr-dropdown
accepts two arrays as input-- "items" for links and "topContent" for
text to display above the links. TopContent was needed for the account
dropdown use case, as it displays name and email address. It also
accepts a horizontal-align parameter.  gr-account-dropdown is refactored
to use the generalized element.

Bug: Issue 4666
Change-Id: I65905b81504d1daa46e78312f576bf7482a4577c
2016-11-30 14:04:08 -08:00

51 lines
1.4 KiB
JavaScript

// 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-dropdown',
properties: {
account: Object,
_hasAvatars: Boolean,
links: {
type: Array,
value: [
{name: 'Settings', url: '/settings'},
{name: 'Switch account', url: '/switch-account'},
{name: 'Sign out', url: '/logout'},
],
},
topContent: {
type: Array,
computed: '_getTopContent(account)',
},
},
attached: function() {
this.$.restAPI.getConfig().then(function(cfg) {
this._hasAvatars = !!(cfg && cfg.plugin && cfg.plugin.has_avatars);
}.bind(this));
},
_getTopContent: function(account) {
return [
{text: account.name, bold: true},
{text: account.email},
];
},
});
})();