jQuery(function($) {
"use strict";
var TEMPLATES = new LuigiTemplate.Cache({
theme: [
"",
"",
" ",
"%{theme_name|h} (%{theme_version|h}, %{theme_date|h})",
"",
],
loading: [
"",
"",
" ",
"Loading...",
"",
],
error: [
"",
"",
" ",
"Error: %{error|h}",
"",
],
});
function filter() {
var qs = $('#themes-q').val().replace(/^\s+|\s+$/g, '').toLowerCase().split(/\s+/);
if (qs.length > 0) {
// hide all themes
$('#themes .list-group-item').addClass('hidden');
// show matching themes
$($.grep($('#themes .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 themes
$('#themes .list-group-item').removeClass('hidden');
}
}
function reload() {
var btn = $('#themes-reload'),
list = $('#themes');
// show loading
btn.toggleClass('disabled').find('.loading').toggleClass('hidden');
list.html(TEMPLATES.run('loading'));
send('theme/list').always(function() {
btn.toggleClass('disabled').find('.loading').toggleClass('hidden');
list.html('');
}).fail(function(r) {
var error = r.responseText;
try {
var data = $.parseJSON(r.responseText);
if (data.error)
error = data.error;
} catch (e) {}
list.html(TEMPLATES.run('error', {
error: error
}));
}).done(function(r) {
list.html($.map(r, function(row) {
var active = (row.is_active == '1');
return TEMPLATES.run('theme', $.extend({}, row, {
q: [row.theme_id, row.theme_name, row.theme_version, row.theme_date].join(' ').toLowerCase(),
}));
}).join(''));
// refresh filters
filter();
});
// stop event
return false;
}
$('#themes-q').on('search-update', function() {
filter();
});
$('#themes').on('click', 'a.list-group-item', function() {
var theme_id = $(this).data('theme_id');
// update highlight
$('#themes .active').removeClass('active');
$(this).addClass('active');
// TODO: show theme details dialog
// $('#theme-edit-dialog').data('theme_id', theme_id).modal('show');
// stop event
return false;
});
$('#themes-reload').click(reload);
// load themes
$('#settings-tab-themes').on('show.bs.tab', function() {
reload();
});
});