From 2defb1ef6cbc2cd762fb0fef2f32636f0bba9f2a Mon Sep 17 00:00:00 2001 From: Sergey Biryukov Date: Tue, 20 Oct 2020 15:29:42 +0000 Subject: [PATCH] Media: Introduce a filter for `wp_get_attachment_image()` HTML output. Props prionkor, antpb, donmhico, audrasjb, Mista-Flo, hellofromTonya. Fixes #50801. git-svn-id: https://develop.svn.wordpress.org/trunk@49234 602fd350-edb4-49c9-b593-d223f7449a82 --- src/wp-includes/media.php | 17 +++++++++++++++-- tests/phpunit/tests/media.php | 18 ++++++++++++++++++ 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/src/wp-includes/media.php b/src/wp-includes/media.php index 726ff6d38e..2403df6a24 100644 --- a/src/wp-includes/media.php +++ b/src/wp-includes/media.php @@ -992,7 +992,7 @@ function wp_get_attachment_image_src( $attachment_id, $size = 'thumbnail', $icon } /** - * Get an HTML img element representing an image attachment + * Get an HTML img element representing an image attachment. * * While `$size` will accept an array, it is better to register a size with * add_image_size() so that a cropped version is generated. It's much more @@ -1099,7 +1099,20 @@ function wp_get_attachment_image( $attachment_id, $size = 'thumbnail', $icon = f $html .= ' />'; } - return $html; + /** + * HTML img element representing an image attachment. + * + * @since 5.6.0 + * + * @param string $html HTML img element or empty string on failure. + * @param int $attachment_id Image attachment ID. + * @param string|int[] $size Requested image size. Can be any registered image size name, or + * an array of width and height values in pixels (in that order). + * @param bool $icon Whether the image should be treated as an icon. + * @param array $attr Array of attribute values for the image markup, keyed by attribute name. + * See wp_get_attachment_image(). + */ + return apply_filters( 'wp_get_attachment_image', $html, $attachment_id, $size, $icon, $attr ); } /** diff --git a/tests/phpunit/tests/media.php b/tests/phpunit/tests/media.php index 32d62f6efd..053ac5008d 100644 --- a/tests/phpunit/tests/media.php +++ b/tests/phpunit/tests/media.php @@ -1343,6 +1343,24 @@ EOF; $this->assertSame( $expected, wp_get_attachment_image( self::$large_id ) ); } + /** + * @ticket 50801 + */ + function test_wp_get_attachment_image_filter_output() { + $image = image_downsize( self::$large_id, 'thumbnail' ); + $expected = 'Override wp_get_attachment_image'; + + add_filter( 'wp_get_attachment_image', array( $this, 'filter_wp_get_attachment_image' ) ); + $output = wp_get_attachment_image( self::$large_id ); + remove_filter( 'wp_get_attachment_image', array( $this, 'filter_wp_get_attachment_image' ) ); + + $this->assertSame( $expected, $output ); + } + + function filter_wp_get_attachment_image() { + return 'Override wp_get_attachment_image'; + } + /** * Test that `wp_get_attachment_image()` returns a proper alt value. *