Files
NodeBB/public/src/forum/users.js

155 lines
4.2 KiB
JavaScript
Raw Normal View History

define(function() {
var Users = {};
2013-09-17 13:05:54 -04:00
Users.init = function() {
2013-06-27 14:38:45 -04:00
var timeoutId = 0;
var loadingMoreUsers = false;
2013-09-17 13:05:54 -04:00
2013-10-09 17:16:07 -04:00
function getActiveSection() {
var url = window.location.href,
2013-06-27 14:38:45 -04:00
parts = url.split('/'),
2013-09-17 13:05:54 -04:00
active = parts[parts.length - 1];
2013-10-09 17:16:07 -04:00
return active;
}
var active = getActiveSection();
2013-06-27 14:38:45 -04:00
var lastSearch = null;
app.addCommasToNumbers();
2013-06-27 14:38:45 -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;
}
});
2013-09-17 13:05:54 -04:00
jQuery('#search-user').on('keyup', function() {
if (timeoutId !== 0) {
2013-06-27 14:38:45 -04:00
clearTimeout(timeoutId);
timeoutId = 0;
}
timeoutId = setTimeout(function() {
var username = $('#search-user').val();
2013-09-17 13:05:54 -04:00
if (username == '') {
2013-11-26 14:25:46 -05:00
jQuery('#user-notfound-notify').html('<i class="fa fa-circle-o"></i>');
jQuery('#user-notfound-notify').parent().removeClass('btn-warning label-warning btn-success label-success');
return;
}
2013-09-17 13:05:54 -04:00
if (lastSearch === username) return;
lastSearch = username;
2013-09-17 13:05:54 -04:00
2013-11-26 14:25:46 -05:00
jQuery('#user-notfound-notify').html('<i class="fa fa-spinner fa-spin"></i>');
setTimeout(function() {
socket.emit('user.search', username, function(err, data) {
2014-01-08 22:53:55 -05:00
if(err) {
return app.alert(err.message);
}
console.log(data);
2014-01-08 22:53:55 -05:00
if (!data) {
$('#user-notfound-notify').html('You need to be logged in to search!');
$('#user-notfound-notify').parent().addClass('btn-warning label-warning');
return;
}
var html = templates.prepare(templates['users'].blocks['users']).parse({
users: data.users
2014-01-08 22:53:55 -05:00
}),
userListEl = $('#users-container');
userListEl.html(html);
if (data && data.users.length === 0) {
2014-01-08 22:53:55 -05:00
$('#user-notfound-notify').html('User not found!');
$('#user-notfound-notify').parent().addClass('btn-warning label-warning');
} else {
$('#user-notfound-notify').html(data.users.length + ' user' + (data.users.length > 1 ? 's' : '') + ' found! Search took ' + data.timing + ' ms.');
2014-01-08 22:53:55 -05:00
$('#user-notfound-notify').parent().addClass('btn-success label-success');
}
});
}, 500); //replace this with global throttling function/constant
2013-09-17 13:05:54 -04:00
2013-06-27 14:38:45 -04:00
}, 250);
});
2013-09-17 13:05:54 -04:00
2014-01-16 17:52:46 -05:00
socket.on('user.isOnline', function(err, data) {
2013-10-09 17:16:07 -04:00
if(getActiveSection() == 'online' && !loadingMoreUsers) {
2013-10-09 17:30:49 -04:00
startLoading('users:online', 0, true);
2014-01-16 18:10:38 -05:00
socket.emit('user.getOnlineAnonCount', {} , function(err, anonCount) {
if(parseInt(anonCount, 10) > 0) {
$('#users-container .anon-user').removeClass('hide');
$('#online_anon_count').html(anonCount);
} else {
$('#users-container .anon-user').addClass('hide');
}
2013-10-04 15:30:52 -04:00
});
2013-09-23 14:40:31 -04:00
}
2013-09-23 13:43:15 -04:00
});
2013-09-17 13:05:54 -04:00
2013-10-09 17:30:49 -04:00
function onUsersLoaded(users, emptyContainer) {
2013-09-17 13:05:54 -04:00
var html = templates.prepare(templates['users'].blocks['users']).parse({
users: users
});
2013-10-09 17:30:49 -04:00
if(emptyContainer)
$('#users-container .registered-user').remove();
$('#users-container').append(html);
$('#users-container .anon-user').appendTo($('#users-container'));
}
2013-09-17 13:05:54 -04:00
function loadMoreUsers() {
var set = '';
2013-09-19 15:50:28 -04:00
if (active === 'latest' || active === 'users') {
set = 'users:joindate';
2013-09-19 15:50:28 -04:00
} else if (active === 'sort-posts') {
set = 'users:postcount';
2013-09-19 15:50:28 -04:00
} else if (active === 'sort-reputation') {
2013-09-17 13:05:54 -04:00
set = 'users:reputation';
2013-09-23 13:43:15 -04:00
} else if (active === 'online') {
set = 'users:online';
}
2013-09-17 13:05:54 -04:00
if (set) {
startLoading(set, $('#users-container').children('.registered-user').length);
}
}
2013-09-17 13:05:54 -04:00
2013-10-09 17:30:49 -04:00
function startLoading(set, after, emptyContainer) {
2013-09-23 14:40:31 -04:00
loadingMoreUsers = true;
socket.emit('user.loadMore', {
2013-09-23 13:43:15 -04:00
set: set,
after: after
2014-01-16 18:12:31 -05:00
}, function(err, data) {
if (data && data.users.length) {
2013-10-09 17:30:49 -04:00
onUsersLoaded(data.users, emptyContainer);
2013-09-23 13:43:15 -04:00
$('#load-more-users-btn').removeClass('disabled');
} else {
$('#load-more-users-btn').addClass('disabled');
}
loadingMoreUsers = false;
});
}
$('#load-more-users-btn').on('click', loadMoreUsers);
2013-09-17 13:05:54 -04:00
$(window).off('scroll').on('scroll', function() {
var bottom = ($(document).height() - $(window).height()) * 0.9;
if ($(window).scrollTop() > bottom && !loadingMoreUsers) {
loadMoreUsers();
}
});
};
return Users;
});