{-# 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.QuickSight.Types.Typography -- 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.QuickSight.Types.Typography 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.Font -- | Determines the typography options. -- -- /See:/ 'newTypography' smart constructor. data Typography = Typography' { -- | Determines the list of font families. fontFamilies :: Prelude.Maybe [Font] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'Typography' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'fontFamilies', 'typography_fontFamilies' - Determines the list of font families. newTypography :: Typography newTypography = Typography' {fontFamilies = Prelude.Nothing} -- | Determines the list of font families. typography_fontFamilies :: Lens.Lens' Typography (Prelude.Maybe [Font]) typography_fontFamilies = Lens.lens (\Typography' {fontFamilies} -> fontFamilies) (\s@Typography' {} a -> s {fontFamilies = a} :: Typography) Prelude.. Lens.mapping Lens.coerced instance Data.FromJSON Typography where parseJSON = Data.withObject "Typography" ( \x -> Typography' Prelude.<$> (x Data..:? "FontFamilies" Data..!= Prelude.mempty) ) instance Prelude.Hashable Typography where hashWithSalt _salt Typography' {..} = _salt `Prelude.hashWithSalt` fontFamilies instance Prelude.NFData Typography where rnf Typography' {..} = Prelude.rnf fontFamilies instance Data.ToJSON Typography where toJSON Typography' {..} = Data.object ( Prelude.catMaybes [("FontFamilies" Data..=) Prelude.<$> fontFamilies] )