proto = 'https://'; $this->user = new stdClass; $this->root = (object) array( 'id' => 'root', 'group' => false, 'children' => array(), ); if ( is_user_logged_in() ) { /* Populate settings we need for the menu based on the current user. */ $this->user->blogs = get_blogs_of_user( get_current_user_id() ); if ( is_multisite() ) { $this->user->active_blog = get_active_blog_for_user( get_current_user_id() ); $this->user->domain = empty( $this->user->active_blog ) ? user_admin_url() : trailingslashit( get_home_url( $this->user->active_blog->blog_id ) ); $this->user->account_domain = $this->user->domain; } else { $this->user->active_blog = $this->user->blogs[get_current_blog_id()]; $this->user->domain = trailingslashit( home_url() ); $this->user->account_domain = $this->user->domain; } } add_action( 'wp_head', 'wp_admin_bar_header' ); add_action( 'admin_head', 'wp_admin_bar_header' ); if ( current_theme_supports( 'admin-bar' ) ) { $admin_bar_args = get_theme_support( 'admin-bar' ); // add_theme_support( 'admin-bar', array( 'callback' => '__return_false') ); $header_callback = $admin_bar_args[0]['callback']; } if ( empty($header_callback) ) $header_callback = '_admin_bar_bump_cb'; add_action('wp_head', $header_callback); wp_enqueue_script( 'admin-bar' ); wp_enqueue_style( 'admin-bar' ); do_action( 'admin_bar_init' ); } public function add_menu( $node ) { $this->add_node( $node ); } public function remove_menu( $id ) { $this->remove_node( $id ); } /** * Add a node to the menu. * * @param array $args - The arguments for each node. * - id - string - The ID of the item. * - title - string - The title of the node. * - parent - string - The ID of the parent node. Optional. * - href - string - The link for the item. Optional. * - group - boolean - If the node is a group. Optional. Default false. * - meta - array - Meta data including the following keys: html, class, onclick, target, title. */ public function add_node( $args ) { // Shim for old method signature: add_node( $parent_id, $menu_obj, $args ) if ( func_num_args() >= 3 && is_string( func_get_arg(0) ) ) $args = array_merge( array( 'parent' => func_get_arg(0) ), func_get_arg(2) ); // Ensure we have a valid title. if ( empty( $args['id'] ) ) { if ( empty( $args['title'] ) ) return; _doing_it_wrong( __METHOD__, __( 'The menu ID should not be empty.' ), '3.3' ); // Deprecated: Generate an ID from the title. $args['id'] = esc_attr( sanitize_title( trim( $args['title'] ) ) ); } $defaults = array( 'id' => false, 'title' => false, 'parent' => false, 'href' => false, 'group' => false, 'meta' => array(), ); // If the node already exists, keep any data that isn't provided. if ( isset( $this->nodes[ $args['id'] ] ) ) $defaults = (array) $this->nodes[ $args['id'] ]; $args = wp_parse_args( $args, $defaults ); $args['children'] = array(); $this->nodes[ $args['id'] ] = (object) $args; } /** * Add a group to a menu node. * * @param array $args - The arguments for each node. * - id - string - The ID of the item. * - parent - string - The ID of the parent node. Optional. Default root. * - meta - array - Meta data including the following keys: class, onclick, target, title. */ public function add_group( $args ) { $args['group'] = true; $this->add_node( $args ); } public function remove_node( $id ) { unset( $this->nodes[ $id ] ); } public function render() { global $is_IE, $is_iphone; // Link nodes to parents. foreach ( $this->nodes as $node ) { // Handle root menu items if ( empty( $node->parent ) ) { $parent = $this->root; // If the parent node isn't registered, ignore the node. } elseif ( ! isset( $this->nodes[ $node->parent ] ) ) { continue; } else { $parent = $this->nodes[ $node->parent ]; } // Ensure that our tree is of the form "item -> group -> item -> group -> ..." if ( ! $parent->group && ! $node->group ) { // Both are items. // The default group is added here to allow groups that are // added before standard menu items to render first. if ( ! isset( $parent->children['default'] ) ) { $parent->children['default'] = (object) array( 'id' => "{$parent->id}-default", 'parent' => $parent->id, 'group' => true, 'children' => array(), ); } $parent = $parent->children['default']; } // Update the parent ID (it might have changed). $node->parent = $parent->id; // Add the node to the tree. $parent->children[] = $node; } // Add browser classes. // We have to do this here since admin bar shows on the front end. $class = 'nojq nojs'; if ( $is_IE ) { if ( strpos( $_SERVER['HTTP_USER_AGENT'], 'MSIE 7' ) ) $class .= ' ie7'; elseif ( strpos( $_SERVER['HTTP_USER_AGENT'], 'MSIE 8' ) ) $class .= ' ie8'; elseif ( strpos( $_SERVER['HTTP_USER_AGENT'], 'MSIE 9' ) ) $class .= ' ie9'; } elseif ( $is_iphone ) { $class .= ' mobile'; } ?> group ) return; // Check for groups within groups. $groups = array(); foreach ( $node->children as $child ) { if ( $child->group ) { $groups[] = $child; } else { if ( ! isset( $default ) ) { // Create a default proxy item to be used in the case of nested groups. $default = (object) wp_parse_args( array( 'children' => array() ), (array) $node ); $groups[] = $default; } $default->children[] = $child; } } $is_single_group = count( $groups ) === 1; // If we don't have any subgroups, render the group. if ( $is_single_group && ! empty( $node->children ) ): if ( ! empty( $node->meta['class'] ) ) $class .= ' ' . $node->meta['class']; ?>
id}-container" ); ?>" class="ab-group-container" role="menu">render_group( $group, $class ); } ?>
group ) return; $is_parent = (bool) $node->children; $has_link = (bool) $node->href; $tabindex = isset($node->meta['tabindex']) ? (int) $node->meta['tabindex'] : 10; $menuclass = ''; $aria_attributes = 'tabindex="' . $tabindex . '" role="menuitem"'; if ( $is_parent ) { $menuclass = 'menupop'; $aria_attributes .= ' aria-haspopup="true"'; } if ( ! empty( $node->meta['class'] ) ) $menuclass .= ' ' . $node->meta['class']; ?>
  • id}" ); ?>" class=""> href="href ) ?>"meta['onclick'] ) ) : ?> onclick="meta['onclick'] ); ?>"meta['target'] ) ) : ?> target="meta['target'] ); ?>"meta['title'] ) ) : ?> title="meta['title'] ); ?>">
    >title; if ( $has_link ): ?>
    children as $group ) { $this->render_group( $group, 'ab-submenu' ); } ?>
    meta['html'] ) ) echo $node->meta['html']; ?>
  • render_item( $node ); } function add_menus() { // User related, aligned right. add_action( 'admin_bar_menu', 'wp_admin_bar_my_account_menu', 10 ); // Site related. add_action( 'admin_bar_menu', 'wp_admin_bar_wp_menu', 10 ); add_action( 'admin_bar_menu', 'wp_admin_bar_my_sites_menu', 20 ); add_action( 'admin_bar_menu', 'wp_admin_bar_site_menu', 30 ); add_action( 'admin_bar_menu', 'wp_admin_bar_updates_menu', 40 ); // Content related. if ( ! is_network_admin() && ! is_user_admin() ) { add_action( 'admin_bar_menu', 'wp_admin_bar_comments_menu', 60 ); add_action( 'admin_bar_menu', 'wp_admin_bar_new_content_menu', 70 ); } add_action( 'admin_bar_menu', 'wp_admin_bar_edit_menu', 80 ); add_action( 'admin_bar_menu', 'wp_admin_bar_shortlink_menu', 90 ); if ( ! is_admin() ) add_action( 'admin_bar_menu', 'wp_admin_bar_search_menu', 100 ); add_action( 'admin_bar_menu', 'wp_admin_bar_add_secondary_groups', 200 ); do_action( 'add_admin_bar_menus' ); } } ?>