user-menu.directive.js
Home
/
ui /
src /
app /
layout /
user-menu.directive.js
import './user-menu.scss';
import userMenuTemplate from './user-menu.tpl.html';
export default angular.module('thingsboard.directives.usermenu', [])
.directive('tbUserMenu', UserMenu)
.name;
function UserMenu() {
return {
restrict: "E",
scope: true,
bindToController: {
displayUserInfo: '=',
},
controller: UserMenuController,
controllerAs: 'vm',
templateUrl: userMenuTemplate
};
}
function UserMenuController($scope, userService, $translate, $state) {
var vm = this;
var dashboardUser = userService.getCurrentUser();
vm.authorityName = authorityName;
vm.logout = logout;
vm.openProfile = openProfile;
vm.userDisplayName = userDisplayName;
function authorityName() {
var name = "user.anonymous";
if (dashboardUser) {
var authority = dashboardUser.authority;
if (authority === 'SYS_ADMIN') {
name = 'user.sys-admin';
} else if (authority === 'TENANT_ADMIN') {
name = 'user.tenant-admin';
} else if (authority === 'CUSTOMER_USER') {
name = 'user.customer';
}
}
return $translate.instant(name);
}
function userDisplayName() {
var name = "";
if (dashboardUser) {
if ((dashboardUser.firstName && dashboardUser.firstName.length > 0) ||
(dashboardUser.lastName && dashboardUser.lastName.length > 0)) {
if (dashboardUser.firstName) {
name += dashboardUser.firstName;
}
if (dashboardUser.lastName) {
if (name.length > 0) {
name += " ";
}
name += dashboardUser.lastName;
}
} else {
name = dashboardUser.email;
}
}
return name;
}
function openProfile() {
$state.go('home.profile');
}
function logout() {
userService.logout();
}
}