Server IP : 192.64.112.168 / Your IP : 18.223.43.151 Web Server : Apache System : Linux nc-ph-2300-85.bluforrest.com 4.18.0-513.9.1.el8_9.x86_64 #1 SMP Sat Dec 2 05:23:44 EST 2023 x86_64 User : expressoneac ( 1128) PHP Version : 8.0.30 Disable Function : exec,passthru,shell_exec,system MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/expressoneac/www/wp-content/plugins/elementor-pro/modules/woocommerce/widgets/ |
Upload File : |
<?php namespace ElementorPro\Modules\Woocommerce\Widgets; use ElementorPro\Plugin; use Elementor\Controls_Manager; use Elementor\Group_Control_Box_Shadow; use Elementor\Group_Control_Typography; use Elementor\Group_Control_Text_Shadow; use Elementor\Group_Control_Border; use Elementor\Repeater; use Elementor\Group_Control_Background; use Elementor\Core\Kits\Documents\Tabs\Global_Typography; use Elementor\Core\Breakpoints\Manager as Breakpoints_Manager; if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly } class Checkout extends Base_Widget { private $reformatted_form_fields; public function get_name() { return 'woocommerce-checkout-page'; } public function get_title() { return esc_html__( 'Checkout', 'elementor-pro' ); } public function get_icon() { return 'eicon-checkout'; } public function get_keywords() { return [ 'woocommerce', 'checkout' ]; } public function get_categories() { return [ 'woocommerce-elements' ]; } public function get_help_url() { return 'https://go.elementor.com/widget-woocommerce-checkout'; } public function get_script_depends() { return [ 'wc-checkout', 'wc-password-strength-meter', 'selectWoo', ]; } public function get_style_depends() { return [ 'select2' ]; } protected function register_controls() { $this->start_controls_section( 'section_content', [ 'label' => esc_html__( 'General', 'elementor-pro' ), ] ); $this->add_control( 'checkout_layout', [ 'label' => esc_html__( 'Layout', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => [ 'two-column' => esc_html__( 'Two columns', 'elementor-pro' ), 'one-column' => esc_html__( 'One column', 'elementor-pro' ), ], 'default' => 'two-column', 'prefix_class' => 'e-checkout-layout-', ] ); $this->add_control( 'sticky_right_column', [ 'label' => esc_html__( 'Sticky Right Column', 'elementor-pro' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Yes', 'elementor-pro' ), 'label_off' => esc_html__( 'No', 'elementor-pro' ), 'return_value' => 'yes', 'description' => esc_html__( 'The Order Summary and Payment sections will remain in place while scrolling.', 'elementor-pro' ), 'frontend_available' => true, 'render_type' => 'none', 'condition' => [ 'checkout_layout' => 'two-column', ], ] ); $this->add_control( 'sticky_right_column_offset', [ 'label' => esc_html__( 'Offset', 'elementor-pro' ), 'type' => Controls_Manager::NUMBER, 'frontend_available' => true, 'conditions' => [ 'relation' => 'and', 'terms' => [ [ 'name' => 'sticky_right_column', 'operator' => '!==', 'value' => '', ], [ 'name' => 'checkout_layout', 'operator' => '=', 'value' => 'two-column', ], ], ], ] ); $this->end_controls_section(); if ( $this->is_wc_feature_active( 'checkout_login_reminder' ) ) { $this->add_checkout_login_reminder_controls(); } $this->start_controls_section( 'billing_details_section', [ 'label' => $this->is_wc_feature_active( 'ship_to_billing_address_only' ) ? esc_html__( 'Billing and Shipping Details', 'elementor-pro' ) : esc_html__( 'Billing Details', 'elementor-pro' ), ] ); $this->add_control( 'billing_details_section_title', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'placeholder' => $this->is_wc_feature_active( 'ship_to_billing_address_only' ) ? esc_html__( 'Billing and Shipping Details', 'elementor-pro' ) : esc_html__( 'Billing Details', 'elementor-pro' ), 'default' => $this->is_wc_feature_active( 'ship_to_billing_address_only' ) ? esc_html__( 'Billing and Shipping Details', 'elementor-pro' ) : esc_html__( 'Billing Details', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_responsive_control( 'billing_details_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], ], 'selectors' => [ '{{WRAPPER}}' => '--billing-details-title-alignment: {{VALUE}};', ], ] ); $repeater = new Repeater(); $repeater->start_controls_tabs( 'tabs', [ 'condition' => [ 'repeater_state' => '', ], ] ); $repeater->start_controls_tab( 'content_tab', [ 'label' => esc_html__( 'Content', 'elementor-pro' ), ] ); $repeater->add_control( 'label', [ 'label' => esc_html__( 'Label', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, ] ); $repeater->add_control( 'placeholder', [ 'label' => esc_html__( 'Placeholder', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, ] ); $repeater->end_controls_tab(); $repeater->start_controls_tab( 'advanced_tab', [ 'label' => esc_html__( 'Advanced', 'elementor-pro' ), ] ); $repeater->add_control( 'default', [ 'label' => esc_html__( 'Default Value', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], ] ); $repeater->end_controls_tab(); $repeater->end_controls_tabs(); $repeater->add_control( 'repeater_state', [ 'label' => esc_html__( 'Repeater State - hidden', 'elementor-pro' ), 'type' => Controls_Manager::HIDDEN, ] ); $repeater->add_control( 'locale_notice', [ 'raw' => __( 'Note: This content cannot be changed due to local regulations.', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'repeater_state' => 'locale', ], ] ); $repeater->add_control( 'from_billing_notice', [ 'raw' => __( 'Note: This label and placeholder are taken from the Billing section. You can change it there.', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'repeater_state' => 'from_billing', ], ] ); $this->add_control( 'billing_details_form_fields', [ 'label' => esc_html__( 'Form Items', 'elementor-pro' ), 'type' => Controls_Manager::REPEATER, 'fields' => $repeater->get_controls(), 'item_actions' => [ 'add' => false, 'duplicate' => false, 'remove' => false, 'sort' => false, ], 'default' => $this->get_billing_field_defaults(), 'title_field' => '{{{ label }}}', ] ); $this->end_controls_section(); if ( $this->is_wc_feature_active( 'shipping' ) && ! $this->is_wc_feature_active( 'ship_to_billing_address_only' ) ) { $this->add_shipping_controls(); } $this->start_controls_section( 'additional_information_section', [ 'label' => esc_html__( 'Additional Information', 'elementor-pro' ), ] ); $this->add_control( 'additional_information_active', [ 'label' => esc_html__( 'Additional Information', 'elementor-pro' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'elementor-pro' ), 'label_off' => esc_html__( 'Hide', 'elementor-pro' ), 'default' => 'yes', 'selectors' => [ '{{WRAPPER}}' => '--additional-information-display: block;', ], ] ); if ( $this->is_wc_feature_active( 'ship_to_billing_address_only' ) ) { $this->add_control( 'additional_information_section_title', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'placeholder' => esc_html__( 'Additional Information', 'elementor-pro' ), 'default' => esc_html__( 'Additional Information', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], 'condition' => [ 'additional_information_active!' => '', ], ] ); $this->add_responsive_control( 'additional_information_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], ], 'selectors' => [ '{{WRAPPER}}' => '--additional-fields-title-alignment: {{VALUE}};', ], 'condition' => [ 'additional_information_active!' => '', ], ] ); } $repeater = new Repeater(); $repeater->start_controls_tabs( 'additional_information_form_fields_tabs' ); $repeater->start_controls_tab( 'additional_information_form_fields_content_tab', [ 'label' => esc_html__( 'Content', 'elementor-pro' ), ] ); $repeater->add_control( 'label', [ 'label' => esc_html__( 'Label', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], ] ); $repeater->add_control( 'placeholder', [ 'label' => esc_html__( 'Placeholder', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], ] ); $repeater->end_controls_tab(); $repeater->start_controls_tab( 'additional_information_form_fields_advanced_tab', [ 'label' => esc_html__( 'Advanced', 'elementor-pro' ), ] ); $repeater->add_control( 'default', [ 'label' => esc_html__( 'Default Value', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], ] ); $repeater->end_controls_tab(); $repeater->end_controls_tabs(); $this->add_control( 'additional_information_form_fields', [ 'label' => esc_html__( 'Items', 'elementor-pro' ), 'type' => Controls_Manager::REPEATER, 'fields' => $repeater->get_controls(), 'item_actions' => [ 'add' => false, 'duplicate' => false, 'remove' => false, 'sort' => false, ], 'default' => [ [ 'field_key' => 'order_comments', 'field_label' => esc_html__( 'Order Notes', 'elementor-pro' ), 'label' => esc_html__( 'Order Notes', 'elementor-pro' ), 'placeholder' => esc_html__( 'Notes about your order, e.g. special notes for delivery.', 'elementor-pro' ), ], ], 'title_field' => '{{{ label }}}', 'condition' => [ 'additional_information_active!' => '', ], ] ); $this->end_controls_section(); if ( $this->is_wc_feature_active( 'signup_and_login_from_checkout' ) ) { $this->add_signup_and_login_from_checkout_controls(); } $this->start_controls_section( 'order_summary_section', [ 'label' => esc_html__( 'Your Order', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_section_title', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Your Order', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_responsive_control( 'order_summary_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], ], 'selectors' => [ '{{WRAPPER}}' => '--order-review-title-alignment: {{VALUE}};', ], ] ); $this->end_controls_section(); if ( $this->is_wc_feature_active( 'coupons' ) ) { $this->add_coupon_controls(); } $this->start_controls_section( 'payment_section', [ 'label' => esc_html__( 'Payment', 'elementor-pro' ), ] ); $this->add_control( 'terms_conditions_heading', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Terms & Conditions', 'elementor-pro' ), ] ); $this->add_control( 'terms_conditions_message_text', [ 'label' => esc_html__( 'Message', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'label_block' => true, 'default' => esc_html__( 'I have read and agree to the website', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_control( 'terms_conditions_link_text', [ 'label' => esc_html__( 'Link Text', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'label_block' => true, 'default' => esc_html__( 'terms and conditions', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_control( 'purchase_buttom_heading', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Purchase Button', 'elementor-pro' ), ] ); $this->add_responsive_control( 'purchase_button_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], 'justify' => [ 'title' => esc_html__( 'Justify', 'elementor-pro' ), 'icon' => 'eicon-text-align-justify', ], ], 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout' => '{{VALUE}}', ], 'selectors_dictionary' => [ 'start' => '--place-order-title-alignment: flex-start; --purchase-button-width: fit-content;', 'center' => '--place-order-title-alignment: center; --purchase-button-width: fit-content;', 'end' => '--place-order-title-alignment: flex-end; --purchase-button-width: fit-content;', 'justify' => '--place-order-title-alignment: stretch; --purchase-button-width: 100%;', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_style', [ 'label' => esc_html__( 'Sections', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_control( 'sections_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'section_normal_box_shadow', 'selector' => $this->get_main_woocommerce_sections_selectors(), ] ); $this->add_control( 'sections_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}}' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'sections_border_width', [ 'label' => esc_html__( 'Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ $this->get_main_woocommerce_sections_selectors() => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'sections_border_type!' => 'none', ], ] ); $this->add_control( 'sections_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-border-color: {{VALUE}};', ], 'condition' => [ 'sections_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'sections_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'sections_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', // move the 'Ship to a different address?' checkbox '{{WRAPPER}} .woocommerce-shipping-fields' => '--shipping-heading-padding-start: {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'sections_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_typography', [ 'label' => esc_html__( 'Typography', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_control( 'sections_typography', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Titles', 'elementor-pro' ), ] ); $this->add_control( 'sections_title_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_titles_typography', 'selector' => $this->get_main_woocommerce_sections_title_selectors(), ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'sections_titles_text_shadow', 'selector' => $this->get_main_woocommerce_sections_title_selectors(), ] ); $this->add_responsive_control( 'sections_title_spacing', [ 'label' => esc_html__( 'Spacing', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--sections-title-spacing: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'sections_secondary_typography', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Secondary Titles', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'sections_secondary_title_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-secondary-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_secondary_titles_typography', 'selector' => '{{WRAPPER}} .e-checkout-secondary-title', ] ); $this->add_responsive_control( 'sections_secondary_title_spacing', [ 'label' => esc_html__( 'Spacing', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--sections-secondary-title-spacing: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'sections_descriptions_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Descriptions', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'sections_descriptions_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-descriptions-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_descriptions_typography', 'selector' => '{{WRAPPER}} .e-description', ] ); $this->add_responsive_control( 'sections_descriptions_spacing', [ 'label' => esc_html__( 'Spacing', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--sections-descriptions-spacing: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'sections_messages_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Messages', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'sections_messages_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-messages-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_messages_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout #payment .payment_box, {{WRAPPER}} .woocommerce-privacy-policy-text p, {{WRAPPER}} .e-checkout-message', ] ); $this->add_control( 'sections_checkboxes_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Checkboxes', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'sections_checkboxes_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-checkboxes-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_checkboxes_typography', 'selector' => '{{WRAPPER}} .woocommerce-form__label-for-checkbox span', ] ); $this->add_control( 'sections_radio_buttons_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Radio Buttons', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'sections_radio_buttons_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--sections-radio-buttons-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sections_radio_buttons_typography', 'selector' => '{{WRAPPER}} .wc_payment_method label, {{WRAPPER}} #shipping_method li label', ] ); // Links $this->add_control( 'sections_links_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Links', 'elementor-pro' ), 'separator' => 'before', ] ); $this->start_controls_tabs( 'links_colors' ); $this->start_controls_tab( 'links_normal_colors', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'links_normal_color', [ 'label' => esc_html__( 'Link Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--links-normal-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'links_hover_colors', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'links_hover_color', [ 'label' => esc_html__( 'Link Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--links-hover-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_forms', [ 'label' => esc_html__( 'Forms', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'forms_columns_gap', [ 'label' => esc_html__( 'Columns Gap', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--forms-columns-gap-padding: calc( {{SIZE}}{{UNIT}}/2 ); --forms-columns-gap-margin: calc( -{{SIZE}}{{UNIT}}/2 );', ], ] ); $this->add_responsive_control( 'forms_rows_gap', [ 'label' => esc_html__( 'Rows Gap', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--forms-rows-gap: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'forms_label_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Labels', 'elementor-pro' ), ] ); $this->add_control( 'forms_label_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--forms-labels-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'forms_label_typography', 'selector' => '{{WRAPPER}} .woocommerce-billing-fields .form-row label, {{WRAPPER}} .woocommerce-shipping-fields .form-row label, {{WRAPPER}} .woocommerce-additional-fields .form-row label, {{WRAPPER}} .e-woocommerce-login-anchor .form-row label, {{WRAPPER}} .e-coupon-anchor-description', ] ); $this->add_responsive_control( 'forms_label_spacing', [ 'label' => esc_html__( 'Spacing', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--forms-label-spacing: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'forms_field_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Fields', 'elementor-pro' ), ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'forms_field_typography', 'selector' => '{{WRAPPER}} #customer_details .input-text, {{WRAPPER}} #customer_details .form-row textarea, {{WRAPPER}} #customer_details .form-row select, {{WRAPPER}} .e-woocommerce-login-anchor .input-text, {{WRAPPER}} #coupon_code, {{WRAPPER}} ::placeholder, {{WRAPPER}} .select2-container--default .select2-selection--single, .select2-results__option', ] ); $this->start_controls_tabs( 'forms_fields_styles' ); $this->start_controls_tab( 'forms_fields_normal_styles', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'forms_fields_normal_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--forms-fields-normal-color: {{VALUE}};', '.e-woo-select2-wrapper .select2-results__option' => 'color: {{VALUE}};', // style select2 arrow '{{WRAPPER}} .select2-container--default .select2-selection--single .select2-selection__arrow b' => 'border-color: {{VALUE}} transparent transparent transparent;', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'forms_fields_normal_background', 'selector' => '{{WRAPPER}} .woocommerce #customer_details .form-row .input-text, {{WRAPPER}} .woocommerce #customer_details .form-row textarea, {{WRAPPER}} .woocommerce form #customer_details select, {{WRAPPER}} .woocommerce .e-woocommerce-login-anchor .form-row .input-text, {{WRAPPER}} #coupon_code, {{WRAPPER}} .select2-container--default .select2-selection--single, {{WRAPPER}} .woocommerce-checkout #payment .payment_methods .payment_box', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'forms_fields_normal_box_shadow', 'selector' => '{{WRAPPER}} #customer_details .input-text, {{WRAPPER}} #customer_details .form-row textarea, {{WRAPPER}} .woocommerce form #customer_details select, {{WRAPPER}} .e-woocommerce-login-anchor .input-text, {{WRAPPER}} #coupon_code, {{WRAPPER}} .select2-container--default .select2-selection--single', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'forms_fields_focus_styles', [ 'label' => esc_html__( 'Focus', 'elementor-pro' ), ] ); $this->add_control( 'forms_fields_focus_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--forms-fields-focus-color: {{VALUE}}', '.e-woo-select2-wrapper .select2-results__option:focus' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'forms_fields_focus_background', 'selector' => '{{WRAPPER}} .woocommerce #customer_details .form-row .input-text:focus, {{WRAPPER}} .woocommerce #customer_details .form-row textarea:focus, {{WRAPPER}} #customer_details select:focus, {{WRAPPER}} .woocommerce .e-woocommerce-login-anchor .form-row .input-text:focus, {{WRAPPER}} #coupon_code:focus, {{WRAPPER}} .select2-container--default .select2-selection--single:focus', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'forms_fields_focus_box_shadow', 'selector' => '{{WRAPPER}} #customer_details .input-text:focus, {{WRAPPER}} #customer_details textarea:focus, {{WRAPPER}} #customer_details select:focus, {{WRAPPER}} .e-woocommerce-login-anchor .input-text:focus, {{WRAPPER}} #coupon_code:focus, {{WRAPPER}} .select2-container--default .select2-selection--single:focus', ] ); $this->add_control( 'forms_fields_focus_border_color', [ 'label' => esc_html__( 'Border Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce #customer_details .form-row .input-text:focus, {{WRAPPER}} .woocommerce #customer_details .form-row textarea:focus, {{WRAPPER}} #customer_details select:focus, {{WRAPPER}} .woocommerce .e-woocommerce-login-anchor .form-row .input-text:focus, {{WRAPPER}} #coupon_code:focus, {{WRAPPER}} .select2-container--default .select2-selection--single:focus' => 'border-color: {{VALUE}}', ], 'condition' => [ 'forms_fields_border_border!' => '', ], ] ); $this->add_control( 'forms_fields_focus_transition_duration', [ 'label' => esc_html__( 'Transition Duration', 'elementor-pro' ) . ' (ms)', 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 3000, 'step' => 100, ], ], 'selectors' => [ '{{WRAPPER}}' => '--forms-fields-focus-transition-duration: {{SIZE}}ms', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'forms_fields_border', 'selector' => '{{WRAPPER}} .woocommerce #customer_details .form-row .input-text, {{WRAPPER}} .woocommerce #customer_details .form-row textarea, {{WRAPPER}} .woocommerce form #customer_details select, {{WRAPPER}} .woocommerce .e-woocommerce-login-anchor .form-row .input-text, {{WRAPPER}} #coupon_code, {{WRAPPER}} .select2-container--default .select2-selection--single', 'separator' => 'before', ] ); $this->add_responsive_control( 'forms_fields_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--forms-fields-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'forms_fields_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--forms-fields-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', // style select2 '{{WRAPPER}} .select2-container--default .select2-selection--single .select2-selection__rendered' => 'line-height: calc( ({{TOP}}{{UNIT}}*2) + 16px ); padding-left: {{LEFT}}{{UNIT}}; padding-right: {{RIGHT}}{{UNIT}};', '{{WRAPPER}} .select2-container--default .select2-selection--single .select2-selection__arrow' => 'height: calc( ({{TOP}}{{UNIT}}*2) + 16px ); right: {{RIGHT}}{{UNIT}};', '{{WRAPPER}} .select2-container--default .select2-selection--single' => 'height: auto;', ], 'separator' => 'after', ] ); $this->add_control( 'forms_button_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Button', 'elementor-pro' ), ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'forms_button_typography', 'selector' => '{{WRAPPER}} .woocommerce-button', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'forms_button_text_shadow', 'selector' => '{{WRAPPER}} .woocommerce-button', ] ); $this->start_controls_tabs( 'forms_buttons_styles' ); $this->start_controls_tab( 'forms_buttons_normal_styles', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'forms_buttons_normal_text_color', [ 'label' => esc_html__( 'Text Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--forms-buttons-normal-text-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'forms_buttons_normal_background', 'selector' => '{{WRAPPER}} .woocommerce-button', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'forms_buttons_normal_box_shadow', 'selector' => '{{WRAPPER}} .woocommerce-button', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'forms_buttons_hover_styles', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'forms_buttons_hover_text_color', [ 'label' => esc_html__( 'Text Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--forms-buttons-hover-text-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'forms_buttons_hover_background', 'selector' => '{{WRAPPER}} .woocommerce-button:hover', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'forms_buttons_focus_box_shadow', 'selector' => '{{WRAPPER}} .woocommerce-button:hover', ] ); $this->add_control( 'forms_buttons_hover_border_color', [ 'label' => esc_html__( 'Border Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-apply-coupon:hover, {{WRAPPER}} .woocommerce-form-login__submit:hover' => 'border-color: {{VALUE}}', ], 'condition' => [ 'forms_buttons_border_type!' => 'none', ], ] ); $this->add_control( 'forms_buttons_hover_transition_duration', [ 'label' => esc_html__( 'Transition Duration', 'elementor-pro' ) . ' (ms)', 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 3000, 'step' => 100, ], ], 'selectors' => [ '{{WRAPPER}}' => '--forms-buttons-hover-transition-duration: {{SIZE}}ms', ], ] ); $this->add_control( 'forms_buttons_hover_animation', [ 'label' => esc_html__( 'Hover Animation', 'elementor-pro' ), 'type' => Controls_Manager::HOVER_ANIMATION, ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_control( 'forms_buttons_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}}' => '--forms-buttons-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'forms_buttons_border_width', [ 'label' => esc_html__( 'Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-apply-coupon, {{WRAPPER}} .woocommerce-form-login__submit' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'forms_buttons_border_type!' => 'none', ], ] ); $this->add_control( 'forms_buttons_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} ' => '--forms-buttons-border-color: {{VALUE}};', ], 'condition' => [ 'forms_buttons_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'forms_buttons_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--forms-buttons-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'forms_buttons_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-button' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}; width: auto;', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_order_summary', [ 'label' => esc_html__( 'Order Summary', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'order_summary_rows_gap', [ 'label' => esc_html__( 'Rows Gap', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'range' => [ 'px' => [ 'max' => 100, ], 'em' => [ 'max' => 10, ], 'rem' => [ 'max' => 10, ], ], 'selectors' => [ '{{WRAPPER}}' => '--order-summary-rows-gap-top: calc( {{SIZE}}{{UNIT}}/2 ); --order-summary-rows-gap-bottom: calc( {{SIZE}}{{UNIT}}/2 );', ], ] ); $this->add_control( 'order_summary_items_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Items', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_items_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--order-summary-items-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_items_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout-review-order-table .cart_item td', ] ); $this->add_control( 'order_summary_variations_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Variations', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_variations_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--order-summary-variations-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_variations_typography', 'global' => [ 'default' => Global_Typography::TYPOGRAPHY_TEXT, ], 'selector' => '{{WRAPPER}} .product-name .variation', ] ); $this->add_control( 'order_summary_items_divider_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Dividers', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_items_divider_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--order-summary-items-divider-color: {{VALUE}};', ], ] ); $this->add_responsive_control( 'order_summary_items_divider_weight', [ 'label' => esc_html__( 'Weight', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--order-summary-items-divider-weight: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'order_summary_totals_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Titles & Totals', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_totals_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--order-summary-totals-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_totals_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout-review-order-table thead tr th, {{WRAPPER}} .woocommerce-checkout-review-order-table tfoot tr th, {{WRAPPER}} .woocommerce-checkout-review-order-table tfoot tr td', ] ); $this->add_control( 'order_summary_dividers_total_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Divider Total', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_totals_divider_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--order-summary-totals-divider-color: {{VALUE}};', ], ] ); $this->add_responsive_control( 'order_summary_totals_divider_weight', [ 'label' => esc_html__( 'Weight', 'elementor-pro' ), 'type' => Controls_Manager::SLIDER, 'size_units' => [ 'px', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--order-summary-totals-divider-weight: {{SIZE}}{{UNIT}};', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_purchase_button', [ 'label' => esc_html__( 'Purchase Button', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'purchase_button_typography', 'selector' => '{{WRAPPER}} .woocommerce #payment #place_order', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'purchase_button_text_shadow', 'selector' => '{{WRAPPER}} .woocommerce #payment #place_order', ] ); $this->start_controls_tabs( 'purchase_button_styles' ); $this->start_controls_tab( 'purchase_button_normal_styles', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'purchase_button_normal_text_color', [ 'label' => esc_html__( 'Text Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-normal-text-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'purchase_button_normal_background', 'selector' => '{{WRAPPER}} #payment #place_order', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'purchase_button_normal_box_shadow', 'selector' => '{{WRAPPER}} #place_order', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'purchase_button_hover_styles', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'purchase_button_hover_text_color', [ 'label' => esc_html__( 'Text Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-hover-text-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'purchase_button_hover_background', 'selector' => '{{WRAPPER}} #payment #place_order:hover', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'purchase_button_hover_box_shadow', 'selector' => '{{WRAPPER}} #place_order:hover', ] ); $this->add_control( 'purchase_button_hover_border_color', [ 'label' => esc_html__( 'Border Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-hover-border-color: {{VALUE}}', ], 'condition' => [ 'purchase_button_border_border!' => '', ], ] ); $this->add_control( 'purchase_button_hover_transition_duration', [ 'label' => esc_html__( 'Transition Duration', 'elementor-pro' ) . ' (ms)', 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 3000, 'step' => 100, ], ], 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-hover-transition-duration: {{SIZE}}ms', ], ] ); $this->add_control( 'purchase_button_hover_animation', [ 'label' => esc_html__( 'Hover Animation', 'elementor-pro' ), 'type' => Controls_Manager::HOVER_ANIMATION, 'frontend_available' => true, 'render_type' => 'template', ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'purchase_button_border', 'selector' => '{{WRAPPER}} #place_order', 'separator' => 'before', ] ); $this->add_responsive_control( 'purchase_button_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'purchase_button_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}}' => '--purchase-button-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}; --purchase-button-width: fit-content;', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_customize', [ 'label' => esc_html__( 'Customize', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $customize_options = []; if ( $this->is_wc_feature_active( 'checkout_login_reminder' ) ) { $customize_options += [ 'customize_returning_customer' => esc_html__( 'Returning Customer', 'elementor-pro' ), ]; } $customize_options += [ 'customize_billing_details' => esc_html__( 'Billing Details', 'elementor-pro' ), 'customize_additional_info' => esc_html__( 'Additional Information', 'elementor-pro' ), ]; if ( $this->is_wc_feature_active( 'shipping' ) ) { $customize_options += [ 'customize_shipping_address' => esc_html__( 'Shipping Address', 'elementor-pro' ), ]; } $customize_options += [ 'customize_order_summary' => esc_html__( 'Order Summary', 'elementor-pro' ), ]; if ( $this->is_wc_feature_active( 'coupons' ) ) { $customize_options += [ 'customize_coupon' => esc_html__( 'Coupon', 'elementor-pro' ), ]; } $customize_options += [ 'customize_payment' => esc_html__( 'Payment', 'elementor-pro' ), ]; $this->add_control( 'section_checkout_show_customize_elements', [ 'label' => esc_html__( 'Select sections of the checkout to customize:', 'elementor-pro' ), 'type' => Controls_Manager::SELECT2, 'multiple' => true, 'options' => $customize_options, 'render_type' => 'ui', 'label_block' => true, ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_customize_returning_customer', [ 'label' => esc_html__( 'Customize: Returning Customer', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_returning_customer', ], ] ); $this->add_control( 'returning_customers_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_returning_customer_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'returning_customers_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .e-woocommerce-login-section', ] ); $this->add_control( 'returning_customers_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'returning_customers_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'returning_customers_border_type!' => 'none', ], ] ); $this->add_control( 'returning_customers_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-border-color: {{VALUE}};', ], 'condition' => [ 'returning_customers_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'returning_customers_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'returning_customers_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'returning_customers_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'returning_customers_secondary_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Secondary Title', 'elementor-pro' ), ] ); $this->add_control( 'returning_customers_secondary_title_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-form-login-toggle' => '--sections-secondary-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'returning_customers_content_typography', 'selector' => '{{WRAPPER}} .woocommerce-form-login-toggle', ] ); $this->add_control( 'returning_customers_description_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Description', 'elementor-pro' ), ] ); $this->add_control( 'returning_customers_description_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-nudge' => '--sections-descriptions-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'returning_customers_description_typography', 'selector' => '{{WRAPPER}} .e-woocommerce-login-nudge.e-description', ] ); $this->add_control( 'returning_customers_checkboxes_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Checkbox', 'elementor-pro' ), ] ); $this->add_control( 'returning_customers_checkboxes_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--sections-checkboxes-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'returning_customers_checkboxes_typography', 'selector' => '{{WRAPPER}} .e-woocommerce-login-section .woocommerce-form__label-for-checkbox span', ] ); $this->add_control( 'returning_customers_link_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Link', 'elementor-pro' ), ] ); $this->start_controls_tabs( 'returning_customers_links' ); $this->start_controls_tab( 'returning_customers_normal_links', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'returning_customers_normal_links_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--links-normal-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'returning_customers_hover_links', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'returning_customers_hover_links_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-login-section' => '--links-hover-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_customize_billing_details', [ 'label' => esc_html__( 'Customize: Billing Details', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_billing_details', ], ] ); $this->add_control( 'customize_billing_details_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_billing_details_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'billing_details_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .e-checkout__column-start .col2-set .col-1', ] ); $this->add_control( 'billing_details_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'billing_details_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-checkout__column-start #customer_details .col-1' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'billing_details_border_type!' => 'none', ], ] ); $this->add_control( 'billing_details_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-border-color: {{VALUE}}', ], 'condition' => [ 'billing_details_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'billing_details_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'billing_details_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'billing_details_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'billing_details_titles_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Title', 'elementor-pro' ), ] ); $this->add_control( 'billing_details_titles_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'billing_details_titles_typography', 'selector' => '{{WRAPPER}} .woocommerce-billing-fields h3', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'billing_details_titles_text_shadow', 'selector' => '{{WRAPPER}} .woocommerce-billing-fields h3', ] ); $this->add_control( 'billing_details_checkboxes_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Checkbox', 'elementor-pro' ), ] ); $this->add_control( 'billing_details_checkboxes_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .col2-set .col-1' => '--sections-checkboxes-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'billing_details_checkboxes_typography', 'selector' => '{{WRAPPER}} .col2-set .col-1 .woocommerce-form__label-for-checkbox span', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_customize_additional_info', [ 'label' => esc_html__( 'Customize: Additional Information', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_additional_info', ], ] ); $this->add_control( 'customize_additional_information_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_additional_information_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'additional_information_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .woocommerce-additional-fields', ] ); $this->add_control( 'additional_information_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'additional_information_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'additional_information_border_type!' => 'none', ], ] ); $this->add_control( 'additional_information_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-border-color: {{VALUE}};', ], 'condition' => [ 'additional_information_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'additional_information_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'additional_information_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'additional_information_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', '{{WRAPPER}}.e-checkout-layout-one-column .e-checkout__container' => 'grid-row-gap: {{BOTTOM}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'additional_information_titles_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Title', 'elementor-pro' ), ] ); $this->add_control( 'additional_information_titles_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-additional-fields' => '--sections-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'additional_information_titles_typography', 'selector' => '{{WRAPPER}} .woocommerce-additional-fields h3', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'additional_information_titles_text_shadow', 'selector' => '{{WRAPPER}} .woocommerce-additional-fields h3', ] ); $this->end_controls_section(); if ( $this->is_wc_feature_active( 'shipping' ) ) { $this->add_shipping_style_controls(); } if ( $this->is_wc_feature_active( 'coupons' ) ) { $this->add_coupons_style_controls(); } $this->start_controls_section( 'section_checkout_tabs_customize_order_summary', [ 'label' => esc_html__( 'Customize: Order Summary', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_order_summary', ], ] ); $this->add_control( 'customize_order_summary_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_order_summary_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'order_summary_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .e-checkout__order_review', ] ); $this->add_control( 'order_summary_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'order_summary_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'order_summary_border_type!' => 'none', ], ] ); $this->add_control( 'order_summary_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-border-color: {{VALUE}}', ], 'condition' => [ 'order_summary_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'order_summary_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'order_summary_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'order_summary_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'order_summary_titles_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Title', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_titles_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_titles_typography', 'selector' => '{{WRAPPER}} h3#order_review_heading', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'order_summary_titles_text_shadow', 'selector' => '{{WRAPPER}} h3#order_review_heading', ] ); $this->add_control( 'order_summary_descriptions_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Message', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_descriptions_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-descriptions-color: {{VALUE}}; --sections-messages-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_descriptions_typography', 'selector' => '{{WRAPPER}} .woocommerce-no-shipping-available-html.e-description, {{WRAPPER}} .woocommerce-no-shipping-available-html.e-checkout-message', ] ); $this->add_control( 'order_summary_radios_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Radio Button', 'elementor-pro' ), ] ); $this->add_control( 'order_summary_radios_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-checkout__order_review' => '--sections-radio-buttons-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'order_summary_radio_typography', 'selector' => '{{WRAPPER}} .woocommerce .e-checkout__order_review ul#shipping_method li label', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_checkout_tabs_customize_payment', [ 'label' => esc_html__( 'Customize: Payment', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_payment', ], ] ); $this->add_control( 'customize_payment_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_payment_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'payment_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .woocommerce-checkout #payment', ] ); $this->add_control( 'payment_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'payment_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'payment_border_type!' => 'none', ], ] ); $this->add_control( 'payment_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-border-color: {{VALUE}};', ], 'condition' => [ 'payment_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'payment_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'payment_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'payment_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout #payment' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'payment_info_box_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Info Box', 'elementor-pro' ), ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'payment_info_box_title_background', 'selector' => '{{WRAPPER}} .woocommerce-checkout #payment .payment_methods .payment_box', ] ); $this->add_control( 'payment_description_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Description', 'elementor-pro' ), ] ); $this->add_control( 'payment_description_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout-payment' => '--sections-descriptions-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'payment_description_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout-payment .e-description', ] ); $this->add_control( 'payment_messages_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Message', 'elementor-pro' ), ] ); $this->add_control( 'payment_messages_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout-payment' => '--sections-messages-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'payment_messages_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout #payment .payment_box, {{WRAPPER}} .woocommerce-privacy-policy-text p', ] ); $this->add_control( 'payment_checkboxes_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Checkbox', 'elementor-pro' ), ] ); $this->add_control( 'payment_checkboxes_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-terms-and-conditions-wrapper' => '--sections-checkboxes-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'payment_checkboxes_typography', 'selector' => '{{WRAPPER}} .woocommerce-terms-and-conditions-wrapper .woocommerce-form__label-for-checkbox span', ] ); $this->add_control( 'payment_radio_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Radio Button', 'elementor-pro' ), ] ); $this->add_control( 'payment_radio_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout-payment' => '--sections-radio-buttons-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'payment_radio_typography', 'selector' => '{{WRAPPER}} .woocommerce-checkout-payment .wc_payment_method label', ] ); $this->add_control( 'payment_links_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Links', 'elementor-pro' ), ] ); $this->start_controls_tabs( 'payment_colors' ); $this->start_controls_tab( 'payment_normal_colors', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'payment_normal_color', [ 'label' => esc_html__( 'Link Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout-payment' => '--links-normal-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'payment_hover_colors', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'payment_hover_color', [ 'label' => esc_html__( 'Link Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-checkout-payment' => '--links-hover-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } private function add_checkout_login_reminder_controls() { $this->start_controls_section( 'returning_customer_heading', [ 'label' => esc_html__( 'Returning Customer', 'elementor-pro' ), ] ); $this->add_control( 'returning_customer_section_title', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Returning customer?', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_control( 'returning_customer_link_text', [ 'label' => esc_html__( 'Link Text', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Click here to login', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->add_responsive_control( 'returning_customer_title_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], ], 'selectors' => [ '{{WRAPPER}}' => '--login-title-alignment: {{VALUE}};', ], ] ); $this->add_responsive_control( 'login_button_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Login Button', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_responsive_control( 'login_button_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], 'justify' => [ 'title' => esc_html__( 'Justify', 'elementor-pro' ), 'icon' => 'eicon-text-align-justify', ], ], 'selectors' => [ '{{WRAPPER}} .e-login-wrap' => '{{VALUE}}', ], 'selectors_dictionary' => [ 'start' => '--login-button-alignment: start; --login-button-width: 35%;', 'center' => '--login-button-alignment: center; --login-button-width: 35%;', 'end' => '--login-button-alignment: end; --login-button-width: 35%;', 'justify' => '--login-button-alignment: center; --login-button-width: 100%;', ], ] ); $this->add_control( 'login_button_alignment_note', [ 'raw' => esc_html__( 'Note: This control will only affect screen sizes Tablet and below', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', ] ); $this->end_controls_section(); } private function add_shipping_controls() { $this->start_controls_section( 'shipping_details_section', [ 'label' => esc_html__( 'Shipping Details', 'elementor-pro' ), ] ); $this->add_control( 'shipping_details_section_title', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Ship to a different address?', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $repeater = new Repeater(); $repeater->add_control( 'repeater_state', [ 'label' => esc_html__( 'Repeater State - hidden', 'elementor-pro' ), 'type' => Controls_Manager::HIDDEN, ] ); $repeater->add_control( 'label_placeholder_notification', [ 'raw' => __( 'Note: This label and placeholder are taken from the Billing section. You can change it there.', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'repeater_state' => 'from_billing', ], ] ); $repeater->start_controls_tabs( 'tabs', [ 'condition' => [ 'repeater_state' => '', ], ] ); $repeater->start_controls_tab( 'content_tab', [ 'label' => esc_html__( 'Content', 'elementor-pro' ), ] ); $repeater->add_control( 'label', [ 'label' => esc_html__( 'Label', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, ] ); $repeater->add_control( 'placeholder', [ 'label' => esc_html__( 'Placeholder', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, ] ); $repeater->end_controls_tab(); $repeater->start_controls_tab( 'advanced_tab', [ 'label' => esc_html__( 'Advanced', 'elementor-pro' ), ] ); $repeater->add_control( 'default', [ 'label' => esc_html__( 'Default Value', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], ] ); $repeater->end_controls_tab(); $repeater->end_controls_tabs(); $repeater->add_control( 'locale_notice', [ 'raw' => __( 'Note: This content cannot be changed due to local regulations.', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'repeater_state' => 'locale', ], ] ); $repeater->add_control( 'from_billing_notice', [ 'raw' => __( 'Note: This label and placeholder are taken from the Billing section. You can change it there.', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'repeater_state' => 'from_billing', ], ] ); $this->add_control( 'shipping_details_form_fields', [ 'label' => esc_html__( 'Form Items', 'elementor-pro' ), 'type' => Controls_Manager::REPEATER, 'fields' => $repeater->get_controls(), 'item_actions' => [ 'add' => false, 'duplicate' => false, 'remove' => false, 'sort' => false, ], 'default' => $this->get_shipping_field_defaults(), 'title_field' => '{{{ label }}}', ] ); $this->end_controls_section(); } private function add_signup_and_login_from_checkout_controls() { $this->start_controls_section( 'create_account_section', [ 'label' => esc_html__( 'Create an Account', 'elementor-pro' ), ] ); $this->add_control( 'create_account_text', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Create an account?', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], ] ); $this->end_controls_section(); } private function add_coupon_controls() { $this->start_controls_section( 'coupon_section', [ 'label' => esc_html__( 'Coupon', 'elementor-pro' ), ] ); $this->add_control( 'coupon_section_display', [ 'label' => esc_html__( 'Coupon', 'elementor-pro' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'elementor-pro' ), 'label_off' => esc_html__( 'Hide', 'elementor-pro' ), 'default' => 'yes', ] ); $this->add_control( 'coupon_section_title_text', [ 'label' => esc_html__( 'Section Title', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Have a coupon?', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->add_control( 'coupon_section_title_link_text', [ 'label' => esc_html__( 'Link Text', 'elementor-pro' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Click here to enter your coupon code', 'elementor-pro' ), 'dynamic' => [ 'active' => true, ], 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->add_responsive_control( 'coupon_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], ], 'selectors' => [ '{{WRAPPER}}' => '--coupon-title-alignment: {{VALUE}};', ], 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->add_responsive_control( 'coupon_button_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Apply Button', 'elementor-pro' ), 'separator' => 'before', 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->add_responsive_control( 'coupon_button_alignment', [ 'label' => esc_html__( 'Alignment', 'elementor-pro' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__( 'Start', 'elementor-pro' ), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'elementor-pro' ), 'icon' => 'eicon-text-align-center', ], 'end' => [ 'title' => esc_html__( 'End', 'elementor-pro' ), 'icon' => 'eicon-text-align-right', ], 'justify' => [ 'title' => esc_html__( 'Justify', 'elementor-pro' ), 'icon' => 'eicon-text-align-justify', ], ], 'selectors' => [ '{{WRAPPER}} .coupon-container-grid' => '{{VALUE}}', ], 'selectors_dictionary' => [ 'start' => '--coupon-button-alignment: start;', 'center' => '--coupon-button-alignment: center;', 'end' => '--coupon-button-alignment: end;', 'justify' => '--coupon-button-alignment: justify; --coupon-button-width: 100%;', ], 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->add_control( 'coupon_button_alignment_note', [ 'raw' => esc_html__( 'Note: This control will only affect screen sizes Tablet and below', 'elementor-pro' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-descriptor', 'condition' => [ 'coupon_section_display' => 'yes', ], ] ); $this->end_controls_section(); } private function add_shipping_style_controls() { $this->start_controls_section( 'section_checkout_tabs_customize_shipping_address', [ 'label' => esc_html__( 'Customize: Shipping Address', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_shipping_address', ], ] ); $this->add_control( 'shipping_address_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_shipping_address_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'shipping_address_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address', ] ); $this->add_control( 'shipping_address_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'shipping_address_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'shipping_address_border_type!' => 'none', ], ] ); $this->add_control( 'shipping_address_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-border-color: {{VALUE}}', ], 'condition' => [ 'shipping_address_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'shipping_address_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'shipping_address_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'shipping_address_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields .shipping_address' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'shipping_address_checkboxes_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Checkboxes', 'elementor-pro' ), 'separator' => 'before', ] ); $this->add_control( 'shipping_address_checkboxes_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .woocommerce-shipping-fields' => '--sections-checkboxes-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'shipping_address_checkboxes_typography', 'selector' => '{{WRAPPER}} .woocommerce-shipping-fields .woocommerce-form__label-for-checkbox span', ] ); $this->end_controls_section(); } private function add_coupons_style_controls() { $this->start_controls_section( 'section_checkout_tabs_customize_coupon', [ 'label' => esc_html__( 'Customize: Coupon', 'elementor-pro' ), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'section_checkout_show_customize_elements' => 'customize_coupon', ], ] ); $this->add_control( 'customize_coupon_section_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Section', 'elementor-pro' ), ] ); $this->add_control( 'customize_coupon_background_color', [ 'label' => esc_html__( 'Background Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-background-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'coupon_section_normal_box_shadow', 'selector' => '{{WRAPPER}} .e-coupon-box', ] ); $this->add_control( 'coupon_border_type', [ 'label' => esc_html__( 'Border Type', 'elementor-pro' ), 'type' => Controls_Manager::SELECT, 'options' => $this->get_custom_border_type_options(), 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-border-type: {{VALUE}};', ], 'separator' => 'before', ] ); $this->add_responsive_control( 'coupon_border_width', [ 'label' => esc_html__( 'Border Width', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'coupon_border_type!' => 'none', ], ] ); $this->add_control( 'coupon_border_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-border-color: {{VALUE}};', ], 'condition' => [ 'coupon_border_type!' => 'none', ], ] ); $this->add_responsive_control( 'coupon_border_radius', [ 'label' => esc_html__( 'Border Radius', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'coupon_padding', [ 'label' => esc_html__( 'Padding', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'coupon_margin', [ 'label' => esc_html__( 'Margin', 'elementor-pro' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ], 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--sections-margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'separator' => 'after', ] ); $this->add_control( 'coupon_secondary_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Secondary Title', 'elementor-pro' ), ] ); $this->add_control( 'coupon_secondary_title_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-woocommerce-coupon-nudge' => '--sections-secondary-title-color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'coupon_content_typography', 'selector' => '{{WRAPPER}} .e-woocommerce-coupon-nudge.e-checkout-secondary-title', ] ); $this->add_control( 'coupon_link_title', [ 'type' => Controls_Manager::HEADING, 'label' => esc_html__( 'Link', 'elementor-pro' ), ] ); $this->start_controls_tabs( 'coupon_links' ); $this->start_controls_tab( 'coupon_normal_links', [ 'label' => esc_html__( 'Normal', 'elementor-pro' ), ] ); $this->add_control( 'coupon_normal_links_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--links-normal-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'coupon_hover_links', [ 'label' => esc_html__( 'Hover', 'elementor-pro' ), ] ); $this->add_control( 'coupon_hover_links_color', [ 'label' => esc_html__( 'Color', 'elementor-pro' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .e-coupon-box' => '--links-hover-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } /** * Get Billing Field Defaults * * Get defaults used for the billing details repeater control. * * @since 3.5.0 * * @return array */ private function get_billing_field_defaults() { $fields = [ 'billing_first_name' => [ 'label' => esc_html__( 'First Name', 'elementor-pro' ), 'repeater_state' => '', ], 'billing_last_name' => [ 'label' => esc_html__( 'Last Name', 'elementor-pro' ), 'repeater_state' => '', ], 'billing_company' => [ 'label' => esc_html__( 'Company Name', 'elementor-pro' ), 'repeater_state' => '', ], 'billing_country' => [ 'label' => esc_html__( 'Country / Region', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'billing_address_1' => [ 'label' => esc_html__( 'Street Address', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'billing_postcode' => [ 'label' => esc_html__( 'Post Code', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'billing_city' => [ 'label' => esc_html__( 'Town / City', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'billing_state' => [ 'label' => esc_html__( 'State', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'billing_phone' => [ 'label' => esc_html__( 'Phone', 'elementor-pro' ), 'repeater_state' => '', ], 'billing_email' => [ 'label' => esc_html__( 'Email Address', 'elementor-pro' ), 'repeater_state' => '', ], ]; return $this->reformat_address_field_defaults( $fields ); } /** * Get Shipping Field Defaults * * Get defaults used for the shipping details repeater control. * * @since 3.5.0 * * @return array */ private function get_shipping_field_defaults() { $fields = [ 'shipping_first_name' => [ 'label' => esc_html__( 'First Name', 'elementor-pro' ), 'repeater_state' => '', ], 'shipping_last_name' => [ 'label' => esc_html__( 'Last Name', 'elementor-pro' ), 'repeater_state' => '', ], 'shipping_company' => [ 'label' => esc_html__( 'Company Name', 'elementor-pro' ), 'repeater_state' => '', ], 'shipping_country' => [ 'label' => esc_html__( 'Country / Region', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'shipping_address_1' => [ 'label' => esc_html__( 'Street Address', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'shipping_postcode' => [ 'label' => esc_html__( 'Post Code', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'shipping_city' => [ 'label' => esc_html__( 'Town / City', 'elementor-pro' ), 'repeater_state' => 'locale', ], 'shipping_state' => [ 'label' => esc_html__( 'State', 'elementor-pro' ), 'repeater_state' => 'locale', ], ]; return $this->reformat_address_field_defaults( $fields ); } /** * Reformat Address Field Defaults * * Used with the `get_..._field_defaults()` methods. * Takes the address array and converts it into the format expected by the repeater controls. * * @since 3.5.0 * * @param $address * @return array */ private function reformat_address_field_defaults( $address ) { $defaults = []; foreach ( $address as $key => $value ) { $defaults[] = [ 'field_key' => $key, 'field_label' => $value['label'], 'label' => $value['label'], 'placeholder' => $value['label'], 'repeater_state' => $value['repeater_state'], ]; } return $defaults; } /** * Get Main Woocommerce Sections Selectors * * Get all the 'Sections' selectors. There are numerous controls that need these selectors so it was easier * to consolidate them into one function. Especially when updates need to be made. * * @since 3.5.0 * * @return string */ private function get_main_woocommerce_sections_selectors() { $selector = '{{WRAPPER}} .e-woocommerce-login-section, {{WRAPPER}} .woocommerce-checkout #customer_details .col-1, {{WRAPPER}} .woocommerce-additional-fields, {{WRAPPER}} .e-checkout__order_review, {{WRAPPER}} .e-coupon-box, {{WRAPPER}} .woocommerce-checkout #payment'; if ( $this->is_wc_feature_active( 'shipping' ) ) { $selector .= ', {{WRAPPER}} .woocommerce-shipping-fields .shipping_address'; } return $selector; } /** * Get Main Woocommerce Sections Title Selectors * * Get all the 'Title' selectors. There are numerous controls that need these selectors so it was easier to * consolidate them into one function. Especially when updates need to be made. * * @since 3.5.0 * * @return string */ private function get_main_woocommerce_sections_title_selectors() { return '{{WRAPPER}} h3#order_review_heading, {{WRAPPER}} .woocommerce-billing-fields h3, {{WRAPPER}} .woocommerce-additional-fields h3'; } /** * Init Gettext Modifications * * Sets the `$gettext_modifications` property used with the `filter_gettext()` in the extended Base_Widget. * * @since 3.5.0 */ protected function init_gettext_modifications() { $instance = $this->get_settings_for_display(); $this->gettext_modifications = [ 'Billing details' => isset( $instance['billing_details_section_title'] ) ? $instance['billing_details_section_title'] : '', 'Billing & Shipping' => isset( $instance['billing_details_section_title'] ) ? $instance['billing_details_section_title'] : '', 'Ship to a different address?' => isset( $instance['shipping_details_section_title'] ) ? $instance['shipping_details_section_title'] : '', 'Additional information' => isset( $instance['additional_information_section_title'] ) ? $instance['additional_information_section_title'] : '', 'Your order' => isset( $instance['order_summary_section_title'] ) ? $instance['order_summary_section_title'] : '', 'Have a coupon?' => isset( $instance['coupon_section_title_text'] ) ? $instance['coupon_section_title_text'] : '', 'Click here to enter your coupon code' => isset( $instance['coupon_section_title_link_text'] ) ? $instance['coupon_section_title_link_text'] : '', 'Returning customer?' => isset( $instance['returning_customer_section_title'] ) ? $instance['returning_customer_section_title'] : '', 'Click here to login' => isset( $instance['returning_customer_link_text'] ) ? $instance['returning_customer_link_text'] : '', 'Create an account?' => isset( $instance['create_account_text'] ) ? $instance['create_account_text'] : '', ]; } /** * WooCommerce Terms and Conditions Checkbox Text. * * WooCommerce filter is used to apply widget settings to Checkout Terms & Conditions text and link text. * * @since 3.5.0 * * @param string $text * @return string */ public function woocommerce_terms_and_conditions_checkbox_text( $text ) { $instance = $this->get_settings_for_display(); if ( ! isset( $instance['terms_conditions_message_text'] ) || ! isset( $instance['terms_conditions_link_text'] ) ) { return $text; } $message = $instance['terms_conditions_message_text']; $link = $instance['terms_conditions_link_text']; $terms_page_id = wc_terms_and_conditions_page_id(); if ( $terms_page_id ) { $message .= ' <a href="' . esc_url( get_permalink( $terms_page_id ) ) . '" class="woocommerce-terms-and-conditions-link" target="_blank">' . $link . '</a>'; } return $message; } /** * Modify Form Field. * * WooCommerce filter is used to apply widget settings to the Checkout forms address fields * from the Billing and Shipping Details widget sections, e.g. label, placeholder, default. * * @since 3.5.0 * * @param array $args * @param string $key * @param string $value * @return array */ public function modify_form_field( $args, $key, $value ) { $reformatted_form_fields = $this->get_reformatted_form_fields(); // Check if we need to modify the args of this form field. if ( isset( $reformatted_form_fields[ $key ] ) ) { $apply_fields = [ 'label', 'placeholder', 'default', ]; foreach ( $apply_fields as $field ) { if ( ! empty( $reformatted_form_fields[ $key ][ $field ] ) ) { $args[ $field ] = $reformatted_form_fields[ $key ][ $field ]; } } } return $args; } /** * Get Reformatted Form Fields. * * Combines the 3 relevant repeater settings arrays into a one level deep associative array * with the keys that match those that WooCommerce uses for its form fields. * * The result is cached so the conversion only ever happens once. * * @since 3.5.0 * * @return array */ private function get_reformatted_form_fields() { if ( ! isset( $this->reformatted_form_fields ) ) { $instance = $this->get_settings_for_display(); // Reformat form repeater field into one usable array. $repeater_fields = [ 'billing_details_form_fields', 'shipping_details_form_fields', 'additional_information_form_fields', ]; $this->reformatted_form_fields = []; // Apply other modifications to inputs. foreach ( $repeater_fields as $repeater_field ) { if ( isset( $instance[ $repeater_field ] ) ) { foreach ( $instance[ $repeater_field ] as $item ) { if ( ! isset( $item['field_key'] ) ) { continue; } $this->reformatted_form_fields[ $item['field_key'] ] = $item; } } } } return $this->reformatted_form_fields; } /** * Render Woocommerce Checkout Login Form * * A custom function to render a login form on the Checkout widget. The default WC Login form * was removed in this file's render() method with: * remove_action( 'woocommerce_before_checkout_form', 'woocommerce_checkout_login_form' ); * * And then we are adding this form into the widget at the * 'woocommerce_checkout_before_customer_details' hook. * * We are doing this in order to match the placement of the Login form to the provided design. * WC places these forms ABOVE the checkout form section where as we needed to place them inside the * checkout form section. So we removed the default login form and added our own form. * * @since 3.5.0 */ private function render_woocommerce_checkout_login_form() { $settings = $this->get_settings_for_display(); $button_classes = [ 'woocommerce-button', 'button', 'woocommerce-form-login__submit', 'e-woocommerce-form-login-submit' ]; if ( $settings['forms_buttons_hover_animation'] ) { $button_classes[] = 'elementor-animation-' . $settings['forms_buttons_hover_animation']; } $this->add_render_attribute( 'button_login', [ 'class' => $button_classes, 'name' => 'login', 'type' => 'submit', ] ); ?> <div class="e-woocommerce-login-section"> <div class="elementor-woocommerce-login-messages"></div> <div class="woocommerce-form-login-toggle e-checkout-secondary-title"> <?php echo esc_html__( 'Returning customer?', 'elementor-pro' ) . ' <a href="#" class="e-show-login">' . esc_html__( 'Click here to login', 'elementor-pro' ) . '</a>'; ?> </div> <div class="e-woocommerce-login-anchor" style="display:none;"> <p class="e-woocommerce-login-nudge e-description"><?php echo esc_html__( 'If you have shopped with us before, please enter your details below. If you are a new customer, please proceed to the Billing section.', 'elementor-pro' ); ?></p> <div class="e-login-wrap"> <div class="e-login-wrap-start"> <p class="form-row form-row-first"> <label for="username"><?php esc_html_e( 'Email', 'elementor-pro' ); ?> <span class="required">*</span></label> <input type="text" class="input-text" name="username" id="username" autocomplete="username" /> </p> <p class="form-row form-row-last"> <label for="password"><?php esc_html_e( 'Password', 'elementor-pro' ); ?> <span class="required">*</span></label> <input class="input-text" type="password" name="password" id="password" autocomplete="current-password" /> </p> <div class="clear"></div> </div> <div class="e-login-wrap-end"> <p class="form-row"> <label for="login" class="e-login-label"> </label> <?php wp_nonce_field( 'woocommerce-login', 'woocommerce-login-nonce' ); ?> <input type="hidden" name="redirect" value="<?php echo esc_url( get_permalink() ); ?>" /> <button <?php $this->print_render_attribute_string( 'button_login' ); ?> value="<?php esc_attr_e( 'Login', 'elementor-pro' ); ?>"><?php esc_html_e( 'Login', 'elementor-pro' ); ?></button> </p> <div class="clear"></div> </div> </div> <div class="e-login-actions-wrap"> <div class="e-login-actions-wrap-start"> <label class="woocommerce-form__label woocommerce-form__label-for-checkbox woocommerce-form-login__rememberme"> <input class="woocommerce-form__input woocommerce-form__input-checkbox" name="rememberme" type="checkbox" id="rememberme" value="forever" /> <span class="elementor-woocomemrce-login-rememberme"><?php esc_html_e( 'Remember me', 'elementor-pro' ); ?></span> </label> </div> <div class="e-login-actions-wrap-end"> <p class="lost_password"> <a href="<?php echo esc_url( wp_lostpassword_url() ); ?>"><?php esc_html_e( 'Lost your password?', 'elementor-pro' ); ?></a> </p> </div> </div> </div> </div> <?php } /** * Render Woocommerce Checkout Coupon Form * * A custom function to render a coupon form on the Checkout widget. The default WC coupon form * was removed in this file's render() method with: * remove_action( 'woocommerce_before_checkout_form', 'woocommerce_checkout_login_form' ); * * And then we are adding this form into the widget at the * 'woocommerce_checkout_order_review' hook. * * We are doing this in order to match the placement of the coupon form to the provided design. * WC places these forms ABOVE the checkout form section where as we needed to place them inside the * checkout form section. So we removed the default coupon form and added our own form. * * @since 3.5.0 */ private function render_woocommerce_checkout_coupon_form() { $settings = $this->get_settings_for_display(); $button_classes = [ 'woocommerce-button', 'button', 'e-apply-coupon' ]; if ( $settings['forms_buttons_hover_animation'] ) { $button_classes[] = 'elementor-animation-' . $settings['forms_buttons_hover_animation']; } $this->add_render_attribute( 'button_coupon', [ 'class' => $button_classes, 'name' => 'apply_coupon', 'type' => 'submit', ] ); ?> <div class="e-coupon-box"> <p class="e-woocommerce-coupon-nudge e-checkout-secondary-title"><?php esc_html_e( 'Have a coupon?', 'elementor-pro' ); ?> <a href="#" class="e-show-coupon-form"><?php esc_html_e( 'Click here to enter your coupon code', 'elementor-pro' ); ?></a></p> <div class="e-coupon-anchor" style="display:none"> <label class="e-coupon-anchor-description"><?php esc_html_e( 'If you have a coupon code, please apply it below.', 'elementor-pro' ); ?></label> <div class="form-row"> <div class="coupon-container-grid"> <div class="col coupon-col-1 "> <input type="text" name="coupon_code" class="input-text" placeholder="<?php esc_attr_e( 'Coupon code', 'elementor-pro' ); ?>" id="coupon_code" value="" /> </div> <div class="col coupon-col-2"> <button <?php $this->print_render_attribute_string( 'button_coupon' ); ?>><?php esc_html_e( 'Apply', 'elementor-pro' ); ?></button> </div> </div> </div> <div class="clear"></div> </div> </div> <?php } /** * Should Render Login * * Decide if the login form should be rendered. * The login form should be rendered if: * 1) The WooCommerce setting is enabled * 2) AND: a logged out user is viewing the page, OR the Editor is open * * @since 3.5.0 * * @return boolean */ private function should_render_login() { return 'no' !== get_option( 'woocommerce_enable_checkout_login_reminder' ) && ( ! is_user_logged_in() || Plugin::elementor()->editor->is_edit_mode() ); } /** * Should Render Coupon * * Decide if the coupon form should be rendered. * The coupon form should be rendered if: * 1) The WooCommerce setting is enabled * 2) And the Coupon Display toggle hasn't been set to 'no' * 3) AND: a payment is needed, OR the Editor is open * * @since 3.5.0 * * @return boolean */ private function should_render_coupon() { $settings = $this->get_settings_for_display(); $coupon_display_control = true; if ( '' === $settings['coupon_section_display'] ) { $coupon_display_control = false; } return ( WC()->cart->needs_payment() || Plugin::elementor()->editor->is_edit_mode() ) && wc_coupons_enabled() && $coupon_display_control; } /** * WooCommerce Checkout Before Customer Details * * Callback function for the woocommerce_checkout_before_customer_details hook that outputs elements * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_before_customer_details() { ?> <div class="e-checkout__container"> <!--open container--> <div class="e-checkout__column e-checkout__column-start"> <!--open column-1--> <?php if ( $this->should_render_login() ) { $this->render_woocommerce_checkout_login_form(); } } /** * Woocommerce Checkout After Customer Details * * Output containing elements. Callback function for the woocommerce_checkout_after_customer_details hook. * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_after_customer_details() { ?> <!--close column-1--> </div> <?php } /** * Woocommerce Checkout Before Order Review Heading 1 * * Output containing elements. Callback function for the woocommerce_checkout_before_order_review_heading hook. * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_before_order_review_heading_1() { ?> <div class="e-checkout__column e-checkout__column-end"> <!--open column-2--> <div class="e-checkout__column-inner e-sticky-right-column"> <!--open column-inner--> <?php } /** * Woocommerce Checkout Before Order Review Heading 2 * * Output containing elements. Callback function for the woocommerce_checkout_before_order_review_heading hook. * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_before_order_review_heading_2() { ?> <div class="e-checkout__order_review"> <!--open order_review--> <?php } /** * Woocommerce Checkout Order Review * * Output containing elements. Callback function for the woocommerce_checkout_order_review hook. * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_order_review() { ?> <!--close wc_order_review--> </div> <!--close order_review--> </div> <?php if ( $this->should_render_coupon() ) { $this->render_woocommerce_checkout_coupon_form(); } ?> <div class="e-checkout__order_review-2"> <!--reopen wc_order_review-2--> <?php } /** * Woocommerce Checkout After Order Review * * Output containing elements. Callback function for the woocommerce_checkout_after_order_review hook. * * This eliminates the need for template overrides. * * @since 3.5.0 */ public function woocommerce_checkout_after_order_review() { ?> <!--close wc_order_review-2--> <!--close column-inner--> </div> <!--close column-2--> </div> <!--close container--> </div> <?php } /** * Add Render Hooks * * Add actions & filters before displaying our widget. * * @since 3.5.0 */ public function add_render_hooks() { add_filter( 'woocommerce_form_field_args', [ $this, 'modify_form_field' ], 70, 3 ); add_filter( 'woocommerce_get_terms_and_conditions_checkbox_text', [ $this, 'woocommerce_terms_and_conditions_checkbox_text' ], 10, 1 ); add_filter( 'gettext', [ $this, 'filter_gettext' ], 20, 3 ); add_action( 'woocommerce_checkout_before_customer_details', [ $this, 'woocommerce_checkout_before_customer_details' ], 5 ); add_action( 'woocommerce_checkout_after_customer_details', [ $this, 'woocommerce_checkout_after_customer_details' ], 95 ); add_action( 'woocommerce_checkout_before_order_review_heading', [ $this, 'woocommerce_checkout_before_order_review_heading_1' ], 5 ); add_action( 'woocommerce_checkout_before_order_review_heading', [ $this, 'woocommerce_checkout_before_order_review_heading_2' ], 95 ); add_action( 'woocommerce_checkout_order_review', [ $this, 'woocommerce_checkout_order_review' ], 15 ); add_action( 'woocommerce_checkout_after_order_review', [ $this, 'woocommerce_checkout_after_order_review' ], 95 ); // remove the default login & coupon form because we'll be adding our own forms remove_action( 'woocommerce_before_checkout_form', 'woocommerce_checkout_coupon_form' ); remove_action( 'woocommerce_before_checkout_form', 'woocommerce_checkout_login_form' ); } /** * Remove Render Hooks * * Remove actions & filters after displaying our widget. * * @since 3.5.0 */ public function remove_render_hooks() { remove_filter( 'woocommerce_form_field_args', [ $this, 'modify_form_field' ], 70 ); remove_filter( 'woocommerce_get_terms_and_conditions_checkbox_text', [ $this, 'woocommerce_terms_and_conditions_checkbox_text' ], 10 ); remove_filter( 'gettext', [ $this, 'filter_gettext' ], 20 ); remove_action( 'woocommerce_checkout_before_customer_details', [ $this, 'woocommerce_checkout_before_customer_details' ], 5 ); remove_action( 'woocommerce_checkout_after_customer_details', [ $this, 'woocommerce_checkout_after_customer_details' ], 95 ); remove_action( 'woocommerce_checkout_before_order_review_heading', [ $this, 'woocommerce_checkout_before_order_review_heading_1' ], 5 ); remove_action( 'woocommerce_checkout_before_order_review_heading', [ $this, 'woocommerce_checkout_before_order_review_heading_2' ], 95 ); remove_action( 'woocommerce_checkout_order_review', [ $this, 'woocommerce_checkout_order_review' ], 15 ); remove_action( 'woocommerce_checkout_after_order_review', [ $this, 'woocommerce_checkout_after_order_review' ], 95 ); } protected function render() { $is_editor = Plugin::elementor()->editor->is_edit_mode(); // Simulate a logged out user so that all WooCommerce sections will render in the Editor if ( $is_editor ) { $store_current_user = wp_get_current_user()->ID; wp_set_current_user( 0 ); } // Add actions & filters before displaying our Widget. $this->add_render_hooks(); // Display our Widget. echo do_shortcode( '[woocommerce_checkout]' ); // Remove actions & filters after displaying our Widget. $this->remove_render_hooks(); // Return to existing logged-in user after widget is rendered. if ( $is_editor ) { wp_set_current_user( $store_current_user ); } } public function get_group_name() { return 'woocommerce'; } }