File: /home/confeduphaar/www/wp-content/plugins/ova-framework/ova-elementor/widgets/ova_feature_box_3.php
<?php
namespace ova_framework\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Core\Schemes\Typography;
use Elementor\Group_Control_Typography;
use Elementor\Core\Schemes\Color;
use Elementor\Utils;
if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
class ova_feature_box_3 extends Widget_Base {
public function get_name() {
return 'ova_feature_box_3';
}
public function get_title() {
return __( 'Ova Box Feature 3', 'ova-framework' );
}
public function get_icon() {
return 'eicon-posts-ticker';
}
public function get_categories() {
return [ 'ovatheme' ];
}
public function get_script_depends() {
return [ 'script-elementor' ];
}
protected function register_controls() {
$this->start_controls_section(
'section_heading_content',
[
'label' => __( 'Content', 'ova-framework' ),
]
);
$this->add_control(
'class_icon',
[
'label' => __( 'Class Icon', 'ova-framework' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => 'flaticon-group',
]
);
$this->add_control(
'title',
[
'label' => __( 'Title', 'ova-framework' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => __('Became Volunteer','ova-framework'),
]
);
$this->add_control(
'desc',
[
'label' => __( 'Description', 'ova-framework' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => __('Saying void can’t isn’t. Lights thing from gathered living dominion it years.','ova-framework'),
]
);
$this->add_control(
'text_readmore',
[
'label' => __( 'Text Read More', 'ova-framework' ),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => __('Register Now','ova-framework'),
]
);
$this->add_control(
'link',
[
'label' => __( 'Link', 'ova-framework' ),
'type' => Controls_Manager::TEXT,
'default' => '#'
]
);
$this->add_control(
'target_link',
[
'label' => esc_html__( 'Open in new window', 'ova-framework' ),
'type' => Controls_Manager::SWITCHER,
'label_on' => esc_html__( 'Yes', 'ova-framework' ),
'label_off' => esc_html__( 'No', 'ova-framework' ),
'default' => 'no',
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_box',
[
'label' => __( 'Icon', 'ova-framework' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'maxwidth_box',
[
'label' => __( 'Max Width Box', 'ova-framework' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px'],
'range' => [
'px' => [
'max' => 2000,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3' => 'max-width: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_responsive_control(
'padding_box_feature',
[
'label' => __( 'Padding', 'ova-framework' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} ova_feature_box_3' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_control(
'bg_color_box',
[
'label' => __( 'Background Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3' => 'background-color : {{VALUE}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_icon',
[
'label' => __( 'Icon', 'ova-framework' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'size_icon',
[
'label' => __( 'Font size', 'ova-framework' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px'],
'range' => [
'px' => [
'max' => 100,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .wrap-icon i:before' => 'font-size: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_control(
'color_icon',
[
'label' => __( 'Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .wrap-icon i:before' => 'color : {{VALUE}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_title',
[
'label' => __( 'Title', 'ova-framework' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'title_typography',
'selector' => '{{WRAPPER}} .ova_feature_box_3 .title',
]
);
$this->add_control(
'color_title',
[
'label' => __( 'Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .title' => 'color : {{VALUE}};',
],
]
);
$this->add_responsive_control(
'margin_title',
[
'label' => __( 'Margin', 'ova-framework' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .title' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_desc',
[
'label' => __( 'Description', 'ova-framework' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'desc_typography',
'selector' => '{{WRAPPER}} .ova_feature_box_3 .desc',
]
);
$this->add_control(
'color_desc',
[
'label' => __( 'Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .desc' => 'color : {{VALUE}};',
],
]
);
$this->add_responsive_control(
'margin_desc',
[
'label' => __( 'Margin', 'ova-framework' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .desc' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_readmore',
[
'label' => __( 'Read More', 'ova-framework' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'readmore_typography',
'selector' => '{{WRAPPER}} .ova_feature_box_3 .readmore a',
]
);
$this->add_control(
'color_readmore',
[
'label' => __( 'Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .readmore a' => 'color : {{VALUE}};',
],
]
);
$this->add_control(
'color_readmore_hover',
[
'label' => __( 'Color hover', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .readmore a:hover' => 'color : {{VALUE}};',
],
]
);
$this->add_control(
'bg_color_readmore',
[
'label' => __( 'Background Color ', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .readmore a' => 'background-color : {{VALUE}};',
],
]
);
$this->add_control(
'bg_color_readmore_hover',
[
'label' => __( 'Background Color hover', 'ova-framework' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .readmore a:hover' => 'background-color : {{VALUE}};',
],
]
);
$this->add_responsive_control(
'margin_readmore',
[
'label' => __( 'Margin', 'ova-framework' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .ova_feature_box_3 .readmore' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->end_controls_section();
}
protected function render() {
$settings = $this->get_settings();
$class_icon = $settings['class_icon'];
$title = $settings['title'];
$desc = $settings['desc'];
$text_readmore = $settings['text_readmore'];
$link = $settings['link'];
$target = '';
if ( 'yes' == $settings['target_link'] ) {
$target = ' target="_blank"';
}
?>
<div class="ova_feature_box_3">
<div class="ova-content">
<div class="wrap-icon">
<span class="icon">
<i class="<?php echo esc_attr( $class_icon ) ?>"></i>
</span>
</div>
<?php if( $title ){ ?>
<h3 class="title">
<?php echo esc_html( $title ) ?>
</h3>
<?php } ?>
<?php if( $desc ){ ?>
<p class="desc">
<?php echo esc_html( $desc ) ?>
</p>
<?php } ?>
<?php if( $text_readmore ){ ?>
<div class="readmore">
<a class="second_font" href="<?php echo esc_attr( $link ) ?>"<?php echo esc_html( $target ); ?>><?php echo esc_html( $text_readmore ) ?></a>
</div>
<?php } ?>
</div>
</div>
<?php
}
}