summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2008-01-19 11:53:43 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2008-01-19 11:53:43 +0000
commit0faa4568a0ab18277259ad1c89309c3c53fa42de (patch)
tree0bcdcc9bfb1263980715b650cffd3a7236d5feeb /lib
parent3e031b4243b38c3739936ae143acf21d305cd570 (diff)
downloadredmine-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.rb25
-rw-r--r--lib/redmine/menu_manager.rb60
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