Get pages by author[s]. Props westi. fixes #1486
git-svn-id: http://svn.automattic.com/wordpress/trunk@4180 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
3964d277ce
commit
e02c90116e
|
@ -265,7 +265,7 @@ function wp_list_pages($args = '') {
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
|
||||||
$defaults = array('depth' => 0, 'show_date' => '', 'date_format' => get_option('date_format'),
|
$defaults = array('depth' => 0, 'show_date' => '', 'date_format' => get_option('date_format'),
|
||||||
'child_of' => 0, 'title_li' => __('Pages'), 'echo' => 1);
|
'child_of' => 0, 'title_li' => __('Pages'), 'echo' => 1, 'authors' => '');
|
||||||
$r = array_merge($defaults, $r);
|
$r = array_merge($defaults, $r);
|
||||||
|
|
||||||
$output = '';
|
$output = '';
|
||||||
|
|
|
@ -1037,7 +1037,7 @@ function &get_pages($args = '') {
|
||||||
parse_str($args, $r);
|
parse_str($args, $r);
|
||||||
|
|
||||||
$defaults = array('child_of' => 0, 'sort_order' => 'ASC', 'sort_column' => 'post_title',
|
$defaults = array('child_of' => 0, 'sort_order' => 'ASC', 'sort_column' => 'post_title',
|
||||||
'hierarchical' => 1, 'exclude' => '', 'include' => '', 'meta_key' => '', 'meta_value' => '');
|
'hierarchical' => 1, 'exclude' => '', 'include' => '', 'meta_key' => '', 'meta_value' => '', 'authors' => '');
|
||||||
$r = array_merge($defaults, $r);
|
$r = array_merge($defaults, $r);
|
||||||
extract($r);
|
extract($r);
|
||||||
|
|
||||||
|
@ -1075,10 +1075,37 @@ function &get_pages($args = '') {
|
||||||
if (!empty($exclusions))
|
if (!empty($exclusions))
|
||||||
$exclusions .= ')';
|
$exclusions .= ')';
|
||||||
|
|
||||||
|
$author_query = '';
|
||||||
|
if (!empty($authors)) {
|
||||||
|
$post_authors = preg_split('/[\s,]+/',$authors);
|
||||||
|
|
||||||
|
if ( count($post_authors) ) {
|
||||||
|
foreach ( $post_authors as $post_author ) {
|
||||||
|
//Do we have an author id or an author login?
|
||||||
|
if ( 0 == intval($post_author) ) {
|
||||||
|
$post_author = get_userdatabylogin($post_author);
|
||||||
|
if ( empty($post_author) )
|
||||||
|
continue;
|
||||||
|
if ( empty($post_author->ID) )
|
||||||
|
continue;
|
||||||
|
$post_author = $post_author->ID;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( '' == $author_query )
|
||||||
|
$author_query = ' post_author = ' . intval($post_author) . ' ';
|
||||||
|
else
|
||||||
|
$author_query .= ' OR post_author = ' . intval($post_author) . ' ';
|
||||||
|
}
|
||||||
|
if ( '' != $author_query )
|
||||||
|
$author_query = " AND ($author_query)";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$query = "SELECT * FROM $wpdb->posts " ;
|
$query = "SELECT * FROM $wpdb->posts " ;
|
||||||
$query .= ( empty( $meta_key ) ? "" : ", $wpdb->postmeta " ) ;
|
$query .= ( empty( $meta_key ) ? "" : ", $wpdb->postmeta " ) ;
|
||||||
$query .= " WHERE (post_type = 'page' AND post_status = 'publish') $exclusions $inclusions " ;
|
$query .= " WHERE (post_type = 'page' AND post_status = 'publish') $exclusions $inclusions " ;
|
||||||
$query .= ( empty( $meta_key ) | empty($meta_value) ? "" : " AND ($wpdb->posts.ID = $wpdb->postmeta.post_id AND $wpdb->postmeta.meta_key = '$meta_key' AND $wpdb->postmeta.meta_value = '$meta_value' )" ) ;
|
$query .= ( empty( $meta_key ) | empty($meta_value) ? "" : " AND ($wpdb->posts.ID = $wpdb->postmeta.post_id AND $wpdb->postmeta.meta_key = '$meta_key' AND $wpdb->postmeta.meta_value = '$meta_value' )" ) ;
|
||||||
|
$query .= $author_query;
|
||||||
$query .= " ORDER BY " . $sort_column . " " . $sort_order ;
|
$query .= " ORDER BY " . $sort_column . " " . $sort_order ;
|
||||||
|
|
||||||
$pages = $wpdb->get_results($query);
|
$pages = $wpdb->get_results($query);
|
||||||
|
|
Loading…
Reference in New Issue