Enforce video dimensions.

props wonderboymusic. see #23831.

git-svn-id: http://core.svn.wordpress.org/trunk@23969 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Mark Jaquith 2013-04-11 22:34:05 +00:00
parent 03e8599e07
commit 4a3ced1433
3 changed files with 67 additions and 15 deletions

View File

@ -110,10 +110,21 @@ window.wp = window.wp || {};
} }
}); });
mediaPreview = function (format, url, mime) { mediaPreview = function (attachment) {
var dimensions = '', url = attachment.url,
mime = attachment.mime,
format = attachment.type;
if ( 'video' === format ) {
if ( attachment.width )
dimensions += ' width="' + attachment.width + '"';
if ( attachment.height )
dimensions += ' height="' + attachment.height + '"';
}
$('#' + format + '-preview').remove(); $('#' + format + '-preview').remove();
$holder.parent().prepend( '<div id="' + format + '-preview" class="wp-format-media-preview">' + $holder.parent().prepend( '<div id="' + format + '-preview" class="wp-format-media-preview">' +
'<' + format + ' class="wp-' + format + '-shortcode" controls="controls" preload="none">' + '<' + format + dimensions + ' class="wp-' + format + '-shortcode" controls="controls" preload="none">' +
'<source type="' + mime + '" src="' + url + '" />' + '<source type="' + mime + '" src="' + url + '" />' +
'</' + format + '></div>' ); '</' + format + '></div>' );
$('.wp-' + format + '-shortcode').mediaelementplayer(); $('.wp-' + format + '-shortcode').mediaelementplayer();
@ -122,25 +133,25 @@ window.wp = window.wp || {};
// When an image is selected, run a callback. // When an image is selected, run a callback.
mediaFrame.on( 'select', function () { mediaFrame.on( 'select', function () {
// Grab the selected attachment. // Grab the selected attachment.
var attachment = mediaFrame.state().get('selection').first(), mime, url, id; var attachment = mediaFrame.state().get('selection').first().toJSON();
id = attachment.get('id'); if ( 0 === attachment.mime.indexOf('audio') ) {
url = attachment.get('url'); $field.val(attachment.url);
mime = attachment.get('mime');
if ( 0 === mime.indexOf('audio') ) {
$field.val(url);
// show one preview at a time // show one preview at a time
mediaPreview('audio', url, mime); mediaPreview(attachment);
} else if ( 0 === mime.indexOf('video') ) { } else if ( 0 === attachment.mime.indexOf('video') ) {
$field.val(url); attachment.src = attachment.url;
$field.val(wp.shortcode.string({
tag: 'video',
attrs: _.pick( attachment, 'src', 'width', 'height' )
}));
// show one preview at a time // show one preview at a time
mediaPreview('video', url, mime); mediaPreview(attachment);
} else { } else {
// set the hidden input's value // set the hidden input's value
$field.val(id); $field.val(attachment.id);
// Show the image in the placeholder // Show the image in the placeholder
$el.html('<img src="' + url + '" />'); $el.html('<img src="' + attachment.url + '" />');
$holder.removeClass('empty').show(); $holder.removeClass('empty').show();
} }
}); });

View File

@ -144,6 +144,12 @@
shortcode = {}; shortcode = {};
if ( attachment.width )
shortcode.width = attachment.width;
if ( attachment.height )
shortcode.height = attachment.height;
if ( props.mime ) { if ( props.mime ) {
switch ( props.mime ) { switch ( props.mime ) {
case 'video/mp4': case 'video/mp4':

View File

@ -1638,6 +1638,11 @@ function wp_prepare_attachment_for_js( $attachment ) {
} }
$response = array_merge( $response, array( 'sizes' => $sizes ), $sizes['full'] ); $response = array_merge( $response, array( 'sizes' => $sizes ), $sizes['full'] );
} elseif ( $meta && 'video' === $type ) {
if ( isset( $meta['width'] ) )
$response['width'] = (int) $meta['width'];
if ( isset( $meta['height'] ) )
$response['height'] = (int) $meta['height'];
} }
if ( function_exists('get_compat_media_markup') ) if ( function_exists('get_compat_media_markup') )
@ -2014,6 +2019,15 @@ function wp_video_embed( $matches, $attr, $url, $rawattr ) {
if ( ! empty( $rawattr['width'] ) && ! empty( $rawattr['height'] ) ) { if ( ! empty( $rawattr['width'] ) && ! empty( $rawattr['height'] ) ) {
$dimensions .= sprintf( 'width="%d" ', (int) $rawattr['width'] ); $dimensions .= sprintf( 'width="%d" ', (int) $rawattr['width'] );
$dimensions .= sprintf( 'height="%d" ', (int) $rawattr['height'] ); $dimensions .= sprintf( 'height="%d" ', (int) $rawattr['height'] );
} elseif ( strstr( $url, home_url() ) ) {
$id = attachment_url_to_postid( $url );
if ( ! empty( $id ) ) {
$meta = wp_get_attachment_metadata( $id );
if ( ! empty( $meta['width'] ) )
$dimensions .= sprintf( 'width="%d" ', (int) $meta['width'] );
if ( ! empty( $meta['height'] ) )
$dimensions .= sprintf( 'height="%d" ', (int) $meta['height'] );
}
} }
$video = do_shortcode( '[video ' . $dimensions . 'src="' . $url . '" /]' ); $video = do_shortcode( '[video ' . $dimensions . 'src="' . $url . '" /]' );
} }
@ -2438,3 +2452,24 @@ function get_the_post_format_image( $attached_size = 'full', &$post = null ) {
function the_post_format_image( $attached_size = 'full' ) { function the_post_format_image( $attached_size = 'full' ) {
echo get_the_post_format_image( $attached_size ); echo get_the_post_format_image( $attached_size );
} }
/**
* Retrieve the post id for an attachment file URL
*
* @since 3.6.0
*
* @param string $url Permalink to check.
* @return int Post ID, or 0 on failure.
*/
function attachment_url_to_postid( $url ) {
global $wpdb;
if ( preg_match( '#\.[a-zA-Z0-9]+$#', $url ) ) {
$id = $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_type = 'attachment' " .
"AND guid = %s", $url ) );
if ( ! empty( $id ) )
return (int) $id;
}
return 0;
}