"use strict";
/* global socket, define, templates, bootbox, app, ajaxify, */
define(function() {
var Users = {};
Users.init = function() {
var yourid = ajaxify.variables.get('yourid');
function isUserAdmin(element) {
var parent = $(element).parents('.users-box');
return (parent.attr('data-admin') !== "0");
}
function isUserBanned(element) {
var parent = $(element).parents('.users-box');
return (parent.attr('data-banned') !== "" && parent.attr('data-banned') !== "0");
}
function getUID(element) {
var parent = $(element).parents('.users-box');
return parent.attr('data-uid');
}
function updateUserBanButtons(elements) {
elements.each(function(index, element) {
var banBtn = $(element);
var uid = getUID(banBtn);
banBtn.toggleClass('disabled', isUserAdmin(banBtn) || uid === yourid);
banBtn.toggleClass('btn-warning', isUserBanned(banBtn));
});
}
function updateUserAdminButtons(elements) {
elements.each(function(index, element) {
var adminBtn = $(element);
var uid = getUID(adminBtn);
adminBtn.toggleClass('disabled', (isUserAdmin(adminBtn) && uid === yourid) || isUserBanned(adminBtn));
adminBtn.toggleClass('btn-success', isUserAdmin(adminBtn));
});
}
function updateButtons() {
updateUserBanButtons($('.ban-btn'));
updateUserAdminButtons($('.admin-btn'));
}
$('#users-container').on('click', '.ban-btn', function() {
var banBtn = $(this);
var parent = banBtn.parents('.users-box');
var uid = getUID(banBtn);
if (!isUserAdmin(banBtn)) {
if (isUserBanned(banBtn)) {
socket.emit('admin.user.unbanUser', uid, function(err) {
if (err) {
return app.alertError(err.message);
}
app.alertSuccess('This user is unbanned!');
});
banBtn.removeClass('btn-warning');
parent.attr('data-banned', 0);
updateUserAdminButtons($('.admin-btn'));
} else {
bootbox.confirm('Do you really want to ban "' + parent.attr('data-username') + '"?', function(confirm) {
if (confirm) {
socket.emit('admin.user.banUser', uid, function(err) {
if (err) {
return app.alertError(err.message);
}
app.alertSuccess('This user is banned!');
});
banBtn.addClass('btn-warning');
parent.attr('data-banned', 1);
updateUserAdminButtons($('.admin-btn'));
}
});
}
}
return false;
});
$('#users-container').on('click', '.admin-btn', function() {
var adminBtn = $(this);
var parent = adminBtn.parents('.users-box');
var uid = getUID(adminBtn);
if(uid === yourid) {
app.alert({
title: 'Error',
message: 'You can\'t remove yourself as Administrator!',
type: 'danger',
timeout: 5000
});
} else if (!isUserAdmin(adminBtn)) {
socket.emit('admin.user.makeAdmin', uid, function(err) {
if (err) {
return app.alertError(err.message);
}
app.alertSuccess('This user is now an administrator.');
});
parent.attr('data-admin', 1);
updateUserBanButtons($('.ban-btn'));
updateUserAdminButtons($('.admin-btn'));
} else if(uid !== yourid) {
bootbox.confirm('Do you really want to remove this user as admin "' + parent.attr('data-username') + '"?', function(confirm) {
if (confirm) {
socket.emit('admin.user.removeAdmin', uid, function(err) {
if (err) {
return app.alertError(err.message);
}
app.alertSuccess('This user is no longer an administrator.');
});
parent.attr('data-admin', 0);
updateUserBanButtons($('.ban-btn'));
updateUserAdminButtons($('.admin-btn'));
}
});
}
return false;
});
$('#users-container').on('click', '.delete-btn', function() {
var deleteBtn = $(this);
var parent = deleteBtn.parents('.users-box');
var uid = getUID(deleteBtn);
bootbox.confirm('Warning!
Do you really want to delete this user "' + parent.attr('data-username') + '"?
This action is not reversable, all user data and content will be erased!', function(confirm) {
if (confirm) {
socket.emit('admin.user.deleteUser', uid, function(err) {
if (err) {
return app.alertError(err.message);
}
parent.remove();
app.alertSuccess('User Deleted!');
});
}
});
});
function handleUserCreate() {
var errorEl = $('#create-modal-error');
$('#createUser').on('click', function() {
$('#create-modal').modal('show');
$('#create-modal form')[0].reset();
errorEl.addClass('hide');
});
$('#create-modal-go').on('click', function() {
var username = $('#create-user-name').val(),
email = $('#create-user-email').val(),
password = $('#create-user-password').val(),
passwordAgain = $('#create-user-password-again').val();
if(password !== passwordAgain) {
return errorEl.html('Error
Passwords must match!
').removeClass('hide'); } var user = { username: username, email: email, password: password }; socket.emit('admin.user.createUser', user, function(err) { if(err) { return errorEl.html('Error' + err.message + '
').removeClass('hide'); } $('#create-modal').modal('hide'); $('#create-modal').on('hidden.bs.modal', function() { ajaxify.go('admin/users'); }); app.alertSuccess('User created!'); }); }); } $('document').ready(function() { var timeoutId = 0, loadingMoreUsers = false; var url = window.location.href, parts = url.split('/'), active = parts[parts.length - 1]; $('.nav-pills li').removeClass('active'); $('.nav-pills li a').each(function() { var $this = $(this); if ($this.attr('href').match(active)) { $this.parent().addClass('active'); return false; } }); $('#search-user').on('keyup', function() { if (timeoutId !== 0) { clearTimeout(timeoutId); timeoutId = 0; } timeoutId = setTimeout(function() { var username = $('#search-user').val(); $('.fa-spinner').removeClass('none'); socket.emit('admin.user.search', username, function(err, data) { if(err) { return app.alertError(err.message); } ajaxify.loadTemplate('admin/users', function(adminUsers) { $('.users').html(templates.parse(templates.getBlock(adminUsers, 'users'), data)); $('.fa-spinner').addClass('none'); if (data && data.users.length === 0) { $('#user-notfound-notify').html('User not found!') .show() .addClass('label-danger') .removeClass('label-success'); } else { $('#user-notfound-notify').html(data.users.length + ' user' + (data.users.length > 1 ? 's' : '') + ' found! Search took ' + data.timing + ' ms.') .show() .addClass('label-success') .removeClass('label-danger'); } updateButtons(); }); }); }, 250); }); updateButtons(); handleUserCreate(); function onUsersLoaded(users) { ajaxify.loadTemplate('admin/users', function(adminUsers) { var html = $(templates.parse(templates.getBlock(adminUsers, 'users'), {users: users})); $('#users-container').append(html); updateUserBanButtons(html.find('.ban-btn')); updateUserAdminButtons(html.find('.admin-btn')); }); } function loadMoreUsers() { var set = ''; if (active === 'latest') { set = 'users:joindate'; } else if (active === 'sort-posts') { set = 'users:postcount'; } else if (active === 'sort-reputation') { set = 'users:reputation'; } if (set) { loadingMoreUsers = true; socket.emit('user.loadMore', { set: set, after: $('#users-container').children().length }, function(err, data) { if (data && data.users.length) { onUsersLoaded(data.users); } loadingMoreUsers = false; }); } } $('#load-more-users-btn').on('click', loadMoreUsers); $(window).off('scroll').on('scroll', function() { var bottom = ($(document).height() - $(window).height()) * 0.9; if ($(window).scrollTop() > bottom && !loadingMoreUsers) { loadMoreUsers(); } }); }); }; return Users; });