set_ignored_hooked_blocks_metadata

The timeline below displays how wordpress function set_ignored_hooked_blocks_metadata has changed across different WordPress versions. If a version is not listed, refer to the next available version below.

WordPress Version: 6.5

/**
 * Adds a list of hooked block types to an anchor block's ignored hooked block types.
 *
 * This function is meant for internal use only.
 *
 * @since 6.5.0
 * @access private
 *
 * @param array                   $parsed_anchor_block The anchor block, in parsed block array format.
 * @param string                  $relative_position   The relative position of the hooked blocks.
 *                                                     Can be one of 'before', 'after', 'first_child', or 'last_child'.
 * @param array                   $hooked_blocks       An array of hooked block types, grouped by anchor block and relative position.
 * @param WP_Block_Template|array $context             The block template, template part, or pattern that the anchor block belongs to.
 * @return string An empty string.
 */
function set_ignored_hooked_blocks_metadata(&$parsed_anchor_block, $relative_position, $hooked_blocks, $context)
{
    $anchor_block_type = $parsed_anchor_block['blockName'];
    $hooked_block_types = isset($hooked_blocks[$anchor_block_type][$relative_position]) ? $hooked_blocks[$anchor_block_type][$relative_position] : array();
    /** This filter is documented in wp-includes/blocks.php */
    $hooked_block_types = apply_filters('hooked_block_types', $hooked_block_types, $relative_position, $anchor_block_type, $context);
    if (empty($hooked_block_types)) {
        return '';
    }
    foreach ($hooked_block_types as $index => $hooked_block_type) {
        $parsed_hooked_block = array('blockName' => $hooked_block_type, 'attrs' => array(), 'innerBlocks' => array(), 'innerContent' => array());
        /** This filter is documented in wp-includes/blocks.php */
        $parsed_hooked_block = apply_filters('hooked_block', $parsed_hooked_block, $hooked_block_type, $relative_position, $parsed_anchor_block, $context);
        /** This filter is documented in wp-includes/blocks.php */
        $parsed_hooked_block = apply_filters("hooked_block_{$hooked_block_type}", $parsed_hooked_block, $hooked_block_type, $relative_position, $parsed_anchor_block, $context);
        if (null === $parsed_hooked_block) {
            unset($hooked_block_types[$index]);
        }
    }
    $previously_ignored_hooked_blocks = isset($parsed_anchor_block['attrs']['metadata']['ignoredHookedBlocks']) ? $parsed_anchor_block['attrs']['metadata']['ignoredHookedBlocks'] : array();
    $parsed_anchor_block['attrs']['metadata']['ignoredHookedBlocks'] = array_unique(array_merge($previously_ignored_hooked_blocks, $hooked_block_types));
    // Markup for the hooked blocks has already been created (in `insert_hooked_blocks`).
    return '';
}