{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.Forecast.Types.TimeSeriesCondition
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
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

-- | Creates a subset of items within an attribute that are modified. For
-- example, you can use this operation to create a subset of items that
-- cost $5 or less. To do this, you specify @\"AttributeName\": \"price\"@,
-- @\"AttributeValue\": \"5\"@, and @\"Condition\": \"LESS_THAN\"@. Pair
-- this operation with the Action operation within the
-- CreateWhatIfForecastRequest$TimeSeriesTransformations operation to
-- define how the attribute is modified.
--
-- /See:/ 'newTimeSeriesCondition' smart constructor.
data TimeSeriesCondition = TimeSeriesCondition'
  { -- | The item_id, dimension name, IM name, or timestamp that you are
    -- modifying.
    TimeSeriesCondition -> Text
attributeName :: Prelude.Text,
    -- | The value that is applied for the chosen @Condition@.
    TimeSeriesCondition -> Text
attributeValue :: Prelude.Text,
    -- | The condition to apply. Valid values are @EQUALS@, @NOT_EQUALS@,
    -- @LESS_THAN@ and @GREATER_THAN@.
    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)

-- |
-- Create a value of 'TimeSeriesCondition' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'attributeName', 'timeSeriesCondition_attributeName' - The item_id, dimension name, IM name, or timestamp that you are
-- modifying.
--
-- 'attributeValue', 'timeSeriesCondition_attributeValue' - The value that is applied for the chosen @Condition@.
--
-- 'condition', 'timeSeriesCondition_condition' - The condition to apply. Valid values are @EQUALS@, @NOT_EQUALS@,
-- @LESS_THAN@ and @GREATER_THAN@.
newTimeSeriesCondition ::
  -- | 'attributeName'
  Prelude.Text ->
  -- | 'attributeValue'
  Prelude.Text ->
  -- | 'condition'
  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_
      }

-- | The item_id, dimension name, IM name, or timestamp that you are
-- modifying.
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)

-- | The value that is applied for the chosen @Condition@.
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)

-- | The condition to apply. Valid values are @EQUALS@, @NOT_EQUALS@,
-- @LESS_THAN@ and @GREATER_THAN@.
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)
          ]
      )