]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-admin/menu-header.php
Wordpress 2.5.1
[autoinstalls/wordpress.git] / wp-admin / menu-header.php
index bbdfe1a7097bdeaab352a20b0a1f4905ffb8f9b6..b9c1dde9398b7a4938bd84960c42632b4ec8d739 100644 (file)
@@ -1,11 +1,46 @@
-<ul id="adminmenu">
 <?php
 $self = preg_replace('|^.*/wp-admin/|i', '', $_SERVER['PHP_SELF']);
 $self = preg_replace('|^.*/plugins/|i', '', $self);
 
 get_admin_page_parent();
 
-foreach ($menu as $item) {
+// We're going to do this loop three times
+?>
+
+<ul id="dashmenu">
+<?php
+foreach ( $menu as $key => $item ) {
+       if ( 3 < $key ) // get each menu item before 3
+               continue;
+       $class = '';
+       // 0 = name, 1 = capability, 2 = file
+       if (( strcmp($self, $item[2]) == 0 && empty($parent_file)) || ($parent_file && ($item[2] == $parent_file))) $class = ' class="current"';
+
+       if ( !empty($submenu[$item[2]]) ) {
+               $submenu[$item[2]] = array_values($submenu[$item[2]]);  // Re-index.
+               $menu_hook = get_plugin_page_hook($submenu[$item[2]][0][2], $item[2]);
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$submenu[$item[2]][0][2]}") || !empty($menu_hook))
+                       echo "\n\t<li><a href='admin.php?page={$submenu[$item[2]][0][2]}'$class>{$item[0]}</a></li>";
+               else
+                       echo "\n\t<li><a href='{$submenu[$item[2]][0][2]}'$class>{$item[0]}</a></li>";
+       } else if ( current_user_can($item[1]) ) {
+               $menu_hook = get_plugin_page_hook($item[2], 'admin.php');
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$item[2]}") || !empty($menu_hook) )
+                       echo "\n\t<li><a href='admin.php?page={$item[2]}'$class>{$item[0]}</a></li>";
+               else
+                       echo "\n\t<li><a href='{$item[2]}'$class>{$item[0]}</a></li>";
+       }
+}
+do_action( 'dashmenu' );
+?>
+</ul>
+
+<ul id="adminmenu">
+<?php
+foreach ( $menu as $key => $item ) {
+       if ( 5 > $key || $key > 25 ) // get each menu item before 3
+               continue;
+
        $class = '';
 
        // 0 = name, 1 = capability, 2 = file
@@ -19,16 +54,77 @@ foreach ($menu as $item) {
                else
                        echo "\n\t<li><a href='{$submenu[$item[2]][0][2]}'$class>{$item[0]}</a></li>";
        } else if ( current_user_can($item[1]) ) {
-               if ( file_exists(ABSPATH . PLUGINDIR . "/{$item[2]}") )
+               $menu_hook = get_plugin_page_hook($item[2], 'admin.php');
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$item[2]}") || !empty($menu_hook) )
                        echo "\n\t<li><a href='admin.php?page={$item[2]}'$class>{$item[0]}</a></li>";
                else
                        echo "\n\t<li><a href='{$item[2]}'$class>{$item[0]}</a></li>";
        }
 }
 
+foreach ( $menu as $key => $item ) {
+       if ( $key < 41 ) // there is a more efficient way to do this!
+               continue;
+
+       $class = '';
+
+       // 0 = name, 1 = capability, 2 = file
+       if (( strcmp($self, $item[2]) == 0 && empty($parent_file)) || ($parent_file && ($item[2] == $parent_file))) $class = ' class="current"';
+
+       if ( !empty($submenu[$item[2]]) ) {
+               $submenu[$item[2]] = array_values($submenu[$item[2]]);  // Re-index.
+               $menu_hook = get_plugin_page_hook($submenu[$item[2]][0][2], $item[2]);
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$submenu[$item[2]][0][2]}") || !empty($menu_hook))
+                       echo "\n\t<li><a href='admin.php?page={$submenu[$item[2]][0][2]}'$class>{$item[0]}</a></li>";
+               else
+                       echo "\n\t<li><a href='{$submenu[$item[2]][0][2]}'$class>{$item[0]}</a></li>";
+       } else if ( current_user_can($item[1]) ) {
+               $menu_hook = get_plugin_page_hook($item[2], 'admin.php');
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$item[2]}") || !empty($menu_hook) )
+                       echo "\n\t<li><a href='admin.php?page={$item[2]}'$class>{$item[0]}</a></li>";
+               else
+                       echo "\n\t<li><a href='{$item[2]}'$class>{$item[0]}</a></li>";
+       }
+}
+
+do_action( 'adminmenu' );
 ?>
 </ul>
 
+<ul id="sidemenu">
+<?php
+$side_items = array();
+foreach ( $menu as $key => $item ) {
+       if ( 26 > $key || $key > 40 )
+               continue;
+
+       $class = '';
+
+       // 0 = name, 1 = capability, 2 = file
+       if (( strcmp($self, $item[2]) == 0 && empty($parent_file)) || ($parent_file && ($item[2] == $parent_file))) $class = ' class="current"';
+
+       if ( !empty($submenu[$item[2]]) ) {
+               $submenu[$item[2]] = array_values($submenu[$item[2]]);  // Re-index.
+               $menu_hook = get_plugin_page_hook($submenu[$item[2]][0][2], $item[2]);
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$submenu[$item[2]][0][2]}") || !empty($menu_hook))
+                       $side_items[] = "\n\t<li><a href='admin.php?page={$submenu[$item[2]][0][2]}'$class>{$item[0]}</a>";
+               else
+                       $side_items[] = "\n\t<li><a href='{$submenu[$item[2]][0][2]}'$class>{$item[0]}</a>";
+       } else if ( current_user_can($item[1]) ) {
+               $menu_hook = get_plugin_page_hook($item[2], 'admin.php');
+               if ( file_exists(ABSPATH . PLUGINDIR . "/{$item[2]}") || !empty($menu_hook) )
+                       $side_items[] = "\n\t<li><a href='admin.php?page={$item[2]}'$class>{$item[0]}</a>";
+               else
+                       $side_items[] = "\n\t<li><a href='{$item[2]}'$class>{$item[0]}</a>";
+       }
+}
+echo implode(' </li>', $side_items) . '</li>';
+unset($side_items);
+do_action( 'sidemenu' );
+?>
+</ul>
+
+
 <?php
 // Sub-menu
 if ( isset($submenu["$parent_file"]) ) :