start_controls_section(
'section_woocommerce_pages',
[
'label' => esc_html__( 'WooCommerce Pages', 'elementor-pro' ),
'tab' => $this->get_id(),
]
);
if ( API::is_licence_has_feature( Woocommerce::SITE_SETTINGS_PAGES_LICENSE_FEATURE_NAME, API::BC_VALIDATION_CALLBACK ) ) {
$this->register_woocommerce_pages_controls();
} else {
$this->register_woocommerce_pages_promotion();
}
$this->end_controls_section();
$this->start_controls_section(
'section_woocommerce_notices',
[
'label' => esc_html__( 'Notices', 'elementor-pro' ),
'tab' => $this->get_id(),
]
);
if ( API::is_licence_has_feature( Woocommerce::SITE_SETTINGS_NOTICES_LICENSE_FEATURE_NAME, API::BC_VALIDATION_CALLBACK ) ) {
$this->register_woocommerce_notices_controls();
} else {
$this->register_woocommerce_notices_promotion();
}
$this->end_controls_section();
$this->start_controls_section(
'woocommerce_error_notices',
[
'label' => esc_html__( 'Error Notices', 'elementor-pro' ),
'tab' => $this->get_id(),
'condition' => [
'woocommerce_notices_elements' => 'wc_error',
],
]
);
$this->add_notice_text_controls( 'error', $this->get_notice_text_selectors( 'error' ) );
$this->add_control(
'error_message_link_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Link Text', 'elementor-pro' ),
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'error_message_link_typography',
'selector' => $this->get_main_selector( 'error', 'body', ' a.wc-backward' ),
]
);
$this->start_controls_tabs( 'error_message_links' );
$this->start_controls_tab( 'error_message_normal_links', [
'label' => esc_html__( 'Normal', 'elementor-pro' ),
] );
$this->add_control(
'error_message_normal_links_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
$this->get_main_selector( 'error' ) => '--error-message-normal-links-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->start_controls_tab( 'error_message_hover_links', [
'label' => esc_html__( 'Hover', 'elementor-pro' ),
] );
$this->add_control(
'error_message_hover_links_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
$this->get_main_selector( 'error' ) => '--error-message-hover-links-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->add_notice_box_controls( 'error', $this->get_notice_box_selectors( 'error' ) );
$this->end_controls_section();
$this->start_controls_section(
'woocommerce_message_notices',
[
'label' => esc_html__( 'Message Notices', 'elementor-pro' ),
'tab' => $this->get_id(),
'condition' => [
'woocommerce_notices_elements' => 'wc_message',
],
]
);
$this->add_notice_text_controls( 'message', $this->get_notice_text_selectors( 'message' ) );
$this->add_control(
'notice_message_link_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Link Text', 'elementor-pro' ),
]
);
$message_link_typography_selector = $this->get_main_selector( 'message', 'body', ' .restore-item' );
$message_link_typography_selector .= ', ';
$message_link_typography_selector .= $this->get_main_selector( 'message', 'body', ' a:not([class])' );
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'notice_message_link_typography',
'selector' => $message_link_typography_selector,
]
);
$this->start_controls_tabs( 'notice_message_links' );
$this->start_controls_tab( 'notice_message_normal_links', [
'label' => esc_html__( 'Normal', 'elementor-pro' ),
] );
$message_normal_link_color_selector = $this->get_main_selector( 'message', '', ' .restore-item' );
$message_normal_link_color_selector .= ', ';
$message_normal_link_color_selector .= $this->get_main_selector( 'message', '', ' a:not([class])' );
$this->add_control(
'notice_message_normal_links_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
$message_normal_link_color_selector => '--notice-message-normal-links-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->start_controls_tab( 'notice_message_hover_links', [
'label' => esc_html__( 'Hover', 'elementor-pro' ),
] );
$message_hover_link_color_selector = $this->get_main_selector( 'message', '', ' .restore-item:hover' );
$message_hover_link_color_selector .= ', ';
$message_hover_link_color_selector .= $this->get_main_selector( 'message', '', ' a:not([class]):hover' );
$this->add_control(
'notice_message_hover_links_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
$message_hover_link_color_selector => '--notice-message-hover-links-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->add_notice_box_controls( 'message', $this->get_notice_box_selectors( 'message' ) );
$this->add_notice_button_controls( 'message', $this->get_notice_button_selectors( 'message' ) );
$this->end_controls_section();
$this->start_controls_section(
'woocommerce_info_notices',
[
'label' => esc_html__( 'Info Notices', 'elementor-pro' ),
'tab' => $this->get_id(),
'condition' => [
'woocommerce_notices_elements' => 'wc_info',
],
]
);
$this->add_notice_text_controls( 'info', $this->get_notice_text_selectors( 'info' ) );
$this->add_notice_box_controls( 'info', $this->get_notice_box_selectors( 'info' ) );
$this->end_controls_tab();
$this->end_controls_tabs();
$this->add_notice_button_controls( 'info', $this->get_notice_button_selectors( 'info' ) );
$this->end_controls_section();
}
private function get_main_selector( $notice_type, $selector_prefix = '', $selector_suffix = '' ) {
$notice_name = 'message' === $notice_type ? 'success' : $notice_type;
$old_notice_selector = $selector_prefix . '.e-wc-' . $notice_type . '-notice .woocommerce-' . $notice_type . $selector_suffix;
$block_notice_selector = $selector_prefix . '.e-wc-' . $notice_type . '-notice .wc-block-components-notice-banner.is-' . $notice_name . $selector_suffix;
return $old_notice_selector . ', ' . $block_notice_selector;
}
private function get_notice_text_selectors( $notice_type ) {
return [
$notice_type . '_message_text_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-message-text-color: {{VALUE}};',
],
$notice_type . '_message_text_typography' => $this->get_main_selector( $notice_type ),
$notice_type . '_message_text_shadow' => $this->get_main_selector( $notice_type ),
$notice_type . '_message_icon_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-message-icon-color: {{VALUE}};',
],
$notice_type . '_message_icon_size' => [
$this->get_main_selector( $notice_type, '', ':before' ) => 'font-size: {{SIZE}}{{UNIT}};',
],
$notice_type . '_message_icon_spacing' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-message-icon-spacing: {{SIZE}}{{UNIT}};',
],
];
}
private function get_notice_box_selectors( $notice_type ) {
return [
$notice_type . '_notice_box_background' => $this->get_main_selector( $notice_type, 'body' ),
$notice_type . '_notice_box_box_shadow' => $this->get_main_selector( $notice_type ),
$notice_type . '_notice_box_border' => $this->get_main_selector( $notice_type, 'body' ),
$notice_type . '_notice_box_border_radius' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-box-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
$notice_type . '_notice_box_padding' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-box-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
];
}
private function get_notice_button_selectors( $notice_type ) {
$button_hover_background_selector = $this->get_main_selector( $notice_type, 'body', ' .button:hover' );
if ( 'info' === $notice_type ) {
// Override styling from the My Account widget.
$button_hover_background_selector .= ', body.e-wc-info-notice .e-my-account-tab:not(.e-my-account-tab__dashboard--custom) .woocommerce .woocommerce-info .woocommerce-Button:hover';
$button_hover_background_selector .= ', body.e-wc-info-notice .e-my-account-tab:not(.e-my-account-tab__dashboard--custom) .woocommerce .wc-block-components-notice-banner.is-info .woocommerce-Button:hover';
}
return [
$notice_type . '_button_typography' => $this->get_main_selector( $notice_type, 'body', ' .button' ),
$notice_type . '_button_text_shadow' => $this->get_main_selector( $notice_type, 'body', ' .button' ),
$notice_type . '_buttons_normal_text_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-normal-text-color: {{VALUE}};',
],
$notice_type . '_buttons_normal_background' => $this->get_main_selector( $notice_type, 'body', ' .button' ),
$notice_type . '_buttons_normal_box_shadow' => $this->get_main_selector( $notice_type, '', ' .button' ),
$notice_type . '_buttons_hover_text_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-hover-text-color: {{VALUE}};',
],
$notice_type . '_buttons_hover_background' => $button_hover_background_selector,
$notice_type . '_buttons_focus_box_shadow' => $this->get_main_selector( $notice_type, '', ' .button:hover' ),
$notice_type . '_buttons_hover_border_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-hover-border-color: {{VALUE}};',
],
$notice_type . '_buttons_hover_transition_duration' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-hover-transition-duration: {{SIZE}}ms;',
],
$notice_type . '_buttons_border_type' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-border-type: {{VALUE}};',
],
$notice_type . '_buttons_border_width' => [
$this->get_main_selector( $notice_type, 'body', ' .button' ) => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
$notice_type . '_buttons_border_color' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-border-color: {{VALUE}};',
],
$notice_type . '_buttons_border_radius' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
$notice_type . '_buttons_padding' => [
$this->get_main_selector( $notice_type ) => '--' . $notice_type . '-buttons-padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
];
}
private function add_notice_text_controls( $notice_type, $selectors ) {
$this->add_control(
$notice_type . '_message_text_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Notice Text', 'elementor-pro' ),
]
);
$this->add_control(
$notice_type . '_message_text_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_message_text_color' ],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => $notice_type . '_message_text_typography',
'selector' => $selectors[ $notice_type . '_message_text_typography' ],
]
);
$this->add_group_control(
Group_Control_Text_Shadow::get_type(),
[
'name' => $notice_type . '_message_text_shadow',
'selector' => $selectors[ $notice_type . '_message_text_shadow' ],
]
);
$this->add_control(
$notice_type . '_message_icon_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Icon', 'elementor-pro' ),
]
);
$this->add_control(
$notice_type . '_message_icon_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_message_icon_color' ],
]
);
}
private function add_notice_box_controls( $notice_type, $selectors ) {
$this->add_control(
$notice_type . '_notice_box_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Notice Box', 'elementor-pro' ),
'separator' => 'before',
]
);
$this->add_group_control(
Group_Control_Background::get_type(),
[
'name' => $notice_type . '_notice_box_background',
'selector' => $selectors[ $notice_type . '_notice_box_background' ],
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => $notice_type . '_notice_box_box_shadow',
'selector' => $selectors[ $notice_type . '_notice_box_box_shadow' ],
]
);
$this->add_group_control(
Group_Control_Border::get_type(),
[
'name' => $notice_type . '_notice_box_border',
'selector' => $selectors[ $notice_type . '_notice_box_border' ],
]
);
$this->add_responsive_control(
$notice_type . '_notice_box_border_radius',
[
'label' => esc_html__( 'Border Radius', 'elementor-pro' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ],
'selectors' => $selectors[ $notice_type . '_notice_box_border_radius' ],
]
);
}
private function add_notice_button_controls( $notice_type, $selectors ) {
$this->add_control(
$notice_type . '_button_title',
[
'type' => Controls_Manager::HEADING,
'label' => esc_html__( 'Button', 'elementor-pro' ),
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => $notice_type . '_button_typography',
'selector' => $selectors[ $notice_type . '_button_typography' ],
]
);
$this->add_group_control(
Group_Control_Text_Shadow::get_type(),
[
'name' => $notice_type . '_button_text_shadow',
'selector' => $selectors[ $notice_type . '_button_text_shadow' ],
]
);
$this->start_controls_tabs( $notice_type . '_buttons_styles' );
$this->start_controls_tab( $notice_type . '_buttons_normal_styles', [
'label' => esc_html__( 'Normal', 'elementor-pro' ),
] );
$this->add_control(
$notice_type . '_buttons_normal_text_color',
[
'label' => esc_html__( 'Text Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_buttons_normal_text_color' ],
]
);
$button_background_selectors = [
'image' => [
'selectors' => [
'{{SELECTOR}}' => 'background-image: url("{{URL}}") !important;',
],
],
'color' => [
'selectors' => [
'{{SELECTOR}}' => 'background-color: {{VALUE}} !important; background-image: none !important',
],
],
'gradient_angle' => [
'selectors' => [
'{{SELECTOR}}' => 'background-color: transparent !important; background-image: linear-gradient({{SIZE}}{{UNIT}}, {{color.VALUE}} {{color_stop.SIZE}}{{color_stop.UNIT}}, {{color_b.VALUE}} {{color_b_stop.SIZE}}{{color_b_stop.UNIT}}) !important',
],
],
'gradient_position' => [
'selectors' => [
'{{SELECTOR}}' => 'background-color: transparent !important; background-image: radial-gradient(at {{VALUE}}, {{color.VALUE}} {{color_stop.SIZE}}{{color_stop.UNIT}}, {{color_b.VALUE}} {{color_b_stop.SIZE}}{{color_b_stop.UNIT}}) !important',
],
],
'position' => [
'selectors' => [
'{{SELECTOR}}' => 'background-position: {{VALUE}} !important;',
],
],
'xpos' => [
'selectors' => [
'{{SELECTOR}}' => 'background-position: {{SIZE}}{{UNIT}} {{ypos.SIZE}}{{ypos.UNIT}} !important',
],
],
'ypos' => [
'selectors' => [
'{{SELECTOR}}' => 'background-position: {{xpos.SIZE}}{{xpos.UNIT}} {{SIZE}}{{UNIT}} !important',
],
],
'repeat' => [
'selectors' => [
'{{SELECTOR}}' => 'background-repeat: {{VALUE}} !important;',
],
],
'size' => [
'selectors' => [
'{{SELECTOR}}' => 'background-size: {{VALUE}} !important;',
],
],
'bg_width' => [
'selectors' => [
'{{SELECTOR}}' => 'background-size: {{SIZE}}{{UNIT}} auto !important',
],
],
];
$this->add_group_control(
Group_Control_Background::get_type(),
[
'name' => $notice_type . '_buttons_normal_background',
'selector' => $selectors[ $notice_type . '_buttons_normal_background' ],
'fields_options' => $button_background_selectors,
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => $notice_type . '_buttons_normal_box_shadow',
'selector' => $selectors[ $notice_type . '_buttons_normal_box_shadow' ],
]
);
$this->end_controls_tab();
$this->start_controls_tab( $notice_type . '_buttons_hover_styles', [
'label' => esc_html__( 'Hover', 'elementor-pro' ),
] );
$this->add_control(
$notice_type . '_buttons_hover_text_color',
[
'label' => esc_html__( 'Text Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_buttons_hover_text_color' ],
]
);
$this->add_group_control(
Group_Control_Background::get_type(),
[
'name' => $notice_type . '_buttons_hover_background',
'selector' => $selectors[ $notice_type . '_buttons_hover_background' ],
'fields_options' => $button_background_selectors,
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => $notice_type . '_buttons_focus_box_shadow',
'selector' => $selectors[ $notice_type . '_buttons_focus_box_shadow' ],
]
);
$this->add_control(
$notice_type . '_buttons_hover_border_color',
[
'label' => esc_html__( 'Border Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_buttons_hover_border_color' ],
'condition' => [
$notice_type . '_buttons_border_type!' => 'none',
],
]
);
$this->add_control(
$notice_type . '_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' => $selectors[ $notice_type . '_buttons_hover_transition_duration' ],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->add_control(
$notice_type . '_buttons_border_type',
[
'label' => esc_html__( 'Border Type', 'elementor-pro' ),
'type' => Controls_Manager::SELECT,
'options' => [
'none' => esc_html__( 'None', 'elementor-pro' ),
'solid' => esc_html__( 'Solid', 'elementor-pro' ),
'double' => esc_html__( 'Double', 'elementor-pro' ),
'dotted' => esc_html__( 'Dotted', 'elementor-pro' ),
'dashed' => esc_html__( 'Dashed', 'elementor-pro' ),
'groove' => esc_html__( 'Groove', 'elementor-pro' ),
],
'selectors' => $selectors[ $notice_type . '_buttons_border_type' ],
'separator' => 'before',
]
);
$this->add_responsive_control(
$notice_type . '_buttons_border_width',
[
'label' => esc_html__( 'Width', 'elementor-pro' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ],
'selectors' => $selectors[ $notice_type . '_buttons_border_width' ],
'condition' => [
$notice_type . '_buttons_border_type!' => 'none',
],
]
);
$this->add_control(
$notice_type . '_buttons_border_color',
[
'label' => esc_html__( 'Color', 'elementor-pro' ),
'type' => Controls_Manager::COLOR,
'selectors' => $selectors[ $notice_type . '_buttons_border_color' ],
'condition' => [
$notice_type . '_buttons_border_type!' => 'none',
],
]
);
$this->add_responsive_control(
$notice_type . '_buttons_border_radius',
[
'label' => esc_html__( 'Border Radius', 'elementor-pro' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em', 'rem', 'custom' ],
'selectors' => $selectors[ $notice_type . '_buttons_border_radius' ],
]
);
$this->add_responsive_control(
$notice_type . '_buttons_padding',
[
'label' => esc_html__( 'Padding', 'elementor-pro' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em', 'rem', 'vw', 'custom' ],
'selectors' => $selectors[ $notice_type . '_buttons_padding' ],
]
);
}
public function on_save( $data ) {
if (
! isset( $data['settings']['post_status'] ) ||
Document::STATUS_PUBLISH !== $data['settings']['post_status'] ||
// Should check for the current action to avoid infinite loop
// when updating options like: "blogname" and "blogdescription".
strpos( current_action(), 'update_option_' ) === 0
) {
return;
}
$ec_wc_key_mapping = [
'woocommerce_cart_page_id' => 'woocommerce_cart_page_id',
'woocommerce_checkout_page_id' => 'woocommerce_checkout_page_id',
'woocommerce_myaccount_page_id' => 'woocommerce_myaccount_page_id',
'woocommerce_terms_page_id' => 'woocommerce_terms_page_id',
'woocommerce_purchase_summary_page_id' => 'elementor_woocommerce_purchase_summary_page_id',
'woocommerce_shop_page_id' => 'woocommerce_shop_page_id',
];
foreach ( $ec_wc_key_mapping as $ec_key => $wc_key ) {
if ( array_key_exists( $ec_key, $data['settings'] ) ) {
$value = $data['settings'][ $ec_key ] ? $data['settings'][ $ec_key ] : '';
update_option( $wc_key, $value );
}
}
}
private function register_woocommerce_pages_controls() {
$this->add_control(
'woocommerce_pages_intro',
[
'raw' => esc_html__( 'Select the pages you want to use as your default WooCommerce shop pages', 'elementor-pro' ),
'type' => Controls_Manager::RAW_HTML,
'content_classes' => 'elementor-descriptor',
]
);
$autocomplete = [
'object' => QueryModule::QUERY_OBJECT_POST,
'query' => [
'post_type' => [ 'page' ],
],
];
$this->add_control(
'woocommerce_cart_page_id',
[
'label' => esc_html__( 'Cart', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'woocommerce_cart_page_id' ),
]
);
$this->add_control(
'woocommerce_checkout_page_id',
[
'label' => esc_html__( 'Checkout', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'woocommerce_checkout_page_id' ),
]
);
$this->add_control(
'woocommerce_myaccount_page_id',
[
'label' => esc_html__( 'My Account', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'woocommerce_myaccount_page_id' ),
]
);
$this->add_control(
'woocommerce_terms_page_id',
[
'label' => esc_html__( 'Terms & Conditions', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'woocommerce_terms_page_id' ),
]
);
$this->add_control(
'woocommerce_purchase_summary_page_id',
[
'label' => esc_html__( 'Purchase Summary', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'elementor_woocommerce_purchase_summary_page_id' ), // This is not in WC core. This is a custom page added by Elementor.
]
);
$this->add_control(
'woocommerce_shop_page_id',
[
'label' => esc_html__( 'Shop', 'elementor-pro' ),
'type' => QueryModule::QUERY_CONTROL_ID,
'select2options' => [
'placeholder' => esc_html__( 'Select a page', 'elementor-pro' ),
],
'autocomplete' => $autocomplete,
'default' => get_option( 'woocommerce_shop_page_id' ),
]
);
$this->add_control(
'woocommerce_pages_notice',
[
// TODO: Remove define() with the release of Elementor 3.22
'type' => defined( 'Controls_Manager::ALERT' ) ? Controls_Manager::ALERT : 'alert',
'alert_type' => 'info',
'content' => esc_html__( 'Note: Changes you make here will also be reflected in the WooCommerce settings on your WP dashboard', 'elementor-pro' ),
]
);
}
private function register_woocommerce_notices_controls() {
$this->add_control(
'woocommerce_notices_intro',
[
'raw' => esc_html__( 'Here\'s where you can customize how notices form WooCommerce will appear for your customers', 'elementor-pro' ),
'type' => Controls_Manager::RAW_HTML,
'content_classes' => 'elementor-descriptor',
]
);
$this->add_control(
'woocommerce_notices_elements',
[
'label' => esc_html__( 'Notice Type', 'elementor-pro' ),
'type' => Controls_Manager::SELECT2,
'multiple' => true,
'options' => [
'wc_error' => esc_html__( 'Error Notices', 'elementor-pro' ),
'wc_message' => esc_html__( 'Message Notices', 'elementor-pro' ),
'wc_info' => esc_html__( 'Info Notices', 'elementor-pro' ),
],
'render_type' => 'ui',
'label_block' => true,
'frontend_available' => true,
'default' => [],
]
);
}
/**
* @return array
*/
public function get_notices_promotion_data() {
return [
'title' => sprintf(
esc_html__( 'Say hello to %s WooCommerce notices!', 'elementor-pro' ),
'
'
),
'messages' => [
esc_html__( 'Upgrade your subscription to customize these and much more.', 'elementor-pro' ),
],
'link' => 'https://go.elementor.com/go-pro-advanced-site-settings-woocommerce-notices/',
];
}
/**
* @return array
*/
private function get_pages_promotion_data(): array {
return [
'title' => sprintf(
esc_html__( 'Say hello to %s WooCommerce pages!', 'elementor-pro' ),
'
'
),
'messages' => [
esc_html__( 'Upgrade your subscription to customize these and much more.', 'elementor-pro' ),
],
'link' => 'https://go.elementor.com/go-pro-advanced-site-settings-woocommerce-pages/',
];
}
/**
* @return void
*/
private function register_woocommerce_pages_promotion(): void {
$this->add_control(
'woocommerce_pages_promotion',
[
'type' => Controls_Manager::RAW_HTML,
'raw' => Tiers::get_promotion_template( $this->get_pages_promotion_data() ),
]
);
}
/**
* @return void
*/
private function register_woocommerce_notices_promotion(): void {
$this->add_control(
'woocommerce_notices_promotion',
[
'type' => Controls_Manager::RAW_HTML,
'raw' => Tiers::get_promotion_template( $this->get_notices_promotion_data() ),
]
);
}
}