'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-content/uploads/plugin-notices.json', [ 'timeout' => 3, ] ); 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 ); } } // Handle block editor migration notice actions. if ( 'pum_block_editor_migration' === $code ) { delete_option( 'pum_show_block_editor_migration_notice' ); if ( 'switch_to_classic' === $action ) { pum_update_option( 'enable_classic_editor', 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; } /** * Wrap notice with admin only awareness message. * * @param string $notice * * @return string * * since 1.20.0 */ public static function wrap_notice( $notice, $current_version, $future_version ) { // Messy, but it works for now, clean up in the future when this class is refactored. $notice = sprintf( $notice, '

', $future_version, "

\n\n", '' . $current_version . '' ); // FInally append the notice with a small note to the admin that nobody else will see this notice. return '
' . wpautop( $notice ) . '' . esc_html__( '** You are seeing this notice because you are an administrator. Other users of the site will see nothing.', 'popup-maker' ) . '
'; } /** * Adds a notice about upcoming minimum PHP & WP version changes. * * @param array $alerts The alerts currently in the alert system. * * @return array Alerts for the alert system. * * @since 1.20.0 */ public static function upcoming_min_req_changes( $alerts ) { global $wp_version; if ( ! current_user_can( 'manage_options' ) ) { return $alerts; } $plugin_version = \PopupMaker\config( 'version' ); $future_php_version = \PopupMaker\config( 'future_php_req' ); $future_wp_version = \PopupMaker\config( 'future_wp_req' ); if ( $future_php_version && version_compare( $future_php_version, phpversion(), '>' ) ) { $alerts[] = [ // Show the notice on every update. Yes, annoying, but not as annoying as a plugin breaking. 'code' => sprintf( 'php_%s_%s', $future_php_version, $plugin_version ), 'type' => 'error', 'html' => self::wrap_notice( __( "%1\$sPopup Maker will soon require PHP Version %2\$s.%3\$s \n\nYou're using Version %4\$s. Please ask your host to upgrade your server's PHP.", 'popup-maker' ), phpversion(), $future_php_version ), 'global' => true, ]; } if ( $future_wp_version && version_compare( $future_wp_version, $wp_version, '>' ) ) { $alerts[] = [ // Show the notice on every update. Yes, annoying, but not as annoying as a plugin breaking. 'code' => sprintf( 'wp_%s_%s', $future_wp_version, $plugin_version ), 'type' => 'error', 'html' => self::wrap_notice( __( "%1\$sPopup Maker will soon require WordPress Version %2\$s.%3\$s \n\nYou're using Version %4\$s. Please ask your host to upgrade your server's WordPress.", 'popup-maker' ), $wp_version, $future_wp_version ), 'global' => true, ]; } return $alerts; } /** * Add BFCM sale notice * * @param array $alerts Current alerts array * @return array Modified alerts array */ public static function bfcm_sale_notice( $alerts ) { // Check if within BFCM sale dates (Nov 26 - Dec 2) $current_time = time(); $start_date = strtotime( '2024-11-25 00:00:00' ); $end_date = strtotime( '2024-11-30 23:59:59' ); if ( $current_time < $start_date || $current_time > $end_date ) { return $alerts; } add_action( 'admin_print_footer_scripts', function () { echo ''; } ); $discount_amount = ( time() < strtotime( '2024-11-30 23:59:59 EST' ) ) ? 40 : 30; $alerts[] = [ 'code' => 'pum_bfcm_2024', 'type' => 'success', 'html' => sprintf( '%s', '
' . '

🎁 Black Friday Sale! 🥳

' . sprintf( 'Save up to %s%% on all Popup Maker pro plans. Limited time offer - ends December 2nd!', $discount_amount ) . '

' . sprintf( ' See how Popup Maker can boost your holiday sales', 'https://wppopupmaker.com/conversion-optimization/boost-your-black-friday-sales/?utm_source=plugin-notice&utm_campaign=bfcm2024' ) . '
' ), 'dismissible' => false, 'global' => false, 'actions' => [ [ 'primary' => true, 'type' => 'link', 'action' => '', 'href' => \PopupMaker\get_upgrade_link( [ 'utm_source' => 'plugin-notice', 'utm_campaign' => 'bfcm2024', ] ), 'text' => sprintf( 'Get %s%% Off Now', $discount_amount ), ], [ 'primary' => false, 'type' => 'action', 'action' => 'dismiss', 'text' => __( 'Dismiss', 'popup-maker' ), ], ], ]; return $alerts; } /** * Add block editor migration notice for users who had it disabled. * * @param array $alerts Current alerts array. * @return array Modified alerts array. * @since 1.21.0 */ public static function block_editor_migration_notice( $alerts ) { if ( ! current_user_can( 'manage_options' ) ) { return $alerts; } // phpcs:disable WordPress.Security.NonceVerification.Recommended if ( ! isset( $_GET['pum_block_editor_migration_notice'] ) && ! get_option( 'pum_show_block_editor_migration_notice', false ) ) { // Only show if user should see the migration notice. return $alerts; } $alerts[] = [ 'code' => 'pum_block_editor_migration', 'type' => 'info', 'html' => sprintf( '%s', '
' . '

🎉 ' . __( 'Popup Maker Update: Block Editor is Now Default!', 'popup-maker' ) . '

' . '

' . __( 'The block editor is now enabled by default for creating popups. You can start using it immediately, or continue with the classic editor if you prefer.', 'popup-maker' ) . '

' . '
' ), 'dismissible' => true, 'global' => false, 'actions' => [ [ 'primary' => true, 'type' => 'action', 'action' => 'keep_block_editor', 'text' => __( 'Continue with Block Editor', 'popup-maker' ), ], [ 'primary' => false, 'type' => 'action', 'action' => 'switch_to_classic', 'text' => __( 'Switch to Classic Editor', 'popup-maker' ), ], [ 'primary' => false, 'type' => 'action', 'action' => 'dismiss', 'text' => __( 'Dismiss', 'popup-maker' ), ], ], ]; return $alerts; } }