Current Path : /storage/v11800/affypharma/public_html/wp-content/plugins/bdthemes-element-pack/modules/post-grid-tab/widgets/ |
Linux v11800 5.3.0-1023-aws #25~18.04.1-Ubuntu SMP Fri Jun 5 15:19:18 UTC 2020 aarch64
|
Current File : /storage/v11800/affypharma/public_html/wp-content/plugins/bdthemes-element-pack/modules/post-grid-tab/widgets/post-grid-tab.php |
<?php
namespace ElementPack\Modules\PostGridTab\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Scheme_Typography;
use Elementor\Group_Control_Border;
use Elementor\Group_Control_Image_Size;
use Elementor\Group_Control_Typography;
use Elementor\Group_Control_Box_Shadow;
use Elementor\Utils;
use ElementPack\Modules\QueryControl\Module;
use ElementPack\Modules\QueryControl\Controls\Group_Control_Posts;
if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
class Post_Grid_Tab extends Widget_Base {
private $_query = null;
public function get_name() {
return 'bdt-post-grid-tab';
}
public function get_title() {
return BDTEP . esc_html__( 'Post Grid Tab', 'bdthemes-element-pack' );
}
public function get_icon() {
return 'bdt-wi-post-grid-tab';
}
public function get_categories() {
return [ 'element-pack' ];
}
public function get_keywords() {
return [ 'post', 'grid', 'tab', 'blog', 'recent', 'news' ];
}
public function get_style_depends() {
return ['bdt-post-grid-tab'];
}
public function get_script_depends() {
return [ 'bdt-uikit-icons', 'gridtab', 'recliner' ];
}
public function on_import( $element ) {
if ( ! get_post_type_object( $element['settings']['posts_post_type'] ) ) {
$element['settings']['posts_post_type'] = 'post';
}
return $element;
}
public function on_export( $element ) {
$element = Group_Control_Posts::on_export_remove_setting_from_element( $element, 'posts' );
return $element;
}
public function get_query() {
return $this->_query;
}
public function _register_controls() {
$this->register_query_section_controls();
}
private function register_query_section_controls() {
$this->start_controls_section(
'section_content_layout',
[
'label' => esc_html__( 'Layout', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_CONTENT,
]
);
$this->add_responsive_control(
'columns',
[
'label' => esc_html__( 'Columns', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'default' => 4,
'tablet_default' => 3,
'mobile_default' => 2,
'options' => [
1 => '1',
2 => '2',
3 => '3',
4 => '4',
5 => '5',
6 => '6',
],
]
);
$this->add_control(
'posts_per_page',
[
'label' => esc_html__( 'Posts Limit', 'bdthemes-element-pack' ),
'type' => Controls_Manager::NUMBER,
'default' => 8,
]
);
$this->add_control(
'item_ratio',
[
'label' => esc_html__( 'Item Height', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'range' => [
'px' => [
'min' => 50,
'max' => 500,
'step' => 5,
],
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab-thumbnail img' => 'height: {{SIZE}}px',
],
]
);
$this->add_control(
'grid_tab_item',
[
'label' => esc_html__( 'Grid Tab Item', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'default' => 'image',
'options' => [
'image' => esc_html__( 'Image', 'bdthemes-element-pack' ),
'title' => esc_html__( 'Title', 'bdthemes-element-pack' ),
],
]
);
$this->add_group_control(
Group_Control_Image_Size::get_type(),
[
'name' => 'thumbnail',
'exclude' => ['custom'],
'condition' => ['grid_tab_item' => 'image'],
'default' => 'medium',
]
);
$this->add_control(
'content_reverse',
[
'label' => esc_html__( 'Content Reverse', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_query',
[
'label' => esc_html__( 'Query', 'bdthemes-element-pack' ),
]
);
$this->add_group_control(
Group_Control_Posts::get_type(),
[
'name' => 'posts',
'label' => esc_html__( 'Posts', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'orderby',
[
'label' => esc_html__( 'Order By', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'default' => 'post_date',
'options' => [
'post_date' => esc_html__( 'Date', 'bdthemes-element-pack' ),
'post_title' => esc_html__( 'Title', 'bdthemes-element-pack' ),
'menu_order' => esc_html__( 'Menu Order', 'bdthemes-element-pack' ),
'rand' => esc_html__( 'Random', 'bdthemes-element-pack' ),
],
]
);
$this->add_control(
'order',
[
'label' => esc_html__( 'Order', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'default' => 'desc',
'options' => [
'asc' => esc_html__( 'ASC', 'bdthemes-element-pack' ),
'desc' => esc_html__( 'DESC', 'bdthemes-element-pack' ),
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_content_additional',
[
'label' => esc_html__( 'Additional', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'show_title',
[
'label' => esc_html__( 'Title', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'title_tag',
[
'label' => esc_html__( 'Title HTML Tag', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'options' => element_pack_title_tags(),
'default' => 'h3',
'condition' => [
'show_title' => 'yes',
],
'separator' => 'after'
]
);
$this->add_control(
'show_author',
[
'label' => esc_html__( 'Author', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'show_date',
[
'label' => esc_html__( 'Date', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'show_comments',
[
'label' => esc_html__( 'Comments', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'show_category',
[
'label' => esc_html__( 'Category', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
'separator' => 'after'
]
);
$this->add_control(
'content_image',
[
'label' => esc_html__('Post Image', 'bdthemes-element-pack'),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes'
]
);
$this->add_group_control(
Group_Control_Image_Size::get_type(),
[
'name' => 'content_thumbnail',
'exclude' => ['custom'],
'condition' => ['grid_tab_item' => 'image'],
'default' => 'full',
'condition' => [
'content_image' => 'yes'
],
'separator' => 'after'
]
);
$this->add_control(
'show_excerpt',
[
'label' => esc_html__( 'Excerpt', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'excerpt_length',
[
'label' => esc_html__( 'Excerpt Length', 'bdthemes-element-pack' ),
'type' => Controls_Manager::NUMBER,
'default' => 45,
'condition' => [
'show_excerpt' => 'yes',
],
'separator' => 'after'
]
);
$this->add_control(
'show_readmore',
[
'label' => esc_html__( 'Read More', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'readmore_text',
[
'label' => esc_html__( 'Read More Text', 'bdthemes-element-pack' ),
'type' => Controls_Manager::TEXT,
'default' => esc_html__( 'Read More', 'bdthemes-element-pack' ),
'placeholder' => esc_html__( 'Read More', 'bdthemes-element-pack' ),
'condition' => [
'show_readmore' => 'yes',
],
]
);
$this->add_control(
'icon',
[
'label' => esc_html__( 'Icon', 'bdthemes-element-pack' ),
'type' => Controls_Manager::ICON,
'label_block' => true,
'condition' => [
'show_readmore' => 'yes',
],
]
);
$this->add_control(
'icon_align',
[
'label' => esc_html__( 'Icon Position', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SELECT,
'default' => 'right',
'options' => [
'left' => esc_html__( 'Before', 'bdthemes-element-pack' ),
'right' => esc_html__( 'After', 'bdthemes-element-pack' ),
],
'condition' => [
'icon!' => '',
],
]
);
$this->add_control(
'icon_indent',
[
'label' => esc_html__( 'Icon Spacing', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 8,
],
'range' => [
'px' => [
'max' => 50,
],
],
'condition' => [
'icon!' => '',
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-button-icon-align-right' => 'margin-left: {{SIZE}}{{UNIT}};',
'{{WRAPPER}} .bdt-post-grid-tab .bdt-button-icon-align-left' => 'margin-right: {{SIZE}}{{UNIT}};',
],
'separator' => 'after'
]
);
$this->add_control(
'show_close',
[
'label' => esc_html__( 'Close Button', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
'default' => 'yes',
]
);
$this->add_control(
'show_arrows',
[
'label' => esc_html__( 'Arrows', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SWITCHER,
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_design_layout',
[
'label' => esc_html__( 'Layout', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'tab_padding',
[
'label' => esc_html__( 'Item Padding', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => '0',
],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
'step' => 2,
],
],
]
);
$this->add_responsive_control(
'tab_text_align',
[
'label' => __( 'Item Text Align', 'bdthemes-element-pack' ),
'type' => Controls_Manager::CHOOSE,
'default' => 'center',
'options' => [
'left' => [
'title' => __( 'Left', 'bdthemes-element-pack' ),
'icon' => 'fa fa-align-left',
],
'center' => [
'title' => __( 'Center', 'bdthemes-element-pack' ),
'icon' => 'fa fa-align-center',
],
'right' => [
'title' => __( 'Right', 'bdthemes-element-pack' ),
'icon' => 'fa fa-align-right',
],
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab > dt' => 'text-align: {{VALUE}};',
],
'condition' => [
'grid_tab_item' => 'title',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'tab_text_typography',
'scheme' => Scheme_Typography::TYPOGRAPHY_4,
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .gridtab > dt',
'condition' => [
'grid_tab_item' => 'title',
],
]
);
$this->add_control(
'item_border_width',
[
'label' => esc_html__( 'Item Border Width', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 10,
],
'range' => [
'px' => [
'min' => 0,
'max' => 100,
'step' => 2,
],
],
]
);
$this->add_control(
'tab_border_color',
[
'label' => esc_html__( 'Item Border Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'default' => '#ddd',
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab > dt, {{WRAPPER}} .bdt-post-grid-tab .gridtab > dd' => 'border-color: {{VALUE}};',
],
]
);
$this->add_control(
'active_tab_no',
[
'label' => esc_html__( 'Active Tab Number', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'separator' => 'before',
'default' => [
'size' => 0,
],
'range' => [
'px' => [
'min' => 0,
'max' => 20,
],
],
]
);
$this->add_control(
'active_tab_background',
[
'label' => esc_html__( 'Active Item Background', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'default' => '#fff',
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab > dt.is-active' => 'background-color: {{VALUE}};',
],
]
);
$this->add_control(
'active_tab_text_color',
[
'label' => esc_html__( 'Active Item Text Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab > dt.is-active' => 'color: {{VALUE}};',
],
'condition' => [
'grid_tab_item' => 'title',
],
]
);
$this->add_responsive_control(
'content_padding',
[
'label' => __( 'Content Padding', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-desc-inner' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_control(
'content_background_color',
[
'label' => esc_html__( 'Content Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab > dd' => 'background-color: {{VALUE}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style_title',
[
'label' => esc_html__( 'Title', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'show_title' => 'yes',
],
]
);
$this->add_control(
'title_color',
[
'label' => esc_html__( 'Title Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-item-title' => 'color: {{VALUE}};',
],
]
);
$this->add_responsive_control(
'title_spacing',
[
'label' => esc_html__( 'Spacing', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 5,
],
'range' => [
'px' => [
'min' => 0,
'max' => 50,
'step' => 2,
],
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-item-title' => 'margin-bottom: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'title_typography',
'label' => esc_html__( 'Typography', 'bdthemes-element-pack' ),
'scheme' => Scheme_Typography::TYPOGRAPHY_4,
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-item-title',
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style_meta',
[
'label' => esc_html__( 'Meta', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_control(
'meta_color',
[
'label' => esc_html__( 'Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'default' => '#adb5bd',
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-meta *' => 'color: {{VALUE}};',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'meta_typography',
'label' => esc_html__( 'Typography', 'bdthemes-element-pack' ),
'scheme' => Scheme_Typography::TYPOGRAPHY_4,
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-meta *',
]
);
$this->add_control(
'divider_color',
[
'label' => esc_html__( 'Divider Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'default' => '#adb5bd',
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-subnav span:after' => 'background-color: {{VALUE}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style_excerpt',
[
'label' => esc_html__( 'Excerpt', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'show_excerpt' => 'yes',
],
]
);
$this->add_control(
'excerpt_color',
[
'label' => esc_html__( 'Excerpt Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-excerpt' => 'color: {{VALUE}};',
],
]
);
$this->add_responsive_control(
'excerpt_spacing',
[
'label' => esc_html__( 'Spacing', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 15,
],
'range' => [
'px' => [
'min' => 0,
'max' => 50,
'step' => 2,
],
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-excerpt' => 'margin-top: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'excerpt_typography',
'label' => esc_html__( 'Typography', 'bdthemes-element-pack' ),
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-excerpt',
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style_readmore',
[
'label' => esc_html__( 'Read More', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'show_readmore' => 'yes',
],
]
);
$this->start_controls_tabs( 'tabs_readmore_style' );
$this->start_controls_tab(
'tab_readmore_normal',
[
'label' => esc_html__( 'Normal', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'readmore_color',
[
'label' => esc_html__( 'Text Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore' => 'color: {{VALUE}};',
],
]
);
$this->add_control(
'readmore_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore' => 'background-color: {{VALUE}};',
],
]
);
$this->add_group_control(
Group_Control_Border::get_type(),
[
'name' => 'readmore_border',
'label' => esc_html__( 'Border', 'bdthemes-element-pack' ),
'placeholder' => '1px',
'default' => '1px',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore',
'separator' => 'before',
]
);
$this->add_responsive_control(
'readmore_border_radius',
[
'label' => esc_html__( 'Border Radius', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => 'readmore_shadow',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore',
]
);
$this->add_responsive_control(
'readmore_padding',
[
'label' => esc_html__( 'Padding', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
'separator' => 'before',
]
);
$this->add_responsive_control(
'readmore_spacing',
[
'label' => esc_html__( 'Spacing', 'bdthemes-element-pack' ),
'type' => Controls_Manager::SLIDER,
'default' => [
'size' => 20,
],
'range' => [
'px' => [
'min' => 0,
'max' => 50,
'step' => 2,
],
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore' => 'margin-top: {{SIZE}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'readmore_typography',
'label' => esc_html__( 'Typography', 'bdthemes-element-pack' ),
'scheme' => Scheme_Typography::TYPOGRAPHY_4,
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore',
]
);
$this->end_controls_tab();
$this->start_controls_tab(
'tab_readmore_hover',
[
'label' => esc_html__( 'Hover', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'readmore_hover_color',
[
'label' => esc_html__( 'Text Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore:hover' => 'color: {{VALUE}};',
],
]
);
$this->add_control(
'readmore_hover_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore:hover' => 'background-color: {{VALUE}};',
],
]
);
$this->add_control(
'readmore_hover_border_color',
[
'label' => esc_html__( 'Border Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'condition' => [
'border_border!' => '',
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .bdt-post-grid-tab-readmore:hover' => 'border-color: {{VALUE}};',
],
]
);
$this->add_control(
'readmore_hover_animation',
[
'label' => esc_html__( 'Animation', 'bdthemes-element-pack' ),
'type' => Controls_Manager::HOVER_ANIMATION,
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->end_controls_section();
$this->start_controls_section(
'section_style_close_button',
[
'label' => esc_html__( 'Close Button', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'show_close' => 'yes',
],
]
);
$this->start_controls_tabs( 'tabs_close_button_style' );
$this->start_controls_tab(
'tab_close_button_normal',
[
'label' => esc_html__( 'Normal', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'close_button_color',
[
'label' => esc_html__( 'Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close:before, {{WRAPPER}} .bdt-post-grid-tab .gridtab__close:after' => 'background: {{VALUE}};',
],
]
);
$this->add_control(
'close_button_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close' => 'background-color: {{VALUE}};',
],
]
);
$this->add_group_control(
Group_Control_Border::get_type(),
[
'name' => 'close_button_border',
'label' => esc_html__( 'Border', 'bdthemes-element-pack' ),
'placeholder' => '1px',
'default' => '1px',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .gridtab__close',
'separator' => 'before',
]
);
$this->add_responsive_control(
'close_button_border_radius',
[
'label' => esc_html__( 'Border Radius', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => 'close_button_shadow',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .gridtab__close',
]
);
$this->add_responsive_control(
'close_button_padding',
[
'label' => esc_html__( 'Padding', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
'separator' => 'before',
]
);
$this->end_controls_tab();
$this->start_controls_tab(
'tab_close_button_hover',
[
'label' => esc_html__( 'Hover', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'close_button_hover_color',
[
'label' => esc_html__( 'Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close:hover::before, {{WRAPPER}} .bdt-post-grid-tab .gridtab__close:hover::after' => 'background: {{VALUE}};',
],
]
);
$this->add_control(
'close_button_hover_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close:hover' => 'background-color: {{VALUE}};',
],
]
);
$this->add_control(
'close_button_hover_border_color',
[
'label' => esc_html__( 'Border Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'condition' => [
'close_button_border_border!' => '',
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__close:hover' => 'border-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->end_controls_section();
$this->start_controls_section(
'section_style_arrows',
[
'label' => esc_html__( 'Arrows', 'bdthemes-element-pack' ),
'tab' => Controls_Manager::TAB_STYLE,
'condition' => [
'show_arrows' => 'yes',
],
]
);
$this->start_controls_tabs( 'tabs_arrows_style' );
$this->start_controls_tab(
'tab_arrows_normal',
[
'label' => esc_html__( 'Normal', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'arrows_color',
[
'label' => esc_html__( 'Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:before, {{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:after' => 'background: {{VALUE}};',
],
]
);
$this->add_control(
'arrows_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow' => 'background-color: {{VALUE}};',
],
]
);
$this->add_group_control(
Group_Control_Border::get_type(),
[
'name' => 'arrows_border',
'label' => esc_html__( 'Border', 'bdthemes-element-pack' ),
'placeholder' => '1px',
'default' => '1px',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow',
'separator' => 'before',
]
);
$this->add_responsive_control(
'arrows_border_radius',
[
'label' => esc_html__( 'Border Radius', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow' => 'border-radius: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_group_control(
Group_Control_Box_Shadow::get_type(),
[
'name' => 'arrows_shadow',
'selector' => '{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow',
]
);
$this->add_responsive_control(
'arrows_padding',
[
'label' => esc_html__( 'Padding', 'bdthemes-element-pack' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', 'em', '%' ],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
'separator' => 'before',
]
);
$this->end_controls_tab();
$this->start_controls_tab(
'tab_arrows_hover',
[
'label' => esc_html__( 'Hover', 'bdthemes-element-pack' ),
]
);
$this->add_control(
'arrows_hover_color',
[
'label' => esc_html__( 'Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:hover::before, {{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:hover::after' => 'background: {{VALUE}};',
],
]
);
$this->add_control(
'arrows_hover_background',
[
'label' => esc_html__( 'Background Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:hover' => 'background-color: {{VALUE}};',
],
]
);
$this->add_control(
'arrows_hover_border_color',
[
'label' => esc_html__( 'Border Color', 'bdthemes-element-pack' ),
'type' => Controls_Manager::COLOR,
'condition' => [
'arrows_border_border!' => '',
],
'selectors' => [
'{{WRAPPER}} .bdt-post-grid-tab .gridtab__arrow:hover' => 'border-color: {{VALUE}};',
],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->end_controls_section();
}
public function get_taxonomies() {
$taxonomies = get_taxonomies( [ 'show_in_nav_menus' => true ], 'objects' );
$options = [ '' => '' ];
foreach ( $taxonomies as $taxonomy ) {
$options[ $taxonomy->name ] = $taxonomy->label;
}
return $options;
}
public function get_posts_tags() {
$taxonomy = $this->get_settings( 'taxonomy' );
foreach ( $this->_query->posts as $post ) {
if ( ! $taxonomy ) {
$post->tags = [];
continue;
}
$tags = wp_get_post_terms( $post->ID, $taxonomy );
$tags_slugs = [];
foreach ( $tags as $tag ) {
$tags_slugs[ $tag->term_id ] = $tag;
}
$post->tags = $tags_slugs;
}
}
public function query_posts() {
$query_args = Module::get_query_args( 'posts', $this->get_settings() );
$query_args['posts_per_page'] = $this->get_settings( 'posts_per_page' );
$this->_query = new \WP_Query( $query_args );
}
public function render() {
$settings = $this->get_settings();
$id = 'bdt-post-grid-tab-' . $this->get_id();
$this->query_posts();
$wp_query = $this->get_query();
if ( ! $wp_query->found_posts ) {
return;
}
$this->get_posts_tags();
$this->render_header();
?>
<dl id="<?php echo esc_attr($id); ?>" class="gridtab">
<?php
while ( $wp_query->have_posts() ) {
$wp_query->the_post();
$this->render_post();
} ?>
</dl>
</div>
<?php
wp_reset_postdata();
}
public function render_content_image($image_id, $size) {
$loading_img = BDTEP_ASSETS_URL . 'images/loading.svg';
$placeholder_image_src = Utils::get_placeholder_image_src();
$image_src = wp_get_attachment_image_src( $image_id, $size );
if ( ! $image_src ) {
$image_src = $placeholder_image_src;
} else {
$image_src = $image_src[0];
}
?>
<div class="bdt-post-grid-tab-image">
<div class="bdt-post-grid-tab-image-inner bdt-gt-mh bdt-cover-container">
<img class="<?php echo esc_attr($size); ?>" src="<?php echo $image_src; ?>" alt="<?php echo get_the_title(); ?>" >
</div>
</div>
<?php
}
public function render_tab_image($image_id) {
$settings = $this->get_settings();
$placeholder_image_src = Utils::get_placeholder_image_src();
$image_src = Group_Control_Image_Size::get_attachment_image_src( $image_id, 'thumbnail', $settings );
if ( ! $image_src ) {
$image_src = $placeholder_image_src;
}
?>
<div class="bdt-post-grid-tab-thumbnail" title="<?php echo get_the_title(); ?>">
<img class="" src="<?php echo $image_src; ?>" alt="<?php echo get_the_title(); ?>">
</div>
<?php
}
public function render_title() {
if ( ! $this->get_settings( 'show_title' ) ) {
return;
}
$tag = $this->get_settings( 'title_tag' );
?>
<a href="<?php echo get_the_permalink(); ?>">
<<?php echo $tag ?> class="bdt-post-grid-tab-item-title bdt-margin-remove">
<?php the_title() ?>
</<?php echo $tag ?>>
</a>
<?php
}
public function render_tab_title() {
echo '<div class="bdt-post-grid-tab-title">';
the_title();
echo '</div>';
}
public function render_author() {
if ( ! $this->get_settings('show_author') ) {
return;
}
echo
'<span class="bdt-post-grid-tab-author bdt-text-capitalize">'.get_the_author().'</span>';
}
public function render_date() {
if ( ! $this->get_settings('show_date') ) {
return;
}
echo
'<span class="bdt-post-grid-tab-date">'.get_the_date().'</span>';
}
public function render_comments() {
if ( ! $this->get_settings('show_comments') ) {
return;
}
echo
'<span><i class="fa fa-comments-o bdt-display-inline-block" aria-hidden="true"></i> '.get_comments_number().'</span>';
}
public function render_category() {
if ( ! $this->get_settings( 'show_category' ) or ! get_the_category_list() ) { return; }
?>
<span class="bdt-post-grid-tab-category">
<?php echo get_the_category_list(' '); ?>
</span>
<?php
}
public function filter_excerpt_length() {
return $this->get_settings( 'excerpt_length' );
}
public function filter_excerpt_more( $more ) {
return '';
}
public function render_excerpt() {
if ( ! $this->get_settings( 'show_excerpt' ) ) {
return;
}
add_filter( 'excerpt_more', [ $this, 'filter_excerpt_more' ], 20 );
add_filter( 'excerpt_length', [ $this, 'filter_excerpt_length' ], 20 );
?>
<div class="bdt-post-grid-tab-excerpt">
<?php do_shortcode(the_excerpt()); ?>
</div>
<?php
remove_filter( 'excerpt_length', [ $this, 'filter_excerpt_length' ], 20 );
remove_filter( 'excerpt_more', [ $this, 'filter_excerpt_more' ], 20 );
}
public function render_readmore() {
if ( ! $this->get_settings('show_readmore') ) {
return;
}
$animation = ($this->get_settings('readmore_hover_animation')) ? ' elementor-animation-'.$this->get_settings('readmore_hover_animation') : '';
echo
'<a href="' . esc_url(get_permalink()) . '" class="bdt-post-grid-tab-readmore bdt-display-inline-block' . esc_attr($animation) . '">
' . esc_html($this->get_settings('readmore_text'));
if ($this->get_settings('icon')) :
echo
'<span class="bdt-button-icon-align-' . esc_attr($this->get_settings('icon_align')) . '">
<i class="' . esc_attr($this->get_settings('icon')) . '"></i>
</span>';
endif;
echo
'</a>';
}
public function render_header($skin = 'default') {
$settings = $this->get_settings();
$this->add_render_attribute('post-grid-tab', 'class', ['bdt-post-grid-tab', 'bdt-post-grid-tab-skin-' . $skin]);
$this->add_render_attribute(
[
'post-grid-tab' => [
'data-settings' => [
wp_json_encode(array_filter([
"grid" => $settings["columns"],
"tabPadding" => $settings["tab_padding"]["size"],
"borderWidth" => $settings["item_border_width"]["size"],
"config" => [
"layout" => ( "title" === $settings["grid_tab_item"] ) ? "tab" : "grid",
"activeTab" => $settings["active_tab_no"]["size"],
"showClose" => ( $settings["show_close"] ) ? true : false,
"showArrows" => ( $settings["show_arrows"] ) ? true : false,
],
"responsive"=> [
[
"breakpoint" => 767,
"settings" => [
"grid" => $settings["columns_tablet"],
]
],
[
"breakpoint" => 480,
"settings" => [
"grid" => $settings["columns_mobile"],
]
]
]
]))
]
]
]
);
?>
<div <?php echo $this->get_render_attribute_string( 'post-grid-tab' ); ?>>
<?php
}
public function render_post_grid_tab_item( $post_id, $image_size = 'full' ) {
$settings = $this->get_settings();
global $post;
$this->add_render_attribute( 'post-grid-tab-item', 'bdt-grid' );
if ( $settings['content_image'] and ( $settings['show_title'] or $settings['show_author'] or $settings['show_date'] or $settings['show_comments'] or $settings['show_category'] or $settings['show_excerpt'] or $settings['show_readmore'] ) ) {
$this->add_render_attribute( 'post-grid-tab-item', 'class', [ 'bdt-post-grid-tab-item', 'bdt-grid', 'bdt-grid-collapse', 'bdt-child-width-1-2@m' ] );
if ('yes' == $settings['content_reverse']) {
$this->add_render_attribute( 'post-grid-tab-item', 'class', 'bdt-flex-row-reverse' );
}
} else {
$this->add_render_attribute( 'post-grid-tab-item', 'class', [ 'bdt-post-grid-tab-item', 'bdt-grid', 'bdt-child-width-1-1' ] );
}
?>
<div <?php echo $this->get_render_attribute_string( 'post-grid-tab-item' ) ?>>
<?php if ( $settings['content_image'] ) : ?>
<?php $this->render_content_image(get_post_thumbnail_id( $post_id ), $image_size ); ?>
<?php endif; ?>
<div class="bdt-post-grid-tab-desc">
<div class="bdt-post-grid-desc-inner bdt-gt-mh">
<?php $this->render_title(); ?>
<?php if ($settings['show_author'] or $settings['show_date'] or $settings['show_category'] or $settings['show_comments']) : ?>
<div class="bdt-post-grid-tab-meta bdt-subnav bdt-flex-middle bdt-margin-small-top">
<?php $this->render_author(); ?>
<?php $this->render_date(); ?>
<?php $this->render_category(); ?>
<?php $this->render_comments(); ?>
</div>
<?php endif; ?>
<?php $this->render_excerpt(); ?>
<?php $this->render_readmore(); ?>
</div>
</div>
</div>
<?php
}
public function render_post() {
global $post;
$settings = $this->get_settings();
?>
<dt>
<?php
if ('title' === $settings['grid_tab_item']) {
$this->render_tab_title();
} else {
$this->render_tab_image(get_post_thumbnail_id( $post->ID ), $settings['thumbnail_size'] );
}
?>
</dt>
<dd><?php $this->render_post_grid_tab_item( $post->ID, $settings['content_thumbnail_size'] ); ?></dd>
<?php
}
}