@@ -0,0 +1,9 | |||
|
1 | <h3 class="title"><%=l(:label_version_new)%></h3> | |
|
2 | ||
|
3 | <% labelled_remote_form_for @version, :url => project_versions_path(@project) do |f| %> | |
|
4 | <%= render :partial => 'versions/form', :locals => { :f => f } %> | |
|
5 | <p class="buttons"> | |
|
6 | <%= submit_tag l(:button_create), :name => nil %> | |
|
7 | <%= submit_tag l(:button_cancel), :name => nil, :onclick => "hideModal(this);", :type => 'button' %> | |
|
8 | </p> | |
|
9 | <% end %> |
@@ -75,6 +75,17 class VersionsController < ApplicationController | |||
|
75 | 75 | |
|
76 | 76 | def new |
|
77 | 77 | @version = @project.versions.build(params[:version]) |
|
78 | ||
|
79 | respond_to do |format| | |
|
80 | format.html | |
|
81 | format.js do | |
|
82 | render :update do |page| | |
|
83 | page.replace_html 'ajax-modal', :partial => 'versions/new_modal' | |
|
84 | page << "showModal('ajax-modal', '600px');" | |
|
85 | page << "Form.Element.focus('version_name');" | |
|
86 | end | |
|
87 | end | |
|
88 | end | |
|
78 | 89 | end |
|
79 | 90 | |
|
80 | 91 | def create |
@@ -93,8 +104,10 class VersionsController < ApplicationController | |||
|
93 | 104 | redirect_back_or_default :controller => 'projects', :action => 'settings', :tab => 'versions', :id => @project |
|
94 | 105 | end |
|
95 | 106 | format.js do |
|
107 | render(:update) {|page| | |
|
108 | page << 'hideModal();' | |
|
96 | 109 | # IE doesn't support the replace_html rjs method for select box options |
|
97 |
|
|
|
110 | page.replace "issue_fixed_version_id", | |
|
98 | 111 | content_tag('select', '<option></option>' + version_options_for_select(@project.shared_versions.open, @version), :id => 'issue_fixed_version_id', :name => 'issue[fixed_version_id]') |
|
99 | 112 | } |
|
100 | 113 | end |
@@ -106,7 +119,10 class VersionsController < ApplicationController | |||
|
106 | 119 | respond_to do |format| |
|
107 | 120 | format.html { render :action => 'new' } |
|
108 | 121 | format.js do |
|
109 | render(:update) {|page| page.alert(@version.errors.full_messages.join('\n')) } | |
|
122 | render :update do |page| | |
|
123 | page.replace_html 'ajax-modal', :partial => 'versions/new_modal' | |
|
124 | page << "Form.Element.focus('version_name');" | |
|
125 | end | |
|
110 | 126 | end |
|
111 | 127 | format.api { render_validation_errors(@version) } |
|
112 | 128 | end |
@@ -27,10 +27,8 | |||
|
27 | 27 | |
|
28 | 28 | <% if @issue.safe_attribute?('fixed_version_id') && @issue.assignable_versions.any? %> |
|
29 | 29 | <p><%= f.select :fixed_version_id, version_options_for_select(@issue.assignable_versions, @issue.fixed_version), :include_blank => true %> |
|
30 |
<%= |
|
|
31 | l(:label_version_new), | |
|
32 | 'version[name]', | |
|
33 | {:controller => 'versions', :action => 'create', :project_id => @issue.project}, | |
|
30 | <%= link_to_remote(image_tag('add.png', :style => 'vertical-align: middle;'), | |
|
31 | {:url => new_project_version_path(@issue.project), :method => 'get'}, | |
|
34 | 32 |
|
|
35 | 33 |
|
|
36 | 34 | </p> |
@@ -321,7 +321,12 function showModal(id, width) { | |||
|
321 | 321 | } |
|
322 | 322 | |
|
323 | 323 | function hideModal(el) { |
|
324 | var modal = Element.up(el, 'div.modal'); | |
|
324 | var modal; | |
|
325 | if (el) { | |
|
326 | modal = Element.up(el, 'div.modal'); | |
|
327 | } else { | |
|
328 | modal = $('ajax-modal'); | |
|
329 | } | |
|
325 | 330 | if (modal) { |
|
326 | 331 | modal.hide(); |
|
327 | 332 | } |
@@ -96,6 +96,16 class VersionsControllerTest < ActionController::TestCase | |||
|
96 | 96 | assert_template 'new' |
|
97 | 97 | end |
|
98 | 98 | |
|
99 | def test_new_from_issue_form | |
|
100 | @request.session[:user_id] = 2 | |
|
101 | xhr :get, :new, :project_id => '1' | |
|
102 | assert_response :success | |
|
103 | assert_select_rjs :replace_html, "ajax-modal" do | |
|
104 | assert_select "form[action=/projects/ecookbook/versions]" | |
|
105 | assert_select "input#version_name" | |
|
106 | end | |
|
107 | end | |
|
108 | ||
|
99 | 109 | def test_create |
|
100 | 110 | @request.session[:user_id] = 2 # manager |
|
101 | 111 | assert_difference 'Version.count' do |
@@ -108,15 +118,29 class VersionsControllerTest < ActionController::TestCase | |||
|
108 | 118 | end |
|
109 | 119 | |
|
110 | 120 | def test_create_from_issue_form |
|
111 |
@request.session[:user_id] = 2 |
|
|
121 | @request.session[:user_id] = 2 | |
|
112 | 122 | assert_difference 'Version.count' do |
|
113 | 123 | xhr :post, :create, :project_id => '1', :version => {:name => 'test_add_version_from_issue_form'} |
|
114 | 124 | end |
|
115 | assert_response :success | |
|
116 | assert_select_rjs :replace, 'issue_fixed_version_id' | |
|
117 | 125 | version = Version.find_by_name('test_add_version_from_issue_form') |
|
118 | 126 | assert_not_nil version |
|
119 | 127 | assert_equal 1, version.project_id |
|
128 | ||
|
129 | assert_response :success | |
|
130 | assert_select_rjs :replace, 'issue_fixed_version_id' do | |
|
131 | assert_select "option[value=#{version.id}][selected=selected]" | |
|
132 | end | |
|
133 | end | |
|
134 | ||
|
135 | def test_create_from_issue_form_with_failure | |
|
136 | @request.session[:user_id] = 2 | |
|
137 | assert_no_difference 'Version.count' do | |
|
138 | xhr :post, :create, :project_id => '1', :version => {:name => ''} | |
|
139 | end | |
|
140 | assert_response :success | |
|
141 | assert_select_rjs :replace_html, "ajax-modal" do | |
|
142 | assert_select "div#errorExplanation" | |
|
143 | end | |
|
120 | 144 | end |
|
121 | 145 | |
|
122 | 146 | def test_get_edit |
General Comments 0
You need to be logged in to leave comments.
Login now