Kaydet (Commit) 5a2a266d authored tarafından Markus Mohrhard's avatar Markus Mohrhard

support more command in chart sidebar

We now have a complete toolbar controller in chart2.

Change-Id: I007d9b058e3d6800204ac035cc2aef5e93c1208b
üst 848f685a
...@@ -184,6 +184,7 @@ $(eval $(call gb_Library_add_exception_objects,chartcontroller,\ ...@@ -184,6 +184,7 @@ $(eval $(call gb_Library_add_exception_objects,chartcontroller,\
chart2/source/controller/main/SelectionHelper \ chart2/source/controller/main/SelectionHelper \
chart2/source/controller/main/ShapeController \ chart2/source/controller/main/ShapeController \
chart2/source/controller/main/StatusBarCommandDispatch \ chart2/source/controller/main/StatusBarCommandDispatch \
chart2/source/controller/main/ToolbarController \
chart2/source/controller/main/UndoActions \ chart2/source/controller/main/UndoActions \
chart2/source/controller/main/UndoCommandDispatch \ chart2/source/controller/main/UndoCommandDispatch \
chart2/source/controller/main/UndoGuard \ chart2/source/controller/main/UndoGuard \
......
...@@ -51,4 +51,8 @@ ...@@ -51,4 +51,8 @@
constructor="org_libreoffice_comp_chart2_sidebar_ChartPanelFactory"> constructor="org_libreoffice_comp_chart2_sidebar_ChartPanelFactory">
<service name="com.sun.star.ui.UIElementFactory"/> <service name="com.sun.star.ui.UIElementFactory"/>
</implementation> </implementation>
<implementation name="org.libreoffice.chart2.Chart2ToolboxController"
constructor="org_libreoffice_chart2_Chart2ToolboxController">
<service name="com.sun.star.frame.ToolbarContoller"/>
</implementation>
</component> </component>
/* -*- 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/.
*/
#ifndef INCLUDED_CHART2_SOURCE_CONTROLLER_INC_CHARTTOOLBARCONTROLLER_HXX
#define INCLUDED_CHART2_SOURCE_CONTROLLER_INC_CHARTTOOLBARCONTROLLER_HXX
#include <cppuhelper/compbase.hxx>
#include <cppuhelper/basemutex.hxx>
#include <com/sun/star/frame/XToolbarController.hpp>
#include <com/sun/star/frame/XStatusListener.hpp>
#include <com/sun/star/util/XUpdatable.hpp>
#include <com/sun/star/lang/XInitialization.hpp>
#include <com/sun/star/lang/XServiceInfo.hpp>
#include <com/sun/star/awt/XWindow.hpp>
#include <com/sun/star/frame/XFramesSupplier.hpp>
#include <boost/noncopyable.hpp>
namespace chart {
namespace {
typedef cppu::WeakComponentImplHelper<
css::frame::XToolbarController, css::frame::XStatusListener,
css::util::XUpdatable, css::lang::XInitialization,
css::lang::XServiceInfo> ChartToolbarControllerBase;
}
class ChartToolbarController : private boost::noncopyable,
private cppu::BaseMutex,
public ChartToolbarControllerBase
{
public:
ChartToolbarController(const css::uno::Sequence<css::uno::Any>& rProperties);
virtual ~ChartToolbarController();
// XToolbarContoller
virtual void SAL_CALL execute(sal_Int16 nKeyModifier)
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual void SAL_CALL click()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual void SAL_CALL doubleClick()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual css::uno::Reference<css::awt::XWindow> SAL_CALL createPopupWindow()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual css::uno::Reference<css::awt::XWindow> SAL_CALL
createItemWindow(const css::uno::Reference<css::awt::XWindow>& rParent)
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
// XServiceInfo
virtual OUString SAL_CALL getImplementationName()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual sal_Bool SAL_CALL supportsService(OUString const & ServiceName)
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
virtual css::uno::Sequence<OUString> SAL_CALL getSupportedServiceNames()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
// XStatusListener
virtual void SAL_CALL statusChanged(const css::frame::FeatureStateEvent& rEvent)
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
// XEventListener
virtual void SAL_CALL disposing(const css::lang::EventObject& rSource)
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
// XInitialization
virtual void SAL_CALL initialize(const css::uno::Sequence<css::uno::Any>& rAny)
throw (css::uno::Exception, std::exception) SAL_OVERRIDE;
// XUpdatable
virtual void SAL_CALL update()
throw (css::uno::RuntimeException, std::exception) SAL_OVERRIDE;
using cppu::WeakComponentImplHelperBase::disposing;
private:
css::uno::Reference<css::frame::XFramesSupplier> mxFramesSupplier;
};
}
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
/* -*- 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/.
*/
#include "ChartToolbarController.hxx"
#include <rtl/ref.hxx>
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#include <com/sun/star/lang/WrappedTargetRuntimeException.hpp>
#include <com/sun/star/uno/XComponentContext.hpp>
#include <com/sun/star/frame/XFrame.hpp>
#include <com/sun/star/frame/XDispatch.hpp>
#include <com/sun/star/frame/XController.hpp>
#include <com/sun/star/frame/XFramesSupplier.hpp>
#include <comphelper/namedvaluecollection.hxx>
#include <cppuhelper/supportsservice.hxx>
namespace chart {
ChartToolbarController::ChartToolbarController(const css::uno::Sequence<css::uno::Any>& rProperties):
ChartToolbarControllerBase(m_aMutex)
{
css::uno::Reference<css::frame::XFrame> xFrame;
sal_Int32 nLength = rProperties.getLength();
for (sal_Int32 i = 0; i < nLength; ++i)
{
css::beans::PropertyValue aPropValue;
rProperties[i] >>= aPropValue;
if (aPropValue.Name == "Frame")
aPropValue.Value >>= xFrame;
}
css::uno::Reference<css::frame::XFramesSupplier> xFramesSupplier(xFrame, css::uno::UNO_QUERY);
mxFramesSupplier = xFramesSupplier;
}
ChartToolbarController::~ChartToolbarController()
{
}
void ChartToolbarController::execute(sal_Int16 /*nKeyModifier*/)
throw (css::uno::RuntimeException, std::exception)
{
}
void ChartToolbarController::click()
throw (css::uno::RuntimeException, std::exception)
{
css::uno::Reference<css::frame::XFrame> xActiveFrame = mxFramesSupplier->getActiveFrame();
if (!xActiveFrame.is())
return;
css::uno::Reference<css::frame::XController> xActiveController = xActiveFrame->getController();
if (!xActiveController.is())
return;
css::uno::Reference<css::frame::XDispatch> xDispatch(xActiveController, css::uno::UNO_QUERY);
if (!xDispatch.is())
return;
css::util::URL aURL;
aURL.Path = "FormatSelection";
xDispatch->dispatch(aURL, css::uno::Sequence<css::beans::PropertyValue>());
}
void ChartToolbarController::doubleClick()
throw (css::uno::RuntimeException, std::exception)
{
SAL_INFO("chart2", "double clicked");
}
css::uno::Reference<css::awt::XWindow> ChartToolbarController::createPopupWindow()
throw (css::uno::RuntimeException, std::exception)
{
return css::uno::Reference<css::awt::XWindow>();
}
css::uno::Reference<css::awt::XWindow> ChartToolbarController::createItemWindow(
const css::uno::Reference<css::awt::XWindow>& /*rParent*/)
throw (css::uno::RuntimeException, std::exception)
{
return css::uno::Reference<css::awt::XWindow>();
}
void ChartToolbarController::statusChanged(const css::frame::FeatureStateEvent& /*rEvent*/)
throw (css::uno::RuntimeException, std::exception)
{
}
void ChartToolbarController::disposing(const css::lang::EventObject& /*rSource*/)
throw (css::uno::RuntimeException, std::exception)
{
}
void ChartToolbarController::initialize(const css::uno::Sequence<css::uno::Any>& /*rAny*/)
throw (css::uno::Exception, std::exception)
{
}
void ChartToolbarController::update()
throw (css::uno::RuntimeException, std::exception)
{
}
OUString ChartToolbarController::getImplementationName()
throw (css::uno::RuntimeException, std::exception)
{
return OUString("org.libreoffice.chart2.ChartToolbarController");
}
sal_Bool ChartToolbarController::supportsService(OUString const & ServiceName)
throw (css::uno::RuntimeException, std::exception)
{
return cppu::supportsService(this, ServiceName);
}
css::uno::Sequence<OUString> ChartToolbarController::getSupportedServiceNames()
throw (css::uno::RuntimeException, std::exception)
{
css::uno::Sequence<OUString> aServiceNames(1);
aServiceNames[0] = "com.sun.star.frame.ToolbarController";
return aServiceNames;
}
}
extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface* SAL_CALL
org_libreoffice_chart2_Chart2ToolboxController(css::uno::XComponentContext*, css::uno::Sequence<css::uno::Any> const & rProperties)
{
return cppu::acquire(new ::chart::ChartToolbarController(rProperties));
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
...@@ -39,6 +39,7 @@ public: ...@@ -39,6 +39,7 @@ public:
const sal_uInt16 nItemId, const sal_uInt16 nItemId,
const ::rtl::OUString& rsCommandName, const ::rtl::OUString& rsCommandName,
const css::uno::Reference<css::frame::XFrame>& rxFrame, const css::uno::Reference<css::frame::XFrame>& rxFrame,
const css::uno::Reference<css::frame::XController>& rxController,
const css::uno::Reference<css::awt::XWindow>& rxParentWindow, const css::uno::Reference<css::awt::XWindow>& rxParentWindow,
const sal_Int32 nItemWidth); const sal_Int32 nItemWidth);
...@@ -47,6 +48,7 @@ private: ...@@ -47,6 +48,7 @@ private:
ToolBox* pToolBox, ToolBox* pToolBox,
const ::rtl::OUString& rsCommandName, const ::rtl::OUString& rsCommandName,
const css::uno::Reference<css::frame::XFrame>& rxFrame, const css::uno::Reference<css::frame::XFrame>& rxFrame,
const css::uno::Reference<css::frame::XController>& rxController,
const sal_Int32 nWidth); const sal_Int32 nWidth);
}; };
......
...@@ -36,7 +36,8 @@ public: ...@@ -36,7 +36,8 @@ public:
virtual void dispose() SAL_OVERRIDE; virtual void dispose() SAL_OVERRIDE;
void SetMoreOptionsCommand(const OUString& rsCommandName, void SetMoreOptionsCommand(const OUString& rsCommandName,
const css::uno::Reference<css::frame::XFrame>& rxFrame); const css::uno::Reference<css::frame::XFrame>& rxFrame,
const css::uno::Reference<css::frame::XController>& rxController);
virtual void DataChanged(const DataChangedEvent& rEvent) SAL_OVERRIDE; virtual void DataChanged(const DataChangedEvent& rEvent) SAL_OVERRIDE;
virtual void MouseButtonDown(const MouseEvent& rMouseEvent) SAL_OVERRIDE; virtual void MouseButtonDown(const MouseEvent& rMouseEvent) SAL_OVERRIDE;
......
...@@ -475,6 +475,17 @@ ...@@ -475,6 +475,17 @@
<value>org.libreoffice.comp.dbu.LimitBoxController</value> <value>org.libreoffice.comp.dbu.LimitBoxController</value>
</prop> </prop>
</node> </node>
<node oor:name="ChartProperties" oor:op="replace">
<prop oor:name="Command">
<value>.uno:ChartProperties</value>
</prop>
<prop oor:name="Module">
<value>com.sun.star.chart2.ChartDocument</value>
</prop>
<prop oor:name="Controller">
<value>org.libreoffice.chart2.Chart2ToolboxController</value>
</prop>
</node>
<node oor:name="c2" oor:op="replace"> <node oor:name="c2" oor:op="replace">
<prop oor:name="Command"> <prop oor:name="Command">
<value>.uno:Refresh</value> <value>.uno:Refresh</value>
......
...@@ -1264,6 +1264,9 @@ ...@@ -1264,6 +1264,9 @@
<prop oor:name="DeckId" oor:type="xs:string"> <prop oor:name="DeckId" oor:type="xs:string">
<value>ChartDeck</value> <value>ChartDeck</value>
</prop> </prop>
<prop oor:name="DefaultMenuCommand">
<value>.uno:ChartProperties</value>
</prop>
<prop oor:name="ContextList"> <prop oor:name="ContextList">
<value oor:separator=";"> <value oor:separator=";">
Chart, Chart, visible ; Chart, Chart, visible ;
...@@ -1288,6 +1291,9 @@ ...@@ -1288,6 +1291,9 @@
<prop oor:name="DeckId" oor:type="xs:string"> <prop oor:name="DeckId" oor:type="xs:string">
<value>ChartDeck</value> <value>ChartDeck</value>
</prop> </prop>
<prop oor:name="DefaultMenuCommand">
<value>.uno:ChartProperties</value>
</prop>
<prop oor:name="ContextList"> <prop oor:name="ContextList">
<value oor:separator=";"> <value oor:separator=";">
Chart, any, visible ; Chart, any, visible ;
......
...@@ -42,6 +42,7 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBoxController( ...@@ -42,6 +42,7 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBoxController(
const sal_uInt16 nItemId, const sal_uInt16 nItemId,
const OUString& rsCommandName, const OUString& rsCommandName,
const Reference<frame::XFrame>& rxFrame, const Reference<frame::XFrame>& rxFrame,
const Reference<frame::XController>& rxController,
const Reference<awt::XWindow>& rxParentWindow, const Reference<awt::XWindow>& rxParentWindow,
const sal_Int32 nWidth) const sal_Int32 nWidth)
{ {
...@@ -49,7 +50,7 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBoxController( ...@@ -49,7 +50,7 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBoxController(
CreateToolBarController( CreateToolBarController(
pToolBox, pToolBox,
rsCommandName, rsCommandName,
rxFrame, rxFrame, rxController,
nWidth)); nWidth));
// Create a controller for the new item. // Create a controller for the new item.
...@@ -137,13 +138,14 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBarController( ...@@ -137,13 +138,14 @@ Reference<frame::XToolbarController> ControllerFactory::CreateToolBarController(
ToolBox* pToolBox, ToolBox* pToolBox,
const OUString& rsCommandName, const OUString& rsCommandName,
const Reference<frame::XFrame>& rxFrame, const Reference<frame::XFrame>& rxFrame,
const Reference<frame::XController>& rxController,
const sal_Int32 nWidth) const sal_Int32 nWidth)
{ {
try try
{ {
Reference<XComponentContext> xContext = comphelper::getProcessComponentContext(); Reference<XComponentContext> xContext = comphelper::getProcessComponentContext();
Reference<frame::XUIControllerFactory> xFactory = frame::theToolbarControllerFactory::get( xContext ); Reference<frame::XUIControllerFactory> xFactory = frame::theToolbarControllerFactory::get( xContext );
OUString sModuleName (Tools::GetModuleName(rxFrame->getController())); OUString sModuleName (Tools::GetModuleName(rxController));
if (xFactory.is() && xFactory->hasController(rsCommandName, sModuleName)) if (xFactory.is() && xFactory->hasController(rsCommandName, sModuleName))
{ {
......
...@@ -69,7 +69,8 @@ void PanelTitleBar::dispose() ...@@ -69,7 +69,8 @@ void PanelTitleBar::dispose()
} }
void PanelTitleBar::SetMoreOptionsCommand(const OUString& rsCommandName, void PanelTitleBar::SetMoreOptionsCommand(const OUString& rsCommandName,
const css::uno::Reference<css::frame::XFrame>& rxFrame) const css::uno::Reference<css::frame::XFrame>& rxFrame,
const css::uno::Reference<css::frame::XController>& rxController)
{ {
if (!rsCommandName.equals(msMoreOptionsCommand)) if (!rsCommandName.equals(msMoreOptionsCommand))
{ {
...@@ -89,7 +90,7 @@ void PanelTitleBar::SetMoreOptionsCommand(const OUString& rsCommandName, ...@@ -89,7 +90,7 @@ void PanelTitleBar::SetMoreOptionsCommand(const OUString& rsCommandName,
maToolBox.get(), maToolBox.get(),
mnMenuItemIndex, mnMenuItemIndex,
msMoreOptionsCommand, msMoreOptionsCommand,
rxFrame, rxFrame, rxController,
VCLUnoHelper::GetInterface(maToolBox.get()), VCLUnoHelper::GetInterface(maToolBox.get()),
0)); 0));
maToolBox->SetController(mnMenuItemIndex, xController, msMoreOptionsCommand); maToolBox->SetController(mnMenuItemIndex, xController, msMoreOptionsCommand);
......
...@@ -669,7 +669,7 @@ void SidebarController::SwitchToDeck ( ...@@ -669,7 +669,7 @@ void SidebarController::SwitchToDeck (
{ {
pTitleBar->SetMoreOptionsCommand( pTitleBar->SetMoreOptionsCommand(
rPanelContexDescriptor.msMenuCommand, rPanelContexDescriptor.msMenuCommand,
mxFrame); mxFrame, xController);
} }
++nWriteIndex; ++nWriteIndex;
......
...@@ -140,7 +140,7 @@ void SidebarToolBox::CreateController ( ...@@ -140,7 +140,7 @@ void SidebarToolBox::CreateController (
const OUString sCommandName (GetItemCommand(nItemId)); const OUString sCommandName (GetItemCommand(nItemId));
aDescriptor.mxController = sfx2::sidebar::ControllerFactory::CreateToolBoxController( aDescriptor.mxController = sfx2::sidebar::ControllerFactory::CreateToolBoxController(
this, nItemId, sCommandName, rxFrame, this, nItemId, sCommandName, rxFrame, rxFrame->getController(),
VCLUnoHelper::GetInterface(this), nItemWidth); VCLUnoHelper::GetInterface(this), nItemWidth);
if (aDescriptor.mxController.is()) if (aDescriptor.mxController.is())
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment