Как добавить в админку сортировку по произвольным полям

Как добавить в админку сортировку по произвольным полям | n-wp.ru

В административной части при просмотре всех записей можно пользоваться фильтрами – выбирать посты за определенную дату, опубликованные в определенной категории. Но многие используют так же и произвольные поля, и было бы неплохо научить WordPress фильтровать посты и по ним.

Как добавить в админку сортировку по произвольным полям

Давайте добавим в блог такую возможность. Для этого откройте файл functions.php используемой вами темы, и добавьте в него следующий код:

add_filter( 'parse_query', 'ba_admin_posts_filter' );
add_action( 'restrict_manage_posts', 'ba_admin_posts_filter_restrict_manage_posts' );
function ba_admin_posts_filter( $query )
{
    global $pagenow;
    if ( is_admin() && $pagenow=='edit.php' && isset($_GET['ADMIN_FILTER_FIELD_NAME']) && $_GET['ADMIN_FILTER_FIELD_NAME'] != '') {
        $query->query_vars['meta_key'] = $_GET['ADMIN_FILTER_FIELD_NAME'];
    if (isset($_GET['ADMIN_FILTER_FIELD_VALUE']) && $_GET['ADMIN_FILTER_FIELD_VALUE'] != '')
        $query->query_vars['meta_value'] = $_GET['ADMIN_FILTER_FIELD_VALUE'];
    }
}
function ba_admin_posts_filter_restrict_manage_posts()
{
    global $wpdb;
    $sql = 'SELECT DISTINCT meta_key FROM '.$wpdb->postmeta.' ORDER BY 1';
    $fields = $wpdb->get_results($sql, ARRAY_N);
?>


<?php
    $current = isset($_GET['ADMIN_FILTER_FIELD_NAME'])? $_GET['ADMIN_FILTER_FIELD_NAME']:'';
    $current_v = isset($_GET['ADMIN_FILTER_FIELD_VALUE'])? $_GET['ADMIN_FILTER_FIELD_VALUE']:'';
    foreach ($fields as $field) {
        if (substr($field[0],0,1) != "_"){
        printf
            (
                '%s',
                $field[0],
                $field[0] == $current? ' selected="selected"':'',
                $field[0]
            );
        }
    }
?>
 <input type="TEXT" name="ADMIN_FILTER_FIELD_VALUE" value="" />
<?php
}

Ну вот теперь, если вы активно используете произвольные поля, то можете по ним фильтровать все записи.

Автор tiaurus 2182 Articles
Являюсь создателем n-wp.ru — блога о WordPress для новичков. Мне интересно многое, поэтому еще я сделал 123-box.ru — блог о программах для Windows, и tiaurus.info — блог о красоте.

6 Комментарии

  1. использую для постовых на ГГЛ произвольное поле “postovoy”. как переиначить этот код, чтобы в админке я мог фильтровать те страницы, на которых уже есть это поле? Благодарю.

      • отфильтровал по полю “postovoy”. можно ли инвертировать? чтобы видеть, какие страницы я в данный момент могу подпортить постовым?:)

Оставить комментарий

Ваш электронный адрес не будет опубликован.


*