mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-11 16:35:47 +01:00
closes #3436
This commit is contained in:
@@ -14,8 +14,8 @@
|
|||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
height: auto;
|
height: auto;
|
||||||
max-width: 125px;
|
max-width: 145px;
|
||||||
min-width: 125px;
|
min-width: 145px;
|
||||||
|
|
||||||
img, .user-icon {
|
img, .user-icon {
|
||||||
.user-icon-style(80px, 4rem);
|
.user-icon-style(80px, 4rem);
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
/* global config, socket, define, templates, bootbox, app, ajaxify */
|
|
||||||
|
/* global socket, define, templates, bootbox, app, ajaxify */
|
||||||
|
|
||||||
define('admin/manage/users', ['admin/modules/selectable'], function(selectable) {
|
define('admin/manage/users', ['admin/modules/selectable'], function(selectable) {
|
||||||
var Users = {};
|
var Users = {};
|
||||||
|
|
||||||
@@ -220,21 +222,9 @@ define('admin/manage/users', ['admin/modules/selectable'], function(selectable)
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var timeoutId = 0,
|
var timeoutId = 0;
|
||||||
loadingMoreUsers = false;
|
|
||||||
|
|
||||||
var url = window.location.href,
|
$('.nav-pills li').removeClass('active').find('a[href="' + window.location.pathname + '"]').parent().addClass('active');
|
||||||
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-name, #search-user-email, #search-user-ip').on('keyup', function() {
|
$('#search-user-name, #search-user-email, #search-user-ip').on('keyup', function() {
|
||||||
if (timeoutId !== 0) {
|
if (timeoutId !== 0) {
|
||||||
@@ -278,50 +268,6 @@ define('admin/manage/users', ['admin/modules/selectable'], function(selectable)
|
|||||||
|
|
||||||
handleUserCreate();
|
handleUserCreate();
|
||||||
|
|
||||||
$('#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();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
function loadMoreUsers() {
|
|
||||||
if (active === 'search') {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var set = 'users:joindate';
|
|
||||||
if (active === 'sort-posts') {
|
|
||||||
set = 'users:postcount';
|
|
||||||
} else if (active === 'sort-reputation') {
|
|
||||||
set = 'users:reputation';
|
|
||||||
} else if (active === 'banned') {
|
|
||||||
set = 'users:banned';
|
|
||||||
}
|
|
||||||
|
|
||||||
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;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function onUsersLoaded(users) {
|
|
||||||
templates.parse('admin/manage/users', 'users', {users: users, requireEmailConfirmation: config.requireEmailConfirmation}, function(html) {
|
|
||||||
$('#users-container').append($(html));
|
|
||||||
selectable.enable('#users-container', '.user-selectable');
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return Users;
|
return Users;
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
var async = require('async'),
|
var async = require('async');
|
||||||
user = require('../../user'),
|
var user = require('../../user');
|
||||||
meta = require('../../meta');
|
var meta = require('../../meta');
|
||||||
|
var db = require('../../database');
|
||||||
|
var pagination = require('../../pagination');
|
||||||
|
|
||||||
|
|
||||||
var usersController = {};
|
var usersController = {};
|
||||||
@@ -10,25 +12,68 @@ var usersController = {};
|
|||||||
usersController.search = function(req, res, next) {
|
usersController.search = function(req, res, next) {
|
||||||
res.render('admin/manage/users', {
|
res.render('admin/manage/users', {
|
||||||
search_display: '',
|
search_display: '',
|
||||||
loadmore_display: 'hide',
|
|
||||||
users: []
|
users: []
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
usersController.sortByPosts = function(req, res, next) {
|
|
||||||
getUsers('users:postcount', req, res, next);
|
|
||||||
};
|
|
||||||
|
|
||||||
usersController.sortByReputation = function(req, res, next) {
|
|
||||||
getUsers('users:reputation', req, res, next);
|
|
||||||
};
|
|
||||||
|
|
||||||
usersController.sortByJoinDate = function(req, res, next) {
|
usersController.sortByJoinDate = function(req, res, next) {
|
||||||
getUsers('users:joindate', req, res, next);
|
getUsers('users:joindate', 'latest', req, res, next);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
usersController.notValidated = function(req, res, next) {
|
||||||
|
getUsers('users:notvalidated', 'notvalidated', req, res, next);
|
||||||
|
};
|
||||||
|
|
||||||
|
usersController.noPosts = function(req, res, next) {
|
||||||
|
getUsersByScore('users:postcount', 'noposts', 0, 0, req, res, next);
|
||||||
|
};
|
||||||
|
|
||||||
|
usersController.inactive = function(req, res, next) {
|
||||||
|
var timeRange = 1000 * 60 * 60 * 24 * 30 * (parseInt(req.query.months, 10) || 3);
|
||||||
|
var cutoff = Date.now() - timeRange;
|
||||||
|
getUsersByScore('users:online', 'inactive', 0, cutoff, req, res, next);
|
||||||
|
};
|
||||||
|
|
||||||
|
function getUsersByScore(set, section, min, max, req, res, callback) {
|
||||||
|
var page = parseInt(req.query.page, 10) || 1;
|
||||||
|
var resultsPerPage = 25;
|
||||||
|
var start = Math.max(0, page - 1) * resultsPerPage;
|
||||||
|
var count = 0;
|
||||||
|
|
||||||
|
async.waterfall([
|
||||||
|
function (next) {
|
||||||
|
async.parallel({
|
||||||
|
count: function (next) {
|
||||||
|
db.sortedSetCount(set, min, max, next);
|
||||||
|
},
|
||||||
|
uids: function (next) {
|
||||||
|
db.getSortedSetRevRangeByScore(set, start, resultsPerPage, max, min, next);
|
||||||
|
}
|
||||||
|
}, next);
|
||||||
|
},
|
||||||
|
function (results, next) {
|
||||||
|
count = results.count;
|
||||||
|
user.getUsers(results.uids, req.uid, next);
|
||||||
|
}
|
||||||
|
], function(err, users) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
users = users.filter(function(user) {
|
||||||
|
return user && parseInt(user.uid, 10);
|
||||||
|
});
|
||||||
|
var data = {
|
||||||
|
users: users,
|
||||||
|
page: page,
|
||||||
|
pageCount: Math.ceil(count / resultsPerPage)
|
||||||
|
};
|
||||||
|
data[section] = true;
|
||||||
|
render(req, res, data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
usersController.banned = function(req, res, next) {
|
usersController.banned = function(req, res, next) {
|
||||||
getUsers('users:banned', req, res, next);
|
getUsers('users:banned', 'banned', req, res, next);
|
||||||
};
|
};
|
||||||
|
|
||||||
usersController.registrationQueue = function(req, res, next) {
|
usersController.registrationQueue = function(req, res, next) {
|
||||||
@@ -75,27 +120,44 @@ usersController.registrationQueue = function(req, res, next) {
|
|||||||
}
|
}
|
||||||
res.render('admin/manage/registration', data);
|
res.render('admin/manage/registration', data);
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
function getUsers(set, req, res, next) {
|
function getUsers(set, section, req, res, next) {
|
||||||
user.getUsersFromSet(set, req.uid, 0, 49, function(err, users) {
|
var page = parseInt(req.query.page, 10) || 1;
|
||||||
|
var resultsPerPage = 25;
|
||||||
|
var start = Math.max(0, page - 1) * resultsPerPage;
|
||||||
|
var stop = start + resultsPerPage - 1;
|
||||||
|
|
||||||
|
async.parallel({
|
||||||
|
count: function(next) {
|
||||||
|
db.sortedSetCard(set, next);
|
||||||
|
},
|
||||||
|
users: function(next) {
|
||||||
|
user.getUsersFromSet(set, req.uid, start, stop, next);
|
||||||
|
}
|
||||||
|
}, function(err, results) {
|
||||||
if (err) {
|
if (err) {
|
||||||
return next(err);
|
return next(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
users = users.filter(function(user) {
|
results.users = results.users.filter(function(user) {
|
||||||
return user && parseInt(user.uid, 10);
|
return user && parseInt(user.uid, 10);
|
||||||
});
|
});
|
||||||
|
var data = {
|
||||||
|
users: results.users,
|
||||||
|
page: page,
|
||||||
|
pageCount: Math.ceil(results.count / resultsPerPage)
|
||||||
|
};
|
||||||
|
data[section] = true;
|
||||||
|
render(req, res, data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
res.render('admin/manage/users', {
|
function render(req, res, data) {
|
||||||
search_display: 'hidden',
|
data.search_display = 'hidden';
|
||||||
loadmore_display: 'block',
|
data.pagination = pagination.create(data.page, data.pageCount, req.query);
|
||||||
users: users,
|
data.requireEmailConfirmation = parseInt(meta.config.requireEmailConfirmation, 10) === 1;
|
||||||
yourid: req.uid,
|
res.render('admin/manage/users', data);
|
||||||
requireEmailConfirmation: parseInt(meta.config.requireEmailConfirmation, 10) === 1
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
usersController.getCSV = function(req, res, next) {
|
usersController.getCSV = function(req, res, next) {
|
||||||
|
|||||||
@@ -58,8 +58,9 @@ function addRoutes(router, middleware, controllers) {
|
|||||||
router.get('/manage/users', middlewares, controllers.admin.users.sortByJoinDate);
|
router.get('/manage/users', middlewares, controllers.admin.users.sortByJoinDate);
|
||||||
router.get('/manage/users/search', middlewares, controllers.admin.users.search);
|
router.get('/manage/users/search', middlewares, controllers.admin.users.search);
|
||||||
router.get('/manage/users/latest', middlewares, controllers.admin.users.sortByJoinDate);
|
router.get('/manage/users/latest', middlewares, controllers.admin.users.sortByJoinDate);
|
||||||
router.get('/manage/users/sort-posts', middlewares, controllers.admin.users.sortByPosts);
|
router.get('/manage/users/not-validated', middlewares, controllers.admin.users.notValidated);
|
||||||
router.get('/manage/users/sort-reputation', middlewares, controllers.admin.users.sortByReputation);
|
router.get('/manage/users/no-posts', middlewares, controllers.admin.users.noPosts);
|
||||||
|
router.get('/manage/users/inactive', middlewares, controllers.admin.users.inactive);
|
||||||
router.get('/manage/users/banned', middlewares, controllers.admin.users.banned);
|
router.get('/manage/users/banned', middlewares, controllers.admin.users.banned);
|
||||||
router.get('/manage/registration', middlewares, controllers.admin.users.registrationQueue);
|
router.get('/manage/registration', middlewares, controllers.admin.users.registrationQueue);
|
||||||
|
|
||||||
|
|||||||
@@ -120,7 +120,12 @@ User.validateEmail = function(socket, uids, callback) {
|
|||||||
|
|
||||||
async.each(uids, function(uid, next) {
|
async.each(uids, function(uid, next) {
|
||||||
user.setUserField(uid, 'email:confirmed', 1, next);
|
user.setUserField(uid, 'email:confirmed', 1, next);
|
||||||
}, callback);
|
}, function(err) {
|
||||||
|
if (err) {
|
||||||
|
return callback(err);
|
||||||
|
}
|
||||||
|
db.sortedSetRemove('users:notvalidated', uids, callback);
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
User.sendValidationEmail = function(socket, uids, callback) {
|
User.sendValidationEmail = function(socket, uids, callback) {
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ var db = require('./database'),
|
|||||||
schemaDate, thisSchemaDate,
|
schemaDate, thisSchemaDate,
|
||||||
|
|
||||||
// IMPORTANT: REMEMBER TO UPDATE VALUE OF latestSchema
|
// IMPORTANT: REMEMBER TO UPDATE VALUE OF latestSchema
|
||||||
latestSchema = Date.UTC(2016, 0, 14);
|
latestSchema = Date.UTC(2016, 0, 20);
|
||||||
|
|
||||||
Upgrade.check = function(callback) {
|
Upgrade.check = function(callback) {
|
||||||
db.get('schemaDate', function(err, value) {
|
db.get('schemaDate', function(err, value) {
|
||||||
@@ -335,6 +335,40 @@ Upgrade.upgrade = function(callback) {
|
|||||||
winston.info('[2016/01/14] Creating user best post sorted sets skipped!');
|
winston.info('[2016/01/14] Creating user best post sorted sets skipped!');
|
||||||
next();
|
next();
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
function(next) {
|
||||||
|
thisSchemaDate = Date.UTC(2016, 0, 20);
|
||||||
|
|
||||||
|
if (schemaDate < thisSchemaDate) {
|
||||||
|
updatesMade = true;
|
||||||
|
winston.info('[2016/01/20] Creating users:notvalidated');
|
||||||
|
|
||||||
|
var batch = require('./batch');
|
||||||
|
var now = Date.now();
|
||||||
|
batch.processSortedSet('users:joindate', function(ids, next) {
|
||||||
|
async.eachSeries(ids, function(id, next) {
|
||||||
|
db.getObjectFields('user:' + id, ['uid', 'email:confirmed'], function(err, userData) {
|
||||||
|
if (err) {
|
||||||
|
return next(err);
|
||||||
|
}
|
||||||
|
if (!userData || !parseInt(userData.uid, 10) || parseInt(userData['email:confirmed'], 10) === 1) {
|
||||||
|
return next();
|
||||||
|
}
|
||||||
|
winston.info('processing uid: ' + userData.uid + ' email:confirmed: ' + userData['email:confirmed']);
|
||||||
|
db.sortedSetAdd('users:notvalidated', now, userData.uid, next);
|
||||||
|
});
|
||||||
|
}, next);
|
||||||
|
}, {}, function(err) {
|
||||||
|
if (err) {
|
||||||
|
return next(err);
|
||||||
|
}
|
||||||
|
winston.info('[2016/01/20] Creating users:notvalidated done!');
|
||||||
|
Upgrade.update(thisSchemaDate, next);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
winston.info('[2016/01/20] Creating users:notvalidated skipped!');
|
||||||
|
next();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Add new schema updates here
|
// Add new schema updates here
|
||||||
// IMPORTANT: REMEMBER TO UPDATE VALUE OF latestSchema IN LINE 24!!!
|
// IMPORTANT: REMEMBER TO UPDATE VALUE OF latestSchema IN LINE 24!!!
|
||||||
|
|||||||
@@ -31,6 +31,7 @@ module.exports = function(User) {
|
|||||||
'userslug': data.userslug,
|
'userslug': data.userslug,
|
||||||
'email': data.email,
|
'email': data.email,
|
||||||
'joindate': timestamp,
|
'joindate': timestamp,
|
||||||
|
'lastonline': timestamp,
|
||||||
'picture': '',
|
'picture': '',
|
||||||
'fullname': data.fullname,
|
'fullname': data.fullname,
|
||||||
'location': '',
|
'location': '',
|
||||||
@@ -89,7 +90,7 @@ module.exports = function(User) {
|
|||||||
db.sortedSetAdd('userslug:uid', userData.uid, userData.userslug, next);
|
db.sortedSetAdd('userslug:uid', userData.uid, userData.userslug, next);
|
||||||
},
|
},
|
||||||
function(next) {
|
function(next) {
|
||||||
db.sortedSetAdd('users:joindate', timestamp, userData.uid, next);
|
db.sortedSetAdd(['users:joindate', 'users:online', 'users:notvalidated'], timestamp, userData.uid, next);
|
||||||
},
|
},
|
||||||
function(next) {
|
function(next) {
|
||||||
db.sortedSetsAdd(['users:postcount', 'users:reputation'], 0, userData.uid, next);
|
db.sortedSetsAdd(['users:postcount', 'users:reputation'], 0, userData.uid, next);
|
||||||
|
|||||||
@@ -91,7 +91,8 @@ module.exports = function(User) {
|
|||||||
'users:postcount',
|
'users:postcount',
|
||||||
'users:reputation',
|
'users:reputation',
|
||||||
'users:banned',
|
'users:banned',
|
||||||
'users:online'
|
'users:online',
|
||||||
|
'users:notvalidated'
|
||||||
], uid, next);
|
], uid, next);
|
||||||
},
|
},
|
||||||
function(next) {
|
function(next) {
|
||||||
|
|||||||
@@ -1,17 +1,16 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var async = require('async'),
|
var async = require('async');
|
||||||
nconf = require('nconf'),
|
var nconf = require('nconf');
|
||||||
winston = require('winston'),
|
|
||||||
|
|
||||||
user = require('../user'),
|
var user = require('../user');
|
||||||
utils = require('../../public/src/utils'),
|
var utils = require('../../public/src/utils');
|
||||||
translator = require('../../public/src/modules/translator'),
|
var translator = require('../../public/src/modules/translator');
|
||||||
plugins = require('../plugins'),
|
var plugins = require('../plugins');
|
||||||
db = require('../database'),
|
var db = require('../database');
|
||||||
meta = require('../meta'),
|
var meta = require('../meta');
|
||||||
emailer = require('../emailer');
|
var emailer = require('../emailer');
|
||||||
|
|
||||||
(function(UserEmail) {
|
(function(UserEmail) {
|
||||||
|
|
||||||
@@ -97,7 +96,10 @@ var async = require('async'),
|
|||||||
if (confirmObj && confirmObj.uid && confirmObj.email) {
|
if (confirmObj && confirmObj.uid && confirmObj.email) {
|
||||||
async.series([
|
async.series([
|
||||||
async.apply(user.setUserField, confirmObj.uid, 'email:confirmed', 1),
|
async.apply(user.setUserField, confirmObj.uid, 'email:confirmed', 1),
|
||||||
async.apply(db.delete, 'confirm:' + code)
|
async.apply(db.delete, 'confirm:' + code),
|
||||||
|
function(next) {
|
||||||
|
db.sortedSetRemove('users:notvalidated', confirmObj.uid, next);
|
||||||
|
}
|
||||||
], function(err) {
|
], function(err) {
|
||||||
callback(err ? new Error('[[error:email-confirm-failed]]') : null);
|
callback(err ? new Error('[[error:email-confirm-failed]]') : null);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -170,6 +170,9 @@ module.exports = function(User) {
|
|||||||
User.email.sendValidationEmail(uid, newEmail);
|
User.email.sendValidationEmail(uid, newEmail);
|
||||||
}
|
}
|
||||||
User.setUserField(uid, 'email:confirmed', 0, next);
|
User.setUserField(uid, 'email:confirmed', 0, next);
|
||||||
|
},
|
||||||
|
function (next) {
|
||||||
|
db.sortedSetAdd('users:notvalidated', Date.now(), uid, next);
|
||||||
}
|
}
|
||||||
], callback);
|
], callback);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -5,8 +5,9 @@
|
|||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<ul class="nav nav-pills">
|
<ul class="nav nav-pills">
|
||||||
<li><a href='{config.relative_path}/admin/manage/users/latest'>Latest Users</a></li>
|
<li><a href='{config.relative_path}/admin/manage/users/latest'>Latest Users</a></li>
|
||||||
<li><a href='{config.relative_path}/admin/manage/users/sort-posts'>Top Posters</a></li>
|
<li><a href='{config.relative_path}/admin/manage/users/not-validated'>Not validated</a></li>
|
||||||
<li><a href='{config.relative_path}/admin/manage/users/sort-reputation'>Most Reputation</a></li>
|
<li><a href='{config.relative_path}/admin/manage/users/no-posts'>No Posts</a></li>
|
||||||
|
<li><a href='{config.relative_path}/admin/manage/users/inactive'>Inactive</a></li>
|
||||||
<li><a href='{config.relative_path}/admin/manage/users/banned'>Banned</a></li>
|
<li><a href='{config.relative_path}/admin/manage/users/banned'>Banned</a></li>
|
||||||
<li><a href='{config.relative_path}/admin/manage/users/search'>User Search</a></li>
|
<li><a href='{config.relative_path}/admin/manage/users/search'>User Search</a></li>
|
||||||
|
|
||||||
@@ -46,6 +47,12 @@
|
|||||||
<i class="fa fa-spinner fa-spin hidden"></i>
|
<i class="fa fa-spinner fa-spin hidden"></i>
|
||||||
<span id="user-notfound-notify" class="label label-danger hide">User not found!</span><br/>
|
<span id="user-notfound-notify" class="label label-danger hide">User not found!</span><br/>
|
||||||
</div>
|
</div>
|
||||||
|
<!-- IF inactive -->
|
||||||
|
<a href="{config.relative_path}/admin/manage/users/inactive?months=3" class="btn btn-default">3 months</a>
|
||||||
|
<a href="{config.relative_path}/admin/manage/users/inactive?months=6" class="btn btn-default">6 months</a>
|
||||||
|
<a href="{config.relative_path}/admin/manage/users/inactive?months=12" class="btn btn-default">12 months</a>
|
||||||
|
<!-- ENDIF inactive -->
|
||||||
|
|
||||||
|
|
||||||
<ul id="users-container">
|
<ul id="users-container">
|
||||||
<!-- BEGIN users -->
|
<!-- BEGIN users -->
|
||||||
@@ -71,6 +78,11 @@
|
|||||||
<!-- IF users.email -->
|
<!-- IF users.email -->
|
||||||
<small><span title="{users.email}">{users.email}</span></small>
|
<small><span title="{users.email}">{users.email}</span></small>
|
||||||
<!-- ENDIF users.email -->
|
<!-- ENDIF users.email -->
|
||||||
|
|
||||||
|
joined <span class="timeago" title="{users.joindateISO}"></span><br/>
|
||||||
|
login <span class="timeago" title="{users.lastonlineISO}"></span><br/>
|
||||||
|
posts {users.postcount}
|
||||||
|
|
||||||
<!-- IF users.flags -->
|
<!-- IF users.flags -->
|
||||||
<div><small><span><i class="fa fa-flag"></i> {users.flags}</span></small></div>
|
<div><small><span><i class="fa fa-flag"></i> {users.flags}</span></small></div>
|
||||||
<!-- ENDIF users.flags -->
|
<!-- ENDIF users.flags -->
|
||||||
@@ -78,6 +90,8 @@
|
|||||||
<!-- END users -->
|
<!-- END users -->
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
|
<!-- IMPORT partials/paginator.tpl -->
|
||||||
|
|
||||||
<div class="modal fade" id="create-modal">
|
<div class="modal fade" id="create-modal">
|
||||||
<div class="modal-dialog">
|
<div class="modal-dialog">
|
||||||
<div class="modal-content">
|
<div class="modal-content">
|
||||||
@@ -117,12 +131,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<div class="text-center {loadmore_display}">
|
|
||||||
<button id="load-more-users-btn" class="btn btn-primary">Load More</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
<ul class="menu-section-list">
|
<ul class="menu-section-list">
|
||||||
<li><a href="{relative_path}/admin/manage/categories">Categories</a></li>
|
<li><a href="{relative_path}/admin/manage/categories">Categories</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/tags">Tags</a></li>
|
<li><a href="{relative_path}/admin/manage/tags">Tags</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/users">Users</a></li>
|
<li><a href="{relative_path}/admin/manage/users/latest">Users</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/registration">Registration Queue</a></li>
|
<li><a href="{relative_path}/admin/manage/registration">Registration Queue</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/groups">Groups</a></li>
|
<li><a href="{relative_path}/admin/manage/groups">Groups</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/flags">Flags</a></li>
|
<li><a href="{relative_path}/admin/manage/flags">Flags</a></li>
|
||||||
@@ -167,7 +167,7 @@
|
|||||||
<ul class="dropdown-menu" role="menu">
|
<ul class="dropdown-menu" role="menu">
|
||||||
<li><a href="{relative_path}/admin/manage/categories">Categories</a></li>
|
<li><a href="{relative_path}/admin/manage/categories">Categories</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/tags">Tags</a></li>
|
<li><a href="{relative_path}/admin/manage/tags">Tags</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/users">Users</a></li>
|
<li><a href="{relative_path}/admin/manage/users/latest">Users</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/registration">Registration Queue</a></li>
|
<li><a href="{relative_path}/admin/manage/registration">Registration Queue</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/groups">Groups</a></li>
|
<li><a href="{relative_path}/admin/manage/groups">Groups</a></li>
|
||||||
<li><a href="{relative_path}/admin/manage/flags">Flags</a></li>
|
<li><a href="{relative_path}/admin/manage/flags">Flags</a></li>
|
||||||
|
|||||||
Reference in New Issue
Block a user