wp/wp-includes/js/tinymce/plugins/wpdialogs/plugin.js
changeset 5 5e2f62d02dcd
child 16 a86126ab1dd4
equal deleted inserted replaced
4:346c88efed21 5:5e2f62d02dcd
       
     1 /* global tinymce */
       
     2 /**
       
     3  * Included for back-compat.
       
     4  * The default WindowManager in TinyMCE 4.0 supports three types of dialogs:
       
     5  *	- With HTML created from JS.
       
     6  *	- With inline HTML (like WPWindowManager).
       
     7  *	- Old type iframe based dialogs.
       
     8  * For examples see the default plugins: https://github.com/tinymce/tinymce/tree/master/js/tinymce/plugins
       
     9  */
       
    10 tinymce.WPWindowManager = tinymce.InlineWindowManager = function( editor ) {
       
    11 	if ( this.wp ) {
       
    12 		return this;
       
    13 	}
       
    14 
       
    15 	this.wp = {};
       
    16 	this.parent = editor.windowManager;
       
    17 	this.editor = editor;
       
    18 
       
    19 	tinymce.extend( this, this.parent );
       
    20 
       
    21 	this.open = function( args, params ) {
       
    22 		var $element,
       
    23 			self = this,
       
    24 			wp = this.wp;
       
    25 
       
    26 		if ( ! args.wpDialog ) {
       
    27 			return this.parent.open.apply( this, arguments );
       
    28 		} else if ( ! args.id ) {
       
    29 			return;
       
    30 		}
       
    31 
       
    32 		if ( typeof jQuery === 'undefined' || ! jQuery.wp || ! jQuery.wp.wpdialog ) {
       
    33 			// wpdialog.js is not loaded
       
    34 			if ( window.console && window.console.error ) {
       
    35 				window.console.error('wpdialog.js is not loaded. Please set "wpdialogs" as dependency for your script when calling wp_enqueue_script(). You may also want to enqueue the "wp-jquery-ui-dialog" stylesheet.');
       
    36 			}
       
    37 
       
    38 			return;
       
    39 		}
       
    40 
       
    41 		wp.$element = $element = jQuery( '#' + args.id );
       
    42 
       
    43 		if ( ! $element.length ) {
       
    44 			return;
       
    45 		}
       
    46 
       
    47 		if ( window.console && window.console.log ) {
       
    48 			window.console.log('tinymce.WPWindowManager is deprecated. Use the default editor.windowManager to open dialogs with inline HTML.');
       
    49 		}
       
    50 
       
    51 		wp.features = args;
       
    52 		wp.params = params;
       
    53 
       
    54 		// Store selection. Takes a snapshot in the FocusManager of the selection before focus is moved to the dialog.
       
    55 		editor.nodeChanged();
       
    56 
       
    57 		// Create the dialog if necessary
       
    58 		if ( ! $element.data('wpdialog') ) {
       
    59 			$element.wpdialog({
       
    60 				title: args.title,
       
    61 				width: args.width,
       
    62 				height: args.height,
       
    63 				modal: true,
       
    64 				dialogClass: 'wp-dialog',
       
    65 				zIndex: 300000
       
    66 			});
       
    67 		}
       
    68 
       
    69 		$element.wpdialog('open');
       
    70 
       
    71 		$element.on( 'wpdialogclose', function() {
       
    72 			if ( self.wp.$element ) {
       
    73 				self.wp = {};
       
    74 			}
       
    75 		});
       
    76 	};
       
    77 
       
    78 	this.close = function() {
       
    79 		if ( ! this.wp.features || ! this.wp.features.wpDialog ) {
       
    80 			return this.parent.close.apply( this, arguments );
       
    81 		}
       
    82 
       
    83 		this.wp.$element.wpdialog('close');
       
    84 	};
       
    85 };
       
    86 
       
    87 tinymce.PluginManager.add( 'wpdialogs', function( editor ) {
       
    88 	// Replace window manager
       
    89 	editor.on( 'init', function() {
       
    90 		editor.windowManager = new tinymce.WPWindowManager( editor );
       
    91 	});
       
    92 });