Current File : /home/bravrvjk/cepurhuye.rw/wp-content/plugins/bopea-function/block//featured-layout-3.php
<?php
namespace bopeaElementor\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Group_Control_Image_Size;
use Elementor\Group_Control_Typography;
use Elementor\Schemes\Color;
use Elementor\Schemes\Typography;
use Elementor\Utils;
use Elementor\Control_Media;
use Elementor\Group_Control_Border;
use Elementor\Group_Control_Box_Shadow;
use Elementor\Group_Control_Text_Shadow;
use Elementor\Group_Control_Background;
use Elementor\Repeater;
use Elementor\Icons_Manager;
if ( ! defined( 'ABSPATH' ) ) exit;
class bopea_feature_layout3 extends Widget_Base {
public $base;
public function get_name() {
return 'bopea-feature-layout3';
}
public function get_title() {
return esc_html__( 'Overlay + 2 below', 'bopea-function' );
}
public function get_icon() {
return 'eicon-elementor-circle jl-icons';
}
public function get_categories() {
return [ 'bopea-elements' ];
}
protected function register_controls() {
$this->start_controls_section(
'section_tab',
[
'label' => esc_html__('Post Query And Settings', 'bopea-function'),
]
);
$this->add_control(
'post_type',
[
'label' =>esc_html__('Post types', 'bopea-function'),
'description' => esc_html__( 'Choose post type to display posts', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'default' => 'post',
'options' => $this->post_get_type(),
]
);
$this->add_control(
'post_type_tax',
[
'label' =>esc_html__('Post taxonomy', 'bopea-function'),
'description' => esc_html__( 'Choose post type (category or tag)', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'default' => 'none',
'options' => $this->post_get_taxs(),
'condition' => [
'post_type!' => ['post']
]
]
);
$this->add_control(
'term_slugs', [
'label' => esc_html__( 'Term Slug', 'bopea-function' ),
'description' => esc_html__( 'Example: slug1,slug2,slug3', 'bopea-function' ),
'type' => Controls_Manager::TEXT,
'label_block' => true,
'condition' => [
'post_type!' => ['post']
]
]
);
$this->add_control(
'categories',
[
'label' =>esc_html__('Select Categories', 'bopea-function'),
'type' => Controls_Manager::SELECT2,
'options' => $this->post_categories(),
'label_block' => true,
'multiple' => true,
'condition' => [
'post_type' => ['post']
]
]
);
$this->add_control(
'tags', [
'label' => esc_html__( 'Tag Slug', 'bopea-function' ),
'description' => esc_html__( 'Example: tagslug1,tagslug2,tagslug3', 'bopea-function' ),
'type' => Controls_Manager::TEXT,
'label_block' => true,
'condition' => [
'post_type' => ['post']
]
]
);
$this->add_control(
'author',
[
'label' =>esc_html__('Author Filter', 'bopea-function'),
'type' => Controls_Manager::SELECT,
'default' => 'none',
'options' => $this->post_author(),
'condition' => [
'post_type' => ['post']
]
]
);
// $this->add_control(
// 'author',
// [
// 'label' =>esc_html__('Select Author', 'bopea-function'),
// 'type' => Controls_Manager::SELECT2,
// 'options' => $this->post_author(),
// 'label_block' => true,
// 'multiple' => true,
// ]
// );
$this->add_control(
'offset',
array(
'label' => esc_html__( 'Post Offset', 'bopea-function' ),
'type' => Controls_Manager::NUMBER,
'default' => '',
)
);
$this->add_control(
'format',
array(
'label' => esc_html__( 'Post Format', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'options' => [
'0' => esc_html__( 'All', 'bopea-function' ),
'gallery' => esc_html__( 'Gallery', 'bopea-function' ),
'video' => esc_html__( 'Video', 'bopea-function' ),
'audio' => esc_html__( 'Audio', 'bopea-function' ),
'quote' => esc_html__( 'Quote', 'bopea-function' ),
],
'default' => '0',
'condition' => [
'post_type' => ['post']
]
)
);
$this->add_control(
'post_not_in', [
'label' => esc_html__( 'Exclude Post IDs', 'bopea-function' ),
'description' => esc_html__( 'Example: 1,2,3', 'bopea-function' ),
'default' => '',
'type' => Controls_Manager::TEXT,
'label_block' => true
]
);
$this->add_control(
'post_in', [
'label' => esc_html__( 'Post IDs Filter', 'bopea-function' ),
'description' => esc_html__( 'Example: 1,2,3', 'bopea-function' ),
'default' => '',
'type' => Controls_Manager::TEXT,
'label_block' => true
]
);
$this->add_control(
'ignore_sticky_posts',
[
'label' => esc_html__( 'Enable sticky posts', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'order',
[
'label' =>esc_html__( 'Sort Order', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'default' => 'date_post',
'options' => [
'date_post' =>esc_html__( 'Latest post', 'bopea-function' ),
'rand' =>esc_html__( 'Random', 'bopea-function' ),
'update' =>esc_html__( 'Latest updated', 'bopea-function' ),
'comment_count' =>esc_html__( 'Popular comment', 'bopea-function' ),
'author' =>esc_html__( 'Author', 'bopea-function' ),
'popular_most' =>esc_html__( 'Popular views', 'bopea-function' ),
'popular_by_month' =>esc_html__( 'Popular views by month', 'bopea-function' ),
'popular_by_week' =>esc_html__( 'Popular views by week', 'bopea-function' ),
'alphabetical_order_decs' =>esc_html__( 'Title DECS', 'bopea-function' ),
'alphabetical_order_asc' =>esc_html__( 'Title ACS', 'bopea-function' ),
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_tab_style', [
'label' => esc_html__( 'Post Custom Style', 'bopea-function' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'jl_cus_img',
[
'label' =>esc_html__( 'Image size', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'default' => '',
'options' => [
'' =>esc_html__( 'Default image size', 'bopea-function' ),
'bopea_large' =>esc_html__( '1600 x 0', 'bopea-function' ),
'bopea_medium' =>esc_html__( '1100 x 0', 'bopea-function' ),
'bopea_small' =>esc_html__( '150 x 150', 'bopea-function' ),
'bopea_layouts' =>esc_html__( '680 x 0', 'bopea-function' ),
'medium' =>esc_html__( 'Medium', 'bopea-function' ),
],
]
);
$this->add_control(
'main_tag',
[
'label' => __( 'Main title Tag', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'options' => [
'h1' => 'H1',
'h2' => 'H2',
'h3' => 'H3',
'h4' => 'H4',
'h5' => 'H5',
'h6' => 'H6',
'div' => 'div',
],
'default' => 'h2',
]
);
$this->add_control(
'sm_tag',
[
'label' => __( 'Small grid title Tag', 'bopea-function' ),
'type' => Controls_Manager::SELECT,
'options' => [
'h1' => 'H1',
'h2' => 'H2',
'h3' => 'H3',
'h4' => 'H4',
'h5' => 'H5',
'h6' => 'H6',
'div' => 'div',
],
'default' => 'h3',
]
);
$this->add_responsive_control(
'mf_font_size',
[
'label' => __( 'Main title font size', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 35,
],
'tablet_default' => [
'size' => 30,
],
'mobile_default' => [
'size' => 23,
],
'range' => [
'px' => [
'min' => 1,
'max' => 500,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-font-main: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'main_typo',
'label' =>esc_html__( 'Main title typography', 'bopea-function' ),
'selector' => '{{WRAPPER}} .jl_fr3_inner .jl_p_fr3:nth-child(1) .jl_fe_text .jl_fe_title',
]
);
$this->add_responsive_control(
'sf_font_size',
[
'label' => __( 'Small title font size', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 23,
],
'tablet_default' => [
'size' => 25,
],
'mobile_default' => [
'size' => 16,
],
'range' => [
'px' => [
'min' => 1,
'max' => 500,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-font-small: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_responsive_control(
'imgm_height',
[
'label' => __( 'Image main height', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 50,
],
'tablet_default' => [
'size' => 40,
],
'mobile_default' => [
'size' => 70,
],
'range' => [
'px' => [
'min' => 0,
'max' => 200,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-main-h: {{SIZE}}%;',
]
]
);
$this->add_responsive_control(
'imgs_height',
[
'label' => __( 'Image small height', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 70,
],
'tablet_default' => [
'size' => 60,
],
'mobile_default' => [
'size' => 100,
],
'range' => [
'px' => [
'min' => 0,
'max' => 200,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-small-h: {{SIZE}}%;',
]
]
);
$this->add_responsive_control(
'grid_spacing',
[
'label' => __( 'Grid Spacing', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 1,
],
'tablet_default' => [
'size' => 1,
],
'mobile_default' => [
'size' => 1,
],
'range' => [
'px' => [
'min' => 0,
'max' => 400,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-grid-gap: {{SIZE}}{{UNIT}};',
]
]
);
$this->add_responsive_control(
'capm_padding',
[
'label' => __( 'Caption main padding', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 40,
],
'tablet_default' => [
'size' => 30,
],
'mobile_default' => [
'size' => 15,
],
'range' => [
'px' => [
'min' => 0,
'max' => 400,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-padding-main: {{SIZE}}{{UNIT}};',
]
]
);
$this->add_responsive_control(
'sl_radius',
[
'label' => __( 'Post border radius', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 0,
'max' => 300,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jlc-car-radius: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_responsive_control(
'caps_padding',
[
'label' => __( 'Caption small padding', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 30,
],
'tablet_default' => [
'size' => 30,
],
'mobile_default' => [
'size' => 15,
],
'range' => [
'px' => [
'min' => 0,
'max' => 400,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-padding-small: {{SIZE}}{{UNIT}};',
]
]
);
$this->add_responsive_control(
'jl_num_text_line',
[
'label' => __( 'Main number line of text', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 1,
'max' => 10,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}}' => '--jl-num-line: {{SIZE}};',
],
]
);
$this->add_responsive_control(
'jl_snum_text_line',
[
'label' => __( 'Small number line of text', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 1,
'max' => 10,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_sm_mt' => '--jl-num-line: {{SIZE}};',
],
]
);
$this->add_control(
'en_meta_line',
[
'label' => esc_html__( 'Enable meta line', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_post_meta' => 'border-top: 1px solid var(--jl-ov-lcor, #ffffff50); padding-top: var(--jl-ov-msp, 13px); margin-top: var(--jl-ov-msp, 13px);',
],
]
);
$this->add_responsive_control(
'jl_mli_space',
[
'label' => __( 'Meta line space', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 1,
'max' => 100,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}}' => '--jl-ov-msp: {{SIZE}}px;',
],
'condition' => [
'en_meta_line!' => ''
]
]
);
$this->add_control(
'jl_mli_color',
[
'label' => __( 'Meta line color', 'bopea-function' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}}' => '--jl-ov-lcor: {{VALUE}};',
],
'condition' => [
'en_meta_line!' => ''
]
]
);
$this->add_control(
'jl_gradient_ov',
[
'label' => esc_html__( 'Enable gradient background', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'yes',
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_imgl' => 'background-color: transparent !important; background: linear-gradient(180deg, rgba(0, 0, 0, 0) var(--jl-ov-bg-pos), var(--jl-ov-bg) var(--jl-ov-bgc-pos)) !important;',
],
]
);
$this->add_control(
'jl_flip_bg',
[
'label' => esc_html__( 'Gradient background from top', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_imgl' => '-moz-transform: scale(-1, -1); -o-transform: scale(-1, -1); -webkit-transform: scale(-1, -1); transform: scale(-1, -1);'
],
'condition' => [
'jl_gradient_ov!' => ''
]
]
);
$this->add_control(
'sl_ov_bg',
[
'label' => __( 'Overlay background color', 'bopea-function' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_imgl' => '--jl-ov-bg: {{VALUE}}; background-color: {{VALUE}};',
]
]
);
$this->add_responsive_control(
'jl_bg_pos',
[
'label' => __( 'Background transparent position', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 0,
'max' => 100,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_imgl' => '--jl-ov-bg-pos: {{SIZE}}%',
],
'condition' => [
'jl_gradient_ov!' => ''
]
]
);
$this->add_responsive_control(
'jl_bgc_pos',
[
'label' => __( 'Background color position', 'bopea-function' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 0,
'max' => 100,
'step' => 1,
]
],
'selectors' => [
'{{WRAPPER}} .jl_ov_el .jl_imgl' => '--jl-ov-bgc-pos: {{SIZE}}%',
],
'condition' => [
'jl_gradient_ov!' => ''
]
]
);
$this->add_responsive_control(
'jl_text_align',
array(
'label' => __( 'Text alignment', 'bopea-function' ),
'type' => Controls_Manager::CHOOSE,
'options' => array(
'left' => array(
'title' => __( 'Left', 'bopea-function' ),
'icon' => 'eicon-text-align-left',
),
'center' => array(
'title' => __( 'Center', 'bopea-function' ),
'icon' => 'eicon-text-align-center',
),
'right' => array(
'title' => __( 'Right', 'bopea-function' ),
'icon' => 'eicon-text-align-right',
),
),
'toggle' => false,
'selectors' => array(
'{{WRAPPER}} .jl_fr3_inner' => '--jl-t-align: {{VALUE}};',
)
)
);
$this->add_control(
'cap_h_align',
[
'label' => __( 'Horizontal Alignment', 'bopea-function' ),
'type' => Controls_Manager::CHOOSE,
'options' => [
'flex-start' => [
'title' => __( 'Left', 'bopea-function' ),
'icon' => 'eicon-h-align-left',
],
'center' => [
'title' => __( 'Center', 'bopea-function' ),
'icon' => 'eicon-h-align-center',
],
'flex-end' => [
'title' => __( 'Right', 'bopea-function' ),
'icon' => 'eicon-h-align-right',
],
],
'toggle' => true,
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-h-align: {{VALUE}}',
]
]
);
$this->add_control(
'cap_v_align',
[
'label' => __( 'Vertical Alignment', 'bopea-function' ),
'type' => Controls_Manager::CHOOSE,
'options' => [
'start' => [
'title' => __( 'Top', 'bopea-function' ),
'icon' => 'eicon-v-align-top',
],
'center' => [
'title' => __( 'Middle', 'bopea-function' ),
'icon' => 'eicon-v-align-middle',
],
'end' => [
'title' => __( 'Bottom', 'bopea-function' ),
'icon' => 'eicon-v-align-bottom',
],
],
'toggle' => true,
'selectors' => [
'{{WRAPPER}} .jl_fr3_inner' => '--jl-v-align: {{VALUE}}',
]
]
);
$this->add_control(
'jl_en_share',
[
'label' => esc_html__( 'Enable share', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'selectors' => array(
'{{WRAPPER}} .jl_fot_share_i.jl_share_l_bg.jls_tooltip' => 'display: inline-flex !important;',
)
]
);
$this->add_control(
'jl_en_sh_l',
[
'label' => esc_html__( 'Enable share inline', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'yes',
'selectors' => [
'{{WRAPPER}} .block-section' => '--jl-sh-lp: 15px;',
],
'condition' => [
'jl_en_share!' => ['']
]
]
);
$this->add_control(
'jl_hide_cat',
[
'label' => esc_html__( 'Hide category', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hide_author',
[
'label' => esc_html__( 'Hide author', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hide_date',
[
'label' => esc_html__( 'Hide date', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hide_meta',
[
'label' => esc_html__( 'Hide author & date', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hide_desc',
[
'label' => esc_html__( 'Hide description', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hide_review',
[
'label' => esc_html__( 'Hide review', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'yes',
'default' => 'no',
]
);
$this->add_control(
'jl_hd_sm_au',
[
'label' => esc_html__( 'Hide author small grid', 'bopea-function' ),
'type' => Controls_Manager::SWITCHER,
'selectors' => array(
'{{WRAPPER}} .jl_sm_mt .jl_author_img_w, {{WRAPPER}} .jl_sm_mt .post-read-time:before, {{WRAPPER}} .jl_sm_mt .post-date:before' => 'display: none !important;',
)
]
);
$this->end_controls_section();
}
protected function render( ) {
$settings = $this->get_settings();
if ( function_exists( 'bopea_feature_layout_3' ) ) {
$settings['blockid'] = 'blockid_' . $this->get_id();
if(!empty($settings['categories'])){
$settings['categories'] = implode(',', $settings['categories']);
}
echo \bopea_feature_layout_3( $settings );
}
}
public function post_categories() {
$terms = get_terms( array(
'taxonomy' => 'category',
'hide_empty' => false,
'posts_per_page' => -1,
'suppress_filters' => false,
) );
$cat_list = [];
foreach($terms as $post) {
$cat_list[$post->term_id] = [$post->name];
}
return $cat_list;
}
public function post_author() {
$blogusers = get_users( array(
'role__not_in' => array( 'subscriber' ),
'fields' => array( 'ID', 'display_name' )
) );
$user_list = [];
$user_list['none']= esc_html__( 'None', 'bopea-function' );
foreach($blogusers as $user) {
$user_list[$user->ID] = [$user->display_name];
}
return $user_list;
}
public function post_get_type() {
$post_types = get_post_types( '', 'names' );
$type_list = [];
$type_list['none']= esc_html__( 'None', 'bopea-function' );
if ( ! empty( $post_types ) ){
foreach($post_types as $p_type) {
$type_list[$p_type] = [$p_type];
}
}
return $type_list;
}
public function post_get_taxs() {
$taxonomies = get_taxonomies();
$type_taxs = [];
$type_taxs['none']= esc_html__( 'None', 'bopea-function' );
if ( ! empty( $taxonomies ) ){
foreach($taxonomies as $p_taxs) {
$type_taxs[$p_taxs] = [$p_taxs];
}
}
return $type_taxs;
}
}