Widget Customizer: Fix 'WidgetCustomizerPreview' is undefined error in IE8/9.
* Move `WidgetCustomizerPreview` to `wp.customize.WidgetCustomizerPreview` * Move `WidgetCustomizerPreview_exports` to export_preview_data() * Use `_wpWidgetCustomizerPreviewSettings` to transfer settings to `wp.customize.WidgetCustomizerPreview` see #27485. Built from https://develop.svn.wordpress.org/trunk@27653 git-svn-id: http://core.svn.wordpress.org/trunk@27496 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
9b0ec406d1
commit
21158f33f7
|
@ -1510,7 +1510,7 @@ var WidgetCustomizer = ( function ($) {
|
||||||
*/
|
*/
|
||||||
getPreviewWidgetElement: function () {
|
getPreviewWidgetElement: function () {
|
||||||
var control = this,
|
var control = this,
|
||||||
widget_customizer_preview = self.getPreviewWindow().WidgetCustomizerPreview;
|
widget_customizer_preview = self.getPreviewWindow().wp.customize.WidgetCustomizerPreview;
|
||||||
return widget_customizer_preview.getWidgetElement( control.params.widget_id );
|
return widget_customizer_preview.getWidgetElement( control.params.widget_id );
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -696,8 +696,9 @@ class WP_Customize_Widgets {
|
||||||
*/
|
*/
|
||||||
static function customize_preview_init() {
|
static function customize_preview_init() {
|
||||||
add_filter( 'sidebars_widgets', array( __CLASS__, 'preview_sidebars_widgets' ), 1 );
|
add_filter( 'sidebars_widgets', array( __CLASS__, 'preview_sidebars_widgets' ), 1 );
|
||||||
add_action( 'wp_enqueue_scripts', array( __CLASS__, 'customize_preview_enqueue_deps' ) );
|
add_action( 'wp_enqueue_scripts', array( __CLASS__, 'customize_preview_enqueue' ) );
|
||||||
add_action( 'wp_footer', array( __CLASS__, 'export_preview_data' ), 9999 );
|
add_action( 'wp_print_styles', array( __CLASS__, 'inject_preview_css' ), 1 );
|
||||||
|
add_action( 'wp_footer', array( __CLASS__, 'export_preview_data' ), 20 );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -719,29 +720,9 @@ class WP_Customize_Widgets {
|
||||||
*
|
*
|
||||||
* @action wp_enqueue_scripts
|
* @action wp_enqueue_scripts
|
||||||
*/
|
*/
|
||||||
static function customize_preview_enqueue_deps() {
|
static function customize_preview_enqueue() {
|
||||||
wp_enqueue_script( 'customize-preview-widgets' );
|
wp_enqueue_script( 'customize-preview-widgets' );
|
||||||
|
|
||||||
add_action( 'wp_print_styles', array( __CLASS__, 'inject_preview_css' ), 1 );
|
|
||||||
|
|
||||||
// Why not wp_localize_script? Because we're not localizing, and it forces values into strings
|
|
||||||
global $wp_scripts;
|
|
||||||
$exports = array(
|
|
||||||
'registered_sidebars' => array_values( $GLOBALS['wp_registered_sidebars'] ),
|
|
||||||
'registered_widgets' => $GLOBALS['wp_registered_widgets'],
|
|
||||||
'i18n' => array(
|
|
||||||
'widget_tooltip' => ( 'Shift-click to edit this widget.' ),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
foreach ( $exports['registered_widgets'] as &$registered_widget ) {
|
|
||||||
unset( $registered_widget['callback'] ); // may not be JSON-serializeable
|
|
||||||
}
|
}
|
||||||
$wp_scripts->add_data(
|
|
||||||
'customize-preview-widgets',
|
|
||||||
'data',
|
|
||||||
sprintf( 'var WidgetCustomizerPreview_exports = %s;', json_encode( $exports ) )
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Insert default style for highlighted widget at early point so theme
|
* Insert default style for highlighted widget at early point so theme
|
||||||
|
@ -767,14 +748,23 @@ class WP_Customize_Widgets {
|
||||||
* @action wp_footer
|
* @action wp_footer
|
||||||
*/
|
*/
|
||||||
static function export_preview_data() {
|
static function export_preview_data() {
|
||||||
wp_print_scripts( array( 'customize-preview-widgets' ) );
|
// Prepare customizer settings to pass to Javascript.
|
||||||
|
$settings = array(
|
||||||
|
'renderedSidebars' => array_fill_keys( array_unique( self::$rendered_sidebars ), true ),
|
||||||
|
'renderedWidgets' => array_fill_keys( array_keys( self::$rendered_widgets ), true ),
|
||||||
|
'registeredSidebars' => array_values( $GLOBALS['wp_registered_sidebars'] ),
|
||||||
|
'registeredWidgets' => $GLOBALS['wp_registered_widgets'],
|
||||||
|
'l10n' => array(
|
||||||
|
'widgetTooltip' => ( 'Shift-click to edit this widget.' ),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
foreach ( $settings['registeredWidgets'] as &$registered_widget ) {
|
||||||
|
unset( $registered_widget['callback'] ); // may not be JSON-serializeable
|
||||||
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<script>
|
<script type="text/javascript">
|
||||||
(function () {
|
var _wpWidgetCustomizerPreviewSettings = <?php echo json_encode( $settings ); ?>;
|
||||||
/*global WidgetCustomizerPreview */
|
|
||||||
WidgetCustomizerPreview.rendered_sidebars = <?php echo json_encode( array_fill_keys( array_unique( self::$rendered_sidebars ), true ) ) ?>;
|
|
||||||
WidgetCustomizerPreview.rendered_widgets = <?php echo json_encode( array_fill_keys( array_keys( self::$rendered_widgets ), true ) ); ?>;
|
|
||||||
}());
|
|
||||||
</script>
|
</script>
|
||||||
<?php
|
<?php
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,24 +1,31 @@
|
||||||
/*global jQuery, WidgetCustomizerPreview_exports */
|
(function( $, wp ){
|
||||||
/*exported WidgetCustomizerPreview */
|
|
||||||
var WidgetCustomizerPreview = (function ($) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var OldPreview, self = {
|
if ( ! wp || ! wp.customize ) { return; }
|
||||||
rendered_sidebars: {}, // @todo Make rendered a property of the Backbone model
|
|
||||||
rendered_widgets: {}, // @todo Make rendered a property of the Backbone model
|
var api = wp.customize,
|
||||||
registered_sidebars: [], // @todo Make a Backbone collection
|
OldPreview;
|
||||||
registered_widgets: {}, // @todo Make array, Backbone collection
|
|
||||||
widget_selectors: [],
|
/**
|
||||||
|
* wp.customize.WidgetCustomizerPreview
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
api.WidgetCustomizerPreview = {
|
||||||
|
renderedSidebars: {}, // @todo Make rendered a property of the Backbone model
|
||||||
|
renderedWidgets: {}, // @todo Make rendered a property of the Backbone model
|
||||||
|
registeredSidebars: [], // @todo Make a Backbone collection
|
||||||
|
registeredWidgets: {}, // @todo Make array, Backbone collection
|
||||||
|
widgetSelectors: [],
|
||||||
preview: null,
|
preview: null,
|
||||||
i18n: {},
|
l10n: {},
|
||||||
|
|
||||||
init: function () {
|
init: function () {
|
||||||
|
var self = this;
|
||||||
this.buildWidgetSelectors();
|
this.buildWidgetSelectors();
|
||||||
this.highlightControls();
|
this.highlightControls();
|
||||||
|
|
||||||
self.preview.bind( 'active', function() {
|
this.preview.bind( 'active', function() {
|
||||||
self.preview.send( 'rendered-sidebars', self.rendered_sidebars ); // @todo Only send array of IDs
|
self.preview.send( 'rendered-sidebars', self.renderedSidebars ); // @todo Only send array of IDs
|
||||||
self.preview.send( 'rendered-widgets', self.rendered_widgets ); // @todo Only send array of IDs
|
self.preview.send( 'rendered-widgets', self.renderedWidgets ); // @todo Only send array of IDs
|
||||||
} );
|
} );
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -26,25 +33,27 @@ var WidgetCustomizerPreview = (function ($) {
|
||||||
* Calculate the selector for the sidebar's widgets based on the registered sidebar's info
|
* Calculate the selector for the sidebar's widgets based on the registered sidebar's info
|
||||||
*/
|
*/
|
||||||
buildWidgetSelectors: function () {
|
buildWidgetSelectors: function () {
|
||||||
$.each( self.registered_sidebars, function ( i, sidebar ) {
|
var self = this;
|
||||||
var widget_tpl = [
|
|
||||||
|
$.each( this.registeredSidebars, function ( i, sidebar ) {
|
||||||
|
var widgetTpl = [
|
||||||
sidebar.before_widget.replace('%1$s', '').replace('%2$s', ''),
|
sidebar.before_widget.replace('%1$s', '').replace('%2$s', ''),
|
||||||
sidebar.before_title,
|
sidebar.before_title,
|
||||||
sidebar.after_title,
|
sidebar.after_title,
|
||||||
sidebar.after_widget
|
sidebar.after_widget
|
||||||
].join(''),
|
].join(''),
|
||||||
empty_widget,
|
emptyWidget,
|
||||||
widget_selector,
|
widgetSelector,
|
||||||
widget_classes;
|
widgetClasses;
|
||||||
|
|
||||||
empty_widget = $(widget_tpl);
|
emptyWidget = $(widgetTpl);
|
||||||
widget_selector = empty_widget.prop('tagName');
|
widgetSelector = emptyWidget.prop('tagName');
|
||||||
widget_classes = empty_widget.prop('className').replace(/^\s+|\s+$/g, '');
|
widgetClasses = emptyWidget.prop('className').replace(/^\s+|\s+$/g, '');
|
||||||
|
|
||||||
if ( widget_classes ) {
|
if ( widgetClasses ) {
|
||||||
widget_selector += '.' + widget_classes.split(/\s+/).join('.');
|
widgetSelector += '.' + widgetClasses.split(/\s+/).join('.');
|
||||||
}
|
}
|
||||||
self.widget_selectors.push(widget_selector);
|
self.widgetSelectors.push(widgetSelector);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -65,10 +74,9 @@ var WidgetCustomizerPreview = (function ($) {
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
highlightControls: function() {
|
highlightControls: function() {
|
||||||
|
var selector = this.widgetSelectors.join(',');
|
||||||
|
|
||||||
var selector = this.widget_selectors.join(',');
|
$(selector).attr( 'title', this.l10n.widgetTooltip );
|
||||||
|
|
||||||
$(selector).attr( 'title', self.i18n.widget_tooltip );
|
|
||||||
|
|
||||||
$(document).on( 'mouseenter', selector, function () {
|
$(document).on( 'mouseenter', selector, function () {
|
||||||
var control = parent.WidgetCustomizer.getWidgetFormControlForWidget( $(this).prop('id') );
|
var control = parent.WidgetCustomizer.getWidgetFormControlForWidget( $(this).prop('id') );
|
||||||
|
@ -89,26 +97,28 @@ var WidgetCustomizerPreview = (function ($) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
$.extend(self, WidgetCustomizerPreview_exports);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Capture the instance of the Preview since it is private
|
* Capture the instance of the Preview since it is private
|
||||||
*/
|
*/
|
||||||
OldPreview = wp.customize.Preview;
|
OldPreview = api.Preview;
|
||||||
wp.customize.Preview = OldPreview.extend( {
|
api.Preview = OldPreview.extend( {
|
||||||
initialize: function( params, options ) {
|
initialize: function( params, options ) {
|
||||||
self.preview = this;
|
api.WidgetCustomizerPreview.preview = this;
|
||||||
OldPreview.prototype.initialize.call( this, params, options );
|
OldPreview.prototype.initialize.call( this, params, options );
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
|
|
||||||
// @todo on customize ready?
|
|
||||||
$(function () {
|
$(function () {
|
||||||
self.init();
|
var settings = window._wpWidgetCustomizerPreviewSettings;
|
||||||
|
if ( ! settings ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$.extend( api.WidgetCustomizerPreview, settings );
|
||||||
|
|
||||||
|
api.WidgetCustomizerPreview.init();
|
||||||
});
|
});
|
||||||
|
|
||||||
return self;
|
})( jQuery, window.wp );
|
||||||
}( jQuery ));
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
var WidgetCustomizerPreview=function(a){"use strict";var b,c={rendered_sidebars:{},rendered_widgets:{},registered_sidebars:[],registered_widgets:{},widget_selectors:[],preview:null,i18n:{},init:function(){this.buildWidgetSelectors(),this.highlightControls(),c.preview.bind("active",function(){c.preview.send("rendered-sidebars",c.rendered_sidebars),c.preview.send("rendered-widgets",c.rendered_widgets)})},buildWidgetSelectors:function(){a.each(c.registered_sidebars,function(b,d){var e,f,g,h=[d.before_widget.replace("%1$s","").replace("%2$s",""),d.before_title,d.after_title,d.after_widget].join("");e=a(h),f=e.prop("tagName"),g=e.prop("className").replace(/^\s+|\s+$/g,""),g&&(f+="."+g.split(/\s+/).join(".")),c.widget_selectors.push(f)})},getWidgetElement:function(b){return a("#"+b)},highlightControls:function(){var b=this.widget_selectors.join(",");a(b).attr("title",c.i18n.widget_tooltip),a(document).on("mouseenter",b,function(){var b=parent.WidgetCustomizer.getWidgetFormControlForWidget(a(this).prop("id"));b&&b.highlightSectionAndControl()}),a(document).on("click",b,function(b){if(b.shiftKey){b.preventDefault();var c=parent.WidgetCustomizer.getWidgetFormControlForWidget(a(this).prop("id"));c&&c.focus()}})}};return a.extend(c,WidgetCustomizerPreview_exports),b=wp.customize.Preview,wp.customize.Preview=b.extend({initialize:function(a,d){c.preview=this,b.prototype.initialize.call(this,a,d)}}),a(function(){c.init()}),c}(jQuery);
|
!function(a,b){if(b&&b.customize){var c,d=b.customize;d.WidgetCustomizerPreview={renderedSidebars:{},renderedWidgets:{},registeredSidebars:[],registeredWidgets:{},widgetSelectors:[],preview:null,l10n:{},init:function(){var a=this;this.buildWidgetSelectors(),this.highlightControls(),this.preview.bind("active",function(){a.preview.send("rendered-sidebars",a.renderedSidebars),a.preview.send("rendered-widgets",a.renderedWidgets)})},buildWidgetSelectors:function(){var b=this;a.each(this.registeredSidebars,function(c,d){var e,f,g,h=[d.before_widget.replace("%1$s","").replace("%2$s",""),d.before_title,d.after_title,d.after_widget].join("");e=a(h),f=e.prop("tagName"),g=e.prop("className").replace(/^\s+|\s+$/g,""),g&&(f+="."+g.split(/\s+/).join(".")),b.widgetSelectors.push(f)})},getWidgetElement:function(b){return a("#"+b)},highlightControls:function(){var b=this.widgetSelectors.join(",");a(b).attr("title",this.l10n.widgetTooltip),a(document).on("mouseenter",b,function(){var b=parent.WidgetCustomizer.getWidgetFormControlForWidget(a(this).prop("id"));b&&b.highlightSectionAndControl()}),a(document).on("click",b,function(b){if(b.shiftKey){b.preventDefault();var c=parent.WidgetCustomizer.getWidgetFormControlForWidget(a(this).prop("id"));c&&c.focus()}})}},c=d.Preview,d.Preview=c.extend({initialize:function(a,b){d.WidgetCustomizerPreview.preview=this,c.prototype.initialize.call(this,a,b)}}),a(function(){var b=window._wpWidgetCustomizerPreviewSettings;b&&(a.extend(d.WidgetCustomizerPreview,b),d.WidgetCustomizerPreview.init())})}}(jQuery,window.wp);
|
Loading…
Reference in New Issue