2023-01-21 01:31:34 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Partial: Latest Recommendations Compact
|
|
|
|
*
|
|
|
|
* Renders the (buffered) HTML for the [fictioneer_latest_recommendations type="compact"] shortcode.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
* @subpackage Fictioneer
|
2024-01-26 17:45:59 +01:00
|
|
|
* @since 4.0.0
|
2023-01-21 01:31:34 +01:00
|
|
|
*
|
2024-10-06 23:17:22 +02:00
|
|
|
* @internal $args['uid'] Unique ID of the shortcode. Pattern: shortcode-id-{id}.
|
2024-01-28 00:11:56 +01:00
|
|
|
* @internal $args['type'] Type argument passed from shortcode ('compact').
|
2023-09-15 15:15:45 +02:00
|
|
|
* @internal $args['count'] Number of posts provided by the shortcode.
|
|
|
|
* @internal $args['author'] Author provided by the shortcode.
|
|
|
|
* @internal $args['order'] Order of posts. Default 'DESC'.
|
|
|
|
* @internal $args['orderby'] Sorting of posts. Default 'date'.
|
|
|
|
* @internal $args['post_ids'] Array of post IDs. Default empty.
|
2023-09-16 23:41:30 +02:00
|
|
|
* @internal $args['author_ids'] Array of author IDs. Default empty.
|
|
|
|
* @internal $args['excluded_authors'] Array of author IDs to exclude. Default empty.
|
2023-09-15 15:15:45 +02:00
|
|
|
* @internal $args['excluded_cats'] Array of category IDs to exclude. Default empty.
|
|
|
|
* @internal $args['excluded_tags'] Array of tag IDs to exclude. Default empty.
|
|
|
|
* @internal $args['ignore_protected'] Whether to ignore protected posts. Default false.
|
2024-09-20 23:41:37 +02:00
|
|
|
* @internal $args['only_protected'] Whether to query only protected posts. Default false.
|
2023-09-15 15:15:45 +02:00
|
|
|
* @internal $args['taxonomies'] Array of taxonomy arrays. Default empty.
|
|
|
|
* @internal $args['relation'] Relationship between taxonomies.
|
2024-04-14 19:46:35 +02:00
|
|
|
* @internal $args['vertical'] Whether to show the vertical variant.
|
2024-05-15 09:57:43 +02:00
|
|
|
* @internal $args['seamless'] Whether to render the image seamless. Default false (Customizer).
|
2024-04-14 19:46:35 +02:00
|
|
|
* @internal $args['aspect_ratio'] Aspect ratio for the image. Only with vertical.
|
2024-04-25 12:50:42 +02:00
|
|
|
* @internal $args['lightbox'] Whether the image is opened in the lightbox. Default true.
|
2024-05-15 09:57:43 +02:00
|
|
|
* @internal $args['thumbnail'] Whether the image is rendered. Default true (Customizer).
|
2024-09-06 01:26:42 +02:00
|
|
|
* @internal $args['terms'] Either inline, pills, none, or false. Default inline.
|
|
|
|
* @internal $args['max_terms'] Maximum number of shown taxonomies. Default 10.
|
2023-09-15 22:42:34 +02:00
|
|
|
* @internal $args['classes'] String of additional CSS classes. Default empty.
|
2024-08-14 01:48:21 +02:00
|
|
|
* @internal $args['infobox'] Whether to show the info box and toggle.
|
2024-09-06 01:26:42 +02:00
|
|
|
* @internal $args['splide'] Configuration JSON for the Splide slider. Default empty.
|
2023-01-21 01:31:34 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2023-08-20 20:21:48 +02:00
|
|
|
// No direct access!
|
|
|
|
defined( 'ABSPATH' ) OR exit;
|
|
|
|
|
2023-01-21 01:31:34 +01:00
|
|
|
// Setup
|
2024-09-06 01:26:42 +02:00
|
|
|
$splide = $args['splide'] ?? 0;
|
2024-08-23 23:12:24 +02:00
|
|
|
$show_terms = ! in_array( $args['terms'], ['none', 'false'] ) &&
|
|
|
|
! get_option( 'fictioneer_hide_taxonomies_on_recommendation_cards' );
|
2023-01-21 01:31:34 +01:00
|
|
|
|
|
|
|
// Prepare query
|
|
|
|
$query_args = array (
|
2023-09-15 14:00:44 +02:00
|
|
|
'fictioneer_query_name' => 'latest_recommendations_compact',
|
2023-01-21 01:31:34 +01:00
|
|
|
'post_type' => 'fcn_recommendation',
|
2023-03-09 02:03:09 +01:00
|
|
|
'post_status' => 'publish',
|
2023-08-17 01:32:02 +02:00
|
|
|
'post__in' => $args['post_ids'], // May be empty!
|
2023-09-16 22:59:43 +02:00
|
|
|
'order' => $args['order'],
|
|
|
|
'orderby' => $args['orderby'],
|
2023-01-21 01:31:34 +01:00
|
|
|
'posts_per_page' => $args['count'],
|
2024-08-23 23:12:24 +02:00
|
|
|
'update_post_term_cache' => $show_terms, // Improve performance
|
2023-01-21 01:31:34 +01:00
|
|
|
'no_found_rows' => true
|
|
|
|
);
|
|
|
|
|
2023-09-16 21:44:12 +02:00
|
|
|
// Author?
|
2023-09-17 01:28:14 +02:00
|
|
|
if ( ! empty( $args['author'] ) ) {
|
2023-09-16 21:44:12 +02:00
|
|
|
$query_args['author_name'] = $args['author'];
|
|
|
|
}
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2023-09-16 22:59:43 +02:00
|
|
|
// Author IDs?
|
|
|
|
if ( ! empty( $args['author_ids'] ) ) {
|
|
|
|
$query_args['author__in'] = $args['author_ids'];
|
|
|
|
}
|
|
|
|
|
2023-03-08 23:24:41 +01:00
|
|
|
// Taxonomies?
|
|
|
|
if ( ! empty( $args['taxonomies'] ) ) {
|
|
|
|
$query_args['tax_query'] = fictioneer_get_shortcode_tax_query( $args );
|
|
|
|
}
|
|
|
|
|
2023-03-10 17:16:54 +01:00
|
|
|
// Excluded tags?
|
|
|
|
if ( ! empty( $args['excluded_tags'] ) ) {
|
|
|
|
$query_args['tag__not_in'] = $args['excluded_tags'];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Excluded categories?
|
|
|
|
if ( ! empty( $args['excluded_cats'] ) ) {
|
|
|
|
$query_args['category__not_in'] = $args['excluded_cats'];
|
|
|
|
}
|
|
|
|
|
2023-09-16 22:59:43 +02:00
|
|
|
// Excluded authors?
|
|
|
|
if ( ! empty( $args['excluded_authors'] ) ) {
|
|
|
|
$query_args['author__not_in'] = $args['excluded_authors'];
|
|
|
|
}
|
|
|
|
|
2023-09-15 15:15:45 +02:00
|
|
|
// Ignore protected?
|
|
|
|
if ( $args['ignore_protected'] ) {
|
2024-09-20 23:32:29 +02:00
|
|
|
$query_args['has_password'] = false;
|
2023-09-15 15:15:45 +02:00
|
|
|
}
|
|
|
|
|
2024-09-20 23:41:37 +02:00
|
|
|
// Only protected?
|
|
|
|
if ( $args['only_protected'] ) {
|
|
|
|
$query_args['has_password'] = true;
|
|
|
|
}
|
|
|
|
|
2023-03-09 11:21:05 +01:00
|
|
|
// Apply filters
|
2023-03-10 15:20:48 +01:00
|
|
|
$query_args = apply_filters( 'fictioneer_filter_shortcode_latest_recommendations_query_args', $query_args, $args );
|
2023-03-09 11:21:05 +01:00
|
|
|
|
2023-01-21 01:31:34 +01:00
|
|
|
// Query chapters
|
2023-08-03 13:17:32 +02:00
|
|
|
$entries = fictioneer_shortcode_query( $query_args );
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
// Extra attributes
|
|
|
|
$attributes = [];
|
|
|
|
|
|
|
|
if ( $splide ) {
|
|
|
|
$attributes[] = "data-splide='{$splide}'";
|
|
|
|
}
|
|
|
|
|
2023-01-21 01:31:34 +01:00
|
|
|
?>
|
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<section class="small-card-block latest-recommendations _compact <?php echo $args['classes']; ?>" <?php echo implode( ' ', $attributes ); ?>>
|
|
|
|
<?php
|
|
|
|
if ( $args['splide'] === false ) {
|
|
|
|
echo '<div class="shortcode-json-invalid">' . __( 'Splide JSON is invalid and has been ignored.', 'fictioneer' ) . '</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $splide ) {
|
2024-10-07 02:08:40 +02:00
|
|
|
echo fictioneer_get_splide_breakpoint_style( $splide, $args['uid'] );
|
2024-10-07 14:15:08 +02:00
|
|
|
echo fictioneer_get_splide_arrows( $args['uid'] );
|
2024-09-06 01:26:42 +02:00
|
|
|
echo '<div class="splide__track">';
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
|
|
|
|
<?php if ( $entries->have_posts() ) : ?>
|
|
|
|
|
2024-10-02 17:54:05 +02:00
|
|
|
<ul class="grid-columns <?php if ( $splide ) { echo 'splide__list'; } ?>">
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php while ( $entries->have_posts() ) : $entries->the_post(); ?>
|
|
|
|
|
|
|
|
<?php
|
|
|
|
// Setup
|
|
|
|
$post_id = $post->ID;
|
|
|
|
$title = fictioneer_get_safe_title( $post_id, 'shortcode-latest-recommendations-compact' );
|
|
|
|
$one_sentence = get_post_meta( $post_id, 'fictioneer_recommendation_one_sentence', true );
|
|
|
|
$fandoms = $show_terms ? get_the_terms( $post, 'fcn_fandom' ) : [];
|
|
|
|
$characters = $show_terms ? get_the_terms( $post, 'fcn_character' ) : [];
|
|
|
|
$genres = $show_terms ? get_the_terms( $post, 'fcn_genre' ) : [];
|
|
|
|
$tags = ( $show_terms && get_option( 'fictioneer_show_tags_on_recommendation_cards' ) ) ?
|
|
|
|
get_the_tags( $post ) : false;
|
|
|
|
$grid_or_vertical = $args['vertical'] ? '_vertical' : '_grid';
|
|
|
|
$card_classes = [];
|
|
|
|
|
|
|
|
// Extra classes
|
|
|
|
if ( $show_terms ) {
|
|
|
|
$card_classes[] = '_info';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( get_theme_mod( 'card_style', 'default' ) !== 'default' ) {
|
|
|
|
$card_classes[] = '_' . get_theme_mod( 'card_style' );
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $args['vertical'] ) {
|
|
|
|
$card_classes[] = '_vertical';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $args['seamless'] ) {
|
|
|
|
$card_classes[] = '_seamless';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! $show_terms ) {
|
|
|
|
$card_classes[] = '_no-tax';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $splide ) {
|
|
|
|
$card_classes[] = 'splide__slide';
|
|
|
|
}
|
|
|
|
|
|
|
|
// Truncate factor
|
|
|
|
$truncate_factor = $args['vertical'] ? '_4-4' : '_cq-3-4';
|
|
|
|
|
|
|
|
// Card attributes
|
|
|
|
$attributes = [];
|
|
|
|
|
|
|
|
if ( $args['aspect_ratio'] ) {
|
|
|
|
$attributes['style'] = '--card-image-aspect-ratio: ' . $args['aspect_ratio'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$attributes = apply_filters( 'fictioneer_filter_card_attributes', $attributes, $post, 'shortcode-latest-recommendations-compact' );
|
|
|
|
|
|
|
|
$card_attributes = '';
|
|
|
|
|
|
|
|
foreach ( $attributes as $key => $value ) {
|
|
|
|
$card_attributes .= esc_attr( $key ) . '="' . esc_attr( $value ) . '" ';
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
|
|
|
|
<li class="post-<?php echo $post_id; ?> card watch-last-clicked _small _recommendation _compact _no-footer <?php echo implode( ' ', $card_classes ); ?>" <?php echo $card_attributes; ?>>
|
|
|
|
<div class="card__body polygon">
|
|
|
|
|
|
|
|
<?php if ( $show_terms && $args['infobox'] ) : ?>
|
|
|
|
<button class="card__info-toggle toggle-last-clicked" aria-label="<?php esc_attr_e( 'Open info box', 'fictioneer' ); ?>"><i class="fa-solid fa-chevron-down"></i></button>
|
|
|
|
<?php endif; ?>
|
|
|
|
|
|
|
|
<div class="card__main <?php echo $grid_or_vertical; ?> _small">
|
|
|
|
|
|
|
|
<?php
|
|
|
|
do_action( 'fictioneer_shortcode_latest_recommendations_card_body', $post, $args );
|
|
|
|
|
|
|
|
if ( $args['thumbnail'] ) {
|
|
|
|
fictioneer_render_thumbnail(
|
|
|
|
array(
|
|
|
|
'post_id' => $post_id,
|
|
|
|
'title' => $title,
|
|
|
|
'classes' => 'card__image cell-img',
|
|
|
|
'permalink' => get_permalink(),
|
|
|
|
'lightbox' => $args['lightbox'],
|
|
|
|
'vertical' => $args['vertical'],
|
|
|
|
'seamless' => $args['seamless'],
|
|
|
|
'aspect_ratio' => $args['aspect_ratio']
|
|
|
|
)
|
2024-01-19 14:13:17 +01:00
|
|
|
);
|
2024-09-06 01:26:42 +02:00
|
|
|
}
|
|
|
|
?>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<h3 class="card__title _small cell-title"><a href="<?php the_permalink(); ?>" class="truncate _1-1"><?php echo $title; ?></a></h3>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<div class="card__content _small cell-desc">
|
|
|
|
<div class="truncate <?php echo $truncate_factor; ?>">
|
|
|
|
<span class="card__by-author"><?php
|
|
|
|
printf(
|
|
|
|
_x( 'by %s —', 'Small card: by {Author} —.', 'fictioneer' ),
|
|
|
|
'<span class="author">' . get_post_meta( $post_id, 'fictioneer_recommendation_author', true ) . '</span>'
|
2024-08-23 23:12:24 +02:00
|
|
|
);
|
2024-09-06 01:26:42 +02:00
|
|
|
?></span>
|
|
|
|
<span><?php
|
|
|
|
if ( ! empty( $one_sentence ) ) {
|
|
|
|
echo wp_strip_all_tags( $one_sentence, true );
|
|
|
|
} else {
|
|
|
|
echo fictioneer_first_paragraph_as_excerpt( get_the_content() );
|
|
|
|
}
|
|
|
|
?></span>
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-08-23 23:12:24 +02:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
</div>
|
2024-08-23 16:44:04 +02:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php if ( $show_terms && $args['infobox'] ) : ?>
|
|
|
|
<div class="card__overlay-infobox escape-last-click">
|
|
|
|
<div class="card__tag-list _small <?php echo $args['terms'] === 'pills' ? '_pills' : ''; ?>">
|
|
|
|
<?php
|
|
|
|
if ( $fandoms || $genres || $tags || $characters ) {
|
|
|
|
$variant = $args['terms'] === 'pills' ? '_pill' : '_inline';
|
|
|
|
|
|
|
|
$terms = array_merge(
|
|
|
|
$fandoms ? fictioneer_get_term_nodes( $fandoms, "{$variant} _fandom" ) : [],
|
|
|
|
$genres ? fictioneer_get_term_nodes( $genres, "{$variant} _genre" ) : [],
|
|
|
|
$tags ? fictioneer_get_term_nodes( $tags, "{$variant} _tag" ) : [],
|
|
|
|
$characters ? fictioneer_get_term_nodes( $characters, "{$variant} _character" ) : []
|
|
|
|
);
|
|
|
|
|
|
|
|
$terms = apply_filters(
|
|
|
|
'fictioneer_filter_shortcode_latest_recommendations_terms',
|
|
|
|
$terms, $post, $args, null
|
|
|
|
);
|
|
|
|
|
|
|
|
// Implode with separator
|
|
|
|
echo implode(
|
|
|
|
fictioneer_get_bullet_separator( 'latest-recommendations-compact', $args['terms'] === 'pills' ),
|
|
|
|
array_slice( $terms, 0, $args['max_terms'] )
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
?><span class="card__no-taxonomies"><?php _e( 'No taxonomies specified yet.', 'fictioneer' ); ?></span><?php
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
</div>
|
2023-01-21 01:31:34 +01:00
|
|
|
</div>
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php endif; ?>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</li>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php endwhile; ?>
|
|
|
|
</ul>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php else : ?>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<div class="no-results"><?php _e( 'Nothing to show.', 'fictioneer' ); ?></div>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php endif; wp_reset_postdata(); ?>
|
2023-01-21 01:31:34 +01:00
|
|
|
|
2024-09-06 01:26:42 +02:00
|
|
|
<?php if ( $splide ) { echo '</div>'; } ?>
|
2023-01-21 01:31:34 +01:00
|
|
|
</section>
|