Дополнительные колонки в таблице админки USERS
Пробовал по аналогии с статьей Дополнительные колонки KAMA
Дошел до сортировки и стопронулся - где-то не туда делаю запрос, может те кто понимает , быстро покажут мне мой недочет . думаю что недочет в 4 часте, но где не пойму
(в дальнейшем буду добавлять сортируемую колонку даты регистрации ) - пробовал через плагин, все работает , но не все плагины и не для всех целей мне по ФЭНШУЮ!
// создаем новую колонку // Колонка только создается и будет пустая add_filter('manage_users_columns', 'add_wpfp_column_user_page', 4); function add_wpfp_column_user_page( $columns ){ $num = 2; // после какой по счету колонки вставлять новые $new_columns = array( 'wpfp_favorites_all' => 'Favorite', ); return array_slice( $columns, 0, $num ) + $new_columns + array_slice( $columns, $num ); } // заполняем колонку данными add_filter( 'manage_users_custom_column', 'add_wpfp_column_user_page_data', 10, 3 ); function add_wpfp_column_user_page_data( $val, $column_name, $user_id ){ $user_info = get_userdata($user_id ); $username = $user_info->user_login; switch ($column_name) { case 'wpfp_favorites_all' : return (int)count(wpfp_get_users_favorites( $username )); // выводятся , целые числа, от 1 до 4000 break; default: } return $val; } // добавляем возможность сортировать колонку add_filter('manage_users_sortable_columns', 'add_wpfp_sortable_column_data'); function add_wpfp_sortable_column_data($sortable_columns){ $sortable_columns['wpfp_favorites_all'] = array('wpfp_favorites_all_sort', desc ); // false = asc. desc - по умолчанию return $sortable_columns; } // Добавить запрос при сортировке колонки // без него нет никакой сортировки add_filter( 'request', 'add_column_wpfp_request_data' ); function add_column_wpfp_request_data( $vars ) { if ( 'wpfp_favorites_all_sort' == $vars['orderby'] ){ $vars['meta_key'] = 'wpfp_favorites_all'; $vars['orderby'] = 'meta_value_num'; } return $vars; }
вот для доп колонки даты регистрации код
/* * Create a column. And maybe remove some of the default ones * @param array $columns Array of all user table columns {column ID} => {column Name} */ add_filter( 'manage_users_columns', 'rudr_modify_user_table' ); function rudr_modify_user_table( $columns ) { // unset( $columns['posts'] ); // maybe you would like to remove default columns $columns['registration_date'] = 'Registration date'; // add new return $columns; } /* * Fill our new column with the registration dates of the users * @param string $row_output text/HTML output of a table cell * @param string $column_id_attr column ID * @param int $user user ID (in fact - table row ID) */ add_filter( 'manage_users_custom_column', 'rudr_modify_user_table_row', 10, 3 ); function rudr_modify_user_table_row( $row_output, $column_id_attr, $user ) { $date_format = 'j M, Y H:i'; switch ( $column_id_attr ) { case 'registration_date' : return date( $date_format, strtotime( get_the_author_meta( 'registered', $user ) ) ); break; default: } return $row_output; } /* * Make our "Registration date" column sortable * @param array $columns Array of all user sortable columns {column ID} => {orderby GET-param} */ add_filter( 'manage_users_sortable_columns', 'rudr_make_registered_column_sortable' ); function rudr_make_registered_column_sortable( $columns ) { return wp_parse_args( array( 'registration_date' => 'registered' ), $columns ); }
Согласен, для таких колонок плагин юзать не всегда хорошая идея!
В этой статье есть пример как изменять запрос. Там хук pre_get_users можно использовать.
Вот пример сортировки по метаплю rating:
По коду из вопроса я не понял, зачем дата реги берется через фукнцию, она ведь в основной таблице присутствует?
Бери проще, так и понятнее: $user->user_registered.
вопрос задан про колонку записей в избранном, а колонка про дату регистрации это дополнение к вопросу. Просто было желание добавить 2 колонки Избранные посты и дата регистрации - коды практически идентичные вот и объеденил в один вопрос
с датой регистрации все работает (столбики добавляются и сортируются) , с избранными , нет, не хватает у меня опыта, необходимо из базы извлекать ЦЫФРУ по "count(wpfp_get_users_favorites( $username ))" - потом её куда-то отдавать , короче пока не решил.
Судя по первому коду, который вроде как работает. Число храниться в метаполе wpfp_favorites_all, ты по нему пробовал сортировать. Звучит банально, но мало ли, может чет ты там затупил...