2008-01-09 03:14:29 -05:00
< ? php
2008-10-01 21:03:26 -04:00
/**
* WordPress Administration Media API .
*
* @ package WordPress
* @ subpackage Administration
*/
/**
2012-09-16 14:31:42 -04:00
* Defines the default media upload tabs
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2019-10-26 17:09:04 -04:00
* @ return string [] Default tabs .
2008-10-01 21:03:26 -04:00
*/
2008-02-26 14:30:10 -05:00
function media_upload_tabs () {
2008-01-09 03:14:29 -05:00
$_default_tabs = array (
2020-01-17 19:54:04 -05:00
'type' => __ ( 'From Computer' ), // Handler action suffix => tab text.
2017-11-30 18:11:00 -05:00
'type_url' => __ ( 'From URL' ),
'gallery' => __ ( 'Gallery' ),
'library' => __ ( 'Media Library' ),
2008-01-09 03:14:29 -05:00
);
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the available tabs in the legacy ( pre - 3.5 . 0 ) media popup .
2014-01-06 00:48:12 -05:00
*
* @ since 2.5 . 0
*
2019-10-26 17:09:04 -04:00
* @ param string [] $_default_tabs An array of media tabs .
2014-01-06 00:48:12 -05:00
*/
return apply_filters ( 'media_upload_tabs' , $_default_tabs );
2008-01-09 03:14:29 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2012-09-16 14:31:42 -04:00
* Adds the gallery tab back to the tabs array if post has image attachments
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2015-10-14 19:44:25 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2015-05-28 17:41:30 -04:00
*
2012-09-16 14:31:42 -04:00
* @ param array $tabs
* @ return array $tabs with gallery if post has image attachment
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function update_gallery_tab ( $tabs ) {
2008-02-26 14:30:10 -05:00
global $wpdb ;
2008-12-08 02:38:05 -05:00
2017-11-30 18:11:00 -05:00
if ( ! isset ( $_REQUEST [ 'post_id' ] ) ) {
unset ( $tabs [ 'gallery' ] );
2008-02-26 14:30:10 -05:00
return $tabs ;
}
2008-12-08 02:38:05 -05:00
2020-10-08 17:15:13 -04:00
$post_id = ( int ) $_REQUEST [ 'post_id' ];
2009-11-16 02:54:02 -05:00
2017-11-30 18:11:00 -05:00
if ( $post_id ) {
2020-10-08 17:15:13 -04:00
$attachments = ( int ) $wpdb -> get_var ( $wpdb -> prepare ( " SELECT count(*) FROM $wpdb->posts WHERE post_type = 'attachment' AND post_status != 'trash' AND post_parent = %d " , $post_id ) );
2017-11-30 18:11:00 -05:00
}
2008-02-26 14:30:10 -05:00
2017-11-30 18:11:00 -05:00
if ( empty ( $attachments ) ) {
unset ( $tabs [ 'gallery' ] );
2008-12-08 02:38:05 -05:00
return $tabs ;
}
2019-09-02 20:41:05 -04:00
/* translators: %s: Number of attachments. */
2017-11-30 18:11:00 -05:00
$tabs [ 'gallery' ] = sprintf ( __ ( 'Gallery (%s)' ), " <span id='attachments-count'> $attachments </span> " );
2008-02-26 14:30:10 -05:00
return $tabs ;
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload tabs UI .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2015-05-28 17:41:30 -04:00
*
* @ global string $redir_tab
2008-10-01 21:03:26 -04:00
*/
2008-02-26 14:30:10 -05:00
function the_media_upload_tabs () {
2012-04-09 21:19:30 -04:00
global $redir_tab ;
2017-11-30 18:11:00 -05:00
$tabs = media_upload_tabs ();
2012-04-11 20:16:37 -04:00
$default = 'type' ;
2011-11-18 03:43:16 -05:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $tabs ) ) {
2008-02-27 03:31:10 -05:00
echo " <ul id='sidemenu'> \n " ;
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $redir_tab ) && array_key_exists ( $redir_tab , $tabs ) ) {
2008-07-09 23:49:52 -04:00
$current = $redir_tab ;
2017-11-30 18:11:00 -05:00
} elseif ( isset ( $_GET [ 'tab' ] ) && array_key_exists ( $_GET [ 'tab' ], $tabs ) ) {
2008-02-13 13:36:40 -05:00
$current = $_GET [ 'tab' ];
2014-01-06 00:48:12 -05:00
} else {
/** This filter is documented in wp-admin/media-upload.php */
$current = apply_filters ( 'media_upload_default_tab' , $default );
}
2009-04-22 07:10:15 -04:00
2008-02-13 13:36:40 -05:00
foreach ( $tabs as $callback => $text ) {
2008-02-27 03:31:10 -05:00
$class = '' ;
2011-11-18 03:43:16 -05:00
2017-11-30 18:11:00 -05:00
if ( $current == $callback ) {
2008-02-27 03:31:10 -05:00
$class = " class='current' " ;
2017-11-30 18:11:00 -05:00
}
2011-11-18 03:43:16 -05:00
2017-11-30 18:11:00 -05:00
$href = add_query_arg (
array (
'tab' => $callback ,
's' => false ,
'paged' => false ,
'post_mime_type' => false ,
'm' => false ,
)
);
$link = " <a href=' " . esc_url ( $href ) . " ' $class > $text </a> " ;
echo " \t <li id=' " . esc_attr ( " tab- $callback " ) . " '> $link </li> \n " ;
2008-02-13 13:36:40 -05:00
}
2019-09-03 21:11:54 -04:00
2008-02-13 13:36:40 -05:00
echo " </ul> \n " ;
}
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the image HTML to send to the editor .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2020-06-20 08:02:12 -04:00
* @ param int $id Image attachment ID .
2015-10-12 13:16:24 -04:00
* @ param string $caption Image caption .
* @ param string $title Image title attribute .
* @ param string $align Image CSS alignment property .
* @ param string $url Optional . Image src URL . Default empty .
2016-04-13 03:28:28 -04:00
* @ param bool | string $rel Optional . Value for rel attribute or whether to add a default value . Default false .
2020-09-20 12:23:07 -04:00
* @ param string | int [] $size Optional . Image size . Accepts any registered image size name , or an array of
* width and height values in pixels ( in that order ) . Default 'medium' .
2015-10-12 13:16:24 -04:00
* @ param string $alt Optional . Image alt attribute . Default empty .
2015-10-12 12:11:24 -04:00
* @ return string The HTML output to insert into the editor .
2008-10-01 21:03:26 -04:00
*/
2016-03-18 16:05:26 -04:00
function get_image_send_to_editor ( $id , $caption , $title , $align , $url = '' , $rel = false , $size = 'medium' , $alt = '' ) {
2008-01-09 03:14:29 -05:00
2016-03-18 16:05:26 -04:00
$html = get_image_tag ( $id , $alt , '' , $align , $size );
2008-01-09 03:14:29 -05:00
2016-03-18 16:05:26 -04:00
if ( $rel ) {
if ( is_string ( $rel ) ) {
$rel = ' rel="' . esc_attr ( $rel ) . '"' ;
} else {
2020-10-08 17:15:13 -04:00
$rel = ' rel="attachment wp-att-' . ( int ) $id . '"' ;
2016-03-18 16:05:26 -04:00
}
2015-09-17 01:46:24 -04:00
} else {
2016-03-18 16:05:26 -04:00
$rel = '' ;
2015-09-17 01:46:24 -04:00
}
2008-03-06 14:48:54 -05:00
2017-11-30 18:11:00 -05:00
if ( $url ) {
2016-03-18 16:05:26 -04:00
$html = '<a href="' . esc_attr ( $url ) . '"' . $rel . '>' . $html . '</a>' ;
2017-11-30 18:11:00 -05:00
}
2008-02-28 16:29:51 -05:00
2014-01-06 00:48:12 -05:00
/**
2016-10-05 15:57:28 -04:00
* Filters the image HTML markup to send to the editor when inserting an image .
2014-01-06 00:48:12 -05:00
*
* @ since 2.5 . 0
2020-07-28 17:21:05 -04:00
* @ since 5.6 . 0 The `$rel` parameter was added .
2014-01-06 00:48:12 -05:00
*
2015-10-12 12:19:23 -04:00
* @ param string $html The image HTML markup to send .
2020-06-20 08:02:12 -04:00
* @ param int $id The attachment ID .
2015-10-12 12:19:23 -04:00
* @ param string $caption The image caption .
* @ param string $title The image title .
* @ param string $align The image alignment .
* @ param string $url The image source URL .
2020-09-20 12:23:07 -04:00
* @ 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 ) .
2015-10-12 12:19:23 -04:00
* @ param string $alt The image alternative , or alt , text .
2020-07-28 17:21:05 -04:00
* @ param string $rel The image rel attribute .
2014-01-06 00:48:12 -05:00
*/
2020-07-28 17:21:05 -04:00
$html = apply_filters ( 'image_send_to_editor' , $html , $id , $caption , $title , $align , $url , $size , $alt , $rel );
2008-01-09 03:14:29 -05:00
2008-02-16 16:54:47 -05:00
return $html ;
2008-01-09 03:14:29 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2020-06-28 10:02:06 -04:00
* Adds image shortcode with caption to editor .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.6 . 0
2008-10-01 21:03:26 -04:00
*
2018-09-14 09:35:25 -04:00
* @ param string $html The image HTML markup to send .
2020-10-10 16:02:05 -04:00
* @ param int $id Image attachment ID .
2018-09-14 09:35:25 -04:00
* @ param string $caption Image caption .
* @ param string $title Image title attribute ( not used ) .
* @ param string $align Image CSS alignment property .
* @ param string $url Image source URL ( not used ) .
2020-09-20 11:55:10 -04:00
* @ param string $size Image size ( not used ) .
2018-09-14 09:35:25 -04:00
* @ param string $alt Image `alt` attribute ( not used ) .
* @ return string The image HTML markup with caption shortcode .
2008-10-01 21:03:26 -04:00
*/
2009-10-19 01:09:41 -04:00
function image_add_caption ( $html , $id , $caption , $title , $align , $url , $size , $alt = '' ) {
2008-07-02 14:41:11 -04:00
2014-09-21 05:56:17 -04:00
/**
2016-05-22 14:01:30 -04:00
* Filters the caption text .
2014-09-21 05:56:17 -04:00
*
* Note : If the caption text is empty , the caption shortcode will not be appended
* to the image HTML when inserted into the editor .
*
2014-11-28 03:56:24 -05:00
* Passing an empty value also prevents the { @ see 'image_add_caption_shortcode' }
2016-05-22 14:01:30 -04:00
* Filters from being evaluated at the end of image_add_caption () .
2014-09-21 05:56:17 -04:00
*
* @ since 4.1 . 0
*
* @ param string $caption The original caption text .
2014-09-21 06:11:16 -04:00
* @ param int $id The attachment ID .
2014-09-21 05:56:17 -04:00
*/
2014-09-21 06:11:16 -04:00
$caption = apply_filters ( 'image_add_caption_text' , $caption , $id );
2014-09-21 05:56:17 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters whether to disable captions .
2014-01-06 00:48:12 -05:00
*
* Prevents image captions from being appended to image HTML when inserted into the editor .
*
* @ since 2.6 . 0
*
2020-06-26 14:49:09 -04:00
* @ param bool $bool Whether to disable appending captions . Returning true from the filter
2014-01-06 00:48:12 -05:00
* will disable captions . Default empty string .
*/
2017-11-30 18:11:00 -05:00
if ( empty ( $caption ) || apply_filters ( 'disable_captions' , '' ) ) {
2009-05-26 18:33:02 -04:00
return $html ;
2017-11-30 18:11:00 -05:00
}
2009-05-26 18:33:02 -04:00
2008-07-02 14:41:11 -04:00
$id = ( 0 < ( int ) $id ) ? 'attachment_' . $id : '' ;
2017-11-30 18:11:00 -05:00
if ( ! preg_match ( '/width=["\']([0-9]+)/' , $html , $matches ) ) {
2009-05-26 18:33:02 -04:00
return $html ;
2017-11-30 18:11:00 -05:00
}
2009-05-26 18:33:02 -04:00
2008-07-02 14:41:11 -04:00
$width = $matches [ 1 ];
2017-11-30 18:11:00 -05:00
$caption = str_replace ( array ( " \r \n " , " \r " ), " \n " , $caption );
2012-03-14 17:53:11 -04:00
$caption = preg_replace_callback ( '/<[a-zA-Z0-9]+(?: [^<>]+>)*/' , '_cleanup_image_add_caption' , $caption );
2014-07-17 05:14:16 -04:00
2020-01-17 19:54:04 -05:00
// Convert any remaining line breaks to <br />.
2012-05-01 21:14:52 -04:00
$caption = preg_replace ( '/[ \n\t]*\n[ \t]*/' , '<br />' , $caption );
2010-11-08 19:42:35 -05:00
2009-05-26 18:33:02 -04:00
$html = preg_replace ( '/(class=["\'][^\'"]*)align(none|left|right|center)\s?/' , '$1' , $html );
2017-11-30 18:11:00 -05:00
if ( empty ( $align ) ) {
2009-05-26 18:33:02 -04:00
$align = 'none' ;
2017-11-30 18:11:00 -05:00
}
2008-07-02 14:41:11 -04:00
2017-11-30 18:11:00 -05:00
$shcode = '[caption id="' . $id . '" align="align' . $align . '" width="' . $width . '"]' . $html . ' ' . $caption . '[/caption]' ;
2008-07-02 14:41:11 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the image HTML markup including the caption shortcode .
2014-01-06 00:48:12 -05:00
*
* @ since 2.6 . 0
*
* @ param string $shcode The image HTML markup with caption shortcode .
* @ param string $html The image HTML markup .
*/
2008-07-02 14:41:11 -04:00
return apply_filters ( 'image_add_caption_shortcode' , $shcode , $html );
}
2012-04-06 16:05:31 -04:00
/**
2020-06-28 10:02:06 -04:00
* Private preg_replace callback used in image_add_caption () .
2012-04-06 16:05:31 -04:00
*
* @ access private
* @ since 3.4 . 0
*/
2012-04-06 15:52:34 -04:00
function _cleanup_image_add_caption ( $matches ) {
2014-07-17 05:14:16 -04:00
// Remove any line breaks from inside the tags.
2012-05-01 21:14:52 -04:00
return preg_replace ( '/[\r\n\t]+/' , ' ' , $matches [ 0 ] );
2012-03-05 02:31:31 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2020-06-28 10:02:06 -04:00
* Adds image HTML to editor .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2012-09-16 14:31:42 -04:00
* @ param string $html
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function media_send_to_editor ( $html ) {
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
var win = window . dialogArguments || opener || parent || top ;
win . send_to_editor ( < ? php echo wp_json_encode ( $html ); ?> );
</ script >
2018-08-16 21:51:36 -04:00
< ? php
2008-02-16 16:54:47 -05:00
exit ;
2008-01-09 03:14:29 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2020-06-28 10:02:06 -04:00
* Saves a file submitted from a POST request and create an attachment post for it .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2016-05-22 13:18:27 -04:00
* @ param string $file_id Index of the `$_FILES` array that the file was sent . Required .
2015-01-09 00:05:23 -05:00
* @ param int $post_id The post ID of a post to attach the media item to . Required , but can
* be set to 0 , creating a media item that has no relationship to a post .
2020-06-28 10:02:06 -04:00
* @ param array $post_data Optional . Overwrite some of the attachment .
* @ param array $overrides Optional . Override the wp_handle_upload () behavior .
2014-03-31 18:33:15 -04:00
* @ return int | WP_Error ID of the attachment or a WP_Error object on failure .
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function media_handle_upload ( $file_id , $post_id , $post_data = array (), $overrides = array ( 'test_form' => false ) ) {
$time = current_time ( 'mysql' );
2019-07-01 08:52:01 -04:00
$post = get_post ( $post_id );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $post ) {
2017-10-21 09:27:48 -04:00
// The post date doesn't usually matter for pages, so don't backdate this upload.
2017-11-30 18:11:00 -05:00
if ( 'page' !== $post -> post_type && substr ( $post -> post_date , 0 , 4 ) > 0 ) {
2008-11-13 22:26:06 -05:00
$time = $post -> post_date ;
2017-11-30 18:11:00 -05:00
}
2008-11-13 22:26:06 -05:00
}
2008-11-13 13:22:00 -05:00
2017-11-30 18:11:00 -05:00
$file = wp_handle_upload ( $_FILES [ $file_id ], $overrides , $time );
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
if ( isset ( $file [ 'error' ] ) ) {
2008-07-23 14:35:38 -04:00
return new WP_Error ( 'upload_error' , $file [ 'error' ] );
2017-11-30 18:11:00 -05:00
}
2009-05-24 19:47:49 -04:00
2017-11-30 18:11:00 -05:00
$name = $_FILES [ $file_id ][ 'name' ];
2016-09-28 21:21:31 -04:00
$ext = pathinfo ( $name , PATHINFO_EXTENSION );
$name = wp_basename ( $name , " . $ext " );
2008-01-25 14:21:11 -05:00
2019-09-18 21:26:55 -04:00
$url = $file [ 'url' ];
$type = $file [ 'type' ];
$file = $file [ 'file' ];
$title = sanitize_text_field ( $name );
$content = '' ;
$excerpt = '' ;
2008-01-25 14:21:11 -05:00
2013-04-12 18:27:24 -04:00
if ( preg_match ( '#^audio#' , $type ) ) {
$meta = wp_read_audio_metadata ( $file );
2015-03-10 01:07:28 -04:00
if ( ! empty ( $meta [ 'title' ] ) ) {
2013-04-12 18:27:24 -04:00
$title = $meta [ 'title' ];
2015-03-10 01:07:28 -04:00
}
2013-04-12 18:27:24 -04:00
if ( ! empty ( $title ) ) {
if ( ! empty ( $meta [ 'album' ] ) && ! empty ( $meta [ 'artist' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: 1: Audio track title, 2: Album title, 3: Artist name. */
2013-07-24 01:47:00 -04:00
$content .= sprintf ( __ ( '"%1$s" from %2$s by %3$s.' ), $title , $meta [ 'album' ], $meta [ 'artist' ] );
2015-01-08 02:05:25 -05:00
} elseif ( ! empty ( $meta [ 'album' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: 1: Audio track title, 2: Album title. */
2013-07-24 01:47:00 -04:00
$content .= sprintf ( __ ( '"%1$s" from %2$s.' ), $title , $meta [ 'album' ] );
2015-01-08 02:05:25 -05:00
} elseif ( ! empty ( $meta [ 'artist' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: 1: Audio track title, 2: Artist name. */
2013-07-24 01:47:00 -04:00
$content .= sprintf ( __ ( '"%1$s" by %2$s.' ), $title , $meta [ 'artist' ] );
2013-04-12 18:27:24 -04:00
} else {
2019-09-02 20:41:05 -04:00
/* translators: %s: Audio track title. */
2013-07-24 01:47:00 -04:00
$content .= sprintf ( __ ( '"%s".' ), $title );
2013-04-12 18:27:24 -04:00
}
2015-01-08 02:05:25 -05:00
} elseif ( ! empty ( $meta [ 'album' ] ) ) {
2013-04-12 18:27:24 -04:00
if ( ! empty ( $meta [ 'artist' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: 1: Audio album title, 2: Artist name. */
2013-04-12 18:27:24 -04:00
$content .= sprintf ( __ ( '%1$s by %2$s.' ), $meta [ 'album' ], $meta [ 'artist' ] );
} else {
$content .= $meta [ 'album' ] . '.' ;
}
2015-01-08 02:05:25 -05:00
} elseif ( ! empty ( $meta [ 'artist' ] ) ) {
2013-04-12 18:27:24 -04:00
$content .= $meta [ 'artist' ] . '.' ;
}
2016-11-20 21:46:30 -05:00
if ( ! empty ( $meta [ 'year' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: Audio file track information. %d: Year of audio track release. */
2013-04-12 18:27:24 -04:00
$content .= ' ' . sprintf ( __ ( 'Released: %d.' ), $meta [ 'year' ] );
2016-11-20 21:46:30 -05:00
}
2013-04-12 18:27:24 -04:00
if ( ! empty ( $meta [ 'track_number' ] ) ) {
$track_number = explode ( '/' , $meta [ 'track_number' ] );
2019-09-03 21:11:54 -04:00
2016-11-20 21:46:30 -05:00
if ( isset ( $track_number [ 1 ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: Audio file track information. 1: Audio track number, 2: Total audio tracks. */
2013-04-12 18:27:24 -04:00
$content .= ' ' . sprintf ( __ ( 'Track %1$s of %2$s.' ), number_format_i18n ( $track_number [ 0 ] ), number_format_i18n ( $track_number [ 1 ] ) );
2016-11-20 21:46:30 -05:00
} else {
2019-09-02 20:41:05 -04:00
/* translators: Audio file track information. %s: Audio track number. */
2018-03-11 12:44:34 -04:00
$content .= ' ' . sprintf ( __ ( 'Track %s.' ), number_format_i18n ( $track_number [ 0 ] ) );
2016-11-20 21:46:30 -05:00
}
2013-04-12 18:27:24 -04:00
}
2016-11-20 21:46:30 -05:00
if ( ! empty ( $meta [ 'genre' ] ) ) {
2019-09-02 20:41:05 -04:00
/* translators: Audio file genre information. %s: Audio genre name. */
2013-04-12 18:27:24 -04:00
$content .= ' ' . sprintf ( __ ( 'Genre: %s.' ), $meta [ 'genre' ] );
2016-11-20 21:46:30 -05:00
}
2013-04-12 18:27:24 -04:00
2018-08-16 21:51:36 -04:00
// Use image exif/iptc data for title and caption defaults if possible.
2019-07-01 08:52:01 -04:00
} elseif ( 0 === strpos ( $type , 'image/' ) ) {
$image_meta = wp_read_image_metadata ( $file );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $image_meta ) {
if ( trim ( $image_meta [ 'title' ] ) && ! is_numeric ( sanitize_title ( $image_meta [ 'title' ] ) ) ) {
$title = $image_meta [ 'title' ];
}
2015-03-10 01:07:28 -04:00
2019-07-01 08:52:01 -04:00
if ( trim ( $image_meta [ 'caption' ] ) ) {
$excerpt = $image_meta [ 'caption' ];
}
2015-03-10 01:07:28 -04:00
}
2008-01-25 14:21:11 -05:00
}
2020-01-17 19:54:04 -05:00
// Construct the attachment array.
2017-11-30 18:11:00 -05:00
$attachment = array_merge (
array (
'post_mime_type' => $type ,
'guid' => $url ,
'post_parent' => $post_id ,
'post_title' => $title ,
'post_content' => $content ,
'post_excerpt' => $excerpt ,
2018-08-16 21:51:36 -04:00
),
$post_data
2017-11-30 18:11:00 -05:00
);
2008-01-25 14:21:11 -05:00
2011-06-27 11:56:42 -04:00
// This should never be set as it would then overwrite an existing attachment.
2015-05-22 01:47:25 -04:00
unset ( $attachment [ 'ID' ] );
2011-06-27 11:56:42 -04:00
2020-01-17 19:54:04 -05:00
// Save the data.
2019-09-03 21:11:54 -04:00
$attachment_id = wp_insert_attachment ( $attachment , $file , $post_id , true );
if ( ! is_wp_error ( $attachment_id ) ) {
2019-10-07 11:30:02 -04:00
// Set a custom header with the attachment_id.
// Used by the browser/client to resume creating image sub-sizes after a PHP fatal error.
if ( ! headers_sent () ) {
header ( 'X-WP-Upload-Attachment-ID: ' . $attachment_id );
}
2019-09-03 21:11:54 -04:00
// The image sub-sizes are created during wp_generate_attachment_metadata().
// This is generally slow and may cause timeouts or out of memory errors.
wp_update_attachment_metadata ( $attachment_id , wp_generate_attachment_metadata ( $attachment_id , $file ) );
}
2008-01-09 03:14:29 -05:00
2019-09-03 21:11:54 -04:00
return $attachment_id ;
2008-01-09 03:14:29 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2016-05-22 13:10:26 -04:00
* Handles a side - loaded file in the same way as an uploaded file is handled by media_handle_upload () .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.6 . 0
2019-09-24 08:54:57 -04:00
* @ since 5.3 . 0 The `$post_id` parameter was made optional .
2008-10-01 21:03:26 -04:00
*
2021-02-09 07:34:06 -05:00
* @ param string [] $file_array Array that represents a `$_FILES` upload array .
* @ param int $post_id Optional . The post ID the media is associated with .
* @ param string $desc Optional . Description of the side - loaded file . Default null .
* @ param array $post_data Optional . Post data to override . Default empty array .
2019-08-30 07:36:08 -04:00
* @ return int | WP_Error The ID of the attachment or a WP_Error on failure .
2008-10-01 21:03:26 -04:00
*/
2019-09-23 12:03:56 -04:00
function media_handle_sideload ( $file_array , $post_id = 0 , $desc = null , $post_data = array () ) {
2017-11-30 18:11:00 -05:00
$overrides = array ( 'test_form' => false );
2009-09-23 21:54:07 -04:00
2021-02-08 18:22:04 -05:00
if ( isset ( $post_data [ 'post_date' ] ) && substr ( $post_data [ 'post_date' ], 0 , 4 ) > 0 ) {
$time = $post_data [ 'post_date' ];
} else {
$post = get_post ( $post_id );
if ( $post && substr ( $post -> post_date , 0 , 4 ) > 0 ) {
2012-10-03 14:49:37 -04:00
$time = $post -> post_date ;
2021-02-08 18:22:04 -05:00
} else {
$time = current_time ( 'mysql' );
2017-11-30 18:11:00 -05:00
}
2012-10-03 14:49:37 -04:00
}
$file = wp_handle_sideload ( $file_array , $overrides , $time );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $file [ 'error' ] ) ) {
2008-07-23 14:35:38 -04:00
return new WP_Error ( 'upload_error' , $file [ 'error' ] );
2017-11-30 18:11:00 -05:00
}
2008-06-04 12:13:55 -04:00
2017-11-30 18:11:00 -05:00
$url = $file [ 'url' ];
$type = $file [ 'type' ];
$file = $file [ 'file' ];
2019-03-01 15:58:52 -05:00
$title = preg_replace ( '/\.[^.]+$/' , '' , wp_basename ( $file ) );
2008-06-04 12:13:55 -04:00
$content = '' ;
2014-07-17 05:14:16 -04:00
// Use image exif/iptc data for title and caption defaults if possible.
2019-07-01 08:52:01 -04:00
$image_meta = wp_read_image_metadata ( $file );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $image_meta ) {
2017-11-30 18:11:00 -05:00
if ( trim ( $image_meta [ 'title' ] ) && ! is_numeric ( sanitize_title ( $image_meta [ 'title' ] ) ) ) {
2008-06-04 12:13:55 -04:00
$title = $image_meta [ 'title' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( trim ( $image_meta [ 'caption' ] ) ) {
2008-06-04 12:13:55 -04:00
$content = $image_meta [ 'caption' ];
2017-11-30 18:11:00 -05:00
}
2008-06-04 12:13:55 -04:00
}
2008-07-09 23:49:52 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $desc ) ) {
2011-09-17 14:27:32 -04:00
$title = $desc ;
2017-11-30 18:11:00 -05:00
}
2008-06-04 12:13:55 -04:00
2014-07-17 05:14:16 -04:00
// Construct the attachment array.
2017-11-30 18:11:00 -05:00
$attachment = array_merge (
array (
'post_mime_type' => $type ,
'guid' => $url ,
'post_parent' => $post_id ,
'post_title' => $title ,
'post_content' => $content ,
2018-08-16 21:51:36 -04:00
),
$post_data
2017-11-30 18:11:00 -05:00
);
2008-06-04 12:13:55 -04:00
2011-06-27 11:56:42 -04:00
// This should never be set as it would then overwrite an existing attachment.
2015-05-22 01:47:25 -04:00
unset ( $attachment [ 'ID' ] );
2011-06-27 11:56:42 -04:00
2020-01-17 19:54:04 -05:00
// Save the attachment metadata.
2019-09-03 21:11:54 -04:00
$attachment_id = wp_insert_attachment ( $attachment , $file , $post_id , true );
if ( ! is_wp_error ( $attachment_id ) ) {
wp_update_attachment_metadata ( $attachment_id , wp_generate_attachment_metadata ( $attachment_id , $file ) );
2017-11-30 18:11:00 -05:00
}
2010-11-15 07:53:11 -05:00
2019-09-03 21:11:54 -04:00
return $attachment_id ;
2008-06-04 12:13:55 -04:00
}
2008-10-01 21:03:26 -04:00
/**
2019-05-26 18:48:51 -04:00
* Outputs the iframe to display the media upload page .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2019-10-09 00:28:02 -04:00
* @ since 5.3 . 0 Formalized the existing and already documented `...$args` parameter
* by adding it to the function signature .
2008-10-01 21:03:26 -04:00
*
2015-05-28 17:41:30 -04:00
* @ global int $body_id
*
2019-05-26 18:48:51 -04:00
* @ param callable $content_func Function that outputs the content .
* @ param mixed ... $args Optional additional parameters to pass to the callback function when it ' s called .
2008-10-01 21:03:26 -04:00
*/
2019-09-15 07:12:55 -04:00
function wp_iframe ( $content_func , ... $args ) {
2011-10-17 16:57:32 -04:00
_wp_admin_html_begin ();
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< title >< ? php bloginfo ( 'name' ); ?> › <?php _e( 'Uploads' ); ?> — <?php _e( 'WordPress' ); ?></title>
2018-08-16 21:51:36 -04:00
< ? php
2011-08-20 23:46:43 -04:00
2018-08-16 21:51:36 -04:00
wp_enqueue_style ( 'colors' );
2020-01-17 19:54:04 -05:00
// Check callback name for 'media'.
2019-09-03 21:11:54 -04:00
if (
( is_array ( $content_func ) && ! empty ( $content_func [ 1 ] ) && 0 === strpos ( ( string ) $content_func [ 1 ], 'media' ) ) ||
( ! is_array ( $content_func ) && 0 === strpos ( $content_func , 'media' ) )
) {
2018-08-16 21:51:36 -04:00
wp_enqueue_style ( 'deprecated-media' );
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
2021-03-18 10:13:08 -04:00
addLoadEvent = function ( func ){ if ( typeof jQuery !== 'undefined' ) jQuery ( document ) . ready ( func ); else if ( typeof wpOnload !== 'function' ){ wpOnload = func ;} else { var oldonload = wpOnload ; wpOnload = function (){ oldonload (); func ();}}};
2020-10-29 14:03:11 -04:00
var ajaxurl = '<?php echo esc_js( admin_url( ' admin - ajax . php ', ' relative ' ) ); ?>' , pagenow = 'media-upload-popup' , adminpage = 'media-upload-popup' ,
2019-09-03 21:11:54 -04:00
isRtl = < ? php echo ( int ) is_rtl (); ?> ;
</ script >
2018-08-16 21:51:36 -04:00
< ? php
2014-01-06 00:48:12 -05:00
/** This action is documented in wp-admin/admin-header.php */
do_action ( 'admin_enqueue_scripts' , 'media-upload-popup' );
/**
2014-03-25 04:05:15 -04:00
* Fires when admin styles enqueued for the legacy ( pre - 3.5 . 0 ) media upload popup are printed .
2014-01-06 00:48:12 -05:00
*
* @ since 2.9 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'admin_print_styles-media-upload-popup' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2014-01-06 00:48:12 -05:00
/** This action is documented in wp-admin/admin-header.php */
do_action ( 'admin_print_styles' );
/**
2014-03-25 04:05:15 -04:00
* Fires when admin scripts enqueued for the legacy ( pre - 3.5 . 0 ) media upload popup are printed .
2014-01-06 00:48:12 -05:00
*
* @ since 2.9 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'admin_print_scripts-media-upload-popup' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2014-01-06 00:48:12 -05:00
/** This action is documented in wp-admin/admin-header.php */
do_action ( 'admin_print_scripts' );
/**
2014-03-25 04:05:15 -04:00
* Fires when scripts enqueued for the admin header for the legacy ( pre - 3.5 . 0 )
* media upload popup are printed .
2014-01-06 00:48:12 -05:00
*
* @ since 2.9 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'admin_head-media-upload-popup' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2014-01-06 00:48:12 -05:00
/** This action is documented in wp-admin/admin-header.php */
do_action ( 'admin_head' );
2018-08-16 21:51:36 -04:00
if ( is_string ( $content_func ) ) {
/**
* Fires in the admin header for each specific form tab in the legacy
* ( pre - 3.5 . 0 ) media upload popup .
*
2021-09-21 14:21:00 -04:00
* The dynamic portion of the hook name , `$content_func` , refers to the form
2021-07-03 17:42:59 -04:00
* callback for the media upload type .
2018-08-16 21:51:36 -04:00
*
* @ since 2.5 . 0
*/
do_action ( " admin_head_ { $content_func } " );
}
2017-11-22 23:09:49 -05:00
2018-08-16 21:51:36 -04:00
$body_id_attr = '' ;
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
if ( isset ( $GLOBALS [ 'body_id' ] ) ) {
$body_id_attr = ' id="' . $GLOBALS [ 'body_id' ] . '"' ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ head >
< body < ? php echo $body_id_attr ; ?> class="wp-core-ui no-js">
< script type = " text/javascript " >
document . body . className = document . body . className . replace ( 'no-js' , 'js' );
</ script >
2018-08-16 21:51:36 -04:00
< ? php
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
call_user_func_array ( $content_func , $args );
2009-05-24 19:47:49 -04:00
2014-01-06 00:48:12 -05:00
/** This action is documented in wp-admin/admin-footer.php */
do_action ( 'admin_print_footer_scripts' );
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2021-03-18 10:13:08 -04:00
< script type = " text/javascript " > if ( typeof wpOnload === 'function' ) wpOnload (); </ script >
2019-09-03 21:11:54 -04:00
</ body >
</ html >
2018-08-16 21:51:36 -04:00
< ? php
2008-01-09 03:14:29 -05:00
}
2010-11-22 12:17:26 -05:00
/**
2012-09-16 14:31:42 -04:00
* Adds the media button to the editor
2010-11-22 12:17:26 -05:00
*
2010-12-20 04:25:21 -05:00
* @ since 2.5 . 0
2012-09-16 14:31:42 -04:00
*
2015-05-28 17:41:30 -04:00
* @ global int $post_ID
*
2012-09-16 14:31:42 -04:00
* @ param string $editor_id
2010-11-22 12:17:26 -05:00
*/
2017-11-30 18:11:00 -05:00
function media_buttons ( $editor_id = 'content' ) {
2014-06-25 21:05:14 -04:00
static $instance = 0 ;
$instance ++ ;
2012-11-26 17:03:37 -05:00
$post = get_post ();
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $post && ! empty ( $GLOBALS [ 'post_ID' ] ) ) {
2012-11-26 17:03:37 -05:00
$post = $GLOBALS [ 'post_ID' ];
2017-11-30 18:11:00 -05:00
}
2012-11-26 17:03:37 -05:00
2019-09-03 21:11:54 -04:00
wp_enqueue_media ( array ( 'post' => $post ) );
2012-09-27 16:04:34 -04:00
2012-11-08 23:40:56 -05:00
$img = '<span class="wp-media-buttons-icon"></span> ' ;
2011-10-05 17:07:04 -04:00
2020-02-09 11:55:09 -05:00
$id_attribute = 1 === $instance ? ' id="insert-media-button"' : '' ;
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
printf (
'<button type="button"%s class="button insert-media add_media" data-editor="%s">%s</button>' ,
2014-09-02 05:08:16 -04:00
$id_attribute ,
2014-06-25 21:05:14 -04:00
esc_attr ( $editor_id ),
$img . __ ( 'Add Media' )
);
2019-09-03 21:11:54 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the legacy ( pre - 3.5 . 0 ) media buttons .
2014-01-06 00:48:12 -05:00
*
2016-05-23 13:28:27 -04:00
* Use { @ see 'media_buttons' } action instead .
*
2014-01-06 00:48:12 -05:00
* @ since 2.5 . 0
2016-05-23 13:28:27 -04:00
* @ deprecated 3.5 . 0 Use { @ see 'media_buttons' } action instead .
2014-01-06 00:48:12 -05:00
*
* @ param string $string Media buttons context . Default empty .
*/
2019-11-09 07:59:03 -05:00
$legacy_filter = apply_filters_deprecated ( 'media_buttons_context' , array ( '' ), '3.5.0' , 'media_buttons' );
2012-11-26 17:32:35 -05:00
if ( $legacy_filter ) {
// #WP22559. Close <a> if a plugin started by closing <a> to open their own <a> tag.
2017-11-30 18:11:00 -05:00
if ( 0 === stripos ( trim ( $legacy_filter ), '</a>' ) ) {
2012-11-26 17:32:35 -05:00
$legacy_filter .= '</a>' ;
2017-11-30 18:11:00 -05:00
}
2012-11-26 17:32:35 -05:00
echo $legacy_filter ;
}
2010-11-22 12:17:26 -05:00
}
2014-11-03 02:09:23 -05:00
/**
* @ global int $post_ID
* @ param string $type
2020-07-23 16:01:04 -04:00
* @ param int $post_id
2014-11-03 02:09:23 -05:00
* @ param string $tab
* @ return string
*/
2012-04-04 20:20:28 -04:00
function get_upload_iframe_src ( $type = null , $post_id = null , $tab = null ) {
2011-09-29 17:47:52 -04:00
global $post_ID ;
2017-11-30 18:11:00 -05:00
if ( empty ( $post_id ) ) {
2012-02-27 14:23:03 -05:00
$post_id = $post_ID ;
2017-11-30 18:11:00 -05:00
}
2012-02-27 14:23:03 -05:00
2017-11-30 18:11:00 -05:00
$upload_iframe_src = add_query_arg ( 'post_id' , ( int ) $post_id , admin_url ( 'media-upload.php' ) );
2010-11-22 12:17:26 -05:00
2020-05-16 14:42:12 -04:00
if ( $type && 'media' !== $type ) {
2017-11-30 18:11:00 -05:00
$upload_iframe_src = add_query_arg ( 'type' , $type , $upload_iframe_src );
}
2011-09-29 17:47:52 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $tab ) ) {
$upload_iframe_src = add_query_arg ( 'tab' , $tab , $upload_iframe_src );
}
2012-04-04 20:20:28 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the upload iframe source URL for a specific media type .
2014-01-06 00:48:12 -05:00
*
2014-11-30 06:28:24 -05:00
* The dynamic portion of the hook name , `$type` , refers to the type
2014-01-06 00:48:12 -05:00
* of media uploaded .
*
2021-03-07 07:32:09 -05:00
* Possible hook names include :
*
* - `image_upload_iframe_src`
* - `media_upload_iframe_src`
*
2014-01-06 00:48:12 -05:00
* @ since 3.0 . 0
*
2021-03-07 07:32:09 -05:00
* @ param string $upload_iframe_src The upload iframe source URL .
2014-01-06 00:48:12 -05:00
*/
2016-08-22 14:25:31 -04:00
$upload_iframe_src = apply_filters ( " { $type } _upload_iframe_src " , $upload_iframe_src );
2010-11-22 12:17:26 -05:00
2017-11-30 18:11:00 -05:00
return add_query_arg ( 'TB_iframe' , true , $upload_iframe_src );
2010-11-22 12:17:26 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Handles form submissions for the legacy media uploader .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2021-07-01 18:02:57 -04:00
* @ return null | array | void Array of error messages keyed by attachment ID , null or void on success .
2008-10-01 21:03:26 -04:00
*/
2008-02-26 14:30:10 -05:00
function media_upload_form_handler () {
2017-11-30 18:11:00 -05:00
check_admin_referer ( 'media-form' );
2008-01-25 14:21:11 -05:00
2009-06-25 02:09:22 -04:00
$errors = null ;
2009-05-30 05:55:32 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $_POST [ 'send' ] ) ) {
$keys = array_keys ( $_POST [ 'send' ] );
2015-03-18 23:56:27 -04:00
$send_id = ( int ) reset ( $keys );
2009-01-20 22:45:57 -05:00
}
2017-11-30 18:11:00 -05:00
if ( ! empty ( $_POST [ 'attachments' ] ) ) {
foreach ( $_POST [ 'attachments' ] as $attachment_id => $attachment ) {
2019-07-01 08:52:01 -04:00
$post = get_post ( $attachment_id , ARRAY_A );
$_post = $post ;
2011-06-28 17:44:56 -04:00
2017-11-30 18:11:00 -05:00
if ( ! current_user_can ( 'edit_post' , $attachment_id ) ) {
continue ;
}
2011-06-28 17:44:56 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $attachment [ 'post_content' ] ) ) {
$post [ 'post_content' ] = $attachment [ 'post_content' ];
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $attachment [ 'post_title' ] ) ) {
$post [ 'post_title' ] = $attachment [ 'post_title' ];
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $attachment [ 'post_excerpt' ] ) ) {
$post [ 'post_excerpt' ] = $attachment [ 'post_excerpt' ];
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $attachment [ 'menu_order' ] ) ) {
$post [ 'menu_order' ] = $attachment [ 'menu_order' ];
}
2009-01-20 22:45:57 -05:00
2017-11-30 18:11:00 -05:00
if ( isset ( $send_id ) && $attachment_id == $send_id ) {
if ( isset ( $attachment [ 'post_parent' ] ) ) {
$post [ 'post_parent' ] = $attachment [ 'post_parent' ];
}
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
/**
* Filters the attachment fields to be saved .
*
* @ since 2.5 . 0
*
* @ see wp_get_attachment_metadata ()
*
* @ param array $post An array of post data .
* @ param array $attachment An array of attachment metadata .
*/
$post = apply_filters ( 'attachment_fields_to_save' , $post , $attachment );
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
if ( isset ( $attachment [ 'image_alt' ] ) ) {
$image_alt = wp_unslash ( $attachment [ 'image_alt' ] );
2019-09-03 21:11:54 -04:00
2020-02-09 11:55:09 -05:00
if ( get_post_meta ( $attachment_id , '_wp_attachment_image_alt' , true ) !== $image_alt ) {
2017-11-30 18:11:00 -05:00
$image_alt = wp_strip_all_tags ( $image_alt , true );
2014-07-17 05:14:16 -04:00
2020-01-28 19:45:18 -05:00
// update_post_meta() expects slashed.
2017-11-30 18:11:00 -05:00
update_post_meta ( $attachment_id , '_wp_attachment_image_alt' , wp_slash ( $image_alt ) );
}
2009-10-19 01:09:41 -04:00
}
2017-11-30 18:11:00 -05:00
if ( isset ( $post [ 'errors' ] ) ) {
$errors [ $attachment_id ] = $post [ 'errors' ];
unset ( $post [ 'errors' ] );
}
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
if ( $post != $_post ) {
wp_update_post ( $post );
}
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
foreach ( get_attachment_taxonomies ( $post ) as $t ) {
if ( isset ( $attachment [ $t ] ) ) {
wp_set_object_terms ( $attachment_id , array_map ( 'trim' , preg_split ( '/,+/' , $attachment [ $t ] ) ), $t , false );
}
}
2009-10-19 01:09:41 -04:00
}
2008-02-16 16:54:47 -05:00
}
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
if ( isset ( $_POST [ 'insert-gallery' ] ) || isset ( $_POST [ 'update-gallery' ] ) ) {
2018-08-16 21:51:36 -04:00
?>
2008-11-25 21:27:37 -05:00
< script type = " text/javascript " >
var win = window . dialogArguments || opener || parent || top ;
win . tb_remove ();
</ script >
< ? php
2019-09-03 21:11:54 -04:00
2008-11-25 21:27:37 -05:00
exit ;
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
if ( isset ( $send_id ) ) {
$attachment = wp_unslash ( $_POST [ 'attachments' ][ $send_id ] );
2019-09-03 21:11:54 -04:00
$html = isset ( $attachment [ 'post_title' ] ) ? $attachment [ 'post_title' ] : '' ;
2009-05-26 18:33:02 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $attachment [ 'url' ] ) ) {
2010-02-22 11:54:51 -05:00
$rel = '' ;
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( strpos ( $attachment [ 'url' ], 'attachment_id' ) || get_attachment_link ( $send_id ) == $attachment [ 'url' ] ) {
$rel = " rel='attachment wp-att- " . esc_attr ( $send_id ) . " ' " ;
}
2019-09-03 21:11:54 -04:00
2008-03-21 19:21:27 -04:00
$html = " <a href=' { $attachment [ 'url' ] } ' $rel > $html </a> " ;
}
2009-05-26 18:33:02 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the HTML markup for a media item sent to the editor .
2014-01-06 00:48:12 -05:00
*
* @ since 2.5 . 0
*
* @ see wp_get_attachment_metadata ()
*
* @ param string $html HTML markup for a media item sent to the editor .
* @ param int $send_id The first key from the $_POST [ 'send' ] data .
* @ param array $attachment Array of attachment metadata .
*/
$html = apply_filters ( 'media_send_to_editor' , $html , $send_id , $attachment );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
return media_send_to_editor ( $html );
2008-01-25 14:21:11 -05:00
}
2008-02-16 16:54:47 -05:00
2009-05-08 16:45:04 -04:00
return $errors ;
2008-02-26 14:30:10 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2015-08-20 17:01:25 -04:00
* Handles the process of uploading media .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-03 02:09:23 -05:00
* @ return null | string
2008-10-01 21:03:26 -04:00
*/
2011-10-05 18:36:03 -04:00
function wp_media_upload_handler () {
2008-08-08 13:05:10 -04:00
$errors = array ();
2017-11-30 18:11:00 -05:00
$id = 0 ;
2008-08-08 13:05:10 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $_POST [ 'html-upload' ] ) && ! empty ( $_FILES ) ) {
check_admin_referer ( 'media-form' );
2020-01-17 19:54:04 -05:00
// Upload File button was clicked.
2017-11-30 18:11:00 -05:00
$id = media_handle_upload ( 'async-upload' , $_REQUEST [ 'post_id' ] );
unset ( $_FILES );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $id ) ) {
2008-02-28 16:29:51 -05:00
$errors [ 'upload_error' ] = $id ;
2017-11-30 18:11:00 -05:00
$id = false ;
2008-02-28 16:29:51 -05:00
}
}
2017-11-30 18:11:00 -05:00
if ( ! empty ( $_POST [ 'insertonlybutton' ] ) ) {
2011-10-18 15:32:40 -04:00
$src = $_POST [ 'src' ];
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $src ) && ! strpos ( $src , '://' ) ) {
2009-12-01 04:22:48 -05:00
$src = " http:// $src " ;
2017-11-30 18:11:00 -05:00
}
2011-09-30 02:22:29 -04:00
2020-05-16 14:42:12 -04:00
if ( isset ( $_POST [ 'media_type' ] ) && 'image' !== $_POST [ 'media_type' ] ) {
2013-03-01 12:00:25 -05:00
$title = esc_html ( wp_unslash ( $_POST [ 'title' ] ) );
2017-11-30 18:11:00 -05:00
if ( empty ( $title ) ) {
2019-03-01 15:58:52 -05:00
$title = esc_html ( wp_basename ( $src ) );
2017-11-30 18:11:00 -05:00
}
2011-09-30 02:22:29 -04:00
2017-11-30 18:11:00 -05:00
if ( $title && $src ) {
$html = " <a href=' " . esc_url ( $src ) . " '> $title </a> " ;
}
2011-09-30 02:22:29 -04:00
$type = 'file' ;
2019-07-01 08:52:01 -04:00
$ext = preg_replace ( '/^.+?\.([^.]+)$/' , '$1' , $src );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $ext ) {
$ext_type = wp_ext2type ( $ext );
2020-05-16 14:42:12 -04:00
if ( 'audio' === $ext_type || 'video' === $ext_type ) {
2011-09-30 02:22:29 -04:00
$type = $ext_type ;
2019-07-01 08:52:01 -04:00
}
2017-11-30 18:11:00 -05:00
}
2011-09-30 02:22:29 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the URL sent to the editor for a specific media type .
2014-01-06 00:48:12 -05:00
*
2014-11-30 06:28:24 -05:00
* The dynamic portion of the hook name , `$type` , refers to the type
2014-01-06 00:48:12 -05:00
* of media being sent .
*
2021-03-07 07:32:09 -05:00
* Possible hook names include :
*
* - `audio_send_to_editor_url`
* - `file_send_to_editor_url`
* - `video_send_to_editor_url`
*
2014-01-06 00:48:12 -05:00
* @ since 3.3 . 0
*
* @ param string $html HTML markup sent to the editor .
* @ param string $src Media source URL .
* @ param string $title Media title .
*/
2016-08-22 14:25:31 -04:00
$html = apply_filters ( " { $type } _send_to_editor_url " , $html , esc_url_raw ( $src ), $title );
2011-09-30 02:22:29 -04:00
} else {
$align = '' ;
2017-11-30 18:11:00 -05:00
$alt = esc_attr ( wp_unslash ( $_POST [ 'alt' ] ) );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $_POST [ 'align' ] ) ) {
2013-03-01 12:00:25 -05:00
$align = esc_attr ( wp_unslash ( $_POST [ 'align' ] ) );
2011-09-30 02:22:29 -04:00
$class = " class='align $align ' " ;
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $src ) ) {
$html = " <img src=' " . esc_url ( $src ) . " ' alt=' $alt ' $class /> " ;
}
2011-09-30 02:22:29 -04:00
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the image URL sent to the editor .
2014-01-06 00:48:12 -05:00
*
* @ since 2.8 . 0
*
* @ param string $html HTML markup sent to the editor for an image .
* @ param string $src Image source URL .
* @ param string $alt Image alternate , or alt , text .
* @ param string $align The image alignment . Default 'alignnone' . Possible values include
* 'alignleft' , 'aligncenter' , 'alignright' , 'alignnone' .
*/
2011-09-30 02:22:29 -04:00
$html = apply_filters ( 'image_send_to_editor_url' , $html , esc_url_raw ( $src ), $alt , $align );
2008-02-28 16:29:51 -05:00
}
2009-10-24 07:43:42 -04:00
2017-11-30 18:11:00 -05:00
return media_send_to_editor ( $html );
2008-02-28 16:29:51 -05:00
}
2014-06-27 17:32:16 -04:00
if ( isset ( $_POST [ 'save' ] ) ) {
2017-11-30 18:11:00 -05:00
$errors [ 'upload_notice' ] = __ ( 'Saved.' );
2015-09-10 13:24:23 -04:00
wp_enqueue_script ( 'admin-gallery' );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
return wp_iframe ( 'media_upload_gallery_form' , $errors );
2015-09-10 13:24:23 -04:00
2014-06-27 17:32:16 -04:00
} elseif ( ! empty ( $_POST ) ) {
2008-02-26 14:30:10 -05:00
$return = media_upload_form_handler ();
2008-02-28 16:29:51 -05:00
2017-11-30 18:11:00 -05:00
if ( is_string ( $return ) ) {
2008-02-26 14:30:10 -05:00
return $return ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( is_array ( $return ) ) {
2008-02-26 14:30:10 -05:00
$errors = $return ;
2017-11-30 18:11:00 -05:00
}
2008-02-26 14:30:10 -05:00
}
2020-02-09 11:55:09 -05:00
if ( isset ( $_GET [ 'tab' ] ) && 'type_url' === $_GET [ 'tab' ] ) {
2011-09-30 02:22:29 -04:00
$type = 'image' ;
2019-09-03 21:11:54 -04:00
2020-04-04 23:02:11 -04:00
if ( isset ( $_GET [ 'type' ] ) && in_array ( $_GET [ 'type' ], array ( 'video' , 'audio' , 'file' ), true ) ) {
2011-09-30 02:22:29 -04:00
$type = $_GET [ 'type' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2011-09-30 02:22:29 -04:00
return wp_iframe ( 'media_upload_type_url_form' , $type , $errors , $id );
}
2008-03-26 17:22:19 -04:00
2012-04-11 20:16:37 -04:00
return wp_iframe ( 'media_upload_type_form' , 'image' , $errors , $id );
2008-01-25 14:21:11 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2020-10-17 10:54:05 -04:00
* Downloads an image from the specified URL , saves it as an attachment , and optionally attaches it to a post .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.6 . 0
2015-05-04 22:16:25 -04:00
* @ since 4.2 . 0 Introduced the `$return` parameter .
2020-10-17 10:54:05 -04:00
* @ since 4.8 . 0 Introduced the 'id' option for the `$return` parameter .
2019-09-24 08:54:57 -04:00
* @ since 5.3 . 0 The `$post_id` parameter was made optional .
2020-02-10 18:47:04 -05:00
* @ since 5.4 . 0 The original URL of the attachment is stored in the `_source_url`
* post meta value .
2008-10-01 21:03:26 -04:00
*
2015-05-04 22:20:25 -04:00
* @ param string $file The URL of the image to download .
2019-09-23 12:03:56 -04:00
* @ param int $post_id Optional . The post ID the media is to be associated with .
2015-05-04 22:20:25 -04:00
* @ param string $desc Optional . Description of the image .
2020-02-10 18:47:04 -05:00
* @ param string $return Optional . Accepts 'html' ( image tag html ) or 'src' ( URL ),
* or 'id' ( attachment ID ) . Default 'html' .
2020-10-17 10:54:05 -04:00
* @ return string | int | WP_Error Populated HTML img tag , attachment ID , or attachment source
* on success , WP_Error object otherwise .
2008-10-01 21:03:26 -04:00
*/
2019-09-23 12:03:56 -04:00
function media_sideload_image ( $file , $post_id = 0 , $desc = null , $return = 'html' ) {
2014-05-23 17:33:14 -04:00
if ( ! empty ( $file ) ) {
2015-05-04 22:20:25 -04:00
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
$allowed_extensions = array ( 'jpg' , 'jpeg' , 'jpe' , 'png' , 'gif' , 'webp' );
2020-10-18 17:06:05 -04:00
/**
* Filters the list of allowed file extensions when sideloading an image from a URL .
*
* The default allowed extensions are :
*
* - `jpg`
* - `jpeg`
* - `jpe`
* - `png`
* - `gif`
*
* @ since 5.6 . 0
*
* @ param string [] $allowed_extensions Array of allowed file extensions .
* @ param string $file The URL of the image to download .
*/
$allowed_extensions = apply_filters ( 'image_sideload_extensions' , $allowed_extensions , $file );
$allowed_extensions = array_map ( 'preg_quote' , $allowed_extensions );
2014-07-17 05:14:16 -04:00
// Set variables for storage, fix file filename for query strings.
2020-10-18 17:06:05 -04:00
preg_match ( '/[^\?]+\.(' . implode ( '|' , $allowed_extensions ) . ')\b/i' , $file , $matches );
2019-09-03 21:11:54 -04:00
2015-10-09 00:46:24 -04:00
if ( ! $matches ) {
2020-02-01 15:32:05 -05:00
return new WP_Error ( 'image_sideload_failed' , __ ( 'Invalid image URL.' ) );
2015-10-09 00:46:24 -04:00
}
2017-11-30 18:11:00 -05:00
$file_array = array ();
2019-03-01 15:58:52 -05:00
$file_array [ 'name' ] = wp_basename ( $matches [ 0 ] );
2014-07-17 05:14:16 -04:00
// Download file to temp location.
2014-05-23 17:33:14 -04:00
$file_array [ 'tmp_name' ] = download_url ( $file );
2008-07-09 23:49:52 -04:00
2014-05-23 17:33:14 -04:00
// If error storing temporarily, return the error.
if ( is_wp_error ( $file_array [ 'tmp_name' ] ) ) {
return $file_array [ 'tmp_name' ];
2008-09-22 18:04:10 -04:00
}
2009-09-23 21:54:07 -04:00
2014-07-17 05:14:16 -04:00
// Do the validation and storage stuff.
2010-12-23 10:41:05 -05:00
$id = media_handle_sideload ( $file_array , $post_id , $desc );
2014-07-17 05:14:16 -04:00
// If error storing permanently, unlink.
2014-05-23 17:33:14 -04:00
if ( is_wp_error ( $id ) ) {
@ unlink ( $file_array [ 'tmp_name' ] );
2008-06-23 12:00:12 -04:00
return $id ;
2020-02-10 18:47:04 -05:00
}
// Store the original attachment source in meta.
add_post_meta ( $id , '_source_url' , $file );
2020-06-20 08:02:12 -04:00
// If attachment ID was requested, return it.
2020-02-10 18:47:04 -05:00
if ( 'id' === $return ) {
Media: Optionally return attachment id from `media_sideload_image()`.
Introduces option to `$return` parameter to return the attachment id created after a successful image sideload.
Props slbmeh, kawauso, alexkingorg, SergeyBiryukov, georgestephanis, DrewAPicture, nacin, trepmal, mattheu, kraftbj, whyisjake, dotancohen, MrGregWaugh, danielbachhuber.
Fixes #19629.
Built from https://develop.svn.wordpress.org/trunk@40597
git-svn-id: http://core.svn.wordpress.org/trunk@40467 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2017-05-09 19:26:42 -04:00
return $id ;
2008-06-23 12:00:12 -04:00
}
2010-12-23 10:41:05 -05:00
$src = wp_get_attachment_url ( $id );
2008-06-23 12:00:12 -04:00
}
2009-09-23 21:54:07 -04:00
2015-05-04 22:20:25 -04:00
// Finally, check to make sure the file has been saved, then return the HTML.
2014-05-23 17:33:14 -04:00
if ( ! empty ( $src ) ) {
2020-02-09 11:55:09 -05:00
if ( 'src' === $return ) {
2015-03-16 20:47:28 -04:00
return $src ;
}
2017-11-30 18:11:00 -05:00
$alt = isset ( $desc ) ? esc_attr ( $desc ) : '' ;
2008-06-23 12:00:12 -04:00
$html = " <img src=' $src ' alt=' $alt ' /> " ;
2019-09-03 21:11:54 -04:00
2008-06-23 12:00:12 -04:00
return $html ;
2015-03-16 20:47:28 -04:00
} else {
return new WP_Error ( 'image_sideload_failed' );
2008-06-23 12:00:12 -04:00
}
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the legacy media uploader form in an iframe .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-03 01:17:22 -05:00
* @ return string | null
2008-10-01 21:03:26 -04:00
*/
2008-02-28 16:29:51 -05:00
function media_upload_gallery () {
2008-08-08 13:05:10 -04:00
$errors = array ();
2017-11-30 18:11:00 -05:00
if ( ! empty ( $_POST ) ) {
2008-02-28 16:29:51 -05:00
$return = media_upload_form_handler ();
2008-03-02 15:17:30 -05:00
2017-11-30 18:11:00 -05:00
if ( is_string ( $return ) ) {
2008-02-28 16:29:51 -05:00
return $return ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( is_array ( $return ) ) {
2008-02-28 16:29:51 -05:00
$errors = $return ;
2017-11-30 18:11:00 -05:00
}
2008-02-28 16:29:51 -05:00
}
2017-11-30 18:11:00 -05:00
wp_enqueue_script ( 'admin-gallery' );
2008-02-28 16:29:51 -05:00
return wp_iframe ( 'media_upload_gallery_form' , $errors );
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the legacy media library form in an iframe .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-03 01:17:22 -05:00
* @ return string | null
2008-10-01 21:03:26 -04:00
*/
2008-02-28 16:29:51 -05:00
function media_upload_library () {
2008-08-08 13:05:10 -04:00
$errors = array ();
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $_POST ) ) {
2008-02-28 16:29:51 -05:00
$return = media_upload_form_handler ();
2008-03-02 15:17:30 -05:00
2017-11-30 18:11:00 -05:00
if ( is_string ( $return ) ) {
2008-02-28 16:29:51 -05:00
return $return ;
2017-11-30 18:11:00 -05:00
}
if ( is_array ( $return ) ) {
2008-02-28 16:29:51 -05:00
$errors = $return ;
2017-11-30 18:11:00 -05:00
}
2008-02-28 16:29:51 -05:00
}
return wp_iframe ( 'media_upload_library_form' , $errors );
2008-01-25 14:21:11 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2008-10-12 22:48:45 -04:00
* Retrieve HTML for the image alignment radio buttons with the specified one checked .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.7 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-30 20:00:22 -05:00
* @ param WP_Post $post
2020-07-23 16:01:04 -04:00
* @ param string $checked
2012-09-16 14:31:42 -04:00
* @ return string
2008-10-01 21:03:26 -04:00
*/
2009-05-07 13:28:51 -04:00
function image_align_input_fields ( $post , $checked = '' ) {
2008-12-09 13:03:31 -05:00
2017-11-30 18:11:00 -05:00
if ( empty ( $checked ) ) {
$checked = get_user_setting ( 'align' , 'none' );
}
2009-11-15 20:37:30 -05:00
2017-11-30 18:11:00 -05:00
$alignments = array (
'none' => __ ( 'None' ),
'left' => __ ( 'Left' ),
'center' => __ ( 'Center' ),
'right' => __ ( 'Right' ),
);
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! array_key_exists ( ( string ) $checked , $alignments ) ) {
2008-08-15 11:40:35 -04:00
$checked = 'none' ;
2017-11-30 18:11:00 -05:00
}
2008-12-09 13:03:31 -05:00
2008-08-15 11:40:35 -04:00
$out = array ();
2019-09-03 21:11:54 -04:00
2009-11-15 20:37:30 -05:00
foreach ( $alignments as $name => $label ) {
2017-11-30 18:11:00 -05:00
$name = esc_attr ( $name );
$out [] = " <input type='radio' name='attachments[ { $post -> ID } ][align]' id='image-align- { $name } - { $post -> ID } ' value=' $name ' " .
( $checked == $name ? " checked='checked' " : '' ) .
2009-11-15 20:37:30 -05:00
" /><label for='image-align- { $name } - { $post -> ID } ' class='align image-align- { $name } -label'> $label </label> " ;
2008-08-15 11:40:35 -04:00
}
2019-09-03 21:11:54 -04:00
2020-10-18 13:27:06 -04:00
return implode ( " \n " , $out );
2008-08-15 11:40:35 -04:00
}
2008-10-01 21:03:26 -04:00
/**
2008-10-12 22:48:45 -04:00
* Retrieve HTML for the size radio buttons with the specified one checked .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.7 . 0
2008-10-01 21:03:26 -04:00
*
2020-07-23 16:01:04 -04:00
* @ param WP_Post $post
2012-09-16 14:31:42 -04:00
* @ param bool | string $check
* @ return array
2008-10-01 21:03:26 -04:00
*/
2009-11-15 20:37:30 -05:00
function image_size_input_fields ( $post , $check = '' ) {
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the names and labels of the default image sizes .
2014-01-06 00:48:12 -05:00
*
* @ since 3.3 . 0
*
2019-10-26 17:09:04 -04:00
* @ param string [] $size_names Array of image size labels keyed by their name . Default values
* include 'Thumbnail' , 'Medium' , 'Large' , and 'Full Size' .
2014-01-06 00:48:12 -05:00
*/
2017-11-30 18:11:00 -05:00
$size_names = apply_filters (
2018-08-16 21:51:36 -04:00
'image_size_names_choose' ,
array (
2017-11-30 18:11:00 -05:00
'thumbnail' => __ ( 'Thumbnail' ),
'medium' => __ ( 'Medium' ),
'large' => __ ( 'Large' ),
'full' => __ ( 'Full Size' ),
)
);
2008-12-07 15:35:50 -05:00
2014-12-20 17:19:24 -05:00
if ( empty ( $check ) ) {
2017-11-30 18:11:00 -05:00
$check = get_user_setting ( 'imgsize' , 'medium' );
2014-12-20 17:19:24 -05:00
}
2019-09-03 21:11:54 -04:00
2014-12-20 17:19:24 -05:00
$out = array ();
foreach ( $size_names as $size => $label ) {
$downsize = image_downsize ( $post -> ID , $size );
2017-11-30 18:11:00 -05:00
$checked = '' ;
2008-12-09 13:03:31 -05:00
2014-12-20 17:19:24 -05:00
// Is this size selectable?
2020-05-16 14:42:12 -04:00
$enabled = ( $downsize [ 3 ] || 'full' === $size );
2017-11-30 18:11:00 -05:00
$css_id = " image-size- { $size } - { $post -> ID } " ;
2008-12-09 13:03:31 -05:00
2014-12-20 17:19:24 -05:00
// If this size is the default but that's not available, don't select it.
if ( $size == $check ) {
if ( $enabled ) {
$checked = " checked='checked' " ;
} else {
$check = '' ;
}
2020-05-16 14:42:12 -04:00
} elseif ( ! $check && $enabled && 'thumbnail' !== $size ) {
2014-12-20 17:19:24 -05:00
/*
* If $check is not enabled , default to the first available size
* that ' s bigger than a thumbnail .
*/
2017-11-30 18:11:00 -05:00
$check = $size ;
2014-12-20 17:19:24 -05:00
$checked = " checked='checked' " ;
}
2014-07-17 05:14:16 -04:00
2014-12-20 17:19:24 -05:00
$html = " <div class='image-size-item'><input type='radio' " . disabled ( $enabled , false , false ) . " name='attachments[ $post->ID ][image-size]' id=' { $css_id } ' value=' { $size } ' $checked /> " ;
2008-12-09 13:03:31 -05:00
2014-12-20 17:19:24 -05:00
$html .= " <label for=' { $css_id } '> $label </label> " ;
2008-12-09 13:03:31 -05:00
2014-12-20 17:19:24 -05:00
// Only show the dimensions if that choice is available.
if ( $enabled ) {
2017-11-30 18:11:00 -05:00
$html .= " <label for=' { $css_id } ' class='help'> " . sprintf ( '(%d × %d)' , $downsize [ 1 ], $downsize [ 2 ] ) . '</label>' ;
2008-08-10 23:54:26 -04:00
}
2014-12-20 17:19:24 -05:00
$html .= '</div>' ;
2008-12-09 13:03:31 -05:00
2014-12-20 17:19:24 -05:00
$out [] = $html ;
}
return array (
'label' => __ ( 'Size' ),
'input' => 'html' ,
2020-10-18 13:27:06 -04:00
'html' => implode ( " \n " , $out ),
2014-12-20 17:19:24 -05:00
);
2008-08-10 23:54:26 -04:00
}
2008-10-01 21:03:26 -04:00
/**
2008-10-12 22:48:45 -04:00
* Retrieve HTML for the Link URL buttons with the default link type as specified .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.7 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-30 20:00:22 -05:00
* @ param WP_Post $post
2020-07-23 16:01:04 -04:00
* @ param string $url_type
2012-09-16 14:31:42 -04:00
* @ return string
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function image_link_input_fields ( $post , $url_type = '' ) {
2008-08-15 11:40:35 -04:00
2017-11-30 18:11:00 -05:00
$file = wp_get_attachment_url ( $post -> ID );
$link = get_attachment_link ( $post -> ID );
2008-08-15 11:40:35 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $url_type ) ) {
$url_type = get_user_setting ( 'urlbutton' , 'post' );
}
2009-11-15 20:37:30 -05:00
2008-08-15 11:40:35 -04:00
$url = '' ;
2019-09-03 21:11:54 -04:00
2020-02-09 11:55:09 -05:00
if ( 'file' === $url_type ) {
2008-08-15 11:40:35 -04:00
$url = $file ;
2020-02-09 11:55:09 -05:00
} elseif ( 'post' === $url_type ) {
2008-08-15 11:40:35 -04:00
$url = $link ;
2017-11-30 18:11:00 -05:00
}
2008-12-09 13:03:31 -05:00
2009-11-15 20:37:30 -05:00
return "
2017-11-30 18:11:00 -05:00
< input type = 'text' class = 'text urlfield' name = 'attachments[$post->ID][url]' value = '" . esc_attr( $url ) . "' />< br />
< button type = 'button' class = 'button urlnone' data - link - url = '' > " . __( 'None' ) . " </ button >
< button type = 'button' class = 'button urlfile' data - link - url = '" . esc_attr( $file ) . "' > " . __( 'File URL' ) . " </ button >
< button type = 'button' class = 'button urlpost' data - link - url = '" . esc_attr( $link ) . "' > " . __( 'Attachment Post URL' ) . '</button>
' ;
2008-08-15 11:40:35 -04:00
}
2015-05-03 21:13:25 -04:00
/**
* Output a textarea element for inputting an attachment caption .
*
* @ since 3.4 . 0
*
* @ param WP_Post $edit_post Attachment WP_Post object .
* @ return string HTML markup for the textarea element .
*/
2017-11-30 18:11:00 -05:00
function wp_caption_input_textarea ( $edit_post ) {
2014-07-17 05:14:16 -04:00
// Post data is already escaped.
2012-02-23 20:58:18 -05:00
$name = " attachments[ { $edit_post -> ID } ][post_excerpt] " ;
2012-03-21 18:48:36 -04:00
return '<textarea name="' . $name . '" id="' . $name . '">' . $edit_post -> post_excerpt . '</textarea>' ;
2012-02-23 20:58:18 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the image attachment fields to edit form fields .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2020-07-23 16:01:04 -04:00
* @ param array $form_fields
2012-09-16 14:31:42 -04:00
* @ param object $post
* @ return array
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function image_attachment_fields_to_edit ( $form_fields , $post ) {
2008-02-16 16:54:47 -05:00
return $form_fields ;
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the single non - image attachment fields to edit form fields .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-05-30 13:38:14 -04:00
* @ param array $form_fields An array of attachment form fields .
* @ param WP_Post $post The WP_Post attachment object .
* @ return array Filtered attachment form fields .
2008-10-01 21:03:26 -04:00
*/
2008-03-12 01:50:07 -04:00
function media_single_attachment_fields_to_edit ( $form_fields , $post ) {
2017-11-30 18:11:00 -05:00
unset ( $form_fields [ 'url' ], $form_fields [ 'align' ], $form_fields [ 'image-size' ] );
2008-03-12 01:50:07 -04:00
return $form_fields ;
}
2010-12-01 14:24:38 -05:00
/**
2020-01-04 13:00:06 -05:00
* Retrieves the post non - image attachment fields to edit form fields .
2010-12-01 14:24:38 -05:00
*
* @ since 2.8 . 0
*
2014-05-30 13:38:14 -04:00
* @ param array $form_fields An array of attachment form fields .
* @ param WP_Post $post The WP_Post attachment object .
* @ return array Filtered attachment form fields .
2010-12-01 14:24:38 -05:00
*/
2009-03-04 03:22:25 -05:00
function media_post_single_attachment_fields_to_edit ( $form_fields , $post ) {
2017-11-30 18:11:00 -05:00
unset ( $form_fields [ 'image_url' ] );
2009-03-04 03:22:25 -05:00
return $form_fields ;
}
2008-10-01 21:03:26 -04:00
/**
2016-07-04 18:45:29 -04:00
* Filters input from media_upload_form_handler () and assigns a default
2012-09-21 18:52:54 -04:00
* post_title from the file name if none supplied .
2012-06-28 16:31:28 -04:00
*
2016-05-23 13:28:27 -04:00
* Illustrates the use of the { @ see 'attachment_fields_to_save' } filter
2012-06-28 16:31:28 -04:00
* which can be used to add default values to any field before saving to DB .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-03 02:09:23 -05:00
* @ param array $post The WP_Post attachment object converted to an array .
* @ param array $attachment An array of attachment metadata .
2014-05-30 13:38:14 -04:00
* @ return array Filtered attachment post object .
2008-10-01 21:03:26 -04:00
*/
2013-09-06 10:10:09 -04:00
function image_attachment_fields_to_save ( $post , $attachment ) {
2020-05-16 14:42:12 -04:00
if ( 'image' === substr ( $post [ 'post_mime_type' ], 0 , 5 ) ) {
2013-09-06 10:10:09 -04:00
if ( strlen ( trim ( $post [ 'post_title' ] ) ) == 0 ) {
2017-11-30 18:11:00 -05:00
$attachment_url = ( isset ( $post [ 'attachment_url' ] ) ) ? $post [ 'attachment_url' ] : $post [ 'guid' ];
$post [ 'post_title' ] = preg_replace ( '/\.\w+$/' , '' , wp_basename ( $attachment_url ) );
2013-09-06 10:10:09 -04:00
$post [ 'errors' ][ 'post_title' ][ 'errors' ][] = __ ( 'Empty Title filled from filename.' );
2008-02-16 16:54:47 -05:00
}
}
return $post ;
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the media element HTML to send to the editor .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2020-07-23 16:01:04 -04:00
* @ param string $html
2020-10-10 16:02:05 -04:00
* @ param int $attachment_id
2020-07-23 16:01:04 -04:00
* @ param array $attachment
2014-11-03 02:09:23 -05:00
* @ return string
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function image_media_send_to_editor ( $html , $attachment_id , $attachment ) {
$post = get_post ( $attachment_id );
2019-09-03 21:11:54 -04:00
2020-05-16 14:42:12 -04:00
if ( 'image' === substr ( $post -> post_mime_type , 0 , 5 ) ) {
2017-11-30 18:11:00 -05:00
$url = $attachment [ 'url' ];
$align = ! empty ( $attachment [ 'align' ] ) ? $attachment [ 'align' ] : 'none' ;
$size = ! empty ( $attachment [ 'image-size' ] ) ? $attachment [ 'image-size' ] : 'medium' ;
$alt = ! empty ( $attachment [ 'image_alt' ] ) ? $attachment [ 'image_alt' ] : '' ;
2020-02-09 11:55:09 -05:00
$rel = ( strpos ( $url , 'attachment_id' ) || get_attachment_link ( $attachment_id ) === $url );
2008-03-27 23:53:05 -04:00
2017-11-30 18:11:00 -05:00
return get_image_send_to_editor ( $attachment_id , $attachment [ 'post_excerpt' ], $attachment [ 'post_title' ], $align , $url , $rel , $size , $alt );
2008-02-16 16:54:47 -05:00
}
return $html ;
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Retrieves the attachment fields to edit form fields .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2014-11-03 02:09:23 -05:00
* @ param WP_Post $post
2020-07-23 16:01:04 -04:00
* @ param array $errors
2012-09-16 14:31:42 -04:00
* @ return array
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function get_attachment_fields_to_edit ( $post , $errors = null ) {
if ( is_int ( $post ) ) {
$post = get_post ( $post );
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( is_array ( $post ) ) {
2012-08-23 16:01:10 -04:00
$post = new WP_Post ( ( object ) $post );
2017-11-30 18:11:00 -05:00
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
$image_url = wp_get_attachment_url ( $post -> ID );
2009-03-04 03:22:25 -05:00
2017-11-30 18:11:00 -05:00
$edit_post = sanitize_post ( $post , 'edit' );
2008-02-16 16:54:47 -05:00
$form_fields = array (
'post_title' => array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Title' ),
'value' => $edit_post -> post_title ,
2008-02-16 16:54:47 -05:00
),
2017-11-30 18:11:00 -05:00
'image_alt' => array (),
2008-02-16 16:54:47 -05:00
'post_excerpt' => array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Caption' ),
'input' => 'html' ,
'html' => wp_caption_input_textarea ( $edit_post ),
2008-02-16 16:54:47 -05:00
),
'post_content' => array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Description' ),
'value' => $edit_post -> post_content ,
'input' => 'textarea' ,
2008-02-28 16:29:51 -05:00
),
'url' => array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Link URL' ),
'input' => 'html' ,
'html' => image_link_input_fields ( $post , get_option ( 'image_default_link_type' ) ),
'helps' => __ ( 'Enter a link URL or click above for presets.' ),
2008-02-16 16:54:47 -05:00
),
2008-09-16 20:40:10 -04:00
'menu_order' => array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Order' ),
'value' => $edit_post -> menu_order ,
),
'image_url' => array (
'label' => __ ( 'File URL' ),
'input' => 'html' ,
'html' => " <input type='text' class='text urlfield' readonly='readonly' name='attachments[ $post->ID ][url]' value=' " . esc_attr ( $image_url ) . " ' /><br /> " ,
'value' => wp_get_attachment_url ( $post -> ID ),
'helps' => __ ( 'Location of the uploaded file.' ),
2008-05-21 14:29:46 -04:00
),
2008-02-16 16:54:47 -05:00
);
2017-11-30 18:11:00 -05:00
foreach ( get_attachment_taxonomies ( $post ) as $taxonomy ) {
$t = ( array ) get_taxonomy ( $taxonomy );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $t [ 'public' ] || ! $t [ 'show_ui' ] ) {
2010-10-28 14:53:09 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $t [ 'label' ] ) ) {
2008-02-16 16:54:47 -05:00
$t [ 'label' ] = $taxonomy ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $t [ 'args' ] ) ) {
2008-02-16 16:54:47 -05:00
$t [ 'args' ] = array ();
2017-11-30 18:11:00 -05:00
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
$terms = get_object_term_cache ( $post -> ID , $taxonomy );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( false === $terms ) {
$terms = wp_get_object_terms ( $post -> ID , $taxonomy , $t [ 'args' ] );
}
2008-02-16 16:54:47 -05:00
$values = array ();
2017-11-30 18:11:00 -05:00
foreach ( $terms as $term ) {
2012-09-18 13:34:01 -04:00
$values [] = $term -> slug ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2020-10-18 13:27:06 -04:00
$t [ 'value' ] = implode ( ', ' , $values );
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
$form_fields [ $taxonomy ] = $t ;
2008-02-16 16:54:47 -05:00
}
2020-01-17 19:54:04 -05:00
/*
* Merge default fields with their errors , so any key passed with the error
* ( e . g . 'error' , 'helps' , 'value' ) will replace the default .
* The recursive merge is easily traversed with array casting :
* foreach ( ( array ) $things as $thing )
*/
2017-11-30 18:11:00 -05:00
$form_fields = array_merge_recursive ( $form_fields , ( array ) $errors );
2008-02-22 00:53:47 -05:00
2012-11-19 03:10:38 -05:00
// This was formerly in image_attachment_fields_to_edit().
2020-05-16 14:42:12 -04:00
if ( 'image' === substr ( $post -> post_mime_type , 0 , 5 ) ) {
2017-11-30 18:11:00 -05:00
$alt = get_post_meta ( $post -> ID , '_wp_attachment_image_alt' , true );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $alt ) ) {
2012-11-19 03:10:38 -05:00
$alt = '' ;
2017-11-30 18:11:00 -05:00
}
2012-11-19 03:10:38 -05:00
$form_fields [ 'post_title' ][ 'required' ] = true ;
$form_fields [ 'image_alt' ] = array (
'value' => $alt ,
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Alternative Text' ),
'helps' => __ ( 'Alt text for the image, e.g. “The Mona Lisa”' ),
2012-11-19 03:10:38 -05:00
);
$form_fields [ 'align' ] = array (
2017-11-30 18:11:00 -05:00
'label' => __ ( 'Alignment' ),
2012-11-19 03:10:38 -05:00
'input' => 'html' ,
2017-11-30 18:11:00 -05:00
'html' => image_align_input_fields ( $post , get_option ( 'image_default_align' ) ),
2012-11-19 03:10:38 -05:00
);
2017-11-30 18:11:00 -05:00
$form_fields [ 'image-size' ] = image_size_input_fields ( $post , get_option ( 'image_default_size' , 'medium' ) );
2012-11-19 03:10:38 -05:00
} else {
unset ( $form_fields [ 'image_alt' ] );
}
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the attachment fields to edit .
2014-01-06 00:48:12 -05:00
*
* @ since 2.5 . 0
*
* @ param array $form_fields An array of attachment form fields .
* @ param WP_Post $post The WP_Post attachment object .
*/
$form_fields = apply_filters ( 'attachment_fields_to_edit' , $form_fields , $post );
2008-02-16 16:54:47 -05:00
return $form_fields ;
}
2008-10-01 21:03:26 -04:00
/**
2008-10-12 22:48:45 -04:00
* Retrieve HTML for media items of post gallery .
*
* The HTML markup retrieved will be created for the progress of SWF Upload
* component . Will also create link for showing and hiding the form to modify
* the image attachment .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2019-08-03 21:59:56 -04:00
* @ global WP_Query $wp_the_query WordPress Query object .
2015-05-28 17:41:30 -04:00
*
2021-10-30 16:17:01 -04:00
* @ param int $post_id Post ID .
2020-07-23 16:01:04 -04:00
* @ param array $errors Errors for attachment , if any .
2008-10-12 22:48:45 -04:00
* @ return string
2008-10-01 21:03:26 -04:00
*/
2008-02-28 16:29:51 -05:00
function get_media_items ( $post_id , $errors ) {
2010-04-10 08:49:58 -04:00
$attachments = array ();
2019-09-03 21:11:54 -04:00
2008-04-14 12:30:27 -04:00
if ( $post_id ) {
2017-11-30 18:11:00 -05:00
$post = get_post ( $post_id );
2019-09-03 21:11:54 -04:00
2020-02-09 11:55:09 -05:00
if ( $post && 'attachment' === $post -> post_type ) {
2017-11-30 18:11:00 -05:00
$attachments = array ( $post -> ID => $post );
} else {
$attachments = get_children (
array (
'post_parent' => $post_id ,
'post_type' => 'attachment' ,
'orderby' => 'menu_order ASC, ID' ,
'order' => 'DESC' ,
)
);
}
2008-02-28 16:29:51 -05:00
} else {
2017-11-30 18:11:00 -05:00
if ( is_array ( $GLOBALS [ 'wp_the_query' ] -> posts ) ) {
foreach ( $GLOBALS [ 'wp_the_query' ] -> posts as $attachment ) {
$attachments [ $attachment -> ID ] = $attachment ;
}
}
2008-02-28 16:29:51 -05:00
}
2008-11-14 18:01:16 -05:00
$output = '' ;
2009-08-19 04:35:24 -04:00
foreach ( ( array ) $attachments as $id => $attachment ) {
2020-02-09 11:55:09 -05:00
if ( 'trash' === $attachment -> post_status ) {
2009-08-19 04:35:24 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
$item = get_media_item ( $id , array ( 'errors' => isset ( $errors [ $id ] ) ? $errors [ $id ] : null ) );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $item ) {
2011-11-13 13:37:30 -05:00
$output .= " \n <div id='media-item- $id ' class='media-item child-of- $attachment->post_parent preloaded'><div class='progress hidden'><div class='bar'></div></div><div id='media-upload-error- $id ' class='hidden'></div><div class='filename hidden'></div> $item\n </div> " ;
2017-11-30 18:11:00 -05:00
}
2009-08-19 04:35:24 -04:00
}
2008-02-28 16:29:51 -05:00
return $output ;
}
2008-10-01 21:03:26 -04:00
/**
2008-10-12 22:48:45 -04:00
* Retrieve HTML form for modifying the image attachment .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2015-05-28 17:41:30 -04:00
* @ global string $redir_tab
*
2020-07-23 16:01:04 -04:00
* @ param int $attachment_id Attachment ID for modification .
* @ param string | array $args Optional . Override defaults .
2008-10-12 22:48:45 -04:00
* @ return string HTML form for attachment .
2008-10-01 21:03:26 -04:00
*/
2008-03-12 01:50:07 -04:00
function get_media_item ( $attachment_id , $args = null ) {
2009-10-26 13:56:28 -04:00
global $redir_tab ;
2008-03-12 01:50:07 -04:00
2019-07-01 08:52:01 -04:00
$thumb_url = false ;
2020-10-08 17:15:13 -04:00
$attachment_id = ( int ) $attachment_id ;
2019-07-01 08:52:01 -04:00
if ( $attachment_id ) {
$thumb_url = wp_get_attachment_image_src ( $attachment_id , 'thumbnail' , true );
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $thumb_url ) {
$thumb_url = $thumb_url [ 0 ];
}
2017-11-30 18:11:00 -05:00
}
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
$post = get_post ( $attachment_id );
$current_post_id = ! empty ( $_GET [ 'post_id' ] ) ? ( int ) $_GET [ 'post_id' ] : 0 ;
2010-11-17 13:47:34 -05:00
2014-05-14 22:45:15 -04:00
$default_args = array (
2017-11-30 18:11:00 -05:00
'errors' => null ,
'send' => $current_post_id ? post_type_supports ( get_post_type ( $current_post_id ), 'editor' ) : true ,
'delete' => true ,
'toggle' => true ,
'show_title' => true ,
2014-05-14 22:45:15 -04:00
);
2019-07-24 20:48:58 -04:00
$parsed_args = wp_parse_args ( $args , $default_args );
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the arguments used to retrieve an image for the edit image form .
2014-01-06 00:48:12 -05:00
*
* @ since 3.1 . 0
*
* @ see get_media_item
*
2019-07-24 20:48:58 -04:00
* @ param array $parsed_args An array of arguments .
2014-01-06 00:48:12 -05:00
*/
2019-07-24 20:48:58 -04:00
$parsed_args = apply_filters ( 'get_media_item_args' , $parsed_args );
2009-10-21 03:27:33 -04:00
2009-12-25 18:04:48 -05:00
$toggle_on = __ ( 'Show' );
$toggle_off = __ ( 'Hide' );
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
$file = get_attached_file ( $post -> ID );
2015-09-14 22:50:25 -04:00
$filename = esc_html ( wp_basename ( $file ) );
2017-11-30 18:11:00 -05:00
$title = esc_attr ( $post -> post_title );
2008-11-15 13:10:35 -05:00
2009-10-26 13:56:28 -04:00
$post_mime_types = get_post_mime_types ();
2017-11-30 18:11:00 -05:00
$keys = array_keys ( wp_match_mime_types ( array_keys ( $post_mime_types ), $post -> post_mime_type ) );
$type = reset ( $keys );
$type_html = " <input type='hidden' id='type-of- $attachment_id ' value=' " . esc_attr ( $type ) . " ' /> " ;
2008-02-28 16:29:51 -05:00
2019-07-24 20:48:58 -04:00
$form_fields = get_attachment_fields_to_edit ( $post , $parsed_args [ 'errors' ] );
2008-01-25 14:21:11 -05:00
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'toggle' ] ) {
$class = empty ( $parsed_args [ 'errors' ] ) ? 'startclosed' : 'startopen' ;
2008-03-12 01:50:07 -04:00
$toggle_links = "
2019-09-03 21:11:54 -04:00
< a class = 'toggle describe-toggle-on' href = '#' > $toggle_on </ a >
< a class = 'toggle describe-toggle-off' href = '#' > $toggle_off </ a > " ;
2008-03-12 01:50:07 -04:00
} else {
2017-11-30 18:11:00 -05:00
$class = '' ;
2008-03-12 01:50:07 -04:00
$toggle_links = '' ;
}
2020-01-17 19:54:04 -05:00
$display_title = ( ! empty ( $title ) ) ? $title : $filename ; // $title shouldn't ever be empty, but just in case.
2019-07-24 20:48:58 -04:00
$display_title = $parsed_args [ 'show_title' ] ? " <div class='filename new'><span class='title'> " . wp_html_excerpt ( $display_title , 60 , '…' ) . '</span></div>' : '' ;
2008-07-09 23:49:52 -04:00
2020-05-16 14:42:12 -04:00
$gallery = ( ( isset ( $_REQUEST [ 'tab' ] ) && 'gallery' === $_REQUEST [ 'tab' ] ) || ( isset ( $redir_tab ) && 'gallery' === $redir_tab ) );
2017-11-30 18:11:00 -05:00
$order = '' ;
2008-07-09 23:49:52 -04:00
foreach ( $form_fields as $key => $val ) {
2020-05-16 14:42:12 -04:00
if ( 'menu_order' === $key ) {
2017-11-30 18:11:00 -05:00
if ( $gallery ) {
$order = " <div class='menu_order'> <input class='menu_order_input' type='text' id='attachments[ $attachment_id ][menu_order]' name='attachments[ $attachment_id ][menu_order]' value=' " . esc_attr ( $val [ 'value' ] ) . " ' /></div> " ;
} else {
2009-12-25 18:04:48 -05:00
$order = " <input type='hidden' name='attachments[ $attachment_id ][menu_order]' value=' " . esc_attr ( $val [ 'value' ] ) . " ' /> " ;
2017-11-30 18:11:00 -05:00
}
2008-07-09 23:49:52 -04:00
2009-12-25 18:04:48 -05:00
unset ( $form_fields [ 'menu_order' ] );
2008-07-09 23:49:52 -04:00
break ;
}
}
2008-03-26 17:00:21 -04:00
2009-09-10 18:07:33 -04:00
$media_dims = '' ;
2017-11-30 18:11:00 -05:00
$meta = wp_get_attachment_metadata ( $post -> ID );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $meta [ 'width' ], $meta [ 'height' ] ) ) {
2009-12-25 18:04:48 -05:00
$media_dims .= " <span id='media-dims- $post->ID '> { $meta [ 'width' ] } × { $meta [ 'height' ] } </span> " ;
2017-11-30 18:11:00 -05:00
}
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the media metadata .
2014-01-06 00:48:12 -05:00
*
* @ since 2.5 . 0
*
* @ param string $media_dims The HTML markup containing the media dimensions .
* @ param WP_Post $post The WP_Post attachment object .
*/
2009-12-25 18:04:48 -05:00
$media_dims = apply_filters ( 'media_meta' , $media_dims , $post );
2009-09-10 18:07:33 -04:00
$image_edit_button = '' ;
2019-09-03 21:11:54 -04:00
2012-11-27 10:06:02 -05:00
if ( wp_attachment_is_image ( $post -> ID ) && wp_image_editor_supports ( array ( 'mime_type' => $post -> post_mime_type ) ) ) {
2017-11-30 18:11:00 -05:00
$nonce = wp_create_nonce ( " image_editor- $post->ID " );
2012-09-26 15:57:44 -04:00
$image_edit_button = " <input type='button' id='imgedit-open-btn- $post->ID ' onclick='imageEdit.open( $post->ID , \" $nonce\ " ) ' class=' button ' value=' " . esc_attr__( 'Edit Image' ) . " ' /> <span class=' spinner ' ></ span > " ;
2009-09-10 18:07:33 -04:00
}
2009-12-25 17:22:21 -05:00
$attachment_url = get_permalink ( $attachment_id );
2008-01-25 14:21:11 -05:00
$item = "
2019-09-03 21:11:54 -04:00
$type_html
$toggle_links
$order
$display_title
< table class = 'slidetoggle describe $class' >
< thead class = 'media-item-info' id = 'media-head-$post->ID' >
< tr >
2009-12-25 18:04:48 -05:00
< td class = 'A1B1' id = 'thumbnail-head-$post->ID' >
2011-11-11 19:52:26 -05:00
< p >< a href = '$attachment_url' target = '_blank' >< img class = 'thumbnail' src = '$thumb_url' alt = '' /></ a ></ p >
2009-12-25 18:04:48 -05:00
< p > $image_edit_button </ p >
2009-12-25 17:22:21 -05:00
</ td >
2009-12-25 18:04:48 -05:00
< td >
2017-11-30 18:11:00 -05:00
< p >< strong > " . __( 'File name:' ) . " </ strong > $filename </ p >
< p >< strong > " . __( 'File type:' ) . " </ strong > $post -> post_mime_type </ p >
< p >< strong > " . __( 'Upload date:' ) . '</strong> ' . mysql2date( __( 'F j, Y' ), $post->post_date ) . '</p>';
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $media_dims ) ) {
$item .= '<p><strong>' . __ ( 'Dimensions:' ) . " </strong> $media_dims </p> \n " ;
}
2010-01-15 17:11:12 -05:00
2019-09-03 21:11:54 -04:00
$item .= " </td></tr> \n " ;
2009-12-12 02:02:26 -05:00
$item .= "
2008-04-14 12:33:37 -04:00
</ thead >
2009-09-10 18:07:33 -04:00
< tbody >
2016-03-07 17:29:26 -05:00
< tr >< td colspan = '2' class = 'imgedit-response' id = 'imgedit-response-$post->ID' ></ td ></ tr > \n
< tr >< td style = 'display:none' colspan = '2' class = 'image-editor' id = 'image-editor-$post->ID' ></ td ></ tr > \n
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
< tr >< td colspan = '2' >< p class = 'media-types media-types-required-info' > " .
2019-09-02 20:41:05 -04:00
/* translators: %s: Asterisk symbol (*). */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
sprintf ( __ ( 'Required fields are marked %s' ), '<span class="required">*</span>' ) .
" </p></td></tr> \n " ;
2008-02-16 16:54:47 -05:00
$defaults = array (
'input' => 'text' ,
'required' => false ,
'value' => '' ,
'extra_rows' => array (),
);
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'send' ] ) {
$parsed_args [ 'send' ] = get_submit_button ( __ ( 'Insert into Post' ), '' , " send[ $attachment_id ] " , false );
2014-05-14 22:45:15 -04:00
}
2019-07-24 20:48:58 -04:00
$delete = empty ( $parsed_args [ 'delete' ] ) ? '' : $parsed_args [ 'delete' ];
2009-12-25 18:04:48 -05:00
if ( $delete && current_user_can ( 'delete_post' , $attachment_id ) ) {
2017-11-30 18:11:00 -05:00
if ( ! EMPTY_TRASH_DAYS ) {
2012-08-14 14:39:15 -04:00
$delete = " <a href=' " . wp_nonce_url ( " post.php?action=delete&post= $attachment_id " , 'delete-post_' . $attachment_id ) . " ' id='del[ $attachment_id ]' class='delete-permanently'> " . __ ( 'Delete Permanently' ) . '</a>' ;
2017-11-30 18:11:00 -05:00
} elseif ( ! MEDIA_TRASH ) {
2009-12-25 18:04:48 -05:00
$delete = " <a href='#' class='del-link' onclick= \" document.getElementById('del_attachment_ $attachment_id ').style.display='block';return false; \" > " . __ ( 'Delete' ) . " </a>
2017-11-26 18:57:55 -05:00
< div id = 'del_attachment_$attachment_id' class = 'del-attachment' style = 'display:none;' > " .
2019-09-02 20:41:05 -04:00
/* translators: %s: File name. */
2017-11-26 18:57:55 -05:00
'<p>' . sprintf ( __ ( 'You are about to delete %s.' ), '<strong>' . $filename . '</strong>' ) . " </p>
< a href = '" . wp_nonce_url( "post.php?action=delete&post=$attachment_id", ' delete - post_ ' . $attachment_id ) . "' id = 'del[$attachment_id]' class = 'button' > " . __( 'Continue' ) . " </ a >
2017-11-30 18:11:00 -05:00
< a href = '#' class = 'button' onclick = \ " this.parentNode.style.display='none';return false; \" > " . __ ( 'Cancel' ) . ' </ a >
</ div > ' ;
2009-12-12 01:40:16 -05:00
} else {
2012-08-14 14:39:15 -04:00
$delete = " <a href=' " . wp_nonce_url ( " post.php?action=trash&post= $attachment_id " , 'trash-post_' . $attachment_id ) . " ' id='del[ $attachment_id ]' class='delete'> " . __ ( 'Move to Trash' ) . " </a>
2017-11-30 18:11:00 -05:00
< a href = '" . wp_nonce_url( "post.php?action=untrash&post=$attachment_id", ' untrash - post_ ' . $attachment_id ) . "' id = 'undo[$attachment_id]' class = 'undo hidden' > " . __( 'Undo' ) . '</a>';
2009-12-12 01:40:16 -05:00
}
2009-11-10 05:38:19 -05:00
} else {
$delete = '' ;
}
2017-11-30 18:11:00 -05:00
$thumbnail = '' ;
2009-12-10 02:04:01 -05:00
$calling_post_id = 0 ;
2019-09-03 21:11:54 -04:00
2014-05-14 22:45:15 -04:00
if ( isset ( $_GET [ 'post_id' ] ) ) {
2010-05-18 18:08:49 -04:00
$calling_post_id = absint ( $_GET [ 'post_id' ] );
2020-01-17 19:54:04 -05:00
} elseif ( isset ( $_POST ) && count ( $_POST ) ) { // Like for async-upload where $_GET['post_id'] isn't set.
2009-12-10 02:04:01 -05:00
$calling_post_id = $post -> post_parent ;
2014-05-14 22:45:15 -04:00
}
2019-09-03 21:11:54 -04:00
2020-05-16 14:42:12 -04:00
if ( 'image' === $type && $calling_post_id
&& current_theme_supports ( 'post-thumbnails' , get_post_type ( $calling_post_id ) )
&& post_type_supports ( get_post_type ( $calling_post_id ), 'thumbnail' )
&& get_post_thumbnail_id ( $calling_post_id ) != $attachment_id
) {
2015-06-26 21:03:25 -04:00
2017-11-30 18:11:00 -05:00
$calling_post = get_post ( $calling_post_id );
2015-05-31 12:54:27 -04:00
$calling_post_type_object = get_post_type_object ( $calling_post -> post_type );
2010-05-18 18:08:49 -04:00
$ajax_nonce = wp_create_nonce ( " set_post_thumbnail- $calling_post_id " );
2017-11-30 18:11:00 -05:00
$thumbnail = " <a class='wp-post-thumbnail' id='wp-post-thumbnail- " . $attachment_id . " ' href='#' onclick='WPSetAsThumbnail( \" $attachment_id\ " , \ " $ajax_nonce\ " ); return false ; '>" . esc_html( $calling_post_type_object->labels->use_featured_image ) . ' </ a > ' ;
2010-05-18 18:08:49 -04:00
}
2009-10-21 03:27:33 -04:00
2019-07-24 20:48:58 -04:00
if ( ( $parsed_args [ 'send' ] || $thumbnail || $delete ) && ! isset ( $form_fields [ 'buttons' ] ) ) {
$form_fields [ 'buttons' ] = array ( 'tr' => " \t \t <tr class='submit'><td></td><td class='savesend'> " . $parsed_args [ 'send' ] . " $thumbnail $delete </td></tr> \n " );
2014-05-14 22:45:15 -04:00
}
2019-09-03 21:11:54 -04:00
2008-02-16 16:54:47 -05:00
$hidden_fields = array ();
foreach ( $form_fields as $id => $field ) {
2020-02-09 11:55:09 -05:00
if ( '_' === $id [ 0 ] ) {
2008-02-16 16:54:47 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'tr' ] ) ) {
2008-02-16 16:54:47 -05:00
$item .= $field [ 'tr' ];
continue ;
}
2009-12-25 18:04:48 -05:00
$field = array_merge ( $defaults , $field );
2017-11-30 18:11:00 -05:00
$name = " attachments[ $attachment_id ][ $id ] " ;
2008-02-16 16:54:47 -05:00
2020-02-09 11:55:09 -05:00
if ( 'hidden' === $field [ 'input' ] ) {
2017-11-30 18:11:00 -05:00
$hidden_fields [ $name ] = $field [ 'value' ];
2008-02-16 16:54:47 -05:00
continue ;
}
2016-03-07 17:29:26 -05:00
$required = $field [ 'required' ] ? '<span class="required">*</span>' : '' ;
$required_attr = $field [ 'required' ] ? ' required' : '' ;
2017-11-30 18:11:00 -05:00
$class = $id ;
$class .= $field [ 'required' ] ? ' form-required' : '' ;
2008-03-12 01:50:07 -04:00
2016-03-07 17:29:26 -05:00
$item .= " \t \t <tr class=' $class '> \n \t \t \t <th scope='row' class='label'><label for=' $name '><span class='alignleft'> { $field [ 'label' ] } { $required } </span><br class='clear' /></label></th> \n \t \t \t <td class='field'> " ;
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ $field [ 'input' ] ] ) ) {
2009-12-25 18:04:48 -05:00
$item .= $field [ $field [ 'input' ] ];
2020-02-09 11:55:09 -05:00
} elseif ( 'textarea' === $field [ 'input' ] ) {
2020-05-16 14:42:12 -04:00
if ( 'post_content' === $id && user_can_richedit () ) {
2014-07-17 05:14:16 -04:00
// Sanitize_post() skips the post_content when user_can_richedit.
2012-02-23 20:58:18 -05:00
$field [ 'value' ] = htmlspecialchars ( $field [ 'value' ], ENT_QUOTES );
2010-12-16 12:48:20 -05:00
}
2014-07-17 05:14:16 -04:00
// Post_excerpt is already escaped by sanitize_post() in get_attachment_fields_to_edit().
2018-02-26 18:10:31 -05:00
$item .= " <textarea id=' $name ' name=' $name ' { $required_attr } > " . $field [ 'value' ] . '</textarea>' ;
2008-02-16 16:54:47 -05:00
} else {
2018-02-26 18:10:31 -05:00
$item .= " <input type='text' class='text' id=' $name ' name=' $name ' value=' " . esc_attr ( $field [ 'value' ] ) . " ' { $required_attr } /> " ;
2008-02-16 16:54:47 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'helps' ] ) ) {
2020-10-18 13:27:06 -04:00
$item .= " <p class='help'> " . implode ( " </p> \n <p class='help'> " , array_unique ( ( array ) $field [ 'helps' ] ) ) . '</p>' ;
2017-11-30 18:11:00 -05:00
}
2008-02-16 16:54:47 -05:00
$item .= " </td> \n \t \t </tr> \n " ;
$extra_rows = array ();
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'errors' ] ) ) {
foreach ( array_unique ( ( array ) $field [ 'errors' ] ) as $error ) {
2008-02-16 16:54:47 -05:00
$extra_rows [ 'error' ][] = $error ;
2017-11-30 18:11:00 -05:00
}
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'extra_rows' ] ) ) {
foreach ( $field [ 'extra_rows' ] as $class => $rows ) {
foreach ( ( array ) $rows as $html ) {
$extra_rows [ $class ][] = $html ;
}
}
}
2008-02-16 16:54:47 -05:00
2017-11-30 18:11:00 -05:00
foreach ( $extra_rows as $class => $rows ) {
foreach ( $rows as $html ) {
2008-03-12 01:50:07 -04:00
$item .= " \t \t <tr><td></td><td class=' $class '> $html </td></tr> \n " ;
2017-11-30 18:11:00 -05:00
}
}
2008-02-16 16:54:47 -05:00
}
2017-11-30 18:11:00 -05:00
if ( ! empty ( $form_fields [ '_final' ] ) ) {
2008-03-12 01:50:07 -04:00
$item .= " \t \t <tr class='final'><td colspan='2'> { $form_fields [ '_final' ] } </td></tr> \n " ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2008-04-14 12:33:37 -04:00
$item .= " \t </tbody> \n " ;
2008-02-16 16:54:47 -05:00
$item .= " \t </table> \n " ;
2017-11-30 18:11:00 -05:00
foreach ( $hidden_fields as $name => $value ) {
2009-05-05 15:43:53 -04:00
$item .= " \t <input type='hidden' name=' $name ' id=' $name ' value=' " . esc_attr ( $value ) . " ' /> \n " ;
2017-11-30 18:11:00 -05:00
}
2008-01-25 14:21:11 -05:00
2009-12-25 18:04:48 -05:00
if ( $post -> post_parent < 1 && isset ( $_REQUEST [ 'post_id' ] ) ) {
2017-11-30 18:11:00 -05:00
$parent = ( int ) $_REQUEST [ 'post_id' ];
2008-12-05 01:21:42 -05:00
$parent_name = " attachments[ $attachment_id ][post_parent] " ;
2017-11-30 18:11:00 -05:00
$item .= " \t <input type='hidden' name=' $parent_name ' id=' $parent_name ' value=' $parent ' /> \n " ;
2008-12-05 01:21:42 -05:00
}
2008-01-25 14:21:11 -05:00
return $item ;
}
2015-05-30 23:18:25 -04:00
/**
* @ since 3.5 . 0
*
* @ param int $attachment_id
* @ param array $args
* @ return array
*/
2012-11-10 20:26:42 -05:00
function get_compat_media_markup ( $attachment_id , $args = null ) {
$post = get_post ( $attachment_id );
$default_args = array (
2017-11-30 18:11:00 -05:00
'errors' => null ,
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
'in_modal' => false ,
2012-11-10 20:26:42 -05:00
);
2012-12-05 05:29:24 -05:00
$user_can_edit = current_user_can ( 'edit_post' , $attachment_id );
2012-11-10 20:26:42 -05:00
$args = wp_parse_args ( $args , $default_args );
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
2012-11-10 20:26:42 -05:00
$args = apply_filters ( 'get_media_item_args' , $args );
2012-11-19 02:20:47 -05:00
$form_fields = array ();
2012-11-10 20:26:42 -05:00
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
if ( $args [ 'in_modal' ] ) {
2017-11-30 18:11:00 -05:00
foreach ( get_attachment_taxonomies ( $post ) as $taxonomy ) {
$t = ( array ) get_taxonomy ( $taxonomy );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $t [ 'public' ] || ! $t [ 'show_ui' ] ) {
2012-11-21 13:53:00 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $t [ 'label' ] ) ) {
2012-11-21 13:53:00 -05:00
$t [ 'label' ] = $taxonomy ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $t [ 'args' ] ) ) {
2012-11-21 13:53:00 -05:00
$t [ 'args' ] = array ();
2017-11-30 18:11:00 -05:00
}
2012-11-19 02:20:47 -05:00
2017-11-30 18:11:00 -05:00
$terms = get_object_term_cache ( $post -> ID , $taxonomy );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( false === $terms ) {
$terms = wp_get_object_terms ( $post -> ID , $taxonomy , $t [ 'args' ] );
}
2012-11-19 02:20:47 -05:00
2012-11-21 13:53:00 -05:00
$values = array ();
2012-11-19 02:20:47 -05:00
2017-11-30 18:11:00 -05:00
foreach ( $terms as $term ) {
2012-11-21 13:53:00 -05:00
$values [] = $term -> slug ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2020-10-18 13:27:06 -04:00
$t [ 'value' ] = implode ( ', ' , $values );
2012-12-05 05:29:24 -05:00
$t [ 'taxonomy' ] = true ;
2012-11-19 02:20:47 -05:00
2017-11-30 18:11:00 -05:00
$form_fields [ $taxonomy ] = $t ;
2012-11-21 13:53:00 -05:00
}
2012-11-19 02:20:47 -05:00
}
2020-01-17 19:54:04 -05:00
/*
* Merge default fields with their errors , so any key passed with the error
* ( e . g . 'error' , 'helps' , 'value' ) will replace the default .
* The recursive merge is easily traversed with array casting :
* foreach ( ( array ) $things as $thing )
*/
2017-11-30 18:11:00 -05:00
$form_fields = array_merge_recursive ( $form_fields , ( array ) $args [ 'errors' ] );
2012-11-19 02:20:47 -05:00
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
2012-11-19 02:20:47 -05:00
$form_fields = apply_filters ( 'attachment_fields_to_edit' , $form_fields , $post );
2017-11-30 18:11:00 -05:00
unset (
2018-08-16 21:51:36 -04:00
$form_fields [ 'image-size' ],
$form_fields [ 'align' ],
$form_fields [ 'image_alt' ],
$form_fields [ 'post_title' ],
$form_fields [ 'post_excerpt' ],
$form_fields [ 'post_content' ],
$form_fields [ 'url' ],
$form_fields [ 'menu_order' ],
$form_fields [ 'image_url' ]
2017-11-30 18:11:00 -05:00
);
2012-11-10 20:26:42 -05:00
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
2012-11-10 20:26:42 -05:00
$media_meta = apply_filters ( 'media_meta' , '' , $post );
$defaults = array (
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
'input' => 'text' ,
2014-03-19 18:13:14 -04:00
'required' => false ,
'value' => '' ,
'extra_rows' => array (),
'show_in_edit' => true ,
'show_in_modal' => true ,
2012-11-10 20:26:42 -05:00
);
$hidden_fields = array ();
$item = '' ;
2019-09-03 21:11:54 -04:00
2012-11-10 20:26:42 -05:00
foreach ( $form_fields as $id => $field ) {
2020-02-09 11:55:09 -05:00
if ( '_' === $id [ 0 ] ) {
2012-11-10 20:26:42 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2012-11-10 20:26:42 -05:00
2017-11-30 18:11:00 -05:00
$name = " attachments[ $attachment_id ][ $id ] " ;
2012-11-21 13:53:00 -05:00
$id_attr = " attachments- $attachment_id - $id " ;
2012-11-10 20:26:42 -05:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'tr' ] ) ) {
2012-11-10 20:26:42 -05:00
$item .= $field [ 'tr' ];
continue ;
}
$field = array_merge ( $defaults , $field );
2017-11-30 18:11:00 -05:00
if ( ( ! $field [ 'show_in_edit' ] && ! $args [ 'in_modal' ] ) || ( ! $field [ 'show_in_modal' ] && $args [ 'in_modal' ] ) ) {
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
2020-02-09 11:55:09 -05:00
if ( 'hidden' === $field [ 'input' ] ) {
2017-11-30 18:11:00 -05:00
$hidden_fields [ $name ] = $field [ 'value' ];
2012-11-10 20:26:42 -05:00
continue ;
}
2012-12-05 05:29:24 -05:00
$readonly = ! $user_can_edit && ! empty ( $field [ 'taxonomy' ] ) ? " readonly='readonly' " : '' ;
2016-03-07 17:29:26 -05:00
$required = $field [ 'required' ] ? '<span class="required">*</span>' : '' ;
$required_attr = $field [ 'required' ] ? ' required' : '' ;
2017-11-30 18:11:00 -05:00
$class = 'compat-field-' . $id ;
$class .= $field [ 'required' ] ? ' form-required' : '' ;
2012-11-10 20:26:42 -05:00
$item .= " \t \t <tr class=' $class '> " ;
2014-01-24 14:06:15 -05:00
$item .= " \t \t \t <th scope='row' class='label'><label for=' $id_attr '><span class='alignleft'> { $field [ 'label' ] } </span> $required <br class='clear' /></label> " ;
2012-11-10 20:26:42 -05:00
$item .= " </th> \n \t \t \t <td class='field'> " ;
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ $field [ 'input' ] ] ) ) {
2012-11-10 20:26:42 -05:00
$item .= $field [ $field [ 'input' ] ];
2020-02-09 11:55:09 -05:00
} elseif ( 'textarea' === $field [ 'input' ] ) {
2020-05-16 14:42:12 -04:00
if ( 'post_content' === $id && user_can_richedit () ) {
2014-07-17 05:14:16 -04:00
// sanitize_post() skips the post_content when user_can_richedit.
2012-11-10 20:26:42 -05:00
$field [ 'value' ] = htmlspecialchars ( $field [ 'value' ], ENT_QUOTES );
}
2018-02-26 18:10:31 -05:00
$item .= " <textarea id=' $id_attr ' name=' $name ' { $required_attr } > " . $field [ 'value' ] . '</textarea>' ;
2012-11-10 20:26:42 -05:00
} else {
2018-02-26 18:10:31 -05:00
$item .= " <input type='text' class='text' id=' $id_attr ' name=' $name ' value=' " . esc_attr ( $field [ 'value' ] ) . " ' $readonly { $required_attr } /> " ;
2012-11-10 20:26:42 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'helps' ] ) ) {
2020-10-18 13:27:06 -04:00
$item .= " <p class='help'> " . implode ( " </p> \n <p class='help'> " , array_unique ( ( array ) $field [ 'helps' ] ) ) . '</p>' ;
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2012-11-10 20:26:42 -05:00
$item .= " </td> \n \t \t </tr> \n " ;
$extra_rows = array ();
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'errors' ] ) ) {
foreach ( array_unique ( ( array ) $field [ 'errors' ] ) as $error ) {
2012-11-10 20:26:42 -05:00
$extra_rows [ 'error' ][] = $error ;
2017-11-30 18:11:00 -05:00
}
}
2012-11-10 20:26:42 -05:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $field [ 'extra_rows' ] ) ) {
foreach ( $field [ 'extra_rows' ] as $class => $rows ) {
foreach ( ( array ) $rows as $html ) {
$extra_rows [ $class ][] = $html ;
}
}
}
2012-11-10 20:26:42 -05:00
2017-11-30 18:11:00 -05:00
foreach ( $extra_rows as $class => $rows ) {
foreach ( $rows as $html ) {
2012-11-10 20:26:42 -05:00
$item .= " \t \t <tr><td></td><td class=' $class '> $html </td></tr> \n " ;
2017-11-30 18:11:00 -05:00
}
}
2012-11-10 20:26:42 -05:00
}
2017-11-30 18:11:00 -05:00
if ( ! empty ( $form_fields [ '_final' ] ) ) {
2012-11-10 20:26:42 -05:00
$item .= " \t \t <tr class='final'><td colspan='2'> { $form_fields [ '_final' ] } </td></tr> \n " ;
2017-11-30 18:11:00 -05:00
}
2016-03-07 17:29:26 -05:00
if ( $item ) {
$item = '<p class="media-types media-types-required-info">' .
2019-09-02 20:41:05 -04:00
/* translators: %s: Asterisk symbol (*). */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
sprintf ( __ ( 'Required fields are marked %s' ), '<span class="required">*</span>' ) .
'</p>' .
'<table class="compat-attachment-fields">' . $item . '</table>' ;
2016-03-07 17:29:26 -05:00
}
2012-11-10 20:26:42 -05:00
2012-12-05 22:28:21 -05:00
foreach ( $hidden_fields as $hidden_field => $value ) {
$item .= '<input type="hidden" name="' . esc_attr ( $hidden_field ) . '" value="' . esc_attr ( $value ) . '" />' . " \n " ;
}
2017-11-30 18:11:00 -05:00
if ( $item ) {
2013-01-04 22:50:28 -05:00
$item = '<input type="hidden" name="attachments[' . $attachment_id . '][menu_order]" value="' . esc_attr ( $post -> menu_order ) . '" />' . $item ;
2017-11-30 18:11:00 -05:00
}
2013-01-04 22:50:28 -05:00
2012-11-10 20:26:42 -05:00
return array (
2017-11-30 18:11:00 -05:00
'item' => $item ,
'meta' => $media_meta ,
2012-11-10 20:26:42 -05:00
);
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload header .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*/
2008-03-05 01:46:42 -05:00
function media_upload_header () {
2020-10-08 17:15:13 -04:00
$post_id = isset ( $_REQUEST [ 'post_id' ] ) ? ( int ) $_REQUEST [ 'post_id' ] : 0 ;
2015-05-31 12:54:27 -04:00
2015-07-14 11:06:25 -04:00
echo '<script type="text/javascript">post_id = ' . $post_id . ';</script>' ;
2019-09-03 21:11:54 -04:00
2012-11-10 02:51:37 -05:00
if ( empty ( $_GET [ 'chromeless' ] ) ) {
echo '<div id="media-upload-header">' ;
the_media_upload_tabs ();
echo '</div>' ;
}
2008-02-26 14:30:10 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload form .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2015-05-28 17:41:30 -04:00
* @ global string $type
* @ global string $tab
2016-08-31 11:22:31 -04:00
* @ global bool $is_IE
2015-05-28 17:41:30 -04:00
* @ global bool $is_opera
*
2014-11-03 01:08:22 -05:00
* @ param array $errors
2008-10-01 21:03:26 -04:00
*/
2008-02-26 14:30:10 -05:00
function media_upload_form ( $errors = null ) {
2016-08-31 11:22:31 -04:00
global $type , $tab , $is_IE , $is_opera ;
2011-11-18 03:43:16 -05:00
2012-04-11 20:16:37 -04:00
if ( ! _device_can_upload () ) {
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
echo '<p>' . sprintf (
/* translators: %s: https://apps.wordpress.org/ */
__ ( '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://apps.wordpress.org/'
) . '</p>' ;
2011-11-18 03:43:16 -05:00
return ;
2012-04-11 20:16:37 -04:00
}
2008-02-28 16:29:51 -05:00
2017-11-30 18:11:00 -05:00
$upload_action_url = admin_url ( 'async-upload.php' );
2020-10-08 17:15:13 -04:00
$post_id = isset ( $_REQUEST [ 'post_id' ] ) ? ( int ) $_REQUEST [ 'post_id' ] : 0 ;
2017-11-30 18:11:00 -05:00
$_type = isset ( $type ) ? $type : '' ;
$_tab = isset ( $tab ) ? $tab : '' ;
2008-01-25 14:21:11 -05:00
2014-05-07 14:25:14 -04:00
$max_upload_size = wp_max_upload_size ();
if ( ! $max_upload_size ) {
$max_upload_size = 0 ;
2010-05-21 08:57:49 -04:00
}
2011-07-29 15:21:21 -04:00
2019-09-03 21:11:54 -04:00
?>
< div id = " media-upload-notice " >
2018-08-16 21:51:36 -04:00
< ? php
2011-07-29 15:21:21 -04:00
2018-08-16 21:51:36 -04:00
if ( isset ( $errors [ 'upload_notice' ] ) ) {
echo $errors [ 'upload_notice' ];
}
2011-10-31 17:38:28 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
< div id = " media-upload-error " >
2018-08-16 21:51:36 -04:00
< ? php
2011-10-31 17:38:28 -04:00
2018-08-16 21:51:36 -04:00
if ( isset ( $errors [ 'upload_error' ] ) && is_wp_error ( $errors [ 'upload_error' ] ) ) {
echo $errors [ 'upload_error' ] -> get_error_message ();
}
2011-10-31 17:38:28 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
if ( is_multisite () && ! is_upload_space_available () ) {
/**
* Fires when an upload will exceed the defined upload space quota for a network site .
*
* @ since 3.5 . 0
*/
do_action ( 'upload_ui_over_quota' );
return ;
}
2014-01-06 00:48:12 -05:00
/**
2018-08-16 21:51:36 -04:00
* Fires just before the legacy ( pre - 3.5 . 0 ) upload interface is loaded .
2014-01-06 00:48:12 -05:00
*
2018-08-16 21:51:36 -04:00
* @ since 2.6 . 0
2014-01-06 00:48:12 -05:00
*/
2019-07-04 21:45:56 -04:00
do_action ( 'pre-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2018-08-16 21:51:36 -04:00
$post_params = array (
'post_id' => $post_id ,
'_wpnonce' => wp_create_nonce ( 'media-form' ),
'type' => $_type ,
'tab' => $_tab ,
'short' => '1' ,
);
2011-07-29 15:21:21 -04:00
2018-08-16 21:51:36 -04:00
/**
* Filters the media upload post parameters .
*
* @ since 3.1 . 0 As 'swfupload_post_params'
* @ since 3.3 . 0
*
* @ param array $post_params An array of media upload parameters used by Plupload .
*/
$post_params = apply_filters ( 'upload_post_params' , $post_params );
/*
* Since 4.9 the `runtimes` setting is hardcoded in our version of Plupload to `html5,html4` ,
* and the `flash_swf_url` and `silverlight_xap_url` are not used .
*/
$plupload_init = array (
'browse_button' => 'plupload-browse-button' ,
'container' => 'plupload-upload-ui' ,
'drop_element' => 'drag-drop-area' ,
'file_data_name' => 'async-upload' ,
'url' => $upload_action_url ,
2019-09-03 21:11:54 -04:00
'filters' => array ( 'max_file_size' => $max_upload_size . 'b' ),
2018-08-16 21:51:36 -04:00
'multipart_params' => $post_params ,
);
2011-07-29 15:21:21 -04:00
2020-01-17 19:54:04 -05:00
/*
* Currently only iOS Safari supports multiple files uploading ,
* but iOS 7. x has a bug that prevents uploading of videos when enabled .
* See #29602.
*/
2019-09-03 21:11:54 -04:00
if (
wp_is_mobile () &&
strpos ( $_SERVER [ 'HTTP_USER_AGENT' ], 'OS 7_' ) !== false &&
strpos ( $_SERVER [ 'HTTP_USER_AGENT' ], 'like Mac OS X' ) !== false
) {
2018-08-16 21:51:36 -04:00
$plupload_init [ 'multi_selection' ] = false ;
}
2014-09-10 18:40:16 -04:00
2021-06-24 15:12:00 -04:00
// Check if WebP images can be edited.
if ( ! wp_image_editor_supports ( array ( 'mime_type' => 'image/webp' ) ) ) {
2021-06-24 16:55:58 -04:00
$plupload_init [ 'webp_upload_error' ] = true ;
2021-06-24 15:12:00 -04:00
}
2018-08-16 21:51:36 -04:00
/**
* Filters the default Plupload settings .
*
* @ since 3.3 . 0
*
* @ param array $plupload_init An array of default settings used by Plupload .
*/
$plupload_init = apply_filters ( 'plupload_init' , $plupload_init );
2010-11-18 19:04:04 -05:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
2018-08-16 21:51:36 -04:00
< ? php
// Verify size is an int. If not return default value.
$large_size_h = absint ( get_option ( 'large_size_h' ) );
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
if ( ! $large_size_h ) {
$large_size_h = 1024 ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
$large_size_w = absint ( get_option ( 'large_size_w' ) );
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
if ( ! $large_size_w ) {
$large_size_w = 1024 ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
var resize_height = < ? php echo $large_size_h ; ?> , resize_width = <?php echo $large_size_w; ?>,
wpUploaderInit = < ? php echo wp_json_encode ( $plupload_init ); ?> ;
</ script >
2008-01-25 14:21:11 -05:00
2019-09-03 21:11:54 -04:00
< div id = " plupload-upload-ui " class = " hide-if-no-js " >
2018-08-16 21:51:36 -04:00
< ? php
/**
* Fires before the upload interface loads .
*
* @ since 2.6 . 0 As 'pre-flash-upload-ui'
* @ since 3.3 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'pre-plupload-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< div id = " drag-drop-area " >
< div class = " drag-drop-inside " >
< p class = " drag-drop-info " >< ? php _e ( 'Drop files to upload' ); ?> </p>
< p >< ? php _ex ( 'or' , 'Uploader: Drop files here - or - Select Files' ); ?> </p>
2021-11-15 18:22:02 -05:00
< p class = " drag-drop-buttons " >< input id = " plupload-browse-button " type = " button " value = " <?php esc_attr_e( 'Select Files' ); ?> " class = " button " /></ p >
2019-09-03 21:11:54 -04:00
</ div >
2011-09-17 22:25:23 -04:00
</ div >
2018-08-16 21:51:36 -04:00
< ? php
/**
* Fires after the upload interface loads .
*
* @ since 2.6 . 0 As 'post-flash-upload-ui'
* @ since 3.3 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'post-plupload-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
2008-03-19 02:18:05 -04:00
2019-09-03 21:11:54 -04:00
< div id = " html-upload-ui " class = " hide-if-js " >
2014-01-06 00:48:12 -05:00
< ? php
/**
* Fires before the upload button in the media upload interface .
*
* @ since 2.6 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'pre-html-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2019-09-03 21:11:54 -04:00
2014-01-06 00:48:12 -05:00
?>
2008-10-30 21:53:39 -04:00
< p id = " async-upload-wrap " >
2017-11-30 18:11:00 -05:00
< label class = " screen-reader-text " for = " async-upload " >< ? php _e ( 'Upload' ); ?> </label>
2010-10-28 17:56:43 -04:00
< input type = " file " name = " async-upload " id = " async-upload " />
2015-10-14 23:08:24 -04:00
< ? php submit_button ( __ ( 'Upload' ), 'primary' , 'html-upload' , false ); ?>
2017-11-30 18:11:00 -05:00
< a href = " # " onclick = " try { top.tb_remove();}catch(e) { }; return false; " >< ? php _e ( 'Cancel' ); ?> </a>
2008-01-25 14:21:11 -05:00
</ p >
2009-03-27 04:36:51 -04:00
< div class = " clear " ></ div >
2018-08-16 21:51:36 -04:00
< ? php
/**
* Fires after the upload button in the media upload interface .
*
* @ since 2.6 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'post-html-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
2011-07-29 04:59:35 -04:00
2021-11-15 18:22:02 -05:00
< p class = " max-upload-size " >
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
< ? php
2019-09-02 20:41:05 -04:00
/* translators: %s: Maximum allowed file size. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
printf ( __ ( 'Maximum upload file size: %s.' ), esc_html ( size_format ( $max_upload_size ) ) );
?>
</ p >
2018-08-16 21:51:36 -04:00
< ? php
2011-11-21 15:46:15 -05:00
2014-01-06 00:48:12 -05:00
/**
* Fires on the post upload UI screen .
*
* Legacy ( pre - 3.5 . 0 ) media workflow hook .
*
* @ since 2.6 . 0
*/
2019-07-04 21:45:56 -04:00
do_action ( 'post-upload-ui' ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores
2008-02-26 14:30:10 -05:00
}
2008-01-25 14:21:11 -05:00
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload form for a given media type .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2020-10-17 10:54:05 -04:00
* @ param string $type
2020-10-17 12:05:09 -04:00
* @ param array $errors
2020-10-17 10:54:05 -04:00
* @ param int | WP_Error $id
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function media_upload_type_form ( $type = 'file' , $errors = null , $id = null ) {
2011-11-18 03:43:16 -05:00
2008-02-26 14:30:10 -05:00
media_upload_header ();
2008-01-25 14:21:11 -05:00
2020-10-08 17:15:13 -04:00
$post_id = isset ( $_REQUEST [ 'post_id' ] ) ? ( int ) $_REQUEST [ 'post_id' ] : 0 ;
2008-01-25 14:21:11 -05:00
2017-11-30 18:11:00 -05:00
$form_action_url = admin_url ( " media-upload.php?type= $type &tab=type&post_id= $post_id " );
2014-01-06 00:48:12 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters the media upload form action URL .
2014-01-06 00:48:12 -05:00
*
* @ since 2.6 . 0
*
* @ param string $form_action_url The media upload form action URL .
* @ param string $type The type of media . Default 'file' .
*/
$form_action_url = apply_filters ( 'media_upload_form_url' , $form_action_url , $type );
2017-11-30 18:11:00 -05:00
$form_class = 'media-upload-form type-form validate' ;
2011-11-11 14:40:23 -05:00
2017-11-30 18:11:00 -05:00
if ( get_user_setting ( 'uploader' ) ) {
2011-11-11 14:40:23 -05:00
$form_class .= ' html-uploader' ;
2017-11-30 18:11:00 -05:00
}
2008-02-26 14:30:10 -05:00
2019-09-03 21:11:54 -04:00
?>
< form enctype = " multipart/form-data " method = " post " action = " <?php echo esc_url( $form_action_url ); ?> " class = " <?php echo $form_class ; ?> " id = " <?php echo $type ; ?>-form " >
< ? php submit_button ( '' , 'hidden' , 'save' , false ); ?>
< input type = " hidden " name = " post_id " id = " post_id " value = " <?php echo (int) $post_id ; ?> " />
< ? php wp_nonce_field ( 'media-form' ); ?>
2008-11-25 21:27:37 -05:00
2019-09-03 21:11:54 -04:00
< h3 class = " media-title " >< ? php _e ( 'Add media files from your computer' ); ?> </h3>
2008-11-25 21:27:37 -05:00
2018-08-16 21:51:36 -04:00
< ? php media_upload_form ( $errors ); ?>
2008-01-25 14:21:11 -05:00
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
jQuery ( function ( $ ){
var preloaded = $ ( " .media-item.preloaded " );
if ( preloaded . length > 0 ) {
preloaded . each ( function (){ prepareMediaItem ({ id : this . id . replace ( / [ ^ 0 - 9 ] / g , '' )}, '' );});
}
updateMediaForm ();
});
</ script >
< div id = " media-items " >
2018-08-16 21:51:36 -04:00
< ? php
2011-07-29 15:21:21 -04:00
2018-08-16 21:51:36 -04:00
if ( $id ) {
if ( ! is_wp_error ( $id ) ) {
add_filter ( 'attachment_fields_to_edit' , 'media_post_single_attachment_fields_to_edit' , 10 , 2 );
echo get_media_items ( $id , $errors );
} else {
echo '<div id="media-upload-error">' . esc_html ( $id -> get_error_message () ) . '</div></div>' ;
exit ;
}
2008-11-25 21:27:37 -05:00
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
2011-07-29 15:21:21 -04:00
2019-09-03 21:11:54 -04:00
< p class = " savebutton ml-submit " >
< ? php submit_button ( __ ( 'Save all changes' ), '' , 'save' , false ); ?>
</ p >
</ form >
2018-08-16 21:51:36 -04:00
< ? php
2008-11-27 16:24:37 -05:00
}
2008-11-25 21:27:37 -05:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload form for external media .
2008-11-25 21:27:37 -05:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.7 . 0
2008-11-25 21:27:37 -05:00
*
2020-07-23 16:01:04 -04:00
* @ param string $type
* @ param object $errors
2020-10-10 16:02:05 -04:00
* @ param int $id
2008-11-25 21:27:37 -05:00
*/
2017-11-30 18:11:00 -05:00
function media_upload_type_url_form ( $type = null , $errors = null , $id = null ) {
if ( null === $type ) {
2011-09-30 02:22:29 -04:00
$type = 'image' ;
2017-11-30 18:11:00 -05:00
}
2011-09-30 02:22:29 -04:00
2008-11-25 21:27:37 -05:00
media_upload_header ();
2020-10-08 17:15:13 -04:00
$post_id = isset ( $_REQUEST [ 'post_id' ] ) ? ( int ) $_REQUEST [ 'post_id' ] : 0 ;
2008-11-25 21:27:37 -05:00
2017-11-30 18:11:00 -05:00
$form_action_url = admin_url ( " media-upload.php?type= $type &tab=type&post_id= $post_id " );
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
$form_action_url = apply_filters ( 'media_upload_form_url' , $form_action_url , $type );
2017-11-30 18:11:00 -05:00
$form_class = 'media-upload-form type-form validate' ;
2011-11-11 14:40:23 -05:00
2017-11-30 18:11:00 -05:00
if ( get_user_setting ( 'uploader' ) ) {
2011-11-11 14:40:23 -05:00
$form_class .= ' html-uploader' ;
2017-11-30 18:11:00 -05:00
}
2008-01-25 14:21:11 -05:00
2019-09-03 21:11:54 -04:00
?>
< form enctype = " multipart/form-data " method = " post " action = " <?php echo esc_url( $form_action_url ); ?> " class = " <?php echo $form_class ; ?> " id = " <?php echo $type ; ?>-form " >
< input type = " hidden " name = " post_id " id = " post_id " value = " <?php echo (int) $post_id ; ?> " />
< ? php wp_nonce_field ( 'media-form' ); ?>
2008-11-25 21:27:37 -05:00
2019-09-03 21:11:54 -04:00
< h3 class = " media-title " >< ? php _e ( 'Insert media from another website' ); ?> </h3>
2008-02-28 16:29:51 -05:00
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
var addExtImage = {
2008-07-09 23:49:52 -04:00
width : '' ,
height : '' ,
align : 'alignnone' ,
insert : function () {
2009-10-19 01:09:41 -04:00
var t = this , html , f = document . forms [ 0 ], cls , title = '' , alt = '' , caption = '' ;
2008-07-09 23:49:52 -04:00
2020-05-16 14:42:12 -04:00
if ( '' === f . src . value || '' === t . width )
2009-10-24 07:43:42 -04:00
return false ;
2008-07-09 23:49:52 -04:00
2009-10-19 01:09:41 -04:00
if ( f . alt . value )
alt = f . alt . value . replace ( / '/g, ' & #039;').replace(/"/g, '"').replace(/</g, '<').replace(/>/g, '>');
2019-09-03 21:11:54 -04:00
< ? php
/** This filter is documented in wp-admin/includes/media.php */
if ( ! apply_filters ( 'disable_captions' , '' ) ) {
?>
if ( f . caption . value ) {
caption = f . caption . value . replace ( / \r\n | \r / g , '\n' );
caption = caption . replace ( /< [ a - zA - Z0 - 9 ] + ( [ ^<> ] + ) ?> /g, function(a){
return a . replace ( / [ \r\n\t ] +/ , ' ' );
});
2012-02-23 20:58:18 -05:00
2019-09-03 21:11:54 -04:00
caption = caption . replace ( / \s * \n\s */ g , '<br />' );
}
< ? php
}
2008-07-09 23:49:52 -04:00
2019-09-03 21:11:54 -04:00
?>
2008-07-09 23:49:52 -04:00
cls = caption ? '' : ' class="' + t . align + '"' ;
2012-11-06 18:23:03 -05:00
html = '<img alt="' + alt + '" src="' + f . src . value + '"' + cls + ' width="' + t . width + '" height="' + t . height + '" />' ;
2008-07-09 23:49:52 -04:00
2011-11-14 14:35:32 -05:00
if ( f . url . value ) {
url = f . url . value . replace ( / '/g, ' & #039;').replace(/"/g, '"').replace(/</g, '<').replace(/>/g, '>');
html = '<a href="' + url + '">' + html + '</a>' ;
}
2008-07-09 23:49:52 -04:00
if ( caption )
2012-05-01 21:14:52 -04:00
html = '[caption id="" align="' + t . align + '" width="' + t . width + '"]' + html + caption + '[/caption]' ;
2008-07-09 23:49:52 -04:00
var win = window . dialogArguments || opener || parent || top ;
win . send_to_editor ( html );
2009-10-24 07:43:42 -04:00
return false ;
2008-07-09 23:49:52 -04:00
},
resetImageData : function () {
var t = addExtImage ;
t . width = t . height = '' ;
document . getElementById ( 'go_button' ) . style . color = '#bbb' ;
if ( ! document . forms [ 0 ] . src . value )
2016-03-07 17:29:26 -05:00
document . getElementById ( 'status_img' ) . innerHTML = '' ;
2010-05-03 14:16:22 -04:00
else document . getElementById ( 'status_img' ) . innerHTML = '<img src="<?php echo esc_url( admin_url( ' images / no . png ' ) ); ?>" alt="" />' ;
2008-07-09 23:49:52 -04:00
},
updateImageData : function () {
var t = addExtImage ;
t . width = t . preloadImg . width ;
t . height = t . preloadImg . height ;
document . getElementById ( 'go_button' ) . style . color = '#333' ;
2010-05-03 14:16:22 -04:00
document . getElementById ( 'status_img' ) . innerHTML = '<img src="<?php echo esc_url( admin_url( ' images / yes . png ' ) ); ?>" alt="" />' ;
2008-07-09 23:49:52 -04:00
},
getImageData : function () {
2011-10-18 15:32:40 -04:00
if ( jQuery ( 'table.describe' ) . hasClass ( 'not-image' ) )
return ;
2008-07-09 23:49:52 -04:00
var t = addExtImage , src = document . forms [ 0 ] . src . value ;
2011-10-18 15:32:40 -04:00
if ( ! src ) {
2008-07-09 23:49:52 -04:00
t . resetImageData ();
return false ;
}
2011-09-30 02:22:29 -04:00
2015-01-15 19:33:22 -05:00
document . getElementById ( 'status_img' ) . innerHTML = '<img src="<?php echo esc_url( admin_url( ' images / spinner - 2 x . gif ' ) ); ?>" alt="" width="16" height="16" />' ;
2008-07-09 23:49:52 -04:00
t . preloadImg = new Image ();
t . preloadImg . onload = t . updateImageData ;
t . preloadImg . onerror = t . resetImageData ;
t . preloadImg . src = src ;
}
2019-09-03 21:11:54 -04:00
};
2011-09-30 02:22:29 -04:00
2019-09-03 21:11:54 -04:00
jQuery ( document ) . ready ( function ( $ ) {
$ ( '.media-types input' ) . click ( function () {
$ ( 'table.describe' ) . toggleClass ( 'not-image' , $ ( '#not-image' ) . prop ( 'checked' ) );
});
2011-09-30 02:22:29 -04:00
});
2019-09-03 21:11:54 -04:00
</ script >
2008-07-09 23:49:52 -04:00
2019-09-03 21:11:54 -04:00
< div id = " media-items " >
< div class = " media-item media-blank " >
2018-08-16 21:51:36 -04:00
< ? php
/**
* Filters the insert media from URL form HTML .
*
* @ since 3.3 . 0
*
* @ param string $form_html The insert from URL form HTML .
*/
echo apply_filters ( 'type_url_form_media' , wp_media_insert_url_form ( $type ) );
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ div >
</ div >
</ form >
2018-08-16 21:51:36 -04:00
< ? php
2008-02-26 14:30:10 -05:00
}
2008-01-25 14:21:11 -05:00
2008-10-01 21:03:26 -04:00
/**
2012-09-16 14:31:42 -04:00
* Adds gallery form to upload iframe
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2015-05-28 17:41:30 -04:00
* @ global string $redir_tab
* @ global string $type
* @ global string $tab
*
2012-09-16 14:31:42 -04:00
* @ param array $errors
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function media_upload_gallery_form ( $errors ) {
2009-09-01 16:44:17 -04:00
global $redir_tab , $type ;
2008-07-09 23:49:52 -04:00
$redir_tab = 'gallery' ;
2008-03-05 01:46:42 -05:00
media_upload_header ();
2008-01-25 14:21:11 -05:00
2020-10-08 17:15:13 -04:00
$post_id = ( int ) $_REQUEST [ 'post_id' ];
2017-11-30 18:11:00 -05:00
$form_action_url = admin_url ( " media-upload.php?type= $type &tab=gallery&post_id= $post_id " );
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
$form_action_url = apply_filters ( 'media_upload_form_url' , $form_action_url , $type );
2017-11-30 18:11:00 -05:00
$form_class = 'media-upload-form validate' ;
2011-11-30 23:51:35 -05:00
2017-11-30 18:11:00 -05:00
if ( get_user_setting ( 'uploader' ) ) {
2011-11-11 14:40:23 -05:00
$form_class .= ' html-uploader' ;
2017-11-30 18:11:00 -05:00
}
2008-02-26 14:30:10 -05:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
jQuery ( function ( $ ){
var preloaded = $ ( " .media-item.preloaded " );
if ( preloaded . length > 0 ) {
preloaded . each ( function (){ prepareMediaItem ({ id : this . id . replace ( / [ ^ 0 - 9 ] / g , '' )}, '' );});
updateMediaForm ();
}
});
</ script >
< div id = " sort-buttons " class = " hide-if-no-js " >
< span >
< ? php _e ( 'All Tabs:' ); ?>
< a href = " # " id = " showall " >< ? php _e ( 'Show' ); ?> </a>
< a href = " # " id = " hideall " style = " display:none; " >< ? php _e ( 'Hide' ); ?> </a>
</ span >
< ? php _e ( 'Sort Order:' ); ?>
< a href = " # " id = " asc " >< ? php _e ( 'Ascending' ); ?> </a> |
< a href = " # " id = " desc " >< ? php _e ( 'Descending' ); ?> </a> |
< a href = " # " id = " clear " >< ? php _ex ( 'Clear' , 'verb' ); ?> </a>
</ div >
< form enctype = " multipart/form-data " method = " post " action = " <?php echo esc_url( $form_action_url ); ?> " class = " <?php echo $form_class ; ?> " id = " gallery-form " >
< ? php wp_nonce_field ( 'media-form' ); ?>
< table class = " widefat " >
< thead >< tr >
< th >< ? php _e ( 'Media' ); ?> </th>
< th class = " order-head " >< ? php _e ( 'Order' ); ?> </th>
< th class = " actions-head " >< ? php _e ( 'Actions' ); ?> </th>
</ tr ></ thead >
</ table >
< div id = " media-items " >
< ? php add_filter ( 'attachment_fields_to_edit' , 'media_post_single_attachment_fields_to_edit' , 10 , 2 ); ?>
< ? php echo get_media_items ( $post_id , $errors ); ?>
</ div >
2008-11-25 21:27:37 -05:00
2019-09-03 21:11:54 -04:00
< p class = " ml-submit " >
< ? php
submit_button (
__ ( 'Save all changes' ),
'savebutton' ,
'save' ,
false ,
array (
'id' => 'save-all' ,
'style' => 'display: none;' ,
)
);
?>
< input type = " hidden " name = " post_id " id = " post_id " value = " <?php echo (int) $post_id ; ?> " />
< input type = " hidden " name = " type " value = " <?php echo esc_attr( $GLOBALS['type'] ); ?> " />
< input type = " hidden " name = " tab " value = " <?php echo esc_attr( $GLOBALS['tab'] ); ?> " />
</ p >
< div id = " gallery-settings " style = " display:none; " >
< div class = " title " >< ? php _e ( 'Gallery Settings' ); ?> </div>
< table id = " basic " class = " describe " >< tbody >
< tr >
< th scope = " row " class = " label " >
< label >
< span class = " alignleft " >< ? php _e ( 'Link thumbnails to:' ); ?> </span>
</ label >
</ th >
< td class = " field " >
< input type = " radio " name = " linkto " id = " linkto-file " value = " file " />
< label for = " linkto-file " class = " radio " >< ? php _e ( 'Image File' ); ?> </label>
< input type = " radio " checked = " checked " name = " linkto " id = " linkto-post " value = " post " />
< label for = " linkto-post " class = " radio " >< ? php _e ( 'Attachment Page' ); ?> </label>
</ td >
</ tr >
< tr >
< th scope = " row " class = " label " >
< label >
< span class = " alignleft " >< ? php _e ( 'Order images by:' ); ?> </span>
</ label >
</ th >
< td class = " field " >
< select id = " orderby " name = " orderby " >
< option value = " menu_order " selected = " selected " >< ? php _e ( 'Menu order' ); ?> </option>
< option value = " title " >< ? php _e ( 'Title' ); ?> </option>
< option value = " post_date " >< ? php _e ( 'Date/Time' ); ?> </option>
< option value = " rand " >< ? php _e ( 'Random' ); ?> </option>
</ select >
</ td >
</ tr >
< tr >
< th scope = " row " class = " label " >
< label >
< span class = " alignleft " >< ? php _e ( 'Order:' ); ?> </span>
</ label >
</ th >
< td class = " field " >
< input type = " radio " checked = " checked " name = " order " id = " order-asc " value = " asc " />
< label for = " order-asc " class = " radio " >< ? php _e ( 'Ascending' ); ?> </label>
< input type = " radio " name = " order " id = " order-desc " value = " desc " />
< label for = " order-desc " class = " radio " >< ? php _e ( 'Descending' ); ?> </label>
</ td >
</ tr >
< tr >
< th scope = " row " class = " label " >
< label >
< span class = " alignleft " >< ? php _e ( 'Gallery columns:' ); ?> </span>
</ label >
</ th >
< td class = " field " >
< select id = " columns " name = " columns " >
< option value = " 1 " > 1 </ option >
< option value = " 2 " > 2 </ option >
< option value = " 3 " selected = " selected " > 3 </ option >
< option value = " 4 " > 4 </ option >
< option value = " 5 " > 5 </ option >
< option value = " 6 " > 6 </ option >
< option value = " 7 " > 7 </ option >
< option value = " 8 " > 8 </ option >
< option value = " 9 " > 9 </ option >
</ select >
</ td >
</ tr >
</ tbody ></ table >
< p class = " ml-submit " >
< input type = " button " class = " button " style = " display:none; " onMouseDown = " wpgallery.update(); " name = " insert-gallery " id = " insert-gallery " value = " <?php esc_attr_e( 'Insert gallery' ); ?> " />
< input type = " button " class = " button " style = " display:none; " onMouseDown = " wpgallery.update(); " name = " update-gallery " id = " update-gallery " value = " <?php esc_attr_e( 'Update gallery settings' ); ?> " />
</ p >
</ div >
</ form >
2018-08-16 21:51:36 -04:00
< ? php
2008-01-25 14:21:11 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2015-10-04 22:44:25 -04:00
* Outputs the legacy media upload form for the media library .
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-10-01 21:03:26 -04:00
*
2019-08-03 21:12:56 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2019-08-03 21:59:56 -04:00
* @ global WP_Query $wp_query WordPress Query object .
2019-08-03 21:46:55 -04:00
* @ global WP_Locale $wp_locale WordPress date and time locale object .
2015-05-28 17:41:30 -04:00
* @ global string $type
* @ global string $tab
* @ global array $post_mime_types
*
2012-09-16 14:31:42 -04:00
* @ param array $errors
2008-10-01 21:03:26 -04:00
*/
2017-11-30 18:11:00 -05:00
function media_upload_library_form ( $errors ) {
2008-02-28 16:29:51 -05:00
global $wpdb , $wp_query , $wp_locale , $type , $tab , $post_mime_types ;
2008-02-27 03:31:10 -05:00
2008-03-05 01:46:42 -05:00
media_upload_header ();
2008-02-27 03:31:10 -05:00
2020-10-08 17:15:13 -04:00
$post_id = isset ( $_REQUEST [ 'post_id' ] ) ? ( int ) $_REQUEST [ 'post_id' ] : 0 ;
2008-02-27 03:31:10 -05:00
2017-11-30 18:11:00 -05:00
$form_action_url = admin_url ( " media-upload.php?type= $type &tab=library&post_id= $post_id " );
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
$form_action_url = apply_filters ( 'media_upload_form_url' , $form_action_url , $type );
2017-11-30 18:11:00 -05:00
$form_class = 'media-upload-form validate' ;
2011-11-11 14:40:23 -05:00
2017-11-30 18:11:00 -05:00
if ( get_user_setting ( 'uploader' ) ) {
2011-11-11 14:40:23 -05:00
$form_class .= ' html-uploader' ;
2017-11-30 18:11:00 -05:00
}
2008-02-27 03:31:10 -05:00
2017-11-30 18:11:00 -05:00
$q = $_GET ;
2014-03-03 11:21:16 -05:00
$q [ 'posts_per_page' ] = 10 ;
2020-10-08 17:15:13 -04:00
$q [ 'paged' ] = isset ( $q [ 'paged' ] ) ? ( int ) $q [ 'paged' ] : 0 ;
2014-03-03 11:21:16 -05:00
if ( $q [ 'paged' ] < 1 ) {
$q [ 'paged' ] = 1 ;
}
$q [ 'offset' ] = ( $q [ 'paged' ] - 1 ) * 10 ;
if ( $q [ 'offset' ] < 1 ) {
$q [ 'offset' ] = 0 ;
}
list ( $post_mime_types , $avail_post_mime_types ) = wp_edit_attachments_query ( $q );
2008-02-27 03:31:10 -05:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< form id = " filter " method = " get " >
< input type = " hidden " name = " type " value = " <?php echo esc_attr( $type ); ?> " />
< input type = " hidden " name = " tab " value = " <?php echo esc_attr( $tab ); ?> " />
< input type = " hidden " name = " post_id " value = " <?php echo (int) $post_id ; ?> " />
< input type = " hidden " name = " post_mime_type " value = " <?php echo isset( $_GET['post_mime_type'] ) ? esc_attr( $_GET['post_mime_type'] ) : ''; ?> " />
< input type = " hidden " name = " context " value = " <?php echo isset( $_GET['context'] ) ? esc_attr( $_GET['context'] ) : ''; ?> " />
< p id = " media-search " class = " search-box " >
< label class = " screen-reader-text " for = " media-search-input " >< ? php _e ( 'Search Media' ); ?> :</label>
< input type = " search " id = " media-search-input " name = " s " value = " <?php the_search_query(); ?> " />
< ? php submit_button ( __ ( 'Search Media' ), '' , '' , false ); ?>
</ p >
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
< ul class = " subsubsub " >
< ? php
$type_links = array ();
$_num_posts = ( array ) wp_count_attachments ();
$matches = wp_match_mime_types ( array_keys ( $post_mime_types ), array_keys ( $_num_posts ) );
foreach ( $matches as $_type => $reals ) {
foreach ( $reals as $real ) {
if ( isset ( $num_posts [ $_type ] ) ) {
$num_posts [ $_type ] += $_num_posts [ $real ];
} else {
$num_posts [ $_type ] = $_num_posts [ $real ];
}
2018-08-16 21:51:36 -04:00
}
2017-11-30 18:11:00 -05:00
}
2020-01-17 19:54:04 -05:00
// If available type specified by media button clicked, filter by that type.
2019-09-03 21:11:54 -04:00
if ( empty ( $_GET [ 'post_mime_type' ] ) && ! empty ( $num_posts [ $type ] ) ) {
$_GET [ 'post_mime_type' ] = $type ;
list ( $post_mime_types , $avail_post_mime_types ) = wp_edit_attachments_query ();
2018-08-16 21:51:36 -04:00
}
2020-02-09 11:55:09 -05:00
if ( empty ( $_GET [ 'post_mime_type' ] ) || 'all' === $_GET [ 'post_mime_type' ] ) {
2018-08-16 21:51:36 -04:00
$class = ' class="current"' ;
2019-09-03 21:11:54 -04:00
} else {
$class = '' ;
2018-08-16 21:51:36 -04:00
}
$type_links [] = '<li><a href="' . esc_url (
add_query_arg (
array (
2019-09-03 21:11:54 -04:00
'post_mime_type' => 'all' ,
2018-08-16 21:51:36 -04:00
'paged' => false ,
2019-09-03 21:11:54 -04:00
'm' => false ,
2018-08-16 21:51:36 -04:00
)
)
2019-09-03 21:11:54 -04:00
) . '"' . $class . '>' . __ ( 'All Types' ) . '</a>' ;
foreach ( $post_mime_types as $mime_type => $label ) {
$class = '' ;
2018-08-16 21:51:36 -04:00
2019-09-03 21:11:54 -04:00
if ( ! wp_match_mime_types ( $mime_type , $avail_post_mime_types ) ) {
continue ;
}
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
if ( isset ( $_GET [ 'post_mime_type' ] ) && wp_match_mime_types ( $mime_type , $_GET [ 'post_mime_type' ] ) ) {
$class = ' class="current"' ;
}
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
$type_links [] = '<li><a href="' . esc_url (
add_query_arg (
array (
'post_mime_type' => $mime_type ,
'paged' => false ,
)
)
) . '"' . $class . '>' . sprintf ( translate_nooped_plural ( $label [ 2 ], $num_posts [ $mime_type ] ), '<span id="' . $mime_type . '-counter">' . number_format_i18n ( $num_posts [ $mime_type ] ) . '</span>' ) . '</a>' ;
}
/**
* Filters the media upload mime type list items .
*
* Returned values should begin with an `<li>` tag .
*
* @ since 3.1 . 0
*
* @ param string [] $type_links An array of list items containing mime type link HTML .
*/
echo implode ( ' | </li>' , apply_filters ( 'media_upload_mime_type_links' , $type_links ) ) . '</li>' ;
unset ( $type_links );
?>
</ ul >
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
< div class = " tablenav " >
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
< ? php
$page_links = paginate_links (
array (
'base' => add_query_arg ( 'paged' , '%#%' ),
'format' => '' ,
'prev_text' => __ ( '«' ),
'next_text' => __ ( '»' ),
'total' => ceil ( $wp_query -> found_posts / 10 ),
'current' => $q [ 'paged' ],
)
);
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
if ( $page_links ) {
echo " <div class='tablenav-pages'> $page_links </div> " ;
}
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< div class = " alignleft actions " >
2018-08-16 21:51:36 -04:00
< ? php
2008-02-28 16:29:51 -05:00
2019-09-03 21:11:54 -04:00
$arc_query = " SELECT DISTINCT YEAR(post_date) AS yyear, MONTH(post_date) AS mmonth FROM $wpdb->posts WHERE post_type = 'attachment' ORDER BY post_date DESC " ;
2008-02-28 16:29:51 -05:00
2019-09-03 21:11:54 -04:00
$arc_result = $wpdb -> get_results ( $arc_query );
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
$month_count = count ( $arc_result );
$selected_month = isset ( $_GET [ 'm' ] ) ? $_GET [ 'm' ] : 0 ;
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
if ( $month_count && ! ( 1 == $month_count && 0 == $arc_result [ 0 ] -> mmonth ) ) {
?>
< select name = 'm' >
< option < ? php selected ( $selected_month , 0 ); ?> value='0'><?php _e( 'All dates' ); ?></option>
< ? php
foreach ( $arc_result as $arc_row ) {
2020-02-09 11:55:09 -05:00
if ( 0 == $arc_row -> yyear ) {
2019-09-03 21:11:54 -04:00
continue ;
}
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
$arc_row -> mmonth = zeroise ( $arc_row -> mmonth , 2 );
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
if ( $arc_row -> yyear . $arc_row -> mmonth == $selected_month ) {
$default = ' selected="selected"' ;
} else {
$default = '' ;
}
2008-02-28 16:29:51 -05:00
2019-09-03 21:11:54 -04:00
echo " <option $default value=' " . esc_attr ( $arc_row -> yyear . $arc_row -> mmonth ) . " '> " ;
echo esc_html ( $wp_locale -> get_month ( $arc_row -> mmonth ) . " $arc_row->yyear " );
echo " </option> \n " ;
}
?>
</ select >
< ? php } ?>
< ? php submit_button ( __ ( 'Filter »' ), '' , 'post-query-submit' , false ); ?>
</ div >
< br class = " clear " />
</ div >
</ form >
< form enctype = " multipart/form-data " method = " post " action = " <?php echo esc_url( $form_action_url ); ?> " class = " <?php echo $form_class ; ?> " id = " library-form " >
2018-08-16 21:51:36 -04:00
< ? php wp_nonce_field ( 'media-form' ); ?>
2008-02-27 03:31:10 -05:00
2019-09-03 21:11:54 -04:00
< script type = " text/javascript " >
jQuery ( function ( $ ){
var preloaded = $ ( " .media-item.preloaded " );
if ( preloaded . length > 0 ) {
preloaded . each ( function (){ prepareMediaItem ({ id : this . id . replace ( / [ ^ 0 - 9 ] / g , '' )}, '' );});
updateMediaForm ();
}
});
</ script >
< div id = " media-items " >
< ? php add_filter ( 'attachment_fields_to_edit' , 'media_post_single_attachment_fields_to_edit' , 10 , 2 ); ?>
< ? php echo get_media_items ( null , $errors ); ?>
</ div >
< p class = " ml-submit " >
< ? php submit_button ( __ ( 'Save all changes' ), 'savebutton' , 'save' , false ); ?>
< input type = " hidden " name = " post_id " id = " post_id " value = " <?php echo (int) $post_id ; ?> " />
</ p >
</ form >
2018-08-16 21:51:36 -04:00
< ? php
2008-02-26 14:30:10 -05:00
}
2008-10-01 21:03:26 -04:00
/**
2012-09-16 14:31:42 -04:00
* Creates the form for external url
2008-10-01 21:03:26 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.7 . 0
2008-10-01 21:03:26 -04:00
*
2012-09-16 14:31:42 -04:00
* @ param string $default_view
* @ return string the form html
2008-10-01 21:03:26 -04:00
*/
2011-10-05 18:36:03 -04:00
function wp_media_insert_url_form ( $default_view = 'image' ) {
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
if ( ! apply_filters ( 'disable_captions' , '' ) ) {
2009-10-19 01:09:41 -04:00
$caption = '
2011-09-30 02:22:29 -04:00
< tr class = " image-only " >
2014-01-24 14:06:15 -05:00
< th scope = " row " class = " label " >
2017-11-30 18:11:00 -05:00
< label for = " caption " >< span class = " alignleft " > ' . __( ' Image Caption ' ) . ' </ span ></ label >
2009-10-19 01:09:41 -04:00
</ th >
2012-03-21 18:48:36 -04:00
< td class = " field " >< textarea id = " caption " name = " caption " ></ textarea ></ td >
2019-09-03 21:11:54 -04:00
</ tr > ' ;
2008-07-16 17:36:17 -04:00
} else {
2009-10-19 01:09:41 -04:00
$caption = '' ;
2008-07-16 17:36:17 -04:00
}
2008-08-09 01:36:14 -04:00
2017-11-30 18:11:00 -05:00
$default_align = get_option ( 'image_default_align' );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( empty ( $default_align ) ) {
2008-08-15 11:40:35 -04:00
$default_align = 'none' ;
2017-11-30 18:11:00 -05:00
}
2008-12-09 13:03:31 -05:00
2020-05-16 14:42:12 -04:00
if ( 'image' === $default_view ) {
2017-11-30 18:11:00 -05:00
$view = 'image-only' ;
2011-09-30 02:22:29 -04:00
$table_class = '' ;
} else {
2019-07-01 08:52:01 -04:00
$view = 'not-image' ;
$table_class = $view ;
2011-09-30 02:22:29 -04:00
}
2008-07-16 17:36:17 -04:00
return '
2011-10-05 17:07:04 -04:00
< p class = " media-types " >< label >< input type = " radio " name = " media_type " value = " image " id = " image-only " ' . checked( ' image - only ', $view, false ) . ' /> ' . __( ' Image ' ) . ' </ label > & nbsp ; & nbsp ; < label >< input type = " radio " name = " media_type " value = " generic " id = " not-image " ' . checked( ' not - image ', $view, false ) . ' /> ' . __( ' Audio , Video , or Other File ' ) . ' </ label ></ p >
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
< p class = " media-types media-types-required-info " > ' .
2019-09-02 20:41:05 -04:00
/* translators: %s: Asterisk symbol (*). */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
sprintf ( __ ( 'Required fields are marked %s' ), '<span class="required">*</span>' ) .
' </ p >
2011-09-30 02:22:29 -04:00
< table class = " describe ' . $table_class . ' " >< tbody >
2008-07-09 23:49:52 -04:00
< tr >
2014-01-24 14:06:15 -05:00
< th scope = " row " class = " label " style = " width:130px; " >
2016-03-07 17:29:26 -05:00
< label for = " src " >< span class = " alignleft " > ' . __( ' URL ' ) . ' </ span > < span class = " required " >*</ span ></ label >
< span class = " alignright " id = " status_img " ></ span >
2008-07-09 23:49:52 -04:00
</ th >
2018-02-26 18:10:31 -05:00
< td class = " field " >< input id = " src " name = " src " value = " " type = " text " required onblur = " addExtImage.getImageData() " /></ td >
2008-07-09 23:49:52 -04:00
</ tr >
2008-02-28 16:29:51 -05:00
< tr >
2014-01-24 14:06:15 -05:00
< th scope = " row " class = " label " >
2016-03-07 17:29:26 -05:00
< label for = " title " >< span class = " alignleft " > ' . __( ' Title ' ) . ' </ span > < span class = " required " >*</ span ></ label >
2008-03-12 01:50:07 -04:00
</ th >
2018-02-26 18:10:31 -05:00
< td class = " field " >< input id = " title " name = " title " value = " " type = " text " required /></ td >
2008-02-28 16:29:51 -05:00
</ tr >
2008-07-09 23:49:52 -04:00
2017-11-30 18:11:00 -05:00
< tr class = " not-image " >< td ></ td >< td >< p class = " help " > ' . __( ' Link text , e . g . & #8220;Ransom Demands (PDF)”' ) . '</p></td></tr>
2011-09-30 02:22:29 -04:00
< tr class = " image-only " >
2014-01-24 14:06:15 -05:00
< th scope = " row " class = " label " >
2017-11-30 18:11:00 -05:00
< label for = " alt " >< span class = " alignleft " > ' . __( ' Alternative Text ' ) . ' </ span ></ label >
2008-03-12 01:50:07 -04:00
</ th >
2018-02-26 18:10:31 -05:00
< td class = " field " >< input id = " alt " name = " alt " value = " " type = " text " required />
2017-11-30 18:11:00 -05:00
< p class = " help " > ' . __( ' Alt text for the image , e . g . & #8220;The Mona Lisa”' ) . '</p></td>
2008-02-28 16:29:51 -05:00
</ tr >
2009-10-19 01:09:41 -04:00
' . $caption . '
2011-09-30 02:22:29 -04:00
< tr class = " align image-only " >
2017-11-30 18:11:00 -05:00
< th scope = " row " class = " label " >< p >< label for = " align " > ' . __( ' Alignment ' ) . ' </ label ></ p ></ th >
2008-02-28 16:29:51 -05:00
< td class = " field " >
2020-02-09 11:55:09 -05:00
< input name = " align " id = " align-none " value = " none " onclick = " addExtImage.align= \ 'align \ '+this.value " type = " radio " ' . ( ' none ' === $default_align ? ' checked = " checked " ' : ' ' ) . ' />
2017-11-30 18:11:00 -05:00
< label for = " align-none " class = " align image-align-none-label " > ' . __( ' None ' ) . ' </ label >
2020-02-09 11:55:09 -05:00
< input name = " align " id = " align-left " value = " left " onclick = " addExtImage.align= \ 'align \ '+this.value " type = " radio " ' . ( ' left ' === $default_align ? ' checked = " checked " ' : ' ' ) . ' />
2017-11-30 18:11:00 -05:00
< label for = " align-left " class = " align image-align-left-label " > ' . __( ' Left ' ) . ' </ label >
2020-02-09 11:55:09 -05:00
< input name = " align " id = " align-center " value = " center " onclick = " addExtImage.align= \ 'align \ '+this.value " type = " radio " ' . ( ' center ' === $default_align ? ' checked = " checked " ' : ' ' ) . ' />
2017-11-30 18:11:00 -05:00
< label for = " align-center " class = " align image-align-center-label " > ' . __( ' Center ' ) . ' </ label >
2020-02-09 11:55:09 -05:00
< input name = " align " id = " align-right " value = " right " onclick = " addExtImage.align= \ 'align \ '+this.value " type = " radio " ' . ( ' right ' === $default_align ? ' checked = " checked " ' : ' ' ) . ' />
2017-11-30 18:11:00 -05:00
< label for = " align-right " class = " align image-align-right-label " > ' . __( ' Right ' ) . ' </ label >
2008-02-28 16:29:51 -05:00
</ td >
</ tr >
2008-07-09 23:49:52 -04:00
2011-09-30 02:22:29 -04:00
< tr class = " image-only " >
2014-01-24 14:06:15 -05:00
< th scope = " row " class = " label " >
2017-11-30 18:11:00 -05:00
< label for = " url " >< span class = " alignleft " > ' . __( ' Link Image To : ' ) . ' </ span ></ label >
2008-07-09 23:49:52 -04:00
</ th >
< td class = " field " >< input id = " url " name = " url " value = " " type = " text " />< br />
2017-11-30 18:11:00 -05:00
< button type = " button " class = " button " value = " " onclick = " document.forms[0].url.value=null " > ' . __( ' None ' ) . ' </ button >
< button type = " button " class = " button " value = " " onclick = " document.forms[0].url.value=document.forms[0].src.value " > ' . __( ' Link to image ' ) . ' </ button >
< p class = " help " > ' . __( ' Enter a link URL or click above for presets . ' ) . ' </ p ></ td >
2008-07-09 23:49:52 -04:00
</ tr >
2011-09-30 02:22:29 -04:00
< tr class = " image-only " >
< td ></ td >
< td >
2017-11-30 18:11:00 -05:00
< input type = " button " class = " button " id = " go_button " style = " color:#bbb; " onclick = " addExtImage.insert() " value = " ' . esc_attr__( 'Insert into Post' ) . ' " />
2011-09-30 02:22:29 -04:00
</ td >
2008-02-28 16:29:51 -05:00
</ tr >
2011-09-30 02:22:29 -04:00
< tr class = " not-image " >
< td ></ td >
< td >
2016-09-28 15:54:28 -04:00
' . get_submit_button( __( ' Insert into Post ' ), ' ', ' insertonlybutton ', false ) . '
2011-09-30 02:22:29 -04:00
</ td >
2009-12-01 04:22:48 -05:00
</ tr >
2019-09-03 21:11:54 -04:00
</ tbody ></ table > ' ;
2010-04-16 17:45:16 -04:00
}
2011-11-11 14:40:23 -05:00
/**
2012-07-11 06:20:15 -04:00
* Displays the multi - file uploader message .
2011-11-11 14:40:23 -05:00
*
* @ since 2.6 . 0
2015-05-28 17:41:30 -04:00
*
* @ global int $post_ID
2011-11-11 14:40:23 -05:00
*/
function media_upload_flash_bypass () {
2012-11-26 18:10:19 -05:00
$browser_uploader = admin_url ( 'media-new.php?browser-uploader' );
2019-07-01 08:52:01 -04:00
$post = get_post ();
if ( $post ) {
2020-10-08 17:15:13 -04:00
$browser_uploader .= '&post_id=' . ( int ) $post -> ID ;
2017-11-30 18:11:00 -05:00
} elseif ( ! empty ( $GLOBALS [ 'post_ID' ] ) ) {
2020-10-08 17:15:13 -04:00
$browser_uploader .= '&post_id=' . ( int ) $GLOBALS [ 'post_ID' ];
2017-11-30 18:11:00 -05:00
}
2012-11-26 18:10:19 -05:00
2011-11-11 14:40:23 -05:00
?>
< p class = " upload-flash-bypass " >
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
< ? php
printf (
2019-09-02 20:41:05 -04:00
/* translators: 1: URL to browser uploader, 2: Additional link attributes. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'You are using the multi-file uploader. Problems? Try the <a href="%1$s" %2$s>browser uploader</a> instead.' ),
$browser_uploader ,
'target="_blank"'
);
?>
2011-11-11 14:40:23 -05:00
</ p >
< ? php
}
/**
2012-07-11 06:20:15 -04:00
* Displays the browser ' s built - in uploader message .
2011-11-11 14:40:23 -05:00
*
* @ since 2.6 . 0
*/
function media_upload_html_bypass () {
?>
< p class = " upload-html-bypass hide-if-no-js " >
2017-11-30 18:11:00 -05:00
< ? php _e ( 'You are using the browser’s built-in file uploader. The WordPress uploader includes multiple file selection and drag and drop capability. <a href="#">Switch to the multi-file uploader</a>.' ); ?>
2011-11-11 14:40:23 -05:00
</ p >
< ? php
}
2012-07-11 06:20:15 -04:00
/**
2012-11-21 10:10:17 -05:00
* Used to display a " After a file has been uploaded... " help message .
2012-07-11 06:20:15 -04:00
*
* @ since 3.3 . 0
*/
2012-11-21 10:10:17 -05:00
function media_upload_text_after () {}
2011-11-21 15:46:15 -05:00
2011-11-08 17:42:20 -05:00
/**
2012-07-11 06:20:15 -04:00
* Displays the checkbox to scale images .
2011-11-08 17:42:20 -05:00
*
2012-07-11 06:20:15 -04:00
* @ since 3.3 . 0
2011-11-08 17:42:20 -05:00
*/
function media_upload_max_image_resize () {
2017-11-30 18:11:00 -05:00
$checked = get_user_setting ( 'upload_resize' ) ? ' checked="true"' : '' ;
2019-07-01 08:52:01 -04:00
$a = '' ;
$end = '' ;
2011-11-08 17:42:20 -05:00
if ( current_user_can ( 'manage_options' ) ) {
2017-11-30 18:11:00 -05:00
$a = '<a href="' . esc_url ( admin_url ( 'options-media.php' ) ) . '" target="_blank">' ;
2011-11-08 17:42:20 -05:00
$end = '</a>' ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< p class = " hide-if-no-js " >< label >
< input name = " image_resize " type = " checkbox " id = " image_resize " value = " true " < ? php echo $checked ; ?> />
2018-08-16 21:51:36 -04:00
< ? php
2019-09-02 20:41:05 -04:00
/* translators: 1: Link start tag, 2: Link end tag, 3: Width, 4: Height. */
2011-11-08 17:42:20 -05:00
printf ( __ ( 'Scale images to match the large size selected in %1$simage options%2$s (%3$d × %4$d).' ), $a , $end , ( int ) get_option ( 'large_size_w' , '1024' ), ( int ) get_option ( 'large_size_h' , '1024' ) );
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
</ label ></ p >
2018-08-16 21:51:36 -04:00
< ? php
2011-11-08 17:42:20 -05:00
}
2012-07-11 06:20:15 -04:00
/**
* Displays the out of storage quota message in Multisite .
*
* @ since 3.5 . 0
*/
function multisite_over_quota_message () {
2019-04-01 08:24:51 -04:00
echo '<p>' . sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Allowed space allocation. */
2019-04-01 08:24:51 -04:00
__ ( 'Sorry, you have used your space allocation of %s. Please delete some files to upload more files.' ),
size_format ( get_space_allowed () * MB_IN_BYTES )
) . '</p>' ;
2012-07-11 06:20:15 -04:00
}
2012-09-21 18:52:54 -04:00
/**
* Displays the image and editor in the post editor
*
* @ since 3.5 . 0
2016-01-08 20:45:26 -05:00
*
* @ param WP_Post $post A post object .
2012-09-21 18:52:54 -04:00
*/
2013-06-19 17:10:51 -04:00
function edit_form_image_editor ( $post ) {
2012-12-06 00:52:19 -05:00
$open = isset ( $_GET [ 'image-editor' ] );
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( $open ) {
2012-12-06 00:52:19 -05:00
require_once ABSPATH . 'wp-admin/includes/image-edit.php' ;
2017-11-30 18:11:00 -05:00
}
2012-12-06 00:52:19 -05:00
2019-07-01 08:52:01 -04:00
$thumb_url = false ;
2020-10-08 17:15:13 -04:00
$attachment_id = ( int ) $post -> ID ;
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $attachment_id ) {
2012-12-06 00:52:19 -05:00
$thumb_url = wp_get_attachment_image_src ( $attachment_id , array ( 900 , 450 ), true );
2017-11-30 18:11:00 -05:00
}
2012-09-21 18:52:54 -04:00
2012-11-05 09:04:22 -05:00
$alt_text = get_post_meta ( $post -> ID , '_wp_attachment_image_alt' , true );
2012-09-21 18:52:54 -04:00
2017-11-30 18:11:00 -05:00
$att_url = wp_get_attachment_url ( $post -> ID );
?>
2016-01-08 14:13:26 -05:00
< div class = " wp_attachment_holder wp-clearfix " >
2013-03-21 01:17:25 -04:00
< ? php
2019-09-03 21:11:54 -04:00
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
if ( wp_attachment_is_image ( $post -> ID ) ) :
$image_edit_button = '' ;
if ( wp_image_editor_supports ( array ( 'mime_type' => $post -> post_mime_type ) ) ) {
2017-11-30 18:11:00 -05:00
$nonce = wp_create_nonce ( " image_editor- $post->ID " );
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
$image_edit_button = " <input type='button' id='imgedit-open-btn- $post->ID ' onclick='imageEdit.open( $post->ID , \" $nonce\ " ) ' class=' button ' value=' " . esc_attr__( 'Edit Image' ) . " ' /> <span class=' spinner ' ></ span > " ;
}
2017-11-22 23:09:49 -05:00
2019-07-01 08:52:01 -04:00
$open_style = '' ;
$not_open_style = '' ;
2019-09-03 21:11:54 -04:00
2017-11-22 23:09:49 -05:00
if ( $open ) {
$open_style = ' style="display:none"' ;
} else {
$not_open_style = ' style="display:none"' ;
}
2013-03-21 01:17:25 -04:00
2019-09-03 21:11:54 -04:00
?>
2012-09-21 18:52:54 -04:00
< div class = " imgedit-response " id = " imgedit-response-<?php echo $attachment_id ; ?> " ></ div >
2017-11-22 23:09:49 -05:00
< div < ? php echo $open_style ; ?> class="wp_attachment_image wp-clearfix" id="media-head-<?php echo $attachment_id; ?>">
2012-11-21 07:05:24 -05:00
< p id = " thumbnail-head-<?php echo $attachment_id ; ?> " >< img class = " thumbnail " src = " <?php echo set_url_scheme( $thumb_url[0] ); ?> " style = " max-width:100% " alt = " " /></ p >
2012-09-21 18:52:54 -04:00
< p >< ? php echo $image_edit_button ; ?> </p>
</ div >
2017-11-22 23:09:49 -05:00
< div < ? php echo $not_open_style ; ?> class="image-editor" id="image-editor-<?php echo $attachment_id; ?>">
2019-09-03 21:11:54 -04:00
< ? php
if ( $open ) {
wp_image_editor ( $attachment_id );
}
?>
2012-12-06 00:52:19 -05:00
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2017-11-30 18:11:00 -05:00
elseif ( $attachment_id && wp_attachment_is ( 'audio' , $post ) ) :
2013-03-21 01:17:25 -04:00
2014-03-06 14:34:14 -05:00
wp_maybe_generate_attachment_metadata ( $post );
2014-02-07 17:41:12 -05:00
2013-07-03 16:19:00 -04:00
echo wp_audio_shortcode ( array ( 'src' => $att_url ) );
2013-03-21 01:17:25 -04:00
2017-11-30 18:11:00 -05:00
elseif ( $attachment_id && wp_attachment_is ( 'video' , $post ) ) :
2012-09-21 18:52:54 -04:00
2014-03-06 14:34:14 -05:00
wp_maybe_generate_attachment_metadata ( $post );
2014-02-07 17:41:12 -05:00
2013-03-21 01:17:25 -04:00
$meta = wp_get_attachment_metadata ( $attachment_id );
2017-11-30 18:11:00 -05:00
$w = ! empty ( $meta [ 'width' ] ) ? min ( $meta [ 'width' ], 640 ) : 0 ;
$h = ! empty ( $meta [ 'height' ] ) ? $meta [ 'height' ] : 0 ;
2019-09-03 21:11:54 -04:00
2014-02-28 16:28:14 -05:00
if ( $h && $w < $meta [ 'width' ] ) {
2013-04-12 18:27:24 -04:00
$h = round ( ( $meta [ 'height' ] * $w ) / $meta [ 'width' ] );
2014-02-28 16:28:14 -05:00
}
2013-04-12 18:27:24 -04:00
2013-07-03 16:19:00 -04:00
$attr = array ( 'src' => $att_url );
2019-09-03 21:11:54 -04:00
2014-02-28 16:28:14 -05:00
if ( ! empty ( $w ) && ! empty ( $h ) ) {
2017-11-30 18:11:00 -05:00
$attr [ 'width' ] = $w ;
2013-07-03 16:19:00 -04:00
$attr [ 'height' ] = $h ;
2014-02-28 16:28:14 -05:00
}
2013-07-03 16:19:00 -04:00
2014-07-08 13:48:17 -04:00
$thumb_id = get_post_thumbnail_id ( $attachment_id );
2019-09-03 21:11:54 -04:00
2014-07-08 13:48:17 -04:00
if ( ! empty ( $thumb_id ) ) {
$attr [ 'poster' ] = wp_get_attachment_url ( $thumb_id );
}
2013-07-03 16:19:00 -04:00
echo wp_video_shortcode ( $attr );
2013-03-21 01:17:25 -04:00
2017-11-30 18:11:00 -05:00
elseif ( isset ( $thumb_url [ 0 ] ) ) :
Media: Add support for rendering PDF thumbnails.
When support for PDFs is available, on upload,
render 'Thumbnail', 'Medium', 'Large', and 'Full' sizes of
the first page, and save them in attachment meta.
Use these renders within Add Media, Media Gallery and List views,
Attachment Details, Post/Attachment Edit screens, and Attachment pages.
Support available by default via Imagick -> ImageMagick -> Ghostscript,
but can be provided by any `WP_Image_Editor` that supports PDFs.
Props adamsilverstein, azaozz, celloexpressions, desrosj, dglingren, ericlewis, ipstenu, joemcgill, joyously, markoheijnen, melchoyce, mikeschroder, tomauger.
Fixes #31050.
Built from https://develop.svn.wordpress.org/trunk@38949
git-svn-id: http://core.svn.wordpress.org/trunk@38892 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-26 03:28:32 -04:00
?>
< div class = " wp_attachment_image wp-clearfix " id = " media-head-<?php echo $attachment_id ; ?> " >
< p id = " thumbnail-head-<?php echo $attachment_id ; ?> " >
< img class = " thumbnail " src = " <?php echo set_url_scheme( $thumb_url[0] ); ?> " style = " max-width:100% " alt = " " />
</ p >
</ div >
< ? php
2017-11-30 18:11:00 -05:00
else :
2016-06-26 18:37:27 -04:00
/**
2016-07-09 10:00:31 -04:00
* Fires when an attachment type can ' t be rendered in the edit form .
2016-06-26 18:37:27 -04:00
*
* @ since 4.6 . 0
*
2016-06-26 21:54:30 -04:00
* @ param WP_Post $post A post object .
2016-06-26 18:37:27 -04:00
*/
do_action ( 'wp_edit_form_attachment_display' , $post );
2017-11-30 18:11:00 -05:00
endif ;
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
?>
2013-03-21 01:17:25 -04:00
</ div >
2013-03-04 18:22:17 -05:00
< div class = " wp_attachment_details edit-form-section " >
2012-11-21 07:03:35 -05:00
< ? php if ( 'image' === substr ( $post -> post_mime_type , 0 , 5 ) ) : ?>
2019-04-10 16:00:50 -04:00
< p class = " attachment-alt-text " >
2012-11-05 09:04:22 -05:00
< label for = " attachment_alt " >< strong >< ? php _e ( 'Alternative Text' ); ?> </strong></label><br />
2019-04-10 16:00:50 -04:00
< input type = " text " class = " widefat " name = " _wp_attachment_image_alt " id = " attachment_alt " aria - describedby = " alt-text-description " value = " <?php echo esc_attr( $alt_text ); ?> " />
</ p >
< p class = " attachment-alt-text-description " id = " alt-text-description " >
2019-09-03 21:11:54 -04:00
< ? php
printf (
/* translators: 1: Link to tutorial, 2: Additional link attributes, 3: Accessibility text. */
2021-11-07 19:22:57 -05:00
__ ( '<a href="%1$s" %2$s>Learn how to describe the purpose of the image%3$s</a>. Leave empty if the image is purely decorative.' ),
2019-09-03 21:11:54 -04:00
esc_url ( 'https://www.w3.org/WAI/tutorials/images/decision-tree' ),
2020-10-19 19:39:04 -04:00
'target="_blank" rel="noopener"' ,
2019-09-03 21:11:54 -04:00
sprintf (
'<span class="screen-reader-text"> %s</span>' ,
/* translators: Accessibility text. */
__ ( '(opens in a new tab)' )
)
);
?>
2012-11-05 09:04:22 -05:00
</ p >
2012-11-21 08:32:26 -05:00
< ? php endif ; ?>
2019-04-10 16:00:50 -04:00
< p >
< label for = " attachment_caption " >< strong >< ? php _e ( 'Caption' ); ?> </strong></label><br />
< textarea class = " widefat " name = " excerpt " id = " attachment_caption " >< ? php echo $post -> post_excerpt ; ?> </textarea>
</ p >
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
< ? php
2019-09-03 21:11:54 -04:00
$quicktags_settings = array ( 'buttons' => 'strong,em,link,block,del,ins,img,ul,ol,li,code,close' );
$editor_args = array (
'textarea_name' => 'content' ,
'textarea_rows' => 5 ,
'media_buttons' => false ,
'tinymce' => false ,
'quicktags' => $quicktags_settings ,
);
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
?>
2019-09-30 13:56:57 -04:00
< label for = " attachment_content " class = " attachment-content-description " >< strong >< ? php _e ( 'Description' ); ?> </strong>
2019-09-03 21:11:54 -04:00
< ? php
if ( preg_match ( '#^(audio|video)/#' , $post -> post_mime_type ) ) {
echo ': ' . __ ( 'Displayed on attachment pages.' );
}
?>
2017-11-30 18:11:00 -05:00
</ label >
2020-06-10 13:21:20 -04:00
< ? php wp_editor ( format_to_edit ( $post -> post_content ), 'attachment_content' , $editor_args ); ?>
Restore the Description field to the media UI in 3.5.
We tried in vain -- a noble but ultimately failed effort -- to reduce the number of fields for attachments from four (title, caption, alt, description) to one (caption for images, title otherwise). Alternative text needed to stay for accessibility reasons, of course.
Eventually title returned due to heavy plugin reliance. Description is too used by too many plugins (often times incorrectly -- the caption is more likely the proper field), hence its less-than-triumphant return today.
Version 3.5 has tried to streamline media in a number of ways. Removing fields may have been too much at once, as it forced not only a user interface change, but a paradigm change as well.
Finally, on upload we populate the description field with IPTC/EXIF captions, rather than the caption field. See #22768, this should be fixed. For now, Description stays.
This commit also restores 'Title' attribute editing to the main tab of the Edit Image dialog. The "Title" field no longer populates title attributes for <img> tags by design (for accessibility and other purposes, see #18984). So, here is a more obvious 'workaround' for the tooltip community.
Finally, this:
* Cleans up the post.php attachment editor, including by showing a prettier form of the mime type.
* Enables plugins to specifically hide attachment_fields_to_edit from either post.php (where you can create meta boxes) or the modal (which you may not want to clutter), for compatibility reasons.
* Hides the 'Describe this file...' placeholder when a field is read-only in the modal.
props nacin, helenyhou.
fixes #22759.
git-svn-id: http://core.svn.wordpress.org/trunk@23083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2012-12-05 19:41:06 -05:00
2012-09-21 18:52:54 -04:00
</ div >
< ? php
2019-09-03 21:11:54 -04:00
2012-11-21 13:53:00 -05:00
$extras = get_compat_media_markup ( $post -> ID );
echo $extras [ 'item' ];
2012-11-21 22:43:16 -05:00
echo '<input type="hidden" id="image-edit-context" value="edit-attachment" />' . " \n " ;
2012-11-05 09:04:22 -05:00
}
/**
2016-07-09 20:56:28 -04:00
* Displays non - editable attachment metadata in the publish meta box .
2012-11-05 09:04:22 -05:00
*
* @ since 3.5 . 0
*/
function attachment_submitbox_metadata () {
2019-09-03 21:11:54 -04:00
$post = get_post ();
$attachment_id = $post -> ID ;
2012-11-05 09:04:22 -05:00
2019-09-03 21:11:54 -04:00
$file = get_attached_file ( $attachment_id );
2015-09-15 00:18:25 -04:00
$filename = esc_html ( wp_basename ( $file ) );
2012-11-05 09:04:22 -05:00
$media_dims = '' ;
2019-09-03 21:11:54 -04:00
$meta = wp_get_attachment_metadata ( $attachment_id );
2017-11-30 18:11:00 -05:00
if ( isset ( $meta [ 'width' ], $meta [ 'height' ] ) ) {
2019-09-03 21:11:54 -04:00
$media_dims .= " <span id='media-dims- $attachment_id '> { $meta [ 'width' ] } × { $meta [ 'height' ] } </span> " ;
2017-11-30 18:11:00 -05:00
}
2014-01-06 00:48:12 -05:00
/** This filter is documented in wp-admin/includes/media.php */
2012-11-05 09:04:22 -05:00
$media_dims = apply_filters ( 'media_meta' , $media_dims , $post );
2019-09-03 21:11:54 -04:00
$att_url = wp_get_attachment_url ( $attachment_id );
2021-01-18 07:55:07 -05:00
$author = new WP_User ( $post -> post_author );
2020-10-19 16:29:05 -04:00
$uploaded_by_name = __ ( '(no author)' );
$uploaded_by_link = '' ;
2021-01-18 07:55:07 -05:00
2020-10-19 16:29:05 -04:00
if ( $author -> exists () ) {
$uploaded_by_name = $author -> display_name ? $author -> display_name : $author -> nickname ;
$uploaded_by_link = get_edit_user_link ( $author -> ID );
2020-10-19 16:45:06 -04:00
}
?>
2020-10-19 16:29:05 -04:00
< div class = " misc-pub-section misc-pub-uploadedby " >
2020-10-19 16:45:06 -04:00
< ? php if ( $uploaded_by_link ) { ?>
< ? php _e ( 'Uploaded by:' ); ?> <a href="<?php echo $uploaded_by_link; ?>"><strong><?php echo $uploaded_by_name; ?></strong></a>
< ? php } else { ?>
< ? php _e ( 'Uploaded by:' ); ?> <strong><?php echo $uploaded_by_name; ?></strong>
< ? php } ?>
2020-10-19 16:29:05 -04:00
</ div >
2020-10-19 16:45:06 -04:00
< ? php
if ( $post -> post_parent ) {
2020-10-19 16:29:05 -04:00
$post_parent = get_post ( $post -> post_parent );
2020-10-19 16:45:06 -04:00
if ( $post_parent ) {
2020-10-19 16:29:05 -04:00
$uploaded_to_title = $post_parent -> post_title ? $post_parent -> post_title : __ ( '(no title)' );
2020-10-19 16:45:06 -04:00
$uploaded_to_link = get_edit_post_link ( $post -> post_parent , 'raw' );
?>
2020-10-19 16:29:05 -04:00
< div class = " misc-pub-section misc-pub-uploadedto " >
2020-10-19 16:45:06 -04:00
< ? php if ( $uploaded_to_link ) { ?>
< ? php _e ( 'Uploaded to:' ); ?> <a href="<?php echo $uploaded_to_link; ?>"><strong><?php echo $uploaded_to_title; ?></strong></a>
< ? php } else { ?>
2020-10-19 16:29:05 -04:00
< ? php _e ( 'Uploaded to:' ); ?> <strong><?php echo $uploaded_to_title; ?></strong>
2020-10-19 16:45:06 -04:00
< ? php } ?>
2020-10-19 16:29:05 -04:00
</ div >
2020-10-19 16:45:06 -04:00
< ? php
}
}
?>
2020-10-19 16:29:05 -04:00
2013-08-22 11:24:10 -04:00
< div class = " misc-pub-section misc-pub-attachment " >
2015-11-03 11:02:25 -05:00
< label for = " attachment_url " >< ? php _e ( 'File URL:' ); ?> </label>
< input type = " text " class = " widefat urlfield " readonly = " readonly " name = " attachment_url " id = " attachment_url " value = " <?php echo esc_attr( $att_url ); ?> " />
Accessibility: Media: Add a "Copy URL" button to the attachment File URL fields.
For a number of years, various screens in the WordPress admin provided users with a readonly input field to copy the attachment file URL. Manually copying from a readonly field is an annoying task at best even for mouser users. It's a usability and accessibility issue at the same time.
These fields now have a new "Copy URL" button that is easy to use and accessible to everyone.
Props theolg, markdubois, vabrashev, sajjad67, xkon, nrqsnchz, melchoyce, audrasjb, afercia.
See #41612, #50322, #50335.
Fixes #48463.
Built from https://develop.svn.wordpress.org/trunk@48232
git-svn-id: http://core.svn.wordpress.org/trunk@48001 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-30 09:16:04 -04:00
< span class = " copy-to-clipboard-container " >
2020-09-27 16:48:05 -04:00
< button type = " button " class = " button copy-attachment-url edit-media " data - clipboard - target = " #attachment_url " >< ? php _e ( 'Copy URL to clipboard' ); ?> </button>
Accessibility: Media: Add a "Copy URL" button to the attachment File URL fields.
For a number of years, various screens in the WordPress admin provided users with a readonly input field to copy the attachment file URL. Manually copying from a readonly field is an annoying task at best even for mouser users. It's a usability and accessibility issue at the same time.
These fields now have a new "Copy URL" button that is easy to use and accessible to everyone.
Props theolg, markdubois, vabrashev, sajjad67, xkon, nrqsnchz, melchoyce, audrasjb, afercia.
See #41612, #50322, #50335.
Fixes #48463.
Built from https://develop.svn.wordpress.org/trunk@48232
git-svn-id: http://core.svn.wordpress.org/trunk@48001 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-06-30 09:16:04 -04:00
< span class = " success hidden " aria - hidden = " true " >< ? php _e ( 'Copied!' ); ?> </span>
</ span >
2012-11-05 09:04:22 -05:00
</ div >
2013-08-22 11:24:10 -04:00
< div class = " misc-pub-section misc-pub-filename " >
2012-11-05 09:04:22 -05:00
< ? php _e ( 'File name:' ); ?> <strong><?php echo $filename; ?></strong>
</ div >
2013-08-22 11:24:10 -04:00
< div class = " misc-pub-section misc-pub-filetype " >
2019-09-03 21:11:54 -04:00
< ? php _e ( 'File type:' ); ?>
< strong >
< ? php
if ( preg_match ( '/^.*?\.(\w+)$/' , get_attached_file ( $post -> ID ), $matches ) ) {
echo esc_html ( strtoupper ( $matches [ 1 ] ) );
list ( $mime_type ) = explode ( '/' , $post -> post_mime_type );
2020-02-09 11:55:09 -05:00
if ( 'image' !== $mime_type && ! empty ( $meta [ 'mime_type' ] ) ) {
if ( " $mime_type / " . strtolower ( $matches [ 1 ] ) !== $meta [ 'mime_type' ] ) {
2019-09-03 21:11:54 -04:00
echo ' (' . $meta [ 'mime_type' ] . ')' ;
}
}
} else {
echo strtoupper ( str_replace ( 'image/' , '' , $post -> post_mime_type ) );
}
?>
2017-11-30 18:11:00 -05:00
</ strong >
2012-11-05 09:04:22 -05:00
</ div >
2013-09-12 11:10:09 -04:00
< ? php
2019-09-03 21:11:54 -04:00
$file_size = false ;
2013-09-24 16:23:10 -04:00
2017-11-30 18:11:00 -05:00
if ( isset ( $meta [ 'filesize' ] ) ) {
$file_size = $meta [ 'filesize' ];
} elseif ( file_exists ( $file ) ) {
$file_size = filesize ( $file );
}
2013-09-12 11:10:09 -04:00
2019-09-03 21:11:54 -04:00
if ( ! empty ( $file_size ) ) {
2017-11-30 18:11:00 -05:00
?>
2019-09-03 21:11:54 -04:00
< div class = " misc-pub-section misc-pub-filesize " >
< ? php _e ( 'File size:' ); ?> <strong><?php echo size_format( $file_size ); ?></strong>
</ div >
< ? php
}
2013-09-12 11:10:09 -04:00
2014-03-31 01:16:16 -04:00
if ( preg_match ( '#^(audio|video)/#' , $post -> post_mime_type ) ) {
2017-09-23 13:07:46 -04:00
$fields = array (
'length_formatted' => __ ( 'Length:' ),
'bitrate' => __ ( 'Bitrate:' ),
);
2013-04-12 18:27:24 -04:00
2013-09-07 12:19:10 -04:00
/**
2016-05-22 14:01:30 -04:00
* Filters the audio and video metadata fields to be shown in the publish meta box .
2013-09-07 12:19:10 -04:00
*
* The key for each item in the array should correspond to an attachment
* metadata key , and the value should be the desired label .
*
2014-01-06 00:48:12 -05:00
* @ since 3.7 . 0
2017-09-23 13:07:46 -04:00
* @ since 4.9 . 0 Added the `$post` parameter .
2013-09-07 12:19:10 -04:00
*
2017-09-23 13:07:46 -04:00
* @ param array $fields An array of the attachment metadata keys and labels .
* @ param WP_Post $post WP_Post object for the current attachment .
2013-09-07 12:19:10 -04:00
*/
2017-09-23 13:07:46 -04:00
$fields = apply_filters ( 'media_submitbox_misc_sections' , $fields , $post );
2013-04-12 18:27:24 -04:00
2014-03-31 01:16:16 -04:00
foreach ( $fields as $key => $label ) {
if ( empty ( $meta [ $key ] ) ) {
continue ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< div class = " misc-pub-section misc-pub-mime-meta misc-pub-<?php echo sanitize_html_class( $key ); ?> " >
< ? php echo $label ; ?>
< strong >
< ? php
switch ( $key ) {
case 'bitrate' :
echo round ( $meta [ 'bitrate' ] / 1000 ) . 'kb/s' ;
if ( ! empty ( $meta [ 'bitrate_mode' ] ) ) {
echo ' ' . strtoupper ( esc_html ( $meta [ 'bitrate_mode' ] ) );
2014-03-31 01:16:16 -04:00
}
2019-09-03 21:11:54 -04:00
break ;
default :
echo esc_html ( $meta [ $key ] );
break ;
}
?>
</ strong >
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2014-03-31 01:16:16 -04:00
}
2013-04-12 18:27:24 -04:00
2017-09-23 13:07:46 -04:00
$fields = array (
'dataformat' => __ ( 'Audio Format:' ),
2017-11-30 18:11:00 -05:00
'codec' => __ ( 'Audio Codec:' ),
2017-09-23 13:07:46 -04:00
);
2013-09-07 12:19:10 -04:00
/**
2016-05-22 14:01:30 -04:00
* Filters the audio attachment metadata fields to be shown in the publish meta box .
2013-09-07 12:19:10 -04:00
*
* The key for each item in the array should correspond to an attachment
* metadata key , and the value should be the desired label .
*
2014-01-06 00:48:12 -05:00
* @ since 3.7 . 0
2017-09-23 13:07:46 -04:00
* @ since 4.9 . 0 Added the `$post` parameter .
2013-09-07 12:19:10 -04:00
*
2017-09-23 13:07:46 -04:00
* @ param array $fields An array of the attachment metadata keys and labels .
* @ param WP_Post $post WP_Post object for the current attachment .
2013-09-07 12:19:10 -04:00
*/
2017-09-23 13:07:46 -04:00
$audio_fields = apply_filters ( 'audio_submitbox_misc_sections' , $fields , $post );
2013-04-12 18:27:24 -04:00
2014-03-31 01:16:16 -04:00
foreach ( $audio_fields as $key => $label ) {
if ( empty ( $meta [ 'audio' ][ $key ] ) ) {
continue ;
}
2019-09-03 21:11:54 -04:00
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< div class = " misc-pub-section misc-pub-audio misc-pub-<?php echo sanitize_html_class( $key ); ?> " >
< ? php echo $label ; ?> <strong><?php echo esc_html( $meta['audio'][ $key ] ); ?></strong>
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2014-03-31 01:16:16 -04:00
}
}
2013-04-12 18:27:24 -04:00
2019-09-03 21:11:54 -04:00
if ( $media_dims ) {
2018-08-16 21:51:36 -04:00
?>
2019-09-03 21:11:54 -04:00
< div class = " misc-pub-section misc-pub-dimensions " >
< ? php _e ( 'Dimensions:' ); ?> <strong><?php echo $media_dims; ?></strong>
</ div >
2018-08-16 21:51:36 -04:00
< ? php
2019-09-03 21:11:54 -04:00
}
2020-02-07 00:13:05 -05:00
if ( ! empty ( $meta [ 'original_image' ] ) ) {
?>
< div class = " misc-pub-section misc-pub-original-image " >
< ? php _e ( 'Original image:' ); ?>
< a href = " <?php echo esc_url( wp_get_original_image_url( $attachment_id ) ); ?> " >
< ? php echo esc_html ( wp_basename ( wp_get_original_image_path ( $attachment_id ) ) ); ?>
</ a >
</ div >
< ? php
}
2012-09-21 18:52:54 -04:00
}
2013-03-21 00:55:42 -04:00
/**
* Parse ID3v2 , ID3v1 , and getID3 comments to extract usable data
*
* @ since 3.6 . 0
*
* @ param array $metadata An existing array with data
* @ param array $data Data supplied by ID3 tags
*/
function wp_add_id3_tag_data ( & $metadata , $data ) {
foreach ( array ( 'id3v2' , 'id3v1' ) as $version ) {
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ $version ][ 'comments' ] ) ) {
foreach ( $data [ $version ][ 'comments' ] as $key => $list ) {
2014-09-10 17:57:15 -04:00
if ( 'length' !== $key && ! empty ( $list ) ) {
2017-11-30 18:11:00 -05:00
$metadata [ $key ] = wp_kses_post ( reset ( $list ) );
2014-07-17 05:14:16 -04:00
// Fix bug in byte stream analysis.
2017-11-30 18:11:00 -05:00
if ( 'terms_of_use' === $key && 0 === strpos ( $metadata [ $key ], 'yright notice.' ) ) {
$metadata [ $key ] = 'Cop' . $metadata [ $key ];
}
2013-03-21 00:55:42 -04:00
}
}
break ;
}
}
if ( ! empty ( $data [ 'id3v2' ][ 'APIC' ] ) ) {
2017-11-30 18:11:00 -05:00
$image = reset ( $data [ 'id3v2' ][ 'APIC' ] );
2013-03-21 00:55:42 -04:00
if ( ! empty ( $image [ 'data' ] ) ) {
$metadata [ 'image' ] = array (
2017-11-30 18:11:00 -05:00
'data' => $image [ 'data' ],
'mime' => $image [ 'image_mime' ],
'width' => $image [ 'image_width' ],
'height' => $image [ 'image_height' ],
2013-03-21 00:55:42 -04:00
);
}
} elseif ( ! empty ( $data [ 'comments' ][ 'picture' ] ) ) {
$image = reset ( $data [ 'comments' ][ 'picture' ] );
if ( ! empty ( $image [ 'data' ] ) ) {
$metadata [ 'image' ] = array (
'data' => $image [ 'data' ],
2017-11-30 18:11:00 -05:00
'mime' => $image [ 'image_mime' ],
2013-03-21 00:55:42 -04:00
);
}
}
}
/**
* Retrieve metadata from a video file ' s ID3 tags
*
* @ since 3.6 . 0
*
* @ param string $file Path to file .
2021-01-03 17:04:04 -05:00
* @ return array | false Returns array of metadata , if found .
2013-03-21 00:55:42 -04:00
*/
function wp_read_video_metadata ( $file ) {
2015-10-06 10:14:25 -04:00
if ( ! file_exists ( $file ) ) {
2013-03-21 00:55:42 -04:00
return false ;
2015-10-06 10:14:25 -04:00
}
2013-03-21 00:55:42 -04:00
$metadata = array ();
2015-10-06 10:14:25 -04:00
if ( ! defined ( 'GETID3_TEMP_DIR' ) ) {
define ( 'GETID3_TEMP_DIR' , get_temp_dir () );
}
if ( ! class_exists ( 'getID3' , false ) ) {
2020-02-06 01:33:11 -05:00
require ABSPATH . WPINC . '/ID3/getid3.php' ;
2015-10-06 10:14:25 -04:00
}
2019-09-03 21:11:54 -04:00
2021-11-25 22:06:03 -05:00
$id3 = new getID3 ();
// Required to get the `created_timestamp` value.
$id3 -> options_audiovideo_quicktime_ReturnAtomData = true ; // phpcs:ignore WordPress.NamingConventions.ValidVariableName
2013-03-21 00:55:42 -04:00
$data = $id3 -> analyze ( $file );
2017-11-30 18:11:00 -05:00
if ( isset ( $data [ 'video' ][ 'lossless' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'lossless' ] = $data [ 'video' ][ 'lossless' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'bitrate' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'bitrate' ] = ( int ) $data [ 'video' ][ 'bitrate' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'bitrate_mode' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'bitrate_mode' ] = $data [ 'video' ][ 'bitrate_mode' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'filesize' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'filesize' ] = ( int ) $data [ 'filesize' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'mime_type' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'mime_type' ] = $data [ 'mime_type' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'playtime_seconds' ] ) ) {
2014-09-10 17:57:15 -04:00
$metadata [ 'length' ] = ( int ) round ( $data [ 'playtime_seconds' ] );
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'playtime_string' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'length_formatted' ] = $data [ 'playtime_string' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'resolution_x' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'width' ] = ( int ) $data [ 'video' ][ 'resolution_x' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'resolution_y' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'height' ] = ( int ) $data [ 'video' ][ 'resolution_y' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'fileformat' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'fileformat' ] = $data [ 'fileformat' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'dataformat' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'dataformat' ] = $data [ 'video' ][ 'dataformat' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'encoder' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'encoder' ] = $data [ 'video' ][ 'encoder' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'video' ][ 'codec' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'codec' ] = $data [ 'video' ][ 'codec' ];
2017-11-30 18:11:00 -05:00
}
2013-03-21 00:55:42 -04:00
2013-04-05 20:29:12 -04:00
if ( ! empty ( $data [ 'audio' ] ) ) {
unset ( $data [ 'audio' ][ 'streams' ] );
$metadata [ 'audio' ] = $data [ 'audio' ];
}
2013-03-21 00:55:42 -04:00
2017-10-04 15:32:47 -04:00
if ( empty ( $metadata [ 'created_timestamp' ] ) ) {
$created_timestamp = wp_get_media_creation_timestamp ( $data );
2020-02-09 11:55:09 -05:00
if ( false !== $created_timestamp ) {
2017-10-04 15:32:47 -04:00
$metadata [ 'created_timestamp' ] = $created_timestamp ;
}
}
2013-03-21 00:55:42 -04:00
wp_add_id3_tag_data ( $metadata , $data );
2017-10-04 15:32:47 -04:00
$file_format = isset ( $metadata [ 'fileformat' ] ) ? $metadata [ 'fileformat' ] : null ;
/**
* Filters the array of metadata retrieved from a video .
*
* In core , usually this selection is what is stored .
* More complete data can be parsed from the `$data` parameter .
*
* @ since 4.9 . 0
*
* @ param array $metadata Filtered Video metadata .
* @ param string $file Path to video file .
* @ param string $file_format File format of video , as analyzed by getID3 .
2021-11-18 08:50:05 -05:00
* @ param array $data Raw metadata from getID3 .
2017-10-04 15:32:47 -04:00
*/
return apply_filters ( 'wp_read_video_metadata' , $metadata , $file , $file_format , $data );
2013-03-21 00:55:42 -04:00
}
/**
2019-01-09 20:32:50 -05:00
* Retrieve metadata from an audio file ' s ID3 tags .
2013-03-21 00:55:42 -04:00
*
* @ since 3.6 . 0
*
* @ param string $file Path to file .
2021-01-03 17:04:04 -05:00
* @ return array | false Returns array of metadata , if found .
2013-03-21 00:55:42 -04:00
*/
function wp_read_audio_metadata ( $file ) {
2015-10-06 10:14:25 -04:00
if ( ! file_exists ( $file ) ) {
2013-03-21 00:55:42 -04:00
return false ;
2015-10-06 10:14:25 -04:00
}
2019-09-03 21:11:54 -04:00
2013-03-21 00:55:42 -04:00
$metadata = array ();
2015-10-06 10:14:25 -04:00
if ( ! defined ( 'GETID3_TEMP_DIR' ) ) {
define ( 'GETID3_TEMP_DIR' , get_temp_dir () );
}
if ( ! class_exists ( 'getID3' , false ) ) {
2020-02-06 01:33:11 -05:00
require ABSPATH . WPINC . '/ID3/getid3.php' ;
2015-10-06 10:14:25 -04:00
}
2019-09-03 21:11:54 -04:00
2021-11-25 22:06:03 -05:00
$id3 = new getID3 ();
// Required to get the `created_timestamp` value.
$id3 -> options_audiovideo_quicktime_ReturnAtomData = true ; // phpcs:ignore WordPress.NamingConventions.ValidVariableName
2013-03-21 00:55:42 -04:00
$data = $id3 -> analyze ( $file );
if ( ! empty ( $data [ 'audio' ] ) ) {
unset ( $data [ 'audio' ][ 'streams' ] );
$metadata = $data [ 'audio' ];
}
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'fileformat' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'fileformat' ] = $data [ 'fileformat' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'filesize' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'filesize' ] = ( int ) $data [ 'filesize' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'mime_type' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'mime_type' ] = $data [ 'mime_type' ];
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'playtime_seconds' ] ) ) {
2014-09-10 17:57:15 -04:00
$metadata [ 'length' ] = ( int ) round ( $data [ 'playtime_seconds' ] );
2017-11-30 18:11:00 -05:00
}
2019-09-03 21:11:54 -04:00
2017-11-30 18:11:00 -05:00
if ( ! empty ( $data [ 'playtime_string' ] ) ) {
2013-03-21 00:55:42 -04:00
$metadata [ 'length_formatted' ] = $data [ 'playtime_string' ];
2017-11-30 18:11:00 -05:00
}
2013-03-21 00:55:42 -04:00
2019-01-09 20:32:50 -05:00
if ( empty ( $metadata [ 'created_timestamp' ] ) ) {
$created_timestamp = wp_get_media_creation_timestamp ( $data );
2019-01-09 20:52:52 -05:00
if ( false !== $created_timestamp ) {
2019-01-09 20:32:50 -05:00
$metadata [ 'created_timestamp' ] = $created_timestamp ;
}
}
2013-03-21 00:55:42 -04:00
wp_add_id3_tag_data ( $metadata , $data );
return $metadata ;
}
2015-03-05 00:35:28 -05:00
2017-10-04 15:32:47 -04:00
/**
* Parse creation date from media metadata .
*
* The getID3 library doesn ' t have a standard method for getting creation dates ,
* so the location of this data can vary based on the MIME type .
*
* @ since 4.9 . 0
*
* @ link https :// github . com / JamesHeinrich / getID3 / blob / master / structure . txt
*
* @ param array $metadata The metadata returned by getID3 :: analyze () .
2021-01-03 17:04:04 -05:00
* @ return int | false A UNIX timestamp for the media ' s creation date if available
* or a boolean FALSE if a timestamp could not be determined .
2017-10-04 15:32:47 -04:00
*/
function wp_get_media_creation_timestamp ( $metadata ) {
$creation_date = false ;
if ( empty ( $metadata [ 'fileformat' ] ) ) {
return $creation_date ;
}
switch ( $metadata [ 'fileformat' ] ) {
case 'asf' :
if ( isset ( $metadata [ 'asf' ][ 'file_properties_object' ][ 'creation_date_unix' ] ) ) {
$creation_date = ( int ) $metadata [ 'asf' ][ 'file_properties_object' ][ 'creation_date_unix' ];
}
break ;
case 'matroska' :
case 'webm' :
2021-11-25 03:35:09 -05:00
if ( isset ( $metadata [ 'matroska' ][ 'comments' ][ 'creation_time' ][ 0 ] ) ) {
$creation_date = strtotime ( $metadata [ 'matroska' ][ 'comments' ][ 'creation_time' ][ 0 ] );
} elseif ( isset ( $metadata [ 'matroska' ][ 'info' ][ 0 ][ 'DateUTC_unix' ] ) ) {
$creation_date = ( int ) $metadata [ 'matroska' ][ 'info' ][ 0 ][ 'DateUTC_unix' ];
2017-10-04 15:32:47 -04:00
}
break ;
case 'quicktime' :
case 'mp4' :
2021-11-25 03:35:09 -05:00
if ( isset ( $metadata [ 'quicktime' ][ 'moov' ][ 'subatoms' ][ 0 ][ 'creation_time_unix' ] ) ) {
$creation_date = ( int ) $metadata [ 'quicktime' ][ 'moov' ][ 'subatoms' ][ 0 ][ 'creation_time_unix' ];
2017-10-04 15:32:47 -04:00
}
break ;
}
return $creation_date ;
}
2015-03-05 00:35:28 -05:00
/**
2020-06-05 04:30:10 -04:00
* Encapsulates the logic for Attach / Detach actions .
2015-03-05 00:35:28 -05:00
*
* @ since 4.2 . 0
*
2015-04-04 17:35:25 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
*
* @ param int $parent_id Attachment parent ID .
* @ param string $action Optional . Attach / detach action . Accepts 'attach' or 'detach' .
* Default 'attach' .
2015-03-05 00:35:28 -05:00
*/
function wp_media_attach_action ( $parent_id , $action = 'attach' ) {
global $wpdb ;
if ( ! $parent_id ) {
return ;
}
if ( ! current_user_can ( 'edit_post' , $parent_id ) ) {
2016-06-29 11:16:29 -04:00
wp_die ( __ ( 'Sorry, you are not allowed to edit this post.' ) );
2015-03-05 00:35:28 -05:00
}
2019-09-03 21:11:54 -04:00
2015-03-05 00:35:28 -05:00
$ids = array ();
2019-09-03 21:11:54 -04:00
2020-06-05 04:30:10 -04:00
foreach ( ( array ) $_REQUEST [ 'media' ] as $attachment_id ) {
$attachment_id = ( int ) $attachment_id ;
2015-03-05 00:35:28 -05:00
2020-06-05 04:30:10 -04:00
if ( ! current_user_can ( 'edit_post' , $attachment_id ) ) {
2015-03-05 00:35:28 -05:00
continue ;
}
2020-06-05 04:30:10 -04:00
$ids [] = $attachment_id ;
2015-03-05 00:35:28 -05:00
}
if ( ! empty ( $ids ) ) {
$ids_string = implode ( ',' , $ids );
2019-09-03 21:11:54 -04:00
2015-03-05 00:35:28 -05:00
if ( 'attach' === $action ) {
$result = $wpdb -> query ( $wpdb -> prepare ( " UPDATE $wpdb->posts SET post_parent = %d WHERE post_type = 'attachment' AND ID IN ( $ids_string ) " , $parent_id ) );
} else {
$result = $wpdb -> query ( " UPDATE $wpdb->posts SET post_parent = 0 WHERE post_type = 'attachment' AND ID IN ( $ids_string ) " );
}
2020-06-04 11:00:09 -04:00
}
2015-03-05 00:35:28 -05:00
2020-06-04 11:00:09 -04:00
if ( isset ( $result ) ) {
2020-06-05 04:30:10 -04:00
foreach ( $ids as $attachment_id ) {
2020-06-04 11:00:09 -04:00
/**
2020-06-05 04:30:10 -04:00
* Fires when media is attached or detached from a post .
2020-06-04 11:00:09 -04:00
*
2020-06-05 04:30:10 -04:00
* @ since 5.5 . 0
2020-06-04 11:00:09 -04:00
*
2020-06-05 04:30:10 -04:00
* @ param string $action Attach / detach action . Accepts 'attach' or 'detach' .
* @ param int $attachment_id The attachment ID .
* @ param int $parent_id Attachment parent ID .
2020-06-04 11:00:09 -04:00
*/
2020-06-05 04:30:10 -04:00
do_action ( 'wp_media_attach_action' , $action , $attachment_id , $parent_id );
2020-06-04 11:00:09 -04:00
2020-06-05 04:30:10 -04:00
clean_attachment_cache ( $attachment_id );
2015-03-05 00:35:28 -05:00
}
$location = 'upload.php' ;
2019-07-01 08:52:01 -04:00
$referer = wp_get_referer ();
2019-09-03 21:11:54 -04:00
2019-07-01 08:52:01 -04:00
if ( $referer ) {
2015-03-05 00:35:28 -05:00
if ( false !== strpos ( $referer , 'upload.php' ) ) {
2015-03-05 10:59:27 -05:00
$location = remove_query_arg ( array ( 'attached' , 'detach' ), $referer );
2015-03-05 00:35:28 -05:00
}
}
2017-11-30 18:11:00 -05:00
$key = 'attach' === $action ? 'attached' : 'detach' ;
2015-03-05 00:35:28 -05:00
$location = add_query_arg ( array ( $key => $result ), $location );
2019-09-03 21:11:54 -04:00
2015-03-05 00:35:28 -05:00
wp_redirect ( $location );
exit ;
}
2015-03-16 20:47:28 -04:00
}