HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vm8 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: afleverb (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //var/www/drakkar_site/wp-content/plugins/otter-blocks/inc/css/blocks/class-review-css.php
<?php
/**
 * Css handling logic for blocks.
 *
 * @package ThemeIsle\GutenbergBlocks\CSS\Blocks
 */

namespace ThemeIsle\GutenbergBlocks\CSS\Blocks;

use ThemeIsle\GutenbergBlocks\Base_CSS;

use ThemeIsle\GutenbergBlocks\CSS\CSS_Utility;

/**
 * Class Review_CSS
 */
class Review_CSS extends Base_CSS {

	/**
	 * The namespace under which the blocks are registered.
	 *
	 * @var string
	 */
	public $block_prefix = 'review';

	/**
	 * Generate Review CSS
	 *
	 * @param mixed $block Block data.
	 * @return string
	 * @since   1.3.0
	 * @access  public
	 */
	public function render_css( $block ) {
		$css     = new CSS_Utility( $block );
		$padding = array(
			'padding'       => array(
				'prefix' => '--padding-desktop-',
			),
			'paddingTablet' => array(
				'prefix' => '--padding-tablet-',
			),
			'paddingMobile' => array(
				'prefix' => '--padding-mobile-',
			),
		);

		$padding_sides = array(
			'top',
			'bottom',
			'left',
			'right',
		);

		$padding_css = array();

		foreach ( $padding as $key => $item ) {
			foreach ( $padding_sides as $side ) {
				array_push(
					$padding_css,
					array(
						'property'  => $item['prefix'] . $side,
						'value'     => $key,
						'format'    => function ( $value, $attrs ) use ( $side ) {
							return $value[ $side ];
						},
						'condition' => function ( $attrs ) use ( $key, $side ) {
							return isset( $attrs[ $key ] ) && isset( $attrs[ $key ][ $side ] );
						},
					)
				);
			}
		}

		$css->add_item(
			array(
				'properties' => array_merge(
					array(
						array(
							'property' => '--background-color',
							'value'    => 'backgroundColor',
							'hasSync'  => 'review-background-color',
						),
						array(
							'property' => '--primary-color',
							'value'    => 'primaryColor',
							'hasSync'  => 'review-primary-color',
						),
						array(
							'property' => '--text-color',
							'value'    => 'textColor',
							'hasSync'  => 'review-text-color',
						),
						array(
							'property' => '--button-text-color',
							'value'    => 'buttonTextColor',
							'hasSync'  => 'review-button-text-color',
						),
						array(
							'property' => '--border-color',
							'value'    => 'borderColor',
							'hasSync'  => 'review-border-color',
						),
						array(
							'property' => '--stars-color',
							'value'    => 'starsColor',
							'hasSync'  => 'review-stars-color',
						),
						array(
							'property' => '--pros-color',
							'value'    => 'prosColor',
							'hasSync'  => 'review-pros-color',
						),
						array(
							'property' => '--cons-color',
							'value'    => 'consColor',
							'hasSync'  => 'review-cons-color',
						),
						array(
							'property' => '--content-font-size',
							'value'    => 'contentFontSize',
						),
						array(
							'property' => '--border-width',
							'value'    => 'borderWidth',
							'unit'     => 'px',
						),
						array(
							'property' => '--border-radius',
							'value'    => 'borderRadius',
							'unit'     => 'px',
						),
						array(
							'property'       => '--box-shadow',
							'pattern'        => 'horizontal vertical blur spread color',
							'pattern_values' => array(
								'horizontal' => array(
									'value'   => 'boxShadow',
									'unit'    => 'px',
									'default' => 0,
									'format'  => function ( $value ) {
										return $value['horizontal'];
									},
								),
								'vertical'   => array(
									'value'   => 'boxShadow',
									'unit'    => 'px',
									'default' => 0,
									'format'  => function ( $value ) {
										return $value['vertical'];
									},
								),
								'blur'       => array(
									'value'   => 'boxShadow',
									'unit'    => 'px',
									'default' => 5,
									'format'  => function ( $value ) {
										return $value['blur'];
									},
								),
								'spread'     => array(
									'value'   => 'boxShadow',
									'unit'    => 'px',
									'default' => 1,
									'format'  => function ( $value ) {
										return $value['spread'];
									},
								),
								'color'      => array(
									'value'   => 'boxShadow',
									'default' => '#000',
									'format'  => function ( $value ) {
										$opacity = $value['colorOpacity'];
										$color   = isset( $value['color'] ) ? $value['color'] : '#000000';
										return ( strpos( $color, '#' ) !== false && $opacity < 100 ) ? Base_CSS::hex2rgba( $color, $opacity / 100 ) : $color;
									},
								),
							),
							'condition'      => function ( $attrs ) {
								return isset( $attrs['boxShadow'] ) && true === $attrs['boxShadow']['active'];
							},
						),
					),
					$padding_css
				),
			)
		);

		$style = $css->generate();

		return $style;
	}

	/**
	 * Generate Review Global CSS
	 *
	 * @return  string|void
	 * @since   2.0.0
	 * @access  public
	 */
	public function render_global_css() {
		$defaults = get_option( 'themeisle_blocks_settings_global_defaults' );
		$block    = $this->library_prefix . '/' . $this->block_prefix;

		if ( empty( $defaults ) ) {
			return;
		}

		$defaults = json_decode( $defaults, true );

		if ( ! isset( $defaults[ $block ] ) ) {
			return;
		}

		$block = array(
			'attrs' => $defaults[ $block ],
		);

		$css = new CSS_Utility( $block );

		$css->add_item(
			array(
				'selector'   => '.wp-block-themeisle-blocks-review',
				'properties' => array(
					array(
						'property' => '--review-background-color',
						'value'    => 'backgroundColor',
					),
					array(
						'property' => '--review-primary-color',
						'value'    => 'primaryColor',
					),
					array(
						'property' => '--review-text-color',
						'value'    => 'textColor',
					),
					array(
						'property' => '--review-button-text-color',
						'value'    => 'buttonTextColor',
					),
					array(
						'property' => '--review-stars-color',
						'value'    => 'starsColor',
					),
					array(
						'property' => '--review-border-color',
						'value'    => 'borderColor',
					),
					array(
						'property' => '--review-pros-color',
						'value'    => 'prosColor',
					),
					array(
						'property' => '--review-cons-color',
						'value'    => 'consColor',
					),
				),
			)
		);

		$style = $css->generate();

		return $style;
	}
}