{-# 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.RenameColumnOperation -- 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.RenameColumnOperation 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 -- | A transform operation that renames a column. -- -- /See:/ 'newRenameColumnOperation' smart constructor. data RenameColumnOperation = RenameColumnOperation' { -- | The name of the column to be renamed. columnName :: Prelude.Text, -- | The new name for the column. newColumnName' :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RenameColumnOperation' 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: -- -- 'columnName', 'renameColumnOperation_columnName' - The name of the column to be renamed. -- -- 'newColumnName'', 'renameColumnOperation_newColumnName' - The new name for the column. newRenameColumnOperation :: -- | 'columnName' Prelude.Text -> -- | 'newColumnName'' Prelude.Text -> RenameColumnOperation newRenameColumnOperation pColumnName_ pNewColumnName_ = RenameColumnOperation' { columnName = pColumnName_, newColumnName' = pNewColumnName_ } -- | The name of the column to be renamed. renameColumnOperation_columnName :: Lens.Lens' RenameColumnOperation Prelude.Text renameColumnOperation_columnName = Lens.lens (\RenameColumnOperation' {columnName} -> columnName) (\s@RenameColumnOperation' {} a -> s {columnName = a} :: RenameColumnOperation) -- | The new name for the column. renameColumnOperation_newColumnName :: Lens.Lens' RenameColumnOperation Prelude.Text renameColumnOperation_newColumnName = Lens.lens (\RenameColumnOperation' {newColumnName'} -> newColumnName') (\s@RenameColumnOperation' {} a -> s {newColumnName' = a} :: RenameColumnOperation) instance Data.FromJSON RenameColumnOperation where parseJSON = Data.withObject "RenameColumnOperation" ( \x -> RenameColumnOperation' Prelude.<$> (x Data..: "ColumnName") Prelude.<*> (x Data..: "NewColumnName") ) instance Prelude.Hashable RenameColumnOperation where hashWithSalt _salt RenameColumnOperation' {..} = _salt `Prelude.hashWithSalt` columnName `Prelude.hashWithSalt` newColumnName' instance Prelude.NFData RenameColumnOperation where rnf RenameColumnOperation' {..} = Prelude.rnf columnName `Prelude.seq` Prelude.rnf newColumnName' instance Data.ToJSON RenameColumnOperation where toJSON RenameColumnOperation' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("ColumnName" Data..= columnName), Prelude.Just ("NewColumnName" Data..= newColumnName') ] )