<?php
namespace ElementorPro\Modules\Woocommerce\Widgets;
use Elementor\Controls_Manager;
use Elementor\Group_Control_Typography;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
class Product_Rating extends Base_Widget {
public function get_name() {
return 'woocommerce-product-rating';
}
public function get_title() {
return __( 'Product Rating', 'elementor-pro' );
}
public function get_icon() {
return 'eicon-product-rating';
}
public function get_keywords() {
return [ 'woocommerce', 'shop', 'store', 'rating', 'review', 'comments', 'stars', 'product' ];
}
protected function register_controls() {
$this->start_controls_section(
'section_product_rating_style',
[
'label' => __( 'Style', 'elementor-pro' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'wc_style_warning',
[
'type' => Controls_Manager::RAW_HTML,
'raw' => __( 'The style of this widget is often affected by your theme and plugins. If you experience any such issue, try to switch to a basic theme and deactivate related plugins.', 'elementor-pro' ),
'content_classes' => 'elementor-panel-alert elementor-panel-alert-info',
]
);
$this->add_control(
'star_color',
[
'label' => __( 'Star Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'.woocommerce {{WRAPPER}} .star-rating' => 'color: {{VALUE}}',
],
]
);
$this->add_control(
'empty_star_color',
[
'label' => __( 'Empty Star Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'.woocommerce {{WRAPPER}} .star-rating::before' => 'color: {{VALUE}}',
],
]
);
$this->add_control(
'link_color',
[
'label' => __( 'Link Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'.woocommerce {{WRAPPER}} .woocommerce-review-link' => 'color: {{VALUE}}',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'text_typography',
'selector' => '.woocommerce {{WRAPPER}} .woocommerce-review-link',
]
);
$this->add_control(
'star_size',
[
'label' => __( 'Star Size', 'elementor-pro' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'unit' => 'em',
],
'range' => [
'em' => [
'min' => 0,
'max' => 4,
'step' => 0.1,
],
],
'selectors' => [
'.woocommerce {{WRAPPER}} .star-rating' => 'font-size: {{SIZE}}{{UNIT}}',
],
]
);
$this->add_control(
'space_between',
[
'label' => __( 'Space Between', 'elementor-pro' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', 'em' ],
'default' => [
'unit' => 'em',
],
'range' => [
'em' => [
'min' => 0,
'max' => 4,
'step' => 0.1,
],
'px' => [
'min' => 0,
'max' => 50,
'step' => 1,
],
],
'selectors' => [
'.woocommerce:not(.rtl) {{WRAPPER}} .star-rating' => 'margin-right: {{SIZE}}{{UNIT}}',
'.woocommerce.rtl {{WRAPPER}} .star-rating' => 'margin-left: {{SIZE}}{{UNIT}}',
],
]
);
$this->add_responsive_control(
'alignment',
[
'label' => __( 'Alignment', 'elementor-pro' ),
'type' => Controls_Manager::CHOOSE,
'options' => [
'left' => [
'title' => __( 'Left', 'elementor-pro' ),
'icon' => 'eicon-text-align-left',
],
'center' => [
'title' => __( 'Center', 'elementor-pro' ),
'icon' => 'eicon-text-align-center',
],
'right' => [
'title' => __( 'Right', 'elementor-pro' ),
'icon' => 'eicon-text-align-right',
],
'justify' => [
'title' => __( 'Justified', 'elementor-pro' ),
'icon' => 'eicon-text-align-justify',
],
],
'prefix_class' => 'elementor-product-rating--align-',
]
);
$this->end_controls_section();
}
protected function render() {
if ( ! post_type_supports( 'product', 'comments' ) ) {
return;
}
global $product;
$product = wc_get_product();
if ( empty( $product ) ) {
return;
}
wc_get_template( 'single-product/rating.php' );
}
public function render_plain_content() {}
}