jQuery(function($) {
"use strict";
var TEMPLATES = new LuigiTemplate.Cache({
user: [
"",
"",
"",
" ",
"%{user_name|h} (%{email|h})",
"",
"%{role_name|h}",
"",
"",
],
loading: [
"",
"",
" ",
"Loading...",
"",
],
error: [
"",
"",
" ",
"Error: %{responseText|h}",
"",
],
});
function filter() {
var qs = $('#filter-q').val().replace(/^\s+|\s+$/g, '').toLowerCase().split(/\s+/);
if (qs.length > 0) {
// hide all users
$('#users .list-group-item').addClass('hidden');
// show matching users
$($.grep($('#users .list-group-item'), function(el) {
var eq = $(el).data('q');
return ($.grep(qs, function(q) {
return eq.indexOf(q) !== -1;
}).length == qs.length);
})).removeClass('hidden');
} else {
// show all users
$('#users .list-group-item').removeClass('hidden');
}
}
function reload() {
var btn = $('#reload'),
list = $('#users');
// show loading
btn.toggleClass('disabled').find('.loading').toggleClass('hidden');
list.html(TEMPLATES.run('loading'));
send('test/get_users').always(function() {
btn.toggleClass('disabled').find('.loading').toggleClass('hidden');
list.html('');
}).fail(function(r) {
console.log('get_users failed: ' + r.responseText);
list.html(TEMPLATES.run('error', r));
}).done(function(r) {
list.html($.map(r.users, function(row) {
return TEMPLATES.run('user', $.extend({}, row, {
q: [row.user_id, row.user_name, row.email, row.role_name].join(' ').toLowerCase(),
row: row,
}));
}).join(''));
// refresh filters
filter();
});
// stop event
return false;
}
function set_user(user_id) {
return send('test/set_user', {
user_id: user_id,
}).fail(function(r) {
alert('Error ' + r.responseText);
}).done(function(r) {
// do nothing
});
}
$('#filter-q').on('search-update', function() {
filter();
});
$('#users').on('click', 'a.list-group-item', function() {
var me = $(this);
// update highlight
$('#users .active').removeClass('active');
me.addClass('active');
$('#edit-dialog').data('row', me.data('row')).modal('show');
// stop event
return false;
});
$('#add-dialog').on('show.bs.modal', function() {
$.each(['name', 'email', 'password'], function(i, id) {
$('#add-' + id).val('');
});
$('#add-role').val('guest');
});
$('#add-dialog').on('shown.bs.modal', function() {
$('#add-name').focus();
});
$('#add-name, #add-email, #add-password').keydown(function(ev) {
if (ev.which == 13) {
setTimeout(function() {
$('#add-confirm').click();
}, 10);
// stop event
return false;
}
});
$('#add-confirm').click(function() {
var me = $(this);
if (me.hasClass('disabled'))
return false;
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
send('test/add_user', {
name: $('#add-name').val(),
email: $('#add-email').val(),
password: $('#add-password').val(),
role: $('#add-role').val(),
active: 't',
}).always(function() {
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
}).fail(function(r) {
alert('Error ' + r.responseText);
}).done(function(r) {
console.log(r);
reload();
$('#add-dialog').modal('hide');
});
// stop event
return false;
});
$('#edit-dialog').on('show.bs.modal', function() {
var row = $(this).data('row');
$.each({
name: 'user_name',
email: 'email',
role: 'role_name',
}, function(id, col) {
$('#edit-' + id).val(row[col]);
});
});
$('#edit-dialog').on('shown.bs.modal', function() {
$('#edit-name').focus();
});
$('#edit-dialog').on('hide.bs.modal', function() {
// clear highlight
$('#users .active').removeClass('active');
});
$('#edit-name, #edit-email').keydown(function(ev) {
if (ev.which == 13) {
setTimeout(function() {
$('#edit-confirm').click();
}, 10);
// stop event
return false;
}
});
$('#edit-confirm').click(function() {
var me = $(this),
user_id = $('#edit-dialog').data('row').user_id;
if (me.hasClass('disabled'))
return false;
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
send('test/edit_user', {
user_id: user_id,
name: $('#edit-name').val(),
email: $('#edit-email').val(),
role: $('#edit-role').val(),
}).always(function() {
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
}).fail(function(r) {
alert('Error ' + r.responseText);
}).done(function(r) {
console.log(r);
reload();
$('#edit-dialog').modal('hide');
});
// stop event
return false;
});
$('#login-dialog').on('show.bs.modal', function() {
$('#login-email').val('');
$('#login-password').val('');
});
$('#login-dialog').on('shown.bs.modal', function() {
$('#login-email').focus();
});
$('#login-confirm').click(function() {
var me = $(this);
if (me.hasClass('disabled'))
return false;
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
send('test/login', {
email: $('#login-email').val(),
password: $('#login-password').val(),
}).always(function() {
// toggle loading
me.toggleClass('disabled').find('.loading').toggleClass('hidden');
}).fail(function(r) {
alert('Error ' + r.responseText);
}).done(function(r) {
console.log(r);
$('#login-dialog').modal('hide');
});
// stop event
return false;
});
$('#login-user, #login-password').keydown(function(ev) {
if (ev.which == 13) {
setTimeout(function() {
// trigger login
$('#login-confirm').click();
}, 10);
// stop event
return false;
}
});
$('#reload').click(reload);
// load users
$('#tab-users').on('show.bs.tab', function() {
reload();
});
});