Existe uma maneira fácil de fazer uma caixa meta ter as guias como a caixa meta Categorias tem?

12

Minha pergunta é bem resumida no título. Estou lançando uma meta box na página de administração New Post / Edit Post e quero configurá-la com guias como a caixa meta Categories. Eu suponho que há uma maneira fácil de entrar nisso, mas não consigo me lembrar de como. Alguém sabe?

    
por Jason Rhodes 20.12.2010 / 23:14

1 resposta

13

Aqui está um exemplo muito básico ...

/*
    Code assumes it will be in the theme functions.php file
    Update the enqueue path if using it elsewhere
*/
add_action( 'add_meta_boxes_post', 'add_post_metabox' );

function add_post_metabox() {
    wp_enqueue_script( 'mytabs', get_bloginfo( 'stylesheet_directory' ). '/mytabs.js', array( 'jquery-ui-tabs' ) );
    add_meta_box( 'examplebox' , __('Example box'), 'my_example_metabox', 'post', 'side', 'core'/*,array()*/);
}

function my_example_metabox() {
    ?>
    <div id="mytabs">
        <ul class="category-tabs">
            <li><a href="#frag1">Tab 1</a></li>
            <li><a href="#frag2">Tab 2</a></li>
            <li><a href="#frag3">Tab 3</a></li>
        </ul>
        <br class="clear" />
        <div id="frag1">
            <p>#1 - Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.</p>
        </div>
        <div class="hidden" id="frag2">
            <p>#2 - Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.</p>
        </div>
        <div class="hidden" id="frag3">
            <p>#3 - Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.</p>
        </div>
    </div>
    <?php
}

O jQuery para o mytabs.js referenciado no enfileiramento.

jQuery(document).ready(function($) {
    $("#mytabs .hidden").removeClass('hidden');
    $("#mytabs").tabs();
});

NOTAS:

  • Usado em um plug-in, o enfileiramento deve chamar plugins_url( '/mytabs.js', __FILE__ ) no lugar da string get_bloginfo .
  • O link de âncora para cada guia deve corresponder ao ID do elemento de conteúdo a que se refere, por exemplo. frag1, frag2, etc.
  • Uma classe oculta é aplicada a cada conteúdo DIV após o primeiro, para que eles fiquem ocultos no carregamento da página (caso contrário você notará um breve salto na página), a classe será removida após o carregamento da página, senão eles permanecerão ocultos .
  • A ação principal deve ser atualizada para refletir o tipo de postagem que você deseja afetar add_action( "add_meta_boxes_YOURTYPE", 'add_post_metabox' ); , usei post no exemplo.
  • Você precisará renderizar o metabox no lado para utilizar o CSS existente do WordPress, que posiciona a guia LI elementos em linha (no entanto, é possível carregar sua própria folha de estilo para lidar com o CSS).

Veja aqui mais informações sobre como configurar o script de guias. enlace

Espero que ajude ..

    
por t31os 21.12.2010 / 14:44