2006-10-03 03:15:13 -04:00
< ? php
require_once ( 'admin.php' );
2008-03-02 15:17:30 -05:00
if ( ! current_user_can ( 'upload_files' ))
wp_die ( __ ( 'You do not have permission to upload files.' ));
2008-02-19 01:13:20 -05:00
// Handle bulk deletes
if ( isset ( $_GET [ 'deleteit' ]) && isset ( $_GET [ 'delete' ]) ) {
check_admin_referer ( 'bulk-media' );
foreach ( ( array ) $_GET [ 'delete' ] as $post_id_del ) {
$post_del = & get_post ( $post_id_del );
if ( ! current_user_can ( 'delete_post' , $post_id_del ) )
wp_die ( __ ( 'You are not allowed to delete this post.' ) );
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
if ( $post_del -> post_type == 'attachment' )
if ( ! wp_delete_attachment ( $post_id_del ) )
wp_die ( __ ( 'Error in deleting...' ) );
2006-10-03 03:15:13 -04:00
}
2008-02-19 01:13:20 -05:00
$sendback = wp_get_referer ();
if ( strpos ( $sendback , 'media.php' ) !== false ) $sendback = get_option ( 'siteurl' ) . '/wp-admin/media.php' ;
$sendback = preg_replace ( '|[^a-z0-9-~+_.?#=&;,/:]|i' , '' , $sendback );
wp_redirect ( $sendback );
exit ();
} elseif ( ! empty ( $_GET [ '_wp_http_referer' ]) ) {
wp_redirect ( remove_query_arg ( array ( '_wp_http_referer' , '_wpnonce' ), stripslashes ( $_SERVER [ 'REQUEST_URI' ])));
2008-03-02 15:17:30 -05:00
exit ;
2006-10-03 03:15:13 -04:00
}
2008-02-19 01:13:20 -05:00
$title = __ ( 'Media Library' );
$parent_file = 'edit.php' ;
wp_enqueue_script ( 'admin-forms' );
if ( 1 == $_GET [ 'c' ] )
wp_enqueue_script ( 'admin-comments' );
require_once ( 'admin-header.php' );
2008-02-27 03:31:10 -05:00
if ( isset ( $_GET [ 'paged' ]) && $start = ( intval ( $_GET [ 'paged' ]) - 1 ) * 15 )
add_filter ( 'post_limits' , $limit_filter = create_function ( '$a' , " return 'LIMIT $start , 15'; " ) );
2008-02-19 01:13:20 -05:00
list ( $post_mime_types , $avail_post_mime_types ) = wp_edit_attachments_query ();
$wp_query -> max_num_pages = ceil ( $wp_query -> found_posts / 15 ); // We grab 20 but only show 15 ( 5 more for ajax extra )
if ( ! isset ( $_GET [ 'paged' ] ) )
$_GET [ 'paged' ] = 1 ;
2008-02-11 02:53:10 -05:00
?>
2008-02-19 01:13:20 -05:00
< div class = " wrap " >
< form id = " posts-filter " action = " " method = " get " >
< h2 >< ? php
if ( is_single () ) {
printf ( __ ( 'Comments on %s' ), apply_filters ( " the_title " , $post -> post_title ));
} else {
$post_mime_type_label = _c ( 'Manage Media|manage media header' );
if ( isset ( $_GET [ 'post_mime_type' ]) && in_array ( $_GET [ 'post_mime_type' ], array_keys ( $post_mime_types ) ) )
$post_mime_type_label = $post_mime_types [ $_GET [ 'post_mime_type' ]][ 1 ];
if ( $post_listing_pageable && ! is_archive () && ! is_search () )
$h2_noun = is_paged () ? sprintf ( __ ( 'Previous %s' ), $post_mime_type_label ) : sprintf ( __ ( 'Latest %s' ), $post_mime_type_label );
else
$h2_noun = $post_mime_type_label ;
// Use $_GET instead of is_ since they can override each other
$h2_author = '' ;
$_GET [ 'author' ] = ( int ) $_GET [ 'author' ];
if ( $_GET [ 'author' ] != 0 ) {
if ( $_GET [ 'author' ] == '-' . $user_ID ) { // author exclusion
$h2_author = ' ' . __ ( 'by other authors' );
} else {
$author_user = get_userdata ( get_query_var ( 'author' ) );
$h2_author = ' ' . sprintf ( __ ( 'by %s' ), wp_specialchars ( $author_user -> display_name ));
}
}
$h2_search = isset ( $_GET [ 's' ]) && $_GET [ 's' ] ? ' ' . sprintf ( __ ( 'matching “%s”' ), wp_specialchars ( get_search_query () ) ) : '' ;
$h2_cat = isset ( $_GET [ 'cat' ]) && $_GET [ 'cat' ] ? ' ' . sprintf ( __ ( 'in “%s”' ), single_cat_title ( '' , false ) ) : '' ;
$h2_tag = isset ( $_GET [ 'tag' ]) && $_GET [ 'tag' ] ? ' ' . sprintf ( __ ( 'tagged with “%s”' ), single_tag_title ( '' , false ) ) : '' ;
$h2_month = isset ( $_GET [ 'm' ]) && $_GET [ 'm' ] ? ' ' . sprintf ( __ ( 'during %s' ), single_month_title ( ' ' , false ) ) : '' ;
printf ( _c ( '%1$s%2$s%3$s%4$s%5$s%6$s|You can reorder these: 1: Posts, 2: by {s}, 3: matching {s}, 4: in {s}, 5: tagged with {s}, 6: during {s}' ), $h2_noun , $h2_author , $h2_search , $h2_cat , $h2_tag , $h2_month );
}
?> </h2>
< ul class = " subsubsub " >
2006-10-04 13:19:10 -04:00
< ? php
2008-02-27 03:31:10 -05:00
$type_links = array ();
2008-02-19 01:13:20 -05:00
$_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 )
$num_posts [ $type ] += $_num_posts [ $real ];
2008-03-06 05:23:00 -05:00
$class = empty ( $_GET [ 'post_mime_type' ]) ? ' class="current"' : '' ;
$type_links [] = " <li><a href= \" upload.php \" $class > " . __ ( 'All Types' ) . " </a> " ;
2008-02-19 01:13:20 -05:00
foreach ( $post_mime_types as $mime_type => $label ) {
$class = '' ;
if ( ! wp_match_mime_types ( $mime_type , $avail_post_mime_types ) )
continue ;
if ( wp_match_mime_types ( $mime_type , $_GET [ 'post_mime_type' ]) )
$class = ' class="current"' ;
2008-02-27 03:31:10 -05:00
$type_links [] = " <li><a href= \" upload.php?post_mime_type= $mime_type\ " $class > " .
2008-02-19 01:13:20 -05:00
sprintf ( $label [ 2 ], $num_posts [ $mime_type ]) . '</a>' ;
}
2008-02-27 03:31:10 -05:00
echo implode ( ' | </li>' , $type_links ) . '</li>' ;
unset ( $type_links );
2007-01-09 04:05:54 -05:00
?>
2008-02-19 01:13:20 -05:00
</ ul >
< ? php
if ( isset ( $_GET [ 'posted' ]) && $_GET [ 'posted' ] ) : $_GET [ 'posted' ] = ( int ) $_GET [ 'posted' ]; ?>
< div id = " message " class = " updated fade " >< p >< strong >< ? php _e ( 'Your post has been saved.' ); ?> </strong> <a href="<?php echo get_permalink( $_GET['posted'] ); ?>"><?php _e('View post'); ?></a> | <a href="post.php?action=edit&post=<?php echo $_GET['posted']; ?>"><?php _e('Edit post'); ?></a></p></div>
2008-02-26 15:35:40 -05:00
< ? php $_SERVER [ 'REQUEST_URI' ] = remove_query_arg ( array ( 'posted' ), $_SERVER [ 'REQUEST_URI' ]);
2006-10-04 13:19:10 -04:00
endif ;
2008-02-19 01:13:20 -05:00
?>
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
< p id = " post-search " >
< input type = " text " id = " post-search-input " name = " s " value = " <?php the_search_query(); ?> " />
2008-02-19 15:33:59 -05:00
< input type = " submit " value = " <?php _e( 'Search Media' ); ?> " class = " button " />
2008-02-19 01:13:20 -05:00
</ p >
< ? php do_action ( 'restrict_manage_posts' ); ?>
2006-10-03 11:40:26 -04:00
2008-02-19 01:13:20 -05:00
< div class = " tablenav " >
< ? php
$page_links = paginate_links ( array (
'base' => add_query_arg ( 'paged' , '%#%' ),
'format' => '' ,
'total' => ceil ( $wp_query -> found_posts / 15 ),
'current' => $_GET [ 'paged' ]
));
if ( $page_links )
echo " <div class='tablenav-pages'> $page_links </div> " ;
?>
< div style = " float: left " >
2008-02-20 19:27:23 -05:00
< input type = " submit " value = " <?php _e('Delete'); ?> " name = " deleteit " class = " button-secondary " />
2008-02-20 12:05:42 -05:00
< ? php wp_nonce_field ( 'bulk-media' ); ?>
2008-02-19 01:13:20 -05:00
< ? php
$arc_query = " SELECT DISTINCT YEAR(post_date) AS yyear, MONTH(post_date) AS mmonth FROM $wpdb->posts WHERE post_type = 'post' ORDER BY post_date DESC " ;
$arc_result = $wpdb -> get_results ( $arc_query );
$month_count = count ( $arc_result );
if ( $month_count && ! ( 1 == $month_count && 0 == $arc_result [ 0 ] -> mmonth ) ) { ?>
< select name = 'm' >
< option < ? php selected ( @ $_GET [ 'm' ], 0 ); ?> value='0'><?php _e('Show all dates'); ?></option>
< ? php
foreach ( $arc_result as $arc_row ) {
if ( $arc_row -> yyear == 0 )
continue ;
$arc_row -> mmonth = zeroise ( $arc_row -> mmonth , 2 );
2008-03-02 15:17:30 -05:00
2008-02-19 01:13:20 -05:00
if ( $arc_row -> yyear . $arc_row -> mmonth == $_GET [ 'm' ] )
$default = ' selected="selected"' ;
else
$default = '' ;
2008-03-02 15:17:30 -05:00
2008-02-19 01:13:20 -05:00
echo " <option $default value=' $arc_row->yyear $arc_row->mmonth '> " ;
echo $wp_locale -> get_month ( $arc_row -> mmonth ) . " $arc_row->yyear " ;
echo " </option> \n " ;
2006-10-03 03:15:13 -04:00
}
2008-02-19 01:13:20 -05:00
?>
</ select >
< ? php } ?>
2008-03-03 15:52:04 -05:00
< input type = " submit " id = " post-query-submit " value = " <?php _e('Filter'); ?> " class = " button-secondary " />
2008-02-19 01:13:20 -05:00
</ div >
< br style = " clear:both; " />
</ div >
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
< br style = " clear:both; " />
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
< ? php include ( 'edit-attachment-rows.php' ); ?>
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
</ form >
2006-10-03 03:15:13 -04:00
2008-02-19 01:13:20 -05:00
< div id = " ajax-response " ></ div >
< div class = " tablenav " >
< ? php
if ( $page_links )
echo " <div class='tablenav-pages'> $page_links </div> " ;
?>
< br style = " clear:both; " />
</ div >
< ? php
if ( 1 == count ( $posts ) && isset ( $_GET [ 'p' ] ) ) {
$comments = $wpdb -> get_results ( " SELECT * FROM $wpdb->comments WHERE comment_post_ID = $id AND comment_approved != 'spam' ORDER BY comment_date " );
if ( $comments ) {
// Make sure comments, post, and post_author are cached
update_comment_cache ( $comments );
$post = get_post ( $id );
$authordata = get_userdata ( $post -> post_author );
?>
< h3 id = " comments " >< ? php _e ( 'Comments' ) ?> </h3>
< ol id = " the-comment-list " class = " list:comment commentlist " >
< ? php
$i = 0 ;
foreach ( $comments as $comment ) {
_wp_comment_list_item ( $comment -> comment_ID , ++ $i );
}
echo '</ol>' ;
} // end if comments
?>
< ? php } ?>
</ div >
2006-10-04 13:19:10 -04:00
2008-02-19 01:13:20 -05:00
< ? php include ( 'admin-footer.php' ); ?>