2009-12-10 07:14:36 +01: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 23:11:12 +01:00
*
2009-12-10 07:14:36 +01:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
2010-02-24 21:13:23 +01:00
* @ return bool Whether post has an image attached .
2009-12-10 07:14:36 +01:00
*/
2010-10-27 02:33:29 +02:00
function has_post_thumbnail ( $post_id = null ) {
return ( bool ) get_post_thumbnail_id ( $post_id );
2009-12-10 07:14:36 +01:00
}
/**
* Retrieve Post Thumbnail ID .
2010-01-15 23:11:12 +01:00
*
2009-12-10 07:14:36 +01:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
* @ return int
*/
2010-10-27 02:33:29 +02:00
function get_post_thumbnail_id ( $post_id = null ) {
$post_id = ( null === $post_id ) ? get_the_ID () : $post_id ;
2009-12-10 07:14:36 +01:00
return get_post_meta ( $post_id , '_thumbnail_id' , true );
}
/**
* Display Post Thumbnail .
2010-01-15 23:11:12 +01:00
*
2009-12-10 07:14:36 +01:00
* @ since 2.9 . 0
*
2011-12-14 00:45:31 +01:00
* @ param int $size Optional . Image size . Defaults to 'post-thumbnail' , which theme sets using set_post_thumbnail_size ( $width , $height , $crop_flag ); .
2009-12-10 07:14:36 +01:00
* @ param string | array $attr Optional . Query string or array of attributes .
*/
function the_post_thumbnail ( $size = 'post-thumbnail' , $attr = '' ) {
2010-10-27 02:33:29 +02:00
echo get_the_post_thumbnail ( null , $size , $attr );
2009-12-10 07:14:36 +01:00
}
2011-05-12 05:06:03 +02:00
/**
* Update cache for thumbnails in the current loop
*
2011-09-30 00:57:43 +02:00
* @ since 3.2
2011-05-12 05:06:03 +02: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 07:14:36 +01:00
/**
* Retrieve Post Thumbnail .
2010-01-15 23:11:12 +01:00
*
2009-12-10 07:14:36 +01:00
* @ since 2.9 . 0
*
* @ param int $post_id Optional . Post ID .
2011-12-14 00:45:31 +01:00
* @ param string $size Optional . Image size . Defaults to 'thumbnail' .
2009-12-10 07:14:36 +01:00
* @ param string | array $attr Optional . Query string or array of attributes .
2010-06-30 02:05:18 +02:00
*/
2010-10-27 02:33:29 +02: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 07:14:36 +01: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-12 05:06:03 +02:00
if ( in_the_loop () )
update_post_thumbnail_cache ();
2009-12-10 07:14:36 +01: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 );
}