टैक्सोनॉमी में मेटाबॉक्स को जोड़ने का एक सरल लेकिन पूर्ण उदाहरण की आवश्यकता है


18

अब जब वर्डप्रेस 4.4 बाहर है, तो हम नए भयानक शब्द मेटा फ़ंक्शंस का उपयोग करना शुरू कर सकते हैं!

फिर भी, एक टैक्नोनामी में एक मूल पाठ क्षेत्र को जोड़ने के तरीके पर कोई सरल ट्यूटोरियल नहीं है। मैंने जस्टिन टडलॉक द्वारा इस भयानक ट्यूटोरियल को अपनी आवश्यकताओं के अनुरूप ढालने की कोशिश की, रंग बीनने वाले से संबंधित सभी कोड को हटा दिया और इसे एक साधारण पाठ इनपुट फ़ील्ड के साथ बदल दिया ... लेकिन यह काम नहीं कर रहा है।

किसी को एक नंगे हड्डियों काम कोड नमूना प्रदान कर सकता है? डेटा सत्यापन, बिना निशान, रंग बीनने वाले के बिना ... केवल एक न्यूनतम टेक्स्ट बॉक्स, Add taxonomy / Edit taxonomy पेज पर जोड़ा गया।

अद्यतन: इस बीच, मैंने इस कोड स्निपेट के कुछ बदलाव किए:

श्रेणी में शब्द मेटा फ़ील्ड जोड़ें :
https://gist.github.com/ms-studio/543a0f7dd8ac05ccf037

पोस्ट टैग में शब्द मेटा फ़ील्ड जोड़ें :
https://gist.github.com/ms-studio/2d78ad3839e05ece2e48

कस्टम टैक्सोनॉमी में शब्द मेटा फ़ील्ड जोड़ें :
https://gist.github.com/ms-studio/fc21fd5720f5bbdfaddc

कस्टम टैक्सोनॉमी में कई शब्द मेटा फ़ील्ड जोड़ें : https://gist.github.com/ms-studio/aeae733f5fd9fc524bbc


कृपया अपना वर्तमान कोड स्निपेट पोस्ट करें और यह कैसे विफल हो जाता है।
बीरगीर

@birgire को अपने मूल कोड को पोस्ट न करने के लिए खेद है, लेकिन यह पहले से ही गड़बड़ था, और मैं इसके बजाय एक स्वच्छ उदाहरण से शुरू करूंगा।
मनु

जवाबों:


13

यह आपकी श्रेणियों में 'TERM META TEXT' नामक एक फ़ील्ड जोड़ देगा। मैंने गैर को बाहर निकाल लिया, लेकिन मुझे वास्तव में लगता है कि इसे वापस जाना चाहिए। इसके अलावा, यह बेहतर है कि कुछ विमुद्रीकरण बनाम कुछ भी न हो। इस उदाहरण में जावास्क्रिप्ट और सीएसएस हुक शामिल हैं जिनकी आपको आवश्यकता हो सकती है या नहीं लेकिन आप जल्दी से देख सकते हैं कि सभी भाग एक साथ कैसे चलते हैं।

का आनंद लें!

// REGISTER TERM META

add_action( 'init', '___register_term_meta_text' );

function ___register_term_meta_text() {

    register_meta( 'term', '__term_meta_text', '___sanitize_term_meta_text' );
}

// SANITIZE DATA

function ___sanitize_term_meta_text ( $value ) {
    return sanitize_text_field ($value);
}

// GETTER (will be sanitized)

function ___get_term_meta_text( $term_id ) {
  $value = get_term_meta( $term_id, '__term_meta_text', true );
  $value = ___sanitize_term_meta_text( $value );
  return $value;
}

// ADD FIELD TO CATEGORY TERM PAGE

add_action( 'category_add_form_fields', '___add_form_field_term_meta_text' );

function ___add_form_field_term_meta_text() { ?>
    <?php wp_nonce_field( basename( __FILE__ ), 'term_meta_text_nonce' ); ?>
    <div class="form-field term-meta-text-wrap">
        <label for="term-meta-text"><?php _e( 'TERM META TEXT', 'text_domain' ); ?></label>
        <input type="text" name="term_meta_text" id="term-meta-text" value="" class="term-meta-text-field" />
    </div>
<?php }


// ADD FIELD TO CATEGORY EDIT PAGE

add_action( 'category_edit_form_fields', '___edit_form_field_term_meta_text' );

function ___edit_form_field_term_meta_text( $term ) {

    $value  = ___get_term_meta_text( $term->term_id );

    if ( ! $value )
        $value = ""; ?>

    <tr class="form-field term-meta-text-wrap">
        <th scope="row"><label for="term-meta-text"><?php _e( 'TERM META TEXT', 'text_domain' ); ?></label></th>
        <td>
            <?php wp_nonce_field( basename( __FILE__ ), 'term_meta_text_nonce' ); ?>
            <input type="text" name="term_meta_text" id="term-meta-text" value="<?php echo esc_attr( $value ); ?>" class="term-meta-text-field"  />
        </td>
    </tr>
<?php }


// SAVE TERM META (on term edit & create)

add_action( 'edit_category',   '___save_term_meta_text' );
add_action( 'create_category', '___save_term_meta_text' );

function ___save_term_meta_text( $term_id ) {

    // verify the nonce --- remove if you don't care
    if ( ! isset( $_POST['term_meta_text_nonce'] ) || ! wp_verify_nonce( $_POST['term_meta_text_nonce'], basename( __FILE__ ) ) )
        return;

    $old_value  = ___get_term_meta_text( $term_id );
    $new_value = isset( $_POST['term_meta_text'] ) ? ___sanitize_term_meta_text ( $_POST['term_meta_text'] ) : '';


    if ( $old_value && '' === $new_value )
        delete_term_meta( $term_id, '__term_meta_text' );

    else if ( $old_value !== $new_value )
        update_term_meta( $term_id, '__term_meta_text', $new_value );
}

// MODIFY COLUMNS (add our meta to the list)

add_filter( 'manage_edit-category_columns', '___edit_term_columns' );

function ___edit_term_columns( $columns ) {

    $columns['__term_meta_text'] = __( 'TERM META TEXT', 'text_domain' );

    return $columns;
}

// RENDER COLUMNS (render the meta data on a column)

add_filter( 'manage_category_custom_column', '___manage_term_custom_column', 10, 3 );

function ___manage_term_custom_column( $out, $column, $term_id ) {

    if ( '__term_meta_text' === $column ) {

        $value  = ___get_term_meta_text( $term_id );

        if ( ! $value )
            $value = '';

        $out = sprintf( '<span class="term-meta-text-block" style="" >%s</div>', esc_attr( $value ) );
    }

    return $out;
}

// ADD JAVASCRIPT & STYLES TO COLUMNS

add_action( 'admin_enqueue_scripts', '___admin_enqueue_scripts' );

function ___admin_enqueue_scripts( $hook_suffix ) {

    if ( 'edit-tags.php' !== $hook_suffix || 'category' !== get_current_screen()->taxonomy )
        return;

    // ADD YOUR SUPPORTING CSS / JS FILES HERE
    // wp_enqueue_style( 'wp-color-picker' );
    // wp_enqueue_script( 'wp-color-picker' );

    add_action( 'admin_head',   '___meta_term_text_print_styles' );
    add_action( 'admin_footer', '___meta_term_text_print_scripts' );
}

// PRINT OUR CUSTOM STYLES

function ___meta_term_text_print_styles() { ?>

    <style type="text/css">
        .column-__term_meta_text { background-color:rgb(249, 249, 249); border: 1px solid lightgray;}
        .column-__term_meta_text .term-meta-text-block { display: inline-block; color:darkturquoise; }
    </style>
<?php }

// PRINT OUR CUSTOM SCRIPTS

function ___meta_term_text_print_scripts() { ?>

    <script type="text/javascript">
        jQuery( document ).ready( function( $ ) {
             $input_field = $( '.term-meta-text-field' );
             // console.log($input_field); // your input field
        } );
    </script>
<?php }

बहुत बहुत धन्यवाद, यह वास्तव में उपयोगी है! लेकिन जब-जब कोड लागू होता है, मैं एक समस्या का सामना करता हूं: टर्म मेटा टेक्स्ट फ़ील्ड को अपडेट किया जाता है जब कोई शब्द संशोधित किया जाता है, लेकिन जब एक शब्द बनाया जाता है तो उसे सहेजा नहीं जाता है।
मनु

मैंने एक और परीक्षण साइट पर कोशिश की, और एक ही व्यवहार देखा - ठीक काम करने वाला सब कुछ, शब्द निर्माण पर छोड़कर, मेटा पाठ सहेजा नहीं गया था। मैंने अंदर गैर सत्यापन को अक्षम कर दिया ___save_term_meta_text( $term_id )... और इस समस्या को ठीक कर दिया, एक नया शब्द बनाते समय मेटा पाठ सहेजा गया है! मैं आपके उत्तर को स्वीकार कर रहा हूं, क्योंकि यह वही प्रदान करता है जो मुझे आरंभ करने की आवश्यकता है।
मनु

1
मैं बस समझ गया कि इस मुद्दे का क्या कारण है: गैर को ___add_form_field_term_meta_text()फ़ंक्शन में परिभाषित नहीं किया जा रहा था । इसे जोड़ने के बाद, सभी अपेक्षा के अनुरूप काम करते हैं।
मनु

1
WP के पहले से ही कुछ को रखा गया है क्योंकि अतिरिक्त nonces के साथ प्रदूषित करने की कोई जरूरत नहीं है। बस करना check_admin_referer( 'add-tag', '_wpnonce_add-tag' );और check_admin_referer( 'update-tag_' . (int) $_POST['tag_ID'] )में 'edit_category'और 'category_category'कार्रवाई।
ज़्लाटेव

यह ध्यान देने योग्य है कि आपके ___register_term_meta_text()फ़ंक्शन में, तीसरे पैरामीटर को हटा दिया गया है और इसके बजाय एक सरणी के साथ बदल दिया गया है। आपको कुछ इस तरह का उपयोग करना होगा:$args = array( 'type' => 'string', 'description' => 'A text field', 'single' => 'false', 'sanitize_callback' => '___sanitize_term_meta_weare_product', 'auth_callback' => null, 'show_in_rest' => false, ); register_meta( 'term', '__term_meta_text', $args );
फ्रिट्स
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.