NewMenuController: Fix template manager icon
The current logic is swapped. MenuAttributes::aImageId can be
only handled by SvFileInformationManager, while the menu item
command is what might be (in case of .uno command) handled
by CommandInfoProvider.
This gone wrong in tdf#96059 which wrongly assumed that
GetImageFromURL is equivalent to what's provided by
CommandInfoProvider (so other places should be checked too).
Change-Id: Ia487c602753dde3fb0d0462ef4b3d63209398b36
diff --git a/framework/source/uielement/newmenucontroller.cxx b/framework/source/uielement/newmenucontroller.cxx
index 09ca33e..e8963fd 100644
--- a/framework/source/uielement/newmenucontroller.cxx
+++ b/framework/source/uielement/newmenucontroller.cxx
@@ -72,7 +72,6 @@ DEFINE_INIT_SERVICE ( NewMenuController, {} )
void NewMenuController::setMenuImages( PopupMenu* pPopupMenu, bool bSetImages )
{
sal_uInt16 nItemCount = pPopupMenu->GetItemCount();
Image aImage;
Reference< XFrame > xFrame( m_xFrame );
for ( sal_uInt16 i = 0; i < nItemCount; i++ )
@@ -82,39 +81,23 @@ void NewMenuController::setMenuImages( PopupMenu* pPopupMenu, bool bSetImages )
{
if ( bSetImages )
{
bool bImageSet( false );
OUString aImageId;
OUString aCmd( pPopupMenu->GetItemCommand( nItemId ) );
sal_uLong nAttributePtr = pPopupMenu->GetUserValue(sal::static_int_cast<sal_uInt16>(i));
MenuAttributes* pAttributes = reinterpret_cast<MenuAttributes *>(nAttributePtr);
if (pAttributes)
aImageId = pAttributes->aImageId;
if ( !aImageId.isEmpty() )
{
aImage = vcl::CommandInfoProvider::Instance().GetImageForCommand(aImageId, xFrame);
if ( !!aImage )
{
bImageSet = true;
pPopupMenu->SetItemImage( nItemId, aImage );
}
}
INetURLObject aURLObj( aImageId.isEmpty() ? aCmd : aImageId );
Image aImage = SvFileInformationManager::GetImageNoDefault( aURLObj );
if ( !aImage )
aImage = vcl::CommandInfoProvider::Instance().GetImageForCommand(aCmd, xFrame);
if ( !bImageSet )
{
OUString aCmd( pPopupMenu->GetItemCommand( nItemId ) );
if ( !aCmd.isEmpty() )
{
INetURLObject aURLObj( aCmd );
aImage = SvFileInformationManager::GetImageNoDefault( aURLObj );
}
if ( !!aImage )
pPopupMenu->SetItemImage( nItemId, aImage );
}
if ( !!aImage )
pPopupMenu->SetItemImage( nItemId, aImage );
}
else
pPopupMenu->SetItemImage( nItemId, aImage );
pPopupMenu->SetItemImage( nItemId, Image() );
}
}
}