/var/www/(Del)hsihk.com/wp-content/plugins/woocommerce/includes/class-wc-order-item-meta.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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
<?php
/**
 * Order Item Meta
 *
 * A Simple class for managing order item meta so plugins add it in the correct format
 *
 * @class         order_item_meta
 * @version        2.2
 * @package        WooCommerce/Classes
 * @author         WooThemes
 */
class WC_Order_Item_Meta {

    public 
$meta;
    public 
$product;

    
/**
     * Constructor
     *
     * @access public
     * @param array $item_meta defaults to array()
     * @param \WC_Product $product defaults to null
     * @return \WC_Order_Item_Meta instance
     */
    
public function __construct$item_meta = array(), $product null ) {
        
$this->meta    $item_meta;
        
$this->product $product;
    }

    
/**
     * Display meta in a formatted list
     *
     * @access public
     * @param bool $flat (default: false)
     * @param bool $return (default: false)
     * @param string $hideprefix (default: _)
     * @return string
     */
    
public function display$flat false$return false$hideprefix '_' ) {

        
$output '';

        
$formatted_meta $this->get_formatted$hideprefix );

        if ( ! empty( 
$formatted_meta ) ) {

            
$meta_list = array();

            foreach ( 
$formatted_meta as $meta_key => $meta ) {

                if ( 
$flat ) {
                    
$meta_list[] = wp_kses_post$meta['label'] . ': ' $meta['value'] );
                } else {
                    
$meta_list[] = '
                            <dt class="variation-' 
sanitize_html_classsanitize_text_field$meta_key ) ) . '">' wp_kses_post$meta['label'] ) . ':</dt>
                            <dd class="variation-' 
sanitize_html_classsanitize_text_field$meta_key ) ) . '">' wp_kses_postwpautop$meta['value'] ) ) . '</dd>
                        '
;
                }
            }

            if ( ! empty( 
$meta_list ) ) {

                if ( 
$flat ) {
                    
$output .= implode", \n"$meta_list );
                } else {
                    
$output .= '<dl class="variation">' implode''$meta_list ). '</dl>';
                }
            }
        }

        if ( 
$return ) {
            return 
$output;
        } else {
            echo 
$output;
        }
    }


    
/**
     * Return an array of formatted item meta in format:
     *
     * array(
     *   $meta_key => array(
     *     'label' => $label,
     *     'value' => $value
     *   )
     * )
     *
     * e.g.
     *
     * array(
     *   'pa_size' => array(
     *     'label' => 'Size',
     *     'value' => 'Medium',
     *   )
     * )
     *
     * @since 2.2
     * @param string $hideprefix exclude meta when key is prefixed with this, defaults to `_`
     * @return array
     */
    
public function get_formatted$hideprefix '_' ) {

        if ( empty( 
$this->meta ) ) {
            return array();
        }

        
$formatted_meta = array();

        foreach ( (array) 
$this->meta as $meta_key => $meta_values ) {

            if ( empty( 
$meta_values ) || ( ! empty( $hideprefix ) && substr$meta_key0) == $hideprefix ) ) {
                continue;
            }

            foreach ( (array) 
$meta_values as $meta_value ) {

                
// Skip serialised meta
                
if ( is_serialized$meta_value ) ) {
                    continue;
                }

                
$attribute_key urldecodestr_replace'attribute_'''$meta_key ) );

                
// If this is a term slug, get the term's nice name
                
if ( taxonomy_exists$attribute_key ) ) {
                    
$term get_term_by'slug'$meta_value$attribute_key );

                    if ( ! 
is_wp_error$term ) && is_object$term ) && $term->name ) {
                        
$meta_value $term->name;
                    }

                
// If we have a product, and its not a term, try to find its non-sanitized name
                
} elseif ( $this->product ) {
                    
$product_attributes $this->product->get_attributes();

                    if ( isset( 
$product_attributes$attribute_key ] ) ) {
                        
$meta_key wc_attribute_label$product_attributes$attribute_key ]['name'] );
                    }
                }

                
// Unique key required
                
$formatted_meta_key $meta_key;
                
$loop               0;
                while ( isset( 
$formatted_meta$formatted_meta_key ] ) ) {
                    
$loop ++;
                    
$formatted_meta_key $meta_key '-' $loop;
                }

                
$formatted_meta$formatted_meta_key ] = array(
                    
'label'     => wc_attribute_label$attribute_key ),
                    
'value'     => apply_filters'woocommerce_order_item_display_meta_value'$meta_value ),
                );
            }
        }

        return 
$formatted_meta;
    }
}