Improve get_media_embedded_in_content()
so that it returns the media it finds in the same order that it appears in the content.
Adds unit test, updates another. Props kopepasah. See #26675. git-svn-id: https://develop.svn.wordpress.org/trunk@31574 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
cbb528de0f
commit
65c58832cb
@ -3220,16 +3220,22 @@ function get_attached_media( $type, $post = 0 ) {
|
|||||||
*/
|
*/
|
||||||
function get_media_embedded_in_content( $content, $types = null ) {
|
function get_media_embedded_in_content( $content, $types = null ) {
|
||||||
$html = array();
|
$html = array();
|
||||||
$allowed_media_types = array( 'audio', 'video', 'object', 'embed', 'iframe' );
|
|
||||||
|
$allowed_media_types = apply_filters( 'get_media_embedded_in_content_allowed', array( 'audio', 'video', 'object', 'embed', 'iframe' ) );
|
||||||
|
|
||||||
if ( ! empty( $types ) ) {
|
if ( ! empty( $types ) ) {
|
||||||
if ( ! is_array( $types ) )
|
if ( ! is_array( $types ) ) {
|
||||||
$types = array( $types );
|
$types = array( $types );
|
||||||
|
}
|
||||||
|
|
||||||
$allowed_media_types = array_intersect( $allowed_media_types, $types );
|
$allowed_media_types = array_intersect( $allowed_media_types, $types );
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ( $allowed_media_types as $tag ) {
|
$tags = implode( '|', $allowed_media_types );
|
||||||
if ( preg_match( '#' . get_tag_regex( $tag ) . '#', $content, $matches ) ) {
|
|
||||||
$html[] = $matches[0];
|
if ( preg_match_all( '#<(?P<tag>' . $tags . ')[^<]*?(?:>[\s\S]*?<\/(?P=tag)>|\s*\/>)#', $content, $matches ) ) {
|
||||||
|
foreach ( $matches[0] as $match ) {
|
||||||
|
$html[] = $match;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -378,7 +378,7 @@ $video
|
|||||||
This is a comment
|
This is a comment
|
||||||
CONTENT;
|
CONTENT;
|
||||||
|
|
||||||
$types = array( 'audio', 'video', 'object', 'embed', 'iframe' );
|
$types = array( 'object', 'embed', 'iframe', 'audio', 'video' );
|
||||||
$contents = array_values( compact( $types ) );
|
$contents = array_values( compact( $types ) );
|
||||||
|
|
||||||
$matches = get_media_embedded_in_content( $content, 'audio' );
|
$matches = get_media_embedded_in_content( $content, 'audio' );
|
||||||
@ -400,6 +400,27 @@ CONTENT;
|
|||||||
$this->assertEquals( $contents, $matches );
|
$this->assertEquals( $contents, $matches );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function test_get_media_embedded_in_content_order() {
|
||||||
|
$audio =<<<AUDIO
|
||||||
|
<audio preload="none">
|
||||||
|
<source />
|
||||||
|
</audio>
|
||||||
|
AUDIO;
|
||||||
|
$video =<<<VIDEO
|
||||||
|
<video preload="none">
|
||||||
|
<source />
|
||||||
|
</video>
|
||||||
|
VIDEO;
|
||||||
|
$content = $audio . $video;
|
||||||
|
|
||||||
|
$matches1 = get_media_embedded_in_content( $content, array( 'audio', 'video' ) );
|
||||||
|
$this->assertEquals( array( $audio, $video ), $matches1 );
|
||||||
|
|
||||||
|
$reversed = $video . $audio;
|
||||||
|
$matches2 = get_media_embedded_in_content( $reversed, array( 'audio', 'video' ) );
|
||||||
|
$this->assertEquals( array( $video, $audio ), $matches2 );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test [video] shortcode processing
|
* Test [video] shortcode processing
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user