From 69a2431dd0513de112b77e5a4c9a3707fb7ea283 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Fri, 2 Dec 2011 19:33:05 +0000 Subject: Dropped TimeEntryReportsController. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8027 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/views/timelog/_date_range.html.erb | 2 +- app/views/timelog/_report_criteria.html.erb | 19 ++++++++ app/views/timelog/report.html.erb | 72 +++++++++++++++++++++++++++++ 3 files changed, 92 insertions(+), 1 deletion(-) create mode 100644 app/views/timelog/_report_criteria.html.erb create mode 100644 app/views/timelog/report.html.erb (limited to 'app/views/timelog') diff --git a/app/views/timelog/_date_range.html.erb b/app/views/timelog/_date_range.html.erb index fb694a704..d1ceb6fbd 100644 --- a/app/views/timelog/_date_range.html.erb +++ b/app/views/timelog/_date_range.html.erb @@ -32,7 +32,7 @@ diff --git a/app/views/timelog/_report_criteria.html.erb b/app/views/timelog/_report_criteria.html.erb new file mode 100644 index 000000000..356a7ab10 --- /dev/null +++ b/app/views/timelog/_report_criteria.html.erb @@ -0,0 +1,19 @@ +<% @report.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? -%> + +<%= '' * level %> +<%= h(format_criteria_value(@report.available_criteria[criterias[level]], value)) %> +<%= '' * (criterias.length - level - 1) -%> + <% total = 0 -%> + <% @report.periods.each do |period| -%> + <% sum = sum_hours(select_hours(hours_for_value, @report.columns, period.to_s)); total += sum -%> + <%= html_hours("%.2f" % sum) if sum > 0 %> + <% end -%> + <%= html_hours("%.2f" % total) if total > 0 %> + +<% 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.html.erb b/app/views/timelog/report.html.erb new file mode 100644 index 000000000..ddbb71852 --- /dev/null +++ b/app/views/timelog/report.html.erb @@ -0,0 +1,72 @@ +
+<%= link_to_if_authorized l(:button_log_time), {:controller => 'timelog', :action => 'new', :project_id => @project, :issue_id => @issue}, :class => 'icon icon-time-add' %> +
+ +<%= render_timelog_breadcrumb %> + +

<%= l(:label_spent_time) %>

+ +<% form_tag({:controller => 'timelog', :action => 'report', :project_id => @project, :issue_id => @issue}, :method => :get, :id => 'query_form') do %> + <% @report.criteria.each do |criterion| %> + <%= hidden_field_tag 'criteria[]', criterion, :id => nil %> + <% end %> + <%= render :partial => 'timelog/date_range' %> + +

: <%= select_tag 'columns', options_for_select([[l(:label_year), 'year'], + [l(:label_month), 'month'], + [l(:label_week), 'week'], + [l(:label_day_plural).titleize, 'day']], @report.columns), + :onchange => "this.form.onsubmit();" %> + + : <%= select_tag('criteria[]', options_for_select([[]] + (@report.available_criteria.keys - @report.criteria).collect{|k| [l_or_humanize(@report.available_criteria[k][:label]), k]}), + :onchange => "this.form.submit();", + :style => 'width: 200px', + :id => nil, + :disabled => (@report.criteria.length >= 3), :id => "criterias") %> + <%= link_to l(:button_clear), {:project_id => @project, :issue_id => @issue, :period_type => params[:period_type], :period => params[:period], :from => @from, :to => @to, :columns => @report.columns}, :class => 'icon icon-reload' %>

+<% end %> + +<% unless @report.criteria.empty? %> +
+

<%= l(:label_total) %>: <%= html_hours(l_hours(@report.total_hours)) %>

+
+ +<% unless @report.hours.empty? %> +
+ + + +<% @report.criteria.each do |criteria| %> + +<% end %> +<% columns_width = (40 / (@report.periods.length+1)).to_i %> +<% @report.periods.each do |period| %> + +<% end %> + + + + +<%= render :partial => 'report_criteria', :locals => {:criterias => @report.criteria, :hours => @report.hours, :level => 0} %> + + + <%= '' * (@report.criteria.size - 1) %> + <% total = 0 -%> + <% @report.periods.each do |period| -%> + <% sum = sum_hours(select_hours(@report.hours, @report.columns, period.to_s)); total += sum -%> + + <% end -%> + + + +
<%= l_or_humanize(@report.available_criteria[criteria][:label]) %><%= period %><%= l(:label_total) %>
<%= l(:label_total) %><%= html_hours("%.2f" % sum) if sum > 0 %><%= html_hours("%.2f" % total) if total > 0 %>
+
+ +<% other_formats_links do |f| %> + <%= f.link_to 'CSV', :url => params %> +<% end %> +<% end %> +<% end %> + +<% html_title l(:label_spent_time), l(:label_report) %> + -- cgit v1.2.3