[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * Media Library administration panel. 4 * 5 * @package WordPress 6 * @subpackage Administration 7 */ 8 9 /** WordPress Administration Bootstrap */ 10 require_once __DIR__ . '/admin.php'; 11 12 if ( ! current_user_can( 'upload_files' ) ) { 13 wp_die( __( 'Sorry, you are not allowed to upload files.' ) ); 14 } 15 16 $mode = get_user_option( 'media_library_mode', get_current_user_id() ) ? get_user_option( 'media_library_mode', get_current_user_id() ) : 'grid'; 17 $modes = array( 'grid', 'list' ); 18 19 if ( isset( $_GET['mode'] ) && in_array( $_GET['mode'], $modes, true ) ) { 20 $mode = $_GET['mode']; 21 update_user_option( get_current_user_id(), 'media_library_mode', $mode ); 22 } 23 24 if ( 'grid' === $mode ) { 25 wp_enqueue_media(); 26 wp_enqueue_script( 'media-grid' ); 27 wp_enqueue_script( 'media' ); 28 29 remove_action( 'admin_head', 'wp_admin_canonical_url' ); 30 31 $q = $_GET; 32 // Let JS handle this. 33 unset( $q['s'] ); 34 $vars = wp_edit_attachments_query_vars( $q ); 35 $ignore = array( 'mode', 'post_type', 'post_status', 'posts_per_page' ); 36 foreach ( $vars as $key => $value ) { 37 if ( ! $value || in_array( $key, $ignore, true ) ) { 38 unset( $vars[ $key ] ); 39 } 40 } 41 42 wp_localize_script( 43 'media-grid', 44 '_wpMediaGridSettings', 45 array( 46 'adminUrl' => parse_url( self_admin_url(), PHP_URL_PATH ), 47 'queryVars' => (object) $vars, 48 ) 49 ); 50 51 get_current_screen()->add_help_tab( 52 array( 53 'id' => 'overview', 54 'title' => __( 'Overview' ), 55 'content' => 56 '<p>' . __( 'All the files you’ve uploaded are listed in the Media Library, with the most recent uploads listed first.' ) . '</p>' . 57 '<p>' . __( 'You can view your media in a simple visual grid or a list with columns. Switch between these views using the icons to the left above the media.' ) . '</p>' . 58 '<p>' . __( 'To delete media items, click the Bulk Select button at the top of the screen. Select any items you wish to delete, then click the Delete Selected button. Clicking the Cancel Selection button takes you back to viewing your media.' ) . '</p>', 59 ) 60 ); 61 62 get_current_screen()->add_help_tab( 63 array( 64 'id' => 'attachment-details', 65 'title' => __( 'Attachment Details' ), 66 'content' => 67 '<p>' . __( 'Clicking an item will display an Attachment Details dialog, which allows you to preview media and make quick edits. Any changes you make to the attachment details will be automatically saved.' ) . '</p>' . 68 '<p>' . __( 'Use the arrow buttons at the top of the dialog, or the left and right arrow keys on your keyboard, to navigate between media items quickly.' ) . '</p>' . 69 '<p>' . __( 'You can also delete individual items and access the extended edit screen from the details dialog.' ) . '</p>', 70 ) 71 ); 72 73 get_current_screen()->set_help_sidebar( 74 '<p><strong>' . __( 'For more information:' ) . '</strong></p>' . 75 '<p>' . __( '<a href="https://wordpress.org/support/article/media-library-screen/">Documentation on Media Library</a>' ) . '</p>' . 76 '<p>' . __( '<a href="https://wordpress.org/support/">Support</a>' ) . '</p>' 77 ); 78 79 // Used in the HTML title tag. 80 $title = __( 'Media Library' ); 81 $parent_file = 'upload.php'; 82 83 require_once ABSPATH . 'wp-admin/admin-header.php'; 84 ?> 85 <div class="wrap" id="wp-media-grid" data-search="<?php _admin_search_query(); ?>"> 86 <h1 class="wp-heading-inline"><?php echo esc_html( $title ); ?></h1> 87 88 <?php 89 if ( current_user_can( 'upload_files' ) ) { 90 ?> 91 <a href="<?php echo esc_url( admin_url( 'media-new.php' ) ); ?>" class="page-title-action aria-button-if-js"><?php echo esc_html_x( 'Add New', 'file' ); ?></a> 92 <?php 93 } 94 ?> 95 96 <hr class="wp-header-end"> 97 98 <div class="error hide-if-js"> 99 <p> 100 <?php 101 printf( 102 /* translators: %s: List view URL. */ 103 __( 'The grid view for the Media Library requires JavaScript. <a href="%s">Switch to the list view</a>.' ), 104 'upload.php?mode=list' 105 ); 106 ?> 107 </p> 108 </div> 109 </div> 110 <?php 111 require_once ABSPATH . 'wp-admin/admin-footer.php'; 112 exit; 113 } 114 115 $wp_list_table = _get_list_table( 'WP_Media_List_Table' ); 116 $pagenum = $wp_list_table->get_pagenum(); 117 118 // Handle bulk actions. 119 $doaction = $wp_list_table->current_action(); 120 121 if ( $doaction ) { 122 check_admin_referer( 'bulk-media' ); 123 124 $post_ids = array(); 125 126 if ( 'delete_all' === $doaction ) { 127 $post_ids = $wpdb->get_col( "SELECT ID FROM $wpdb->posts WHERE post_type='attachment' AND post_status = 'trash'" ); 128 $doaction = 'delete'; 129 } elseif ( isset( $_REQUEST['media'] ) ) { 130 $post_ids = $_REQUEST['media']; 131 } elseif ( isset( $_REQUEST['ids'] ) ) { 132 $post_ids = explode( ',', $_REQUEST['ids'] ); 133 } 134 135 $location = 'upload.php'; 136 $referer = wp_get_referer(); 137 if ( $referer ) { 138 if ( false !== strpos( $referer, 'upload.php' ) ) { 139 $location = remove_query_arg( array( 'trashed', 'untrashed', 'deleted', 'message', 'ids', 'posted' ), $referer ); 140 } 141 } 142 143 switch ( $doaction ) { 144 case 'detach': 145 wp_media_attach_action( $_REQUEST['parent_post_id'], 'detach' ); 146 break; 147 148 case 'attach': 149 wp_media_attach_action( $_REQUEST['found_post_id'] ); 150 break; 151 152 case 'trash': 153 if ( empty( $post_ids ) ) { 154 break; 155 } 156 foreach ( (array) $post_ids as $post_id ) { 157 if ( ! current_user_can( 'delete_post', $post_id ) ) { 158 wp_die( __( 'Sorry, you are not allowed to move this item to the Trash.' ) ); 159 } 160 161 if ( ! wp_trash_post( $post_id ) ) { 162 wp_die( __( 'Error in moving the item to Trash.' ) ); 163 } 164 } 165 $location = add_query_arg( 166 array( 167 'trashed' => count( $post_ids ), 168 'ids' => implode( ',', $post_ids ), 169 ), 170 $location 171 ); 172 break; 173 case 'untrash': 174 if ( empty( $post_ids ) ) { 175 break; 176 } 177 foreach ( (array) $post_ids as $post_id ) { 178 if ( ! current_user_can( 'delete_post', $post_id ) ) { 179 wp_die( __( 'Sorry, you are not allowed to restore this item from the Trash.' ) ); 180 } 181 182 if ( ! wp_untrash_post( $post_id ) ) { 183 wp_die( __( 'Error in restoring the item from Trash.' ) ); 184 } 185 } 186 $location = add_query_arg( 'untrashed', count( $post_ids ), $location ); 187 break; 188 case 'delete': 189 if ( empty( $post_ids ) ) { 190 break; 191 } 192 foreach ( (array) $post_ids as $post_id_del ) { 193 if ( ! current_user_can( 'delete_post', $post_id_del ) ) { 194 wp_die( __( 'Sorry, you are not allowed to delete this item.' ) ); 195 } 196 197 if ( ! wp_delete_attachment( $post_id_del ) ) { 198 wp_die( __( 'Error in deleting the attachment.' ) ); 199 } 200 } 201 $location = add_query_arg( 'deleted', count( $post_ids ), $location ); 202 break; 203 default: 204 $screen = get_current_screen()->id; 205 206 /** This action is documented in wp-admin/edit.php */ 207 $location = apply_filters( "handle_bulk_actions-{$screen}", $location, $doaction, $post_ids ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores 208 } 209 210 wp_redirect( $location ); 211 exit; 212 } elseif ( ! empty( $_GET['_wp_http_referer'] ) ) { 213 wp_redirect( remove_query_arg( array( '_wp_http_referer', '_wpnonce' ), wp_unslash( $_SERVER['REQUEST_URI'] ) ) ); 214 exit; 215 } 216 217 $wp_list_table->prepare_items(); 218 219 // Used in the HTML title tag. 220 $title = __( 'Media Library' ); 221 $parent_file = 'upload.php'; 222 223 wp_enqueue_script( 'media' ); 224 225 add_screen_option( 'per_page' ); 226 227 get_current_screen()->add_help_tab( 228 array( 229 'id' => 'overview', 230 'title' => __( 'Overview' ), 231 'content' => 232 '<p>' . __( 'All the files you’ve uploaded are listed in the Media Library, with the most recent uploads listed first. You can use the Screen Options tab to customize the display of this screen.' ) . '</p>' . 233 '<p>' . __( 'You can narrow the list by file type/status or by date using the dropdown menus above the media table.' ) . '</p>' . 234 '<p>' . __( 'You can view your media in a simple visual grid or a list with columns. Switch between these views using the icons to the left above the media.' ) . '</p>', 235 ) 236 ); 237 get_current_screen()->add_help_tab( 238 array( 239 'id' => 'actions-links', 240 'title' => __( 'Available Actions' ), 241 'content' => 242 '<p>' . __( 'Hovering over a row reveals action links: Edit, Delete Permanently, and View. Clicking Edit or on the media file’s name displays a simple screen to edit that individual file’s metadata. Clicking Delete Permanently will delete the file from the media library (as well as from any posts to which it is currently attached). View will take you to the display page for that file.' ) . '</p>', 243 ) 244 ); 245 get_current_screen()->add_help_tab( 246 array( 247 'id' => 'attaching-files', 248 'title' => __( 'Attaching Files' ), 249 'content' => 250 '<p>' . __( 'If a media file has not been attached to any content, you will see that in the Uploaded To column, and can click on Attach to launch a small popup that will allow you to search for existing content and attach the file.' ) . '</p>', 251 ) 252 ); 253 254 get_current_screen()->set_help_sidebar( 255 '<p><strong>' . __( 'For more information:' ) . '</strong></p>' . 256 '<p>' . __( '<a href="https://wordpress.org/support/article/media-library-screen/">Documentation on Media Library</a>' ) . '</p>' . 257 '<p>' . __( '<a href="https://wordpress.org/support/">Support</a>' ) . '</p>' 258 ); 259 260 get_current_screen()->set_screen_reader_content( 261 array( 262 'heading_views' => __( 'Filter media items list' ), 263 'heading_pagination' => __( 'Media items list navigation' ), 264 'heading_list' => __( 'Media items list' ), 265 ) 266 ); 267 268 require_once ABSPATH . 'wp-admin/admin-header.php'; 269 ?> 270 271 <div class="wrap"> 272 <h1 class="wp-heading-inline"><?php echo esc_html( $title ); ?></h1> 273 274 <?php 275 if ( current_user_can( 'upload_files' ) ) { 276 ?> 277 <a href="<?php echo esc_url( admin_url( 'media-new.php' ) ); ?>" class="page-title-action"><?php echo esc_html_x( 'Add New', 'file' ); ?></a> 278 <?php 279 } 280 281 if ( isset( $_REQUEST['s'] ) && strlen( $_REQUEST['s'] ) ) { 282 echo '<span class="subtitle">'; 283 printf( 284 /* translators: %s: Search query. */ 285 __( 'Search results for: %s' ), 286 '<strong>' . get_search_query() . '</strong>' 287 ); 288 echo '</span>'; 289 } 290 ?> 291 292 <hr class="wp-header-end"> 293 294 <?php 295 $message = ''; 296 if ( ! empty( $_GET['posted'] ) ) { 297 $message = __( 'Media file updated.' ); 298 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'posted' ), $_SERVER['REQUEST_URI'] ); 299 } 300 301 if ( ! empty( $_GET['attached'] ) && absint( $_GET['attached'] ) ) { 302 $attached = absint( $_GET['attached'] ); 303 if ( 1 === $attached ) { 304 $message = __( 'Media file attached.' ); 305 } else { 306 /* translators: %s: Number of media files. */ 307 $message = _n( '%s media file attached.', '%s media files attached.', $attached ); 308 } 309 $message = sprintf( $message, number_format_i18n( $attached ) ); 310 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'detach', 'attached' ), $_SERVER['REQUEST_URI'] ); 311 } 312 313 if ( ! empty( $_GET['detach'] ) && absint( $_GET['detach'] ) ) { 314 $detached = absint( $_GET['detach'] ); 315 if ( 1 === $detached ) { 316 $message = __( 'Media file detached.' ); 317 } else { 318 /* translators: %s: Number of media files. */ 319 $message = _n( '%s media file detached.', '%s media files detached.', $detached ); 320 } 321 $message = sprintf( $message, number_format_i18n( $detached ) ); 322 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'detach', 'attached' ), $_SERVER['REQUEST_URI'] ); 323 } 324 325 if ( ! empty( $_GET['deleted'] ) && absint( $_GET['deleted'] ) ) { 326 $deleted = absint( $_GET['deleted'] ); 327 if ( 1 === $deleted ) { 328 $message = __( 'Media file permanently deleted.' ); 329 } else { 330 /* translators: %s: Number of media files. */ 331 $message = _n( '%s media file permanently deleted.', '%s media files permanently deleted.', $deleted ); 332 } 333 $message = sprintf( $message, number_format_i18n( $deleted ) ); 334 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'deleted' ), $_SERVER['REQUEST_URI'] ); 335 } 336 337 if ( ! empty( $_GET['trashed'] ) && absint( $_GET['trashed'] ) ) { 338 $trashed = absint( $_GET['trashed'] ); 339 if ( 1 === $trashed ) { 340 $message = __( 'Media file moved to the Trash.' ); 341 } else { 342 /* translators: %s: Number of media files. */ 343 $message = _n( '%s media file moved to the Trash.', '%s media files moved to the Trash.', $trashed ); 344 } 345 $message = sprintf( $message, number_format_i18n( $trashed ) ); 346 $message .= ' <a href="' . esc_url( wp_nonce_url( 'upload.php?doaction=undo&action=untrash&ids=' . ( isset( $_GET['ids'] ) ? $_GET['ids'] : '' ), 'bulk-media' ) ) . '">' . __( 'Undo' ) . '</a>'; 347 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'trashed' ), $_SERVER['REQUEST_URI'] ); 348 } 349 350 if ( ! empty( $_GET['untrashed'] ) && absint( $_GET['untrashed'] ) ) { 351 $untrashed = absint( $_GET['untrashed'] ); 352 if ( 1 === $untrashed ) { 353 $message = __( 'Media file restored from the Trash.' ); 354 } else { 355 /* translators: %s: Number of media files. */ 356 $message = _n( '%s media file restored from the Trash.', '%s media files restored from the Trash.', $untrashed ); 357 } 358 $message = sprintf( $message, number_format_i18n( $untrashed ) ); 359 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'untrashed' ), $_SERVER['REQUEST_URI'] ); 360 } 361 362 $messages[1] = __( 'Media file updated.' ); 363 $messages[2] = __( 'Media file permanently deleted.' ); 364 $messages[3] = __( 'Error saving media file.' ); 365 $messages[4] = __( 'Media file moved to the Trash.' ) . ' <a href="' . esc_url( wp_nonce_url( 'upload.php?doaction=undo&action=untrash&ids=' . ( isset( $_GET['ids'] ) ? $_GET['ids'] : '' ), 'bulk-media' ) ) . '">' . __( 'Undo' ) . '</a>'; 366 $messages[5] = __( 'Media file restored from the Trash.' ); 367 368 if ( ! empty( $_GET['message'] ) && isset( $messages[ $_GET['message'] ] ) ) { 369 $message = $messages[ $_GET['message'] ]; 370 $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'message' ), $_SERVER['REQUEST_URI'] ); 371 } 372 373 if ( ! empty( $message ) ) { 374 ?> 375 <div id="message" class="updated notice is-dismissible"><p><?php echo $message; ?></p></div> 376 <?php } ?> 377 378 <form id="posts-filter" method="get"> 379 380 <?php $wp_list_table->views(); ?> 381 382 <?php $wp_list_table->display(); ?> 383 384 <div id="ajax-response"></div> 385 <?php find_posts_div(); ?> 386 </form> 387 </div> 388 389 <?php 390 require_once ABSPATH . 'wp-admin/admin-footer.php';
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Wed Jan 22 01:00:02 2025 | Cross-referenced by PHPXref 0.7.1 |