##// END OF EJS Templates
Remember "Only display used statuses" checkbox value after update....
Jean-Philippe Lang -
r9814:072475b8a5bc
parent child
Show More
@@ -1,128 +1,128
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class WorkflowsController < ApplicationController
18 class WorkflowsController < ApplicationController
19 layout 'admin'
19 layout 'admin'
20
20
21 before_filter :require_admin, :find_roles, :find_trackers
21 before_filter :require_admin, :find_roles, :find_trackers
22
22
23 def index
23 def index
24 @workflow_counts = WorkflowTransition.count_by_tracker_and_role
24 @workflow_counts = WorkflowTransition.count_by_tracker_and_role
25 end
25 end
26
26
27 def edit
27 def edit
28 @role = Role.find_by_id(params[:role_id]) if params[:role_id]
28 @role = Role.find_by_id(params[:role_id]) if params[:role_id]
29 @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
29 @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
30
30
31 if request.post?
31 if request.post?
32 WorkflowTransition.destroy_all( ["role_id=? and tracker_id=?", @role.id, @tracker.id])
32 WorkflowTransition.destroy_all( ["role_id=? and tracker_id=?", @role.id, @tracker.id])
33 (params[:issue_status] || []).each { |status_id, transitions|
33 (params[:issue_status] || []).each { |status_id, transitions|
34 transitions.each { |new_status_id, options|
34 transitions.each { |new_status_id, options|
35 author = options.is_a?(Array) && options.include?('author') && !options.include?('always')
35 author = options.is_a?(Array) && options.include?('author') && !options.include?('always')
36 assignee = options.is_a?(Array) && options.include?('assignee') && !options.include?('always')
36 assignee = options.is_a?(Array) && options.include?('assignee') && !options.include?('always')
37 WorkflowTransition.create(:role_id => @role.id, :tracker_id => @tracker.id, :old_status_id => status_id, :new_status_id => new_status_id, :author => author, :assignee => assignee)
37 WorkflowTransition.create(:role_id => @role.id, :tracker_id => @tracker.id, :old_status_id => status_id, :new_status_id => new_status_id, :author => author, :assignee => assignee)
38 }
38 }
39 }
39 }
40 if @role.save
40 if @role.save
41 redirect_to :action => 'edit', :role_id => @role, :tracker_id => @tracker
41 redirect_to :action => 'edit', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]
42 return
42 return
43 end
43 end
44 end
44 end
45
45
46 @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
46 @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
47 if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
47 if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
48 @statuses = @tracker.issue_statuses
48 @statuses = @tracker.issue_statuses
49 end
49 end
50 @statuses ||= IssueStatus.sorted.all
50 @statuses ||= IssueStatus.sorted.all
51
51
52 if @tracker && @role && @statuses.any?
52 if @tracker && @role && @statuses.any?
53 workflows = WorkflowTransition.where(:role_id => @role.id, :tracker_id => @tracker.id).all
53 workflows = WorkflowTransition.where(:role_id => @role.id, :tracker_id => @tracker.id).all
54 @workflows = {}
54 @workflows = {}
55 @workflows['always'] = workflows.select {|w| !w.author && !w.assignee}
55 @workflows['always'] = workflows.select {|w| !w.author && !w.assignee}
56 @workflows['author'] = workflows.select {|w| w.author}
56 @workflows['author'] = workflows.select {|w| w.author}
57 @workflows['assignee'] = workflows.select {|w| w.assignee}
57 @workflows['assignee'] = workflows.select {|w| w.assignee}
58 end
58 end
59 end
59 end
60
60
61 def permissions
61 def permissions
62 @role = Role.find_by_id(params[:role_id]) if params[:role_id]
62 @role = Role.find_by_id(params[:role_id]) if params[:role_id]
63 @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
63 @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
64
64
65 if request.post? && @role && @tracker
65 if request.post? && @role && @tracker
66 WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {})
66 WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {})
67 redirect_to :action => 'permissions', :role_id => @role, :tracker_id => @tracker
67 redirect_to :action => 'permissions', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]
68 return
68 return
69 end
69 end
70
70
71 @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
71 @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
72 if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
72 if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
73 @statuses = @tracker.issue_statuses
73 @statuses = @tracker.issue_statuses
74 end
74 end
75 @statuses ||= IssueStatus.sorted.all
75 @statuses ||= IssueStatus.sorted.all
76
76
77 if @role && @tracker
77 if @role && @tracker
78 @fields = (Tracker::CORE_FIELDS_ALL - @tracker.disabled_core_fields).map {|field| [field, l("field_"+field.sub(/_id$/, ''))]}
78 @fields = (Tracker::CORE_FIELDS_ALL - @tracker.disabled_core_fields).map {|field| [field, l("field_"+field.sub(/_id$/, ''))]}
79 @custom_fields = @tracker.custom_fields
79 @custom_fields = @tracker.custom_fields
80
80
81 @permissions = WorkflowPermission.where(:tracker_id => @tracker.id, :role_id => @role.id).all.inject({}) do |h, w|
81 @permissions = WorkflowPermission.where(:tracker_id => @tracker.id, :role_id => @role.id).all.inject({}) do |h, w|
82 h[w.old_status_id] ||= {}
82 h[w.old_status_id] ||= {}
83 h[w.old_status_id][w.field_name] = w.rule
83 h[w.old_status_id][w.field_name] = w.rule
84 h
84 h
85 end
85 end
86 @statuses.each {|status| @permissions[status.id] ||= {}}
86 @statuses.each {|status| @permissions[status.id] ||= {}}
87 end
87 end
88 end
88 end
89
89
90 def copy
90 def copy
91
91
92 if params[:source_tracker_id].blank? || params[:source_tracker_id] == 'any'
92 if params[:source_tracker_id].blank? || params[:source_tracker_id] == 'any'
93 @source_tracker = nil
93 @source_tracker = nil
94 else
94 else
95 @source_tracker = Tracker.find_by_id(params[:source_tracker_id].to_i)
95 @source_tracker = Tracker.find_by_id(params[:source_tracker_id].to_i)
96 end
96 end
97 if params[:source_role_id].blank? || params[:source_role_id] == 'any'
97 if params[:source_role_id].blank? || params[:source_role_id] == 'any'
98 @source_role = nil
98 @source_role = nil
99 else
99 else
100 @source_role = Role.find_by_id(params[:source_role_id].to_i)
100 @source_role = Role.find_by_id(params[:source_role_id].to_i)
101 end
101 end
102
102
103 @target_trackers = params[:target_tracker_ids].blank? ? nil : Tracker.find_all_by_id(params[:target_tracker_ids])
103 @target_trackers = params[:target_tracker_ids].blank? ? nil : Tracker.find_all_by_id(params[:target_tracker_ids])
104 @target_roles = params[:target_role_ids].blank? ? nil : Role.find_all_by_id(params[:target_role_ids])
104 @target_roles = params[:target_role_ids].blank? ? nil : Role.find_all_by_id(params[:target_role_ids])
105
105
106 if request.post?
106 if request.post?
107 if params[:source_tracker_id].blank? || params[:source_role_id].blank? || (@source_tracker.nil? && @source_role.nil?)
107 if params[:source_tracker_id].blank? || params[:source_role_id].blank? || (@source_tracker.nil? && @source_role.nil?)
108 flash.now[:error] = l(:error_workflow_copy_source)
108 flash.now[:error] = l(:error_workflow_copy_source)
109 elsif @target_trackers.nil? || @target_roles.nil?
109 elsif @target_trackers.nil? || @target_roles.nil?
110 flash.now[:error] = l(:error_workflow_copy_target)
110 flash.now[:error] = l(:error_workflow_copy_target)
111 else
111 else
112 WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles)
112 WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles)
113 flash[:notice] = l(:notice_successful_update)
113 flash[:notice] = l(:notice_successful_update)
114 redirect_to :action => 'copy', :source_tracker_id => @source_tracker, :source_role_id => @source_role
114 redirect_to :action => 'copy', :source_tracker_id => @source_tracker, :source_role_id => @source_role
115 end
115 end
116 end
116 end
117 end
117 end
118
118
119 private
119 private
120
120
121 def find_roles
121 def find_roles
122 @roles = Role.sorted.all
122 @roles = Role.sorted.all
123 end
123 end
124
124
125 def find_trackers
125 def find_trackers
126 @trackers = Tracker.sorted.all
126 @trackers = Tracker.sorted.all
127 end
127 end
128 end
128 end
@@ -1,57 +1,58
1 <%= render :partial => 'action_menu' %>
1 <%= render :partial => 'action_menu' %>
2
2
3 <h2><%=l(:label_workflow)%></h2>
3 <h2><%=l(:label_workflow)%></h2>
4
4
5 <div class="tabs">
5 <div class="tabs">
6 <ul>
6 <ul>
7 <li><%= link_to l(:label_status_transitions), {:action => 'edit', :role_id => @role, :tracker_id => @tracker}, :class => 'selected' %></li>
7 <li><%= link_to l(:label_status_transitions), {:action => 'edit', :role_id => @role, :tracker_id => @tracker}, :class => 'selected' %></li>
8 <li><%= link_to l(:label_fields_permissions), {:action => 'permissions', :role_id => @role, :tracker_id => @tracker} %></li>
8 <li><%= link_to l(:label_fields_permissions), {:action => 'permissions', :role_id => @role, :tracker_id => @tracker} %></li>
9 </ul>
9 </ul>
10 </div>
10 </div>
11
11
12 <p><%=l(:text_workflow_edit)%>:</p>
12 <p><%=l(:text_workflow_edit)%>:</p>
13
13
14 <%= form_tag({}, :method => 'get') do %>
14 <%= form_tag({}, :method => 'get') do %>
15 <p>
15 <p>
16 <label><%=l(:label_role)%>:
16 <label><%=l(:label_role)%>:
17 <%= select_tag 'role_id', options_from_collection_for_select(@roles, "id", "name", @role && @role.id) %></label>
17 <%= select_tag 'role_id', options_from_collection_for_select(@roles, "id", "name", @role && @role.id) %></label>
18
18
19 <label><%=l(:label_tracker)%>:
19 <label><%=l(:label_tracker)%>:
20 <%= select_tag 'tracker_id', options_from_collection_for_select(@trackers, "id", "name", @tracker && @tracker.id) %></label>
20 <%= select_tag 'tracker_id', options_from_collection_for_select(@trackers, "id", "name", @tracker && @tracker.id) %></label>
21
21
22 <%= submit_tag l(:button_edit), :name => nil %>
22 <%= submit_tag l(:button_edit), :name => nil %>
23
23
24 <%= hidden_field_tag 'used_statuses_only', '0' %>
24 <%= hidden_field_tag 'used_statuses_only', '0' %>
25 <label><%= check_box_tag 'used_statuses_only', '1', @used_statuses_only %> <%= l(:label_display_used_statuses_only) %></label>
25 <label><%= check_box_tag 'used_statuses_only', '1', @used_statuses_only %> <%= l(:label_display_used_statuses_only) %></label>
26
26
27 </p>
27 </p>
28 <% end %>
28 <% end %>
29
29
30 <% if @tracker && @role && @statuses.any? %>
30 <% if @tracker && @role && @statuses.any? %>
31 <%= form_tag({}, :id => 'workflow_form' ) do %>
31 <%= form_tag({}, :id => 'workflow_form' ) do %>
32 <%= hidden_field_tag 'tracker_id', @tracker.id %>
32 <%= hidden_field_tag 'tracker_id', @tracker.id %>
33 <%= hidden_field_tag 'role_id', @role.id %>
33 <%= hidden_field_tag 'role_id', @role.id %>
34 <%= hidden_field_tag 'used_statuses_only', params[:used_statuses_only] %>
34 <div class="autoscroll">
35 <div class="autoscroll">
35 <%= render :partial => 'form', :locals => {:name => 'always', :workflows => @workflows['always']} %>
36 <%= render :partial => 'form', :locals => {:name => 'always', :workflows => @workflows['always']} %>
36
37
37 <fieldset class="collapsible" style="padding: 0; margin-top: 0.5em;">
38 <fieldset class="collapsible" style="padding: 0; margin-top: 0.5em;">
38 <legend onclick="toggleFieldset(this);"><%= l(:label_additional_workflow_transitions_for_author) %></legend>
39 <legend onclick="toggleFieldset(this);"><%= l(:label_additional_workflow_transitions_for_author) %></legend>
39 <div id="author_workflows" style="margin: 0.5em 0 0.5em 0;">
40 <div id="author_workflows" style="margin: 0.5em 0 0.5em 0;">
40 <%= render :partial => 'form', :locals => {:name => 'author', :workflows => @workflows['author']} %>
41 <%= render :partial => 'form', :locals => {:name => 'author', :workflows => @workflows['author']} %>
41 </div>
42 </div>
42 </fieldset>
43 </fieldset>
43 <%= javascript_tag "hideFieldset($('author_workflows'))" unless @workflows['author'].present? %>
44 <%= javascript_tag "hideFieldset($('author_workflows'))" unless @workflows['author'].present? %>
44
45
45 <fieldset class="collapsible" style="padding: 0;">
46 <fieldset class="collapsible" style="padding: 0;">
46 <legend onclick="toggleFieldset(this);"><%= l(:label_additional_workflow_transitions_for_assignee) %></legend>
47 <legend onclick="toggleFieldset(this);"><%= l(:label_additional_workflow_transitions_for_assignee) %></legend>
47 <div id="assignee_workflows" style="margin: 0.5em 0 0.5em 0;">
48 <div id="assignee_workflows" style="margin: 0.5em 0 0.5em 0;">
48 <%= render :partial => 'form', :locals => {:name => 'assignee', :workflows => @workflows['assignee']} %>
49 <%= render :partial => 'form', :locals => {:name => 'assignee', :workflows => @workflows['assignee']} %>
49 </div>
50 </div>
50 </fieldset>
51 </fieldset>
51 <%= javascript_tag "hideFieldset($('assignee_workflows'))" unless @workflows['assignee'].present? %>
52 <%= javascript_tag "hideFieldset($('assignee_workflows'))" unless @workflows['assignee'].present? %>
52 </div>
53 </div>
53 <%= submit_tag l(:button_save) %>
54 <%= submit_tag l(:button_save) %>
54 <% end %>
55 <% end %>
55 <% end %>
56 <% end %>
56
57
57 <% html_title(l(:label_workflow)) -%>
58 <% html_title(l(:label_workflow)) -%>
@@ -1,94 +1,95
1 <%= render :partial => 'action_menu' %>
1 <%= render :partial => 'action_menu' %>
2
2
3 <h2><%=l(:label_workflow)%></h2>
3 <h2><%=l(:label_workflow)%></h2>
4
4
5 <div class="tabs">
5 <div class="tabs">
6 <ul>
6 <ul>
7 <li><%= link_to l(:label_status_transitions), {:action => 'edit', :role_id => @role, :tracker_id => @tracker} %></li>
7 <li><%= link_to l(:label_status_transitions), {:action => 'edit', :role_id => @role, :tracker_id => @tracker} %></li>
8 <li><%= link_to l(:label_fields_permissions), {:action => 'permissions', :role_id => @role, :tracker_id => @tracker}, :class => 'selected' %></li>
8 <li><%= link_to l(:label_fields_permissions), {:action => 'permissions', :role_id => @role, :tracker_id => @tracker}, :class => 'selected' %></li>
9 </ul>
9 </ul>
10 </div>
10 </div>
11
11
12 <p><%=l(:text_workflow_edit)%>:</p>
12 <p><%=l(:text_workflow_edit)%>:</p>
13
13
14 <%= form_tag({}, :method => 'get') do %>
14 <%= form_tag({}, :method => 'get') do %>
15 <p>
15 <p>
16 <label><%=l(:label_role)%>:
16 <label><%=l(:label_role)%>:
17 <%= select_tag 'role_id', options_from_collection_for_select(@roles, "id", "name", @role && @role.id) %></label>
17 <%= select_tag 'role_id', options_from_collection_for_select(@roles, "id", "name", @role && @role.id) %></label>
18
18
19 <label><%=l(:label_tracker)%>:
19 <label><%=l(:label_tracker)%>:
20 <%= select_tag 'tracker_id', options_from_collection_for_select(@trackers, "id", "name", @tracker && @tracker.id) %></label>
20 <%= select_tag 'tracker_id', options_from_collection_for_select(@trackers, "id", "name", @tracker && @tracker.id) %></label>
21
21
22 <%= submit_tag l(:button_edit), :name => nil %>
22 <%= submit_tag l(:button_edit), :name => nil %>
23
23
24 <%= hidden_field_tag 'used_statuses_only', '0' %>
24 <%= hidden_field_tag 'used_statuses_only', '0' %>
25 <label><%= check_box_tag 'used_statuses_only', '1', @used_statuses_only %> <%= l(:label_display_used_statuses_only) %></label>
25 <label><%= check_box_tag 'used_statuses_only', '1', @used_statuses_only %> <%= l(:label_display_used_statuses_only) %></label>
26 </p>
26 </p>
27 <% end %>
27 <% end %>
28
28
29 <% if @tracker && @role && @statuses.any? %>
29 <% if @tracker && @role && @statuses.any? %>
30 <%= form_tag({}, :id => 'workflow_form' ) do %>
30 <%= form_tag({}, :id => 'workflow_form' ) do %>
31 <%= hidden_field_tag 'tracker_id', @tracker.id %>
31 <%= hidden_field_tag 'tracker_id', @tracker.id %>
32 <%= hidden_field_tag 'role_id', @role.id %>
32 <%= hidden_field_tag 'role_id', @role.id %>
33 <%= hidden_field_tag 'used_statuses_only', params[:used_statuses_only] %>
33 <div class="autoscroll">
34 <div class="autoscroll">
34 <table class="list fields_permissions">
35 <table class="list fields_permissions">
35 <thead>
36 <thead>
36 <tr>
37 <tr>
37 <th align="left">
38 <th align="left">
38 </th>
39 </th>
39 <th align="center" colspan="<%= @statuses.length %>"><%=l(:label_issue_status)%></th>
40 <th align="center" colspan="<%= @statuses.length %>"><%=l(:label_issue_status)%></th>
40 </tr>
41 </tr>
41 <tr>
42 <tr>
42 <td></td>
43 <td></td>
43 <% for status in @statuses %>
44 <% for status in @statuses %>
44 <td width="<%= 75 / @statuses.size %>%" align="center">
45 <td width="<%= 75 / @statuses.size %>%" align="center">
45 <%=h status.name %>
46 <%=h status.name %>
46 </td>
47 </td>
47 <% end %>
48 <% end %>
48 </tr>
49 </tr>
49 </thead>
50 </thead>
50 <tbody>
51 <tbody>
51 <tr class="group open">
52 <tr class="group open">
52 <td colspan="<%= @statuses.size + 1 %>">
53 <td colspan="<%= @statuses.size + 1 %>">
53 <span class="expander" onclick="toggleRowGroup(this);">&nbsp;</span>
54 <span class="expander" onclick="toggleRowGroup(this);">&nbsp;</span>
54 <%= l(:field_core_fields) %>
55 <%= l(:field_core_fields) %>
55 </td>
56 </td>
56 </tr>
57 </tr>
57 <% @fields.each do |field, name| %>
58 <% @fields.each do |field, name| %>
58 <tr class="<%= cycle("odd", "even") %>">
59 <tr class="<%= cycle("odd", "even") %>">
59 <td>
60 <td>
60 <%=h name %>
61 <%=h name %>
61 </td>
62 </td>
62 <% for status in @statuses -%>
63 <% for status in @statuses -%>
63 <td align="center" class="<%= @permissions[status.id][field] %>">
64 <td align="center" class="<%= @permissions[status.id][field] %>">
64 <%= field_permission_tag(@permissions, status, field) %>
65 <%= field_permission_tag(@permissions, status, field) %>
65 </td>
66 </td>
66 <% end -%>
67 <% end -%>
67 </tr>
68 </tr>
68 <% end %>
69 <% end %>
69 <% if @custom_fields.any? %>
70 <% if @custom_fields.any? %>
70 <tr class="group open">
71 <tr class="group open">
71 <td colspan="<%= @statuses.size + 1 %>">
72 <td colspan="<%= @statuses.size + 1 %>">
72 <span class="expander" onclick="toggleRowGroup(this);">&nbsp;</span>
73 <span class="expander" onclick="toggleRowGroup(this);">&nbsp;</span>
73 <%= l(:label_custom_field_plural) %>
74 <%= l(:label_custom_field_plural) %>
74 </td>
75 </td>
75 </tr>
76 </tr>
76 <% @custom_fields.each do |field| %>
77 <% @custom_fields.each do |field| %>
77 <tr class="<%= cycle("odd", "even") %>">
78 <tr class="<%= cycle("odd", "even") %>">
78 <td>
79 <td>
79 <%=h field.name %>
80 <%=h field.name %>
80 </td>
81 </td>
81 <% for status in @statuses -%>
82 <% for status in @statuses -%>
82 <td align="center" class="<%= @permissions[status.id][field.id.to_s] %>">
83 <td align="center" class="<%= @permissions[status.id][field.id.to_s] %>">
83 <%= field_permission_tag(@permissions, status, field) %>
84 <%= field_permission_tag(@permissions, status, field) %>
84 </td>
85 </td>
85 <% end -%>
86 <% end -%>
86 </tr>
87 </tr>
87 <% end %>
88 <% end %>
88 <% end %>
89 <% end %>
89 </tbody>
90 </tbody>
90 </table>
91 </table>
91 </div>
92 </div>
92 <%= submit_tag l(:button_save) %>
93 <%= submit_tag l(:button_save) %>
93 <% end %>
94 <% end %>
94 <% end %>
95 <% end %>
General Comments 0
You need to be logged in to leave comments. Login now