2012-12-06 08:10:20 +01:00
< ? php
/**
* WordPress media templates .
*
* @ package WordPress
* @ subpackage Media
* @ since 3.5 . 0
*/
2014-03-14 13:20:15 +01:00
/**
* Output the markup for a audio tag to be used in an Underscore template
* when data . model is passed .
*
* @ since 3.9 . 0
*/
function wp_underscore_audio_template () {
$audio_types = wp_get_audio_extensions ();
?>
< audio controls
class = " wp-audio-shortcode "
2014-03-26 13:11:14 +01:00
width = " { { _.isUndefined( data.model.width ) ? 400 : data.model.width }} "
2014-03-14 13:20:15 +01:00
preload = " { { _.isUndefined( data.model.preload ) ? 'none' : data.model.preload }} "
< #
< ? php foreach ( array ( 'autoplay' , 'loop' ) as $attr ) :
?> if ( ! _.isUndefined( data.model.<?php echo $attr ?> ) && data.model.<?php echo $attr ?> ) {
#> <?php echo $attr ?><#
}
< ? php endforeach ?> #>
>
< # if ( ! _.isEmpty( data.model.src ) ) { #>
< source src = " { { data.model.src }} " type = " { { wp.media.view.settings.embedMimes[ data.model.src.split('.').pop() ] }} " />
< # } #>
< ? php foreach ( $audio_types as $type ) :
?> <# if ( ! _.isEmpty( data.model.<?php echo $type ?> ) ) { #>
< source src = " { { data.model.<?php echo $type ?> }} " type = " { { wp.media.view.settings.embedMimes[ '<?php echo $type ?>' ] }} " />
< # } #>
< ? php endforeach ;
?> </audio>
< ? php
}
/**
* Output the markup for a video tag to be used in an Underscore template
* when data . model is passed .
*
* @ since 3.9 . 0
*/
function wp_underscore_video_template () {
$video_types = wp_get_video_extensions ();
?>
2014-03-23 00:26:17 +01:00
< # var w, h, settings = wp.media.view.settings,
isYouTube = ! _ . isEmpty ( data . model . src ) && data . model . src . match ( / youtube | youtu\ . be / );
2014-03-14 13:20:15 +01:00
2014-03-23 00:26:17 +01:00
if ( settings . contentWidth && data . model . width >= settings . contentWidth ) {
w = settings . contentWidth ;
} else {
w = data . model . width ;
}
if ( w !== data . model . width ) {
h = Math . ceil ( ( h * w ) / data . model . width );
} else {
h = data . model . height ;
}
2014-03-14 13:20:15 +01:00
#>
< div style = " max-width: 100%; width: { { w }}px " >
< video controls
class = " wp-video-shortcode { { isYouTube ? ' youtube-video' : '' }} "
width = " { { w }} "
height = " { { h }} "
< ? php
$props = array ( 'poster' => '' , 'preload' => 'metadata' );
foreach ( $props as $key => $value ) :
if ( empty ( $value ) ) {
?> <#
if ( ! _ . isUndefined ( data . model .< ? php echo $key ?> ) && data.model.<?php echo $key ?> ) {
#> <?php echo $key ?>="{{ data.model.<?php echo $key ?> }}"<#
} #>
< ? php } else {
echo $key ?> ="{{ _.isUndefined( data.model.<?php echo $key ?> ) ? '<?php echo $value ?>' : data.model.<?php echo $key ?> }}"<?php
}
endforeach ;
?> <#
< ? php foreach ( array ( 'autoplay' , 'loop' ) as $attr ) :
?> if ( ! _.isUndefined( data.model.<?php echo $attr ?> ) && data.model.<?php echo $attr ?> ) {
#> <?php echo $attr ?><#
}
< ? php endforeach ?> #>
>
< # if ( ! _.isEmpty( data.model.src ) ) {
if ( isYouTube ) { #>
< source src = " { { data.model.src }} " type = " video/youtube " />
< # } else { #>
2014-03-23 00:26:17 +01:00
< source src = " { { data.model.src }} " type = " { { settings.embedMimes[ data.model.src.split('.').pop() ] }} " />
2014-03-14 13:20:15 +01:00
< # }
} #>
< ? php foreach ( $video_types as $type ) :
?> <# if ( data.model.<?php echo $type ?> ) { #>
2014-03-23 00:26:17 +01:00
< source src = " { { data.model.<?php echo $type ?> }} " type = " { { settings.embedMimes[ '<?php echo $type ?>' ] }} " />
2014-03-14 13:20:15 +01:00
< # } #>
< ? php endforeach ; ?>
{{{ data . model . content }}}
</ video >
</ div >
< ? php
}
2012-12-06 08:10:20 +01:00
/**
* Prints the templates used in the media manager .
*
* @ since 3.5 . 0
*/
function wp_print_media_templates () {
global $is_IE ;
$class = 'media-modal wp-core-ui' ;
if ( $is_IE && strpos ( $_SERVER [ 'HTTP_USER_AGENT' ], 'MSIE 7' ) !== false )
$class .= ' ie7' ;
?>
< script type = " text/html " id = " tmpl-media-frame " >
< div class = " media-frame-menu " ></ div >
< div class = " media-frame-title " ></ div >
< div class = " media-frame-router " ></ div >
< div class = " media-frame-content " ></ div >
< div class = " media-frame-toolbar " ></ div >
< div class = " media-frame-uploader " ></ div >
</ script >
< script type = " text/html " id = " tmpl-media-modal " >
< div class = " <?php echo $class ; ?> " >
< a class = " media-modal-close " href = " # " title = " <?php esc_attr_e('Close'); ?> " >< span class = " media-modal-icon " ></ span ></ a >
< div class = " media-modal-content " ></ div >
</ div >
< div class = " media-modal-backdrop " ></ div >
</ script >
< script type = " text/html " id = " tmpl-uploader-window " >
< div class = " uploader-window-content " >
2014-03-01 22:34:17 +01:00
< h3 >< ? php _e ( 'Drop files to upload' ); ?> </h3>
</ div >
</ script >
< script type = " text/html " id = " tmpl-uploader-editor " >
< div class = " uploader-editor-content " >
2014-03-23 02:42:15 +01:00
< div class = " uploader-editor-title " >< ? php _e ( 'Drop files to upload' ); ?> </div>
2012-12-06 08:10:20 +01:00
</ div >
</ script >
< script type = " text/html " id = " tmpl-uploader-inline " >
< # var messageClass = data.message ? 'has-upload-message' : 'no-upload-message'; #>
< div class = " uploader-inline-content { { messageClass }} " >
< # if ( data.message ) { #>
< h3 class = " upload-message " > {{ data . message }} </ h3 >
< # } #>
< ? php if ( ! _device_can_upload () ) : ?>
2014-03-03 03:34:27 +01:00
< h3 class = " upload-instructions " >< ? php printf ( __ ( 'The web browser on your device cannot be used to upload files. You may be able to use the <a href="%s">native app for your device</a> instead.' ), 'https://wordpress.org/mobile/' ); ?> </h3>
2012-12-06 08:10:20 +01:00
< ? php elseif ( is_multisite () && ! is_upload_space_available () ) : ?>
< h3 class = " upload-instructions " >< ? php _e ( 'Upload Limit Exceeded' ); ?> </h3>
2013-11-26 08:52:08 +01:00
< ? php
/** This action is documented in wp-admin/includes/media.php */
do_action ( 'upload_ui_over_quota' ); ?>
2012-12-06 08:10:20 +01:00
< ? php else : ?>
< div class = " upload-ui " >
< h3 class = " upload-instructions drop-instructions " >< ? php _e ( 'Drop files anywhere to upload' ); ?> </h3>
< a href = " # " class = " browser button button-hero " >< ? php _e ( 'Select Files' ); ?> </a>
</ div >
< div class = " upload-inline-status " ></ div >
< div class = " post-upload-ui " >
< ? php
2013-11-26 08:52:08 +01:00
/** This action is documented in wp-admin/includes/media.php */
2012-12-06 08:10:20 +01:00
do_action ( 'pre-upload-ui' );
2013-11-26 08:52:08 +01:00
/** This action is documented in wp-admin/includes/media.php */
2012-12-06 08:10:20 +01:00
do_action ( 'pre-plupload-upload-ui' );
if ( 10 === remove_action ( 'post-plupload-upload-ui' , 'media_upload_flash_bypass' ) ) {
2013-11-26 08:52:08 +01:00
/** This action is documented in wp-admin/includes/media.php */
2012-12-06 08:10:20 +01:00
do_action ( 'post-plupload-upload-ui' );
add_action ( 'post-plupload-upload-ui' , 'media_upload_flash_bypass' );
} else {
2013-11-26 08:52:08 +01:00
/** This action is documented in wp-admin/includes/media.php */
2012-12-06 08:10:20 +01:00
do_action ( 'post-plupload-upload-ui' );
}
$upload_size_unit = $max_upload_size = wp_max_upload_size ();
$byte_sizes = array ( 'KB' , 'MB' , 'GB' );
for ( $u = - 1 ; $upload_size_unit > 1024 && $u < count ( $byte_sizes ) - 1 ; $u ++ ) {
$upload_size_unit /= 1024 ;
}
if ( $u < 0 ) {
$upload_size_unit = 0 ;
$u = 0 ;
} else {
$upload_size_unit = ( int ) $upload_size_unit ;
}
?>
< p class = " max-upload-size " >< ? php
printf ( __ ( 'Maximum upload file size: %d%s.' ), esc_html ( $upload_size_unit ), esc_html ( $byte_sizes [ $u ]) );
?> </p>
2013-11-26 08:52:08 +01:00
< ? php
/** This action is documented in wp-admin/includes/media.php */
do_action ( 'post-upload-ui' ); ?>
2012-12-06 08:10:20 +01:00
</ div >
< ? php endif ; ?>
</ div >
</ script >
< script type = " text/html " id = " tmpl-uploader-status " >
< h3 >< ? php _e ( 'Uploading' ); ?> </h3>
< a class = " upload-dismiss-errors " href = " # " >< ? php _e ( 'Dismiss Errors' ); ?> </a>
< div class = " media-progress-bar " >< div ></ div ></ div >
< div class = " upload-details " >
< span class = " upload-count " >
< span class = " upload-index " ></ span > / < span class = " upload-total " ></ span >
</ span >
< span class = " upload-detail-separator " >& ndash ; </ span >
< span class = " upload-filename " ></ span >
</ div >
< div class = " upload-errors " ></ div >
</ script >
< script type = " text/html " id = " tmpl-uploader-status-error " >
< span class = " upload-error-label " >< ? php _e ( 'Error' ); ?> </span>
< span class = " upload-error-filename " > {{{ data . filename }}} </ span >
< span class = " upload-error-message " > {{ data . message }} </ span >
</ script >
< script type = " text/html " id = " tmpl-attachment " >
< div class = " attachment-preview type- { { data.type }} subtype- { { data.subtype }} { { data.orientation }} " >
< # if ( data.uploading ) { #>
< div class = " media-progress-bar " >< div ></ div ></ div >
< # } else if ( 'image' === data.type ) { #>
< div class = " thumbnail " >
< div class = " centered " >
< img src = " { { data.size.url }} " draggable = " false " />
</ div >
</ div >
< # } else { #>
< img src = " { { data.icon }} " class = " icon " draggable = " false " />
< div class = " filename " >
< div > {{ data . filename }} </ div >
</ div >
< # } #>
< # if ( data.buttons.close ) { #>
2014-03-04 22:10:15 +01:00
< a class = " close media-modal-icon " href = " # " title = " <?php esc_attr_e('Remove'); ?> " ></ a >
2012-12-06 08:10:20 +01:00
< # } #>
< # if ( data.buttons.check ) { #>
2014-03-04 22:10:15 +01:00
< a class = " check " href = " # " title = " <?php esc_attr_e('Deselect'); ?> " >< div class = " media-modal-icon " ></ div ></ a >
2012-12-06 08:10:20 +01:00
< # } #>
</ div >
< #
var maybeReadOnly = data . can . save || data . allowLocalEdits ? '' : 'readonly' ;
if ( data . describe ) { #>
< # if ( 'image' === data.type ) { #>
< input type = " text " value = " { { data.caption }} " class = " describe " data - setting = " caption "
2012-12-09 18:11:25 +01:00
placeholder = " <?php esc_attr_e('Caption this image…'); ?> " {{ maybeReadOnly }} />
2012-12-06 08:10:20 +01:00
< # } else { #>
< input type = " text " value = " { { data.title }} " class = " describe " data - setting = " title "
< # if ( 'video' === data.type ) { #>
placeholder = " <?php esc_attr_e('Describe this video…'); ?> "
< # } else if ( 'audio' === data.type ) { #>
placeholder = " <?php esc_attr_e('Describe this audio file…'); ?> "
< # } else { #>
placeholder = " <?php esc_attr_e('Describe this media file…'); ?> "
< # } #> {{ maybeReadOnly }} />
< # } #>
< # } #>
</ script >
< script type = " text/html " id = " tmpl-attachment-details " >
< h3 >
< ? php _e ( 'Attachment Details' ); ?>
< span class = " settings-save-status " >
< span class = " spinner " ></ span >
< span class = " saved " >< ? php esc_html_e ( 'Saved.' ); ?> </span>
</ span >
</ h3 >
< div class = " attachment-info " >
< div class = " thumbnail " >
< # if ( data.uploading ) { #>
< div class = " media-progress-bar " >< div ></ div ></ div >
< # } else if ( 'image' === data.type ) { #>
< img src = " { { data.size.url }} " draggable = " false " />
< # } else { #>
< img src = " { { data.icon }} " class = " icon " draggable = " false " />
< # } #>
</ div >
< div class = " details " >
< div class = " filename " > {{ data . filename }} </ div >
< div class = " uploaded " > {{ data . dateFormatted }} </ div >
< # if ( 'image' === data.type && ! data.uploading ) { #>
< # if ( data.width && data.height ) { #>
< div class = " dimensions " > {{ data . width }} & times ; {{ data . height }} </ div >
< # } #>
< # if ( data.can.save ) { #>
< a class = " edit-attachment " href = " { { data.editLink }}&image-editor " target = " _blank " >< ? php _e ( 'Edit Image' ); ?> </a>
< a class = " refresh-attachment " href = " # " >< ? php _e ( 'Refresh' ); ?> </a>
< # } #>
< # } #>
2013-07-23 07:39:08 +02:00
< # if ( data.fileLength ) { #>
< div class = " file-length " >< ? php _e ( 'Length:' ); ?> {{ data.fileLength }}</div>
< # } #>
2012-12-06 08:10:20 +01:00
< # if ( ! data.uploading && data.can.remove ) { #>
2014-03-07 17:42:14 +01:00
< ? php if ( MEDIA_TRASH ) : ?>
< a class = " trash-attachment " href = " # " >< ? php _e ( 'Trash' ); ?> </a>
< ? php else : ?>
< a class = " delete-attachment " href = " # " >< ? php _e ( 'Delete Permanently' ); ?> </a>
< ? php endif ; ?>
2012-12-06 08:10:20 +01:00
< # } #>
< div class = " compat-meta " >
< # if ( data.compat && data.compat.meta ) { #>
{{{ data . compat . meta }}}
< # } #>
</ div >
</ div >
</ div >
< # var maybeReadOnly = data.can.save || data.allowLocalEdits ? '' : 'readonly'; #>
< label class = " setting " data - setting = " title " >
< span >< ? php _e ( 'Title' ); ?> </span>
< input type = " text " value = " { { data.title }} " {{ maybeReadOnly }} />
</ label >
< label class = " setting " data - setting = " caption " >
< span >< ? php _e ( 'Caption' ); ?> </span>
< textarea {{ maybeReadOnly }} > {{ data . caption }} </ textarea >
</ label >
< # if ( 'image' === data.type ) { #>
< label class = " setting " data - setting = " alt " >
< span >< ? php _e ( 'Alt Text' ); ?> </span>
< input type = " text " value = " { { data.alt }} " {{ maybeReadOnly }} />
</ label >
< # } #>
< label class = " setting " data - setting = " description " >
< span >< ? php _e ( 'Description' ); ?> </span>
< textarea {{ maybeReadOnly }} > {{ data . description }} </ textarea >
</ label >
</ script >
< script type = " text/html " id = " tmpl-media-selection " >
< div class = " selection-info " >
< span class = " count " ></ span >
< # if ( data.editable ) { #>
< a class = " edit-selection " href = " # " >< ? php _e ( 'Edit' ); ?> </a>
< # } #>
< # if ( data.clearable ) { #>
< a class = " clear-selection " href = " # " >< ? php _e ( 'Clear' ); ?> </a>
< # } #>
</ div >
< div class = " selection-view " ></ div >
</ script >
< script type = " text/html " id = " tmpl-attachment-display-settings " >
< h3 >< ? php _e ( 'Attachment Display Settings' ); ?> </h3>
< # if ( 'image' === data.type ) { #>
< label class = " setting " >
< span >< ? php _e ( 'Alignment' ); ?> </span>
< select class = " alignment "
data - setting = " align "
< # if ( data.userSettings ) { #>
data - user - setting = " align "
< # } #>>
< option value = " left " >
< ? php esc_attr_e ( 'Left' ); ?>
</ option >
< option value = " center " >
< ? php esc_attr_e ( 'Center' ); ?>
</ option >
< option value = " right " >
< ? php esc_attr_e ( 'Right' ); ?>
</ option >
< option value = " none " selected >
< ? php esc_attr_e ( 'None' ); ?>
</ option >
</ select >
</ label >
< # } #>
< div class = " setting " >
< label >
2013-07-23 07:39:08 +02:00
< # if ( data.model.canEmbed ) { #>
< span >< ? php _e ( 'Embed or Link' ); ?> </span>
< # } else { #>
< span >< ? php _e ( 'Link To' ); ?> </span>
< # } #>
2012-12-06 08:10:20 +01:00
< select class = " link-to "
data - setting = " link "
2013-07-23 07:39:08 +02:00
< # if ( data.userSettings && ! data.model.canEmbed ) { #>
2012-12-06 08:10:20 +01:00
data - user - setting = " urlbutton "
< # } #>>
2013-07-23 19:29:55 +02:00
< # if ( data.model.canEmbed ) { #>
2013-07-23 07:39:08 +02:00
< option value = " embed " selected >
2013-07-23 19:29:55 +02:00
< ? php esc_attr_e ( 'Embed Media Player' ); ?>
2013-07-23 07:39:08 +02:00
</ option >
< option value = " file " >
< # } else { #>
2013-01-04 09:02:16 +01:00
< option value = " file " selected >
2013-07-23 07:39:08 +02:00
< # } #>
< # if ( data.model.canEmbed ) { #>
< ? php esc_attr_e ( 'Link to Media File' ); ?>
< # } else { #>
2012-12-06 08:10:20 +01:00
< ? php esc_attr_e ( 'Media File' ); ?>
2013-07-23 07:39:08 +02:00
< # } #>
2012-12-06 08:10:20 +01:00
</ option >
2013-01-04 09:02:16 +01:00
< option value = " post " >
2013-07-23 07:39:08 +02:00
< # if ( data.model.canEmbed ) { #>
< ? php esc_attr_e ( 'Link to Attachment Page' ); ?>
< # } else { #>
2013-01-04 09:02:16 +01:00
< ? php esc_attr_e ( 'Attachment Page' ); ?>
2013-07-23 07:39:08 +02:00
< # } #>
</ option >
< # if ( 'image' === data.type ) { #>
< option value = " custom " >
< ? php esc_attr_e ( 'Custom URL' ); ?>
2013-01-04 09:02:16 +01:00
</ option >
2012-12-06 08:10:20 +01:00
< option value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ option >
2013-07-23 07:39:08 +02:00
< # } #>
2012-12-06 08:10:20 +01:00
</ select >
</ label >
< input type = " text " class = " link-to-custom " data - setting = " linkUrl " />
</ div >
< # if ( 'undefined' !== typeof data.sizes ) { #>
< label class = " setting " >
< span >< ? php _e ( 'Size' ); ?> </span>
< select class = " size " name = " size "
data - setting = " size "
< # if ( data.userSettings ) { #>
data - user - setting = " imgsize "
< # } #>>
< ? php
2013-10-25 00:59:20 +02:00
/** This filter is documented in wp-admin/includes/media.php */
2012-12-06 08:10:20 +01:00
$sizes = apply_filters ( 'image_size_names_choose' , array (
'thumbnail' => __ ( 'Thumbnail' ),
'medium' => __ ( 'Medium' ),
'large' => __ ( 'Large' ),
'full' => __ ( 'Full Size' ),
) );
foreach ( $sizes as $value => $name ) : ?>
< #
var size = data . sizes [ '<?php echo esc_js( $value ); ?>' ];
if ( size ) { #>
< option value = " <?php echo esc_attr( $value ); ?> " < ? php selected ( $value , 'full' ); ?> >
< ? php echo esc_html ( $name ); ?> – {{ size.width }} × {{ size.height }}
</ option >
< # } #>
< ? php endforeach ; ?>
</ select >
</ label >
< # } #>
</ script >
< script type = " text/html " id = " tmpl-gallery-settings " >
< h3 >< ? php _e ( 'Gallery Settings' ); ?> </h3>
< label class = " setting " >
< span >< ? php _e ( 'Link To' ); ?> </span>
< select class = " link-to "
data - setting = " link "
< # if ( data.userSettings ) { #>
data - user - setting = " urlbutton "
< # } #>>
2013-05-03 00:07:37 +02:00
< option value = " post " selected >
2013-01-04 09:02:16 +01:00
< ? php esc_attr_e ( 'Attachment Page' ); ?>
</ option >
2013-05-03 00:07:37 +02:00
< option value = " file " >
< ? php esc_attr_e ( 'Media File' ); ?>
</ option >
2013-07-03 22:43:19 +02:00
< option value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ option >
2012-12-06 08:10:20 +01:00
</ select >
</ label >
< label class = " setting " >
< span >< ? php _e ( 'Columns' ); ?> </span>
< select class = " columns " name = " columns "
data - setting = " columns " >
< ? php for ( $i = 1 ; $i <= 9 ; $i ++ ) : ?>
< option value = " <?php echo esc_attr( $i ); ?> " < ? php selected ( $i , 3 ); ?> >
< ? php echo esc_html ( $i ); ?>
</ option >
< ? php endfor ; ?>
</ select >
</ label >
< label class = " setting " >
2012-12-09 18:11:25 +01:00
< span >< ? php _e ( 'Random Order' ); ?> </span>
2012-12-06 08:10:20 +01:00
< input type = " checkbox " data - setting = " _orderbyRandom " />
</ label >
</ script >
2014-02-24 19:08:16 +01:00
< script type = " text/html " id = " tmpl-playlist-settings " >
2014-02-24 20:50:15 +01:00
< h3 >< ? php _e ( 'Playlist Settings' ); ?> </h3>
2014-02-24 19:08:16 +01:00
2014-03-27 18:58:15 +01:00
< # var emptyModel = _.isEmpty( data.model ); #>
2014-03-10 00:19:15 +01:00
< label class = " setting " >
2014-03-27 18:58:15 +01:00
< input type = " checkbox " data - setting = " tracklist " < # if ( emptyModel ) { #>
2014-02-24 21:26:14 +01:00
checked = " checked "
< # } #> />
2014-03-10 00:19:15 +01:00
< span >< ? php _e ( 'Show Tracklist' ); ?> </span>
2014-02-24 19:08:16 +01:00
</ label >
2014-03-27 18:58:15 +01:00
< # if ( 'audio' === data.model.type ) { #>
2014-02-24 19:08:16 +01:00
< label class = " setting " >
2014-03-27 18:58:15 +01:00
< input type = " checkbox " data - setting = " artists " < # if ( emptyModel ) { #>
2014-02-24 21:26:14 +01:00
checked = " checked "
< # } #> />
2014-03-10 00:19:15 +01:00
< span >< ? php _e ( 'Show Artist Name in Tracklist' ); ?> </span>
2014-02-24 19:08:16 +01:00
</ label >
2014-03-26 23:12:16 +01:00
< # } #>
2014-02-24 19:08:16 +01:00
< label class = " setting " >
2014-02-27 20:22:14 +01:00
< input type = " checkbox " data - setting = " images " < # if ( emptyModel ) { #>
2014-02-24 21:26:14 +01:00
checked = " checked "
< # } #> />
2014-03-10 00:19:15 +01:00
< span >< ? php _e ( 'Show Images' ); ?> </span>
2014-02-24 19:08:16 +01:00
</ label >
</ script >
2012-12-06 08:10:20 +01:00
< script type = " text/html " id = " tmpl-embed-link-settings " >
< label class = " setting " >
< span >< ? php _e ( 'Title' ); ?> </span>
< input type = " text " class = " alignment " data - setting = " title " />
</ label >
</ script >
< script type = " text/html " id = " tmpl-embed-image-settings " >
< div class = " thumbnail " >
< img src = " { { data.model.url }} " draggable = " false " />
</ div >
2013-11-26 08:52:08 +01:00
< ? php
/** This filter is documented in wp-admin/includes/media.php */
if ( ! apply_filters ( 'disable_captions' , '' ) ) : ?>
2012-12-06 08:10:20 +01:00
< label class = " setting caption " >
< span >< ? php _e ( 'Caption' ); ?> </span>
< textarea data - setting = " caption " />
</ label >
< ? php endif ; ?>
< label class = " setting alt-text " >
< span >< ? php _e ( 'Alt Text' ); ?> </span>
< input type = " text " data - setting = " alt " />
</ label >
< div class = " setting align " >
< span >< ? php _e ( 'Align' ); ?> </span>
< div class = " button-group button-large " data - setting = " align " >
< button class = " button " value = " left " >
< ? php esc_attr_e ( 'Left' ); ?>
</ button >
< button class = " button " value = " center " >
< ? php esc_attr_e ( 'Center' ); ?>
</ button >
< button class = " button " value = " right " >
< ? php esc_attr_e ( 'Right' ); ?>
</ button >
< button class = " button active " value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ button >
</ div >
</ div >
< div class = " setting link-to " >
< span >< ? php _e ( 'Link To' ); ?> </span>
< div class = " button-group button-large " data - setting = " link " >
< button class = " button " value = " file " >
< ? php esc_attr_e ( 'Image URL' ); ?>
</ button >
< button class = " button " value = " custom " >
< ? php esc_attr_e ( 'Custom URL' ); ?>
</ button >
< button class = " button active " value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ button >
</ div >
< input type = " text " class = " link-to-custom " data - setting = " linkUrl " />
</ div >
</ script >
< script type = " text/html " id = " tmpl-attachments-css " >
< style type = " text/css " id = " { { data.id }}-css " >
#{{ data.id }} {
padding : 0 {{ data . gutter }} px ;
}
#{{ data.id }} .attachment {
margin : {{ data . gutter }} px ;
width : {{ data . edge }} px ;
}
#{{ data.id }} .attachment-preview,
#{{ data.id }} .attachment-preview .thumbnail {
width : {{ data . edge }} px ;
height : {{ data . edge }} px ;
}
#{{ data.id }} .portrait .thumbnail img {
max - width : {{ data . edge }} px ;
height : auto ;
}
#{{ data.id }} .landscape .thumbnail img {
width : auto ;
max - height : {{ data . edge }} px ;
}
</ style >
</ script >
2014-01-28 22:17:12 +01:00
< script type = " text/html " id = " tmpl-image-details " >
< ? php // reusing .media-embed to pick up the styles for now ?>
< div class = " media-embed " >
2014-03-05 16:06:14 +01:00
< div class = " embed-media-settings " >
2014-01-28 22:17:12 +01:00
< div class = " thumbnail " >
< img src = " { { data.model.url }} " draggable = " false " />
</ div >
2014-03-19 22:16:14 +01:00
< # if ( data.attachment && window.imageEdit ) { #>
2014-03-06 23:55:14 +01:00
< input type = " button " class = " edit-attachment button " value = " <?php esc_attr_e( 'Edit Image' ); ?> " />
< # } #>
2014-01-28 22:17:12 +01:00
< div class = " setting url " >
< ? php // might want to make the url editable if it isn't an attachment ?>
< input type = " text " disabled = " disabled " value = " { { data.model.url }} " />
</ div >
< ? php
/** This filter is documented in wp-admin/includes/media.php */
if ( ! apply_filters ( 'disable_captions' , '' ) ) : ?>
< label class = " setting caption " >
< span >< ? php _e ( 'Caption' ); ?> </span>
< textarea data - setting = " caption " > {{ data . model . caption }} </ textarea >
</ label >
< ? php endif ; ?>
< label class = " setting alt-text " >
< span >< ? php _e ( 'Alt Text' ); ?> </span>
< input type = " text " data - setting = " alt " value = " { { data.model.alt }} " />
</ label >
< div class = " setting align " >
< span >< ? php _e ( 'Align' ); ?> </span>
< div class = " button-group button-large " data - setting = " align " >
< button class = " button " value = " left " >
< ? php esc_attr_e ( 'Left' ); ?>
</ button >
< button class = " button " value = " center " >
< ? php esc_attr_e ( 'Center' ); ?>
</ button >
< button class = " button " value = " right " >
< ? php esc_attr_e ( 'Right' ); ?>
</ button >
< button class = " button active " value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ button >
</ div >
</ div >
< div class = " setting link-to " >
2014-01-29 00:21:13 +01:00
< span >< ? php _e ( 'Link To' ); ?> </span>
2014-01-28 22:17:12 +01:00
< div class = " button-group button-large " data - setting = " link " >
2014-01-29 00:21:13 +01:00
< # if ( data.attachment ) { #>
2014-01-28 22:17:12 +01:00
< button class = " button " value = " file " >
< ? php esc_attr_e ( 'Media File' ); ?>
</ button >
< button class = " button " value = " post " >
< ? php esc_attr_e ( 'Attachment Page' ); ?>
</ button >
2014-01-29 00:21:13 +01:00
< # } else { #>
2014-01-28 22:17:12 +01:00
< button class = " button " value = " file " >
< ? php esc_attr_e ( 'Image URL' ); ?>
</ button >
2014-01-29 00:21:13 +01:00
< # } #>
2014-01-28 22:17:12 +01:00
< button class = " button " value = " custom " >
< ? php esc_attr_e ( 'Custom URL' ); ?>
</ button >
< button class = " button active " value = " none " >
< ? php esc_attr_e ( 'None' ); ?>
</ button >
</ div >
< input type = " text " class = " link-to-custom " data - setting = " linkUrl " />
</ div >
< # if ( data.attachment ) { #>
< div class = " setting size " >
< span >< ? php _e ( 'Size' ); ?> </span>
< div class = " button-group button-large " data - setting = " size " >
< ? php
/** This filter is documented in wp-admin/includes/media.php */
$sizes = apply_filters ( 'image_size_names_choose' , array (
'thumbnail' => __ ( 'Thumbnail' ),
'medium' => __ ( 'Medium' ),
'large' => __ ( 'Large' ),
'full' => __ ( 'Full Size' ),
) );
foreach ( $sizes as $value => $name ) : ?>
2014-01-29 00:21:13 +01:00
< # var size = data.attachment.sizes['<?php echo esc_js( $value ); ?>'];
2014-01-28 22:17:12 +01:00
if ( size ) { #>
< button class = " button " value = " <?php echo esc_attr( $value ); ?> " >
< ? php echo esc_html ( $name ); ?>
</ button >
< # } #>
< ? php endforeach ; ?>
</ div >
</ div >
< # } #>
</ div >
</ div >
</ script >
2014-03-05 16:06:14 +01:00
2014-03-06 23:55:14 +01:00
< script type = " text/html " id = " tmpl-image-editor " >
< div id = " media-head- { { { data.id }}} " ></ div >
< div id = " image-editor- { { { data.id }}} " ></ div >
</ script >
2014-03-05 16:06:14 +01:00
< script type = " text/html " id = " tmpl-audio-details " >
2014-03-23 04:16:14 +01:00
< # var ext, html5types = {
mp3 : wp . media . view . settings . embedMimes . mp3 ,
ogg : wp . media . view . settings . embedMimes . ogg
}; #>
2014-03-19 06:31:15 +01:00
2014-03-09 02:01:14 +01:00
< ? php $audio_types = wp_get_audio_extensions (); ?>
2014-03-09 06:25:15 +01:00
< div class = " media-embed media-embed-details " >
2014-03-05 16:06:14 +01:00
< div class = " embed-media-settings embed-audio-settings " >
2014-03-14 13:20:15 +01:00
< ? php wp_underscore_audio_template () ?>
2014-03-19 06:31:15 +01:00
< # if ( ! _.isEmpty( data.model.src ) ) {
ext = data . model . src . split ( '.' ) . pop ();
if ( html5types [ ext ] ) {
delete html5types [ ext ];
}
#>
2014-03-05 16:06:14 +01:00
< label class = " setting " >
< span > SRC </ span >
2014-03-09 02:01:14 +01:00
< input type = " text " disabled = " disabled " data - setting = " src " value = " { { data.model.src }} " />
2014-03-09 11:32:15 +01:00
< a class = " remove-setting " > {{{ wp . media . view . l10n . remove }}} </ a >
2014-03-05 16:06:14 +01:00
</ label >
< # } #>
< ? php
2014-03-09 02:01:14 +01:00
foreach ( $audio_types as $type ) :
2014-03-19 06:31:15 +01:00
?> <# if ( ! _.isEmpty( data.model.<?php echo $type ?> ) ) {
if ( ! _ . isUndefined ( html5types .< ? php echo $type ?> ) ) {
delete html5types .< ? php echo $type ?> ;
}
#>
2014-03-05 16:06:14 +01:00
< label class = " setting " >
< span >< ? php echo strtoupper ( $type ) ?> </span>
2014-03-09 02:01:14 +01:00
< input type = " text " disabled = " disabled " data - setting = " <?php echo $type ?> " value = " { { data.model.<?php echo $type ?> }} " />
2014-03-09 11:32:15 +01:00
< a class = " remove-setting " > {{{ wp . media . view . l10n . remove }}} </ a >
2014-03-05 16:06:14 +01:00
</ label >
< # } #>
< ? php endforeach ?>
2014-03-19 06:31:15 +01:00
< # if ( ! _.isEmpty( html5types ) ) { #>
< div class = " setting " >
< span > {{{ wp . media . view . l10n . mediaHTML5Text }}} </ span >
< div class = " button-large " >
2014-03-23 04:16:14 +01:00
< # _.each( html5types, function (mime, type) { #>
< button class = " button add-media-source " data - mime = " { { mime }} " > {{ type }} </ button >
2014-03-19 06:31:15 +01:00
< # } ) #>
</ div >
</ div >
< # } #>
2014-03-05 16:06:14 +01:00
< div class = " setting preload " >
< span >< ? php _e ( 'Preload' ); ?> </span>
< div class = " button-group button-large " data - setting = " preload " >
2014-03-21 01:19:16 +01:00
< button class = " button " value = " auto " >< ? php _ex ( 'Auto' , 'auto preload' ); ?> </button>
2014-03-06 20:06:16 +01:00
< button class = " button " value = " metadata " >< ? php _e ( 'Metadata' ); ?> </button>
< button class = " button active " value = " none " >< ? php _e ( 'None' ); ?> </button>
2014-03-05 16:06:14 +01:00
</ div >
</ div >
< label class = " setting checkbox-setting " >
< span >< ? php _e ( 'Autoplay' ); ?> </span>
< input type = " checkbox " data - setting = " autoplay " />
</ label >
< label class = " setting checkbox-setting " >
< span >< ? php _e ( 'Loop' ); ?> </span>
< input type = " checkbox " data - setting = " loop " />
</ label >
2014-03-20 14:33:14 +01:00
< label class = " setting " >
< span >< ? php _e ( 'Caption' ); ?> </span>
< input type = " text " data - setting = " caption " value = " { { data.model.caption }} " />
</ label >
2014-03-05 16:06:14 +01:00
< div class = " clear " ></ div >
</ div >
</ div >
</ script >
< script type = " text/html " id = " tmpl-video-details " >
2014-03-23 04:16:14 +01:00
< # var ext, html5types = {
mp4 : wp . media . view . settings . embedMimes . mp4 ,
ogv : wp . media . view . settings . embedMimes . ogv ,
webm : wp . media . view . settings . embedMimes . webm
}; #>
2014-03-19 06:31:15 +01:00
2014-03-09 02:01:14 +01:00
< ? php $video_types = wp_get_video_extensions (); ?>
2014-03-09 06:25:15 +01:00
< div class = " media-embed media-embed-details " >
2014-03-05 16:06:14 +01:00
< div class = " embed-media-settings embed-video-settings " >
< div class = " wp-video-holder " >
2014-03-14 00:39:16 +01:00
< #
var isYouTube = ! _ . isEmpty ( data . model . src ) && data . model . src . match ( / youtube | youtu\ . be / );
w = ! data . model . width || data . model . width > 640 ? 640 : data . model . width ,
h = ! data . model . height ? 360 : data . model . height ;
if ( data . model . width && w !== data . model . width ) {
h = Math . ceil ( ( h * w ) / data . model . width );
}
#>
2014-03-14 13:20:15 +01:00
< ? php wp_underscore_video_template () ?>
2014-03-19 06:31:15 +01:00
< # if ( ! _.isEmpty( data.model.src ) ) {
ext = data . model . src . split ( '.' ) . pop ();
if ( html5types [ ext ] ) {
delete html5types [ ext ];
}
#>
2014-03-05 16:06:14 +01:00
< label class = " setting " >
< span > SRC </ span >
2014-03-09 02:01:14 +01:00
< input type = " text " disabled = " disabled " data - setting = " src " value = " { { data.model.src }} " />
2014-03-09 11:32:15 +01:00
< a class = " remove-setting " > {{{ wp . media . view . l10n . remove }}} </ a >
2014-03-05 16:06:14 +01:00
</ label >
2014-03-09 02:01:14 +01:00
< # } #>
< ? php foreach ( $video_types as $type ) :
2014-03-19 06:31:15 +01:00
?> <# if ( ! _.isEmpty( data.model.<?php echo $type ?> ) ) {
if ( ! _ . isUndefined ( html5types .< ? php echo $type ?> ) ) {
delete html5types .< ? php echo $type ?> ;
}
#>
2014-03-05 16:06:14 +01:00
< label class = " setting " >
< span >< ? php echo strtoupper ( $type ) ?> </span>
2014-03-09 02:01:14 +01:00
< input type = " text " disabled = " disabled " data - setting = " <?php echo $type ?> " value = " { { data.model.<?php echo $type ?> }} " />
2014-03-09 11:32:15 +01:00
< a class = " remove-setting " > {{{ wp . media . view . l10n . remove }}} </ a >
2014-03-05 16:06:14 +01:00
</ label >
< # } #>
< ? php endforeach ?>
</ div >
2014-03-19 06:31:15 +01:00
< # if ( ! _.isEmpty( html5types ) ) { #>
< div class = " setting " >
< span > {{{ wp . media . view . l10n . mediaHTML5Text }}} </ span >
< div class = " button-large " >
2014-03-23 04:16:14 +01:00
< # _.each( html5types, function (mime, type) { #>
< button class = " button add-media-source " data - mime = " { { mime }} " > {{ type }} </ button >
2014-03-19 06:31:15 +01:00
< # } ) #>
</ div >
</ div >
< # } #>
2014-03-09 06:25:15 +01:00
< # if ( ! _.isEmpty( data.model.poster ) ) { #>
2014-03-05 16:06:14 +01:00
< label class = " setting " >
< span >< ? php _e ( 'Poster Image' ); ?> </span>
2014-03-09 06:25:15 +01:00
< input type = " text " disabled = " disabled " data - setting = " poster " value = " { { data.model.poster }} " />
2014-03-09 11:32:15 +01:00
< a class = " remove-setting " > {{{ wp . media . view . l10n . remove }}} </ a >
2014-03-05 16:06:14 +01:00
</ label >
2014-03-09 06:25:15 +01:00
< # } #>
2014-03-05 16:06:14 +01:00
< div class = " setting preload " >
< span >< ? php _e ( 'Preload' ); ?> </span>
< div class = " button-group button-large " data - setting = " preload " >
2014-03-21 01:19:16 +01:00
< button class = " button " value = " auto " >< ? php _ex ( 'Auto' , 'auto preload' ); ?> </button>
2014-03-09 02:01:14 +01:00
< button class = " button " value = " metadata " >< ? php _e ( 'Metadata' ); ?> </button>
< button class = " button active " value = " none " >< ? php _e ( 'None' ); ?> </button>
2014-03-05 16:06:14 +01:00
</ div >
</ div >
< label class = " setting checkbox-setting " >
< span >< ? php _e ( 'Autoplay' ); ?> </span>
< input type = " checkbox " data - setting = " autoplay " />
</ label >
< label class = " setting checkbox-setting " >
< span >< ? php _e ( 'Loop' ); ?> </span>
< input type = " checkbox " data - setting = " loop " />
</ label >
< div class = " clear " ></ div >
2014-03-09 11:32:15 +01:00
< label class = " setting " data - setting = " content " >
2014-03-19 09:18:14 +01:00
< span >< ? php _e ( 'Tracks (subtitles, captions, descriptions, chapters, or metadata)' ); ?> </span>
2014-03-09 11:32:15 +01:00
< #
var content = '' ;
if ( ! _ . isEmpty ( data . model . content ) ) {
var tracks = jQuery ( data . model . content ) . filter ( 'track' );
_ . each ( tracks . toArray (), function ( track ) {
content += track . outerHTML ; #>
< p >
< input class = " content-track " type = " text " value = " { { track.outerHTML }} " />
< a class = " remove-setting remove-track " > {{{ wp . media . view . l10n . remove }}} </ a >
</ p >
< # } ); #>
< # } else { #>
2014-03-10 01:19:15 +01:00
< em >< ? php _e ( 'There are no associated subtitles.' ); ?> </em>
2014-03-09 11:32:15 +01:00
< # } #>
< textarea class = " hidden content-setting " > {{ content }} </ textarea >
</ label >
2014-03-20 14:33:14 +01:00
< label class = " setting " >
< span >< ? php _e ( 'Caption' ); ?> </span>
< input type = " text " data - setting = " caption " value = " { { data.model.caption }} " />
</ label >
2014-03-05 16:06:14 +01:00
</ div >
</ div >
</ script >
2014-03-05 08:01:14 +01:00
< script type = " text/html " id = " tmpl-editor-gallery " >
< div class = " toolbar " >
2014-03-20 01:48:15 +01:00
< div class = " dashicons dashicons-edit edit " ></ div >< div class = " dashicons dashicons-no-alt remove " ></ div >
2014-03-05 08:01:14 +01:00
</ div >
< div class = " gallery gallery-columns- { { { data.columns }}} " >
< # _.each( data.attachments, function( attachment, index ) { #>
< dl class = " gallery-item " >
< dt class = " gallery-icon " >
2014-03-18 04:25:14 +01:00
< img src = " { { { attachment.thumbnail.url }}} " width = " { { attachment.thumbnail.width }} " height = " { { attachment.thumbnail.height }} " />
2014-03-05 08:01:14 +01:00
</ dt >
< dd class = " wp-caption-text gallery-caption " >
{{ attachment . caption }}
</ dd >
</ dl >
< # if ( index % data.columns === data.columns - 1 ) { #>
< br style = " clear: both; " >
< # } #>
< # } ); #>
</ div >
</ script >
2014-03-19 08:02:15 +01:00
< script type = " text/html " id = " tmpl-editor-audio " >
< div class = " toolbar " >
2014-03-20 01:48:15 +01:00
< div class = " dashicons dashicons-edit edit " ></ div >
2014-03-19 08:02:15 +01:00
< div class = " dashicons dashicons-no-alt remove " ></ div >
</ div >
2014-03-20 14:33:14 +01:00
< # if ( ! _.isEmpty( data.model.caption ) ) { #>
< div class = " track-details " > {{{ data . model . caption }}} </ div >
< # } #>
2014-03-19 08:02:15 +01:00
< ? php wp_underscore_audio_template () ?>
2014-03-27 08:02:16 +01:00
< div class = " wpview-overlay " ></ div >
2014-03-19 08:02:15 +01:00
</ script >
< script type = " text/html " id = " tmpl-editor-video " >
< div class = " toolbar " >
2014-03-20 01:48:15 +01:00
< div class = " dashicons dashicons-edit edit " ></ div >
2014-03-19 08:02:15 +01:00
< div class = " dashicons dashicons-no-alt remove " ></ div >
</ div >
2014-03-20 14:33:14 +01:00
< # if ( ! _.isEmpty( data.model.caption ) ) { #>
< div class = " track-details " > {{{ data . model . caption }}} </ div >
< # } #>
2014-03-19 08:02:15 +01:00
< ? php wp_underscore_video_template () ?>
2014-03-27 08:02:16 +01:00
< div class = " wpview-overlay " ></ div >
2014-03-19 08:02:15 +01:00
</ script >
2014-03-20 14:33:14 +01:00
< ? php wp_underscore_playlist_templates () ?>
< script type = " text/html " id = " tmpl-editor-playlist " >
< div class = " toolbar " >
< div class = " dashicons dashicons-edit edit " ></ div >
< div class = " dashicons dashicons-no-alt remove " ></ div >
</ div >
< div class = " wp-playlist wp- { { data.type }}-playlist wp-playlist- { { data.style }} " >
< # if ( 'audio' === data.type ){ #>
< div class = " wp-playlist-current-item " ></ div >
< # } #>
< {{ data . type }} controls = " controls " preload = " none " < #
if ( data . width ) { #> width="{{ data.width }}"<# }
#><# if ( data.height ) { #> height="{{ data.height }}"<# } #>></{{ data.type }}>
< div class = " wp-playlist-next " ></ div >
< div class = " wp-playlist-prev " ></ div >
</ div >
2014-03-27 08:02:16 +01:00
< div class = " wpview-overlay " ></ div >
2014-03-20 14:33:14 +01:00
</ script >
2012-12-06 08:10:20 +01:00
< ? php
2013-11-26 08:52:08 +01:00
/**
2014-03-25 09:05:15 +01:00
* Fires when the custom Backbone media templates are printed .
2013-11-26 08:52:08 +01:00
*
* @ since 3.5 . 0
*/
2012-12-06 08:10:20 +01:00
do_action ( 'print_media_templates' );
}