127 lines
3.6 KiB
PHP
127 lines
3.6 KiB
PHP
<?php
|
|
/**
|
|
* Template Name: Recommendations
|
|
*
|
|
* Shows a list of all published recommendations with hooks for customization.
|
|
* It's paginated using the "Blog pages show at most" (posts_per_page)
|
|
* option under Settings > Reading.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Fictioneer
|
|
* @since 3.0
|
|
*/
|
|
|
|
|
|
// Setup
|
|
$post_id = get_the_ID();
|
|
$page = get_query_var( 'paged', 1 ) ?: 1; // Main query
|
|
$order = fictioneer_sanitize_query_var( $_GET['order'] ?? 0, ['desc', 'asc'], 'desc' );
|
|
$orderby = fictioneer_sanitize_query_var( $_GET['orderby'] ?? 0, fictioneer_allowed_orderby(), 'modified' );
|
|
$ago = $_GET['ago'] ?? 0;
|
|
$ago = is_numeric( $ago ) ? absint( $ago ) : sanitize_text_field( $ago );
|
|
|
|
// Prepare query
|
|
$query_args = array (
|
|
'fictioneer_query_name' => 'recommendations_list',
|
|
'post_type' => 'fcn_recommendation',
|
|
'post_status' => 'publish',
|
|
'orderby' => $orderby,
|
|
'order' => $order,
|
|
'paged' => $page,
|
|
'posts_per_page' => get_option( 'posts_per_page', 8 ),
|
|
'update_post_term_cache' => ! get_option( 'fictioneer_hide_taxonomies_on_recommendation_cards' )
|
|
);
|
|
|
|
// Append date query (if any)
|
|
$query_args = fictioneer_append_date_query( $query_args, $ago, $orderby );
|
|
|
|
// Filter query arguments
|
|
$query_args = apply_filters( 'fictioneer_filter_recommendations_query_args', $query_args, $post_id );
|
|
|
|
// Query recommendations
|
|
$list_of_recommendations = new WP_Query( $query_args );
|
|
|
|
// Prime author cache
|
|
if ( function_exists( 'update_post_author_caches' ) ) {
|
|
update_post_author_caches( $list_of_recommendations->posts );
|
|
}
|
|
|
|
// Header
|
|
get_header();
|
|
|
|
?>
|
|
|
|
<main id="main" class="main singular recommendations">
|
|
|
|
<div class="observer main-observer"></div>
|
|
|
|
<?php do_action( 'fictioneer_main' ); ?>
|
|
|
|
<div class="main__background polygon polygon--main background-texture"></div>
|
|
|
|
<div class="main__wrapper">
|
|
|
|
<?php do_action( 'fictioneer_main_wrapper' ); ?>
|
|
|
|
<?php while ( have_posts() ) : the_post(); ?>
|
|
|
|
<?php
|
|
// Setup
|
|
$title = trim( get_the_title() );
|
|
$breadcrumb_name = empty( $title ) ? __( 'Recommendations', 'fictioneer' ) : $title;
|
|
$this_breadcrumb = [ $breadcrumb_name, get_the_permalink() ];
|
|
|
|
// Arguments for hooks and templates/etc.
|
|
$hook_args = array(
|
|
'current_page' => $page,
|
|
'post_id' => $post_id,
|
|
'recommendations' => $list_of_recommendations,
|
|
'queried_type' => 'fcn_recommendation',
|
|
'query_args' => $query_args,
|
|
'order' => $order,
|
|
'orderby' => $orderby,
|
|
'ago' => $ago
|
|
);
|
|
?>
|
|
|
|
<article id="singular-<?php echo $post_id; ?>" class="singular__article recommendations__article padding-top padding-left padding-right padding-bottom">
|
|
|
|
<?php if ( ! empty( $title ) ) : ?>
|
|
<header class="singular__header recommendations__header">
|
|
<h1 class="singular__title recommendations__title"><?php echo $title; ?></h1>
|
|
</header>
|
|
<?php endif; ?>
|
|
|
|
<?php if ( get_the_content() ) : ?>
|
|
<section class="singular__content recommendations__content content-section">
|
|
<?php the_content(); ?>
|
|
</section>
|
|
<?php endif; ?>
|
|
|
|
<?php do_action( 'fictioneer_recommendations_after_content', $hook_args ); ?>
|
|
|
|
</article>
|
|
|
|
<?php endwhile; ?>
|
|
|
|
</div>
|
|
|
|
</main>
|
|
|
|
<?php
|
|
// Footer arguments
|
|
$footer_args = array(
|
|
'post_type' => 'page',
|
|
'post_id' => $post_id,
|
|
'breadcrumbs' => array(
|
|
[fcntr( 'frontpage' ), get_home_url()]
|
|
)
|
|
);
|
|
|
|
// Add current breadcrumb
|
|
$footer_args['breadcrumbs'][] = $this_breadcrumb;
|
|
|
|
// Get footer with breadcrumbs
|
|
get_footer( null, $footer_args );
|
|
?>
|