2016-06-13 22:34:39 +02:00
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
const events = require('../events.js');
|
2018-06-25 16:47:20 +02:00
|
|
|
|
const api = require('../api.js');
|
2016-06-13 22:34:39 +02:00
|
|
|
|
|
|
|
|
|
class TopNavigationItem {
|
|
|
|
|
constructor(accessKey, title, url, available, imageUrl) {
|
|
|
|
|
this.accessKey = accessKey;
|
|
|
|
|
this.title = title;
|
|
|
|
|
this.url = url;
|
|
|
|
|
this.available = available === undefined ? true : available;
|
|
|
|
|
this.imageUrl = imageUrl === undefined ? null : imageUrl;
|
|
|
|
|
this.key = null;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class TopNavigation extends events.EventTarget {
|
|
|
|
|
constructor() {
|
|
|
|
|
super();
|
|
|
|
|
this.activeItem = null;
|
|
|
|
|
this._keyToItem = new Map();
|
|
|
|
|
this._items = [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getAll() {
|
|
|
|
|
return this._items;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
get(key) {
|
|
|
|
|
if (!this._keyToItem.has(key)) {
|
|
|
|
|
throw `An item with key ${key} does not exist.`;
|
|
|
|
|
}
|
|
|
|
|
return this._keyToItem.get(key);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
add(key, item) {
|
|
|
|
|
item.key = key;
|
|
|
|
|
if (this._keyToItem.has(key)) {
|
|
|
|
|
throw `An item with key ${key} was already added.`;
|
|
|
|
|
}
|
|
|
|
|
this._keyToItem.set(key, item);
|
|
|
|
|
this._items.push(item);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
activate(key) {
|
|
|
|
|
this.activeItem = null;
|
2016-06-14 10:31:48 +02:00
|
|
|
|
this.dispatchEvent(new CustomEvent('activate', {
|
|
|
|
|
detail: {
|
|
|
|
|
key: key,
|
|
|
|
|
item: key ? this.get(key) : null,
|
|
|
|
|
},
|
|
|
|
|
}));
|
2016-06-13 22:34:39 +02:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-13 21:50:07 +02:00
|
|
|
|
setTitle(title) {
|
2018-06-25 16:47:20 +02:00
|
|
|
|
api.fetchConfig().then(() => {
|
|
|
|
|
document.oldTitle = null;
|
|
|
|
|
document.title = api.getName() + (title ? (' – ' + title) : '');
|
|
|
|
|
});
|
2016-07-13 21:50:07 +02:00
|
|
|
|
}
|
|
|
|
|
|
2016-06-13 22:34:39 +02:00
|
|
|
|
showAll() {
|
|
|
|
|
for (let item of this._items) {
|
|
|
|
|
item.available = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
show(key) {
|
|
|
|
|
this.get(key).available = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
hide(key) {
|
|
|
|
|
this.get(key).available = false;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function _makeTopNavigation() {
|
|
|
|
|
const ret = new TopNavigation();
|
2018-07-24 06:14:29 +02:00
|
|
|
|
ret.add('home', new TopNavigationItem('H', 'Home', ''));
|
|
|
|
|
ret.add('posts', new TopNavigationItem('P', 'Posts', 'posts'));
|
|
|
|
|
ret.add('upload', new TopNavigationItem('U', 'Upload', 'upload'));
|
|
|
|
|
ret.add('comments', new TopNavigationItem('C', 'Comments', 'comments'));
|
|
|
|
|
ret.add('tags', new TopNavigationItem('T', 'Tags', 'tags'));
|
|
|
|
|
ret.add('users', new TopNavigationItem('S', 'Users', 'users'));
|
|
|
|
|
ret.add('account', new TopNavigationItem('A', 'Account', 'user/{me}'));
|
|
|
|
|
ret.add('register', new TopNavigationItem('R', 'Register', 'register'));
|
|
|
|
|
ret.add('login', new TopNavigationItem('L', 'Log in', 'login'));
|
|
|
|
|
ret.add('logout', new TopNavigationItem('O', 'Logout', 'logout'));
|
|
|
|
|
ret.add('help', new TopNavigationItem('E', 'Help', 'help'));
|
2016-06-13 22:34:39 +02:00
|
|
|
|
ret.add(
|
|
|
|
|
'settings',
|
|
|
|
|
new TopNavigationItem(
|
|
|
|
|
null,
|
|
|
|
|
'<i class=\'fa fa-cog\'></i>',
|
2018-07-24 06:14:29 +02:00
|
|
|
|
'settings'));
|
2016-06-13 22:34:39 +02:00
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
module.exports = _makeTopNavigation();
|