275 lines
8.9 KiB
PHP
275 lines
8.9 KiB
PHP
<?php
|
|
/**
|
|
* Edit Comments Administration Panel.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
/** WordPress Administration Bootstrap */
|
|
require_once('admin.php');
|
|
|
|
$title = __('Edit Comments');
|
|
wp_enqueue_script( 'admin-comments' );
|
|
wp_enqueue_script( 'admin-forms' );
|
|
wp_enqueue_script( 'jquery-table-hotkeys' );
|
|
|
|
if ( isset( $_POST['delete_all_spam'] ) ) {
|
|
check_admin_referer('bulk-spam-delete');
|
|
|
|
$deleted_spam = $wpdb->query( "DELETE FROM $wpdb->comments WHERE comment_approved = 'spam'" );
|
|
wp_redirect('edit-comments.php?deleted=' . (int) $deleted_spam);
|
|
}
|
|
|
|
if ( !empty( $_REQUEST['delete_comments'] ) && isset($_REQUEST['action']) ) {
|
|
check_admin_referer('bulk-comments');
|
|
|
|
$comments_deleted = $comments_approved = $comments_unapproved = $comments_spammed = 0;
|
|
foreach ($_REQUEST['delete_comments'] as $comment) : // Check the permissions on each
|
|
$comment = (int) $comment;
|
|
$post_id = (int) $wpdb->get_var( $wpdb->prepare( "SELECT comment_post_ID FROM $wpdb->comments WHERE comment_ID = %d", $comment) );
|
|
if ( !current_user_can('edit_post', $post_id) )
|
|
continue;
|
|
if ( $_REQUEST['action'] == 'markspam' ) {
|
|
wp_set_comment_status($comment, 'spam');
|
|
$comments_spammed++;
|
|
} elseif ( $_REQUEST['action'] == 'delete' ) {
|
|
wp_set_comment_status($comment, 'delete');
|
|
$comments_deleted++;
|
|
} elseif ( $_REQUEST['action'] == 'approve' ) {
|
|
wp_set_comment_status($comment, 'approve');
|
|
$comments_approved++;
|
|
} elseif ( $_REQUEST['action'] == 'unapprove' ) {
|
|
wp_set_comment_status($comment, 'hold');
|
|
$comments_unapproved++;
|
|
}
|
|
endforeach;
|
|
$redirect_to = basename( __FILE__ ) . '?deleted=' . $comments_deleted . '&approved=' . $comments_approved . '&spam=' . $comments_spammed . '&unapproved=' . $comments_unapproved;
|
|
if ( isset($_REQUEST['apage']) )
|
|
$redirect_to = add_query_arg( 'apage', absint($_REQUEST['apage']), $redirect_to );
|
|
if ( !empty($_REQUEST['mode']) )
|
|
$redirect_to = add_query_arg('mode', $_REQUEST['mode'], $redirect_to);
|
|
if ( !empty($_REQUEST['comment_status']) )
|
|
$redirect_to = add_query_arg('comment_status', $_REQUEST['comment_status'], $redirect_to);
|
|
if ( !empty($_REQUEST['s']) )
|
|
$redirect_to = add_query_arg('s', $_REQUEST['s'], $redirect_to);
|
|
wp_redirect( $redirect_to );
|
|
} elseif ( !empty($_GET['_wp_http_referer']) ) {
|
|
wp_redirect(remove_query_arg(array('_wp_http_referer', '_wpnonce'), stripslashes($_SERVER['REQUEST_URI'])));
|
|
exit;
|
|
}
|
|
|
|
require_once('admin-header.php');
|
|
|
|
$mode = ( ! isset($_GET['mode']) || empty($_GET['mode']) ) ? 'detail' : attribute_escape($_GET['mode']);
|
|
|
|
$comment_status = isset($_GET['comment_status']) ? attribute_escape($_GET['comment_status']) : '';
|
|
|
|
$post_id = isset($_GET['p']) ? (int) $_GET['p'] : 0;
|
|
|
|
$search_dirty = ( isset($_GET['s']) ) ? $_GET['s'] : '';
|
|
$search = attribute_escape( $search_dirty ); ?>
|
|
|
|
<div id="edit-settings">
|
|
<a href="#edit_settings" id="show-settings-link" class="hide-if-no-js show-settings"><?php _e('Page Options') ?></a>
|
|
<div id="edit-settings-wrap" class="hidden">
|
|
<a href="#edit_settings" id="hide-settings-link" class="show-settings"><?php _e('Hide Options') ?></a>
|
|
<h5><?php _e('Show on screen') ?></h5>
|
|
<form id="adv-settings" action="" method="get">
|
|
<div class="metabox-prefs">
|
|
<?php manage_columns_prefs('comment') ?>
|
|
<?php wp_nonce_field( 'hiddencolumns', 'hiddencolumnsnonce', false ); ?>
|
|
<br class="clear" />
|
|
</div></form>
|
|
</div></div>
|
|
|
|
<?php
|
|
if ( isset( $_GET['approved'] ) || isset( $_GET['deleted'] ) || isset( $_GET['spam'] ) ) {
|
|
$approved = isset( $_GET['approved'] ) ? (int) $_GET['approved'] : 0;
|
|
$deleted = isset( $_GET['deleted'] ) ? (int) $_GET['deleted'] : 0;
|
|
$spam = isset( $_GET['spam'] ) ? (int) $_GET['spam'] : 0;
|
|
|
|
if ( $approved > 0 || $deleted > 0 || $spam > 0 ) {
|
|
echo '<div id="moderated" class="updated fade"><p>';
|
|
|
|
if ( $approved > 0 ) {
|
|
printf( __ngettext( '%s comment approved', '%s comments approved', $approved ), $approved );
|
|
echo '<br />';
|
|
}
|
|
|
|
if ( $deleted > 0 ) {
|
|
printf( __ngettext( '%s comment deleted', '%s comments deleted', $deleted ), $deleted );
|
|
echo '<br />';
|
|
}
|
|
|
|
if ( $spam > 0 ) {
|
|
printf( __ngettext( '%s comment marked as spam', '%s comments marked as spam', $spam ), $spam );
|
|
echo '<br />';
|
|
}
|
|
|
|
echo '</p></div>';
|
|
}
|
|
}
|
|
?>
|
|
<div class="wrap">
|
|
|
|
<h2><?php _e('Manage Comments'); ?></h2>
|
|
|
|
<ul class="subsubsub">
|
|
<?php
|
|
$status_links = array();
|
|
$num_comments = wp_count_comments();
|
|
$stati = array(
|
|
'moderated' => sprintf(__ngettext('Awaiting Moderation (%s)', 'Awaiting Moderation (%s)', number_format_i18n($num_comments->moderated) ), "<span class='comment-count'>" . number_format_i18n($num_comments->moderated) . "</span>"),
|
|
'approved' => _c('Approved|plural'),
|
|
'spam' => sprintf(__ngettext('Spam (%s)', 'Spam (%s)', number_format_i18n($num_comments->spam) ), "<span class='spam-comment-count'>" . number_format_i18n($num_comments->spam) . "</span>")
|
|
);
|
|
$class = ( '' === $comment_status ) ? ' class="current"' : '';
|
|
$status_links[] = "<li><a href=\"edit-comments.php\"$class>".__('Show All Comments')."</a>";
|
|
foreach ( $stati as $status => $label ) {
|
|
$class = '';
|
|
|
|
if ( $status == $comment_status )
|
|
$class = ' class="current"';
|
|
|
|
$status_links[] = "<li class='$status'><a href=\"edit-comments.php?comment_status=$status\"$class>$label</a>";
|
|
}
|
|
|
|
$status_links = apply_filters( 'comment_status_links', $status_links );
|
|
|
|
echo implode(' | </li>', $status_links) . '</li>';
|
|
unset($status_links);
|
|
?>
|
|
</ul>
|
|
|
|
<?php
|
|
|
|
$comments_per_page = apply_filters('comments_per_page', 20, $comment_status);
|
|
|
|
if ( isset( $_GET['apage'] ) )
|
|
$page = abs( (int) $_GET['apage'] );
|
|
else
|
|
$page = 1;
|
|
|
|
$start = $offset = ( $page - 1 ) * $comments_per_page;
|
|
|
|
list($_comments, $total) = _wp_get_comment_list( $comment_status, $search_dirty, $start, $comments_per_page + 5, $post_id ); // Grab a few extra
|
|
|
|
$comments = array_slice($_comments, 0, $comments_per_page);
|
|
$extra_comments = array_slice($_comments, $comments_per_page);
|
|
|
|
$page_links = paginate_links( array(
|
|
'base' => add_query_arg( 'apage', '%#%' ),
|
|
'format' => '',
|
|
'total' => ceil($total / $comments_per_page),
|
|
'current' => $page
|
|
));
|
|
|
|
?>
|
|
|
|
<form id="comments-form" action="" method="post">
|
|
<input type="hidden" name="mode" value="<?php echo $mode; ?>" />
|
|
<input type="hidden" name="comment_status" value="<?php echo $comment_status; ?>" />
|
|
|
|
<div class="tablenav">
|
|
|
|
<?php
|
|
if ( $page_links )
|
|
echo "<div class='tablenav-pages'>$page_links</div>";
|
|
?>
|
|
|
|
<div class="alignleft">
|
|
<select name="action">
|
|
<option value="" selected="selected"><?php _e('Actions') ?></option>
|
|
<?php if ( empty($comment_status) || 'approved' == $comment_status ): ?>
|
|
<option value="unapprove"><?php _e('Unapprove'); ?></option>
|
|
<?php endif; ?>
|
|
<?php if ( empty($comment_status) || 'moderated' == $comment_status ): ?>
|
|
<option value="approve"><?php _e('Approve'); ?></option>
|
|
<?php endif; ?>
|
|
<?php if ( 'spam' != $comment_status ): ?>
|
|
<option value="markspam"><?php _e('Mark as Spam'); ?></option>
|
|
<?php endif; ?>
|
|
<option value="delete"><?php _e('Delete'); ?></option>
|
|
</select>
|
|
<input type="submit" name="doaction" id="doaction" value="<?php _e('Apply'); ?>" class="button-secondary apply" />
|
|
<?php wp_nonce_field('bulk-comments'); ?>
|
|
<?php if ( isset($_GET['apage']) ) { ?>
|
|
<input type="hidden" name="apage" value="<?php echo absint( $_GET['apage'] ); ?>" />
|
|
<?php }
|
|
|
|
if ( 'spam' == $comment_status ) {
|
|
wp_nonce_field('bulk-spam-delete'); ?>
|
|
<input type="submit" name="delete_all_spam" value="<?php _e('Delete All Spam'); ?>" class="button-secondary apply" />
|
|
<?php } ?>
|
|
<?php do_action('manage_comments_nav', $comment_status); ?>
|
|
</div>
|
|
|
|
<br class="clear" />
|
|
|
|
</div>
|
|
|
|
<br class="clear" />
|
|
<?php
|
|
if ($comments) {
|
|
?>
|
|
<table class="widefat">
|
|
<thead>
|
|
<tr>
|
|
<?php print_column_headers('comment'); ?>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="the-comment-list" class="list:comment">
|
|
<?php
|
|
foreach ($comments as $comment)
|
|
_wp_comment_row( $comment->comment_ID, $mode, $comment_status );
|
|
?>
|
|
</tbody>
|
|
<tbody id="the-extra-comment-list" class="list:comment" style="display: none;">
|
|
<?php
|
|
foreach ($extra_comments as $comment)
|
|
_wp_comment_row( $comment->comment_ID, $mode, $comment_status );
|
|
?>
|
|
</tbody>
|
|
</table>
|
|
|
|
</form>
|
|
|
|
<form id="get-extra-comments" method="post" action="" class="add:the-extra-comment-list:" style="display: none;">
|
|
<input type="hidden" name="s" value="<?php echo $search; ?>" />
|
|
<input type="hidden" name="mode" value="<?php echo $mode; ?>" />
|
|
<input type="hidden" name="comment_status" value="<?php echo $comment_status; ?>" />
|
|
<input type="hidden" name="page" value="<?php echo isset($_REQUEST['page']) ? absint( $_REQUEST['page'] ) : 1; ?>" />
|
|
<?php wp_nonce_field( 'add-comment', '_ajax_nonce', false ); ?>
|
|
</form>
|
|
|
|
<div id="ajax-response"></div>
|
|
<?php
|
|
} elseif ( 'moderated' == $_GET['comment_status'] ) {
|
|
?>
|
|
<p>
|
|
<?php _e('No comments awaiting moderation… yet.') ?>
|
|
</p>
|
|
<?php
|
|
} else {
|
|
?>
|
|
<p>
|
|
<?php _e('No results found.') ?>
|
|
</p>
|
|
<?php
|
|
}
|
|
?>
|
|
<div class="tablenav">
|
|
<?php
|
|
if ( $page_links )
|
|
echo "<div class='tablenav-pages'>$page_links</div>";
|
|
?>
|
|
<br class="clear" />
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php
|
|
wp_comment_reply('-1', true, 'detail');
|
|
include('admin-footer.php'); ?>
|