From 267c6f2ac71f92999e969232431ba04678e7437e Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 07:54:39 +0200 Subject: Adding upstream version 4:24.2.0. Signed-off-by: Daniel Baumann --- sfx2/source/sidebar/ControllerFactory.cxx | 251 ++++++++++++++++++++++++++++++ 1 file changed, 251 insertions(+) create mode 100644 sfx2/source/sidebar/ControllerFactory.cxx (limited to 'sfx2/source/sidebar/ControllerFactory.cxx') diff --git a/sfx2/source/sidebar/ControllerFactory.cxx b/sfx2/source/sidebar/ControllerFactory.cxx new file mode 100644 index 0000000000..cc453c53cd --- /dev/null +++ b/sfx2/source/sidebar/ControllerFactory.cxx @@ -0,0 +1,251 @@ +/* -*- 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/. + * + * This file incorporates work covered by the following license notice: + * + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed + * with this work for additional information regarding copyright + * ownership. The ASF licenses this file to you under the Apache + * License, Version 2.0 (the "License"); you may not use this file + * except in compliance with the License. You may obtain a copy of + * the License at http://www.apache.org/licenses/LICENSE-2.0 . + */ + +#include +#include + +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +using namespace css; +using namespace css::uno; + +namespace sfx2::sidebar { + +Reference ControllerFactory::CreateImageController( + const Reference& rxFrame, + const Reference& rxParentWindow) +{ + rtl::Reference xController(new framework::ImageOrientationController( + comphelper::getProcessComponentContext(), rxFrame, rxParentWindow, + vcl::CommandInfoProvider::GetModuleIdentifier(rxFrame))); + + xController->update(); + return xController; +} + +Reference ControllerFactory::CreateToolBoxController( + ToolBox* pToolBox, + const ToolBoxItemId nItemId, + const OUString& rsCommandName, + const Reference& rxFrame, + const Reference& rxController, + const Reference& rxParentWindow, + const sal_Int32 nWidth, bool bSideBar) +{ + Reference xController ( + CreateToolBarController( + VCLUnoHelper::GetInterface(pToolBox), + rsCommandName, + rxFrame, rxController, + nWidth, bSideBar)); + + bool bFactoryHasController( xController.is() ); + + // Create a controller for the new item. + if ( !bFactoryHasController ) + { + xController = ::framework::CreateToolBoxController( + rxFrame, + pToolBox, + nItemId, + rsCommandName); + } + if ( ! xController.is()) + { + xController = new framework::GenericToolbarController( + ::comphelper::getProcessComponentContext(), + rxFrame, + pToolBox, + nItemId, + rsCommandName); + } + + // Initialize the controller with eg a service factory. + Reference xInitialization (xController, UNO_QUERY); + if (!bFactoryHasController && xInitialization.is()) + { + beans::PropertyValue aPropValue; + std::vector aPropertyVector; + + aPropValue.Name = "Frame"; + aPropValue.Value <<= rxFrame; + aPropertyVector.push_back(Any(aPropValue)); + + aPropValue.Name = "ServiceManager"; + aPropValue.Value <<= ::comphelper::getProcessServiceFactory(); + aPropertyVector.push_back(Any(aPropValue)); + + aPropValue.Name = "CommandURL"; + aPropValue.Value <<= rsCommandName; + aPropertyVector.push_back(Any(aPropValue)); + + Sequence aArgs (comphelper::containerToSequence(aPropertyVector)); + xInitialization->initialize(aArgs); + } + + if (xController.is()) + { + if (rxParentWindow.is()) + { + Reference xItemWindow (xController->createItemWindow(rxParentWindow)); + VclPtr pItemWindow = VCLUnoHelper::GetWindow(xItemWindow); + if (pItemWindow != nullptr) + { + WindowType nType = pItemWindow->GetType(); + if (nType == WindowType::LISTBOX || nType == WindowType::MULTILISTBOX || nType == WindowType::COMBOBOX) + pItemWindow->SetAccessibleName(pToolBox->GetItemText(nItemId)); + if (nWidth > 0) + pItemWindow->SetSizePixel(Size(nWidth, pItemWindow->GetSizePixel().Height())); + pToolBox->SetItemWindow(nItemId, pItemWindow); + } + } + + Reference xUpdatable (xController, UNO_QUERY); + if (xUpdatable.is()) + xUpdatable->update(); + + // Add tooltip. + if (xController.is()) + { + auto aProperties = vcl::CommandInfoProvider::GetCommandProperties(rsCommandName, + vcl::CommandInfoProvider::GetModuleIdentifier(rxFrame)); + const OUString sTooltip (vcl::CommandInfoProvider::GetTooltipForCommand( + rsCommandName, aProperties, rxFrame)); + if (pToolBox->GetQuickHelpText(nItemId).isEmpty()) + pToolBox->SetQuickHelpText(nItemId, sTooltip); + pToolBox->EnableItem(nItemId); + } + } + + return xController; +} + +Reference ControllerFactory::CreateToolBoxController( + weld::Toolbar& rToolbar, weld::Builder& rBuilder, + const OUString& rsCommandName, + const Reference& rxFrame, + const Reference& rxController, + bool bSideBar) +{ + css::uno::Reference xWidget(new weld::TransportAsXWindow(&rToolbar, &rBuilder)); + + Reference xController( + CreateToolBarController( + xWidget, + rsCommandName, + rxFrame, rxController, + -1, bSideBar)); + + if (!xController.is()) + { + xController = new framework::GenericToolbarController( + ::comphelper::getProcessComponentContext(), + rxFrame, + rToolbar, + rsCommandName); + } + + if (xController.is()) + { + xController->createItemWindow(xWidget); + + Reference xUpdatable(xController, UNO_QUERY); + if (xUpdatable.is()) + xUpdatable->update(); + } + + return xController; +} + + +Reference ControllerFactory::CreateToolBarController( + const Reference& rxToolbar, + const OUString& rsCommandName, + const Reference& rxFrame, + const Reference& rxController, + const sal_Int32 nWidth, bool bSideBar) +{ + try + { + Reference xContext = comphelper::getProcessComponentContext(); + Reference xFactory = frame::theToolbarControllerFactory::get( xContext ); + OUString sModuleName (Tools::GetModuleName(rxController)); + + if (xFactory.is() && xFactory->hasController(rsCommandName, sModuleName)) + { + beans::PropertyValue aPropValue; + std::vector aPropertyVector; + + aPropValue.Name = "ModuleIdentifier"; + aPropValue.Value <<= sModuleName; + aPropertyVector.push_back( Any( aPropValue )); + + aPropValue.Name = "Frame"; + aPropValue.Value <<= rxFrame; + aPropertyVector.push_back( Any( aPropValue )); + + aPropValue.Name = "ServiceManager"; + aPropValue.Value <<= comphelper::getProcessServiceFactory(); + aPropertyVector.push_back( Any( aPropValue )); + + aPropValue.Name = "ParentWindow"; + aPropValue.Value <<= rxToolbar; + aPropertyVector.push_back( Any( aPropValue )); + + aPropValue.Name = "IsSidebar"; + aPropValue.Value <<= bSideBar; + aPropertyVector.push_back( Any( aPropValue )); + + if (nWidth > 0) + { + aPropValue.Name = "Width"; + aPropValue.Value <<= nWidth; + aPropertyVector.push_back( Any( aPropValue )); + } + + Sequence aArgs (comphelper::containerToSequence(aPropertyVector)); + return Reference( + xFactory->createInstanceWithArgumentsAndContext( + rsCommandName, + aArgs, + xContext), + UNO_QUERY); + } + } + catch (Exception&) + { + // Ignore exception. + } + return nullptr; +} + +} // end of namespace sfx2::sidebar + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit v1.2.3