เพิ่มเมนูตัวกรองในรายการผู้ดูแลระบบของโพสต์ (ประเภทกำหนดเอง) เพื่อกรองโพสต์ตามค่าฟิลด์ที่กำหนดเอง


45

คำตอบนี้อยู่ใกล้กับสิ่งที่ฉันกำลังทำ แต่ฉันต้องการระบุเขตข้อมูลที่กำหนดเองโดยเฉพาะและแสดงเมนูเลือกของค่าที่มีอยู่ ขอบคุณ!


1
@soulseekah ไม่ถูกกฎหมายที่จะขอเส้นทางก่อนลองสิ่งของ?
frnhr

คำตอบ:


73

ง่าย ๆ ก่อนอื่นให้สร้างรายการแบบหล่นลงด้วยค่าเมตาที่คุณต้องการจากนั้นตรวจจับการส่งตัวกรองเพียงเปลี่ยนPOST_TYPEเป็นชื่อประเภทโพสต์และMETA_KEYชื่อเมตาคีย์ของคุณ:

<?php
/*
Plugin Name: Admin Filter BY Custom Fields
Plugin URI: http://en.bainternet.info
Description: answer to http://wordpress.stackexchange.com/q/45436/2487
Version: 1.0
Author: Bainternet
Author URI: http://en.bainternet.info
*/

add_action( 'restrict_manage_posts', 'wpse45436_admin_posts_filter_restrict_manage_posts' );
/**
 * First create the dropdown
 * make sure to change POST_TYPE to the name of your custom post type
 * 
 * @author Ohad Raz
 * 
 * @return void
 */
function wpse45436_admin_posts_filter_restrict_manage_posts(){
    $type = 'post';
    if (isset($_GET['post_type'])) {
        $type = $_GET['post_type'];
    }

    //only add filter to post type you want
    if ('POST_TYPE' == $type){
        //change this to the list of values you want to show
        //in 'label' => 'value' format
        $values = array(
            'label' => 'value', 
            'label1' => 'value1',
            'label2' => 'value2',
        );
        ?>
        <select name="ADMIN_FILTER_FIELD_VALUE">
        <option value=""><?php _e('Filter By ', 'wose45436'); ?></option>
        <?php
            $current_v = isset($_GET['ADMIN_FILTER_FIELD_VALUE'])? $_GET['ADMIN_FILTER_FIELD_VALUE']:'';
            foreach ($values as $label => $value) {
                printf
                    (
                        '<option value="%s"%s>%s</option>',
                        $value,
                        $value == $current_v? ' selected="selected"':'',
                        $label
                    );
                }
        ?>
        </select>
        <?php
    }
}


add_filter( 'parse_query', 'wpse45436_posts_filter' );
/**
 * if submitted filter by post meta
 * 
 * make sure to change META_KEY to the actual meta key
 * and POST_TYPE to the name of your custom post type
 * @author Ohad Raz
 * @param  (wp_query object) $query
 * 
 * @return Void
 */
function wpse45436_posts_filter( $query ){
    global $pagenow;
    $type = 'post';
    if (isset($_GET['post_type'])) {
        $type = $_GET['post_type'];
    }
    if ( 'POST_TYPE' == $type && is_admin() && $pagenow=='edit.php' && isset($_GET['ADMIN_FILTER_FIELD_VALUE']) && $_GET['ADMIN_FILTER_FIELD_VALUE'] != '') {
        $query->query_vars['meta_key'] = 'META_KEY';
        $query->query_vars['meta_value'] = $_GET['ADMIN_FILTER_FIELD_VALUE'];
    }
}

ยอดเยี่ยม ฉันมีปัญหาในการทำให้สิ่งนี้ปรากฏบนหน้าโพสต์ประเภท custtom ของฉัน (type = ผู้เข้าร่วมการแข่งขัน) คุณช่วยตรวจสอบรหัส function.php ของฉันได้ไหม สิ่งนี้นำมาจากปลั๊กอินที่มีอยู่หรือไม่ pastebin.com/BJMua8nq
adam5280

คุณไม่ได้เปลี่ยนที่POST_TYPEนี่ลองนี้: pastebin.com/tabUfh3Y
Bainternet

Works! ขอบคุณ @Bainternet! $ type = 'โพสต์'; ในบรรทัดที่ 65 จะต้องมีการเปลี่ยนแปลงเช่นกัน ขอบคุณอีกครั้ง!
adam5280

:) สิ่งเดียวที่คุณไม่จำเป็นต้องเปลี่ยนมีไว้สำหรับค่าเริ่มต้น แต่ก็ใช้ได้เช่นกัน
Bainternet

2
คำตอบนี้ใช้งานได้กับ WordPress 4.9.5! อายุมากแล้วขอบคุณมาก!
ดาวี่

1

หากคุณใช้แบบสอบถามอื่นภายในโปรดrestrict_manage_postsตรวจสอบให้แน่ใจว่าคุณเพิ่ม&& $query->is_main_query()คำสั่ง parse_query ถ้ามีคำสั่งมิฉะนั้นตัวกรอง parse_query จะรบกวนการค้นหาครั้งที่สอง

if ( 'POST_TYPE' == $type
      && is_admin()
      && $pagenow=='edit.php'
      && isset($_GET['ADMIN_FILTER_FIELD_VALUE'])
      && $_GET['ADMIN_FILTER_FIELD_VALUE'] != ''
      && $query->is_main_query()
) {
      $query->query_vars['meta_key'] = 'META_KEY';
      $query->query_vars['meta_value'] = $_GET['ADMIN_FILTER_FIELD_VALUE'];
}

0

หากคุณต้องเพิ่มเขตข้อมูลจำนวนมากคุณต้องเพิ่มในแบบสอบถาม

$query->query_vars['meta_query'][] = array(
    'key'     => 'KEY',
    'value'   => $_GET['FIELD'],
    'compare' => 'LIKE'
);
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.