Return the requested image size in get_the_post_format_image()
props kovshenin. fixes #24188. git-svn-id: http://core.svn.wordpress.org/trunk@24240 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
a251b69906
commit
34455bbbd8
|
@ -2453,13 +2453,33 @@ function get_the_post_format_image( $attached_size = 'full', &$post = null ) {
|
||||||
$meta['image']
|
$meta['image']
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$attachment_id = img_html_to_post_id( $meta['image'], $matched_html );
|
||||||
|
if ( $attachment_id && $matched_html ) {
|
||||||
|
$meta['image'] = str_replace( $matched_html, wp_get_attachment_image( $attachment_id, $attached_size ), $meta['image'] );
|
||||||
|
$attachment = wp_get_attachment_image_src( $attachment_id, $attached_size );
|
||||||
|
$attachment_width = ( ! empty( $attachment[1] ) ) ? $attachment[1] : 0;
|
||||||
|
|
||||||
|
if ( $attachment_width && preg_match_all( '#width=([\'"])(.+?)\1#is', $meta['image'], $matches ) && ! empty( $matches ) )
|
||||||
|
foreach ( $matches[2] as $width )
|
||||||
|
if ( $width != $attachment_width )
|
||||||
|
$meta['image'] = str_replace( $matches[0], sprintf( 'width="%d"', $attachment_width ), $meta['image'] );
|
||||||
|
}
|
||||||
|
|
||||||
$image = do_shortcode( $meta['image'] );
|
$image = do_shortcode( $meta['image'] );
|
||||||
} elseif ( ! preg_match( '#<[^>]+>#', $meta['image'] ) ) {
|
} elseif ( ! preg_match( '#<[^>]+>#', $meta['image'] ) ) {
|
||||||
// not HTML, assume URL
|
// not HTML, assume URL
|
||||||
$image = sprintf( '<img src="%s" alt="" />', esc_url( $meta['image'] ) );
|
$attachment_id = attachment_url_to_postid( $meta['image'] );
|
||||||
|
if ( $attachment_id )
|
||||||
|
$image = wp_get_attachment_image( $attachment_id, $attached_size );
|
||||||
|
else
|
||||||
|
$image = sprintf( '<img src="%s" alt="" />', esc_url( $meta['image'] ) );
|
||||||
} else {
|
} else {
|
||||||
// assume HTML
|
// assume HTML
|
||||||
$image = $meta['image'];
|
$image = $meta['image'];
|
||||||
|
$attachment_id = img_html_to_post_id( $image, $matched_html );
|
||||||
|
if ( $attachment_id && $matched_html )
|
||||||
|
$image = str_replace( $matched_html, wp_get_attachment_image( $attachment_id, $attached_size ), $image );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( false === strpos( $image, '<a ' ) )
|
if ( false === strpos( $image, '<a ' ) )
|
||||||
|
@ -2532,6 +2552,11 @@ function get_the_post_format_image( $attached_size = 'full', &$post = null ) {
|
||||||
$htmls = get_content_images( $content, true, true, 1 );
|
$htmls = get_content_images( $content, true, true, 1 );
|
||||||
if ( ! empty( $htmls ) ) {
|
if ( ! empty( $htmls ) ) {
|
||||||
$html = reset( $htmls );
|
$html = reset( $htmls );
|
||||||
|
|
||||||
|
$attachment_id = img_html_to_post_id( $html, $matched_html );
|
||||||
|
if ( $attachment_id && $matched_html )
|
||||||
|
$html = str_replace( $matched_html, wp_get_attachment_image( $attachment_id, $attached_size ), $html );
|
||||||
|
|
||||||
$post->split_content = $content;
|
$post->split_content = $content;
|
||||||
$post->format_content[ $cache_key ] = sprintf( $link_fmt, $html );
|
$post->format_content[ $cache_key ] = sprintf( $link_fmt, $html );
|
||||||
return $post->format_content[ $cache_key ];
|
return $post->format_content[ $cache_key ];
|
||||||
|
@ -2569,3 +2594,39 @@ function attachment_url_to_postid( $url ) {
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the attachment post id from HTML containing an image.
|
||||||
|
*
|
||||||
|
* @since 3.6.0
|
||||||
|
*
|
||||||
|
* @param string $html The html, possibly with an image
|
||||||
|
* @param string $matched_html Passed by reference, will be set to to the matched img string
|
||||||
|
* @return int The attachment id if found, or 0.
|
||||||
|
*/
|
||||||
|
function img_html_to_post_id( $html, &$matched_html = null ) {
|
||||||
|
$attachment_id = 0;
|
||||||
|
|
||||||
|
// Look for an <img /> tag
|
||||||
|
if ( ! preg_match( '#' . get_tag_regex( 'img' ) . '#i', $html, $matches ) || empty( $matches ) )
|
||||||
|
return $attachment_id;
|
||||||
|
|
||||||
|
$matched_html = $matches[0];
|
||||||
|
|
||||||
|
// Look for attributes.
|
||||||
|
if ( ! preg_match_all( '#(src|class)=([\'"])(.+?)\2#is', $matched_html, $matches ) || empty( $matches ) )
|
||||||
|
return $attachment_id;
|
||||||
|
|
||||||
|
$attr = array();
|
||||||
|
foreach ( $matches[1] as $key => $attribute_name )
|
||||||
|
$attr[ $attribute_name ] = $matches[3][ $key ];
|
||||||
|
|
||||||
|
if ( ! empty( $attr['class'] ) && false !== strpos( $attr['class'], 'wp-image-' ) )
|
||||||
|
if ( preg_match( '#wp-image-([0-9]+)#i', $attr['class'], $matches ) )
|
||||||
|
$attachment_id = absint( $matches[1] );
|
||||||
|
|
||||||
|
if ( ! $attachment_id && ! empty( $attr['src'] ) )
|
||||||
|
$attachment_id = attachment_url_to_postid( $attr['src'] );
|
||||||
|
|
||||||
|
return $attachment_id;
|
||||||
|
}
|
Loading…
Reference in New Issue