summaryrefslogtreecommitdiffstats
path: root/app/views/timelog
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2011-12-02 19:33:05 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2011-12-02 19:33:05 +0000
commit69a2431dd0513de112b77e5a4c9a3707fb7ea283 (patch)
tree4f26db5d2aa1a79077c32c0db9ffbdc8a701277b /app/views/timelog
parentcaf898d7d13fa9df8acfaab4a7163f123cb59bf9 (diff)
downloadredmine-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.erb2
-rw-r--r--app/views/timelog/_report_criteria.html.erb19
-rw-r--r--app/views/timelog/report.html.erb72
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) %>
+