diff options
author | Angie Byron <webchick@24967.no-reply.drupal.org> | 2009-08-22 19:58:28 +0000 |
---|---|---|
committer | Angie Byron <webchick@24967.no-reply.drupal.org> | 2009-08-22 19:58:28 +0000 |
commit | a2694498f141f24ba4860f73a2c3ec238f65eab0 (patch) | |
tree | e0b63f70d10fc492ad02a40666a350e7bd184813 /includes | |
parent | d71ffc5aba6ee0e40ded64906b3bc430b7428e4f (diff) | |
download | brdo-a2694498f141f24ba4860f73a2c3ec238f65eab0.tar.gz brdo-a2694498f141f24ba4860f73a2c3ec238f65eab0.tar.bz2 |
#542658 by Gábor Hojtsy, sun, pwolanin: Move action 'tabs' out of local tasks.
Diffstat (limited to 'includes')
-rw-r--r-- | includes/common.inc | 3 | ||||
-rw-r--r-- | includes/menu.inc | 118 | ||||
-rw-r--r-- | includes/theme.inc | 1 |
3 files changed, 94 insertions, 28 deletions
diff --git a/includes/common.inc b/includes/common.inc index 767d0c400..caaa3f5a4 100644 --- a/includes/common.inc +++ b/includes/common.inc @@ -4343,6 +4343,9 @@ function drupal_common_theme() { 'menu_local_task' => array( 'arguments' => array('link' => NULL, 'active' => FALSE), ), + 'menu_local_action' => array( + 'arguments' => array('link' => NULL), + ), 'menu_local_tasks' => array( 'arguments' => array(), ), diff --git a/includes/menu.inc b/includes/menu.inc index e3e5e724f..f80836cc7 100644 --- a/includes/menu.inc +++ b/includes/menu.inc @@ -113,6 +113,11 @@ define('MENU_CREATED_BY_ADMIN', 0x0040); define('MENU_IS_LOCAL_TASK', 0x0080); /** + * Internal menu flag -- menu item is a local action. + */ +define('MENU_IS_LOCAL_ACTION', 0x0100); + +/** * @} End of "Menu flags". */ @@ -168,6 +173,14 @@ define('MENU_LOCAL_TASK', MENU_IS_LOCAL_TASK); define('MENU_DEFAULT_LOCAL_TASK', MENU_IS_LOCAL_TASK | MENU_LINKS_TO_PARENT); /** + * Menu type -- An action specific to the parent, usually rendered as a link. + * + * Local actions are menu items that describe actions on the parent item such + * as adding a new user, taxonomy term, etc. + */ +define('MENU_LOCAL_ACTION', MENU_IS_LOCAL_TASK | MENU_IS_LOCAL_ACTION); + +/** * @} End of "Menu item types". */ @@ -1306,6 +1319,15 @@ function theme_menu_local_task($link, $active = FALSE) { } /** + * Generate the HTML output for a single local action link. + * + * @ingroup themeable + */ +function theme_menu_local_action($link) { + return '<li>' . $link . "</li>\n"; +} + +/** * Generates elements for the $arg array in the help hook. */ function drupal_help_arg($arg = array()) { @@ -1437,27 +1459,39 @@ function menu_navigation_links($menu_name, $level = 0) { } /** - * Collects the local tasks (tabs) for a given level. + * Collects the local tasks (tabs), action links, and the root path. * * @param $level * The level of tasks you ask for. Primary tasks are 0, secondary are 1. - * @param $return_root - * Whether to return the root path for the current page. * @return - * Themed output corresponding to the tabs of the requested level, or - * router path if $return_root == TRUE. This router path corresponds to - * a parent tab, if the current page is a default local task. - */ -function menu_local_tasks($level = 0, $return_root = FALSE) { - $tabs = &drupal_static(__FUNCTION__); - $root_path = &drupal_static(__FUNCTION__ . ':root_path'); + * An array containing + * - tabs: Local tasks for the requested level: + * - count: The number of local tasks. + * - output: The themed output of local tasks. + * - actions: Action links for the requested level: + * - count: The number of action links. + * - output: The themed output of action links. + * - root_path: The router path for the current page. If the current page is + * a default local task, then this corresponds to the parent tab. + */ +function menu_local_tasks($level = 0) { + $data = &drupal_static(__FUNCTION__); + $root_path = &drupal_static(__FUNCTION__ . ':root_path', ''); + $empty = array( + 'tabs' => array('count' => 0, 'output' => ''), + 'actions' => array('count' => 0, 'output' => ''), + 'root_path' => &$root_path, + ); - if (!isset($tabs)) { + if (!isset($data)) { + $data = array(); + // Set defaults in case there are no actions or tabs. + $actions = $empty['actions']; $tabs = array(); $router_item = menu_get_item(); if (!$router_item || !$router_item['access']) { - return ''; + return $empty; } // Get all tabs and the root page. $result = db_select('menu_router', NULL, array('fetch' => PDO::FETCH_ASSOC)) @@ -1480,7 +1514,6 @@ function menu_local_tasks($level = 0, $return_root = FALSE) { // Store the translated item for later use. $tasks[$item['path']] = $item; } - // Find all tabs below the current path. $path = $router_item['path']; // Tab parenting may skip levels, so the number of parts in the path may not @@ -1488,31 +1521,42 @@ function menu_local_tasks($level = 0, $return_root = FALSE) { $depth = 1001; while (isset($children[$path])) { $tabs_current = ''; + $actions_current = ''; $next_path = ''; - $count = 0; + $tab_count = 0; + $action_count = 0; foreach ($children[$path] as $item) { if ($item['access']) { - $count++; // The default task is always active. if ($item['type'] == MENU_DEFAULT_LOCAL_TASK) { - // Find the first parent which is not a default local task. + // Find the first parent which is not a default local task or action. for ($p = $item['tab_parent']; $tasks[$p]['type'] == MENU_DEFAULT_LOCAL_TASK; $p = $tasks[$p]['tab_parent']); $link = theme('menu_item_link', array('href' => $tasks[$p]['href']) + $item); $tabs_current .= theme('menu_local_task', $link, TRUE); $next_path = $item['path']; + $tab_count++; } else { $link = theme('menu_item_link', $item); - $tabs_current .= theme('menu_local_task', $link); + if ($item['type'] == MENU_LOCAL_TASK) { + $tabs_current .= theme('menu_local_task', $link); + $tab_count++; + } + else { + $actions_current .= theme('menu_local_action', $link); + $action_count++; + } } } } $path = $next_path; - $tabs[$depth]['count'] = $count; + $tabs[$depth]['count'] = $tab_count; $tabs[$depth]['output'] = $tabs_current; + $actions['count'] = $action_count; + $actions['output'] = $actions_current; $depth++; } - + $data['actions'] = $actions; // Find all tabs at the same level or above the current one. $parent = $router_item['tab_parent']; $path = $router_item['path']; @@ -1524,6 +1568,9 @@ function menu_local_tasks($level = 0, $return_root = FALSE) { $next_parent = ''; $count = 0; foreach ($children[$parent] as $item) { + if ($item['type'] == MENU_LOCAL_ACTION) { + continue; + } if ($item['access']) { $count++; if ($item['type'] == MENU_DEFAULT_LOCAL_TASK) { @@ -1560,36 +1607,51 @@ function menu_local_tasks($level = 0, $return_root = FALSE) { ksort($tabs); // Remove the depth, we are interested only in their relative placement. $tabs = array_values($tabs); + $data['tabs'] = $tabs; } - if ($return_root) { - return $root_path; - } - else { - // We do not display single tabs. - return (isset($tabs[$level]) && $tabs[$level]['count'] > 1) ? $tabs[$level]['output'] : ''; + if (isset($data['tabs'][$level])) { + return array( + 'tabs' => $data['tabs'][$level], + 'actions' => $data['actions'], + 'root_path' => $root_path, + ); } + return $empty; } /** * Returns the rendered local tasks at the top level. */ function menu_primary_local_tasks() { - return menu_local_tasks(0); + $links = menu_local_tasks(0); + // Do not display single tabs. + return ($links['tabs']['count'] > 1 ? $links['tabs']['output'] : ''); } /** * Returns the rendered local tasks at the second level. */ function menu_secondary_local_tasks() { - return menu_local_tasks(1); + $links = menu_local_tasks(1); + // Do not display single tabs. + return ($links['tabs']['count'] > 1 ? $links['tabs']['output'] : ''); +} + +/** + * Returns the rendered local actions at the current level. + */ +function menu_local_actions() { + $links = menu_local_tasks(); + return $links['actions']['output']; } /** * Returns the router path, or the path of the parent tab of a default local task. */ function menu_tab_root_path() { - return menu_local_tasks(0, TRUE); + $links = menu_local_tasks(); + return $links['root_path']; } /** diff --git a/includes/theme.inc b/includes/theme.inc index 73af67648..32feb595a 100644 --- a/includes/theme.inc +++ b/includes/theme.inc @@ -2039,6 +2039,7 @@ function template_preprocess_page(&$variables) { $variables['messages'] = $variables['show_messages'] ? theme('status_messages') : ''; $variables['main_menu'] = theme_get_setting('toggle_main_menu') ? menu_main_menu() : array(); $variables['secondary_menu'] = theme_get_setting('toggle_secondary_menu') ? menu_secondary_menu() : array(); + $variables['action_links'] = menu_local_actions(); $variables['search_box'] = (theme_get_setting('toggle_search') ? drupal_render(drupal_get_form('search_theme_form')) : ''); $variables['site_name'] = (theme_get_setting('toggle_name') ? filter_xss_admin(variable_get('site_name', 'Drupal')) : ''); $variables['site_slogan'] = (theme_get_setting('toggle_slogan') ? filter_xss_admin(variable_get('site_slogan', '')) : ''); |