2011-09-14 09:02:46 +02:00
|
|
|
var showNotice, adminMenu, columns, validateForm, screenMeta, autofold_menu;
|
2009-01-12 14:43:17 +01:00
|
|
|
(function($){
|
2011-10-06 11:18:56 +02:00
|
|
|
// Removed in 3.3.
|
|
|
|
// (perhaps) needed for back-compat
|
2009-01-12 14:43:17 +01:00
|
|
|
adminMenu = {
|
2011-10-06 11:18:56 +02:00
|
|
|
init : function() {},
|
|
|
|
fold : function() {},
|
|
|
|
restoreMenuState : function() {},
|
|
|
|
toggle : function() {},
|
|
|
|
favorites : function() {}
|
2009-01-02 16:08:58 +01:00
|
|
|
};
|
|
|
|
|
2009-01-12 14:43:17 +01:00
|
|
|
// show/hide/save table columns
|
|
|
|
columns = {
|
|
|
|
init : function() {
|
2010-11-13 18:21:40 +01:00
|
|
|
var that = this;
|
2010-11-13 16:58:23 +01:00
|
|
|
$('.hide-column-tog', '#adv-settings').click( function() {
|
2010-11-13 18:21:40 +01:00
|
|
|
var $t = $(this), column = $t.val();
|
2011-05-25 03:04:12 +02:00
|
|
|
if ( $t.prop('checked') )
|
2010-11-13 18:21:40 +01:00
|
|
|
that.checked(column);
|
|
|
|
else
|
|
|
|
that.unchecked(column);
|
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
columns.saveManageColumnsState();
|
2009-08-18 11:53:37 +02:00
|
|
|
});
|
2009-01-12 14:43:17 +01:00
|
|
|
},
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
saveManageColumnsState : function() {
|
|
|
|
var hidden = this.hidden();
|
2009-01-12 14:43:17 +01:00
|
|
|
$.post(ajaxurl, {
|
|
|
|
action: 'hidden-columns',
|
|
|
|
hidden: hidden,
|
2009-04-05 10:25:10 +02:00
|
|
|
screenoptionnonce: $('#screenoptionnonce').val(),
|
2009-01-12 14:43:17 +01:00
|
|
|
page: pagenow
|
|
|
|
});
|
2010-04-29 05:43:11 +02:00
|
|
|
},
|
2010-05-03 22:26:11 +02:00
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
checked : function(column) {
|
|
|
|
$('.column-' + column).show();
|
2010-11-14 19:00:09 +01:00
|
|
|
this.colSpanChange(+1);
|
2010-04-29 05:43:11 +02:00
|
|
|
},
|
2010-05-03 22:26:11 +02:00
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
unchecked : function(column) {
|
|
|
|
$('.column-' + column).hide();
|
2010-11-14 19:00:09 +01:00
|
|
|
this.colSpanChange(-1);
|
2010-04-29 05:43:11 +02:00
|
|
|
},
|
2010-05-03 22:26:11 +02:00
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
hidden : function() {
|
|
|
|
return $('.manage-column').filter(':hidden').map(function() { return this.id; }).get().join(',');
|
|
|
|
},
|
2010-05-03 22:26:11 +02:00
|
|
|
|
2010-04-29 05:43:11 +02:00
|
|
|
useCheckboxesForHidden : function() {
|
|
|
|
this.hidden = function(){
|
|
|
|
return $('.hide-column-tog').not(':checked').map(function() {
|
|
|
|
var id = this.id;
|
|
|
|
return id.substring( id, id.length - 5 );
|
|
|
|
}).get().join(',');
|
|
|
|
};
|
2010-11-14 19:00:09 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
colSpanChange : function(diff) {
|
2010-11-17 05:52:01 +01:00
|
|
|
var $t = $('table').find('.colspanchange'), n;
|
2010-11-14 19:00:09 +01:00
|
|
|
if ( !$t.length )
|
|
|
|
return;
|
2010-11-17 05:52:01 +01:00
|
|
|
n = parseInt( $t.attr('colspan'), 10 ) + diff;
|
2010-11-14 19:00:09 +01:00
|
|
|
$t.attr('colspan', n.toString());
|
2010-05-06 16:13:31 +02:00
|
|
|
}
|
2009-01-02 16:08:58 +01:00
|
|
|
}
|
2009-03-27 23:47:47 +01:00
|
|
|
|
2009-01-12 14:43:17 +01:00
|
|
|
$(document).ready(function(){columns.init();});
|
2009-03-27 23:47:47 +01:00
|
|
|
|
2009-07-01 10:12:39 +02:00
|
|
|
validateForm = function( form ) {
|
2009-11-19 11:24:14 +01:00
|
|
|
return !$( form ).find('.form-required').filter( function() { return $('input:visible', this).val() == ''; } ).addClass( 'form-invalid' ).find('input:visible').change( function() { $(this).closest('.form-invalid').removeClass( 'form-invalid' ); } ).size();
|
2009-07-01 10:12:39 +02:00
|
|
|
}
|
|
|
|
|
2009-01-12 14:43:17 +01:00
|
|
|
// stub for doing better warnings
|
|
|
|
showNotice = {
|
|
|
|
warn : function() {
|
|
|
|
var msg = commonL10n.warnDelete || '';
|
|
|
|
if ( confirm(msg) ) {
|
|
|
|
return true;
|
|
|
|
}
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2009-01-12 14:43:17 +01:00
|
|
|
return false;
|
|
|
|
},
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2009-01-12 14:43:17 +01:00
|
|
|
note : function(text) {
|
|
|
|
alert(text);
|
|
|
|
}
|
|
|
|
};
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
screenMeta = {
|
2011-09-16 07:01:54 +02:00
|
|
|
element: null, // #screen-meta
|
|
|
|
toggles: null, // .screen-meta-toggle
|
2011-09-16 09:10:04 +02:00
|
|
|
page: null, // #wpcontent
|
2011-09-16 07:01:54 +02:00
|
|
|
padding: null, // the closed page padding-top property
|
|
|
|
top: null, // the closed element top property
|
|
|
|
map: {
|
|
|
|
'wp-admin-bar-screen-options': 'screen-options-wrap',
|
|
|
|
'wp-admin-bar-help': 'contextual-help-wrap'
|
2011-05-05 21:51:32 +02:00
|
|
|
},
|
2011-09-16 07:01:54 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
init: function() {
|
2011-09-16 07:01:54 +02:00
|
|
|
screenMeta.element = $('#screen-meta');
|
|
|
|
screenMeta.toggles = $('.screen-meta-toggle');
|
2011-09-16 09:10:04 +02:00
|
|
|
screenMeta.page = $('#wpcontent');
|
2011-09-16 07:01:54 +02:00
|
|
|
|
|
|
|
screenMeta.toggles.click( screenMeta.toggleEvent );
|
2011-05-05 21:51:32 +02:00
|
|
|
},
|
2011-09-16 07:01:54 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
toggleEvent: function( e ) {
|
|
|
|
var panel;
|
|
|
|
e.preventDefault();
|
2009-05-25 01:47:49 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
// Check to see if we found a panel.
|
2011-09-16 07:01:54 +02:00
|
|
|
if ( ! screenMeta.map[ this.id ] )
|
2011-05-05 21:51:32 +02:00
|
|
|
return;
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2011-09-16 07:01:54 +02:00
|
|
|
panel = $('#' + screenMeta.map[ this.id ]);
|
2009-08-18 11:53:37 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
if ( panel.is(':visible') )
|
|
|
|
screenMeta.close( panel, $(this) );
|
|
|
|
else
|
|
|
|
screenMeta.open( panel, $(this) );
|
|
|
|
},
|
|
|
|
open: function( panel, link ) {
|
2011-09-16 07:01:54 +02:00
|
|
|
// Close open panel
|
|
|
|
screenMeta.toggles.filter('.selected').click();
|
2011-05-05 21:51:32 +02:00
|
|
|
|
2011-09-16 07:01:54 +02:00
|
|
|
// Open selected panel
|
|
|
|
link.addClass('selected');
|
|
|
|
|
|
|
|
screenMeta.padding = parseInt( screenMeta.page.css('paddingTop'), 10 );
|
|
|
|
screenMeta.top = parseInt( screenMeta.element.css('top'), 10 );
|
|
|
|
|
|
|
|
panel.show();
|
|
|
|
|
2011-09-28 02:57:56 +02:00
|
|
|
screenMeta.refresh();
|
|
|
|
},
|
|
|
|
refresh: function( panel, link ) {
|
2011-10-23 19:55:24 +02:00
|
|
|
var columns = $('#contextual-help-wrap').children(),
|
|
|
|
height;
|
|
|
|
|
|
|
|
columns.height('auto');
|
2011-10-24 21:13:23 +02:00
|
|
|
|
2011-10-23 19:55:24 +02:00
|
|
|
height = Math.max.apply( null, $.map( columns, function( el ) { return $(el).height(); }) );
|
|
|
|
columns.height( height );
|
|
|
|
|
2011-09-16 07:01:54 +02:00
|
|
|
screenMeta.element.css({ top: 0 });
|
|
|
|
screenMeta.page.css({ paddingTop: screenMeta.padding + screenMeta.element.outerHeight() });
|
2011-05-05 21:51:32 +02:00
|
|
|
},
|
|
|
|
close: function( panel, link ) {
|
2011-09-16 07:01:54 +02:00
|
|
|
screenMeta.element.css({ top: screenMeta.top });
|
|
|
|
screenMeta.page.css({ paddingTop: screenMeta.padding });
|
|
|
|
panel.hide();
|
|
|
|
link.removeClass('selected');
|
2011-05-05 21:51:32 +02:00
|
|
|
}
|
|
|
|
};
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2011-09-26 23:03:38 +02:00
|
|
|
/**
|
|
|
|
* Help tabs.
|
|
|
|
*/
|
|
|
|
$('.contextual-help-tabs').delegate('a', 'click focus', function(e) {
|
|
|
|
var link = $(this),
|
2011-10-23 19:55:24 +02:00
|
|
|
panel;
|
2011-09-26 23:03:38 +02:00
|
|
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
// Don't do anything if the click is for the tab already showing.
|
|
|
|
if ( link.is('.active a') )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Links
|
|
|
|
$('.contextual-help-tabs .active').removeClass('active');
|
|
|
|
link.parent('li').addClass('active');
|
|
|
|
|
|
|
|
panel = $( link.attr('href') );
|
|
|
|
|
|
|
|
// Panels
|
|
|
|
$('.help-tab-content').not( panel ).removeClass('active').hide();
|
|
|
|
panel.addClass('active').show();
|
2011-09-28 02:57:56 +02:00
|
|
|
|
|
|
|
// Refresh the padding of the screen meta box.
|
|
|
|
screenMeta.refresh();
|
2011-09-26 23:03:38 +02:00
|
|
|
});
|
2011-09-16 07:01:54 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
$(document).ready( function() {
|
2011-10-06 11:18:56 +02:00
|
|
|
var lastClicked = false, checks, first, last, checked, menu = $('#adminmenu'),
|
2011-10-13 04:47:00 +02:00
|
|
|
pageInput = $('input.current-page'), currentPage = pageInput.val(), folded;
|
2011-10-06 11:18:56 +02:00
|
|
|
|
|
|
|
// admin menu
|
|
|
|
$('#collapse-menu', menu).click(function(){
|
|
|
|
var body = $(document.body);
|
|
|
|
|
|
|
|
if ( body.hasClass('folded') ) {
|
|
|
|
body.removeClass('folded');
|
2011-10-29 23:56:27 +02:00
|
|
|
setUserSetting('mfold', 'o');
|
2011-10-06 11:18:56 +02:00
|
|
|
} else {
|
|
|
|
body.addClass('folded');
|
|
|
|
setUserSetting('mfold', 'f');
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
|
|
|
|
$('li.wp-has-submenu', menu).hoverIntent({
|
|
|
|
over: function(e){
|
|
|
|
var b, h, o, f, m = $(this).find('.wp-submenu');
|
|
|
|
|
2011-10-11 19:59:51 +02:00
|
|
|
if ( !$(document.body).hasClass('folded') && $(this).hasClass('wp-menu-open') )
|
|
|
|
return;
|
|
|
|
|
2011-10-06 11:18:56 +02:00
|
|
|
b = $(this).offset().top + m.height() + 1; // Bottom offset of the menu
|
|
|
|
h = $('#wpwrap').height(); // Height of the entire page
|
|
|
|
o = 60 + b - h;
|
|
|
|
f = $(window).height() + $(window).scrollTop() - 15; // The fold
|
|
|
|
|
|
|
|
if ( f < (b - o) )
|
|
|
|
o = b - f;
|
|
|
|
|
|
|
|
if ( o > 1 )
|
|
|
|
m.css({'marginTop':'-'+o+'px'});
|
|
|
|
else if ( m.css('marginTop') )
|
|
|
|
m.css({'marginTop':''});
|
|
|
|
|
|
|
|
m.addClass('sub-open');
|
|
|
|
},
|
|
|
|
out: function(){
|
|
|
|
$(this).find('.wp-submenu').removeClass('sub-open');
|
|
|
|
},
|
|
|
|
timeout: 200,
|
|
|
|
sensitivity: 7,
|
|
|
|
interval: 90
|
|
|
|
});
|
2009-08-18 11:53:37 +02:00
|
|
|
|
2011-05-05 21:51:32 +02:00
|
|
|
// Move .updated and .error alert boxes. Don't move boxes designed to be inline.
|
|
|
|
$('div.wrap h2:first').nextAll('div.updated, div.error').addClass('below-h2');
|
|
|
|
$('div.updated, div.error').not('.below-h2, .inline').insertAfter( $('div.wrap h2:first') );
|
|
|
|
|
|
|
|
// Init screen meta
|
|
|
|
screenMeta.init();
|
2009-01-02 16:08:58 +01:00
|
|
|
|
|
|
|
// check all checkboxes
|
2009-08-18 11:53:37 +02:00
|
|
|
$('tbody').children().children('.check-column').find(':checkbox').click( function(e) {
|
2009-01-02 16:08:58 +01:00
|
|
|
if ( 'undefined' == e.shiftKey ) { return true; }
|
|
|
|
if ( e.shiftKey ) {
|
|
|
|
if ( !lastClicked ) { return true; }
|
2009-08-18 11:53:37 +02:00
|
|
|
checks = $( lastClicked ).closest( 'form' ).find( ':checkbox' );
|
2009-01-02 16:08:58 +01:00
|
|
|
first = checks.index( lastClicked );
|
|
|
|
last = checks.index( this );
|
2011-05-25 03:04:12 +02:00
|
|
|
checked = $(this).prop('checked');
|
2009-01-02 16:08:58 +01:00
|
|
|
if ( 0 < first && 0 < last && first != last ) {
|
2011-05-25 03:04:12 +02:00
|
|
|
checks.slice( first, last ).prop( 'checked', function(){
|
2009-08-18 11:53:37 +02:00
|
|
|
if ( $(this).closest('tr').is(':visible') )
|
2011-05-25 03:04:12 +02:00
|
|
|
return checked;
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2011-05-25 03:04:12 +02:00
|
|
|
return false;
|
2009-01-02 16:08:58 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
lastClicked = this;
|
|
|
|
return true;
|
2009-08-18 11:53:37 +02:00
|
|
|
});
|
2009-01-02 16:08:58 +01:00
|
|
|
|
2010-10-07 11:53:37 +02:00
|
|
|
$('thead, tfoot').find('.check-column :checkbox').click( function(e) {
|
2011-05-21 00:47:36 +02:00
|
|
|
var c = $(this).prop('checked'),
|
2009-08-18 11:53:37 +02:00
|
|
|
kbtoggle = 'undefined' == typeof toggleWithKeyboard ? false : toggleWithKeyboard,
|
|
|
|
toggle = e.shiftKey || kbtoggle;
|
2009-12-09 12:27:47 +01:00
|
|
|
|
2009-08-18 11:53:37 +02:00
|
|
|
$(this).closest( 'table' ).children( 'tbody' ).filter(':visible')
|
|
|
|
.children().children('.check-column').find(':checkbox')
|
2011-05-21 00:47:36 +02:00
|
|
|
.prop('checked', function() {
|
2009-08-18 11:53:37 +02:00
|
|
|
if ( $(this).closest('tr').is(':hidden') )
|
2011-05-21 00:47:36 +02:00
|
|
|
return false;
|
2009-01-02 16:08:58 +01:00
|
|
|
if ( toggle )
|
2011-05-21 00:47:36 +02:00
|
|
|
return $(this).prop( 'checked' );
|
2009-01-02 16:08:58 +01:00
|
|
|
else if (c)
|
2011-05-21 00:47:36 +02:00
|
|
|
return true;
|
|
|
|
return false;
|
2009-01-02 16:08:58 +01:00
|
|
|
});
|
2009-08-18 11:53:37 +02:00
|
|
|
|
|
|
|
$(this).closest('table').children('thead, tfoot').filter(':visible')
|
|
|
|
.children().children('.check-column').find(':checkbox')
|
2011-05-21 00:47:36 +02:00
|
|
|
.prop('checked', function() {
|
2009-01-02 16:08:58 +01:00
|
|
|
if ( toggle )
|
2011-05-21 00:47:36 +02:00
|
|
|
return false;
|
2009-01-02 16:08:58 +01:00
|
|
|
else if (c)
|
2011-05-21 00:47:36 +02:00
|
|
|
return true;
|
|
|
|
return false;
|
2009-01-02 16:08:58 +01:00
|
|
|
});
|
|
|
|
});
|
2009-08-18 11:53:37 +02:00
|
|
|
|
2009-05-03 19:06:29 +02:00
|
|
|
$('#default-password-nag-no').click( function() {
|
|
|
|
setUserSetting('default_password_nag', 'hide');
|
|
|
|
$('div.default-password-nag').hide();
|
|
|
|
return false;
|
|
|
|
});
|
2010-02-18 06:14:48 +01:00
|
|
|
|
|
|
|
// tab in textareas
|
2011-05-21 00:47:36 +02:00
|
|
|
$('#newcontent').bind('keydown.wpevent_InsertTab', function(e) {
|
2010-02-18 06:14:48 +01:00
|
|
|
if ( e.keyCode != 9 )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
var el = e.target, selStart = el.selectionStart, selEnd = el.selectionEnd, val = el.value, scroll, sel;
|
|
|
|
|
2010-03-02 12:49:06 +01:00
|
|
|
try {
|
|
|
|
this.lastKey = 9; // not a standard DOM property, lastKey is to help stop Opera tab event. See blur handler below.
|
|
|
|
} catch(err) {}
|
2010-02-18 06:14:48 +01:00
|
|
|
|
|
|
|
if ( document.selection ) {
|
|
|
|
el.focus();
|
|
|
|
sel = document.selection.createRange();
|
|
|
|
sel.text = '\t';
|
|
|
|
} else if ( selStart >= 0 ) {
|
|
|
|
scroll = this.scrollTop;
|
|
|
|
el.value = val.substring(0, selStart).concat('\t', val.substring(selEnd) );
|
|
|
|
el.selectionStart = el.selectionEnd = selStart + 1;
|
|
|
|
this.scrollTop = scroll;
|
|
|
|
}
|
2010-03-17 17:27:25 +01:00
|
|
|
|
2010-03-02 12:49:06 +01:00
|
|
|
if ( e.stopPropagation )
|
|
|
|
e.stopPropagation();
|
|
|
|
if ( e.preventDefault )
|
|
|
|
e.preventDefault();
|
|
|
|
});
|
2010-03-17 17:27:25 +01:00
|
|
|
|
2011-05-21 00:47:36 +02:00
|
|
|
$('#newcontent').bind('blur.wpevent_InsertTab', function(e) {
|
2010-03-02 12:49:06 +01:00
|
|
|
if ( this.lastKey && 9 == this.lastKey )
|
|
|
|
this.focus();
|
2010-02-18 06:14:48 +01:00
|
|
|
});
|
2011-06-10 21:33:45 +02:00
|
|
|
|
|
|
|
if ( pageInput.length ) {
|
2011-07-11 23:53:29 +02:00
|
|
|
pageInput.closest('form').submit( function(e){
|
|
|
|
|
|
|
|
// Reset paging var for new filters/searches but not for bulk actions. See #17685.
|
|
|
|
if ( $('select[name="action"]').val() == -1 && $('select[name="action2"]').val() == -1 && pageInput.val() == currentPage )
|
2011-06-10 21:33:45 +02:00
|
|
|
pageInput.val('1');
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2011-09-14 09:02:46 +02:00
|
|
|
// auto-fold the menu when screen is under 800px
|
|
|
|
$(window).bind('resize.autofold', function(){
|
|
|
|
if ( getUserSetting('mfold') == 'f' )
|
|
|
|
return;
|
|
|
|
|
2011-09-23 22:22:52 +02:00
|
|
|
var width = $(window).width();
|
2011-09-14 09:02:46 +02:00
|
|
|
|
2011-09-23 22:22:52 +02:00
|
|
|
// fold admin menu
|
2011-10-06 11:18:56 +02:00
|
|
|
if ( width <= 800 ) {
|
|
|
|
if ( !folded ) {
|
|
|
|
$(document.body).addClass('folded');
|
|
|
|
folded = true;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ( folded ) {
|
|
|
|
$(document.body).removeClass('folded');
|
|
|
|
folded = false;
|
|
|
|
}
|
|
|
|
}
|
2011-09-14 09:02:46 +02:00
|
|
|
|
|
|
|
}).triggerHandler('resize');
|
2011-10-10 06:19:05 +02:00
|
|
|
|
2010-10-07 11:53:37 +02:00
|
|
|
});
|
2011-05-05 21:51:32 +02:00
|
|
|
|
2011-05-29 04:04:52 +02:00
|
|
|
// internal use
|
2011-05-29 07:07:32 +02:00
|
|
|
$(document).bind( 'wp_CloseOnEscape', function( e, data ) {
|
2011-05-29 04:04:52 +02:00
|
|
|
if ( typeof(data.cb) != 'function' )
|
|
|
|
return;
|
|
|
|
|
|
|
|
if ( typeof(data.condition) != 'function' || data.condition() )
|
|
|
|
data.cb();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
|
2011-05-21 00:47:36 +02:00
|
|
|
})(jQuery);
|