szurubooru/public_html/js/Presenters/TopNavigationPresenter.js

78 lines
1.8 KiB
JavaScript
Raw Normal View History

2014-08-31 23:22:56 +02:00
var App = App || {};
App.Presenters = App.Presenters || {};
2014-09-04 19:06:12 +02:00
App.Presenters.TopNavigationPresenter = function(
jQuery,
util,
promise,
auth) {
2014-08-31 23:22:56 +02:00
var selectedElement = null;
2014-09-02 23:07:50 +02:00
var $el = jQuery('#top-navigation');
2014-10-05 10:41:12 +02:00
var templates = {};
var baseTitle = document.title;
2014-09-02 09:36:42 +02:00
2014-09-17 22:37:49 +02:00
function init(args, loaded) {
promise.wait(util.promiseTemplate('top-navigation'))
2014-10-05 10:41:12 +02:00
.then(function(template) {
templates.topNavigation = template;
2014-09-17 22:37:49 +02:00
render();
loaded();
auth.startObservingLoginChanges('top-navigation', loginStateChanged);
});
2014-09-02 23:07:50 +02:00
}
2014-08-31 23:22:56 +02:00
function select(newSelectedElement) {
selectedElement = newSelectedElement;
2014-09-17 11:48:10 +02:00
$el.find('li a').removeClass('active');
$el.find('li.' + selectedElement).find('a').addClass('active');
2014-09-08 22:02:28 +02:00
}
2014-08-31 23:22:56 +02:00
2014-09-02 23:07:50 +02:00
function loginStateChanged() {
render();
}
2014-08-31 23:22:56 +02:00
function render() {
2014-10-05 10:41:12 +02:00
$el.html(templates.topNavigation({
loggedIn: auth.isLoggedIn(),
user: auth.getCurrentUser(),
2014-09-07 19:49:11 +02:00
canListUsers: auth.hasPrivilege(auth.privileges.listUsers),
2014-09-30 22:09:43 +02:00
canListPosts: auth.hasPrivilege(auth.privileges.listPosts),
2014-09-07 19:49:11 +02:00
canListTags: auth.hasPrivilege(auth.privileges.listTags),
canUploadPosts: auth.hasPrivilege(auth.privileges.uploadPosts),
}));
2014-09-17 11:48:10 +02:00
$el.find('li.' + selectedElement).find('a').addClass('active');
2014-09-08 22:02:28 +02:00
}
2014-08-31 23:22:56 +02:00
function focus() {
var $tmp = jQuery('<a href="#"> </a>');
$el.prepend($tmp);
$tmp.focus();
$tmp.remove();
}
2014-09-24 23:24:51 +02:00
function getBaseTitle() {
return baseTitle;
}
function changeTitle(subTitle) {
var newTitle = baseTitle;
if (subTitle) {
newTitle += ' - ' + subTitle;
}
document.title = newTitle;
}
2014-08-31 23:22:56 +02:00
return {
init: init,
2014-08-31 23:22:56 +02:00
render: render,
select: select,
focus: focus,
2014-09-24 23:24:51 +02:00
getBaseTitle: getBaseTitle,
changeTitle: changeTitle,
2014-08-31 23:22:56 +02:00
};
};
2014-10-05 10:41:12 +02:00
App.DI.registerSingleton('topNavigationPresenter', ['jQuery', 'util', 'promise', 'auth'], App.Presenters.TopNavigationPresenter);