Current File : /home/natitnen/hintact.com/wp-content/plugins/ave-core/shortcodes/blog/view.php |
<?php
$style = $atts['style'];
$filter_id = $atts['filter_id'];
$section_id = uniqid( 'heading-id' );
$ajax_trigger = $atts['ajax_trigger'];
$carousel_heading = $unique_id = '';
if( !empty( $atts['carousel_heading'] ) ) {
$carousel_heading = '<header class="fancy-title" id="' . $section_id . '"><h2 class="font-weight-bold">'. esc_html( $atts['carousel_heading'] ) . '</h2></header>';
}
$ajax_wrapper = '';
if( !empty( $atts['unique_id'] ) ) {
$unique_id = $atts['unique_id'];
$ajax_wrapper = '.' . $unique_id;
}
// check
$located = locate_template( "templates/blog/tmpl-$style.php" );
if ( ! file_exists( $located ) ) {
return;
}
$masonry_sizes = array(
'shortest' => 'h-300',
'short' => 'h-300',
'stall' => 'h-300',
'taller' => 'h-300',
);
$i = 0;
// Enqueue Conditional Script
$this->scripts();
// The CSS
$this->generate_css();
echo '<div data-filter-id="' . $filter_id . '" class="liquid-blog-posts ' . $this->get_id() . ' ' . $unique_id . ' " data-post-per-page="' . $atts['posts_per_page'] . '">';
// Include filter
if( 'yes' === $atts['enable_filter'] ) {
$filter_located = locate_template( 'templates/blog/partial-filters.php' );
include $filter_located;
}
// Build Query
$GLOBALS['wp_query'] = new WP_Query( $this->build_query() );
$before = $after = '';
if( 'timeline' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-timeline row" data-liquid-masonry="true">';
$before = '<div class="' . $this->get_grid_class() . ' masonry-item">';
$after = '</div>';
}
elseif( 'classic-full' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-classic row">';
$before = '<div class="col-md-12">';
$after = '</div>';
}
elseif( 'candy' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-candy row">';
$before = '<div class="col-md-5 masonry-item">';
$after = '</div>';
}
elseif( 'featured-2' === $style ) {
echo '<div class="liquid-blog-grid row" data-liquid-masonry="true">';
$before = '<div class="' . $this->get_grid_class() . ' masonry-item">';
$after = '</div>';
}
elseif( 'category' === $style || 'category-compact' === $style || 'category-bordered' === $style ) {
echo '<div class="liquid-blog-grid row" data-liquid-masonry="true">';
$before = '<div class="' . $this->get_grid_class() . ' masonry-item">';
$after = '</div>';
}
elseif( 'split' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-split row" data-liquid-masonry="true" data-masonry-options=\'{ "stagger": 50, "hiddenStyle": { "transform": "translateY(100px)", "opacity": 0 }, "visibleStyle": { "transform": "translateY(0)", "opacity": 1 }, "filtersID": "#' . $filter_id . '" }\'>';
$before = '<div class="col-sm-12 masonry-item ">';
$after = '</div>';
}
elseif( 'masonry' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-grid liquid-blog-style-masonry liquid-blog-grid-columns-4" data-liquid-masonry="true">';
$before = '<div class="' . $this->get_grid_class() . ' masonry-item">';
$after = '</div>';
}
elseif( 'minimal' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-square row mx-0" data-liquid-masonry="true">';
$before = '<div class="col-md-4 masonry-item px-0">';
$after = '</div>';
}
elseif( 'square' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-square row" data-liquid-masonry="true">';
$before = '<div class="col-md-4 masonry-item">';
$after = '</div>';
}
elseif( 'square-2' === $style ) {
echo '<div class="liquid-blog-grid row" data-liquid-masonry="true">';
$before = '<div class="masonry-item col-md-4">';
$after = '</div>';
}
elseif( 'featured-fullwidth' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-fullwidth row">';
$before = '<div class="col-xs-12">';
$after = '</div>';
}
elseif( 'carousel' === $style ) {
echo '<div class="liquid-blog-grid liquid-blog-style-carousel"><div class="carousel-container carousel-nav-circle carousel-nav-bordered carousel-nav-sm">
' . $carousel_heading . '
<div class="carousel-items row" data-lqd-flickity=\'{ "equalHeightCells": true, "fullwidthSide": true, "prevNextButtons": true, "navArrow": 6, "buttonsAppendTo": "#' . $section_id . '" }\'>';
$before = '<div class="carousel-item col-lg-8 col-md-6 col-sm-12">';
$after = '</div>';
}
elseif( 'carousel-filter' === $style ) {
echo '<div class="carousel-container carousel-nav-floated carousel-nav-vertical carousel-nav-left carousel-nav-circle carousel-nav-solid carousel-nav-lg carousel-nav-shadowed" data-filterable-carousel="true">
<div class="carousel-items row" data-lqd-flickity=\'{ "filters": "#' . $filter_id . '", "prevNextButtons": true, "navArrow": 1, "fullwidthSide": true, "navOffsets": { "nav": {"left": -10, "top": 200} } }\'>';
$before = '<div class="carousel-item col-lg-8 col-md-6 col-sm-12">';
$after = '</div>';
}
elseif( 'metro' === $style || 'metro-alt' === $style ) {
echo '<div class="liquid-blog-grid row">';
echo '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" class="liquid-lp-gradient" width="0" height="0">
<defs>
<linearGradient id="liquid-lp-gradient" x1="0%" y1="0%" x2="100%" y2="0%">
<stop offset="0%" />
<stop offset="100%" />
</linearGradient>
</defs>
</svg>';
$before = '<div class="col-md-10 col-md-offset-1 col-lg-6 col-lg-offset-0 col-xs-12">';
$after = '</div>';
}
else {
echo '<div class="liquid-blog-grid row">';
$before = '<div class="' . $this->get_grid_class() . '">';
$after = '</div>';
}
while( have_posts() ): the_post();
$post_classes = array( 'liquid-lp' );
if( 'text-date' === $style ) {
$post_classes[] = 'liquid-lp-time-aside';
}
elseif( 'grid' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-grid liquid-blog-scheme-dark';
}
elseif( 'metro' === $style || 'metro-alt' === $style ) {
$post_classes[] = 'liquid-lp-sp-block';
if( 'metro-alt' === $style ) {
$post_classes[] = 'liquid-lp-sp-block-alt';
}
$featured = get_post_meta( get_the_ID(), 'post-metro-featured', true );
if( 'featured' === $featured ) {
$post_classes[] = 'liquid-lp-featured';
}
elseif( 'instagram' === $featured ) {
$post_classes[] = 'liquid-lp-sp-instagram';
}
else{
$i++;
if( $i % 3 == 0 || $i % 4 == 0 ) {
$post_classes[] = 'liquid-lp-reverse';
}
if( $i % 4 == 0 ) {
$i = 0;
}
}
}
elseif( 'candy' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-candy liquid-blog-scheme-dark';
$i++;
if( $i % 2 == 0 ) {
$before = '<div class="col-sm-6 col-md-5 col-md-offset-2 masonry-item">';
}
else {
$before = '<div class="col-sm-6 col-md-5 masonry-item">';
}
}
elseif( 'featured-2' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-contents-inside contents-bottom liquid-blog-item-featured liquid-blog-scheme-light liquid-blog-scheme-light-alt overlay-bg-none h-pt-55';
}
elseif( 'category' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-cat liquid-blog-scheme-dark liquid-blog-scheme-dark-alt';
}
elseif( 'category-compact' === $style ) {
$post_classes[] = 'liquid-lp liquid-blog-item liquid-blog-item-cat-compact liquid-blog-scheme-dark liquid-blog-scheme-dark-alt';
}
elseif( 'category-bordered' === $style ) {
$post_classes[] = 'liquid-lp liquid-blog-item liquid-blog-item-cat-border liquid-blog-scheme-dark liquid-blog-scheme-dark-alt';
}
elseif( 'small' === $style ) {
$post_classes[] = 'liquid-lp-small-thumb d-flex flex-row flex-wrap align-items-start mb-4';
}
elseif( 'square' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-contents-inside liquid-blog-item-square liquid-blog-scheme-light round h-450';
$i++;
if( 1 === $i ) {
$before = '<div class="col-md-6 masonry-item">';
}
else {
$before = '<div class="col-md-3 col-sm-6 masonry-item">';
}
}
elseif( 'square-2' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-contents-inside liquid-blog-item-rect liquid-blog-scheme-light h-pt-60';
$i++;
if( 1 === $i ) {
$before = '<div class="masonry-item col-md-8">';
}
else {
$before = '<div class="masonry-item col-md-4">';
}
}
elseif( 'timeline' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-timeline liquid-blog-scheme-dark liquid-blog-scheme-dark-alt';
}
elseif( 'masonry' === $style ) {
$post_size_meta = get_post_meta( get_the_ID(), 'liquid-post-height', true );
$post_size = isset( $masonry_sizes[ $post_size_meta ] ) ? $masonry_sizes[ $post_size_meta ] : 'h-300';
$post_classes[] = 'liquid-blog-item liquid-blog-contents-inside liquid-blog-item-masonry liquid-blog-scheme-light liquid-blog-cloned-title ' . $post_size;
}
elseif( 'minimal' === $style ) {
$post_classes[] = 'liquid-lp liquid-blog-item liquid-blog-item-gray liquid-blog-scheme-dark';
}
elseif( 'featured-fullwidth' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-contents-inside contents-middle liquid-blog-item-fullwidth liquid-blog-scheme-light liquid-blog-scheme-light-alt h-100';
}
elseif( 'carousel' === $style ) {
$post_width_meta = get_post_meta( get_the_ID(), 'post-carousel-width', true );
$post_width = !empty( $post_width_meta ) ? $post_width_meta : '8';
$before = '<div class="carousel-item col-lg-' . $post_width . ' col-md-6 col-sm-12">';
$post_classes[] = 'liquid-blog-item liquid-blog-item-carousel liquid-blog-contents-inside contents-bottom liquid-blog-scheme-light liquid-blog-scheme-light-alt h-300';
}
elseif( 'split' === $style ) {
$before = '<div class="col-sm-12 masonry-item ' . $this->entry_term_classes() . '">';
$post_classes[] = 'liquid-blog-item liquid-blog-item-split liquid-blog-scheme-dark liquid-blog-scheme-dark-alt';
}
elseif( 'classic-full' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-grid liquid-blog-scheme-dark';
}
elseif( 'podcast' === $style ) {
$post_classes[] = 'liquid-blog-item liquid-blog-item-hownow liquid-blog-scheme-dark';
}
$post_classes = join( ' ', get_post_class( $post_classes, get_the_ID() ) );
$attributes = array(
'id' => 'post-' . get_the_ID(),
'class' => $post_classes
);
echo $before;
printf( '<article%s>', ld_helper()->html_attributes( $attributes ) );
if( 'quote' === get_post_format() ) {
$quote_located = locate_template( 'templates/blog/format-quote.php' );
include $quote_located;
}
else {
include $located;
}
echo '</article>';
echo $after;
endwhile;
if( 'carousel' === $style ) {
echo '</div></div>';
}
echo '</div><!--/ .row -->';
// Pagination
if( 'pagination' === $atts['pagination'] ) {
$max = $GLOBALS['wp_query']->max_num_pages;
// Set up paginated links.
$links = paginate_links( array(
'type' => 'array',
'format' => 'page/%#%/?ajaxify=1',
'prev_next' => true,
'prev_text' => '<span aria-hidden="true">' . wp_kses_post( __( '<i class="fa fa-angle-left"></i>', 'ave-core' ) ) . '</span>',
'next_text' => '<span aria-hidden="true">' . wp_kses_post( __( '<i class="fa fa-angle-right"></i>', 'ave-core' ) ) . '</span>',
) );
if( !empty( $links ) ) {
printf( '<div class="page-nav"><nav aria-label="Page navigation"><ul class="pagination"><li>%s</li></ul></nav></div>', join( "</li>\n\t<li>", $links ) );
}
}
if( in_array( $atts['pagination'], array( 'ajax' ) ) && $url = get_next_posts_page_link( $GLOBALS['wp_query']->max_num_pages ) ) {
$hash = array(
'ajax' => 'btn btn-md ajax-load-more',
);
$attributes = array(
'href' => add_query_arg( 'ajaxify', '1', $url ),
'rel' => 'nofollow',
'data-ajaxify' => true,
'data-ajaxify-options' => json_encode( array(
'wrapper' => '.liquid-blog-posts' . $ajax_wrapper . ' > .liquid-blog-grid',
'items' => '> div',
'trigger' => $ajax_trigger,
) )
);
echo '<div class="liquid-pf-nav ld-pf-nav-ajax"><div class="page-nav text-center"><nav aria-label="' . esc_attr__( 'Page navigation', 'ave-core' ) . '">';
switch( $atts['pagination'] ) {
case 'ajax':
$ajax_text = ! empty( $atts['ajax_text'] ) ? esc_html( $atts['ajax_text'] ) : esc_html__( 'Load more', 'ave-core' );
$attributes['class'] = 'ld-ajax-loadmore';
printf( '<a%2$s><span><span class="static">%1$s</span><span class="loading"><span class="dots"><span></span><span></span><span></span></span><span class="text-uppercase lts-sp-1">' . esc_html__( 'Loading', 'ave-core' ) . '</span></span><span class="all-loaded">' . esc_html__( 'All items loaded', 'ave-core' ) . ' <i class="fa fa-check"></i></span></span></a>', $ajax_text, ld_helper()->html_attributes( $attributes ), $url );
break;
}
echo '</nav></div></div>';
}
wp_reset_query();
echo '</div><!--/ .liquid-blog-posts -->';