2013-10-03 15:04:25 -04:00
|
|
|
define(function() {
|
|
|
|
|
var Users = {};
|
2013-08-14 13:32:07 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
Users.init = function() {
|
|
|
|
|
var yourid = templates.get('yourid');
|
2013-09-17 13:07:30 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
function isUserAdmin(element) {
|
|
|
|
|
var parent = $(element).parents('.users-box');
|
|
|
|
|
return (parent.attr('data-admin') !== "0");
|
|
|
|
|
}
|
2013-09-07 15:48:38 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
function isUserBanned(element) {
|
|
|
|
|
var parent = $(element).parents('.users-box');
|
|
|
|
|
return (parent.attr('data-banned') !== "" && parent.attr('data-banned') !== "0");
|
|
|
|
|
}
|
2013-08-14 13:32:07 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
function getUID(element) {
|
|
|
|
|
var parent = $(element).parents('.users-box');
|
|
|
|
|
return parent.attr('data-uid');
|
|
|
|
|
}
|
2013-08-14 13:32:07 -04:00
|
|
|
|
2014-01-02 21:44:13 -05:00
|
|
|
function updateUserBanButtons() {
|
2013-10-03 15:04:25 -04:00
|
|
|
jQuery('.ban-btn').each(function(index, element) {
|
|
|
|
|
var banBtn = $(element);
|
|
|
|
|
var uid = getUID(banBtn);
|
|
|
|
|
if (isUserAdmin(banBtn) || uid === yourid)
|
|
|
|
|
banBtn.addClass('disabled');
|
|
|
|
|
else if (isUserBanned(banBtn))
|
|
|
|
|
banBtn.addClass('btn-warning');
|
2013-12-27 14:18:30 -08:00
|
|
|
else if (!isUserAdmin(banBtn))
|
|
|
|
|
banBtn.removeClass('disabled');
|
2013-10-03 15:04:25 -04:00
|
|
|
else
|
2013-08-14 13:32:07 -04:00
|
|
|
banBtn.removeClass('btn-warning');
|
2014-01-02 21:44:13 -05:00
|
|
|
updateUserAdminButtons();
|
2013-10-03 15:04:25 -04:00
|
|
|
});
|
|
|
|
|
}
|
2013-12-27 14:18:30 -08:00
|
|
|
|
2014-01-02 21:44:13 -05:00
|
|
|
function updateUserAdminButtons() {
|
|
|
|
|
jQuery('.admin-btn').each(function(index, element) {
|
|
|
|
|
var adminBtn = $(element);
|
|
|
|
|
var uid = getUID(adminBtn);
|
|
|
|
|
if (isUserAdmin(adminBtn)) {
|
|
|
|
|
adminBtn.attr('value', 'UnMake Admin').html('Remove Admin');
|
|
|
|
|
if (uid === yourid) {
|
|
|
|
|
adminBtn.addClass('disabled');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (isUserBanned(adminBtn))
|
|
|
|
|
adminBtn.addClass('disabled');
|
|
|
|
|
else if (!isUserBanned(adminBtn))
|
|
|
|
|
adminBtn.removeClass('disabled');
|
2013-12-27 14:18:30 -08:00
|
|
|
else
|
2014-01-02 21:44:13 -05:00
|
|
|
adminBtn.removeClass('btn-warning');
|
2013-12-27 14:18:30 -08:00
|
|
|
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
function initUsers() {
|
2013-12-27 14:18:30 -08:00
|
|
|
updateUserBanButtons();
|
|
|
|
|
updateUserAdminButtons();
|
2013-06-26 12:32:30 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
$('#users-container').on('click', '.ban-btn', function() {
|
|
|
|
|
var banBtn = $(this);
|
|
|
|
|
var isAdmin = isUserAdmin(banBtn);
|
|
|
|
|
var isBanned = isUserBanned(banBtn);
|
|
|
|
|
var parent = banBtn.parents('.users-box');
|
|
|
|
|
var uid = getUID(banBtn);
|
|
|
|
|
|
|
|
|
|
if (!isAdmin) {
|
|
|
|
|
if (isBanned) {
|
|
|
|
|
socket.emit('api:admin.user.unbanUser', uid);
|
|
|
|
|
banBtn.removeClass('btn-warning');
|
|
|
|
|
parent.attr('data-banned', 0);
|
2013-12-27 14:18:30 -08:00
|
|
|
updateUserAdminButtons();
|
2013-10-03 15:04:25 -04:00
|
|
|
} else {
|
|
|
|
|
bootbox.confirm('Do you really want to ban "' + parent.attr('data-username') + '"?', function(confirm) {
|
|
|
|
|
if (confirm) {
|
|
|
|
|
socket.emit('api:admin.user.banUser', uid);
|
|
|
|
|
banBtn.addClass('btn-warning');
|
|
|
|
|
parent.attr('data-banned', 1);
|
2013-12-27 14:18:30 -08:00
|
|
|
updateUserAdminButtons();
|
2013-10-03 15:04:25 -04:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
2013-06-26 12:32:30 -04:00
|
|
|
|
2013-12-27 14:18:30 -08:00
|
|
|
return false;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$('#users-container').on('click', '.admin-btn', function() {
|
|
|
|
|
var adminBtn = $(this);
|
|
|
|
|
var isAdmin = isUserAdmin(adminBtn);
|
|
|
|
|
var parent = adminBtn.parents('.users-box');
|
|
|
|
|
var isBanned = isUserBanned(adminBtn);
|
|
|
|
|
var uid = getUID(adminBtn);
|
2014-01-08 22:53:55 -05:00
|
|
|
|
2013-12-27 14:18:30 -08:00
|
|
|
if(uid === yourid){
|
2014-01-02 21:44:13 -05:00
|
|
|
app.alert({
|
|
|
|
|
title: 'Error',
|
|
|
|
|
message: 'You can\'t remove yourself as Administrator!',
|
|
|
|
|
type: 'danger',
|
|
|
|
|
timeout: 5000
|
|
|
|
|
});
|
2013-12-27 14:18:30 -08:00
|
|
|
}
|
|
|
|
|
else if (!isAdmin) {
|
|
|
|
|
socket.emit('api:admin.user.makeAdmin', uid);
|
2014-01-02 21:44:13 -05:00
|
|
|
adminBtn.attr('value', 'UnMake Admin').html('Remove Admin');
|
2013-12-27 14:18:30 -08:00
|
|
|
parent.attr('data-admin', 1);
|
|
|
|
|
updateUserBanButtons();
|
2014-01-08 22:53:55 -05:00
|
|
|
|
2013-12-27 14:18:30 -08:00
|
|
|
} 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('api:admin.user.removeAdmin', uid);
|
|
|
|
|
adminBtn.attr('value', 'Make Admin').html('Make Admin');
|
|
|
|
|
parent.attr('data-admin', 0);
|
|
|
|
|
updateUserBanButtons();
|
2014-01-08 22:53:55 -05:00
|
|
|
|
2013-12-27 14:18:30 -08:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
2014-01-08 22:53:55 -05:00
|
|
|
|
2013-12-27 14:18:30 -08:00
|
|
|
|
2013-06-26 12:32:30 -04:00
|
|
|
return false;
|
2013-10-03 15:04:25 -04:00
|
|
|
});
|
|
|
|
|
}
|
2013-06-26 12:32:30 -04:00
|
|
|
|
2013-12-23 13:27:26 -05:00
|
|
|
function handleUserCreate() {
|
|
|
|
|
$('#createUser').on('click', function() {
|
|
|
|
|
$('#create-modal').modal('show');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$('#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(),
|
|
|
|
|
errorEl = $('#create-modal-error');
|
|
|
|
|
|
|
|
|
|
if(password !== passwordAgain) {
|
|
|
|
|
return errorEl.html('<strong>Error</strong><p>Passwords must match!</p>').removeClass('hide');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var user = {
|
|
|
|
|
username: username,
|
|
|
|
|
email: email,
|
|
|
|
|
password: password
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
socket.emit('api:admin.user.createUser', user, function(err, data) {
|
|
|
|
|
if(err) {
|
|
|
|
|
return errorEl.html('<strong>Error</strong><p>' + err + '</p>').removeClass('hide');
|
|
|
|
|
}
|
|
|
|
|
$('#create-modal').modal('hide');
|
2013-12-23 13:31:13 -05:00
|
|
|
app.alertSuccess('User created!');
|
2013-12-23 21:03:45 -05:00
|
|
|
ajaxify.go('admin/users');
|
2013-12-23 13:27:26 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2013-06-26 12:32:30 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
jQuery('document').ready(function() {
|
2013-08-27 13:47:19 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
var timeoutId = 0,
|
|
|
|
|
loadingMoreUsers = false;
|
2013-08-27 13:47:19 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
var url = window.location.href,
|
|
|
|
|
parts = url.split('/'),
|
|
|
|
|
active = parts[parts.length - 1];
|
2013-08-27 13:47:19 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
jQuery('.nav-pills li').removeClass('active');
|
|
|
|
|
jQuery('.nav-pills li a').each(function() {
|
|
|
|
|
if (this.getAttribute('href').match(active)) {
|
|
|
|
|
jQuery(this.parentNode).addClass('active');
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
jQuery('#search-user').on('keyup', function() {
|
|
|
|
|
if (timeoutId !== 0) {
|
|
|
|
|
clearTimeout(timeoutId);
|
|
|
|
|
timeoutId = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
timeoutId = setTimeout(function() {
|
|
|
|
|
var username = $('#search-user').val();
|
|
|
|
|
|
2013-11-26 14:25:46 -05:00
|
|
|
jQuery('.fa-spinner').removeClass('none');
|
2013-10-03 15:04:25 -04:00
|
|
|
|
2014-01-08 22:53:55 -05:00
|
|
|
socket.emit('api:admin.user.search', username, function(err, data) {
|
|
|
|
|
if(err) {
|
|
|
|
|
return app.alertError(err.message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var html = templates.prepare(templates['admin/users'].blocks['users']).parse({
|
|
|
|
|
users: data
|
|
|
|
|
}),
|
|
|
|
|
userListEl = document.querySelector('.users');
|
|
|
|
|
|
|
|
|
|
userListEl.innerHTML = html;
|
|
|
|
|
jQuery('.fa-spinner').addClass('none');
|
|
|
|
|
|
|
|
|
|
if (data && data.length === 0) {
|
|
|
|
|
$('#user-notfound-notify').html('User not found!')
|
|
|
|
|
.show()
|
|
|
|
|
.addClass('label-danger')
|
|
|
|
|
.removeClass('label-success');
|
|
|
|
|
} else {
|
|
|
|
|
$('#user-notfound-notify').html(data.length + ' user' + (data.length > 1 ? 's' : '') + ' found!')
|
|
|
|
|
.show()
|
|
|
|
|
.addClass('label-success')
|
|
|
|
|
.removeClass('label-danger');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
initUsers();
|
|
|
|
|
});
|
2013-10-03 15:04:25 -04:00
|
|
|
}, 250);
|
|
|
|
|
});
|
2013-08-27 13:47:19 -04:00
|
|
|
|
2013-06-26 15:19:18 -04:00
|
|
|
initUsers();
|
2013-08-27 13:47:19 -04:00
|
|
|
|
2013-12-23 13:27:26 -05:00
|
|
|
handleUserCreate();
|
|
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
function onUsersLoaded(users) {
|
|
|
|
|
var html = templates.prepare(templates['admin/users'].blocks['users']).parse({
|
|
|
|
|
users: users
|
|
|
|
|
});
|
|
|
|
|
$('#users-container').append(html);
|
|
|
|
|
updateUserButtons();
|
2013-08-12 14:32:56 -04:00
|
|
|
}
|
|
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
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;
|
2014-01-10 16:00:03 -05:00
|
|
|
socket.emit('api:user.loadMore', {
|
2013-10-03 15:04:25 -04:00
|
|
|
set: set,
|
|
|
|
|
after: $('#users-container').children().length
|
|
|
|
|
}, function(data) {
|
|
|
|
|
if (data.users.length) {
|
|
|
|
|
onUsersLoaded(data.users);
|
|
|
|
|
}
|
|
|
|
|
loadingMoreUsers = false;
|
|
|
|
|
});
|
|
|
|
|
}
|
2013-08-12 14:32:56 -04:00
|
|
|
}
|
|
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
$('#load-more-users-btn').on('click', loadMoreUsers);
|
2013-08-12 14:32:56 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
$(window).off('scroll').on('scroll', function() {
|
|
|
|
|
var bottom = ($(document).height() - $(window).height()) * 0.9;
|
2013-08-12 14:32:56 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
if ($(window).scrollTop() > bottom && !loadingMoreUsers) {
|
|
|
|
|
loadMoreUsers();
|
|
|
|
|
}
|
|
|
|
|
});
|
2013-08-12 14:32:56 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
});
|
|
|
|
|
};
|
2013-08-12 14:32:56 -04:00
|
|
|
|
2013-10-03 15:04:25 -04:00
|
|
|
return Users;
|
|
|
|
|
});
|