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
|