aboutsummaryrefslogtreecommitdiff
path: root/common/src/Common/Util/Time.hs
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'