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
/home/sportsfe.../httpdocs/wp-conte.../plugins/advanced.../classes
File: utils.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* Class Advanced_Ads_Utils
[2] Fix | Delete
*/
[3] Fix | Delete
class Advanced_Ads_Utils {
[4] Fix | Delete
/**
[5] Fix | Delete
* Merges multiple arrays, recursively, and returns the merged array.
[6] Fix | Delete
*
[7] Fix | Delete
* This function is similar to PHP's array_merge_recursive() function, but it
[8] Fix | Delete
* handles non-array values differently. When merging values that are not both
[9] Fix | Delete
* arrays, the latter value replaces the former rather than merging with it.
[10] Fix | Delete
*
[11] Fix | Delete
* Example:
[12] Fix | Delete
* $link_options_1 = array( 'fragment' => 'x', 'class' => array( 'a', 'b' ) );
[13] Fix | Delete
* $link_options_2 = array( 'fragment' => 'y', 'class' => array( 'c', 'd' ) );
[14] Fix | Delete
* // This results in array( 'fragment' => 'y', 'class' => array( 'a', 'b', 'c', 'd' ) ).
[15] Fix | Delete
*
[16] Fix | Delete
* @param array $arrays An arrays of arrays to merge.
[17] Fix | Delete
* @param bool $preserve_integer_keys (optional) If given, integer keys will be preserved and merged instead of appended.
[18] Fix | Delete
* @return array The merged array.
[19] Fix | Delete
* @copyright Copyright 2001 - 2013 Drupal contributors. License: GPL-2.0+. Drupal is a registered trademark of Dries Buytaert.
[20] Fix | Delete
*/
[21] Fix | Delete
public static function merge_deep_array( array $arrays, $preserve_integer_keys = false ) {
[22] Fix | Delete
$result = [];
[23] Fix | Delete
foreach ( $arrays as $array ) {
[24] Fix | Delete
if ( ! is_array( $array ) ) {
[25] Fix | Delete
continue; }
[26] Fix | Delete
[27] Fix | Delete
foreach ( $array as $key => $value ) {
[28] Fix | Delete
// Renumber integer keys as array_merge_recursive() does unless
[29] Fix | Delete
// $preserve_integer_keys is set to TRUE. Note that PHP automatically
[30] Fix | Delete
// converts array keys that are integer strings (e.g., '1') to integers.
[31] Fix | Delete
if ( is_integer( $key ) && ! $preserve_integer_keys ) {
[32] Fix | Delete
$result[] = $value;
[33] Fix | Delete
} elseif ( isset( $result[ $key ] ) && is_array( $result[ $key ] ) && is_array( $value ) ) {
[34] Fix | Delete
// recurse when both values are arrays.
[35] Fix | Delete
$result[ $key ] = self::merge_deep_array( [ $result[ $key ], $value ], $preserve_integer_keys );
[36] Fix | Delete
} else {
[37] Fix | Delete
// otherwise, use the latter value, overriding any previous value.
[38] Fix | Delete
$result[ $key ] = $value;
[39] Fix | Delete
}
[40] Fix | Delete
}
[41] Fix | Delete
}
[42] Fix | Delete
return $result;
[43] Fix | Delete
}
[44] Fix | Delete
[45] Fix | Delete
/**
[46] Fix | Delete
* Convert array of html attributes to string.
[47] Fix | Delete
*
[48] Fix | Delete
* @param array $data attributes.
[49] Fix | Delete
* @return string
[50] Fix | Delete
* @since untagged
[51] Fix | Delete
*/
[52] Fix | Delete
public static function build_html_attributes( $data ) {
[53] Fix | Delete
$result = '';
[54] Fix | Delete
foreach ( $data as $_html_attr => $_values ) {
[55] Fix | Delete
if ( 'style' === $_html_attr ) {
[56] Fix | Delete
$_style_values_string = '';
[57] Fix | Delete
foreach ( $_values as $_style_attr => $_style_values ) {
[58] Fix | Delete
if ( is_array( $_style_values ) ) {
[59] Fix | Delete
$_style_values_string .= $_style_attr . ': ' . implode( ' ', array_filter( $_style_values ) ) . '; ';
[60] Fix | Delete
} else {
[61] Fix | Delete
$_style_values_string .= $_style_attr . ': ' . $_style_values . '; ';
[62] Fix | Delete
}
[63] Fix | Delete
}
[64] Fix | Delete
$result .= " style=\"$_style_values_string\"";
[65] Fix | Delete
} else {
[66] Fix | Delete
if ( is_array( $_values ) ) {
[67] Fix | Delete
$_values_string = esc_attr( implode( ' ', array_filter( $_values ) ) );
[68] Fix | Delete
} else {
[69] Fix | Delete
$_values_string = esc_attr( $_values );
[70] Fix | Delete
}
[71] Fix | Delete
if ( $_values_string !== '' ) {
[72] Fix | Delete
$result .= " $_html_attr=\"$_values_string\"";
[73] Fix | Delete
}
[74] Fix | Delete
}
[75] Fix | Delete
}
[76] Fix | Delete
return $result;
[77] Fix | Delete
}
[78] Fix | Delete
[79] Fix | Delete
/**
[80] Fix | Delete
* Get inline asset.
[81] Fix | Delete
*
[82] Fix | Delete
* @param string $content existing content.
[83] Fix | Delete
* @return string $content
[84] Fix | Delete
*/
[85] Fix | Delete
public static function get_inline_asset( $content ) {
[86] Fix | Delete
// WP Fastest Cache Premium: "Render Blocking Js" feature.
[87] Fix | Delete
$content = ltrim( $content );
[88] Fix | Delete
if ( class_exists( 'WpFastestCache', false )
[89] Fix | Delete
&& '<script' === substr( $content, 0, 7 ) ) {
[90] Fix | Delete
$content = substr_replace( $content, '<script data-wpfc-render="false"', 0, 7 );
[91] Fix | Delete
}
[92] Fix | Delete
[93] Fix | Delete
if ( Advanced_Ads_Checks::active_autoptimize() || Advanced_Ads_Checks::active_wp_rocket() ) {
[94] Fix | Delete
return '<!--noptimize-->' . $content . '<!--/noptimize-->';
[95] Fix | Delete
}
[96] Fix | Delete
return $content;
[97] Fix | Delete
}
[98] Fix | Delete
[99] Fix | Delete
/**
[100] Fix | Delete
* Get nested ads of an ad or a group.
[101] Fix | Delete
*
[102] Fix | Delete
* @param string $id Id.
[103] Fix | Delete
* @param string $type Type (placement, ad or group).
[104] Fix | Delete
* @return array of Advanced_Ads_Ad objects.
[105] Fix | Delete
*/
[106] Fix | Delete
public static function get_nested_ads( $id, $type ) {
[107] Fix | Delete
$result = [];
[108] Fix | Delete
[109] Fix | Delete
switch ( $type ) {
[110] Fix | Delete
case 'placement':
[111] Fix | Delete
$placements = Advanced_Ads::get_ad_placements_array();
[112] Fix | Delete
if ( isset( $placements[ $id ]['item'] ) ) {
[113] Fix | Delete
$item = explode( '_', $placements[ $id ]['item'] );
[114] Fix | Delete
if ( isset( $item[1] ) ) {
[115] Fix | Delete
return self::get_nested_ads( $item[1], $item[0] );
[116] Fix | Delete
}
[117] Fix | Delete
}
[118] Fix | Delete
case 'ad':
[119] Fix | Delete
$ad = \Advanced_Ads\Ad_Repository::get( $id );
[120] Fix | Delete
$result[] = $ad;
[121] Fix | Delete
if ( 'group' === $ad->type && ! empty( $ad->output['group_id'] ) ) {
[122] Fix | Delete
$result = array_merge( $result, self::get_nested_ads( $ad->output['group_id'], 'group' ) );
[123] Fix | Delete
}
[124] Fix | Delete
break;
[125] Fix | Delete
case 'group':
[126] Fix | Delete
$group = new Advanced_Ads_Group( $id );
[127] Fix | Delete
$ads = $group->get_all_ads();
[128] Fix | Delete
foreach ( $ads as $ad ) {
[129] Fix | Delete
$result = array_merge( $result, self::get_nested_ads( $ad->ID, 'ad' ) );
[130] Fix | Delete
}
[131] Fix | Delete
break;
[132] Fix | Delete
}
[133] Fix | Delete
return $result;
[134] Fix | Delete
}
[135] Fix | Delete
[136] Fix | Delete
/**
[137] Fix | Delete
* Maybe translate a capability to a set of roles.
[138] Fix | Delete
*
[139] Fix | Delete
* @param string/array $roles_or_caps A set of roles or capabilities.
[140] Fix | Delete
* @return array $roles A list of roles.
[141] Fix | Delete
*/
[142] Fix | Delete
public static function maybe_translate_cap_to_role( $roles_or_caps ) {
[143] Fix | Delete
global $wp_roles;
[144] Fix | Delete
[145] Fix | Delete
$roles_or_caps = (array) $roles_or_caps;
[146] Fix | Delete
$roles = [];
[147] Fix | Delete
[148] Fix | Delete
foreach ( $roles_or_caps as $cap ) {
[149] Fix | Delete
if ( $wp_roles->is_role( $cap ) ) {
[150] Fix | Delete
$roles[] = $cap;
[151] Fix | Delete
continue;
[152] Fix | Delete
}
[153] Fix | Delete
[154] Fix | Delete
foreach ( $wp_roles->roles as $id => $role ) {
[155] Fix | Delete
if ( isset( $role['capabilities'][ $cap ] ) ) {
[156] Fix | Delete
$roles[] = $id;
[157] Fix | Delete
}
[158] Fix | Delete
}
[159] Fix | Delete
}
[160] Fix | Delete
[161] Fix | Delete
return array_unique( $roles );
[162] Fix | Delete
}
[163] Fix | Delete
[164] Fix | Delete
/**
[165] Fix | Delete
* Check if the page is loaded in an iframe.
[166] Fix | Delete
*
[167] Fix | Delete
* @return bool
[168] Fix | Delete
*/
[169] Fix | Delete
public static function is_iframe() {
[170] Fix | Delete
if ( is_customize_preview() ) {
[171] Fix | Delete
return true;
[172] Fix | Delete
}
[173] Fix | Delete
[174] Fix | Delete
if ( self::is_elementor_preview_or_edit() ) {
[175] Fix | Delete
return true;
[176] Fix | Delete
}
[177] Fix | Delete
[178] Fix | Delete
return false;
[179] Fix | Delete
}
[180] Fix | Delete
[181] Fix | Delete
/**
[182] Fix | Delete
* Check if the Elementor preview mode is used.
[183] Fix | Delete
*
[184] Fix | Delete
* @deprecated
[185] Fix | Delete
*
[186] Fix | Delete
* @return bool
[187] Fix | Delete
*/
[188] Fix | Delete
private static function is_elementor_preview_or_edit() {
[189] Fix | Delete
if ( class_exists( '\Elementor\Plugin' ) ) {
[190] Fix | Delete
try {
[191] Fix | Delete
$refl_plugin = new ReflectionClass( '\Elementor\Plugin' );
[192] Fix | Delete
[193] Fix | Delete
if ( $refl_plugin->hasMethod( 'instance' ) ) {
[194] Fix | Delete
$refl_instance_method = $refl_plugin->getMethod( 'instance' );
[195] Fix | Delete
[196] Fix | Delete
if ( $refl_instance_method->isPublic() && $refl_instance_method->isStatic() ) {
[197] Fix | Delete
[198] Fix | Delete
if ( class_exists( '\Elementor\Preview' ) && $refl_plugin->hasProperty( 'preview' ) ) {
[199] Fix | Delete
$preview_property = new ReflectionProperty( '\Elementor\Plugin', 'preview' );
[200] Fix | Delete
[201] Fix | Delete
if ( $preview_property->isPublic() && ! $preview_property->isStatic() ) {
[202] Fix | Delete
if ( method_exists( '\Elementor\Preview', 'is_preview_mode' )
[203] Fix | Delete
&& \Elementor\Plugin::$instance->preview->is_preview_mode() ) {
[204] Fix | Delete
return true;
[205] Fix | Delete
}
[206] Fix | Delete
}
[207] Fix | Delete
}
[208] Fix | Delete
[209] Fix | Delete
if ( class_exists( '\Elementor\Editor' ) && $refl_plugin->hasProperty( 'editor' ) ) {
[210] Fix | Delete
$editor_property = new ReflectionProperty( '\Elementor\Plugin', 'editor' );
[211] Fix | Delete
[212] Fix | Delete
if ( $editor_property->isPublic() && ! $editor_property->isStatic() ) {
[213] Fix | Delete
if ( method_exists( '\Elementor\Editor', 'is_edit_mode' )
[214] Fix | Delete
&& \Elementor\Plugin::$instance->editor->is_edit_mode() ) {
[215] Fix | Delete
return true;
[216] Fix | Delete
}
[217] Fix | Delete
}
[218] Fix | Delete
}
[219] Fix | Delete
}
[220] Fix | Delete
}
[221] Fix | Delete
} catch ( Exception $e ) {
[222] Fix | Delete
// not much we can do here.
[223] Fix | Delete
}
[224] Fix | Delete
}
[225] Fix | Delete
return false;
[226] Fix | Delete
}
[227] Fix | Delete
[228] Fix | Delete
/**
[229] Fix | Delete
* Get DateTimeZone object for the WP installation
[230] Fix | Delete
*
[231] Fix | Delete
* @return DateTimeZone DateTimeZone object.
[232] Fix | Delete
*/
[233] Fix | Delete
public static function get_wp_timezone() {
[234] Fix | Delete
static $date_time_zone;
[235] Fix | Delete
if ( ! is_null( $date_time_zone ) ) {
[236] Fix | Delete
return $date_time_zone;
[237] Fix | Delete
}
[238] Fix | Delete
[239] Fix | Delete
// wp_timezone() is available since WordPress 5.3.0.
[240] Fix | Delete
if ( function_exists( 'wp_timezone' ) ) {
[241] Fix | Delete
$date_time_zone = wp_timezone();
[242] Fix | Delete
[243] Fix | Delete
return $date_time_zone;
[244] Fix | Delete
}
[245] Fix | Delete
[246] Fix | Delete
$time_zone = get_option( 'timezone_string' );
[247] Fix | Delete
// no timezone string but gmt offset.
[248] Fix | Delete
if ( empty( $time_zone ) ) {
[249] Fix | Delete
$time_zone = get_option( 'gmt_offset' );
[250] Fix | Delete
// gmt + x but not prefixed with a "+".
[251] Fix | Delete
if ( preg_match( '/^\d/', $time_zone ) ) {
[252] Fix | Delete
$time_zone = '+' . $time_zone;
[253] Fix | Delete
}
[254] Fix | Delete
}
[255] Fix | Delete
[256] Fix | Delete
$date_time_zone = new DateTimeZone( $time_zone );
[257] Fix | Delete
[258] Fix | Delete
return $date_time_zone;
[259] Fix | Delete
}
[260] Fix | Delete
[261] Fix | Delete
/**
[262] Fix | Delete
* Get literal expression of timezone.
[263] Fix | Delete
*
[264] Fix | Delete
* @return string Human readable timezone name.
[265] Fix | Delete
*/
[266] Fix | Delete
public static function get_timezone_name() {
[267] Fix | Delete
$time_zone = self::get_wp_timezone()->getName();
[268] Fix | Delete
if ( $time_zone === 'UTC' ) {
[269] Fix | Delete
return 'UTC+0';
[270] Fix | Delete
}
[271] Fix | Delete
[272] Fix | Delete
if ( strpos( $time_zone, '+' ) === 0 || strpos( $time_zone, '-' ) === 0 ) {
[273] Fix | Delete
return 'UTC' . $time_zone;
[274] Fix | Delete
}
[275] Fix | Delete
[276] Fix | Delete
// translators: time zone name.
[277] Fix | Delete
return sprintf( __( 'time of %s', 'advanced-ads' ), $time_zone );
[278] Fix | Delete
}
[279] Fix | Delete
}
[280] Fix | Delete
[281] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function