2008-09-30 02:27:27 +02:00
< ? php
2008-10-02 03:02:17 +02:00
/**
2012-11-21 13:19:40 +01:00
* Manage media uploaded file .
*
* There are many filters in here for media . Plugins can extend functionality
* by hooking into the filters .
2008-10-02 03:02:17 +02:00
*
* @ package WordPress
* @ subpackage Administration
*/
2012-11-21 13:19:40 +01:00
/** Load WordPress Administration Bootstrap */
2013-09-25 02:18:11 +02:00
require_once ( dirname ( __FILE__ ) . '/admin.php' );
2012-11-21 13:19:40 +01:00
2017-12-01 00:11:00 +01:00
if ( ! current_user_can ( 'upload_files' ) ) {
wp_die ( __ ( 'Sorry, you are not allowed to upload files.' ) );
}
2012-11-21 13:19:40 +01:00
2017-12-01 00:11:00 +01:00
wp_enqueue_script ( 'plupload-handlers' );
2012-11-21 13:19:40 +01:00
2012-11-27 00:10:19 +01:00
$post_id = 0 ;
if ( isset ( $_REQUEST [ 'post_id' ] ) ) {
$post_id = absint ( $_REQUEST [ 'post_id' ] );
2017-12-01 00:11:00 +01:00
if ( ! get_post ( $post_id ) || ! current_user_can ( 'edit_post' , $post_id ) ) {
2012-11-27 00:10:19 +01:00
$post_id = 0 ;
2017-12-01 00:11:00 +01:00
}
2012-11-27 00:10:19 +01:00
}
2012-11-21 13:19:40 +01:00
2012-11-21 13:27:12 +01:00
if ( $_POST ) {
2017-12-01 00:11:00 +01:00
if ( isset ( $_POST [ 'html-upload' ] ) && ! empty ( $_FILES ) ) {
check_admin_referer ( 'media-form' );
2020-01-29 01:45:18 +01:00
// Upload File button was clicked.
2015-09-10 19:18:24 +02:00
$upload_id = media_handle_upload ( 'async-upload' , $post_id );
if ( is_wp_error ( $upload_id ) ) {
wp_die ( $upload_id );
}
2012-11-21 13:19:40 +01:00
}
2015-09-10 19:18:24 +02:00
wp_redirect ( admin_url ( 'upload.php' ) );
2012-11-21 13:27:12 +01:00
exit ;
}
2012-11-21 13:19:40 +01:00
2017-12-01 00:11:00 +01:00
$title = __ ( 'Upload New Media' );
2012-11-21 16:10:17 +01:00
$parent_file = 'upload.php' ;
2017-12-01 00:11:00 +01:00
get_current_screen () -> add_help_tab (
array (
'id' => 'overview' ,
'title' => __ ( 'Overview' ),
'content' =>
2019-07-05 07:21:56 +02:00
'<p>' . __ ( 'You can upload media files here without creating a post first. This allows you to upload files to use with posts and pages later and/or to get a web link for a particular file that you can share. There are three options for uploading files:' ) . '</p>' .
'<ul>' .
'<li>' . __ ( '<strong>Drag and drop</strong> your files into the area below. Multiple files are allowed.' ) . '</li>' .
'<li>' . __ ( 'Clicking <strong>Select Files</strong> opens a navigation window showing you files in your operating system. Selecting <strong>Open</strong> after clicking on the file you want activates a progress bar on the uploader screen.' ) . '</li>' .
'<li>' . __ ( 'Revert to the <strong>Browser Uploader</strong> by clicking the link below the drag and drop box.' ) . '</li>' .
'</ul>' ,
2017-12-01 00:11:00 +01:00
)
);
2012-11-21 16:10:17 +01:00
get_current_screen () -> set_help_sidebar (
2017-12-01 00:11:00 +01:00
'<p><strong>' . __ ( 'For more information:' ) . '</strong></p>' .
2019-07-26 00:45:57 +02:00
'<p>' . __ ( '<a href="https://wordpress.org/support/article/media-add-new-screen/">Documentation on Uploading Media Files</a>' ) . '</p>' .
2019-04-09 00:59:56 +02:00
'<p>' . __ ( '<a href="https://wordpress.org/support/">Support</a>' ) . '</p>'
2012-11-21 16:10:17 +01:00
);
require_once ( ABSPATH . 'wp-admin/admin-header.php' );
2012-11-27 23:41:15 +01:00
$form_class = 'media-upload-form type-form validate' ;
2012-11-21 16:10:17 +01:00
2017-12-01 00:11:00 +01:00
if ( get_user_setting ( 'uploader' ) || isset ( $_GET [ 'browser-uploader' ] ) ) {
2012-11-21 16:10:17 +01:00
$form_class .= ' html-uploader' ;
2017-12-01 00:11:00 +01:00
}
2012-11-21 16:10:17 +01:00
?>
< div class = " wrap " >
2015-06-27 17:41:25 +02:00
< h1 >< ? php echo esc_html ( $title ); ?> </h1>
2012-11-21 13:19:40 +01:00
2017-12-01 00:11:00 +01:00
< form enctype = " multipart/form-data " method = " post " action = " <?php echo admin_url( 'media-new.php' ); ?> " class = " <?php echo esc_attr( $form_class ); ?> " id = " file-form " >
2012-11-21 13:19:40 +01:00
< ? php media_upload_form (); ?>
< script type = " text/javascript " >
2012-11-27 00:10:19 +01:00
var post_id = < ? php echo $post_id ; ?> , shortform = 3;
2012-11-21 13:19:40 +01:00
</ script >
2012-11-27 00:10:19 +01:00
< input type = " hidden " name = " post_id " id = " post_id " value = " <?php echo $post_id ; ?> " />
2017-12-01 00:11:00 +01:00
< ? php wp_nonce_field ( 'media-form' ); ?>
2012-11-21 13:19:40 +01:00
< div id = " media-items " class = " hide-if-no-js " ></ div >
</ form >
2012-11-21 16:10:17 +01:00
</ div >
2012-11-21 13:19:40 +01:00
< ? php
2012-11-21 16:10:17 +01:00
include ( ABSPATH . 'wp-admin/admin-footer.php' );