2021-05-19 11:09:27 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Duotone block support flag.
|
|
|
|
*
|
|
|
|
* Parts of this source were derived and modified from TinyColor,
|
|
|
|
* released under the MIT license.
|
|
|
|
*
|
|
|
|
* https://github.com/bgrins/TinyColor
|
|
|
|
*
|
|
|
|
* Copyright (c), Brian Grinstead, http://briangrinstead.com
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
* a copy of this software and associated documentation files (the
|
|
|
|
* "Software"), to deal in the Software without restriction, including
|
|
|
|
* without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
* permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
* the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be
|
|
|
|
* included in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
|
|
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
|
|
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
* @since 5.8.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Register the block support.
|
|
|
|
WP_Block_Supports::get_instance()->register(
|
|
|
|
'duotone',
|
|
|
|
array(
|
2023-06-29 02:21:28 -04:00
|
|
|
'register_attribute' => array( 'WP_Duotone', 'register_duotone_support' ),
|
2021-05-19 11:09:27 -04:00
|
|
|
)
|
|
|
|
);
|
2023-06-29 02:21:28 -04:00
|
|
|
|
|
|
|
// Add classnames to blocks using duotone support.
|
Editor: Lazily load Duotone settings only when needed.
Introduced in [56101] the `WP_Duotone` class, hooks into the `wp_loaded` action to load duotone style data from global styles. Hooking in early in the bootstrap process caused a number of problems. This hook, triggered an error on installing, as this lookup for global styles, would result in a global post trying to be created, even before the table existed. Additionally, this implementation caused a severe performance regression, as duotone styling data was loaded unnecessarily for requests that did not require such data, such as REST API calls or actions within the wp-admin interface.
In this change, refactor the `WP_Duotone` to lazily load the global styles and theme.json data, only when a block that supports duotone is encountered. The method `render_duotone_support` was change to take a third parameter to reuse the existing `WP_Block_Type` object passed to the filter, to save it being looked up again. The code has also got improved type checking and the use of the util function `block_has_support`. Furthermore, the code's readability has been improved, along with enhancements to the documentation blocks.
Props Chouby, spacedmonkey, SergeyBiryukov, swissspidy, costdev, joemcgill, flixos90, mukesh27, nazmul111, ajlende, isabel_brison.
Fixes #58673.
Built from https://develop.svn.wordpress.org/trunk@56226
git-svn-id: http://core.svn.wordpress.org/trunk@55738 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-07-13 07:34:28 -04:00
|
|
|
add_filter( 'render_block', array( 'WP_Duotone', 'render_duotone_support' ), 10, 3 );
|
2024-06-03 21:48:17 -04:00
|
|
|
add_filter( 'render_block_core/image', array( 'WP_Duotone', 'restore_image_outer_container' ), 10, 1 );
|
2023-06-29 02:21:28 -04:00
|
|
|
|
|
|
|
// Enqueue styles.
|
|
|
|
// Block styles (core-block-supports-inline-css) before the style engine (wp_enqueue_stored_styles).
|
|
|
|
// Global styles (global-styles-inline-css) after the other global styles (wp_enqueue_global_styles).
|
|
|
|
add_action( 'wp_enqueue_scripts', array( 'WP_Duotone', 'output_block_styles' ), 9 );
|
|
|
|
add_action( 'wp_enqueue_scripts', array( 'WP_Duotone', 'output_global_styles' ), 11 );
|
|
|
|
|
|
|
|
// Add SVG filters to the footer. Also, for classic themes, output block styles (core-block-supports-inline-css).
|
|
|
|
add_action( 'wp_footer', array( 'WP_Duotone', 'output_footer_assets' ), 10 );
|
|
|
|
|
|
|
|
// Add styles and SVGs for use in the editor via the EditorStyles component.
|
|
|
|
add_filter( 'block_editor_settings_all', array( 'WP_Duotone', 'add_editor_settings' ), 10 );
|
|
|
|
|
|
|
|
// Migrate the old experimental duotone support flag.
|
|
|
|
add_filter( 'block_type_metadata_settings', array( 'WP_Duotone', 'migrate_experimental_duotone_support_flag' ), 10, 2 );
|