Widget Customizer: Improve behavior of bigger widgets.

* Support widgets which are higher than browsers viewport.
* Use widgets width as max-width.
* Don't animate the width of wide widgets to make them visible, instead fade them in/out.
* Fix Chrome flickerings while updating wide widgets.

props adamsilverstein, westonruter, ocean90.
see #27348.

git-svn-id: https://develop.svn.wordpress.org/trunk@27798 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Dominik Schilling (ocean90) 2014-03-27 23:12:25 +00:00
parent bbe59d0487
commit 4d57b96fb2
2 changed files with 27 additions and 20 deletions

View File

@ -50,16 +50,16 @@
left: auto !important;
max-width: 100%;
}
.customize-control-widget_form.wide-widget-control .widget-inside {
position: fixed;
left: 299px;
top: 25%;
padding: 20px;
border: 1px solid rgb(229, 229, 229);
z-index: -1;
overflow: auto;
}
.customize-control-widget_form.wide-widget-control.collapsing .widget-inside {
z-index: -2;
.customize-control-widget_form.wide-widget-control .widget-inside > .form {
padding: 20px;
}
.customize-control-widget_form.wide-widget-control .widget-top {

View File

@ -703,6 +703,7 @@ var WidgetCustomizer = ( function ($) {
_setupWideWidget: function () {
var control = this,
widget_inside,
widget_form,
customize_sidebar,
position_widget,
theme_controls_container;
@ -712,11 +713,12 @@ var WidgetCustomizer = ( function ($) {
}
widget_inside = control.container.find( '.widget-inside' );
widget_form = widget_inside.find( '> .form' );
customize_sidebar = $( '.wp-full-overlay-sidebar-content:first' );
control.container.addClass( 'wide-widget-control' );
control.container.find( '.widget-content:first' ).css( {
'min-width': control.params.width,
'max-width': control.params.width,
'min-height': control.params.height
} );
@ -725,31 +727,37 @@ var WidgetCustomizer = ( function ($) {
* element is at the same top position as the widget-top. When the
* widget-top is scrolled out of view, keep the widget-top in view;
* likewise, don't allow the widget to drop off the bottom of the window.
* If a widget is too tall to fit in the window, don't let the height
* exceed the window height so that the contents of the widget control
* will become scrollable (overflow:auto).
*/
position_widget = function () {
var offset_top = control.container.offset().top,
height,
top,
max_top;
height = widget_inside.outerHeight();
top = Math.max( offset_top, 0 );
max_top = $( window ).height() - height;
top = Math.min( top, max_top );
window_height = $( window ).height(),
form_height = widget_form.outerHeight(),
top;
widget_inside.css( 'max-height', window_height );
top = Math.max(
0, // prevent top from going off screen
Math.min(
Math.max( offset_top, 0 ), // distance widget in panel is from top of screen
window_height - form_height // flush up against bottom of screen
)
);
widget_inside.css( 'top', top );
};
theme_controls_container = $( '#customize-theme-controls' );
control.container.on( 'expand', function () {
position_widget();
customize_sidebar.on( 'scroll', position_widget );
$( window ).on( 'resize', position_widget );
theme_controls_container.on( 'expanded collapsed', position_widget );
position_widget();
} );
control.container.on( 'collapsed', function () {
customize_sidebar.off( 'scroll', position_widget );
theme_controls_container.off( 'expanded collapsed', position_widget );
$( window ).off( 'resize', position_widget );
theme_controls_container.off( 'expanded collapsed', position_widget );
} );
// Reposition whenever a sidebar's widgets are changed
@ -1375,7 +1383,6 @@ var WidgetCustomizer = ( function ($) {
return;
}
complete;
if ( do_expand ) {
// Close all other widget controls before expanding this one
wp.customize.control.each( function ( other_control ) {
@ -1384,18 +1391,18 @@ var WidgetCustomizer = ( function ($) {
}
} );
control.container.trigger( 'expand' );
control.container.addClass( 'expanding' );
complete = function () {
control.container.removeClass( 'expanding' );
control.container.addClass( 'expanded' );
control.container.trigger( 'expanded' );
};
if ( control.params.is_wide ) {
inside.animate( { width: 'show' }, 'fast', complete );
inside.fadeIn( 'fast', complete );
} else {
inside.slideDown( 'fast', complete );
}
control.container.trigger( 'expand' );
control.container.addClass( 'expanding' );
} else {
control.container.trigger( 'collapse' );
control.container.addClass( 'collapsing' );
@ -1405,7 +1412,7 @@ var WidgetCustomizer = ( function ($) {
control.container.trigger( 'collapsed' );
};
if ( control.params.is_wide ) {
inside.animate( { width: 'hide' }, 'fast', complete );
inside.fadeOut( 'fast', complete );
} else {
inside.slideUp( 'fast', function() {
widget.css( { width:'', margin:'' } );