Как фильтровать список записей (в панели управления WordPress) используя произвольное поле (функционал поиска)?

7 мая 2011 г., 14:41:35
Просмотры: 28.8K
Голосов: 41

Несмотря на то, что я много искал в Google, я не нашел ответа на очень простой вопрос:

У меня есть записи с произвольным полем (например, supplier_name). Я хотел бы иметь возможность искать и фильтровать мои записи в соответствии с этим произвольным полем. Другими словами, в списке записей админ-панели я хотел бы иметь поле поиска (названное "Имя поставщика"), где я могу ввести значение (например, "IBM"), а затем нажать на кнопку поиска, которая вернет мне все записи, у которых есть произвольное поле с названием "supplier_name" и значением "IBM".

Как это можно реализовать?

0
Все ответы на вопрос 1
4
46

Я закодировал плагин специально для этого, но так и не нашел времени его опубликовать:

Скриншот интерфейса фильтрации по произвольным полям

Использование:

В выпадающем списке вы видите список всех произвольных полей. Просто выберите поле, по которому хотите фильтровать, и нажмите "Фильтр". Если вам нужно отфильтровать записи по конкретному значению произвольного поля, выберите имя поля, введите нужное значение и нажмите "Фильтр".

<?php
/*
Plugin Name: Admin Filter BY Custom Fields
Plugin URI: http://en.bainternet.info
Description: Фильтрация записей или страниц в админке по произвольным полям (post meta)
Version: 1.0
Author: Bainternet
Author URI: http://en.bainternet.info
*/

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);
?>
<select name="ADMIN_FILTER_FIELD_NAME">
<option value=""><?php _e('Фильтровать по произвольным полям', 'baapf'); ?></option>
<?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
            (
                '<option value="%s"%s>%s</option>',
                $field[0],
                $field[0] == $current? ' selected="selected"':'',
                $field[0]
            );
        }
    }
?>
</select> <?php _e('Значение:', 'baapf'); ?><input type="TEXT" name="ADMIN_FILTER_FIELD_VALUE" value="<?php echo $current_v; ?>" />
<?php
}
7 мая 2011 г. 18:06:15
Комментарии

Почему бы не использовать вспомогательную функцию для вашего выпадающего списка? Например, заменить $field[0] == $current? ' selected="selected"':'', на selected( $field[0] == $current, true, false ), ... :)

t31os t31os
18 июл. 2011 г. 17:44:27

этот ответ больше не работает.

Kir Mazur Kir Mazur
9 июл. 2018 г. 22:48:01

Есть ли способ заставить это работать в новых версиях WordPress?

nakkeru nakkeru
27 нояб. 2018 г. 13:30:52

У меня есть пользовательская таблица (Имя таблицы: ssl_transaction_cus) в базе данных, которая используется для хранения информации о пожертвованиях. Я вывел все данные из этой таблицы на 'странице меню администратора' в виде таблицы (с использованием тега Table). Я хотел бы иметь возможность фильтровать эти данные по 'Названию мероприятия'.

Я пытаюсь сделать это согласно этому ответу. Но там есть код для пользовательских записей или постов. У меня нет CPT для этих данных, только пользовательские данные. Я пытаюсь уже долгое время, но не могу добиться успеха. Пожалуйста, посмотрите https://wordpress.stackexchange.com/questions/408599/how-to-filter-with-dropdown-in-backend-for-custom-data

Kaizur Kaizur
15 авг. 2022 г. 11:15:34