mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-09 01:48:21 +01:00
Inline documentation for hooks in wp-includes/class-wp-editor.php.
Props kpdesign for some cleanup. Fixes #27523. Built from https://develop.svn.wordpress.org/trunk@27828 git-svn-id: http://core.svn.wordpress.org/trunk@27662 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
4bd2c5ce85
commit
4ce89ca20c
@ -172,7 +172,15 @@ final class _WP_Editors {
|
|||||||
include(ABSPATH . 'wp-admin/includes/media.php');
|
include(ABSPATH . 'wp-admin/includes/media.php');
|
||||||
|
|
||||||
echo '<div id="wp-' . $editor_id . '-media-buttons" class="wp-media-buttons">';
|
echo '<div id="wp-' . $editor_id . '-media-buttons" class="wp-media-buttons">';
|
||||||
do_action('media_buttons', $editor_id);
|
|
||||||
|
/**
|
||||||
|
* Fires after the default media button(s) are displayed.
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
do_action( 'media_buttons', $editor_id );
|
||||||
echo "</div>\n";
|
echo "</div>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -180,9 +188,24 @@ final class _WP_Editors {
|
|||||||
echo "</div>\n";
|
echo "</div>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the HTML markup output that displays the editor.
|
||||||
|
*
|
||||||
|
* @since 2.1.0
|
||||||
|
*
|
||||||
|
* @param string $output Editor's HTML markup.
|
||||||
|
*/
|
||||||
$the_editor = apply_filters( 'the_editor', '<div id="wp-' . $editor_id . '-editor-container" class="wp-editor-container">' .
|
$the_editor = apply_filters( 'the_editor', '<div id="wp-' . $editor_id . '-editor-container" class="wp-editor-container">' .
|
||||||
'<textarea' . $editor_class . $height . $tabindex . $autocomplete . ' cols="40" name="' . $set['textarea_name'] . '" ' .
|
'<textarea' . $editor_class . $height . $tabindex . $autocomplete . ' cols="40" name="' . $set['textarea_name'] . '" ' .
|
||||||
'id="' . $editor_id . '">%s</textarea></div>' );
|
'id="' . $editor_id . '">%s</textarea></div>' );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the default editor content.
|
||||||
|
*
|
||||||
|
* @since 2.1.0
|
||||||
|
*
|
||||||
|
* @param string $content Default editor content.
|
||||||
|
*/
|
||||||
$content = apply_filters( 'the_editor_content', $content );
|
$content = apply_filters( 'the_editor_content', $content );
|
||||||
|
|
||||||
printf( $the_editor, $content );
|
printf( $the_editor, $content );
|
||||||
@ -220,7 +243,16 @@ final class _WP_Editors {
|
|||||||
if ( $set['dfw'] )
|
if ( $set['dfw'] )
|
||||||
$qtInit['buttons'] .= ',fullscreen';
|
$qtInit['buttons'] .= ',fullscreen';
|
||||||
|
|
||||||
$qtInit = apply_filters('quicktags_settings', $qtInit, $editor_id);
|
/**
|
||||||
|
* Filter the Quicktags settings.
|
||||||
|
*
|
||||||
|
* @since 3.3.0
|
||||||
|
*
|
||||||
|
* @param array $qtInit Quicktags settings.
|
||||||
|
* @param string $editor_id The unique editor ID, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
$qtInit = apply_filters( 'quicktags_settings', $qtInit, $editor_id );
|
||||||
|
|
||||||
self::$qt_settings[$editor_id] = $qtInit;
|
self::$qt_settings[$editor_id] = $qtInit;
|
||||||
|
|
||||||
self::$qt_buttons = array_merge( self::$qt_buttons, explode(',', $qtInit['buttons']) );
|
self::$qt_buttons = array_merge( self::$qt_buttons, explode(',', $qtInit['buttons']) );
|
||||||
@ -237,20 +269,41 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
|
|
||||||
self::$mce_locale = $mce_locale;
|
self::$mce_locale = $mce_locale;
|
||||||
|
|
||||||
|
/** This filter is documented in wp-admin/includes/media.php */
|
||||||
$no_captions = (bool) apply_filters( 'disable_captions', '' );
|
$no_captions = (bool) apply_filters( 'disable_captions', '' );
|
||||||
$first_run = true;
|
$first_run = true;
|
||||||
$ext_plugins = '';
|
$ext_plugins = '';
|
||||||
|
|
||||||
if ( $set['teeny'] ) {
|
if ( $set['teeny'] ) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the list of teenyMCE plugins.
|
||||||
|
*
|
||||||
|
* @since 2.7.0
|
||||||
|
*
|
||||||
|
* @param array $plugins An array of teenyMCE plugins.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
self::$plugins = $plugins = apply_filters( 'teeny_mce_plugins', array( 'fullscreen', 'image', 'wordpress', 'wpeditimage', 'wplink' ), $editor_id );
|
self::$plugins = $plugins = apply_filters( 'teeny_mce_plugins', array( 'fullscreen', 'image', 'wordpress', 'wpeditimage', 'wplink' ), $editor_id );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TinyMCE external plugins filter
|
* Filter the list of TinyMCE external plugins.
|
||||||
*
|
*
|
||||||
* Takes an associative array of external plugins for TinyMCE in the form 'plugin_name' => 'url'.
|
* The filter takes an associative array of external plugins for
|
||||||
* The url should be absolute and should include the js file name to be loaded.
|
* TinyMCE in the form 'plugin_name' => 'url'.
|
||||||
* Example: 'myplugin' => 'http://my-site.com/wp-content/plugins/myfolder/mce_plugin.js'.
|
*
|
||||||
* If the plugin adds a button, it should be added with one of the "$mce_buttons" filters.
|
* The url should be absolute, and should include the js filename
|
||||||
|
* to be loaded. For example:
|
||||||
|
* 'myplugin' => 'http://mysite.com/wp-content/plugins/myfolder/mce_plugin.js'.
|
||||||
|
*
|
||||||
|
* If the external plugin adds a button, it should be added with
|
||||||
|
* one of the 'mce_buttons' filters.
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @param array $external_plugins An array of external TinyMCE plugins.
|
||||||
*/
|
*/
|
||||||
$mce_external_plugins = apply_filters( 'mce_external_plugins', array() );
|
$mce_external_plugins = apply_filters( 'mce_external_plugins', array() );
|
||||||
|
|
||||||
@ -275,10 +328,14 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TinyMCE default plugins filter
|
* Filter the list of default TinyMCE plugins.
|
||||||
*
|
*
|
||||||
* Specifies which of the default plugins that are included in WordPress should be added to
|
* The filter specifies which of the default plugins included
|
||||||
* the TinyMCE instance.
|
* in WordPress should be added to the TinyMCE instance.
|
||||||
|
*
|
||||||
|
* @since 3.3.0
|
||||||
|
*
|
||||||
|
* @param array $plugins An array of default TinyMCE plugins.
|
||||||
*/
|
*/
|
||||||
$plugins = array_unique( apply_filters( 'tiny_mce_plugins', $plugins ) );
|
$plugins = array_unique( apply_filters( 'tiny_mce_plugins', $plugins ) );
|
||||||
|
|
||||||
@ -289,13 +346,19 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( ! empty( $mce_external_plugins ) ) {
|
if ( ! empty( $mce_external_plugins ) ) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This filter loads translations for external TinyMCE 3.x plugins.
|
* Filter the translations loaded for external TinyMCE 3.x plugins.
|
||||||
*
|
*
|
||||||
* Takes an associative array 'plugin_name' => 'path', where path is the
|
* The filter takes an associative array ('plugin_name' => 'path')
|
||||||
* include path to the file. The language file should follow the same format as
|
* where 'path' is the include path to the file.
|
||||||
* wp_mce_translation() and should define a variable $strings that
|
*
|
||||||
* holds all translated strings.
|
* The language file should follow the same format as wp_mce_translation(),
|
||||||
|
* and should define a variable ($strings) that holds all translated strings.
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @param array $translations Translations for external TinyMCE plugins.
|
||||||
*/
|
*/
|
||||||
$mce_external_languages = apply_filters( 'mce_external_languages', array() );
|
$mce_external_languages = apply_filters( 'mce_external_languages', array() );
|
||||||
|
|
||||||
@ -425,6 +488,13 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the comma-delimited list of stylesheets to load in TinyMCE.
|
||||||
|
*
|
||||||
|
* @since 2.1.0
|
||||||
|
*
|
||||||
|
* @param array $stylesheets Comma-delimited list of stylesheets.
|
||||||
|
*/
|
||||||
$mce_css = trim( apply_filters( 'mce_css', implode( ',', $mce_css ) ), ' ,' );
|
$mce_css = trim( apply_filters( 'mce_css', implode( ',', $mce_css ) ), ' ,' );
|
||||||
|
|
||||||
if ( ! empty($mce_css) )
|
if ( ! empty($mce_css) )
|
||||||
@ -432,13 +502,58 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( $set['teeny'] ) {
|
if ( $set['teeny'] ) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the list of teenyMCE buttons (Text tab).
|
||||||
|
*
|
||||||
|
* @since 2.7.0
|
||||||
|
*
|
||||||
|
* @param array $buttons An array of teenyMCE buttons.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
$mce_buttons = apply_filters( 'teeny_mce_buttons', array('bold', 'italic', 'underline', 'blockquote', 'strikethrough', 'bullist', 'numlist', 'alignleft', 'aligncenter', 'alignright', 'undo', 'redo', 'link', 'unlink', 'fullscreen'), $editor_id );
|
$mce_buttons = apply_filters( 'teeny_mce_buttons', array('bold', 'italic', 'underline', 'blockquote', 'strikethrough', 'bullist', 'numlist', 'alignleft', 'aligncenter', 'alignright', 'undo', 'redo', 'link', 'unlink', 'fullscreen'), $editor_id );
|
||||||
$mce_buttons_2 = $mce_buttons_3 = $mce_buttons_4 = array();
|
$mce_buttons_2 = $mce_buttons_3 = $mce_buttons_4 = array();
|
||||||
} else {
|
} else {
|
||||||
$mce_buttons = apply_filters('mce_buttons', array('bold', 'italic', 'strikethrough', 'bullist', 'numlist', 'blockquote', 'hr', 'alignleft', 'aligncenter', 'alignright', 'link', 'unlink', 'wp_more', 'spellchecker', 'fullscreen', 'wp_adv' ), $editor_id);
|
|
||||||
$mce_buttons_2 = apply_filters('mce_buttons_2', array( 'formatselect', 'underline', 'alignjustify', 'forecolor', 'pastetext', 'removeformat', 'charmap', 'outdent', 'indent', 'undo', 'redo', 'wp_help' ), $editor_id);
|
/**
|
||||||
$mce_buttons_3 = apply_filters('mce_buttons_3', array(), $editor_id);
|
* Filter the first-row list of TinyMCE buttons (Visual tab).
|
||||||
$mce_buttons_4 = apply_filters('mce_buttons_4', array(), $editor_id);
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param array $buttons First-row list of buttons.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
$mce_buttons = apply_filters( 'mce_buttons', array('bold', 'italic', 'strikethrough', 'bullist', 'numlist', 'blockquote', 'hr', 'alignleft', 'aligncenter', 'alignright', 'link', 'unlink', 'wp_more', 'spellchecker', 'fullscreen', 'wp_adv' ), $editor_id );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the second-row list of TinyMCE buttons (Visual tab).
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param array $buttons Second-row list of buttons.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
$mce_buttons_2 = apply_filters( 'mce_buttons_2', array( 'formatselect', 'underline', 'alignjustify', 'forecolor', 'pastetext', 'removeformat', 'charmap', 'outdent', 'indent', 'undo', 'redo', 'wp_help' ), $editor_id );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the third-row list of TinyMCE buttons (Visual tab).
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param array $buttons Third-row list of buttons.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
$mce_buttons_3 = apply_filters( 'mce_buttons_3', array(), $editor_id );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the fourth-row list of TinyMCE buttons (Visual tab).
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @param array $buttons Fourth-row list of buttons.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
|
$mce_buttons_4 = apply_filters( 'mce_buttons_4', array(), $editor_id );
|
||||||
}
|
}
|
||||||
|
|
||||||
$body_class = $editor_id;
|
$body_class = $editor_id;
|
||||||
@ -489,13 +604,35 @@ final class _WP_Editors {
|
|||||||
if ( is_array( $set['tinymce'] ) )
|
if ( is_array( $set['tinymce'] ) )
|
||||||
$mceInit = array_merge( $mceInit, $set['tinymce'] );
|
$mceInit = array_merge( $mceInit, $set['tinymce'] );
|
||||||
|
|
||||||
// For people who really REALLY know what they're doing with TinyMCE
|
/*
|
||||||
// You can modify $mceInit to add, remove, change elements of the config before tinyMCE.init
|
* For people who really REALLY know what they're doing with TinyMCE
|
||||||
// Setting "valid_elements", "invalid_elements" and "extended_valid_elements" can be done through this filter.
|
* You can modify $mceInit to add, remove, change elements of the config
|
||||||
// Best is to use the default cleanup by not specifying valid_elements, as TinyMCE contains full set of XHTML 1.0.
|
* before tinyMCE.init. Setting "valid_elements", "invalid_elements"
|
||||||
|
* and "extended_valid_elements" can be done through this filter. Best
|
||||||
|
* is to use the default cleanup by not specifying valid_elements,
|
||||||
|
* as TinyMCE contains full set of XHTML 1.0.
|
||||||
|
*/
|
||||||
if ( $set['teeny'] ) {
|
if ( $set['teeny'] ) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the teenyMCE config before init.
|
||||||
|
*
|
||||||
|
* @since 2.7.0
|
||||||
|
*
|
||||||
|
* @param array $mceInit An array with teenyMCE config.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
$mceInit = apply_filters( 'teeny_mce_before_init', $mceInit, $editor_id );
|
$mceInit = apply_filters( 'teeny_mce_before_init', $mceInit, $editor_id );
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the TinyMCE config before init.
|
||||||
|
*
|
||||||
|
* @since 2.5.0
|
||||||
|
*
|
||||||
|
* @param array $mceInit An array with TinyMCE config.
|
||||||
|
* @param string $editor_id Unique editor identifier, e.g. 'content'.
|
||||||
|
*/
|
||||||
$mceInit = apply_filters( 'tiny_mce_before_init', $mceInit, $editor_id );
|
$mceInit = apply_filters( 'tiny_mce_before_init', $mceInit, $editor_id );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -827,6 +964,13 @@ final class _WP_Editors {
|
|||||||
|
|
||||||
$suffix = ( defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ) ? '' : '.min';
|
$suffix = ( defined('SCRIPT_DEBUG') && SCRIPT_DEBUG ) ? '' : '.min';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fires immediately before the TinyMCE settings are printed.
|
||||||
|
*
|
||||||
|
* @since 3.2.0
|
||||||
|
*
|
||||||
|
* @param array $mce_settings TinyMCE settings array.
|
||||||
|
*/
|
||||||
do_action( 'before_wp_tiny_mce', self::$mce_settings );
|
do_action( 'before_wp_tiny_mce', self::$mce_settings );
|
||||||
?>
|
?>
|
||||||
|
|
||||||
@ -861,7 +1005,14 @@ final class _WP_Editors {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Allow scripts to be added after tinymce.js has been loaded but before any editor instances are created.
|
/**
|
||||||
|
* Fires after tinymce.js is loaded, but before any TinyMCE editor
|
||||||
|
* instances are created.
|
||||||
|
*
|
||||||
|
* @since 3.9.0
|
||||||
|
*
|
||||||
|
* @param array $mce_settings TinyMCE settings array.
|
||||||
|
*/
|
||||||
do_action( 'wp_tiny_mce_init', self::$mce_settings );
|
do_action( 'wp_tiny_mce_init', self::$mce_settings );
|
||||||
|
|
||||||
?>
|
?>
|
||||||
@ -938,6 +1089,13 @@ final class _WP_Editors {
|
|||||||
if ( in_array( 'wpfullscreen', self::$plugins, true ) || in_array( 'fullscreen', self::$qt_buttons, true ) )
|
if ( in_array( 'wpfullscreen', self::$plugins, true ) || in_array( 'fullscreen', self::$qt_buttons, true ) )
|
||||||
self::wp_fullscreen_html();
|
self::wp_fullscreen_html();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fires after any core TinyMCE editor instances are created.
|
||||||
|
*
|
||||||
|
* @since 3.2.0
|
||||||
|
*
|
||||||
|
* @param array $mce_settings TinyMCE settings array.
|
||||||
|
*/
|
||||||
do_action( 'after_wp_tiny_mce', self::$mce_settings );
|
do_action( 'after_wp_tiny_mce', self::$mce_settings );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -978,6 +1136,14 @@ final class _WP_Editors {
|
|||||||
'help' => array( 'title' => __('Help (Alt + Shift + H)'), 'both' => false ),
|
'help' => array( 'title' => __('Help (Alt + Shift + H)'), 'both' => false ),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the list of TinyMCE buttons for the fullscreen
|
||||||
|
* 'Distraction Free Writing' editor.
|
||||||
|
*
|
||||||
|
* @since 3.2.0
|
||||||
|
*
|
||||||
|
* @param array $buttons An array of TinyMCE buttons for the DFW editor.
|
||||||
|
*/
|
||||||
$buttons = apply_filters( 'wp_fullscreen_buttons', $buttons );
|
$buttons = apply_filters( 'wp_fullscreen_buttons', $buttons );
|
||||||
|
|
||||||
foreach ( $buttons as $button => $args ) {
|
foreach ( $buttons as $button => $args ) {
|
||||||
@ -1093,17 +1259,20 @@ final class _WP_Editors {
|
|||||||
*
|
*
|
||||||
* @since 3.7.0
|
* @since 3.7.0
|
||||||
*
|
*
|
||||||
|
* @see 'wp_link_query_args' filter
|
||||||
|
*
|
||||||
* @param array $results {
|
* @param array $results {
|
||||||
* An associative array of query results.
|
* An associative array of query results.
|
||||||
*
|
*
|
||||||
* @type array {
|
* @type array {
|
||||||
* @type int 'ID' The post ID.
|
* @type int $ID Post ID.
|
||||||
* @type string 'title' The trimmed, escaped post title.
|
* @type string $title The trimmed, escaped post title.
|
||||||
* @type string 'permalink' The post permalink.
|
* @type string $permalink Post permalink.
|
||||||
* @type string 'info' A 'Y/m/d'-formatted date for 'post' post type, the 'singular_name' post type label otherwise.
|
* @type string $info A 'Y/m/d'-formatted date for 'post' post type,
|
||||||
|
* the 'singular_name' post type label otherwise.
|
||||||
* }
|
* }
|
||||||
* }
|
* }
|
||||||
* @param array $query An array of WP_Query arguments. @see 'wp_link_query_args' filter
|
* @param array $query An array of WP_Query arguments.
|
||||||
*/
|
*/
|
||||||
return apply_filters( 'wp_link_query', $results, $query );
|
return apply_filters( 'wp_link_query', $results, $query );
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user