Fixed user list presenter disrespecting privileges

If user had no right to view user accounts, the list presenter ignored
that and linked to pages that shown privilege errors. Now it shows the
links only if user has right to view user accounts.
This commit is contained in:
Marcin Kurczewski 2014-11-17 22:16:02 +01:00
parent 97482fb38e
commit 6a751ed0b2
3 changed files with 27 additions and 11 deletions

View file

@ -39,12 +39,14 @@
#user-list .user img { #user-list .user img {
vertical-align: top; vertical-align: top;
margin-right: 1em;
display: block; display: block;
} }
#user-list .user>a { #user-list .user .avatar {
display: block;
float: left; float: left;
margin-right: 1em;
}
#user-list .user .avatar a {
display: block;
} }
#user-list .user .details { #user-list .user .details {
float: left; float: left;

View file

@ -13,11 +13,14 @@ App.Presenters.UserListPresenter = function(
var $el = jQuery('#content'); var $el = jQuery('#content');
var templates = {}; var templates = {};
var params; var params;
var privileges = {};
function init(params, loaded) { function init(params, loaded) {
topNavigationPresenter.select('users'); topNavigationPresenter.select('users');
topNavigationPresenter.changeTitle('Users'); topNavigationPresenter.changeTitle('Users');
privileges.canViewUsers = auth.hasPrivilege(auth.privileges.viewUsers);
promise.wait( promise.wait(
util.promiseTemplate('user-list'), util.promiseTemplate('user-list'),
util.promiseTemplate('user-list-item')) util.promiseTemplate('user-list-item'))
@ -60,7 +63,7 @@ App.Presenters.UserListPresenter = function(
} }
function render() { function render() {
$el.html(templates.list()); $el.html(templates.list(privileges));
} }
function updateActiveOrder(activeOrder) { function updateActiveOrder(activeOrder) {
@ -71,10 +74,10 @@ App.Presenters.UserListPresenter = function(
function renderUsers($page, users) { function renderUsers($page, users) {
var $target = $page.find('.users'); var $target = $page.find('.users');
_.each(users, function(user) { _.each(users, function(user) {
var $item = jQuery('<li>' + templates.listItem({ var $item = jQuery('<li>' + templates.listItem(_.extend({
user: user, user: user,
formatRelativeTime: util.formatRelativeTime, formatRelativeTime: util.formatRelativeTime,
}) + '</li>'); }, privileges)) + '</li>');
$target.append($item); $target.append($item);
}); });
_.map(_.map($target.find('img'), jQuery), util.loadImagesNicely); _.map(_.map($target.find('img'), jQuery), util.loadImagesNicely);

View file

@ -1,12 +1,23 @@
<div class="user"> <div class="user">
<a href="#/user/<%= user.name %>"> <div class="avatar">
<img width="80" height="80" src="/data/thumbnails/80x80/avatars/<%= user.name %>" alt="<%= user.name %>"/> <% if (canViewUsers) { %>
</a> <a href="#/user/<%= user.name %>">
<% } %>
<img width="80" height="80" src="/data/thumbnails/80x80/avatars/<%= user.name %>" alt="<%= user.name %>"/>
<% if (canViewUsers) { %>
</a>
<% } %>
</div>
<div class="details"> <div class="details">
<h1> <h1>
<a href="#/user/<%= user.name %>"> <% if (canViewUsers) { %>
<a href="#/user/<%= user.name %>">
<%= user.name %>
</a>
<% } else { %>
<%= user.name %> <%= user.name %>
</a> <% } %>
</h1> </h1>
<div class="date-joined" title="<%= user.registrationTime %>"> <div class="date-joined" title="<%= user.registrationTime %>">
Joined: <%= formatRelativeTime(user.registrationTime) %> Joined: <%= formatRelativeTime(user.registrationTime) %>