]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-includes/js/tinymce/plugins/wpdialogs/plugin.js
WordPress 3.9
[autoinstalls/wordpress.git] / wp-includes / js / tinymce / plugins / wpdialogs / plugin.js
diff --git a/wp-includes/js/tinymce/plugins/wpdialogs/plugin.js b/wp-includes/js/tinymce/plugins/wpdialogs/plugin.js
new file mode 100644 (file)
index 0000000..8b9229f
--- /dev/null
@@ -0,0 +1,92 @@
+/* global tinymce */
+/**
+ * Included for back-compat.
+ * The default WindowManager in TinyMCE 4.0 supports three types of dialogs:
+ *     - With HTML created from JS.
+ *     - With inline HTML (like WPWindowManager).
+ *     - Old type iframe based dialogs.
+ * For examples see the default plugins: https://github.com/tinymce/tinymce/tree/master/js/tinymce/plugins
+ */
+tinymce.WPWindowManager = tinymce.InlineWindowManager = function( editor ) {
+       if ( this.wp ) {
+               return this;
+       }
+
+       this.wp = {};
+       this.parent = editor.windowManager;
+       this.editor = editor;
+
+       tinymce.extend( this, this.parent );
+
+       this.open = function( args, params ) {
+               var $element,
+                       self = this,
+                       wp = this.wp;
+
+               if ( ! args.wpDialog ) {
+                       return this.parent.open.apply( this, arguments );
+               } else if ( ! args.id ) {
+                       return;
+               }
+
+               if ( typeof jQuery === 'undefined' || ! jQuery.wp || ! jQuery.wp.wpdialog ) {
+                       // wpdialog.js is not loaded
+                       if ( window.console && window.console.error ) {
+                               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.');
+                       }
+
+                       return;
+               }
+
+               wp.$element = $element = jQuery( '#' + args.id );
+
+               if ( ! $element.length ) {
+                       return;
+               }
+
+               if ( window.console && window.console.log ) {
+                       window.console.log('tinymce.WPWindowManager is deprecated. Use the default editor.windowManager to open dialogs with inline HTML.');
+               }
+
+               wp.features = args;
+               wp.params = params;
+
+               // Store selection. Takes a snapshot in the FocusManager of the selection before focus is moved to the dialog.
+               editor.nodeChanged();
+
+               // Create the dialog if necessary
+               if ( ! $element.data('wpdialog') ) {
+                       $element.wpdialog({
+                               title: args.title,
+                               width: args.width,
+                               height: args.height,
+                               modal: true,
+                               dialogClass: 'wp-dialog',
+                               zIndex: 300000
+                       });
+               }
+
+               $element.wpdialog('open');
+
+               $element.on( 'wpdialogclose', function() {
+                       if ( self.wp.$element ) {
+                               self.wp = {};
+                       }
+               });
+       };
+
+       this.close = function() {
+               if ( ! this.wp.features || ! this.wp.features.wpDialog ) {
+                       return this.parent.close.apply( this, arguments );
+               }
+
+               this.wp.$element.wpdialog('close');
+       };
+};
+
+tinymce.PluginManager.add( 'wpdialogs', function( editor ) {
+       // Replace window manager
+       editor.on( 'init', function() {
+               editor.windowManager = new tinymce.WPWindowManager( editor );
+       });
+});