Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-inclu...
File: class-wp-theme-json.php
} elseif ( empty( $inner ) ) {
[2000] Fix | Delete
$selectors_scoped[] = $outer;
[2001] Fix | Delete
}
[2002] Fix | Delete
}
[2003] Fix | Delete
}
[2004] Fix | Delete
[2005] Fix | Delete
$result = implode( ', ', $selectors_scoped );
[2006] Fix | Delete
return $result;
[2007] Fix | Delete
}
[2008] Fix | Delete
[2009] Fix | Delete
/**
[2010] Fix | Delete
* Scopes the selectors for a given style node.
[2011] Fix | Delete
*
[2012] Fix | Delete
* This includes the primary selector, i.e. `$node['selector']`, as well as any custom
[2013] Fix | Delete
* selectors for features and subfeatures, e.g. `$node['selectors']['border']` etc.
[2014] Fix | Delete
*
[2015] Fix | Delete
* @since 6.6.0
[2016] Fix | Delete
*
[2017] Fix | Delete
* @param string $scope Selector to scope to.
[2018] Fix | Delete
* @param array $node Style node with selectors to scope.
[2019] Fix | Delete
* @return array Node with updated selectors.
[2020] Fix | Delete
*/
[2021] Fix | Delete
protected static function scope_style_node_selectors( $scope, $node ) {
[2022] Fix | Delete
$node['selector'] = static::scope_selector( $scope, $node['selector'] );
[2023] Fix | Delete
[2024] Fix | Delete
if ( empty( $node['selectors'] ) ) {
[2025] Fix | Delete
return $node;
[2026] Fix | Delete
}
[2027] Fix | Delete
[2028] Fix | Delete
foreach ( $node['selectors'] as $feature => $selector ) {
[2029] Fix | Delete
if ( is_string( $selector ) ) {
[2030] Fix | Delete
$node['selectors'][ $feature ] = static::scope_selector( $scope, $selector );
[2031] Fix | Delete
}
[2032] Fix | Delete
if ( is_array( $selector ) ) {
[2033] Fix | Delete
foreach ( $selector as $subfeature => $subfeature_selector ) {
[2034] Fix | Delete
$node['selectors'][ $feature ][ $subfeature ] = static::scope_selector( $scope, $subfeature_selector );
[2035] Fix | Delete
}
[2036] Fix | Delete
}
[2037] Fix | Delete
}
[2038] Fix | Delete
[2039] Fix | Delete
return $node;
[2040] Fix | Delete
}
[2041] Fix | Delete
[2042] Fix | Delete
/**
[2043] Fix | Delete
* Gets preset values keyed by slugs based on settings and metadata.
[2044] Fix | Delete
*
[2045] Fix | Delete
* <code>
[2046] Fix | Delete
* $settings = array(
[2047] Fix | Delete
* 'typography' => array(
[2048] Fix | Delete
* 'fontFamilies' => array(
[2049] Fix | Delete
* array(
[2050] Fix | Delete
* 'slug' => 'sansSerif',
[2051] Fix | Delete
* 'fontFamily' => '"Helvetica Neue", sans-serif',
[2052] Fix | Delete
* ),
[2053] Fix | Delete
* array(
[2054] Fix | Delete
* 'slug' => 'serif',
[2055] Fix | Delete
* 'colors' => 'Georgia, serif',
[2056] Fix | Delete
* )
[2057] Fix | Delete
* ),
[2058] Fix | Delete
* ),
[2059] Fix | Delete
* );
[2060] Fix | Delete
* $meta = array(
[2061] Fix | Delete
* 'path' => array( 'typography', 'fontFamilies' ),
[2062] Fix | Delete
* 'value_key' => 'fontFamily',
[2063] Fix | Delete
* );
[2064] Fix | Delete
* $values_by_slug = get_settings_values_by_slug();
[2065] Fix | Delete
* // $values_by_slug === array(
[2066] Fix | Delete
* // 'sans-serif' => '"Helvetica Neue", sans-serif',
[2067] Fix | Delete
* // 'serif' => 'Georgia, serif',
[2068] Fix | Delete
* // );
[2069] Fix | Delete
* </code>
[2070] Fix | Delete
*
[2071] Fix | Delete
* @since 5.9.0
[2072] Fix | Delete
* @since 6.6.0 Passing $settings to the callbacks defined in static::PRESETS_METADATA.
[2073] Fix | Delete
*
[2074] Fix | Delete
* @param array $settings Settings to process.
[2075] Fix | Delete
* @param array $preset_metadata One of the PRESETS_METADATA values.
[2076] Fix | Delete
* @param string[] $origins List of origins to process.
[2077] Fix | Delete
* @return array Array of presets where each key is a slug and each value is the preset value.
[2078] Fix | Delete
*/
[2079] Fix | Delete
protected static function get_settings_values_by_slug( $settings, $preset_metadata, $origins ) {
[2080] Fix | Delete
$preset_per_origin = _wp_array_get( $settings, $preset_metadata['path'], array() );
[2081] Fix | Delete
[2082] Fix | Delete
$result = array();
[2083] Fix | Delete
foreach ( $origins as $origin ) {
[2084] Fix | Delete
if ( ! isset( $preset_per_origin[ $origin ] ) ) {
[2085] Fix | Delete
continue;
[2086] Fix | Delete
}
[2087] Fix | Delete
foreach ( $preset_per_origin[ $origin ] as $preset ) {
[2088] Fix | Delete
$slug = _wp_to_kebab_case( $preset['slug'] );
[2089] Fix | Delete
[2090] Fix | Delete
$value = '';
[2091] Fix | Delete
if ( isset( $preset_metadata['value_key'], $preset[ $preset_metadata['value_key'] ] ) ) {
[2092] Fix | Delete
$value_key = $preset_metadata['value_key'];
[2093] Fix | Delete
$value = $preset[ $value_key ];
[2094] Fix | Delete
} elseif (
[2095] Fix | Delete
isset( $preset_metadata['value_func'] ) &&
[2096] Fix | Delete
is_callable( $preset_metadata['value_func'] )
[2097] Fix | Delete
) {
[2098] Fix | Delete
$value_func = $preset_metadata['value_func'];
[2099] Fix | Delete
$value = call_user_func( $value_func, $preset, $settings );
[2100] Fix | Delete
} else {
[2101] Fix | Delete
// If we don't have a value, then don't add it to the result.
[2102] Fix | Delete
continue;
[2103] Fix | Delete
}
[2104] Fix | Delete
[2105] Fix | Delete
$result[ $slug ] = $value;
[2106] Fix | Delete
}
[2107] Fix | Delete
}
[2108] Fix | Delete
return $result;
[2109] Fix | Delete
}
[2110] Fix | Delete
[2111] Fix | Delete
/**
[2112] Fix | Delete
* Similar to get_settings_values_by_slug, but doesn't compute the value.
[2113] Fix | Delete
*
[2114] Fix | Delete
* @since 5.9.0
[2115] Fix | Delete
*
[2116] Fix | Delete
* @param array $settings Settings to process.
[2117] Fix | Delete
* @param array $preset_metadata One of the PRESETS_METADATA values.
[2118] Fix | Delete
* @param string[] $origins List of origins to process.
[2119] Fix | Delete
* @return array Array of presets where the key and value are both the slug.
[2120] Fix | Delete
*/
[2121] Fix | Delete
protected static function get_settings_slugs( $settings, $preset_metadata, $origins = null ) {
[2122] Fix | Delete
if ( null === $origins ) {
[2123] Fix | Delete
$origins = static::VALID_ORIGINS;
[2124] Fix | Delete
}
[2125] Fix | Delete
[2126] Fix | Delete
$preset_per_origin = _wp_array_get( $settings, $preset_metadata['path'], array() );
[2127] Fix | Delete
[2128] Fix | Delete
$result = array();
[2129] Fix | Delete
foreach ( $origins as $origin ) {
[2130] Fix | Delete
if ( ! isset( $preset_per_origin[ $origin ] ) ) {
[2131] Fix | Delete
continue;
[2132] Fix | Delete
}
[2133] Fix | Delete
foreach ( $preset_per_origin[ $origin ] as $preset ) {
[2134] Fix | Delete
$slug = _wp_to_kebab_case( $preset['slug'] );
[2135] Fix | Delete
[2136] Fix | Delete
// Use the array as a set so we don't get duplicates.
[2137] Fix | Delete
$result[ $slug ] = $slug;
[2138] Fix | Delete
}
[2139] Fix | Delete
}
[2140] Fix | Delete
return $result;
[2141] Fix | Delete
}
[2142] Fix | Delete
[2143] Fix | Delete
/**
[2144] Fix | Delete
* Transforms a slug into a CSS Custom Property.
[2145] Fix | Delete
*
[2146] Fix | Delete
* @since 5.9.0
[2147] Fix | Delete
*
[2148] Fix | Delete
* @param string $input String to replace.
[2149] Fix | Delete
* @param string $slug The slug value to use to generate the custom property.
[2150] Fix | Delete
* @return string The CSS Custom Property. Something along the lines of `--wp--preset--color--black`.
[2151] Fix | Delete
*/
[2152] Fix | Delete
protected static function replace_slug_in_string( $input, $slug ) {
[2153] Fix | Delete
return strtr( $input, array( '$slug' => $slug ) );
[2154] Fix | Delete
}
[2155] Fix | Delete
[2156] Fix | Delete
/**
[2157] Fix | Delete
* Given the block settings, extracts the CSS Custom Properties
[2158] Fix | Delete
* for the presets and adds them to the $declarations array
[2159] Fix | Delete
* following the format:
[2160] Fix | Delete
*
[2161] Fix | Delete
* array(
[2162] Fix | Delete
* 'name' => 'property_name',
[2163] Fix | Delete
* 'value' => 'property_value,
[2164] Fix | Delete
* )
[2165] Fix | Delete
*
[2166] Fix | Delete
* @since 5.8.0
[2167] Fix | Delete
* @since 5.9.0 Added the `$origins` parameter.
[2168] Fix | Delete
*
[2169] Fix | Delete
* @param array $settings Settings to process.
[2170] Fix | Delete
* @param string[] $origins List of origins to process.
[2171] Fix | Delete
* @return array The modified $declarations.
[2172] Fix | Delete
*/
[2173] Fix | Delete
protected static function compute_preset_vars( $settings, $origins ) {
[2174] Fix | Delete
$declarations = array();
[2175] Fix | Delete
foreach ( static::PRESETS_METADATA as $preset_metadata ) {
[2176] Fix | Delete
if ( empty( $preset_metadata['css_vars'] ) ) {
[2177] Fix | Delete
continue;
[2178] Fix | Delete
}
[2179] Fix | Delete
$values_by_slug = static::get_settings_values_by_slug( $settings, $preset_metadata, $origins );
[2180] Fix | Delete
foreach ( $values_by_slug as $slug => $value ) {
[2181] Fix | Delete
$declarations[] = array(
[2182] Fix | Delete
'name' => static::replace_slug_in_string( $preset_metadata['css_vars'], $slug ),
[2183] Fix | Delete
'value' => $value,
[2184] Fix | Delete
);
[2185] Fix | Delete
}
[2186] Fix | Delete
}
[2187] Fix | Delete
[2188] Fix | Delete
return $declarations;
[2189] Fix | Delete
}
[2190] Fix | Delete
[2191] Fix | Delete
/**
[2192] Fix | Delete
* Given an array of settings, extracts the CSS Custom Properties
[2193] Fix | Delete
* for the custom values and adds them to the $declarations
[2194] Fix | Delete
* array following the format:
[2195] Fix | Delete
*
[2196] Fix | Delete
* array(
[2197] Fix | Delete
* 'name' => 'property_name',
[2198] Fix | Delete
* 'value' => 'property_value,
[2199] Fix | Delete
* )
[2200] Fix | Delete
*
[2201] Fix | Delete
* @since 5.8.0
[2202] Fix | Delete
*
[2203] Fix | Delete
* @param array $settings Settings to process.
[2204] Fix | Delete
* @return array The modified $declarations.
[2205] Fix | Delete
*/
[2206] Fix | Delete
protected static function compute_theme_vars( $settings ) {
[2207] Fix | Delete
$declarations = array();
[2208] Fix | Delete
$custom_values = isset( $settings['custom'] ) ? $settings['custom'] : array();
[2209] Fix | Delete
$css_vars = static::flatten_tree( $custom_values );
[2210] Fix | Delete
foreach ( $css_vars as $key => $value ) {
[2211] Fix | Delete
$declarations[] = array(
[2212] Fix | Delete
'name' => '--wp--custom--' . $key,
[2213] Fix | Delete
'value' => $value,
[2214] Fix | Delete
);
[2215] Fix | Delete
}
[2216] Fix | Delete
[2217] Fix | Delete
return $declarations;
[2218] Fix | Delete
}
[2219] Fix | Delete
[2220] Fix | Delete
/**
[2221] Fix | Delete
* Given a tree, it creates a flattened one
[2222] Fix | Delete
* by merging the keys and binding the leaf values
[2223] Fix | Delete
* to the new keys.
[2224] Fix | Delete
*
[2225] Fix | Delete
* It also transforms camelCase names into kebab-case
[2226] Fix | Delete
* and substitutes '/' by '-'.
[2227] Fix | Delete
*
[2228] Fix | Delete
* This is thought to be useful to generate
[2229] Fix | Delete
* CSS Custom Properties from a tree,
[2230] Fix | Delete
* although there's nothing in the implementation
[2231] Fix | Delete
* of this function that requires that format.
[2232] Fix | Delete
*
[2233] Fix | Delete
* For example, assuming the given prefix is '--wp'
[2234] Fix | Delete
* and the token is '--', for this input tree:
[2235] Fix | Delete
*
[2236] Fix | Delete
* {
[2237] Fix | Delete
* 'some/property': 'value',
[2238] Fix | Delete
* 'nestedProperty': {
[2239] Fix | Delete
* 'sub-property': 'value'
[2240] Fix | Delete
* }
[2241] Fix | Delete
* }
[2242] Fix | Delete
*
[2243] Fix | Delete
* it'll return this output:
[2244] Fix | Delete
*
[2245] Fix | Delete
* {
[2246] Fix | Delete
* '--wp--some-property': 'value',
[2247] Fix | Delete
* '--wp--nested-property--sub-property': 'value'
[2248] Fix | Delete
* }
[2249] Fix | Delete
*
[2250] Fix | Delete
* @since 5.8.0
[2251] Fix | Delete
*
[2252] Fix | Delete
* @param array $tree Input tree to process.
[2253] Fix | Delete
* @param string $prefix Optional. Prefix to prepend to each variable. Default empty string.
[2254] Fix | Delete
* @param string $token Optional. Token to use between levels. Default '--'.
[2255] Fix | Delete
* @return array The flattened tree.
[2256] Fix | Delete
*/
[2257] Fix | Delete
protected static function flatten_tree( $tree, $prefix = '', $token = '--' ) {
[2258] Fix | Delete
$result = array();
[2259] Fix | Delete
foreach ( $tree as $property => $value ) {
[2260] Fix | Delete
$new_key = $prefix . str_replace(
[2261] Fix | Delete
'/',
[2262] Fix | Delete
'-',
[2263] Fix | Delete
strtolower( _wp_to_kebab_case( $property ) )
[2264] Fix | Delete
);
[2265] Fix | Delete
[2266] Fix | Delete
if ( is_array( $value ) ) {
[2267] Fix | Delete
$new_prefix = $new_key . $token;
[2268] Fix | Delete
$flattened_subtree = static::flatten_tree( $value, $new_prefix, $token );
[2269] Fix | Delete
foreach ( $flattened_subtree as $subtree_key => $subtree_value ) {
[2270] Fix | Delete
$result[ $subtree_key ] = $subtree_value;
[2271] Fix | Delete
}
[2272] Fix | Delete
} else {
[2273] Fix | Delete
$result[ $new_key ] = $value;
[2274] Fix | Delete
}
[2275] Fix | Delete
}
[2276] Fix | Delete
return $result;
[2277] Fix | Delete
}
[2278] Fix | Delete
[2279] Fix | Delete
/**
[2280] Fix | Delete
* Given a styles array, it extracts the style properties
[2281] Fix | Delete
* and adds them to the $declarations array following the format:
[2282] Fix | Delete
*
[2283] Fix | Delete
* array(
[2284] Fix | Delete
* 'name' => 'property_name',
[2285] Fix | Delete
* 'value' => 'property_value,
[2286] Fix | Delete
* )
[2287] Fix | Delete
*
[2288] Fix | Delete
* @since 5.8.0
[2289] Fix | Delete
* @since 5.9.0 Added the `$settings` and `$properties` parameters.
[2290] Fix | Delete
* @since 6.1.0 Added `$theme_json`, `$selector`, and `$use_root_padding` parameters.
[2291] Fix | Delete
* @since 6.5.0 Output a `min-height: unset` rule when `aspect-ratio` is set.
[2292] Fix | Delete
* @since 6.6.0 Pass current theme JSON settings to wp_get_typography_font_size_value(), and process background properties.
[2293] Fix | Delete
*
[2294] Fix | Delete
* @param array $styles Styles to process.
[2295] Fix | Delete
* @param array $settings Theme settings.
[2296] Fix | Delete
* @param array $properties Properties metadata.
[2297] Fix | Delete
* @param array $theme_json Theme JSON array.
[2298] Fix | Delete
* @param string $selector The style block selector.
[2299] Fix | Delete
* @param boolean $use_root_padding Whether to add custom properties at root level.
[2300] Fix | Delete
* @return array Returns the modified $declarations.
[2301] Fix | Delete
*/
[2302] Fix | Delete
protected static function compute_style_properties( $styles, $settings = array(), $properties = null, $theme_json = null, $selector = null, $use_root_padding = null ) {
[2303] Fix | Delete
if ( null === $properties ) {
[2304] Fix | Delete
$properties = static::PROPERTIES_METADATA;
[2305] Fix | Delete
}
[2306] Fix | Delete
[2307] Fix | Delete
$declarations = array();
[2308] Fix | Delete
if ( empty( $styles ) ) {
[2309] Fix | Delete
return $declarations;
[2310] Fix | Delete
}
[2311] Fix | Delete
[2312] Fix | Delete
$root_variable_duplicates = array();
[2313] Fix | Delete
[2314] Fix | Delete
foreach ( $properties as $css_property => $value_path ) {
[2315] Fix | Delete
$value = static::get_property_value( $styles, $value_path, $theme_json );
[2316] Fix | Delete
[2317] Fix | Delete
if ( str_starts_with( $css_property, '--wp--style--root--' ) && ( static::ROOT_BLOCK_SELECTOR !== $selector || ! $use_root_padding ) ) {
[2318] Fix | Delete
continue;
[2319] Fix | Delete
}
[2320] Fix | Delete
/*
[2321] Fix | Delete
* Root-level padding styles don't currently support strings with CSS shorthand values.
[2322] Fix | Delete
* This may change: https://github.com/WordPress/gutenberg/issues/40132.
[2323] Fix | Delete
*/
[2324] Fix | Delete
if ( '--wp--style--root--padding' === $css_property && is_string( $value ) ) {
[2325] Fix | Delete
continue;
[2326] Fix | Delete
}
[2327] Fix | Delete
[2328] Fix | Delete
if ( str_starts_with( $css_property, '--wp--style--root--' ) && $use_root_padding ) {
[2329] Fix | Delete
$root_variable_duplicates[] = substr( $css_property, strlen( '--wp--style--root--' ) );
[2330] Fix | Delete
}
[2331] Fix | Delete
[2332] Fix | Delete
/*
[2333] Fix | Delete
* Look up protected properties, keyed by value path.
[2334] Fix | Delete
* Skip protected properties that are explicitly set to `null`.
[2335] Fix | Delete
*/
[2336] Fix | Delete
if ( is_array( $value_path ) ) {
[2337] Fix | Delete
$path_string = implode( '.', $value_path );
[2338] Fix | Delete
if (
[2339] Fix | Delete
isset( static::PROTECTED_PROPERTIES[ $path_string ] ) &&
[2340] Fix | Delete
_wp_array_get( $settings, static::PROTECTED_PROPERTIES[ $path_string ], null ) === null
[2341] Fix | Delete
) {
[2342] Fix | Delete
continue;
[2343] Fix | Delete
}
[2344] Fix | Delete
}
[2345] Fix | Delete
[2346] Fix | Delete
// Processes background styles.
[2347] Fix | Delete
if ( 'background' === $value_path[0] && isset( $styles['background'] ) ) {
[2348] Fix | Delete
$background_styles = wp_style_engine_get_styles( array( 'background' => $styles['background'] ) );
[2349] Fix | Delete
$value = isset( $background_styles['declarations'][ $css_property ] ) ? $background_styles['declarations'][ $css_property ] : $value;
[2350] Fix | Delete
}
[2351] Fix | Delete
[2352] Fix | Delete
// Skip if empty and not "0" or value represents array of longhand values.
[2353] Fix | Delete
$has_missing_value = empty( $value ) && ! is_numeric( $value );
[2354] Fix | Delete
if ( $has_missing_value || is_array( $value ) ) {
[2355] Fix | Delete
continue;
[2356] Fix | Delete
}
[2357] Fix | Delete
[2358] Fix | Delete
// Calculates fluid typography rules where available.
[2359] Fix | Delete
if ( 'font-size' === $css_property ) {
[2360] Fix | Delete
/*
[2361] Fix | Delete
* wp_get_typography_font_size_value() will check
[2362] Fix | Delete
* if fluid typography has been activated and also
[2363] Fix | Delete
* whether the incoming value can be converted to a fluid value.
[2364] Fix | Delete
* Values that already have a clamp() function will not pass the test,
[2365] Fix | Delete
* and therefore the original $value will be returned.
[2366] Fix | Delete
* Pass the current theme_json settings to override any global settings.
[2367] Fix | Delete
*/
[2368] Fix | Delete
$value = wp_get_typography_font_size_value( array( 'size' => $value ), $settings );
[2369] Fix | Delete
}
[2370] Fix | Delete
[2371] Fix | Delete
if ( 'aspect-ratio' === $css_property ) {
[2372] Fix | Delete
// For aspect ratio to work, other dimensions rules must be unset.
[2373] Fix | Delete
// This ensures that a fixed height does not override the aspect ratio.
[2374] Fix | Delete
$declarations[] = array(
[2375] Fix | Delete
'name' => 'min-height',
[2376] Fix | Delete
'value' => 'unset',
[2377] Fix | Delete
);
[2378] Fix | Delete
}
[2379] Fix | Delete
[2380] Fix | Delete
$declarations[] = array(
[2381] Fix | Delete
'name' => $css_property,
[2382] Fix | Delete
'value' => $value,
[2383] Fix | Delete
);
[2384] Fix | Delete
}
[2385] Fix | Delete
[2386] Fix | Delete
// If a variable value is added to the root, the corresponding property should be removed.
[2387] Fix | Delete
foreach ( $root_variable_duplicates as $duplicate ) {
[2388] Fix | Delete
$discard = array_search( $duplicate, array_column( $declarations, 'name' ), true );
[2389] Fix | Delete
if ( is_numeric( $discard ) ) {
[2390] Fix | Delete
array_splice( $declarations, $discard, 1 );
[2391] Fix | Delete
}
[2392] Fix | Delete
}
[2393] Fix | Delete
[2394] Fix | Delete
return $declarations;
[2395] Fix | Delete
}
[2396] Fix | Delete
[2397] Fix | Delete
/**
[2398] Fix | Delete
* Returns the style property for the given path.
[2399] Fix | Delete
*
[2400] Fix | Delete
* It also converts references to a path to the value
[2401] Fix | Delete
* stored at that location, e.g.
[2402] Fix | Delete
* { "ref": "style.color.background" } => "#fff".
[2403] Fix | Delete
*
[2404] Fix | Delete
* @since 5.8.0
[2405] Fix | Delete
* @since 5.9.0 Added support for values of array type, which are returned as is.
[2406] Fix | Delete
* @since 6.1.0 Added the `$theme_json` parameter.
[2407] Fix | Delete
* @since 6.3.0 It no longer converts the internal format "var:preset|color|secondary"
[2408] Fix | Delete
* to the standard form "--wp--preset--color--secondary".
[2409] Fix | Delete
* This is already done by the sanitize method,
[2410] Fix | Delete
* so every property will be in the standard form.
[2411] Fix | Delete
*
[2412] Fix | Delete
* @param array $styles Styles subtree.
[2413] Fix | Delete
* @param array $path Which property to process.
[2414] Fix | Delete
* @param array $theme_json Theme JSON array.
[2415] Fix | Delete
* @return string|array Style property value.
[2416] Fix | Delete
*/
[2417] Fix | Delete
protected static function get_property_value( $styles, $path, $theme_json = null ) {
[2418] Fix | Delete
$value = _wp_array_get( $styles, $path, '' );
[2419] Fix | Delete
[2420] Fix | Delete
if ( '' === $value || null === $value ) {
[2421] Fix | Delete
// No need to process the value further.
[2422] Fix | Delete
return '';
[2423] Fix | Delete
}
[2424] Fix | Delete
[2425] Fix | Delete
/*
[2426] Fix | Delete
* This converts references to a path to the value at that path
[2427] Fix | Delete
* where the values is an array with a "ref" key, pointing to a path.
[2428] Fix | Delete
* For example: { "ref": "style.color.background" } => "#fff".
[2429] Fix | Delete
*/
[2430] Fix | Delete
if ( is_array( $value ) && isset( $value['ref'] ) ) {
[2431] Fix | Delete
$value_path = explode( '.', $value['ref'] );
[2432] Fix | Delete
$ref_value = _wp_array_get( $theme_json, $value_path );
[2433] Fix | Delete
// Only use the ref value if we find anything.
[2434] Fix | Delete
if ( ! empty( $ref_value ) && is_string( $ref_value ) ) {
[2435] Fix | Delete
$value = $ref_value;
[2436] Fix | Delete
}
[2437] Fix | Delete
[2438] Fix | Delete
if ( is_array( $ref_value ) && isset( $ref_value['ref'] ) ) {
[2439] Fix | Delete
$path_string = json_encode( $path );
[2440] Fix | Delete
$ref_value_string = json_encode( $ref_value );
[2441] Fix | Delete
_doing_it_wrong(
[2442] Fix | Delete
'get_property_value',
[2443] Fix | Delete
sprintf(
[2444] Fix | Delete
/* translators: 1: theme.json, 2: Value name, 3: Value path, 4: Another value name. */
[2445] Fix | Delete
__( 'Your %1$s file uses a dynamic value (%2$s) for the path at %3$s. However, the value at %3$s is also a dynamic value (pointing to %4$s) and pointing to another dynamic value is not supported. Please update %3$s to point directly to %4$s.' ),
[2446] Fix | Delete
'theme.json',
[2447] Fix | Delete
$ref_value_string,
[2448] Fix | Delete
$path_string,
[2449] Fix | Delete
$ref_value['ref']
[2450] Fix | Delete
),
[2451] Fix | Delete
'6.1.0'
[2452] Fix | Delete
);
[2453] Fix | Delete
}
[2454] Fix | Delete
}
[2455] Fix | Delete
[2456] Fix | Delete
if ( is_array( $value ) ) {
[2457] Fix | Delete
return $value;
[2458] Fix | Delete
}
[2459] Fix | Delete
[2460] Fix | Delete
return $value;
[2461] Fix | Delete
}
[2462] Fix | Delete
[2463] Fix | Delete
/**
[2464] Fix | Delete
* Builds metadata for the setting nodes, which returns in the form of:
[2465] Fix | Delete
*
[2466] Fix | Delete
* [
[2467] Fix | Delete
* [
[2468] Fix | Delete
* 'path' => ['path', 'to', 'some', 'node' ],
[2469] Fix | Delete
* 'selector' => 'CSS selector for some node'
[2470] Fix | Delete
* ],
[2471] Fix | Delete
* [
[2472] Fix | Delete
* 'path' => [ 'path', 'to', 'other', 'node' ],
[2473] Fix | Delete
* 'selector' => 'CSS selector for other node'
[2474] Fix | Delete
* ],
[2475] Fix | Delete
* ]
[2476] Fix | Delete
*
[2477] Fix | Delete
* @since 5.8.0
[2478] Fix | Delete
*
[2479] Fix | Delete
* @param array $theme_json The tree to extract setting nodes from.
[2480] Fix | Delete
* @param array $selectors List of selectors per block.
[2481] Fix | Delete
* @return array An array of setting nodes metadata.
[2482] Fix | Delete
*/
[2483] Fix | Delete
protected static function get_setting_nodes( $theme_json, $selectors = array() ) {
[2484] Fix | Delete
$nodes = array();
[2485] Fix | Delete
if ( ! isset( $theme_json['settings'] ) ) {
[2486] Fix | Delete
return $nodes;
[2487] Fix | Delete
}
[2488] Fix | Delete
[2489] Fix | Delete
// Top-level.
[2490] Fix | Delete
$nodes[] = array(
[2491] Fix | Delete
'path' => array( 'settings' ),
[2492] Fix | Delete
'selector' => static::ROOT_CSS_PROPERTIES_SELECTOR,
[2493] Fix | Delete
);
[2494] Fix | Delete
[2495] Fix | Delete
// Calculate paths for blocks.
[2496] Fix | Delete
if ( ! isset( $theme_json['settings']['blocks'] ) ) {
[2497] Fix | Delete
return $nodes;
[2498] Fix | Delete
}
[2499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function