mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-09 15:35:47 +01:00
for andrew
This commit is contained in:
@@ -1,4 +1,83 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function initUsers() {
|
||||||
|
|
||||||
|
|
||||||
|
function isUserAdmin(element) {
|
||||||
|
var parent = $(element).parents('.users-box');
|
||||||
|
return (parent.attr('data-admin') !== "0");
|
||||||
|
}
|
||||||
|
|
||||||
|
function getUID(element) {
|
||||||
|
var parent = $(element).parents('.users-box');
|
||||||
|
return parent.attr('data-uid');
|
||||||
|
}
|
||||||
|
|
||||||
|
jQuery('.admin-btn').each(function(index, element) {
|
||||||
|
var adminBtn = $(element);
|
||||||
|
var isAdmin = isUserAdmin(adminBtn);
|
||||||
|
|
||||||
|
if(isAdmin)
|
||||||
|
adminBtn.addClass('btn-success');
|
||||||
|
else
|
||||||
|
adminBtn.removeClass('btn-success');
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
jQuery('.delete-btn').each(function(index, element) {
|
||||||
|
var deleteBtn = $(element);
|
||||||
|
var isAdmin = isUserAdmin(deleteBtn);
|
||||||
|
|
||||||
|
if(isAdmin)
|
||||||
|
deleteBtn.addClass('disabled');
|
||||||
|
else
|
||||||
|
deleteBtn.show();
|
||||||
|
});
|
||||||
|
|
||||||
|
jQuery('.admin-btn').on('click', function() {
|
||||||
|
var adminBtn = $(this);
|
||||||
|
var isAdmin = isUserAdmin(adminBtn);
|
||||||
|
var parent = adminBtn.parents('.users-box');
|
||||||
|
var uid = getUID(adminBtn);
|
||||||
|
|
||||||
|
if(isAdmin) {
|
||||||
|
socket.emit('api:admin.user.removeAdmin', uid);
|
||||||
|
adminBtn.removeClass('btn-success');
|
||||||
|
parent.find('.delete-btn').removeClass('disabled');
|
||||||
|
parent.attr('data-admin', 0);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
bootbox.confirm('Do you really want to make "' + parent.attr('data-username') +'" an admin?', function(confirm) {
|
||||||
|
if(confirm) {
|
||||||
|
socket.emit('api:admin.user.makeAdmin', uid);
|
||||||
|
adminBtn.addClass('btn-success');
|
||||||
|
parent.find('.delete-btn').addClass('disabled');
|
||||||
|
parent.attr('data-admin', 1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
jQuery('.delete-btn').on('click', function() {
|
||||||
|
var deleteBtn = $(this);
|
||||||
|
var isAdmin = isUserAdmin(deleteBtn);
|
||||||
|
var parent = deleteBtn.parents('.users-box');
|
||||||
|
var uid = getUID(deleteBtn);
|
||||||
|
|
||||||
|
if(!isAdmin) {
|
||||||
|
bootbox.confirm('Do you really want to delete "' + parent.attr('data-username') +'"?', function(confirm) {
|
||||||
|
socket.emit('api:admin.user.deleteUser', uid);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
(function() {
|
(function() {
|
||||||
jQuery('document').ready(function() {
|
jQuery('document').ready(function() {
|
||||||
|
|
||||||
@@ -23,85 +102,14 @@
|
|||||||
timeoutId = 0;
|
timeoutId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
timeoutId = setTimeout(function() {
|
timeoutId = setTimeout(function() {
|
||||||
jQuery('.icon-spinner').removeClass('none');
|
jQuery('.icon-spinner').removeClass('none');
|
||||||
socket.emit('api:admin.user.search', $('#search-user').val());
|
socket.emit('api:admin.user.search', $('#search-user').val());
|
||||||
}, 250);
|
}, 250);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
initUsers();
|
||||||
|
|
||||||
function isUserAdmin(element) {
|
|
||||||
var parent = $(element).parents('.users-box');
|
|
||||||
return (parent.attr('data-admin') !== "0");
|
|
||||||
}
|
|
||||||
|
|
||||||
function getUID(element) {
|
|
||||||
var parent = $(element).parents('.users-box');
|
|
||||||
return parent.attr('data-uid');
|
|
||||||
}
|
|
||||||
|
|
||||||
jQuery('.admin-btn').each(function(index, element) {
|
|
||||||
var adminBtn = $(element);
|
|
||||||
var isAdmin = isUserAdmin(adminBtn);
|
|
||||||
|
|
||||||
if(isAdmin)
|
|
||||||
adminBtn.addClass('btn-success');
|
|
||||||
else
|
|
||||||
adminBtn.removeClass('btn-success');
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
jQuery('.delete-btn').each(function(index, element) {
|
|
||||||
var deleteBtn = $(element);
|
|
||||||
var isAdmin = isUserAdmin(deleteBtn);
|
|
||||||
|
|
||||||
if(isAdmin)
|
|
||||||
deleteBtn.addClass('disabled');
|
|
||||||
else
|
|
||||||
deleteBtn.show();
|
|
||||||
});
|
|
||||||
|
|
||||||
jQuery('.admin-btn').on('click', function() {
|
|
||||||
var adminBtn = $(this);
|
|
||||||
var isAdmin = isUserAdmin(adminBtn);
|
|
||||||
var parent = adminBtn.parents('.users-box');
|
|
||||||
var uid = getUID(adminBtn);
|
|
||||||
|
|
||||||
if(isAdmin) {
|
|
||||||
socket.emit('api:admin.user.removeAdmin', uid);
|
|
||||||
adminBtn.removeClass('btn-success');
|
|
||||||
parent.find('.delete-btn').removeClass('disabled');
|
|
||||||
parent.attr('data-admin', 0);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
bootbox.confirm('Do you really want to make "' + parent.attr('data-username') +'" an admin?', function(confirm) {
|
|
||||||
if(confirm) {
|
|
||||||
socket.emit('api:admin.user.makeAdmin', uid);
|
|
||||||
adminBtn.addClass('btn-success');
|
|
||||||
parent.find('.delete-btn').addClass('disabled');
|
|
||||||
parent.attr('data-admin', 1);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
jQuery('.delete-btn').on('click', function() {
|
|
||||||
var deleteBtn = $(this);
|
|
||||||
var isAdmin = isUserAdmin(deleteBtn);
|
|
||||||
var parent = deleteBtn.parents('.users-box');
|
|
||||||
var uid = getUID(deleteBtn);
|
|
||||||
|
|
||||||
if(!isAdmin) {
|
|
||||||
bootbox.confirm('Do you really want to delete "' + parent.attr('data-username') +'"?', function(confirm) {
|
|
||||||
socket.emit('api:admin.user.deleteUser', uid);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -43,6 +43,7 @@
|
|||||||
socket.emit('api:get_all_rooms');
|
socket.emit('api:get_all_rooms');
|
||||||
|
|
||||||
socket.on('api:admin.user.search', function(data) {
|
socket.on('api:admin.user.search', function(data) {
|
||||||
|
console.log('move this into user.js but it should execute only once');
|
||||||
var html = templates.prepare(templates['admin/users'].blocks['users']).parse({
|
var html = templates.prepare(templates['admin/users'].blocks['users']).parse({
|
||||||
users: data
|
users: data
|
||||||
}),
|
}),
|
||||||
@@ -57,12 +58,14 @@
|
|||||||
.addClass('label-important')
|
.addClass('label-important')
|
||||||
.removeClass('label-success');
|
.removeClass('label-success');
|
||||||
}
|
}
|
||||||
else
|
else {
|
||||||
$('#user-notfound-notify').html(data.length + ' user'+(data.length>1?'s':'') + ' found!')
|
$('#user-notfound-notify').html(data.length + ' user'+(data.length>1?'s':'') + ' found!')
|
||||||
.show()
|
.show()
|
||||||
.addClass('label-success')
|
.addClass('label-success')
|
||||||
.removeClass('label-important');
|
.removeClass('label-important');
|
||||||
|
}
|
||||||
|
|
||||||
|
user.initUsers();
|
||||||
});
|
});
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
Reference in New Issue
Block a user