parent = $widget; $this->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', ) ); $this->add_control( 'product_title', array( 'label' => __( 'Title', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $this->add_control( 'title_above_img', array( 'label' => __( 'Place Title Above Image', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'prefix_class' => 'premium-woo-title-above-', 'render_type' => 'template', 'condition' => array( $this->get_control_id( 'product_title' ) => 'yes', $this->get_control_id( 'product_image' ) => 'yes', ), ) ); $this->add_control( 'product_category', array( 'label' => __( 'Category', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $this->add_control( 'product_rating', array( 'label' => __( 'Rating', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $this->add_control( 'product_price', array( 'label' => __( 'Price', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $this->add_control( 'product_cta', array( 'label' => __( 'Add To Cart', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SWITCHER, 'default' => 'yes', ) ); $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, {{WRAPPER}} .premium-woo-product__link' => 'text-align: {{VALUE}}', ), ) ); $this->end_controls_section(); } /** * Register Product Style Controls. * * @since 4.7.0 * @access public * * @param Widget_Base $widget widget object. */ public function register_product_content_style( Widget_Base $widget ) { $this->parent = $widget; $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, {{WRAPPER}} .premium-woo-product-wrapper:hover .premium-woo-products-details-wrap, {{WRAPPER}} .premium-woo-products-details-wrap', ) ); $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 Image Overlay section. * * @since 4.7.0 * @access public * * @param Widget_Base $widget widget object. */ public function register_image_overlay( Widget_Base $widget ) { $this->parent = $widget; $this->start_controls_section( 'section_overlay_controls', array( 'label' => __( 'Overlay', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, ) ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'overlay_background', 'types' => array( 'classic', 'gradient' ), 'selector' => '{{WRAPPER}} .premium-woo-product-overlay', ) ); $this->add_responsive_control( 'overlay_icons_align', array( 'label' => __( 'Icons Alignment', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::CHOOSE, 'options' => array( 'flex-start' => array( 'title' => __( 'Top', 'premium-addons-for-elementor' ), 'icon' => 'eicon-arrow-up', ), 'center' => array( 'title' => __( 'Center', 'premium-addons-for-elementor' ), 'icon' => 'eicon-text-align-center', ), 'flex-end' => array( 'title' => __( 'Bottom', 'premium-addons-for-elementor' ), 'icon' => 'eicon-arrow-down', ), ), 'default' => 'flex-end', 'toggle' => false, 'selectors' => array( '{{WRAPPER}} .premium-woo-product-overlay' => 'align-items: {{VALUE}}', ), ) ); $this->end_controls_section(); } /** * Register Product CTA style Controls. * * @since 4.7.0 * @access public * * @param Widget_Base $widget widget object. */ public function register_product_cta_style( Widget_Base $widget ) { $this->parent = $widget; $this->start_controls_section( 'section_button_style', array( 'label' => __( 'Add To Cart', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => array( $this->get_control_id( 'product_cta' ) => 'yes', ), ) ); $this->add_responsive_control( 'cta_size', array( 'label' => __( 'Size', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SLIDER, 'size_units' => array( 'px', 'em' ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-atc-button' => 'font-size: {{SIZE}}{{UNIT}}; min-width: {{SIZE}}{{UNIT}}; min-height: {{SIZE}}{{UNIT}};', ), ) ); $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-woocommerce .premium-woo-atc-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, 'global' => array( 'default' => Global_Colors::COLOR_SECONDARY, ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce.premium-woo-skin-grid-8 .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-woocommerce .premium-woo-atc-button', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'cta_shadow', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-atc-button', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'cta_border', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-atc-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-woocommerce .premium-woo-atc-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-woocommerce.premium-woo-skin-grid-8 .premium-woo-atc-button:hover .button' => '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-atc-button:hover', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'cta_shadow_hover', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-atc-button:hover', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'cta_border_hover', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-atc-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-woocommerce .premium-woo-atc-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 * * @param Widget_Base $widget widget object. */ public function register_quick_view_controls( Widget_Base $widget ) { $this->parent = $widget; $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->end_controls_section(); } /** * Register Style Quick View Controls. * * @since 4.7.0 * @access public * * @param Widget_Base $widget widget object. */ public function register_quick_style_controls( Widget_Base $widget ) { $this->parent = $widget; $this->start_controls_section( 'section_quick_view_style', array( 'label' => __( 'Quick View Icon', 'premium-addons-for-elementor' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => array( $this->get_control_id( 'quick_view' ) => 'yes', ), ) ); $this->add_responsive_control( 'qv_size', array( 'label' => __( 'Size', 'premium-addons-for-elementor' ), 'type' => Controls_Manager::SLIDER, 'size_units' => array( 'px', 'em' ), 'range' => array( 'px' => array( 'min' => 20, 'max' => 200, ), ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce .premium-woo-qv-btn' => 'font-size: {{SIZE}}{{UNIT}}; min-width: {{SIZE}}{{UNIT}}; min-height: {{SIZE}}{{UNIT}};', ), ) ); $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-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, 'global' => array( 'default' => Global_Colors::COLOR_SECONDARY, ), 'selectors' => array( '{{WRAPPER}} .premium-woocommerce.premium-woo-skin-grid-8 .premium-woo-qv-icon' => '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-qv-btn', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'qv_shadow', 'selector' => '{{WRAPPER}} .premium-woocommerce .premium-woo-qv-btn', ) ); $this->add_group_control( Group_Control_Border::get_type(), array( 'name' => 'qv_border', 'selector' => '{{WRAPPER}} .premium-woocommerce .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-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-skin-grid-8 .premium-woo-qv-icon: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-qv-btn:hover', ) ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), array( 'name' => 'qv_shadow_hover', 'selector' => '{{WRAPPER}} .premium-woocommerce .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-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-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(); } /** * Render Main HTML. * * @since 1.5.0 * @access protected */ public function render() { $papro_activated = apply_filters( 'papro_activated', false ); if ( ! $papro_activated ) { ?>