私はマルチユーザーのWordPressセットアップに取り組んでいて、特定のタイプのユーザーが彼らが書いた投稿、画像、ページなどを見ることができるようにしました。これを実現するためのコードは次のようになります。
add_filter('pre_get_posts', 'current_author_posts');
function current_author_posts($query) {
if ($query->is_admin && current_user_can('artist')) {
global $user_ID;
$query->set('author', $user_ID);
}
return $query;
}
これは管理インターフェース内ではうまく機能しますが、投稿数のすべてが誤って表示されたままになります。
これらの数字を操作したり、投稿、ページ、メディア、カスタム投稿の種類を問わずに正しいフィルタやフックを知っていますか。
どうもありがとう。
これはほとんどうまくいきましたが、質問の詳細に合わせて添付ファイルと投稿タイプを異なる方法で処理するには改良が必要です(コード内のコメントを参照)...
まず、フィルタの見つけ方に注目する価値があると思います。apply_filters( 'views_' . $screen->id, $views )
要素を検査する
/wp-admin
と/wp-includes
で subsubsub (面白いクラス名、btw)をグローバルに検索します。
/wp-admin/includes/class-wp-list-table.php
foreach( array( 'edit-post', 'edit-page', 'edit-movie', 'upload' ) as $hook )
add_filter( "views_$hook" , 'wpse_30331_custom_view_count', 10, 1);
function wpse_30331_custom_view_count( $views )
{
global $current_screen;
switch( $current_screen->id )
{
case 'edit-post':
$views = wpse_30331_manipulate_views( 'post', $views );
break;
case 'edit-page':
$views = wpse_30331_manipulate_views( 'page', $views );
break;
case 'edit-movie':
$views = wpse_30331_manipulate_views( 'movie', $views );
break;
case 'upload':
$views = wpse_30331_manipulate_views( 'attachment', $views );
break;
}
return $views;
}
function wpse_30331_manipulate_views( $what, $views )
{
global $user_ID, $wpdb;
/*
* This is not working for me, 'artist' and 'administrator' are passing this condition (?)
*/
if ( !current_user_can('artist') )
return $views;
/*
* This needs refining, and maybe a better method
* e.g. Attachments have completely different counts
*/
$total = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE (post_status = 'publish' OR post_status = 'draft' OR post_status = 'pending') AND (post_author = '$user_ID' AND post_type = '$what' ) ");
$publish = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE post_status = 'publish' AND post_author = '$user_ID' AND post_type = '$what' ");
$draft = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE post_status = 'draft' AND post_author = '$user_ID' AND post_type = '$what' ");
$pending = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->posts WHERE post_status = 'pending' AND post_author = '$user_ID' AND post_type = '$what' ");
/*
* Only tested with Posts/Pages
* - there are moments where Draft and Pending shouldn't return any value
*/
$views['all'] = preg_replace( '/\(.+\)/U', '('.$total.')', $views['all'] );
$views['publish'] = preg_replace( '/\(.+\)/U', '('.$publish.')', $views['publish'] );
$views['draft'] = preg_replace( '/\(.+\)/U', '('.$draft.')', $views['draft'] );
$views['pending'] = preg_replace( '/\(.+\)/U', '('.$pending.')', $views['pending'] );
// Debug info
//echo 'Default counts: <pre>'.print_r($views,true).'</pre>';
//echo '<hr><hr>';
//echo 'Query for this screen of this post_type: <b>'.$what.'</b><pre>'.print_r($wp_query,true).'</pre>';
return $views;
}
これを書いている時点で、この機能は現在メソッド "views()"内のクラスWP_List_Tableにあります。
フィルタは次のようになりました。
$views = apply_filters( "views_{$this->screen->id}", $views );
$ viewsは各リスト要素の配列を含みます。
[19-Feb-2016 11:43:44 UTC] Array
(
[all] => <a href="link_to_view" class="current">Alle <span class="count">(1)</span></a>
[trash] => <a href="link_to_view">Trash <span class="count">(94)</span></a>
[confirmed] => <a href="link_to_view">Confirmed <span class="count">(1)</span></a>
)
優先度> 10でcurrent_screenフックにフックすることができます。
add_action( 'current_screen', function ( $current_screen ) {
if ($current_screen->id === 'edit-my_page')
add_filter( "views_{$current_screen->id}", 'list_table_views_filter' );
}, 20);
function list_table_views_filter( array $view ) {
error_log(print_r($view, true));
return $view;
}
その後、リスト内の要素を追加/変更/削除することができます。