{-# OPTIONS_GHC -Wno-orphans #-}

module LawfulConversions.Relations.TextAndUtcTime where

import Data.Time
import LawfulConversions.Classes
import LawfulConversions.Prelude
import LawfulConversions.Relations.StringAndText ()
import LawfulConversions.Relations.StringAndUtcTime ()

-- | Implements ISO-8601.
instance IsSome Text UTCTime where
  to :: UTCTime -> Text
to = String -> Text
forall a. IsString a => String -> a
fromString (String -> Text) -> (UTCTime -> String) -> UTCTime -> Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. UTCTime -> String
forall a b. IsSome a b => b -> a
to
  maybeFrom :: Text -> Maybe UTCTime
maybeFrom = forall a b. IsSome a b => a -> Maybe b
maybeFrom @String (String -> Maybe UTCTime)
-> (Text -> String) -> Text -> Maybe UTCTime
forall b c a. (b -> c) -> (a -> b) -> a -> c
forall {k} (cat :: k -> k -> *) (b :: k) (c :: k) (a :: k).
Category cat =>
cat b c -> cat a b -> cat a c
. Text -> String
forall a b. IsSome a b => b -> a
to