/var/www/html_us/wp-content/plugins/woocommerce/src/Internal/Utilities/BlocksUtil.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php

namespace Automattic\WooCommerce\Internal\Utilities;

/**
 * Helper functions for working with blocks.
 */
class BlocksUtil {

    
/**
     * Return blocks with their inner blocks flattened.
     *
     * @param array $blocks Array of blocks as returned by parse_blocks().
     * @return array All blocks.
     */
    
public static function flatten_blocks$blocks ) {
        return 
array_reduce(
            
$blocks,
            function( 
$carry$block ) {
                
array_push$carryarray_diff_key$blockarray_flip( array( 'innerBlocks' ) ) ) );
                if ( isset( 
$block['innerBlocks'] ) ) {
                    
$inner_blocks self::flatten_blocks$block['innerBlocks'] );
                    return 
array_merge$carry$inner_blocks );
                }

                return 
$carry;
            },
            array()
        );
    }

    
/**
     * Get all instances of the specified block from the widget area.
     *
     * @param array $block_name The name (id) of a block, e.g. `woocommerce/mini-cart`.
     * @return array Array of blocks as returned by parse_blocks().
     */
    
public static function get_blocks_from_widget_area$block_name ) {
        return 
array_reduce(
            
get_option'widget_block' ),
            function ( 
$acc$block ) use ( $block_name ) {
                
$parsed_blocks = ! empty( $block ) && is_array$block ) ? parse_blocks$block['content'] ) : array();
                if ( ! empty( 
$parsed_blocks ) && $block_name === $parsed_blocks[0]['blockName'] ) {
                    
array_push$acc$parsed_blocks[0] );
                    return 
$acc;
                }
                return 
$acc;
            },
            array()
        );
    }

    
/**
     * Get all instances of the specified block on a specific template part.
     *
     * @param string $block_name The name (id) of a block, e.g. `woocommerce/mini-cart`.
     * @param string $template_part_slug The woo page to search, e.g. `header`.
     * @return array Array of blocks as returned by parse_blocks().
     */
    
public static function get_block_from_template_part$block_name$template_part_slug ) {
        
$template get_block_templateget_stylesheet() . '//' $template_part_slug'wp_template_part' );
        
$blocks   parse_blocks$template->content );

        
$flatten_blocks self::flatten_blocks$blocks );

        return 
array_values(
            
array_filter(
                
$flatten_blocks,
                function ( 
$block ) use ( $block_name ) {
                    return ( 
$block_name === $block['blockName'] );
                }
            )
        );
    }
}