Skip to content
This repository has been archived by the owner on Feb 23, 2024. It is now read-only.

Commit

Permalink
Fix duotone for fixed and repeated images on the front end
Browse files Browse the repository at this point in the history
  • Loading branch information
albarin committed May 13, 2022
1 parent 7c4e235 commit ab27159
Showing 1 changed file with 42 additions and 27 deletions.
69 changes: 42 additions & 27 deletions src/BlockTypes/FeaturedProduct.php
Original file line number Diff line number Diff line change
Expand Up @@ -96,16 +96,16 @@ protected function render( $attributes, $content ) {

$image_url = esc_url( $this->get_image_url( $attributes, $product ) );

$styles = $this->get_styles( $attributes, $image_url );
$classes = $this->get_classes( $attributes );
$wrapper_classes = $this->get_wrapper_classes( $attributes );
$classes = $this->get_classes( $attributes );

$output = sprintf( '<div class="%1$s wp-block-woocommerce-featured-product">', esc_attr( trim( $classes ) ) );
$output .= sprintf( '<div class="%s" style="%s">', esc_attr( $wrapper_classes ), esc_attr( $styles ) );
$output .= $this->render_wrapper( $attributes );
$output .= $this->render_overlay( $attributes );

if ( ! $attributes['isRepeated'] && ! $attributes['hasParallax'] ) {
$output .= $this->render_image( $attributes, $product, $image_url );
} else {
$output .= $this->render_bg_image( $attributes, $image_url );
}

$output .= $title;
Expand Down Expand Up @@ -175,6 +175,43 @@ private function render_image( $attributes, $product, $image_url ) {
return '';
}

/**
* Renders the featured image as a div background.
*
* @param array $attributes Block attributes. Default empty array.
* @param string $image_url Product image url.
*
* @return string
*/
private function render_bg_image( $attributes, $image_url ) {
$styles = $this->get_bg_styles( $attributes, $image_url );

$classes = [ 'wc-block-featured-product__background-image' ];

if ( $attributes['hasParallax'] ) {
$classes[] = ' has-parallax';
}

return sprintf( '<div class="%1$s" style="%2$s" /></div>', implode( ' ', $classes ), $styles );
}

/**
* Renders the image wrapper.
*
* @param array $attributes Block attributes. Default empty array.
*
* @return string
*/
private function render_wrapper( $attributes ) {
$min_height = $attributes['minHeight'] ?? wc_get_theme_support( 'featured_block::default_height', 500 );

if ( isset( $attributes['minHeight'] ) ) {
$style = sprintf( 'min-height:%dpx;', intval( $min_height ) );
}

return sprintf( '<div class="wc-block-featured-product__wrapper" style="%s">', esc_attr( $style ) );
}

/**
* Renders the block overlay
*
Expand Down Expand Up @@ -204,7 +241,7 @@ private function render_overlay( $attributes ) {
*
* @return string
*/
public function get_styles( $attributes, $image_url ) {
public function get_bg_styles( $attributes, $image_url ) {
$style = '';

if ( $attributes['isRepeated'] || $attributes['hasParallax'] ) {
Expand All @@ -224,34 +261,12 @@ public function get_styles( $attributes, $image_url ) {
);
}

$min_height = $attributes['minHeight'] ?? wc_get_theme_support( 'featured_block::default_height', 500 );

if ( isset( $attributes['minHeight'] ) ) {
$style .= sprintf( 'min-height:%dpx;', intval( $min_height ) );
}

$global_style_style = StyleAttributesUtils::get_styles_by_attributes( $attributes, $this->global_style_wrapper );
$style .= $global_style_style;

return $style;
}

/**
* Get class names for the block wrapper.
*
* @param array $attributes Block attributes. Default empty array.
* @return string
*/
private function get_wrapper_classes( $attributes ) {
$classes[] = 'wc-block-featured-product__wrapper';

if ( $attributes['hasParallax'] ) {
$classes[] = ' has-parallax';
}

return implode( ' ', $classes );
}

/**
* Get class names for the block container.
*
Expand Down

0 comments on commit ab27159

Please sign in to comment.