/
var
/
www
/
barefootlaw.org
/
wp-content
/
plugins
/
happy-elementor-addons
/
widgets
/
mailchimp
/
Upload File
HOME
<?php /** * Member widget class * * @package Happy_Addons */ namespace Happy_Addons\Elementor\Widget; use Elementor\Group_Control_Text_Shadow; use Elementor\Controls_Manager; use Elementor\Group_Control_Border; use Elementor\Group_Control_Background; use Elementor\Group_Control_Box_Shadow; use Elementor\Group_Control_Typography; use Happy_Addons\Elementor\Controls\Select2; defined( 'ABSPATH' ) || die(); class Mailchimp extends Base { private $settings; /** * Get widget title. * * @since 2.24.1 * @access public * * @return string Widget title. */ public function get_title() { return __( 'MailChimp', 'happy-elementor-addons' ); } public function __construct( $data = [], $args = null ) { parent::__construct( $data, $args ); $this->settings = ha_get_credentials( 'mailchimp' ); } /** * Get widget icon. * * @since 2.24.1 * @access public * * @return string Widget icon. */ public function get_icon() { return 'hm hm-mail-chimp'; } public function get_keywords() { return ['email', 'mail chimp', 'mail', 'subscription']; } /** * Register widget content controls */ protected function register_content_controls() { $this->__mailchimp_content_controls(); $this->__mailchimp_form_content_controls(); $this->__success_error_content_controls(); } protected function __mailchimp_content_controls() { $this->start_controls_section( '_section_mailchimp', [ 'label' => __( 'MailChimp', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_CONTENT, ] ); $this->add_control( 'mailchimp_api_check', [ 'raw' => '<strong>' . esc_html__( 'Please note!', 'happy-elementor-addons' ) . '</strong> ' . esc_html__( 'Please set API Key in Happy Addons Dashboard - ', 'happy-elementor-addons' ) . '<a style="border-bottom-color: inherit;" href="' . esc_url( admin_url( 'admin.php?page=happy-addons#credentials' ) ) . '" target="_blank" >' . esc_html__( 'Credentials', 'happy-elementor-addons' ) . '</a>' . esc_html__( ' - MailChimp and Create Audience.', 'happy-elementor-addons' ), 'type' => Controls_Manager::RAW_HTML, 'content_classes' => 'elementor-panel-alert elementor-panel-alert-warning', 'render_type' => 'ui', 'condition' => [ 'mailchimp_api_choose' => 'global', ], ] ); /* * Need to solve api get issue from controller to controller */ $this->add_control( 'mailchimp_api_choose', [ 'label' => __( 'Choose API from', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'global', 'options' => [ 'global' => __( 'Global', 'happy-elementor-addons' ), 'custom' => __( 'Custom', 'happy-elementor-addons' ), ], ] ); $this->add_control( 'mailchimp_api', [ 'label' => __( 'MailChimp API', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'label_block' => true, 'placeholder' => __( 'Enter your mailchimp api here', 'happy-elementor-addons' ), 'condition' => [ 'mailchimp_api_choose' => 'custom', ], 'dynamic' => [ 'active' => true], ] ); $this->add_control( 'mailchimp_lists', [ 'label' => __( 'Audience', 'happy-elementor-addons' ), 'label_block' => true, 'type' => Select2::TYPE, 'multiple' => false, 'placeholder' => 'Choose your created audience ', 'dynamic_params' => [ 'object_type' => 'mailchimp_list', 'global_api' => isset( $this->settings['api'] ) ? $this->settings['api'] : '', 'control_dependency' => [ 'mailchimp_api_choose' => 'mailchimp_api_choose', 'mailchimp_api' => 'mailchimp_api', ], ], 'select2options' => [ 'minimumInputLength' => 0, ], 'description' => esc_html__( 'Create a audience/ list in mailchimp account ', 'happy-elementor-addons' ) . '<a href="https://mailchimp.com/help/create-audience/" target="_blank"> ' . esc_html__( 'Create Audience', 'happy-elementor-addons' ) . '</a>', ] ); $this->add_control( 'mailchimp_list_tags', [ 'label' => __( 'Tags', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'label_block' => true, 'placeholder' => __( 'Tag-1, Tag-2', 'happy-elementor-addons' ), 'description' => __( 'Enter tag here to separate your subscribers. Use comma separator to use multiple tags. Example: Tag-1, Tag-2, Tag-3', 'happy-elementor-addons' ), 'condition' => [ 'mailchimp_lists!' => '', ], 'dynamic' => [ 'active' => true], ] ); $this->add_control( 'enable_double_opt_in', [ 'label' => __( 'Enable Double Opt In?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'no', ] ); $this->end_controls_section(); } protected function __mailchimp_form_content_controls() { $this->start_controls_section( '_section_mailchimp_form', [ 'label' => __( 'Form', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_CONTENT, ] ); $this->add_responsive_control( 'form_alignment', [ 'label' => __( 'Form Alignment', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'horizontal', 'devices' => ['desktop', 'tablet', 'mobile'], 'desktop_default' => 'horizontal', 'tablet_default' => 'horizontal', 'mobile_default' => 'vertical', // 'desktop_default' => ['horizontal'], // 'tablet_default' => ['horizontal'], // 'mobile_default' => ['vertical'], 'options' => [ 'horizontal' => esc_html__( 'Horizontal', 'happy-elementor-addons' ), 'vertical' => esc_html__( 'Vertical', 'happy-elementor-addons' ), ], 'prefix_class' => 'ha-mailchimp%s-', // 'frontend_available' => true, ] ); $this->add_control( 'enable_name', [ 'label' => __( 'Enable Name?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'no', ] ); $this->add_control( '_fname_heading', [ 'label' => __( 'First Name:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'enable_name' => 'yes', ], ] ); $this->add_control( 'fname_label', [ 'label' => __( 'Label', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'First Name input label', 'happy-elementor-addons' ), 'condition' => [ 'enable_name' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'fname_placeholder', [ 'label' => __( 'Placeholder', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'default' => __( 'First Name', 'happy-elementor-addons' ), 'placeholder' => __( 'First Name input placeholder', 'happy-elementor-addons' ), 'condition' => [ 'enable_name' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'fname_enable_icon', [ 'label' => __( 'Enable Icon With Input?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'yes', 'condition' => [ 'enable_name' => 'yes', ], ] ); $this->add_control( 'fname_icon', [ 'label' => __( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'hm hm-user', 'library' => 'regular', ], 'condition' => [ 'enable_name' => 'yes', 'fname_enable_icon' => 'yes', ], ] ); $this->add_control( 'fname_icon_position', [ 'label' => __( 'Icon Position', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'before', 'options' => [ 'before' => __( 'Before Input', 'happy-elementor-addons' ), 'after' => __( 'After Input', 'happy-elementor-addons' ), ], 'condition' => [ 'enable_name' => 'yes', 'fname_enable_icon' => 'yes', ], ] ); $this->add_control( '_lname_heading', [ 'label' => __( 'Last Name:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'enable_name' => 'yes', ], ] ); $this->add_control( 'lname_label', [ 'label' => __( 'Label', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Last Name input label', 'happy-elementor-addons' ), 'condition' => [ 'enable_name' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'lname_placeholder', [ 'label' => __( 'Placeholder', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'default' => __( 'Last Name', 'happy-elementor-addons' ), 'placeholder' => __( 'Last Name input placeholder', 'happy-elementor-addons' ), 'condition' => [ 'enable_name' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'lname_enable_icon', [ 'label' => __( 'Enable Icon With Input?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'yes', 'condition' => [ 'enable_name' => 'yes', ], ] ); $this->add_control( 'lname_icon', [ 'label' => __( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'hm hm-user', 'library' => 'regular', ], 'condition' => [ 'enable_name' => 'yes', 'lname_enable_icon' => 'yes', ], ] ); $this->add_control( 'lname_icon_position', [ 'label' => __( 'Icon Position', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'before', 'options' => [ 'before' => __( 'Before Input', 'happy-elementor-addons' ), 'after' => __( 'After Input', 'happy-elementor-addons' ), ], 'condition' => [ 'enable_name' => 'yes', 'lname_enable_icon' => 'yes', ], ] ); $this->add_control( 'enable_phone', [ 'label' => __( 'Enable Phone?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'no', ] ); $this->add_control( '_phone_heading', [ 'label' => __( 'Phone:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'enable_phone' => 'yes', ], ] ); $this->add_control( 'phone_label', [ 'label' => __( 'Label', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Phone input label', 'happy-elementor-addons' ), 'condition' => [ 'enable_phone' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'phone_placeholder', [ 'label' => __( 'Placeholder', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'default' => __( 'Phone', 'happy-elementor-addons' ), 'placeholder' => __( 'Phone input placeholder', 'happy-elementor-addons' ), 'condition' => [ 'enable_phone' => 'yes', ], 'dynamic' => ['active' => true], ] ); $this->add_control( 'phone_enable_icon', [ 'label' => __( 'Enable Icon With Input?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'yes', 'condition' => [ 'enable_phone' => 'yes', ], ] ); $this->add_control( 'phone_icon', [ 'label' => __( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'hm hm-phone', 'library' => 'regular', ], 'condition' => [ 'enable_phone' => 'yes', 'phone_enable_icon' => 'yes', ], ] ); $this->add_control( 'phone_icon_position', [ 'label' => __( 'Icon Position', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'before', 'options' => [ 'before' => __( 'Before Input', 'happy-elementor-addons' ), 'after' => __( 'After Input', 'happy-elementor-addons' ), ], 'condition' => [ 'enable_phone' => 'yes', 'phone_enable_icon' => 'yes', ], ] ); $this->add_control( '_email_heading', [ 'label' => __( 'Email:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', ] ); $this->add_control( 'email_label', [ 'label' => __( 'Label', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Email input label', 'happy-elementor-addons' ), 'dynamic' => ['active' => true], ] ); $this->add_control( 'email_placeholder', [ 'label' => __( 'Placeholder', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'default' => __( 'Email', 'happy-elementor-addons' ), 'placeholder' => __( 'Email input placeholder', 'happy-elementor-addons' ), 'dynamic' => ['active' => true], ] ); $this->add_control( 'email_enable_icon', [ 'label' => __( 'Enable Icon With Input?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'yes', ] ); $this->add_control( 'email_icon', [ 'label' => __( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'hm hm-envelop', 'library' => 'regular', ], 'condition' => [ 'email_enable_icon' => 'yes', ], ] ); $this->add_control( 'email_icon_position', [ 'label' => __( 'Icon Position', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'before', 'options' => [ 'before' => __( 'Before Input', 'happy-elementor-addons' ), 'after' => __( 'After Input', 'happy-elementor-addons' ), ], 'condition' => [ 'email_enable_icon' => 'yes', ], ] ); $this->add_control( '_button_heading', [ 'label' => __( 'Button:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', ] ); $this->add_control( 'button_text', [ 'label' => __( 'Text', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Subscribe', 'happy-elementor-addons' ), 'dynamic' => ['active' => true], ] ); $this->add_control( 'button_enable_icon', [ 'label' => __( 'Enable Icon With Button?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'yes', ] ); $this->add_control( 'button_icon', [ 'label' => __( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'hm hm-tick', 'library' => 'regular', ], 'condition' => [ 'button_enable_icon' => 'yes', ], ] ); $this->add_control( 'button_icon_position', [ 'label' => __( 'Icon Position', 'happy-elementor-addons' ), 'type' => Controls_Manager::SELECT, 'default' => 'before', 'options' => [ 'before' => __( 'Before Input', 'happy-elementor-addons' ), 'after' => __( 'After Input', 'happy-elementor-addons' ), ], 'condition' => [ 'button_enable_icon' => 'yes', ], ] ); $this->end_controls_section(); } protected function __success_error_content_controls() { $this->start_controls_section( '_section_success_error_label', [ 'label' => esc_html__( 'Success & Error', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_CONTENT, ] ); $this->add_control( 'mailchimp_success_message', [ 'label' => __( 'Success Message', 'happy-elementor-addons' ), 'type' => Controls_Manager::TEXT, 'label_block' => true, 'default' => __( 'Your data has been inserted on Mailchimp.', 'happy-elementor-addons' ), 'placeholder' => __( 'Type your success message here', 'happy-elementor-addons' ), 'dynamic' => ['active' => true], ] ); $this->add_control( 'mailchimp_success_message_show_in_editor', [ 'label' => __( 'Success Message Show in Editor?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => '', ] ); $this->add_control( 'mailchimp_error_message_show_in_editor', [ 'label' => __( 'Error Message Show in Editor?', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => __( 'Yes', 'happy-elementor-addons' ), 'label_off' => __( 'No', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => '', ] ); $this->end_controls_section(); } /** * Register styles related controls */ protected function register_style_controls() { $this->__mailchimp_label_style_controls(); $this->__input_style_controls(); $this->__input_icon_style_controls(); $this->__button_style_controls(); $this->__success_error_style_controls(); } protected function __mailchimp_label_style_controls() { $this->start_controls_section( '_section_style_mailchimp_label', [ 'label' => esc_html__( 'Label', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'input_label_typography', 'label' => esc_html__( 'Typography', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-input-label', ] ); $this->add_control( 'input_label_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#000000', 'selectors' => [ '{{WRAPPER}} .ha-mc-input-label' => 'color: {{VALUE}}', ], ] ); $this->add_responsive_control( 'input_label_margin', [ 'label' => esc_html__( 'Margin', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-input-label' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->end_controls_section(); } protected function __input_style_controls() { // input style $this->start_controls_section( 'input_style', [ 'label' => esc_html__( 'Input', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'space_between_input', [ 'label' => __( 'Space Between Input (px)', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, 'step' => 1, ], ], 'devices' => ['desktop', 'tablet', 'mobile'], 'desktop_default' => [ 'unit' => 'px', 'size' => 30, ], 'tablet_default' => [ 'size' => 10, 'unit' => 'px', ], 'mobile_default' => [ 'size' => 5, 'unit' => 'px', ], 'selectors' => [ 'body[data-elementor-device-mode="desktop"] {{WRAPPER}}.ha-mailchimp-vertical .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-bottom: {{SIZE}}{{UNIT}}; margin-right: unset;', 'body[data-elementor-device-mode="desktop"] {{WRAPPER}}.ha-mailchimp-horizontal .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-right: {{SIZE}}{{UNIT}}; margin-bottom: unset;', 'body[data-elementor-device-mode="tablet"] {{WRAPPER}}.ha-mailchimp-tablet-vertical .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-bottom: {{SIZE}}{{UNIT}}; margin-right: unset;', 'body[data-elementor-device-mode="tablet"] {{WRAPPER}}.ha-mailchimp-tablet-horizontal .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-right: {{SIZE}}{{UNIT}}; margin-bottom: unset;', 'body[data-elementor-device-mode="mobile"] {{WRAPPER}}.ha-mailchimp-mobile-vertical .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-bottom: {{SIZE}}{{UNIT}}; margin-right: unset;', 'body[data-elementor-device-mode="mobile"] {{WRAPPER}}.ha-mailchimp-mobile-horizontal .ha-mailchimp-form .ha-mc-input-wrapper' => 'margin-right: {{SIZE}}{{UNIT}}; margin-bottom: unset;', // '{{WRAPPER}} .ha-mailchimp-form.vertical .ha-mc-input-wrapper' => 'margin-bottom: {{SIZE}}{{UNIT}};', // '{{WRAPPER}} .ha-mailchimp-form.horizontal .ha-mc-input-wrapper' => 'margin-right: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'input_style_inputted_value_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#000000', 'selectors' => [ '{{WRAPPER}} .ha-mc-input input' => 'color: {{VALUE}}', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'input_typography', 'label' => esc_html__( 'Typography', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-input input', ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'input_style_background', 'label' => esc_html__( 'Background', 'happy-elementor-addons' ), 'types' => ['classic', 'gradient'], 'selector' => '{{WRAPPER}} .ha-mc-input input', 'exclude' => [ 'image', ], ] ); $this->add_responsive_control( 'input_style_radius', [ 'label' => esc_html__( 'Border Radius', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'selectors' => [ '{{WRAPPER}} .ha-mc-input input' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}} !important;', ], ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'input_style_border', 'label' => esc_html__( 'Border', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-input input', ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'input_style_box_shadow', 'label' => esc_html__( 'Box Shadow', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-input input, {{WRAPPER}} .ha-mc-input input:focus', ] ); $this->add_responsive_control( 'input_style_padding', [ 'label' => esc_html__( 'Padding', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'default' => [ 'top' => 0, 'right' => 20, 'bottom' => 0, 'left' => 20, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-input input' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_control( 'input_style_width__switch', [ 'label' => esc_html__( 'Use Width', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'happy-elementor-addons' ), 'label_off' => esc_html__( 'Hide', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'no', ] ); $this->add_responsive_control( 'input_style_width', [ 'label' => esc_html__( 'Width', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px', '%'], 'default' => [ 'unit' => '%', 'size' => 66, ], 'range' => [ 'px' => [ 'min' => 0, 'max' => 1000, 'step' => 5, ], '%' => [ 'min' => 0, 'max' => 100, ], ], 'selectors' => [ '{{WRAPPER}} .ha-mc-input-wrapper' => 'flex: 0 0 {{SIZE}}{{UNIT}};', ], 'condition' => [ 'input_style_width__switch' => 'yes', ], ] ); // $this->add_responsive_control( // 'input_style_margin_bottom', // [ // 'label' => esc_html__('Margin Bottom', 'happy-elementor-addons'), // 'type' => Controls_Manager::SLIDER, // 'size_units' => ['px'], // 'range' => [ // 'px' => [ // 'min' => 0, // 'max' => 100, // 'step' => 1, // ], // ], // 'default' => [ // 'unit' => 'px', // 'size' => 20, // ], // 'selectors' => [ // '{{WRAPPER}} .ha-mc-input-wrapper:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};', // ], // 'condition' => [ // 'form_style_switcher!' => 'yes' // ] // ] // ); // $this->add_responsive_control( // 'input_style_margin_right', // [ // 'label' => esc_html__('Margin Right', 'happy-elementor-addons'), // 'type' => Controls_Manager::SLIDER, // 'size_units' => ['px',], // 'range' => [ // 'px' => [ // 'min' => 0, // 'max' => 100, // 'step' => 1, // ], // ], // 'default' => [ // 'unit' => 'px', // 'size' => 30, // ], // 'selectors' => [ // // 'body[data-elementor-device-mode="desktop"] {{WRAPPER}}.ha-mailchimp-vertical .ha-mc-input-wrapper:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};', // 'body[data-elementor-device-mode="desktop"] {{WRAPPER}}.ha-mailchimp-horizontal .ha-mc-input-wrapper:not(:last-child)' => 'margin-right: {{SIZE}}{{UNIT}};', // // 'body[data-elementor-device-mode="tablet"] {{WRAPPER}}.ha-mailchimp-tablet-vertical .ha-mc-input-wrapper:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};', // 'body[data-elementor-device-mode="tablet"] {{WRAPPER}}.ha-mailchimp-tablet-horizontal .ha-mc-input-wrapper:not(:last-child)' => 'margin-right: {{SIZE}}{{UNIT}};', // // 'body[data-elementor-device-mode="mobile"] {{WRAPPER}}.ha-mailchimp-mobile-vertical .ha-mc-input-wrapper:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};', // 'body[data-elementor-device-mode="mobile"] {{WRAPPER}}.ha-mailchimp-mobile-horizontal .ha-mc-input-wrapper:not(:last-child)' => 'margin-right: {{SIZE}}{{UNIT}};', // // '{{WRAPPER}} .ha-mailchimp-form.horizontal .ha-mc-input-wrapper:not(:last-child)' => 'margin-right: {{SIZE}}{{UNIT}};', // ], // 'condition' => [ // 'form_style_switcher' => 'yes' // ] // ] // ); // $this->add_responsive_control( // 'inline_margin_bottom', // [ // 'label' => esc_html__('Margin Bottom', 'happy-elementor-addons'), // 'type' => Controls_Manager::SLIDER, // 'devices' => ['mobile'], // 'selectors' => [ // '{{WRAPPER}} .multiple_form_fields > .ha-mc-input-wrapper:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};', // ], // 'condition' => [ // 'form_style_switcher' => 'yes', // Inline Style // 'section_form_name_show' => 'yes', // Show Names // ] // ] // ); $this->add_control( 'input_style_placeholder_heading', [ 'label' => esc_html__( 'Placeholder', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', ] ); $this->add_control( 'input_style_placeholder_color', [ 'label' => esc_html__( 'Placeholder Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#000000', 'selectors' => [ '{{WRAPPER}} .ha-mc-input input::-webkit-input-placeholder' => 'color: {{VALUE}}', '{{WRAPPER}} .ha-mc-input input::-moz-placeholder' => 'color: {{VALUE}}', '{{WRAPPER}} .ha-mc-input input:-ms-input-placeholder' => 'color: {{VALUE}}', '{{WRAPPER}} .ha-mc-input input:-moz-placeholder' => 'color: {{VALUE}}', ], ] ); $this->add_responsive_control( 'input_style_placeholder_font_size', [ 'label' => esc_html__( 'Font Size', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, 'step' => 1, ], ], 'default' => [ 'unit' => 'px', 'size' => 14, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-input input::-webkit-input-placeholder' => 'font-size: {{SIZE}}{{UNIT}};', '{{WRAPPER}} .ha-mc-input input::-moz-placeholder' => 'font-size: {{SIZE}}{{UNIT}};', '{{WRAPPER}} .ha-mc-input input:-ms-input-placeholder' => 'font-size: {{SIZE}}{{UNIT}};', '{{WRAPPER}} .ha-mc-input input:-moz-placeholder' => 'font-size: {{SIZE}}{{UNIT}};', ], ] ); $this->end_controls_section(); } protected function __input_icon_style_controls() { $this->start_controls_section( 'input_icon_style_holder', [ 'label' => esc_html__( 'Input Icon', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'input_icon_background', 'label' => esc_html__( 'Background', 'happy-elementor-addons' ), 'types' => ['classic', 'gradient'], 'selector' => '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper', 'exclude' => [ 'image', ], ] ); $this->add_control( 'input_icon_color_hr', [ 'type' => Controls_Manager::DIVIDER, ] ); $this->add_control( 'input_icon_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#000000', 'selectors' => [ '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper i' => 'color: {{VALUE}};', '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper svg path' => 'stroke: {{VALUE}}; fill: {{VALUE}};', ], ] ); $this->add_responsive_control( 'input_icon_font_size', [ 'label' => esc_html__( 'Font Size', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => 0, 'max' => 200, 'step' => 1, ], ], 'default' => [ 'unit' => 'px', 'size' => 10, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper' => 'font-size: {{SIZE}}{{UNIT}};', '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper svg' => 'max-width: {{SIZE}}{{UNIT}}; max-height: {{SIZE}}{{UNIT}};', // '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper svg' => 'height: 1em, width: auto;', ], ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'input_icon_border', 'label' => esc_html__( 'Border', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper', ] ); $this->add_responsive_control( 'input_icon_padding', [ 'label' => esc_html__( 'Padding', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'input_icon_border_radius', [ 'label' => esc_html__( 'Border Radius', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-input .ha-mc-icon-wrapper' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}} !important;;', ], ] ); $this->end_controls_section(); } protected function __button_style_controls() { $this->start_controls_section( 'button_style_holder', [ 'label' => esc_html__( 'Button', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'button_typography', 'label' => esc_html__( 'Typography', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-button', ] ); $this->add_responsive_control( 'button_border_radius', [ 'label' => esc_html__( 'Border Radius', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-button' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'button_padding', [ 'label' => esc_html__( 'Padding', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'devices' => ['desktop', 'tablet', 'mobile'], 'desktop_default' => [ 'top' => 8, 'right' => 20, 'bottom' => 8, 'left' => 20, 'unit' => 'px', 'isLinked' => '', ], 'tablet_default' => [ 'top' => 8, 'right' => 15, 'bottom' => 8, 'left' => 15, 'unit' => 'px', 'isLinked' => '', ], 'mobile_default' => [ 'top' => 8, 'right' => 10, 'bottom' => 8, 'left' => 10, 'unit' => 'px', 'isLinked' => '', ], 'selectors' => [ '{{WRAPPER}} .ha-mc-button' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'button_box_shadow', 'label' => esc_html__( 'Box Shadow', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-button', ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'button_border', 'label' => esc_html__( 'Border', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-button', ] ); $this->add_group_control( Group_Control_Text_Shadow::get_type(), [ 'name' => 'button_title_shadow', 'selector' => '{{WRAPPER}} .ha-mc-button', ] ); $this->add_control( 'button_style_use_width_height', [ 'label' => esc_html__( 'Use Width', 'happy-elementor-addons' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'happy-elementor-addons' ), 'label_off' => esc_html__( 'Hide', 'happy-elementor-addons' ), 'return_value' => 'yes', 'default' => 'no', ] ); $this->add_responsive_control( 'button_width', [ 'label' => esc_html__( 'Width', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px', '%'], 'range' => [ 'px' => [ 'min' => 50, 'max' => 1000, 'step' => 1, ], '%' => [ 'min' => 10, 'max' => 100, ], ], 'default' => [ 'unit' => 'px', 'size' => 50, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-button-wrapper' => 'width: {{SIZE}}{{UNIT}};', ], 'condition' => [ 'button_style_use_width_height' => 'yes', ], ] ); $this->add_responsive_control( 'button_style_margin', [ 'label' => esc_html__( 'Margin', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-button' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->start_controls_tabs( 'button_normal_and_hover_tabs' ); $this->start_controls_tab( 'button_normal_tab', [ 'label' => esc_html__( 'Normal', 'happy-elementor-addons' ), ] ); $this->add_control( 'button_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#fff', 'selectors' => [ '{{WRAPPER}} .ha-mc-button' => 'color: {{VALUE}};', '{{WRAPPER}} .ha-mc-button svg path' => 'stroke: {{VALUE}}; fill: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'button_background', 'label' => esc_html__( 'Background', 'happy-elementor-addons' ), 'types' => ['classic', 'gradient'], 'selector' => '{{WRAPPER}} .ha-mc-button', 'exclude' => [ 'image', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'button_hover_tab', [ 'label' => esc_html__( 'Hover', 'happy-elementor-addons' ), ] ); $this->add_control( 'button_color_hover', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'default' => '#fff', 'selectors' => [ '{{WRAPPER}} .ha-mc-button:hover' => 'color: {{VALUE}};', '{{WRAPPER}} .ha-mc-button:hover svg path' => 'stroke: {{VALUE}}; fill: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'button_background_hover', 'label' => esc_html__( 'Background', 'happy-elementor-addons' ), 'types' => ['classic', 'gradient'], 'selector' => '{{WRAPPER}} .ha-mc-button:hover', 'exclude' => [ 'image', ], ] ); $this->add_control( 'button_border_color_hover', [ 'label' => esc_html__( 'Border Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ha-mc-button:hover' => 'border-color: {{VALUE}};', ], 'condition' => [ 'button_border_border!' => '', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_control( 'button_icon_heading', [ 'label' => esc_html__( 'Icon', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', ] ); $this->add_responsive_control( 'button_icon_padding_right', [ 'label' => esc_html__( 'Icon Spacing', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, 'step' => 1, ], ], 'default' => [ 'unit' => 'px', 'size' => 10, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > i, {{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > svg' => 'margin-right: {{SIZE}}{{UNIT}};', ], 'condition' => [ 'button_icon_position' => 'before', ], ] ); $this->add_responsive_control( 'button_icon_padding_left', [ 'label' => esc_html__( 'Icon Spacing', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, 'step' => 1, ], ], 'default' => [ 'unit' => 'px', 'size' => 10, ], 'selectors' => [ '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > i, {{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > svg' => 'margin-left: {{SIZE}}{{UNIT}};', ], 'condition' => [ 'button_icon_position' => 'after', ], ] ); $this->add_responsive_control( 'button_icon_size', [ 'label' => esc_html__( 'Icon Size', 'happy-elementor-addons' ), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px', '%'], 'range' => [ 'px' => [ 'min' => 1, 'max' => 100, 'step' => 5, ], '%' => [ 'min' => 1, 'max' => 100, ], ], 'default' => [ 'unit' => 'px', 'size' => 10, ], 'selectors' => [ // '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > i, {{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > i' => 'font-size: {{SIZE}}{{UNIT}};', // '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > i, {{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper > svg' => 'max-width: {{SIZE}}{{UNIT}}; height: auto', '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper' => 'font-size: {{SIZE}}{{UNIT}};', '{{WRAPPER}} .ha-mc-button .ha-mc-icon-wrapper svg' => 'max-width: {{SIZE}}{{UNIT}}; max-height: {{SIZE}}{{UNIT}}', ], ] ); $this->end_controls_section(); } protected function __success_error_style_controls() { $this->start_controls_section( 'success_error', [ 'label' => esc_html__( 'Success & Error Message', 'happy-elementor-addons' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'success_error_padding', [ 'label' => esc_html__( 'Padding', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'selectors' => [ '{{WRAPPER}} .ha-mc-response-message' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'success_error_margin', [ 'label' => esc_html__( 'Margin', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'selectors' => [ '{{WRAPPER}} .ha-mc-response-message' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_control( 'success_error_border_radius', [ 'label' => esc_html__( 'Border Radius', 'happy-elementor-addons' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%', 'em'], 'selectors' => [ '{{WRAPPER}} .ha-mc-response-message' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'success_error_typography', 'selector' => '{{WRAPPER}} .ha-mc-response-message', ] ); $this->add_control( 'success_heading', [ 'label' => esc_html__( 'Success:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, ] ); $this->add_control( 'success_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ha-mc-response-message.success' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'success_bg_color', 'label' => esc_html__( 'Background Color', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-response-message.success', ) ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'success_border', 'label' => esc_html__( 'Border', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-response-message.success', ] ); $this->add_control( 'error_heading', [ 'label' => esc_html__( 'Error:', 'happy-elementor-addons' ), 'type' => Controls_Manager::HEADING, ] ); $this->add_control( 'error_color', [ 'label' => esc_html__( 'Color', 'happy-elementor-addons' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ha-mc-response-message.error' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), array( 'name' => 'error_bg_color', 'label' => esc_html__( 'Background Color', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-response-message.error', ) ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'error_border', 'label' => esc_html__( 'Border', 'happy-elementor-addons' ), 'selector' => '{{WRAPPER}} .ha-mc-response-message.error', ] ); $this->end_controls_section(); } protected function render() { $settings = $this->get_settings_for_display(); $form_fields = ( ( $settings['enable_name'] == 'yes' || $settings['enable_phone'] == 'yes' ) ? 'multiple_form_fields' : '' ); $list_id = ( ( is_array( $settings['mailchimp_lists'] ) ) ? ( isset( $settings['mailchimp_lists'][0] ) ? ltrim( $settings['mailchimp_lists'][0] ) : '' ) : ( ltrim( $settings['mailchimp_lists'] ) ) ); ?> <div class="ha-mailchimp-wrapper" data-post-id="<?php echo esc_attr( get_the_ID() ); ?>" data-widget-id="<?php echo esc_attr( $this->get_id() ); ?>"> <?php if ( \Elementor\Plugin::$instance->editor->is_edit_mode() && $settings['mailchimp_success_message_show_in_editor'] == 'yes' ) : ?> <div class="ha-mc-response-message success"><?php esc_html_e( 'This is a dummy message for success. This won\'t show in preview', 'happy-elementor-addons' ); ?></div> <?php endif; ?> <?php if ( \Elementor\Plugin::$instance->editor->is_edit_mode() && $settings['mailchimp_error_message_show_in_editor'] == 'yes' ) : ?> <div class="ha-mc-response-message error"><?php esc_html_e( 'This is a dummy message for error. This won\'t show in preview', 'happy-elementor-addons' ); ?></div> <?php endif; ?> <div class="ha-mc-response-message"></div> <form class="ha-mailchimp-form <?php echo esc_attr( $form_fields ); ?>" data-list-id="<?php echo esc_attr( $list_id ); ?>" data-success-message="<?php echo esc_attr($settings['mailchimp_success_message']); ?>"> <?php if ( $settings['enable_name'] == 'yes' ) : ?> <div class="ha-mc-input-wrapper"> <?php if ( ! empty( $settings['fname_label'] ) ) : ?> <label class="ha-mc-input-label"><?php echo esc_html( $settings['fname_label'] ); ?></label> <?php endif; ?> <div class="ha-mc-input <?php echo esc_attr( $settings['fname_icon_position'] ); ?>"> <?php if ( $settings['fname_enable_icon'] == 'yes' && $settings['fname_icon_position'] == 'before' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'fname_icon' ); ?></div> <?php endif; ?> <input type="text" name="fname" placeholder="<?php echo esc_attr( $settings['fname_placeholder'] ); ?>"> <?php if ( $settings['fname_enable_icon'] == 'yes' && $settings['fname_icon_position'] == 'after' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'fname_icon' ); ?></div> <?php endif; ?> </div> </div> <div class="ha-mc-input-wrapper"> <?php if ( ! empty( $settings['lname_label'] ) ) : ?> <label class="ha-mc-input-label"><?php echo esc_html( $settings['lname_label'] ); ?></label> <?php endif; ?> <div class="ha-mc-input <?php echo esc_attr( $settings['lname_icon_position'] ); ?>"> <?php if ( $settings['lname_enable_icon'] == 'yes' && $settings['lname_icon_position'] == 'before' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'lname_icon' ); ?></div> <?php endif; ?> <input type="text" name="lname" placeholder="<?php echo esc_attr( $settings['lname_placeholder'] ); ?>"> <?php if ( $settings['lname_enable_icon'] == 'yes' && $settings['lname_icon_position'] == 'after' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'lname_icon' ); ?></div> <?php endif; ?> </div> </div> <?php endif; ?> <?php if ( $settings['enable_phone'] == 'yes' ) : ?> <div class="ha-mc-input-wrapper"> <?php if ( ! empty( $settings['phone_label'] ) ) : ?> <label class="ha-mc-input-label"><?php echo esc_html( $settings['phone_label'] ); ?></label> <?php endif; ?> <div class="ha-mc-input <?php echo esc_attr( $settings['phone_icon_position'] ); ?>"> <?php if ( $settings['phone_enable_icon'] == 'yes' && $settings['phone_icon_position'] == 'before' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'phone_icon' ); ?></div> <?php endif; ?> <input type="text" name="phone" placeholder="<?php echo esc_attr( $settings['phone_placeholder'] ); ?>"> <?php if ( $settings['phone_enable_icon'] == 'yes' && $settings['phone_icon_position'] == 'after' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'phone_icon' ); ?></div> <?php endif; ?> </div> </div> <?php endif; ?> <div class="ha-mc-input-wrapper"> <?php if ( ! empty( $settings['email_label'] ) ) : ?> <label class="ha-mc-input-label"><?php echo esc_html( $settings['email_label'] ); ?></label> <?php endif; ?> <div class="ha-mc-input <?php echo esc_attr( $settings['email_icon_position'] ); ?>"> <?php if ( $settings['email_enable_icon'] == 'yes' && $settings['email_icon_position'] == 'before' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'email_icon' ); ?></div> <?php endif; ?> <input type="email" name="email" placeholder="<?php echo esc_attr( $settings['email_placeholder'] ); ?>" required> <?php if ( $settings['email_enable_icon'] == 'yes' && $settings['email_icon_position'] == 'after' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'email_icon' ); ?></div> <?php endif; ?> </div> </div> <div class="ha-mc-button-wrapper"> <button type="submit" class="ha-mc-button" name="ha-mailchimp"> <?php if ( $settings['button_enable_icon'] == 'yes' && $settings['button_icon_position'] == 'before' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'button_icon' ); ?></div> <?php endif; ?> <?php echo esc_attr( $settings['button_text'] ); ?> <?php if ( $settings['button_enable_icon'] == 'yes' && $settings['button_icon_position'] == 'after' ) : ?> <div class="ha-mc-icon-wrapper"><?php ha_render_icon( $settings, null, 'button_icon' ); ?></div> <?php endif; ?> </button> </div> </form> </div> <?php } }