'toolbar_item', 'tab' => array( '#type' => 'search', '#attributes' => array( 'placeholder' => t('Search the site'), 'class' => array('search-global'), ), ), '#weight' => 200, // Custom CSS, JS or a library can be associated with the toolbar item. '#attached' => array( 'library' => array( 'search/global', ), ), ); // The 'Home' tab is a simple link, which is wrapped in markup associated // with a visual tab styling. $items['home'] = array( '#type' => 'toolbar_item', 'tab' => array( '#type' => 'link', '#title' => t('Home'), '#url' => Url::fromRoute(''), '#options' => array( 'attributes' => array( 'title' => t('Home page'), 'class' => array('toolbar-icon', 'toolbar-icon-home'), ), ), ), '#weight' => -20, ); // A tray may be associated with a tab. // // When the tab is activated, the tray will become visible, either in a // horizontal or vertical orientation on the screen. // // The tray should contain a renderable array. An optional #heading property // can be passed. This text is written to a heading tag in the tray as a // landmark for accessibility. $items['commerce'] = array( '#type' => 'toolbar_item', 'tab' => array( '#type' => 'link', '#title' => t('Shopping cart'), '#url' => Url::fromRoute('cart'), '#options' => array( 'attributes' => array( 'title' => t('Shopping cart'), ), ), ), 'tray' => array( '#heading' => t('Shopping cart actions'), 'shopping_cart' => array( '#theme' => 'item_list', '#items' => array( /* An item list renderable array */ ), ), ), '#weight' => 150, ); // The tray can be used to render arbitrary content. // // A renderable array passed to the 'tray' property will be rendered outside // the administration bar but within the containing toolbar element. // // If the default behavior and styling of a toolbar tray is not desired, one // can render content to the toolbar element and apply custom theming and // behaviors. $items['user_messages'] = array( // Include the toolbar_tab_wrapper to style the link like a toolbar tab. // Exclude the theme wrapper if custom styling is desired. '#type' => 'toolbar_item', 'tab' => array( '#type' => 'link', '#theme' => 'user_message_toolbar_tab', '#theme_wrappers' => array(), '#title' => t('Messages'), '#url' => Url::fromRoute('user.message'), '#options' => array( 'attributes' => array( 'title' => t('Messages'), ), ), ), 'tray' => array( '#heading' => t('User messages'), 'messages' => array(/* renderable content */), ), '#weight' => 125, ); return $items; } /** * Alter the toolbar menu after hook_toolbar() is invoked. * * This hook is invoked by toolbar_view() immediately after hook_toolbar(). The * toolbar definitions are passed in by reference. Each element of the $items * array is one item returned by a module from hook_toolbar(). Additional items * may be added, or existing items altered. * * @param $items * Associative array of toolbar menu definitions returned from hook_toolbar(). */ function hook_toolbar_alter(&$items) { // Move the User tab to the right. $items['commerce']['#weight'] = 5; } /** * @} End of "addtogroup hooks". */