start_controls_section( 'section_content_field', array( 'label' => __( 'Display Options', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'product_image', array( 'label' => __( 'Image', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $repeater = new REPEATER(); $repeater->add_control( 'product_segment', array( 'label' => __( 'Select Product Segment', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_product_blocks(), 'multiple' => true, ) ); $repeater->add_control( 'excerpt_length', array( 'label' => __( 'Excerpt Length', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::NUMBER, 'condition' => array( 'product_segment' => 'desc', ), ) ); $this->add_control( 'product_structure', array( 'label' => __( 'Product Structure', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::REPEATER, 'default' => array( array( 'product_segment' => 'title', ), array( 'product_segment' => 'category', ), array( 'product_segment' => 'ratings', ), array( 'product_segment' => 'price', ), array( 'product_segment' => 'cta', ), ), 'fields' => $repeater->get_controls(), 'title_field' => '{{{ product_segment }}}', ) ); $this->add_responsive_control( 'alignment', array( 'label' => __( 'Alignment', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::CHOOSE, 'options' => array( 'left' => array( 'title' => __( 'Left', 'premium-addons-for-elementor' ), 'icon' => 'eicon-text-align-left', ), 'center' => array( 'title' => __( 'Center', 'premium-addons-for-elementor' ), 'icon' => 'eicon-text-align-center', ), 'right' => array( 'title' => __( 'Right', 'premium-addons-for-elementor' ), 'icon' => 'eicon-text-align-right', ), ), 'default' => 'center', 'toggle' => false, 'prefix_class' => 'premium-woo-product-align-', 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap' => 'text-align: {{VALUE}}', ), ) ); $this->end_controls_section(); } /** * Register product content style. * Register product content style Controls. * * @since 4.7.0 * @access public */ public function register_product_content_style() { $this->start_controls_section( 'section_product_style', array( 'label' => __( 'Product', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'content_background', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woo-product-wrapper', ) ); $this->add_responsive_control( 'content_padding', array( 'label' => __( 'Padding', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ), ) ); $this->end_controls_section(); } /** * Register product excerpt style. * Register product excerpt style Controls. * * @since 4.7.0 * @access public */ public function register_product_excerpt_style() { $this->start_controls_section( 'section_desc_style', array( 'label' => __( 'Description', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, ) ); $this->add_control( 'desc_color', array( 'label' => __( 'Color', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::COLOR, 'global' => array( 'default' => Global_Colors::COLOR_TEXT, ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-product-desc' => 'color: {{VALUE}};', ), ) ); $this->add_group_control( Group_Control_Typography::get_type(), array( 'name' => 'desc_typography', 'global' => array( 'default' => Global_Typography::TYPOGRAPHY_TEXT, ), 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-product-desc', ) ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), array( 'name' => 'desc_text_shadow', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-product-desc', ) ); $this->add_responsive_control( 'desc_spacing', array( 'label' => __( 'Margin', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-product-desc' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ), ) ); $this->end_controls_section(); } /** * Register product CTA style. * Register product CTA style Controls. * * @since 4.7.0 * @access public */ public function register_product_cta_style() { $this->start_controls_section( 'section_button_style', array( 'label' => __( 'Add To Cart', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, ) ); $this->add_group_control( Group_Control_Typography::get_type(), array( 'name' => 'cta_typography', 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button', 'global' => array( 'default' => Global_Typography::TYPOGRAPHY_ACCENT, ), ) ); $this->add_responsive_control( 'cta_padding', array( 'label' => __( 'Padding', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ), ) ); $this->start_controls_tabs( 'cta_style_tabs' ); $this->start_controls_tab( 'cta_style_tab_normal', array( 'label' => __( 'Normal', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'cta_color', array( 'label' => __( 'Color', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::COLOR, 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button' => 'color: {{VALUE}};', ), ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'cta_background', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'cta_shadow', 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'cta_border', 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button', ) ); $this->add_control( 'cta_radius', array( 'label' => __( 'Border Radius', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}', ), ) ); $this->end_controls_tab(); $this->start_controls_tab( 'cta_style_tab_hover', array( 'label' => __( 'Hover', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'cta_color_hover', array( 'label' => __( 'Color', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::COLOR, 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button:hover' => 'color: {{VALUE}}', ), ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'cta_background_hover', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-atc-button .button:hover', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'cta_shadow_hover', 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button:hover', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'cta_border_hover', 'selector' => '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button:hover', ) ); $this->add_control( 'cta_radius_hover', array( 'label' => __( 'Border Radius', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', '%', 'em' ), 'selectors' => array( '{{WRAPPER}} .premium-woo-products-details-wrap .premium-woo-atc-button .button:hover' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}', ), ) ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } /** * Register Quick View Controls. * * @since 4.7.0 * @access public */ public function register_quick_view_controls() { $this->start_controls_section( 'section_content_quick_view', array( 'label' => __( 'Quick View', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'quick_view', array( 'label' => __( 'Enable Quick View', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $this->add_control( 'quick_view_type', array( 'label' => __( 'Quick View', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SELECT, 'options' => array( 'button' => __( 'On Button Click', 'premium-addons-for-elementor' ), 'image' => __( 'On Image Click', 'premium-addons-for-elementor' ), ), 'default' => 'button', 'condition' => array( $this->get_control_id( 'quick_view' ) => 'yes', ), ) ); $this->end_controls_section(); } /** * Register Style Quick View Controls. * * @since 4.7.0 * @access public */ public function register_quick_style_controls() { $this->start_controls_section( 'section_quick_view_style', array( 'label' => __( 'Quick View Trigger Button', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => array( $this->get_control_id( 'quick_view' ) => 'yes', $this->get_control_id( 'quick_view_type' ) => 'button', ), ) ); $this->add_group_control( Group_Control_Typography::get_type(), array( 'name' => 'qv_typography', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn', 'global' => array( 'default' => Global_Typography::TYPOGRAPHY_ACCENT, ), ) ); $this->add_responsive_control( 'qv_padding', array( 'label' => __( 'Padding', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ), ) ); $this->start_controls_tabs( 'qv_style_tabs' ); $this->start_controls_tab( 'qv_style_tab_normal', array( 'label' => __( 'Normal', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'qv_color', array( 'label' => __( 'Color', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::COLOR, 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn' => 'color: {{VALUE}};', ), ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'qv_background', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'qv_shadow', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'qv_border', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn', ) ); $this->add_control( 'qv_radius', array( 'label' => __( 'Border Radius', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', 'em', '%' ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}', ), ) ); $this->end_controls_tab(); $this->start_controls_tab( 'qv_style_tab_hover', array( 'label' => __( 'Hover', 'premium-addons-for-elementor' ), ) ); $this->add_control( 'qv_color_hover', array( 'label' => __( 'Color', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::COLOR, 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn:hover' => 'color: {{VALUE}}', ), ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'qv_background_hover', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn:hover', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'qv_shadow_hover', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn:hover', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'qv_border_hover', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn:hover', ) ); $this->add_control( 'qv_radius_hover', array( 'label' => __( 'Border Radius', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => array( 'px', '%', 'em' ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-products-details-wrap .premium-woo-qv-btn:hover' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}', ), ) ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } /** * Get Product Blocks. * * @since 4.7.0 * @access public * * @return array */ public function get_product_blocks() { $blocks = array( 'title' => __( 'Title', 'premium-addons-for-elementor' ), 'category' => __( 'Category', 'premium-addons-for-elementor' ), 'ratings' => __( 'Rating', 'premium-addons-for-elementor' ), 'price' => __( 'Price', 'premium-addons-for-elementor' ), 'desc' => __( 'Excerpt', 'premium-addons-for-elementor' ), 'cta' => __( 'Add To Cart', 'premium-addons-for-elementor' ), ); return $blocks; } /** * Render Main HTML. * * @since 1.5.0 * @access protected */ public function render() { $settings = $this->parent->get_settings(); $skin = Skin_Init::get_instance( $this->get_id() ); echo wp_kses_post( sanitize_text_field( $skin->render( $this->get_id(), $settings, $this->parent->get_id() ) ) ); } }