Docs: Improve JSDoc for `js/media-upload.js`.
Props terwdan, diedeexterkate, andizer, ireneyoast. Fixes #42956. Built from https://develop.svn.wordpress.org/trunk@42426 git-svn-id: http://core.svn.wordpress.org/trunk@42257 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
4e5215deec
commit
d1c58e7850
|
@ -1,13 +1,38 @@
|
||||||
/* global tinymce, QTags */
|
/* global tinymce, QTags */
|
||||||
// send html to the post editor
|
|
||||||
|
/**
|
||||||
|
* Contains global functions for the media upload within the post edit screen.
|
||||||
|
*
|
||||||
|
* Updates the ThickBox anchor href and the ThickBox's own properties in order
|
||||||
|
* to set the size and position on every resize event. Also adds a function to
|
||||||
|
* send HTML or text to the currently active editor.
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @requires jQuery
|
||||||
|
*/
|
||||||
|
|
||||||
var wpActiveEditor, send_to_editor;
|
var wpActiveEditor, send_to_editor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends the HTML passed in the parameters to TinyMCE.
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @global
|
||||||
|
*
|
||||||
|
* @param {string} html The HTML to be sent to the editor.
|
||||||
|
* @returns {void|boolean} Returns false when both TinyMCE and QTags instances
|
||||||
|
* are unavailable. This means that the HTML was not
|
||||||
|
* sent to the editor.
|
||||||
|
*/
|
||||||
send_to_editor = function( html ) {
|
send_to_editor = function( html ) {
|
||||||
var editor,
|
var editor,
|
||||||
hasTinymce = typeof tinymce !== 'undefined',
|
hasTinymce = typeof tinymce !== 'undefined',
|
||||||
hasQuicktags = typeof QTags !== 'undefined';
|
hasQuicktags = typeof QTags !== 'undefined';
|
||||||
|
|
||||||
|
// If no active editor is set, try to set it.
|
||||||
if ( ! wpActiveEditor ) {
|
if ( ! wpActiveEditor ) {
|
||||||
if ( hasTinymce && tinymce.activeEditor ) {
|
if ( hasTinymce && tinymce.activeEditor ) {
|
||||||
editor = tinymce.activeEditor;
|
editor = tinymce.activeEditor;
|
||||||
|
@ -19,23 +44,38 @@ send_to_editor = function( html ) {
|
||||||
editor = tinymce.get( wpActiveEditor );
|
editor = tinymce.get( wpActiveEditor );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If the editor is set and not hidden, insert the HTML into the content of the
|
||||||
|
// editor.
|
||||||
if ( editor && ! editor.isHidden() ) {
|
if ( editor && ! editor.isHidden() ) {
|
||||||
editor.execCommand( 'mceInsertContent', false, html );
|
editor.execCommand( 'mceInsertContent', false, html );
|
||||||
} else if ( hasQuicktags ) {
|
} else if ( hasQuicktags ) {
|
||||||
|
// If quick tags are available, insert the HTML into its content.
|
||||||
QTags.insertContent( html );
|
QTags.insertContent( html );
|
||||||
} else {
|
} else {
|
||||||
|
// If neither the TinyMCE editor and the quick tags are available, add the HTML
|
||||||
|
// to the current active editor.
|
||||||
document.getElementById( wpActiveEditor ).value += html;
|
document.getElementById( wpActiveEditor ).value += html;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the old thickbox remove function exists, call it
|
// If the old thickbox remove function exists, call it.
|
||||||
if ( window.tb_remove ) {
|
if ( window.tb_remove ) {
|
||||||
try { window.tb_remove(); } catch( e ) {}
|
try { window.tb_remove(); } catch( e ) {}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// thickbox settings
|
|
||||||
var tb_position;
|
var tb_position;
|
||||||
(function($) {
|
(function($) {
|
||||||
|
/**
|
||||||
|
* Recalculates and applies the new ThickBox position based on the current
|
||||||
|
* window size.
|
||||||
|
*
|
||||||
|
* @since 2.6.0
|
||||||
|
*
|
||||||
|
* @global
|
||||||
|
*
|
||||||
|
* @returns {Object[]} Array containing jQuery objects for all the found
|
||||||
|
* ThickBox anchors.
|
||||||
|
*/
|
||||||
tb_position = function() {
|
tb_position = function() {
|
||||||
var tbWindow = $('#TB_window'),
|
var tbWindow = $('#TB_window'),
|
||||||
width = $(window).width(),
|
width = $(window).width(),
|
||||||
|
@ -55,6 +95,11 @@ var tb_position;
|
||||||
tbWindow.css({'top': 20 + adminbar_height + 'px', 'margin-top': '0'});
|
tbWindow.css({'top': 20 + adminbar_height + 'px', 'margin-top': '0'});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Recalculates the new height and width for all links with a ThickBox class.
|
||||||
|
*
|
||||||
|
* @since 2.6.0
|
||||||
|
*/
|
||||||
return $('a.thickbox').each( function() {
|
return $('a.thickbox').each( function() {
|
||||||
var href = $(this).attr('href');
|
var href = $(this).attr('href');
|
||||||
if ( ! href ) return;
|
if ( ! href ) return;
|
||||||
|
@ -64,6 +109,7 @@ var tb_position;
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Add handler to recalculates the ThickBox position when the window is resized.
|
||||||
$(window).resize(function(){ tb_position(); });
|
$(window).resize(function(){ tb_position(); });
|
||||||
|
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '5.0-alpha-42425';
|
$wp_version = '5.0-alpha-42426';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue