283 lines
5.7 KiB
JavaScript
283 lines
5.7 KiB
JavaScript
jQuery(document).ready(function($) {
|
|
|
|
window.listTable = {
|
|
|
|
init: function() {
|
|
this.loading = false;
|
|
|
|
$('form').each(function() {
|
|
this.reset();
|
|
});
|
|
|
|
if ( '' == $.query.GET('paged') )
|
|
$.query.SET('paged', 1);
|
|
this.set_total_pages();
|
|
|
|
this.$tbody = $('#the-list, #the-comment-list');
|
|
|
|
this.$overlay = $('<div id="loading-items>')
|
|
.html(listTableL10n.loading)
|
|
.hide()
|
|
.prependTo($('body'));
|
|
},
|
|
|
|
// paging
|
|
set_total_pages: function(num) {
|
|
var last_page_url = $('.last-page').attr('href');
|
|
|
|
if ( last_page_url )
|
|
this.total_pages = num || $.query.load( last_page_url ).get('paged');
|
|
},
|
|
|
|
get_total_pages: function() {
|
|
return this.total_pages;
|
|
},
|
|
|
|
htmlencode: function(value) {
|
|
return $('<div/>').text(value).html();
|
|
},
|
|
|
|
update_rows: function(args, reset_paging, callback) {
|
|
if ( this.loading )
|
|
return false;
|
|
|
|
var different = false, data = {};
|
|
|
|
$.each(args, function(key, val) {
|
|
if ( val != $.query.GET(key) ) {
|
|
$.query.SET(key, val);
|
|
different = true;
|
|
}
|
|
});
|
|
|
|
if ( !different )
|
|
return false;
|
|
|
|
this.show_overlay();
|
|
|
|
if ( reset_paging )
|
|
$.query.SET('paged', 1);
|
|
|
|
$.each( $.query.get(), function(key, value) {
|
|
if ( true === value )
|
|
data[key] = '';
|
|
else
|
|
data[key] = value;
|
|
});
|
|
|
|
this._callback = callback;
|
|
|
|
this.fetch_list(
|
|
data,
|
|
$.proxy(this, 'handle_success'),
|
|
$.proxy(this, 'handle_error')
|
|
);
|
|
|
|
return true;
|
|
},
|
|
|
|
fetch_list: function(data, success_callback, error_callback) {
|
|
data = $.extend(data, {
|
|
'action': 'fetch-list',
|
|
'list_args': list_args
|
|
});
|
|
|
|
$.ajax({
|
|
url: ajaxurl,
|
|
global: false,
|
|
dataType: 'json',
|
|
data: data,
|
|
success: success_callback,
|
|
error: error_callback
|
|
});
|
|
},
|
|
|
|
handle_success: function(response) {
|
|
if ( 'object' != typeof response ) {
|
|
this.handle_error();
|
|
} else {
|
|
this.hide_overlay();
|
|
|
|
this.$tbody.html(response.rows);
|
|
|
|
$('.displaying-num').html(response.total_items_i18n);
|
|
$('.total-pages').html(response.total_pages_i18n);
|
|
|
|
this.set_total_pages(response.total_pages);
|
|
|
|
$('.current-page').val($.query.GET('paged'));
|
|
|
|
$('th.column-cb :input').attr('checked', false);
|
|
|
|
if ( this._callback )
|
|
this._callback();
|
|
}
|
|
},
|
|
|
|
handle_error: function() {
|
|
this.hide_overlay();
|
|
|
|
$('h2').after('<div class="error ajax below-h2"><p>' + listTableL10n.error + '</p></div>');
|
|
},
|
|
|
|
show_overlay: function() {
|
|
this.loading = true;
|
|
|
|
$('.error.ajax').remove();
|
|
|
|
this.$overlay
|
|
.css({
|
|
width: this.$tbody.width() + 'px',
|
|
height: this.$tbody.height() - 20 + 'px'
|
|
})
|
|
.css(this.$tbody.offset())
|
|
.show();
|
|
},
|
|
|
|
hide_overlay: function() {
|
|
this.loading = false;
|
|
this.$overlay.hide();
|
|
}
|
|
}
|
|
|
|
listTable.init();
|
|
|
|
// Ajaxify various UI elements
|
|
|
|
function change_page(paged, $el) {
|
|
if ( paged < 1 || paged > listTable.get_total_pages() )
|
|
return false;
|
|
|
|
listTable.update_rows({'paged': paged}, false, function() {
|
|
if ( $el.parents('.tablenav.bottom').length )
|
|
window.scrollTo(0, 0);
|
|
});
|
|
}
|
|
|
|
// pagination
|
|
$('.tablenav-pages a').click(function() {
|
|
var $el = $(this),
|
|
paged = $.query.GET('paged');
|
|
|
|
switch ( $el.attr('class') ) {
|
|
case 'first-page':
|
|
paged = 1;
|
|
break;
|
|
case 'prev-page':
|
|
paged -= 1;
|
|
break;
|
|
case 'next-page':
|
|
paged += 1;
|
|
break;
|
|
case 'last-page':
|
|
paged = listTable.get_total_pages();
|
|
break;
|
|
}
|
|
|
|
change_page(paged, $el);
|
|
|
|
return false;
|
|
});
|
|
|
|
$('.current-page').keypress(function(e) {
|
|
if ( 13 != e.keyCode )
|
|
return;
|
|
|
|
var $el = $(this);
|
|
|
|
change_page(parseInt($el.val()), $el);
|
|
|
|
return false;
|
|
});
|
|
|
|
// sortable columns
|
|
$('th.sortable a, th.sorted a').click(function() {
|
|
|
|
function get_initial_order($el) {
|
|
return $.query.load( $el.find('a').attr('href') ).get('order');
|
|
}
|
|
|
|
var $link = $(this),
|
|
$th = $link.parent('th'),
|
|
orderby = $.query.load( $link.attr('href') ).get('orderby'),
|
|
order;
|
|
|
|
if ( orderby == $.query.get('orderby') ) {
|
|
// changing the direction
|
|
order = ( 'asc' == $.query.get('order') ) ? 'desc' : 'asc';
|
|
} else {
|
|
// changing the parameter
|
|
order = get_initial_order($th);
|
|
|
|
var $old_th = $('th.sorted');
|
|
if ( $old_th.length ) {
|
|
$old_th.removeClass('sorted').addClass('sortable');
|
|
$old_th.removeClass('desc').removeClass('asc').addClass(
|
|
'asc' == get_initial_order( $old_th ) ? 'desc' : 'asc'
|
|
);
|
|
}
|
|
|
|
$th.removeClass('sortable').addClass('sorted');
|
|
}
|
|
|
|
$th.removeClass('desc').removeClass('asc').addClass(order);
|
|
|
|
listTable.update_rows({'orderby': orderby, 'order': order}, true);
|
|
|
|
return false;
|
|
});
|
|
|
|
// searchbox
|
|
function change_search(ev) {
|
|
if ( 'keypress' == ev.type && 13 != ev.keyCode )
|
|
return;
|
|
|
|
ev.preventDefault();
|
|
ev.stopImmediatePropagation();
|
|
|
|
var data = $(this).parent('.search-box').find(':input').serializeObject();
|
|
|
|
listTable.update_rows(data, true, function() {
|
|
if ( $('h2.nav-tab-wrapper').length )
|
|
return;
|
|
|
|
$('h2 .subtitle').remove();
|
|
|
|
if ( data.s )
|
|
$('h2').append($('<span class="subtitle">').html(
|
|
listTableL10n.search.replace('%s', this.htmlencode(data.s))
|
|
));
|
|
});
|
|
}
|
|
$('.search-box :submit').click(change_search);
|
|
$('.search-box :text').keypress(change_search);
|
|
|
|
// tablenav dropdowns
|
|
$('#post-query-submit').click(function() {
|
|
var args = {};
|
|
|
|
$(this).parents('.actions').find('select[name!="action"]').each(function() {
|
|
var $el = $(this);
|
|
|
|
args[$el.attr('name')] = $el.val();
|
|
});
|
|
|
|
listTable.update_rows(args, true);
|
|
|
|
return false;
|
|
});
|
|
|
|
// view switch
|
|
$('.view-switch a').click(function() {
|
|
var $this = $(this);
|
|
|
|
listTable.update_rows({'mode': $.query.load($this.attr('href')).get('mode')}, false, function() {
|
|
$('.view-switch .current').removeClass('current');
|
|
$this.addClass('current');
|
|
});
|
|
|
|
return false;
|
|
});
|
|
});
|
|
|