{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.Forecast.Types.TimeSeriesCondition where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Forecast.Types.Condition
import qualified Amazonka.Prelude as Prelude
data TimeSeriesCondition = TimeSeriesCondition'
{
TimeSeriesCondition -> Text
attributeName :: Prelude.Text,
TimeSeriesCondition -> Text
attributeValue :: Prelude.Text,
TimeSeriesCondition -> Condition
condition :: Condition
}
deriving (TimeSeriesCondition -> TimeSeriesCondition -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: TimeSeriesCondition -> TimeSeriesCondition -> Bool
$c/= :: TimeSeriesCondition -> TimeSeriesCondition -> Bool
== :: TimeSeriesCondition -> TimeSeriesCondition -> Bool
$c== :: TimeSeriesCondition -> TimeSeriesCondition -> Bool
Prelude.Eq, ReadPrec [TimeSeriesCondition]
ReadPrec TimeSeriesCondition
Int -> ReadS TimeSeriesCondition
ReadS [TimeSeriesCondition]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [TimeSeriesCondition]
$creadListPrec :: ReadPrec [TimeSeriesCondition]
readPrec :: ReadPrec TimeSeriesCondition
$creadPrec :: ReadPrec TimeSeriesCondition
readList :: ReadS [TimeSeriesCondition]
$creadList :: ReadS [TimeSeriesCondition]
readsPrec :: Int -> ReadS TimeSeriesCondition
$creadsPrec :: Int -> ReadS TimeSeriesCondition
Prelude.Read, Int -> TimeSeriesCondition -> ShowS
[TimeSeriesCondition] -> ShowS
TimeSeriesCondition -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [TimeSeriesCondition] -> ShowS
$cshowList :: [TimeSeriesCondition] -> ShowS
show :: TimeSeriesCondition -> String
$cshow :: TimeSeriesCondition -> String
showsPrec :: Int -> TimeSeriesCondition -> ShowS
$cshowsPrec :: Int -> TimeSeriesCondition -> ShowS
Prelude.Show, forall x. Rep TimeSeriesCondition x -> TimeSeriesCondition
forall x. TimeSeriesCondition -> Rep TimeSeriesCondition x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep TimeSeriesCondition x -> TimeSeriesCondition
$cfrom :: forall x. TimeSeriesCondition -> Rep TimeSeriesCondition x
Prelude.Generic)
newTimeSeriesCondition ::
Prelude.Text ->
Prelude.Text ->
Condition ->
TimeSeriesCondition
newTimeSeriesCondition :: Text -> Text -> Condition -> TimeSeriesCondition
newTimeSeriesCondition
Text
pAttributeName_
Text
pAttributeValue_
Condition
pCondition_ =
TimeSeriesCondition'
{ $sel:attributeName:TimeSeriesCondition' :: Text
attributeName =
Text
pAttributeName_,
$sel:attributeValue:TimeSeriesCondition' :: Text
attributeValue = Text
pAttributeValue_,
$sel:condition:TimeSeriesCondition' :: Condition
condition = Condition
pCondition_
}
timeSeriesCondition_attributeName :: Lens.Lens' TimeSeriesCondition Prelude.Text
timeSeriesCondition_attributeName :: Lens' TimeSeriesCondition Text
timeSeriesCondition_attributeName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimeSeriesCondition' {Text
attributeName :: Text
$sel:attributeName:TimeSeriesCondition' :: TimeSeriesCondition -> Text
attributeName} -> Text
attributeName) (\s :: TimeSeriesCondition
s@TimeSeriesCondition' {} Text
a -> TimeSeriesCondition
s {$sel:attributeName:TimeSeriesCondition' :: Text
attributeName = Text
a} :: TimeSeriesCondition)
timeSeriesCondition_attributeValue :: Lens.Lens' TimeSeriesCondition Prelude.Text
timeSeriesCondition_attributeValue :: Lens' TimeSeriesCondition Text
timeSeriesCondition_attributeValue = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimeSeriesCondition' {Text
attributeValue :: Text
$sel:attributeValue:TimeSeriesCondition' :: TimeSeriesCondition -> Text
attributeValue} -> Text
attributeValue) (\s :: TimeSeriesCondition
s@TimeSeriesCondition' {} Text
a -> TimeSeriesCondition
s {$sel:attributeValue:TimeSeriesCondition' :: Text
attributeValue = Text
a} :: TimeSeriesCondition)
timeSeriesCondition_condition :: Lens.Lens' TimeSeriesCondition Condition
timeSeriesCondition_condition :: Lens' TimeSeriesCondition Condition
timeSeriesCondition_condition = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimeSeriesCondition' {Condition
condition :: Condition
$sel:condition:TimeSeriesCondition' :: TimeSeriesCondition -> Condition
condition} -> Condition
condition) (\s :: TimeSeriesCondition
s@TimeSeriesCondition' {} Condition
a -> TimeSeriesCondition
s {$sel:condition:TimeSeriesCondition' :: Condition
condition = Condition
a} :: TimeSeriesCondition)
instance Data.FromJSON TimeSeriesCondition where
parseJSON :: Value -> Parser TimeSeriesCondition
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"TimeSeriesCondition"
( \Object
x ->
Text -> Text -> Condition -> TimeSeriesCondition
TimeSeriesCondition'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser a
Data..: Key
"AttributeName")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser a
Data..: Key
"AttributeValue")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser a
Data..: Key
"Condition")
)
instance Prelude.Hashable TimeSeriesCondition where
hashWithSalt :: Int -> TimeSeriesCondition -> Int
hashWithSalt Int
_salt TimeSeriesCondition' {Text
Condition
condition :: Condition
attributeValue :: Text
attributeName :: Text
$sel:condition:TimeSeriesCondition' :: TimeSeriesCondition -> Condition
$sel:attributeValue:TimeSeriesCondition' :: TimeSeriesCondition -> Text
$sel:attributeName:TimeSeriesCondition' :: TimeSeriesCondition -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
attributeName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
attributeValue
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Condition
condition
instance Prelude.NFData TimeSeriesCondition where
rnf :: TimeSeriesCondition -> ()
rnf TimeSeriesCondition' {Text
Condition
condition :: Condition
attributeValue :: Text
attributeName :: Text
$sel:condition:TimeSeriesCondition' :: TimeSeriesCondition -> Condition
$sel:attributeValue:TimeSeriesCondition' :: TimeSeriesCondition -> Text
$sel:attributeName:TimeSeriesCondition' :: TimeSeriesCondition -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
attributeName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
attributeValue
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Condition
condition
instance Data.ToJSON TimeSeriesCondition where
toJSON :: TimeSeriesCondition -> Value
toJSON TimeSeriesCondition' {Text
Condition
condition :: Condition
attributeValue :: Text
attributeName :: Text
$sel:condition:TimeSeriesCondition' :: TimeSeriesCondition -> Condition
$sel:attributeValue:TimeSeriesCondition' :: TimeSeriesCondition -> Text
$sel:attributeName:TimeSeriesCondition' :: TimeSeriesCondition -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just
(Key
"AttributeName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
attributeName),
forall a. a -> Maybe a
Prelude.Just
(Key
"AttributeValue" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
attributeValue),
forall a. a -> Maybe a
Prelude.Just (Key
"Condition" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Condition
condition)
]
)