/* -*- 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 <config_features.h>
#include <com/sun/star/document/XEmbeddedScripts.hpp>
#include <com/sun/star/drawing/ModuleDispatcher.hpp>
#include <com/sun/star/embed/XStorage.hpp>
#include <com/sun/star/embed/ElementModes.hpp>
#include <com/sun/star/frame/Desktop.hpp>
#include <com/sun/star/frame/DispatchResultEvent.hpp>
#include <com/sun/star/frame/DispatchResultState.hpp>
#include <com/sun/star/frame/DispatchHelper.hpp>
#include <com/sun/star/frame/UnknownModuleException.hpp>
#include <com/sun/star/frame/XLayoutManager.hpp>
#include <com/sun/star/frame/XSynchronousFrameLoader.hpp>
#include <com/sun/star/sdbc/DriverManager.hpp>
#include <com/sun/star/system/SystemShellExecute.hpp>
#include <com/sun/star/system/SystemShellExecuteFlags.hpp>
#include <com/sun/star/system/SystemShellExecuteException.hpp>
#include <com/sun/star/task/XJobExecutor.hpp>
#include <com/sun/star/text/ModuleDispatcher.hpp>
#include <com/sun/star/task/OfficeRestartManager.hpp>
#include <com/sun/star/task/XInteractionHandler.hpp>
#include <com/sun/star/ui/dialogs/AddressBookSourcePilot.hpp>
#include <com/sun/star/ui/UIElementType.hpp>
#include <com/sun/star/ui/XUIElement.hpp>
#include <com/sun/star/uno/Reference.hxx>
#include <com/sun/star/util/XCloseable.hpp>
#include <com/sun/star/util/CloseVetoException.hpp>
#include <org/freedesktop/PackageKit/SyncDbusSessionHelper.hpp>
#include <comphelper/namedvaluecollection.hxx>
#include <comphelper/processfactory.hxx>
#include <comphelper/propertysequence.hxx>
#include <svtools/addresstemplate.hxx>
#include <svtools/miscopt.hxx>
#include <svtools/restartdialog.hxx>
#include <svl/visitem.hxx>
#include <unotools/intlwrapper.hxx>
#include <unotools/configmgr.hxx>
#include <tools/svlibrary.h>
#include <tools/diagnose_ex.h>
#include <vcl/sysdata.hxx>
#include <vcl/weld.hxx>
#include <svl/intitem.hxx>
#include <svl/eitem.hxx>
#include <svl/stritem.hxx>
#include <basic/sbstar.hxx>
#include <basic/basmgr.hxx>
#include <basic/basrdll.hxx>
#include <svtools/sfxecode.hxx>
#include <svtools/ehdl.hxx>
#include <vcl/help.hxx>
#include <vcl/stdtext.hxx>
#include <rtl/ustrbuf.hxx>
#include <sal/log.hxx>
#include <osl/file.hxx>
#include <vcl/EnumContext.hxx>
#include <unotools/pathoptions.hxx>
#include <unotools/moduleoptions.hxx>
#include <unotools/viewoptions.hxx>
#include <svtools/helpopt.hxx>
#include <toolkit/helper/vclunohelper.hxx>
#include <unotools/bootstrap.hxx>
#include <rtl/bootstrap.hxx>
#include <cppuhelper/exc_hlp.hxx>
#include <com/sun/star/frame/ModuleManager.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <sfx2/app.hxx>
#include <sfx2/request.hxx>
#include <sfx2/dispatch.hxx>
#include <sfx2/bindings.hxx>
#include <sfx2/msg.hxx>
#include <sfx2/objface.hxx>
#include <sfx2/objitem.hxx>
#include <sfx2/objsh.hxx>
#include <sfx2/hintpost.hxx>
#include <sfx2/viewsh.hxx>
#include <sfx2/docfac.hxx>
#include <sfx2/docfile.hxx>
#include <sfx2/docfilt.hxx>
#include <sfx2/new.hxx>
#include <sfxtypes.hxx>
#include <sfx2/tabdlg.hxx>
#include <arrdecl.hxx>
#include <sfx2/strings.hrc>
#include <sfx2/passwd.hxx>
#include <sfx2/sfxresid.hxx>
#include <sfx2/childwin.hxx>
#include <appdata.hxx>
#include <sfx2/minfitem.hxx>
#include <sfx2/event.hxx>
#include <sfx2/module.hxx>
#include <sfx2/viewfrm.hxx>
#include <sfxpicklist.hxx>
#include "imestatuswindow.hxx"
#include <sfx2/sfxdlg.hxx>
#include <sfx2/sfxsids.hrc>
#include <sorgitm.hxx>
#include <sfx2/sfxhelp.hxx>
#include <sfx2/zoomitem.hxx>
#include <sfx2/templatedlg.hxx>
#include <sfx2/sidebar/Sidebar.hxx>
#include <sfx2/notebookbar/SfxNotebookBar.hxx>
#include <sfx2/sidebar/SidebarController.hxx>
#include <sfx2/safemode.hxx>
#include <comphelper/types.hxx>
#include <officecfg/Office/Common.hxx>
#include <officecfg/Office/UI/ToolbarMode.hxx>
#include <unotools/confignode.hxx>
#include <officecfg/Setup.hxx>
#include <memory>
#include <openuriexternally.hxx>
using namespace ::com::sun::star;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::frame;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::util;
using namespace ::com::sun::star::script;
using namespace ::com::sun::star::system;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::document;
using namespace ::com::sun::star::ui;
namespace
{
OUString lcl_getAppName( vcl::EnumContext::Application eApp )
{
switch ( eApp )
{
case vcl::EnumContext::Application::Writer:
return OUString( "Writer" );
break;
case vcl::EnumContext::Application::Calc:
return OUString( "Calc" );
break;
case vcl::EnumContext::Application::Impress:
return OUString( "Impress" );
break;
case vcl::EnumContext::Application::Draw:
return OUString( "Draw" );
break;
case vcl::EnumContext::Application::Formula:
return OUString( "Formula" );
break;
case vcl::EnumContext::Application::Base:
return OUString( "Base" );
break;
default:
return OUString();
break;
}
}
// lp#527938, debian#602953, fdo#33266, i#105408
bool lcl_isBaseAvailable()
{
try
{
// if we get css::sdbc::DriverManager, libsdbc2 is there
// and the bibliography is assumed to work
return css::sdbc::DriverManager::create(comphelper::getProcessComponentContext()).is();
}
catch (Exception & e)
{
SAL_INFO("sfx.appl", "assuming Base to be missing; caught " << e);
return false;
}
}
void lcl_tryLoadBibliography()
{
// lp#527938, debian#602953, fdo#33266, i#105408
// make sure we actually can instantiate services from base first
if(!lcl_isBaseAvailable())
{
try
{
using namespace org::freedesktop::PackageKit;
using namespace svtools;
Reference< XSyncDbusSessionHelper > xSyncDbusSessionHelper(SyncDbusSessionHelper::create(comphelper::getProcessComponentContext()));
Sequence< OUString > vPackages { "libreoffice-base" };
xSyncDbusSessionHelper->InstallPackageNames(vPackages, OUString());
// Ill be back (hopefully)!
SolarMutexGuard aGuard;
executeRestartDialog(comphelper::getProcessComponentContext(), nullptr, RESTART_REASON_BIBLIOGRAPHY_INSTALL);
}
catch (const Exception & e)
{
SAL_INFO(
"sfx.appl",
"trying to install LibreOffice Base, caught " << e);
}
return;
}
try // fdo#48775
{
SfxStringItem aURL(SID_FILE_NAME, OUString(".component:Bibliography/View1"));
SfxStringItem aRef(SID_REFERER, OUString("private:user"));
SfxStringItem aTarget(SID_TARGETNAME, OUString("_blank"));
SfxViewFrame::Current()->GetDispatcher()->ExecuteList(SID_OPENDOC,
SfxCallMode::ASYNCHRON, { &aURL, &aRef, &aTarget });
}
catch (const Exception & e)
{
SAL_INFO( "sfx.appl",
"trying to load bibliography database, caught " << e);
}
}
}
/// Find the correct location of the document (LICENSE.fodt, etc.), and return
/// it in rURL if found.
static bool checkURL( const char *pName, const char *pExt, OUString &rURL )
{
using namespace osl;
DirectoryItem aDirItem;
#ifdef MACOSX
rURL = "$BRAND_BASE_DIR/Resources/" + OUString::createFromAscii( pName ) +
OUString::createFromAscii( pExt );
#else
rURL = "$BRAND_BASE_DIR/" + OUString::createFromAscii( pName ) +
OUString::createFromAscii( pExt );
#endif
rtl::Bootstrap::expandMacros( rURL );
if (!rURL.isEmpty())
return DirectoryItem::get( rURL, aDirItem ) == DirectoryItem::E_None;
else
return false;
}
/// Displays CREDITS or LICENSE in any of the available version
static void showDocument( const char* pBaseName )
{
try {
Reference < XDesktop2 > xDesktop = Desktop::create( ::comphelper::getProcessComponentContext() );
auto args(::comphelper::InitPropertySequence({
{"ViewOnly", makeAny(true)},
{"ReadOnly", makeAny(true)}
}));
OUString aURL;
if ( checkURL ( pBaseName, ".fodt", aURL ) ||
checkURL ( pBaseName, ".html", aURL ) ||
checkURL ( pBaseName, "", aURL ) ) {
xDesktop->loadComponentFromURL( aURL, "_blank", 0, args );
}
} catch (const css::uno::Exception &) {
}
}
namespace
{
Reference<XFrame> GetRequestFrame(const SfxRequest& rReq)
{
const SfxItemSet* pArgs = rReq.GetInternalArgs_Impl();
const SfxPoolItem* pItem = nullptr;
Reference <XFrame> xFrame;
if (pArgs && pArgs->GetItemState(SID_FILLFRAME, false, &pItem) == SfxItemState::SET)
{
OSL_ENSURE( dynamic_cast< const SfxUnoFrameItem *>( pItem ) != nullptr, "SfxApplication::OfaExec_Impl: XFrames are to be transported via SfxUnoFrameItem by now!" );
xFrame = static_cast< const SfxUnoFrameItem*>( pItem )->GetFrame();
}
return xFrame;
}
vcl::Window* getFrameWindow(const Reference<XFrame>& rFrame)
{
if (rFrame.is())
{
try
{
Reference< awt::XWindow > xContainerWindow(rFrame->getContainerWindow(), UNO_SET_THROW);
VclPtr<vcl::Window> pWindow = VCLUnoHelper::GetWindow(xContainerWindow);
return pWindow;
}
catch (const Exception&)
{
DBG_UNHANDLED_EXCEPTION("sfx.appl");
}
}
SAL_WARN( "sfx.appl", "no parent for dialogs" );
return nullptr;
}
class LicenseDialog : public weld::GenericDialogController
{
public:
LicenseDialog(weld::Window* pParent)
: GenericDialogController(pParent, "sfx/ui/licensedialog.ui", "LicenseDialog")
{
}
short execute()
{
short nRet = m_xDialog->run();
if (nRet == RET_OK)
showDocument("LICENSE");
return nRet;
}
};
class SafeModeQueryDialog : public weld::MessageDialogController
{
public:
SafeModeQueryDialog(weld::Window* pParent)
: MessageDialogController(pParent, "sfx/ui/safemodequerydialog.ui", "SafeModeQueryDialog")
{
}
short execute()
{
short nRet = m_xDialog->run();
if (nRet == RET_OK)
{
sfx2::SafeMode::putFlag();
uno::Reference< uno::XComponentContext > xContext = comphelper::getProcessComponentContext();
css::task::OfficeRestartManager::get(xContext)->requestRestart(
css::uno::Reference< css::task::XInteractionHandler >());
}
return nRet;
}
};
}
vcl::Window* SfxRequest::GetFrameWindow() const
{
return getFrameWindow(GetRequestFrame(*this));
}
weld::Window* SfxRequest::GetFrameWeld() const
{
vcl::Window* pWin = GetFrameWindow();
return pWin ? pWin->GetFrameWeld() : nullptr;
}
void SfxApplication::MiscExec_Impl( SfxRequest& rReq )
{
bool bDone = false;
switch ( rReq.GetSlot() )
{
case SID_SETOPTIONS:
{
if( rReq.GetArgs() )
SetOptions_Impl( *rReq.GetArgs() );
break;
}
case SID_QUITAPP:
case SID_LOGOUT:
{
// protect against reentrant calls
if ( pImpl->bInQuit )
return;
if ( rReq.GetSlot() == SID_LOGOUT )
{
for ( SfxObjectShell *pObjSh = SfxObjectShell::GetFirst();
pObjSh; pObjSh = SfxObjectShell::GetNext( *pObjSh ) )
{
if ( !pObjSh->IsModified() )
continue;
SfxViewFrame* pFrame = SfxViewFrame::GetFirst( pObjSh );
if ( !pFrame || !pFrame->GetWindow().IsReallyVisible() )
continue;
if (pObjSh->PrepareClose())
pObjSh->SetModified( false );
else
return;
}
SfxStringItem aNameItem( SID_FILE_NAME, OUString("vnd.sun.star.cmd:logout") );
SfxStringItem aReferer( SID_REFERER, "private/user" );
pImpl->pAppDispat->ExecuteList(SID_OPENDOC,
SfxCallMode::SLOT, { &aNameItem, &aReferer });
return;
}
// try from nested requests again after 100ms
if( Application::GetDispatchLevel() > 1 )
{
/* Don't save the request for closing the application and try it later
again. This is an UI bound functionality ... and the user will try it again
if the dialog is closed. But we should not close the application automatically
if this dialog is closed by the user ...
So we ignore this request now and wait for a new user decision.
*/
SAL_INFO("sfx.appl", "QueryExit => sal_False, DispatchLevel == " << Application::GetDispatchLevel() );
return;
}
// block reentrant calls
pImpl->bInQuit = true;
Reference < XDesktop2 > xDesktop = Desktop::create ( ::comphelper::getProcessComponentContext() );
rReq.ForgetAllArgs();
// if terminate() failed, pImpl->bInQuit will now be sal_False, allowing further calls of SID_QUITAPP
bool bTerminated = xDesktop->terminate();
if (!bTerminated)
// if terminate() was successful, SfxApplication is now dead!
pImpl->bInQuit = false;
// Set return value, terminate if possible
rReq.SetReturnValue( SfxBoolItem( rReq.GetSlot(), bTerminated ) );
return;
}
case SID_CONFIG:
case SID_TOOLBOXOPTIONS:
case SID_CONFIGSTATUSBAR:
case SID_CONFIGMENU:
case SID_CONFIGACCEL:
case SID_CONFIGEVENT:
{
SfxAbstractDialogFactory* pFact =
SfxAbstractDialogFactory::Create();
const SfxStringItem* pStringItem = rReq.GetArg<SfxStringItem>(SID_CONFIG);
SfxItemSet aSet(
GetPool(), svl::Items<SID_CONFIG, SID_CONFIG>{} );
if ( pStringItem )
{
aSet.Put( SfxStringItem(
SID_CONFIG, pStringItem->GetValue() ) );
}
Reference <XFrame> xFrame(GetRequestFrame(rReq));
ScopedVclPtr<SfxAbstractTabDialog> pDlg(pFact->CreateCustomizeTabDialog(
&aSet, xFrame ));
const short nRet = pDlg->Execute();
if ( nRet )
bDone = true;
break;
}
case SID_CLOSEDOCS:
{
Reference < XDesktop2 > xDesktop = Desktop::create( ::comphelper::getProcessComponentContext() );
Reference< XIndexAccess > xTasks( xDesktop->getFrames(), UNO_QUERY );
if ( !xTasks.is() )
break;
sal_Int32 n=0;
do
{
if ( xTasks->getCount() <= n )
break;
Any aAny = xTasks->getByIndex(n);
Reference < XCloseable > xTask;
aAny >>= xTask;
try
{
xTask->close(true);
n++;
}
catch( CloseVetoException& )
{
}
}
while( true );
bool bOk = ( n == 0);
rReq.SetReturnValue( SfxBoolItem( 0, bOk ) );
bDone = true;
break;
}
case SID_SAVEDOCS:
{
bool bOK = true;
for ( SfxObjectShell *pObjSh = SfxObjectShell::GetFirst();
pObjSh;
pObjSh = SfxObjectShell::GetNext( *pObjSh ) )
{
SfxRequest aReq( SID_SAVEDOC, SfxCallMode::SLOT, pObjSh->GetPool() );
if ( pObjSh->IsModified() )
{
pObjSh->ExecuteSlot( aReq );
const SfxBoolItem *pItem = dynamic_cast<const SfxBoolItem*>( aReq.GetReturnValue() );
if ( !pItem || !pItem->GetValue() )
bOK = false;
}
}
rReq.SetReturnValue( SfxBoolItem( 0, bOK ) );
rReq.Done();
break;
}
case SID_SEND_FEEDBACK:
{
OUString module = SfxHelp::GetCurrentModuleIdentifier();
OUString sURL("https://hub.libreoffice.org/send-feedback/?LOversion=" + utl::ConfigManager::getAboutBoxProductVersion() +
"&LOlocale=" + utl::ConfigManager::getLocale() + "&LOmodule=" + module.copy(module.lastIndexOf('.') + 1 ) );
sfx2::openUriExternally(sURL, false);
break;
}
case SID_Q_AND_A:
{
// Askbot has URL's normalized to languages, not locales
// Get language from locale: ll or lll or ll-CC or lll-CC
OUString sURL("https://hub.libreoffice.org/forum/?LOlocale=" + utl::ConfigManager::getLocale());
sfx2::openUriExternally(sURL, false);
break;
}
case SID_DOCUMENTATION:
{
// Open documentation page based on locales
OUString sURL("https://hub.libreoffice.org/documentation/?LOlocale=" + utl::ConfigManager::getLocale());
sfx2::openUriExternally(sURL, false);
break;
}
case SID_DONATION:
{
// Open donation page based on language + script (BCP47) with language as fall back.
OUString aLang = LanguageTag(utl::ConfigManager::getLocale()).getLanguage();
OUString aBcp47 = LanguageTag(utl::ConfigManager::getLocale()).getBcp47();
OUString sURL("https://hub.libreoffice.org/donation/?BCP47=" + aBcp47 + "&LOlang=" + aLang );
sfx2::openUriExternally(sURL, false);
break;
}
case SID_SHOW_LICENSE:
{
LicenseDialog aDialog(rReq.GetFrameWeld());
aDialog.execute();
break;
}
case SID_SHOW_CREDITS:
{
showDocument( "CREDITS" );
break;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
case SID_HELPINDEX:
{
Help* pHelp = Application::GetHelp();
if ( pHelp )
{
pHelp->Start(".uno:HelpIndex", static_cast<vcl::Window*>(nullptr)); // show start page
bDone = true;
}
break;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
case SID_HELPTIPS:
{
// Evaluate Parameter
const SfxBoolItem* pOnItem = rReq.GetArg<SfxBoolItem>(SID_HELPTIPS);
bool bOn = pOnItem
? pOnItem->GetValue()
: !Help::IsQuickHelpEnabled();
if ( bOn )
Help::EnableQuickHelp();
else
Help::DisableQuickHelp();
SvtHelpOptions().SetHelpTips( bOn );
Invalidate(SID_HELPTIPS);
bDone = true;
// Record if possible
if ( !rReq.IsAPI() )
rReq.AppendItem( SfxBoolItem( SID_HELPTIPS, bOn) );
break;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
case SID_EXTENDEDHELP:
{
Help::StartExtHelp();
break;
}
case SID_HELPBALLOONS:
{
// Evaluate Parameter
const SfxBoolItem* pOnItem = rReq.GetArg<SfxBoolItem>(SID_HELPBALLOONS);
bool bOn = pOnItem
? pOnItem->GetValue()
: !Help::IsBalloonHelpEnabled();
if ( bOn )
Help::EnableBalloonHelp();
else
Help::DisableBalloonHelp();
SvtHelpOptions().SetExtendedHelp( bOn );
Invalidate(SID_HELPBALLOONS);
bDone = true;
// Record if possible
if ( !rReq.IsAPI() )
rReq.AppendItem( SfxBoolItem( SID_HELPBALLOONS, bOn) );
break;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
case SID_ABOUT:
{
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
ScopedVclPtr<VclAbstractDialog> pDlg(pFact->CreateVclDialog( nullptr, SID_ABOUT ));
pDlg->Execute();
bDone = true;
break;
}
case SID_TEMPLATE_MANAGER:
{
ScopedVclPtrInstance< SfxTemplateManagerDlg > dlg;
dlg->Execute();
bDone = true;
break;
}
case SID_TEMPLATE_ADDRESSBOKSOURCE:
{
ScopedVclPtrInstance< svt::AddressBookSourceDialog > aDialog(GetTopWindow(), ::comphelper::getProcessComponentContext());
aDialog->Execute();
bDone = true;
break;
}
#if HAVE_FEATURE_SCRIPTING
case SID_BASICSTOP:
StarBASIC::Stop();
break;
case SID_BASICBREAK :
BasicDLL::BasicBreak();
break;
#endif
case SID_SHOW_IME_STATUS_WINDOW:
if (sfx2::appl::ImeStatusWindow::canToggle())
{
const SfxBoolItem * pItem = rReq.GetArg<SfxBoolItem>(SID_SHOW_IME_STATUS_WINDOW);
bool bShow = pItem == nullptr
? !pImpl->m_xImeStatusWindow->isShowing()
: pItem->GetValue();
pImpl->m_xImeStatusWindow->show(bShow);
if (pItem == nullptr)
rReq.AppendItem(SfxBoolItem(SID_SHOW_IME_STATUS_WINDOW,
bShow));
}
bDone = true;
break;
case SID_ZOOM_50_PERCENT:
case SID_ZOOM_75_PERCENT:
case SID_ZOOM_100_PERCENT:
case SID_ZOOM_150_PERCENT:
case SID_ZOOM_200_PERCENT:
case SID_ZOOM_OPTIMAL:
case SID_ZOOM_ENTIRE_PAGE:
case SID_ZOOM_PAGE_WIDTH:
{
SfxObjectShell* pCurrentShell = SfxObjectShell::Current();
if (!pCurrentShell)
return;
// make sure aZoom is initialized with a proper value if SetType
// doesn't work
SvxZoomItem aZoom( SvxZoomType::PERCENT, 100 );
switch (rReq.GetSlot())
{
case SID_ZOOM_50_PERCENT:
aZoom.SetValue(50);
break;
case SID_ZOOM_75_PERCENT:
aZoom.SetValue(75);
break;
case SID_ZOOM_100_PERCENT:
aZoom.SetValue(100);
break;
case SID_ZOOM_150_PERCENT:
aZoom.SetValue(150);
break;
case SID_ZOOM_200_PERCENT:
aZoom.SetValue(200);
break;
case SID_ZOOM_OPTIMAL:
aZoom.SetType( SvxZoomType::OPTIMAL );
break;
case SID_ZOOM_ENTIRE_PAGE:
aZoom.SetType( SvxZoomType::WHOLEPAGE );
break;
case SID_ZOOM_PAGE_WIDTH:
aZoom.SetType( SvxZoomType::PAGEWIDTH );
break;
}
pCurrentShell->GetDispatcher()->ExecuteList(SID_ATTR_ZOOM, SfxCallMode::ASYNCHRON, { &aZoom });
break;
}
case SID_TOOLBAR_MODE:
{
const SfxStringItem* pModeName = rReq.GetArg<SfxStringItem>( SID_TOOLBAR_MODE );
if ( !pModeName )
{
bDone = true;
break;
}
OUString aNewName(pModeName->GetValue());
uno::Reference< uno::XComponentContext > xContext =
::comphelper::getProcessComponentContext();
// Get information about current frame and module
Reference<XFrame> xCurrentFrame;
vcl::EnumContext::Application eCurrentApp = vcl::EnumContext::Application::NONE;
OUString aCurrentMode;
SfxViewFrame* pViewFrame = SfxViewFrame::Current();
if( pViewFrame )
{
xCurrentFrame = pViewFrame->GetFrame().GetFrameInterface();
const Reference<frame::XModuleManager> xModuleManager = frame::ModuleManager::create( xContext );
eCurrentApp = vcl::EnumContext::GetApplicationEnum( xModuleManager->identify( xCurrentFrame ) );
OUStringBuffer aPath("org.openoffice.Office.UI.ToolbarMode/Applications/");
aPath.append( lcl_getAppName( eCurrentApp ) );
const utl::OConfigurationTreeRoot aAppNode(
xContext,
aPath.makeStringAndClear(),
true);
if ( !aAppNode.isValid() )
{
bDone = true;
break;
}
aCurrentMode = comphelper::getString( aAppNode.getNodeValue( "Active" ) );
if ( aCurrentMode == aNewName )
{
bDone = true;
break;
}
// Save new toolbar mode for a current module
aAppNode.setNodeValue( "Active", makeAny( aNewName ) );
aAppNode.commit();
}
// Apply settings for all frames
pViewFrame = SfxViewFrame::GetFirst();
while( pViewFrame )
{
Reference<XFrame> xFrame = pViewFrame->GetFrame().GetFrameInterface();
// We want to change mode only for a current app module, ignore other apps
const Reference<frame::XModuleManager> xModuleManager = frame::ModuleManager::create( xContext );
vcl::EnumContext::Application eApp = vcl::EnumContext::GetApplicationEnum( xModuleManager->identify( xFrame ) );
if ( eApp != eCurrentApp )
{
pViewFrame = SfxViewFrame::GetNext( *pViewFrame );
continue;
}
Reference<css::beans::XPropertySet> xPropSet( xFrame, UNO_QUERY );
Reference<css::frame::XLayoutManager> xLayoutManager;
if ( xPropSet.is() )
{
try
{
Any aValue = xPropSet->getPropertyValue( "LayoutManager" );
aValue >>= xLayoutManager;
}
catch ( const css::uno::RuntimeException& )
{
throw;
}
catch ( css::uno::Exception& )
{
}
}
if ( xLayoutManager.is() )
{
css::uno::Sequence<OUString> aMandatoryToolbars;
css::uno::Sequence<OUString> aUserToolbars;
std::vector<OUString> aBackupList;
OUString aSidebarMode;
OUStringBuffer aPath = OUStringBuffer( "org.openoffice.Office.UI.ToolbarMode/Applications/" );
aPath.append( lcl_getAppName( eApp ) );
aPath.append( "/Modes" );
// Read mode settings
const utl::OConfigurationTreeRoot aModesNode(
xContext,
aPath.makeStringAndClear(),
true);
if ( !aModesNode.isValid() )
{
bDone = true;
break;
}
const Sequence<OUString> aModeNodeNames( aModesNode.getNodeNames() );
const sal_Int32 nCount( aModeNodeNames.getLength() );
for ( sal_Int32 nReadIndex = 0; nReadIndex < nCount; ++nReadIndex )
{
const utl::OConfigurationNode aModeNode( aModesNode.openNode( aModeNodeNames[nReadIndex] ) );
if ( !aModeNode.isValid() )
continue;
OUString aCommandArg = comphelper::getString( aModeNode.getNodeValue( "CommandArg" ) );
if ( aCommandArg == aNewName )
{
aMandatoryToolbars = aModeNode.getNodeValue( "Toolbars" ).get< uno::Sequence<OUString> >();
aUserToolbars = aModeNode.getNodeValue( "UserToolbars" ).get< uno::Sequence<OUString> >();
aSidebarMode = comphelper::getString( aModeNode.getNodeValue( "Sidebar" ) );
break;
}
}
// Backup visible toolbar list and hide all toolbars
Sequence<Reference<XUIElement>> aUIElements = xLayoutManager->getElements();
for ( sal_Int32 i = 0; i < aUIElements.getLength(); i++ )
{
Reference< XUIElement > xUIElement( aUIElements[i] );
Reference< XPropertySet > xPropertySet( aUIElements[i], UNO_QUERY );
if ( xPropertySet.is() && xUIElement.is() )
{
try
{
OUString aResName;
sal_Int16 nType( -1 );
xPropertySet->getPropertyValue( "Type" ) >>= nType;
xPropertySet->getPropertyValue( "ResourceURL" ) >>= aResName;
if (( nType == css::ui::UIElementType::TOOLBAR ) &&
!aResName.isEmpty() )
{
if ( xLayoutManager->isElementVisible( aResName ) )
{
aBackupList.push_back( aResName );
}
xLayoutManager->hideElement( aResName );
}
}
catch ( const Exception& )
{
}
}
}
// Show toolbars
for ( OUString& rName : aMandatoryToolbars )
{
xLayoutManager->createElement( rName );
xLayoutManager->showElement( rName );
}
for ( OUString& rName : aUserToolbars )
{
xLayoutManager->createElement( rName );
xLayoutManager->showElement( rName );
}
// Sidebar
pViewFrame->ShowChildWindow( SID_SIDEBAR );
sfx2::sidebar::SidebarController* pSidebar =
sfx2::sidebar::SidebarController::GetSidebarControllerForFrame( xFrame );
if ( pSidebar )
{
if ( aSidebarMode == "Arrow" )
{
pSidebar->FadeOut();
}
else if ( aSidebarMode == "Tabs" )
{
pSidebar->FadeIn();
pSidebar->RequestOpenDeck();
pSidebar->RequestCloseDeck();
}
else if ( aSidebarMode == "Opened" )
{
pSidebar->FadeIn();
pSidebar->RequestOpenDeck();
}
}
// Show/Hide the Notebookbar
const SfxPoolItem* pItem;
pViewFrame->GetDispatcher()->QueryState( SID_NOTEBOOKBAR, pItem );
// Save settings
if ( pViewFrame == SfxViewFrame::Current() )
{
css::uno::Sequence<OUString> aBackup( aBackupList.size() );
for ( size_t i = 0; i < aBackupList.size(); ++i )
aBackup[i] = aBackupList[i];
for ( sal_Int32 nReadIndex = 0; nReadIndex < nCount; ++nReadIndex )
{
const utl::OConfigurationNode aModeNode( aModesNode.openNode( aModeNodeNames[nReadIndex] ) );
if ( !aModeNode.isValid() )
continue;
OUString aCommandArg = comphelper::getString( aModeNode.getNodeValue( "CommandArg" ) );
if ( aCommandArg == aCurrentMode )
{
aModeNode.setNodeValue( "UserToolbars", makeAny( aBackup ) );
break;
}
}
aModesNode.commit();
}
}
pViewFrame = SfxViewFrame::GetNext(*pViewFrame);
}
bDone = true;
break;
}
case SID_AVAILABLE_TOOLBARS:
{
const SfxStringItem* pToolbarName = rReq.GetArg<SfxStringItem>(SID_AVAILABLE_TOOLBARS);
if ( pToolbarName )
{
Reference < XDesktop2 > xDesktop = Desktop::create ( ::comphelper::getProcessComponentContext() );
Reference< XFrame > xFrame = xDesktop->getActiveFrame();
Reference< css::beans::XPropertySet > xPropSet( xFrame, UNO_QUERY );
Reference< css::frame::XLayoutManager > xLayoutManager;
if ( xPropSet.is() )
{
try
{
Any aValue = xPropSet->getPropertyValue("LayoutManager");
aValue >>= xLayoutManager;
}
catch ( const css::uno::RuntimeException& )
{
throw;
}
catch ( css::uno::Exception& )
{
}
}
if ( xLayoutManager.is() )
{
OUStringBuffer aBuf( "private:resource/toolbar/" );
aBuf.append( pToolbarName->GetValue() );
// Evaluate Parameter
OUString aToolbarName( aBuf.makeStringAndClear() );
bool bShow( !xLayoutManager->isElementVisible( aToolbarName ));
if ( bShow )
{
xLayoutManager->createElement( aToolbarName );
xLayoutManager->showElement( aToolbarName );
}
else
xLayoutManager->hideElement( aToolbarName );
}
}
bDone = true;
break;
}
case SID_MENUBAR:
{
sfx2::SfxNotebookBar::ToggleMenubar();
bDone = true;
break;
}
case SID_SAFE_MODE:
{
SafeModeQueryDialog aDialog(rReq.GetFrameWeld());
aDialog.execute();
break;
}
default:
break;
}
if ( bDone )
rReq.Done();
}
void SfxApplication::MiscState_Impl(SfxItemSet &rSet)
{
const sal_uInt16 *pRanges = rSet.GetRanges();
DBG_ASSERT(pRanges && *pRanges, "Set without range");
while ( *pRanges )
{
for(sal_uInt16 nWhich = *pRanges++; nWhich <= *pRanges; ++nWhich)
{
switch(nWhich)
{
case SID_TEMPLATE_ADDRESSBOKSOURCE:
if ( !SvtModuleOptions().IsModuleInstalled(SvtModuleOptions::EModule::DATABASE) )
rSet.Put(SfxVisibilityItem(nWhich, false));
break;
case SID_QUITAPP:
{
if ( pImpl->nDocModalMode )
rSet.DisableItem(nWhich);
else
rSet.Put(SfxStringItem(nWhich, SfxResId(STR_QUITAPP)));
break;
}
case SID_CONFIG:
case SID_TOOLBOXOPTIONS:
case SID_CONFIGSTATUSBAR:
case SID_CONFIGMENU:
case SID_CONFIGACCEL:
case SID_CONFIGEVENT:
{
if( SvtMiscOptions().DisableUICustomization() )
rSet.DisableItem(nWhich);
break;
}
#if HAVE_FEATURE_SCRIPTING
case SID_BASICSTOP:
if ( !StarBASIC::IsRunning() )
rSet.DisableItem(nWhich);
break;
#endif
case SID_HELPTIPS:
{
rSet.Put( SfxBoolItem( SID_HELPTIPS, Help::IsQuickHelpEnabled() ) );
}
break;
case SID_HELPBALLOONS:
{
rSet.Put( SfxBoolItem( SID_HELPBALLOONS, Help::IsBalloonHelpEnabled() ) );
}
break;
case SID_EXTENDEDHELP:
{
}
break;
case SID_CLOSEDOCS:
{
Reference < XDesktop2 > xDesktop = Desktop::create( ::comphelper::getProcessComponentContext() );
Reference< XIndexAccess > xTasks( xDesktop->getFrames(), UNO_QUERY );
if ( !xTasks.is() || !xTasks->getCount() )
rSet.DisableItem(nWhich);
break;
}
case SID_SAVEDOCS:
{
bool bModified = false;
for ( SfxObjectShell *pObjSh = SfxObjectShell::GetFirst();
pObjSh;
pObjSh = SfxObjectShell::GetNext( *pObjSh ) )
{
if ( pObjSh->IsModified() )
{
bModified = true;
break;
}
}
if ( !bModified )
rSet.DisableItem( nWhich );
break;
}
case SID_SHOW_IME_STATUS_WINDOW:
if (sfx2::appl::ImeStatusWindow::canToggle())
rSet.Put(SfxBoolItem(
SID_SHOW_IME_STATUS_WINDOW,
pImpl->m_xImeStatusWindow->
isShowing()));
else
rSet.DisableItem(SID_SHOW_IME_STATUS_WINDOW);
break;
case SID_TEMPLATE_MANAGER:
{
SvtMiscOptions aMiscOptions;
if ( !aMiscOptions.IsExperimentalMode() )
{
rSet.DisableItem( nWhich );
rSet.Put( SfxVisibilityItem( nWhich, false ) );
}
}
break;
case SID_ZOOM_50_PERCENT:
case SID_ZOOM_75_PERCENT:
case SID_ZOOM_100_PERCENT:
case SID_ZOOM_150_PERCENT:
case SID_ZOOM_200_PERCENT:
case SID_ZOOM_OPTIMAL:
case SID_ZOOM_ENTIRE_PAGE:
case SID_ZOOM_PAGE_WIDTH:
{
SfxObjectShell* pCurrentShell = SfxObjectShell::Current();
const SfxPoolItem *pItem;
SfxItemState aState = pCurrentShell ?
pCurrentShell->GetDispatcher()->QueryState(SID_ATTR_ZOOM, pItem) : SfxItemState::DISABLED;
if ( aState == SfxItemState::DISABLED )
rSet.DisableItem( nWhich );
}
break;
case SID_MENUBAR:
{
Reference < XDesktop2 > xDesktop = Desktop::create ( ::comphelper::getProcessComponentContext() );
Reference< XFrame > xFrame = xDesktop->getActiveFrame();
Reference< css::beans::XPropertySet > xPropSet( xFrame, UNO_QUERY );
Reference< css::frame::XLayoutManager > xLayoutManager;
if ( xPropSet.is() )
{
try
{
Any aValue = xPropSet->getPropertyValue("LayoutManager");
aValue >>= xLayoutManager;
}
catch ( const css::uno::RuntimeException& )
{
throw;
}
catch ( css::uno::Exception& )
{
}
}
if ( xLayoutManager.is() )
{
bool bState = true;
bState = xLayoutManager->getElement( "private:resource/menubar/menubar" ).is()
&& xLayoutManager->isElementVisible( "private:resource/menubar/menubar" );
SfxBoolItem aItem( SID_MENUBAR, bState );
rSet.Put( aItem );
}
break;
}
case SID_SAFE_MODE:
{
// no restart in safe mode when already in safe mode
if ( Application::IsSafeModeEnabled() )
rSet.DisableItem( SID_SAFE_MODE );
break;
}
default:
break;
}
}
++pRanges;
}
}
#if HAVE_FEATURE_SCRIPTING
#ifndef DISABLE_DYNLOADING
typedef rtl_uString* (*basicide_choose_macro)(void*, void*, sal_Bool);
extern "C" { static void thisModule() {} }
#else
extern "C" rtl_uString* basicide_choose_macro(void*, void*, sal_Bool);
#endif
OUString ChooseMacro( const Reference< XModel >& rxLimitToDocument, const Reference< XFrame >& xDocFrame, bool bChooseOnly )
{
#ifndef DISABLE_DYNLOADING
osl::Module aMod;
// load basctl module
aMod.loadRelative(&thisModule, SVLIBRARY("basctl"));
// get symbol
basicide_choose_macro pSymbol = reinterpret_cast<basicide_choose_macro>(aMod.getFunctionSymbol("basicide_choose_macro"));
SAL_WARN_IF(!pSymbol, "sfx.appl", "SfxApplication::MacroOrganizer, no symbol!");
if (!pSymbol)
return OUString();
aMod.release();
#else
#define pSymbol basicide_choose_macro
#endif
// call basicide_choose_macro in basctl
rtl_uString* pScriptURL = pSymbol( rxLimitToDocument.get(), xDocFrame.get(), bChooseOnly );
OUString aScriptURL( pScriptURL );
rtl_uString_release( pScriptURL );
return aScriptURL;
#ifdef DISABLE_DYNLOADING
#undef pSymbol
#endif
}
#endif
namespace
{
#if HAVE_FEATURE_SCRIPTING
vcl::Window* lcl_getDialogParent( const Reference< XFrame >& _rxFrame, vcl::Window* _pFallback )
{
if ( !_rxFrame.is() )
return _pFallback;
try
{
Reference< awt::XWindow > xContainerWindow( _rxFrame->getContainerWindow(), UNO_SET_THROW );
VclPtr<vcl::Window> pWindow = VCLUnoHelper::GetWindow( xContainerWindow );
OSL_ENSURE( pWindow, "lcl_getDialogParent: cool, somebody implemented a VCL-less toolkit!" );
if ( pWindow )
return pWindow->GetSystemWindow();
}
catch( const Exception& )
{
DBG_UNHANDLED_EXCEPTION("sfx.appl");
}
return _pFallback;
}
SfxViewFrame* lcl_getBasicIDEViewFrame( SfxObjectShell const * i_pBasicIDE )
{
SfxViewFrame* pView = SfxViewFrame::GetFirst( i_pBasicIDE );
while ( pView )
{
if ( pView->GetObjectShell()->GetFactory().GetDocumentServiceName() == "com.sun.star.script.BasicIDE" )
break;
pView = SfxViewFrame::GetNext( *pView, i_pBasicIDE );
}
return pView;
}
Reference< XFrame > lcl_findStartModuleFrame( const Reference<XComponentContext> & rxContext )
{
try
{
Reference < XDesktop2 > xDesktop = Desktop::create( rxContext );
Reference < XIndexAccess > xContainer( xDesktop->getFrames(), UNO_QUERY_THROW );
Reference< XModuleManager2 > xCheck = ModuleManager::create(rxContext);
sal_Int32 nCount = xContainer->getCount();
for ( sal_Int32 i=0; i<nCount; ++i )
{
try
{
Reference < XFrame > xFrame( xContainer->getByIndex(i), UNO_QUERY_THROW );
OUString sModule = xCheck->identify( xFrame );
if ( sModule == "com.sun.star.frame.StartModule" )
return xFrame;
}
catch( const UnknownModuleException& )
{
// silence
}
catch(const Exception&)
{
// re-throw, caught below
throw;
}
}
}
catch( const Exception& )
{
DBG_UNHANDLED_EXCEPTION("sfx.appl");
}
return nullptr;
}
#endif // HAVE_FEATURE_SCRIPTING
}
void SfxApplication::OfaExec_Impl( SfxRequest& rReq )
{
switch ( rReq.GetSlot() )
{
case SID_OPTIONS_TREEDIALOG:
{
OUString sPageURL;
const SfxStringItem* pURLItem = rReq.GetArg<SfxStringItem>(SID_OPTIONS_PAGEURL);
if ( pURLItem )
sPageURL = pURLItem->GetValue();
Reference <XFrame> xFrame(GetRequestFrame(rReq));
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
VclPtr<VclAbstractDialog> pDlg =
pFact->CreateFrameDialog(rReq.GetFrameWindow(), xFrame, rReq.GetSlot(), sPageURL );
short nRet = pDlg->Execute();
pDlg.disposeAndClear();
SfxViewFrame* pView = SfxViewFrame::GetFirst();
while ( pView )
{
if (nRet == RET_OK)
{
SfxObjectShell* pObjSh = pView->GetObjectShell();
if (pObjSh)
pObjSh->SetConfigOptionsChecked(false);
}
pView->GetBindings().InvalidateAll(false);
pView = SfxViewFrame::GetNext( *pView );
}
break;
}
case SID_MORE_DICTIONARIES:
{
try
{
uno::Reference< uno::XComponentContext > xContext =
::comphelper::getProcessComponentContext();
uno::Reference< css::system::XSystemShellExecute > xSystemShell(
css::system::SystemShellExecute::create(xContext) );
// read repository URL from configuration
OUString sTemplRepoURL(officecfg::Office::Common::Dictionaries::RepositoryURL::get());
if ( xSystemShell.is() && !sTemplRepoURL.isEmpty() )
{
OUStringBuffer aURLBuf( sTemplRepoURL );
aURLBuf.append("?lang=");
// read locale from configuration
OUString sLocale(officecfg::Setup::L10N::ooLocale::get());
if (sLocale.isEmpty())
sLocale = "en-US";
aURLBuf.append( sLocale );
xSystemShell->execute(
aURLBuf.makeStringAndClear(),
OUString(),
css::system::SystemShellExecuteFlags::URIS_ONLY );
}
}
catch( const css::uno::Exception& )
{
SAL_WARN( "sfx.appl", "SfxApplication::OfaExec_Impl(SID_MORE_DICTIONARIES): caught an exception!" );
}
break;
}
#if HAVE_FEATURE_SCRIPTING
case SID_BASICIDE_APPEAR:
{
SfxViewFrame* pView = lcl_getBasicIDEViewFrame( nullptr );
if ( !pView )
{
SfxObjectShell* pBasicIDE = SfxObjectShell::CreateObject( "com.sun.star.script.BasicIDE" );
pBasicIDE->DoInitNew();
pBasicIDE->SetModified( false );
try
{
// load the Basic IDE via direct access to the SFX frame loader. A generic loadComponentFromURL
// (which could be done via SfxViewFrame::LoadDocumentIntoFrame) is not feasible here, since the Basic IDE
// does not really play nice with the framework's concept. For instance, it is a "singleton document",
// which conflicts, at the latest, with the framework's concept of loading into _blank frames.
// So, since we know that our frame loader can handle it, we skip the generic framework loader
// mechanism, and the type detection (which doesn't know about the Basic IDE).
Reference< XComponentContext > xContext( ::comphelper::getProcessComponentContext() );
Reference< XSynchronousFrameLoader > xLoader(
xContext->getServiceManager()->createInstanceWithContext("com.sun.star.comp.office.FrameLoader", xContext),
UNO_QUERY_THROW );
::comphelper::NamedValueCollection aLoadArgs;
aLoadArgs.put( "Model", pBasicIDE->GetModel() );
aLoadArgs.put( "URL", OUString( "private:factory/sbasic" ) );
Reference< XFrame > xTargetFrame( lcl_findStartModuleFrame( xContext ) );
if ( !xTargetFrame.is() )
xTargetFrame = SfxFrame::CreateBlankFrame();
ENSURE_OR_THROW( xTargetFrame.is(), "could not obtain a frameto load the Basic IDE into!" );
xLoader->load( aLoadArgs.getPropertyValues(), xTargetFrame );
}
catch( const Exception& )
{
DBG_UNHANDLED_EXCEPTION("sfx.appl");
}
pView = lcl_getBasicIDEViewFrame( pBasicIDE );
if ( pView )
pView->SetName( "BASIC:1" );
}
if ( pView )
pView->GetFrame().Appear();
const SfxItemSet* pArgs = rReq.GetArgs();
if ( pArgs && pView )
{
SfxViewShell* pViewShell = pView->GetViewShell();
SfxObjectShell* pObjShell = pView->GetObjectShell();
if ( pViewShell && pObjShell )
{
SfxRequest aReq( SID_BASICIDE_SHOWWINDOW, SfxCallMode::SYNCHRON, pObjShell->GetPool() );
aReq.SetArgs( *pArgs );
pViewShell->ExecuteSlot( aReq );
}
}
rReq.Done();
}
break;
case SID_BASICCHOOSER:
{
const SfxItemSet* pArgs = rReq.GetArgs();
const SfxPoolItem* pItem;
bool bChooseOnly = false;
Reference< XModel > xLimitToModel;
if(pArgs && SfxItemState::SET == pArgs->GetItemState(SID_RECORDMACRO, false, &pItem) )
{
bool bRecord = static_cast<const SfxBoolItem*>(pItem)->GetValue();
if ( bRecord )
{
// !Hack
bChooseOnly = false;
SfxObjectShell* pCurrentShell = SfxObjectShell::Current();
OSL_ENSURE( pCurrentShell, "macro recording outside an SFX document?" );
if ( pCurrentShell )
xLimitToModel = pCurrentShell->GetModel();
}
}
Reference <XFrame> xFrame(GetRequestFrame(rReq));
rReq.SetReturnValue(SfxStringItem(rReq.GetSlot(), ChooseMacro(xLimitToModel, xFrame, bChooseOnly)));
rReq.Done();
}
break;
case SID_MACROORGANIZER:
{
SAL_INFO("sfx.appl", "handling SID_MACROORGANIZER");
const SfxItemSet* pArgs = rReq.GetArgs();
const SfxPoolItem* pItem;
sal_Int16 nTabId = 0;
if(pArgs && SfxItemState::SET == pArgs->GetItemState(SID_MACROORGANIZER, false, &pItem) )
{
nTabId = static_cast<const SfxUInt16Item*>(pItem)->GetValue();
}
SfxApplication::MacroOrganizer( nTabId );
rReq.Done();
}
break;
case SID_RUNMACRO:
{
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
SAL_INFO("sfx.appl", "SfxApplication::OfaExec_Impl: case ScriptOrg");
Reference <XFrame> xFrame(GetRequestFrame(rReq));
if ( !xFrame.is() )
{
const SfxViewFrame* pViewFrame = SfxViewFrame::Current();
if ( pViewFrame )
xFrame = pViewFrame->GetFrame().GetFrameInterface();
}
do // artificial loop for flow control
{
ScopedVclPtr<AbstractScriptSelectorDialog> pDlg(pFact->CreateScriptSelectorDialog(
lcl_getDialogParent( xFrame, GetTopWindow() ), xFrame ));
OSL_ENSURE( pDlg, "SfxApplication::OfaExec_Impl( SID_RUNMACRO ): no dialog!" );
if ( !pDlg )
break;
pDlg->SetRunLabel();
short nDialogResult = pDlg->Execute();
if ( !nDialogResult )
break;
Sequence< Any > args;
Sequence< sal_Int16 > outIndex;
Sequence< Any > outArgs;
Any ret;
Reference< XInterface > xScriptContext;
Reference< XController > xController;
if ( xFrame.is() )
xController = xFrame->getController();
if ( xController.is() )
xScriptContext = xController->getModel();
if ( !xScriptContext.is() )
xScriptContext = xController;
SfxObjectShell::CallXScript( xScriptContext, pDlg->GetScriptURL(), args, ret, outIndex, outArgs );
}
while ( false );
rReq.Done();
}
break;
case SID_SCRIPTORGANIZER:
{
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
SAL_INFO("sfx.appl", "SfxApplication::OfaExec_Impl: case ScriptOrg");
const SfxItemSet* pArgs = rReq.GetArgs();
const SfxPoolItem* pItem;
OUString aLanguage;
if(pArgs && SfxItemState::SET == pArgs->GetItemState(SID_SCRIPTORGANIZER, false, &pItem) )
{
aLanguage = static_cast<const SfxScriptOrganizerItem*>(pItem)->getLanguage();
}
OUString aLang( aLanguage );
SAL_INFO("sfx.appl", "SfxApplication::OfaExec_Impl: about to create dialog for: " << aLang);
// not sure about the vcl::Window*
ScopedVclPtr<VclAbstractDialog> pDlg( pFact->CreateSvxScriptOrgDialog( GetTopWindow(), aLanguage ) );
if( pDlg )
{
pDlg->Execute();
}
else
{
SAL_WARN("sfx.appl", "no dialog!!!");
}
rReq.Done();
}
break;
#endif // HAVE_FEATURE_SCRIPTING
case SID_OFFICE_CHECK_PLZ:
{
bool bRet = false;
const SfxStringItem* pStringItem = rReq.GetArg<SfxStringItem>(rReq.GetSlot());
if ( pStringItem )
{
bRet = true /*!!!SfxIniManager::CheckPLZ( aPLZ )*/;
}
#if HAVE_FEATURE_SCRIPTING
else
SbxBase::SetError( ERRCODE_BASIC_WRONG_ARGS );
#endif
rReq.SetReturnValue( SfxBoolItem( rReq.GetSlot(), bRet ) );
}
break;
case SID_AUTO_CORRECT_DLG:
{
SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
SfxItemSet aSet(GetPool(), svl::Items<SID_AUTO_CORRECT_DLG, SID_AUTO_CORRECT_DLG>{});
const SfxPoolItem* pItem=nullptr;
const SfxItemSet* pSet = rReq.GetArgs();
SfxItemPool* pSetPool = pSet ? pSet->GetPool() : nullptr;
if ( pSet && pSet->GetItemState( pSetPool->GetWhich( SID_AUTO_CORRECT_DLG ), false, &pItem ) == SfxItemState::SET )
aSet.Put( *pItem );
const SfxViewFrame* pViewFrame = SfxViewFrame::Current();
ScopedVclPtr<SfxAbstractTabDialog> pDlg(pFact->CreateAutoCorrTabDialog(pViewFrame? &pViewFrame->GetWindow(): nullptr, &aSet));
pDlg->Execute();
break;
}
case SID_NEWSD :
{
SvtModuleOptions aModuleOpt;
if ( !aModuleOpt.IsImpress() )
{
std::unique_ptr<weld::MessageDialog> xBox(Application::CreateMessageDialog(nullptr,
VclMessageType::Warning, VclButtonsType::Ok,
SfxResId(STR_MODULENOTINSTALLED)));
xBox->run();
return;
}
Reference< uno::XComponentContext > xContext = ::comphelper::getProcessComponentContext();
Reference< frame::XDispatchProvider > xProv = drawing::ModuleDispatcher::create( xContext );
OUString aCmd = OUString::createFromAscii( GetInterface()->GetSlot( rReq.GetSlot() )->GetUnoName() );
Reference< frame::XDispatchHelper > xHelper( frame::DispatchHelper::create(xContext) );
Sequence < beans::PropertyValue > aSeq;
if ( rReq.GetArgs() )
TransformItems( rReq.GetSlot(), *rReq.GetArgs(), aSeq );
Any aResult = xHelper->executeDispatch( xProv, aCmd, OUString(), 0, aSeq );
frame::DispatchResultEvent aEvent;
bool bSuccess = (aResult >>= aEvent) &&
(aEvent.State == frame::DispatchResultState::SUCCESS);
rReq.SetReturnValue( SfxBoolItem( rReq.GetSlot(), bSuccess ) );
}
break;
case FN_LABEL :
case FN_BUSINESS_CARD :
case FN_XFORMS_INIT :
{
Reference< uno::XComponentContext > xContext = ::comphelper::getProcessComponentContext();
Reference< frame::XDispatchProvider > xProv = text::ModuleDispatcher::create( xContext );
OUString aCmd = OUString::createFromAscii( GetInterface()->GetSlot( rReq.GetSlot() )->GetUnoName() );
Reference< frame::XDispatchHelper > xHelper( frame::DispatchHelper::create(xContext) );
Sequence < beans::PropertyValue > aSeq;
if ( rReq.GetArgs() )
TransformItems( rReq.GetSlot(), *rReq.GetArgs(), aSeq );
Any aResult = xHelper->executeDispatch( xProv, aCmd, OUString(), 0, aSeq );
frame::DispatchResultEvent aEvent;
bool bSuccess = (aResult >>= aEvent) &&
(aEvent.State == frame::DispatchResultState::SUCCESS);
rReq.SetReturnValue( SfxBoolItem( rReq.GetSlot(), bSuccess ) );
}
break;
case SID_ADDRESS_DATA_SOURCE:
{
try
{
Reference< uno::XComponentContext > xORB = ::comphelper::getProcessComponentContext();
Reference< ui::dialogs::XExecutableDialog > xDialog;
xDialog = ui::dialogs::AddressBookSourcePilot::createWithParent(xORB, nullptr);
xDialog->execute();
}
catch(const css::uno::Exception&)
{
DBG_UNHANDLED_EXCEPTION("sfx.appl");
}
}
break;
case SID_COMP_BIBLIOGRAPHY:
lcl_tryLoadBibliography();
break;
}
}
void SfxApplication::OfaState_Impl(SfxItemSet &rSet)
{
SvtModuleOptions aModuleOpt;
if( !aModuleOpt.IsWriter())
{
rSet.DisableItem( FN_LABEL );
rSet.DisableItem( FN_BUSINESS_CARD );
rSet.DisableItem( FN_XFORMS_INIT );
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
↑ V519 The 'bState' variable is assigned values twice successively. Perhaps this is a mistake. Check lines: 1188, 1189.