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
This commit is contained in:
Andrew Ozz 2016-02-29 19:37:42 +00:00
parent 8ce52f3926
commit 259b343c36
2 changed files with 22 additions and 20 deletions

View File

@ -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' ) {
if ( tinymce.Env.ie && tinymce.Env.ie < 10 && typeof window.wpLink !== 'undefined' ) {
window.wpLink.open( editor.id );
}
return;
}

View File

@ -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 );