mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-02 03:55:55 +01:00
testing user search in admin panel
This commit is contained in:
106
public/src/forum/admin/users.js
Normal file
106
public/src/forum/admin/users.js
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
|
||||||
|
(function() {
|
||||||
|
jQuery('document').ready(function() {
|
||||||
|
|
||||||
|
var yourid = templates.get('yourid');
|
||||||
|
|
||||||
|
var url = window.location.href,
|
||||||
|
parts = url.split('/'),
|
||||||
|
active = parts[parts.length-1];
|
||||||
|
|
||||||
|
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 () {
|
||||||
|
console.log('derp');
|
||||||
|
jQuery('.icon-spinner').removeClass('none');
|
||||||
|
console.log($('#search-user').val());
|
||||||
|
socket.emit('api:admin.user.search', $('#search-user').val());
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
socket.on('api:admin.user.search', function(data) {
|
||||||
|
console.log(data);
|
||||||
|
});
|
||||||
|
|
||||||
|
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;
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}());
|
||||||
@@ -132,6 +132,9 @@
|
|||||||
socket.emit('api:notifications.hasFlag');
|
socket.emit('api:notifications.hasFlag');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
require(['mobileMenu'], function(mobileMenu) {
|
require(['mobileMenu'], function(mobileMenu) {
|
||||||
mobileMenu.init();
|
mobileMenu.init();
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
|
|
||||||
<div class="search {search_display} well">
|
<div class="search {search_display} well">
|
||||||
<input type="text" placeholder="Enter a username to search" onkeypress="jQuery('.icon-spinner').removeClass('none');" /><br />
|
<input id="search-user" type="text" placeholder="Enter a username to search"/><br />
|
||||||
<i class="icon-spinner icon-spin none"></i>
|
<i class="icon-spinner icon-spin none"></i>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -36,105 +36,10 @@
|
|||||||
<div>
|
<div>
|
||||||
<a href="#" class="btn delete-btn btn-danger">Delete</a>
|
<a href="#" class="btn delete-btn btn-danger">Delete</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<!-- END users -->
|
<!-- END users -->
|
||||||
|
|
||||||
<input type="hidden" template-variable="yourid" value="{yourid}" />
|
<input type="hidden" template-variable="yourid" value="{yourid}" />
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript" src="../../src/forum/admin/users.js"></script>
|
||||||
//DRY Failure. this needs to go into an ajaxify onready style fn. Currently is copy pasted into every single function so after ACP is off the ground fix asap
|
|
||||||
(function() {
|
|
||||||
jQuery('document').ready(function() {
|
|
||||||
|
|
||||||
var yourid = templates.get('yourid');
|
|
||||||
|
|
||||||
var url = window.location.href,
|
|
||||||
parts = url.split('/'),
|
|
||||||
active = parts[parts.length-1];
|
|
||||||
|
|
||||||
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;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
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;
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
}());
|
|
||||||
</script>
|
|
||||||
12
src/user.js
12
src/user.js
@@ -253,6 +253,18 @@ var utils = require('./../public/src/utils.js'),
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
User.search = function(username, callback) {
|
||||||
|
console.log('searching '+username);
|
||||||
|
RDB.keys('username:'+ username + '*:uid', function(err, data) {
|
||||||
|
if(err === null) {
|
||||||
|
console.log(data);
|
||||||
|
callback(data);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
console.log(err);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
User.sendConfirmationEmail = function (email) {
|
User.sendConfirmationEmail = function (email) {
|
||||||
if (global.config['email:host'] && global.config['email:port'] && global.config['email:from']) {
|
if (global.config['email:host'] && global.config['email:port'] && global.config['email:from']) {
|
||||||
var confirm_code = utils.generateUUID(),
|
var confirm_code = utils.generateUUID(),
|
||||||
|
|||||||
@@ -431,6 +431,14 @@ var SocketIO = require('socket.io').listen(global.server, { log:false }),
|
|||||||
admin.user.deleteUser(uid, theirid, socket);
|
admin.user.deleteUser(uid, theirid, socket);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
socket.on('api:admin.user.search', function(username) {
|
||||||
|
if(uid && uid > 0) {
|
||||||
|
user.search(username, function(data) {
|
||||||
|
socket.emit('api:admin.user.search', data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
}(SocketIO));
|
}(SocketIO));
|
||||||
|
|||||||
Reference in New Issue
Block a user