diff options
author | Eric Davis <edavis@littlestreamsoftware.com> | 2010-10-05 16:07:17 +0000 |
---|---|---|
committer | Eric Davis <edavis@littlestreamsoftware.com> | 2010-10-05 16:07:17 +0000 |
commit | e13790c62c800a5b6d9528b5e2db2aad2c5e3710 (patch) | |
tree | 7be0ed076c62d3267a0f7839e07a6fcec011e533 /app/views/timelog | |
parent | a034172b24cde31bac0f18b842db8c76cfb80bb1 (diff) | |
download | redmine-e13790c62c800a5b6d9528b5e2db2aad2c5e3710.tar.gz redmine-e13790c62c800a5b6d9528b5e2db2aad2c5e3710.zip |
Refactor: extract TimelogController#report to a new controller class
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4232 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/views/timelog')
-rw-r--r-- | app/views/timelog/_date_range.rhtml | 2 | ||||
-rw-r--r-- | app/views/timelog/_report_criteria.rhtml | 19 | ||||
-rw-r--r-- | app/views/timelog/report.rhtml | 76 |
3 files changed, 1 insertions, 96 deletions
diff --git a/app/views/timelog/_date_range.rhtml b/app/views/timelog/_date_range.rhtml index 2482a9fc3..041e5587f 100644 --- a/app/views/timelog/_date_range.rhtml +++ b/app/views/timelog/_date_range.rhtml @@ -30,7 +30,7 @@ <ul> <li><%= link_to(l(:label_details), url_params.merge({:controller => 'timelog', :action => 'details', :project_id => @project, :issue_id => @issue }), :class => (@controller.action_name == 'details' ? 'selected' : nil)) %></li> - <li><%= link_to(l(:label_report), url_params.merge({:controller => 'timelog', :action => 'report', :project_id => @project, :issue_id => @issue}), + <li><%= link_to(l(:label_report), url_params.merge({:controller => 'time_entry_reports', :action => 'report', :project_id => @project, :issue_id => @issue}), :class => (@controller.action_name == 'report' ? 'selected' : nil)) %></li> </ul> </div> diff --git a/app/views/timelog/_report_criteria.rhtml b/app/views/timelog/_report_criteria.rhtml deleted file mode 100644 index c9a1cfb45..000000000 --- a/app/views/timelog/_report_criteria.rhtml +++ /dev/null @@ -1,19 +0,0 @@ -<% @hours.collect {|h| h[criterias[level]].to_s}.uniq.each do |value| %> -<% hours_for_value = select_hours(hours, criterias[level], value) -%> -<% next if hours_for_value.empty? -%> -<tr class="<%= cycle('odd', 'even') %> <%= 'last-level' unless criterias.length > level+1 %>"> -<%= '<td></td>' * level %> -<td><%= h(format_criteria_value(criterias[level], value)) %></td> -<%= '<td></td>' * (criterias.length - level - 1) -%> - <% total = 0 -%> - <% @periods.each do |period| -%> - <% sum = sum_hours(select_hours(hours_for_value, @columns, period.to_s)); total += sum -%> - <td class="hours"><%= html_hours("%.2f" % sum) if sum > 0 %></td> - <% end -%> - <td class="hours"><%= html_hours("%.2f" % total) if total > 0 %></td> -</tr> -<% if criterias.length > level+1 -%> - <%= render(:partial => 'report_criteria', :locals => {:criterias => criterias, :hours => hours_for_value, :level => (level + 1)}) %> -<% end -%> - -<% end %> diff --git a/app/views/timelog/report.rhtml b/app/views/timelog/report.rhtml deleted file mode 100644 index 533467ef2..000000000 --- a/app/views/timelog/report.rhtml +++ /dev/null @@ -1,76 +0,0 @@ -<div class="contextual"> -<%= link_to_if_authorized l(:button_log_time), {:controller => 'timelog', :action => 'edit', :project_id => @project, :issue_id => @issue}, :class => 'icon icon-time-add' %> -</div> - -<%= render_timelog_breadcrumb %> - -<h2><%= l(:label_spent_time) %></h2> - -<% form_remote_tag(:url => {}, :html => {:method => :get, :id => 'query_form'}, :method => :get, :update => 'content') do %> - <% @criterias.each do |criteria| %> - <%= hidden_field_tag 'criterias[]', criteria, :id => nil %> - <% end %> - <%# TODO: get rid of the project_id field, that should already be in the URL %> - <%= hidden_field_tag('project_id', params[:project_id]) if @project %> - <%= hidden_field_tag('issue_id', params[:issue_id]) if @issue %> - <%= render :partial => 'date_range' %> - - <p><%= l(:label_details) %>: <%= select_tag 'columns', options_for_select([[l(:label_year), 'year'], - [l(:label_month), 'month'], - [l(:label_week), 'week'], - [l(:label_day_plural).titleize, 'day']], @columns), - :onchange => "this.form.onsubmit();" %> - - <%= l(:button_add) %>: <%= select_tag('criterias[]', options_for_select([[]] + (@available_criterias.keys - @criterias).collect{|k| [l_or_humanize(@available_criterias[k][:label]), k]}), - :onchange => "this.form.onsubmit();", - :style => 'width: 200px', - :id => nil, - :disabled => (@criterias.length >= 3)) %> - <%= link_to_remote l(:button_clear), {:url => {:project_id => @project, :period_type => params[:period_type], :period => params[:period], :from => @from, :to => @to, :columns => @columns}, - :method => :get, - :update => 'content' - }, :class => 'icon icon-reload' %></p> -<% end %> - -<% unless @criterias.empty? %> -<div class="total-hours"> -<p><%= l(:label_total) %>: <%= html_hours(l_hours(@total_hours)) %></p> -</div> - -<% unless @hours.empty? %> -<table class="list" id="time-report"> -<thead> -<tr> -<% @criterias.each do |criteria| %> - <th><%= l_or_humanize(@available_criterias[criteria][:label]) %></th> -<% end %> -<% columns_width = (40 / (@periods.length+1)).to_i %> -<% @periods.each do |period| %> - <th class="period" width="<%= columns_width %>%"><%= period %></th> -<% end %> - <th class="total" width="<%= columns_width %>%"><%= l(:label_total) %></th> -</tr> -</thead> -<tbody> -<%= render :partial => 'report_criteria', :locals => {:criterias => @criterias, :hours => @hours, :level => 0} %> - <tr class="total"> - <td><%= l(:label_total) %></td> - <%= '<td></td>' * (@criterias.size - 1) %> - <% total = 0 -%> - <% @periods.each do |period| -%> - <% sum = sum_hours(select_hours(@hours, @columns, period.to_s)); total += sum -%> - <td class="hours"><%= html_hours("%.2f" % sum) if sum > 0 %></td> - <% end -%> - <td class="hours"><%= html_hours("%.2f" % total) if total > 0 %></td> - </tr> -</tbody> -</table> - -<% other_formats_links do |f| %> - <%= f.link_to 'CSV', :url => params %> -<% end %> -<% end %> -<% end %> - -<% html_title l(:label_spent_time), l(:label_report) %> - |