diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2011-12-02 19:33:05 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2011-12-02 19:33:05 +0000 |
commit | 69a2431dd0513de112b77e5a4c9a3707fb7ea283 (patch) | |
tree | 4f26db5d2aa1a79077c32c0db9ffbdc8a701277b /app/views/timelog | |
parent | caf898d7d13fa9df8acfaab4a7163f123cb59bf9 (diff) | |
download | redmine-69a2431dd0513de112b77e5a4c9a3707fb7ea283.tar.gz redmine-69a2431dd0513de112b77e5a4c9a3707fb7ea283.zip |
Dropped TimeEntryReportsController.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8027 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/views/timelog')
-rw-r--r-- | app/views/timelog/_date_range.html.erb | 2 | ||||
-rw-r--r-- | app/views/timelog/_report_criteria.html.erb | 19 | ||||
-rw-r--r-- | app/views/timelog/report.html.erb | 72 |
3 files changed, 92 insertions, 1 deletions
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 @@ <ul> <li><%= link_to(l(:label_details), url_params.merge({:controller => 'timelog', :action => 'index', :project_id => @project, :issue_id => @issue }), :class => (@controller.action_name == 'index' ? 'selected' : nil)) %></li> - <li><%= link_to(l(:label_report), url_params.merge({:controller => 'time_entry_reports', :action => 'report', :project_id => @project, :issue_id => @issue}), + <li><%= link_to(l(:label_report), url_params.merge({:controller => 'timelog', :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.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? -%> +<tr class="<%= cycle('odd', 'even') %> <%= 'last-level' unless criterias.length > level+1 %>"> +<%= '<td></td>' * level %> +<td><%= h(format_criteria_value(@report.available_criteria[criterias[level]], value)) %></td> +<%= '<td></td>' * (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 -%> + <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.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 @@ +<div class="contextual"> +<%= link_to_if_authorized l(:button_log_time), {:controller => 'timelog', :action => 'new', :project_id => @project, :issue_id => @issue}, :class => 'icon icon-time-add' %> +</div> + +<%= render_timelog_breadcrumb %> + +<h2><%= l(:label_spent_time) %></h2> + +<% 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' %> + + <p><label for='columns'><%= l(:label_details) %></label>: <%= 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();" %> + + <label for='criterias'><%= l(:button_add) %></label>: <%= 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' %></p> +<% end %> + +<% unless @report.criteria.empty? %> +<div class="total-hours"> +<p><%= l(:label_total) %>: <%= html_hours(l_hours(@report.total_hours)) %></p> +</div> + +<% unless @report.hours.empty? %> +<div class="autoscroll"> +<table class="list" id="time-report"> +<thead> +<tr> +<% @report.criteria.each do |criteria| %> + <th><%= l_or_humanize(@report.available_criteria[criteria][:label]) %></th> +<% end %> +<% columns_width = (40 / (@report.periods.length+1)).to_i %> +<% @report.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 => @report.criteria, :hours => @report.hours, :level => 0} %> + <tr class="total"> + <td><%= l(:label_total) %></td> + <%= '<td></td>' * (@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 -%> + <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> +</div> + +<% other_formats_links do |f| %> + <%= f.link_to 'CSV', :url => params %> +<% end %> +<% end %> +<% end %> + +<% html_title l(:label_spent_time), l(:label_report) %> + |