blob: 9ab7ab5522b7820aa903dd42d5c3113c8e91d440 (
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
|
module Common.Util.Time
( timeToDay
, parseDay
) where
import Data.Text (Text)
import qualified Data.Text as T
import Data.Time (UTCTime)
import qualified Data.Time as Time
import Data.Time.Calendar (Day)
import Data.Time.LocalTime
import qualified Text.Read as T
timeToDay :: UTCTime -> IO Day
timeToDay time = localDay . (flip utcToLocalTime time) <$> getTimeZone time
parseDay :: Text -> Maybe Day
parseDay str = do
(d, m, y) <-
case T.splitOn str "/" of
[d, m, y] -> Just (d, m, y)
_ -> Nothing
d' <- T.readMaybe . T.unpack $ d
m' <- T.readMaybe . T.unpack $ m
y' <- T.readMaybe . T.unpack $ y
return $ Time.fromGregorian y' m' d'
|