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'; } ?>