{-# 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.PersonalizeRuntime.Types.PredictedItem where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
data PredictedItem = PredictedItem'
{
PredictedItem -> Maybe Text
itemId :: Prelude.Maybe Prelude.Text,
PredictedItem -> Maybe Text
promotionName :: Prelude.Maybe Prelude.Text,
PredictedItem -> Maybe Double
score :: Prelude.Maybe Prelude.Double
}
deriving (PredictedItem -> PredictedItem -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PredictedItem -> PredictedItem -> Bool
$c/= :: PredictedItem -> PredictedItem -> Bool
== :: PredictedItem -> PredictedItem -> Bool
$c== :: PredictedItem -> PredictedItem -> Bool
Prelude.Eq, ReadPrec [PredictedItem]
ReadPrec PredictedItem
Int -> ReadS PredictedItem
ReadS [PredictedItem]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PredictedItem]
$creadListPrec :: ReadPrec [PredictedItem]
readPrec :: ReadPrec PredictedItem
$creadPrec :: ReadPrec PredictedItem
readList :: ReadS [PredictedItem]
$creadList :: ReadS [PredictedItem]
readsPrec :: Int -> ReadS PredictedItem
$creadsPrec :: Int -> ReadS PredictedItem
Prelude.Read, Int -> PredictedItem -> ShowS
[PredictedItem] -> ShowS
PredictedItem -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PredictedItem] -> ShowS
$cshowList :: [PredictedItem] -> ShowS
show :: PredictedItem -> String
$cshow :: PredictedItem -> String
showsPrec :: Int -> PredictedItem -> ShowS
$cshowsPrec :: Int -> PredictedItem -> ShowS
Prelude.Show, forall x. Rep PredictedItem x -> PredictedItem
forall x. PredictedItem -> Rep PredictedItem x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PredictedItem x -> PredictedItem
$cfrom :: forall x. PredictedItem -> Rep PredictedItem x
Prelude.Generic)
newPredictedItem ::
PredictedItem
newPredictedItem :: PredictedItem
newPredictedItem =
PredictedItem'
{ $sel:itemId:PredictedItem' :: Maybe Text
itemId = forall a. Maybe a
Prelude.Nothing,
$sel:promotionName:PredictedItem' :: Maybe Text
promotionName = forall a. Maybe a
Prelude.Nothing,
$sel:score:PredictedItem' :: Maybe Double
score = forall a. Maybe a
Prelude.Nothing
}
predictedItem_itemId :: Lens.Lens' PredictedItem (Prelude.Maybe Prelude.Text)
predictedItem_itemId :: Lens' PredictedItem (Maybe Text)
predictedItem_itemId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PredictedItem' {Maybe Text
itemId :: Maybe Text
$sel:itemId:PredictedItem' :: PredictedItem -> Maybe Text
itemId} -> Maybe Text
itemId) (\s :: PredictedItem
s@PredictedItem' {} Maybe Text
a -> PredictedItem
s {$sel:itemId:PredictedItem' :: Maybe Text
itemId = Maybe Text
a} :: PredictedItem)
predictedItem_promotionName :: Lens.Lens' PredictedItem (Prelude.Maybe Prelude.Text)
predictedItem_promotionName :: Lens' PredictedItem (Maybe Text)
predictedItem_promotionName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PredictedItem' {Maybe Text
promotionName :: Maybe Text
$sel:promotionName:PredictedItem' :: PredictedItem -> Maybe Text
promotionName} -> Maybe Text
promotionName) (\s :: PredictedItem
s@PredictedItem' {} Maybe Text
a -> PredictedItem
s {$sel:promotionName:PredictedItem' :: Maybe Text
promotionName = Maybe Text
a} :: PredictedItem)
predictedItem_score :: Lens.Lens' PredictedItem (Prelude.Maybe Prelude.Double)
predictedItem_score :: Lens' PredictedItem (Maybe Double)
predictedItem_score = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PredictedItem' {Maybe Double
score :: Maybe Double
$sel:score:PredictedItem' :: PredictedItem -> Maybe Double
score} -> Maybe Double
score) (\s :: PredictedItem
s@PredictedItem' {} Maybe Double
a -> PredictedItem
s {$sel:score:PredictedItem' :: Maybe Double
score = Maybe Double
a} :: PredictedItem)
instance Data.FromJSON PredictedItem where
parseJSON :: Value -> Parser PredictedItem
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"PredictedItem"
( \Object
x ->
Maybe Text -> Maybe Text -> Maybe Double -> PredictedItem
PredictedItem'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"itemId")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"promotionName")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"score")
)
instance Prelude.Hashable PredictedItem where
hashWithSalt :: Int -> PredictedItem -> Int
hashWithSalt Int
_salt PredictedItem' {Maybe Double
Maybe Text
score :: Maybe Double
promotionName :: Maybe Text
itemId :: Maybe Text
$sel:score:PredictedItem' :: PredictedItem -> Maybe Double
$sel:promotionName:PredictedItem' :: PredictedItem -> Maybe Text
$sel:itemId:PredictedItem' :: PredictedItem -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
itemId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
promotionName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Double
score
instance Prelude.NFData PredictedItem where
rnf :: PredictedItem -> ()
rnf PredictedItem' {Maybe Double
Maybe Text
score :: Maybe Double
promotionName :: Maybe Text
itemId :: Maybe Text
$sel:score:PredictedItem' :: PredictedItem -> Maybe Double
$sel:promotionName:PredictedItem' :: PredictedItem -> Maybe Text
$sel:itemId:PredictedItem' :: PredictedItem -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
itemId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
promotionName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Double
score