From a214f4f34a85f034d6b3a7d48c5a448c92f996e0 Mon Sep 17 00:00:00 2001 From: jamesu Date: Fri, 19 Mar 2010 13:24:52 +0000 Subject: [PATCH] Fix reporting for weeks --- app/controllers/entries_controller.rb | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/app/controllers/entries_controller.rb b/app/controllers/entries_controller.rb index ae7daff..803004c 100644 --- a/app/controllers/entries_controller.rb +++ b/app/controllers/entries_controller.rb @@ -94,26 +94,27 @@ def show end def report - now = (params[:date] || Time.now).to_date + now = params[:date] ? Date.parse(params[:date]) : Time.now.to_date report_period = params[:period] report_year = now.year - days_past_week = Proc.new {|entry| (now - entry.start_date.to_date) > 7.days} - days_past_month = Proc.new {|entry| (now - entry.start_date.to_date) > 1.month} + days_past_week = Proc.new {|entry| (now - entry.date) > 7.days} + days_past_month = Proc.new {|entry| (now - entry.date) > 1.month} days_this_year = Proc.new {|entry| now.year != entry.year} case report_period when 'week' - day_list = make_time_list(now - 1.month + 1, now) {|d| d.cweek} - daymap = [0] + day_list + day_list = make_time_list(now - 1.month + 1, now) {|d| d.cweek}.uniq + daymap = {} + day_list.each{|d| daymap[d] = d } @grouped_entries = @logged_user.entries.reject(&days_past_month).group_by do |entry| - entry.start_date.to_date.cweek + entry.date.cweek end else - day_list = make_time_list(now - 1.week + 1, now) {|d| d.cwday} + day_list = make_time_list(now - 1.week + 1, now) {|d| d.cwday}.uniq daymap = ["", "Sun", "Mon", "Tues", "Wed", "Thurs", "Fri", "Sat"] @grouped_entries = @logged_user.entries.reject(&days_past_week).group_by do |entry| - entry.start_date.to_date.cwday + entry.date.cwday end end