a021467b25
2007/01/29 17:30:37 af 1.14.96.6: #i68075# New RelocateToParentWindow() method. 2007/01/25 15:23:26 af 1.14.96.5: RESYNC: (1.15-1.16); FILE MERGED 2007/01/24 17:49:50 af 1.14.96.4: #i68075# The click handler can now be supplied along with a control. 2006/09/25 17:29:20 af 1.14.96.3: RESYNC: (1.14-1.15); FILE MERGED 2006/09/21 09:13:11 af 1.14.96.2: #i68075# Removed unused mpTitleToolBox member. 2006/08/22 11:52:13 af 1.14.96.1: #i68075# Added PaneActivation functor. Adaption to changes in the pane window implementation.
868 lines
23 KiB
C++
868 lines
23 KiB
C++
/*************************************************************************
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* $RCSfile: TaskPaneViewShell.cxx,v $
|
|
*
|
|
* $Revision: 1.17 $
|
|
*
|
|
* last change: $Author: rt $ $Date: 2007-04-03 16:21:15 $
|
|
*
|
|
* 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
|
|
*
|
|
************************************************************************/
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
#include "precompiled_sd.hxx"
|
|
|
|
#include "TaskPaneViewShell.hxx"
|
|
|
|
#include "TaskPaneShellManager.hxx"
|
|
#include "ToolPanelChildWindow.hrc"
|
|
#include "ToolPanelChildWindow.hxx"
|
|
#include "taskpane/SlideSorterCacheDisplay.hxx"
|
|
#include "taskpane/ToolPanel.hxx"
|
|
#include "taskpane/TitledControl.hxx"
|
|
#include "LayoutMenu.hxx"
|
|
#include "TaskPaneFocusManager.hxx"
|
|
#include "taskpane/SubToolPanel.hxx"
|
|
#include "taskpane/ScrollPanel.hxx"
|
|
#include "taskpane/TaskPaneControlFactory.hxx"
|
|
#include "controls/MasterPagesPanel.hxx"
|
|
#include "controls/MasterPagesSelector.hxx"
|
|
#include "controls/CustomAnimationPanel.hxx"
|
|
#include "controls/SlideTransitionPanel.hxx"
|
|
#include "controls/AnimationSchemesPanel.hxx"
|
|
#include "TitleToolBox.hxx"
|
|
#include "taskpane/ControlContainer.hxx"
|
|
#include "FrameView.hxx"
|
|
#include "Window.hxx"
|
|
#include "PaneDockingWindow.hxx"
|
|
#include "AccessibleTaskPane.hxx"
|
|
#include "DrawSubController.hxx"
|
|
#include "sdmod.hxx"
|
|
#include "app.hrc"
|
|
#include "glob.hrc"
|
|
#include "res_bmp.hrc"
|
|
#include "helpids.h"
|
|
#include "strings.hrc"
|
|
#include "sdresid.hxx"
|
|
#include "framework/FrameworkHelper.hxx"
|
|
|
|
#ifndef _COM_SUN_STAR_DRAWING_FRAMEWORK_XRESOURCEID_HPP_
|
|
#include <com/sun/star/drawing/framework/XResourceId.hpp>
|
|
#endif
|
|
#ifndef _COM_SUN_STAR_DRAWING_FRAMEWORK_RESOURCEACTIVATIONMODE_HPP_
|
|
#include <com/sun/star/drawing/framework/ResourceActivationMode.hpp>
|
|
#endif
|
|
|
|
#ifndef _SVX_DLG_CTRL_HXX
|
|
#include <svx/dlgctrl.hxx>
|
|
#endif
|
|
#ifndef _SFX_BINDINGS_HXX
|
|
#include <sfx2/bindings.hxx>
|
|
#endif
|
|
#ifndef _SFXDISPATCH_HXX
|
|
#include <sfx2/dispatch.hxx>
|
|
#endif
|
|
#ifndef _SFXVIEWFRM_HXX
|
|
#include <sfx2/viewfrm.hxx>
|
|
#endif
|
|
#include <sfx2/msg.hxx>
|
|
#include <sfx2/objface.hxx>
|
|
#ifndef _SVX_COLRCTRL_HXX
|
|
#include <svx/colrctrl.hxx>
|
|
#endif
|
|
#ifndef _XTABLE_HXX
|
|
#include <svx/xtable.hxx>
|
|
#endif
|
|
#include <vcl/dockwin.hxx>
|
|
#ifndef _SDTREELB_HXX
|
|
#include "sdtreelb.hxx"
|
|
#endif
|
|
#ifndef SD_DRAW_VIEW_SHELL_HXX
|
|
#include "DrawViewShell.hxx"
|
|
#endif
|
|
#include "drawdoc.hxx"
|
|
#ifndef SD_VIEW_SHELL_BASE_HXX
|
|
#include "ViewShellBase.hxx"
|
|
#endif
|
|
#ifndef _SVX_RULER_HXX //autogen
|
|
#include <svx/ruler.hxx>
|
|
#endif
|
|
#ifndef _SV_SVAPP_HXX
|
|
#include <vcl/svapp.hxx>
|
|
#endif
|
|
|
|
//#define SHOW_TEST_PANEL
|
|
#ifdef SHOW_TEST_PANEL
|
|
#include "TestPanel.hxx"
|
|
#endif
|
|
//#define SHOW_COLOR_MENU
|
|
#ifdef SHOW_COLOR_MENU
|
|
#include "TestMenu.hxx"
|
|
#endif
|
|
|
|
#include <vector>
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
using namespace ::sd::toolpanel;
|
|
|
|
#define TaskPaneViewShell
|
|
#include "sdslots.hxx"
|
|
|
|
|
|
using namespace ::com::sun::star;
|
|
using namespace ::com::sun::star::uno;
|
|
using ::sd::framework::FrameworkHelper;
|
|
|
|
|
|
namespace sd { namespace toolpanel {
|
|
|
|
SFX_IMPL_INTERFACE(TaskPaneViewShell, SfxShell, SdResId(STR_TASKPANEVIEWSHELL))
|
|
{
|
|
}
|
|
|
|
|
|
TYPEINIT1(TaskPaneViewShell, ViewShell);
|
|
|
|
|
|
/** Inner implementation class of TaskPaneViewShell.
|
|
*/
|
|
class TaskPaneViewShell::Implementation
|
|
{
|
|
public:
|
|
static const sal_uInt32 mnInvalidId = 0xffffffff;
|
|
|
|
Implementation (void);
|
|
~Implementation (void);
|
|
|
|
/** Here the panels are created that are shown in the task pane.
|
|
*/
|
|
void Setup (ToolPanel* pToolPanel, ViewShellBase& rBase);
|
|
|
|
/** Make a new panel known to the translation table that translates
|
|
between internal indices as returned by
|
|
ControlContainer::AddControl() and public indices defined by
|
|
TaskPaneViewShell::PanelId.
|
|
*/
|
|
void AddPanel (sal_uInt32 nInternalId, PanelId nPublicId);
|
|
|
|
/** Return the public id for the given internal one.
|
|
@return
|
|
When the given public id is not known then PID_UNKNOWN is
|
|
returned.
|
|
*/
|
|
PanelId GetPublicId (sal_uInt32 nInternalId) const;
|
|
|
|
/** Return the internal id for the given public one.
|
|
@return
|
|
When the given public id is not known then mnInvalidId is
|
|
returned.
|
|
*/
|
|
sal_uInt32 GetInternalId (PanelId nPublicId) const;
|
|
|
|
private:
|
|
/** This map translates between internal indices returned by
|
|
ControlContainer::AddControl() and public indices defined by
|
|
TaskPaneViewShell::PanelId.
|
|
*/
|
|
typedef ::std::vector<PanelId> InternalIdToPanelIdMap;
|
|
InternalIdToPanelIdMap maIndexMap;
|
|
};
|
|
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
enum MenuId {
|
|
MID_UNLOCK_TASK_PANEL = 1,
|
|
MID_LOCK_TASK_PANEL = 2,
|
|
MID_CUSTOMIZE = 3,
|
|
MID_FIRST_CONTROL = 4
|
|
};
|
|
|
|
/** This control is used for extracting the title string from the resource
|
|
of some dialogs that are displayed in the task pane. With this the
|
|
actual controls can be created on demand. This class only loads (a part
|
|
of) their resource.
|
|
*/
|
|
class DummyControl : public Control
|
|
{
|
|
public:
|
|
DummyControl (::Window* pParent, const ResId& rResId)
|
|
: Control(pParent,rResId)
|
|
{
|
|
FreeResource();
|
|
}
|
|
};
|
|
|
|
class ResourceActivationClickHandler
|
|
{
|
|
public:
|
|
ResourceActivationClickHandler (
|
|
const ::boost::shared_ptr<FrameworkHelper>& rpFrameworkHelper,
|
|
const Reference<drawing::framework::XResourceId>& rxResourceId,
|
|
ControlContainer& rControlContainer);
|
|
void operator () (TitledControl& rTitledControl);
|
|
|
|
private:
|
|
::boost::shared_ptr<FrameworkHelper> mpFrameworkHelper;
|
|
Reference<drawing::framework::XResourceId> mxResourceId;
|
|
ControlContainer& mrControlContainer;
|
|
};
|
|
|
|
} // end of anonymouse namespace
|
|
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::Implementation::Setup (
|
|
ToolPanel* pToolPanel,
|
|
ViewShellBase& rBase)
|
|
{
|
|
SdDrawDocument* pDocument = rBase.GetDocument();
|
|
sal_uInt32 nId;
|
|
sal_uInt32 nIdOfControlToExpand;
|
|
|
|
::boost::shared_ptr<FrameworkHelper> pFrameworkHelper (FrameworkHelper::Instance(rBase));
|
|
Reference<drawing::framework::XResourceId> xTaskPaneId (pFrameworkHelper->CreateResourceId(
|
|
FrameworkHelper::msTaskPaneURL, FrameworkHelper::msRightPaneURL));
|
|
|
|
// The master page controls.
|
|
nId = pToolPanel->AddControl (
|
|
controls::MasterPagesPanel::CreateControlFactory(rBase),
|
|
SdResId(STR_TASKPANEL_MASTER_PAGE_TITLE),
|
|
HID_SD_SLIDE_DESIGNS,
|
|
ResourceActivationClickHandler(
|
|
pFrameworkHelper,
|
|
pFrameworkHelper->CreateResourceId(
|
|
FrameworkHelper::msMasterPagesTaskPanelURL, xTaskPaneId),
|
|
pToolPanel->GetControlContainer()));
|
|
AddPanel (nId, PID_MASTER_PAGES);
|
|
|
|
// Layout Menu.
|
|
nId = pToolPanel->AddControl (
|
|
LayoutMenu::CreateControlFactory(rBase, *pDocument->GetDocSh()),
|
|
SdResId(STR_TASKPANEL_LAYOUT_MENU_TITLE),
|
|
HID_SD_SLIDE_LAYOUTS,
|
|
ResourceActivationClickHandler(
|
|
pFrameworkHelper,
|
|
pFrameworkHelper->CreateResourceId(
|
|
FrameworkHelper::msLayoutTaskPanelURL, xTaskPaneId),
|
|
pToolPanel->GetControlContainer()));
|
|
AddPanel (nId, PID_LAYOUT);
|
|
nIdOfControlToExpand = nId;
|
|
|
|
{
|
|
DummyControl aControl (pToolPanel, SdResId(RID_CUSTOMANIMATION_START+0));
|
|
|
|
// CustomAnimationPanel
|
|
nId = pToolPanel->AddControl (
|
|
controls::CustomAnimationPanel::CreateControlFactory(rBase),
|
|
aControl.GetText(),
|
|
HID_SD_CUSTOM_ANIMATIONS,
|
|
ResourceActivationClickHandler(
|
|
pFrameworkHelper,
|
|
pFrameworkHelper->CreateResourceId(
|
|
FrameworkHelper::msCustomAnimationTaskPanelURL, xTaskPaneId),
|
|
pToolPanel->GetControlContainer()));
|
|
AddPanel (nId, PID_CUSTOM_ANIMATION);
|
|
}
|
|
|
|
// SlideTransitionPanel
|
|
{
|
|
DummyControl aControl (pToolPanel, SdResId(RID_CUSTOMANIMATION_START+3));
|
|
|
|
nId = pToolPanel->AddControl (
|
|
controls::SlideTransitionPanel::CreateControlFactory(rBase),
|
|
aControl.GetText(),
|
|
HID_SD_SLIDE_TRANSITIONS,
|
|
ResourceActivationClickHandler(
|
|
pFrameworkHelper,
|
|
pFrameworkHelper->CreateResourceId(
|
|
FrameworkHelper::msSlideTransitionTaskPanelURL, xTaskPaneId),
|
|
pToolPanel->GetControlContainer()));
|
|
AddPanel (nId, PID_SLIDE_TRANSITION);
|
|
}
|
|
|
|
#ifdef SHOW_COLOR_MENU
|
|
// Test Menu.
|
|
pToolPanel->AddControl (
|
|
ColorMenu::CreateControlFactory(),
|
|
String::CreateFromAscii ("Color Test Menu"),
|
|
0);
|
|
#endif
|
|
|
|
#ifdef SHOW_TEST_PANEL
|
|
// Test Panel.
|
|
pToolPanel->AddControl (
|
|
TestPanel::CreateControlFactory(),
|
|
String::CreateFromAscii ("Test Panel"),
|
|
0);
|
|
#endif
|
|
|
|
#ifdef USE_SLIDE_SORTER_CACHE_DISPLAY
|
|
pToolPanel->AddControl (
|
|
SlideSorterCacheDisplay::CreateControlFactory(pDocument),
|
|
String::CreateFromAscii("Slide Sorter Cache Status"),
|
|
0);
|
|
#endif
|
|
|
|
// Expand the layout menu.
|
|
pToolPanel->GetControlContainer().SetExpansionState (
|
|
nIdOfControlToExpand,
|
|
ControlContainer::ES_EXPAND);
|
|
|
|
pToolPanel->GetWindow()->Show();
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::Initialize (void)
|
|
{
|
|
if ( ! mbIsInitialized)
|
|
{
|
|
mbIsInitialized = true;
|
|
mpImpl->Setup (mpTaskPane.get(), GetViewShellBase());
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
TaskPaneViewShell::TaskPaneViewShell (
|
|
SfxViewFrame* pFrame,
|
|
ViewShellBase& rViewShellBase,
|
|
::Window* pParentWindow,
|
|
FrameView* pFrameViewArgument)
|
|
: ViewShell (pFrame, pParentWindow, rViewShellBase),
|
|
mpImpl(NULL),
|
|
mpTaskPane(NULL),
|
|
mbIsInitialized(false),
|
|
mpSubShellManager(),
|
|
mnMenuId(0)
|
|
{
|
|
meShellType = ST_TASK_PANE;
|
|
|
|
mpImpl.reset (new Implementation());
|
|
|
|
mpContentWindow->SetCenterAllowed (false);
|
|
|
|
mpTaskPane = ::std::auto_ptr<ToolPanel>(new ToolPanel (
|
|
mpContentWindow.get(), *this));
|
|
|
|
GetParentWindow()->SetBackground(Wallpaper());
|
|
mpContentWindow->SetBackground(Wallpaper());
|
|
|
|
GetParentWindow()->SetHelpId(HID_SD_TASK_PANE);
|
|
|
|
PaneDockingWindow* pDockingWindow = dynamic_cast<PaneDockingWindow*>(GetDockingWindow());
|
|
if (pDockingWindow != NULL)
|
|
{
|
|
pDockingWindow->InitializeTitleToolBox();
|
|
mnMenuId = pDockingWindow->AddMenu (
|
|
String(SdResId(STR_TASKPANEL_MASTER_PAGE_MENU_TITLE)),
|
|
HID_SD_TASK_PANE_VIEW_MENU,
|
|
LINK(this, TaskPaneViewShell, ToolboxClickHandler));
|
|
}
|
|
|
|
// Tell the focus manager that we want to pass the focus to our
|
|
// child.
|
|
FocusManager::Instance().RegisterDownLink(pParentWindow, mpTaskPane.get());
|
|
|
|
SetPool (&GetDoc()->GetPool());
|
|
|
|
if (pFrameViewArgument != NULL)
|
|
mpFrameView = pFrameViewArgument;
|
|
else
|
|
mpFrameView = new FrameView(GetDoc());
|
|
GetFrameView()->Connect();
|
|
|
|
// Hide or delete unused controls that we have inherited from the
|
|
// ViewShell base class.
|
|
mpHorizontalScrollBar.reset();
|
|
mpVerticalScrollBar.reset();
|
|
mpScrollBarBox.reset();
|
|
mpHorizontalRuler.reset();
|
|
mpVerticalRuler.reset();
|
|
|
|
SetName (String (RTL_CONSTASCII_USTRINGPARAM("TaskPaneViewShell")));
|
|
|
|
// For accessibility we have to shortly hide the content window. This
|
|
// triggers the construction of a new accessibility object for the new
|
|
// view shell. (One is created earlier while the construtor of the base
|
|
// class is executed. At that time the correct accessibility object can
|
|
// not be constructed.)
|
|
if (mpContentWindow.get() !=NULL)
|
|
{
|
|
mpContentWindow->Hide();
|
|
mpContentWindow->Show();
|
|
}
|
|
|
|
// Register the shell manager as factory at the ViewShellManager.
|
|
mpSubShellManager.reset (new TaskPaneShellManager(
|
|
GetViewShellBase().GetViewShellManager(),
|
|
*this));
|
|
GetViewShellBase().GetViewShellManager().AddSubShellFactory(this, mpSubShellManager);
|
|
}
|
|
|
|
|
|
|
|
|
|
TaskPaneViewShell::~TaskPaneViewShell (void)
|
|
{
|
|
GetViewShellBase().GetViewShellManager().RemoveSubShellFactory(this, mpSubShellManager);
|
|
}
|
|
|
|
|
|
|
|
// static
|
|
void TaskPaneViewShell::RegisterControls (void)
|
|
{
|
|
SfxModule* pModule = SD_MOD();
|
|
controls::MasterPagesSelector::RegisterInterface (pModule);
|
|
LayoutMenu::RegisterInterface (pModule);
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::ArrangeGUIElements (void)
|
|
{
|
|
ViewShell::ArrangeGUIElements();
|
|
|
|
Point aOrigin (maViewPos);
|
|
Size aSize (maViewSize);
|
|
|
|
Initialize();
|
|
|
|
// Place the task pane.
|
|
if (mpTaskPane.get() != NULL)
|
|
mpTaskPane->SetPosSizePixel (Point(0,0), aSize);
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::GetFocus (void)
|
|
{
|
|
Invalidate ();
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::LoseFocus (void)
|
|
{
|
|
Invalidate ();
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::KeyInput (const KeyEvent& rEvent)
|
|
{
|
|
KeyCode nCode = rEvent.GetKeyCode();
|
|
if (nCode == KEY_RETURN)
|
|
{
|
|
mpTaskPane->GrabFocus();
|
|
}
|
|
else
|
|
ViewShell::KeyInput (rEvent, NULL);
|
|
}
|
|
|
|
|
|
|
|
|
|
IMPL_LINK(TaskPaneViewShell, ToolboxClickHandler, ToolBox*, pToolBox)
|
|
{
|
|
if (pToolBox->GetCurItemId() == mnMenuId)
|
|
{
|
|
pToolBox->EndSelection();
|
|
|
|
DockingWindow* pDockingWindow = GetDockingWindow();
|
|
::std::auto_ptr<PopupMenu> pMenu = CreatePopupMenu (
|
|
pDockingWindow!=NULL && !pDockingWindow->IsFloatingMode());
|
|
pMenu->SetSelectHdl (
|
|
LINK(this, TaskPaneViewShell, MenuSelectHandler));
|
|
|
|
// pass toolbox button rect so the menu can stay open on button up
|
|
Rectangle aRect = pToolBox->GetItemRect(mnMenuId);
|
|
aRect.SetPos(pToolBox->GetPosPixel() );
|
|
pMenu->Execute (pDockingWindow, aRect, POPUPMENU_EXECUTE_DOWN);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
|
|
IMPL_LINK(TaskPaneViewShell, MenuSelectHandler, Menu*, pMenu)
|
|
{
|
|
if (pMenu)
|
|
{
|
|
pMenu->Deactivate();
|
|
switch (pMenu->GetCurItemId())
|
|
{
|
|
case MID_UNLOCK_TASK_PANEL:
|
|
{
|
|
DockingWindow* pDockingWindow = GetDockingWindow();
|
|
if (pDockingWindow != NULL)
|
|
pDockingWindow->SetFloatingMode (TRUE);
|
|
}
|
|
break;
|
|
|
|
case MID_LOCK_TASK_PANEL:
|
|
{
|
|
DockingWindow* pDockingWindow = GetDockingWindow();
|
|
if (pDockingWindow != NULL)
|
|
pDockingWindow->SetFloatingMode (FALSE);
|
|
}
|
|
break;
|
|
|
|
case MID_CUSTOMIZE:
|
|
DBG_ASSERT (0, "Customization not yet implemented");
|
|
break;
|
|
|
|
default:
|
|
{
|
|
sal_uInt32 nIndex (pMenu->GetUserValue(pMenu->GetCurItemId()));
|
|
mpTaskPane->GetControlContainer().SetVisibilityState (
|
|
nIndex,
|
|
ControlContainer::VS_TOGGLE);
|
|
// mpTaskPane->Resize();
|
|
// mpTaskPane->Invalidate();
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
|
|
::std::auto_ptr<PopupMenu> TaskPaneViewShell::CreatePopupMenu (
|
|
bool bIsDocking)
|
|
{
|
|
::std::auto_ptr<PopupMenu> pMenu (new PopupMenu ());
|
|
FloatingWindow* pFloat = static_cast<FloatingWindow*>(pMenu->GetWindow());
|
|
if (pFloat != NULL)
|
|
{
|
|
pFloat->SetPopupModeFlags (
|
|
pFloat->GetPopupModeFlags()
|
|
| FLOATWIN_POPUPMODE_NOMOUSEUPCLOSE);
|
|
}
|
|
|
|
// warning free code changes:
|
|
// FLOATWIN_POPUPMODE_NOMOUSEUPCLOSE is 0x10000, so cast to USHORT is 0
|
|
// so why was this used anyway?
|
|
pMenu->SetMenuFlags (
|
|
pMenu->GetMenuFlags() /* | (USHORT)FLOATWIN_POPUPMODE_NOMOUSEUPCLOSE */ );
|
|
|
|
// Add one entry for every tool panel element to individually make
|
|
// them visible or hide them.
|
|
USHORT nIndex = MID_FIRST_CONTROL;
|
|
sal_uInt32 nControlIndex;
|
|
ControlContainer& rContainer (mpTaskPane->GetControlContainer());
|
|
for (nControlIndex=0;
|
|
nControlIndex<rContainer.GetControlCount();
|
|
nControlIndex=rContainer.GetNextIndex(nControlIndex,true,false))
|
|
{
|
|
TreeNode* pChild = rContainer.GetControl(nControlIndex);
|
|
TitledControl* pControl
|
|
= static_cast<TitledControl*>(pChild->GetWindow());
|
|
pMenu->InsertItem (nIndex,
|
|
pControl->GetTitle(),
|
|
MIB_CHECKABLE);
|
|
pMenu->SetUserValue (nIndex, nControlIndex);
|
|
if (pControl->IsVisible())
|
|
pMenu->CheckItem (nIndex, TRUE);
|
|
nIndex++;
|
|
}
|
|
|
|
pMenu->InsertSeparator ();
|
|
|
|
// Add entry for docking or un-docking the tool panel.
|
|
if (bIsDocking)
|
|
pMenu->InsertItem (
|
|
MID_UNLOCK_TASK_PANEL,
|
|
String(SdResId(STR_TASKPANEL_MASTER_PAGE_MENU_UNLOCK)));
|
|
else
|
|
pMenu->InsertItem (
|
|
MID_LOCK_TASK_PANEL,
|
|
String(SdResId(STR_TASKPANEL_MASTER_PAGE_MENU_LOCK)));
|
|
pMenu->RemoveDisabledEntries (FALSE, FALSE);
|
|
|
|
return pMenu;
|
|
}
|
|
|
|
|
|
|
|
|
|
SdPage* TaskPaneViewShell::GetActualPage (void)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
SdPage* TaskPaneViewShell::getCurrentPage(void) const
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
|
|
|
|
void TaskPaneViewShell::Execute (SfxRequest& )
|
|
{
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::GetState (SfxItemSet& rItemSet)
|
|
{
|
|
(void)rItemSet;
|
|
}
|
|
|
|
|
|
|
|
|
|
TaskPaneShellManager& TaskPaneViewShell::GetSubShellManager (void) const
|
|
{
|
|
return *mpSubShellManager.get();
|
|
}
|
|
|
|
|
|
|
|
|
|
DockingWindow* TaskPaneViewShell::GetDockingWindow (void)
|
|
{
|
|
::Window* pParentWindow = GetParentWindow();
|
|
DockingWindow* pDockingWindow = NULL;
|
|
while (pParentWindow!=NULL && pDockingWindow==NULL)
|
|
{
|
|
pDockingWindow = dynamic_cast<DockingWindow*>(pParentWindow);
|
|
pParentWindow = pParentWindow->GetParent();
|
|
}
|
|
return pDockingWindow;
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::ShowPanel (PanelId nPublicId)
|
|
{
|
|
Initialize();
|
|
sal_uInt32 nId (mpImpl->GetInternalId (nPublicId));
|
|
if (nId != Implementation::mnInvalidId)
|
|
{
|
|
// First make the control visible. At least its title bar is then
|
|
// visible.
|
|
mpTaskPane->GetControlContainer().SetVisibilityState (
|
|
nId,
|
|
ControlContainer::VS_SHOW);
|
|
|
|
// Now expand it so that the whole control becomes visible.
|
|
mpTaskPane->GetControlContainer().SetExpansionState (
|
|
nId,
|
|
ControlContainer::ES_EXPAND);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
::com::sun::star::uno::Reference<
|
|
::com::sun::star::accessibility::XAccessible>
|
|
TaskPaneViewShell::CreateAccessibleDocumentView (::sd::Window* pWindow)
|
|
{
|
|
::com::sun::star::uno::Reference<
|
|
::com::sun::star::accessibility::XAccessible> xAccessible;
|
|
|
|
if (mpTaskPane.get()!=NULL && pWindow!=NULL)
|
|
{
|
|
// We have to call CreateAccessible directly so that we can specify
|
|
// the correct accessible parent.
|
|
::Window* pParentWindow = pWindow->GetAccessibleParentWindow();
|
|
if (pParentWindow != NULL)
|
|
xAccessible = mpTaskPane->CreateAccessibleObject(
|
|
pParentWindow->GetAccessible());
|
|
}
|
|
|
|
return xAccessible;
|
|
}
|
|
|
|
|
|
|
|
|
|
::std::auto_ptr<DrawSubController> TaskPaneViewShell::CreateSubController (void)
|
|
{
|
|
// This view shell is not designed to be the main view shell and thus
|
|
// does not support a UNO controller.
|
|
return ::std::auto_ptr<DrawSubController>();
|
|
}
|
|
|
|
|
|
|
|
|
|
bool TaskPaneViewShell::RelocateToParentWindow (::Window* pParentWindow)
|
|
{
|
|
::Window* pOldParentWindow = GetParentWindow();
|
|
FocusManager::Instance().RemoveLinks(pOldParentWindow, mpTaskPane.get());
|
|
FocusManager::Instance().RemoveLinks(mpTaskPane.get(), pOldParentWindow);
|
|
|
|
ViewShell::RelocateToParentWindow(pParentWindow);
|
|
|
|
PaneDockingWindow* pDockingWindow = dynamic_cast<PaneDockingWindow*>(GetDockingWindow());
|
|
if (pDockingWindow != NULL)
|
|
{
|
|
pDockingWindow->InitializeTitleToolBox();
|
|
mnMenuId = pDockingWindow->AddMenu (
|
|
String(SdResId(STR_TASKPANEL_MASTER_PAGE_MENU_TITLE)),
|
|
HID_SD_TASK_PANE_VIEW_MENU,
|
|
LINK(this, TaskPaneViewShell, ToolboxClickHandler));
|
|
}
|
|
FocusManager::Instance().RegisterDownLink(pParentWindow, mpTaskPane.get());
|
|
|
|
Resize();
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
|
|
|
|
//===== TaskPaneViewShell::Implementation =====================================
|
|
|
|
TaskPaneViewShell::Implementation::Implementation (void)
|
|
: maIndexMap(
|
|
(InternalIdToPanelIdMap::size_type)PID__END,
|
|
PID_UNKNOWN)
|
|
{
|
|
}
|
|
|
|
|
|
|
|
|
|
TaskPaneViewShell::Implementation::~Implementation (void)
|
|
{
|
|
}
|
|
|
|
|
|
|
|
|
|
void TaskPaneViewShell::Implementation::AddPanel (
|
|
sal_uInt32 nInternalId,
|
|
PanelId nPublicId)
|
|
{
|
|
maIndexMap[nInternalId] = nPublicId;
|
|
}
|
|
|
|
|
|
|
|
|
|
TaskPaneViewShell::PanelId
|
|
TaskPaneViewShell::Implementation::GetPublicId (
|
|
sal_uInt32 nInternalId) const
|
|
{
|
|
if (nInternalId < maIndexMap.size())
|
|
return maIndexMap[nInternalId];
|
|
else
|
|
return PID_UNKNOWN;
|
|
}
|
|
|
|
|
|
|
|
|
|
sal_uInt32
|
|
TaskPaneViewShell::Implementation::GetInternalId (
|
|
TaskPaneViewShell::PanelId nPublicId) const
|
|
{
|
|
sal_uInt32 nId = mnInvalidId;
|
|
for (sal_uInt32 nI=0; nI<maIndexMap.size(); nI++)
|
|
if (maIndexMap[nI] == nPublicId)
|
|
{
|
|
nId = nI;
|
|
break;
|
|
}
|
|
|
|
return nId;
|
|
}
|
|
|
|
|
|
|
|
|
|
//===== PanelActivation =======================================================
|
|
|
|
PanelActivation::PanelActivation (ViewShellBase& rBase, TaskPaneViewShell::PanelId nPanelId)
|
|
: mrBase(rBase),
|
|
mnPanelId(nPanelId)
|
|
{
|
|
}
|
|
|
|
void PanelActivation::operator() (bool)
|
|
{
|
|
toolpanel::TaskPaneViewShell* pTaskPane
|
|
= dynamic_cast<toolpanel::TaskPaneViewShell*>(
|
|
framework::FrameworkHelper::Instance(mrBase)
|
|
->GetViewShell(framework::FrameworkHelper::msRightPaneURL).get());
|
|
if (pTaskPane != NULL)
|
|
pTaskPane->ShowPanel(mnPanelId);
|
|
}
|
|
|
|
|
|
|
|
|
|
//===== ResourceActivationClickHandler ========================================
|
|
|
|
ResourceActivationClickHandler::ResourceActivationClickHandler (
|
|
const ::boost::shared_ptr<FrameworkHelper>& rpFrameworkHelper,
|
|
const Reference<drawing::framework::XResourceId>& rxResourceId,
|
|
ControlContainer& rControlContainer)
|
|
: mpFrameworkHelper(rpFrameworkHelper),
|
|
mxResourceId(rxResourceId),
|
|
mrControlContainer(rControlContainer)
|
|
{
|
|
}
|
|
|
|
|
|
|
|
|
|
void ResourceActivationClickHandler::operator () (TitledControl& rTitledControl)
|
|
{
|
|
mrControlContainer.SetExpansionState (
|
|
&rTitledControl,
|
|
ControlContainer::ES_EXPAND);
|
|
mpFrameworkHelper->GetConfigurationController()->requestResourceActivation(
|
|
mxResourceId, drawing::framework::ResourceActivationMode_REPLACE);
|
|
}
|
|
|
|
|
|
} } // end of namespace ::sd::toolpanel
|