Current Path : /storage/v11800/andslite-new/public_html/wp-content/plugins/popup-maker/classes/Admin/ |
Linux v11800 5.3.0-1023-aws #25~18.04.1-Ubuntu SMP Fri Jun 5 15:19:18 UTC 2020 aarch64
|
Current File : /storage/v11800/andslite-new/public_html/wp-content/plugins/popup-maker/classes/Admin/Notices.php |
<?php
/**
* Class for Admin Notices
*
* @package PUM
* @copyright Copyright (c) 2023, Code Atlantic LLC
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Handles showing remote notices through the admin alerts system.
*
* @since 1.17.0
*/
class PUM_Admin_Notices {
/**
* Enqueues and sets up pointers across our admin pages.
*/
public static function init() {
if ( is_admin() && current_user_can( 'manage_options' ) ) {
add_filter( 'pum_alert_list', [ __CLASS__, 'tips_alert' ] );
add_action( 'pum_alert_dismissed', [ __CLASS__, 'alert_handler' ], 10, 2 );
}
}
/**
* Adds a 'tip' alert occasionally inside PM's admin area
*
* @since 1.17.0
*
* @param array $alerts The alerts currently in the alert system.
* @return array Alerts for the alert system.
*/
public static function tips_alert( $alerts ) {
if ( ! self::should_show_notice() ) {
return $alerts;
}
$notices = self::get_notices();
if ( empty( $notices ) ) {
return $alerts;
}
// Foreach notice, add it to the alerts array.
foreach ( $notices as $notice ) {
$alert = [
'code' => 'pum_notice_' . $notice['id'],
'type' => 'success',
'html' => $notice['content'],
'actions' => [],
'global' => $notice['is_global'] ? true : false,
];
if ( ! empty( $notice['link'] ) ) {
$alert['actions'][] = [
'primary' => true,
'type' => 'link',
'action' => '',
'href' => $notice['link'],
'text' => __( 'Learn more', 'popup-maker' ),
];
}
$alert['actions'][] = [
'primary' => false,
'type' => 'action',
'action' => 'dismiss',
'text' => __( 'Dismiss', 'popup-maker' ),
];
$alert['actions'][] = [
'primary' => false,
'type' => 'action',
'action' => 'disable_notices',
'text' => __( 'Turn off these occasional notices', 'popup-maker' ),
];
$alerts[] = $alert;
}
return $alerts;
}
/**
* Get notices to show.
*
* @return array
*/
public static function get_notices() {
$notices = get_transient( 'pum_plugin_notices' );
if ( ! $notices ) {
$notices = self::fetch_notices();
}
$dismissed_notices = get_option( 'pum_dismissed_notices', [] );
// Remove dismissed notices.
if ( $dismissed_notices ) {
foreach ( $notices as $key => $notice ) {
if ( in_array( $notice->id, $dismissed_notices, true ) ) {
unset( $notices[ $key ] );
}
}
}
// Removed filtered notices.
foreach ( $notices as $key => $notice ) {
if ( ! empty( $notice['filters'] ) ) {
foreach ( $notice['filters'] as $filter ) {
$filter = explode( ':', $filter );
$type = trim( $filter[0] );
$extra = trim( ! empty( $filter[1] ) ? $filter[1] : '' );
if ( ! empty( $type ) ) {
switch ( $type ) {
case 'plugin':
if ( $extra && ! is_plugin_active( "$extra/$extra.php" ) ) {
unset( $notices[ $key ] );
}
break;
case 'theme':
if ( ! wp_get_theme( $extra )->exists() ) {
unset( $notices[ $key ] );
}
break;
case 'environment':
if ( $extra && ! self::check_environment( $extra ) ) {
unset( $notices[ $key ] );
}
break;
}
}
}
}
}
return $notices;
}
/**
* Fetch list of notices from the Popup Maker server.
*
* @since 1.17.0
*
* @return array
*/
public static function fetch_notices() {
$notices = wp_remote_get( 'https://wppopupmaker.com/wp-json/wp/v2/plugin-notices' );
if ( is_wp_error( $notices ) ) {
return [];
}
$notices = json_decode( wp_remote_retrieve_body( $notices ), true );
if ( ! is_array( $notices ) ) {
return [];
}
foreach ( $notices as $i => $notice ) {
$notices[ $i ] = [
'id' => $notice['id'],
'content' => $notice['content']['rendered'],
'excerpt' => $notice['excerpt']['rendered'],
'link' => $notice['acf']['learn_more_url'],
'is_global' => $notice['acf']['is_global'],
'filters' => $notice['acf']['use_filters'] ? $notice['acf']['filters'] : [],
];
}
set_transient( 'pum_plugin_notices', $notices, 12 * HOUR_IN_SECONDS );
return $notices;
}
/**
* Checks if any options have been clicked from admin notices.
*
* @since 1.17.0
*
* @param string $code The code for the alert.
* @param string $action Action taken on the alert.
*/
public static function alert_handler( $code, $action ) {
if ( strpos( $code, 'pum_notice_' ) === 0 ) {
if ( 'disable_notices' === $action ) {
pum_update_option( 'disable_notices', true );
}
}
}
/**
* Whether or not we should show notice alert
*
* @since 1.17.0
*
* @return bool True if the alert should be shown
*/
public static function should_show_notice() {
if ( ! current_user_can( 'manage_options' ) ) {
return false;
}
if ( self::has_turned_off_notices() ) {
return false;
}
if ( strtotime( self::get_installed_on() . ' +3 days' ) < time() ) {
// return false;
}
return true;
}
/**
* Checks to see if site has turned off PM notices
*
* @since 1.17.0
*
* @return bool True if site has disabled notices
*/
public static function has_turned_off_notices() {
return true === pum_get_option( 'disable_notices', false ) || 1 === intval( pum_get_option( 'disable_notices', false ) );
}
/**
* Get the datetime string for when PM was installed.
*
* @since 1.17.0
*
* @return string
*/
public static function get_installed_on() {
$installed_on = get_option( 'pum_installed_on', false );
if ( ! $installed_on ) {
$installed_on = current_time( 'mysql' );
}
return $installed_on;
}
/**
* Checks if the current environment is a development environment.
*
* @since 1.17.0
*
* @param string $type The type of environment to check for.
*
* @return bool
*/
public static function check_environment( $type ) {
$env = function_exists( 'wp_get_environment_type' ) ? wp_get_environment_type() : 'production';
switch ( $type ) {
case 'local':
return 'local' === $env;
case 'staging':
return 'staging' === $env;
case 'development':
return 'development' === $env;
case 'production':
return 'production' === $env;
}
return false;
}
}