forked from potsda.mn/mobilizon
Add datetime_to_date_string/3 and is_same_day?/2 to Mobilizon.Service.DateTime
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
7ecf2e1da0
commit
aca2ed612e
|
@ -16,8 +16,13 @@ defmodule Mobilizon.Service.DateTime do
|
|||
Mobilizon.Cldr.Time.to_string!(datetime, format: format, locale: locale_or_default(locale))
|
||||
end
|
||||
|
||||
@spec datetime_tz_convert(DateTime.t(), String.t()) :: DateTime.t()
|
||||
def datetime_tz_convert(%DateTime{} = datetime, timezone) do
|
||||
@spec datetime_to_date_string(DateTime.t(), String.t(), to_string_format()) :: String.t()
|
||||
def datetime_to_date_string(%DateTime{} = datetime, locale \\ "en", format \\ :short) do
|
||||
Mobilizon.Cldr.Date.to_string!(datetime, format: format, locale: locale_or_default(locale))
|
||||
end
|
||||
|
||||
@spec datetime_tz_convert(DateTime.t(), String.t() | nil) :: DateTime.t()
|
||||
def datetime_tz_convert(%DateTime{} = datetime, timezone) when is_binary(timezone) do
|
||||
case DateTime.shift_zone(datetime, timezone) do
|
||||
{:ok, datetime_with_tz} ->
|
||||
datetime_with_tz
|
||||
|
@ -27,6 +32,8 @@ defmodule Mobilizon.Service.DateTime do
|
|||
end
|
||||
end
|
||||
|
||||
def datetime_tz_convert(%DateTime{} = datetime, nil), do: datetime
|
||||
|
||||
@spec datetime_relative(DateTime.t(), String.t()) :: String.t()
|
||||
def datetime_relative(%DateTime{} = datetime, locale \\ "en") do
|
||||
Relative.to_string!(datetime, Mobilizon.Cldr,
|
||||
|
@ -200,4 +207,9 @@ defmodule Mobilizon.Service.DateTime do
|
|||
DateTime.compare(DateTime.add(last_notification_sent, 3_600), DateTime.utc_now()) ==
|
||||
:lt
|
||||
end
|
||||
|
||||
@spec is_same_day?(DateTime.t(), DateTime.t()) :: boolean()
|
||||
def is_same_day?(%DateTime{} = one, %DateTime{} = two) do
|
||||
DateTime.to_date(one) == DateTime.to_date(two)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue