![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/thread-self/cwd/wp-content/plugins/uicore-elements/includes/widgets/ |
<?php namespace UiCoreElements; use Elementor\Controls_Manager; use Elementor\Group_Control_Border; use Elementor\Group_Control_Typography; use Elementor\Group_Control_Box_Shadow; use Elementor\Group_Control_Background; use Elementor\Group_Control_Css_Filter; use Elementor\Icons_Manager; use Elementor\Utils; use UiCoreElements\UiCoreWidget; defined('ABSPATH') || exit(); /** * Icon Box * * @author Lucas Marini Falbo <[email protected]> * @since 1.0.0 */ class IconBox extends UiCoreWidget { public function get_name() { return 'uicore-icon-box'; } public function get_title() { return __('Icon Box', 'uicore-elements'); } public function get_icon() { return 'eicon-icon-box ui-e-widget'; } public function get_categories() { return ['uicore']; } public function get_keywords() { return ['icon', 'features', 'info', 'box']; } public function get_styles() { return ['icon-box']; } public function get_scripts() { return [ 'icon-box' => [ 'conditions' => [ 'relation' => 'or', 'terms' => [ [ 'name' => 'description_animation', 'operator' => '==', 'value' => 'ui-e-animation-description-show', ], [ 'name' => 'readmore_animation', 'operator' => '==', 'value' => 'ui-e-animation-rm-show', ], ], ], ] ]; } protected function register_controls() { $this->start_controls_section( 'section_content_icon_box', [ 'label' => esc_html__('Icon Box', 'uicore-elements'), ] ); $this->add_control( 'icon_type', [ 'label' => esc_html__('Icon Type', 'uicore-elements'), 'type' => Controls_Manager::CHOOSE, 'toggle' => false, 'default' => 'icon', 'render_type' => 'template', 'options' => [ 'none' => [ 'title' => esc_html__('None', 'uicore-elements'), 'icon' => 'eicon-editor-close' ], 'icon' => [ 'title' => esc_html__('Icon', 'uicore-elements'), 'icon' => 'fas fa-star' ], 'image' => [ 'title' => esc_html__('Image', 'uicore-elements'), 'icon' => 'far fa-image' ] ] ] ); $this->add_control( 'selected_icon', [ 'label' => esc_html__('Icon', 'uicore-elements'), 'type' => Controls_Manager::ICONS, 'default' => [ 'value' => 'fas fa-star', 'library' => 'fa-solid', ], 'render_type' => 'template', 'condition' => [ 'icon_type' => 'icon', ], ] ); $this->add_control( 'image', [ 'label' => esc_html__('Image Icon', 'uicore-elements'), 'type' => Controls_Manager::MEDIA, 'render_type' => 'template', 'default' => [ 'url' => Utils::get_placeholder_image_src(), ], 'condition' => [ 'icon_type' => 'image' ] ] ); $this->add_control( 'title_text', [ 'label' => esc_html__('Title', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], 'default' => esc_html__('Icon Box Title', 'uicore-elements'), 'placeholder' => esc_html__('Enter your title', 'uicore-elements'), 'label_block' => true, ] ); $this->add_control( 'title_link_url', [ 'label' => esc_html__('Title Link URL', 'uicore-elements'), 'type' => Controls_Manager::URL, 'dynamic' => ['active' => true], ] ); $this->add_control( 'sub_title_text', [ 'label' => esc_html__('Subtitle', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], 'default' => esc_html__('Icon Box Subtitle', 'uicore-elements'), 'placeholder' => esc_html__('Enter your sub title', 'uicore-elements'), 'label_block' => true, ] ); $this->add_control( 'description_text', [ 'label' => esc_html__('Description', 'uicore-elements'), 'type' => Controls_Manager::WYSIWYG, 'dynamic' => [ 'active' => true, ], 'default' => esc_html__("This serves as the explanatory text for the icon box. Use it to provide additional context or details that elaborate on the title's content.", "uicore-elements"), 'placeholder' => esc_html__('Enter your description', 'uicore-elements'), 'rows' => 10, ] ); $this->add_control( 'position', [ 'label' => esc_html__('Icon Position', 'uicore-elements'), 'type' => Controls_Manager::CHOOSE, 'separator' => 'before', 'default' => 'top', 'options' => [ 'left' => [ 'title' => esc_html__('Left', 'uicore-elements'), 'icon' => 'eicon-h-align-left', ], 'top' => [ 'title' => esc_html__('Top', 'uicore-elements'), 'icon' => 'eicon-v-align-top', ], 'right' => [ 'title' => esc_html__('Right', 'uicore-elements'), 'icon' => 'eicon-h-align-right', ], 'bottom' => [ 'title' => esc_html__('Bottom', 'uicore-elements'), 'icon' => 'eicon-v-align-bottom', ], ], 'frontend_available' => true, 'prefix_class' => 'ui-e-', 'toggle' => false, 'render_type' => 'template', 'conditions' => [ 'relation' => 'or', 'terms' => [ [ 'name' => 'selected_icon[value]', 'operator' => '!=', 'value' => '' ], [ 'name' => 'image[url]', 'operator' => '!=', 'value' => '' ], ] ] ] ); $this->add_control( 'icon_inline', [ 'label' => esc_html__('Icon Inline', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, 'prefix_class' => 'ui-e-inline-', 'render_type' => 'template', 'frontend_available' => true, 'condition' => [ 'position' => ['left', 'right'] ], ] ); $this->add_responsive_control( 'icon_vertical_alignment', [ 'label' => esc_html__('Icon Vertical Alignment', 'uicore-elements'), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'start' => [ 'title' => esc_html__('Top', 'uicore-elements'), 'icon' => 'eicon-v-align-top', ], 'center' => [ 'title' => esc_html__('Middle', 'uicore-elements'), 'icon' => 'eicon-v-align-middle', ], 'end' => [ 'title' => esc_html__('Bottom', 'uicore-elements'), 'icon' => 'eicon-v-align-bottom', ], ], 'default' => 'start', 'toggle' => false, 'selectors' => [ '{{WRAPPER}} .ui-e-flex-wrp' => 'align-items: {{VALUE}};', ], 'condition' => [ 'position' => ['left', 'right'], 'icon_inline' => '', ], ] ); $this->add_responsive_control( 'text_align', [ 'label' => esc_html__('Alignment', 'uicore-elements'), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'left' => [ 'title' => esc_html__('Left', 'uicore-elements'), 'icon' => 'eicon-text-align-left', ], 'center' => [ 'title' => esc_html__('Center', 'uicore-elements'), 'icon' => 'eicon-text-align-center', ], 'right' => [ 'title' => esc_html__('Right', 'uicore-elements'), 'icon' => 'eicon-text-align-right', ], 'justify' => [ 'title' => esc_html__('Justified', 'uicore-elements'), 'icon' => 'eicon-text-align-justify', ], ], 'default' => 'center', 'tablet_default' => 'center', 'mobile_default' => 'center', 'toggle' => false, 'prefix_class' => 'ui-e-align%s-', 'selectors' => [ '{{WRAPPER}}' => '--ui-e-ico-box-text-align: {{VALUE}};', ], ] ); // Responsible for using 'text_align' value as css property instead of css value on the readmore, if animated and left/right positioned without inline. // In this case, the readmore with show animation is absolute with margin:auto, text-align stops working. $this->add_control( 'text_align_readmore', [ 'label' => esc_html__( 'Readmore Animation Alignment', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::HIDDEN, 'default' => '0', 'condition' => [ 'text_align' => ['left', 'right'], 'icon_inline' => '', 'readmore_animation' => 'ui-e-animation-rm-show', ], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'margin-{{text_align.VALUE}}: {{VALUE}} !important;', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_content_readmore', [ 'label' => esc_html__('Read More', 'uicore-elements'), 'condition' => [ 'readmore' => 'yes', ], ] ); $this->add_control( 'readmore_text', [ 'label' => esc_html__('Text', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'dynamic' => ['active' => true], 'default' => esc_html__('Read More', 'uicore-elements'), 'placeholder' => esc_html__('Read More', 'uicore-elements'), ] ); $this->add_control( 'readmore_link', [ 'label' => esc_html__('Link to', 'uicore-elements'), 'type' => Controls_Manager::URL, 'dynamic' => [ 'active' => true, ], 'placeholder' => esc_html__('https://your-link.com', 'uicore-elements'), 'default' => [ 'url' => '#', ], 'condition' => [ 'readmore' => 'yes', ] ] ); $this->add_control( 'onclick', [ 'label' => esc_html__('OnClick', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, 'condition' => [ 'readmore' => 'yes', ] ] ); $this->add_control( 'onclick_event', [ 'label' => esc_html__('OnClick Event', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'placeholder' => 'myFunction()', 'condition' => [ 'readmore' => 'yes', 'onclick' => 'yes' ] ] ); $this->add_control( 'readmore_icon', [ 'label' => esc_html__('Icon', 'uicore-elements'), 'type' => Controls_Manager::ICONS, 'condition' => [ 'readmore' => 'yes' ], 'label_block' => false, 'skin' => 'inline' ] ); $this->add_control( 'readmore_icon_align', [ 'label' => esc_html__('Icon Position', 'uicore-elements'), 'type' => Controls_Manager::SELECT, 'default' => 'right', 'options' => [ 'left' => esc_html__('Left', 'uicore-elements'), 'right' => esc_html__('Right', 'uicore-elements'), ], 'selectors_dictionary' => [ 'left' => 'flex-direction: row-reverse;', 'right' => 'flex-direction: row;', ], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => '{{VALUE}};', ], 'condition' => [ 'readmore_icon[value]!' => '', ], ] ); $this->add_control( 'readmore_icon_indent', [ 'label' => esc_html__('Icon Spacing', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'max' => 100, ], ], 'default' => [ 'size' => 8, ], 'condition' => [ 'readmore_icon[value]!' => '', 'readmore_text!' => '', 'text_align!' => 'justify' ], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'gap: {{SIZE}}px;', ], ] ); $this->add_responsive_control( 'readmore_horizontal_offset', [ 'label' => esc_html__('Horizontal Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, ], 'tablet_default' => [ 'size' => 0, ], 'mobile_default' => [ 'size' => 0, ], 'range' => [ 'px' => [ 'min' => -200, 'max' => 200, ], ], 'condition' => [ 'readmore_on_hover' => 'yes', ], ] ); $this->add_responsive_control( 'readmore_vertical_offset', [ 'label' => esc_html__('Vertical Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, ], 'tablet_default' => [ 'size' => 0, ], 'mobile_default' => [ 'size' => 0, ], 'range' => [ 'px' => [ 'min' => -200, 'max' => 200, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'translate: {{readmore_horizontal_offset.SIZE}}px {{SIZE}}px;' ], 'condition' => [ 'readmore_on_hover' => 'yes', ], ] ); $this->add_control( 'button_css_id', [ 'label' => esc_html__('Button ID', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'dynamic' => [ 'active' => true, ], 'default' => '', 'title' => esc_html__('Add your custom id WITHOUT hash (#) key. e.g: my-id', 'uicore-elements'), 'separator' => 'before', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_content_badge', [ 'label' => esc_html__('Badge', 'uicore-elements'), 'condition' => [ 'badge' => 'yes', ], ] ); $this->add_control( 'badge_text', [ 'label' => esc_html__('Badge Text', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'default' => 'POPULAR', 'placeholder' => 'Type Badge Title', 'dynamic' => [ 'active' => true, ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_content_additional', [ 'label' => esc_html__('Additional Options', 'uicore-elements'), ] ); $this->add_control( 'title_size', [ 'label' => esc_html__('Title HTML Tag', 'uicore-elements'), 'type' => Controls_Manager::SELECT, 'default' => 'h4', 'options' => Helper::get_title_tags(), ] ); $this->add_control( 'readmore', [ 'label' => esc_html__('Read More Button', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, 'separator' => 'before', 'frontend_available' => true, 'default' => 'yes', ] ); $this->add_control( 'badge', [ 'label' => esc_html__('Badge', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, ] ); $this->add_control( 'global_link', [ 'label' => esc_html__('Global Link', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, ] ); $this->add_control( 'global_link_url', [ 'label' => esc_html__('Global Link URL', 'uicore-elements'), 'type' => Controls_Manager::URL, 'dynamic' => ['active' => true], 'placeholder' => 'http://your-link.com', 'condition' => [ 'global_link' => 'yes' ] ] ); $this->end_controls_section(); $this->start_controls_section( 'section_style_icon_box', [ 'label' => esc_html__('Icon/Image', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'icon_type!' => 'none', ], ] ); $this->start_controls_tabs('icon_colors'); $this->start_controls_tab( 'icon_colors_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_control( 'icon_color', [ 'label' => esc_html__('Icon Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp i' => 'color: {{VALUE}};', '{{WRAPPER}} .ui-e-icon-wrp svg' => 'fill: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', ], ] ); $this->add_control( 'show_svg_icon_color', [ 'label' => esc_html__('Svg Icon Color', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, 'condition' => [ 'icon_type!' => 'image', ], ] ); $this->add_control( 'svg_icon_fill_color', [ 'label' => esc_html__('Fill Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp svg, {{WRAPPER}} .ui-e-icon-wrp svg *' => 'fill: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', 'show_svg_icon_color' => 'yes', ], ] ); $this->add_control( 'svg_icon_stroke_color', [ 'label' => esc_html__('Stroke Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp svg, {{WRAPPER}} .ui-e-icon-wrp svg *' => 'stroke: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', 'show_svg_icon_color' => 'yes', ], ] ); $this->add_control( 'blur_effect', [ 'label' => esc_html__('Blur Filter', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, ] ); $this->add_control( 'blur_level', [ 'label' => esc_html__('Blur Level', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'step' => 1, 'max' => 50, ] ], 'default' => [ 'size' => 5 ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => 'backdrop-filter: blur({{SIZE}}px); -webkit-backdrop-filter: blur({{SIZE}}px);' ], 'condition' => [ 'blur_effect' => 'yes', ] ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'icon_background', 'selector' => '{{WRAPPER}} .ui-e-icon-wrp', ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'icon_border', 'placeholder' => '1px', 'default' => '1px', 'selector' => '{{WRAPPER}} .ui-e-icon-wrp' ] ); $this->add_responsive_control( 'icon_radius', [ 'label' => esc_html__('Border Radius', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'icon_radius_advanced_show!' => 'yes', ], ] ); $this->add_control( 'icon_radius_advanced_show', [ 'label' => esc_html__('Advanced Radius', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER,'' ] ); $this->add_control( 'icon_radius_advanced', [ 'label' => esc_html__('Radius', 'uicore-elements'), 'description' => sprintf('Generate the advanced border radius on https://9elements.github.io/fancy-border-radius/', 'uicore-elements'), 'type' => Controls_Manager::TEXT, 'size_units' => ['px', '%'], 'default' => '75% 25% 43% 57% / 46% 29% 71% 54%', 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => 'border-radius: {{VALUE}}; overflow: hidden;', '{{WRAPPER}} .ui-e-icon-wrp img' => 'border-radius: {{VALUE}}; overflow: hidden;' ], 'condition' => [ 'icon_radius_advanced_show' => 'yes', ], ] ); $this->add_responsive_control( 'icon_padding', [ 'label' => esc_html__('Padding', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', 'em', '%'], 'default' => [ 'top' => 10, 'right' => 10, 'bottom' => 10, 'left' => 10, 'unit' => 'px', 'isLinked' => true, ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};' ] ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'icon_shadow', 'selector' => '{{WRAPPER}} .ui-e-icon-wrp' ] ); $this->add_responsive_control( 'icon_space', [ 'label' => esc_html__('Spacing', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'separator' => 'before', 'default' => [ 'size' => 15, ], 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, ], ], 'selectors' => [ '{{WRAPPER}}' => '--ui-e-ico-box-icon-spacing: {{SIZE}}{{UNIT}} !important;', ], ] ); $this->add_control( 'image_fullwidth', [ 'label' => esc_html__('Image Fullwidth', 'uicore-elements'), 'type' => Controls_Manager::SWITCHER, 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => 'width: 100%; box-sizing: border-box; margin-left: calc(var(--ui-e-content-padding-left) * -1); margin-right: calc(var(--ui-e-content-padding-right) * -1); margin-top: calc(var(--ui-e-content-padding-top) *-1);', ], 'condition' => [ 'icon_type' => 'image' ] ] ); $this->add_responsive_control( 'icon_size', [ 'label' => esc_html__('Size', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px', 'em', 'vh', 'vw'], 'range' => [ 'px' => [ 'min' => 6, 'max' => 300, ], ], 'default' => [ 'unit' => 'px', 'size' => 42, ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => '--ui-e-media-size: {{SIZE}}{{UNIT}};', ], 'condition' => [ 'icon_type' => 'icon', ], ] ); $this->add_responsive_control( 'image_size', [ 'label' => esc_html__('Size', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'size_units' => ['px', 'em', 'vh', 'vw'], 'range' => [ 'px' => [ 'min' => 6, 'max' => 300, ], ], 'default' => [ 'unit' => 'px', 'size' => 120, ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => '--ui-e-media-size: {{SIZE}}{{UNIT}};', ], 'conditions' => [ 'relation' => 'and', 'terms' => [ [ 'name' => 'image_fullwidth', 'operator' => '==', 'value' => '' ], [ 'name' => 'icon_type', 'operator' => '==', 'value' => 'image' ], ] ] ] ); $this->add_control( 'rotate', [ 'label' => esc_html__('Rotate', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, 'unit' => 'deg', ], 'range' => [ 'deg' => [ 'max' => 360, 'min' => -360, ], ], 'selectors' => [ '{{WRAPPER}}' => '--ui-e-ico-box-icon-rotate: {{SIZE}}{{UNIT}};', ], ] ); $this->add_control( 'icon_background_rotate', [ 'label' => esc_html__('Background Rotate', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, 'unit' => 'deg', ], 'range' => [ 'deg' => [ 'max' => 360, 'min' => -360, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => '--ui-e-ico-box-icon-wrp-rotate: {{SIZE}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'icon_vertical_offset', [ 'label' => esc_html__('Icon Vertical Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => -200, 'max' => 200, ], ], 'default' => [ 'size' => 0, ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => '--ui-e-ico-box-vertical-off: {{SIZE}}px' ], ] ); $this->add_responsive_control( 'icon_horizontal_offset', [ 'label' => esc_html__('Icon Horizontal Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => -200, 'max' => 200, ], ], 'default' => [ 'size' => 0, ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp' => '--ui-e-ico-box-horizontal-off: {{SIZE}}px' ], ] ); $this->add_control( 'image_icon_heading', [ 'label' => esc_html__('Image Effect', 'uicore-elements'), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'icon_type' => 'image', ], ] ); $this->add_group_control( Group_Control_Css_Filter::get_type(), [ 'name' => 'css_filters', 'selector' => '{{WRAPPER}} .ui-e-ico-box img', 'condition' => [ 'icon_type' => 'image', ], ] ); $this->add_control( 'image_opacity', [ 'label' => esc_html__('Opacity', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'max' => 1, 'min' => 0.10, 'step' => 0.01, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-ico-box img' => 'opacity: {{SIZE}};', ], 'condition' => [ 'icon_type' => 'image', ], ] ); $this->add_control( 'background_hover_transition', [ 'label' => esc_html__('Transition Duration', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0.3, ], 'range' => [ 'px' => [ 'max' => 3, 'step' => 0.1, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-icon-wrp img' => 'transition-duration: {{SIZE}}s', '{{WRAPPER}}:hover .ui-e-icon-wrp img' => 'transform: ', ], 'condition' => [ 'icon_type' => 'image', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'icon_hover', [ 'label' => esc_html__('Hover', 'uicore-elements'), ] ); $this->add_control( 'icon_hover_color', [ 'label' => esc_html__('Icon Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp' => 'color: {{VALUE}};', '{{WRAPPER}}:hover .ui-e-icon-wrp svg' => 'fill: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', ], ] ); $this->add_control( 'svg_icon_hover_fill_color', [ 'label' => esc_html__('Fill Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp svg, {{WRAPPER}}:hover .ui-e-icon-wrp svg *' => 'fill: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', 'show_svg_icon_color' => 'yes', ], ] ); $this->add_control( 'svg_icon_hover_stroke_color', [ 'label' => esc_html__('Stroke Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp svg, {{WRAPPER}}:hover .ui-e-icon-wrp svg *' => 'stroke: {{VALUE}};', ], 'condition' => [ 'icon_type!' => 'image', 'show_svg_icon_color' => 'yes', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'icon_hover_background', 'separator' => 'before', 'selector' => '{{WRAPPER}}:hover .ui-e-icon-wrp', ] ); $this->add_control( 'icon_hover_border_color', [ 'label' => esc_html__('Border Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'separator' => 'before', 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp' => 'border-color: {{VALUE}};', ], 'condition' => [ 'icon_border_border!' => '', ], ] ); $this->add_responsive_control( 'icon_hover_radius', [ 'label' => esc_html__('Border Radius', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'separator' => 'after', 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}; overflow: hidden;', '{{WRAPPER}}:hover .ui-e-icon-wrp img' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}}; overflow: hidden;' ] ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'icon_hover_shadow', 'selector' => '{{WRAPPER}}:hover .ui-e-icon-wrp' ] ); $this->add_control( 'image_icon_hover_heading', [ 'label' => esc_html__('Image Effect', 'uicore-elements'), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'icon_type' => 'image', ], ] ); $this->add_group_control( Group_Control_Css_Filter::get_type(), [ 'name' => 'css_filters_hover', 'selector' => '{{WRAPPER}}:hover .ui-e-icon-wrp img', 'condition' => [ 'icon_type' => 'image', ], ] ); $this->add_control( 'image_opacity_hover', [ 'label' => esc_html__('Opacity', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'max' => 1, 'min' => 0.10, 'step' => 0.01, ], ], 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp img' => 'opacity: {{SIZE}};', ], 'condition' => [ 'icon_type' => 'image', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); $this->start_controls_section( 'section_style_title', [ 'label' => esc_html__('Title', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->start_controls_tabs('tabs_title_style'); $this->start_controls_tab( 'tab_title_style_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_control( 'title_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-title' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_title_style_hover', [ 'label' => esc_html__('Hover', 'uicore-elements'), ] ); $this->add_control( 'title_color_hover', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-title' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_responsive_control( 'title_bottom_space', [ 'label' => esc_html__('Spacing', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, ], ], 'separator' => 'before', 'default' => [ 'unit' => 'px', 'size' => 0, ], 'selectors' => [ '{{WRAPPER}} .ui-e-title' => 'margin-bottom: {{SIZE}}{{UNIT}} !important;', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'title_typography', 'selector' => '{{WRAPPER}} .ui-e-title', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_style_sub_title', [ 'label' => esc_html__('Subtitle', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'sub_title_text!' => '', ], ] ); $this->start_controls_tabs('tabs_sub_title_style'); $this->start_controls_tab( 'tab_sub_title_style_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_control( 'sub_title_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-subtitle' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_sub_title_style_hover', [ 'label' => esc_html__('Hover', 'uicore-elements'), ] ); $this->add_control( 'sub_title_color_hover', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-subtitle' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_responsive_control( 'sub_title_bottom_space', [ 'label' => esc_html__('Spacing', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 100, ], ], 'separator' => 'before', 'default' => [ 'unit' => 'px', 'size' => 20, ], 'selectors' => [ '{{WRAPPER}} .ui-e-subtitle' => 'margin-bottom: {{SIZE}}{{UNIT}} !important;', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'sub_title_typography', 'selector' => '{{WRAPPER}} .ui-e-subtitle', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_style_description', [ 'label' => esc_html__('Description', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->start_controls_tabs('tabs_description_style'); $this->start_controls_tab( 'tab_description_style_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_control( 'description_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-description' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_description_style_hover', [ 'label' => esc_html__('Hover', 'uicore-elements'), ] ); $this->add_control( 'description_color_hover', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-description' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->add_responsive_control( 'description_bottom_space', [ 'label' => esc_html__('Spacing', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'unit' => 'px', 'size' => 0, ], 'separator' => 'before', 'selectors' => [ '{{WRAPPER}} .ui-e-description' => 'margin-bottom: {{SIZE}}{{UNIT}} !important;', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'description_typography', 'selector' => '{{WRAPPER}} .ui-e-description', ] ); $this->end_controls_section(); $this->start_controls_section( 'section_style_readmore', [ 'label' => esc_html__('Read More', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'readmore' => 'yes', ], ] ); $this->start_controls_tabs('tabs_readmore_style'); $this->start_controls_tab( 'tab_readmore_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'readmore_typography', 'selector' => '{{WRAPPER}} .ui-e-readmore', ] ); $this->add_control( 'readmore_text_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'color: {{VALUE}};', '{{WRAPPER}} .ui-e-readmore svg' => 'fill: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'readmore_background', 'selector' => '{{WRAPPER}} .ui-e-readmore', ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'readmore_border', 'placeholder' => '1px', 'default' => '1px', 'selector' => '{{WRAPPER}} .ui-e-readmore' ] ); $this->add_responsive_control( 'readmore_radius', [ 'label' => esc_html__('Border Radius', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'readmore_padding', [ 'label' => esc_html__('Padding', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', 'em', '%'], 'selectors' => [ '{{WRAPPER}} .ui-e-readmore' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'readmore_shadow', 'selector' => '{{WRAPPER}} .ui-e-readmore', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_readmore_box_hover', [ 'label' => esc_html__('Box hover', 'uicore-elements'), ] ); $this->add_control( 'readmore_box_hover_text_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-readmore' => 'color: {{VALUE}};', '{{WRAPPER}}:hover .ui-e-readmore svg' => 'fill: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'readmore_box_hover_background', 'selector' => '{{WRAPPER}}:hover .ui-e-readmore', ] ); $this->add_control( 'readmore_box_hover_border_color', [ 'label' => esc_html__('Border Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-readmore' => 'border-color: {{VALUE}};', ], 'condition' => [ 'readmore_border_border!' => '' ] ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'readmore_box_hover_shadow', 'selector' => '{{WRAPPER}}:hover .ui-e-readmore', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_readmore_hover', [ 'label' => esc_html__('Button hover', 'uicore-elements'), ] ); $this->add_control( 'readmore_hover_text_color', [ 'label' => esc_html__('Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-readmore:hover' => 'color: {{VALUE}};', '{{WRAPPER}} .ui-e-readmore:hover svg' => 'fill: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'readmore_hover_background', 'selector' => '{{WRAPPER}} .ui-e-readmore:hover', ] ); $this->add_control( 'readmore_hover_border_color', [ 'label' => esc_html__('Border Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-readmore:hover' => 'border-color: {{VALUE}};', ], 'condition' => [ 'readmore_border_border!' => '' ] ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'readmore_hover_shadow', 'selector' => '{{WRAPPER}} .ui-e-readmore:hover', ] ); $this->add_control( 'readmore_hover_animation', [ 'label' => esc_html__('Hover Animation', 'uicore-elements'), 'type' => Controls_Manager::HOVER_ANIMATION, ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); $this->start_controls_section( 'section_style_badge', [ 'label' => esc_html__('Badge', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, 'condition' => [ 'badge' => 'yes', ], ] ); $this->add_control( 'badge_position', [ 'label' => esc_html__('Position', 'uicore-elements'), 'type' => Controls_Manager::SELECT, 'default' => 'start right', 'options' => [ 'start left' => esc_html__('Top Left', 'uicore-elements'), 'start center' => esc_html__('Top Center', 'uicore-elements'), 'start right' => esc_html__('Top Right', 'uicore-elements'), 'center ' => esc_html__('Center', 'uicore-elements'), 'center left' => esc_html__('Center Left', 'uicore-elements'), 'center right' => esc_html__('Center Right', 'uicore-elements'), 'end left' => esc_html__('Bottom Left', 'uicore-elements'), 'end center' => esc_html__('Bottom Center', 'uicore-elements'), 'end right' => esc_html__('Bottom Right', 'uicore-elements'), ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge-wrp' => '--ui-e-badge-position: {{VALUE}}', ] ] ); $this->add_responsive_control( 'badge_horizontal_offset', [ 'label' => esc_html__('Horizontal Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, ], 'tablet_default' => [ 'size' => 0, ], 'mobile_default' => [ 'size' => 0, ], 'range' => [ 'px' => [ 'min' => -300, 'step' => 2, 'max' => 300, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge-wrp' => '--ui-e-badge-horizontal-off: {{SIZE}}px;' ], ] ); $this->add_responsive_control( 'badge_vertical_offset', [ 'label' => esc_html__('Vertical Offset', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'default' => [ 'size' => 0, ], 'tablet_default' => [ 'size' => 0, ], 'mobile_default' => [ 'size' => 0, ], 'range' => [ 'px' => [ 'min' => -300, 'step' => 2, 'max' => 300, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge-wrp' => '--ui-e-badge-vertical-off: {{SIZE}}px;', ], ] ); $this->add_responsive_control( 'badge_rotate', [ 'label' => esc_html__('Rotate', 'uicore-elements'), 'type' => Controls_Manager::SLIDER, 'devices' => ['desktop', 'tablet', 'mobile'], 'default' => [ 'size' => 0, ], 'tablet_default' => [ 'size' => 0, ], 'mobile_default' => [ 'size' => 0, ], 'range' => [ 'px' => [ 'min' => -360, 'max' => 360, 'step' => 5, ], ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge' => 'rotate: {{SIZE}}deg;' ], ] ); $this->start_controls_tabs('tabs_badge'); $this->start_controls_tab( 'tab_badge_style_normal', [ 'label' => esc_html__('Normal', 'uicore-elements'), ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'badge_typography', 'selector' => '{{WRAPPER}} .ui-e-badge', 'fields_options' => [ 'font_size' => [ 'default' => [ 'unit' => 'px', 'size' => 12, ], ], 'line_height' => [ 'default' => [ 'unit' => 'em', 'size' => 1, ], ], ], ] ); $this->add_control( 'badge_text_color', [ 'label' => esc_html__('Text Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .ui-e-badge' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'badge_background', 'selector' => '{{WRAPPER}} .ui-e-badge', ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'badge_border', 'placeholder' => '1px', 'default' => '1px', 'selector' => '{{WRAPPER}} .ui-e-badge' ] ); $this->add_responsive_control( 'badge_radius', [ 'label' => esc_html__('Border Radius', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', '%'], 'default' => [ 'top' => 10, 'right' => 10, 'bottom' => 10, 'left' => 10, 'unit' => 'px', 'isLinked' => true, ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'badge_padding', [ 'label' => esc_html__('Padding', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', 'em', '%'], 'default' => [ 'top' => '8', 'right' => '12', 'bottom' => '8', 'left' => '12', 'unit' => 'px', 'isLinked' => false, ], 'selectors' => [ '{{WRAPPER}} .ui-e-badge' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'badge_shadow', 'selector' => '{{WRAPPER}} .ui-e-badge', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'tab_badge_style_hover', [ 'label' => esc_html__('Hover', 'uicore-elements'), ] ); $this->add_control( 'badge_text_hover_color', [ 'label' => esc_html__('Text Color', 'uicore-elements'), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}}:hover .ui-e-badge' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'badge_hover_background', 'selector' => '{{WRAPPER}}:hover .ui-e-badge', ] ); $this->add_group_control( Group_Control_Border::get_type(), [ 'name' => 'badge_hover_border', 'placeholder' => '1px', 'default' => '1px', 'selector' => '{{WRAPPER}}:hover .ui-e-badge' ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'badge_hover_shadow', 'selector' => '{{WRAPPER}}:hover .ui-e-badge', ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); $this->start_controls_section( 'section_animation', [ 'label' => esc_html__('Animations', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_control( 'description_animation', [ 'label' => esc_html__( 'Description Hover Animation', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::SELECT, 'default' => '', 'options' => [ '' => esc_html__( 'None', 'uicore-elements' ), 'ui-e-animation-description-show' => esc_html__( 'Show', 'uicore-elements' ), ], 'prefix_class' => '', 'frontend_available' => true, 'conditions' => [ 'relation' => 'or', 'terms' => [ [ 'name' => 'position', 'operator' => '==', 'value' => 'top', ], [ 'relation' => 'and', 'terms' => [ [ 'name' => 'position', 'operator' => 'in', 'value' => ['left', 'right'], ], [ 'name' => 'icon_inline', 'operator' => '==', 'value' => 'yes', ], ], ], ], ], ] ); // Creates a prefix if has readmore button AND description animation. This allows us to apply some bottom space to the absolute flex-wrapper, keeping it above readmore $this->add_control( 'description_prefix', [ 'label' => esc_html__( 'Prefix Class for Description with Readmore', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::HIDDEN, 'default' => 'readmore', 'condition' => [ 'readmore' => 'yes', 'description_animation' => 'ui-e-animation-description-show', ], 'prefix_class' => 'ui-e-has-', ] ); $this->add_control( 'readmore_animation', [ 'label' => esc_html__( 'Button Hover Animation', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::SELECT, 'default' => '', 'options' => [ '' => esc_html__( 'None', 'uicore-elements' ), 'ui-e-animation-rm-show' => esc_html__( 'Show', 'uicore-elements' ), 'ui-e-animation-rm-ico' => esc_html__( 'Icon', 'uicore-elements' ), ], 'prefix_class' => '', 'frontend_available' => true, 'condition' => [ 'readmore' => 'yes', 'position!' => 'bottom', ] ] ); $this->add_control( 'icon_animation', [ 'label' => esc_html__('Icon Hover Animation', 'uicore-elements'), 'type' => Controls_Manager::SELECT, 'prefix_class' => '', 'default' => '', 'options' => [ '' => esc_html__('None', 'uicore-elements'), 'ui-e-animation-ico-float' => esc_html__('Icon Float', 'uicore-elements'), 'ui-e-animation-ico-grow' => esc_html__('Background Circle', 'uicore-elements'), 'ui-e-animation-ico-slide' => esc_html__('Background Slide', 'uicore-elements'), ], 'condition' => [ 'icon_type!' => 'none', ] ] ); $this->add_control( 'icon_animation_background', [ 'label' => esc_html__( 'Color', 'uicore-elements' ), 'type' => Controls_Manager::COLOR, 'condition' => [ 'icon_animation' => [ 'ui-e-animation-ico-grow', 'ui-e-animation-ico-slide' ] ], 'selectors' => [ '{{WRAPPER}}:hover .ui-e-icon-wrp:after' => 'background-color: {{VALUE}}', ], ] ); $this->add_control( 'widget_animation', [ 'label' => esc_html__( 'Item Hover Animation', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::SELECT, 'default' => '', 'options' => [ '' => esc_html__( 'None', 'uicore-elements' ), 'ui-e-animation-widget-zoom' => esc_html__( 'Zoom', 'uicore-elements' ), 'ui-e-animation-widget-translate' => esc_html__( 'Translate', 'uicore-elements' ), ], 'prefix_class' => '', ] ); $this->add_control( 'widget_animation_zoom', [ 'label' => esc_html__( 'Zoom scale', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => .8, 'max' => 1.3, 'step' => 0.01, ], ], 'default' => [ 'unit' => 'px', 'size' => 1.12, ], 'condition' =>[ 'widget_animation' => 'ui-e-animation-widget-zoom', ], 'selectors' => [ '{{WRAPPER}}' => '--ui-e-ico-box-widget-zoom: {{SIZE}}', ], ] ); $this->add_control( 'widget_animation_translate', [ 'label' => esc_html__( 'Translate value', 'uicore-elements' ), 'type' => \Elementor\Controls_Manager::SLIDER, 'size_units' => ['px'], 'range' => [ 'px' => [ 'min' => -50, 'max' => 50, 'step' => 1, ], ], 'default' => [ 'unit' => 'px', 'size' => -36, ], 'condition' =>[ 'widget_animation' => 'ui-e-animation-widget-translate', ], 'selectors' => [ '{{WRAPPER}}' => '--ui-e-ico-box-widget-translate: {{SIZE}}{{UNIT}}', ], ] ); $this->end_controls_section(); $this->start_controls_section( 'section_style_additional', [ 'label' => esc_html__('Additional', 'uicore-elements'), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'content_padding', [ 'label' => esc_html__('Content Inner Padding', 'uicore-elements'), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => ['px', 'em', '%'], 'frontend_available' => true, 'selectors' => [ '{{WRAPPER}} .ui-e-ico-box' => '--ui-e-content-padding-top: {{TOP}}{{UNIT}}; --ui-e-content-padding-right: {{RIGHT}}{{UNIT}}; --ui-e-content-padding-bot: {{BOTTOM}}{{UNIT}}; --ui-e-content-padding-left: {{LEFT}}{{UNIT}};' ] ] ); $this->end_controls_section(); } protected function render() { $settings = $this->get_settings_for_display(); // Get the proper media $media_type = $settings['icon_type']; switch($media_type) { case 'icon' : $media = $settings['selected_icon']; break; case 'image' : $media = $settings['image']; $media_size = isset($settings['image_fullwidth']) ? 'large' : 'medium'; // Gets the proper media size. break; } // Build the title if (! empty($settings['title_link_url']['url'])){ $hasTitleUrl = true; $this->add_link_attributes( 'title_link', $settings['title_link_url'] ); $titleUrl = "<a {$this->get_render_attribute_string( 'title_link')}>"; } else { $hasTitleUrl = false;} $title = '<'.esc_html($settings['title_size']).' class="ui-e-title">'; $title .= $hasTitleUrl ? wp_kses_post($titleUrl) : ''; // url $title .= esc_html($settings['title_text']); $title .= $hasTitleUrl ? '</a>' : ''; // url closure $title .= '</'.esc_html($settings['title_size']).'>'; // Build the global Url if($settings['global_link'] && $settings['global_link_url']['url'] && !$this->is_edit_mode()){ $global_target = $settings['global_link_url']['is_external'] ? '_blank' : '_self'; $this->add_render_attribute('global_link', 'onclick', "window.open('{$settings['global_link_url']['url']}', '$global_target')"); } // Build the subtitle $subtitle = $settings['sub_title_text'] != '' ? "<div class='ui-e-subtitle'> {$settings['sub_title_text']} </div>" : ''; // Build the readmore $readmore = $settings['readmore']; if($readmore){ $rmContent = $settings['readmore_text']; $rmIcon = $settings['readmore_icon']['value'] == '' ? false : true; if(!empty($settings['readmore_link']['url'])){ $this->add_link_attributes( 'rm_link', $settings['readmore_link']); } $this->add_render_attribute('rm_atts', 'class', $settings['readmore_hover_animation'] ? 'ui-e-readmore elementor-animation-'.esc_attr($settings['readmore_hover_animation']) : 'ui-e-readmore'); if (!empty($settings['button_css_id'])) { $this->add_render_attribute( 'rm_atts', 'id', esc_attr($settings['button_css_id']) ); } if ($settings['onclick']) { $this->add_render_attribute( 'rm_atts', 'onclick', esc_js($settings['onclick_event']) ); } } // Check the icon position and sets the inline (true puts title/subtitlte inside flex wrapper, false puts inside content) switch($settings['position']){ // Always true if top; always false if bottom and left/right checks the user choice case 'top' : $inline = true; break; case 'bottom' : $inline = false; break; default : $inline = $settings['icon_inline'] === 'yes' ? true : false; break; } ?> <div class="ui-e-ico-box" <?php $this->print_render_attribute_string('global_link');?>> <?php if($settings['badge']) : ?> <span class="ui-e-badge-wrp"> <span class="ui-e-badge ui-e-<?php echo esc_attr($settings['badge_position']);?>"> <?php echo esc_html($settings['badge_text']);?> </span> </span> <?php endif; ?> <div class='ui-e-flex-wrp'> <?php if($media_type != 'none') : ?> <div class="ui-e-icon-wrp"> <?php if ($media_type == 'icon') { Icons_Manager::render_icon( $media, [ 'aria-hidden' => 'true' ] ); } else { echo wp_get_attachment_image( $media['id'], $media_size ); } ?> </div> <?php endif; ?> <?php echo $inline ? '<div class="ui-e-title-wrp">' . wp_kses_post($title . $subtitle) . '</div>' : '' ;?> </div> <div class="ui-e-box-content"> <?php echo $inline ? '' : '<div class="ui-e-title-wrp">' . wp_kses_post($title . $subtitle) . '</div>' ;?> <div class="ui-e-description"> <?php echo wp_kses_post($settings['description_text']);?> </div> <?php if($readmore) : ?> <a <?php $this->print_render_attribute_string('rm_link'); $this->print_render_attribute_string('rm_atts');?>> <?php echo esc_html($rmContent);?> <?php if($rmIcon) : ?> <span> <?php Icons_Manager::render_icon( $settings['readmore_icon'], [ 'aria-hidden' => 'true' ] ); ?> </span> <?php endif; ?> </a> <?php endif; ?> </div> </div> <?php } } \Elementor\Plugin::instance()->widgets_manager->register(new IconBox());