module Stratosphere.CustomerProfiles.SegmentDefinition.ProfileTypeDimensionProperty (
        ProfileTypeDimensionProperty(..), mkProfileTypeDimensionProperty
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data ProfileTypeDimensionProperty
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-customerprofiles-segmentdefinition-profiletypedimension.html>
    ProfileTypeDimensionProperty {ProfileTypeDimensionProperty -> ()
haddock_workaround_ :: (),
                                  -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-customerprofiles-segmentdefinition-profiletypedimension.html#cfn-customerprofiles-segmentdefinition-profiletypedimension-dimensiontype>
                                  ProfileTypeDimensionProperty -> Value Text
dimensionType :: (Value Prelude.Text),
                                  -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-customerprofiles-segmentdefinition-profiletypedimension.html#cfn-customerprofiles-segmentdefinition-profiletypedimension-values>
                                  ProfileTypeDimensionProperty -> ValueList Text
values :: (ValueList Prelude.Text)}
  deriving stock (ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> Bool
(ProfileTypeDimensionProperty
 -> ProfileTypeDimensionProperty -> Bool)
-> (ProfileTypeDimensionProperty
    -> ProfileTypeDimensionProperty -> Bool)
-> Eq ProfileTypeDimensionProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> Bool
== :: ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> Bool
$c/= :: ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> Bool
/= :: ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> Bool
Prelude.Eq, Int -> ProfileTypeDimensionProperty -> ShowS
[ProfileTypeDimensionProperty] -> ShowS
ProfileTypeDimensionProperty -> String
(Int -> ProfileTypeDimensionProperty -> ShowS)
-> (ProfileTypeDimensionProperty -> String)
-> ([ProfileTypeDimensionProperty] -> ShowS)
-> Show ProfileTypeDimensionProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ProfileTypeDimensionProperty -> ShowS
showsPrec :: Int -> ProfileTypeDimensionProperty -> ShowS
$cshow :: ProfileTypeDimensionProperty -> String
show :: ProfileTypeDimensionProperty -> String
$cshowList :: [ProfileTypeDimensionProperty] -> ShowS
showList :: [ProfileTypeDimensionProperty] -> ShowS
Prelude.Show)
mkProfileTypeDimensionProperty ::
  Value Prelude.Text
  -> ValueList Prelude.Text -> ProfileTypeDimensionProperty
mkProfileTypeDimensionProperty :: Value Text -> ValueList Text -> ProfileTypeDimensionProperty
mkProfileTypeDimensionProperty Value Text
dimensionType ValueList Text
values
  = ProfileTypeDimensionProperty
      {haddock_workaround_ :: ()
haddock_workaround_ = (), dimensionType :: Value Text
dimensionType = Value Text
dimensionType,
       values :: ValueList Text
values = ValueList Text
values}
instance ToResourceProperties ProfileTypeDimensionProperty where
  toResourceProperties :: ProfileTypeDimensionProperty -> ResourceProperties
toResourceProperties ProfileTypeDimensionProperty {()
ValueList Text
Value Text
haddock_workaround_ :: ProfileTypeDimensionProperty -> ()
dimensionType :: ProfileTypeDimensionProperty -> Value Text
values :: ProfileTypeDimensionProperty -> ValueList Text
haddock_workaround_ :: ()
dimensionType :: Value Text
values :: ValueList Text
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::CustomerProfiles::SegmentDefinition.ProfileTypeDimension",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"DimensionType" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
dimensionType,
                       Key
"Values" Key -> ValueList Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= ValueList Text
values]}
instance JSON.ToJSON ProfileTypeDimensionProperty where
  toJSON :: ProfileTypeDimensionProperty -> Value
toJSON ProfileTypeDimensionProperty {()
ValueList Text
Value Text
haddock_workaround_ :: ProfileTypeDimensionProperty -> ()
dimensionType :: ProfileTypeDimensionProperty -> Value Text
values :: ProfileTypeDimensionProperty -> ValueList Text
haddock_workaround_ :: ()
dimensionType :: Value Text
values :: ValueList Text
..}
    = [(Key, Value)] -> Value
JSON.object
        [Key
"DimensionType" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
dimensionType, Key
"Values" Key -> ValueList Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= ValueList Text
values]
instance Property "DimensionType" ProfileTypeDimensionProperty where
  type PropertyType "DimensionType" ProfileTypeDimensionProperty = Value Prelude.Text
  set :: PropertyType "DimensionType" ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> ProfileTypeDimensionProperty
set PropertyType "DimensionType" ProfileTypeDimensionProperty
newValue ProfileTypeDimensionProperty {()
ValueList Text
Value Text
haddock_workaround_ :: ProfileTypeDimensionProperty -> ()
dimensionType :: ProfileTypeDimensionProperty -> Value Text
values :: ProfileTypeDimensionProperty -> ValueList Text
haddock_workaround_ :: ()
dimensionType :: Value Text
values :: ValueList Text
..}
    = ProfileTypeDimensionProperty {dimensionType :: Value Text
dimensionType = PropertyType "DimensionType" ProfileTypeDimensionProperty
Value Text
newValue, ()
ValueList Text
haddock_workaround_ :: ()
values :: ValueList Text
haddock_workaround_ :: ()
values :: ValueList Text
..}
instance Property "Values" ProfileTypeDimensionProperty where
  type PropertyType "Values" ProfileTypeDimensionProperty = ValueList Prelude.Text
  set :: PropertyType "Values" ProfileTypeDimensionProperty
-> ProfileTypeDimensionProperty -> ProfileTypeDimensionProperty
set PropertyType "Values" ProfileTypeDimensionProperty
newValue ProfileTypeDimensionProperty {()
ValueList Text
Value Text
haddock_workaround_ :: ProfileTypeDimensionProperty -> ()
dimensionType :: ProfileTypeDimensionProperty -> Value Text
values :: ProfileTypeDimensionProperty -> ValueList Text
haddock_workaround_ :: ()
dimensionType :: Value Text
values :: ValueList Text
..}
    = ProfileTypeDimensionProperty {values :: ValueList Text
values = PropertyType "Values" ProfileTypeDimensionProperty
ValueList Text
newValue, ()
Value Text
haddock_workaround_ :: ()
dimensionType :: Value Text
haddock_workaround_ :: ()
dimensionType :: Value Text
..}