mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-05 07:58:35 +01:00
block.json: Allow passing PHP filename as variations
field.
Previously, the `variations` field in a block.json file could be used to provide a static list of the block's variations (i.e., an array). Alternatively, the block's `variation_callback` could be set during server-side block registration to point to a PHP function to generate those variations. This changeset makes it so that the block.json `variations` field can be alternatively set to a string, which will be interpreted as the filename of a PHP file that generates the variations. It is loosely modeled after [54132], which introduced the `render` field for `block.json`, as a way to point to a PHP file instead of providing a `render_callback`. Props bernhard-reiter, gziolo. Fixes #61280. Built from https://develop.svn.wordpress.org/trunk@58801 git-svn-id: http://core.svn.wordpress.org/trunk@58197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
86754f2bc2
commit
8ab984897f
@ -385,6 +385,7 @@ function get_block_metadata_i18n_schema() {
|
|||||||
* @since 6.3.0 Added `selectors` field.
|
* @since 6.3.0 Added `selectors` field.
|
||||||
* @since 6.4.0 Added support for `blockHooks` field.
|
* @since 6.4.0 Added support for `blockHooks` field.
|
||||||
* @since 6.5.0 Added support for `allowedBlocks`, `viewScriptModule`, and `viewStyle` fields.
|
* @since 6.5.0 Added support for `allowedBlocks`, `viewScriptModule`, and `viewStyle` fields.
|
||||||
|
* @since 6.7.0 Allow PHP filename as `variations` argument.
|
||||||
*
|
*
|
||||||
* @param string $file_or_folder Path to the JSON file with metadata definition for
|
* @param string $file_or_folder Path to the JSON file with metadata definition for
|
||||||
* the block or path to the folder where the `block.json` file is located.
|
* the block or path to the folder where the `block.json` file is located.
|
||||||
@ -522,6 +523,34 @@ function register_block_type_from_metadata( $file_or_folder, $args = array() ) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If `variations` is a string, it's the name of a PHP file that
|
||||||
|
// generates the variations.
|
||||||
|
if ( ! empty( $metadata['variations'] ) && is_string( $metadata['variations'] ) ) {
|
||||||
|
$variations_path = wp_normalize_path(
|
||||||
|
realpath(
|
||||||
|
dirname( $metadata['file'] ) . '/' .
|
||||||
|
remove_block_asset_path_prefix( $metadata['variations'] )
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if ( $variations_path ) {
|
||||||
|
/**
|
||||||
|
* Generates the list of block variations.
|
||||||
|
*
|
||||||
|
* @since 6.7.0
|
||||||
|
*
|
||||||
|
* @return string Returns the list of block variations.
|
||||||
|
*/
|
||||||
|
$settings['variation_callback'] = static function () use ( $variations_path ) {
|
||||||
|
$variations = require $variations_path;
|
||||||
|
return $variations;
|
||||||
|
};
|
||||||
|
// The block instance's `variations` field is only allowed to be an array
|
||||||
|
// (of known block variations). We unset it so that the block instance will
|
||||||
|
// provide a getter that returns the result of the `variation_callback` instead.
|
||||||
|
unset( $settings['variations'] );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$settings = array_merge( $settings, $args );
|
$settings = array_merge( $settings, $args );
|
||||||
|
|
||||||
$script_fields = array(
|
$script_fields = array(
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.7-alpha-58800';
|
$wp_version = '6.7-alpha-58801';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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
Block a user