* @license GPL-2.0+ * @link https://robincornett.com * @copyright 2014-2016 Robin Cornett Creative, LLC */ class Display_Featured_Image_Genesis_Output { /** * @var Display_Featured_Image_Genesis_Common $common */ protected $common; /** * @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() { $this->setting = displayfeaturedimagegenesis_get_setting(); if ( $this->quit_now() ) { return; } $this->common = new Display_Featured_Image_Genesis_Common(); $this->item = Display_Featured_Image_Genesis_Common::get_image_variables(); add_filter( 'jetpack_photon_override_image_downsize', '__return_true' ); add_action( 'wp_enqueue_scripts', array( $this, 'load_scripts' ) ); } /** * enqueue plugin styles and scripts. * @return enqueue * * @since 1.0.0 */ public function load_scripts() { if ( ! $this->can_do_things() ) { return; } $css_file = apply_filters( 'display_featured_image_genesis_css_file', plugin_dir_url( __FILE__ ) . 'css/display-featured-image-genesis.css' ); wp_enqueue_style( 'displayfeaturedimage-style', esc_url( $css_file ), array(), $this->common->version ); if ( $this->setting['max_height'] ) { $this->add_inline_style(); } add_filter( 'body_class', array( $this, 'add_body_class' ) ); $large = $this->common->minimum_backstretch_width(); $width = absint( $this->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 || Display_Featured_Image_Genesis_Common::is_in_array( 'force_backstretch' ) ) { $this->do_backstretch_image_things(); } else { $this->do_large_image_things(); } } /** * Add max_height to output via inline style. * * @since 2.6.0 */ public function add_inline_style() { $css = sprintf( '.big-leader { max-height: %spx; }', $this->setting['max_height'] ); wp_add_inline_style( 'displayfeaturedimage-style', strip_tags( $css ) ); } /** * set body class if featured images are displayed using the plugin * @param filter $classes body_class * * @since 1.0.0 */ public function add_body_class( $classes ) { if ( ! $this->can_do_things() ) { return $classes; } $large = $this->common->minimum_backstretch_width(); $width = (int) $this->item->backstretch[1]; if ( false === $this->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 ); } /** * All actions required to output the backstretch image * @since 2.3.4 */ protected function do_backstretch_image_things() { wp_register_script( 'displayfeaturedimage-backstretch', plugins_url( '/includes/js/backstretch.js', dirname( __FILE__ ) ), array( 'jquery' ), $this->common->version, true ); wp_enqueue_script( 'displayfeaturedimage-backstretch-set', plugins_url( '/includes/js/backstretch-set.js', dirname( __FILE__ ) ), array( 'jquery', 'displayfeaturedimage-backstretch' ), $this->common->version, true ); add_action( 'wp_print_scripts', array( $this, 'localize_scripts' ) ); $hook = apply_filters( 'display_featured_image_move_backstretch_image', 'genesis_after_header' ); $priority = apply_filters( 'display_featured_image_move_backstretch_image_priority', 10 ); add_action( esc_attr( $hook ), array( $this, 'do_backstretch_image_title' ), $priority ); } /** * Pass variables through to our js * @return $output variable array to send to js * * @since 2.3.0 */ public function localize_scripts() { // backstretch settings which can be filtered $backstretch_vars = apply_filters( 'display_featured_image_genesis_backstretch_variables', array( 'centeredX' => true, 'centeredY' => true, 'fade' => 750, ) ); $image_id = Display_Featured_Image_Genesis_Common::set_image_id(); $large = wp_get_attachment_image_src( $image_id, 'large' ); $medium_large = wp_get_attachment_image_src( $image_id, 'medium_large' ); $output = array( 'source' => array( 'backstretch' => esc_url( $this->item->backstretch[0] ), 'large' => $large[3] ? esc_url( $large[0] ) : '', 'medium_large' => $medium_large[3] ? esc_url( $medium_large[0] ) : '', ), 'width' => array( 'backstretch' => $this->item->backstretch[1], 'large' => $large[3] ? $large[1] : '', 'medium_large' => $medium_large[3] ? $medium_large[1] : '', ), 'height' => (int) $this->setting['less_header'], 'centeredX' => (bool) $backstretch_vars['centeredX'], 'centeredY' => (bool) $backstretch_vars['centeredY'], 'fade' => (int) $backstretch_vars['fade'], 'title' => esc_attr( $this->item->title ), ); wp_localize_script( 'displayfeaturedimage-backstretch-set', 'BackStretchVars', $output ); } /** * backstretch image title ( for images which are larger than Media Settings > Large ) * @return image * * @since 1.0.0 */ public function do_backstretch_image_title() { $this->description = new Display_Featured_Image_Genesis_Description(); if ( $this->move_title() ) { $this->remove_title_descriptions(); } echo '
'; echo '
'; do_action( 'display_featured_image_genesis_before_title' ); if ( $this->move_excerpts() ) { $this->do_title_descriptions(); } elseif ( $this->move_title() ) { // if titles are being moved to overlay the image if ( ! empty( $this->item->title ) && $this->do_the_title() ) { echo wp_kses_post( $this->do_the_title() ); } add_action( 'genesis_before_loop', array( $this, 'add_descriptions' ) ); } do_action( 'display_featured_image_genesis_after_title' ); // close wrap echo '
'; // if javascript not enabled, do a fallback background image printf( '', esc_url( $this->item->backstretch[0] ) ); // close big-leader echo '
'; add_filter( 'jetpack_photon_override_image_downsize', '__return_false' ); // TODO remove } /** * 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 ); $hook = apply_filters( 'display_featured_image_genesis_move_large_image', 'genesis_before_loop' ); if ( ! is_singular() || is_page_template( 'page_blog.php' ) ) { $check = strpos( $hook, 'entry' ) || strpos( $hook, 'post' ); if ( false !== $check ) { $hook = 'genesis_before_loop'; } } $priority = apply_filters( 'display_featured_image_genesis_move_large_image_priority', 12 ); add_action( esc_attr( $hook ), array( $this, 'do_large_image' ), $priority ); // works for both HTML5 and XHTML } /** * Large image, centered above content * @return image * * @since 1.0.0 */ public function do_large_image() { $image_id = Display_Featured_Image_Genesis_Common::set_image_id(); $attr['class'] = 'aligncenter featured'; $attr['alt'] = $this->item->title; $image_size = apply_filters( 'display_featured_image_large_image_size', Display_Featured_Image_Genesis_Common::image_size() ); $image = wp_get_attachment_image( $image_id, $image_size, false, $attr ); $image = apply_filters( 'display_featured_image_genesis_large_image_output', $image ); echo wp_kses_post( $image ); } /** * Return the title. * @return string title with markup. * * @since 2.3.1 */ protected function do_the_title() { if ( is_front_page() && ! $this->description->show_front_page_title() ) { return; } $class = is_singular() ? 'entry-title' : 'archive-title'; $itemprop = genesis_html5() ? 'itemprop="headline"' : ''; $title = $this->item->title; $title_output = sprintf( '

%s

', $class, $itemprop, $title ); return apply_filters( 'display_featured_image_genesis_modify_title_overlay', $title_output, esc_attr( $class ), esc_attr( $itemprop ), $title ); } /** * Separate archive titles from descriptions. Titles show in leader image * area; descriptions show before loop. * * @return descriptions * * @since 1.3.0 * */ public function add_descriptions() { $this->description->do_tax_description(); $this->description->do_author_description(); $this->description->do_cpt_archive_description(); } /** * Do title and description together (for excerpt output) * @return title/description/excerpt * * @since 2.3.1 */ protected function do_title_descriptions() { $this->description->do_front_blog_excerpt(); $this->description->do_excerpt(); genesis_do_taxonomy_title_description(); genesis_do_author_title_description(); genesis_do_cpt_archive_title_description(); } /** * Remove Genesis titles/descriptions * @since 2.3.1 */ protected function remove_title_descriptions() { if ( is_singular() && ! is_page_template( 'page_blog.php' ) ) { remove_action( 'genesis_entry_header', 'genesis_do_post_title' ); // HTML5 remove_action( 'genesis_post_title', 'genesis_do_post_title' ); // XHTML } remove_action( 'genesis_before_loop', 'genesis_do_taxonomy_title_description', 15 ); remove_action( 'genesis_before_loop', 'genesis_do_author_title_description', 15 ); remove_action( 'genesis_before_loop', 'genesis_do_cpt_archive_title_description' ); remove_action( 'genesis_before_loop', 'genesis_do_blog_template_heading' ); remove_action( 'genesis_before_loop', 'genesis_do_posts_page_heading' ); } /** * 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() { $exclude_front = is_front_page() && $this->setting['exclude_front']; $post_type = get_post_type(); $skip_post_type = is_singular() && isset( $this->setting['skip'][ $post_type ] ) && $this->setting['skip'][ $post_type ] ? true : false; /** * 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() */ $post_types = array( 'attachment', 'revision', 'nav_menu_item' ); if ( is_admin() || Display_Featured_Image_Genesis_Common::is_in_array( 'skipped_posttypes', $post_types ) || $skip_post_type || $exclude_front || $this->check_post_meta( '_displayfeaturedimagegenesis_disable' ) ) { return true; } return false; } /** * 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; $medium = (int) apply_filters( 'displayfeaturedimagegenesis_set_medium_width', get_option( 'medium_size_w' ) ); $width = (int) $this->item->backstretch[1]; // check if they have enabled display on subsequent pages $is_paged = ! empty( $this->setting['is_paged'] ) ? $this->setting['is_paged'] : 0; // 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( $this->item->backstretch ) || $width <= $medium || ( is_paged() && ! $is_paged ) || ( is_singular() && false !== $this->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 * @var filter * @since 2.0.0 (deprecated old function from 1.3.3) */ protected function move_excerpts() { $move_excerpts = $this->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 && ! Display_Featured_Image_Genesis_Common::is_in_array( 'omit_excerpt' ) ) { return true; } return false; } /** * filter to maybe move titles, or not * @var filter * @since 2.2.0 */ protected function move_title() { $keep_titles = $this->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 || Display_Featured_Image_Genesis_Common::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 ( ! isset( $this->setting['thumbnails'] ) || ! $this->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; } /** * 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; } }