summaryrefslogtreecommitdiffstats
path: root/app/views/timelog
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2010-10-05 16:07:17 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2010-10-05 16:07:17 +0000
commite13790c62c800a5b6d9528b5e2db2aad2c5e3710 (patch)
tree7be0ed076c62d3267a0f7839e07a6fcec011e533 /app/views/timelog
parenta034172b24cde31bac0f18b842db8c76cfb80bb1 (diff)
downloadredmine-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.rhtml2
-rw-r--r--app/views/timelog/_report_criteria.rhtml19
-rw-r--r--app/views/timelog/report.rhtml76
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) %>
-