mirror of
https://github.com/facebook/duckling.git
synced 2024-12-01 08:19:36 +03:00
62 lines
1.5 KiB
Haskell
62 lines
1.5 KiB
Haskell
|
-- Copyright (c) 2016-present, Facebook, Inc.
|
||
|
-- All rights reserved.
|
||
|
--
|
||
|
-- This source code is licensed under the BSD-style license found in the
|
||
|
-- LICENSE file in the root directory of this source tree. An additional grant
|
||
|
-- of patent rights can be found in the PATENTS file in the same directory.
|
||
|
|
||
|
|
||
|
{-# 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
|
||
|
]
|