/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: ControlContainer.cxx,v $ * * $Revision: 1.7 $ * * last change: $Author: rt $ $Date: 2005-09-09 06:29:24 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ #include "taskpane/ControlContainer.hxx" #include "taskpane/TaskPaneTreeNode.hxx" #include #ifndef _SV_SVAPP_HXX #include #endif namespace sd { namespace toolpanel { ControlContainer::ControlContainer (TreeNode* pNode) : mpNode(pNode), mnActiveControlIndex(-1), mbMultiSelection(false) { } ControlContainer::~ControlContainer (void) { // Set mpNode to NULL so that no one calls it from now on. mpNode = NULL; DeleteChildren(); } void ControlContainer::DeleteChildren (void) { ControlList::iterator I; ControlList::iterator Iend (maControlList.end()); for (I=maControlList.begin(); I!=Iend; ++I) delete *I; maControlList.clear(); if (mpNode != NULL) mpNode->FireStateChangeEvent(EID_ALL_CHILDREN_REMOVED); } sal_uInt32 ControlContainer::AddControl (::std::auto_ptr pControl) { ::osl::MutexGuard aGuard (maMutex); pControl->GetWindow()->Show(); sal_uInt32 nIndex = maControlList.size(); maControlList.push_back (pControl.get()); pControl.release(); ListHasChanged (); if (mpNode != NULL) mpNode->FireStateChangeEvent(EID_CHILD_ADDED, pControl.get()); return nIndex; } void ControlContainer::SetExpansionState ( UINT32 nIndex, ExpansionState aState) { ::osl::MutexGuard aGuard (maMutex); bool bResizeNecessary (false); if (mbMultiSelection) { TreeNode* pControl = GetControl(nIndex); switch (aState) { case ES_TOGGLE: bResizeNecessary = pControl->Expand( ! pControl->IsExpanded()); break; case ES_EXPAND: bResizeNecessary = pControl->Expand(true); break; case ES_COLLAPSE: bResizeNecessary = pControl->Expand(false); break; } } else { // When bExpansionState is true then the control to expand is the // one with the given index. If bExpansionState is false and the // given index points to the active control then then following // control (in cyclic order) it is expanded. When there is only one // control then that is always expanded. do { // Ignore a call with an invalid index. if (nIndex<0 || nIndex>=GetControlCount()) break; bool bExpand; switch (aState) { case ES_TOGGLE: bExpand = ! GetControl(nIndex)->IsExpanded(); break; case ES_EXPAND: bExpand = true; break; case ES_COLLAPSE: bExpand = false; break; } if (bExpand) { // Make the specified control the active one and expand it. mnActiveControlIndex = nIndex; } else { if (nIndex == mnActiveControlIndex) { // We have to determine a new active control since the // current one is about to be collapsed. Choose the // previous one for the last and the next one for all // other. if (mnActiveControlIndex+1 == GetControlCount()) mnActiveControlIndex = GetPreviousIndex(mnActiveControlIndex); else mnActiveControlIndex = GetNextIndex (mnActiveControlIndex); } } // Update the expansion state of all controls. for (UINT32 i=0; iExpand(i == mnActiveControlIndex); } } while (false); } if (bResizeNecessary && mpNode != NULL) mpNode->RequestResize(); } void ControlContainer::SetExpansionState ( TreeNode* pControl, ExpansionState aState) { SetExpansionState (GetControlIndex(pControl), aState); } sal_uInt32 ControlContainer::GetControlIndex (TreeNode* pControlToExpand) const { sal_uInt32 nIndex; for (nIndex=0; nIndexGetWindow()->IsVisible()) nCount += 1; } return nCount; } TreeNode* ControlContainer::GetControl (sal_uInt32 nIndex) const { if (nIndex>=0 && nIndex