2019-03-12 09:27:46 +00:00
< ? php
/**
* List Table API : WP_Posts_List_Table class
*
* @ package WordPress
* @ subpackage Administration
* @ since 3.1 . 0
*/
/**
* Core class used to implement displaying posts in a list table .
*
* @ since 3.1 . 0
* @ access private
*
* @ see WP_List_Table
*/
class WP_Posts_List_Table extends WP_List_Table {
/**
* Whether the items should be displayed hierarchically or linearly .
*
* @ since 3.1 . 0
* @ var bool
*/
protected $hierarchical_display ;
/**
* Holds the number of pending comments for each post .
*
* @ since 3.1 . 0
* @ var array
*/
protected $comment_pending_count ;
/**
* Holds the number of posts for this user .
*
* @ since 3.1 . 0
* @ var int
*/
private $user_posts_count ;
/**
* Holds the number of posts which are sticky .
*
* @ since 3.1 . 0
* @ var int
*/
private $sticky_posts_count = 0 ;
private $is_trash ;
/**
* Current level for output .
*
* @ since 4.3 . 0
* @ var int
*/
protected $current_level = 0 ;
/**
* Constructor .
*
* @ since 3.1 . 0
*
* @ see WP_List_Table :: __construct () for more information on default arguments .
*
* @ global WP_Post_Type $post_type_object
* @ global wpdb $wpdb
*
* @ param array $args An associative array of arguments .
*/
public function __construct ( $args = array () ) {
global $post_type_object , $wpdb ;
2019-04-16 19:56:22 +00:00
parent :: __construct (
array (
'plural' => 'posts' ,
'screen' => isset ( $args [ 'screen' ] ) ? $args [ 'screen' ] : null ,
)
);
2019-03-12 09:27:46 +00:00
$post_type = $this -> screen -> post_type ;
$post_type_object = get_post_type_object ( $post_type );
2019-04-16 19:56:22 +00:00
$exclude_states = get_post_stati (
array (
'show_in_admin_all_list' => false ,
)
);
$this -> user_posts_count = intval (
$wpdb -> get_var (
$wpdb -> prepare (
"
2019-03-12 09:27:46 +00:00
SELECT COUNT ( 1 )
FROM $wpdb -> posts
WHERE post_type = % s
AND post_status NOT IN ( '" . implode( "' , '", $exclude_states ) . "' )
AND post_author = % d
2019-04-16 19:56:22 +00:00
" ,
$post_type ,
get_current_user_id ()
)
)
);
2019-03-12 09:27:46 +00:00
if ( $this -> user_posts_count && ! current_user_can ( $post_type_object -> cap -> edit_others_posts ) && empty ( $_REQUEST [ 'post_status' ] ) && empty ( $_REQUEST [ 'all_posts' ] ) && empty ( $_REQUEST [ 'author' ] ) && empty ( $_REQUEST [ 'show_sticky' ] ) ) {
$_GET [ 'author' ] = get_current_user_id ();
}
if ( 'post' === $post_type && $sticky_posts = get_option ( 'sticky_posts' ) ) {
2019-04-16 19:56:22 +00:00
$sticky_posts = implode ( ', ' , array_map ( 'absint' , ( array ) $sticky_posts ) );
2019-03-12 09:27:46 +00:00
$this -> sticky_posts_count = $wpdb -> get_var ( $wpdb -> prepare ( " SELECT COUNT( 1 ) FROM $wpdb->posts WHERE post_type = %s AND post_status NOT IN ('trash', 'auto-draft') AND ID IN ( $sticky_posts ) " , $post_type ) );
}
}
/**
* Sets whether the table layout should be hierarchical or not .
*
* @ since 4.2 . 0
*
* @ param bool $display Whether the table layout should be hierarchical .
*/
public function set_hierarchical_display ( $display ) {
$this -> hierarchical_display = $display ;
}
/**
* @ return bool
*/
public function ajax_user_can () {
return current_user_can ( get_post_type_object ( $this -> screen -> post_type ) -> cap -> edit_posts );
}
/**
* @ global array $avail_post_stati
* @ global WP_Query $wp_query
* @ global int $per_page
* @ global string $mode
*/
public function prepare_items () {
global $avail_post_stati , $wp_query , $per_page , $mode ;
// is going to call wp()
$avail_post_stati = wp_edit_posts_query ();
$this -> set_hierarchical_display ( is_post_type_hierarchical ( $this -> screen -> post_type ) && 'menu_order title' === $wp_query -> query [ 'orderby' ] );
$post_type = $this -> screen -> post_type ;
2019-04-16 19:56:22 +00:00
$per_page = $this -> get_items_per_page ( 'edit_' . $post_type . '_per_page' );
2019-03-12 09:27:46 +00:00
/** This filter is documented in wp-admin/includes/post.php */
2019-04-16 19:56:22 +00:00
$per_page = apply_filters ( 'edit_posts_per_page' , $per_page , $post_type );
2019-03-12 09:27:46 +00:00
if ( $this -> hierarchical_display ) {
$total_items = $wp_query -> post_count ;
} elseif ( $wp_query -> found_posts || $this -> get_pagenum () === 1 ) {
$total_items = $wp_query -> found_posts ;
} else {
$post_counts = ( array ) wp_count_posts ( $post_type , 'readable' );
2019-04-16 19:56:22 +00:00
if ( isset ( $_REQUEST [ 'post_status' ] ) && in_array ( $_REQUEST [ 'post_status' ], $avail_post_stati ) ) {
2019-03-12 09:27:46 +00:00
$total_items = $post_counts [ $_REQUEST [ 'post_status' ] ];
} elseif ( isset ( $_REQUEST [ 'show_sticky' ] ) && $_REQUEST [ 'show_sticky' ] ) {
$total_items = $this -> sticky_posts_count ;
} elseif ( isset ( $_GET [ 'author' ] ) && $_GET [ 'author' ] == get_current_user_id () ) {
$total_items = $this -> user_posts_count ;
} else {
$total_items = array_sum ( $post_counts );
// Subtract post types that are not included in the admin all list.
foreach ( get_post_stati ( array ( 'show_in_admin_all_list' => false ) ) as $state ) {
$total_items -= $post_counts [ $state ];
}
}
}
if ( ! empty ( $_REQUEST [ 'mode' ] ) ) {
$mode = $_REQUEST [ 'mode' ] === 'excerpt' ? 'excerpt' : 'list' ;
set_user_setting ( 'posts_list_mode' , $mode );
} else {
$mode = get_user_setting ( 'posts_list_mode' , 'list' );
}
$this -> is_trash = isset ( $_REQUEST [ 'post_status' ] ) && $_REQUEST [ 'post_status' ] === 'trash' ;
2019-04-16 19:56:22 +00:00
$this -> set_pagination_args (
array (
'total_items' => $total_items ,
'per_page' => $per_page ,
)
);
2019-03-12 09:27:46 +00:00
}
/**
* @ return bool
*/
public function has_items () {
return have_posts ();
}
/**
*/
public function no_items () {
2019-04-16 19:56:22 +00:00
if ( isset ( $_REQUEST [ 'post_status' ] ) && 'trash' === $_REQUEST [ 'post_status' ] ) {
2019-03-12 09:27:46 +00:00
echo get_post_type_object ( $this -> screen -> post_type ) -> labels -> not_found_in_trash ;
2019-04-16 19:56:22 +00:00
} else {
2019-03-12 09:27:46 +00:00
echo get_post_type_object ( $this -> screen -> post_type ) -> labels -> not_found ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
/**
* Determine if the current view is the " All " view .
*
* @ since 4.2 . 0
*
* @ return bool Whether the current view is the " All " view .
*/
protected function is_base_request () {
$vars = $_GET ;
unset ( $vars [ 'paged' ] );
if ( empty ( $vars ) ) {
return true ;
} elseif ( 1 === count ( $vars ) && ! empty ( $vars [ 'post_type' ] ) ) {
return $this -> screen -> post_type === $vars [ 'post_type' ];
}
return 1 === count ( $vars ) && ! empty ( $vars [ 'mode' ] );
}
/**
* Helper to create links to edit . php with params .
*
* @ since 4.4 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $args Associative array of URL parameters for the link .
* @ param string $label Link text .
* @ param string $class Optional . Class attribute . Default empty string .
2019-03-12 09:27:46 +00:00
* @ return string The formatted link string .
*/
protected function get_edit_link ( $args , $label , $class = '' ) {
$url = add_query_arg ( $args , 'edit.php' );
$class_html = $aria_current = '' ;
if ( ! empty ( $class ) ) {
2019-04-16 19:56:22 +00:00
$class_html = sprintf (
2019-03-12 09:27:46 +00:00
' class="%s"' ,
esc_attr ( $class )
);
if ( 'current' === $class ) {
$aria_current = ' aria-current="page"' ;
}
}
return sprintf (
'<a href="%s"%s%s>%s</a>' ,
esc_url ( $url ),
$class_html ,
$aria_current ,
$label
);
}
/**
* @ global array $locked_post_status This seems to be deprecated .
* @ global array $avail_post_stati
* @ return array
*/
protected function get_views () {
global $locked_post_status , $avail_post_stati ;
$post_type = $this -> screen -> post_type ;
2019-04-16 19:56:22 +00:00
if ( ! empty ( $locked_post_status ) ) {
2019-03-12 09:27:46 +00:00
return array ();
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
$status_links = array ();
2019-04-16 19:56:22 +00:00
$num_posts = wp_count_posts ( $post_type , 'readable' );
$total_posts = array_sum ( ( array ) $num_posts );
$class = '' ;
2019-03-12 09:27:46 +00:00
$current_user_id = get_current_user_id ();
2019-04-16 19:56:22 +00:00
$all_args = array ( 'post_type' => $post_type );
$mine = '' ;
2019-03-12 09:27:46 +00:00
// Subtract post types that are not included in the admin all list.
foreach ( get_post_stati ( array ( 'show_in_admin_all_list' => false ) ) as $state ) {
$total_posts -= $num_posts -> $state ;
}
if ( $this -> user_posts_count && $this -> user_posts_count !== $total_posts ) {
if ( isset ( $_GET [ 'author' ] ) && ( $_GET [ 'author' ] == $current_user_id ) ) {
$class = 'current' ;
}
$mine_args = array (
'post_type' => $post_type ,
2019-04-16 19:56:22 +00:00
'author' => $current_user_id ,
2019-03-12 09:27:46 +00:00
);
$mine_inner_html = sprintf (
_nx (
'Mine <span class="count">(%s)</span>' ,
'Mine <span class="count">(%s)</span>' ,
$this -> user_posts_count ,
'posts'
),
number_format_i18n ( $this -> user_posts_count )
);
$mine = $this -> get_edit_link ( $mine_args , $mine_inner_html , $class );
$all_args [ 'all_posts' ] = 1 ;
2019-04-16 19:56:22 +00:00
$class = '' ;
2019-03-12 09:27:46 +00:00
}
if ( empty ( $class ) && ( $this -> is_base_request () || isset ( $_REQUEST [ 'all_posts' ] ) ) ) {
$class = 'current' ;
}
$all_inner_html = sprintf (
_nx (
'All <span class="count">(%s)</span>' ,
'All <span class="count">(%s)</span>' ,
$total_posts ,
'posts'
),
number_format_i18n ( $total_posts )
);
$status_links [ 'all' ] = $this -> get_edit_link ( $all_args , $all_inner_html , $class );
if ( $mine ) {
$status_links [ 'mine' ] = $mine ;
}
2019-04-16 19:56:22 +00:00
foreach ( get_post_stati ( array ( 'show_in_admin_status_list' => true ), 'objects' ) as $status ) {
2019-03-12 09:27:46 +00:00
$class = '' ;
$status_name = $status -> name ;
if ( ! in_array ( $status_name , $avail_post_stati ) || empty ( $num_posts -> $status_name ) ) {
continue ;
}
2019-04-16 19:56:22 +00:00
if ( isset ( $_REQUEST [ 'post_status' ] ) && $status_name === $_REQUEST [ 'post_status' ] ) {
2019-03-12 09:27:46 +00:00
$class = 'current' ;
}
$status_args = array (
'post_status' => $status_name ,
2019-04-16 19:56:22 +00:00
'post_type' => $post_type ,
2019-03-12 09:27:46 +00:00
);
$status_label = sprintf (
translate_nooped_plural ( $status -> label_count , $num_posts -> $status_name ),
number_format_i18n ( $num_posts -> $status_name )
);
$status_links [ $status_name ] = $this -> get_edit_link ( $status_args , $status_label , $class );
}
if ( ! empty ( $this -> sticky_posts_count ) ) {
$class = ! empty ( $_REQUEST [ 'show_sticky' ] ) ? 'current' : '' ;
$sticky_args = array (
2019-04-16 19:56:22 +00:00
'post_type' => $post_type ,
'show_sticky' => 1 ,
2019-03-12 09:27:46 +00:00
);
$sticky_inner_html = sprintf (
_nx (
'Sticky <span class="count">(%s)</span>' ,
'Sticky <span class="count">(%s)</span>' ,
$this -> sticky_posts_count ,
'posts'
),
number_format_i18n ( $this -> sticky_posts_count )
);
$sticky_link = array (
2019-04-16 19:56:22 +00:00
'sticky' => $this -> get_edit_link ( $sticky_args , $sticky_inner_html , $class ),
2019-03-12 09:27:46 +00:00
);
// Sticky comes after Publish, or if not listed, after All.
2019-04-16 19:56:22 +00:00
$split = 1 + array_search ( ( isset ( $status_links [ 'publish' ] ) ? 'publish' : 'all' ), array_keys ( $status_links ) );
2019-03-12 09:27:46 +00:00
$status_links = array_merge ( array_slice ( $status_links , 0 , $split ), $sticky_link , array_slice ( $status_links , $split ) );
}
return $status_links ;
}
/**
* @ return array
*/
protected function get_bulk_actions () {
2019-04-16 19:56:22 +00:00
$actions = array ();
2019-03-12 09:27:46 +00:00
$post_type_obj = get_post_type_object ( $this -> screen -> post_type );
if ( current_user_can ( $post_type_obj -> cap -> edit_posts ) ) {
if ( $this -> is_trash ) {
$actions [ 'untrash' ] = __ ( 'Restore' );
} else {
$actions [ 'edit' ] = __ ( 'Edit' );
}
}
if ( current_user_can ( $post_type_obj -> cap -> delete_posts ) ) {
if ( $this -> is_trash || ! EMPTY_TRASH_DAYS ) {
$actions [ 'delete' ] = __ ( 'Delete Permanently' );
} else {
$actions [ 'trash' ] = __ ( 'Move to Trash' );
}
}
return $actions ;
}
/**
* Displays a categories drop - down for filtering on the Posts list table .
*
* @ since 4.6 . 0
*
* @ global int $cat Currently selected category .
*
* @ param string $post_type Post type slug .
*/
protected function categories_dropdown ( $post_type ) {
global $cat ;
/**
* Filters whether to remove the 'Categories' drop - down from the post list table .
*
* @ since 4.6 . 0
*
* @ param bool $disable Whether to disable the categories drop - down . Default false .
* @ param string $post_type Post type slug .
*/
if ( false !== apply_filters ( 'disable_categories_dropdown' , false , $post_type ) ) {
return ;
}
if ( is_object_in_taxonomy ( $post_type , 'category' ) ) {
$dropdown_options = array (
'show_option_all' => get_taxonomy ( 'category' ) -> labels -> all_items ,
2019-04-16 19:56:22 +00:00
'hide_empty' => 0 ,
'hierarchical' => 1 ,
'show_count' => 0 ,
'orderby' => 'name' ,
'selected' => $cat ,
2019-03-12 09:27:46 +00:00
);
echo '<label class="screen-reader-text" for="cat">' . __ ( 'Filter by category' ) . '</label>' ;
wp_dropdown_categories ( $dropdown_options );
}
}
/**
* @ param string $which
*/
protected function extra_tablenav ( $which ) {
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< div class = " alignleft actions " >
2019-04-16 19:56:22 +00:00
< ? php
if ( 'top' === $which && ! is_singular () ) {
2019-03-12 09:27:46 +00:00
ob_start ();
$this -> months_dropdown ( $this -> screen -> post_type );
$this -> categories_dropdown ( $this -> screen -> post_type );
/**
* Fires before the Filter button on the Posts and Pages list tables .
*
* The Filter button allows sorting by date and / or category on the
* Posts list table , and sorting by date on the Pages list table .
*
* @ since 2.1 . 0
* @ since 4.4 . 0 The `$post_type` parameter was added .
* @ since 4.6 . 0 The `$which` parameter was added .
*
* @ param string $post_type The post type slug .
* @ param string $which The location of the extra table nav markup :
* 'top' or 'bottom' for WP_Posts_List_Table ,
* 'bar' for WP_Media_List_Table .
*/
do_action ( 'restrict_manage_posts' , $this -> screen -> post_type , $which );
$output = ob_get_clean ();
if ( ! empty ( $output ) ) {
echo $output ;
submit_button ( __ ( 'Filter' ), '' , 'filter_action' , false , array ( 'id' => 'post-query-submit' ) );
}
}
if ( $this -> is_trash && current_user_can ( get_post_type_object ( $this -> screen -> post_type ) -> cap -> edit_others_posts ) && $this -> has_items () ) {
submit_button ( __ ( 'Empty Trash' ), 'apply' , 'delete_all' , false );
}
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
</ div >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
/**
* Fires immediately following the closing " actions " div in the tablenav for the posts
* list table .
*
* @ since 4.4 . 0
*
* @ param string $which The location of the extra table nav markup : 'top' or 'bottom' .
*/
do_action ( 'manage_posts_extra_tablenav' , $which );
}
/**
* @ return string
*/
public function current_action () {
2019-04-16 19:56:22 +00:00
if ( isset ( $_REQUEST [ 'delete_all' ] ) || isset ( $_REQUEST [ 'delete_all2' ] ) ) {
2019-03-12 09:27:46 +00:00
return 'delete_all' ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
return parent :: current_action ();
}
/**
* @ return array
*/
protected function get_table_classes () {
return array ( 'widefat' , 'fixed' , 'striped' , is_post_type_hierarchical ( $this -> screen -> post_type ) ? 'pages' : 'posts' );
}
/**
* @ return array
*/
public function get_columns () {
$post_type = $this -> screen -> post_type ;
$posts_columns = array ();
$posts_columns [ 'cb' ] = '<input type="checkbox" />' ;
/* translators: manage posts column name */
$posts_columns [ 'title' ] = _x ( 'Title' , 'column name' );
if ( post_type_supports ( $post_type , 'author' ) ) {
$posts_columns [ 'author' ] = __ ( 'Author' );
}
$taxonomies = get_object_taxonomies ( $post_type , 'objects' );
$taxonomies = wp_filter_object_list ( $taxonomies , array ( 'show_admin_column' => true ), 'and' , 'name' );
/**
* Filters the taxonomy columns in the Posts list table .
*
* The dynamic portion of the hook name , `$post_type` , refers to the post
* type slug .
*
* @ since 3.5 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $taxonomies Array of taxonomy names to show columns for .
* @ param string $post_type The post type .
2019-03-12 09:27:46 +00:00
*/
$taxonomies = apply_filters ( " manage_taxonomies_for_ { $post_type } _columns " , $taxonomies , $post_type );
$taxonomies = array_filter ( $taxonomies , 'taxonomy_exists' );
foreach ( $taxonomies as $taxonomy ) {
2019-04-16 19:56:22 +00:00
if ( 'category' === $taxonomy ) {
2019-03-12 09:27:46 +00:00
$column_key = 'categories' ;
2019-04-16 19:56:22 +00:00
} elseif ( 'post_tag' === $taxonomy ) {
2019-03-12 09:27:46 +00:00
$column_key = 'tags' ;
2019-04-16 19:56:22 +00:00
} else {
2019-03-12 09:27:46 +00:00
$column_key = 'taxonomy-' . $taxonomy ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
$posts_columns [ $column_key ] = get_taxonomy ( $taxonomy ) -> labels -> name ;
}
2019-04-16 19:56:22 +00:00
$post_status = ! empty ( $_REQUEST [ 'post_status' ] ) ? $_REQUEST [ 'post_status' ] : 'all' ;
if ( post_type_supports ( $post_type , 'comments' ) && ! in_array ( $post_status , array ( 'pending' , 'draft' , 'future' ) ) ) {
2019-03-12 09:27:46 +00:00
$posts_columns [ 'comments' ] = '<span class="vers comment-grey-bubble" title="' . esc_attr__ ( 'Comments' ) . '"><span class="screen-reader-text">' . __ ( 'Comments' ) . '</span></span>' ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
$posts_columns [ 'date' ] = __ ( 'Date' );
if ( 'page' === $post_type ) {
/**
* Filters the columns displayed in the Pages list table .
*
* @ since 2.5 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $post_columns An associative array of column headings .
2019-03-12 09:27:46 +00:00
*/
$posts_columns = apply_filters ( 'manage_pages_columns' , $posts_columns );
} else {
/**
* Filters the columns displayed in the Posts list table .
*
* @ since 1.5 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $post_columns An associative array of column headings .
* @ param string $post_type The post type slug .
2019-03-12 09:27:46 +00:00
*/
$posts_columns = apply_filters ( 'manage_posts_columns' , $posts_columns , $post_type );
}
/**
* Filters the columns displayed in the Posts list table for a specific post type .
*
* The dynamic portion of the hook name , `$post_type` , refers to the post type slug .
*
* @ since 3.0 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $post_columns An associative array of column headings .
2019-03-12 09:27:46 +00:00
*/
return apply_filters ( " manage_ { $post_type } _posts_columns " , $posts_columns );
}
/**
* @ return array
*/
protected function get_sortable_columns () {
return array (
'title' => 'title' ,
'parent' => 'parent' ,
'comments' => 'comment_count' ,
2019-04-16 19:56:22 +00:00
'date' => array ( 'date' , true ),
2019-03-12 09:27:46 +00:00
);
}
/**
* @ global WP_Query $wp_query
* @ global int $per_page
* @ param array $posts
* @ param int $level
*/
public function display_rows ( $posts = array (), $level = 0 ) {
global $wp_query , $per_page ;
2019-04-16 19:56:22 +00:00
if ( empty ( $posts ) ) {
2019-03-12 09:27:46 +00:00
$posts = $wp_query -> posts ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
add_filter ( 'the_title' , 'esc_html' );
if ( $this -> hierarchical_display ) {
$this -> _display_rows_hierarchical ( $posts , $this -> get_pagenum (), $per_page );
} else {
$this -> _display_rows ( $posts , $level );
}
}
/**
* @ param array $posts
* @ param int $level
*/
private function _display_rows ( $posts , $level = 0 ) {
2019-04-16 19:56:22 +00:00
$post_type = $this -> screen -> post_type ;
2019-03-12 09:27:46 +00:00
// Create array of post IDs.
$post_ids = array ();
2019-04-16 19:56:22 +00:00
foreach ( $posts as $a_post ) {
2019-03-12 09:27:46 +00:00
$post_ids [] = $a_post -> ID ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( post_type_supports ( $post_type , 'comments' ) ) {
$this -> comment_pending_count = get_pending_comments_num ( $post_ids );
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
foreach ( $posts as $post ) {
2019-03-12 09:27:46 +00:00
$this -> single_row ( $post , $level );
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
/**
* @ global wpdb $wpdb
* @ global WP_Post $post
* @ param array $pages
* @ param int $pagenum
* @ param int $per_page
*/
private function _display_rows_hierarchical ( $pages , $pagenum = 1 , $per_page = 20 ) {
global $wpdb ;
$level = 0 ;
if ( ! $pages ) {
$pages = get_pages ( array ( 'sort_column' => 'menu_order' ) );
2019-04-16 19:56:22 +00:00
if ( ! $pages ) {
2019-03-12 09:27:46 +00:00
return ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
/*
* Arrange pages into two parts : top level pages and children_pages
* children_pages is two dimensional array , eg .
* children_pages [ 10 ][] contains all sub - pages whose parent is 10.
* It only takes O ( N ) to arrange this and it takes O ( 1 ) for subsequent lookup operations
* If searching , ignore hierarchy and treat everything as top level
*/
if ( empty ( $_REQUEST [ 's' ] ) ) {
$top_level_pages = array ();
2019-04-16 19:56:22 +00:00
$children_pages = array ();
2019-03-12 09:27:46 +00:00
foreach ( $pages as $page ) {
// Catch and repair bad pages.
if ( $page -> post_parent == $page -> ID ) {
$page -> post_parent = 0 ;
$wpdb -> update ( $wpdb -> posts , array ( 'post_parent' => 0 ), array ( 'ID' => $page -> ID ) );
clean_post_cache ( $page );
}
2019-04-16 19:56:22 +00:00
if ( 0 == $page -> post_parent ) {
2019-03-12 09:27:46 +00:00
$top_level_pages [] = $page ;
2019-04-16 19:56:22 +00:00
} else {
2019-03-12 09:27:46 +00:00
$children_pages [ $page -> post_parent ][] = $page ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
$pages = & $top_level_pages ;
}
2019-04-16 19:56:22 +00:00
$count = 0 ;
$start = ( $pagenum - 1 ) * $per_page ;
$end = $start + $per_page ;
2019-03-12 09:27:46 +00:00
$to_display = array ();
foreach ( $pages as $page ) {
2019-04-16 19:56:22 +00:00
if ( $count >= $end ) {
2019-03-12 09:27:46 +00:00
break ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
if ( $count >= $start ) {
2019-04-16 19:56:22 +00:00
$to_display [ $page -> ID ] = $level ;
2019-03-12 09:27:46 +00:00
}
$count ++ ;
2019-04-16 19:56:22 +00:00
if ( isset ( $children_pages ) ) {
2019-03-12 09:27:46 +00:00
$this -> _page_rows ( $children_pages , $count , $page -> ID , $level + 1 , $pagenum , $per_page , $to_display );
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
// If it is the last pagenum and there are orphaned pages, display them with paging as well.
2019-04-16 19:56:22 +00:00
if ( isset ( $children_pages ) && $count < $end ) {
foreach ( $children_pages as $orphans ) {
2019-03-12 09:27:46 +00:00
foreach ( $orphans as $op ) {
2019-04-16 19:56:22 +00:00
if ( $count >= $end ) {
2019-03-12 09:27:46 +00:00
break ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
if ( $count >= $start ) {
2019-04-16 19:56:22 +00:00
$to_display [ $op -> ID ] = 0 ;
2019-03-12 09:27:46 +00:00
}
$count ++ ;
}
}
}
$ids = array_keys ( $to_display );
_prime_post_caches ( $ids );
if ( ! isset ( $GLOBALS [ 'post' ] ) ) {
$GLOBALS [ 'post' ] = reset ( $ids );
}
foreach ( $to_display as $page_id => $level ) {
echo " \t " ;
$this -> single_row ( $page_id , $level );
}
}
/**
* Given a top level page ID , display the nested hierarchy of sub - pages
* together with paging support
*
* @ since 3.1 . 0 ( Standalone function exists since 2.6 . 0 )
* @ since 4.2 . 0 Added the `$to_display` parameter .
*
* @ param array $children_pages
* @ param int $count
* @ param int $parent
* @ param int $level
* @ param int $pagenum
* @ param int $per_page
* @ param array $to_display List of pages to be displayed . Passed by reference .
*/
private function _page_rows ( & $children_pages , & $count , $parent , $level , $pagenum , $per_page , & $to_display ) {
2019-04-16 19:56:22 +00:00
if ( ! isset ( $children_pages [ $parent ] ) ) {
2019-03-12 09:27:46 +00:00
return ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
$start = ( $pagenum - 1 ) * $per_page ;
2019-04-16 19:56:22 +00:00
$end = $start + $per_page ;
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
foreach ( $children_pages [ $parent ] as $page ) {
if ( $count >= $end ) {
2019-03-12 09:27:46 +00:00
break ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
// If the page starts in a subtree, print the parents.
if ( $count == $start && $page -> post_parent > 0 ) {
$my_parents = array ();
2019-04-16 19:56:22 +00:00
$my_parent = $page -> post_parent ;
2019-03-12 09:27:46 +00:00
while ( $my_parent ) {
// Get the ID from the list or the attribute if my_parent is an object
$parent_id = $my_parent ;
if ( is_object ( $my_parent ) ) {
$parent_id = $my_parent -> ID ;
}
2019-04-16 19:56:22 +00:00
$my_parent = get_post ( $parent_id );
2019-03-12 09:27:46 +00:00
$my_parents [] = $my_parent ;
2019-04-16 19:56:22 +00:00
if ( ! $my_parent -> post_parent ) {
2019-03-12 09:27:46 +00:00
break ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
$my_parent = $my_parent -> post_parent ;
}
$num_parents = count ( $my_parents );
while ( $my_parent = array_pop ( $my_parents ) ) {
2019-04-16 19:56:22 +00:00
$to_display [ $my_parent -> ID ] = $level - $num_parents ;
2019-03-12 09:27:46 +00:00
$num_parents -- ;
}
}
if ( $count >= $start ) {
2019-04-16 19:56:22 +00:00
$to_display [ $page -> ID ] = $level ;
2019-03-12 09:27:46 +00:00
}
$count ++ ;
$this -> _page_rows ( $children_pages , $count , $page -> ID , $level + 1 , $pagenum , $per_page , $to_display );
}
2019-04-16 19:56:22 +00:00
unset ( $children_pages [ $parent ] ); //required in order to keep track of orphans
2019-03-12 09:27:46 +00:00
}
/**
* Handles the checkbox column output .
*
* @ since 4.3 . 0
*
* @ param WP_Post $post The current WP_Post object .
*/
public function column_cb ( $post ) {
2019-04-16 19:56:22 +00:00
if ( current_user_can ( 'edit_post' , $post -> ID ) ) :
?>
< label class = " screen-reader-text " for = " cb-select-<?php the_ID(); ?> " >
< ? php
printf ( __ ( 'Select %s' ), _draft_or_post_title () );
?>
</ label >
2019-03-12 09:27:46 +00:00
< input id = " cb-select-<?php the_ID(); ?> " type = " checkbox " name = " post[] " value = " <?php the_ID(); ?> " />
< div class = " locked-indicator " >
< span class = " locked-indicator-icon " aria - hidden = " true " ></ span >
2019-04-16 19:56:22 +00:00
< span class = " screen-reader-text " >
< ? php
2019-03-12 09:27:46 +00:00
printf (
/* translators: %s: post title */
__ ( '“%s” is locked' ),
_draft_or_post_title ()
);
2019-04-16 19:56:22 +00:00
?>
</ span >
2019-03-12 09:27:46 +00:00
</ div >
2019-04-16 19:56:22 +00:00
< ? php
endif ;
2019-03-12 09:27:46 +00:00
}
/**
* @ since 4.3 . 0
*
* @ param WP_Post $post
* @ param string $classes
* @ param string $data
* @ param string $primary
*/
protected function _column_title ( $post , $classes , $data , $primary ) {
echo '<td class="' . $classes . ' page-title" ' , $data , '>' ;
echo $this -> column_title ( $post );
echo $this -> handle_row_actions ( $post , 'title' , $primary );
echo '</td>' ;
}
/**
* Handles the title column output .
*
* @ since 4.3 . 0
*
* @ global string $mode List table view mode .
*
* @ param WP_Post $post The current WP_Post object .
*/
public function column_title ( $post ) {
global $mode ;
if ( $this -> hierarchical_display ) {
if ( 0 === $this -> current_level && ( int ) $post -> post_parent > 0 ) {
// Sent level 0 by accident, by default, or because we don't know the actual level.
$find_main_page = ( int ) $post -> post_parent ;
while ( $find_main_page > 0 ) {
$parent = get_post ( $find_main_page );
if ( is_null ( $parent ) ) {
break ;
}
$this -> current_level ++ ;
$find_main_page = ( int ) $parent -> post_parent ;
if ( ! isset ( $parent_name ) ) {
/** This filter is documented in wp-includes/post-template.php */
$parent_name = apply_filters ( 'the_title' , $parent -> post_title , $parent -> ID );
}
}
}
}
$can_edit_post = current_user_can ( 'edit_post' , $post -> ID );
if ( $can_edit_post && $post -> post_status != 'trash' ) {
$lock_holder = wp_check_post_lock ( $post -> ID );
if ( $lock_holder ) {
2019-04-16 19:56:22 +00:00
$lock_holder = get_userdata ( $lock_holder );
2019-03-12 09:27:46 +00:00
$locked_avatar = get_avatar ( $lock_holder -> ID , 18 );
2019-04-16 19:56:22 +00:00
$locked_text = esc_html ( sprintf ( __ ( '%s is currently editing' ), $lock_holder -> display_name ) );
2019-03-12 09:27:46 +00:00
} else {
$locked_avatar = $locked_text = '' ;
}
echo '<div class="locked-info"><span class="locked-avatar">' . $locked_avatar . '</span> <span class="locked-text">' . $locked_text . " </span></div> \n " ;
}
$pad = str_repeat ( '— ' , $this -> current_level );
2019-04-16 19:56:22 +00:00
echo '<strong>' ;
2019-03-12 09:27:46 +00:00
$format = get_post_format ( $post -> ID );
if ( $format ) {
$label = get_post_format_string ( $format );
$format_class = 'post-state-format post-format-icon post-format-' . $format ;
$format_args = array (
'post_format' => $format ,
2019-04-16 19:56:22 +00:00
'post_type' => $post -> post_type ,
2019-03-12 09:27:46 +00:00
);
echo $this -> get_edit_link ( $format_args , $label . ':' , $format_class );
}
$title = _draft_or_post_title ();
if ( $can_edit_post && $post -> post_status != 'trash' ) {
printf (
'<a class="row-title" href="%s" aria-label="%s">%s%s</a>' ,
get_edit_post_link ( $post -> ID ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( '“%s” (Edit)' ), $title ) ),
$pad ,
$title
);
} else {
echo $pad . $title ;
}
_post_states ( $post );
if ( isset ( $parent_name ) ) {
$post_type_object = get_post_type_object ( $post -> post_type );
echo ' | ' . $post_type_object -> labels -> parent_item_colon . ' ' . esc_html ( $parent_name );
}
echo " </strong> \n " ;
if ( ! is_post_type_hierarchical ( $this -> screen -> post_type ) && 'excerpt' === $mode && current_user_can ( 'read_post' , $post -> ID ) ) {
if ( post_password_required ( $post ) ) {
echo '<span class="protected-post-excerpt">' . esc_html ( get_the_excerpt () ) . '</span>' ;
} else {
echo esc_html ( get_the_excerpt () );
}
}
get_inline_data ( $post );
}
/**
* Handles the post date column output .
*
* @ since 4.3 . 0
*
* @ global string $mode List table view mode .
*
* @ param WP_Post $post The current WP_Post object .
*/
public function column_date ( $post ) {
global $mode ;
if ( '0000-00-00 00:00:00' === $post -> post_date ) {
2019-04-16 19:56:22 +00:00
$t_time = $h_time = __ ( 'Unpublished' );
2019-03-12 09:27:46 +00:00
$time_diff = 0 ;
} else {
$t_time = get_the_time ( __ ( 'Y/m/d g:i:s a' ) );
$m_time = $post -> post_date ;
2019-04-16 19:56:22 +00:00
$time = get_post_time ( 'G' , true , $post );
2019-03-12 09:27:46 +00:00
$time_diff = time () - $time ;
if ( $time_diff > 0 && $time_diff < DAY_IN_SECONDS ) {
$h_time = sprintf ( __ ( '%s ago' ), human_time_diff ( $time ) );
} else {
$h_time = mysql2date ( __ ( 'Y/m/d' ), $m_time );
}
}
if ( 'publish' === $post -> post_status ) {
$status = __ ( 'Published' );
} elseif ( 'future' === $post -> post_status ) {
if ( $time_diff > 0 ) {
$status = '<strong class="error-message">' . __ ( 'Missed schedule' ) . '</strong>' ;
} else {
$status = __ ( 'Scheduled' );
}
} else {
$status = __ ( 'Last Modified' );
}
/**
* Filters the status text of the post .
*
* @ since 4.8 . 0
*
* @ param string $status The status text .
* @ param WP_Post $post Post object .
* @ param string $column_name The column name .
* @ param string $mode The list display mode ( 'excerpt' or 'list' ) .
*/
$status = apply_filters ( 'post_date_column_status' , $status , $post , 'date' , $mode );
if ( $status ) {
echo $status . '<br />' ;
}
if ( 'excerpt' === $mode ) {
/**
* Filters the published time of the post .
*
* If `$mode` equals 'excerpt' , the published time and date are both displayed .
* If `$mode` equals 'list' ( default ), the publish date is displayed , with the
* time and date together available as an abbreviation definition .
*
* @ since 2.5 . 1
*
* @ param string $t_time The published time .
* @ param WP_Post $post Post object .
* @ param string $column_name The column name .
* @ param string $mode The list display mode ( 'excerpt' or 'list' ) .
*/
echo apply_filters ( 'post_date_column_time' , $t_time , $post , 'date' , $mode );
} else {
/** This filter is documented in wp-admin/includes/class-wp-posts-list-table.php */
echo '<abbr title="' . $t_time . '">' . apply_filters ( 'post_date_column_time' , $h_time , $post , 'date' , $mode ) . '</abbr>' ;
}
}
/**
* Handles the comments column output .
*
* @ since 4.3 . 0
*
* @ param WP_Post $post The current WP_Post object .
*/
public function column_comments ( $post ) {
?>
< div class = " post-com-count-wrapper " >
< ? php
2019-04-16 19:56:22 +00:00
$pending_comments = isset ( $this -> comment_pending_count [ $post -> ID ] ) ? $this -> comment_pending_count [ $post -> ID ] : 0 ;
2019-03-12 09:27:46 +00:00
$this -> comments_bubble ( $post -> ID , $pending_comments );
?>
</ div >
< ? php
}
/**
* Handles the post author column output .
*
* @ since 4.3 . 0
*
* @ param WP_Post $post The current WP_Post object .
*/
public function column_author ( $post ) {
$args = array (
'post_type' => $post -> post_type ,
2019-04-16 19:56:22 +00:00
'author' => get_the_author_meta ( 'ID' ),
2019-03-12 09:27:46 +00:00
);
echo $this -> get_edit_link ( $args , get_the_author () );
}
/**
* Handles the default column output .
*
* @ since 4.3 . 0
*
* @ param WP_Post $post The current WP_Post object .
* @ param string $column_name The current column name .
*/
public function column_default ( $post , $column_name ) {
if ( 'categories' === $column_name ) {
$taxonomy = 'category' ;
} elseif ( 'tags' === $column_name ) {
$taxonomy = 'post_tag' ;
} elseif ( 0 === strpos ( $column_name , 'taxonomy-' ) ) {
$taxonomy = substr ( $column_name , 9 );
} else {
$taxonomy = false ;
}
if ( $taxonomy ) {
$taxonomy_object = get_taxonomy ( $taxonomy );
2019-04-16 19:56:22 +00:00
$terms = get_the_terms ( $post -> ID , $taxonomy );
2019-03-12 09:27:46 +00:00
if ( is_array ( $terms ) ) {
$out = array ();
foreach ( $terms as $t ) {
$posts_in_term_qv = array ();
if ( 'post' != $post -> post_type ) {
$posts_in_term_qv [ 'post_type' ] = $post -> post_type ;
}
if ( $taxonomy_object -> query_var ) {
$posts_in_term_qv [ $taxonomy_object -> query_var ] = $t -> slug ;
} else {
$posts_in_term_qv [ 'taxonomy' ] = $taxonomy ;
2019-04-16 19:56:22 +00:00
$posts_in_term_qv [ 'term' ] = $t -> slug ;
2019-03-12 09:27:46 +00:00
}
$label = esc_html ( sanitize_term_field ( 'name' , $t -> name , $t -> term_id , $taxonomy , 'display' ) );
$out [] = $this -> get_edit_link ( $posts_in_term_qv , $label );
}
/* translators: used between list items, there is a space after the comma */
echo join ( __ ( ', ' ), $out );
} else {
echo '<span aria-hidden="true">—</span><span class="screen-reader-text">' . $taxonomy_object -> labels -> no_terms . '</span>' ;
}
return ;
}
if ( is_post_type_hierarchical ( $post -> post_type ) ) {
/**
* Fires in each custom column on the Posts list table .
*
* This hook only fires if the current post type is hierarchical ,
* such as pages .
*
* @ since 2.5 . 0
*
* @ param string $column_name The name of the column to display .
* @ param int $post_id The current post ID .
*/
do_action ( 'manage_pages_custom_column' , $column_name , $post -> ID );
} else {
/**
* Fires in each custom column in the Posts list table .
*
* This hook only fires if the current post type is non - hierarchical ,
* such as posts .
*
* @ since 1.5 . 0
*
* @ param string $column_name The name of the column to display .
* @ param int $post_id The current post ID .
*/
do_action ( 'manage_posts_custom_column' , $column_name , $post -> ID );
}
/**
* Fires for each custom column of a specific post type in the Posts list table .
*
* The dynamic portion of the hook name , `$post->post_type` , refers to the post type .
*
* @ since 3.1 . 0
*
* @ param string $column_name The name of the column to display .
* @ param int $post_id The current post ID .
*/
do_action ( " manage_ { $post -> post_type } _posts_custom_column " , $column_name , $post -> ID );
}
/**
* @ global WP_Post $post
*
* @ param int | WP_Post $post
* @ param int $level
*/
public function single_row ( $post , $level = 0 ) {
$global_post = get_post ();
2019-04-16 19:56:22 +00:00
$post = get_post ( $post );
2019-03-12 09:27:46 +00:00
$this -> current_level = $level ;
$GLOBALS [ 'post' ] = $post ;
setup_postdata ( $post );
$classes = 'iedit author-' . ( get_current_user_id () == $post -> post_author ? 'self' : 'other' );
$lock_holder = wp_check_post_lock ( $post -> ID );
if ( $lock_holder ) {
$classes .= ' wp-locked' ;
}
if ( $post -> post_parent ) {
2019-04-16 19:56:22 +00:00
$count = count ( get_post_ancestors ( $post -> ID ) );
$classes .= ' level-' . $count ;
2019-03-12 09:27:46 +00:00
} else {
2019-04-16 19:56:22 +00:00
$classes .= ' level-0' ;
2019-03-12 09:27:46 +00:00
}
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< tr id = " post-<?php echo $post->ID ; ?> " class = " <?php echo implode( ' ', get_post_class( $classes , $post->ID ) ); ?> " >
< ? php $this -> single_row_columns ( $post ); ?>
</ tr >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
$GLOBALS [ 'post' ] = $global_post ;
}
/**
* Gets the name of the default primary column .
*
* @ since 4.3 . 0
*
* @ return string Name of the default primary column , in this case , 'title' .
*/
protected function get_default_primary_column_name () {
return 'title' ;
}
/**
* Generates and displays row action links .
*
* @ since 4.3 . 0
*
* @ param object $post Post being acted upon .
* @ param string $column_name Current column name .
* @ param string $primary Primary column name .
* @ return string Row actions output for posts .
*/
protected function handle_row_actions ( $post , $column_name , $primary ) {
if ( $primary !== $column_name ) {
return '' ;
}
$post_type_object = get_post_type_object ( $post -> post_type );
2019-04-16 19:56:22 +00:00
$can_edit_post = current_user_can ( 'edit_post' , $post -> ID );
$actions = array ();
$title = _draft_or_post_title ();
2019-03-12 09:27:46 +00:00
if ( $can_edit_post && 'trash' != $post -> post_status ) {
$actions [ 'edit' ] = sprintf (
'<a href="%s" aria-label="%s">%s</a>' ,
get_edit_post_link ( $post -> ID ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Edit “%s”' ), $title ) ),
__ ( 'Edit' )
);
if ( 'wp_block' !== $post -> post_type ) {
$actions [ 'inline hide-if-no-js' ] = sprintf (
2019-04-16 19:56:22 +00:00
'<button type="button" class="button-link editinline" aria-label="%s" aria-expanded="false">%s</button>' ,
2019-03-12 09:27:46 +00:00
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Quick edit “%s” inline' ), $title ) ),
__ ( 'Quick Edit' )
);
}
}
if ( current_user_can ( 'delete_post' , $post -> ID ) ) {
if ( 'trash' === $post -> post_status ) {
$actions [ 'untrash' ] = sprintf (
'<a href="%s" aria-label="%s">%s</a>' ,
wp_nonce_url ( admin_url ( sprintf ( $post_type_object -> _edit_link . '&action=untrash' , $post -> ID ) ), 'untrash-post_' . $post -> ID ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Restore “%s” from the Trash' ), $title ) ),
__ ( 'Restore' )
);
} elseif ( EMPTY_TRASH_DAYS ) {
$actions [ 'trash' ] = sprintf (
'<a href="%s" class="submitdelete" aria-label="%s">%s</a>' ,
get_delete_post_link ( $post -> ID ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Move “%s” to the Trash' ), $title ) ),
_x ( 'Trash' , 'verb' )
);
}
if ( 'trash' === $post -> post_status || ! EMPTY_TRASH_DAYS ) {
$actions [ 'delete' ] = sprintf (
'<a href="%s" class="submitdelete" aria-label="%s">%s</a>' ,
get_delete_post_link ( $post -> ID , '' , true ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Delete “%s” permanently' ), $title ) ),
__ ( 'Delete Permanently' )
);
}
}
if ( is_post_type_viewable ( $post_type_object ) ) {
if ( in_array ( $post -> post_status , array ( 'pending' , 'draft' , 'future' ) ) ) {
if ( $can_edit_post ) {
2019-04-16 19:56:22 +00:00
$preview_link = get_preview_post_link ( $post );
2019-03-12 09:27:46 +00:00
$actions [ 'view' ] = sprintf (
'<a href="%s" rel="bookmark" aria-label="%s">%s</a>' ,
esc_url ( $preview_link ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Preview “%s”' ), $title ) ),
__ ( 'Preview' )
);
}
} elseif ( 'trash' != $post -> post_status ) {
$actions [ 'view' ] = sprintf (
'<a href="%s" rel="bookmark" aria-label="%s">%s</a>' ,
get_permalink ( $post -> ID ),
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'View “%s”' ), $title ) ),
__ ( 'View' )
);
}
}
if ( 'wp_block' === $post -> post_type ) {
$actions [ 'export' ] = sprintf (
'<button type="button" class="wp-list-reusable-blocks__export button-link" data-id="%s" aria-label="%s">%s</button>' ,
$post -> ID ,
/* translators: %s: post title */
esc_attr ( sprintf ( __ ( 'Export “%s” as JSON' ), $title ) ),
__ ( 'Export as JSON' )
);
}
if ( is_post_type_hierarchical ( $post -> post_type ) ) {
/**
* Filters the array of row action links on the Pages list table .
*
* The filter is evaluated only for hierarchical post types .
*
* @ since 2.8 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $actions An array of row action links . Defaults are
* 'Edit' , 'Quick Edit' , 'Restore' , 'Trash' ,
* 'Delete Permanently' , 'Preview' , and 'View' .
* @ param WP_Post $post The post object .
2019-03-12 09:27:46 +00:00
*/
$actions = apply_filters ( 'page_row_actions' , $actions , $post );
} else {
/**
* Filters the array of row action links on the Posts list table .
*
* The filter is evaluated only for non - hierarchical post types .
*
* @ since 2.8 . 0
*
2019-04-16 19:56:22 +00:00
* @ param string [] $actions An array of row action links . Defaults are
* 'Edit' , 'Quick Edit' , 'Restore' , 'Trash' ,
* 'Delete Permanently' , 'Preview' , and 'View' .
* @ param WP_Post $post The post object .
2019-03-12 09:27:46 +00:00
*/
$actions = apply_filters ( 'post_row_actions' , $actions , $post );
}
return $this -> row_actions ( $actions );
}
/**
* Outputs the hidden row displayed when inline editing
*
* @ since 3.1 . 0
*
* @ global string $mode List table view mode .
*/
public function inline_edit () {
global $mode ;
$screen = $this -> screen ;
2019-04-16 19:56:22 +00:00
$post = get_default_post_to_edit ( $screen -> post_type );
2019-03-12 09:27:46 +00:00
$post_type_object = get_post_type_object ( $screen -> post_type );
2019-04-16 19:56:22 +00:00
$taxonomy_names = get_object_taxonomies ( $screen -> post_type );
2019-03-12 09:27:46 +00:00
$hierarchical_taxonomies = array ();
2019-04-16 19:56:22 +00:00
$flat_taxonomies = array ();
2019-03-12 09:27:46 +00:00
foreach ( $taxonomy_names as $taxonomy_name ) {
$taxonomy = get_taxonomy ( $taxonomy_name );
$show_in_quick_edit = $taxonomy -> show_in_quick_edit ;
/**
* Filters whether the current taxonomy should be shown in the Quick Edit panel .
*
* @ since 4.2 . 0
*
* @ param bool $show_in_quick_edit Whether to show the current taxonomy in Quick Edit .
* @ param string $taxonomy_name Taxonomy name .
* @ param string $post_type Post type of current Quick Edit post .
*/
if ( ! apply_filters ( 'quick_edit_show_taxonomy' , $show_in_quick_edit , $taxonomy_name , $screen -> post_type ) ) {
continue ;
}
2019-04-16 19:56:22 +00:00
if ( $taxonomy -> hierarchical ) {
2019-03-12 09:27:46 +00:00
$hierarchical_taxonomies [] = $taxonomy ;
2019-04-16 19:56:22 +00:00
} else {
2019-03-12 09:27:46 +00:00
$flat_taxonomies [] = $taxonomy ;
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
}
2019-04-16 19:56:22 +00:00
$m = ( isset ( $mode ) && 'excerpt' === $mode ) ? 'excerpt' : 'list' ;
$can_publish = current_user_can ( $post_type_object -> cap -> publish_posts );
$core_columns = array (
'cb' => true ,
'date' => true ,
'title' => true ,
'categories' => true ,
'tags' => true ,
'comments' => true ,
'author' => true ,
);
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< form method = " get " >< table style = " display: none " >< tbody id = " inlineedit " >
< ? php
2019-04-16 19:56:22 +00:00
$hclass = count ( $hierarchical_taxonomies ) ? 'post' : 'page' ;
2019-03-12 09:27:46 +00:00
$inline_edit_classes = " inline-edit-row inline-edit-row- $hclass " ;
$bulk_edit_classes = " bulk-edit-row bulk-edit-row- $hclass bulk-edit- { $screen -> post_type } " ;
$quick_edit_classes = " quick-edit-row quick-edit-row- $hclass inline-edit- { $screen -> post_type } " ;
$bulk = 0 ;
2019-04-16 19:56:22 +00:00
while ( $bulk < 2 ) {
?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< tr id = " <?php echo $bulk ? 'bulk-edit' : 'inline-edit'; ?> " class = "
< ? php
echo $inline_edit_classes . ' ' ;
echo $bulk ? $bulk_edit_classes : $quick_edit_classes ;
?>
" style= " display : none " ><td colspan= " < ? php echo $this -> get_column_count (); ?> " class="colspanchange">
2019-03-12 09:27:46 +00:00
< fieldset class = " inline-edit-col-left " >
< legend class = " inline-edit-legend " >< ? php echo $bulk ? __ ( 'Bulk Edit' ) : __ ( 'Quick Edit' ); ?> </legend>
< div class = " inline-edit-col " >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( post_type_supports ( $screen -> post_type , 'title' ) ) :
if ( $bulk ) :
?>
2019-03-12 09:27:46 +00:00
< div id = " bulk-title-div " >
< div id = " bulk-titles " ></ div >
</ div >
2019-04-16 19:56:22 +00:00
< ? php else : // $bulk ?>
2019-03-12 09:27:46 +00:00
< label >
< span class = " title " >< ? php _e ( 'Title' ); ?> </span>
< span class = " input-text-wrap " >< input type = " text " name = " post_title " class = " ptitle " value = " " /></ span >
</ label >
2019-04-16 19:56:22 +00:00
< ? php if ( is_post_type_viewable ( $screen -> post_type ) ) : // is_post_type_viewable check ?>
2019-03-12 09:27:46 +00:00
< label >
< span class = " title " >< ? php _e ( 'Slug' ); ?> </span>
< span class = " input-text-wrap " >< input type = " text " name = " post_name " value = " " /></ span >
</ label >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
endif ; // is_post_type_viewable check
endif ; // $bulk
endif ; // post_type_supports title
?>
2019-04-16 19:56:22 +00:00
< ? php if ( ! $bulk ) : ?>
2019-03-12 09:27:46 +00:00
< fieldset class = " inline-edit-date " >
< legend >< span class = " title " >< ? php _e ( 'Date' ); ?> </span></legend>
< ? php touch_time ( 1 , 1 , 0 , 1 ); ?>
</ fieldset >
< br class = " clear " />
2019-04-16 19:56:22 +00:00
< ? php
endif ; // $bulk
if ( post_type_supports ( $screen -> post_type , 'author' ) ) :
$authors_dropdown = '' ;
if ( current_user_can ( $post_type_object -> cap -> edit_others_posts ) ) :
$users_opt = array (
'hide_if_only_one_author' => false ,
'who' => 'authors' ,
'name' => 'post_author' ,
'class' => 'authors' ,
'multi' => 1 ,
'echo' => 0 ,
'show' => 'display_name_with_login' ,
);
if ( $bulk ) {
$users_opt [ 'show_option_none' ] = __ ( '— No Change —' );
}
if ( $authors = wp_dropdown_users ( $users_opt ) ) :
$authors_dropdown = '<label class="inline-edit-author">' ;
$authors_dropdown .= '<span class="title">' . __ ( 'Author' ) . '</span>' ;
$authors_dropdown .= $authors ;
$authors_dropdown .= '</label>' ;
endif ;
endif ; // authors
?>
< ? php
if ( ! $bulk ) {
echo $authors_dropdown ;}
2019-03-12 09:27:46 +00:00
endif ; // post_type_supports author
2019-04-16 19:56:22 +00:00
if ( ! $bulk && $can_publish ) :
?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< div class = " inline-edit-group wp-clearfix " >
< label class = " alignleft " >
< span class = " title " >< ? php _e ( 'Password' ); ?> </span>
< span class = " input-text-wrap " >< input type = " text " name = " post_password " class = " inline-edit-password-input " value = " " /></ span >
</ label >
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< em class = " alignleft inline-edit-or " >
< ? php
/* translators: Between password field and private checkbox on post quick edit interface */
_e ( '–OR–' );
?>
2019-03-12 09:27:46 +00:00
</ em >
< label class = " alignleft inline-edit-private " >
2019-04-16 19:56:22 +00:00
< input type = " checkbox " name = " keep_private " value = " private " />
< span class = " checkbox-title " >< ? php _e ( 'Private' ); ?> </span>
2019-03-12 09:27:46 +00:00
</ label >
</ div >
2019-04-16 19:56:22 +00:00
< ? php endif ; ?>
2019-03-12 09:27:46 +00:00
</ div ></ fieldset >
2019-04-16 19:56:22 +00:00
< ? php if ( count ( $hierarchical_taxonomies ) && ! $bulk ) : ?>
2019-03-12 09:27:46 +00:00
< fieldset class = " inline-edit-col-center inline-edit-categories " >< div class = " inline-edit-col " >
2019-04-16 19:56:22 +00:00
< ? php foreach ( $hierarchical_taxonomies as $taxonomy ) : ?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< span class = " title inline-edit-categories-label " >< ? php echo esc_html ( $taxonomy -> labels -> name ); ?> </span>
2019-03-12 09:27:46 +00:00
< input type = " hidden " name = " <?php echo ( $taxonomy->name === 'category' ) ? 'post_category[]' : 'tax_input[' . esc_attr( $taxonomy->name ) . '][]'; ?> " value = " 0 " />
2019-04-16 19:56:22 +00:00
< ul class = " cat-checklist <?php echo esc_attr( $taxonomy->name ); ?>-checklist " >
< ? php wp_terms_checklist ( null , array ( 'taxonomy' => $taxonomy -> name ) ); ?>
2019-03-12 09:27:46 +00:00
</ ul >
< ? php endforeach ; //$hierarchical_taxonomies as $taxonomy ?>
</ div ></ fieldset >
< ? php endif ; // count( $hierarchical_taxonomies ) && !$bulk ?>
< fieldset class = " inline-edit-col-right " >< div class = " inline-edit-col " >
2019-04-16 19:56:22 +00:00
< ? php
if ( post_type_supports ( $screen -> post_type , 'author' ) && $bulk ) {
echo $authors_dropdown ;
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( post_type_supports ( $screen -> post_type , 'page-attributes' ) ) :
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( $post_type_object -> hierarchical ) :
?>
< label >
< span class = " title " >< ? php _e ( 'Parent' ); ?> </span>
< ? php
$dropdown_args = array (
'post_type' => $post_type_object -> name ,
'selected' => $post -> post_parent ,
'name' => 'post_parent' ,
'show_option_none' => __ ( 'Main Page (no parent)' ),
'option_none_value' => 0 ,
'sort_column' => 'menu_order, post_title' ,
);
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( $bulk ) {
$dropdown_args [ 'show_option_no_change' ] = __ ( '— No Change —' );
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
/**
* Filters the arguments used to generate the Quick Edit page - parent drop - down .
*
* @ since 2.7 . 0
*
* @ see wp_dropdown_pages ()
*
* @ param array $dropdown_args An array of arguments .
*/
$dropdown_args = apply_filters ( 'quick_edit_dropdown_pages_args' , $dropdown_args );
wp_dropdown_pages ( $dropdown_args );
?>
</ label >
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< ? php
endif ; // hierarchical
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( ! $bulk ) :
?>
2019-03-12 09:27:46 +00:00
< label >
< span class = " title " >< ? php _e ( 'Order' ); ?> </span>
2019-04-16 19:56:22 +00:00
< span class = " input-text-wrap " >< input type = " text " name = " menu_order " class = " inline-edit-menu-order-input " value = " <?php echo $post->menu_order ; ?> " /></ span >
2019-03-12 09:27:46 +00:00
</ label >
2019-04-16 19:56:22 +00:00
< ? php
endif ; // !$bulk
2019-03-12 09:27:46 +00:00
endif ; // page-attributes
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< ? php if ( 0 < count ( get_page_templates ( null , $screen -> post_type ) ) ) : ?>
2019-03-12 09:27:46 +00:00
< label >
< span class = " title " >< ? php _e ( 'Template' ); ?> </span>
< select name = " page_template " >
2019-04-16 19:56:22 +00:00
< ? php if ( $bulk ) : ?>
2019-03-12 09:27:46 +00:00
< option value = " -1 " >< ? php _e ( '— No Change —' ); ?> </option>
2019-04-16 19:56:22 +00:00
< ? php endif ; // $bulk ?>
< ? php
2019-03-12 09:27:46 +00:00
/** This filter is documented in wp-admin/includes/meta-boxes.php */
2019-04-16 19:56:22 +00:00
$default_title = apply_filters ( 'default_page_template_title' , __ ( 'Default Template' ), 'quick-edit' );
?>
2019-03-12 09:27:46 +00:00
< option value = " default " >< ? php echo esc_html ( $default_title ); ?> </option>
2019-04-16 19:56:22 +00:00
< ? php page_template_dropdown ( '' , $screen -> post_type ); ?>
2019-03-12 09:27:46 +00:00
</ select >
</ label >
< ? php endif ; ?>
2019-04-16 19:56:22 +00:00
< ? php if ( count ( $flat_taxonomies ) && ! $bulk ) : ?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< ? php foreach ( $flat_taxonomies as $taxonomy ) : ?>
< ? php
if ( current_user_can ( $taxonomy -> cap -> assign_terms ) ) :
$taxonomy_name = esc_attr ( $taxonomy -> name );
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< label class = " inline-edit-tags " >
2019-04-16 19:56:22 +00:00
< span class = " title " >< ? php echo esc_html ( $taxonomy -> labels -> name ); ?> </span>
2019-03-12 09:27:46 +00:00
< textarea data - wp - taxonomy = " <?php echo $taxonomy_name ; ?> " cols = " 22 " rows = " 1 " name = " tax_input[<?php echo $taxonomy_name ; ?>] " class = " tax_input_<?php echo $taxonomy_name ; ?> " ></ textarea >
</ label >
2019-04-16 19:56:22 +00:00
< ? php endif ; ?>
2019-03-12 09:27:46 +00:00
< ? php endforeach ; //$flat_taxonomies as $taxonomy ?>
2019-04-16 19:56:22 +00:00
< ? php endif ; // count( $flat_taxonomies ) && !$bulk ?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< ? php
if ( post_type_supports ( $screen -> post_type , 'comments' ) || post_type_supports ( $screen -> post_type , 'trackbacks' ) ) :
if ( $bulk ) :
?>
2019-03-12 09:27:46 +00:00
< div class = " inline-edit-group wp-clearfix " >
2019-04-16 19:56:22 +00:00
< ? php if ( post_type_supports ( $screen -> post_type , 'comments' ) ) : ?>
2019-03-12 09:27:46 +00:00
< label class = " alignleft " >
< span class = " title " >< ? php _e ( 'Comments' ); ?> </span>
< select name = " comment_status " >
< option value = " " >< ? php _e ( '— No Change —' ); ?> </option>
< option value = " open " >< ? php _e ( 'Allow' ); ?> </option>
< option value = " closed " >< ? php _e ( 'Do not allow' ); ?> </option>
</ select >
</ label >
< ? php endif ; if ( post_type_supports ( $screen -> post_type , 'trackbacks' ) ) : ?>
< label class = " alignright " >
< span class = " title " >< ? php _e ( 'Pings' ); ?> </span>
< select name = " ping_status " >
< option value = " " >< ? php _e ( '— No Change —' ); ?> </option>
< option value = " open " >< ? php _e ( 'Allow' ); ?> </option>
< option value = " closed " >< ? php _e ( 'Do not allow' ); ?> </option>
</ select >
</ label >
< ? php endif ; ?>
</ div >
2019-04-16 19:56:22 +00:00
< ? php else : // $bulk ?>
2019-03-12 09:27:46 +00:00
< div class = " inline-edit-group wp-clearfix " >
2019-04-16 19:56:22 +00:00
< ? php if ( post_type_supports ( $screen -> post_type , 'comments' ) ) : ?>
2019-03-12 09:27:46 +00:00
< label class = " alignleft " >
< input type = " checkbox " name = " comment_status " value = " open " />
< span class = " checkbox-title " >< ? php _e ( 'Allow Comments' ); ?> </span>
</ label >
< ? php endif ; if ( post_type_supports ( $screen -> post_type , 'trackbacks' ) ) : ?>
< label class = " alignleft " >
< input type = " checkbox " name = " ping_status " value = " open " />
< span class = " checkbox-title " >< ? php _e ( 'Allow Pings' ); ?> </span>
</ label >
< ? php endif ; ?>
</ div >
2019-04-16 19:56:22 +00:00
< ? php
endif ; // $bulk
endif ; // post_type_supports comments or pings
?>
2019-03-12 09:27:46 +00:00
< div class = " inline-edit-group wp-clearfix " >
< label class = " inline-edit-status alignleft " >
< span class = " title " >< ? php _e ( 'Status' ); ?> </span>
< select name = " _status " >
2019-04-16 19:56:22 +00:00
< ? php if ( $bulk ) : ?>
2019-03-12 09:27:46 +00:00
< option value = " -1 " >< ? php _e ( '— No Change —' ); ?> </option>
< ? php endif ; // $bulk ?>
< ? php if ( $can_publish ) : // Contributors only get "Unpublished" and "Pending Review" ?>
< option value = " publish " >< ? php _e ( 'Published' ); ?> </option>
< option value = " future " >< ? php _e ( 'Scheduled' ); ?> </option>
2019-04-16 19:56:22 +00:00
< ? php if ( $bulk ) : ?>
< option value = " private " >< ? php _e ( 'Private' ); ?> </option>
2019-03-12 09:27:46 +00:00
< ? php endif ; // $bulk ?>
< ? php endif ; ?>
< option value = " pending " >< ? php _e ( 'Pending Review' ); ?> </option>
< option value = " draft " >< ? php _e ( 'Draft' ); ?> </option>
</ select >
</ label >
2019-04-16 19:56:22 +00:00
< ? php if ( 'post' === $screen -> post_type && $can_publish && current_user_can ( $post_type_object -> cap -> edit_others_posts ) ) : ?>
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
< ? php if ( $bulk ) : ?>
2019-03-12 09:27:46 +00:00
< label class = " alignright " >
< span class = " title " >< ? php _e ( 'Sticky' ); ?> </span>
< select name = " sticky " >
< option value = " -1 " >< ? php _e ( '— No Change —' ); ?> </option>
< option value = " sticky " >< ? php _e ( 'Sticky' ); ?> </option>
< option value = " unsticky " >< ? php _e ( 'Not Sticky' ); ?> </option>
</ select >
</ label >
< ? php else : // $bulk ?>
< label class = " alignleft " >
< input type = " checkbox " name = " sticky " value = " sticky " />
< span class = " checkbox-title " >< ? php _e ( 'Make this post sticky' ); ?> </span>
</ label >
< ? php endif ; // $bulk ?>
< ? php endif ; // 'post' && $can_publish && current_user_can( 'edit_others_cap' ) ?>
</ div >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( $bulk && current_theme_supports ( 'post-formats' ) && post_type_supports ( $screen -> post_type , 'post-formats' ) ) {
$post_formats = get_theme_support ( 'post-formats' );
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< label class = " alignleft " >
< span class = " title " >< ? php _ex ( 'Format' , 'post format' ); ?> </span>
< select name = " post_format " >
< option value = " -1 " >< ? php _e ( '— No Change —' ); ?> </option>
< option value = " 0 " >< ? php echo get_post_format_string ( 'standard' ); ?> </option>
2019-04-16 19:56:22 +00:00
< ? php
if ( is_array ( $post_formats [ 0 ] ) ) {
foreach ( $post_formats [ 0 ] as $format ) {
?>
2019-03-12 09:27:46 +00:00
< option value = " <?php echo esc_attr( $format ); ?> " >< ? php echo esc_html ( get_post_format_string ( $format ) ); ?> </option>
2019-04-16 19:56:22 +00:00
< ? php
}
2019-03-12 09:27:46 +00:00
}
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
</ select ></ label >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
</ div ></ fieldset >
2019-04-16 19:56:22 +00:00
< ? php
list ( $columns ) = $this -> get_column_info ();
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
foreach ( $columns as $column_name => $column_display_name ) {
if ( isset ( $core_columns [ $column_name ] ) ) {
continue ;
}
2019-03-12 09:27:46 +00:00
2019-04-16 19:56:22 +00:00
if ( $bulk ) {
/**
* Fires once for each column in Bulk Edit mode .
*
* @ since 2.7 . 0
*
* @ param string $column_name Name of the column to edit .
* @ param WP_Post $post_type The post type slug .
*/
do_action ( 'bulk_edit_custom_box' , $column_name , $screen -> post_type );
} else {
/**
* Fires once for each column in Quick Edit mode .
*
* @ since 2.7 . 0
*
* @ param string $column_name Name of the column to edit .
* @ param string $post_type The post type slug , or current screen name if this is a taxonomy list table .
* @ param string taxonomy The taxonomy name , if any .
*/
do_action ( 'quick_edit_custom_box' , $column_name , $screen -> post_type , '' );
}
2019-03-12 09:27:46 +00:00
}
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
< div class = " submit inline-edit-save " >
< button type = " button " class = " button cancel alignleft " >< ? php _e ( 'Cancel' ); ?> </button>
2019-04-16 19:56:22 +00:00
< ? php
if ( ! $bulk ) {
2019-03-12 09:27:46 +00:00
wp_nonce_field ( 'inlineeditnonce' , '_inline_edit' , false );
?>
< button type = " button " class = " button button-primary save alignright " >< ? php _e ( 'Update' ); ?> </button>
< span class = " spinner " ></ span >
2019-04-16 19:56:22 +00:00
< ? php
} else {
2019-03-12 09:27:46 +00:00
submit_button ( __ ( 'Update' ), 'primary alignright' , 'bulk_edit' , false );
2019-04-16 19:56:22 +00:00
}
?>
2019-03-12 09:27:46 +00:00
< input type = " hidden " name = " post_view " value = " <?php echo esc_attr( $m ); ?> " />
< input type = " hidden " name = " screen " value = " <?php echo esc_attr( $screen->id ); ?> " />
< ? php if ( ! $bulk && ! post_type_supports ( $screen -> post_type , 'author' ) ) { ?>
< input type = " hidden " name = " post_author " value = " <?php echo esc_attr( $post->post_author ); ?> " />
< ? php } ?>
< br class = " clear " />
< div class = " notice notice-error notice-alt inline hidden " >
< p class = " error " ></ p >
</ div >
</ div >
</ td ></ tr >
2019-04-16 19:56:22 +00:00
< ? php
$bulk ++ ;
2019-03-12 09:27:46 +00:00
}
2019-04-16 19:56:22 +00:00
?>
2019-03-12 09:27:46 +00:00
</ tbody ></ table ></ form >
2019-04-16 19:56:22 +00:00
< ? php
2019-03-12 09:27:46 +00:00
}
}