oont-contents/plugins/jetpack/extensions/blocks/wordads/wordads.php
2025-02-08 15:10:23 +01:00

138 lines
3.6 KiB
PHP

<?php //phpcs:ignore WordPress.Files.FileName.InvalidClassFileName
/**
* Ads Block.
*
* @since 7.1.0
*
* @package automattic/jetpack
*/
namespace Automattic\Jetpack\Extensions;
use Automattic\Jetpack\Blocks;
use Automattic\Jetpack\Current_Plan as Jetpack_Plan;
use Jetpack;
use Jetpack_Gutenberg;
/**
* Jetpack's Ads Block class.
*
* @since 7.1.0
*/
class WordAds {
/**
* Check if site is on WP.com Simple.
*
* @return bool
*/
private static function is_wpcom() {
return defined( 'IS_WPCOM' ) && IS_WPCOM;
}
/**
* Check if the WordAds module is active.
*
* @return bool
*/
private static function is_jetpack_module_active() {
return method_exists( 'Jetpack', 'is_module_active' ) && Jetpack::is_module_active( 'wordads' );
}
/**
* Check if the site is approved for ads for WP.com Simple sites.
*
* @return bool
*/
private static function is_available() {
if ( self::is_wpcom() ) {
return has_any_blog_stickers( array( 'wordads', 'wordads-approved', 'wordads-approved-misfits' ), get_current_blog_id() );
}
return Jetpack_Plan::supports( 'wordads' );
}
/**
* Register the WordAds block.
*/
public static function register() {
if ( self::is_available() ) {
Blocks::jetpack_register_block(
__DIR__,
array(
'render_callback' => array( __CLASS__, 'gutenblock_render' ),
)
);
}
}
/**
* Set if the WordAds block is available.
*/
public static function set_availability() {
$block_name = Blocks::get_block_name( __DIR__ );
if ( ! self::is_available() ) {
Jetpack_Gutenberg::set_extension_unavailable( $block_name, 'WordAds unavailable' );
return;
}
// Make the block available. Just in case it wasn't registered before.
Jetpack_Gutenberg::set_extension_available( $block_name );
}
/**
* Renders the WordAds block.
*
* @param array $attr Block attributes.
*
* @return string Block HTML.
*/
public static function gutenblock_render( $attr ) {
global $wordads;
/** If the WordAds module is not active, don't render the block. */
if ( ! self::is_jetpack_module_active() ) {
return '';
}
/** This filter is already documented in modules/wordads/class-wordads.php `insert_ad()` */
if (
empty( $wordads )
|| empty( $wordads->params )
|| is_feed()
|| apply_filters( 'wordads_inpost_disable', false )
) {
return '';
}
if ( ! empty( $attr['hideMobile'] ) && $wordads->params->is_mobile() ) {
return '';
}
if ( ! self::is_wpcom() && $wordads->option( 'wordads_house' ) ) {
return $wordads->get_ad( 'inline', 'house' );
}
// section_id is mostly deprecated at this point, but it helps us (devs) keep track of which ads end up where
// 6 is to keep track of gutenblock ads.
$section_id = $wordads->params->blog_id . '6';
$align = 'center';
if ( isset( $attr['align'] ) && in_array( $attr['align'], array( 'left', 'center', 'right' ), true ) ) {
$align = $attr['align'];
}
$align = 'align' . $align;
$ad_tag_ids = $wordads->get_ad_tags();
$format = 'mrec';
if ( isset( $attr['format'] ) && isset( $ad_tag_ids[ $attr['format'] ] ) ) {
$format = $attr['format'];
}
$height = $ad_tag_ids[ $format ]['height'];
$width = $ad_tag_ids[ $format ]['width'];
$snippet = $wordads->get_ad_snippet( $section_id, $height, $width, 'gutenberg', $wordads->get_solo_unit_css() );
return $wordads->get_ad_div( 'inline', $snippet, array( $align ) );
}
}
add_action( 'init', array( 'Automattic\\Jetpack\\Extensions\\WordAds', 'register' ) );
add_action( 'jetpack_register_gutenberg_extensions', array( 'Automattic\\Jetpack\\Extensions\\WordAds', 'set_availability' ) );