File "class-premium-upsell-admin-block.php"
Full Path: /home/concvitk/public_html/wp-content/plugins/wordpress-seo/admin/class-premium-upsell-admin-block.php
File size: 7.21 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* WPSEO plugin file.
*
* @package WPSEO\Admin
*/
use Yoast\WP\SEO\Conditionals\WooCommerce_Conditional;
use Yoast\WP\SEO\Promotions\Application\Promotion_Manager;
/**
* Class WPSEO_Premium_Upsell_Admin_Block
*/
class WPSEO_Premium_Upsell_Admin_Block {
/**
* Hook to display the block on.
*
* @var string
*/
protected $hook;
/**
* Identifier to use in the dismissal functionality.
*
* @var string
*/
protected $identifier = 'premium_upsell';
/**
* Registers which hook the block will be displayed on.
*
* @param string $hook Hook to display the block on.
*/
public function __construct( $hook ) {
$this->hook = $hook;
}
/**
* Registers WordPress hooks.
*
* @return void
*/
public function register_hooks() {
add_action( $this->hook, [ $this, 'render' ] );
}
/**
* Renders the upsell block.
*
* @return void
*/
public function render() {
$is_woocommerce_active = ( new WooCommerce_Conditional() )->is_met();
$url = ( $is_woocommerce_active ) ? WPSEO_Shortlinker::get( 'https://yoa.st/admin-footer-upsell-woocommerce' ) : WPSEO_Shortlinker::get( 'https://yoa.st/17h' );
[ $header_text, $header_icon ] = $this->get_header( $is_woocommerce_active );
$arguments = $this->get_arguments( $is_woocommerce_active );
$header_class = ( $is_woocommerce_active ) ? 'woo-header' : '';
$arguments_html = implode( '', array_map( [ $this, 'get_argument_html' ], $arguments ) );
$class = $this->get_html_class();
/* translators: %s expands to Yoast SEO Premium */
$button_text = $this->get_button_text( $is_woocommerce_active );
/* translators: Hidden accessibility text. */
$button_text .= '<span class="screen-reader-text">' . esc_html__( '(Opens in a new browser tab)', 'wordpress-seo' ) . '</span>'
. '<span aria-hidden="true" class="yoast-button-upsell__caret"></span>';
$upgrade_button = sprintf(
'<a id="%1$s" class="yoast-button-upsell" data-action="load-nfd-ctb" data-ctb-id="f6a84663-465f-4cb5-8ba5-f7a6d72224b2" href="%2$s" target="_blank">%3$s</a>',
esc_attr( 'wpseo-' . $this->identifier . '-popup-button' ),
esc_url( $url ),
$button_text
);
echo '<div class="' . esc_attr( $class ) . '">';
if ( YoastSEO()->classes->get( Promotion_Manager::class )->is( 'black-friday-promotion' ) ) {
$bf_label = esc_html__( 'BLACK FRIDAY', 'wordpress-seo' );
$sale_label = esc_html__( '30% OFF', 'wordpress-seo' );
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Already escaped above.
echo "<div class='black-friday-container'><span>$sale_label</span> <span style='margin-left: auto;'>$bf_label</span> </div>";
}
echo '<div class="' . esc_attr( $class . '--container' ) . '">';
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Correctly escaped in get_header() method.
echo '<h2 class="' . esc_attr( $class . '--header' ) . ' ' . esc_attr( $header_class ) . ' ">' . $header_text . $header_icon . '</h2>';
echo '<span class="' . esc_attr( $class . '--subheader' ) . '">'
. esc_html__( 'Now includes Local, News & Video SEO + 1 Google Docs seat!', 'wordpress-seo' )
. '</span>';
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Correctly escaped in $this->get_argument_html() method.
echo '<ul class="' . esc_attr( $class . '--motivation' ) . '">' . $arguments_html . '</ul>';
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- Correctly escaped in $upgrade_button and $button_text above.
echo '<p style="max-width: inherit;">' . $upgrade_button . '</p>';
echo '</div>';
echo '</div>';
}
/**
* Formats the argument to a HTML list item.
*
* @param string $argument The argument to format.
*
* @return string Formatted argument in HTML.
*/
protected function get_argument_html( $argument ) {
$class = $this->get_html_class();
return sprintf(
'<li style="margin-inline-start: 8px;"><span>•</span><div class="%1$s">%2$s</div></li>',
esc_attr( $class . '--argument' ),
$argument
);
}
/**
* Returns the HTML base class to use.
*
* @return string The HTML base class.
*/
protected function get_html_class() {
return 'yoast_' . $this->identifier;
}
/**
* Returns the arguments based on whether WooCommerce is active.
*
* @param bool $is_woocommerce_active Whether WooCommerce is active.
*
* @return array<string> The arguments list.
*/
private function get_arguments( bool $is_woocommerce_active ) {
$arguments = [
esc_html__( 'Generate SEO optimized metadata in seconds with AI', 'wordpress-seo' ),
esc_html__( 'Make your articles visible, be seen in Google News', 'wordpress-seo' ),
esc_html__( 'Built to get found by search, AI, and real users', 'wordpress-seo' ),
esc_html__( 'Easy Local SEO. Show up in Google Maps results', 'wordpress-seo' ),
esc_html__( 'Internal links and redirect management, easy', 'wordpress-seo' ),
esc_html__( 'Access to friendly help when you need it, day or night', 'wordpress-seo' ),
];
if ( $is_woocommerce_active ) {
$arguments[1] = esc_html__( 'Boost visibility for your products, from 10 or 10,000+', 'wordpress-seo' );
}
return $arguments;
}
/**
* Returns the header text and icon based on whether WooCommerce is active.
*
* @param bool $is_woocommerce_active Whether WooCommerce is active.
*
* @return array<string, string> The header text and icon.
*/
private function get_header( bool $is_woocommerce_active ) {
$assets_uri = trailingslashit( plugin_dir_url( WPSEO_FILE ) );
if ( $is_woocommerce_active ) {
$header_text = sprintf(
/* translators: %s expands to Yoast WooCommerce SEO */
esc_html__( 'Upgrade to %s', 'wordpress-seo' ),
'Yoast WooCommerce SEO'
);
$header_icon = sprintf(
'<img src="%s" alt="%s" width="14" height="14" style="margin-inline-start: 8px;">',
esc_url( $assets_uri . 'packages/js/images/icon-trolley.svg' ),
esc_attr__( 'this is a trolley icon', 'wordpress-seo' )
);
}
else {
$header_text = sprintf(
/* translators: %s expands to Yoast SEO Premium*/
esc_html__( 'Upgrade to %s', 'wordpress-seo' ),
'Yoast SEO Premium'
);
$header_icon = sprintf(
'<img src="%s" alt="%s" width="14" height="14" style="margin-inline-start: 8px;">',
esc_url( $assets_uri . 'packages/js/images/icon-crown.svg' ),
esc_attr__( 'this is a crown icon', 'wordpress-seo' )
);
}
return [ $header_text, $header_icon ];
}
/**
* Returns the button text based on whether WooCommerce is active.
*
* @param bool $is_woocommerce_active Whether WooCommerce is active.
*
* @return string The button text.
*/
private function get_button_text( bool $is_woocommerce_active ): string {
if ( YoastSEO()->classes->get( Promotion_Manager::class )->is( 'black-friday-promotion' ) ) {
return esc_html__( 'Get 30% off now!', 'wordpress-seo' );
}
else {
// phpcs:disable Squiz.ControlStructures.InlineIfDeclaration.NotSingleLine -- needed to add translators comments.
return $is_woocommerce_active
/* translators: %s expands to Yoast WooCommerce SEO */
? sprintf( esc_html__( 'Explore %s now!', 'wordpress-seo' ), 'Yoast WooCommerce SEO' )
/* translators: %s expands to Yoast SEO Premium */
: sprintf( esc_html__( 'Explore %s now!', 'wordpress-seo' ), 'Yoast SEO Premium' );
}
}
}