diff options
-rw-r--r-- | app/controllers/issues_controller.rb | 10 | ||||
-rw-r--r-- | app/views/settings/_display.html.erb | 2 | ||||
-rw-r--r-- | config/locales/en.yml | 1 | ||||
-rw-r--r-- | config/locales/fr.yml | 1 | ||||
-rw-r--r-- | config/settings.yml | 2 | ||||
-rw-r--r-- | lib/redmine.rb | 4 | ||||
-rw-r--r-- | test/functional/issues_controller_test.rb | 54 |
7 files changed, 70 insertions, 4 deletions
diff --git a/app/controllers/issues_controller.rb b/app/controllers/issues_controller.rb index 7c10769aa..cf402de22 100644 --- a/app/controllers/issues_controller.rb +++ b/app/controllers/issues_controller.rb @@ -350,6 +350,16 @@ class IssuesController < ApplicationController end end + # Overrides Redmine::MenuManager::MenuController::ClassMethods for + # when the "New issue" tab is enabled + def current_menu_item + if Setting.new_project_issue_tab_enabled? && [:new, :create].include?(action_name.to_sym) + :new_issue + else + super + end + end + private def retrieve_previous_and_next_issue_ids diff --git a/app/views/settings/_display.html.erb b/app/views/settings/_display.html.erb index 3497f9076..1185a7cae 100644 --- a/app/views/settings/_display.html.erb +++ b/app/views/settings/_display.html.erb @@ -24,6 +24,8 @@ <p><%= setting_check_box :thumbnails_enabled %></p> <p><%= setting_text_field :thumbnails_size, :size => 6 %></p> + +<p><%= setting_check_box :new_project_issue_tab_enabled %></p> </div> <%= submit_tag l(:button_save) %> diff --git a/config/locales/en.yml b/config/locales/en.yml index e1a8f2bd4..b3396c5de 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -443,6 +443,7 @@ en: setting_search_results_per_page: Search results per page setting_attachment_extensions_allowed: Allowed extensions setting_attachment_extensions_denied: Disallowed extensions + setting_new_project_issue_tab_enabled: Display the "New issue" tab permission_add_project: Create project permission_add_subprojects: Create subprojects diff --git a/config/locales/fr.yml b/config/locales/fr.yml index 659a873ea..6a72024f6 100644 --- a/config/locales/fr.yml +++ b/config/locales/fr.yml @@ -455,6 +455,7 @@ fr: setting_attachment_extensions_denied: Extensions non autorisées setting_sys_api_key: Clé de protection de l'API setting_lost_password: Autoriser la réinitialisation par email de mot de passe perdu + setting_new_project_issue_tab_enabled: Afficher l'onglet "Nouvelle demande" permission_add_project: Créer un projet permission_add_subprojects: Créer des sous-projets diff --git a/config/settings.yml b/config/settings.yml index 20dfe5416..fd807c8a1 100644 --- a/config/settings.yml +++ b/config/settings.yml @@ -275,3 +275,5 @@ non_working_week_days: default: - '6' - '7' +new_project_issue_tab_enabled: + default: 0 diff --git a/lib/redmine.rb b/lib/redmine.rb index 540384071..1d37a523b 100644 --- a/lib/redmine.rb +++ b/lib/redmine.rb @@ -231,6 +231,10 @@ Redmine::MenuManager.map :project_menu do |menu| menu.push :roadmap, { :controller => 'versions', :action => 'index' }, :param => :project_id, :if => Proc.new { |p| p.shared_versions.any? } menu.push :issues, { :controller => 'issues', :action => 'index' }, :param => :project_id, :caption => :label_issue_plural + menu.push :new_issue, { :controller => 'issues', :action => 'new', :copy_from => nil }, :param => :project_id, :caption => :label_issue_new, + :html => { :accesskey => Redmine::AccessKeys.key_for(:new_issue) }, + :if => Proc.new { |p| Setting.new_project_issue_tab_enabled? && p.trackers.any? }, + :permission => :add_issues menu.push :gantt, { :controller => 'gantts', :action => 'show' }, :param => :project_id, :caption => :label_gantt menu.push :calendar, { :controller => 'calendars', :action => 'show' }, :param => :project_id, :caption => :label_calendar menu.push :news, { :controller => 'news', :action => 'index' }, :param => :project_id, :caption => :label_news_plural diff --git a/test/functional/issues_controller_test.rb b/test/functional/issues_controller_test.rb index 0a021289a..8e04d7cf5 100644 --- a/test/functional/issues_controller_test.rb +++ b/test/functional/issues_controller_test.rb @@ -1060,7 +1060,7 @@ class IssuesControllerTest < ActionController::TestCase def test_index_should_include_new_issue_link @request.session[:user_id] = 2 get :index, :project_id => 1 - assert_select 'a.new-issue[href="/projects/ecookbook/issues/new"]', :text => 'New issue' + assert_select '#content a.new-issue[href="/projects/ecookbook/issues/new"]', :text => 'New issue' end def test_index_should_not_include_new_issue_link_for_project_without_trackers @@ -1068,7 +1068,7 @@ class IssuesControllerTest < ActionController::TestCase @request.session[:user_id] = 2 get :index, :project_id => 1 - assert_select 'a.new-issue', 0 + assert_select '#content a.new-issue', 0 end def test_index_should_not_include_new_issue_link_for_users_with_copy_issues_permission_only @@ -1078,13 +1078,59 @@ class IssuesControllerTest < ActionController::TestCase @request.session[:user_id] = 2 get :index, :project_id => 1 - assert_select 'a.new-issue', 0 + assert_select '#content a.new-issue', 0 end def test_index_without_project_should_include_new_issue_link @request.session[:user_id] = 2 get :index - assert_select 'a.new-issue[href="/issues/new"]', :text => 'New issue' + assert_select '#content a.new-issue[href="/issues/new"]', :text => 'New issue' + end + + def test_index_should_not_include_new_issue_tab_when_disabled + with_settings :new_project_issue_tab_enabled => '0' do + @request.session[:user_id] = 2 + get :index, :project_id => 1 + assert_select '#main-menu a.new-issue', 0 + end + end + + def test_index_should_include_new_issue_tab_when_enabled + with_settings :new_project_issue_tab_enabled => '1' do + @request.session[:user_id] = 2 + get :index, :project_id => 1 + assert_select '#main-menu a.new-issue[href="/projects/ecookbook/issues/new"]', :text => 'New issue' + end + end + + def test_new_should_have_new_issue_tab_as_current_menu_item + with_settings :new_project_issue_tab_enabled => '1' do + @request.session[:user_id] = 2 + get :new, :project_id => 1 + assert_select '#main-menu a.new-issue.selected' + end + end + + def test_index_should_not_include_new_issue_tab_for_project_without_trackers + with_settings :new_project_issue_tab_enabled => '1' do + Project.find(1).trackers.clear + + @request.session[:user_id] = 2 + get :index, :project_id => 1 + assert_select '#main-menu a.new-issue', 0 + end + end + + def test_index_should_not_include_new_issue_tab_for_users_with_copy_issues_permission_only + with_settings :new_project_issue_tab_enabled => '1' do + role = Role.find(1) + role.remove_permission! :add_issues + role.add_permission! :copy_issues + + @request.session[:user_id] = 2 + get :index, :project_id => 1 + assert_select '#main-menu a.new-issue', 0 + end end def test_show_by_anonymous |