/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: ToolPanelViewShell.hxx,v $ * $Revision: 1.12 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef SD_TOOL_PANEL_VIEW_SHELL_HXX #define SD_TOOL_PANEL_VIEW_SHELL_HXX #include "ViewShell.hxx" #include "glob.hxx" #include "taskpane/PanelId.hxx" #include "framework/FrameworkHelper.hxx" #include #include #include #include #include #include class PopupMenu; namespace com { namespace sun { namespace star { namespace ui { class XUIElement; } } } } namespace sd { class PaneDockingWindow; namespace toolpanel { class TaskPaneShellManager; class TitleToolBox; class TitleBar; class TitledControl; class ToolPanelViewShell_Impl; /** The tool panel is a view shell for some very specific reasons: - It fits better into the concept of panes being docking windows whose content, a view shell, can be exchanged on runtime. - A control in the tool panel that wants to show a context menu has to do that over the dispatcher of a shell. These shells, usually implemented by the controls themselves, have to be managed by someone. If interpreted as object bars this can be handled by the ObjectBarManager of the ViewShell. */ class ToolPanelViewShell : public ViewShell { public: TYPEINFO(); SFX_DECL_INTERFACE(SD_IF_SDTOOLPANELSHELL) ToolPanelViewShell ( SfxViewFrame* pFrame, ViewShellBase& rViewShellBase, ::Window* pParentWindow, FrameView* pFrameView); virtual ~ToolPanelViewShell (void); /** Register the SFX interfaces so that (some of) the controls can be pushed as SFX shells on the shell stack and process slot calls and so on. */ static void RegisterControls (void); virtual void GetFocus (void); virtual void LoseFocus (void); virtual void KeyInput (const KeyEvent& rEvent); using sd::ViewShell::KeyInput; virtual SdPage* GetActualPage (void); virtual SdPage* getCurrentPage (void) const; void Execute (SfxRequest& rRequest); void GetState (SfxItemSet& rItemSet); virtual void ArrangeGUIElements (void); TaskPaneShellManager& GetSubShellManager (void) const; /** deactivates the given panel, bypassing the configuration controller. Only valid for tool panels which are not under the drawing framework's control. */ void ActivatePanel( const ::rtl::OUString& i_rPanelResourceURL ); /** deactivates the given panel, bypassing the configuration controller */ void DeactivatePanel( const ::rtl::OUString& i_rPanelResourceURL ); /** Return a pointer to the docking window that is the parent or a predecessor of the content window. @return When the view shell is not placed in a docking window, e.g. when shown in the center pane, then is returned. */ DockingWindow* GetDockingWindow (void); virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible> CreateAccessibleDocumentView (::sd::Window* pWindow); virtual css::uno::Reference CreateSubController (void); /** Relocate all toplevel controls to the given parent window. */ virtual bool RelocateToParentWindow (::Window* pParentWindow); /// returns if and only if the given window is the panel anchor window of our ToolPanelDeck bool IsPanelAnchorWindow( const ::Window& i_rWindow ) const; /** creates an XUIElement for the given standard panel */ ::com::sun::star::uno::Reference< ::com::sun::star::ui::XUIElement > CreatePanelUIElement( const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XFrame >& i_rDocFrame, const ::rtl::OUString& i_rPanelResourceURL ); private: ::boost::scoped_ptr< ToolPanelViewShell_Impl > mpImpl; ::boost::shared_ptr mpSubShellManager; /** The id of the menu in the menu bar/tool box of the parent docking window. */ USHORT mnMenuId; /** Create a popup menu. it contains two sections, one for docking or un-docking the tool panel, one for toggling the visibility state of the tool panel items. @param bIsDocking According to this flag one of the lock/unlock entries is made disabled. */ ::std::auto_ptr CreatePopupMenu (bool bIsDocking); /** Initialize the task pane view shell if that has not yet been done before. If mbIsInitialized is already set to then this method returns immediately. */ void Initialize (void); }; } } // end of namespace ::sd::toolpanel #endif