fictioneer/recommendations.php
2023-08-20 01:12:49 +02:00

124 lines
3.8 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
*
* @internal ('fictioneer_filter_and_search_id') ACF field. You can use this ID for plugins.
* @internal ('fictioneer_short_name') ACF field. Meant for an abbreviated page name.
*/
?>
<?php
// Setup
$page = get_query_var( 'paged', 1 ) ?: 1; // Main query
$order = array_intersect( [strtolower( $_GET['order'] ?? 0 )], ['desc', 'asc'] );
$order = reset( $order ) ?: 'desc';
$orderby = array_intersect( [strtolower( $_GET['orderby'] ?? 0 )], ['modified', 'date', 'title', 'rand'] );
$orderby = reset( $orderby ) ?: 'modified';
$ago = $_GET['ago'] ?? 0;
$ago = is_numeric( $ago ) ? absint( $ago ) : sanitize_text_field( $ago );
// Prepare query
$query_args = array (
'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, get_the_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 );
}
?>
<?php 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' => get_the_ID(),
'recommendations' => $list_of_recommendations,
'queried_type' => 'fcn_recommendation',
'query_args' => $query_args,
'order' => $order,
'orderby' => $orderby,
'ago' => $ago
);
?>
<article id="singular-<?php the_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' => get_the_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 );
?>