aboutsummaryrefslogtreecommitdiffstats
path: root/lib/carlosgoce/calendar.rb
blob: 6a5d8f60c67b5177c3de1931fb9c3c96406d3b69 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
require 'rubygems'
require 'active_support/core_ext/time'
require 'active_support/core_ext/date'

module CarlosGoce
  class Calendar
    attr_reader :year

    def initialize(year=Date.today.year)
      @year = year
    end

    def to_h
      Hash.new.tap {|h|
        (1..12).each do |month|
          h[month] = Hash.new.tap {|m|
            m[:days] = (1..Time.days_in_month(month, @year)).to_a
            m[:name] = I18n.t('date.month_names')[month].downcase

            # todo: Need improvement. Not too performant...
            # todo: Maby it should be moved to it's own class too to keep things simple
            m[:days_names] = Array.new.tap {|a|
              m[:days].each do |d|
                t = Time.new @year, month, d
                a << I18n.t('date.day_names')[t.wday].downcase
              end
            }
          }
        end

        h[:formatted_days] = Array.new.tap {|a|
          # todo Why I need to use 1?
          days_before_week_start = Date.new(@year, 1, h[1][:days].first).wday
          empty_days = [''] * (days_before_week_start - 1)

          a << (empty_days + h[1][:days])
        }
      }
    end

    def generate(layout, file, year)
      layout.create file, to_h, year
    end
  end
end