diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-02-22 18:19:00 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2008-02-22 18:19:00 +0000 |
commit | 792b7f30e32eec84d6106e947fc3987e4e26a0b0 (patch) | |
tree | 4cb8b01adcbd16fd7b0bde60c0372ccb57f42e6f /lib | |
parent | b0bb41ad355771d4ae4704585f29bc12ae6c345d (diff) | |
download | redmine-792b7f30e32eec84d6106e947fc3987e4e26a0b0.tar.gz redmine-792b7f30e32eec84d6106e947fc3987e4e26a0b0.zip |
Menus items:
* fixed broken translation when a plugin is installed (closes #649)
* small fix to the plugin API: options parameter added to Redmine::Plugin#menu
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1172 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib')
-rw-r--r-- | lib/redmine/menu_manager.rb | 9 | ||||
-rw-r--r-- | lib/redmine/plugin.rb | 9 |
2 files changed, 12 insertions, 6 deletions
diff --git a/lib/redmine/menu_manager.rb b/lib/redmine/menu_manager.rb index 3b29912a1..c645b5ce8 100644 --- a/lib/redmine/menu_manager.rb +++ b/lib/redmine/menu_manager.rb @@ -122,7 +122,7 @@ module Redmine class MenuItem include GLoc - attr_reader :name, :url, :param, :condition, :caption, :html_options + attr_reader :name, :url, :param, :condition, :html_options def initialize(name, url, options) raise "Invalid option :if for menu item '#{name}'" if options[:if] && !options[:if].respond_to?(:call) @@ -131,9 +131,14 @@ module Redmine @url = url @condition = options[:if] @param = options[:param] || :id - @caption = options[:caption] || (l_has_string?("label_#{name}".to_sym) ? "label_#{name}".to_sym : name.to_s.humanize) + @caption_key = options[:caption] @html_options = options[:html] || {} end + + def caption + # check if localized string exists on first render (after GLoc strings are loaded) + @caption ||= (@caption_key || (l_has_string?("label_#{@name}".to_sym) ? "label_#{@name}".to_sym : @name.to_s.humanize)) + end end end end diff --git a/lib/redmine/plugin.rb b/lib/redmine/plugin.rb index e6047974e..36632c13e 100644 --- a/lib/redmine/plugin.rb +++ b/lib/redmine/plugin.rb @@ -66,11 +66,12 @@ module Redmine #:nodoc: # Adds an item to the given +menu+. # The +id+ parameter (equals to the project id) is automatically added to the url. - # menu :project_menu, :label_plugin_example, :controller => 'example', :action => 'say_hello' + # menu :project_menu, :plugin_example, { :controller => 'example', :action => 'say_hello' }, :caption => 'Sample' # - # Currently, only the project menu can be extended. Thus, the +name+ parameter must be +:project_menu+ - def menu(name, label, url) - Redmine::MenuManager.map(name) {|menu| menu.push label, url} + # +name+ parameter can be: :top_menu, :account_menu, :application_menu or :project_menu + # + def menu(name, item, url, options={}) + Redmine::MenuManager.map(name) {|menu| menu.push item, url, options} end # Defines a permission called +name+ for the given +actions+. |