File: /home/emerlux/public_html/wp-content/plugins/porto-functionality/elementor/widgets/info_box.php
<?php
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
/**
* Porto Elementor Info Box Widget
*
* Porto Elementor widget to display icon boxes.
*
* @since 1.5.0
*/
use Elementor\Controls_Manager;
use Elementor\Group_Control_Border;
use Elementor\Group_Control_Typography;
class Porto_Elementor_Info_Box_Widget extends \Elementor\Widget_Base {
public function get_name() {
return 'porto_info_box';
}
public function get_title() {
return __( 'Porto Info Box', 'porto-functionality' );
}
public function get_categories() {
return array( 'porto-elements' );
}
public function has_widget_inner_wrapper(): bool {
return ! Elementor\Plugin::$instance->experiments->is_feature_active( 'e_optimized_markup' );
}
public function get_keywords() {
return array( 'icon', 'info box', 'image box', 'icon box' );
}
public function get_icon() {
return 'eicon-info-box porto-elementor-widget-icon';
}
protected function is_dynamic_content(): bool {
return false;
}
protected function register_controls() {
$this->start_controls_section(
'section_info_box',
array(
'label' => __( 'Info Box', 'porto-functionality' ),
)
);
$this->add_control(
'pos',
array(
'type' => Controls_Manager::SELECT,
'label' => __( 'Layout', 'porto-functionality' ),
'options' => array(
'default' => __( 'Icon at Left with heading', 'porto-functionality' ),
'heading-right' => __( 'Icon at Right with heading', 'porto-functionality' ),
'left' => __( 'Icon at Left', 'porto-functionality' ),
'right' => __( 'Icon at Right', 'porto-functionality' ),
'top' => __( 'Icon at Top', 'porto-functionality' ),
),
'default' => 'default',
'description' => __( 'Select icon position. Icon box style will be changed according to the icon position.', 'porto-functionality' ),
)
);
$this->add_responsive_control(
'h_align',
array(
'type' => Controls_Manager::CHOOSE,
'label' => __( 'Horizontal Align', 'porto-functionality' ),
'options' => array(
'center' => array(
'title' => esc_html__( 'Center', 'porto-functionality' ),
'icon' => 'eicon-text-align-center',
),
'left' => array(
'title' => esc_html__( 'left', 'porto-functionality' ),
'icon' => 'eicon-text-align-left',
),
'right' => array(
'title' => esc_html__( 'Right', 'porto-functionality' ),
'icon' => 'eicon-text-align-right',
),
),
'default' => 'center',
'condition' => array(
'pos' => 'top',
),
'render_type' => 'template',
'selectors' => array(
'.elementor-element-{{ID}} .porto-sicon-box.top-icon' => 'text-align: {{VALUE}};',
),
)
);
$this->add_control(
'icon_type',
array(
'label' => __( 'Icon to display', 'porto-functionality' ),
'type' => Controls_Manager::SELECT,
'options' => array(
'icon' => __( 'Icon Fonts', 'porto-functionality' ),
'custom' => __( 'Custom Image Icon', 'porto-functionality' ),
),
'default' => 'icon',
'description' => __( 'Use an existing font icon or upload a custom image.', 'porto-functionality' ),
)
);
$this->add_control(
'icon_cl',
array(
'type' => Controls_Manager::ICONS,
'label' => __( 'Icon', 'porto-functionality' ),
'fa4compatibility' => 'icon',
'default' => array(
'value' => 'fas fa-star',
'library' => 'fa-solid',
),
'condition' => array(
'icon_type' => 'icon',
),
)
);
$this->add_control(
'icon_img',
array(
'type' => Controls_Manager::MEDIA,
'label' => __( 'Upload Image Icon:', 'porto-functionality' ),
'description' => __( 'Upload the custom image icon.', 'porto-functionality' ),
'dynamic' => array(
'active' => true,
),
'condition' => array(
'icon_type' => array( 'custom' ),
),
)
);
$this->add_control(
'icon_img_url',
array(
'type' => Controls_Manager::TEXT,
'label' => __( 'External Image Url', 'porto-functionality' ),
'condition' => array(
'icon_type' => array( 'custom' ),
),
)
);
$this->add_control(
'title',
array(
'type' => Controls_Manager::TEXT,
'label' => __( 'Title', 'porto-functionality' ),
'description' => __( 'Provide the title for this icon box.', 'porto-functionality' ),
'dynamic' => array(
'active' => true,
),
)
);
$this->add_control(
'subtitle',
array(
'type' => Controls_Manager::TEXT,
'label' => __( 'Sub title', 'porto-functionality' ),
'description' => __( 'Provide the sub title for this icon box.', 'porto-functionality' ),
'dynamic' => array(
'active' => true,
),
)
);
$this->add_control(
'content',
array(
'type' => Controls_Manager::WYSIWYG,
'label' => __( 'Description', 'porto-functionality' ),
'description' => __( 'Provide the description for this icon box.', 'porto-functionality' ),
)
);
$this->add_control(
'read_more',
array(
'type' => Controls_Manager::SELECT,
'label' => __( 'Apply link to:', 'porto-functionality' ),
'options' => array(
'none' => __( 'No Link', 'porto-functionality' ),
'box' => __( 'Complete Box', 'porto-functionality' ),
'title' => __( 'Box Title', 'porto-functionality' ),
'more' => __( 'Display Read More', 'porto-functionality' ),
),
'default' => 'none',
)
);
$this->add_control(
'link',
array(
'type' => Controls_Manager::URL,
'label' => __( 'Add Link', 'porto-functionality' ),
'description' => __( 'Add a custom link or select existing page.', 'porto-functionality' ),
'condition' => array(
'read_more' => array( 'box', 'title', 'more' ),
),
'dynamic' => array(
'active' => true,
),
)
);
$this->add_control(
'link_color_hover',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Hover Color', 'porto-functionality' ),
'condition' => array(
'read_more' => array( 'box' ),
),
'selectors' => array(
'{{WRAPPER}}:hover .porto-sicon-title, {{WRAPPER}}:hover .porto-icon, {{WRAPPER}}:hover .porto-sicon-img, {{WRAPPER}}:hover .porto-sicon-description, {{WRAPPER}}:hover .porto-sicon-header p' => 'color: {{VALUE}};',
'.elementor-element-{{ID}} .porto-sicon-title, .elementor-element-{{ID}} .porto-sicon-header p, .elementor-element-{{ID}} .porto-sicon-description' => 'transition: color .3s;',
),
)
);
$this->add_control(
'read_text',
array(
'type' => Controls_Manager::TEXT,
'label' => __( 'Read More Text', 'porto-functionality' ),
'default' => 'Read More',
'description' => __( 'Customize the read more text.', 'porto-functionality' ),
'condition' => array(
'read_more' => 'more',
),
)
);
$this->add_control(
'hover_effect',
array(
'type' => Controls_Manager::SELECT,
'label' => __( 'Select Hover Effect type', 'porto-functionality' ),
'options' => array(
'style_1' => __( 'No Effect', 'porto-functionality' ),
'style_2' => __( 'Icon Zoom', 'porto-functionality' ),
'style_3' => __( 'Icon Slide Up', 'porto-functionality' ),
'hover-icon-left' => __( 'Icon Slide Left', 'porto-functionality' ),
'hover-icon-right' => __( 'Icon Slide Right', 'porto-functionality' ),
),
'default' => 'style_1',
'description' => __( 'Select the type of effct you want on hover', 'porto-functionality' ),
)
);
$this->end_controls_section();
$this->start_controls_section(
'section_mobile_layout',
array(
'label' => __( 'Mobile Layout ( <=575px )', 'porto-functionality' ),
'condition' => array(
'pos' => array( 'default', 'heading-right', 'left', 'right' ),
),
)
);
$this->add_control(
'mobile_pos',
array(
'type' => Controls_Manager::SWITCHER,
'label' => __( 'Layout', 'porto-functionality' ),
'description' => __( 'Display the info box as \'Icon at Top\' layout.', 'porto-functionality' ),
'selectors' => array(
'.elementor-element-{{ID}} .porto-sicon-box' => '--porto-infobox-mpos: column;',
),
)
);
$this->add_control(
'mobile_valign',
array(
'label' => esc_html__( 'Alignment', 'porto-functionality' ),
'type' => Controls_Manager::CHOOSE,
'description' => esc_html__( 'Control the horizontal align.', 'porto-functionality' ),
'options' => array(
'left' => array(
'title' => esc_html__( 'Left', 'porto-functionality' ),
'icon' => 'eicon-text-align-left',
),
'center' => array(
'title' => esc_html__( 'Center', 'porto-functionality' ),
'icon' => 'eicon-text-align-center',
),
'right' => array(
'title' => esc_html__( 'Right', 'porto-functionality' ),
'icon' => 'eicon-text-align-right',
),
),
'condition' => array(
'mobile_pos' => 'yes',
),
'selectors' => array(
'.elementor-element-{{ID}} .porto-sicon-box' => '--porto-infobox-mpos-align: {{VALUE}};',
),
)
);
$this->end_controls_section();
$this->start_controls_section(
'section_info_box_style_icon',
array(
'label' => __( 'Icon', 'porto-functionality' ),
'tab' => Controls_Manager::TAB_STYLE,
)
);
$this->add_control(
'icon_style',
array(
'type' => Controls_Manager::SELECT,
'label' => __( 'Icon Style', 'porto-functionality' ),
'options' => array(
'none' => __( 'Simple', 'porto-functionality' ),
'advanced' => __( 'Design your own(Recommended)', 'porto-functionality' ),
'circle' => __( 'Circle Background', 'porto-functionality' ),
'circle_img' => __( 'Circle Image(Use image instead of icon on Content > Icon option)', 'porto-functionality' ),
'square' => __( 'Square Background', 'porto-functionality' ),
),
'default' => 'none',
)
);
$this->add_responsive_control(
'img_width',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Image Width', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 16,
'max' => 512,
),
'em' => array(
'step' => 1,
'min' => 0,
'max' => 72,
),
),
'default' => array(
'unit' => 'px',
'size' => 48,
),
'size_units' => array(
'px',
'em',
),
'description' => __( 'Provide image width', 'porto-functionality' ),
'condition' => array(
'icon_type' => 'custom',
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-img' => 'font-size: {{SIZE}}{{UNIT}};',
),
)
);
$this->add_responsive_control(
'icon_size',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Font Size', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 12,
'max' => 72,
),
'em' => array(
'step' => 1,
'min' => 0,
'max' => 72,
),
),
'default' => array(
'unit' => 'px',
'size' => 32,
),
'size_units' => array(
'px',
'em',
),
'condition' => array(
'icon_type' => 'icon',
),
'selectors' => array(
'{{WRAPPER}} .porto-icon' => 'font-size: {{SIZE}}{{UNIT}};',
),
)
);
$this->add_control(
'icon_color',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Color', 'porto-functionality' ),
'default' => '#333333',
'condition' => array(
'icon_type' => 'icon',
),
'selectors' => array(
'{{WRAPPER}} .porto-icon' => 'color: {{VALUE}};',
'{{WRAPPER}} .porto-icon svg' => 'fill: {{VALUE}};',
),
)
);
$this->add_control(
'icon_color_bg',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Background Color', 'porto-functionality' ),
'default' => '#ffffff',
'description' => __( 'Select background color for icon.', 'porto-functionality' ),
'condition' => array(
'icon_style' => array( 'circle', 'circle_img', 'square', 'advanced' ),
),
'selectors' => array(
'.elementor-element-{{ID}} .porto-sicon-img.porto-u-circle-img:before' => 'border-color: {{VALUE}};',
'.elementor-element-{{ID}} .porto-sicon-img' => 'background: {{VALUE}};',
'.elementor-element-{{ID}} .porto-icon' => 'background: {{VALUE}};',
),
)
);
$this->add_control(
'icon_hv_bcolor',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Hover Background Color', 'porto-functionality' ),
'condition' => array(
'icon_style' => array( 'circle', 'circle_img', 'square', 'advanced' ),
),
'selectors' => array(
'.elementor-element-{{ID}}:hover .porto-sicon-img.porto-u-circle-img:before' => 'border-color: {{VALUE}};',
'.elementor-element-{{ID}}:hover .porto-sicon-img' => 'background: {{VALUE}};',
'.elementor-element-{{ID}}:hover .porto-icon' => 'background: {{VALUE}};',
),
)
);
$this->add_group_control(
Group_Control_Border::get_type(),
array(
'name' => 'icon_bd',
'selector' => '{{WRAPPER}} .porto-sicon-img, {{WRAPPER}} .porto-icon.advanced',
'condition' => array(
'icon_style' => array( 'circle_img', 'advanced' ),
),
)
);
$this->add_responsive_control(
'icon_border_radius',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Border Radius (px)', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 1,
'max' => 200,
),
),
'default' => array(
'unit' => 'px',
'size' => 200,
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-img' => 'border-radius: {{SIZE}}{{UNIT}};',
'{{WRAPPER}} .porto-icon.advanced' => 'border-radius: {{SIZE}}{{UNIT}};',
),
'condition' => array(
'icon_style' => array( 'none', 'circle_img', 'advanced' ),
),
)
);
$this->add_responsive_control(
'icon_border_spacing',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Size (px)', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 0,
'max' => 500,
),
),
'default' => array(
'unit' => 'px',
'size' => 50,
),
'description' => __( 'Icon width and height', 'porto-functionality' ),
'condition' => array(
'icon_style' => array( 'advanced' ),
'icon_type!' => 'custom',
),
'selectors' => array(
'{{WRAPPER}} .porto-icon.advanced' => 'width: {{SIZE}}{{UNIT}}; height: {{SIZE}}{{UNIT}}; line-height: {{SIZE}}{{UNIT}};',
),
)
);
$this->add_control(
'icon_pd',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Spacing', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 0,
'max' => 500,
),
),
'default' => array(
'unit' => 'px',
'size' => 50,
),
'description' => __( 'Spacing from center of the icon till the boundary of border / background', 'porto-functionality' ),
'condition' => array(
'icon_style' => array( 'circle_img', 'advanced' ),
'icon_type' => 'custom',
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-img.porto-u-circle-img:before' => 'border-width: calc({{SIZE}}{{UNIT}} + 1px);',
'{{WRAPPER}} .porto-sicon-img' => 'padding: {{SIZE}}{{UNIT}};',
),
)
);
$this->add_responsive_control(
'icon_margin',
array(
'label' => esc_html__( 'Icon Margin', 'porto-functionality' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => array(
'px',
'em',
'rem',
),
'selectors' => array(
'{{WRAPPER}} .porto-icon, {{WRAPPER}} .porto-sicon-img' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
),
'qa_selector' => '.porto-icon, .porto-sicon-img',
)
);
$this->add_control(
'mobile_spacing',
array(
'label' => esc_html__( 'Icon Margin(<576px)', 'porto-functionality' ),
'description' => esc_html__( 'Controls the spacing of the icon.', 'porto-functionality' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => array(
'px',
'em',
'rem',
),
'selectors' => array(
'.elementor-element-{{ID}} .porto-sicon-box' => '--porto-infobox-mmargin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};'
),
'condition' => array(
'mobile_pos' => 'yes',
),
)
);
$this->end_controls_section();
$this->start_controls_section(
'section_info_box_style_title',
array(
'label' => __( 'Text', 'porto-functionality' ),
'tab' => Controls_Manager::TAB_STYLE,
)
);
$this->add_control(
'heading_tag',
array(
'type' => Controls_Manager::SELECT,
'label' => __( 'Title Tag', 'porto-functionality' ),
'options' => array(
'h3' => __( 'Default', 'porto-functionality' ),
'h1' => __( 'H1', 'porto-functionality' ),
'h2' => __( 'H2', 'porto-functionality' ),
'h4' => __( 'H4', 'porto-functionality' ),
'h5' => __( 'H5', 'porto-functionality' ),
'h6' => __( 'H6', 'porto-functionality' ),
'div' => __( 'DIV', 'porto-functionality' ),
'p' => __( 'P tag', 'porto-functionality' ),
),
'default' => 'h3',
'description' => __( 'Default is H3', 'porto-functionality' ),
)
);
$this->add_group_control(
Group_Control_Typography::get_type(),
array(
'name' => 'title_google_font_style',
'label' => __( 'Title Typography', 'porto-functionality' ),
'global' => array(
'active' => false,
),
'selector' => '{{WRAPPER}} .porto-sicon-title',
)
);
$this->add_control(
'title_font_color1',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Title Color', 'porto-functionality' ),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-title' => 'color: {{VALUE}};',
),
)
);
$this->add_control(
'title_font_color1_hover',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Title Hover Color', 'porto-functionality' ),
'condition' => array(
'read_more' => array( 'title' ),
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-title:hover' => 'color: {{VALUE}};',
'{{WRAPPER}} .porto-sicon-title' => 'transition: color .3s;',
),
)
);
$this->add_control(
'title_margin_top',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Title Margin Top', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 0,
'max' => 100,
),
'rem' => array(
'step' => 0.1,
'min' => 0,
'max' => 10,
),
),
'default' => array(
'unit' => 'px',
),
'size_units' => array(
'px',
'rem',
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-title' => 'margin-top: {{SIZE}}{{UNIT}};',
),
)
);
$this->add_control(
'title_margin_bottom',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Title Margin Bottom', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 0,
'max' => 100,
),
'rem' => array(
'step' => 0.1,
'min' => 0,
'max' => 10,
),
),
'default' => array(
'unit' => 'px',
),
'size_units' => array(
'px',
'rem',
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-title' => 'margin-bottom: {{SIZE}}{{UNIT}};',
),
'qa_selector' => '.porto-sicon-title',
'separator' => 'after',
)
);
$this->add_group_control(
Group_Control_Typography::get_type(),
array(
'name' => 'sub_title_google_font_style',
'label' => __( 'Sub Title Typography', 'porto-functionality' ),
'global' => array(
'active' => false,
),
'selector' => '{{WRAPPER}} .porto-sicon-header p',
)
);
$this->add_control(
'subtitle_font_color1',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Sub Title Color', 'porto-functionality' ),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-header p' => 'color: {{VALUE}};',
),
'separator' => 'after',
)
);
$this->add_group_control(
Group_Control_Typography::get_type(),
array(
'name' => 'desc_google_font_style',
'label' => __( 'Description Typography', 'porto-functionality' ),
'global' => array(
'active' => false,
),
'selector' => '{{WRAPPER}} .porto-sicon-description',
)
);
$this->add_control(
'desc_font_color1',
array(
'type' => Controls_Manager::COLOR,
'label' => __( 'Description Color', 'porto-functionality' ),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-description' => 'color: {{VALUE}};',
),
)
);
$this->add_control(
'sub_title_margin_bottom',
array(
'type' => Controls_Manager::SLIDER,
'label' => __( 'Spacing between Title & Description', 'porto-functionality' ),
'range' => array(
'px' => array(
'step' => 1,
'min' => 0,
'max' => 100,
),
'rem' => array(
'step' => 0.1,
'min' => 0,
'max' => 10,
),
),
'default' => array(
'unit' => 'px',
),
'size_units' => array(
'px',
'rem',
),
'selectors' => array(
'{{WRAPPER}} .porto-sicon-header' => 'margin-bottom: {{SIZE}}{{UNIT}};',
),
'qa_selector' => '.porto-sicon-description',
)
);
$this->end_controls_section();
}
protected function render() {
$atts = $this->get_settings_for_display();
if ( isset( $atts['icon_cl'] ) && isset( $atts['icon_cl']['value'] ) ) {
if ( isset( $atts['icon_cl']['library'] ) && isset( $atts['icon_cl']['value']['id'] ) ) {
$atts['icon_type'] = $atts['icon_cl']['library'];
$atts['icon'] = $atts['icon_cl']['value']['id'];
} else {
$atts['icon'] = $atts['icon_cl']['value'];
}
}
$atts['icon_size'] = '';
$atts['icon_border_size'] = '';
$atts['icon_border_radius'] = '';
$atts['icon_border_spacing'] = '';
if ( is_array( $atts['icon_img'] ) && ! empty( $atts['icon_img']['id'] ) ) {
$atts['img_width'] = '';
$atts['icon_img'] = (int) $atts['icon_img']['id'];
} elseif ( is_array( $atts['icon_img'] ) && ! empty( $atts['icon_img']['url'] ) ) {
$atts['icon_img'] = $atts['icon_img']['url'];
if ( isset( $atts['img_width'] ) && is_array( $atts['img_width'] ) ) {
$atts['img_width'] = $atts['img_width']['size'];
}
} elseif ( ! empty( $atts['icon_img_url'] ) && ( empty( $atts['icon_img'] ) || empty( $atts['icon_img']['id'] ) ) ) {
$atts['icon_img'] = $atts['icon_img_url'];
if ( isset( $atts['img_width'] ) && is_array( $atts['img_width'] ) ) {
$atts['img_width'] = $atts['img_width']['size'];
}
} elseif ( is_array( $atts['icon_img'] ) && empty( $atts['icon_img']['id'] ) ) {
$atts['icon_img'] = '';
$atts['img_width'] = '';
} else {
$atts['img_width'] = '';
}
if ( $template = porto_shortcode_template( 'porto_info_box' ) ) {
$this->add_inline_editing_attributes( 'title' );
$this->add_render_attribute( 'title', 'class', 'porto-sicon-title' );
$this->add_inline_editing_attributes( 'subtitle' );
$this->add_inline_editing_attributes( 'content', 'advanced' );
$title_attrs_escaped = ' ' . $this->get_render_attribute_string( 'title' );
$subtitle_attrs_escaped = ' ' . $this->get_render_attribute_string( 'subtitle' );
$desc_attrs_escaped = ' ' . $this->get_render_attribute_string( 'content' );
$atts['icon_color'] = '';
$atts['icon_color_bg'] = '';
$atts['icon_color_border'] = '';
$atts['icon_border_style'] = '';
if ( isset( $atts['icon_margin_right'] ) && isset( $atts['icon_margin_right']['size'] ) && ( $atts['icon_margin_right']['size'] || '0' == $atts['icon_margin_right']['size'] ) && ! empty( $atts['icon_margin_right']['unit'] ) ) {
$atts['icon_margin_right'] = $atts['icon_margin_right']['size'] . $atts['icon_margin_right']['unit'];
} else {
$atts['icon_margin_right'] = '';
}
if ( isset( $atts['icon_margin_bottom'] ) && isset( $atts['icon_margin_bottom']['size'] ) && ( $atts['icon_margin_bottom']['size'] || '0' == $atts['icon_margin_bottom']['size'] ) && ! empty( $atts['icon_margin_bottom']['unit'] ) ) {
$atts['icon_margin_bottom'] = $atts['icon_margin_bottom']['size'] . $atts['icon_margin_bottom']['unit'];
} else {
$atts['icon_margin_bottom'] = '';
}
$atts['title_margin_bottom'] = '';
$atts['sub_title_margin_bottom'] = '';
$atts['page_builder'] = 'elementor';
include $template;
}
}
protected function content_template() {
?>
<#
if ( settings.icon_img_url && ! settings.icon_img.url ) {
settings.icon_img.url = settings.icon_img_url;
}
view.addRenderAttribute( 'wrapper', 'class', 'porto-sicon-box' );
if ( settings.mobile_pos ) {
view.addRenderAttribute( 'wrapper', 'class', 'porto-sicon-mobile' );
if ( '' != settings.mobile_spacing.left || '' != settings.mobile_spacing.right ||'' != settings.mobile_spacing.top ||'' != settings.mobile_spacing.bottom ) {
view.addRenderAttribute( 'wrapper', 'class', 'porto-sicon-mspace' );
}
}
if ( settings.hover_effect ) {
view.addRenderAttribute( 'wrapper', 'class', settings.hover_effect );
}
if ( settings.pos ) {
view.addRenderAttribute( 'wrapper', 'class', settings.pos + '-icon' );
if ( 'default' == settings.pos && settings.content ) {
view.addRenderAttribute( 'wrapper', 'class', 'flex-wrap' );
}
view.addRenderAttribute( 'icon-wrapper', 'class', 'porto-sicon-' + settings.pos );
}
var box_html = '';
if ( 'custom' == settings.icon_type ) {
view.addRenderAttribute( 'porto-sicon-img', 'class', 'porto-sicon-img' );
if ( 'circle' == settings.icon_style ) {
view.addRenderAttribute( 'porto-sicon-img', 'class', 'porto-u-circle' );
}
if ( 'circle_img' == settings.icon_style ) {
view.addRenderAttribute( 'porto-sicon-img', 'class', 'porto-u-circle-img' );
}
if ( 'square' == settings.icon_style ) {
view.addRenderAttribute( 'porto-sicon-img', 'class', 'porto-u-square' );
}
if ( settings.icon_img.url ) {
box_html += '<div style="display: inline-block;" ' + view.getRenderAttributeString( 'porto-sicon-img' ) + '>';
box_html += '<img class="img-icon" src="' + settings.icon_img.url + '" />';
box_html += '</div>';
}
} else if ( settings.icon_cl.value ) {
view.addRenderAttribute( 'porto-icon', 'class', 'porto-icon' );
if ( settings.icon_style ) {
view.addRenderAttribute( 'porto-icon', 'class', settings.icon_style );
}
box_html += '<div style="display: inline-block;" ' + view.getRenderAttributeString( 'porto-icon' ) + '>';
if ( 'svg' == settings.icon_cl.library ) {
let svgHtml = elementor.helpers.renderIcon( view, settings.icon_cl, { 'aria-hidden': true }, 'i' , 'object' );
if ( svgHtml && svgHtml.value ) {
box_html += svgHtml.value;
}
} else {
box_html += '<i class="' + settings.icon_cl.value + '"></i>';
}
box_html += '</div>';
}
if ( box_html ) {
box_html = '<div class="porto-just-icon-wrapper">' + box_html + '</div>';
}
if ( settings.link && settings.link.url ) {
view.addRenderAttribute( 'link', 'href', settings.link.url );
if ( 'more' == settings.read_more ) {
view.addRenderAttribute( 'link', 'class', 'porto-sicon-read' );
} else {
view.addRenderAttribute( 'link', 'class', 'porto-sicon-box-link' );
}
}
view.addRenderAttribute( 'title', 'class', 'porto-sicon-title' );
view.addInlineEditingAttributes( 'title' );
view.addInlineEditingAttributes( 'subtitle' );
view.addInlineEditingAttributes( 'content', 'advanced' );
#>
<# if ( settings.link && 'box' == settings.read_more ) { #>
<a {{{ view.getRenderAttributeString( 'link' ) }}}>
<# } #>
<div {{{ view.getRenderAttributeString( 'wrapper' ) }}}>
<# if ( 'heading-right' == settings.pos || 'right' == settings.pos ) { #>
<# if ( 'right' == settings.pos ) { #>
<div class="porto-sicon-body">
<# } #>
<# if ( settings.title || settings.subtitle ) { #>
<div class="porto-sicon-header">
<# if ( settings.title ) { #>
<# if ( settings.link && 'title' == settings.read_more ) { #>
<a {{{ view.getRenderAttributeString( 'link' ) }}}>
<# } #>
<{{{ settings.heading_tag }}} {{{ view.getRenderAttributeString( 'title' ) }}}>{{{ settings.title }}}</{{{ settings.heading_tag }}}>
<# if ( settings.link && 'title' == settings.read_more ) { #>
</a>
<# } #>
<# } #>
<# if ( settings.subtitle ) { #>
<p {{{ view.getRenderAttributeString( 'subtitle' ) }}}>{{{ settings.subtitle }}}</p>
<# } #>
</div>
<# } #>
<# if ( 'right' !== settings.pos ) { #>
<# if ( 'none' !== settings.icon_cl.value || settings.icon_img.url ) { #>
<div {{{ view.getRenderAttributeString( 'icon-wrapper' ) }}}>{{{ box_html }}}</div>
<# } #>
<# } #>
<# if ( settings.content ) { #>
<div class="porto-sicon-description" {{{ view.getRenderAttributeString( 'description' ) }}}>
{{{ settings.content }}}
<# if ( settings.link && 'more' == settings.read_more ) { #>
<a {{{ view.getRenderAttributeString( 'link' ) }}}>
{{{ settings.read_text }}}
<span> »</span>
</a>
<# } #>
</div>
<# } #>
<# if ( 'right' == settings.pos ) { #>
</div>
<# if ( 'none' !== settings.icon_cl.value || settings.icon_img.url ) { #>
<div {{{ view.getRenderAttributeString( 'icon-wrapper' ) }}}>{{{ box_html }}}</div>
<# } #>
<# } #>
<# } else { #>
<# if ( 'none' !== settings.icon_cl.value || settings.icon_img.url ) { #>
<div {{{ view.getRenderAttributeString( 'icon-wrapper' ) }}}>{{{ box_html }}}</div>
<# } #>
<# if ( 'left' == settings.pos ) { #>
<div class="porto-sicon-body">
<# } #>
<# if ( settings.title || settings.subtitle ) { #>
<div class="porto-sicon-header">
<# if ( settings.title ) { #>
<# if ( settings.link && 'title' == settings.read_more ) { #>
<a {{{ view.getRenderAttributeString( 'link' ) }}}>
<# } #>
<{{{ settings.heading_tag }}} {{{ view.getRenderAttributeString( 'title' ) }}}>{{{ settings.title }}}</{{{ settings.heading_tag }}}>
<# if ( settings.link && 'title' == settings.read_more ) { #>
</a>
<# } #>
<# } #>
<# if ( settings.subtitle ) { #>
<p {{{ view.getRenderAttributeString( 'subtitle' ) }}}>{{{ settings.subtitle }}}</p>
<# } #>
</div>
<# } #>
<# if ( settings.content || ( settings.link && 'more' == settings.read_more && settings.read_text ) ) { #>
<div class="porto-sicon-description" {{{ view.getRenderAttributeString( 'content' ) }}}>
{{{ settings.content }}}
<# if ( settings.link && 'more' == settings.read_more ) { #>
<a {{{ view.getRenderAttributeString( 'link' ) }}}>
{{{ settings.read_text }}}
<span> »</span>
</a>
<# } #>
</div>
<# } #>
<# if ( 'left' == settings.pos ) { #>
</div>
<# } #>
<# } #>
</div>
<# if ( settings.link && 'box' == settings.read_more ) { #>
</a>
<# } #>
<?php
}
}