2009-12-10 01:14:36 -05:00
< ? php
/**
* WordPress Post Thumbnail Template Functions .
*
* Support for post thumbnails
* Themes function . php must call add_theme_support ( 'post-thumbnails' ) to use these .
*
* @ package WordPress
* @ subpackage Template
*/
/**
* Check if post has an image attached .
2010-01-15 17:11:12 -05:00
*
2009-12-10 01:14:36 -05:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
2010-02-24 15:13:23 -05:00
* @ return bool Whether post has an image attached .
2009-12-10 01:14:36 -05:00
*/
2010-10-26 20:33:29 -04:00
function has_post_thumbnail ( $post_id = null ) {
return ( bool ) get_post_thumbnail_id ( $post_id );
2009-12-10 01:14:36 -05:00
}
/**
* Retrieve Post Thumbnail ID .
2010-01-15 17:11:12 -05:00
*
2009-12-10 01:14:36 -05:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
* @ return int
*/
2010-10-26 20:33:29 -04:00
function get_post_thumbnail_id ( $post_id = null ) {
$post_id = ( null === $post_id ) ? get_the_ID () : $post_id ;
2009-12-10 01:14:36 -05:00
return get_post_meta ( $post_id , '_thumbnail_id' , true );
}
/**
* Display Post Thumbnail .
2010-01-15 17:11:12 -05:00
*
2009-12-10 01:14:36 -05:00
* @ since 2.9 . 0
*
* @ param int $size Optional . Image size . Defaults to 'post-thumbnail' , which theme sets using set_post_thumbnail_size ( $width , $height , $crop_flag ); .
* @ param string | array $attr Optional . Query string or array of attributes .
*/
function the_post_thumbnail ( $size = 'post-thumbnail' , $attr = '' ) {
2010-10-26 20:33:29 -04:00
echo get_the_post_thumbnail ( null , $size , $attr );
2009-12-10 01:14:36 -05:00
}
2011-05-11 23:06:03 -04:00
/**
* Update cache for thumbnails in the current loop
*
2011-09-29 18:57:43 -04:00
* @ since 3.2
2011-05-11 23:06:03 -04:00
*/
function update_post_thumbnail_cache () {
global $wp_query ;
if ( $wp_query -> thumbnails_cached )
return ;
$thumb_ids = array ();
foreach ( $wp_query -> posts as $post ) {
if ( $id = get_post_thumbnail_id ( $post -> ID ) )
$thumb_ids [] = $id ;
}
if ( ! empty ( $thumb_ids ) ) {
get_posts ( array (
'update_post_term_cache' => false ,
'include' => $thumb_ids ,
'post_type' => 'attachment' ,
'post_status' => 'inherit' ,
'nopaging' => true
) );
}
$wp_query -> thumbnails_cached = true ;
}
2009-12-10 01:14:36 -05:00
/**
* Retrieve Post Thumbnail .
2010-01-15 17:11:12 -05:00
*
2009-12-10 01:14:36 -05:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
* @ param string $size Optional . Image size . Defaults to 'thumbnail' .
* @ param string | array $attr Optional . Query string or array of attributes .
2010-06-29 20:05:18 -04:00
*/
2010-10-26 20:33:29 -04:00
function get_the_post_thumbnail ( $post_id = null , $size = 'post-thumbnail' , $attr = '' ) {
$post_id = ( null === $post_id ) ? get_the_ID () : $post_id ;
2009-12-10 01:14:36 -05:00
$post_thumbnail_id = get_post_thumbnail_id ( $post_id );
$size = apply_filters ( 'post_thumbnail_size' , $size );
if ( $post_thumbnail_id ) {
do_action ( 'begin_fetch_post_thumbnail_html' , $post_id , $post_thumbnail_id , $size ); // for "Just In Time" filtering of all of wp_get_attachment_image()'s filters
2011-05-11 23:06:03 -04:00
if ( in_the_loop () )
update_post_thumbnail_cache ();
2009-12-10 01:14:36 -05:00
$html = wp_get_attachment_image ( $post_thumbnail_id , $size , false , $attr );
do_action ( 'end_fetch_post_thumbnail_html' , $post_id , $post_thumbnail_id , $size );
} else {
$html = '' ;
}
return apply_filters ( 'post_thumbnail_html' , $html , $post_id , $post_thumbnail_id , $size , $attr );
}
2010-08-28 07:57:28 -04:00
?>