1*b1cdbd2cSJim Jagielski /************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski 23*b1cdbd2cSJim Jagielski 24*b1cdbd2cSJim Jagielski #ifndef SD_TASKPANE_TITLED_CONTROL_HXX 25*b1cdbd2cSJim Jagielski #define SD_TASKPANE_TITLED_CONTROL_HXX 26*b1cdbd2cSJim Jagielski 27*b1cdbd2cSJim Jagielski #include "taskpane/TaskPaneTreeNode.hxx" 28*b1cdbd2cSJim Jagielski #include "taskpane/ControlContainer.hxx" 29*b1cdbd2cSJim Jagielski #include "TitleBar.hxx" 30*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/framework/XResourceId.hpp> 31*b1cdbd2cSJim Jagielski #include <tools/string.hxx> 32*b1cdbd2cSJim Jagielski #include <tools/gen.hxx> 33*b1cdbd2cSJim Jagielski #ifndef SD_WINDOW_HXX 34*b1cdbd2cSJim Jagielski #include <vcl/window.hxx> 35*b1cdbd2cSJim Jagielski #endif 36*b1cdbd2cSJim Jagielski #include <memory> 37*b1cdbd2cSJim Jagielski #include <boost/function.hpp> 38*b1cdbd2cSJim Jagielski 39*b1cdbd2cSJim Jagielski class Window; 40*b1cdbd2cSJim Jagielski 41*b1cdbd2cSJim Jagielski namespace sd { namespace toolpanel { 42*b1cdbd2cSJim Jagielski 43*b1cdbd2cSJim Jagielski class ControlContainer; 44*b1cdbd2cSJim Jagielski 45*b1cdbd2cSJim Jagielski /** This wrapper adds a title bar to a control. Both title bar and 46*b1cdbd2cSJim Jagielski control are child windows. 47*b1cdbd2cSJim Jagielski */ 48*b1cdbd2cSJim Jagielski class TitledControl 49*b1cdbd2cSJim Jagielski : public ::Window, 50*b1cdbd2cSJim Jagielski public TreeNode 51*b1cdbd2cSJim Jagielski { 52*b1cdbd2cSJim Jagielski public: 53*b1cdbd2cSJim Jagielski typedef ::boost::function1<void, TitledControl&> ClickHandler; 54*b1cdbd2cSJim Jagielski 55*b1cdbd2cSJim Jagielski /** Create a new descriptor for the given control. 56*b1cdbd2cSJim Jagielski @param pParent 57*b1cdbd2cSJim Jagielski The parent window of the new descriptor. 58*b1cdbd2cSJim Jagielski @param pControl 59*b1cdbd2cSJim Jagielski The control that is shown when being in the expanded 60*b1cdbd2cSJim Jagielski state. 61*b1cdbd2cSJim Jagielski @param rTitle 62*b1cdbd2cSJim Jagielski String that is shown as title in the title area above the 63*b1cdbd2cSJim Jagielski control. 64*b1cdbd2cSJim Jagielski @param rClickHandler 65*b1cdbd2cSJim Jagielski The typical action of the click handler is to expand the control. 66*b1cdbd2cSJim Jagielski @param eType 67*b1cdbd2cSJim Jagielski Type of the title bar. This specifies how the title bar 68*b1cdbd2cSJim Jagielski will be formated. For more information see TitleBar. 69*b1cdbd2cSJim Jagielski 70*b1cdbd2cSJim Jagielski */ 71*b1cdbd2cSJim Jagielski TitledControl ( 72*b1cdbd2cSJim Jagielski TreeNode* pParent, 73*b1cdbd2cSJim Jagielski ::std::auto_ptr<TreeNode> pControl, 74*b1cdbd2cSJim Jagielski const String& rTitle, 75*b1cdbd2cSJim Jagielski const ClickHandler& rClickHandler, 76*b1cdbd2cSJim Jagielski TitleBar::TitleBarType eType); 77*b1cdbd2cSJim Jagielski 78*b1cdbd2cSJim Jagielski virtual ~TitledControl (void); 79*b1cdbd2cSJim Jagielski 80*b1cdbd2cSJim Jagielski 81*b1cdbd2cSJim Jagielski virtual Size GetPreferredSize (void); 82*b1cdbd2cSJim Jagielski virtual sal_Int32 GetPreferredWidth (sal_Int32 nHeight); 83*b1cdbd2cSJim Jagielski virtual sal_Int32 GetPreferredHeight (sal_Int32 nWidth); 84*b1cdbd2cSJim Jagielski virtual bool IsResizable (void); 85*b1cdbd2cSJim Jagielski virtual ::Window* GetWindow (void); 86*b1cdbd2cSJim Jagielski 87*b1cdbd2cSJim Jagielski virtual void Resize (void); 88*b1cdbd2cSJim Jagielski virtual void GetFocus (void); 89*b1cdbd2cSJim Jagielski virtual void KeyInput (const KeyEvent& rEvent); 90*b1cdbd2cSJim Jagielski 91*b1cdbd2cSJim Jagielski // void Select (bool bExpansionState); 92*b1cdbd2cSJim Jagielski 93*b1cdbd2cSJim Jagielski TitleBar* GetTitleBar (void); 94*b1cdbd2cSJim Jagielski /** Return the control child. When a control factory has been given and 95*b1cdbd2cSJim Jagielski the control has not yet been created and the given flag is <TRUE/> 96*b1cdbd2cSJim Jagielski then the control is created. 97*b1cdbd2cSJim Jagielski */ 98*b1cdbd2cSJim Jagielski TreeNode* GetControl (void); 99*b1cdbd2cSJim Jagielski const TreeNode* GetConstControl () const; 100*b1cdbd2cSJim Jagielski 101*b1cdbd2cSJim Jagielski const String& GetTitle (void) const; 102*b1cdbd2cSJim Jagielski 103*b1cdbd2cSJim Jagielski /** Expand the control without informing its container. This 104*b1cdbd2cSJim Jagielski method ususally is called by the container as a result of a 105*b1cdbd2cSJim Jagielski higher level expand command. You may want to use 106*b1cdbd2cSJim Jagielski ExpandViaContainer() instead. 107*b1cdbd2cSJim Jagielski @param bExpanded 108*b1cdbd2cSJim Jagielski When <TRUE/> then the control is expanded, otherwise it is 109*b1cdbd2cSJim Jagielski collapsed. 110*b1cdbd2cSJim Jagielski */ 111*b1cdbd2cSJim Jagielski virtual bool Expand (bool bExpanded = true); 112*b1cdbd2cSJim Jagielski 113*b1cdbd2cSJim Jagielski /** Return whether the control is currently expanded (<TRUE/>) or 114*b1cdbd2cSJim Jagielski not (<FALSE/>). 115*b1cdbd2cSJim Jagielski */ 116*b1cdbd2cSJim Jagielski virtual bool IsExpanded (void) const; 117*b1cdbd2cSJim Jagielski 118*b1cdbd2cSJim Jagielski /** Returns the value of the control. 119*b1cdbd2cSJim Jagielski */ 120*b1cdbd2cSJim Jagielski virtual bool IsExpandable (void) const; 121*b1cdbd2cSJim Jagielski 122*b1cdbd2cSJim Jagielski virtual void SetEnabledState(bool bFlag); 123*b1cdbd2cSJim Jagielski 124*b1cdbd2cSJim Jagielski virtual bool IsShowing (void) const; 125*b1cdbd2cSJim Jagielski virtual void Show (bool bVisible); 126*b1cdbd2cSJim Jagielski 127*b1cdbd2cSJim Jagielski virtual ::com::sun::star::uno::Reference< 128*b1cdbd2cSJim Jagielski ::com::sun::star::accessibility::XAccessible > CreateAccessibleObject ( 129*b1cdbd2cSJim Jagielski const ::com::sun::star::uno::Reference< 130*b1cdbd2cSJim Jagielski ::com::sun::star::accessibility::XAccessible>& rxParent); 131*b1cdbd2cSJim Jagielski 132*b1cdbd2cSJim Jagielski using Window::GetWindow; 133*b1cdbd2cSJim Jagielski using Window::Show; 134*b1cdbd2cSJim Jagielski 135*b1cdbd2cSJim Jagielski private: 136*b1cdbd2cSJim Jagielski String msTitle; 137*b1cdbd2cSJim Jagielski bool mbVisible; 138*b1cdbd2cSJim Jagielski void* mpUserData; 139*b1cdbd2cSJim Jagielski ::std::auto_ptr<ClickHandler> mpClickHandler; 140*b1cdbd2cSJim Jagielski 141*b1cdbd2cSJim Jagielski /// Do not use! Assignment operator is not supported. 142*b1cdbd2cSJim Jagielski const TitledControl& operator= ( 143*b1cdbd2cSJim Jagielski const TitledControl& aDescriptor); 144*b1cdbd2cSJim Jagielski 145*b1cdbd2cSJim Jagielski void UpdateStates (void); 146*b1cdbd2cSJim Jagielski 147*b1cdbd2cSJim Jagielski DECL_LINK(WindowEventListener, VclSimpleEvent*); 148*b1cdbd2cSJim Jagielski }; 149*b1cdbd2cSJim Jagielski 150*b1cdbd2cSJim Jagielski 151*b1cdbd2cSJim Jagielski 152*b1cdbd2cSJim Jagielski 153*b1cdbd2cSJim Jagielski /** This standard implementation of the ClickHandler expands, or toggles the 154*b1cdbd2cSJim Jagielski expansion state, of the control, whose title was clicked. 155*b1cdbd2cSJim Jagielski */ 156*b1cdbd2cSJim Jagielski class TitledControlStandardClickHandler 157*b1cdbd2cSJim Jagielski { 158*b1cdbd2cSJim Jagielski public: 159*b1cdbd2cSJim Jagielski /** Create a new instance of this class. 160*b1cdbd2cSJim Jagielski @param rControlContainer 161*b1cdbd2cSJim Jagielski The container of which the TitledControl is part of. 162*b1cdbd2cSJim Jagielski @param eExpansionState 163*b1cdbd2cSJim Jagielski This specifies whether to always expand the titled control or to 164*b1cdbd2cSJim Jagielski toggle its expansion state. 165*b1cdbd2cSJim Jagielski */ 166*b1cdbd2cSJim Jagielski TitledControlStandardClickHandler ( 167*b1cdbd2cSJim Jagielski ControlContainer& rControlContainer, 168*b1cdbd2cSJim Jagielski ControlContainer::ExpansionState eExpansionState); 169*b1cdbd2cSJim Jagielski void operator () (TitledControl& rTitledControl); 170*b1cdbd2cSJim Jagielski private: 171*b1cdbd2cSJim Jagielski ControlContainer& mrControlContainer; 172*b1cdbd2cSJim Jagielski ControlContainer::ExpansionState meExpansionState; 173*b1cdbd2cSJim Jagielski }; 174*b1cdbd2cSJim Jagielski 175*b1cdbd2cSJim Jagielski } } // end of namespace ::sd::toolpanel 176*b1cdbd2cSJim Jagielski 177*b1cdbd2cSJim Jagielski #endif 178