adicionando a categoria à coluna admin para um tipo de postagem personalizado?


13

Criei um tipo de postagem personalizado chamado article e as informações fornecidas na tela de resumo do administrador são escassas. Consegui adicionar a imagem em miniatura da postagem da imagem em destaque usando o http://codex.wordpress.org/Plugin_API/Action_Reference/manage_posts_custom_column em um tutorial.

No entanto, eu gostaria de obter uma visão geral das categorias e subcategorias que essas postagens lhes atribuíram na página de administração. ou seja, adicionar uma coluna para essa parte?

Aqui está o código que eu usei para registrar a taxonomia no código de tipos de postagem personalizados


Você pode usar um plugin como o Codepress Admin Columns
fregante 26/03

Respostas:


18

A função register_taxonomy possui um parâmetro chamado show_admin_columnque manipulará a adição de uma coluna. Você já tentou isso?

por exemplo:

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

1
Por favor, adicione código e explique como usá-lo responde à pergunta. Se você quiser apenas pedir algo ao OP, use os comentários.
cybmeta

6

Após algumas pesquisas, encontrei uma solução usando o manage_edit-${post_type}_columnsfiltro e a manage_${post_type}_posts_custom_columnação.

As colunas são criadas com o filtro e, em seguida, a coluna é preenchida com a ação. Presumo que colunas adicionais possam ser adicionadas e preenchidas facilmente usando as idéias neste link 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;
}
}
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.