Fix some sizing issues with video embeds, and improve video/audio embed shortcode flexibility.
* `loop`, `autoplay`, and `preload` are now available via the shortcode. Use them non-annoyingly, please! * Attributes that pass through the filters are now proper key/value pairs, not an array of `key="value"` strings. * `preload` defaults to `metadata` for videos. This fixes the vertical video preview and Safari ogv/webm playback issues. * Wrap a div around video embeds to combat a ME.js issue with responsive width=100% themes. Props kovshenin. Fixes #24134, #24798. git-svn-id: http://core.svn.wordpress.org/trunk@24789 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
bc0a60920d
commit
290d61138c
|
@ -856,7 +856,12 @@ function wp_audio_shortcode( $attr ) {
|
||||||
$audio = null;
|
$audio = null;
|
||||||
|
|
||||||
$default_types = wp_get_audio_extensions();
|
$default_types = wp_get_audio_extensions();
|
||||||
$defaults_atts = array( 'src' => '' );
|
$defaults_atts = array(
|
||||||
|
'src' => '',
|
||||||
|
'loop' => '',
|
||||||
|
'autoplay' => '',
|
||||||
|
'preload' => 'none'
|
||||||
|
);
|
||||||
foreach ( $default_types as $type )
|
foreach ( $default_types as $type )
|
||||||
$defaults_atts[$type] = '';
|
$defaults_atts[$type] = '';
|
||||||
|
|
||||||
|
@ -900,11 +905,25 @@ function wp_audio_shortcode( $attr ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$atts = array(
|
$atts = array(
|
||||||
sprintf( 'class="%s"', apply_filters( 'wp_audio_shortcode_class', 'wp-audio-shortcode' ) ),
|
'class' => apply_filters( 'wp_audio_shortcode_class', 'wp-audio-shortcode' ),
|
||||||
sprintf( 'id="audio-%d-%d"', $post_id, $instances ),
|
'id' => sprintf( 'audio-%d-%d', $post_id, $instances ),
|
||||||
|
'loop' => $loop,
|
||||||
|
'autoplay' => $autoplay,
|
||||||
|
'preload' => $preload,
|
||||||
);
|
);
|
||||||
|
|
||||||
$html = sprintf( '<audio %s controls="controls" preload="none">', join( ' ', $atts ) );
|
// These ones should just be omitted altogether if they are blank
|
||||||
|
foreach ( array( 'loop', 'autoplay', 'preload' ) as $a ) {
|
||||||
|
if ( empty( $atts[$a] ) )
|
||||||
|
unset( $atts[$a] );
|
||||||
|
}
|
||||||
|
|
||||||
|
$attr_strings = [];
|
||||||
|
foreach ( $atts as $k => $v ) {
|
||||||
|
$attr_strings[] = $k . '="' . esc_attr( $v ) . '"';
|
||||||
|
}
|
||||||
|
|
||||||
|
$html = sprintf( '<audio %s controls="controls">', join( ' ', $attr_strings ) );
|
||||||
|
|
||||||
$fileurl = '';
|
$fileurl = '';
|
||||||
$source = '<source type="%s" src="%s" />';
|
$source = '<source type="%s" src="%s" />';
|
||||||
|
@ -959,6 +978,9 @@ function wp_video_shortcode( $attr ) {
|
||||||
$defaults_atts = array(
|
$defaults_atts = array(
|
||||||
'src' => '',
|
'src' => '',
|
||||||
'poster' => '',
|
'poster' => '',
|
||||||
|
'loop' => '',
|
||||||
|
'autoplay' => '',
|
||||||
|
'preload' => 'metadata',
|
||||||
'height' => 360,
|
'height' => 360,
|
||||||
'width' => empty( $content_width ) ? 640 : $content_width,
|
'width' => empty( $content_width ) ? 640 : $content_width,
|
||||||
);
|
);
|
||||||
|
@ -1018,16 +1040,28 @@ function wp_video_shortcode( $attr ) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$atts = array(
|
$atts = array(
|
||||||
sprintf( 'class="%s"', apply_filters( 'wp_video_shortcode_class', 'wp-video-shortcode' ) ),
|
'class' => apply_filters( 'wp_video_shortcode_class', 'wp-video-shortcode' ),
|
||||||
sprintf( 'id="video-%d-%d"', $post_id, $instances ),
|
'id' => sprintf( 'video-%d-%d', $post_id, $instances ),
|
||||||
sprintf( 'width="%d"', $width ),
|
'width' => absint( $width ),
|
||||||
sprintf( 'height="%d"', $height ),
|
'height' => absint( $height ),
|
||||||
|
'poster' => esc_url( $poster ),
|
||||||
|
'loop' => $loop,
|
||||||
|
'autoplay' => $autoplay,
|
||||||
|
'preload' => $preload,
|
||||||
);
|
);
|
||||||
|
|
||||||
if ( ! empty( $poster ) )
|
// These ones should just be omitted altogether if they are blank
|
||||||
$atts[] = sprintf( 'poster="%s"', esc_url( $poster ) );
|
foreach ( array( 'poster', 'loop', 'autoplay', 'preload' ) as $a ) {
|
||||||
|
if ( empty( $atts[$a] ) )
|
||||||
|
unset( $atts[$a] );
|
||||||
|
}
|
||||||
|
|
||||||
$html = sprintf( '<video %s controls="controls" preload="none">', join( ' ', $atts ) );
|
$attr_strings = [];
|
||||||
|
foreach ( $atts as $k => $v ) {
|
||||||
|
$attr_strings[] = $k . '="' . esc_attr( $v ) . '"';
|
||||||
|
}
|
||||||
|
|
||||||
|
$html = sprintf( '<video %s controls="controls">', join( ' ', $attr_strings ) );
|
||||||
|
|
||||||
$fileurl = '';
|
$fileurl = '';
|
||||||
$source = '<source type="%s" src="%s" />';
|
$source = '<source type="%s" src="%s" />';
|
||||||
|
@ -1046,6 +1080,7 @@ function wp_video_shortcode( $attr ) {
|
||||||
$html .= wp_mediaelement_fallback( $fileurl );
|
$html .= wp_mediaelement_fallback( $fileurl );
|
||||||
$html .= '</video>';
|
$html .= '</video>';
|
||||||
|
|
||||||
|
$html = sprintf( '<div style="width: %dpx; max-width: 100%%;">%s</div>', $width, $html );
|
||||||
return apply_filters( 'wp_video_shortcode', $html, $atts, $video, $post_id );
|
return apply_filters( 'wp_video_shortcode', $html, $atts, $video, $post_id );
|
||||||
}
|
}
|
||||||
add_shortcode( 'video', apply_filters( 'wp_video_shortcode_handler', 'wp_video_shortcode' ) );
|
add_shortcode( 'video', apply_filters( 'wp_video_shortcode_handler', 'wp_video_shortcode' ) );
|
||||||
|
|
Loading…
Reference in New Issue