Действие restrict_manage_posts вызывает add_extra_tablenav()
функцию, с помощью которой вы добавляете дополнительные выпадающие списки в желаемую таблицу списка.
В приведенном ниже примере мы сначала убедиться , что сообщение типа правильно, а затем захватить все значения DB , сохраненные против competition_name
ключа в postmeta
таблице (вы должны изменить имя ключа по мере необходимости). Запрос является довольно простым и проверяет только то, опубликовано ли соревнование , принимает ли только уникальные значения (вы не хотите дублировать в раскрывающемся списке), а затем упорядочивает их в алфавитном порядке.
Затем мы проверяем результаты (нет смысла выводить выпадающий список ни за что), а затем строим параметры (включая значение по умолчанию, чтобы показать все). Наконец, выпадающий список выводится.
Как указано в моем комментарии, это еще не конец истории; вам понадобится некоторая логика, чтобы сказать Таблице списков, чтобы она показывала желаемые результаты только тогда, когда фильтр активен, но я оставлю вас посмотреть на это, а затем начать другой вопрос, если вам потребуется дополнительная помощь. Подсказка - проверьте файл /wp-admin/includes/class-wp-posts-list-table.php
, и это родитель.../wp-class-list-table.php
/**
* Add extra dropdowns to the List Tables
*
* @param required string $post_type The Post Type that is being displayed
*/
add_action('restrict_manage_posts', 'add_extra_tablenav');
function add_extra_tablenav($post_type){
global $wpdb;
/** Ensure this is the correct Post Type*/
if($post_type !== 'competition')
return;
/** Grab the results from the DB */
$query = $wpdb->prepare('
SELECT DISTINCT pm.meta_value FROM %1$s pm
LEFT JOIN %2$s p ON p.ID = pm.post_id
WHERE pm.meta_key = "%3$s"
AND p.post_status = "%4$s"
AND p.post_type = "%5$s"
ORDER BY "%3$s"',
$wpdb->postmeta,
$wpdb->posts,
'competition_name', // Your meta key - change as required
'publish', // Post status - change as required
$post_type
);
$results = $wpdb->get_col($query);
/** Ensure there are options to show */
if(empty($results))
return;
// get selected option if there is one selected
if (isset( $_GET['competition-name'] ) && $_GET['competition-name'] != '') {
$selectedName = $_GET['competition-name'];
} else {
$selectedName = -1;
}
/** Grab all of the options that should be shown */
$options[] = sprintf('<option value="-1">%1$s</option>', __('All Competitions', 'your-text-domain'));
foreach($results as $result) :
if ($result == $selectedName) {
$options[] = sprintf('<option value="%1$s" selected>%2$s</option>', esc_attr($result), $result);
} else {
$options[] = sprintf('<option value="%1$s">%2$s</option>', esc_attr($result), $result);
}
endforeach;
/** Output the dropdown menu */
echo '<select class="" id="competition-name" name="competition-name">';
echo join("\n", $options);
echo '</select>';
}
restrict_manage_posts
ловушку действия, чтобы добавить дополнительные выпадающие списки. Не забывайте, что вам также необходимо добавить некоторую логику для фильтра, поскольку WP не будет знать, что с ним делать из коробки (в отличие от выпадающих списков таксономии, которые он может обрабатывать автоматически).