File "wpr-feature-list.php"
Full path: /home/webide/saman-clinic.ir/wp-content/plugins/royal-elementor-addons/modules/feature-list/widgets/wpr-feature-list.php
File size: 25.34 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace WprAddons\Modules\FeatureList\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Utils;
use Elementor\Core\Responsive\Responsive;
use Elementor\Group_Control_Border;
use Elementor\Group_Control_Box_Shadow;
use Elementor\Group_Control_Text_Shadow;
use Elementor\Group_Control_Background;
use Elementor\Group_Control_Typography;
use Elementor\Core\Schemes\Typography;
use Elementor\Core\Schemes\Color;
use Elementor\Repeater;
use Elementor\Group_Control_Image_Size;
use WprAddons\Classes\Utilities;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
class Wpr_Feature_List extends Widget_Base {
public function get_name() {
return 'wpr-feature-list';
}
public function get_title() {
return esc_html__( 'Feature List', 'wpr-addons' );
}
public function get_icon() {
return 'wpr-icon eicon-editor-list-ul';
}
public function get_categories() {
return [ 'wpr-widgets'];
}
public function get_keywords() {
return [ 'royal', 'features', 'feature list', 'icon list' ];
}
public function get_custom_help_url() {
if ( empty(get_option('wpr_wl_plugin_links')) )
// return 'https://royal-elementor-addons.com/contact/?ref=rea-plugin-panel-grid-help-btn';
return 'https://wordpress.org/support/plugin/royal-elementor-addons/';
}
protected function register_controls() {
// Tab: Content ==============
// Section: General ----------
$this->start_controls_section(
'section_feature_list_general',
[
'label' => esc_html__( 'General', 'wpr-addons' ),
'tab' => Controls_Manager::TAB_CONTENT,
]
);
Utilities::wpr_library_buttons( $this, Controls_Manager::RAW_HTML );
$this->add_responsive_control(
'list_layout',
[
'label' => esc_html__( 'Layout', 'wpr-addons' ),
'type' => Controls_Manager::CHOOSE,
'label_block' => false,
'default' => 'left',
'options' => [
'left' => [
'title' => esc_html__( 'Left', 'wpr-addons' ),
'icon' => 'eicon-h-align-left',
],
'center' => [
'title' => esc_html__( 'Center', 'wpr-addons' ),
'icon' => 'eicon-h-align-center',
],
'right' => [
'title' => esc_html__( 'Right', 'wpr-addons' ),
'icon' => 'eicon-h-align-right',
]
],
'prefix_class' => 'wpr-feature-list-',
'render_type' => 'template',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-item' => 'justify-content: {{VALUE}}',
],
'separator' => 'before',
]
);
$this->add_control(
'icon_vertical_align',
[
'label' => esc_html__( 'Vertical Align', 'wpr-addons' ),
'type' => Controls_Manager::CHOOSE,
'label_block' => false,
'default' => 'center',
'options' => [
'flex-start' => [
'title' => esc_html__( 'Top', 'wpr-addons' ),
'icon' => 'eicon-v-align-top',
],
'center' => [
'title' => esc_html__( 'Middle', 'wpr-addons' ),
'icon' => 'eicon-v-align-middle',
],
'flex-end' => [
'title' => esc_html__( 'Bottom', 'wpr-addons' ),
'icon' => 'eicon-v-align-bottom',
]
],
'render_type' => 'template',
'selectors' => [
'{{WRAPPER}}.wpr-feature-list-left .wpr-feature-list-item' => 'align-items: {{VALUE}}',
'{{WRAPPER}}.wpr-feature-list-right .wpr-feature-list-item' => 'align-items: {{VALUE}}'
],
'condition' => [
'list_layout!' => 'center',
]
]
);
$this->add_control(
'feature_list_content_alignment',
[
'label' => esc_html__( 'Alignment', 'wpr-addons' ),
'type' => Controls_Manager::CHOOSE,
'options' => [
'flex-start' => [
'title' => esc_html__( 'Left', 'wpr-addons' ),
'icon' => 'eicon-text-align-left',
],
'center' => [
'title' => esc_html__( 'Center', 'wpr-addons' ),
'icon' => 'eicon-text-align-center',
],
'flex-end' => [
'title' => esc_html__( 'Right', 'wpr-addons' ),
'icon' => 'eicon-text-align-right',
]
],
'prefix_class' => 'wpr-feature-list-align-',
'render_type' => 'template',
'default' => 'center',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-item' => 'align-items: {{VALUE}};',
],
'condition' => [
'list_layout' => 'center',
]
]
);
$this->add_control(
'feature_list_icon_shape',
[
'label' => esc_html__( 'Icon Shape', 'wpr-addons' ),
'type' => Controls_Manager::SELECT,
'default' => 'square',
'label_block' => false,
'options' => [
'square' => esc_html__( 'Square', 'wpr-addons' ),
'rhombus' => esc_html__( 'Rhombus', 'wpr-addons' )
],
'separator' => 'before',
'prefix_class' => 'wpr-feature-list-'
]
);
$this->add_group_control(
\Elementor\Group_Control_Image_Size::get_type(),
[
'name' => 'thumbnail',
'exclude' => [ 'custom' ],
'include' => [],
'default' => 'large',
]
);
$this->add_control(
'feature_list_title_tag',
[
'label' => esc_html__( 'Title HTML Tag', 'wpr-addons' ),
'type' => Controls_Manager::SELECT,
'options' => [
'h1' => 'H1',
'h2' => 'H2',
'h3' => 'H3',
'h4' => 'H4',
'h5' => 'H5',
'h6' => 'H6',
'div' => 'div',
'span' => 'span',
'P' => 'p'
],
'default' => 'h2'
]
);
$this->add_control(
'feature_list_line',
[
'label' => esc_html__( 'Show Line', 'wpr-addons' ),
'type' => Controls_Manager::SWITCHER,
'render_type' => 'template',
'prefix_class' => 'wpr-feature-list-line-',
'separator' => 'before',
'default' => 'yes',
'condition' => [
'list_layout' => ['left', 'right']
]
]
);
$this->add_responsive_control(
'list_item_spacing_v',
[
'label' => esc_html__( 'Vertical Spacing', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
],
],
'default' => [
'unit' => 'px',
'size' => 35,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-item:not(:last-child)' => 'margin-bottom: {{SIZE}}{{UNIT}};',
],
'render_type' => 'template',
'separator' => 'before'
]
);
$this->add_responsive_control(
'list_item_spacing_h',
[
'label' => esc_html__( 'Horizontal Spacing', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
],
],
'default' => [
'unit' => 'px',
'size' => 20,
],
'selectors' => [
'{{WRAPPER}}.wpr-feature-list-left .wpr-feature-list-icon-wrap' => 'margin-right: {{SIZE}}{{UNIT}};',
'{{WRAPPER}}.wpr-feature-list-right .wpr-feature-list-icon-wrap' => 'margin-left: {{SIZE}}{{UNIT}};',
],
'condition' => [
'list_layout!' => 'center'
]
]
);
$this->add_responsive_control(
'list_item_title_distance',
[
'label' => esc_html__( 'Title Distance', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
],
],
'default' => [
'unit' => 'px',
'size' => 5,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-title' => 'margin-bottom: {{SIZE}}{{UNIT}};',
],
'render_type' => 'template'
]
);
$this->add_control(
'list_item_media_distance',
[
'label' => esc_html__( 'Media Distance', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
],
],
'default' => [
'unit' => 'px',
'size' => 0,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-wrap' => 'margin-bottom: {{SIZE}}{{UNIT}};',
],
'condition' => [
'list_layout' => 'center'
]
]
);
$this->end_controls_section();
// Tab: Content ==============
// Section: Content ----------
$this->start_controls_section(
'content_section',
[
'label' => esc_html__( 'Content', 'wpr-addons' ),
'tab' => \Elementor\Controls_Manager::TAB_CONTENT,
]
);
$repeater = new \Elementor\Repeater();
$repeater->start_controls_tabs(
'list_tabs'
);
$repeater->start_controls_tab(
'content_tab',
[
'label' => __( 'Content', 'wpr-addons' ),
]
);
$repeater->add_control(
'feature_list_media_type',
[
'label' => esc_html__( 'Media Type', 'wpr-addons' ),
'type' => Controls_Manager::SELECT,
'options' => [
'icon' => esc_html__( 'Icon', 'wpr-addons' ),
'image' => esc_html__( 'Image', 'wpr-addons' )
],
'default' => 'icon',
'label_block' => false,
]
);
$repeater->add_control(
'list_icon',
[
'label' => esc_html__( 'Select Icon', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::ICONS,
'default' => [
'value' => 'fas fa-star',
'library' => 'solid',
],
'label_block' => false,
'skin' => 'inline',
'condition' => [
'feature_list_media_type' => 'icon'
]
]
);
$repeater->add_control(
'list_image',
[
'label' => esc_html__( 'Choose Image', 'plugin-name' ),
'type' => \Elementor\Controls_Manager::MEDIA,
'skin' => 'inline',
'dynamic' => [
'active' => true,
],
'condition' => [
'feature_list_media_type' => 'image'
]
]
);
$repeater->add_control(
'list_title', [
'label' => esc_html__( 'Title', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::TEXT,
'dynamic' => [
'active' => true,
],
'default' => esc_html__( 'List Title' , 'wpr-addons' ),
'separator' => 'before',
'label_block' => true,
]
);
$repeater->add_control(
'list_title_url',
[
'label' => esc_html__( 'Title Link', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::URL,
'dynamic' => [
'active' => true,
],
'placeholder' => esc_html__( 'https://your-link.com', 'wpr-addons' ),
'default' => [
'url' => '',
'is_external' => true,
'nofollow' => true,
'custom_attributes' => '',
],
'label_block' => true,
]
);
$repeater->add_control(
'list_content',
[
'label' => esc_html__( 'Content', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::TEXTAREA,
'dynamic' => [
'active' => true,
],
'default' => esc_html__( 'List Content', 'wpr-addons' ),
'placeholder' => esc_html__( 'Type your description here', 'wpr-addons' ),
'rows' => 10,
]
);
$repeater->end_controls_tab();
$repeater->start_controls_tab(
'styles_tab',
[
'label' => __( 'Style', 'wpr-addons' ),
]
);
$repeater->add_control(
'feature_list_custom_styles',
[
'label' => esc_html__( 'Custom Styles', 'wpr-addons' ),
'type' => Controls_Manager::SWITCHER,
]
);
$repeater->add_control(
'feature_list_title_color_unique',
[
'label' => esc_html__( 'Title Color', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-title a.wpr-feature-list-url' => 'color: {{VALUE}}',
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-title' => 'color: {{VALUE}}'
],
'condition' => [
'feature_list_custom_styles' => 'yes'
]
]
);
$repeater->add_control(
'feature_list_icon_color_unique',
[
'label' => esc_html__( 'Icon Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#ffffff',
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-icon-inner-wrap i' => 'color: {{VALUE}}',
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-icon-inner-wrap svg' => 'fill: {{VALUE}}',
],
'condition' => [
'feature_list_custom_styles' => 'yes'
]
]
);
$repeater->add_control(
'feature_list_icon_wrapper_bg_color_unique',
[
'label' => esc_html__( 'Icon Bg Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#966CE6',
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-icon-inner-wrap' => 'background-color: {{VALUE}}',
],
'condition' => [
'feature_list_custom_styles' => 'yes'
]
]
);
$repeater->add_control(
'feature_list_icon_wrapper_border_color_unique',
[
'label' => esc_html__( 'Icon Border Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#6A65FF',
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} .wpr-feature-list-icon-inner-wrap' => 'border-color: {{VALUE}}',
],
'condition' => [
'feature_list_custom_styles' => 'yes'
]
]
);
$repeater->end_controls_tab();
$repeater->end_controls_tabs();
$this->add_control(
'list',
[
'label' => esc_html__( 'Repeater List', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::REPEATER,
'fields' => $repeater->get_controls(),
'default' => [
[
'list_title' => esc_html__( 'Feature List', 'wpr-addons' ),
'list_content' => esc_html__( 'Add multiple feature items, set different icons or images for each feature and also give custom links if needed.', 'wpr-addons' ),
'list_icon' => [
'value' => 'fas fa-rocket',
'library' => 'solid'
],
],
[
'list_title' => esc_html__( 'Key Features', 'wpr-addons' ),
'list_content' => esc_html__( 'Choose your style from three different layouts and two unique icon background shapes.', 'wpr-addons' ),
'list_icon' => [
'value' => 'far fa-flag',
'library' => 'solid'
],
'feature_list_custom_styles' => 'yes',
'feature_list_icon_wrapper_bg_color_unique' => '#966CE6'
],
[
'list_title' => esc_html__( 'Connector Line', 'wpr-addons' ),
'list_content' => esc_html__( 'Show a connector line between each icon, changes its color and style to fit your unique design. ', 'wpr-addons' ),
'list_icon' => [
'value' => 'fas fa-grip-lines-vertical',
'library' => 'solid'
],
],
[
'list_title' => esc_html__( 'Custom Styles', 'wpr-addons' ),
'list_content' => esc_html__( 'Easily customize every aspect of your list from widget styles but also you can give custom colors to each item as well.', 'wpr-addons' ),
'list_icon' => [
'value' => 'fas fa-paint-brush',
'library' => 'solid'
],
],
],
'title_field' => '{{{ list_title }}}',
]
);
$this->end_controls_section();
// Section: Request New Feature
Utilities::wpr_add_section_request_feature( $this, Controls_Manager::RAW_HTML, '' );
// Tab: STYLE ==============
// Section: Icon ----------
$this->start_controls_section(
'section_feature_list_icon_styles',
[
'label' => esc_html__( 'Media', 'wpr-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'feature_list_icon_color',
[
'label' => esc_html__( 'Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#FFF',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap i' => 'color: {{VALUE}}',
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap svg' => 'fill: {{VALUE}}',
],
]
);
$this->add_control(
'feature_list_icon_wrapper_bg_color',
[
'label' => esc_html__( 'Background Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#6A65FF',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'background-color: {{VALUE}}',
],
]
);
$this->add_control(
'feature_list_icon_wrapper_border_color',
[
'label' => esc_html__( 'Border Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'border-color: {{VALUE}}',
],
]
);
$this->add_responsive_control(
'feature_list_icon_size',
[
'label' => esc_html__( 'Icon Size', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 5,
'max' => 100,
],
],
'default' => [
'unit' => 'px',
'size' => 25,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-wrap i' => 'font-size: {{SIZE}}{{UNIT}};',
'{{WRAPPER}} .wpr-feature-list-icon-wrap svg' => 'width: {{SIZE}}{{UNIT}}; height: auto;',
],
'separator' => 'before',
]
);
$this->add_responsive_control(
'feature_list_icon_wrapper_size',
[
'label' => esc_html__( 'Box Size', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'render_type' => 'template',
'range' => [
'px' => [
'min' => 5,
'max' => 200,
],
],
'default' => [
'unit' => 'px',
'size' => 75,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'width: {{SIZE}}{{UNIT}}; height: {{SIZE}}{{UNIT}}'
]
]
);
$this->add_control(
'feature_list_icon_wrapper_border_type',
[
'label' => esc_html__( 'Border Type', 'wpr-addons' ),
'type' => Controls_Manager::SELECT,
'options' => [
'none' => esc_html__( 'None', 'wpr-addons' ),
'solid' => esc_html__( 'Solid', 'wpr-addons' ),
'double' => esc_html__( 'Double', 'wpr-addons' ),
'dotted' => esc_html__( 'Dotted', 'wpr-addons' ),
'dashed' => esc_html__( 'Dashed', 'wpr-addons' ),
'groove' => esc_html__( 'Groove', 'wpr-addons' ),
],
'default' => 'none',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'border-style: {{VALUE}};',
],
'separator' => 'before',
]
);
$this->add_control(
'feature_list_icon_wrapper_border_width',
[
'label' => esc_html__( 'Border Width', 'wpr-addons' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px' ],
'default' => [
'top' => 1,
'right' => 1,
'bottom' => 1,
'left' => 1,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'border-width: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
'condition' => [
'feature_list_icon_wrapper_border_type!' => 'none',
]
]
);
$this->add_control(
'feature_list_icon_wrapper_border_radius',
[
'label' => esc_html__( 'Border Radius', 'wpr-addons' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px' ],
'default' => [
'top' => 5,
'right' => 5,
'bottom' => 5,
'left' => 5,
],
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-icon-inner-wrap' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
]
]
);
$this->end_controls_section();
// Tab: STYLE ==============
// Section: Line ----------
$this->start_controls_section(
'section_feature_list_line_styles',
[
'label' => esc_html__( 'Line', 'wpr-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'feature_list_line' => 'yes'
]
]
);
$this->add_control(
'feature_list_line_color',
[
'label' => esc_html__( 'Color', 'wpr-addons' ),
'type' => \Elementor\Controls_Manager::COLOR,
'default' => '#6A65FF',
'selectors' => [
// '{{WRAPPER}} .wpr-feature-list-icon-wrap::before' => 'border-color: {{VALUE}}',
'{{WRAPPER}} .wpr-feature-list-line' => 'border-color: {{VALUE}}'
],
]
);
$this->add_control(
'feature_list_line_width',
[
'label' => esc_html__( 'Width', 'wpr-addons' ),
'type' => Controls_Manager::SLIDER,
'size_units' => ['px'],
'range' => [
'px' => [
'min' => 1,
'max' => 10,
],
],
'default' => [
'unit' => 'px',
'size' => 2,
],
'selectors' => [
// '{{WRAPPER}} .wpr-feature-list-icon-wrap::before' => 'border-width: {{SIZE}}{{UNIT}}; height: calc({{feature_list_icon_wrapper_size.SIZE}}px + {{list_item_spacing_v.SIZE}}px + {{list_item_title_distance.SIZE}}px)',
'{{WRAPPER}} .wpr-feature-list-line' => 'border-left-width: {{SIZE}}{{UNIT}};',
],
'separator' => 'before'
]
);
$this->add_control(
'feature_list_line_border_type',
[
'label' => esc_html__( 'Type', 'wpr-addons' ),
'type' => Controls_Manager::SELECT,
'default' => 'solid',
'label_block' => false,
'options' => [
'solid' => esc_html__( 'Solid', 'wpr-addons' ),
'dashed' => esc_html__( 'Dashed', 'wpr-addons' ),
'dotted' => esc_html__( 'Dotted', 'wpr-addons' ),
],
'selectors' => [
// '{{WRAPPER}} .wpr-feature-list-icon-wrap::before' => 'border-style: {{VALUE}};',
'{{WRAPPER}} .wpr-feature-list-line' => 'border-left-style: {{VALUE}};',
]
]
);
$this->end_controls_section();
// Tab: STYLE ==============
// Section: Title & Description ----------
$this->start_controls_section(
'section_feature_list_title_&_description_styles',
[
'label' => esc_html__( 'Title & Description', 'wpr-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'title_heading',
[
'label' => esc_html__( 'Title', 'wpr-addons' ),
'type' => Controls_Manager::HEADING,
'separator' => 'before'
]
);
$this->add_control(
'feature_list_title_color',
[
'label' => esc_html__( 'Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#000',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-title' => 'color: {{VALUE}}',
'{{WRAPPER}} .wpr-feature-list-title a.wpr-feature-list-url' => 'color: {{VALUE}}',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'feature_list_title',
'scheme' => Typography::TYPOGRAPHY_3,
'selector' => '{{WRAPPER}} .wpr-feature-list-title',
'fields_options' => [
'typography' => [
'default' => 'custom',
],
'font_weight' => [
'default' => '500',
],
'font_family' => [
'default' => 'Roboto',
],
'font_size' => [
'default' => [
'size' => '20',
'unit' => 'px',
]
]
]
]
);
$this->add_control(
'description_heading',
[
'label' => esc_html__( 'Description', 'wpr-addons' ),
'type' => Controls_Manager::HEADING,
'separator' => 'before'
]
);
$this->add_control(
'feature_list_description_color',
[
'label' => esc_html__( 'Color', 'wpr-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '#6E6B6B',
'selectors' => [
'{{WRAPPER}} .wpr-feature-list-description' => 'color: {{VALUE}}',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'feature_list_description',
'scheme' => Typography::TYPOGRAPHY_3,
'selector' => '{{WRAPPER}} .wpr-feature-list-description',
'fields_options' => [
'typography' => [
'default' => 'custom',
],
'font_weight' => [
'default' => '400',
],
'font_family' => [
'default' => 'Roboto',
],
'font_size' => [
'default' => [
'size' => '14',
'unit' => 'px',
]
]
]
]
);
$this->end_controls_section();
}
protected function render() {
$settings = $this->get_settings_for_display();
if ( $settings['list'] ) {
$count_items = 0;
echo '<div class="wpr-feature-list-wrap">';
echo '<ul class="wpr-feature-list">';
foreach ( $settings['list'] as $item ) {
$this->add_link_attributes( 'list_title_url'. $count_items, $item['list_title_url'] );
echo '<li class="wpr-feature-list-item elementor-repeater-item-' . esc_attr( $item['_id'] ) .'">';
echo '<div class="wpr-feature-list-icon-wrap">';
echo '<span class="wpr-feature-list-line"></span>';
echo '<div class="wpr-feature-list-icon-inner-wrap">';
if ( 'icon' === $item['feature_list_media_type'] ) {
\Elementor\Icons_Manager::render_icon( $item['list_icon'], [ 'aria-hidden' => 'true' ] );
} else {
$src = \Elementor\Group_Control_Image_Size::get_attachment_image_src( $item['list_image']['id'], 'thumbnail', $settings );
echo '<img src="'. esc_url($src) .'">';
}
echo '</div>';
echo '</div>';
echo '<div class="wpr-feature-list-content-wrap">';
if ( empty($item['list_title_url']) ) {
echo '<'. esc_attr($settings['feature_list_title_tag']) .' class="wpr-feature-list-title">'. wp_kses_post($item['list_title']) .'</'. esc_attr($settings['feature_list_title_tag']) .'>';
} else {
echo '<'. esc_attr($settings['feature_list_title_tag']) .' class="wpr-feature-list-title"><a class="wpr-feature-list-url" '. $this->get_render_attribute_string( 'list_title_url'. $count_items ) .'>'. wp_kses_post($item['list_title']) .'</a></'. esc_attr($settings['feature_list_title_tag']) .'>';
}
echo '<p class="wpr-feature-list-description">'. wp_kses_post($item['list_content']) .'</p>';
echo '</div>';
echo '</li>';
$count_items++;
}
echo '</ul>';
echo '</div>';
}
}
}