Top-Level Menus
Add a Top-Level Menu Add a Top-Level Menu
To add a new Top-level menu to WordPress Administration, use the add_menu_page() function.
1 2 3 4 5 6 7 8 9 10 | <?php add_menu_page( string $page_title , string $menu_title , string $capability , string $menu_slug , callable $function = '' , string $icon_url = '' , int $position = null ); |
Example Example
Lets say we want to add a new Top-level menu called “WPOrg”.
The first step will be creating a function which will output the HTML. In this function we will perform the necessary security checks and render the options we’ve registered using the Settings API.
We recommend wrapping your HTML using a <div>
with a class of wrap
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | <?php function wporg_options_page_html() { // check user capabilities if ( ! current_user_can( 'manage_options' ) ) { return ; } ?> <div class = "wrap" > <h1><?php esc_html( get_admin_page_title() ); ?></h1> <form action= "options.php" method= "post" > <?php // output security fields for the registered setting "wporg_options" settings_fields( 'wporg_options' ); // output setting sections and their fields // (sections are registered for "wporg", each field is registered to a specific section) do_settings_sections( 'wporg' ); // output save settings button submit_button( 'Save Settings' ); ?> </form> </div> <?php } |
The second step will be registering our WPOrg menu. The registration needs to occur during the admin_menu
action hook.
1 2 3 4 5 6 7 8 9 10 11 12 13 | <?php function wporg_options_page() { add_menu_page( 'WPOrg' , 'WPOrg Options' , 'manage_options' , 'wporg' , 'wporg_options_page_html' , plugin_dir_url( __FILE__ ) . 'images/icon_wporg.png' , 20 ); } add_action( 'admin_menu' , 'wporg_options_page' ); |
For a list of parameters and what each do please see the add_menu_page() in the reference.
Using a PHP File for HTML Using a PHP File for HTML
The best practice for portable code would be to create a Callback that requires/includes your PHP file.
For the sake of completeness and helping you understand legacy code, we will show another way: passing a PHP file path
as the $menu_slug
parameter with an null
$function
parameter.
1 2 3 4 5 6 7 8 9 10 11 12 13 | <?php function wporg_options_page() { add_menu_page( 'WPOrg' , 'WPOrg Options' , 'manage_options' , plugin_dir_path( __FILE__ ) . 'admin/view.php' , null, plugin_dir_url( __FILE__ ) . 'images/icon_wporg.png' , 20 ); } add_action( 'admin_menu' , 'wporg_options_page' ); |
Remove a Top-Level Menu Remove a Top-Level Menu
To remove a registered menu from WordPress Administration, use the remove_menu_page() function.
1 2 3 4 | <?php remove_menu_page( string $menu_slug ); |
Warning:
Removing menus won’t prevent users accessing them directly.
This should never be used as a way to restrict user capabilities.
Example Example
Lets say we want to remove the “Tools” menu from.
1 2 3 4 5 | <?php function wporg_remove_options_page() { remove_menu_page( 'tools.php' ); } add_action( 'admin_menu' , 'wporg_remove_options_page' , 99 ); |
Make sure that the menu have been registered with the admin_menu
hook before attempting to remove, specify a higher priority number for add_action().