Files
display-featured-image-genesis/includes/output/class-displayfeaturedimagegenesis-output.php
T

475 lines
14 KiB
PHP

<?php
/**
* @package DisplayFeaturedImageGenesis
* @author Robin Cornett <hello@robincornett.com>
* @license GPL-2.0+
* @link https://robincornett.com
* @copyright 2014-2019 Robin Cornett Creative, LLC
*/
class Display_Featured_Image_Genesis_Output {
/**
* @var Display_Featured_Image_Genesis_Description $description
*/
protected $description;
/**
* @var
*/
protected $setting;
/**
* @var
*/
protected $item;
/**
* set parameters for scripts, etc. to run.
*
* @since 1.1.3
*/
public function manage_output() {
if ( $this->quit_now() ) {
return;
}
add_filter( 'jetpack_photon_override_image_downsize', '__return_true' );
add_action( 'wp_enqueue_scripts', array( $this, 'load_scripts' ) );
}
/**
* enqueue plugin styles and scripts.
*
* @since 1.0.0
*/
public function load_scripts() {
if ( ! $this->can_do_things() ) {
return;
}
include_once 'class-displayfeaturedimagegenesis-enqueue.php';
$enqueue = new DisplayFeaturedImageGenesisEnqueue( $this->get_setting(), $this->get_item() );
$enqueue->enqueue_style();
add_filter( 'body_class', array( $this, 'add_body_class' ) );
$large = $this->get_minimum_backstretch_width();
$item = $this->get_item();
$width = absint( $item->backstretch[1] );
/**
* Creates display_featured_image_genesis_force_backstretch filter to check
* whether get_post_type array should force the backstretch effect for this post type.
* @uses is_in_array()
*/
if ( $width > $large || displayfeaturedimagegenesis_get()->is_in_array( 'force_backstretch' ) ) {
$scriptless = displayfeaturedimagegenesis_get_setting( 'scriptless' );
if ( ! $scriptless ) {
$enqueue->enqueue_scripts();
}
$this->launch_backstretch_image();
} else {
$this->do_large_image_things();
}
}
/**
* set body class if featured images are displayed using the plugin
*
* @param $classes array
*
* @return array
*
* @since 1.0.0
*/
public function add_body_class( $classes ) {
if ( ! $this->can_do_things() ) {
return $classes;
}
$large = $this->get_minimum_backstretch_width();
$item = $this->get_item();
$width = (int) $item->backstretch[1];
if ( false === $item->content || ! is_singular() ) {
if ( $width > $large ) {
$classes[] = 'has-leader';
} elseif ( $width <= $large ) {
$classes[] = 'large-featured';
}
}
return apply_filters( 'display_featured_image_genesis_classes', $classes );
}
/**
* Actually output the backstretch/banner image and title markup at the designated hook.
* @since 3.1.0
*/
protected function launch_backstretch_image() {
$location = $this->get_hooks();
add_action( esc_attr( $location['backstretch']['hook'] ), array( $this, 'do_backstretch_image_title' ), $location['backstretch']['priority'] );
}
/**
* backstretch image title ( for images which are larger than Media Settings > Large )
*
* @since 1.0.0
*/
public function do_backstretch_image_title() {
$description = $this->get_description_class();
if ( $this->move_title() ) {
$description->remove_title_descriptions();
}
$class = 'big-leader';
$scriptless = displayfeaturedimagegenesis_get_setting( 'scriptless' );
if ( $scriptless ) {
$class .= ' big-leader--scriptless';
}
echo '<div class="' . esc_attr( $class ) . '">';
$image = $this->get_banner_image();
if ( $scriptless ) {
// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
echo $image;
}
echo '<div class="wrap">';
do_action( 'display_featured_image_genesis_before_title' );
if ( $this->move_title() ) {
if ( $this->move_excerpts() ) {
$description->do_title_descriptions();
} else {
$item = $this->get_item();
if ( ! empty( $item->title ) && $this->do_the_title() ) {
echo $this->do_the_title();
}
add_action( 'genesis_before_loop', array( $description, 'add_descriptions' ) );
}
}
do_action( 'display_featured_image_genesis_after_title' );
// close wrap
echo '</div>';
if ( ! $scriptless ) {
printf( '<noscript><div class="backstretch no-js">%s</div></noscript>', $image );
}
// close big-leader
echo '</div>';
add_filter( 'jetpack_photon_override_image_downsize', '__return_false' );
}
/**
* Get the banner/noscript image.
* @since 3.1.0
*
* @return string
*/
protected function get_banner_image() {
$image_id = displayfeaturedimagegenesis_get()->set_image_id();
return wp_get_attachment_image(
$image_id,
'displayfeaturedimage_backstretch',
false,
array(
'alt' => $this->get_image_alt_text( $image_id ),
'class' => 'big-leader__image post-image',
'aria-hidden' => 'true',
)
);
}
/**
* Get the alt text for the featured image. Use the image alt text if filter is true.
*
* @param string $image_id
*
* @return mixed
*/
protected function get_image_alt_text( $image_id = '' ) {
$item = $this->get_item();
$alt_text = $item->title;
if ( $image_id && apply_filters( 'displayfeaturedimagegenesis_prefer_image_alt', false ) ) {
$image_alt = get_post_meta( $image_id, '_wp_attachment_image_alt', true );
if ( $image_alt ) {
$alt_text = $image_alt;
}
}
return $alt_text;
}
/**
* All actions required to output the large image
* @since 2.3.4
*/
protected function do_large_image_things() {
remove_action( 'genesis_before_loop', 'genesis_do_cpt_archive_title_description' );
add_action( 'genesis_before_loop', 'genesis_do_cpt_archive_title_description', 15 );
$location = $this->get_hooks();
add_action( esc_attr( $location['large']['hook'] ), array( $this, 'do_large_image' ), $location['large']['priority'] ); // works for both HTML5 and XHTML
}
/**
* Large image, centered above content
*
* @since 1.0.0
*/
public function do_large_image() {
$image_id = displayfeaturedimagegenesis_get()->set_image_id();
$attr['class'] = 'aligncenter featured';
$attr['alt'] = $this->get_image_alt_text( $image_id );
$image_size = apply_filters( 'display_featured_image_large_image_size', displayfeaturedimagegenesis_get()->image_size() );
$image = wp_get_attachment_image( $image_id, $image_size, false, $attr );
$image = apply_filters( 'display_featured_image_genesis_large_image_output', $image, $image_id );
echo wp_kses_post( $image );
}
/**
* Return the title.
* @return string title with markup.
*
* @since 2.3.1
*/
protected function do_the_title() {
$description = $this->get_description_class();
if ( is_front_page() && ! $description->show_front_page_title() ) {
return '';
}
$class = is_singular() ? 'entry-title' : 'archive-title';
$itemprop = genesis_html5() ? 'itemprop="headline"' : '';
$item = $this->get_item();
$title = $item->title;
$title_output = sprintf( '<h1 class="%s featured-image-overlay" %s>%s</h1>', $class, $itemprop, $title );
return apply_filters( 'display_featured_image_genesis_modify_title_overlay', $title_output, esc_attr( $class ), esc_attr( $itemprop ), $title );
}
/**
* Check plugin settings/filters to see if the featured image should output on this post/etc. at all.
* Returns true to quit now; false to carry on.
* @return bool
*/
protected function quit_now() {
$setting = $this->get_setting();
$disable = false;
$exclude_front = is_front_page() && $setting['exclude_front'];
$post_type = get_post_type();
$skip_singular = is_singular() && isset( $setting['skip'][ $post_type ] ) && $setting['skip'][ $post_type ] ? true : false;
if ( $this->get_skipped_posttypes() || $skip_singular || $exclude_front || 1 === (int) get_post_meta( get_the_ID(), '_displayfeaturedimagegenesis_disable', true ) ) {
$disable = true;
}
/**
* Allow users to decide to quite early conditionally, outside of specific post types.
* @since 2.6.1
*/
return apply_filters( 'displayfeaturedimagegenesis_disable', $disable );
}
/**
* Creates display_featured_image_genesis_skipped_posttypes filter to check
* whether get_post_type array should not run plugin on this post type.
* @uses is_in_array()
*/
protected function get_skipped_posttypes() {
$post_types = array( 'attachment', 'revision', 'nav_menu_item' );
return displayfeaturedimagegenesis_get()->is_in_array( 'skipped_posttypes', $post_types );
}
/**
* Check whether plugin can output backstretch or large image
* @return boolean checks featured image size. returns true if can proceed; false if cannot
*
* @since 2.3.4
*/
public function can_do_things() {
$can_do = true;
$item = $this->get_item();
$medium = (int) apply_filters( 'displayfeaturedimagegenesis_set_medium_width', get_option( 'medium_size_w' ) );
$width = (int) $item->backstretch[1];
// check if they have enabled display on subsequent pages
$is_paged = $this->get_setting( 'is_paged' );
// if there is no backstretch image set, or it is too small, or the image is in the content, or it's page 2+ and they didn't change the setting, die
if ( empty( $item->backstretch ) || $width <= $medium || ( is_paged() && ! $is_paged ) || ( is_singular() && false !== $item->content ) ) {
$can_do = false;
}
return apply_filters( 'displayfeaturedimagegenesis_can_do', $can_do );
}
/**
* Create a filter to not move excerpts if move excerpts is enabled.
* @return bool
* @since 2.0.0 (deprecated old function from 1.3.3)
*/
protected function move_excerpts() {
$move_excerpts = $this->get_setting( 'move_excerpts' );
/**
* Creates display_featured_image_genesis_omit_excerpt filter to check
* whether get_post_type array should not move excerpts for this post type.
* @uses is_in_array()
*/
if ( $move_excerpts && ! displayfeaturedimagegenesis_get()->is_in_array( 'omit_excerpt' ) ) {
return true;
}
return false;
}
/**
* filter to maybe move titles, or not
* @return bool
* @since 2.2.0
*/
protected function move_title() {
$keep_titles = $this->get_setting( 'keep_titles' );
/**
* Creates display_featured_image_genesis_do_not_move_titles filter to check
* whether get_post_type array should not move titles to overlay the featured image.
* @uses is_in_array()
*/
if ( $keep_titles || displayfeaturedimagegenesis_get()->is_in_array( 'do_not_move_titles' ) || $this->check_post_meta( '_displayfeaturedimagegenesis_move' ) ) {
return false;
}
return true;
}
/**
* If there is no image to use for the post thumbnail in archives,
* optionally use the term or post type image as a fallback instead.
*
* @param $defaults
*
* @return mixed
* @since 2.5.0
*/
public function change_thumbnail_fallback( $defaults ) {
if ( ! $this->get_setting( 'thumbnails' ) ) {
return $defaults;
}
remove_action( 'genesis_entry_content', 'display_featured_image_genesis_add_archive_thumbnails', 5 );
$args = array(
'post_mime_type' => 'image',
'post_parent' => get_the_ID(),
'post_type' => 'attachment',
);
$attached_images = get_children( $args );
if ( $attached_images ) {
return $defaults;
}
$image_id = display_featured_image_genesis_get_term_image_id();
if ( empty( $image_id ) ) {
$image_id = display_featured_image_genesis_get_cpt_image_id();
}
if ( $image_id ) {
$defaults['fallback'] = $image_id;
}
return $defaults;
}
/**
* Instantiate the description class as needed.
* @return \Display_Featured_Image_Genesis_Description
* @since 3.1.0
*/
protected function get_description_class() {
if ( isset( $this->description ) ) {
return $this->description;
}
include_once 'class-displayfeaturedimagegenesis-description.php';
$this->description = new Display_Featured_Image_Genesis_Description();
return $this->description;
}
/**
* Get the current featured image and related variables.
* @return \stdClass
*/
protected function get_item() {
if ( isset( $this->item ) ) {
return $this->item;
}
$this->item = displayfeaturedimagegenesis_get()->get_image_variables();
return $this->item;
}
/**
* Get the minimum acceptable backstretch width.
*
* @return int
*/
protected function get_minimum_backstretch_width() {
return displayfeaturedimagegenesis_get()->minimum_backstretch_width();
}
/**
* Define the hooks/priorities for image output.
*
* @return array
*/
protected function get_hooks() {
$setting = displayfeaturedimagegenesis_get_setting();
$large_hook = apply_filters( 'display_featured_image_genesis_move_large_image', $setting['large_hook'] );
if ( ! is_singular() || is_page_template( 'page_blog.php' ) ) {
$check = strpos( $large_hook, 'entry' ) || strpos( $large_hook, 'post' );
if ( false !== $check ) {
$large_hook = 'genesis_before_loop';
}
}
return apply_filters( 'displayfeaturedimagegenesis_hooks', array(
'backstretch' => array(
'hook' => apply_filters( 'display_featured_image_move_backstretch_image', $setting['backstretch_hook'] ),
'priority' => apply_filters( 'display_featured_image_move_backstretch_image_priority', $setting['backstretch_priority'] ),
),
'large' => array(
'hook' => $large_hook,
'priority' => apply_filters( 'display_featured_image_genesis_move_large_image_priority', $setting['large_priority'] ),
),
) );
}
/**
* Check the post_meta for singular posts/pages/posts page.
*
* @param $meta_key string the post_meta key to check
*
* @return bool
* @since 2.5.2
*/
protected function check_post_meta( $meta_key ) {
$post_id = get_option( 'page_for_posts' ) && is_home() ? get_option( 'page_for_posts' ) : get_the_ID();
$post_meta = (bool) get_post_meta( $post_id, $meta_key, true );
return (bool) ( is_home() || is_singular() ) && $post_meta;
}
/**
* Get the plugin setting.
* @param string $key
*
* @return mixed
*/
private function get_setting( $key = '' ) {
if ( isset( $this->setting ) ) {
return $key ? $this->setting[ $key ] : $this->setting;
}
$this->setting = displayfeaturedimagegenesis_get_setting();
return $key ? $this->setting[ $key ] : $this->setting;
}
}