nginx-proxy-manager/frontend/js/app/ui/header/main.js

68 lines
1.8 KiB
JavaScript
Raw Normal View History

2018-06-19 18:48:14 -04:00
const $ = require('jquery');
const Mn = require('backbone.marionette');
2018-07-18 00:28:41 -04:00
const i18n = require('../../i18n');
2018-06-19 18:48:14 -04:00
const Cache = require('../../cache');
const Controller = require('../../controller');
const Tokens = require('../../tokens');
const template = require('./main.ejs');
module.exports = Mn.View.extend({
id: 'header',
className: 'header',
template: template,
ui: {
link: 'a',
details: 'a.edit-details',
password: 'a.change-password'
2018-06-19 18:48:14 -04:00
},
events: {
'click @ui.details': function (e) {
e.preventDefault();
Controller.showUserForm(Cache.User);
},
'click @ui.password': function (e) {
e.preventDefault();
Controller.showUserPasswordForm(Cache.User);
},
2018-06-19 18:48:14 -04:00
'click @ui.link': function (e) {
e.preventDefault();
let href = $(e.currentTarget).attr('href');
switch (href) {
case '/':
Controller.showDashboard();
break;
case '/logout':
Controller.logout();
break;
}
}
},
templateContext: {
getUserField: function (field, default_val) {
return Cache.User.get(field) || default_val;
},
getRole: function () {
2018-07-18 00:28:41 -04:00
return i18n('roles', Cache.User.isAdmin() ? 'admin' : 'user');
2018-06-19 18:48:14 -04:00
},
getLogoutText: function () {
if (Tokens.getTokenCount() > 1) {
2018-07-18 00:28:41 -04:00
return i18n('main', 'sign-in-as', {name: Tokens.getNextTokenName()});
2018-06-19 18:48:14 -04:00
}
2018-07-18 02:55:09 -04:00
return i18n('str', 'sign-out');
2018-06-19 18:48:14 -04:00
}
2018-07-08 21:22:10 -04:00
},
initialize: function () {
this.listenTo(Cache.User, 'change', this.render);
2018-06-19 18:48:14 -04:00
}
});