Comment ajouter une page de sous-menu à un type de publication personnalisé?


15

J'essaie de créer un sous-menu sous un type de publication personnalisé que j'ai nommé Portefeuilles.

Lorsque je passe add_submenu_page()à add_options_page(), il affiche correctement un nouveau lien dans le menu Paramètres, mais il ne s'affiche pas dans le menu Portefeuilles.

Qu'est-ce que je fais mal?

Ci-dessous mon extrait de code;

add_action( 'admin_menu', 'mt_add_pages' );

function mt_add_pages() {
    add_submenu_page(
        __( 'portfolios', 'menu-test' ),
        __( 'Test Settings', 'menu-test' ),
        'manage_options',
        'testsettings',
        'mt_settings_page'
    );

    function mt_settings_page() {
        echo "<h2>" . __( 'Test Settings', 'menu-test' ) . "</h2>";
    }
}

je pense que vous passez limace parent incorrects, c.-à-portefeuilles. vérifiez-le à nouveau ... à la place des portefeuilles passez le slug de votre type de message personnalisé ..
codepixlabs

Réponses:


31

add_options_page()l'ajoute automatiquement sous les paramètres, mais add_submenu_page()vous permet de contrôler où vous souhaitez qu'il apparaisse.

Essayez quelque chose comme ceci:

add_submenu_page(
    'edit.php?post_type=portfolios',
    __( 'Test Settings', 'menu-test' ),
    __( 'Test Settings', 'menu-test' ),
    'manage_options',
    'testsettings',
    'mt_settings_page'
);

1
Votre code ne fonctionnera que si vous manquez un troisième argument de menu_title. Voir le codex
Rahil Wazir

4
add_submenu_page('edit.php?post_type='.$this->plugin->posttype, __('Settings', $this->plugin->name), __('Settings', $this->plugin->name), 'manage_options', $this->plugin->name, array(&$this, 'adminPanel'));

il y a un panneau d'administration est un nom de fonction de rappel.


1
Pouvez-vous expliquer un peu plus?
bravokeyl

4

Pour développer l'exemple @Jai ...

Mes paramètres

$postType = 'foo';
$categoryType = 'bar';

Type de message personnalisé

            $args = array(
                    'labels'             => array('name'=>$postType, ...),
                    'rewrite'            => array('slug' => 'all-'.$postType),
                    'taxonomies'         => array($categoryType)
            );

register_post_type( 'foo', $args );

Taxonomie des catégories personnalisées

            $args = array(
                    'labels'            => array( 'name' => _x( $categoryType, 'taxonomy general name' )),
                    'rewrite'           => array( 'slug' => $categoryType ),
            );

register_taxonomy( $categoryType, array( $postType ), $args );

Ajouter des catégories comme éléments de sous-menu

    $wp_term = get_categories( 'taxonomy='.$categoryType.'&type='.$postType ); 
    if ( $wp_term ) {
        foreach ( $wp_term as $term ) {
            // add_submenu_page( string $parent_slug, string $page_title, string $menu_title, string $capability, string $menu_slug,                                                  callable $function = '' )
            add_submenu_page(    'edit.php?post_type='.$postType,      $term->name,        $term->name,        'manage_options',   'edit.php?post_type='.$postType.'&'.$categoryType.'='.$term->slug, ''); 
        }
    } 

1
/**
* Adds a submenu page under a custom post type parent.
*/
function books_register_ref_page() {
    add_submenu_page(
        'edit.php?post_type=book',
        __( 'Books Shortcode Reference', 'textdomain' ),
        __( 'Shortcode Reference', 'textdomain' ),
        'manage_options',
        'books-shortcode-ref',
        'books_ref_page_callback'
    );
}

/**
* Display callback for the submenu page.
*/
function books_ref_page_callback() { 
    ?>
    <div class="wrap">
        <h1><?php _e( 'Books Shortcode Reference', 'textdomain' ); ?></h1>
        <p><?php _e( 'Helpful stuff here', 'textdomain' ); ?></p>
    </div>
    <?php
}

Lien vers la source , auteur: Christina Blust

En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.