เพิ่มเขตข้อมูลไปยังหน้าจอแก้ไขหมวดหมู่แท็กและภาษีแบบกำหนดเองในผู้ดูแลระบบ WordPress หรือไม่


33

คำถามคือ " ฉันจะเพิ่มหนึ่งหรือหลายฟิลด์ในหน้าจอแก้ไขหมวดหมู่แท็กและภาษีแบบกำหนดเองใน WordPress Admin ได้อย่างไร " คำถามนี้ถูกถามในรายการ wp-hackers 1 สิงหาคม 2010 และฉันเสนอวิธีแก้ปัญหาในภายหลังในวันนั้น ผู้ถามเดิมพูดคุยเกี่ยวกับปัญหาอีกครั้งในวันนี้ (21 ส.ค. ) ซึ่งทำให้ฉันนึกถึงวิธีแก้ปัญหา เนื่องจากอาจเป็นความต้องการทั่วไปฉันจึงตัดสินใจโพสต์โซลูชันรวมถึงโค้ดที่นี่เพื่อให้คนอื่น ๆ ค้นพบในอนาคต


สวัสดีไมค์ฉันคิดว่ามันจะดีกว่าถ้าคุณโพสต์รหัสในกล่องคำตอบ ด้วยวิธีนี้เรามีการสำรองที่นี่ในกรณีที่ gitHub ลง
ariefbayu

@silent: เฮ้ฉันกำลังทำมันอยู่ :) ฉันทำไปครึ่งทางแล้ว แต่ฉันก็ชนกำแพงแล้วต้องนอน นี่คือสิ่งที่มันจะดูเหมือน (บางสิ่ง) เมื่อฉันทำ: wordpress.stackexchange.com/questions/578/#582
MikeSchinkel

มีการพัฒนาเพิ่มเติมเกี่ยวกับสิ่งนี้หรือไม่? จริง ๆ แล้วฉันสนใจ ... : D
John P Bloch

เฮ้@John P Bloch : ลูกค้าของฉันตรึงฉันไว้และแค่ไม่มีเวลา หวังว่าในไม่ช้า ...
MikeSchinkel

@John P Bloch ฉันลองแล้วมันใช้งานได้ดีฉันต้อง 'จัดกลุ่ม' หมวดหมู่ที่ไม่มีหมวดหมู่ของผู้ปกครอง
Amit

คำตอบ:


23

ฉันเพิ่มฟิลด์ 'รูปภาพ' ใหม่ (ไฟล์ประเภทอินพุต) ในหมวดหมู่ด้วยความช่วยเหลือของสิ่งเหล่านี้

add_action('category_edit_form_fields','category_edit_form_fields');
add_action('category_edit_form', 'category_edit_form');
add_action('category_add_form_fields','category_edit_form_fields');
add_action('category_add_form','category_edit_form');


function category_edit_form() {
?>
<script type="text/javascript">
jQuery(document).ready(function(){
jQuery('#edittag').attr( "enctype", "multipart/form-data" ).attr( "encoding", "multipart/form-data" );
        });
</script>
<?php 
}

function category_edit_form_fields () {
?>
    <tr class="form-field">
            <th valign="top" scope="row">
                <label for="catpic"><?php _e('Picture of the category', ''); ?></label>
            </th>
            <td>
                <input type="file" id="catpic" name="catpic"/>
            </td>
        </tr>
        <?php 
    }

คุณมีอิสระที่จะใช้อนุกรมวิธานใด ๆ เพียงแค่เปลี่ยนcategoryเป็นชื่ออนุกรมวิธานของคุณ


นี่เป็นสิ่งที่ยอดเยี่ยม แต่คุณช่วยอธิบาย (หรือให้ตัวอย่าง) วิธีที่จะรวมการปรับแต่งนี้ได้อย่างถูกต้องถ้าคุณต้องการเพิ่มสิ่งนี้ลงในอนุกรมวิธานที่กำหนดเอง - ตัวอย่างเช่น "คน"
NetConstructor.com

2
อัปเดต - แม้ว่าฉันได้คัดลอกรหัสที่แน่นอนของคุณด้านบนเพื่อทดสอบไฟล์นี้ดูเหมือนจะไม่ถูกบันทึกหรืออย่างน้อยก็ไม่ปรากฏขึ้น คุณช่วยอธิบายได้ว่าไฟล์บันทึกอยู่ที่ไหนการแก้ไขสิทธิ์ของโฟลเดอร์นั้นต้องแก้ไข (หรือดีกว่าคุณสามารถอธิบายว่าจะแก้ไขตำแหน่งของโฟลเดอร์ที่บันทึกไว้ได้อย่างไร) เมื่อฉันเลือกไฟล์แล้วพยายามบันทึกคำที่บันทึกทุกอย่างยกเว้นไฟล์และดังนั้นจึงไม่แสดงรูปภาพที่อัปโหลด
NetConstructor.com

9

นอกจากนี้หากคุณต้องการเพิ่มเขตข้อมูลนั้นลงในแบบฟอร์ม taxonomy แบบกำหนดเองคุณเพียงแค่แทนที่หมวดหมู่ด้วยชื่อ taxonomy แบบกำหนดเองในadd_actionฟังก์ชัน

ตัวอย่าง:

add_action('{custom_taxonomy}_edit_form_fields','category_edit_form_fields');
add_action('{custom_taxonomy}_edit_form', 'category_edit_form');
add_action('{custom_taxonomy}_add_form_fields','category_edit_form_fields');
add_action('{custom_taxonomy}_add_form','category_edit_form');

2

สำหรับผู้ที่ต้องการขอลงในช่องฟอร์มแท็กเบ็ดจะแตกต่างกันเล็กน้อย

add_tag_form_fields

แทน tag_add_form_fields อย่างที่คุณคาดหวัง


1

ฉันรู้ว่าสิ่งนี้ถูกถามเมื่อไม่นานมานี้ แต่ WordPress ได้เปลี่ยนแปลงไปเล็กน้อยตั้งแต่นั้นมาฉันจึงตัดสินใจพัฒนาสคริปต์ขนาดเล็กที่ทำให้กระบวนการเพิ่มเขตข้อมูลที่กำหนดเองใน taxonomies ง่ายขึ้นและช่วยให้คุณเพิ่มคอลัมน์ลงในตารางข้อกำหนดสำหรับแต่ละฟิลด์ สคริปต์นี้เรียกว่าamarkal-taxonomyและเป็นส่วนหนึ่งของกรอบงานAmarkal WordPress

การใช้การamarkal-taxonomyเพิ่มฟิลด์ที่กำหนดเองจะช่วยให้:

// Add a text field to the 'category' taxonomy 'add' & 'edit' forms:
amarkal_taxonomy_add_field('category', 'cat_icon', array(
    'type'        => 'text',
    'label'       => 'Icon',
    'description' => 'The category\'s icon',
    'table'       => array(
        'show'      => true,  // Add a column to the terms table
        'sortable'  => true   // Make that column sortable
    )
));

// Then you can retrieve the data using:
$icon = get_term_meta( $term_id, 'cat_icon', true );

1

ฉันได้เพิ่มการเพิ่มภาพและลบภาพพิเศษยื่นลงในอนุกรมวิธานที่กำหนดเองซึ่งเป็นชื่อประกัน

/**
 * Plugin class
 **/
if ( ! class_exists( 'CT_TAX_META' ) ) {

class CT_TAX_META {

  public function __construct() {
    //
  }

 /*
  * Initialize the class and start calling our hooks and filters
  * @since 1.0.0
 */
 public function init() {
   add_action( 'insurance_add_form_fields', array ( $this, 'add_category_image' ), 10, 2 );
   add_action( 'created_insurance', array ( $this, 'save_category_image' ), 10, 2 );
   add_action( 'insurance_edit_form_fields', array ( $this, 'update_category_image' ), 10, 2 );
   add_action( 'edited_insurance', array ( $this, 'updated_category_image' ), 10, 2 );
   add_action( 'admin_enqueue_scripts', array( $this, 'load_media' ) );
   add_action( 'admin_footer', array ( $this, 'add_script' ) );
 }

public function load_media() {
 wp_enqueue_media();
}

 /*
  * Add a form field in the new category page
  * @since 1.0.0
 */
 public function add_category_image ( $taxonomy ) { ?>
   <div class="form-field term-group">
     <label for="category-image-id"><?php _e('Image', 'hero-theme'); ?></label>
     <input type="hidden" id="category-image-id" name="category-image-id" class="custom_media_url" value="">
     <div id="category-image-wrapper"></div>
     <p>
       <input type="button" class="button button-secondary ct_tax_media_button" id="ct_tax_media_button" name="ct_tax_media_button" value="<?php _e( 'Add Image', 'hero-theme' ); ?>" />
       <input type="button" class="button button-secondary ct_tax_media_remove" id="ct_tax_media_remove" name="ct_tax_media_remove" value="<?php _e( 'Remove Image', 'hero-theme' ); ?>" />
    </p>
   </div>
 <?php
 }

 /*
  * Save the form field
  * @since 1.0.0
 */
 public function save_category_image ( $term_id, $tt_id ) {
   if( isset( $_POST['category-image-id'] ) && '' !== $_POST['category-image-id'] ){
     $image = $_POST['category-image-id'];
     add_term_meta( $term_id, 'category-image-id', $image, true );
   }
 }

 /*
  * Edit the form field
  * @since 1.0.0
 */
 public function update_category_image ( $term, $taxonomy ) { ?>
   <tr class="form-field term-group-wrap">
     <th scope="row">
       <label for="category-image-id"><?php _e( 'Image', 'hero-theme' ); ?></label>
     </th>
     <td>
       <?php $image_id = get_term_meta ( $term -> term_id, 'category-image-id', true ); ?>
       <input type="hidden" id="category-image-id" name="category-image-id" value="<?php echo $image_id; ?>">
       <div id="category-image-wrapper">
         <?php if ( $image_id ) { ?>
           <?php echo wp_get_attachment_image ( $image_id, 'thumbnail' ); ?>
         <?php } ?>
       </div>
       <p>
         <input type="button" class="button button-secondary ct_tax_media_button" id="ct_tax_media_button" name="ct_tax_media_button" value="<?php _e( 'Add Image', 'hero-theme' ); ?>" />
         <input type="button" class="button button-secondary ct_tax_media_remove" id="ct_tax_media_remove" name="ct_tax_media_remove" value="<?php _e( 'Remove Image', 'hero-theme' ); ?>" />
       </p>
     </td>
   </tr>
 <?php
 }

/*
 * Update the form field value
 * @since 1.0.0
 */
 public function updated_category_image ( $term_id, $tt_id ) {
   if( isset( $_POST['category-image-id'] ) && '' !== $_POST['category-image-id'] ){
     $image = $_POST['category-image-id'];
     update_term_meta ( $term_id, 'category-image-id', $image );
   } else {
     update_term_meta ( $term_id, 'category-image-id', '' );
   }
 }

/*
 * Add script
 * @since 1.0.0
 */
 public function add_script() { ?>
   <script>
     jQuery(document).ready( function($) {
       function ct_media_upload(button_class) {
         var _custom_media = true,
         _orig_send_attachment = wp.media.editor.send.attachment;
         $('body').on('click', button_class, function(e) {
           var button_id = '#'+$(this).attr('id');
           var send_attachment_bkp = wp.media.editor.send.attachment;
           var button = $(button_id);
           _custom_media = true;
           wp.media.editor.send.attachment = function(props, attachment){
             if ( _custom_media ) {
               $('#category-image-id').val(attachment.id);
               $('#category-image-wrapper').html('<img class="custom_media_image" src="" style="margin:0;padding:0;max-height:100px;float:none;" />');
               $('#category-image-wrapper .custom_media_image').attr('src',attachment.url).css('display','block');
             } else {
               return _orig_send_attachment.apply( button_id, [props, attachment] );
             }
            }
         wp.media.editor.open(button);
         return false;
       });
     }
     ct_media_upload('.ct_tax_media_button.button'); 
     $('body').on('click','.ct_tax_media_remove',function(){
       $('#category-image-id').val('');
       $('#category-image-wrapper').html('<img class="custom_media_image" src="" style="margin:0;padding:0;max-height:100px;float:none;" />');
     });
     // Thanks: http://stackoverflow.com/questions/15281995/wordpress-create-category-ajax-response
     $(document).ajaxComplete(function(event, xhr, settings) {
       var queryStringArr = settings.data.split('&');
       if( $.inArray('action=add-tag', queryStringArr) !== -1 ){
         var xml = xhr.responseXML;
         $response = $(xml).find('term_id').text();
         if($response!=""){
           // Clear the thumb image
           $('#category-image-wrapper').html('');
         }
       }
     });
   });
 </script>
 <?php }

  }

$CT_TAX_META = new CT_TAX_META();
$CT_TAX_META -> init();

}

หมายเหตุ: หากคุณต้องการเพิ่มฟิลด์นี้ลงใน taxonomy อื่นเช่นสำหรับประเภทโพสต์ที่กำหนดเองคุณจะต้องแทนที่การอ้างอิงไปยังหมวดหมู่ด้วยการอ้างอิงถึงทากอนุกรมวิธานของคุณเอง ตัวอย่างเช่นหากคุณเพิ่มสร้าง taxonomy ประเภทคุณจะขอฟังก์ชั่นนี้ผ่าน

add_action( 'taxonomy_add_form_fields', array ( $this, 'add_category_image' ), 10, 2 ).

บุ้งอนุกรมวิธานของฉันคือประกัน

add_action ('insurance_add_form_fields', อาร์เรย์ ($ this, 'add_category_image'), 10, 2);

ใช้รหัสนี้ในfunctions.phpไฟล์ของคุณ


0

คุณต้องเพิ่มรหัสของคุณลงในไฟล์ themes.php ของชุดรูปแบบของคุณ - และถ้าคุณต้องการเพิ่มเขตข้อมูลนั้นลงในแบบฟอร์ม taxonomy แบบกำหนดเองคุณเพียงแค่แทนที่หมวดหมู่ด้วยชื่อ taxonomy แบบกำหนดเองในฟังก์ชัน add_action ตัวอย่าง: add_action ('category_edit_form_fields', 'category_edit_form_fields'); จะเป็น add_action ('custom_taxonomy_name_form_fields', 'function_name_to_hook_on');


โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.