declarations' => array( * 'color' => 'gray', * 'width' => '3em', * ), * ), * ); * * $css = wp_style_engine_get_stylesheet_from_css_rules( $css_rules ); * * Returns: * * .elephant-are-cool{color:gray;width:3em} * * @since 6.1.0 * * @param array $css_rules { * Required. A collection of CSS rules. * * @type array ...$0 { * @type string $selector A CSS selector. * @type string[] $declarations An associative array of CSS definitions, * e.g. `array( "$property" => "$value", "$property" => "$value" )`. * } * } * @param array $options { * Optional. An array of options. Default empty array. * * @type string|null $context An identifier describing the origin of the style object, * e.g. 'block-supports' or 'global-styles'. Default 'block-supports'. * When set, the style engine will attempt to store the CSS rules. * @type bool $optimize Whether to optimize the CSS output, e.g. combine rules. * Default false. * @type bool $prettify Whether to add new lines and indents to output. * Defaults to whether the `SCRIPT_DEBUG` constant is defined. * } * @return string A string of compiled CSS declarations, or empty string. */ function wp_style_engine_get_stylesheet_from_css_rules( $css_rules, $options = array() ) { if ( empty( $css_rules ) ) { return ''; } $options = wp_parse_args( $options, array( 'context' => null, ) ); $css_rule_objects = array(); foreach ( $css_rules as $css_rule ) { if ( empty( $css_rule['selector'] ) || empty( $css_rule['declarations'] ) || ! is_array( $css_rule['declarations'] ) ) { continue; } if ( ! empty( $options['context'] ) ) { WP_Style_Engine::store_css_rule( $options['context'], $css_rule['selector'], $css_rule['declarations'] ); } $css_rule_objects[] = new WP_Style_Engine_CSS_Rule( $css_rule['selector'], $css_rule['declarations'] ); } if ( empty( $css_rule_objects ) ) { return ''; } return WP_Style_Engine::compile_stylesheet_from_css_rules( $css_rule_objects, $options ); } /** * Returns compiled CSS from a store, if found. * * @since 6.1.0 * * @param string $context A valid context name, corresponding to an existing store key. * @param array $options { * Optional. An array of options. Default empty array. * * @type bool $optimize Whether to optimize the CSS output, e.g. combine rules. * Default false. * @type bool $prettify Whether to add new lines and indents to output. * Defaults to whether the `SCRIPT_DEBUG` constant is defined. * } * @return string A compiled CSS string. */ function wp_style_engine_get_stylesheet_from_context( $context, $options = array() ) { return WP_Style_Engine::compile_stylesheet_from_css_rules( WP_Style_Engine::get_store( $context )->get_all_rules(), $options ); } der_addresses SET state=%s WHERE country=%s AND state=%s LIMIT %d", $new_state, $country_code, $old_state, $limit ); $wpdb->query( $update_query ); } // We need to split the update query for the postmeta table in two, select + update, // because MySQL doesn't support the LIMIT keyword in multi-table UPDATE statements. $select_meta_ids_query = $wpdb->prepare( "SELECT meta_id FROM {$wpdb->prefix}postmeta, (SELECT DISTINCT post_id FROM {$wpdb->prefix}postmeta WHERE (meta_key = '_billing_country' OR meta_key='_shipping_country') AND meta_value=%s) AS states_in_country WHERE (meta_key='_billing_state' OR meta_key='_shipping_state') AND meta_value=%s AND {$wpdb->postmeta}.post_id = states_in_country.post_id LIMIT %d", $country_code, $old_state, $limit ); $meta_ids = $wpdb->get_results( $select_meta_ids_query, ARRAY_A ); if ( ! empty( $meta_ids ) ) { $meta_ids = ArrayUtil::select( $meta_ids, 'meta_id' ); $meta_ids_as_comma_separated = '(' . join( ',', $meta_ids ) . ')'; $update_query = $wpdb->prepare( "UPDATE {$wpdb->prefix}postmeta SET meta_value=%s WHERE meta_id IN {$meta_ids_as_comma_separated}", $new_state ); $wpdb->query( $update_query ); } } $states_as_comma_separated = "('" . join( "','", array_keys( $old_to_new_states_mapping ) ) . "')"; $posts_exist_query = $wpdb->prepare( " SELECT 1 FROM {$wpdb->prefix}postmeta WHERE (meta_key='_billing_state' OR meta_key='_shipping_state') AND meta_value IN {$states_as_comma_separated} AND post_id IN ( SELECT post_id FROM {$wpdb->prefix}postmeta WHERE (meta_key = '_billing_country' OR meta_key='_shipping_country') AND meta_value=%s )", $country_code ); if ( $cot_exists ) { $more_exist_query = $wpdb->prepare( " SELECT EXISTS( SELECT 1 FROM {$wpdb->prefix}wc_order_addresses WHERE country=%s AND state IN {$states_as_comma_separated} ) OR EXISTS ( {$posts_exist_query} )", $country_code ); } else { $more_exist_query = "SELECT EXISTS ({$posts_exist_query})"; } return (int) ( $wpdb->get_var( $more_exist_query ) ) !== 0; // phpcs:enable WordPress.DB.PreparedSQL.NotPrepared, WordPress.DB.PreparedSQL.InterpolatedNotPrepared } /** * Migrate state codes in the tax rates table. * * @param string $country_code The country that has the states for which the migration is needed. * @param array $old_to_new_states_mapping An associative array where keys are the old state codes and values are the new state codes. * @return void */ private static function migrate_country_states_for_tax_rates( string $country_code, array $old_to_new_states_mapping ): void { global $wpdb; foreach ( $old_to_new_states_mapping as $old_state_code => $new_state_code ) { $wpdb->query( $wpdb->prepare( "UPDATE {$wpdb->prefix}woocommerce_tax_rates SET tax_rate_state=%s WHERE tax_rate_country=%s AND tax_rate_state=%s", $new_state_code, $country_code, $old_state_code ) ); } } }