{-# LANGUAGE DeriveAnyClass #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE NoRebindableSyntax #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TypeFamilies #-}
module Duckling.Volume.Types where
import Control.DeepSeq
import Data.Aeson
import Data.Hashable
import Data.Text (Text)
import qualified Data.Text as Text
import GHC.Generics
import Prelude
import Duckling.Resolve (Resolve (..))
data Unit
  = Gallon
  | Hectolitre
  | Litre
  | Millilitre
  deriving (Eq, Generic, Hashable, Ord, Show, NFData)
instance ToJSON Unit where
  toJSON = String . Text.toLower . Text.pack . show
data VolumeData = VolumeData
  { unit :: Maybe Unit
  , value :: Double
  }
  deriving (Eq, Generic, Hashable, Ord, Show, NFData)
instance Resolve VolumeData where
  type ResolvedValue VolumeData = VolumeValue
  resolve _ VolumeData {unit = Nothing} = Nothing
  resolve _ VolumeData {unit = Just unit, value} = Just VolumeValue
    {vValue = value, vUnit = unit}
data VolumeValue = VolumeValue
  { vUnit :: Unit
  , vValue :: Double
  }
  deriving (Eq, Ord, Show)
instance ToJSON VolumeValue where
  toJSON (VolumeValue unit value) = object
    [ "type" .= ("value" :: Text)
    , "value" .= value
    , "unit" .= unit
    ]