2016-06-14 08:31:48 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const router = require('../router.js');
|
|
|
|
const api = require('../api.js');
|
2017-01-20 20:51:04 +00:00
|
|
|
const uri = require('../util/uri.js');
|
2016-08-22 19:38:21 +00:00
|
|
|
const misc = require('../util/misc.js');
|
2016-06-14 08:31:48 +00:00
|
|
|
const config = require('../config.js');
|
|
|
|
const views = require('../util/views.js');
|
2016-06-19 17:16:40 +00:00
|
|
|
const User = require('../models/user.js');
|
2016-06-14 08:31:48 +00:00
|
|
|
const topNavigation = require('../models/top_navigation.js');
|
|
|
|
const UserView = require('../views/user_view.js');
|
|
|
|
const EmptyView = require('../views/empty_view.js');
|
|
|
|
|
|
|
|
class UserController {
|
|
|
|
constructor(ctx, section) {
|
2016-08-23 19:18:03 +00:00
|
|
|
const userName = ctx.parameters.name;
|
|
|
|
if (!api.hasPrivilege('users:view') &&
|
|
|
|
!api.isLoggedIn({name: userName})) {
|
|
|
|
this._view = new EmptyView();
|
|
|
|
this._view.showError('You don\'t have privileges to view users.');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
topNavigation.setTitle('User ' + userName);
|
|
|
|
User.get(userName).then(user => {
|
2016-06-14 08:31:48 +00:00
|
|
|
const isLoggedIn = api.isLoggedIn(user);
|
|
|
|
const infix = isLoggedIn ? 'self' : 'any';
|
|
|
|
|
2016-08-23 19:18:03 +00:00
|
|
|
this._name = userName;
|
2016-08-28 21:55:45 +00:00
|
|
|
user.addEventListener('change', e => this._evtSaved(e, section));
|
2016-06-19 17:16:40 +00:00
|
|
|
|
2016-06-14 08:31:48 +00:00
|
|
|
const myRankIndex = api.user ?
|
|
|
|
api.allRanks.indexOf(api.user.rank) :
|
|
|
|
0;
|
|
|
|
let ranks = {};
|
|
|
|
for (let [rankIdx, rankIdentifier] of api.allRanks.entries()) {
|
|
|
|
if (rankIdentifier === 'anonymous') {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (rankIdx > myRankIndex) {
|
|
|
|
continue;
|
|
|
|
}
|
2016-06-19 17:16:40 +00:00
|
|
|
ranks[rankIdentifier] = api.rankNames.get(rankIdentifier);
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (isLoggedIn) {
|
|
|
|
topNavigation.activate('account');
|
|
|
|
} else {
|
|
|
|
topNavigation.activate('users');
|
|
|
|
}
|
|
|
|
this._view = new UserView({
|
|
|
|
user: user,
|
|
|
|
section: section,
|
|
|
|
isLoggedIn: isLoggedIn,
|
|
|
|
canEditName: api.hasPrivilege(`users:edit:${infix}:name`),
|
|
|
|
canEditPassword: api.hasPrivilege(`users:edit:${infix}:pass`),
|
|
|
|
canEditEmail: api.hasPrivilege(`users:edit:${infix}:email`),
|
|
|
|
canEditRank: api.hasPrivilege(`users:edit:${infix}:rank`),
|
|
|
|
canEditAvatar: api.hasPrivilege(`users:edit:${infix}:avatar`),
|
|
|
|
canEditAnything: api.hasPrivilege(`users:edit:${infix}`),
|
|
|
|
canDelete: api.hasPrivilege(`users:delete:${infix}`),
|
|
|
|
ranks: ranks,
|
|
|
|
});
|
2016-08-22 19:38:21 +00:00
|
|
|
this._view.addEventListener('change', e => this._evtChange(e));
|
2016-08-22 18:45:58 +00:00
|
|
|
this._view.addEventListener('submit', e => this._evtUpdate(e));
|
2016-06-14 08:31:48 +00:00
|
|
|
this._view.addEventListener('delete', e => this._evtDelete(e));
|
2017-01-08 01:12:38 +00:00
|
|
|
}, error => {
|
2016-06-14 08:31:48 +00:00
|
|
|
this._view = new EmptyView();
|
2017-01-08 01:12:38 +00:00
|
|
|
this._view.showError(error.message);
|
2016-06-14 08:31:48 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-08-22 19:38:21 +00:00
|
|
|
_evtChange(e) {
|
|
|
|
misc.enableExitConfirmation();
|
|
|
|
}
|
|
|
|
|
2016-08-28 21:55:45 +00:00
|
|
|
_evtSaved(e, section) {
|
2016-08-22 19:38:21 +00:00
|
|
|
misc.disableExitConfirmation();
|
2016-06-19 17:16:40 +00:00
|
|
|
if (this._name !== e.detail.user.name) {
|
|
|
|
router.replace(
|
2017-01-20 20:51:04 +00:00
|
|
|
uri.formatClientLink('user', e.detail.user.name, section),
|
|
|
|
null, false);
|
2016-06-19 17:16:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-22 18:45:58 +00:00
|
|
|
_evtUpdate(e) {
|
2016-06-14 08:31:48 +00:00
|
|
|
this._view.clearMessages();
|
|
|
|
this._view.disableForm();
|
|
|
|
const isLoggedIn = api.isLoggedIn(e.detail.user);
|
|
|
|
const infix = isLoggedIn ? 'self' : 'any';
|
|
|
|
|
2016-06-19 17:16:40 +00:00
|
|
|
if (e.detail.name !== undefined) {
|
|
|
|
e.detail.user.name = e.detail.name;
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
2016-06-19 17:16:40 +00:00
|
|
|
if (e.detail.email !== undefined) {
|
|
|
|
e.detail.user.email = e.detail.email;
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
2016-06-19 17:16:40 +00:00
|
|
|
if (e.detail.rank !== undefined) {
|
|
|
|
e.detail.user.rank = e.detail.rank;
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
2016-06-19 17:16:40 +00:00
|
|
|
|
|
|
|
if (e.detail.password !== undefined) {
|
|
|
|
e.detail.user.password = e.detail.password;
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
2016-06-19 17:16:40 +00:00
|
|
|
|
|
|
|
if (e.detail.avatarStyle !== undefined) {
|
|
|
|
e.detail.user.avatarStyle = e.detail.avatarStyle;
|
|
|
|
if (e.detail.avatarContent) {
|
|
|
|
e.detail.user.avatarContent = e.detail.avatarContent;
|
|
|
|
}
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
|
|
|
|
2016-06-19 17:16:40 +00:00
|
|
|
e.detail.user.save().then(() => {
|
|
|
|
return isLoggedIn ?
|
|
|
|
api.login(
|
|
|
|
e.detail.name || api.userName,
|
|
|
|
e.detail.password || api.userPassword,
|
|
|
|
false) :
|
|
|
|
Promise.resolve();
|
|
|
|
}).then(() => {
|
|
|
|
this._view.showSuccess('Settings updated.');
|
|
|
|
this._view.enableForm();
|
2017-01-08 01:12:38 +00:00
|
|
|
}, error => {
|
|
|
|
this._view.showError(error.message);
|
2016-06-19 17:16:40 +00:00
|
|
|
this._view.enableForm();
|
|
|
|
});
|
2016-06-14 08:31:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
_evtDelete(e) {
|
|
|
|
this._view.clearMessages();
|
|
|
|
this._view.disableForm();
|
|
|
|
const isLoggedIn = api.isLoggedIn(e.detail.user);
|
2016-06-19 17:16:40 +00:00
|
|
|
e.detail.user.delete()
|
|
|
|
.then(() => {
|
2016-06-14 08:31:48 +00:00
|
|
|
if (isLoggedIn) {
|
|
|
|
api.forget();
|
|
|
|
api.logout();
|
|
|
|
}
|
|
|
|
if (api.hasPrivilege('users:list')) {
|
2017-01-20 20:51:04 +00:00
|
|
|
const ctx = router.show(uri.formatClientLink('users'));
|
2016-06-14 08:31:48 +00:00
|
|
|
ctx.controller.showSuccess('Account deleted.');
|
|
|
|
} else {
|
2017-01-20 20:51:04 +00:00
|
|
|
const ctx = router.show(uri.formatClientLink());
|
2016-06-14 08:31:48 +00:00
|
|
|
ctx.controller.showSuccess('Account deleted.');
|
|
|
|
}
|
2017-01-08 01:12:38 +00:00
|
|
|
}, error => {
|
|
|
|
this._view.showError(error.message);
|
2016-06-14 08:31:48 +00:00
|
|
|
this._view.enableForm();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = router => {
|
2017-01-20 20:51:04 +00:00
|
|
|
router.enter(['user', ':name'], (ctx, next) => {
|
2016-06-14 08:31:48 +00:00
|
|
|
ctx.controller = new UserController(ctx, 'summary');
|
|
|
|
});
|
2017-01-20 20:51:04 +00:00
|
|
|
router.enter(['user', ':name', 'edit'], (ctx, next) => {
|
2016-06-14 08:31:48 +00:00
|
|
|
ctx.controller = new UserController(ctx, 'edit');
|
|
|
|
});
|
2017-01-20 20:51:04 +00:00
|
|
|
router.enter(['user', ':name', 'delete'], (ctx, next) => {
|
2016-06-14 08:31:48 +00:00
|
|
|
ctx.controller = new UserController(ctx, 'delete');
|
|
|
|
});
|
|
|
|
};
|