blob: 5f129e59047aa0f8b8e472007d3290d3ef192a0b (
plain)
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
module DateTimeHelper
# Public: Usually-correct format for a DateTime-ish object
# To define a new new format define the `simple_date_{FORMAT}` method
#
# date - a DateTime, Date or Time
# opts - a Hash of options (default: { format: :html})
# :format - :html returns a HTML <time> tag
# :text returns a plain String
#
# Examples
#
# simple_date(Time.now)
# # => "<time>..."
#
# simple_date(Time.now, :format => :text)
# # => "March 10, 2014"
#
# Returns a String
# Raises ArgumentError if the format is unrecognized
def simple_date(date, opts = {})
opts = { :format => :html }.merge(opts)
date_formatter = "simple_date_#{ opts[:format] }"
if respond_to?(date_formatter)
send(date_formatter, date)
else
raise ArgumentError, "Unrecognized format :#{ opts[:format] }"
end
end
# Usually-correct HTML formatting of a DateTime-ish object
# Use LinkToHelper#simple_date with desired formatting options
#
# date - a DateTime, Date or Time
#
# Returns a String
def simple_date_html(date)
date = date.in_time_zone unless date.is_a?(Date)
time_tag date, simple_date_text(date), :title => date.to_s
end
# Usually-correct plain text formatting of a DateTime-ish object
# Use LinkToHelper#simple_date with desired formatting options
#
# date - a DateTime, Date or Time
#
# Returns a String
def simple_date_text(date)
date = date.in_time_zone.to_date unless date.is_a? Date
date_format = _('simple_date_format')
date_format = :long if date_format == 'simple_date_format'
I18n.l(date, :format => date_format)
end
# Strips the date from a DateTime
#
# date - a DateTime, Date or Time
#
# Examples
#
# simple_time(Time.now)
# # => "10:46:54"
#
# Returns a String
def simple_time(date)
date.strftime("%H:%M:%S").strip
end
end
|