From 259b343c36745682a544bb569f5de5b6e1bbe87b Mon Sep 17 00:00:00 2001 From: Andrew Ozz Date: Mon, 29 Feb 2016 19:37:42 +0000 Subject: [PATCH] TinyMCE, inline link: - Fix running wpLink without tinymce.js and the TinyMCE plugin without wplink.js. - Do not show the Advanced button in the inline link dialog when wpLink is not loaded. See #33301. git-svn-id: https://develop.svn.wordpress.org/trunk@36777 602fd350-edb4-49c9-b593-d223f7449a82 --- .../js/tinymce/plugins/wplink/plugin.js | 20 +++++++++-------- src/wp-includes/js/wplink.js | 22 +++++++++---------- 2 files changed, 22 insertions(+), 20 deletions(-) diff --git a/src/wp-includes/js/tinymce/plugins/wplink/plugin.js b/src/wp-includes/js/tinymce/plugins/wplink/plugin.js index c47b4c384f..690c3ea626 100644 --- a/src/wp-includes/js/tinymce/plugins/wplink/plugin.js +++ b/src/wp-includes/js/tinymce/plugins/wplink/plugin.js @@ -144,11 +144,16 @@ 'wp_link_remove' ], true ); - editToolbar = editor.wp._createToolbar( [ + var editButtons = [ 'wp_link_input', - 'wp_link_apply', - 'wp_link_advanced' - ], true ); + 'wp_link_apply' + ]; + + if ( typeof window.wpLink !== 'undefined' ) { + editButtons.push( 'wp_link_advanced' ); + } + + editToolbar = editor.wp._createToolbar( editButtons, true ); editToolbar.on( 'show', function() { if ( ! tinymce.$( document.body ).hasClass( 'modal-open' ) ) { @@ -177,11 +182,8 @@ } ); editor.addCommand( 'WP_Link', function() { - if ( tinymce.Env.ie && tinymce.Env.ie < 10 ) { - if ( typeof window.wpLink !== 'undefined' ) { - window.wpLink.open( editor.id ); - } - + if ( tinymce.Env.ie && tinymce.Env.ie < 10 && typeof window.wpLink !== 'undefined' ) { + window.wpLink.open( editor.id ); return; } diff --git a/src/wp-includes/js/wplink.js b/src/wp-includes/js/wplink.js index d82fd8604b..8cef9544c5 100644 --- a/src/wp-includes/js/wplink.js +++ b/src/wp-includes/js/wplink.js @@ -1,7 +1,7 @@ -/* global tinymce, wpLinkL10n, wpActiveEditor */ + var wpLink; -( function( $ ) { +( function( $, wpLinkL10n ) { var editor, correctedURL, linkNode, inputs = {}, isTouch = ( 'ontouchend' in document ); @@ -80,7 +80,7 @@ var wpLink; select: function( event, ui ) { $input.val( ui.item.permalink ); - if ( inputs.wrap.hasClass( 'has-text-field' ) && tinymce.trim( inputs.text.val() ) === '' ) { + if ( inputs.wrap.hasClass( 'has-text-field' ) && $.trim( inputs.text.val() ) === '' ) { inputs.text.val( ui.item.title ); } @@ -144,12 +144,12 @@ var wpLink; this.textarea = $( '#' + window.wpActiveEditor ).get( 0 ); - if ( typeof tinymce !== 'undefined' ) { + if ( typeof window.tinymce !== 'undefined' ) { // Make sure the link wrapper is the last element in the body, // or the inline editor toolbar may show above the backdrop. $body.append( inputs.backdrop, inputs.wrap ); - ed = tinymce.get( wpActiveEditor ); + ed = window.tinymce.get( window.wpActiveEditor ); if ( ed && ! ed.isHidden() ) { editor = ed; @@ -157,7 +157,7 @@ var wpLink; editor = null; } - if ( editor && tinymce.isIE && ! editor.windowManager.wplinkBookmark ) { + if ( editor && window.tinymce.isIE && ! editor.windowManager.wplinkBookmark ) { editor.windowManager.wplinkBookmark = editor.selection.getBookmark(); } } @@ -236,7 +236,7 @@ var wpLink; for ( i = nodes.length - 1; i >= 0; i-- ) { node = nodes[i]; - if ( node.nodeType != 3 && ! tinymce.dom.BookmarkManager.isBookmarkNode( node ) ) { + if ( node.nodeType != 3 && ! window.tinymce.dom.BookmarkManager.isBookmarkNode( node ) ) { return false; } } @@ -253,7 +253,7 @@ var wpLink; if ( linkNode ) { linkText = linkNode.innerText || linkNode.textContent; - if ( ! tinymce.trim( linkText ) ) { + if ( ! $.trim( linkText ) ) { linkText = text || ''; } @@ -397,7 +397,7 @@ var wpLink; editor.focus(); - if ( tinymce.isIE && editor.windowManager.wplinkBookmark ) { + if ( window.tinymce.isIE && editor.windowManager.wplinkBookmark ) { editor.selection.moveToBookmark( editor.windowManager.wplinkBookmark ); editor.windowManager.wplinkBookmark = null; } @@ -474,7 +474,7 @@ var wpLink; } } - selection = tinymce.trim( selection ); + selection = $.trim( selection ); if ( selection && emailRegexp.test( selection ) ) { // Selection is email address @@ -496,4 +496,4 @@ var wpLink; }; $( document ).ready( wpLink.init ); -})( jQuery ); +})( jQuery, window.wpLinkL10n );