Speed up jQuery based scripts, props Denis-de-Bernardy, see #10021
git-svn-id: http://svn.automattic.com/wordpress/trunk@11837 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
9eef5564d5
commit
491b68752b
|
@ -2,18 +2,20 @@ var showNotice, adminMenu, columns, validateForm;
|
||||||
(function($){
|
(function($){
|
||||||
// sidebar admin menu
|
// sidebar admin menu
|
||||||
adminMenu = {
|
adminMenu = {
|
||||||
|
|
||||||
init : function() {
|
init : function() {
|
||||||
$('#adminmenu div.wp-menu-toggle').each( function() {
|
var menu = $('#adminmenu');
|
||||||
if ( $(this).siblings('.wp-submenu').length )
|
|
||||||
$(this).click(function(){ adminMenu.toggle( $(this).siblings('.wp-submenu') ); });
|
$('.wp-menu-toggle', menu).each( function() {
|
||||||
|
var t = $(this), sub = t.siblings('.wp-submenu');
|
||||||
|
if ( sub.length )
|
||||||
|
t.click(function(){ adminMenu.toggle( sub ); });
|
||||||
else
|
else
|
||||||
$(this).hide();
|
t.hide();
|
||||||
});
|
});
|
||||||
|
|
||||||
this.favorites();
|
this.favorites();
|
||||||
|
|
||||||
$('a.separator').click(function(){
|
$('.separator', menu).click(function(){
|
||||||
if ( $('body').hasClass('folded') ) {
|
if ( $('body').hasClass('folded') ) {
|
||||||
adminMenu.fold(1);
|
adminMenu.fold(1);
|
||||||
deleteUserSetting( 'mfold' );
|
deleteUserSetting( 'mfold' );
|
||||||
|
@ -24,27 +26,31 @@ adminMenu = {
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
if ( $('body').hasClass('folded') ) {
|
if ( $('body').hasClass('folded') )
|
||||||
this.fold();
|
this.fold();
|
||||||
}
|
|
||||||
this.restoreMenuState();
|
this.restoreMenuState();
|
||||||
},
|
},
|
||||||
|
|
||||||
restoreMenuState : function() {
|
restoreMenuState : function() {
|
||||||
$('#adminmenu li.wp-has-submenu').each(function(i, e) {
|
$('li.wp-has-submenu', '#adminmenu').each(function(i, e) {
|
||||||
var v = getUserSetting( 'm'+i );
|
var v = getUserSetting( 'm'+i );
|
||||||
if ( $(e).hasClass('wp-has-current-submenu') ) return true; // leave the current parent open
|
if ( $(e).hasClass('wp-has-current-submenu') )
|
||||||
|
return true; // leave the current parent open
|
||||||
|
|
||||||
if ( 'o' == v ) $(e).addClass('wp-menu-open');
|
if ( 'o' == v )
|
||||||
else if ( 'c' == v ) $(e).removeClass('wp-menu-open');
|
$(e).addClass('wp-menu-open');
|
||||||
|
else if ( 'c' == v )
|
||||||
|
$(e).removeClass('wp-menu-open');
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
toggle : function(el) {
|
toggle : function(el) {
|
||||||
|
el['slideToggle'](150, function() {
|
||||||
|
el.css('display','');
|
||||||
|
}).parent().toggleClass( 'wp-menu-open' );
|
||||||
|
|
||||||
el['slideToggle'](150, function(){el.css('display','');}).parent().toggleClass( 'wp-menu-open' );
|
$('.wp-has-submenu', '#adminmenu').each(function(i, e) {
|
||||||
|
|
||||||
$('#adminmenu li.wp-has-submenu').each(function(i, e) {
|
|
||||||
var v = $(e).hasClass('wp-menu-open') ? 'o' : 'c';
|
var v = $(e).hasClass('wp-menu-open') ? 'o' : 'c';
|
||||||
setUserSetting( 'm'+i, v );
|
setUserSetting( 'm'+i, v );
|
||||||
});
|
});
|
||||||
|
@ -62,14 +68,14 @@ adminMenu = {
|
||||||
over: function(e){
|
over: function(e){
|
||||||
var m, b, h, o, f;
|
var m, b, h, o, f;
|
||||||
m = $(this).find('.wp-submenu');
|
m = $(this).find('.wp-submenu');
|
||||||
b = m.parent().offset().top + m.height() + 1; // Bottom offset of the menu
|
b = $(this).offset().top + m.height() + 1; // Bottom offset of the menu
|
||||||
h = $('#wpwrap').height(); // Height of the entire page
|
h = $('#wpwrap').height(); // Height of the entire page
|
||||||
o = 60 + b - h;
|
o = 60 + b - h;
|
||||||
f = $(window).height() + $('body').scrollTop() - 15; // The fold
|
f = $(window).height() + $(window).scrollTop() - 15; // The fold
|
||||||
if (f < (b - o)) {
|
if ( f < (b - o) ) {
|
||||||
o = b - f;
|
o = b - f;
|
||||||
}
|
}
|
||||||
if (o > 1) {
|
if ( o > 1 ) {
|
||||||
m.css({'marginTop':'-'+o+'px'});
|
m.css({'marginTop':'-'+o+'px'});
|
||||||
} else if ( m.css('marginTop') ) {
|
} else if ( m.css('marginTop') ) {
|
||||||
m.css({'marginTop':''});
|
m.css({'marginTop':''});
|
||||||
|
@ -86,27 +92,42 @@ adminMenu = {
|
||||||
},
|
},
|
||||||
|
|
||||||
favorites : function() {
|
favorites : function() {
|
||||||
$('#favorite-inside').width($('#favorite-actions').width()-4);
|
$('#favorite-inside').width( $('#favorite-actions').width() - 4 );
|
||||||
$('#favorite-toggle, #favorite-inside').bind( 'mouseenter', function(){$('#favorite-inside').removeClass('slideUp').addClass('slideDown'); setTimeout(function(){if ( $('#favorite-inside').hasClass('slideDown') ) { $('#favorite-inside').slideDown(100); $('#favorite-first').addClass('slide-down'); }}, 200) } );
|
$('#favorite-toggle, #favorite-inside').bind('mouseenter', function() {
|
||||||
|
$('#favorite-inside').removeClass('slideUp').addClass('slideDown');
|
||||||
$('#favorite-toggle, #favorite-inside').bind( 'mouseleave', function(){$('#favorite-inside').removeClass('slideDown').addClass('slideUp'); setTimeout(function(){if ( $('#favorite-inside').hasClass('slideUp') ) { $('#favorite-inside').slideUp(100, function(){ $('#favorite-first').removeClass('slide-down'); } ); }}, 300) } );
|
setTimeout(function() {
|
||||||
|
if ( $('#favorite-inside').hasClass('slideDown') ) {
|
||||||
|
$('#favorite-inside').slideDown(100);
|
||||||
|
$('#favorite-first').addClass('slide-down');
|
||||||
|
}
|
||||||
|
}, 200);
|
||||||
|
}).bind('mouseleave', function() {
|
||||||
|
$('#favorite-inside').removeClass('slideDown').addClass('slideUp');
|
||||||
|
setTimeout(function() {
|
||||||
|
if ( $('#favorite-inside').hasClass('slideUp') ) {
|
||||||
|
$('#favorite-inside').slideUp(100, function() {
|
||||||
|
$('#favorite-first').removeClass('slide-down');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}, 300);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
$(document).ready(function(){adminMenu.init();});
|
$(document).ready(function(){ adminMenu.init(); });
|
||||||
|
|
||||||
// show/hide/save table columns
|
// show/hide/save table columns
|
||||||
columns = {
|
columns = {
|
||||||
init : function() {
|
init : function() {
|
||||||
$('.hide-column-tog').click( function() {
|
$('.hide-column-tog', '#adv-settings').click( function() {
|
||||||
var column = $(this).val(), show = $(this).attr('checked');
|
var column = $(this).val();
|
||||||
if ( show ) {
|
if ( $(this).attr('checked') )
|
||||||
$('.column-' + column).show();
|
$('.column-' + column).show();
|
||||||
} else {
|
else
|
||||||
$('.column-' + column).hide();
|
$('.column-' + column).hide();
|
||||||
}
|
|
||||||
columns.save_manage_columns_state();
|
columns.save_manage_columns_state();
|
||||||
} );
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
save_manage_columns_state : function() {
|
save_manage_columns_state : function() {
|
||||||
|
@ -148,17 +169,20 @@ jQuery(document).ready( function($) {
|
||||||
var lastClicked = false, checks, first, last, checked;
|
var lastClicked = false, checks, first, last, checked;
|
||||||
|
|
||||||
// pulse
|
// pulse
|
||||||
$('.fade').animate( { backgroundColor: '#ffffe0' }, 300).animate( { backgroundColor: '#fffbcc' }, 300).animate( { backgroundColor: '#ffffe0' }, 300).animate( { backgroundColor: '#fffbcc' }, 300);
|
$('div.fade').animate( { opacity: .5 }, 400)
|
||||||
|
.animate( { opacity: 1 }, 400)
|
||||||
|
.animate( { opacity: .5 }, 400)
|
||||||
|
.animate( { opacity: 1 }, 400);
|
||||||
|
|
||||||
// Move .updated and .error alert boxes
|
// Move .updated and .error alert boxes
|
||||||
$('div.wrap h2 ~ div.updated, div.wrap h2 ~ div.error').addClass('below-h2');
|
$('div.wrap').children('h2:first').nextAll('div.updated, div.error').addClass('below-h2');
|
||||||
$('div.updated, div.error').not('.below-h2').insertAfter('div.wrap h2:first');
|
$('div.updated, div.error').not('.below-h2').insertAfter( $('div.wrap').children('h2:first') );
|
||||||
|
|
||||||
// screen settings tab
|
// screen settings tab
|
||||||
$('#show-settings-link').click(function () {
|
$('#show-settings-link').click(function () {
|
||||||
if ( ! $('#screen-options-wrap').hasClass('screen-options-open') ) {
|
if ( ! $('#screen-options-wrap').hasClass('screen-options-open') )
|
||||||
$('#contextual-help-link-wrap').css('visibility', 'hidden');
|
$('#contextual-help-link-wrap').css('visibility', 'hidden');
|
||||||
}
|
|
||||||
$('#screen-options-wrap').slideToggle('fast', function(){
|
$('#screen-options-wrap').slideToggle('fast', function(){
|
||||||
if ( $(this).hasClass('screen-options-open') ) {
|
if ( $(this).hasClass('screen-options-open') ) {
|
||||||
$('#show-settings-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
|
$('#show-settings-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
|
||||||
|
@ -174,10 +198,10 @@ jQuery(document).ready( function($) {
|
||||||
|
|
||||||
// help tab
|
// help tab
|
||||||
$('#contextual-help-link').click(function () {
|
$('#contextual-help-link').click(function () {
|
||||||
if ( ! $('#contextual-help-wrap').hasClass('contextual-help-open') ) {
|
if ( ! $('#contextual-help-wrap').hasClass('contextual-help-open') )
|
||||||
$('#screen-options-link-wrap').css('visibility', 'hidden');
|
$('#screen-options-link-wrap').css('visibility', 'hidden');
|
||||||
}
|
|
||||||
$('#contextual-help-wrap').slideToggle('fast', function(){
|
$('#contextual-help-wrap').slideToggle('fast', function() {
|
||||||
if ( $(this).hasClass('contextual-help-open') ) {
|
if ( $(this).hasClass('contextual-help-open') ) {
|
||||||
$('#contextual-help-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
|
$('#contextual-help-link').css({'backgroundImage':'url("images/screen-options-right.gif")'});
|
||||||
$('#screen-options-link-wrap').css('visibility', '');
|
$('#screen-options-link-wrap').css('visibility', '');
|
||||||
|
@ -189,20 +213,19 @@ jQuery(document).ready( function($) {
|
||||||
});
|
});
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
$('#contextual-help-link-wrap, #screen-options-link-wrap').show();
|
|
||||||
|
|
||||||
// check all checkboxes
|
// check all checkboxes
|
||||||
$( 'table:visible tbody .check-column :checkbox' ).click( function(e) {
|
$('tbody').children().children('.check-column').find(':checkbox').click( function(e) {
|
||||||
if ( 'undefined' == e.shiftKey ) { return true; }
|
if ( 'undefined' == e.shiftKey ) { return true; }
|
||||||
if ( e.shiftKey ) {
|
if ( e.shiftKey ) {
|
||||||
if ( !lastClicked ) { return true; }
|
if ( !lastClicked ) { return true; }
|
||||||
checks = $( lastClicked ).parents( 'form:first' ).find( ':checkbox' );
|
checks = $( lastClicked ).closest( 'form' ).find( ':checkbox' );
|
||||||
first = checks.index( lastClicked );
|
first = checks.index( lastClicked );
|
||||||
last = checks.index( this );
|
last = checks.index( this );
|
||||||
checked = $(this).attr('checked');
|
checked = $(this).attr('checked');
|
||||||
if ( 0 < first && 0 < last && first != last ) {
|
if ( 0 < first && 0 < last && first != last ) {
|
||||||
checks.slice( first, last ).attr( 'checked', function(){
|
checks.slice( first, last ).attr( 'checked', function(){
|
||||||
if ( $(this).parents('tr').is(':visible') )
|
if ( $(this).closest('tr').is(':visible') )
|
||||||
return checked ? 'checked' : '';
|
return checked ? 'checked' : '';
|
||||||
|
|
||||||
return '';
|
return '';
|
||||||
|
@ -211,13 +234,17 @@ jQuery(document).ready( function($) {
|
||||||
}
|
}
|
||||||
lastClicked = this;
|
lastClicked = this;
|
||||||
return true;
|
return true;
|
||||||
} );
|
});
|
||||||
$( 'thead :checkbox, tfoot :checkbox' ).click( function(e) {
|
|
||||||
var c = $(this).attr('checked'), kbtoggle = 'undefined' == typeof toggleWithKeyboard ? false : toggleWithKeyboard, toggle = e.shiftKey || kbtoggle;
|
|
||||||
|
|
||||||
|
$('thead, tfoot').find(':checkbox').click( function(e) {
|
||||||
|
var c = $(this).attr('checked'),
|
||||||
|
kbtoggle = 'undefined' == typeof toggleWithKeyboard ? false : toggleWithKeyboard,
|
||||||
|
toggle = e.shiftKey || kbtoggle;
|
||||||
|
|
||||||
$(this).parents( 'form:first' ).find( 'table tbody:visible' ).find( '.check-column :checkbox' ).attr( 'checked', function() {
|
$(this).closest( 'table' ).children( 'tbody' ).filter(':visible')
|
||||||
if ( $(this).parents('tr').is(':hidden') )
|
.children().children('.check-column').find(':checkbox')
|
||||||
|
.attr('checked', function() {
|
||||||
|
if ( $(this).closest('tr').is(':hidden') )
|
||||||
return '';
|
return '';
|
||||||
if ( toggle )
|
if ( toggle )
|
||||||
return $(this).attr( 'checked' ) ? '' : 'checked';
|
return $(this).attr( 'checked' ) ? '' : 'checked';
|
||||||
|
@ -225,7 +252,10 @@ jQuery(document).ready( function($) {
|
||||||
return 'checked';
|
return 'checked';
|
||||||
return '';
|
return '';
|
||||||
});
|
});
|
||||||
$(this).parents( 'form:first' ).find( 'table thead:visible, table tfoot:visible').find( '.check-column :checkbox' ).attr( 'checked', function() {
|
|
||||||
|
$(this).closest('table').children('thead, tfoot').filter(':visible')
|
||||||
|
.children().children('.check-column').find(':checkbox')
|
||||||
|
.attr('checked', function() {
|
||||||
if ( toggle )
|
if ( toggle )
|
||||||
return '';
|
return '';
|
||||||
else if (c)
|
else if (c)
|
||||||
|
@ -233,17 +263,16 @@ jQuery(document).ready( function($) {
|
||||||
return '';
|
return '';
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#default-password-nag-no').click( function() {
|
$('#default-password-nag-no').click( function() {
|
||||||
setUserSetting('default_password_nag', 'hide');
|
setUserSetting('default_password_nag', 'hide');
|
||||||
$('div.default-password-nag').hide();
|
$('div.default-password-nag').hide();
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
jQuery(document).ready( function($){
|
jQuery(document).ready( function($){
|
||||||
var turboNag = $('.turbo-nag');
|
var turboNag = $('span.turbo-nag', '#user_info');
|
||||||
|
|
||||||
if ( !turboNag.length || ('undefined' != typeof(google) && google.gears) )
|
if ( !turboNag.length || ('undefined' != typeof(google) && google.gears) )
|
||||||
return;
|
return;
|
||||||
|
@ -260,5 +289,4 @@ jQuery(document).ready( function($){
|
||||||
}
|
}
|
||||||
|
|
||||||
turboNag.show();
|
turboNag.show();
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -1,74 +1,83 @@
|
||||||
|
|
||||||
var wpWidgets;
|
var wpWidgets;
|
||||||
(function($) {
|
(function($) {
|
||||||
|
|
||||||
wpWidgets = {
|
wpWidgets = {
|
||||||
|
|
||||||
init : function() {
|
init : function() {
|
||||||
var rem;
|
var rem, sidebars = $('div.widgets-sortables');
|
||||||
|
|
||||||
if ( $('body').hasClass('widgets_access') ) {
|
$('#widgets-right').children('.widgets-holder-wrap').children('.sidebar-name').click(function(){
|
||||||
return;
|
var c = $(this).siblings('.widgets-sortables'), p = $(this).parent();
|
||||||
}
|
if ( !p.hasClass('closed') ) {
|
||||||
|
|
||||||
$('#widgets-right div.sidebar-name').click(function(){
|
|
||||||
var c = $(this).siblings('.widgets-sortables');
|
|
||||||
if ( c.is(':visible') ) {
|
|
||||||
c.sortable('disable');
|
c.sortable('disable');
|
||||||
$(this).parent().addClass('closed');
|
p.addClass('closed');
|
||||||
} else {
|
} else {
|
||||||
$(this).parent().removeClass('closed');
|
p.removeClass('closed');
|
||||||
c.sortable('enable').sortable('refresh');
|
c.sortable('enable').sortable('refresh');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#widgets-left div.sidebar-name').click(function(){
|
$('#widgets-left').children('.widgets-holder-wrap').children('.sidebar-name').click(function() {
|
||||||
if ( $(this).siblings('.widget-holder').is(':visible') ) {
|
$(this).siblings('.widget-holder').parent().toggleClass('closed');
|
||||||
$(this).parent().addClass('closed');
|
});
|
||||||
|
|
||||||
|
sidebars.not('#wp_inactive_widgets').each(function(){
|
||||||
|
var h = 50, H = $(this).children('.widget').length;
|
||||||
|
h = h + parseInt(H * 48, 10);
|
||||||
|
$(this).css( 'minHeight', h + 'px' );
|
||||||
|
});
|
||||||
|
|
||||||
|
$('a.widget-action').live('click', function(){
|
||||||
|
var css = {}, widget = $(this).closest('div.widget'), inside = widget.children('.widget-inside'), w = parseInt( widget.find('input.widget-width').val(), 10 );
|
||||||
|
|
||||||
|
if ( inside.is(':hidden') ) {
|
||||||
|
if ( w > 250 && inside.closest('div.widgets-sortables').length ) {
|
||||||
|
css['width'] = w + 30 + 'px';
|
||||||
|
if ( inside.closest('div.widget-liquid-right').length )
|
||||||
|
css['marginLeft'] = 235 - w + 'px';
|
||||||
|
widget.css(css);
|
||||||
|
}
|
||||||
|
wpWidgets.fixLabels(widget);
|
||||||
|
inside.slideDown('fast');
|
||||||
} else {
|
} else {
|
||||||
$(this).parent().removeClass('closed');
|
inside.slideUp('fast', function() {
|
||||||
|
widget.css({'width':'','marginLeft':''});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#widgets-right .widget, #wp_inactive_widgets .widget').each(function(){
|
$('input.widget-control-save').live('click', function(){
|
||||||
|
wpWidgets.save( $(this).closest('div.widget'), 0, 1, 0 );
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$('a.widget-control-remove').live('click', function(){
|
||||||
|
wpWidgets.save( $(this).closest('div.widget'), 1, 1, 0 );
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$('a.widget-control-close').live('click', function(){
|
||||||
|
wpWidgets.close( $(this).closest('div.widget') );
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
sidebars.children('.widget').each(function() {
|
||||||
wpWidgets.appendTitle(this);
|
wpWidgets.appendTitle(this);
|
||||||
|
if ( $('p.widget-error', this).length )
|
||||||
|
$('a.widget-action', this).click();
|
||||||
});
|
});
|
||||||
|
|
||||||
this.addEvents();
|
$('#widget-list').children('.widget').draggable({
|
||||||
$('.widget-error').parents('.widget').find('a.widget-action').click();
|
connectToSortable: 'div.widgets-sortables',
|
||||||
|
handle: '> .widget-top > .widget-title',
|
||||||
$('#available-widgets').droppable({
|
|
||||||
tolerance: 'pointer',
|
|
||||||
accept: function(o){
|
|
||||||
return $(o).parent().attr('id') != 'widget-list';
|
|
||||||
},
|
|
||||||
drop: function(e,ui) {
|
|
||||||
ui.draggable.addClass('deleting');
|
|
||||||
$('#removing-widget').hide().children('span').html('');
|
|
||||||
},
|
|
||||||
over: function(e,ui) {
|
|
||||||
ui.draggable.addClass('deleting');
|
|
||||||
$('.widget-placeholder').hide();
|
|
||||||
|
|
||||||
if ( ui.draggable.hasClass('ui-sortable-helper') )
|
|
||||||
$('#removing-widget').show().children('span').html( ui.draggable.find('.widget-title h4').html() );
|
|
||||||
},
|
|
||||||
out: function(e,ui) {
|
|
||||||
ui.draggable.removeClass('deleting');
|
|
||||||
$('.widget-placeholder').show();
|
|
||||||
$('#removing-widget').hide().children('span').html('');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#widget-list .widget').draggable({
|
|
||||||
connectToSortable: '.widgets-sortables',
|
|
||||||
handle: '.widget-title',
|
|
||||||
distance: 2,
|
distance: 2,
|
||||||
helper: 'clone',
|
helper: 'clone',
|
||||||
zIndex: 5,
|
zIndex: 5,
|
||||||
containment: 'document',
|
containment: 'document',
|
||||||
start: function(e,ui) {
|
start: function(e,ui) {
|
||||||
wpWidgets.fixWebkit(1);
|
wpWidgets.fixWebkit(1);
|
||||||
ui.helper.find('.widget-description').hide();
|
ui.helper.find('div.widget-description').hide();
|
||||||
},
|
},
|
||||||
stop: function(e,ui) {
|
stop: function(e,ui) {
|
||||||
if ( rem )
|
if ( rem )
|
||||||
|
@ -78,17 +87,17 @@ wpWidgets = {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.widgets-sortables').sortable({
|
sidebars.sortable({
|
||||||
placeholder: 'widget-placeholder',
|
placeholder: 'widget-placeholder',
|
||||||
connectWith: '.widgets-sortables',
|
items: '> .widget',
|
||||||
items: '.widget',
|
handle: '> .widget-top > .widget-title',
|
||||||
handle: '.widget-title',
|
connectWith: 'div.widgets-sortables',
|
||||||
cursor: 'move',
|
cursor: 'move',
|
||||||
distance: 2,
|
distance: 2,
|
||||||
containment: 'document',
|
containment: 'document',
|
||||||
start: function(e,ui) {
|
start: function(e,ui) {
|
||||||
wpWidgets.fixWebkit(1);
|
wpWidgets.fixWebkit(1);
|
||||||
ui.item.find('.widget-inside').hide();
|
ui.item.children('.widget-inside').hide();
|
||||||
ui.item.css({'marginLeft':'','width':''});
|
ui.item.css({'marginLeft':'','width':''});
|
||||||
},
|
},
|
||||||
stop: function(e,ui) {
|
stop: function(e,ui) {
|
||||||
|
@ -101,7 +110,10 @@ wpWidgets = {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var add = ui.item.find('input.add_new').val(), n = ui.item.find('input.multi_number').val(), id = ui.item.attr('id'), sb = $(this).attr('id');
|
var add = ui.item.find('input.add_new').val(),
|
||||||
|
n = ui.item.find('input.multi_number').val(),
|
||||||
|
id = ui.item.attr('id'),
|
||||||
|
sb = $(this).attr('id');
|
||||||
|
|
||||||
ui.item.css({'marginLeft':'','width':''});
|
ui.item.css({'marginLeft':'','width':''});
|
||||||
wpWidgets.fixWebkit();
|
wpWidgets.fixWebkit();
|
||||||
|
@ -115,7 +127,6 @@ wpWidgets = {
|
||||||
ui.item.attr( 'id', 'new-' + id );
|
ui.item.attr( 'id', 'new-' + id );
|
||||||
rem = 'div#' + id;
|
rem = 'div#' + id;
|
||||||
}
|
}
|
||||||
wpWidgets.addEvents(ui.item);
|
|
||||||
wpWidgets.save( ui.item, 0, 0, 1 );
|
wpWidgets.save( ui.item, 0, 0, 1 );
|
||||||
ui.item.find('input.add_new').val('');
|
ui.item.find('input.add_new').val('');
|
||||||
ui.item.find('a.widget-action').click();
|
ui.item.find('a.widget-action').click();
|
||||||
|
@ -127,14 +138,36 @@ wpWidgets = {
|
||||||
if ( !$(this).is(':visible') )
|
if ( !$(this).is(':visible') )
|
||||||
$(this).sortable('cancel');
|
$(this).sortable('cancel');
|
||||||
}
|
}
|
||||||
}).not(':visible').sortable('disable');
|
}).parent().filter('.closed').children('.widgets-sortables').sortable('disable');
|
||||||
wpWidgets.resize();
|
|
||||||
wpWidgets.fixLabels();
|
$('#available-widgets').droppable({
|
||||||
|
tolerance: 'pointer',
|
||||||
|
accept: function(o){
|
||||||
|
return $(o).parent().attr('id') != 'widget-list';
|
||||||
|
},
|
||||||
|
drop: function(e,ui) {
|
||||||
|
ui.draggable.addClass('deleting');
|
||||||
|
$('#removing-widget').hide().children('span').html('');
|
||||||
|
},
|
||||||
|
over: function(e,ui) {
|
||||||
|
ui.draggable.addClass('deleting');
|
||||||
|
$('div.widget-placeholder').hide();
|
||||||
|
|
||||||
|
if ( ui.draggable.hasClass('ui-sortable-helper') )
|
||||||
|
$('#removing-widget').show().children('span')
|
||||||
|
.html( ui.draggable.find('div.widget-title').children('h4').html() );
|
||||||
|
},
|
||||||
|
out: function(e,ui) {
|
||||||
|
ui.draggable.removeClass('deleting');
|
||||||
|
$('div.widget-placeholder').show();
|
||||||
|
$('#removing-widget').hide().children('span').html('');
|
||||||
|
}
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
saveOrder : function(sb) {
|
saveOrder : function(sb) {
|
||||||
if ( sb )
|
if ( sb )
|
||||||
$('#' + sb).parents('.widgets-holder-wrap').find('.ajax-feedback').css('visibility', 'visible');
|
$('#' + sb).closest('div.widgets-holder-wrap').find('img.ajax-feedback').css('visibility', 'visible');
|
||||||
|
|
||||||
var a = {
|
var a = {
|
||||||
action: 'widgets-order',
|
action: 'widgets-order',
|
||||||
|
@ -142,20 +175,21 @@ wpWidgets = {
|
||||||
sidebars: []
|
sidebars: []
|
||||||
};
|
};
|
||||||
|
|
||||||
$('.widgets-sortables').each( function() {
|
$('div.widgets-sortables').each( function() {
|
||||||
a['sidebars[' + $(this).attr('id') + ']'] = $(this).sortable('toArray').join(',');
|
a['sidebars[' + $(this).attr('id') + ']'] = $(this).sortable('toArray').join(',');
|
||||||
});
|
});
|
||||||
|
|
||||||
$.post( ajaxurl, a, function() {
|
$.post( ajaxurl, a, function() {
|
||||||
$('.ajax-feedback').css('visibility', 'hidden');
|
$('img.ajax-feedback').css('visibility', 'hidden');
|
||||||
});
|
});
|
||||||
|
|
||||||
this.resize();
|
this.resize();
|
||||||
},
|
},
|
||||||
|
|
||||||
save : function(widget, del, animate, order) {
|
save : function(widget, del, animate, order) {
|
||||||
var sb = widget.parents('.widgets-sortables').attr('id'), data = widget.find('form').serialize(), a;
|
var sb = widget.closest('div.widgets-sortables').attr('id'), data = widget.find('form').serialize(), a;
|
||||||
widget = $(widget);
|
widget = $(widget);
|
||||||
widget.find('.ajax-feedback').css('visibility', 'visible');
|
$('.ajax-feedback', widget).css('visibility', 'visible');
|
||||||
|
|
||||||
a = {
|
a = {
|
||||||
action: 'save-widget',
|
action: 'save-widget',
|
||||||
|
@ -172,11 +206,11 @@ wpWidgets = {
|
||||||
var id;
|
var id;
|
||||||
|
|
||||||
if ( del ) {
|
if ( del ) {
|
||||||
if ( !$('.widget_number', widget).val() ) {
|
if ( !$('input.widget_number', widget).val() ) {
|
||||||
id = $('.widget-id', widget).val();
|
id = $('input.widget-id', widget).val();
|
||||||
$('#available-widgets .widget-id').each(function(){
|
$('#available-widgets').find('input.widget-id').each(function(){
|
||||||
if ( $(this).val() == id )
|
if ( $(this).val() == id )
|
||||||
$(this).parents('.widget').show();
|
$(this).closest('div.widget').show();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -193,7 +227,7 @@ wpWidgets = {
|
||||||
} else {
|
} else {
|
||||||
$('.ajax-feedback').css('visibility', 'hidden');
|
$('.ajax-feedback').css('visibility', 'hidden');
|
||||||
if ( r && r.length > 2 ) {
|
if ( r && r.length > 2 ) {
|
||||||
$('.widget-content', widget).html(r);
|
$('div.widget-content', widget).html(r);
|
||||||
wpWidgets.appendTitle(widget);
|
wpWidgets.appendTitle(widget);
|
||||||
wpWidgets.fixLabels(widget);
|
wpWidgets.fixLabels(widget);
|
||||||
}
|
}
|
||||||
|
@ -204,20 +238,17 @@ wpWidgets = {
|
||||||
},
|
},
|
||||||
|
|
||||||
appendTitle : function(widget) {
|
appendTitle : function(widget) {
|
||||||
$('input[type="text"]', widget).each(function(){
|
var title = $('input[id*="-title"]', widget);
|
||||||
var title;
|
if ( title = title.val() ) {
|
||||||
if ( this.id.indexOf('title') != -1 ) {
|
title = title.replace(/<[^<>]+>/g, '').replace(/</g, '<').replace(/>/g, '>');
|
||||||
title = $(this).val().replace(/<[^<>]+>/g, '').replace(/</g, '<').replace(/>/g, '>');
|
$(widget).children('.widget-top').children('.widget-title').children()
|
||||||
if ( title )
|
.children('.in-widget-title').html(': ' + title);
|
||||||
$('.widget-title .in-widget-title', widget).html(': ' + title);
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
},
|
},
|
||||||
|
|
||||||
resize : function() {
|
resize : function() {
|
||||||
$('.widgets-sortables').not('#wp_inactive_widgets').each(function(){
|
$('div.widgets-sortables').not('#wp_inactive_widgets').each(function(){
|
||||||
var h = 50, H = $('.widget', this).length;
|
var h = 50, H = $(this).children('.widget').length;
|
||||||
h = h + parseInt(H * 48, 10);
|
h = h + parseInt(H * 48, 10);
|
||||||
$(this).css( 'minHeight', h + 'px' );
|
$(this).css( 'minHeight', h + 'px' );
|
||||||
});
|
});
|
||||||
|
@ -231,54 +262,21 @@ wpWidgets = {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
fixLabels : function(sc) {
|
fixLabels : function(widget) {
|
||||||
sc = sc || document;
|
widget.children('.widget-inside').find('label').each(function(){
|
||||||
|
|
||||||
$('.widget-inside label', sc).each(function(){
|
|
||||||
var f = $(this).attr('for');
|
var f = $(this).attr('for');
|
||||||
|
|
||||||
if ( f && f == $('input', this).attr('id') )
|
if ( f && f == $('input', this).attr('id') )
|
||||||
$(this).removeAttr('for');
|
$(this).removeAttr('for');
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
close : function(widget) {
|
close : function(widget) {
|
||||||
widget.find('.widget-inside').slideUp('fast', function(){
|
widget.children('.widget-inside').slideUp('fast', function(){
|
||||||
widget.css({'width':'','marginLeft':''});
|
widget.css({'width':'','marginLeft':''});
|
||||||
});
|
});
|
||||||
},
|
|
||||||
|
|
||||||
addEvents : function(sc) {
|
|
||||||
sc = sc || document;
|
|
||||||
$('a.widget-action', sc).click(function(){
|
|
||||||
var w = parseInt( $(this).parents('.widget').find('.widget-width').val(), 10 ), css = {}, inside = $(this).parents('.widget-top').siblings('.widget-inside');
|
|
||||||
if ( inside.is(':hidden') ) {
|
|
||||||
if ( w > 250 && inside.parents('.widgets-sortables').length ) {
|
|
||||||
css['width'] = w + 30 + 'px';
|
|
||||||
if ( inside.parents('.widget-liquid-right').length )
|
|
||||||
css['marginLeft'] = 235 - w + 'px';
|
|
||||||
inside.parents('.widget').css(css);
|
|
||||||
}
|
|
||||||
inside.slideDown('fast');
|
|
||||||
} else {
|
|
||||||
inside.slideUp('fast', function(){ inside.parents('.widget').css({'width':'','marginLeft':''}); });
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
$('.widget-control-save', sc).click(function(){
|
|
||||||
wpWidgets.save( $(this).parents('.widget'), 0, 1, 0 );
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
$('.widget-control-remove', sc).click(function(){
|
|
||||||
wpWidgets.save( $(this).parents('.widget'), 1, 1, 0 );
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
$('.widget-control-close', sc).click(function(){
|
|
||||||
wpWidgets.close( $(this).parents('.widget') );
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
$(document).ready(function(){wpWidgets.init();});
|
|
||||||
|
$(document).ready(function($){ wpWidgets.init(); });
|
||||||
|
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -15,9 +15,19 @@ require_once(ABSPATH . 'wp-admin/includes/widgets.php');
|
||||||
if ( ! current_user_can('switch_themes') )
|
if ( ! current_user_can('switch_themes') )
|
||||||
wp_die( __( 'Cheatin’ uh?' ));
|
wp_die( __( 'Cheatin’ uh?' ));
|
||||||
|
|
||||||
wp_enqueue_script('admin-widgets');
|
|
||||||
wp_admin_css( 'widgets' );
|
wp_admin_css( 'widgets' );
|
||||||
|
|
||||||
|
$widgets_access = get_user_setting( 'widgets_access' );
|
||||||
|
if ( isset($_GET['widgets-access']) ) {
|
||||||
|
$widgets_access = 'on' == $_GET['widgets-access'] ? 'on' : 'off';
|
||||||
|
set_user_setting( 'widgets_access', $widgets_access );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( 'on' == $widgets_access )
|
||||||
|
add_filter( 'admin_body_class', create_function('', '{return " widgets_access ";}') );
|
||||||
|
else
|
||||||
|
wp_enqueue_script('admin-widgets');
|
||||||
|
|
||||||
do_action( 'sidebar_admin_setup' );
|
do_action( 'sidebar_admin_setup' );
|
||||||
|
|
||||||
$title = __( 'Widgets' );
|
$title = __( 'Widgets' );
|
||||||
|
@ -302,15 +312,6 @@ if ( isset($_GET['editwidget']) && $_GET['editwidget'] ) {
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
$widgets_access = get_user_setting( 'widgets_access' );
|
|
||||||
if ( isset($_GET['widgets-access']) ) {
|
|
||||||
$widgets_access = 'on' == $_GET['widgets-access'] ? 'on' : 'off';
|
|
||||||
set_user_setting( 'widgets_access', $widgets_access );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( 'on' == $widgets_access )
|
|
||||||
add_filter( 'admin_body_class', create_function('', '{return " widgets_access ";}') );
|
|
||||||
|
|
||||||
$messages = array(
|
$messages = array(
|
||||||
__('Changes saved.')
|
__('Changes saved.')
|
||||||
);
|
);
|
||||||
|
|
|
@ -60,7 +60,7 @@ function wp_default_scripts( &$scripts ) {
|
||||||
|
|
||||||
$scripts->add( 'utils', "/wp-admin/js/utils$suffix.js", false, '20090102' );
|
$scripts->add( 'utils', "/wp-admin/js/utils$suffix.js", false, '20090102' );
|
||||||
|
|
||||||
$scripts->add( 'common', "/wp-admin/js/common$suffix.js", array('jquery', 'hoverIntent', 'utils'), '20090730' );
|
$scripts->add( 'common', "/wp-admin/js/common$suffix.js", array('jquery', 'hoverIntent', 'utils'), '20090817' );
|
||||||
$scripts->add_data( 'common', 'group', 1 );
|
$scripts->add_data( 'common', 'group', 1 );
|
||||||
$scripts->localize( 'common', 'commonL10n', array(
|
$scripts->localize( 'common', 'commonL10n', array(
|
||||||
'warnDelete' => __("You are about to permanently delete the selected items.\n 'Cancel' to stop, 'OK' to delete."),
|
'warnDelete' => __("You are about to permanently delete the selected items.\n 'Cancel' to stop, 'OK' to delete."),
|
||||||
|
@ -340,7 +340,7 @@ function wp_default_scripts( &$scripts ) {
|
||||||
$scripts->add( 'media-upload', "/wp-admin/js/media-upload$suffix.js", array( 'thickbox' ), '20090114' );
|
$scripts->add( 'media-upload', "/wp-admin/js/media-upload$suffix.js", array( 'thickbox' ), '20090114' );
|
||||||
$scripts->add_data( 'media-upload', 'group', 1 );
|
$scripts->add_data( 'media-upload', 'group', 1 );
|
||||||
|
|
||||||
$scripts->add( 'admin-widgets', "/wp-admin/js/widgets$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable' ), '20090601' );
|
$scripts->add( 'admin-widgets', "/wp-admin/js/widgets$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable' ), '20090817' );
|
||||||
$scripts->add_data( 'admin-widgets', 'group', 1 );
|
$scripts->add_data( 'admin-widgets', 'group', 1 );
|
||||||
|
|
||||||
$scripts->add( 'word-count', "/wp-admin/js/word-count$suffix.js", array( 'jquery' ), '20090422' );
|
$scripts->add( 'word-count', "/wp-admin/js/word-count$suffix.js", array( 'jquery' ), '20090422' );
|
||||||
|
|
Loading…
Reference in New Issue