প্রশাসক পৃষ্ঠায় কাস্টম পোস্ট প্রকারে কাস্টম ফিল্ড দ্বারা ফিল্টার


11

আমি প্রতিযোগিতার নাম, উত্তর ইত্যাদির জন্য কাস্টম ক্ষেত্রগুলি তৈরি করতে উন্নত কাস্টম ক্ষেত্রগুলি ব্যবহার করেছি আমি প্রতিযোগিতার জন্য ছবিতে প্রদর্শিত কাস্টম পোস্ট টাইপ করেছি এবং আমার কাস্টম ক্ষেত্রের মানগুলি থেকে কলামগুলি তৈরি করতে আমি ওয়ার্ডপ্রেস ফাংশন.এফপি ব্যবহার করেছি।

আমি নীচে দেখানো মত বিভিন্ন নাম / লেবেলগুলির সাথে প্রতিযোগিতা সহ "ফিল্টার বাই" -ডাবডাউন বাক্সটি পাওয়ার চেষ্টা করছি, তবে আমি কেবলমাত্র ট্যাক্সনোমি ব্যবহার করে সমাধান পেতে পারি, যা সম্ভব হলে আমি ব্যবহার করতে পারি না কারণ আমি কেবলমাত্র কাস্টম ক্ষেত্র ব্যবহার করেছি অন্য সব কিছুর.

কেবলমাত্র কাস্টম ক্ষেত্রগুলি ব্যবহার করে কী ড্রপডাউন করে "ফিল্টার বাই ফিল্টার" করা সম্ভব?

দ্বারা ওয়ার্ডপ্রেস ফিল্টার


restrict_manage_postsঅতিরিক্ত ড্রপডাউন বাক্স যুক্ত করতে আপনি ক্রিয়া হুকটি ব্যবহার করতে পারেন । ভুলে যাবেন না যে আপনাকে ফিল্টারটির জন্য কিছু যুক্তিও যুক্ত করতে হবে, যদিও ডাব্লুপিই জানবে না যে এটি বাক্সের বাইরে কী করবে (ট্যাক্সোনমি ড্রপডাউন তালিকার বিপরীতে যা এটি স্বয়ংক্রিয়ভাবে পরিচালনা করতে পারে)।
ডেভিড গার্ড

অতিরিক্ত চিন্তা হিসাবে - আপনি যদি চান, আপনি নিজের তালিকা সারণির সাথে লিঙ্ক করতে নামটি তৈরি করতে পারেন , যার অর্থ আপনি ড্রপডাউন না করে নামটিতে ক্লিক করে একটি প্রতিযোগিতা ফিল্টার করতে পারেন।
ডেভিড গার্ড

উত্তর:


12

এবং ফিল্টার জন্য ফলাফল প্রদর্শন করার জন্য এই কোড চেষ্টা করুন

add_filter( 'parse_query', 'prefix_parse_filter' );
function  prefix_parse_filter($query) {
   global $pagenow;
   $current_page = isset( $_GET['post_type'] ) ? $_GET['post_type'] : '';

   if ( is_admin() && 
     'competition' == $current_page &&
     'edit.php' == $pagenow && 
      isset( $_GET['competition-name'] ) && 
      $_GET['competition-name'] != '') {

    $competion_name = $_GET['competition-name'];
    $query->query_vars['meta_key'] = 'competition_name';
    $query->query_vars['meta_value'] = $competition_name;
    $query->query_vars['meta_compare'] = '=';
  }
}

প্রয়োজনীয় হিসাবে মেটা কী এবং মেটা মান পরিবর্তন করুন। আমি "মেটা_কি হিসাবে প্রতিযোগিতার নাম এবং নির্বাচনী ড্রপ ডাউন নাম হিসাবে" প্রতিযোগিতার নাম "নিয়েছি।


ভাল লাগল, আমি অলস বোধ করছিলাম তাই তিনি একটি অতিরিক্ত প্রশ্ন জিজ্ঞাসা করার পরামর্শ দিলেন;)
ডেভিড গার্ড

2 টি উত্তর মত একটি সম্পূর্ণ উত্তর এবং একত্রিত করা উচিত বলে মনে হচ্ছে।
আরসিএনিল

10

Restrict_manage_posts কর্ম আরম্ভ করে add_extra_tablenav()ফাংশন, যা কিভাবে আপনি আপনার পছন্দসই তালিকা ছক অতিরিক্ত dropdowns যোগ করুন।

নীচের উদাহরণে, আমরা প্রথমে পোস্ট প্রকারটি সঠিক কিনা তা নিশ্চিত করি এবং তারপরে আমরা টেবিলের 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>';

}

এটি ব্যবহার করার সময়, আমি ত্রুটিটি Notice: wpdb::prepare was called incorrectly. The query does not contain the correct number of placeholders (6) for the number of arguments passed (5). Please see Debugging in WordPress for more information. (This message was added in version 4.8.3.) in /[...]/wp-includes/functions.php on line 4773
পেয়েছি

আমিও একই ত্রুটি
পাচ্ছি

0

যদি এটি কারও পক্ষে কাজ করে না, আমার সমাধানটির প্রয়োজন ছিল যে কলামটি আমি কাস্টম পোস্টের ধরণের জন্য বাছাইযোগ্য কলামগুলির তালিকায় ফিল্টার করার চেষ্টা করছিলাম।

// Make Custom Post Type Custom Columns Sortable
function cpt_custom_columns_sortable( $columns ) {

    // Add our columns to $columns array
    $columns['item_number'] = 'item_number';
    $columns['coat_school'] = 'coat_school'; 

    return $columns;
} add_filter( 'manage_edit-your-custom-post-type-slug_sortable_columns', 'cpt_custom_columns_sortable' );

0

ডাব্লুপিডিবি সংশোধন করতে নীচের ক্যোয়ারীটি প্রতিস্থাপন করুন: ত্রুটি প্রস্তুত করুন:

$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,
        'competition_name' //this is needed a second time to define "%3$s" in ORDER BY
  );
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.