summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2009-01-17 08:25:55 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2009-01-17 08:25:55 +0000
commit5ed2e78ae2abc249c410665f65b1ed9e84c4d6c5 (patch)
tree3633734ae47a08d75666f8e8ca5fae788c0f2ddf
parentd1a1e25bb8902ec46c5b3cc95dc5dad5f3e7265c (diff)
downloadredmine-5ed2e78ae2abc249c410665f65b1ed9e84c4d6c5.tar.gz
redmine-5ed2e78ae2abc249c410665f65b1ed9e84c4d6c5.zip
Make use of tracker_ids association in issue custom field form.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2272 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/controllers/custom_fields_controller.rb4
-rw-r--r--app/views/custom_fields/_form.rhtml5
-rw-r--r--test/functional/custom_fields_controller_test.rb4
3 files changed, 5 insertions, 8 deletions
diff --git a/app/controllers/custom_fields_controller.rb b/app/controllers/custom_fields_controller.rb
index 4589996f1..9b13d19b6 100644
--- a/app/controllers/custom_fields_controller.rb
+++ b/app/controllers/custom_fields_controller.rb
@@ -33,7 +33,6 @@ class CustomFieldsController < ApplicationController
case params[:type]
when "IssueCustomField"
@custom_field = IssueCustomField.new(params[:custom_field])
- @custom_field.trackers = Tracker.find(params[:tracker_ids]) if params[:tracker_ids]
when "UserCustomField"
@custom_field = UserCustomField.new(params[:custom_field])
when "ProjectCustomField"
@@ -54,9 +53,6 @@ class CustomFieldsController < ApplicationController
def edit
@custom_field = CustomField.find(params[:id])
if request.post? and @custom_field.update_attributes(params[:custom_field])
- if @custom_field.is_a? IssueCustomField
- @custom_field.trackers = params[:tracker_ids] ? Tracker.find(params[:tracker_ids]) : []
- end
flash[:notice] = l(:notice_successful_update)
redirect_to :action => 'list', :tab => @custom_field.class.name
end
diff --git a/app/views/custom_fields/_form.rhtml b/app/views/custom_fields/_form.rhtml
index 43ed5feb9..0222ddb66 100644
--- a/app/views/custom_fields/_form.rhtml
+++ b/app/views/custom_fields/_form.rhtml
@@ -67,13 +67,14 @@ function toggle_custom_field_format() {
</div>
<div class="box">
-<% case @custom_field.type.to_s
+<% case @custom_field.class.name
when "IssueCustomField" %>
<fieldset><legend><%=l(:label_tracker_plural)%></legend>
<% for tracker in @trackers %>
- <%= check_box_tag "tracker_ids[]", tracker.id, (@custom_field.trackers.include? tracker) %> <%= tracker.name %>
+ <%= check_box_tag "custom_field[tracker_ids][]", tracker.id, (@custom_field.trackers.include? tracker) %> <%= tracker.name %>
<% end %>
+ <%= hidden_field_tag "custom_field[tracker_ids][]", '' %>
</fieldset>
&nbsp;
<p><%= f.check_box :is_required %></p>
diff --git a/test/functional/custom_fields_controller_test.rb b/test/functional/custom_fields_controller_test.rb
index fa36d2afd..d77bad527 100644
--- a/test/functional/custom_fields_controller_test.rb
+++ b/test/functional/custom_fields_controller_test.rb
@@ -34,7 +34,6 @@ class CustomFieldsControllerTest < Test::Unit::TestCase
def test_post_new_list_custom_field
assert_difference 'CustomField.count' do
post :new, :type => "IssueCustomField",
- :tracker_ids => ["1"],
:custom_field => {:name => "test_post_new_list",
:default_value => "",
:min_length => "0",
@@ -45,7 +44,8 @@ class CustomFieldsControllerTest < Test::Unit::TestCase
:max_length => "0",
:is_filter => "0",
:is_required =>"0",
- :field_format => "list"}
+ :field_format => "list",
+ :tracker_ids => ["1", ""]}
end
assert_redirected_to '/custom_fields/list'
field = IssueCustomField.find_by_name('test_post_new_list')