2003-05-28 09:54:49 +02:00
|
|
|
<?php
|
2004-04-25 08:42:45 +02:00
|
|
|
// This array constructs the admin menu bar.
|
|
|
|
//
|
|
|
|
// Menu item name
|
|
|
|
// The minimum level the user needs to access the item: between 0 and 10
|
|
|
|
// The URL of the item's file
|
2006-11-18 08:31:29 +01:00
|
|
|
$menu[0] = array(__('Dashboard'), 'read', 'index.php');
|
2006-07-04 19:19:15 +02:00
|
|
|
|
2007-03-07 06:29:15 +01:00
|
|
|
if (strpos($_SERVER['REQUEST_URI'], 'edit-pages.php') !== false)
|
2006-11-18 08:31:29 +01:00
|
|
|
$menu[5] = array(__('Write'), 'edit_pages', 'page-new.php');
|
2006-07-04 19:19:15 +02:00
|
|
|
else
|
2006-11-18 08:31:29 +01:00
|
|
|
$menu[5] = array(__('Write'), 'edit_posts', 'post-new.php');
|
2007-03-07 06:29:15 +01:00
|
|
|
if (strpos($_SERVER['REQUEST_URI'], 'page-new.php') !== false)
|
2006-11-18 08:31:29 +01:00
|
|
|
$menu[10] = array(__('Manage'), 'edit_pages', 'edit-pages.php');
|
2006-07-04 19:19:15 +02:00
|
|
|
else
|
2006-11-18 08:31:29 +01:00
|
|
|
$menu[10] = array(__('Manage'), 'edit_posts', 'edit.php');
|
2007-02-27 16:24:54 +01:00
|
|
|
|
2007-12-22 10:46:13 +01:00
|
|
|
$awaiting_mod = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments WHERE comment_approved = '0'");
|
2008-01-05 01:17:35 +01:00
|
|
|
$menu[15] = array(__('Design'), 'switch_themes', 'themes.php');
|
2008-02-26 23:45:46 +01:00
|
|
|
$menu[20] = array( sprintf( __('Comments %s'), "<span id='awaiting-mod'><span class='comment-count'>$awaiting_mod</span></span>" ), 'edit_posts', 'edit-comments.php');
|
2008-02-25 09:08:09 +01:00
|
|
|
$menu[30] = array(__('Settings'), 'manage_options', 'options-general.php');
|
|
|
|
$menu[35] = array(__('Plugins'), 'activate_plugins', 'plugins.php');
|
2005-08-08 09:38:41 +02:00
|
|
|
if ( current_user_can('edit_users') )
|
2008-02-25 09:08:09 +01:00
|
|
|
$menu[40] = array(__('Users'), 'edit_users', 'users.php');
|
2005-08-08 09:38:41 +02:00
|
|
|
else
|
2008-02-25 09:08:09 +01:00
|
|
|
$menu[40] = array(__('Profile'), 'read', 'profile.php');
|
2005-02-05 05:53:19 +01:00
|
|
|
|
2007-01-07 10:02:11 +01:00
|
|
|
$_wp_real_parent_file['post.php'] = 'post-new.php'; // Back-compat
|
2008-01-04 12:47:06 +01:00
|
|
|
$submenu['post-new.php'][5] = array(__('Post'), 'edit_posts', 'post-new.php');
|
|
|
|
$submenu['post-new.php'][10] = array(__('Page'), 'edit_pages', 'page-new.php');
|
2008-01-04 21:18:55 +01:00
|
|
|
$submenu['post-new.php'][15] = array(__('Link'), 'manage_links', 'link-add.php');
|
2004-11-16 20:29:51 +01:00
|
|
|
|
2006-11-17 17:22:46 +01:00
|
|
|
$submenu['edit-comments.php'][5] = array(__('Comments'), 'edit_posts', 'edit-comments.php');
|
|
|
|
|
2005-07-13 18:04:14 +02:00
|
|
|
$submenu['edit.php'][5] = array(__('Posts'), 'edit_posts', 'edit.php');
|
|
|
|
$submenu['edit.php'][10] = array(__('Pages'), 'edit_pages', 'edit-pages.php');
|
2008-01-04 12:47:06 +01:00
|
|
|
$submenu['edit.php'][15] = array(__('Links'), 'manage_links', 'link-manager.php');
|
|
|
|
$submenu['edit.php'][20] = array(__('Categories'), 'manage_categories', 'categories.php');
|
2008-01-25 20:34:10 +01:00
|
|
|
$submenu['edit.php'][25] = array(__('Tags'), 'manage_categories', 'edit-tags.php');
|
|
|
|
$submenu['edit.php'][30] = array(__('Link Categories'), 'manage_categories', 'edit-link-categories.php');
|
|
|
|
$submenu['edit.php'][35] = array(__('Media Library'), 'upload_files', 'upload.php');
|
|
|
|
$submenu['edit.php'][40] = array(__('Import'), 'import', 'import.php');
|
|
|
|
$submenu['edit.php'][45] = array(__('Export'), 'import', 'export.php');
|
2008-01-04 12:47:06 +01:00
|
|
|
|
2006-06-08 20:36:05 +02:00
|
|
|
if ( current_user_can('edit_users') ) {
|
2006-08-15 23:03:11 +02:00
|
|
|
$_wp_real_parent_file['profile.php'] = 'users.php'; // Back-compat for plugins adding submenus to profile.php.
|
2006-06-08 20:36:05 +02:00
|
|
|
$submenu['users.php'][5] = array(__('Authors & Users'), 'edit_users', 'users.php');
|
|
|
|
$submenu['users.php'][10] = array(__('Your Profile'), 'read', 'profile.php');
|
|
|
|
} else {
|
|
|
|
$submenu['profile.php'][5] = array(__('Your Profile'), 'read', 'profile.php');
|
|
|
|
}
|
2004-08-23 01:24:50 +02:00
|
|
|
|
2005-11-17 00:32:38 +01:00
|
|
|
$submenu['options-general.php'][10] = array(__('General'), 'manage_options', 'options-general.php');
|
|
|
|
$submenu['options-general.php'][15] = array(__('Writing'), 'manage_options', 'options-writing.php');
|
|
|
|
$submenu['options-general.php'][20] = array(__('Reading'), 'manage_options', 'options-reading.php');
|
|
|
|
$submenu['options-general.php'][25] = array(__('Discussion'), 'manage_options', 'options-discussion.php');
|
2006-05-22 21:34:28 +02:00
|
|
|
$submenu['options-general.php'][30] = array(__('Privacy'), 'manage_options', 'options-privacy.php');
|
|
|
|
$submenu['options-general.php'][35] = array(__('Permalinks'), 'manage_options', 'options-permalink.php');
|
|
|
|
$submenu['options-general.php'][40] = array(__('Miscellaneous'), 'manage_options', 'options-misc.php');
|
2004-08-23 01:24:50 +02:00
|
|
|
|
2005-07-13 18:04:14 +02:00
|
|
|
$submenu['plugins.php'][5] = array(__('Plugins'), 'activate_plugins', 'plugins.php');
|
|
|
|
$submenu['plugins.php'][10] = array(__('Plugin Editor'), 'edit_plugins', 'plugin-editor.php');
|
2004-11-17 04:15:44 +01:00
|
|
|
|
2005-07-13 18:04:14 +02:00
|
|
|
$submenu['themes.php'][5] = array(__('Themes'), 'switch_themes', 'themes.php');
|
|
|
|
$submenu['themes.php'][10] = array(__('Theme Editor'), 'edit_themes', 'theme-editor.php');
|
2004-09-11 18:12:40 +02:00
|
|
|
|
2007-05-06 22:36:11 +02:00
|
|
|
do_action('_admin_menu');
|
|
|
|
|
2006-05-02 21:08:37 +02:00
|
|
|
// Create list of page plugin hook names.
|
2006-11-18 08:31:29 +01:00
|
|
|
foreach ($menu as $menu_page) {
|
2006-05-02 21:08:37 +02:00
|
|
|
$admin_page_hooks[$menu_page[2]] = sanitize_title($menu_page[0]);
|
2006-11-18 08:31:29 +01:00
|
|
|
}
|
2006-05-02 21:08:37 +02:00
|
|
|
|
2006-08-16 00:13:36 +02:00
|
|
|
$_wp_submenu_nopriv = array();
|
|
|
|
$_wp_menu_nopriv = array();
|
2006-02-17 01:57:10 +01:00
|
|
|
// Loop over submenus and remove pages for which the user does not have privs.
|
|
|
|
foreach ($submenu as $parent => $sub) {
|
|
|
|
foreach ($sub as $index => $data) {
|
|
|
|
if ( ! current_user_can($data[1]) ) {
|
|
|
|
unset($submenu[$parent][$index]);
|
2006-08-16 00:13:36 +02:00
|
|
|
$_wp_submenu_nopriv[$parent][$data[2]] = true;
|
2006-02-17 01:57:10 +01:00
|
|
|
}
|
|
|
|
}
|
2006-11-19 08:56:05 +01:00
|
|
|
|
2006-02-17 01:57:10 +01:00
|
|
|
if ( empty($submenu[$parent]) )
|
|
|
|
unset($submenu[$parent]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Loop over the top-level menu.
|
|
|
|
// Menus for which the original parent is not acessible due to lack of privs will have the next
|
2006-11-19 08:56:05 +01:00
|
|
|
// submenu in line be assigned as the new menu parent.
|
2006-08-14 23:24:43 +02:00
|
|
|
foreach ( $menu as $id => $data ) {
|
2007-09-04 01:32:58 +02:00
|
|
|
if ( empty($submenu[$data[2]]) )
|
2006-08-14 23:24:43 +02:00
|
|
|
continue;
|
|
|
|
$subs = $submenu[$data[2]];
|
|
|
|
$first_sub = array_shift($subs);
|
|
|
|
$old_parent = $data[2];
|
|
|
|
$new_parent = $first_sub[2];
|
|
|
|
// If the first submenu is not the same as the assigned parent,
|
|
|
|
// make the first submenu the new parent.
|
|
|
|
if ( $new_parent != $old_parent ) {
|
2006-08-15 23:03:11 +02:00
|
|
|
$_wp_real_parent_file[$old_parent] = $new_parent;
|
2006-08-14 23:24:43 +02:00
|
|
|
$menu[$id][2] = $new_parent;
|
2007-02-27 16:24:54 +01:00
|
|
|
|
2006-08-14 23:24:43 +02:00
|
|
|
foreach ($submenu[$old_parent] as $index => $data) {
|
|
|
|
$submenu[$new_parent][$index] = $submenu[$old_parent][$index];
|
|
|
|
unset($submenu[$old_parent][$index]);
|
|
|
|
}
|
2006-08-15 23:03:11 +02:00
|
|
|
unset($submenu[$old_parent]);
|
|
|
|
$_wp_submenu_nopriv[$new_parent] = $_wp_submenu_nopriv[$old_parent];
|
2006-08-14 23:24:43 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
do_action('admin_menu', '');
|
|
|
|
|
|
|
|
// Remove menus that have no accessible submenus and require privs that the user does not have.
|
2006-08-15 23:03:11 +02:00
|
|
|
// Run re-parent loop again.
|
2006-02-17 01:57:10 +01:00
|
|
|
foreach ( $menu as $id => $data ) {
|
|
|
|
// If submenu is empty...
|
|
|
|
if ( empty($submenu[$data[2]]) ) {
|
|
|
|
// And user doesn't have privs, remove menu.
|
|
|
|
if ( ! current_user_can($data[1]) ) {
|
2006-08-15 23:03:11 +02:00
|
|
|
$_wp_menu_nopriv[$data[2]] = true;
|
2006-02-17 01:57:10 +01:00
|
|
|
unset($menu[$id]);
|
|
|
|
}
|
2006-08-15 23:03:11 +02:00
|
|
|
}
|
2006-02-17 01:57:10 +01:00
|
|
|
}
|
|
|
|
|
2006-11-18 08:31:29 +01:00
|
|
|
unset($id);
|
2006-10-03 09:15:13 +02:00
|
|
|
|
2006-11-18 08:31:29 +01:00
|
|
|
uksort($menu, "strnatcasecmp"); // make it all pretty
|
2004-10-18 06:50:08 +02:00
|
|
|
|
2006-11-18 08:31:29 +01:00
|
|
|
if (! user_can_access_admin_page()) {
|
2007-12-05 08:34:57 +01:00
|
|
|
do_action('admin_page_access_denied');
|
2006-07-06 00:00:03 +02:00
|
|
|
wp_die( __('You do not have sufficient permissions to access this page.') );
|
2006-11-18 08:31:29 +01:00
|
|
|
}
|
2004-10-18 06:50:08 +02:00
|
|
|
|
2006-11-18 08:31:29 +01:00
|
|
|
?>
|