Your IP : 3.21.105.119


Current Path : /home/church/www/offwins.com/wp-content/plugins/post-grid/templates/
Upload File :
Current File : /home/church/www/offwins.com/wp-content/plugins/post-grid/templates/post-grid-hook.php

<?php
if ( ! defined('ABSPATH')) exit;  // if direct access




add_action('post_grid_main', 'post_grid_main_lazy', 5);

function post_grid_main_lazy($atts){


    $grid_id = $atts['id'];
    $post_grid_options = get_post_meta( $grid_id, 'post_grid_meta_options', true );

    $lazy_load_enable = isset($post_grid_options['lazy_load_enable']) ? $post_grid_options['lazy_load_enable'] : 'grid';
    $lazy_load_image_src = isset($post_grid_options['lazy_load_image_src']) ? $post_grid_options['lazy_load_image_src'] : '';



    ?>
    <div id="post-grid-lazy-<?php echo $grid_id; ?>" class="post-grid-lazy"><img src="<?php echo $lazy_load_image_src; ?>"/></div>
    <script>
        jQuery('#post-grid-lazy-<?php echo $grid_id; ?>').ready(function($){
            jQuery('#post-grid-lazy-<?php echo $grid_id; ?>').fadeOut();
            jQuery('#post-grid-<?php echo $grid_id; ?>').fadeIn();
        })
    </script>
    <style type="text/css">
        #post-grid-<?php echo $grid_id; ?>{display: none;}
        .post-grid-lazy{
            text-align: center;
        }
    </style>
    <?php



}



add_action('post_grid_main', 'post_grid_main_container', 10);

function post_grid_main_container($atts){

    global  $post_grid_css;

    $grid_id = $atts['id'];
    $post_grid_options = get_post_meta( $grid_id, 'post_grid_meta_options', true );

    $grid_type = isset($post_grid_options['grid_type']) ? $post_grid_options['grid_type'] : 'grid';

    $args['grid_id'] = $grid_id;
    $args['options'] = $post_grid_options;

    wp_enqueue_style( 'post-grid-style' );

    $lazy_load_enable = isset($post_grid_options['lazy_load_enable']) ? $post_grid_options['lazy_load_enable'] : 'grid';
    $masonry_enable = !empty($post_grid_options['masonry_enable']) ? $post_grid_options['masonry_enable'] : 'no';
    $grid_type = isset($post_grid_options['grid_type']) ? $post_grid_options['grid_type'] : 'grid';

    $post_grid_js_args = array(
        'id' => $grid_id,
        'lazy_load' => $lazy_load_enable,
        'masonry_enable' => $masonry_enable,
        'view_type' => $grid_type,
    );

    $post_grid_js_args = apply_filters('post_grid_js_args', $post_grid_js_args, $args);


    ?>
    <div data-options='<?php echo json_encode($post_grid_js_args); ?>' id="post-grid-<?php echo $grid_id; ?>" class="post-grid <?php echo $grid_type; ?>">
        <?php
        do_action('post_grid_container', $args);
        ?>
    </div>
    <?php



}


add_action('post_grid_container', 'post_grid_container_search', 5);

function post_grid_container_search($args){

    $post_grid_settings = get_option('post_grid_settings');

    $grid_id = $args['grid_id'];
    $post_grid_options = $args['options'];

    $font_aw_version = isset($post_grid_settings['font_aw_version']) ? $post_grid_settings['font_aw_version'] : 'v_5';


    $nav_top_search = isset($post_grid_options['nav_top']['search']) ? $post_grid_options['nav_top']['search'] : 'no';
    $grid_type = isset($post_grid_options['grid_type']) ? $post_grid_options['grid_type'] : 'grid';

    if($nav_top_search !='yes') return;


    if($font_aw_version == 'v_5'){
        $nav_top_search_icon = '<i class="fas fa-search"></i>';
    }elseif($font_aw_version == 'v_4'){
        $nav_top_search_icon = '<i class="fa fa-search"></i>';
    }

    $nav_top_search_placeholder = isset($post_grid_options['nav_top']['search_placeholder']) ? $post_grid_options['nav_top']['search_placeholder'] : __('Start typing', 'post-grid');
    $nav_top_search_icon = isset($post_grid_options['nav_top']['search_icon']) ? $post_grid_options['nav_top']['search_icon'] : $nav_top_search_icon;


    $keyword = isset($_GET['keyword']) ? sanitize_text_field($_GET['keyword']) : '';

    ?>
    <div class="grid-nav-top">
        <div class="nav-search">
            <span class="search-icon"><?php echo $nav_top_search_icon; ?></span>
            <input grid_id="<?php echo $grid_id; ?>" title="<?php echo __('Press enter to reset', 'post-grid'); ?>" class="search" type="text"  placeholder="<?php echo $nav_top_search_placeholder; ?>" value="<?php echo $keyword; ?>">
        </div>
    </div>



    <?php



}







add_action('post_grid_container', 'post_grid_posts_loop', 10);

function post_grid_posts_loop($args){

   global $wp_query;

    $post_grid_options = $args['options'];
    $grid_id = $args['grid_id'];

    $post_types = isset($post_grid_options['post_types']) ? $post_grid_options['post_types'] : array('post');
    $keyword = isset($post_grid_options['keyword']) ? $post_grid_options['keyword'] : '';
    $exclude_post_id = isset($post_grid_options['exclude_post_id']) ? $post_grid_options['exclude_post_id'] : '';

    $exclude_post_id = !empty($exclude_post_id) ? array_map('intval',explode(',',$exclude_post_id)) : array();
    $include_post_id = isset($post_grid_options['include_post_id']) ? $post_grid_options['include_post_id'] : '';
    $include_post_id = !empty($include_post_id) ? array_map('intval',explode(',', $include_post_id)) : array();


    $post_status = isset($post_grid_options['post_status']) ? $post_grid_options['post_status'] : 'publish';
    $query_order = isset($post_grid_options['query_order']) ? $post_grid_options['query_order'] : 'DESC';
    $query_orderby = isset($post_grid_options['query_orderby']) ? $post_grid_options['query_orderby'] : array('date');
    $query_orderby = implode(' ', $query_orderby);
    $offset = isset($post_grid_options['offset']) ? (int)$post_grid_options['offset'] : '';
    $posts_per_page = isset($post_grid_options['posts_per_page']) ? $post_grid_options['posts_per_page'] : 10;
    $query_orderby_meta_key = isset($post_grid_options['query_orderby_meta_key']) ? $post_grid_options['query_orderby_meta_key'] : '';
    $ignore_paged = isset($post_grid_options['ignore_paged']) ? $post_grid_options['ignore_paged'] : 'no';


    $taxonomies = !empty($post_grid_options['taxonomies']) ? $post_grid_options['taxonomies'] : array();
    $categories_relation = isset($post_grid_options['categories_relation']) ? $post_grid_options['categories_relation'] : 'OR';

    $query_args = array();



    /* ################################ Tax query ######################################*/

    $tax_query = array();

    foreach($taxonomies as $taxonomy => $taxonomyData){

        $terms = !empty($taxonomyData['terms']) ? $taxonomyData['terms'] : array();
        $terms_relation = !empty($taxonomyData['terms_relation']) ? $taxonomyData['terms_relation'] : 'OR';
        $checked = !empty($taxonomyData['checked']) ? $taxonomyData['checked'] : '';

        if(!empty($terms) && !empty($checked)){
            $tax_query[] = array(
                'taxonomy' => $taxonomy,
                'field'    => 'term_id',
                'terms'    => $terms,
                'operator'    => $terms_relation,
            );
        }
    }


    $tax_query_relation = array( 'relation' => $categories_relation );
    $tax_query = array_merge($tax_query_relation, $tax_query );


    /* ################################ Keyword query ######################################*/

    $keyword = isset($_GET['keyword']) ? sanitize_text_field($_GET['keyword']) : $keyword;


    /* ################################ Single pages ######################################*/


    if(is_singular()):
        $current_post_id = get_the_ID();
        $query_args['post__not_in'] = array($current_post_id);
    endif;




    if ( get_query_var('paged') ) {
        $paged = get_query_var('paged');
    }elseif ( get_query_var('page') ) {
        $paged = get_query_var('page');
    }else {
        $paged = 1;
    }

    if($ignore_paged == 'yes'){
        $paged = 1;
    }



    if(!empty($post_types))
        $query_args['post_type'] = $post_types;

    if(!empty($post_status))
        $query_args['post_status'] = $post_status;

    if(!empty($keyword))
        $query_args['s'] = $keyword;


    if(!empty($exclude_post_id))
        $query_args['post__not_in'] = $exclude_post_id;

    if(!empty($include_post_id))
        $query_args['post__in'] = $include_post_id;


    if(!empty($query_order))
        $query_args['order'] = $query_order;

    if(!empty($query_orderby))
        $query_args['orderby'] = $query_orderby;

    if(!empty($query_orderby_meta_key))
        $query_args['meta_key'] = $query_orderby_meta_key;

    if(!empty($posts_per_page))
        $query_args['posts_per_page'] = (int)$posts_per_page;

    if(!empty($paged))
        $query_args['paged'] = $paged;

    if(!empty($offset))
        $query_args['offset'] = $offset + ( ($paged-1) * $posts_per_page );


    if(!empty($tax_query))
        $query_args['tax_query'] = $tax_query;



    $query_args = apply_filters('post_grid_filter_query_args', $query_args, $grid_id);
    $query_args = apply_filters('post_grid_query_args', $query_args, $args);


    //echo '<pre>'.var_export($query_args, true).'</pre>';

    $post_grid_wp_query = new WP_Query($query_args);

    $wp_query = $post_grid_wp_query;


    //echo '<pre>'.var_export($post_grid_wp_query, true).'</pre>';

    $loop_count = 0;

    if ( $post_grid_wp_query->have_posts() ) :

        do_action('post_grid_loop_top', $args);

        ?>
        <div class="<?php echo apply_filters('post_grid_grid_items_class','grid-items', $args); ?>">
            <?php
            do_action('post_grid_before_loop', $args);

            while ( $post_grid_wp_query->have_posts() ) : $post_grid_wp_query->the_post();
                $post_id = get_the_ID();
                $args['post_id'] = $post_id;
                $args['loop_count'] = $loop_count;

                //echo '####'.$loop_count;

                do_action('post_grid_loop', $args);

                $loop_count++;
            endwhile;

            do_action('post_grid_after_loop', $args);

            ?>
        </div>
        <?php
        do_action('post_grid_loop_bottom', $args, $post_grid_wp_query);

        wp_reset_query();
        wp_reset_postdata();

    else:
        ?>
        <div class="no-post-found">
            <?php
            do_action('post_grid_loop_no_post', $args);
            ?>
        </div>
    <?php
    endif;

}

add_action('post_grid_loop_no_post', 'post_grid_loop_no_post', 10);

function post_grid_loop_no_post($args){

    $post_grid_options = $args['options'];

    $no_post_text = !empty($post_grid_options['no_post_text']) ? $post_grid_options['no_post_text'] : __('No post found','post-grid');

    ?>
    <div class="no-post-found">
        <?php echo apply_filters('post_grid_no_post_text', $no_post_text); ?>
    </div>
    <?php

}



add_action('post_grid_loop', 'post_grid_loop', 10);

function post_grid_loop($args){

    $post_id = $args['post_id'] ;
    $loop_count = $args['loop_count'] ;
    $post_grid_options = $args['options'];


    $enable_multi_skin = isset($post_grid_options['enable_multi_skin']) ? $post_grid_options['enable_multi_skin'] : 'no';
    $skin = isset($post_grid_options['skin']) ? $post_grid_options['skin'] : 'flat';
    $layout_id = isset($post_grid_options['layout_id']) ? $post_grid_options['layout_id'] : '';


    if($loop_count % 2 == 0){
        $odd_even_class = 'even';
    }else{
        $odd_even_class = 'odd';
    }

    $odd_even_class = $odd_even_class.' '.$loop_count;


    $post_options = get_post_meta( $post_id, 'post_grid_post_settings', true );

    if($enable_multi_skin=='yes'){

        $skin = !empty($post_options['post_skin']) ? $post_options['post_skin'] : $skin;

    }

    $item_css_class = array();

    $item_css_class['item'] = 'item';
    $item_css_class['item_id'] = 'item-'.$post_id;

    $item_css_class['skin'] = 'skin '.$skin;
    $item_css_class['odd_even'] = $odd_even_class;




    $item_css_class = apply_filters('post_grid_item_classes', $item_css_class, $args);
    $item_css_class = implode(' ', $item_css_class);

    ?>

    <div class="<?php echo $item_css_class; ?> ">
        <?php
        do_action('post_grid_item_top', $args);
        ?>
        <div class="layer-wrapper layout-<?php echo $layout_id; ?>">
            <?php

            $layout_args['layout_id'] = !empty($layout_id) ? $layout_id  : $skin;
            $layout_args['post_id'] = $post_id;
            $layout_args['options'] = $post_grid_options;

            //echo $odd_even_class;
            do_action('post_grid_item_layout', $layout_args);

            ?>
        </div>
    </div>
    <?php
}





add_action('post_grid_item_layout', 'post_grid_item_layout_media', 10);

function post_grid_item_layout_media($args){

    $post_id = $args['post_id'] ;
    $post_grid_options = $args['options'];

    $layout_id = isset($post_grid_options['layout_id']) ? $post_grid_options['layout_id'] : '';

    if(!empty($layout_id)) return;


    $media_source = !empty($post_grid_options['media_source']) ? $post_grid_options['media_source'] : array();
    $featured_img_size = !empty($post_grid_options['featured_img_size']) ? $post_grid_options['featured_img_size'] : 'full';
    $thumb_linked = !empty($post_grid_options['thumb_linked']) ? $post_grid_options['thumb_linked'] : 'yes';

    wp_enqueue_style( 'post-grid-skin' );

    $html_media = '';

    $is_image = false;
    foreach($media_source as $source_info){

        $media = post_grid_get_media($post_id, $source_info['id'], $featured_img_size, $thumb_linked);

        if ( $is_image ) continue;

        if(!empty($source_info['checked'])){
            if(!empty($media)){

                $html_media = post_grid_get_media($post_id, $source_info['id'], $featured_img_size, $thumb_linked);
                $is_image = true;
            }
            else{
                $html_media = '';
            }
        }
    }



    $html_media = apply_filters('post_grid_filter_html_media', $html_media);

    //echo get_the_title($post_id);

    ?>
    <div class="layer-media"><?php echo $html_media; ?></div>
    <?php

}




add_action('post_grid_item_layout', 'post_grid_item_layout_content', 20);

function post_grid_item_layout_content($args){

    $post_id = $args['post_id'];
    $post_grid_options = $args['options'];
    $skin = $args['layout_id'];

    $layout_id = isset($post_grid_options['layout_id']) ? $post_grid_options['layout_id'] : '';

    if(!empty($layout_id)) return;

    $post_grid_layout_content = get_option( 'post_grid_layout_content' );
    $class_post_grid_functions = new class_post_grid_functions();

    $layout_content = isset($post_grid_options['layout']['content']) ? $post_grid_options['layout']['content'] : 'flat';


    if(empty($post_grid_layout_content)){
        $layout = $class_post_grid_functions->layout_content($layout_content);
    }
    else{

        if(!empty($post_grid_layout_content[$layout_content])){
            $layout = $post_grid_layout_content[$layout_content];

        }
        else{
            $layout = array();
        }
    }

    ?>
    <div class="layer-content">
        <?php
        foreach($layout as $elementIndex=>$element){
            $element_id = isset($element['key']) ? $element['key'] : '';

            if(empty($element_id)) return;

            //var_dump($element_id);
            $element_args['element'] = $element;
            $element_args['index'] = $elementIndex;

            $element_args['post_id'] = $post_id;
            $element_args['layout_id'] = $post_id;

            do_action('post_grid_layout_element_'.$element_id, $element_args);

        }

        ?>
    </div>
    <?php





}

add_action('post_grid_container', 'post_grid_container_old_layout_css', 20);

function post_grid_container_old_layout_css($args){

    $post_grid_options = $args['options'];

    $layout_id = isset($post_grid_options['layout_id']) ? $post_grid_options['layout_id'] : '';

    if(!empty($layout_id)) return;


    $grid_id = $args['grid_id'];
    $post_grid_options = $args['options'];
    $layout_content = isset($post_grid_options['layout']['content']) ? $post_grid_options['layout']['content'] : 'flat';

    $class_post_grid_functions = new class_post_grid_functions();

    $post_grid_layout_content = get_option( 'post_grid_layout_content' );

    if(empty($post_grid_layout_content)){
        $layout = $class_post_grid_functions->layout_content($layout_content);
    }else{
        if(!empty($post_grid_layout_content[$layout_content])){
            $layout = $post_grid_layout_content[$layout_content];
        }else{
            $layout = array();
        }
    }


    //var_dump($layout);

    ?>
    <style type="text/css">
        <?php
        foreach($layout as $item_id=>$item_info){
            $item_css = $item_info['css'];
            $item_key = $item_info['key'];

            if($item_key=='categories' || $item_key=='tags'){
                ?>
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?> a{<?php echo $item_css; ?>}
                <?php
            }elseif($item_key=='down_arrow'){
                $arrow_size = $item_info['arrow_size'];
                $arrow_bg_color = $item_info['arrow_bg_color'];
                ?>
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?>{<?php echo $item_css; ?>}
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?>{
                  border-left: <?php echo $arrow_size; ?> solid rgba(0, 0, 0, 0);
                  border-right: <?php echo $arrow_size; ?> solid rgba(0, 0, 0, 0);
                  border-top: <?php echo $arrow_size; ?> solid  <?php echo $arrow_bg_color; ?>;
                  height: 0;
                  width: 0;
                }
                <?php

            }elseif($item_key=='up_arrow'){
                $arrow_size = $item_info['arrow_size'];
                $arrow_bg_color = $item_info['arrow_bg_color'];
                ?>
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?>{<?php echo $item_css; ?>}
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?>{
                  border-bottom: <?php echo $arrow_size; ?> solid <?php echo $arrow_bg_color; ?>;
                  border-left: <?php echo $arrow_size; ?> solid transparent;
                  border-right: <?php echo $arrow_size; ?> solid transparent;
                  height: 0;
                  width: 0;
                }
                <?php
            }else{
                ?>
                #post-grid-<?php echo $grid_id; ?> .element_<?php echo $item_id; ?>{<?php echo $item_css; ?>}
                <?php
            }
        }
	foreach($layout as $item_id=>$item_info){
		$item_css_hover = $item_info['css_hover'];
		echo '#post-grid-'.$grid_id.' .element_'.$item_id.':hover{'.$item_css_hover.'}';
		}
    ?>
    </style>
    <?php

}

add_action('post_grid_item_layout', 'post_grid_item_layout_new', 30);

function post_grid_item_layout_new($args){

    $post_id = $args['post_id'];
    $post_grid_options = $args['options'];
    $layout_id = $args['layout_id'];

    if(empty($layout_id)) return;


    $layout_elements_data = get_post_meta( $layout_id, 'layout_elements_data', true );



    //echo '<pre>'.var_export($layout_elements_data, ture).'</pre>';


    if(!empty($layout_elements_data))
    foreach($layout_elements_data as $elementIndex=>$elementData){
        foreach($elementData as $elementId=>$element) {

            //var_dump($element);

            $element_args['element'] = $element;
            $element_args['index'] = $elementIndex;

            $element_args['post_id'] = $post_id;
            $element_args['layout_id'] = $layout_id;

            do_action('post_grid_layout_element_' . $elementId, $element_args);

        }

    }






}



add_action('post_grid_loop_bottom', 'post_grid_loop_bottom_pagination', 10, 2);

function post_grid_loop_bottom_pagination($args, $post_grid_wp_query){

    $post_grid_options = $args['options'];

    $pagination_type = isset($post_grid_options['nav_bottom']['pagination_type']) ? $post_grid_options['nav_bottom']['pagination_type'] : 'normal';

    if($pagination_type =='none') return;

    ?>
    <div class="pagination">
        <?php
        do_action('post_grid_pagination_'.$pagination_type, $args, $post_grid_wp_query);
        ?>
    </div>
    <?php

}


add_action('post_grid_pagination_normal', 'post_grid_pagination_normal', 10, 2);

function post_grid_pagination_normal($args, $post_grid_wp_query){


    $post_grid_options = $args['options'];
    $grid_id = $args['grid_id'];

    if ( get_query_var('paged') ) {
        $paged = get_query_var('paged');
    }elseif ( get_query_var('page') ) {
        $paged = get_query_var('page');
    }else {
        $paged = 1;
    }

    $max_num_pages = isset($post_grid_wp_query->max_num_pages) ? $post_grid_wp_query->max_num_pages : 0;

    $pagination_prev_text = !empty($post_grid_options['pagination']['prev_text']) ? $post_grid_options['pagination']['prev_text'] : __('« Previous', 'post-grid');
    $pagination_next_text = !empty($post_grid_options['pagination']['next_text']) ? $post_grid_options['pagination']['next_text'] : __('Next »', 'post-grid');
    $pagination_max_num_pages = !empty($post_grid_options['pagination']['max_num_pages']) ? $post_grid_options['pagination']['max_num_pages'] : $max_num_pages;

    $pagination_font_size = !empty($post_grid_options['pagination']['font_size']) ? $post_grid_options['pagination']['font_size'] : '17px';
    $pagination_font_color = !empty($post_grid_options['pagination']['font_color']) ? $post_grid_options['pagination']['font_color'] : '#646464';
    $pagination_bg_color = !empty($post_grid_options['pagination']['bg_color']) ? $post_grid_options['pagination']['bg_color'] : '#646464';
    $pagination_active_bg_color = !empty($post_grid_options['pagination']['active_bg_color']) ? $post_grid_options['pagination']['active_bg_color'] : '#4b4b4b';


    ?>
    <div class="paginate">
        <?php

        $big = 999999999; // need an unlikely integer

        echo paginate_links(
            array(
                'base' => str_replace( $big, '%#%', esc_url( get_pagenum_link( $big ) ) ),
                'format' => '?paged=%#%',
                'current' => max( 1, $paged ),
                'total' => $pagination_max_num_pages,
                'prev_text'          => $pagination_prev_text,
                'next_text'          => $pagination_next_text,
            )
        );

        ?>
    </div>
    <style type="text/css">
        #post-grid-<?php echo $grid_id; ?> .pagination .page-numbers{
            font-size:<?php echo $pagination_font_size; ?>;
            color:<?php echo $pagination_font_color; ?>;
            background:<?php echo $pagination_bg_color; ?>;
        }
        #post-grid-<?php echo $grid_id; ?> .pagination .page-numbers:hover,
        #post-grid-<?php echo $grid_id; ?> .pagination .page-numbers.current{
            background:<?php echo $pagination_active_bg_color; ?>;
        }
    </style>
    <?php

}



add_action('post_grid_container', 'post_grid_custom_css', 90);

function post_grid_custom_css($args){

    $post_grid_options = $args['options'];
    $grid_type = isset($post_grid_options['grid_type']) ? $post_grid_options['grid_type'] : 'grid';

    //var_dump($grid_type);

    //if($grid_type != 'grid' && $grid_type != 'filterable') return;

    $grid_id = $args['grid_id'];

    do_action('post_grid_view_type_css_'.$grid_type, $args);


}






add_action('post_grid_view_type_css_grid', 'post_grid_view_type_css_grid', 90);

function post_grid_view_type_css_grid($args){

    $post_grid_options = $args['options'];
    $grid_id = $args['grid_id'];

    $items_width_desktop = isset($post_grid_options['width']['desktop']) ? $post_grid_options['width']['desktop'] : '';
    $items_width_tablet = isset($post_grid_options['width']['tablet']) ? $post_grid_options['width']['tablet'] : '';
    $items_width_mobile = isset($post_grid_options['width']['mobile']) ? $post_grid_options['width']['mobile'] : '';

    $items_height_style = !empty($post_grid_options['item_height']['style']) ? $post_grid_options['item_height']['style'] : 'auto_height';
    $items_height_style_tablet = !empty($post_grid_options['item_height']['style_tablet']) ? $post_grid_options['item_height']['style_tablet'] : 'auto_height';
    $items_height_style_mobile = !empty($post_grid_options['item_height']['style_mobile']) ?$post_grid_options['item_height']['style_mobile'] : 'auto_height';

    $items_fixed_height = !empty($post_grid_options['item_height']['fixed_height']) ? $post_grid_options['item_height']['fixed_height'] : '220px';
    $items_fixed_height_tablet = !empty($post_grid_options['item_height']['fixed_height_tablet']) ? $post_grid_options['item_height']['fixed_height_tablet'] : '220px';
    $items_fixed_height_mobile = !empty($post_grid_options['item_height']['fixed_height_mobile']) ? $post_grid_options['item_height']['fixed_height_mobile'] : '220px';

    $items_margin = isset($post_grid_options['margin']) ? $post_grid_options['margin'] : '';
    $item_padding = isset($post_grid_options['item_padding']) ? $post_grid_options['item_padding'] : '';

    $items_media_height_style = !empty($post_grid_options['media_height']['style']) ? $post_grid_options['media_height']['style'] : 'auto_height';
    $items_media_fixed_height = !empty($post_grid_options['media_height']['fixed_height']) ? $post_grid_options['media_height']['fixed_height'] : '';

    $grid_layout_name = !empty($post_grid_options['grid_layout']['name']) ? $post_grid_options['grid_layout']['name'] : '';
    $grid_layout_col_multi = 3;

    if($items_height_style == 'auto_height'){
        $items_height = 'auto';
    }elseif($items_height_style == 'fixed_height'){
        $items_height = $items_fixed_height;
    }elseif($items_height_style == 'max_height'){
        $items_height = $items_fixed_height;
    }else{
        $items_height = '220px';
    }

    if($items_media_height_style == 'auto_height'){
        $items_media_height = 'auto';
    }elseif($items_media_height_style == 'fixed_height'){
        $items_media_height = $items_media_fixed_height;
    }elseif($items_media_height_style == 'max_height'){
        $items_media_height = $items_media_fixed_height;
    }else{
        $items_media_height = '220px';
    }

    $container_padding = isset($post_grid_options['container']['padding']) ? $post_grid_options['container']['padding'] : '';
    $container_bg_color = isset($post_grid_options['container']['bg_color']) ? $post_grid_options['container']['bg_color'] : '';
    $container_bg_image = isset($post_grid_options['container']['bg_image']) ? $post_grid_options['container']['bg_image'] : '';
    $items_wrapper_text_align = isset($post_grid_options['items_wrapper']['text_align']) ? $post_grid_options['items_wrapper']['text_align'] : 'center';


    $items_bg_color_type = isset($post_grid_options['items_bg_color_type']) ? $post_grid_options['items_bg_color_type'] : '';
    $items_bg_color = isset($post_grid_options['items_bg_color']) ? $post_grid_options['items_bg_color'] : '#fff';


    ?>
    <style type="text/css">
        #post-grid-<?php echo $grid_id; ?> {
        <?php if(!empty($container_padding)): ?>
            padding:<?php echo $container_padding; ?>;
        <?php endif; ?>
        <?php if(!empty($container_bg_color)): ?>
            background-color: <?php echo $container_bg_color; ?>;
        <?php endif; ?>
        <?php if(!empty($container_bg_image)): ?>
            background-image: url(<?php echo $container_bg_image; ?>);
        <?php endif; ?>
        <?php if(!empty($container_text_align)): ?>
            text-align: <?php echo $container_text_align; ?>;
        <?php endif; ?>
        }
        #post-grid-<?php echo $grid_id; ?> .grid-items{
        <?php if(!empty($items_wrapper_text_align)): ?>
            text-align: <?php echo $items_wrapper_text_align; ?>;
        <?php endif; ?>
        }
        #post-grid-<?php echo $grid_id; ?> .item{
        <?php if(!empty($items_margin)): ?>
            margin:<?php echo $items_margin; ?>;
        <?php endif; ?>
        <?php if(!empty($item_padding)): ?>
            padding:<?php echo $item_padding; ?>;
        <?php endif; ?>
        <?php if($items_bg_color_type=='fixed'): ?>
            background:<?php echo $items_bg_color; ?>;
        <?php endif; ?>
        }
        #post-grid-<?php echo $grid_id; ?>  .item .layer-media{
            <?php
            if($items_media_height_style == 'fixed_height' || $items_media_height_style == 'auto_height'){
                echo 'height:'.$items_media_height.';';
            }elseif($items_media_height_style=='max_height'){
                echo 'max-height:'.$items_media_height.';';
            }else{
                echo 'height:'.$items_media_height.';';
            }
            ?>
        }
        @media only screen and ( min-width: 0px ) and ( max-width: 767px ) {
            #post-grid-<?php echo $grid_id; ?> .item{
            <?php if(!empty($items_width_mobile)): ?>
                width:<?php echo $items_width_mobile; ?>;
            <?php endif; ?>
            <?php
            if($items_height_style == 'fixed_height'){
                echo 'height:'.$items_height.';';
            }elseif($items_height_style=='max_height'){
                echo 'max-height:'.$items_height.';';
            }elseif($items_height_style=='auto_height'){
                echo 'height:auto;';
            }else{
                echo 'height:auto;';
            }
            ?>
            }
        }
        @media only screen and ( min-width: 768px ) and ( max-width: 1023px ) {
            #post-grid-<?php echo $grid_id; ?> .item{
            <?php if(!empty($items_width_tablet)): ?>
                width:<?php echo $items_width_tablet; ?>;
            <?php endif; ?>
            <?php
            if($items_height_style_tablet == 'fixed_height'){
                echo 'height:'.$items_fixed_height_tablet.';';
            }elseif($items_height_style_tablet=='max_height'){
                echo 'max-height:'.$items_fixed_height_tablet.';';
            }elseif($items_height_style_tablet=='auto_height'){
                echo 'max-height:auto;';
            }else{
                echo 'height:auto;';
            }
            ?>
            }
        }
        @media only screen and (min-width: 1024px ){
            #post-grid-<?php echo $grid_id; ?> .item{
            <?php if(!empty($items_width_desktop)): ?>
                width:<?php echo $items_width_desktop; ?>;
            <?php endif; ?>
            <?php
            if($items_height_style == 'fixed_height'){
                echo 'height:'.$items_height.';';
            }elseif($items_height_style=='max_height'){
                echo 'max-height:'.$items_height.';';
            }elseif($items_height_style=='auto_height'){
                echo 'height:auto;';
            }else{
                echo 'height:auto;';
            }
            ?>
            }
        }

        <?php


	if($grid_layout_name=='layout_grid'){

	}
	elseif($grid_layout_name=='layout_1_N'){

		$width = intval((int)$items_width_desktop*$grid_layout_col_multi)+intval((int)$items_margin*2*($grid_layout_col_multi-1));

		?>
        @media only screen and (min-width: 1024px ) {
            #post-grid-<?php echo $grid_id; ?> .item:first-child{
                width: <?php echo $width; ?>px;
            }
        }
		<?php
	}

	elseif($grid_layout_name=='layout_N_1'){

		$width = intval((int)$items_width_desktop*$grid_layout_col_multi)+intval((int)$items_margin*2*($grid_layout_col_multi-1));


		?>
        @media only screen and (min-width: 1024px ) {
            #post-grid-<?php echo $grid_id; ?> .item:last-child{
                width: <?php echo $width; ?>px;
             }
        }
		<?php
		}
	elseif($grid_layout_name=='layout_3'){
		$width = intval($items_width_desktop)+intval($items_margin);
		?>
        @media only screen and (min-width: 1024px ) {
            #post-grid-<?php echo $grid_id; ?> .item:first-child{
                float: left;
             }
            #post-grid-<?php echo $grid_id; ?> .item{
                 float: right;
             }
        }
		<?php
	}
	elseif($grid_layout_name=='layout_L_R'){
	    ?>
        @media only screen and (min-width: 1024px ) {
            #post-grid-<?php echo $grid_id; ?> .item.odd .layer-media{
                  float: right;
             }
        }
	    <?php
	}
	elseif($grid_layout_name=='layout_1_N_1'){
		$width = intval((int)$items_width_desktop*$grid_layout_col_multi)+intval((int)$items_margin*2*($grid_layout_col_multi-1));
		?>
        @media only screen and (min-width: 1024px ) {
            #post-grid-<?php echo $grid_id; ?> .item:nth-child(1),
            #post-grid-<?php echo $grid_id; ?> .item:nth-child(<?php echo $grid_layout_col_multi+2; ?>) {
                  width: <?php echo $width; ?>px;
            }
        }
		<?php
	}
	?>


    </style>
    <?php

}



add_action('post_grid_container', 'post_grid_main_scripts', 80);

function post_grid_main_scripts($args){
    $post_grid_options = $args['options'];
    $grid_id = $args['grid_id'];
    $grid_type = isset($post_grid_options['grid_type']) ? $post_grid_options['grid_type'] : 'grid';


    $layout_id = isset($post_grid_options['layout_id']) ? $post_grid_options['layout_id'] : '';

    $custom_js = isset($post_grid_options['custom_js']) ? $post_grid_options['custom_js'] : '';
    $custom_css = isset($post_grid_options['custom_css']) ? $post_grid_options['custom_css'] : '';
    $load_fontawesome = !empty($post_grid_options['load_fontawesome']) ? $post_grid_options['load_fontawesome'] : 'no';
    $masonry_enable = !empty($post_grid_options['masonry_enable']) ? $post_grid_options['masonry_enable'] : 'no';


    $post_grid_settings = get_option('post_grid_settings');
    $font_aw_version = isset($post_grid_settings['font_aw_version']) ? $post_grid_settings['font_aw_version'] : '';






    wp_enqueue_script(   'post_grid_scripts');
    wp_localize_script('post_grid_scripts', 'post_grid_ajax', array('post_grid_ajaxurl' => admin_url('admin-ajax.php')));



    if($masonry_enable == 'yes'){
        wp_enqueue_script( 'masonry' );
        wp_enqueue_script( 'imagesloaded' );
    }

    //var_dump($load_fontawesome);

    if($load_fontawesome == 'yes'){
        if($font_aw_version == 'v_5'){
            wp_enqueue_style('font-awesome-5');
        }elseif ($font_aw_version =='v_4'){
            wp_enqueue_style('font-awesome-4');
        }

    }

    $layout_custom_scripts = get_post_meta($layout_id,'custom_scripts', true);
    $layout_custom_css = isset($layout_custom_scripts['custom_css']) ? $layout_custom_scripts['custom_css'] : '';

    $layout_elements_data = get_post_meta( $layout_id, 'layout_elements_data', true );



    if(!empty($layout_elements_data))
        foreach($layout_elements_data as $elementIndex=>$elementData){
            foreach($elementData as $elementId=>$element) {

                //var_dump($element);

                $element_args['element'] = $element;
                $element_args['index'] = $elementIndex;

                //$element_args['post_id'] = $post_id;
                $element_args['layout_id'] = $layout_id;

                //ob_start();
                do_action('post_grid_layout_element_css_' . $elementId, $element_args);
                //$element_css .= ob_get_clean();

            }

        }



    ?>

    <?php //echo $element_css; ?>
    <?php

    ?>
    <?php if(!empty($custom_css)): ?>
        <style type="text/css">
            <?php
            echo $custom_css;
            ?>
        </style>
    <?php endif; ?>

    <?php if(!empty($layout_custom_css)): ?>
        <style type="text/css">
            <?php
            echo str_replace('__ID__', 'layout-'.$layout_id, $layout_custom_css);
            ?>
        </style>
    <?php endif; ?>
    <script>
        <?php
        if(!empty($custom_js)): ?>
            <?php echo $custom_js; ?>
        <?php
        endif;

        $masonry_load = apply_filters('post_grid_masonry_load', true, $args);

        if($masonry_enable=='yes' && $masonry_load == true ):
            ?>
            jQuery('#post-grid-lazy-<?php echo $grid_id; ?>').ready(function($){
                var $container = $('#post-grid-<?php echo $grid_id; ?> .grid-items');
                $container.masonry({
                    itemSelector: '.item',
                    columnWidth: '.item', //as you wish , you can use numeric
                    isAnimated: true,
                    isFitWidth: true,
                    horizontalOrder: true,
                });
                $container.imagesLoaded().done( function() {
                    $container.masonry('layout');
                });
            })
        <?php endif; ?>
    </script>
    <?php

}







add_action('post_grid_container', 'post_grid_main_convert_layout', 90);

function post_grid_main_convert_layout($args){



    $post_grid_layout_convert = isset($_GET['post_grid_layout_convert']) ? sanitize_text_field($_GET['post_grid_layout_convert']) : '';
    $_wpnonce = isset($_GET['_wpnonce']) ? sanitize_text_field($_GET['_wpnonce']) : '';

    if(empty($post_grid_layout_convert)) return;


    $layout_converted = false;

    if(wp_verify_nonce($_wpnonce,'post_grid_layout_convert')){

        $layout_converted = true;
    }else{
        $options = $args['options'];
        $grid_id = (int) $args['grid_id'];

        $layout_id = isset($options['layout_id']) ? $options['layout_id'] : '';

        if(!empty($layout_id)) return;
    }



    if(!$layout_converted) return;


    $content_layout = isset($options['layout']['content']) ? $options['layout']['content'] : '';
    $layout_skin = isset($options['skin']) ? $options['skin'] : '';
    $media_source = isset($options['media_source']) ? $options['media_source'] : '';
    $media_height = isset($options['media_height']) ? $options['media_height'] : '';

    $media_height_style = isset($media_height['style']) ? $media_height['style'] : '';
    $media_fixed_height = isset($media_height['fixed_height']) ? $media_height['fixed_height'] : '';


    //var_dump($options);

    $featured_img_size = !empty($options['featured_img_size']) ? $options['featured_img_size'] : 'full';

    $thumb_linked = isset($options['thumb_linked']) ? $options['thumb_linked'] : 'no';
    //var_dump($options);

    $thumb_linked = ($thumb_linked == 'yes') ? 'post_link' : 'none';


    //var_dump($thumb_linked);

    if(empty($content_layout)) return;
    if(empty($layout_skin)) return;

    $post_grid_layout_content = get_option('post_grid_layout_content');


    $content_layout_data = isset($post_grid_layout_content[$content_layout]) ? $post_grid_layout_content[$content_layout] : '';

    if(empty($content_layout_data)) return;



    $layout_elements_data = array();

    $layout_elements_data[0]['wrapper_start']['wrapper_id'] = '';
    $layout_elements_data[0]['wrapper_start']['wrapper_class'] = 'layer-media';
    $layout_elements_data[0]['wrapper_start']['css_idle'] = '';


    $layout_elements_data[1]['media']['media_height']['large_type'] = $media_height_style;
    $layout_elements_data[1]['media']['media_height']['large'] = $media_fixed_height;
    $layout_elements_data[1]['media']['media_height']['medium_type'] = $media_height_style;
    $layout_elements_data[1]['media']['media_height']['medium'] = $media_fixed_height;
    $layout_elements_data[1]['media']['media_height']['small_type'] = $media_height_style;
    $layout_elements_data[1]['media']['media_height']['small'] = $media_fixed_height;

    foreach ( $media_source as $source ){
        $source_id = $source['id'];
        $source_checked = isset( $source['checked']) ? 'yes' : 'no';

        if($source_checked != 'yes') continue;

        $layout_elements_data[1]['media']['media_source'][$source_id]['enable'] = $source_checked;

        if($source_id == 'featured_image' || $source_id == 'first_image' || $source_id == 'empty_thumb'){
            $layout_elements_data[1]['media']['media_source'][$source_id]['link_to'] = $thumb_linked;
        }




    }



    $layout_elements_data[1]['media']['margin'] = '';
    $layout_elements_data[1]['media']['padding'] = '';



    $layout_elements_data[2]['wrapper_end']['wrapper_id'] = '';

    $layout_elements_data[3]['wrapper_start']['wrapper_id'] = '';
    $layout_elements_data[3]['wrapper_start']['wrapper_class'] = 'layer-content';

    $item_count = 4;

    foreach ($content_layout_data as $index => $item){

        //echo '<pre>'.var_export($item, true).'</pre>';

        $custom_class = isset($item['custom_class']) ? $item['custom_class'] : '';
        $char_limit = isset($item['char_limit']) ? $item['char_limit'] : '';
        $key = isset($item['key']) ? $item['key'] : '';
        $css = isset($item['css']) ? $item['css'] : '';
        $css_hover = isset($item['css_hover']) ? $item['css_hover'] : '';
        $read_more_text = isset($item['read_more_text']) ? $item['read_more_text'] : '';
        $link_target = isset($item['link_target']) ? $item['link_target'] : '';
        $five_star_count = isset($item['five_star_count']) ? $item['five_star_count'] : '';


        $layout_elements_data[$item_count][$key]['custom_class'] = $custom_class;
        $layout_elements_data[$item_count][$key]['css'] = $css;
        $layout_elements_data[$item_count][$key]['css_hover'] = $css_hover;

        if($key == 'title' || $key == 'title_link' || $key == 'excerpt' || $key == 'excerpt_read_more'){
            $layout_elements_data[$item_count][$key]['char_limit'] = $char_limit;
            $layout_elements_data[$item_count][$key]['link_to'] = 'post_link';
        }

        if($key == 'read_more' || $key == 'excerpt_read_more'){
            $layout_elements_data[$item_count][$key]['read_more_text'] = $read_more_text;

        }
        if($key == 'read_more' || $key == 'excerpt_read_more' || $key == 'title_link'){
            $layout_elements_data[$item_count][$key]['link_target'] = $link_target;
            $layout_elements_data[$item_count][$key]['link_to'] = 'post_link';

        }


        if($key == 'five_star'){
            $layout_elements_data[$item_count][$key]['five_star_count'] = $five_star_count;

        }



        $item_count++;

    }

    $layout_elements_data[$item_count]['wrapper_end']['wrapper_id'] = '';


    //echo '<pre>'.var_export($layout_elements_data, true).'</pre>';

    $post_grid_title = get_the_title($grid_id);

    $post_args = array(
        'post_title' => $post_grid_title.' - '.$layout_skin .' - '. $content_layout,
        'post_type' => 'post_grid_layout',
        'post_status' => 'publish',
        'post_author' => 1,

    );

    $new_layout_id = wp_insert_post($post_args);

    $custom_scripts['custom_css'] = post_grid_layout_css($layout_skin);
    $custom_scripts['custom_js'] = '';
    $layout_options['layout_preview_img'] = '';


    update_post_meta($new_layout_id,'layout_elements_data', $layout_elements_data);
    update_post_meta($new_layout_id,'custom_scripts', $custom_scripts);
    update_post_meta($new_layout_id,'layout_options', $layout_options);


    //echo '<pre>'.var_export($options, true).'</pre>';

    $options['layout_id'] = $new_layout_id;

    update_post_meta($grid_id,'post_grid_meta_options', $options);

    if($layout_converted){

        ?>
        <p>Layout converted successfully, please go <a href="<?php echo get_edit_post_link($new_layout_id); ?>">#<?php echo $new_layout_id; ?></a> this link to edit layout </p>
        <p>Please report issue if you found any problem, <a href="https://www.pickplugins.com/forum/">create support ticket</a> </p>
        <?php
    }


}