1082 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			1082 lines
		
	
	
		
			42 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
 | |
| /*************************************************************************
 | |
|  *
 | |
|  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 | |
|  *
 | |
|  * Copyright 2000, 2010 Oracle and/or its affiliates.
 | |
|  *
 | |
|  * OpenOffice.org - a multi-platform office productivity suite
 | |
|  *
 | |
|  * This file is part of OpenOffice.org.
 | |
|  *
 | |
|  * OpenOffice.org is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License version 3
 | |
|  * only, as published by the Free Software Foundation.
 | |
|  *
 | |
|  * OpenOffice.org is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Lesser General Public License version 3 for more details
 | |
|  * (a copy is included in the LICENSE file that accompanied this code).
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * version 3 along with OpenOffice.org.  If not, see
 | |
|  * <http://www.openoffice.org/license.html>
 | |
|  * for a copy of the LGPLv3 License.
 | |
|  *
 | |
|  ************************************************************************/
 | |
| 
 | |
| // MARKER(update_precomp.py): autogen include statement, do not remove
 | |
| #include "precompiled_framework.hxx"
 | |
| 
 | |
| 
 | |
| //_________________________________________________________________________________________________________________
 | |
| //  my own includes
 | |
| //_________________________________________________________________________________________________________________
 | |
| #include <classes/menumanager.hxx>
 | |
| #include <xml/menuconfiguration.hxx>
 | |
| #include <classes/bmkmenu.hxx>
 | |
| #include <classes/addonmenu.hxx>
 | |
| #include <helper/imageproducer.hxx>
 | |
| #include <threadhelp/resetableguard.hxx>
 | |
| #include "classes/addonsoptions.hxx"
 | |
| #include <classes/fwkresid.hxx>
 | |
| #include <services.h>
 | |
| #include "classes/resource.hrc"
 | |
| 
 | |
| //_________________________________________________________________________________________________________________
 | |
| //  interface includes
 | |
| //_________________________________________________________________________________________________________________
 | |
| #include <com/sun/star/frame/XDispatchProvider.hpp>
 | |
| #include <com/sun/star/frame/XDispatch.hpp>
 | |
| #include <com/sun/star/util/XURLTransformer.hpp>
 | |
| #include <com/sun/star/lang/XMultiServiceFactory.hpp>
 | |
| #include <com/sun/star/beans/XPropertySet.hpp>
 | |
| #include <com/sun/star/frame/XFramesSupplier.hpp>
 | |
| #include <com/sun/star/frame/XDesktop.hpp>
 | |
| #include <com/sun/star/container/XEnumeration.hpp>
 | |
| #include <com/sun/star/util/XStringWidth.hpp>
 | |
| 
 | |
| //_________________________________________________________________________________________________________________
 | |
| //  includes of other projects
 | |
| //_________________________________________________________________________________________________________________
 | |
| #include <comphelper/processfactory.hxx>
 | |
| 
 | |
| #include <comphelper/extract.hxx>
 | |
| #include <svtools/menuoptions.hxx>
 | |
| #include <unotools/historyoptions.hxx>
 | |
| #include <unotools/pathoptions.hxx>
 | |
| #include <unotools/localfilehelper.hxx>
 | |
| 
 | |
| #include <toolkit/unohlp.hxx>
 | |
| #include <tools/urlobj.hxx>
 | |
| 
 | |
| #include <vcl/svapp.hxx>
 | |
| #include <vcl/window.hxx>
 | |
| #include <osl/mutex.hxx>
 | |
| #include <vcl/svapp.hxx>
 | |
| #include <osl/file.hxx>
 | |
| #include <cppuhelper/implbase1.hxx>
 | |
| 
 | |
| //_________________________________________________________________________________________________________________
 | |
| //  namespace
 | |
| //_________________________________________________________________________________________________________________
 | |
| 
 | |
| using namespace ::cppu;
 | |
| using namespace ::com::sun::star::uno;
 | |
| using namespace ::com::sun::star::util;
 | |
| using namespace ::com::sun::star::beans;
 | |
| using namespace ::com::sun::star::frame;
 | |
| using namespace ::com::sun::star::lang;
 | |
| using namespace ::com::sun::star::container;
 | |
| 
 | |
| 
 | |
| class StringLength : public ::cppu::WeakImplHelper1< ::com::sun::star::util::XStringWidth >
 | |
| {
 | |
|     public:
 | |
|         StringLength() {}
 | |
|         virtual ~StringLength() {}
 | |
| 
 | |
|         // XStringWidth
 | |
|         sal_Int32 SAL_CALL queryStringWidth( const ::rtl::OUString& aString )
 | |
|             throw (::com::sun::star::uno::RuntimeException)
 | |
|         {
 | |
|             return aString.getLength();
 | |
|         }
 | |
| };
 | |
| 
 | |
| namespace framework
 | |
| {
 | |
| 
 | |
| // special menu ids/command ids for dynamic popup menus
 | |
| #define SID_SFX_START           5000
 | |
| #define SID_NEWDOCDIRECT        (SID_SFX_START + 537)
 | |
| #define SID_AUTOPILOTMENU       (SID_SFX_START + 1381)
 | |
| #define SID_PICKLIST            (SID_SFX_START + 510)
 | |
| #define SID_MDIWINDOWLIST       (SID_SFX_START + 610)
 | |
| #define SID_ADDONLIST           (SID_SFX_START + 1677)
 | |
| #define SID_HELPMENU            (SID_SFX_START + 410)
 | |
| 
 | |
| #define SFX_REFERER_USER        "private:user"
 | |
| 
 | |
| const ::rtl::OUString aSlotNewDocDirect( RTL_CONSTASCII_USTRINGPARAM( "slot:5537" ));
 | |
| const ::rtl::OUString aSlotAutoPilot( RTL_CONSTASCII_USTRINGPARAM( "slot:6381" ));
 | |
| 
 | |
| const ::rtl::OUString aSpecialFileMenu( RTL_CONSTASCII_USTRINGPARAM( "file" ));
 | |
| const ::rtl::OUString aSpecialWindowMenu( RTL_CONSTASCII_USTRINGPARAM( "window" ));
 | |
| const ::rtl::OUString aSlotSpecialFileMenu( RTL_CONSTASCII_USTRINGPARAM( "slot:5510" ));
 | |
| const ::rtl::OUString aSlotSpecialWindowMenu( RTL_CONSTASCII_USTRINGPARAM( "slot:5610" ));
 | |
| const ::rtl::OUString aSlotSpecialToolsMenu( RTL_CONSTASCII_USTRINGPARAM( "slot:6677" ));
 | |
| 
 | |
| // special uno commands for picklist and window list
 | |
| const ::rtl::OUString aSpecialFileCommand( RTL_CONSTASCII_USTRINGPARAM( "PickList" ));
 | |
| const ::rtl::OUString aSpecialWindowCommand( RTL_CONSTASCII_USTRINGPARAM( "WindowList" ));
 | |
| 
 | |
| const ::rtl::OUString UNO_COMMAND( RTL_CONSTASCII_USTRINGPARAM( ".uno:" ));
 | |
| 
 | |
| // #110897#
 | |
| MenuManager::MenuManager(
 | |
|     const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& xServiceFactory,
 | |
|     REFERENCE< XFRAME >& rFrame, Menu* pMenu, sal_Bool bDelete, sal_Bool bDeleteChildren )
 | |
| :   // #110897#
 | |
|     ThreadHelpBase( &Application::GetSolarMutex() ),
 | |
|     mxServiceFactory(xServiceFactory)
 | |
| {
 | |
|     m_bActive           = sal_False;
 | |
|     m_bDeleteMenu       = bDelete;
 | |
|     m_bDeleteChildren   = bDeleteChildren;
 | |
|     m_pVCLMenu          = pMenu;
 | |
|     m_xFrame            = rFrame;
 | |
|     m_bInitialized      = sal_False;
 | |
|     m_bIsBookmarkMenu   = sal_False;
 | |
|     SAL_STATIC_CAST( ::com::sun::star::uno::XInterface*, (OWeakObject*)this )->acquire();
 | |
| 
 | |
|     const StyleSettings& rSettings = Application::GetSettings().GetStyleSettings();
 | |
|     m_bShowMenuImages   = rSettings.GetUseImagesInMenus();
 | |
| 
 | |
|     sal_Int32 nAddonsURLPrefixLength = ADDONSPOPUPMENU_URL_PREFIX.getLength();
 | |
| 
 | |
| 
 | |
|     USHORT nItemCount = pMenu->GetItemCount();
 | |
|     m_aMenuItemHandlerVector.reserve(nItemCount);
 | |
|     ::rtl::OUString aItemCommand;
 | |
|     for ( USHORT i = 0; i < nItemCount; i++ )
 | |
|     {
 | |
|         USHORT nItemId = FillItemCommand(aItemCommand,pMenu, i );
 | |
|         bool bShowMenuImages( m_bShowMenuImages );
 | |
| 
 | |
|         // overwrite the show icons on menu option?
 | |
|         if (!bShowMenuImages)
 | |
|         {
 | |
|             MenuItemBits nBits = pMenu->GetItemBits( nItemId );
 | |
|             bShowMenuImages = ( ( nBits & MIB_ICON ) == MIB_ICON );
 | |
|         }
 | |
| 
 | |
|         PopupMenu* pPopupMenu = pMenu->GetPopupMenu( nItemId );
 | |
|         if ( pPopupMenu )
 | |
|         {
 | |
|             AddMenu(pPopupMenu,aItemCommand,nItemId,bDeleteChildren,bDeleteChildren);
 | |
|             if (! (( aItemCommand.getLength() > nAddonsURLPrefixLength ) &&
 | |
|                 ( aItemCommand.indexOf( ADDONSPOPUPMENU_URL_PREFIX ) == 0 )) )
 | |
|             {
 | |
|                 // #110897#
 | |
|                 // MenuManager* pSubMenuManager = new MenuManager( rFrame, pPopupMenu, bDeleteChildren, bDeleteChildren );
 | |
| 
 | |
|                 // Create addon popup menu if there exist elements and this is the tools popup menu
 | |
|                 if (( nItemId == SID_ADDONLIST ||
 | |
|                     aItemCommand == aSlotSpecialToolsMenu ) &&
 | |
|                     AddonMenuManager::HasAddonMenuElements() )
 | |
|                 {
 | |
|                     USHORT      nCount   = 0;
 | |
|                     AddonMenu*  pSubMenu = AddonMenuManager::CreateAddonMenu( rFrame );
 | |
|                     if ( pSubMenu && ( pSubMenu->GetItemCount() > 0 ))
 | |
|                     {
 | |
|                         if ( pPopupMenu->GetItemType( nCount-1 ) != MENUITEM_SEPARATOR )
 | |
|                             pPopupMenu->InsertSeparator();
 | |
| 
 | |
|                         // Use resource to load popup menu title
 | |
|                         String aAddonsStrRes = String( FwkResId( STR_MENU_ADDONS ));
 | |
|                         pPopupMenu->InsertItem( ITEMID_ADDONLIST, aAddonsStrRes );
 | |
|                         pPopupMenu->SetPopupMenu( ITEMID_ADDONLIST, pSubMenu );
 | |
| 
 | |
|                         // Set item command for popup menu to enable it for GetImageFromURL
 | |
|                         const static ::rtl::OUString aSlotString( RTL_CONSTASCII_USTRINGPARAM( "slot:" ));
 | |
|                         aItemCommand = aSlotString;
 | |
|                         aItemCommand += ::rtl::OUString::valueOf( (sal_Int32)ITEMID_ADDONLIST );
 | |
|                         pPopupMenu->SetItemCommand( ITEMID_ADDONLIST, aItemCommand );
 | |
| 
 | |
|                         // #110897#
 | |
|                         // MenuManager* pSubMenuManager = new MenuManager( rFrame, pSubMenu, sal_True, sal_False );
 | |
|                         AddMenu(pSubMenu,::rtl::OUString(),nItemId,sal_True,sal_False);
 | |
|                         // Set image for the addon popup menu item
 | |
|                         if ( bShowMenuImages && !pPopupMenu->GetItemImage( ITEMID_ADDONLIST ))
 | |
|                         {
 | |
|                             Image aImage = GetImageFromURL( rFrame, aItemCommand, FALSE );
 | |
|                             if ( !!aImage )
 | |
|                                    pPopupMenu->SetItemImage( ITEMID_ADDONLIST, aImage );
 | |
|                         }
 | |
|                     }
 | |
|                     else
 | |
|                         delete pSubMenu;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             if ( nItemId == SID_NEWDOCDIRECT ||
 | |
|                  aItemCommand == aSlotNewDocDirect )
 | |
|             {
 | |
|                 // #110897#
 | |
|                 // Reference< ::com::sun::star::lang::XMultiServiceFactory > aMultiServiceFactory(::comphelper::getProcessServiceFactory());
 | |
|                 // MenuConfiguration aMenuCfg( aMultiServiceFactory );
 | |
|                 MenuConfiguration aMenuCfg( getServiceFactory() );
 | |
|                 BmkMenu* pSubMenu = (BmkMenu*)aMenuCfg.CreateBookmarkMenu( rFrame, BOOKMARK_NEWMENU );
 | |
|                 pMenu->SetPopupMenu( nItemId, pSubMenu );
 | |
| 
 | |
|                 // #110897#
 | |
|                 // MenuManager* pSubMenuManager = new MenuManager( rFrame, pSubMenu, sal_True, sal_False );
 | |
|                 AddMenu(pSubMenu,::rtl::OUString(),nItemId,sal_True,sal_False);
 | |
|                 if ( bShowMenuImages && !pMenu->GetItemImage( nItemId ))
 | |
|                 {
 | |
|                     Image aImage = GetImageFromURL( rFrame, aItemCommand, FALSE );
 | |
|                     if ( !!aImage )
 | |
|                            pMenu->SetItemImage( nItemId, aImage );
 | |
|                 }
 | |
|             }
 | |
|             else if ( nItemId == SID_AUTOPILOTMENU ||
 | |
|                       aItemCommand == aSlotAutoPilot )
 | |
|             {
 | |
|                 // #110897#
 | |
|                 // Reference< ::com::sun::star::lang::XMultiServiceFactory > aMultiServiceFactory(::comphelper::getProcessServiceFactory());
 | |
|                 // MenuConfiguration aMenuCfg( aMultiServiceFactory );
 | |
|                 MenuConfiguration aMenuCfg( getServiceFactory() );
 | |
|                 BmkMenu* pSubMenu = (BmkMenu*)aMenuCfg.CreateBookmarkMenu( rFrame, BOOKMARK_WIZARDMENU );
 | |
|                 pMenu->SetPopupMenu( nItemId, pSubMenu );
 | |
| 
 | |
|                 // #110897#
 | |
|                 // MenuManager* pSubMenuManager = new MenuManager( rFrame, pSubMenu, sal_True, sal_False );
 | |
|                 AddMenu(pSubMenu,::rtl::OUString(),nItemId,sal_True,sal_False);
 | |
| 
 | |
| 
 | |
|                 if ( bShowMenuImages && !pMenu->GetItemImage( nItemId ))
 | |
|                 {
 | |
|                     Image aImage = GetImageFromURL( rFrame, aItemCommand, FALSE );
 | |
|                     if ( !!aImage )
 | |
|                            pMenu->SetItemImage( nItemId, aImage );
 | |
|                 }
 | |
|             }
 | |
|             else if ( pMenu->GetItemType( i ) != MENUITEM_SEPARATOR )
 | |
|             {
 | |
|                 if ( bShowMenuImages )
 | |
|                 {
 | |
|                     if ( AddonMenuManager::IsAddonMenuId( nItemId ))
 | |
|                     {
 | |
|                         // Add-Ons uses a images from different places
 | |
|                         Image           aImage;
 | |
|                         rtl::OUString   aImageId;
 | |
| 
 | |
|                         MenuConfiguration::Attributes* pMenuAttributes =
 | |
|                             (MenuConfiguration::Attributes*)pMenu->GetUserValue( nItemId );
 | |
| 
 | |
|                         if ( pMenuAttributes && pMenuAttributes->aImageId.getLength() > 0 )
 | |
|                         {
 | |
|                             // Retrieve image id from menu attributes
 | |
|                             aImage = GetImageFromURL( rFrame, aImageId, FALSE );
 | |
|                         }
 | |
| 
 | |
|                         if ( !aImage )
 | |
|                         {
 | |
|                             aImage = GetImageFromURL( rFrame, aItemCommand, FALSE );
 | |
|                             if ( !aImage )
 | |
|                                 aImage = AddonsOptions().GetImageFromURL( aItemCommand, FALSE );
 | |
|                         }
 | |
| 
 | |
|                         if ( !!aImage )
 | |
|                             pMenu->SetItemImage( nItemId, aImage );
 | |
|                     }
 | |
|                     else if ( !pMenu->GetItemImage( nItemId ))
 | |
|                     {
 | |
|                         Image aImage = GetImageFromURL( rFrame, aItemCommand, FALSE );
 | |
|                         if ( !!aImage )
 | |
|                                pMenu->SetItemImage( nItemId, aImage );
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 REFERENCE< XDISPATCH > aXDispatchRef;
 | |
|                 m_aMenuItemHandlerVector.push_back( new MenuItemHandler( nItemId, NULL, aXDispatchRef ));
 | |
| 
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // retrieve label information for all menu items without item text
 | |
| 
 | |
|     SetHdl();
 | |
| }
 | |
| 
 | |
| 
 | |
| void MenuManager::SetHdl()
 | |
| {
 | |
|     m_pVCLMenu->SetHighlightHdl( LINK( this, MenuManager, Highlight ));
 | |
|     m_pVCLMenu->SetActivateHdl( LINK( this, MenuManager, Activate ));
 | |
|     m_pVCLMenu->SetDeactivateHdl( LINK( this, MenuManager, Deactivate ));
 | |
|     m_pVCLMenu->SetSelectHdl( LINK( this, MenuManager, Select ));
 | |
| 
 | |
|     if ( mxServiceFactory.is() )
 | |
|         m_xURLTransformer.set( mxServiceFactory->createInstance(SERVICENAME_URLTRANSFORMER),UNO_QUERY );
 | |
| }
 | |
| 
 | |
| MenuManager::~MenuManager()
 | |
| {
 | |
|     std::vector< MenuItemHandler* >::iterator p;
 | |
|     for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|     {
 | |
|         MenuItemHandler* pItemHandler = *p;
 | |
|         pItemHandler->xMenuItemDispatch.clear();
 | |
|         if ( pItemHandler->pSubMenuManager )
 | |
|             SAL_STATIC_CAST( ::com::sun::star::uno::XInterface*, (OWeakObject*)pItemHandler->pSubMenuManager )->release();
 | |
|         delete pItemHandler;
 | |
|     }
 | |
| 
 | |
|     if ( m_bDeleteMenu )
 | |
|         delete m_pVCLMenu;
 | |
| }
 | |
| 
 | |
| 
 | |
| MenuManager::MenuItemHandler* MenuManager::GetMenuItemHandler( USHORT nItemId )
 | |
| {
 | |
|     ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|     std::vector< MenuItemHandler* >::iterator p;
 | |
|     for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|     {
 | |
|         MenuItemHandler* pItemHandler = *p;
 | |
|         if ( pItemHandler->nItemId == nItemId )
 | |
|             return pItemHandler;
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| void SAL_CALL MenuManager::statusChanged( const FEATURSTATEEVENT& Event )
 | |
| throw ( RuntimeException )
 | |
| {
 | |
|     ::rtl::OUString aFeatureURL = Event.FeatureURL.Complete;
 | |
|     MenuItemHandler* pStatusChangedMenu = NULL;
 | |
| 
 | |
|     {
 | |
|         ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|         std::vector< MenuItemHandler* >::iterator p;
 | |
|         for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|         {
 | |
|             MenuItemHandler* pMenuItemHandler = *p;
 | |
|             if ( pMenuItemHandler->aMenuItemURL == aFeatureURL )
 | |
|             {
 | |
|                 pStatusChangedMenu = pMenuItemHandler;
 | |
|                 break;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if ( pStatusChangedMenu )
 | |
|     {
 | |
|         SolarMutexGuard aSolarGuard;
 | |
|         {
 | |
|             ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|             sal_Bool bSetCheckmark      = sal_False;
 | |
|             sal_Bool bCheckmark         = sal_False;
 | |
|             sal_Bool bMenuItemEnabled   = m_pVCLMenu->IsItemEnabled( pStatusChangedMenu->nItemId );
 | |
| 
 | |
|             if ( Event.IsEnabled != bMenuItemEnabled )
 | |
|                 m_pVCLMenu->EnableItem( pStatusChangedMenu->nItemId, Event.IsEnabled );
 | |
| 
 | |
|             if ( Event.State >>= bCheckmark )
 | |
|                  bSetCheckmark = sal_True;
 | |
| 
 | |
|             if ( bSetCheckmark )
 | |
|                 m_pVCLMenu->CheckItem( pStatusChangedMenu->nItemId, bCheckmark );
 | |
|         }
 | |
| 
 | |
|         if ( Event.Requery )
 | |
|         {
 | |
|             URL aTargetURL;
 | |
|             aTargetURL.Complete = pStatusChangedMenu->aMenuItemURL;
 | |
| 
 | |
|             // #110897#
 | |
|             m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|             REFERENCE< XDISPATCHPROVIDER > xDispatchProvider( m_xFrame, UNO_QUERY );
 | |
|             REFERENCE< XDISPATCH > xMenuItemDispatch = xDispatchProvider->queryDispatch(
 | |
|                                                             aTargetURL, ::rtl::OUString(), 0 );
 | |
| 
 | |
|             if ( xMenuItemDispatch.is() )
 | |
|             {
 | |
|                 pStatusChangedMenu->xMenuItemDispatch   = xMenuItemDispatch;
 | |
|                 pStatusChangedMenu->aMenuItemURL        = aTargetURL.Complete;
 | |
|                 xMenuItemDispatch->addStatusListener( SAL_STATIC_CAST( XSTATUSLISTENER*, this ), aTargetURL );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void MenuManager::RemoveListener()
 | |
| {
 | |
|     ResetableGuard aGuard( m_aLock );
 | |
|     ClearMenuDispatch();
 | |
| }
 | |
| 
 | |
| void MenuManager::ClearMenuDispatch(const EVENTOBJECT& Source,bool _bRemoveOnly)
 | |
| {
 | |
|     // disposing called from parent dispatcher
 | |
|     // remove all listener to prepare shutdown
 | |
| 
 | |
|     // #110897#
 | |
|     std::vector< MenuItemHandler* >::iterator p;
 | |
|     for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|     {
 | |
|         MenuItemHandler* pItemHandler = *p;
 | |
|         if ( pItemHandler->xMenuItemDispatch.is() )
 | |
|         {
 | |
|             URL aTargetURL;
 | |
|             aTargetURL.Complete = pItemHandler->aMenuItemURL;
 | |
|             m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|             pItemHandler->xMenuItemDispatch->removeStatusListener(
 | |
|                 SAL_STATIC_CAST( XSTATUSLISTENER*, this ), aTargetURL );
 | |
|         }
 | |
| 
 | |
|         pItemHandler->xMenuItemDispatch.clear();
 | |
|         if ( pItemHandler->pSubMenuManager )
 | |
|         {
 | |
|             if ( _bRemoveOnly )
 | |
|                 pItemHandler->pSubMenuManager->RemoveListener();
 | |
|             else
 | |
|                 pItemHandler->pSubMenuManager->disposing( Source );
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void SAL_CALL MenuManager::disposing( const EVENTOBJECT& Source ) throw ( RUNTIMEEXCEPTION )
 | |
| {
 | |
|     if ( Source.Source == m_xFrame )
 | |
|     {
 | |
|         ResetableGuard aGuard( m_aLock );
 | |
|         ClearMenuDispatch(Source,false);
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|         // disposing called from menu item dispatcher, remove listener
 | |
|         MenuItemHandler* pMenuItemDisposing = NULL;
 | |
| 
 | |
|         {
 | |
|             ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|             std::vector< MenuItemHandler* >::iterator p;
 | |
|             for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|             {
 | |
|                 MenuItemHandler* pMenuItemHandler = *p;
 | |
|                 if ( pMenuItemHandler->xMenuItemDispatch == Source.Source )
 | |
|                 {
 | |
|                     pMenuItemDisposing = pMenuItemHandler;
 | |
|                     break;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if ( pMenuItemDisposing )
 | |
|             {
 | |
|                 URL aTargetURL;
 | |
|                 aTargetURL.Complete = pMenuItemDisposing->aMenuItemURL;
 | |
| 
 | |
|                 // #110897#
 | |
|                 m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|                 pMenuItemDisposing->xMenuItemDispatch->removeStatusListener(SAL_STATIC_CAST( XSTATUSLISTENER*, this ), aTargetURL );
 | |
|                 pMenuItemDisposing->xMenuItemDispatch.clear();
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void MenuManager::UpdateSpecialFileMenu( Menu* pMenu )
 | |
| {
 | |
|     // update picklist
 | |
|     Sequence< Sequence< PropertyValue > > aHistoryList = SvtHistoryOptions().GetList( ePICKLIST );
 | |
|     ::std::vector< MenuItemHandler* > aNewPickVector;
 | |
|     Reference< XStringWidth > xStringLength( new StringLength );
 | |
| 
 | |
|     USHORT  nPickItemId = START_ITEMID_PICKLIST;
 | |
|     int     nPickListMenuItems = ( aHistoryList.getLength() > 99 ) ? 99 : aHistoryList.getLength();
 | |
| 
 | |
|     aNewPickVector.reserve(nPickListMenuItems);
 | |
|     for ( int i = 0; i < nPickListMenuItems; i++ )
 | |
|     {
 | |
|         Sequence< PropertyValue > aPickListEntry = aHistoryList[i];
 | |
| 
 | |
|         REFERENCE< XDISPATCH > aXDispatchRef;
 | |
|         MenuItemHandler* pNewMenuItemHandler = new MenuItemHandler(
 | |
|                                                     nPickItemId++,
 | |
|                                                     NULL,
 | |
|                                                     aXDispatchRef );
 | |
| 
 | |
|         for ( int j = 0; j < aPickListEntry.getLength(); j++ )
 | |
|         {
 | |
|             Any a = aPickListEntry[j].Value;
 | |
| 
 | |
|             if ( aPickListEntry[j].Name == HISTORY_PROPERTYNAME_URL )
 | |
|                 a >>= pNewMenuItemHandler->aMenuItemURL;
 | |
|             else if ( aPickListEntry[j].Name == HISTORY_PROPERTYNAME_FILTER )
 | |
|                 a >>= pNewMenuItemHandler->aFilter;
 | |
|             else if ( aPickListEntry[j].Name == HISTORY_PROPERTYNAME_TITLE )
 | |
|                 a >>= pNewMenuItemHandler->aTitle;
 | |
|             else if ( aPickListEntry[j].Name == HISTORY_PROPERTYNAME_PASSWORD )
 | |
|                 a >>= pNewMenuItemHandler->aPassword;
 | |
|         }
 | |
| 
 | |
|         aNewPickVector.push_back( pNewMenuItemHandler );
 | |
|     }
 | |
| 
 | |
|     if ( !aNewPickVector.empty() )
 | |
|     {
 | |
|         URL aTargetURL;
 | |
|         REFERENCE< XDISPATCHPROVIDER > xDispatchProvider( m_xFrame, UNO_QUERY );
 | |
| 
 | |
|         // #110897#
 | |
|         REFERENCE< XDISPATCH > xMenuItemDispatch;
 | |
| 
 | |
|         static const ::rtl::OUString s_sDefault(RTL_CONSTASCII_USTRINGPARAM("_default"));
 | |
|         // query for dispatcher
 | |
|         std::vector< MenuItemHandler* >::iterator p;
 | |
|         for ( p = aNewPickVector.begin(); p != aNewPickVector.end(); p++ )
 | |
|         {
 | |
|             MenuItemHandler* pMenuItemHandler = *p;
 | |
| 
 | |
|             aTargetURL.Complete = pMenuItemHandler->aMenuItemURL;
 | |
|             m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|             if ( !xMenuItemDispatch.is() )
 | |
|             {
 | |
|                 // attention: this code assume that "_blank" can only be consumed by desktop service
 | |
|                 xMenuItemDispatch = xDispatchProvider->queryDispatch( aTargetURL, s_sDefault, 0 );
 | |
|             }
 | |
| 
 | |
|             if ( xMenuItemDispatch.is() )
 | |
|             {
 | |
|                 pMenuItemHandler->xMenuItemDispatch = xMenuItemDispatch;
 | |
|                 pMenuItemHandler->aMenuItemURL      = aTargetURL.Complete;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         {
 | |
|             ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|             int nRemoveItemCount = 0;
 | |
|             int nItemCount       = pMenu->GetItemCount();
 | |
| 
 | |
|             if ( nItemCount > 0 )
 | |
|             {
 | |
|                 // remove all old picklist entries from menu
 | |
|                 sal_uInt16 nPos = pMenu->GetItemPos( START_ITEMID_PICKLIST );
 | |
|                 for ( sal_uInt16 n = nPos; n < pMenu->GetItemCount(); )
 | |
|                 {
 | |
|                     pMenu->RemoveItem( n );
 | |
|                     ++nRemoveItemCount;
 | |
|                 }
 | |
| 
 | |
|                 if ( pMenu->GetItemType( pMenu->GetItemCount()-1 ) == MENUITEM_SEPARATOR )
 | |
|                     pMenu->RemoveItem( pMenu->GetItemCount()-1 );
 | |
| 
 | |
|                 // remove all old picklist entries from menu handler
 | |
|                 if ( nRemoveItemCount > 0 )
 | |
|                 {
 | |
|                     for( sal_uInt32 nIndex = m_aMenuItemHandlerVector.size() - nRemoveItemCount;
 | |
|                          nIndex < m_aMenuItemHandlerVector.size();  )
 | |
|                     {
 | |
|                         delete m_aMenuItemHandlerVector.at( nIndex );
 | |
|                         m_aMenuItemHandlerVector.erase( m_aMenuItemHandlerVector.begin() + nIndex );
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             // append new picklist menu entries
 | |
|             aNewPickVector.reserve(aNewPickVector.size());
 | |
|             pMenu->InsertSeparator();
 | |
|             const sal_uInt32 nCount = aNewPickVector.size();
 | |
|             for ( sal_uInt32 i = 0; i < nCount; i++ )
 | |
|             {
 | |
|                 char menuShortCut[5] = "~n: ";
 | |
| 
 | |
|                 ::rtl::OUString aMenuShortCut;
 | |
|                 if ( i <= 9 )
 | |
|                 {
 | |
|                     if ( i == 9 )
 | |
|                         aMenuShortCut = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "1~0: " ));
 | |
|                     else
 | |
|                     {
 | |
|                         menuShortCut[1] = (char)( '1' + i );
 | |
|                         aMenuShortCut = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( menuShortCut ));
 | |
|                     }
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     aMenuShortCut = rtl::OUString::valueOf((sal_Int32)( i + 1 ));
 | |
|                     aMenuShortCut += rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( ": " ));
 | |
|                 }
 | |
| 
 | |
|                 // Abbreviate URL
 | |
|                 rtl::OUString   aURLString( aNewPickVector.at( i )->aMenuItemURL );
 | |
|                 rtl::OUString   aTipHelpText;
 | |
|                 rtl::OUString   aMenuTitle;
 | |
|                 INetURLObject   aURL( aURLString );
 | |
| 
 | |
|                 if ( aURL.GetProtocol() == INET_PROT_FILE )
 | |
|                 {
 | |
|                     // Do handle file URL differently => convert it to a system
 | |
|                     // path and abbreviate it with a special function:
 | |
|                     String aFileSystemPath( aURL.getFSysPath( INetURLObject::FSYS_DETECT ) );
 | |
| 
 | |
|                     ::rtl::OUString aSystemPath( aFileSystemPath );
 | |
|                     ::rtl::OUString aCompactedSystemPath;
 | |
| 
 | |
|                     aTipHelpText = aSystemPath;
 | |
|                     oslFileError nError = osl_abbreviateSystemPath( aSystemPath.pData, &aCompactedSystemPath.pData, 46, NULL );
 | |
|                     if ( !nError )
 | |
|                         aMenuTitle = String( aCompactedSystemPath );
 | |
|                     else
 | |
|                         aMenuTitle = aSystemPath;
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     // Use INetURLObject to abbreviate all other URLs
 | |
|                     String  aShortURL;
 | |
|                     aShortURL = aURL.getAbbreviated( xStringLength, 46, INetURLObject::DECODE_UNAMBIGUOUS );
 | |
|                     aMenuTitle += aShortURL;
 | |
|                     aTipHelpText = aURLString;
 | |
|                 }
 | |
| 
 | |
|                 ::rtl::OUString aTitle( aMenuShortCut + aMenuTitle );
 | |
| 
 | |
|                 MenuItemHandler* pMenuItemHandler = aNewPickVector.at( i );
 | |
|                 pMenu->InsertItem( pMenuItemHandler->nItemId, aTitle );
 | |
|                 pMenu->SetTipHelpText( pMenuItemHandler->nItemId, aTipHelpText );
 | |
|                 m_aMenuItemHandlerVector.push_back( pMenuItemHandler );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| void MenuManager::UpdateSpecialWindowMenu( Menu* pMenu,const Reference< XMultiServiceFactory >& xServiceFactory,framework::IMutex& _rMutex )
 | |
| {
 | |
|     // update window list
 | |
|     ::std::vector< ::rtl::OUString > aNewWindowListVector;
 | |
| 
 | |
|     // #110897#
 | |
|     Reference< XDesktop > xDesktop( xServiceFactory->createInstance( SERVICENAME_DESKTOP ), UNO_QUERY );
 | |
| 
 | |
|     USHORT  nActiveItemId = 0;
 | |
|     USHORT  nItemId = START_ITEMID_WINDOWLIST;
 | |
| 
 | |
|     if ( xDesktop.is() )
 | |
|     {
 | |
|         Reference< XFramesSupplier > xTasksSupplier( xDesktop, UNO_QUERY );
 | |
|         Reference< XFrame > xCurrentFrame = xDesktop->getCurrentFrame();
 | |
|         Reference< XIndexAccess > xList( xTasksSupplier->getFrames(), UNO_QUERY );
 | |
|         sal_Int32 nCount = xList->getCount();
 | |
|         aNewWindowListVector.reserve(nCount);
 | |
|         for (sal_Int32 i=0; i<nCount; ++i )
 | |
|         {
 | |
|             Reference< XFrame > xFrame;
 | |
|             xList->getByIndex(i) >>= xFrame;
 | |
| 
 | |
|             if (xFrame.is())
 | |
|             {
 | |
|                 if ( xFrame == xCurrentFrame )
 | |
|                     nActiveItemId = nItemId;
 | |
| 
 | |
|                 Window* pWin = VCLUnoHelper::GetWindow( xFrame->getContainerWindow() );
 | |
|                 if ( pWin && pWin->IsVisible() )
 | |
|                 {
 | |
|                     aNewWindowListVector.push_back( pWin->GetText() );
 | |
|                     ++nItemId;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     {
 | |
|         ResetableGuard aGuard( _rMutex );
 | |
| 
 | |
|         int nItemCount = pMenu->GetItemCount();
 | |
| 
 | |
|         if ( nItemCount > 0 )
 | |
|         {
 | |
|             // remove all old window list entries from menu
 | |
|             sal_uInt16 nPos = pMenu->GetItemPos( START_ITEMID_WINDOWLIST );
 | |
|             for ( sal_uInt16 n = nPos; n < pMenu->GetItemCount(); )
 | |
|                 pMenu->RemoveItem( n );
 | |
| 
 | |
|             if ( pMenu->GetItemType( pMenu->GetItemCount()-1 ) == MENUITEM_SEPARATOR )
 | |
|                 pMenu->RemoveItem( pMenu->GetItemCount()-1 );
 | |
|         }
 | |
| 
 | |
|         if ( !aNewWindowListVector.empty() )
 | |
|         {
 | |
|             // append new window list entries to menu
 | |
|             pMenu->InsertSeparator();
 | |
|             nItemId = START_ITEMID_WINDOWLIST;
 | |
|             const sal_uInt32 nCount = aNewWindowListVector.size();
 | |
|             for ( sal_uInt32 i = 0; i < nCount; i++ )
 | |
|             {
 | |
|                 pMenu->InsertItem( nItemId, aNewWindowListVector.at( i ), MIB_RADIOCHECK );
 | |
|                 if ( nItemId == nActiveItemId )
 | |
|                     pMenu->CheckItem( nItemId );
 | |
|                 ++nItemId;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void MenuManager::CreatePicklistArguments( Sequence< PropertyValue >& aArgsList, const MenuItemHandler* pMenuItemHandler )
 | |
| {
 | |
|     int NUM_OF_PICKLIST_ARGS = 3;
 | |
| 
 | |
|     Any a;
 | |
|     aArgsList.realloc( NUM_OF_PICKLIST_ARGS );
 | |
| 
 | |
|     aArgsList[0].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "FileName" ));
 | |
|     a <<= pMenuItemHandler->aMenuItemURL;
 | |
|     aArgsList[0].Value = a;
 | |
| 
 | |
|     aArgsList[1].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Referer" ));
 | |
|     a <<= ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SFX_REFERER_USER ));
 | |
|     aArgsList[1].Value = a;
 | |
| 
 | |
|     ::rtl::OUString aFilter( pMenuItemHandler->aFilter );
 | |
| 
 | |
|     sal_Int32 nPos = aFilter.indexOf( '|' );
 | |
|     if ( nPos >= 0 )
 | |
|     {
 | |
|         ::rtl::OUString aFilterOptions;
 | |
| 
 | |
|         if ( nPos < ( aFilter.getLength() - 1 ) )
 | |
|             aFilterOptions = aFilter.copy( nPos+1 );
 | |
| 
 | |
|         aArgsList[2].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "FilterOptions" ));
 | |
|         a <<= aFilterOptions;
 | |
|         aArgsList[2].Value = a;
 | |
| 
 | |
|         aFilter = aFilter.copy( 0, nPos-1 );
 | |
|         aArgsList.realloc( ++NUM_OF_PICKLIST_ARGS );
 | |
|     }
 | |
| 
 | |
|     aArgsList[NUM_OF_PICKLIST_ARGS-1].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "FilterName" ));
 | |
|     a <<= aFilter;
 | |
|     aArgsList[NUM_OF_PICKLIST_ARGS-1].Value = a;
 | |
| }
 | |
| 
 | |
| 
 | |
| //_________________________________________________________________________________________________________________
 | |
| // vcl handler
 | |
| //_________________________________________________________________________________________________________________
 | |
| 
 | |
| IMPL_LINK( MenuManager, Activate, Menu *, pMenu )
 | |
| {
 | |
|     if ( pMenu == m_pVCLMenu )
 | |
|     {
 | |
|         // set/unset hiding disabled menu entries
 | |
|         sal_Bool bDontHide          = SvtMenuOptions().IsEntryHidingEnabled();
 | |
|         const StyleSettings& rSettings = Application::GetSettings().GetStyleSettings();
 | |
|         sal_Bool bShowMenuImages    = rSettings.GetUseImagesInMenus();
 | |
| 
 | |
|         sal_uInt16 nFlag = pMenu->GetMenuFlags();
 | |
|         if ( bDontHide )
 | |
|             nFlag &= ~MENU_FLAG_HIDEDISABLEDENTRIES;
 | |
|         else
 | |
|             nFlag |= MENU_FLAG_HIDEDISABLEDENTRIES;
 | |
|         pMenu->SetMenuFlags( nFlag );
 | |
| 
 | |
|         if ( m_bActive )
 | |
|             return 0;
 | |
| 
 | |
|         m_bActive = TRUE;
 | |
| 
 | |
|         ::rtl::OUString aCommand( m_aMenuItemCommand );
 | |
|         if ( m_aMenuItemCommand.matchIgnoreAsciiCase( UNO_COMMAND, 0 ))
 | |
|         {
 | |
|             // Remove protocol part from command so we can use an easier comparision method
 | |
|             aCommand = aCommand.copy( UNO_COMMAND.getLength() );
 | |
|         }
 | |
| 
 | |
|         if ( m_aMenuItemCommand == aSpecialFileMenu ||
 | |
|              m_aMenuItemCommand == aSlotSpecialFileMenu ||
 | |
|              aCommand == aSpecialFileCommand )
 | |
|             UpdateSpecialFileMenu( pMenu );
 | |
|         else if ( m_aMenuItemCommand == aSpecialWindowMenu ||
 | |
|                   m_aMenuItemCommand == aSlotSpecialWindowMenu ||
 | |
|                   aCommand == aSpecialWindowCommand )
 | |
|                   UpdateSpecialWindowMenu( pMenu,getServiceFactory(),m_aLock );
 | |
| 
 | |
|         // Check if some modes have changed so we have to update our menu images
 | |
|         if ( bShowMenuImages != m_bShowMenuImages )
 | |
|         {
 | |
|             // The mode changed so we have to replace all images
 | |
|             m_bShowMenuImages   = bShowMenuImages;
 | |
|             FillMenuImages( m_xFrame, pMenu, bShowMenuImages );
 | |
|         }
 | |
| 
 | |
|         if ( m_bInitialized )
 | |
|             return 0;
 | |
|         else
 | |
|         {
 | |
|             URL aTargetURL;
 | |
| 
 | |
|             // #110897#
 | |
|             ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|             REFERENCE< XDISPATCHPROVIDER > xDispatchProvider( m_xFrame, UNO_QUERY );
 | |
|             if ( xDispatchProvider.is() )
 | |
|             {
 | |
|                 std::vector< MenuItemHandler* >::iterator p;
 | |
|                 for ( p = m_aMenuItemHandlerVector.begin(); p != m_aMenuItemHandlerVector.end(); p++ )
 | |
|                 {
 | |
|                     MenuItemHandler* pMenuItemHandler = *p;
 | |
|                     if ( pMenuItemHandler &&
 | |
|                          pMenuItemHandler->pSubMenuManager == 0 &&
 | |
|                          !pMenuItemHandler->xMenuItemDispatch.is() )
 | |
|                     {
 | |
|                         // There is no dispatch mechanism for the special window list menu items,
 | |
|                         // because they are handled directly through XFrame->activate!!!
 | |
|                         if ( pMenuItemHandler->nItemId < START_ITEMID_WINDOWLIST ||
 | |
|                              pMenuItemHandler->nItemId > END_ITEMID_WINDOWLIST )
 | |
|                         {
 | |
|                             ::rtl::OUString aItemCommand = pMenu->GetItemCommand( pMenuItemHandler->nItemId );
 | |
|                             if ( !aItemCommand.getLength() )
 | |
|                             {
 | |
|                                 const static ::rtl::OUString aSlotString( RTL_CONSTASCII_USTRINGPARAM( "slot:" ));
 | |
|                                 aItemCommand = aSlotString;
 | |
|                                 aItemCommand += ::rtl::OUString::valueOf( (sal_Int32)pMenuItemHandler->nItemId );
 | |
|                                 pMenu->SetItemCommand( pMenuItemHandler->nItemId, aItemCommand );
 | |
|                             }
 | |
| 
 | |
|                             aTargetURL.Complete = aItemCommand;
 | |
| 
 | |
|                             m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|                             REFERENCE< XDISPATCH > xMenuItemDispatch;
 | |
|                             if ( m_bIsBookmarkMenu )
 | |
|                                 xMenuItemDispatch = xDispatchProvider->queryDispatch( aTargetURL, pMenuItemHandler->aTargetFrame, 0 );
 | |
|                             else
 | |
|                                 xMenuItemDispatch = xDispatchProvider->queryDispatch( aTargetURL, ::rtl::OUString(), 0 );
 | |
| 
 | |
|                             if ( xMenuItemDispatch.is() )
 | |
|                             {
 | |
|                                 pMenuItemHandler->xMenuItemDispatch = xMenuItemDispatch;
 | |
|                                 pMenuItemHandler->aMenuItemURL      = aTargetURL.Complete;
 | |
|                                 xMenuItemDispatch->addStatusListener( SAL_STATIC_CAST( XSTATUSLISTENER*, this ), aTargetURL );
 | |
|                             }
 | |
|                             else
 | |
|                                 pMenu->EnableItem( pMenuItemHandler->nItemId, sal_False );
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| 
 | |
| IMPL_LINK( MenuManager, Deactivate, Menu *, pMenu )
 | |
| {
 | |
|     if ( pMenu == m_pVCLMenu )
 | |
|         m_bActive = sal_False;
 | |
| 
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| 
 | |
| IMPL_LINK( MenuManager, Select, Menu *, pMenu )
 | |
| {
 | |
|     URL                     aTargetURL;
 | |
|     Sequence<PropertyValue> aArgs;
 | |
|     REFERENCE< XDISPATCH >  xDispatch;
 | |
| 
 | |
|     {
 | |
|         ResetableGuard aGuard( m_aLock );
 | |
| 
 | |
|         USHORT nCurItemId = pMenu->GetCurItemId();
 | |
|         if ( pMenu == m_pVCLMenu &&
 | |
|              pMenu->GetItemType( nCurItemId ) != MENUITEM_SEPARATOR )
 | |
|         {
 | |
|             if ( nCurItemId >= START_ITEMID_WINDOWLIST &&
 | |
|                  nCurItemId <= END_ITEMID_WINDOWLIST )
 | |
|             {
 | |
|                 // window list menu item selected
 | |
| 
 | |
|                 // #110897#
 | |
|                 // Reference< XFramesSupplier > xDesktop( ::comphelper::getProcessServiceFactory()->createInstance(
 | |
|                 //  DESKTOP_SERVICE ), UNO_QUERY );
 | |
|                 Reference< XFramesSupplier > xDesktop( getServiceFactory()->createInstance( SERVICENAME_DESKTOP ), UNO_QUERY );
 | |
| 
 | |
|                 if ( xDesktop.is() )
 | |
|                 {
 | |
|                     USHORT nTaskId = START_ITEMID_WINDOWLIST;
 | |
|                     Reference< XIndexAccess > xList( xDesktop->getFrames(), UNO_QUERY );
 | |
|                     sal_Int32 nCount = xList->getCount();
 | |
|                     for ( sal_Int32 i=0; i<nCount; ++i )
 | |
|                     {
 | |
|                         Reference< XFrame > xFrame;
 | |
|                         xList->getByIndex(i) >>= xFrame;
 | |
| 
 | |
|                         if ( xFrame.is() && nTaskId == nCurItemId )
 | |
|                         {
 | |
|                             Window* pWin = VCLUnoHelper::GetWindow( xFrame->getContainerWindow() );
 | |
|                             pWin->GrabFocus();
 | |
|                             pWin->ToTop( TOTOP_RESTOREWHENMIN );
 | |
|                             break;
 | |
|                         }
 | |
| 
 | |
|                         nTaskId++;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 MenuItemHandler* pMenuItemHandler = GetMenuItemHandler( nCurItemId );
 | |
|                 if ( pMenuItemHandler && pMenuItemHandler->xMenuItemDispatch.is() )
 | |
|                 {
 | |
|                     aTargetURL.Complete = pMenuItemHandler->aMenuItemURL;
 | |
|                     m_xURLTransformer->parseStrict( aTargetURL );
 | |
| 
 | |
|                     if ( nCurItemId >= START_ITEMID_PICKLIST &&
 | |
|                          nCurItemId <  START_ITEMID_WINDOWLIST )
 | |
|                     {
 | |
|                         // picklist menu item selected
 | |
|                         CreatePicklistArguments( aArgs, pMenuItemHandler );
 | |
|                     }
 | |
|                     else if ( m_bIsBookmarkMenu )
 | |
|                     {
 | |
|                         // bookmark menu item selected
 | |
|                         aArgs.realloc( 1 );
 | |
|                         aArgs[0].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Referer" ));
 | |
|                         aArgs[0].Value <<= ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( SFX_REFERER_USER ));
 | |
|                     }
 | |
| 
 | |
|                     xDispatch = pMenuItemHandler->xMenuItemDispatch;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if ( xDispatch.is() )
 | |
|         xDispatch->dispatch( aTargetURL, aArgs );
 | |
| 
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| 
 | |
| IMPL_LINK( MenuManager, Highlight, Menu *, EMPTYARG )
 | |
| {
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| // #110897#
 | |
| const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& MenuManager::getServiceFactory()
 | |
| {
 | |
|     // #110897#
 | |
|     return mxServiceFactory;
 | |
| }
 | |
| 
 | |
| void MenuManager::AddMenu(PopupMenu* _pPopupMenu,const ::rtl::OUString& _sItemCommand,USHORT _nItemId,sal_Bool _bDelete,sal_Bool _bDeleteChildren)
 | |
| {
 | |
|     MenuManager* pSubMenuManager = new MenuManager( getServiceFactory(), m_xFrame, _pPopupMenu, _bDelete, _bDeleteChildren );
 | |
| 
 | |
|     // store menu item command as we later have to know which menu is active (see Activate handler)
 | |
|     pSubMenuManager->m_aMenuItemCommand = _sItemCommand;
 | |
| 
 | |
|     REFERENCE< XDISPATCH > aXDispatchRef;
 | |
|     MenuItemHandler* pMenuItemHandler = new MenuItemHandler(
 | |
|                                                 _nItemId,
 | |
|                                                 pSubMenuManager,
 | |
|                                                 aXDispatchRef );
 | |
|     m_aMenuItemHandlerVector.push_back( pMenuItemHandler );
 | |
| }
 | |
| 
 | |
| USHORT MenuManager::FillItemCommand(::rtl::OUString& _rItemCommand,Menu* _pMenu,USHORT _nIndex) const
 | |
| {
 | |
|     USHORT nItemId = _pMenu->GetItemId( _nIndex );
 | |
| 
 | |
|     _rItemCommand = _pMenu->GetItemCommand( nItemId );
 | |
|     if ( !_rItemCommand.getLength() )
 | |
|     {
 | |
|         const static ::rtl::OUString aSlotString( RTL_CONSTASCII_USTRINGPARAM( "slot:" ));
 | |
|         _rItemCommand = aSlotString;
 | |
|         _rItemCommand += ::rtl::OUString::valueOf( (sal_Int32)nItemId );
 | |
|         _pMenu->SetItemCommand( nItemId, _rItemCommand );
 | |
|     }
 | |
|     return nItemId;
 | |
| }
 | |
| void MenuManager::FillMenuImages(Reference< XFrame >& _xFrame,Menu* _pMenu,sal_Bool bShowMenuImages)
 | |
| {
 | |
|     AddonsOptions       aAddonOptions;
 | |
| 
 | |
|     for ( USHORT nPos = 0; nPos < _pMenu->GetItemCount(); nPos++ )
 | |
|     {
 | |
|         USHORT nId = _pMenu->GetItemId( nPos );
 | |
|         if ( _pMenu->GetItemType( nPos ) != MENUITEM_SEPARATOR )
 | |
|         {
 | |
|             bool bTmpShowMenuImages( bShowMenuImages );
 | |
|             // overwrite the show icons on menu option?
 | |
|             if (!bTmpShowMenuImages)
 | |
|             {
 | |
|                 MenuItemBits nBits =  _pMenu->GetItemBits( nId );
 | |
|                 bTmpShowMenuImages = ( ( nBits & MIB_ICON ) == MIB_ICON );
 | |
|             }
 | |
| 
 | |
|             if ( bTmpShowMenuImages )
 | |
|             {
 | |
|                 sal_Bool        bImageSet = sal_False;
 | |
|                 ::rtl::OUString aImageId;
 | |
| 
 | |
|                 ::framework::MenuConfiguration::Attributes* pMenuAttributes =
 | |
|                     (::framework::MenuConfiguration::Attributes*)_pMenu->GetUserValue( nId );
 | |
| 
 | |
|                 if ( pMenuAttributes )
 | |
|                     aImageId = pMenuAttributes->aImageId; // Retrieve image id from menu attributes
 | |
| 
 | |
|                 if ( aImageId.getLength() > 0 )
 | |
|                 {
 | |
|                     Image aImage = GetImageFromURL( _xFrame, aImageId, FALSE );
 | |
|                     if ( !!aImage )
 | |
|                     {
 | |
|                         bImageSet = sal_True;
 | |
|                         _pMenu->SetItemImage( nId, aImage );
 | |
|                     }
 | |
|                 }
 | |
| 
 | |
|                 if ( !bImageSet )
 | |
|                 {
 | |
|                     rtl::OUString aMenuItemCommand = _pMenu->GetItemCommand( nId );
 | |
|                     Image aImage = GetImageFromURL( _xFrame, aMenuItemCommand, FALSE );
 | |
|                     if ( !aImage )
 | |
|                         aImage = aAddonOptions.GetImageFromURL( aMenuItemCommand, FALSE );
 | |
| 
 | |
|                     _pMenu->SetItemImage( nId, aImage );
 | |
|                 }
 | |
|             }
 | |
|             else
 | |
|                 _pMenu->SetItemImage( nId, Image() );
 | |
|         }
 | |
|     }
 | |
| }
 | |
| }
 | |
| 
 | |
| /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
 |