добавить категорию в столбце администратора для пользовательского типа сообщения?


13

Я создал пользовательский тип записи под названием article, и информация, представленная на сводном экране администратора, немногочисленна. Мне удалось добавить миниатюрное изображение после публикации, используя http://codex.wordpress.org/Plugin_API/Action_Reference/manage_posts_custom_column из учебника.

Однако я хотел бы получить возможность ознакомиться с категориями и подкатегориями, которые были назначены этим сообщениям на странице администратора. т.е. добавление столбца для этой части?

Вот код, который я использовал для регистрации таксономии в коде пользовательских типов записей


Вы можете использовать плагин, такой как Codepress Admin Columns
fregante

Ответы:


18

Функция register_taxonomy имеет вызываемый параметр, show_admin_columnкоторый будет обрабатывать добавление столбца. Вы пробовали это?

например:

register_taxonomy(
    'my_tax, 
    'post_type', 
    array(
        'label'             => 'My Taxonomy',
        'show_admin_column' => true,
        )
);

1
Пожалуйста, добавьте код и объясните, как его использовать. Если вы просто хотите что-то спросить у ОП, используйте комментарии.
cybmeta

6

После некоторых поисков я нашел решение, используя manage_edit-${post_type}_columnsфильтр и manage_${post_type}_posts_custom_columnдействие.

Столбцы создаются с помощью фильтра, а затем столбец заполняется действием. Я предполагаю, что дополнительные столбцы могут быть добавлены и заполнены довольно легко, используя идеи в этой ссылке http://justintadlock.com/archives/2011/06/27/custom-columns-for-custom-post-types

add_filter('manage_edit-article_columns', 'my_columns');
function my_columns($columns) {
    $columns['article_category'] = 'Category';
return $columns;
}

add_action( 'manage_article_posts_custom_column', 'my_manage_article_columns', 10, 2 );

function my_manage_article_columns( $column, $post_id ) {
global $post;

switch( $column ) {

    /* If displaying the 'article_category' column. */
    case 'article_category' :

        /* Get the genres for the post. */
        $terms = get_the_terms( $post_id, 'article_category' );

        /* If terms were found. */
        if ( !empty( $terms ) ) {

            $out = array();

            /* Loop through each term, linking to the 'edit posts' page for the specific term. */
            foreach ( $terms as $term ) {
                $out[] = sprintf( '<a href="%s">%s</a>',
                    esc_url( add_query_arg( array( 'post_type' => $post->post_type, 'article_category' => $term->slug ), 'edit.php' ) ),
                    esc_html( sanitize_term_field( 'name', $term->name, $term->term_id, 'article_category', 'display' ) )
                );
            }

            /* Join the terms, separating them with a comma. */
            echo join( ', ', $out );
        }

        /* If no terms were found, output a default message. */
        else {
            _e( 'No Articles' );
        }

        break;

    /* Just break out of the switch statement for everything else. */
    default :
        break;
}
}
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.