{-# 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.Outposts.Types.LineItemRequest 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 LineItemRequest = LineItemRequest'
{
LineItemRequest -> Maybe Text
catalogItemId :: Prelude.Maybe Prelude.Text,
LineItemRequest -> Maybe Natural
quantity :: Prelude.Maybe Prelude.Natural
}
deriving (LineItemRequest -> LineItemRequest -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: LineItemRequest -> LineItemRequest -> Bool
$c/= :: LineItemRequest -> LineItemRequest -> Bool
== :: LineItemRequest -> LineItemRequest -> Bool
$c== :: LineItemRequest -> LineItemRequest -> Bool
Prelude.Eq, ReadPrec [LineItemRequest]
ReadPrec LineItemRequest
Int -> ReadS LineItemRequest
ReadS [LineItemRequest]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [LineItemRequest]
$creadListPrec :: ReadPrec [LineItemRequest]
readPrec :: ReadPrec LineItemRequest
$creadPrec :: ReadPrec LineItemRequest
readList :: ReadS [LineItemRequest]
$creadList :: ReadS [LineItemRequest]
readsPrec :: Int -> ReadS LineItemRequest
$creadsPrec :: Int -> ReadS LineItemRequest
Prelude.Read, Int -> LineItemRequest -> ShowS
[LineItemRequest] -> ShowS
LineItemRequest -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [LineItemRequest] -> ShowS
$cshowList :: [LineItemRequest] -> ShowS
show :: LineItemRequest -> String
$cshow :: LineItemRequest -> String
showsPrec :: Int -> LineItemRequest -> ShowS
$cshowsPrec :: Int -> LineItemRequest -> ShowS
Prelude.Show, forall x. Rep LineItemRequest x -> LineItemRequest
forall x. LineItemRequest -> Rep LineItemRequest x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep LineItemRequest x -> LineItemRequest
$cfrom :: forall x. LineItemRequest -> Rep LineItemRequest x
Prelude.Generic)
newLineItemRequest ::
LineItemRequest
newLineItemRequest :: LineItemRequest
newLineItemRequest =
LineItemRequest'
{ $sel:catalogItemId:LineItemRequest' :: Maybe Text
catalogItemId = forall a. Maybe a
Prelude.Nothing,
$sel:quantity:LineItemRequest' :: Maybe Natural
quantity = forall a. Maybe a
Prelude.Nothing
}
lineItemRequest_catalogItemId :: Lens.Lens' LineItemRequest (Prelude.Maybe Prelude.Text)
lineItemRequest_catalogItemId :: Lens' LineItemRequest (Maybe Text)
lineItemRequest_catalogItemId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\LineItemRequest' {Maybe Text
catalogItemId :: Maybe Text
$sel:catalogItemId:LineItemRequest' :: LineItemRequest -> Maybe Text
catalogItemId} -> Maybe Text
catalogItemId) (\s :: LineItemRequest
s@LineItemRequest' {} Maybe Text
a -> LineItemRequest
s {$sel:catalogItemId:LineItemRequest' :: Maybe Text
catalogItemId = Maybe Text
a} :: LineItemRequest)
lineItemRequest_quantity :: Lens.Lens' LineItemRequest (Prelude.Maybe Prelude.Natural)
lineItemRequest_quantity :: Lens' LineItemRequest (Maybe Natural)
lineItemRequest_quantity = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\LineItemRequest' {Maybe Natural
quantity :: Maybe Natural
$sel:quantity:LineItemRequest' :: LineItemRequest -> Maybe Natural
quantity} -> Maybe Natural
quantity) (\s :: LineItemRequest
s@LineItemRequest' {} Maybe Natural
a -> LineItemRequest
s {$sel:quantity:LineItemRequest' :: Maybe Natural
quantity = Maybe Natural
a} :: LineItemRequest)
instance Prelude.Hashable LineItemRequest where
hashWithSalt :: Int -> LineItemRequest -> Int
hashWithSalt Int
_salt LineItemRequest' {Maybe Natural
Maybe Text
quantity :: Maybe Natural
catalogItemId :: Maybe Text
$sel:quantity:LineItemRequest' :: LineItemRequest -> Maybe Natural
$sel:catalogItemId:LineItemRequest' :: LineItemRequest -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
catalogItemId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
quantity
instance Prelude.NFData LineItemRequest where
rnf :: LineItemRequest -> ()
rnf LineItemRequest' {Maybe Natural
Maybe Text
quantity :: Maybe Natural
catalogItemId :: Maybe Text
$sel:quantity:LineItemRequest' :: LineItemRequest -> Maybe Natural
$sel:catalogItemId:LineItemRequest' :: LineItemRequest -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
catalogItemId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
quantity
instance Data.ToJSON LineItemRequest where
toJSON :: LineItemRequest -> Value
toJSON LineItemRequest' {Maybe Natural
Maybe Text
quantity :: Maybe Natural
catalogItemId :: Maybe Text
$sel:quantity:LineItemRequest' :: LineItemRequest -> Maybe Natural
$sel:catalogItemId:LineItemRequest' :: LineItemRequest -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"CatalogItemId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
catalogItemId,
(Key
"Quantity" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Natural
quantity
]
)