2004-04-28 21:49:27 +02:00
< ? php
2008-08-16 09:27:34 +02:00
/**
* Edit Posts Administration Panel .
*
* @ package WordPress
* @ subpackage Administration
*/
/** WordPress Administration Bootstrap */
2004-10-19 05:03:06 +02:00
require_once ( 'admin.php' );
2004-04-24 06:47:27 +02:00
2008-11-20 05:51:47 +01:00
// Back-compat for viewing comments of an entry
if ( $_redirect = intval ( max ( @ $_GET [ 'p' ], @ $_GET [ 'attachment_id' ], @ $_GET [ 'page_id' ] ) ) ) {
wp_redirect ( admin_url ( 'edit-comments.php?p=' . $_redirect ) );
exit ;
} else {
unset ( $_redirect );
}
2008-08-20 06:06:36 +02:00
// Handle bulk actions
2008-09-29 11:26:21 +02:00
if ( isset ( $_GET [ 'action' ]) && ( - 1 != $_GET [ 'action' ] || - 1 != $_GET [ 'action2' ] ) ) {
$doaction = ( - 1 != $_GET [ 'action' ] ) ? $_GET [ 'action' ] : $_GET [ 'action2' ];
switch ( $doaction ) {
2008-08-20 06:06:36 +02:00
case 'delete' :
2008-11-11 12:34:08 +01:00
if ( isset ( $_GET [ 'post' ]) && ! isset ( $_GET [ 'bulk_edit' ]) && ( isset ( $_GET [ 'doaction' ]) || isset ( $_GET [ 'doaction2' ])) ) {
2008-08-20 06:06:36 +02:00
check_admin_referer ( 'bulk-posts' );
2008-12-01 19:02:16 +01:00
$deleted = 0 ;
2008-08-20 06:06:36 +02:00
foreach ( ( array ) $_GET [ 'post' ] 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.' ) );
if ( $post_del -> post_type == 'attachment' ) {
if ( ! wp_delete_attachment ( $post_id_del ) )
wp_die ( __ ( 'Error in deleting...' ) );
} else {
if ( ! wp_delete_post ( $post_id_del ) )
wp_die ( __ ( 'Error in deleting...' ) );
}
2008-12-01 19:02:16 +01:00
$deleted ++ ;
2008-08-20 06:06:36 +02:00
}
}
break ;
case 'edit' :
2008-11-11 12:34:08 +01:00
if ( isset ( $_GET [ 'post' ]) && isset ( $_GET [ 'bulk_edit' ]) ) {
2008-09-25 15:42:34 +02:00
check_admin_referer ( 'bulk-posts' );
2008-09-29 11:26:21 +02:00
2008-09-30 12:30:56 +02:00
if ( - 1 == $_GET [ '_status' ] ) {
$_GET [ 'post_status' ] = null ;
unset ( $_GET [ '_status' ], $_GET [ 'post_status' ]);
} else {
$_GET [ 'post_status' ] = $_GET [ '_status' ];
}
2008-09-29 11:26:21 +02:00
2008-09-25 15:42:34 +02:00
$done = bulk_edit_posts ( $_GET );
}
2008-08-20 06:06:36 +02:00
break ;
2008-02-13 21:53:18 +01:00
}
2008-09-25 15:42:34 +02:00
2008-02-13 21:53:18 +01:00
$sendback = wp_get_referer ();
2008-09-29 11:26:21 +02:00
if ( strpos ( $sendback , 'post.php' ) !== false ) $sendback = admin_url ( 'post-new.php' );
elseif ( strpos ( $sendback , 'attachments.php' ) !== false ) $sendback = admin_url ( 'attachments.php' );
2008-09-25 15:42:34 +02:00
if ( isset ( $done ) ) {
2008-09-30 12:30:56 +02:00
$done [ 'updated' ] = count ( $done [ 'updated' ] );
$done [ 'skipped' ] = count ( $done [ 'skipped' ] );
$done [ 'locked' ] = count ( $done [ 'locked' ] );
2008-09-25 15:42:34 +02:00
$sendback = add_query_arg ( $done , $sendback );
}
2008-12-01 19:02:16 +01:00
if ( isset ( $deleted ) )
$sendback = add_query_arg ( 'deleted' , $deleted , $sendback );
2008-02-13 21:53:18 +01:00
wp_redirect ( $sendback );
exit ();
2008-09-29 11:26:21 +02:00
} elseif ( isset ( $_GET [ '_wp_http_referer' ]) && ! empty ( $_GET [ '_wp_http_referer' ]) ) {
wp_redirect ( remove_query_arg ( array ( '_wp_http_referer' , '_wpnonce' ), stripslashes ( $_SERVER [ 'REQUEST_URI' ]) ) );
2008-03-02 21:17:30 +01:00
exit ;
2008-02-13 21:53:18 +01:00
}
2008-09-27 00:27:48 +02:00
if ( empty ( $title ) )
2008-10-17 23:22:11 +02:00
$title = __ ( 'Edit Posts' );
2006-11-18 08:31:29 +01:00
$parent_file = 'edit.php' ;
2008-10-05 06:43:52 +02:00
wp_enqueue_script ( 'inline-edit-post' );
2003-10-26 21:34:24 +01:00
2007-10-10 00:49:42 +02:00
list ( $post_stati , $avail_post_stati ) = wp_edit_posts_query ();
2008-02-08 02:40:14 +01:00
2008-03-11 21:10:39 +01:00
require_once ( 'admin-header.php' );
2008-02-08 02:40:14 +01:00
if ( ! isset ( $_GET [ 'paged' ] ) )
$_GET [ 'paged' ] = 1 ;
2008-02-13 21:53:18 +01:00
2008-08-20 06:06:36 +02:00
if ( empty ( $_GET [ 'mode' ]) )
$mode = 'list' ;
else
2008-09-28 06:11:27 +02:00
$mode = attribute_escape ( $_GET [ 'mode' ]); ?>
2005-11-11 00:36:50 +01:00
2008-11-05 21:30:26 +01:00
< div class = " wrap " >
2008-11-26 14:51:25 +01:00
< ? php screen_icon (); ?>
2008-12-04 13:01:02 +01:00
< h2 >< ? php echo wp_specialchars ( $title );
if ( isset ( $_GET [ 's' ]) && $_GET [ 's' ] )
printf ( '<span class="subtitle">' . __ ( 'Search results for “%s”' ) . '</span>' , wp_specialchars ( get_search_query () ) ); ?>
</ h2 >
2008-11-05 21:30:26 +01:00
2008-09-28 06:11:27 +02:00
< ? php
2008-09-25 23:54:14 +02:00
if ( isset ( $_GET [ 'posted' ]) && $_GET [ 'posted' ] ) : $_GET [ 'posted' ] = ( int ) $_GET [ 'posted' ]; ?>
2008-09-25 15:42:34 +02:00
< 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="<?php echo get_edit_post_link( $_GET['posted'] ); ?>"><?php _e('Edit post'); ?></a></p></div>
< ? php $_SERVER [ 'REQUEST_URI' ] = remove_query_arg ( array ( 'posted' ), $_SERVER [ 'REQUEST_URI' ]);
endif ; ?>
2008-12-01 19:02:16 +01:00
< ? php if ( isset ( $_GET [ 'locked' ]) || isset ( $_GET [ 'skipped' ]) || isset ( $_GET [ 'updated' ]) || isset ( $_GET [ 'deleted' ]) ) { ?>
2008-09-25 15:42:34 +02:00
< div id = " message " class = " updated fade " >< p >
2008-12-01 19:02:16 +01:00
< ? php if ( isset ( $_GET [ 'updated' ]) && ( int ) $_GET [ 'updated' ] ) {
2008-11-10 18:47:41 +01:00
printf ( __ngettext ( '%s post updated.' , '%s posts updated.' , $_GET [ 'updated' ] ), number_format_i18n ( $_GET [ 'updated' ] ) );
2008-09-30 12:30:56 +02:00
unset ( $_GET [ 'updated' ]);
}
2008-09-29 11:26:21 +02:00
2008-12-01 19:02:16 +01:00
if ( isset ( $_GET [ 'skipped' ]) && ( int ) $_GET [ 'skipped' ] )
2008-09-30 12:30:56 +02:00
unset ( $_GET [ 'skipped' ]);
2008-12-01 19:02:16 +01:00
if ( isset ( $_GET [ 'locked' ]) && ( int ) $_GET [ 'locked' ] ) {
2008-11-10 18:47:41 +01:00
printf ( __ngettext ( '%s post not updated, somebody is editing it.' , '%s posts not updated, somebody is editing them.' , $_GET [ 'locked' ] ), number_format_i18n ( $_GET [ 'locked' ] ) );
2008-09-30 12:30:56 +02:00
unset ( $_GET [ 'locked' ]);
2008-12-01 19:02:16 +01:00
}
if ( isset ( $_GET [ 'deleted' ]) && ( int ) $_GET [ 'deleted' ] ) {
printf ( __ngettext ( 'Post deleted.' , '%s posts deleted.' , $_GET [ 'deleted' ] ), number_format_i18n ( $_GET [ 'deleted' ] ) );
unset ( $_GET [ 'deleted' ]);
}
$_SERVER [ 'REQUEST_URI' ] = remove_query_arg ( array ( 'locked' , 'skipped' , 'updated' , 'deleted' ), $_SERVER [ 'REQUEST_URI' ] );
2008-11-11 12:34:08 +01:00
?>
2008-09-25 15:42:34 +02:00
</ p ></ div >
< ? php } ?>
2008-10-24 21:56:44 +02:00
< form id = " posts-filter " action = " " method = " get " >
2008-11-26 01:36:25 +01:00
2008-02-08 02:40:14 +01:00
< ul class = " subsubsub " >
2008-02-05 21:30:24 +01:00
< ? php
2008-09-26 23:53:26 +02:00
if ( empty ( $locked_post_status ) ) :
2008-02-05 21:30:24 +01:00
$status_links = array ();
2008-03-23 08:10:17 +01:00
$num_posts = wp_count_posts ( 'post' , 'readable' );
2008-11-06 22:56:29 +01:00
$total_posts = array_sum ( ( array ) $num_posts );
2008-03-23 08:10:17 +01:00
$class = empty ( $_GET [ 'post_status' ] ) ? ' class="current"' : '' ;
2008-11-06 22:56:29 +01:00
$status_links [] = " <li><a href='edit.php' $class > " . sprintf ( __ngettext ( 'All <span class="count">(%s)</span>' , 'All <span class="count">(%s)</span>' , $total_posts ), number_format_i18n ( $total_posts ) ) . '</a>' ;
2008-02-05 21:30:24 +01:00
foreach ( $post_stati as $status => $label ) {
$class = '' ;
2008-03-23 08:10:17 +01:00
if ( ! in_array ( $status , $avail_post_stati ) )
2008-02-05 21:30:24 +01:00
continue ;
2008-03-23 08:10:17 +01:00
if ( empty ( $num_posts -> $status ) )
2008-02-29 22:49:49 +01:00
continue ;
2008-08-14 19:00:37 +02:00
if ( isset ( $_GET [ 'post_status' ]) && $status == $_GET [ 'post_status' ] )
2008-02-05 21:30:24 +01:00
$class = ' class="current"' ;
2008-11-06 22:56:29 +01:00
$status_links [] = " <li><a href='edit.php?post_status= $status ' $class > " . sprintf ( __ngettext ( $label [ 2 ][ 0 ], $label [ 2 ][ 1 ], $num_posts -> $status ), number_format_i18n ( $num_posts -> $status ) ) . '</a>' ;
2008-02-05 21:30:24 +01:00
}
2008-11-06 22:56:29 +01:00
echo implode ( " |</li> \n " , $status_links ) . '</li>' ;
2008-03-23 08:10:17 +01:00
unset ( $status_links );
2008-09-26 23:53:26 +02:00
endif ;
2008-02-05 21:30:24 +01:00
?>
</ ul >
2008-10-24 20:25:46 +02:00
< p class = " search-box " >
< label class = " hidden " for = " post-search-input " >< ? php _e ( 'Search Posts' ); ?> :</label>
< input type = " text " class = " search-input " id = " post-search-input " name = " s " value = " <?php the_search_query(); ?> " />
2008-11-08 00:12:39 +01:00
< input type = " submit " value = " <?php _e( 'Search Posts' ); ?> " class = " button " />
2008-10-24 20:25:46 +02:00
</ p >
< ? php if ( isset ( $_GET [ 'post_status' ] ) ) : ?>
< input type = " hidden " name = " post_status " value = " <?php echo attribute_escape( $_GET['post_status'] ) ?> " />
< ? php endif ; ?>
< input type = " hidden " name = " mode " value = " <?php echo $mode ; ?> " />
2008-11-26 01:36:25 +01:00
< ? php if ( have_posts () ) { ?>
2008-10-24 20:25:46 +02:00
< div class = " tablenav " >
2007-05-29 06:28:10 +02:00
< ? php
2008-10-24 20:25:46 +02:00
$page_links = paginate_links ( array (
'base' => add_query_arg ( 'paged' , '%#%' ),
'format' => '' ,
2008-11-27 01:28:24 +01:00
'prev_text' => __ ( '«' ),
'next_text' => __ ( '»' ),
2008-10-24 20:25:46 +02:00
'total' => $wp_query -> max_num_pages ,
'current' => $_GET [ 'paged' ]
));
?>
< div class = " alignleft actions " >
< select name = " action " >
< option value = " -1 " selected = " selected " >< ? php _e ( 'Actions' ); ?> </option>
< option value = " edit " >< ? php _e ( 'Edit' ); ?> </option>
< option value = " delete " >< ? php _e ( 'Delete' ); ?> </option>
</ select >
< input type = " submit " value = " <?php _e('Apply'); ?> " name = " doaction " id = " doaction " class = " button-secondary action " />
< ? php wp_nonce_field ( 'bulk-posts' ); ?>
< ? php // view filters
2008-03-11 21:10:39 +01:00
if ( ! is_singular () ) {
2007-05-28 20:34:06 +02:00
$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 " ;
2006-02-12 08:53:23 +01:00
2007-05-28 20:34:06 +02:00
$arc_result = $wpdb -> get_results ( $arc_query );
2005-02-11 18:58:11 +01:00
2007-05-28 20:34:06 +02:00
$month_count = count ( $arc_result );
2005-02-11 18:58:11 +01:00
2008-08-14 19:00:37 +02:00
if ( $month_count && ! ( 1 == $month_count && 0 == $arc_result [ 0 ] -> mmonth ) ) {
$m = isset ( $_GET [ 'm' ]) ? ( int ) $_GET [ 'm' ] : 0 ;
?>
2008-02-08 02:40:14 +01:00
< select name = 'm' >
2008-08-14 19:00:37 +02:00
< option < ? php selected ( $m , 0 ); ?> value='0'><?php _e('Show all dates'); ?></option>
2008-02-08 02:40:14 +01:00
< ? php
foreach ( $arc_result as $arc_row ) {
if ( $arc_row -> yyear == 0 )
continue ;
$arc_row -> mmonth = zeroise ( $arc_row -> mmonth , 2 );
2008-03-02 21:17:30 +01:00
2008-08-14 19:00:37 +02:00
if ( $arc_row -> yyear . $arc_row -> mmonth == $m )
2008-02-08 02:40:14 +01:00
$default = ' selected="selected"' ;
else
$default = '' ;
2008-03-02 21:17:30 +01:00
2008-02-08 02:40:14 +01: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 " ;
}
?>
</ select >
< ? php } ?>
2005-02-11 18:58:11 +01:00
2008-04-08 03:53:53 +02:00
< ? php
$dropdown_options = array ( 'show_option_all' => __ ( 'View all categories' ), 'hide_empty' => 0 , 'hierarchical' => 1 ,
'show_count' => 0 , 'orderby' => 'name' , 'selected' => $cat );
wp_dropdown_categories ( $dropdown_options );
do_action ( 'restrict_manage_posts' );
?>
2008-02-21 01:27:23 +01:00
< input type = " submit " id = " post-query-submit " value = " <?php _e('Filter'); ?> " class = " button-secondary " />
2008-03-13 21:39:56 +01:00
2008-02-23 08:20:08 +01:00
< ? php } ?>
2008-02-08 02:40:14 +01:00
</ div >
2005-02-11 18:58:11 +01:00
2008-10-03 02:13:12 +02:00
< ? php if ( $page_links ) { ?>
2008-11-10 18:42:51 +01:00
< div class = " tablenav-pages " >< ? php $page_links_text = sprintf ( '<span class="displaying-num">' . __ ( 'Displaying %s–%s of %s' ) . '</span>%s' ,
2008-11-06 22:56:29 +01:00
number_format_i18n ( ( $_GET [ 'paged' ] - 1 ) * $wp_query -> query_vars [ 'posts_per_page' ] + 1 ),
number_format_i18n ( min ( $_GET [ 'paged' ] * $wp_query -> query_vars [ 'posts_per_page' ], $wp_query -> found_posts ) ),
number_format_i18n ( $wp_query -> found_posts ),
$page_links
); echo $page_links_text ; ?> </div>
2008-10-03 02:13:12 +02:00
< ? php } ?>
< div class = " view-switch " >
2008-12-01 22:32:51 +01:00
< a href = " <?php echo clean_url(add_query_arg('mode', 'list', $_SERVER['REQUEST_URI'] )) ?> " >< img < ? php if ( 'list' == $mode ) echo 'class="current"' ; ?> id="view-switch-list" src="../wp-includes/images/blank.gif" width="20" height="20" title="<?php _e('List View') ?>" alt="<?php _e('List View') ?>" /></a>
< a href = " <?php echo clean_url(add_query_arg('mode', 'excerpt', $_SERVER['REQUEST_URI'] )) ?> " >< img < ? php if ( 'excerpt' == $mode ) echo 'class="current"' ; ?> id="view-switch-excerpt" src="../wp-includes/images/blank.gif" width="20" height="20" title="<?php _e('Excerpt View') ?>" alt="<?php _e('Excerpt View') ?>" /></a>
2008-02-08 02:40:14 +01:00
</ div >
2007-05-28 20:34:06 +02:00
2008-10-03 02:13:12 +02:00
< div class = " clear " ></ div >
</ div >
< div class = " clear " ></ div >
2005-02-11 18:58:11 +01:00
2007-05-29 06:28:10 +02:00
< ? php include ( 'edit-post-rows.php' ); ?>
2005-08-31 04:39:17 +02:00
2008-02-08 02:40:14 +01:00
< div class = " tablenav " >
< ? php
if ( $page_links )
2008-11-06 22:56:29 +01:00
echo " <div class='tablenav-pages'> $page_links_text </div> " ;
2008-02-08 02:40:14 +01:00
?>
2008-03-23 07:41:43 +01:00
2008-10-24 20:25:46 +02:00
< div class = " alignleft actions " >
2008-09-25 23:12:33 +02:00
< select name = " action2 " >
< option value = " -1 " selected = " selected " >< ? php _e ( 'Actions' ); ?> </option>
< option value = " edit " >< ? php _e ( 'Edit' ); ?> </option>
< option value = " delete " >< ? php _e ( 'Delete' ); ?> </option>
</ select >
< input type = " submit " value = " <?php _e('Apply'); ?> " name = " doaction2 " id = " doaction2 " class = " button-secondary action " />
2008-02-28 07:50:25 +01:00
< br class = " clear " />
2005-03-28 04:34:16 +02:00
</ div >
2008-09-25 23:12:33 +02:00
< br class = " clear " />
</ div >
2008-11-26 01:36:25 +01:00
< ? php } else { // have_posts() ?>
< div class = " clear " ></ div >
< p >< ? php _e ( 'No posts found' ) ?> </p>
< ? php } ?>
2008-09-25 23:12:33 +02:00
</ form >
< ? php inline_edit_row ( 'post' ); ?>
< div id = " ajax-response " ></ div >
2005-03-28 04:34:16 +02:00
2008-03-23 07:41:43 +01:00
< br class = " clear " />
2006-11-19 08:56:05 +01:00
</ div >
2007-05-28 20:34:06 +02:00
2008-11-07 04:13:50 +01:00
< script type = " text/javascript " >
/* <![CDATA[ */
( function ( $ ){
$ ( document ) . ready ( function (){
$ ( '#doaction, #doaction2' ) . click ( function (){
if ( $ ( 'select[name^="action"]' ) . val () == 'delete' ) {
2008-11-10 18:42:51 +01:00
var m = '<?php echo js_escape(__("You are about to delete the selected posts.\n ' Cancel ' to stop, ' OK ' to delete.")); ?>' ;
2008-11-07 04:13:50 +01:00
return showNotice . warn ( m );
}
});
});
})( jQuery );
2008-11-17 20:16:26 +01:00
columns . init ( 'edit' );
2008-11-07 04:13:50 +01:00
/* ]]> */
</ script >
2007-05-28 20:34:06 +02:00
< ? php include ( 'admin-footer.php' ); ?>