diff options
Diffstat (limited to 'svx/source')
-rw-r--r-- | svx/source/dialog/orienthelper.cxx | 149 |
1 files changed, 0 insertions, 149 deletions
diff --git a/svx/source/dialog/orienthelper.cxx b/svx/source/dialog/orienthelper.cxx deleted file mode 100644 index 7be0ea70058d..000000000000 --- a/svx/source/dialog/orienthelper.cxx +++ /dev/null @@ -1,149 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include <svx/orienthelper.hxx> - -#include <vector> -#include <utility> - -#include <vcl/button.hxx> -#include <svx/dialcontrol.hxx> - -namespace svx { - - -struct OrientationHelper_Impl -{ - typedef std::pair< VclPtr<vcl::Window>, TriState > WindowPair; - typedef std::vector< WindowPair > WindowVec; - - CheckBox& mrCbStacked; - WindowVec maWinVec; - bool mbEnabled; - bool mbVisible; - - explicit OrientationHelper_Impl( DialControl& rCtrlDial, CheckBox& rCbStacked ); - - void AddDependentWindow( vcl::Window& rWindow, TriState eDisableIfStacked ); - - void EnableDependentWindows(); - void EnableWindow( vcl::Window& rWindow, TriState eDisableIfStacked ); - - void ShowDependentWindows(); - - DECL_LINK( ClickHdl, Button*, void ); -}; - - -OrientationHelper_Impl::OrientationHelper_Impl( DialControl& rCtrlDial, CheckBox& rCbStacked ) : - mrCbStacked( rCbStacked ), - mbEnabled( rCtrlDial.IsEnabled() ), - mbVisible( rCtrlDial.IsVisible() ) -{ - maWinVec.emplace_back( &rCtrlDial, TRISTATE_TRUE ); - maWinVec.emplace_back( &mrCbStacked, TRISTATE_INDET ); - mrCbStacked.SetClickHdl( LINK( this, OrientationHelper_Impl, ClickHdl ) ); -} - -void OrientationHelper_Impl::AddDependentWindow( vcl::Window& rWindow, TriState eDisableIfStacked ) -{ - maWinVec.emplace_back( &rWindow, eDisableIfStacked ); - EnableWindow( rWindow, eDisableIfStacked ); -} - -void OrientationHelper_Impl::EnableDependentWindows() -{ - WindowVec::const_iterator aEnd = maWinVec.end(); - for( WindowVec::iterator aIt = maWinVec.begin(); aIt != aEnd; ++aIt ) - EnableWindow( *aIt->first, aIt->second ); -} - -void OrientationHelper_Impl::EnableWindow( vcl::Window& rWindow, TriState eDisableIfStacked ) -{ - bool bDisableOnStacked = false; - switch( eDisableIfStacked ) - { - // TRISTATE_TRUE: Disable window, if stacked text is turned on or "don't know". - case TRISTATE_TRUE: bDisableOnStacked = (mrCbStacked.GetState() != TRISTATE_FALSE); break; - // TRISTATE_FALSE: Disable window, if stacked text is turned off or "don't know". - case TRISTATE_FALSE: bDisableOnStacked = (mrCbStacked.GetState() != TRISTATE_TRUE); break; - default: ;//prevent warning - } - rWindow.Enable( mbEnabled && !bDisableOnStacked ); -} - -void OrientationHelper_Impl::ShowDependentWindows() -{ - WindowVec::const_iterator aEnd = maWinVec.end(); - for( WindowVec::iterator aIt = maWinVec.begin(); aIt != aEnd; ++aIt ) - aIt->first->Show( mbVisible ); -} - -IMPL_LINK_NOARG(OrientationHelper_Impl, ClickHdl, Button*, void) -{ - EnableDependentWindows(); -} - - -OrientationHelper::OrientationHelper( DialControl& rCtrlDial, NumericField& rNfRotation, CheckBox& rCbStacked ) : - mpImpl( new OrientationHelper_Impl( rCtrlDial, rCbStacked ) ) -{ - rCtrlDial.SetLinkedField( &rNfRotation ); - mpImpl->EnableDependentWindows(); - mpImpl->ShowDependentWindows(); -} - -OrientationHelper::~OrientationHelper() -{ -} - -void OrientationHelper::AddDependentWindow( vcl::Window& rWindow, TriState eDisableIfStacked ) -{ - mpImpl->AddDependentWindow( rWindow, eDisableIfStacked ); -} - -void OrientationHelper::Enable( bool bEnable ) -{ - mpImpl->mbEnabled = bEnable; - mpImpl->EnableDependentWindows(); -} - -void OrientationHelper::Show( bool bShow ) -{ - mpImpl->mbVisible = bShow; - mpImpl->ShowDependentWindows(); -} - -void OrientationHelper::SetStackedState( TriState eState ) -{ - if( eState != GetStackedState() ) - { - mpImpl->mrCbStacked.SetState( eState ); - mpImpl->EnableDependentWindows(); - } -} - -TriState OrientationHelper::GetStackedState() const -{ - return mpImpl->mrCbStacked.GetState(); -} - -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |