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/clone/wp-conte.../plugins/popup-ma.../classes
File: Previews.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* Manage popup prevews.
[2] Fix | Delete
*
[3] Fix | Delete
* @package PopupMaker
[4] Fix | Delete
*/
[5] Fix | Delete
[6] Fix | Delete
if ( ! defined( 'ABSPATH' ) ) {
[7] Fix | Delete
exit;
[8] Fix | Delete
}
[9] Fix | Delete
[10] Fix | Delete
/**
[11] Fix | Delete
* Class PUM_Previews
[12] Fix | Delete
*
[13] Fix | Delete
* This class sets up the necessary changes to allow admins & editors to preview popups on the front end.
[14] Fix | Delete
*/
[15] Fix | Delete
class PUM_Previews {
[16] Fix | Delete
[17] Fix | Delete
/**
[18] Fix | Delete
* Initiator method.
[19] Fix | Delete
*/
[20] Fix | Delete
public static function init() {
[21] Fix | Delete
add_action( 'template_redirect', [ __CLASS__, 'force_load_preview' ] );
[22] Fix | Delete
add_filter( 'pum_popup_is_loadable', [ __CLASS__, 'is_loadable' ], 1000, 2 );
[23] Fix | Delete
add_filter( 'pum_popup_data_attr', [ __CLASS__, 'data_attr' ], 1000, 2 );
[24] Fix | Delete
add_filter( 'pum_popup_get_public_settings', [ __CLASS__, 'get_public_settings' ], 1000, 2 );
[25] Fix | Delete
}
[26] Fix | Delete
[27] Fix | Delete
/**
[28] Fix | Delete
* Get popup id for previewing.
[29] Fix | Delete
*
[30] Fix | Delete
* @return false|int
[31] Fix | Delete
*/
[32] Fix | Delete
public static function get_popup_preview() {
[33] Fix | Delete
static $preview_id;
[34] Fix | Delete
[35] Fix | Delete
if ( isset( $preview_id ) ) {
[36] Fix | Delete
return $preview_id;
[37] Fix | Delete
}
[38] Fix | Delete
[39] Fix | Delete
$preview_id = false;
[40] Fix | Delete
[41] Fix | Delete
if (
[42] Fix | Delete
! isset( $_GET['popup_preview'] ) ||
[43] Fix | Delete
! isset( $_GET['popup'] ) ||
[44] Fix | Delete
// Overridden as wp_verify_nonce is already safe: https://github.com/WordPress/WordPress-Coding-Standards/issues/869#issuecomment-611782416.
[45] Fix | Delete
// phpcs:ignore WordPress.Security.ValidatedSanitizedInput.MissingUnslash, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized
[46] Fix | Delete
! wp_verify_nonce( $_GET['popup_preview'], 'popup-preview' )
[47] Fix | Delete
) {
[48] Fix | Delete
return false;
[49] Fix | Delete
}
[50] Fix | Delete
[51] Fix | Delete
$popup_id = sanitize_text_field( wp_unslash( $_GET['popup'] ) );
[52] Fix | Delete
[53] Fix | Delete
if ( is_numeric( $_GET['popup'] ) && absint( $_GET['popup'] ) > 0 ) {
[54] Fix | Delete
$preview_id = absint( $_GET['popup'] );
[55] Fix | Delete
} else {
[56] Fix | Delete
$post = get_page_by_path( $popup_id, OBJECT, 'popup' );
[57] Fix | Delete
$preview_id = $post->ID;
[58] Fix | Delete
}
[59] Fix | Delete
[60] Fix | Delete
return $preview_id;
[61] Fix | Delete
[62] Fix | Delete
}
[63] Fix | Delete
[64] Fix | Delete
/**
[65] Fix | Delete
* Sets the Popup Post Type public arg to true for content editors.
[66] Fix | Delete
*
[67] Fix | Delete
* This enables them to use the built in preview links.
[68] Fix | Delete
*
[69] Fix | Delete
* @param int $popup_id Popup ID.
[70] Fix | Delete
*
[71] Fix | Delete
* @return bool
[72] Fix | Delete
*/
[73] Fix | Delete
private static function is_previewing_popup( $popup_id = 0 ) {
[74] Fix | Delete
if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
[75] Fix | Delete
return false;
[76] Fix | Delete
}
[77] Fix | Delete
[78] Fix | Delete
$preview_id = static::get_popup_preview();
[79] Fix | Delete
[80] Fix | Delete
return $popup_id === $preview_id && current_user_can( 'edit_post', $preview_id );
[81] Fix | Delete
}
[82] Fix | Delete
[83] Fix | Delete
/**
[84] Fix | Delete
* Force popup to load no matter its status if its supposed to be previewed.
[85] Fix | Delete
*/
[86] Fix | Delete
public static function force_load_preview() {
[87] Fix | Delete
$preview_id = static::get_popup_preview();
[88] Fix | Delete
[89] Fix | Delete
$popup = pum_get_popup( $preview_id );
[90] Fix | Delete
[91] Fix | Delete
if ( $popup->is_valid() && $preview_id === $popup->ID ) {
[92] Fix | Delete
PUM_Site_Popups::preload_popup( $popup );
[93] Fix | Delete
}
[94] Fix | Delete
}
[95] Fix | Delete
[96] Fix | Delete
/**
[97] Fix | Delete
* For popup previews this will force only the correct popup to load.
[98] Fix | Delete
*
[99] Fix | Delete
* @param bool $loadable Is popup loadable.
[100] Fix | Delete
* @param int $popup_id Popup ID.
[101] Fix | Delete
*
[102] Fix | Delete
* @return bool
[103] Fix | Delete
*/
[104] Fix | Delete
public static function is_loadable( $loadable, $popup_id ) {
[105] Fix | Delete
return self::is_previewing_popup( $popup_id ) ? true : $loadable;
[106] Fix | Delete
}
[107] Fix | Delete
[108] Fix | Delete
/**
[109] Fix | Delete
* On popup previews add an admin debug trigger.
[110] Fix | Delete
*
[111] Fix | Delete
* @deprecated 1.16.10 Use get_public_settings instead.
[112] Fix | Delete
*
[113] Fix | Delete
* @param array $data_attr Array of popup data attributes.
[114] Fix | Delete
* @param int $popup_id Popup ID.
[115] Fix | Delete
*
[116] Fix | Delete
* @return mixed
[117] Fix | Delete
*/
[118] Fix | Delete
public static function data_attr( $data_attr, $popup_id ) {
[119] Fix | Delete
if ( ! self::is_previewing_popup( $popup_id ) ) {
[120] Fix | Delete
return $data_attr;
[121] Fix | Delete
}
[122] Fix | Delete
[123] Fix | Delete
$data_attr['triggers'] = [
[124] Fix | Delete
[
[125] Fix | Delete
'type' => 'admin_debug',
[126] Fix | Delete
],
[127] Fix | Delete
];
[128] Fix | Delete
[129] Fix | Delete
return $data_attr;
[130] Fix | Delete
}
[131] Fix | Delete
[132] Fix | Delete
/**
[133] Fix | Delete
* On popup previews add an admin debug trigger.
[134] Fix | Delete
*
[135] Fix | Delete
* @param array $settings Array of settigs.
[136] Fix | Delete
* @param PUM_Model_Popup $popup Popup model object.
[137] Fix | Delete
*
[138] Fix | Delete
* @return array
[139] Fix | Delete
*/
[140] Fix | Delete
public static function get_public_settings( $settings, $popup ) {
[141] Fix | Delete
if ( ! self::is_previewing_popup( $popup->ID ) ) {
[142] Fix | Delete
return $settings;
[143] Fix | Delete
}
[144] Fix | Delete
[145] Fix | Delete
$settings['triggers'] = [
[146] Fix | Delete
[
[147] Fix | Delete
'type' => 'admin_debug',
[148] Fix | Delete
],
[149] Fix | Delete
];
[150] Fix | Delete
[151] Fix | Delete
return $settings;
[152] Fix | Delete
}
[153] Fix | Delete
}
[154] Fix | Delete
[155] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function