Current Path : /var/www/mainsite/wp-content/themes/maxcoach/elementor/widgets/carousel/ |
Current File : /var/www/mainsite/wp-content/themes/maxcoach/elementor/widgets/carousel/blog-carousel.php |
<?php namespace Maxcoach_Elementor; use Elementor\Controls_Manager; use Elementor\Group_Control_Background; use Elementor\Group_Control_Box_Shadow; use Elementor\Group_Control_Typography; use Elementor\Group_Control_Image_Size; defined( 'ABSPATH' ) || exit; class Widget_Blog_Carousel extends Posts_Carousel_Base { public function get_name() { return 'tm-blog-carousel'; } public function get_title() { return esc_html__( 'Blog Carousel', 'maxcoach' ); } public function get_icon_part() { return 'eicon-posts-carousel'; } public function get_keywords() { return [ 'blog', 'posts', 'carousel' ]; } protected function get_post_type() { return 'post'; } protected function register_controls() { $this->add_layout_section(); $this->add_box_style_section(); $this->add_caption_style_section(); parent::register_controls(); } protected function before_slider() { $this->add_render_attribute( self::SLIDER_KEY, 'class', 'maxcoach-blog-carousel' ); } private function add_layout_section() { $this->start_controls_section( 'layout_section', [ 'label' => esc_html__( 'Layout', 'maxcoach' ), ] ); $this->add_control( 'hover_effect', [ 'label' => esc_html__( 'Hover Effect', 'maxcoach' ), 'type' => Controls_Manager::SELECT, 'options' => [ '' => esc_html__( 'None', 'maxcoach' ), 'zoom-in' => esc_html__( 'Zoom In', 'maxcoach' ), 'zoom-out' => esc_html__( 'Zoom Out', 'maxcoach' ), ], 'default' => '', 'prefix_class' => 'maxcoach-animation-', ] ); $this->add_control( 'show_caption_category', [ 'label' => esc_html__( 'Category', 'maxcoach' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'maxcoach' ), 'label_off' => esc_html__( 'Hide', 'maxcoach' ), 'default' => 'yes', 'separator' => 'before', ] ); $this->add_control( 'show_caption_excerpt', [ 'label' => esc_html__( 'Excerpt', 'maxcoach' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'maxcoach' ), 'label_off' => esc_html__( 'Hide', 'maxcoach' ), 'default' => 'yes', 'separator' => 'before', ] ); $this->add_control( 'excerpt_length', [ 'label' => esc_html__( 'Excerpt Length', 'maxcoach' ), 'type' => Controls_Manager::NUMBER, 'min' => 5, 'condition' => [ 'show_caption_excerpt' => 'yes', ], ] ); $this->add_control( 'show_caption_read_more', [ 'label' => esc_html__( 'Read More', 'maxcoach' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'maxcoach' ), 'label_off' => esc_html__( 'Hide', 'maxcoach' ), 'default' => 'yes', 'separator' => 'before', ] ); $this->add_control( 'read_more_text', [ 'label' => esc_html__( 'Read More Text', 'maxcoach' ), 'type' => Controls_Manager::TEXT, 'default' => esc_html__( 'Read More', 'maxcoach' ), 'condition' => [ 'show_caption_read_more' => 'yes', ], ] ); $this->add_control( 'show_caption_share', [ 'label' => esc_html__( 'Share', 'maxcoach' ), 'type' => Controls_Manager::SWITCHER, 'label_on' => esc_html__( 'Show', 'maxcoach' ), 'label_off' => esc_html__( 'Hide', 'maxcoach' ), ] ); $this->add_control( 'show_caption_meta', [ 'label' => esc_html__( 'Meta', 'maxcoach' ), 'label_block' => true, 'type' => Controls_Manager::SELECT2, 'multiple' => true, 'default' => [ 'date', 'views', ], 'options' => [ 'author' => esc_html__( 'Author', 'maxcoach' ), 'date' => esc_html__( 'Date', 'maxcoach' ), 'views' => esc_html__( 'View Count', 'maxcoach' ), 'comments' => esc_html__( 'Comment Count', 'maxcoach' ), ], ] ); $this->add_control( 'thumbnail_default_size', [ 'label' => esc_html__( 'Use Default Thumbnail Size', 'maxcoach' ), 'type' => Controls_Manager::SWITCHER, 'default' => '1', 'return_value' => '1', 'separator' => 'before', ] ); $this->add_group_control( Group_Control_Image_Size::get_type(), [ 'name' => 'thumbnail', 'default' => 'full', 'condition' => [ 'thumbnail_default_size!' => '1', ], ] ); $this->end_controls_section(); } private function add_box_style_section() { $this->start_controls_section( 'box_style_section', [ 'label' => esc_html__( 'Box', 'maxcoach' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_control( 'box_border_radius', [ 'label' => esc_html__( 'Border Radius', 'maxcoach' ), 'type' => Controls_Manager::SLIDER, 'range' => [ 'px' => [ 'min' => 0, 'max' => 200, ], ], 'selectors' => [ '{{WRAPPER}} .maxcoach-box' => 'border-radius: {{SIZE}}{{UNIT}}', ], ] ); $this->start_controls_tabs( 'box_skin_tabs' ); $this->start_controls_tab( 'box_skin_normal_tab', [ 'label' => esc_html__( 'Normal', 'maxcoach' ), ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'box_box_shadow', 'selector' => '{{WRAPPER}} .maxcoach-box', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'box_skin_hover_tab', [ 'label' => esc_html__( 'Hover', 'maxcoach' ), ] ); $this->add_group_control( Group_Control_Box_Shadow::get_type(), [ 'name' => 'box_box_shadow_hover', 'selector' => '{{WRAPPER}} .maxcoach-box:hover', ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } private function add_caption_style_section() { $this->start_controls_section( 'caption_style_section', [ 'label' => esc_html__( 'Caption', 'maxcoach' ), 'tab' => Controls_Manager::TAB_STYLE, ] ); $this->add_responsive_control( 'text_align', [ 'label' => esc_html__( 'Text Align', 'maxcoach' ), 'type' => Controls_Manager::CHOOSE, 'options' => Widget_Utils::get_control_options_text_align(), 'default' => '', 'selectors' => [ '{{WRAPPER}} .post-wrapper' => 'text-align: {{VALUE}};', ], ] ); $this->add_responsive_control( 'caption_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-caption' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_responsive_control( 'caption_padding', [ 'label' => esc_html__( 'Padding', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-caption' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); // Meta style. $this->add_control( 'caption_meta_heading', [ 'label' => esc_html__( 'Meta', 'maxcoach' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'show_caption_meta!' => '', ], ] ); $this->add_responsive_control( 'caption_meta_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-meta' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'show_caption_meta!' => '', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'caption_meta_typography', 'label' => esc_html__( 'Typography', 'maxcoach' ), 'selector' => '{{WRAPPER}} .post-meta', 'condition' => [ 'show_caption_meta!' => '', ], ] ); $this->start_controls_tabs( 'caption_meta_style_tabs', [ 'condition' => [ 'show_caption_meta!' => '', ], ] ); $this->start_controls_tab( 'caption_meta_style_normal_tab', [ 'label' => esc_html__( 'Normal', 'maxcoach' ), ] ); $this->add_control( 'caption_meta_text_color', [ 'label' => esc_html__( 'Text Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-meta' => 'color: {{VALUE}};', ], ] ); $this->add_control( 'caption_meta_link_color', [ 'label' => esc_html__( 'Link Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-meta a' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'caption_meta_style_hover_tab', [ 'label' => esc_html__( 'Hover', 'maxcoach' ), ] ); $this->add_control( 'caption_meta_link_hover_color', [ 'label' => esc_html__( 'Link Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-meta a:hover' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); // Category style. $this->add_control( 'caption_category_heading', [ 'label' => esc_html__( 'Category', 'maxcoach' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'show_caption_category' => 'yes', ], ] ); $this->add_responsive_control( 'caption_category_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-categories' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'show_caption_category' => 'yes', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'caption_category_typography', 'label' => esc_html__( 'Typography', 'maxcoach' ), 'selector' => '{{WRAPPER}} .post-categories', 'condition' => [ 'show_caption_category' => 'yes', ], ] ); $this->start_controls_tabs( 'caption_category_style_tabs', [ 'condition' => [ 'show_caption_category' => 'yes', ], ] ); $this->start_controls_tab( 'caption_category_style_normal_tab', [ 'label' => esc_html__( 'Normal', 'maxcoach' ), ] ); $this->add_control( 'caption_category_color', [ 'label' => esc_html__( 'Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-categories' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'caption_category_bg', 'selector' => '{{WRAPPER}} .post-categories a', ] ); $this->end_controls_tab(); $this->start_controls_tab( 'caption_category_style_hover_tab', [ 'label' => esc_html__( 'Hover', 'maxcoach' ), ] ); $this->add_control( 'caption_category_hover_color', [ 'label' => esc_html__( 'Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-categories a:hover' => 'color: {{VALUE}};', ], ] ); $this->add_group_control( Group_Control_Background::get_type(), [ 'name' => 'caption_category_hover_bg', 'selector' => '{{WRAPPER}} .post-categories a:hover', ] ); $this->end_controls_tab(); $this->end_controls_tabs(); // Title style. $this->add_control( 'caption_title_heading', [ 'label' => esc_html__( 'Title', 'maxcoach' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', ] ); $this->add_responsive_control( 'caption_title_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-title' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'caption_title_typography', 'label' => esc_html__( 'Typography', 'maxcoach' ), 'selector' => '{{WRAPPER}} .post-title', ] ); $this->start_controls_tabs( 'caption_title_style_tabs' ); $this->start_controls_tab( 'caption_title_style_normal_tab', [ 'label' => esc_html__( 'Normal', 'maxcoach' ), ] ); $this->add_control( 'caption_title_color', [ 'label' => esc_html__( 'Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-title a' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'caption_title_style_hover_tab', [ 'label' => esc_html__( 'Hover', 'maxcoach' ), ] ); $this->add_control( 'caption_title_hover_color', [ 'label' => esc_html__( 'Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-title a:hover' => 'color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); // Excerpt style. $this->add_control( 'caption_excerpt_heading', [ 'label' => esc_html__( 'Excerpt', 'maxcoach' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'show_caption_excerpt' => 'yes', ], ] ); $this->add_responsive_control( 'caption_excerpt_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-excerpt' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'show_caption_excerpt' => 'yes', ], ] ); $this->add_group_control( Group_Control_Typography::get_type(), [ 'name' => 'caption_excerpt_typography', 'label' => esc_html__( 'Typography', 'maxcoach' ), 'selector' => '{{WRAPPER}} .post-excerpt', 'condition' => [ 'show_caption_excerpt' => 'yes', ], ] ); $this->add_control( 'caption_excerpt_color', [ 'label' => esc_html__( 'Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .post-excerpt' => 'color: {{VALUE}};', ], 'condition' => [ 'show_caption_excerpt' => 'yes', ], ] ); // Read more style. $this->add_control( 'caption_read_more_heading', [ 'label' => esc_html__( 'Read More', 'maxcoach' ), 'type' => Controls_Manager::HEADING, 'separator' => 'before', 'condition' => [ 'show_caption_read_more' => 'yes', ], ] ); $this->add_responsive_control( 'caption_read_more_margin', [ 'label' => esc_html__( 'Margin', 'maxcoach' ), 'type' => Controls_Manager::DIMENSIONS, 'size_units' => [ 'px', '%', 'em' ], 'selectors' => [ '{{WRAPPER}} .post-read-more' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};', ], 'condition' => [ 'show_caption_read_more' => 'yes', ], ] ); $this->start_controls_tabs( 'read_more_style_tabs', [ 'condition' => [ 'show_caption_read_more' => 'yes', ], ] ); $this->start_controls_tab( 'read_more_style_normal_tab', [ 'label' => esc_html__( 'Normal', 'maxcoach' ), ] ); $this->add_control( 'button_text_color', [ 'label' => esc_html__( 'Text Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'default' => '', 'selectors' => [ '{{WRAPPER}} .tm-button' => 'color: {{VALUE}};', ], ] ); $this->add_control( 'button_background_color', [ 'label' => esc_html__( 'Background Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .tm-button:before' => 'background-color: {{VALUE}};', ], ] ); $this->add_control( 'button_border_color', [ 'label' => esc_html__( 'Border Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .tm-button' => 'border-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->start_controls_tab( 'read_more_style_hover_tab', [ 'label' => esc_html__( 'Hover', 'maxcoach' ), ] ); $this->add_control( 'button_hover_text_color', [ 'label' => esc_html__( 'Text Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .tm-button:hover' => 'color: {{VALUE}};', ], ] ); $this->add_control( 'button_hover_background_color', [ 'label' => esc_html__( 'Background Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .tm-button:after' => 'background-color: {{VALUE}};', ], ] ); $this->add_control( 'button_hover_border_color', [ 'label' => esc_html__( 'Border Color', 'maxcoach' ), 'type' => Controls_Manager::COLOR, 'selectors' => [ '{{WRAPPER}} .tm-button:hover' => 'border-color: {{VALUE}};', ], ] ); $this->end_controls_tab(); $this->end_controls_tabs(); $this->end_controls_section(); } protected function print_slide( array $settings ) { ?> <div <?php post_class( 'swiper-slide' ); ?>> <div class="post-wrapper maxcoach-box"> <a href="<?php the_permalink(); ?>" class="post-feature post-thumbnail maxcoach-image"> <div class="post-background" <?php if ( has_post_thumbnail() ) : ?> <?php $size = \Maxcoach_Image::elementor_parse_image_size( $settings, '480x480' ); ?> <?php $url = \Maxcoach_Image::get_the_post_thumbnail_url( array( 'size' => $size ) ); ?> style="background-image: url( <?php echo $url; ?> );" <?php endif; ?> ></div> </a> <div class="post-caption"> <?php if ( 'yes' === $settings['show_caption_category'] ) : ?> <?php \Maxcoach_Post::instance()->the_category(); ?> <?php endif; ?> <h3 class="post-title"> <a href="<?php the_permalink(); ?>"><?php the_title(); ?></a> </h3> <?php if ( 'yes' === $settings['show_caption_excerpt'] ) : ?> <?php if ( empty( $settings['excerpt_length'] ) ) { $settings['excerpt_length'] = 10; } ?> <div class="post-excerpt"> <?php \Maxcoach_Templates::excerpt( array( 'limit' => $settings['excerpt_length'], 'type' => 'word', ) ); ?> </div> <?php endif; ?> <?php if ( ! empty( $settings['show_caption_meta'] ) ) : ?> <?php $meta = $settings['show_caption_meta']; ?> <div class="post-meta"> <div class="inner"> <?php if ( in_array( 'author', $meta, true ) ): ?> <?php \Maxcoach_Post::instance()->meta_author_template(); ?> <?php endif; ?> <?php if ( in_array( 'date', $meta, true ) ): ?> <?php \Maxcoach_Post::instance()->meta_date_template(); ?> <?php endif; ?> <?php if ( in_array( 'views', $meta, true ) ): ?> <?php \Maxcoach_Post::instance()->meta_view_count_template(); ?> <?php endif; ?> <?php if ( in_array( 'comments', $meta, true ) ): ?> <?php \Maxcoach_Post::instance()->meta_comment_count_template(); ?> <?php endif; ?> </div> </div> <?php endif; ?> <?php if ( 'yes' === $settings['show_caption_read_more'] || 'yes' === $settings['show_caption_share'] ): ?> <div class="post-footer"> <?php if ( 'yes' === $settings['show_caption_read_more'] ): ?> <?php $read_more_text = ! empty( $settings['read_more_text'] ) ? $settings['read_more_text'] : esc_html__( 'Read more', 'maxcoach' ); \Maxcoach_Templates::render_button( [ 'text' => $read_more_text, 'link' => [ 'url' => get_the_permalink(), ], 'size' => 'lg', 'wrapper_class' => 'post-read-more', ] ); ?> <?php endif; ?> <?php if ( 'yes' === $settings['show_caption_share'] ): ?> <?php \Maxcoach_Post::instance()->loop_share(); ?> <?php endif; ?> </div> <?php endif; ?> </div> </div> </div> <?php } }