HEX
Server: LiteSpeed
System: Linux l24.yourwebhosting.net 5.14.0-611.54.3.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Thu May 7 16:31:24 EDT 2026 x86_64
User: turkishi (1582)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: //proc/self/root/home/turkishi/www/wp-content/themes/kidzieo/includes/elementor/blog.php
<?php
namespace Elementor; // Custom widgets must be defined in the Elementor namespace
if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly (security measure)

/**
 * Widget Name: Projects Carousel
 */
class PBMIT_BlogElement extends Widget_Base{

 	// The get_name() method is a simple one, you just need to return a widget name that will be used in the code.
	public function get_name() {
		return 'pbmit_blog_element';
	}

	// The get_title() method, which again, is a very simple one, you need to return the widget title that will be displayed as the widget label.
	public function get_title() {

		$blog_cpt_singular_title	= esc_attr__('Blog','kidzieo');
		$blog_cpt_singular_title2	= get_theme_mod( 'blog-cpt-singular-title' );
		$blog_cpt_singular_title	= ( !empty($blog_cpt_singular_title2) ) ? $blog_cpt_singular_title2 : $blog_cpt_singular_title ;

		return sprintf( esc_attr__( 'Kidzieo %1$s Element', 'kidzieo') , $blog_cpt_singular_title );
	}

	// The get_icon() method, is an optional but recommended method, it lets you set the widget icon. you can use any of the eicon or font-awesome icons, simply return the class name as a string.
	public function get_icon() {
		return 'far fa-newspaper';
	}

	// The get_categories method, lets you set the category of the widget, return the category name as a string.
	public function get_categories() {
		return [ 'kidzieo_category' ];
	}

	public function __construct($data = [], $args = null) {
		parent::__construct($data, $args);
		if( !empty($data['settings']["view-type"]) && $data['settings']["view-type"]=='carousel' ){
			wp_enqueue_script( 'swiper' );
			wp_enqueue_style( 'swiper' );
		}
		if( !empty($data['settings']["sortable"]) && $data['settings']["sortable"]=='yes' ){
			wp_enqueue_script( 'isotope' );
		}
		if( !empty($data['settings']["view-type"]) && $data['settings']["view-type"]=='masonry' ){			
			wp_enqueue_script( 'masonry' );
			wp_enqueue_script( 'isotope' );

		}
		if( ( !empty($data['settings']["view-type"]) && $data['settings']["view-type"]=='masonry' ) &&
		( !empty($data['settings']["infinite-scroll"]) && $data['settings']["infinite-scroll"]=='yes' )
		){
			wp_enqueue_script( 'infinite-scroll' );		
		}
	}

	protected function register_controls() {

		// Blog

		$blog_cpt_title		= esc_attr__('Blog','kidzieo');
		$blog_cpt_title2	= get_theme_mod( 'blog-cpt-title' );
		$blog_cpt_title		= ( !empty($blog_cpt_title2) ) ? $blog_cpt_title2 : $blog_cpt_title ;

		$blog_cpt_singular_title	= esc_attr__('Blog','kidzieo');
		$blog_cpt_singular_title2	= get_theme_mod( 'blog-cpt-singular-title' );
		$blog_cpt_singular_title	= ( !empty($blog_cpt_singular_title2) ) ? $blog_cpt_singular_title2 : $blog_cpt_singular_title ;

		$blog_cat_singular_title	= esc_attr__('blog Category','kidzieo');
		$blog_cat_singular_title2	= get_theme_mod( 'blog-cat-singular-title' );
		$blog_cat_singular_title	= ( !empty($blog_cat_singular_title2) ) ? $blog_cat_singular_title2 : 
		$blog_cat_singular_title ;

		// Style
		$this->start_controls_section(
			'style_section',
			[
				'label'	=> sprintf(esc_attr__( '%1$s Style Options', 'kidzieo' ), $blog_cpt_singular_title ),
				'tab'	=> Controls_Manager::TAB_CONTENT,
			]
		);
		$this->add_control(
			'style',
			[
				'label'			=> sprintf( esc_attr__( 'Select %1$s View Style', 'kidzieo' ), $blog_cpt_singular_title ),
				'description'	=> sprintf( esc_attr__( 'Select  %1$s View style.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> 'pbmit_imgselect',
				'label_block'	=> true,
				'thumb_width'	=> '110px',
				'default'		=> '1',
				'options'		=> pbmit_element_template_list( 'blog', true ),
			]
		);
		$this->end_controls_section();

		// Column and Carousel Options
		$this->start_controls_section(
			'row_column_section',
			[
				'label'		=> esc_attr__( 'Column and Carousel Options', 'kidzieo' ),
				'condition'	=>[
					'style!'	=>['2'],
				],
			]
		);
		$this->add_control(
			'view-type',
			[
				'label'			=> sprintf( esc_attr__( 'How you like to view each %1$s box?', 'kidzieo' ), $blog_cpt_singular_title ),
				'description'	=> esc_attr__( 'Show as carousel view, simple row-column view or masonry view.', 'kidzieo' ),
				'type'			=> 'pbmit_imgselect',
				'label_block'	=> true,
				'thumb_width'	=> '110px',
				'default'		=> 'row-column',
				'options'		=> [
					'row-column'	=> esc_url( get_template_directory_uri() . '/includes/images/row-column.png' ),
					'carousel'		=> esc_url( get_template_directory_uri() . '/includes/images/carousel.png' ),
					'masonry'		=> esc_url( get_template_directory_uri() . '/includes/images/masonry.png' ),
				],
			]
		);
		// Carousel: Heading
		$this->add_control(
			'carousel_options',
			[
				'label'		=> esc_attr__( 'Carousel Options', 'kidzieo' ),
				'type' 		=> Controls_Manager::HEADING,
				'separator' => 'before',
				'condition'	=> [
					'view-type' => 'carousel',
				]
			]
		);
		// Carousel : Autoplay
		$this->add_control(
			'carousel-autoplay',
			[
				'label'			=> esc_attr__( 'Carousel: Autoplay', 'kidzieo' ),
				'description'	=> esc_attr__( 'Autoplay of carousel.', 'kidzieo' ),
				'type'			=> Controls_Manager::SELECT,
				'default'		=> '0',
				'options'		=> [
					'1'				=> esc_attr__( 'Yes', 'kidzieo' ),
					'0'				=> esc_attr__( 'No', 'kidzieo' ),
				],
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		// Carousel : delay
		$this->add_control(
			'carousel-delay',
			[
				'label'			=> esc_attr__( 'Carousel: delay', 'kidzieo' ),
				'description'	=> esc_attr__( 'Slide hold time (in ms).', 'kidzieo' ),
				'type'			=> Controls_Manager::TEXT,
				'default'		=> '4000',
				'condition'		=> [
					'view-type'			=> 'carousel',
					'carousel-autoplay'	=> '1',
				]
			]
		);

		// Carousel : Loop
		$this->add_control(
			'carousel-loop',
			[
				'label'			=> esc_attr__( 'Carousel: Loop', 'kidzieo' ),
				'description'	=> esc_attr__( 'Infinity loop. Duplicate last and first items to get loop illusion.', 'kidzieo' ),
				'type'			=> Controls_Manager::SELECT,
				'default'		=> '1',
				'options'		=> [
					'1'				=> esc_attr__( 'Yes', 'kidzieo' ),
					'0'				=> esc_attr__( 'No', 'kidzieo' ),
				],
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		
		// Carousel : Center
		$this->add_control(
			'carousel-center',
			[
				'label'			=> esc_attr__( 'Carousel: Center', 'kidzieo' ),
				'description'	=> esc_attr__( 'Center item. Works well with even an odd number of items.', 'kidzieo' ),
				'type'			=> Controls_Manager::SELECT,
				'default'		=> '0',
				'options'		=> [
					'1'				=> esc_attr__( 'Yes', 'kidzieo' ),
					'0'				=> esc_attr__( 'No', 'kidzieo' ),
				],
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		// Carousel : Nav
		$this->add_control(
			'carousel-nav',
			[
				'label'			=> esc_attr__( 'Carousel: Nav', 'kidzieo' ),
				'description'	=> esc_attr__( 'Show next/prev buttons.', 'kidzieo' ),
				'type'			=> Controls_Manager::SELECT,
				'default'		=> '0',
				'options'		=> [
					'1'				=> esc_attr__( 'Yes', 'kidzieo' ),
					'0'				=> esc_attr__( 'No', 'kidzieo' ),
					'above'			=> esc_attr__( 'Yes, near heading area', 'kidzieo' ),
				],
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		// Carousel : Dots
		$this->add_control(
			'carousel-dots',
			[
				'label'			=> esc_attr__( 'Carousel: Dots', 'kidzieo' ),
				'description'	=> esc_attr__( 'Show dots navigation.', 'kidzieo' ),
				'type'			=> Controls_Manager::SELECT,
				'default'		=> '0',
				'options'		=> [
					'1'				=> esc_attr__( 'Yes', 'kidzieo' ),
					'0'				=> esc_attr__( 'No', 'kidzieo' ),
				],
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		// Carousel : Speed
		$this->add_control(
			'carousel-speed',
			[
				'label'			=> esc_attr__( 'Carousel:Speed', 'kidzieo' ),
				'description'	=> esc_attr__( 'Slider animation time (in ms.)', 'kidzieo' ),
				'type'			=> Controls_Manager::TEXT,
				'default'		=> '3000',
				'condition'		=> [
					'view-type'		=> 'carousel',
				]
			]
		);
		// Infinite scroll
		$this->add_control(
			'infinite-scroll-section-heading',
			[
				'label'			=> esc_attr__( 'Infinite Scroll Options', 'kidzieo' ),
				'type'			=> Controls_Manager::HEADING,
				'separator'		=> 'before',
				'condition'		=> [
					'view-type'		=> 'masonry',
					'style!'		=> ['2'],
				],
			]
		);
		$this->add_control(
			'infinite-scroll',
			[
				'label'		 	=> esc_attr__( 'Enable infinite scroll ?', 'kidzieo' ),
				'description' 	=> sprintf( esc_attr__( 'Select YES to dynamically load more %1$s', 'kidzieo' ), $blog_cpt_title ),
				'type'		 	=> Controls_Manager::SWITCHER,
				'label_on' 		=> esc_attr__( 'Yes', 'kidzieo' ),
				'label_off' 	=> esc_attr__( 'No', 'kidzieo' ),
				'return_value'	=> 'yes',
				'default' 		=> '',
				'condition'		=> [
					'view-type'		=> 'masonry',
					'style!'		=> ['2'],
				],
			]
		);
		$this->add_control(
			'infinite-scroll-show-loadmore-type',
			[
				'label'		=> esc_attr__( 'Load new boxes', 'kidzieo' ),
				'type'		=> Controls_Manager::SELECT,
				'options'	=> [
					'auto'		=> esc_attr( 'On page scroll (auto)' ),
					'button'	=> esc_attr( 'On button click' ),
				],
				'condition'	=> [
					'view-type'			=> 'masonry',
					'infinite-scroll'	=> 'yes',
					'style!'			=> ['2'],
				],
				'default' => esc_attr( 'auto' ),
			]
		);
		$this->add_control(
			'infinite-scroll-loadmore-btn-title',
			[
				'label' 		=> esc_attr__( 'Button text', 'kidzieo' ),
				'description' 	=> esc_attr__( 'Button title for the "Load More" button.', 'kidzieo' ),
				'type' 			=> Controls_Manager::TEXTAREA,
				'dynamic'		=> [
					'active' 		=> true,
				],
				'condition' 	=> [
					'infinite-scroll-show-loadmore-type'	=> 'button',
					'infinite-scroll'						=> 'yes',
					'view-type'								=> 'masonry',
					'style!'								=> ['2'],
				],
				'default'		=> esc_attr__( 'Load More', 'kidzieo' ),
				'placeholder'	=> esc_attr__( 'Enter button title', 'kidzieo' ),
				'label_block'	=> true,
			]
		);

		// Columns
		$this->add_control(
			'view-column-section-heading',
			[
				'label'			=> esc_attr__( 'Column Settings', 'kidzieo' ),
				'type'			=> Controls_Manager::HEADING,
				'separator'		=> 'before',
			]
		);
		$this->add_control(
			'columns',
			[
				'label'			=> esc_attr__( 'View in Column', 'kidzieo' ),
				'description'	=> esc_attr__( 'Select how many column to show.', 'kidzieo' ),
				'type'			=> 'pbmit_imgselect',
				'label_block'	=> true,
				'thumb_width'	=> '110px',
				'default'		=> '3',
				'options'		=> [
					'1'				=> esc_url( get_template_directory_uri() . '/includes/images/column-1.png' ),
					'2'				=> esc_url( get_template_directory_uri() . '/includes/images/column-2.png' ),
					'3'				=> esc_url( get_template_directory_uri() . '/includes/images/column-3.png' ),
					'4'				=> esc_url( get_template_directory_uri() . '/includes/images/column-4.png' ),
				],
			]
		);
		$this->end_controls_section();

		// Heading and Subheading
		$this->start_controls_section(
			'heading_section',
			[
				'label' => esc_attr__( 'Heading and Subheading', 'kidzieo' ),
			]
		);
		$this->add_control(
			'title_animation',
			[
				'label'			=> esc_attr__( 'Heading Animation', 'kidzieo' ),
				'description'	=> esc_attr__( 'Select Heading Text Animation View style.', 'kidzieo' ) . ' ' . pbmit_esc_kses('<br><a target="_blank" href="' . esc_url('http://kidzieo-demo.pbminfotech.com/demo1/element/#heading-animations') . '">' . esc_attr__( 'See all anmiation demo here.', 'kidzieo' ) . '</a>' ),
				'type'			=> Controls_Manager::SELECT,
				'options' => [
					''			=> esc_attr__( 'No animation', 'kidzieo' ),
					'1'			=> esc_attr__( 'Animation Style 1', 'kidzieo' ),
					'2'			=> esc_attr__( 'Animation Style 2', 'kidzieo' ),
					'3'			=> esc_attr__( 'Animation Style 3', 'kidzieo' ),
				],
				'separator'	=> 'before',
			]
		);
		$this->add_control(
			'title',
			[
				'label'		=> esc_attr__( 'Heading', 'kidzieo' ),
				'type'		=> Controls_Manager::TEXTAREA,
				'dynamic'	=> [
					'active'		=> true,
				],
				'default'		=> esc_attr__( 'Our Blog', 'kidzieo' ),
				'placeholder'	=> esc_attr__( 'Enter your heading', 'kidzieo' ),
				'label_block'	=> true,
			]
		);
		$this->add_control(
			'title_link',
			[
				'label'			=> esc_attr__( 'Heading Link', 'kidzieo' ),
				'type'			=> Controls_Manager::URL,
				'label_block'	=> true,
			]
		);
		$this->add_control(
			'subtitle',
			[
				'label' => esc_attr__( 'Subheading', 'kidzieo' ),
				'type' 	=> Controls_Manager::TEXTAREA,
				'dynamic' => [
					'active' => true,
				],
				'placeholder' => esc_attr__( 'Enter your subtitle', 'kidzieo' ),
				'label_block' => true,
			]
		);
		$this->add_control(
			'subtitle_link',
			[
				'label' 	  => esc_attr__( 'Subheading Link', 'kidzieo' ),
				'type' 		  => Controls_Manager::URL,
				'label_block' => true,
			]
		);
		$this->add_control(
			'desc',
			[
				'label' 	  => esc_attr__( 'Description', 'kidzieo' ),
				'type' 		  => Controls_Manager::TEXTAREA,
				'placeholder' => esc_attr__( 'Type your description here', 'kidzieo' ),
			]
		);
		$this->add_control(
			'reverse_title',
			[
				'label' 	  	=> esc_attr__( 'Reverse Heading', 'kidzieo' ),
				'description' 	=> esc_attr__( 'Show Subheading before Heading', 'kidzieo' ),
				'type' 		  	=> Controls_Manager::SWITCHER,
				'label_on' 	  	=> esc_attr__( 'Yes', 'kidzieo' ),
				'label_off'   	=> esc_attr__( 'No', 'kidzieo' ),
				'return_value' 	=> 'yes',
				'default' 		=> '',
			]
		);
		$this->add_responsive_control(
			'text_align',
			[
				'label'			=> esc_attr__( 'Alignment', 'kidzieo' ),
				'type'			=> Controls_Manager::CHOOSE,
				'options'		=> [
					'left'			=> [
						'title'			=> esc_attr__( 'Left', 'kidzieo' ),
						'icon' 			=> 'fa fa-align-left',
					],
					'center'		=> [
						'title'			=> esc_attr__( 'Center', 'kidzieo' ),
						'icon'			=> 'fa fa-align-center',
					],
					'right'			=> [
						'title'			=> esc_attr__( 'Right', 'kidzieo' ),
						'icon'			=> 'fa fa-align-right',
					],
				],
				'prefix_class'	=> 'pbmit-ele-header-align-',
				'selectors'		=> [
					'{{WRAPPER}} .pbmit-heading-subheading'	=> 'text-align: {{VALUE}};',
				],
			]
		);
		$this->add_control(
			'btn_title',
			[
				'label'			=> esc_attr__( 'Button Title', 'kidzieo' ),
				'type'			=> Controls_Manager::TEXT,
				'dynamic'		=> [
					'active'		=> true,
				],
				'default'		=> esc_attr__( 'Read More', 'kidzieo' ),
				'placeholder'	=> esc_attr__( 'Enter button title here', 'kidzieo' ),
				'label_block'	=> true,
				'default' 	  => esc_attr__( 'Read More', 'kidzieo' ),			
				'condition'		=> [
					'style'			=> ['1'],
				],
			]
		);
		$this->add_control(
			'btn_link',
			[
				'label'			=> esc_attr__( 'Button Link', 'kidzieo' ),
				'type'			=> Controls_Manager::URL,
				'label_block'	=> true,
				'default'		=> array (
					'url'				=> '',
					'is_external'		=> '',
					'nofollow'			=> '',
					'custom_attributes'	=> '',
				),
				'condition'		=> [
					'style'			=>	['1'],
				],
			]
		);

		$this->end_controls_section();

		// Heading and Subheading
		$this->start_controls_section(
			'data_section',
			[
				'label'	=> sprintf( esc_attr__( '%1$s Content Options', 'kidzieo' ), $blog_cpt_singular_title ),
			]
		);
		$this->add_control(
			'from_category',
			[
				'label' 		=> sprintf( esc_attr__( 'Show %2$s from selected %1$s?', 'kidzieo' ), $blog_cat_singular_title, $blog_cpt_singular_title ),
				'type' 			=> Controls_Manager::SELECT2,
				'options' 		=> $this->select_category(),
				'multiple' 		=> true,
				'label_block'	=> true,
				'placeholder'   => esc_attr__( 'All Categories', 'kidzieo' ),
			]
		);
		$this->add_control(
			'show',
			[
				'label' 	  => sprintf( esc_attr__( '%1$s to show', 'kidzieo' ), $blog_cpt_singular_title ),
				'description' => sprintf( esc_attr__( 'How many %1$s you want to show.', 'kidzieo' ), $blog_cpt_singular_title ),
				'separator'   => 'before',
				'type' 		  => Controls_Manager::NUMBER,
				'default' 	  => '6',
			]
		);
		$this->add_control(
			'sortable',
			[
				'label'			=> sprintf( esc_attr__( 'Show Sortable %1$s?', 'kidzieo' ), $blog_cpt_singular_title ),
				'description'	=> sprintf( esc_attr__( 'Select YES to show sortable %1$s.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> Controls_Manager::SWITCHER,
				'label_on'		=> esc_attr__( 'Yes', 'kidzieo' ),
				'label_off'		=> esc_attr__( 'No', 'kidzieo' ),
				'return_value'	=> 'yes',
				'default'		=> '',
				'condition'		=> [
					'view-type'		=> 'row-column',
				]
			]
		);
		$this->add_control(
			'ajax_sortable',
			[
				'label'			=> esc_attr__( 'Ajax based sortable Category?', 'kidzieo' ),
				'description'	=> sprintf( esc_attr__( 'Select YES to load %1$s using Ajax on click on the category.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> Controls_Manager::SWITCHER,
				'label_on'		=> esc_attr__( 'Yes', 'kidzieo' ),
				'label_off'		=> esc_attr__( 'No', 'kidzieo' ),
				'return_value'	=> 'yes',
				'default'		=> '',
				'condition'		=> [
					'sortable'		=> 'yes',
					'view-type'		=> 'row-column',
					'style!'		=> ['2'],
					'offset!'		=> 'yes',
				],
			]
		);
		$this->add_control(
			'pagination',
			[
				'label' 		=> esc_attr__( 'Show Pagination ?', 'kidzieo' ),
				'description' 	=>  sprintf( esc_attr__( 'Select YES to Show pagination links below %1$s boxes.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> Controls_Manager::SWITCHER,
				'label_on'		=> esc_attr__( 'Yes', 'kidzieo' ),
				'label_off'		=> esc_attr__( 'No', 'kidzieo' ),
				'return_value'	=> 'yes',
				'default'		=> '',
				'condition'		=> [
					'view-type'		=> 'row-column',
					'sortable!'     => 'yes',
					]
				]
			);
			$this->add_control(
				'ajax_pagination',
				[
					'label'			=> esc_attr__( 'Load post without page refresh on Pagination click ?', 'kidzieo' ),
					'description' 	=>  sprintf( esc_attr__( 'Select YES to load Posts without page refresh (ajax based) when click on the pagination links.', 'kidzieo' ), $blog_cpt_singular_title ),
					'type'			=> Controls_Manager::SWITCHER,
					'label_on'		=> esc_attr__( 'Yes', 'kidzieo' ),
					'label_off'		=> esc_attr__( 'No', 'kidzieo' ),
					'return_value'	=> 'yes',
					'default'		=> '',
					'condition'		=> [
						'pagination'    => 'yes',
						'view-type'		=> 'row-column',
						'sortable!'     => 'yes',
				]
			]
		);
		$this->add_control(
			'order',
			[
				'label' 		=> esc_attr__( 'Order', 'kidzieo' ),
				'description' 	=> esc_attr__( 'Designates the ascending or descending order.', 'kidzieo' ),
				'type' 			=> Controls_Manager::SELECT,
				'separator' 	=> 'before',
				'default' 		=> 'DESC',
				'options' 		=> [
					'ASC'		=> esc_attr__( 'Ascending order (1, 2, 3; a, b, c)', 'kidzieo' ),
					'DESC'		=> esc_attr__( 'Descending order (3, 2, 1; c, b, a)', 'kidzieo' ),
				]
			]
		);
		$this->add_control(
			'orderby',
			[
				'label' 	  => esc_attr__( 'Order By', 'kidzieo' ),
				'description' => sprintf( esc_attr__( ' Sort retrieved %1$s by parameter.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type' 		  => Controls_Manager::SELECT,
				'default' 	  => 'none',
				'options' 	  => [
					'none'		=> esc_attr__( 'No order', 'kidzieo' ),
					'ID'		=> esc_attr__( 'ID', 'kidzieo' ),
					'title'		=> esc_attr__( 'Title', 'kidzieo' ),
					'date'		=> esc_attr__( 'Date', 'kidzieo' ),
					'rand'		=> esc_attr__( 'Random', 'kidzieo' ),
				]
			]
		);
		$this->add_control(
			'offset',
			[
				'label'			=> sprintf( esc_attr__( 'Skip %1$s (offset)', 'kidzieo' ), $blog_cpt_singular_title ),
				'description'	=> sprintf( esc_attr__( 'How many  %1$s you like to skip.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> Controls_Manager::SELECT,
				'label_block'	=> true,
				'default'		=> '',
				'options'		=> [
					''			=> sprintf(esc_attr__( 'Show All %1$s (No skip)', 'kidzieo' ), $blog_cpt_title ),
					'1'			=> sprintf(esc_attr__( 'Skip first %1$s', 'kidzieo' ), $blog_cpt_singular_title ),
					'2'			=> sprintf(esc_attr__( 'Skip two %1$s', 'kidzieo' ), $blog_cpt_title ),
					'3'			=> sprintf(esc_attr__( 'Skip three %1$s', 'kidzieo' ), $blog_cpt_title ),
					'4'			=> sprintf(esc_attr__( 'Skip four %1$s', 'kidzieo' ), $blog_cpt_title ),
					'5'			=> sprintf(esc_attr__( 'Skip five %1$s', 'kidzieo' ), $blog_cpt_title ),
				],
				'condition'	=> [
					'ajax_sortable!' => 'yes',
				]
			]
		);
		$this->end_controls_section();

		// HTML Tags
		$this->start_controls_section(
			'advanced_section',
			[
				'label' => pbmit_esc_kses('<img class="pbmit-tab-small-logo" src="'.get_template_directory_uri() . '/includes/images/pbm-small-logo.png" /> ') . esc_attr__( 'Tag & Gap Settings', 'kidzieo' ),
				'tab'   => Controls_Manager::TAB_ADVANCED,
			]
		);
		$this->add_control(
			'tag_options',
			[
				'label'			=> esc_attr__( 'Tags for SEO', 'kidzieo' ),
				'type'			=> Controls_Manager::HEADING,
				'separator'		=> 'before',
			]
		);
		$this->add_control(
			'title_tag',
			[
				'label'		=> esc_attr__( 'Heading Tag', 'kidzieo' ),
				'type'		=> Controls_Manager::SELECT,
				'options'	=> [
					'h1'		=> esc_attr( 'H1' ),
					'h2'		=> esc_attr( 'H2' ),
					'h3'		=> esc_attr( 'H3' ),
					'h4'		=> esc_attr( 'H4' ),
					'h5'		=> esc_attr( 'H5' ),
					'h6'		=> esc_attr( 'H6' ),
					'div'		=> esc_attr( 'DIV' ),
				],
				'default' => esc_attr( 'h2' ),
			]
		);
		$this->add_control(
			'subtitle_tag',
			[
				'label'   => esc_attr__( 'Subheading Tag', 'kidzieo' ),
				'type' 	  => Controls_Manager::SELECT,
				'options' => [
					'h1'	=> esc_attr( 'H1' ),
					'h2'	=> esc_attr( 'H2' ),
					'h3'	=> esc_attr( 'H3' ),
					'h4'	=> esc_attr( 'H4' ),
					'h5'	=> esc_attr( 'H5' ),
					'h6'	=> esc_attr( 'H6' ),
					'div'	=> esc_attr( 'DIV' ),
				],
				'default' => esc_attr( 'h4' ),
			]
		);

		$this->add_control(
			'gap_options',
			[
				'label'			=> sprintf( esc_attr__( 'Gap between %1$s boxes', 'kidzieo' ), $blog_cpt_singular_title ),
				'type'			=> Controls_Manager::HEADING,
				'separator'		=> 'before',
			]
		);
		$this->add_control(
			'gap',
			[
				'label' 	  => esc_attr__( 'Box Gap', 'kidzieo' ),
				'description' =>  sprintf( esc_attr__( 'Gap between each %1$s box.', 'kidzieo' ), $blog_cpt_singular_title ),
				'type' 		  => Controls_Manager::SELECT,
				'default' 	  => 'default',
				'options' 	  => [
					'default'	=> esc_attr__( 'Default Gap', 'kidzieo' ),
					'0px'		=> esc_attr__( 'No Gap (0px)', 'kidzieo' ),
					'5px'		=> esc_attr__( '5px', 'kidzieo' ),
					'10px'		=> esc_attr__( '10px', 'kidzieo' ),
					'15px'		=> esc_attr__( '15px', 'kidzieo' ),
					'20px'		=> esc_attr__( '20px', 'kidzieo' ),
					'25px'		=> esc_attr__( '25px', 'kidzieo' ),
					'30px'		=> esc_attr__( '30px', 'kidzieo' ),
					'35px'		=> esc_attr__( '35px', 'kidzieo' ),
					'40px'		=> esc_attr__( '40px', 'kidzieo' ),
					'45px'		=> esc_attr__( '45px', 'kidzieo' ),
					'50px'		=> esc_attr__( '50px', 'kidzieo' ),
				],
			]
		);
		$this->end_controls_section();

	}

	protected function render() {

		$settings	= $this->get_settings_for_display();
		extract($settings);

		// check variables
		$columns = ( !empty($columns) ) ? $columns : '1' ;

		// Masonry image sizes
		$masonry_image_size_array = array(
			'pbmit-img-770x492', // For masonry 1st box
			'pbmit-img-770x762', // For masonry 2nd box
			'pbmit-img-770x492', // For masonry 3rd box
			'pbmit-img-770x745', // For masonry 4th box
			'pbmit-img-770x745', // For masonry 5th box
			'pbmit-img-770x872', // For masonry 6th box
			'pbmit-img-770x447', // For masonry 7th box
			'pbmit-img-770x485', // For masonry 8th box
			'pbmit-img-770x974', // For masonry 9th box
		);
		
		$swiper_class = '';
		if( isset($data['settings']["view-type"]) && !empty($data['settings']["view-type"]) && $data['settings']["view-type"]=='carousel' ){
			$swiper_class = ' swiper-wrapper';
		}

		$infinite_scroll_enabled = ( isset($settings['infinite-scroll']) && !empty($settings['infinite-scroll']) ) ? $settings['infinite-scroll'] : 'no' ;
		$loadmore_btn = ( isset($settings['infinite-scroll-show-loadmore-type']) && !empty($settings['infinite-scroll-show-loadmore-type']) ) ? $settings['infinite-scroll-show-loadmore-type'] : 'no' ;

		$loadmore_btn_title = ( isset($settings['infinite-scroll-loadmore-btn-title']) && !empty($settings['infinite-scroll-loadmore-btn-title']) ) ? $settings['infinite-scroll-loadmore-btn-title'] : '' ;

		// Starting container
		pbmit_element_container( array(
			'position'	=> 'start',
			'cpt'		=> 'blog',
			'data'		=> $settings
		) );
		?>

		<div class="pbmit-ele-header-area">
			<div class="pbmit-header-area-inner">
				<?php pbmit_heading_subheading($settings, true); ?>
				<?php 
					// Button
					$button_html = '';
					if( !empty($settings['btn_title']) && !empty($settings['btn_link']['url']) ){
						$button_html = '<div class="pbmit-blog-btn pbmit-head-btn">' . pbmit_link_render($settings['btn_link'], 'start' ) . pbmit_esc_kses($settings['btn_title']) . pbmit_link_render($settings['btn_link'], 'end' ) . '</div>';
					} ?>
					<?php if( $style == '1' ){ 				
						echo pbmit_esc_kses($button_html);
					} 
					?>
			</div>
			<?php
			/* Sortable Category  */
			$sortable_html = pbmit_sortable_category( $settings, 'category' );
			echo pbmit_esc_kses($sortable_html);
			?>
		</div>

		<?php
		// Infinite scroll data
		$infinite_scroll_data = array();
		$infinite_scroll_data['cpt'] = 'blog';
		$infinite_scroll_data['style'] = $style;

		if( !empty($settings['columns']) ){
			$infinite_scroll_data['columns'] = $settings['columns'];
		}
		if( !empty($settings['show']) ){
			$infinite_scroll_data['show'] = $settings['show'];
		}

		if( !empty($settings['offset']) ){
			$infinite_scroll_data['offset'] = $settings['offset'];
		}
		if( !empty($settings['from_category']) ){
			$infinite_scroll_data['from_category'] = $settings['from_category'];
		}
		if( !empty($settings['show']) ){
			$infinite_scroll_data['show'] = $settings['show'];
		}
		if( !empty($settings['order']) ){
			$infinite_scroll_data['order'] = $settings['order'];
		}
		if( !empty($settings['orderby']) ){
			$infinite_scroll_data['orderby'] = $settings['orderby'];
		}
		echo pbmit_esc_kses('<div class="pbmit-infinite-scroll-data">'.json_encode($infinite_scroll_data).'</div>');

		// Preparing $args
		if(is_front_page()) {
			$paged = (get_query_var('page')) ? get_query_var('page') : 1;
		}else {
			$paged = (get_query_var('paged')) ? get_query_var('paged') : 1;
		}
		$args = array(
			'post_type'				=> 'post',
			'status'				=> 'publish',
			'posts_per_page'		=> $show,
			'ignore_sticky_posts'	=> true,
			'paged' => $paged,
		);

		if( !empty($offset) ){
			$args['offset'] = $offset;
		}
		if( !empty($orderby) && $orderby!='none' ){
			$args['orderby'] = $orderby;
			if( !empty($order) ){
				$args['order'] = $order;
			}
		}

		// From selected category/group
		if( !empty($from_category) ){
			$args['tax_query'] = array(
				array(
					'taxonomy' => 'category',
					'field'	=> 'slug',
					'terms'	=> $from_category,
				),
			);
		};
		// Wp query to fetch posts
		$posts = new \WP_Query( $args );

		if ( $posts->have_posts() ) {
			?>

			<div class="pbmit-element-posts-wrapper row multi-columns-row <?php if( !empty($settings['view-type']) && trim($settings['view-type'])=='carousel' ){ ?>swiper-container<?php } ?>">
				
				<?php

				$odd_even		= 'odd';
				$col_odd_even	= 'odd';
				$x				= 1;
				$pbmit_global_sc_loop_inner_count = 0;

				while ( $posts->have_posts() ) {
					$return = '';
					$posts->the_post();

					// masonry image size
					$imgsize = ''; // default image size variable. This should be empty.
					if( !empty($settings['view-type']) && $settings['view-type'] == 'masonry' ){
						$imgsize = $masonry_image_size_array[($pbmit_global_sc_loop_inner_count)];
					}

					// Template
					if( file_exists( locate_template( '/theme-parts/blog/blog-style-'.esc_attr($style).'.php', false, false ) ) ){

						$return .= pbmit_element_block_container( array(
							'position'		=> 'start',
							'column'		=> $columns,
							'cpt'			=> 'blog',
							'taxonomy'		=> 'category',
							'style'			=> $style,
							'odd_even'		=> $odd_even,
							'col_odd_even'	=> $col_odd_even,
						) );

						ob_start();
						$r = include( locate_template( '/theme-parts/blog/blog-style-'.esc_attr($style).'.php', false, false ) );
						$return .= ob_get_contents();
						ob_end_clean();

						$return .= pbmit_element_block_container( array(
							'position'	=> 'end',
						) );

						// Variable to count current, for image size and other use
						$pbmit_global_sc_loop_inner_count++;
						if( !empty($box_size_array) ){
							if (($x) % (count($box_size_array)) == 0) {
								$pbmit_global_sc_loop_inner_count = 0;
							}
						}

					}

					echo pbmit_esc_kses($return);

					// odd or even
					if( $odd_even == 'odd' ){ $odd_even = 'even'; } else { $odd_even = 'odd'; }
					if( !empty($columns) ){
						if( $x % $columns == 0 ){
							if( $col_odd_even == 'odd' ){ $col_odd_even = 'even'; } else { $col_odd_even = 'odd'; }
						}
					}
					$x++;

				}
				?>

			</div> <!-- .pbmit-element-posts-wrapper -->

			<?php
			// Pagination
			if( isset($settings['pagination']) && $settings['pagination']=='yes' && $settings['view-type']!='carousel' ){
				$return .= pbmit_pagination( $posts );
			}
			?>

			<?php
			// infinite scroll
			if( $infinite_scroll_enabled=='yes' ){
				// Load More button
				if( $loadmore_btn == 'button' ){
					if( empty($loadmore_btn_title) ){
						$loadmore_btn_title = esc_attr__( 'Load More', 'kidzieo' );
					}
					echo pbmit_esc_kses( '<div class="pbmit-ajax-load-more-btn"><a href="#">' . esc_attr($loadmore_btn_title) . '</a></div>' );
				}
				echo pbmit_esc_kses( '<div class="pbmit-infinite-loader"><img src="' . get_template_directory_uri() . '/images/three-dots.svg" width="60" alt="' . esc_attr__( 'Loader', 'kidzieo' ) . '"></div><div class="pbmit-infinite-scroll-last">' . esc_attr__( 'All content loaded', 'kidzieo' ) . '</div>' );
			}
			?>

		<?php } else { ?>

			<div class="pbmit-no-data-message"><?php esc_html_e('No data available.', 'kidzieo'); ?></div>

		<?php } ?>

		<?php wp_reset_postdata(); ?>

		<?php
		// Ending wrapper of the whole arear
		pbmit_element_container( array(
			'position'	=> 'end',
			'cpt'		=> 'blog',
			'data'		=> $settings
		) );
		?>

		<?php
	}

	protected function content_template() {}

	protected function select_category() {
	  	$category = get_categories( array('hide_empty' => false ) );
	  	$cat = array();
	  	foreach( $category as $item ) {
			$cat_count = get_category( $item );

		 	if( $item ) {
				$cat[$item->slug] = $item->name . ' ('.$cat_count->count.')';
		 	}
	  	}
	  	return $cat;
	}
}
// After the Schedule class is defined, I must register the new widget class with Elementor:
Plugin::instance()->widgets_manager->register( new PBMIT_BlogElement() );