{-# 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.QuickSight.Types.PanelTitleOptions 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
import Amazonka.QuickSight.Types.FontConfiguration
import Amazonka.QuickSight.Types.HorizontalTextAlignment
import Amazonka.QuickSight.Types.Visibility
data PanelTitleOptions = PanelTitleOptions'
{ PanelTitleOptions -> Maybe FontConfiguration
fontConfiguration :: Prelude.Maybe FontConfiguration,
PanelTitleOptions -> Maybe HorizontalTextAlignment
horizontalTextAlignment :: Prelude.Maybe HorizontalTextAlignment,
PanelTitleOptions -> Maybe Visibility
visibility :: Prelude.Maybe Visibility
}
deriving (PanelTitleOptions -> PanelTitleOptions -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PanelTitleOptions -> PanelTitleOptions -> Bool
$c/= :: PanelTitleOptions -> PanelTitleOptions -> Bool
== :: PanelTitleOptions -> PanelTitleOptions -> Bool
$c== :: PanelTitleOptions -> PanelTitleOptions -> Bool
Prelude.Eq, ReadPrec [PanelTitleOptions]
ReadPrec PanelTitleOptions
Int -> ReadS PanelTitleOptions
ReadS [PanelTitleOptions]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PanelTitleOptions]
$creadListPrec :: ReadPrec [PanelTitleOptions]
readPrec :: ReadPrec PanelTitleOptions
$creadPrec :: ReadPrec PanelTitleOptions
readList :: ReadS [PanelTitleOptions]
$creadList :: ReadS [PanelTitleOptions]
readsPrec :: Int -> ReadS PanelTitleOptions
$creadsPrec :: Int -> ReadS PanelTitleOptions
Prelude.Read, Int -> PanelTitleOptions -> ShowS
[PanelTitleOptions] -> ShowS
PanelTitleOptions -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PanelTitleOptions] -> ShowS
$cshowList :: [PanelTitleOptions] -> ShowS
show :: PanelTitleOptions -> String
$cshow :: PanelTitleOptions -> String
showsPrec :: Int -> PanelTitleOptions -> ShowS
$cshowsPrec :: Int -> PanelTitleOptions -> ShowS
Prelude.Show, forall x. Rep PanelTitleOptions x -> PanelTitleOptions
forall x. PanelTitleOptions -> Rep PanelTitleOptions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PanelTitleOptions x -> PanelTitleOptions
$cfrom :: forall x. PanelTitleOptions -> Rep PanelTitleOptions x
Prelude.Generic)
newPanelTitleOptions ::
PanelTitleOptions
newPanelTitleOptions :: PanelTitleOptions
newPanelTitleOptions =
PanelTitleOptions'
{ $sel:fontConfiguration:PanelTitleOptions' :: Maybe FontConfiguration
fontConfiguration =
forall a. Maybe a
Prelude.Nothing,
$sel:horizontalTextAlignment:PanelTitleOptions' :: Maybe HorizontalTextAlignment
horizontalTextAlignment = forall a. Maybe a
Prelude.Nothing,
$sel:visibility:PanelTitleOptions' :: Maybe Visibility
visibility = forall a. Maybe a
Prelude.Nothing
}
panelTitleOptions_fontConfiguration :: Lens.Lens' PanelTitleOptions (Prelude.Maybe FontConfiguration)
panelTitleOptions_fontConfiguration :: Lens' PanelTitleOptions (Maybe FontConfiguration)
panelTitleOptions_fontConfiguration = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PanelTitleOptions' {Maybe FontConfiguration
fontConfiguration :: Maybe FontConfiguration
$sel:fontConfiguration:PanelTitleOptions' :: PanelTitleOptions -> Maybe FontConfiguration
fontConfiguration} -> Maybe FontConfiguration
fontConfiguration) (\s :: PanelTitleOptions
s@PanelTitleOptions' {} Maybe FontConfiguration
a -> PanelTitleOptions
s {$sel:fontConfiguration:PanelTitleOptions' :: Maybe FontConfiguration
fontConfiguration = Maybe FontConfiguration
a} :: PanelTitleOptions)
panelTitleOptions_horizontalTextAlignment :: Lens.Lens' PanelTitleOptions (Prelude.Maybe HorizontalTextAlignment)
panelTitleOptions_horizontalTextAlignment :: Lens' PanelTitleOptions (Maybe HorizontalTextAlignment)
panelTitleOptions_horizontalTextAlignment = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PanelTitleOptions' {Maybe HorizontalTextAlignment
horizontalTextAlignment :: Maybe HorizontalTextAlignment
$sel:horizontalTextAlignment:PanelTitleOptions' :: PanelTitleOptions -> Maybe HorizontalTextAlignment
horizontalTextAlignment} -> Maybe HorizontalTextAlignment
horizontalTextAlignment) (\s :: PanelTitleOptions
s@PanelTitleOptions' {} Maybe HorizontalTextAlignment
a -> PanelTitleOptions
s {$sel:horizontalTextAlignment:PanelTitleOptions' :: Maybe HorizontalTextAlignment
horizontalTextAlignment = Maybe HorizontalTextAlignment
a} :: PanelTitleOptions)
panelTitleOptions_visibility :: Lens.Lens' PanelTitleOptions (Prelude.Maybe Visibility)
panelTitleOptions_visibility :: Lens' PanelTitleOptions (Maybe Visibility)
panelTitleOptions_visibility = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PanelTitleOptions' {Maybe Visibility
visibility :: Maybe Visibility
$sel:visibility:PanelTitleOptions' :: PanelTitleOptions -> Maybe Visibility
visibility} -> Maybe Visibility
visibility) (\s :: PanelTitleOptions
s@PanelTitleOptions' {} Maybe Visibility
a -> PanelTitleOptions
s {$sel:visibility:PanelTitleOptions' :: Maybe Visibility
visibility = Maybe Visibility
a} :: PanelTitleOptions)
instance Data.FromJSON PanelTitleOptions where
parseJSON :: Value -> Parser PanelTitleOptions
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"PanelTitleOptions"
( \Object
x ->
Maybe FontConfiguration
-> Maybe HorizontalTextAlignment
-> Maybe Visibility
-> PanelTitleOptions
PanelTitleOptions'
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
"FontConfiguration")
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
"HorizontalTextAlignment")
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
"Visibility")
)
instance Prelude.Hashable PanelTitleOptions where
hashWithSalt :: Int -> PanelTitleOptions -> Int
hashWithSalt Int
_salt PanelTitleOptions' {Maybe HorizontalTextAlignment
Maybe FontConfiguration
Maybe Visibility
visibility :: Maybe Visibility
horizontalTextAlignment :: Maybe HorizontalTextAlignment
fontConfiguration :: Maybe FontConfiguration
$sel:visibility:PanelTitleOptions' :: PanelTitleOptions -> Maybe Visibility
$sel:horizontalTextAlignment:PanelTitleOptions' :: PanelTitleOptions -> Maybe HorizontalTextAlignment
$sel:fontConfiguration:PanelTitleOptions' :: PanelTitleOptions -> Maybe FontConfiguration
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe FontConfiguration
fontConfiguration
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe HorizontalTextAlignment
horizontalTextAlignment
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Visibility
visibility
instance Prelude.NFData PanelTitleOptions where
rnf :: PanelTitleOptions -> ()
rnf PanelTitleOptions' {Maybe HorizontalTextAlignment
Maybe FontConfiguration
Maybe Visibility
visibility :: Maybe Visibility
horizontalTextAlignment :: Maybe HorizontalTextAlignment
fontConfiguration :: Maybe FontConfiguration
$sel:visibility:PanelTitleOptions' :: PanelTitleOptions -> Maybe Visibility
$sel:horizontalTextAlignment:PanelTitleOptions' :: PanelTitleOptions -> Maybe HorizontalTextAlignment
$sel:fontConfiguration:PanelTitleOptions' :: PanelTitleOptions -> Maybe FontConfiguration
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe FontConfiguration
fontConfiguration
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe HorizontalTextAlignment
horizontalTextAlignment
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Visibility
visibility
instance Data.ToJSON PanelTitleOptions where
toJSON :: PanelTitleOptions -> Value
toJSON PanelTitleOptions' {Maybe HorizontalTextAlignment
Maybe FontConfiguration
Maybe Visibility
visibility :: Maybe Visibility
horizontalTextAlignment :: Maybe HorizontalTextAlignment
fontConfiguration :: Maybe FontConfiguration
$sel:visibility:PanelTitleOptions' :: PanelTitleOptions -> Maybe Visibility
$sel:horizontalTextAlignment:PanelTitleOptions' :: PanelTitleOptions -> Maybe HorizontalTextAlignment
$sel:fontConfiguration:PanelTitleOptions' :: PanelTitleOptions -> Maybe FontConfiguration
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"FontConfiguration" 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 FontConfiguration
fontConfiguration,
(Key
"HorizontalTextAlignment" 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 HorizontalTextAlignment
horizontalTextAlignment,
(Key
"Visibility" 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 Visibility
visibility
]
)