diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-01-19 11:53:43 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-01-19 11:53:43 +0000 |
commit | 0faa4568a0ab18277259ad1c89309c3c53fa42de (patch) | |
tree | 0bcdcc9bfb1263980715b650cffd3a7236d5feeb /lib | |
parent | 3e031b4243b38c3739936ae143acf21d305cd570 (diff) | |
download | redmine-0faa4568a0ab18277259ad1c89309c3c53fa42de.tar.gz redmine-0faa4568a0ab18277259ad1c89309c3c53fa42de.zip |
Highlight the current item of the main menu.
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1076 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib')
-rw-r--r-- | lib/redmine.rb | 25 | ||||
-rw-r--r-- | lib/redmine/menu_manager.rb | 60 |
2 files changed, 73 insertions, 12 deletions
diff --git a/lib/redmine.rb b/lib/redmine.rb index 2dca9ed50..d0e152467 100644 --- a/lib/redmine.rb +++ b/lib/redmine.rb @@ -91,15 +91,18 @@ end # Project menu configuration Redmine::MenuManager.map :project_menu do |menu| - menu.push :label_overview, :controller => 'projects', :action => 'show' - menu.push :label_activity, :controller => 'projects', :action => 'activity' - menu.push :label_roadmap, :controller => 'projects', :action => 'roadmap' - menu.push :label_issue_plural, { :controller => 'issues', :action => 'index' }, :param => :project_id - menu.push :label_news_plural, { :controller => 'news', :action => 'index' }, :param => :project_id - menu.push :label_document_plural, { :controller => 'documents', :action => 'index' }, :param => :project_id - menu.push :label_wiki, { :controller => 'wiki', :action => 'index', :page => nil }, :if => Proc.new { |p| p.wiki && !p.wiki.new_record? } - menu.push :label_board_plural, { :controller => 'boards', :action => 'index', :id => nil }, :param => :project_id, :if => Proc.new { |p| p.boards.any? } - menu.push :label_attachment_plural, :controller => 'projects', :action => 'list_files' - menu.push :label_repository, { :controller => 'repositories', :action => 'show' }, :if => Proc.new { |p| p.repository && !p.repository.new_record? } - menu.push :label_settings, :controller => 'projects', :action => 'settings' + menu.push :overview, { :controller => 'projects', :action => 'show' }, :caption => :label_overview + menu.push :activity, { :controller => 'projects', :action => 'activity' }, :caption => :label_activity + menu.push :roadmap, { :controller => 'projects', :action => 'roadmap' }, :caption => :label_roadmap + menu.push :issues, { :controller => 'issues', :action => 'index' }, :param => :project_id, :caption => :label_issue_plural + menu.push :news, { :controller => 'news', :action => 'index' }, :param => :project_id, :caption => :label_news_plural + menu.push :documents, { :controller => 'documents', :action => 'index' }, :param => :project_id, :caption => :label_document_plural + menu.push :wiki, { :controller => 'wiki', :action => 'index', :page => nil }, + :if => Proc.new { |p| p.wiki && !p.wiki.new_record? }, :caption => :label_wiki + menu.push :boards, { :controller => 'boards', :action => 'index', :id => nil }, :param => :project_id, + :if => Proc.new { |p| p.boards.any? }, :caption => :label_board_plural + menu.push :files, { :controller => 'projects', :action => 'list_files' }, :caption => :label_attachment_plural + menu.push :repository, { :controller => 'repositories', :action => 'show' }, + :if => Proc.new { |p| p.repository && !p.repository.new_record? }, :caption => :label_repository + menu.push :settings, { :controller => 'projects', :action => 'settings' }, :caption => :label_settings end diff --git a/lib/redmine/menu_manager.rb b/lib/redmine/menu_manager.rb index d4a46b3e1..c801cb383 100644 --- a/lib/redmine/menu_manager.rb +++ b/lib/redmine/menu_manager.rb @@ -17,6 +17,63 @@ module Redmine module MenuManager + module MenuController + def self.included(base) + base.extend(ClassMethods) + end + + module ClassMethods + @@menu_items = Hash.new {|hash, key| hash[key] = {:default => key, :actions => {}}} + mattr_accessor :menu_items + + # Set the menu item name for a controller or specific actions + # Examples: + # * menu_item :tickets # => sets the menu name to :tickets for the whole controller + # * menu_item :tickets, :only => :list # => sets the menu name to :tickets for the 'list' action only + # * menu_item :tickets, :only => [:list, :show] # => sets the menu name to :tickets for 2 actions only + # + # The default menu item name for a controller is controller_name by default + # Eg. the default menu item name for ProjectsController is :projects + def menu_item(id, options = {}) + if actions = options[:only] + actions = [] << actions unless actions.is_a?(Array) + actions.each {|a| menu_items[controller_name.to_sym][:actions][a.to_sym] = id} + else + menu_items[controller_name.to_sym][:default] = id + end + end + end + + def menu_items + self.class.menu_items + end + + # Returns the menu item name according to the current action + def current_menu_item + menu_items[controller_name.to_sym][:actions][action_name.to_sym] || + menu_items[controller_name.to_sym][:default] + end + end + + module MenuHelper + # Returns the current menu item name + def current_menu_item + @controller.current_menu_item + end + + # Renders the application main menu as a ul element + def render_main_menu(project) + links = [] + Redmine::MenuManager.allowed_items(:project_menu, User.current, project).each do |item| + unless item.condition && !item.condition.call(project) + links << content_tag('li', + link_to(l(item.caption), {item.param => project}.merge(item.url), + :class => (current_menu_item == item.name ? 'selected' : nil))) + end + end if project && !project.new_record? + links.empty? ? nil : content_tag('ul', links.join("\n")) + end + end class << self def map(menu_name) @@ -48,13 +105,14 @@ module Redmine end class MenuItem - attr_reader :name, :url, :param, :condition + attr_reader :name, :url, :param, :condition, :caption def initialize(name, url, options) @name = name @url = url @condition = options[:if] @param = options[:param] || :id + @caption = options[:caption] || name.to_s.humanize end end end |