1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 // MARKER(update_precomp.py): autogen include statement, do not remove 25 #include "precompiled_sfx2.hxx" 26 #include <svl/stritem.hxx> 27 #include <svl/eitem.hxx> 28 #include <svl/whiter.hxx> 29 #include <vcl/msgbox.hxx> 30 #include <vcl/toolbox.hxx> 31 #include <svl/intitem.hxx> 32 #include <svtools/sfxecode.hxx> 33 #include <svtools/ehdl.hxx> 34 #include <com/sun/star/frame/XLayoutManager.hpp> 35 #include <com/sun/star/frame/XModuleManager.hpp> 36 #include <com/sun/star/beans/XPropertySet.hpp> 37 #include <com/sun/star/embed/EmbedStates.hpp> 38 #include <com/sun/star/embed/EmbedMisc.hpp> 39 #include <com/sun/star/system/SystemShellExecute.hpp> 40 #include <com/sun/star/system/SystemShellExecuteFlags.hpp> 41 #include <com/sun/star/container/XContainerQuery.hpp> 42 #include <com/sun/star/frame/XStorable.hpp> 43 #include <com/sun/star/datatransfer/clipboard/XClipboard.hpp> 44 #include <cppuhelper/implbase1.hxx> 45 46 #include <osl/file.hxx> 47 #include <vos/mutex.hxx> 48 #include <tools/urlobj.hxx> 49 #include <unotools/tempfile.hxx> 50 #include <unotools/pathoptions.hxx> 51 #include <svtools/miscopt.hxx> 52 #include <svtools/soerr.hxx> 53 #include <unotools/internaloptions.hxx> 54 55 #include <unotools/javaoptions.hxx> 56 #include <basic/basmgr.hxx> 57 #include <basic/sbuno.hxx> 58 #include <framework/actiontriggerhelper.hxx> 59 #include <comphelper/processfactory.hxx> 60 #include <comphelper/sequenceashashmap.hxx> 61 #include <toolkit/unohlp.hxx> 62 63 64 #include <sfx2/app.hxx> 65 #include "view.hrc" 66 #include <sfx2/viewsh.hxx> 67 #include "viewimp.hxx" 68 #include "sfx2/sfxresid.hxx" 69 #include <sfx2/request.hxx> 70 #include <sfx2/templdlg.hxx> 71 #include <sfx2/printer.hxx> 72 #include <sfx2/docfile.hxx> 73 #include <sfx2/dispatch.hxx> 74 #include "arrdecl.hxx" 75 #include <sfx2/docfac.hxx> 76 #include "view.hrc" 77 #include "sfxlocal.hrc" 78 #include <sfx2/sfxbasecontroller.hxx> 79 #include "sfx2/mailmodelapi.hxx" 80 #include <sfx2/viewfrm.hxx> 81 #include <sfx2/event.hxx> 82 #include <sfx2/fcontnr.hxx> 83 #include <sfx2/ipclient.hxx> 84 #include "workwin.hxx" 85 #include <sfx2/objface.hxx> 86 #include <sfx2/docfilt.hxx> 87 88 // #110897# 89 #ifndef _UNOTOOLS_PROCESSFACTORY_HXX 90 #include <comphelper/processfactory.hxx> 91 #endif 92 93 using namespace ::com::sun::star; 94 using namespace ::com::sun::star::uno; 95 using namespace ::com::sun::star::frame; 96 using namespace ::com::sun::star::beans; 97 using namespace ::com::sun::star::util; 98 using namespace ::com::sun::star::system; 99 using namespace ::cppu; 100 namespace css = ::com::sun::star; 101 102 //========================================================================= 103 DBG_NAME(SfxViewShell) 104 105 #define SfxViewShell 106 #include "sfxslots.hxx" 107 108 //========================================================================= 109 110 class SfxClipboardChangeListener : public ::cppu::WeakImplHelper1< 111 datatransfer::clipboard::XClipboardListener > 112 { 113 public: 114 SfxClipboardChangeListener( SfxViewShell* pView, const uno::Reference< datatransfer::clipboard::XClipboardNotifier >& xClpbrdNtfr ); 115 virtual ~SfxClipboardChangeListener(); 116 117 // XEventListener 118 virtual void SAL_CALL disposing( const lang::EventObject& rEventObject ) 119 throw ( uno::RuntimeException ); 120 121 // XClipboardListener 122 virtual void SAL_CALL changedContents( const datatransfer::clipboard::ClipboardEvent& rEventObject ) 123 throw ( uno::RuntimeException ); 124 125 void DisconnectViewShell() { m_pViewShell = NULL; } 126 void ChangedContents(); 127 128 enum AsyncExecuteCmd 129 { 130 ASYNCEXECUTE_CMD_DISPOSING, 131 ASYNCEXECUTE_CMD_CHANGEDCONTENTS 132 }; 133 134 struct AsyncExecuteInfo 135 { 136 AsyncExecuteInfo( AsyncExecuteCmd eCmd, uno::Reference< datatransfer::clipboard::XClipboardListener > xThis, SfxClipboardChangeListener* pListener ) : 137 m_eCmd( eCmd ), m_xThis( xThis ), m_pListener( pListener ) {} 138 139 AsyncExecuteCmd m_eCmd; 140 uno::Reference< datatransfer::clipboard::XClipboardListener > m_xThis; 141 SfxClipboardChangeListener* m_pListener; 142 }; 143 144 private: 145 SfxViewShell* m_pViewShell; 146 uno::Reference< datatransfer::clipboard::XClipboardNotifier > m_xClpbrdNtfr; 147 uno::Reference< lang::XComponent > m_xCtrl; 148 149 DECL_STATIC_LINK( SfxClipboardChangeListener, AsyncExecuteHdl_Impl, AsyncExecuteInfo* ); 150 }; 151 152 SfxClipboardChangeListener::SfxClipboardChangeListener( SfxViewShell* pView, const uno::Reference< datatransfer::clipboard::XClipboardNotifier >& xClpbrdNtfr ) 153 : m_pViewShell( 0 ), m_xClpbrdNtfr( xClpbrdNtfr ) 154 { 155 m_xCtrl = uno::Reference < lang::XComponent >( pView->GetController(), uno::UNO_QUERY ); 156 if ( m_xCtrl.is() ) 157 { 158 m_xCtrl->addEventListener( uno::Reference < lang::XEventListener > ( static_cast < lang::XEventListener* >( this ) ) ); 159 m_pViewShell = pView; 160 } 161 if ( m_xClpbrdNtfr.is() ) 162 { 163 m_xClpbrdNtfr->addClipboardListener( uno::Reference< datatransfer::clipboard::XClipboardListener >( 164 static_cast< datatransfer::clipboard::XClipboardListener* >( this ))); 165 } 166 } 167 168 SfxClipboardChangeListener::~SfxClipboardChangeListener() 169 { 170 } 171 172 void SfxClipboardChangeListener::ChangedContents() 173 { 174 const ::vos::OGuard aGuard( Application::GetSolarMutex() ); 175 if( m_pViewShell ) 176 { 177 SfxBindings& rBind = m_pViewShell->GetViewFrame()->GetBindings(); 178 rBind.Invalidate( SID_PASTE ); 179 rBind.Invalidate( SID_PASTE_SPECIAL ); 180 rBind.Invalidate( SID_CLIPBOARD_FORMAT_ITEMS ); 181 } 182 } 183 184 IMPL_STATIC_LINK_NOINSTANCE( SfxClipboardChangeListener, AsyncExecuteHdl_Impl, AsyncExecuteInfo*, pAsyncExecuteInfo ) 185 { 186 if ( pAsyncExecuteInfo ) 187 { 188 uno::Reference< datatransfer::clipboard::XClipboardListener > xThis( pAsyncExecuteInfo->m_xThis ); 189 if ( pAsyncExecuteInfo->m_pListener ) 190 { 191 if ( pAsyncExecuteInfo->m_eCmd == ASYNCEXECUTE_CMD_DISPOSING ) 192 pAsyncExecuteInfo->m_pListener->DisconnectViewShell(); 193 else if ( pAsyncExecuteInfo->m_eCmd == ASYNCEXECUTE_CMD_CHANGEDCONTENTS ) 194 pAsyncExecuteInfo->m_pListener->ChangedContents(); 195 } 196 } 197 delete pAsyncExecuteInfo; 198 199 return 0; 200 } 201 202 void SAL_CALL SfxClipboardChangeListener::disposing( const lang::EventObject& /*rEventObject*/ ) 203 throw ( uno::RuntimeException ) 204 { 205 // Either clipboard or ViewShell is going to be destroyed -> no interest in listening anymore 206 uno::Reference< lang::XComponent > xCtrl( m_xCtrl ); 207 uno::Reference< datatransfer::clipboard::XClipboardNotifier > xNotify( m_xClpbrdNtfr ); 208 209 uno::Reference< datatransfer::clipboard::XClipboardListener > xThis( static_cast< datatransfer::clipboard::XClipboardListener* >( this )); 210 if ( xCtrl.is() ) 211 xCtrl->removeEventListener( uno::Reference < lang::XEventListener > ( static_cast < lang::XEventListener* >( this ))); 212 if ( xNotify.is() ) 213 xNotify->removeClipboardListener( xThis ); 214 215 // Make asynchronous call to avoid locking SolarMutex which is the 216 // root for many deadlocks, especially in conjuction with the "Windows" 217 // based single thread apartment clipboard code! 218 AsyncExecuteInfo* pInfo = new AsyncExecuteInfo( ASYNCEXECUTE_CMD_DISPOSING, xThis, this ); 219 Application::PostUserEvent( STATIC_LINK( 0, SfxClipboardChangeListener, AsyncExecuteHdl_Impl ), pInfo ); 220 } 221 222 void SAL_CALL SfxClipboardChangeListener::changedContents( const datatransfer::clipboard::ClipboardEvent& ) 223 throw ( RuntimeException ) 224 { 225 // Make asynchronous call to avoid locking SolarMutex which is the 226 // root for many deadlocks, especially in conjuction with the "Windows" 227 // based single thread apartment clipboard code! 228 uno::Reference< datatransfer::clipboard::XClipboardListener > xThis( static_cast< datatransfer::clipboard::XClipboardListener* >( this )); 229 AsyncExecuteInfo* pInfo = new AsyncExecuteInfo( ASYNCEXECUTE_CMD_CHANGEDCONTENTS, xThis, this ); 230 Application::PostUserEvent( STATIC_LINK( 0, SfxClipboardChangeListener, AsyncExecuteHdl_Impl ), pInfo ); 231 } 232 233 //========================================================================= 234 235 static ::rtl::OUString RetrieveLabelFromCommand( 236 const ::rtl::OUString& rCommandURL, 237 const css::uno::Reference< css::frame::XFrame >& rFrame ) 238 { 239 static css::uno::WeakReference< frame::XModuleManager > s_xModuleManager; 240 static css::uno::WeakReference< container::XNameAccess > s_xNameAccess; 241 242 ::rtl::OUString aLabel; 243 css::uno::Reference< css::frame::XModuleManager > xModuleManager( s_xModuleManager ); 244 css::uno::Reference< css::container::XNameAccess > xNameAccess( s_xNameAccess ); 245 css::uno::Reference< css::lang::XMultiServiceFactory > xSMGR( 246 ::comphelper::getProcessServiceFactory(), css::uno::UNO_QUERY_THROW); 247 248 try 249 { 250 if ( !xModuleManager.is() ) 251 { 252 xModuleManager = css::uno::Reference< css::frame::XModuleManager >( 253 xSMGR->createInstance( 254 ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.frame.ModuleManager" ))), 255 css::uno::UNO_QUERY_THROW ); 256 s_xModuleManager = xModuleManager; 257 } 258 259 ::rtl::OUString aModuleIdentifier = xModuleManager->identify( rFrame ); 260 261 if ( !xNameAccess.is() ) 262 { 263 xNameAccess = css::uno::Reference< css::container::XNameAccess >( 264 xSMGR->createInstance( 265 ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.frame.UICommandDescription" ))), 266 css::uno::UNO_QUERY_THROW ); 267 s_xNameAccess = xNameAccess; 268 } 269 270 css::uno::Any a = xNameAccess->getByName( aModuleIdentifier ); 271 css::uno::Reference< css::container::XNameAccess > xUICommands; 272 a >>= xUICommands; 273 274 rtl::OUString aStr; 275 css::uno::Sequence< css::beans::PropertyValue > aPropSeq; 276 277 a = xUICommands->getByName( rCommandURL ); 278 if ( a >>= aPropSeq ) 279 { 280 for ( sal_Int32 i = 0; i < aPropSeq.getLength(); i++ ) 281 { 282 if ( aPropSeq[i].Name.equalsAscii( "Label" )) 283 { 284 aPropSeq[i].Value >>= aStr; 285 break; 286 } 287 } 288 aLabel = aStr; 289 } 290 } 291 catch ( css::uno::Exception& ) 292 { 293 } 294 295 return aLabel; 296 } 297 298 //========================================================================= 299 SfxViewShell_Impl::SfxViewShell_Impl(sal_uInt16 const nFlags) 300 : aInterceptorContainer( aMutex ) 301 , m_bControllerSet(false) 302 , m_nPrinterLocks(0) 303 , m_bCanPrint(SFX_VIEW_CAN_PRINT == (nFlags & SFX_VIEW_CAN_PRINT)) 304 , m_bHasPrintOptions( 305 SFX_VIEW_HAS_PRINTOPTIONS == (nFlags & SFX_VIEW_HAS_PRINTOPTIONS)) 306 , m_bPlugInsActive(true) 307 , m_bIsShowView(SFX_VIEW_NO_SHOW != (nFlags & SFX_VIEW_NO_SHOW)) 308 , m_bGotOwnership(false) 309 , m_bGotFrameOwnership(false) 310 , m_eScroll(SCROLLING_DEFAULT) 311 , m_nFamily(0xFFFF) // undefined, default set by TemplateDialog 312 , m_pController(0) 313 , m_pAccExec(0) 314 {} 315 316 //========================================================================= 317 SFX_IMPL_INTERFACE(SfxViewShell,SfxShell,SfxResId(0)) 318 { 319 SFX_CHILDWINDOW_REGISTRATION( SID_MAIL_CHILDWIN ); 320 } 321 322 TYPEINIT2(SfxViewShell,SfxShell,SfxListener); 323 324 //-------------------------------------------------------------------- 325 /** search for a filter name dependent on type and module 326 */ 327 328 static ::rtl::OUString impl_retrieveFilterNameFromTypeAndModule( 329 const css::uno::Reference< css::container::XContainerQuery >& rContainerQuery, 330 const ::rtl::OUString& rType, 331 const ::rtl::OUString& rModuleIdentifier, 332 const sal_Int32 nFlags ) 333 { 334 // Retrieve filter from type 335 css::uno::Sequence< css::beans::NamedValue > aQuery( 2 ); 336 aQuery[0].Name = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Type" )); 337 aQuery[0].Value = css::uno::makeAny( rType ); 338 aQuery[1].Name = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "DocumentService" )); 339 aQuery[1].Value = css::uno::makeAny( rModuleIdentifier ); 340 341 css::uno::Reference< css::container::XEnumeration > xEnumeration = 342 rContainerQuery->createSubSetEnumerationByProperties( aQuery ); 343 344 ::rtl::OUString aFoundFilterName; 345 while ( xEnumeration->hasMoreElements() ) 346 { 347 ::comphelper::SequenceAsHashMap aFilterPropsHM( xEnumeration->nextElement() ); 348 ::rtl::OUString aFilterName = aFilterPropsHM.getUnpackedValueOrDefault( 349 ::rtl::OUString::createFromAscii( "Name" ), 350 ::rtl::OUString() ); 351 352 sal_Int32 nFilterFlags = aFilterPropsHM.getUnpackedValueOrDefault( 353 ::rtl::OUString::createFromAscii( "Flags" ), 354 sal_Int32( 0 ) ); 355 356 if ( nFilterFlags & nFlags ) 357 { 358 aFoundFilterName = aFilterName; 359 break; 360 } 361 } 362 363 return aFoundFilterName; 364 } 365 366 //-------------------------------------------------------------------- 367 /** search for an internal typename, which map to the current app module 368 and map also to a "family" of file formats as e.g. PDF/MS Doc/OOo Doc. 369 */ 370 enum ETypeFamily 371 { 372 E_MS_DOC, 373 E_OOO_DOC 374 }; 375 376 ::rtl::OUString impl_searchFormatTypeForApp(const css::uno::Reference< css::frame::XFrame >& xFrame , 377 ETypeFamily eTypeFamily) 378 { 379 static ::rtl::OUString SERVICENAME_MODULEMANAGER = ::rtl::OUString::createFromAscii("com.sun.star.frame.ModuleManager"); 380 381 try 382 { 383 css::uno::Reference< css::lang::XMultiServiceFactory > xSMGR (::comphelper::getProcessServiceFactory() , css::uno::UNO_QUERY_THROW); 384 css::uno::Reference< css::frame::XModuleManager > xModuleManager(xSMGR->createInstance(SERVICENAME_MODULEMANAGER), css::uno::UNO_QUERY_THROW); 385 386 ::rtl::OUString sModule = xModuleManager->identify(xFrame); 387 ::rtl::OUString sType ; 388 389 switch(eTypeFamily) 390 { 391 case E_MS_DOC: 392 { 393 if (sModule.equalsAscii( "com.sun.star.text.TextDocument" )) 394 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "writer_MS_Word_97" )); 395 else 396 if (sModule.equalsAscii( "com.sun.star.sheet.SpreadsheetDocument" )) 397 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "calc_MS_Excel_97" )); 398 else 399 if (sModule.equalsAscii( "com.sun.star.drawing.DrawingDocument" )) 400 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "impress_MS_PowerPoint_97" )); 401 else 402 if (sModule.equalsAscii( "com.sun.star.presentation.PresentationDocument" )) 403 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "impress_MS_PowerPoint_97" )); 404 } 405 break; 406 407 case E_OOO_DOC: 408 { 409 if (sModule.equalsAscii( "com.sun.star.text.TextDocument" )) 410 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "writer8" )); 411 else 412 if (sModule.equalsAscii( "com.sun.star.sheet.SpreadsheetDocument" )) 413 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "calc8" )); 414 else 415 if (sModule.equalsAscii( "com.sun.star.drawing.DrawingDocument" )) 416 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "draw8" )); 417 else 418 if (sModule.equalsAscii( "com.sun.star.presentation.PresentationDocument" )) 419 sType = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "impress8" )); 420 } 421 break; 422 } 423 424 return sType; 425 } 426 catch(const css::uno::RuntimeException& exRun) 427 { throw exRun; } 428 catch(const css::uno::Exception&) 429 {} 430 431 return ::rtl::OUString(); 432 } 433 434 //-------------------------------------------------------------------- 435 436 void SfxViewShell::ExecMisc_Impl( SfxRequest &rReq ) 437 { 438 const sal_uInt16 nId = rReq.GetSlot(); 439 switch( nId ) 440 { 441 case SID_STYLE_FAMILY : 442 { 443 SFX_REQUEST_ARG(rReq, pItem, SfxUInt16Item, nId, sal_False); 444 if (pItem) 445 { 446 pImp->m_nFamily = pItem->GetValue(); 447 } 448 break; 449 } 450 451 case SID_STYLE_CATALOG: 452 { 453 SfxTemplateCatalog aCatalog( 454 SFX_APP()->GetTopWindow(), &GetViewFrame()->GetBindings()); 455 aCatalog.Execute(); 456 rReq.Ignore(); 457 break; 458 } 459 case SID_ACTIVATE_STYLE_APPLY: 460 { 461 com::sun::star::uno::Reference< com::sun::star::frame::XFrame > xFrame( 462 GetViewFrame()->GetFrame().GetFrameInterface(), 463 com::sun::star::uno::UNO_QUERY); 464 465 Reference< com::sun::star::beans::XPropertySet > xPropSet( xFrame, UNO_QUERY ); 466 Reference< ::com::sun::star::frame::XLayoutManager > xLayoutManager; 467 if ( xPropSet.is() ) 468 { 469 try 470 { 471 Any aValue = xPropSet->getPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "LayoutManager" ))); 472 aValue >>= xLayoutManager; 473 if ( xLayoutManager.is() ) 474 { 475 rtl::OUString aTextResString( RTL_CONSTASCII_USTRINGPARAM( "private:resource/toolbar/textobjectbar" )); 476 uno::Reference< ui::XUIElement > xElement = xLayoutManager->getElement( aTextResString ); 477 if(!xElement.is()) 478 { 479 rtl::OUString aFrameResString( RTL_CONSTASCII_USTRINGPARAM( "private:resource/toolbar/frameobjectbar" )); 480 xElement = xLayoutManager->getElement( aFrameResString ); 481 } 482 if(!xElement.is()) 483 { 484 rtl::OUString aOleResString( RTL_CONSTASCII_USTRINGPARAM( "private:resource/toolbar/oleobjectbar" )); 485 xElement = xLayoutManager->getElement( aOleResString ); 486 } 487 if(xElement.is()) 488 { 489 uno::Reference< awt::XWindow > xWin( xElement->getRealInterface(), uno::UNO_QUERY_THROW ); 490 Window* pWin = VCLUnoHelper::GetWindow( xWin ); 491 ToolBox* pTextToolbox = dynamic_cast< ToolBox* >( pWin ); 492 if( pTextToolbox ) 493 { 494 sal_uInt16 nItemCount = pTextToolbox->GetItemCount(); 495 for( sal_uInt16 nItem = 0; nItem < nItemCount; ++nItem ) 496 { 497 sal_uInt16 nItemId = pTextToolbox->GetItemId( nItem ); 498 const XubString& rCommand = pTextToolbox->GetItemCommand( nItemId ); 499 if( rCommand.EqualsAscii( ".uno:StyleApply" ) ) 500 { 501 Window* pItemWin = pTextToolbox->GetItemWindow( nItemId ); 502 if( pItemWin ) 503 pItemWin->GrabFocus(); 504 break; 505 } 506 } 507 } 508 } 509 } 510 } 511 catch ( Exception& ) 512 { 513 } 514 } 515 rReq.Done(); 516 } 517 break; 518 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 519 520 case SID_MAIL_SENDDOCASMS: 521 case SID_MAIL_SENDDOCASOOO: 522 case SID_MAIL_SENDDOCASPDF: 523 case SID_MAIL_SENDDOC: 524 case SID_MAIL_SENDDOCASFORMAT: 525 { 526 SfxObjectShell* pDoc = GetObjectShell(); 527 if ( pDoc && pDoc->QueryHiddenInformation( 528 WhenSaving, &GetViewFrame()->GetWindow() ) != RET_YES ) 529 break; 530 531 if ( SvtInternalOptions().MailUIEnabled() ) 532 { 533 GetViewFrame()->SetChildWindow( SID_MAIL_CHILDWIN, sal_True ); 534 } 535 else 536 { 537 SfxMailModel aModel; 538 rtl::OUString aDocType; 539 540 SFX_REQUEST_ARG(rReq, pMailSubject, SfxStringItem, SID_MAIL_SUBJECT, sal_False ); 541 if ( pMailSubject ) 542 aModel.SetSubject( pMailSubject->GetValue() ); 543 544 SFX_REQUEST_ARG(rReq, pMailRecipient, SfxStringItem, SID_MAIL_RECIPIENT, sal_False ); 545 if ( pMailRecipient ) 546 { 547 String aRecipient( pMailRecipient->GetValue() ); 548 String aMailToStr( String::CreateFromAscii( "mailto:" )); 549 550 if ( aRecipient.Search( aMailToStr ) == 0 ) 551 aRecipient = aRecipient.Erase( 0, aMailToStr.Len() ); 552 aModel.AddAddress( aRecipient, SfxMailModel::ROLE_TO ); 553 } 554 SFX_REQUEST_ARG(rReq, pMailDocType, SfxStringItem, SID_TYPE_NAME, sal_False ); 555 if ( pMailDocType ) 556 aDocType = pMailDocType->GetValue(); 557 558 uno::Reference < frame::XFrame > xFrame( pFrame->GetFrame().GetFrameInterface() ); 559 SfxMailModel::SendMailResult eResult = SfxMailModel::SEND_MAIL_ERROR; 560 561 if ( nId == SID_MAIL_SENDDOC ) 562 eResult = aModel.SaveAndSend( xFrame, rtl::OUString() ); 563 else 564 if ( nId == SID_MAIL_SENDDOCASPDF ) 565 eResult = aModel.SaveAndSend( xFrame, rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "pdf_Portable_Document_Format" ))); 566 else 567 if ( nId == SID_MAIL_SENDDOCASMS ) 568 { 569 aDocType = impl_searchFormatTypeForApp(xFrame, E_MS_DOC); 570 if (aDocType.getLength() > 0) 571 eResult = aModel.SaveAndSend( xFrame, aDocType ); 572 } 573 else 574 if ( nId == SID_MAIL_SENDDOCASOOO ) 575 { 576 aDocType = impl_searchFormatTypeForApp(xFrame, E_OOO_DOC); 577 if (aDocType.getLength() > 0) 578 eResult = aModel.SaveAndSend( xFrame, aDocType ); 579 } 580 581 if ( eResult == SfxMailModel::SEND_MAIL_ERROR ) 582 { 583 InfoBox aBox( SFX_APP()->GetTopWindow(), SfxResId( MSG_ERROR_SEND_MAIL )); 584 aBox.Execute(); 585 rReq.Ignore(); 586 } 587 else 588 rReq.Done(); 589 } 590 591 break; 592 } 593 594 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 595 case SID_WEBHTML: 596 { 597 static const char HTML_DOCUMENT_TYPE[] = "writer_web_HTML"; 598 static const char HTML_GRAPHIC_TYPE[] = "graphic_HTML"; 599 const sal_Int32 FILTERFLAG_EXPORT = 0x00000002; 600 601 css::uno::Reference< lang::XMultiServiceFactory > xSMGR(::comphelper::getProcessServiceFactory(), css::uno::UNO_QUERY_THROW); 602 css::uno::Reference < css::frame::XFrame > xFrame( pFrame->GetFrame().GetFrameInterface() ); 603 css::uno::Reference< css::frame::XModel > xModel; 604 605 const rtl::OUString aModuleManager( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.frame.ModuleManager" )); 606 css::uno::Reference< css::frame::XModuleManager > xModuleManager( xSMGR->createInstance( aModuleManager ), css::uno::UNO_QUERY_THROW ); 607 if ( !xModuleManager.is() ) 608 { 609 rReq.Done(sal_False); 610 return; 611 } 612 613 rtl::OUString aModule; 614 try 615 { 616 aModule = xModuleManager->identify( xFrame ); 617 } 618 catch ( css::uno::RuntimeException& ) 619 { 620 throw; 621 } 622 catch ( css::uno::Exception& ) 623 { 624 } 625 626 if ( xFrame.is() ) 627 { 628 css::uno::Reference< css::frame::XController > xController = xFrame->getController(); 629 if ( xController.is() ) 630 xModel = xController->getModel(); 631 } 632 633 // We need at least a valid module name and model reference 634 css::uno::Reference< css::frame::XStorable > xStorable( xModel, css::uno::UNO_QUERY ); 635 if ( xModel.is() && xStorable.is() ) 636 { 637 rtl::OUString aFilterName; 638 rtl::OUString aTypeName( RTL_CONSTASCII_USTRINGPARAM( HTML_DOCUMENT_TYPE )); 639 rtl::OUString aFileName; 640 rtl::OUString aExtension( RTL_CONSTASCII_USTRINGPARAM( "htm" )); 641 642 rtl::OUString aLocation = xStorable->getLocation(); 643 INetURLObject aFileObj( aLocation ); 644 645 bool bPrivateProtocol = ( aFileObj.GetProtocol() == INET_PROT_PRIV_SOFFICE ); 646 bool bHasLocation = ( aLocation.getLength() > 0 ) && !bPrivateProtocol; 647 648 css::uno::Reference< css::container::XContainerQuery > xContainerQuery( 649 xSMGR->createInstance( rtl::OUString( 650 RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.document.FilterFactory" ))), 651 css::uno::UNO_QUERY_THROW ); 652 653 // Retrieve filter from type 654 sal_Int32 nFilterFlags = FILTERFLAG_EXPORT; 655 aFilterName = impl_retrieveFilterNameFromTypeAndModule( xContainerQuery, aTypeName, aModule, nFilterFlags ); 656 if ( aFilterName.getLength() == 0 ) 657 { 658 // Draw/Impress uses a different type. 2nd chance try to use alternative type name 659 aFilterName = impl_retrieveFilterNameFromTypeAndModule( 660 xContainerQuery, ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( HTML_GRAPHIC_TYPE )), aModule, nFilterFlags ); 661 } 662 663 // No filter found => error 664 // No type and no location => error 665 if (( aFilterName.getLength() == 0 ) || ( aTypeName.getLength() == 0 )) 666 { 667 rReq.Done(sal_False); 668 return; 669 } 670 671 // Use provided save file name. If empty determine file name 672 if ( !bHasLocation ) 673 { 674 // Create a default file name with the correct extension 675 const rtl::OUString aPreviewFileName( RTL_CONSTASCII_USTRINGPARAM( "webpreview" )); 676 aFileName = aPreviewFileName; 677 } 678 else 679 { 680 // Determine file name from model 681 INetURLObject aFObj( xStorable->getLocation() ); 682 aFileName = aFObj.getName( INetURLObject::LAST_SEGMENT, true, INetURLObject::NO_DECODE ); 683 } 684 685 OSL_ASSERT( aFilterName.getLength() > 0 ); 686 OSL_ASSERT( aFileName.getLength() > 0 ); 687 688 // Creates a temporary directory to store our predefined file into it. 689 ::utl::TempFile aTempDir( NULL, sal_True ); 690 691 INetURLObject aFilePathObj( aTempDir.GetURL() ); 692 aFilePathObj.insertName( aFileName ); 693 aFilePathObj.setExtension( aExtension ); 694 695 rtl::OUString aFileURL = aFilePathObj.GetMainURL( INetURLObject::NO_DECODE ); 696 697 css::uno::Sequence< css::beans::PropertyValue > aArgs( 1 ); 698 aArgs[0].Name = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "FilterName" )); 699 aArgs[0].Value = css::uno::makeAny( aFilterName ); 700 701 // Store document in the html format 702 try 703 { 704 xStorable->storeToURL( aFileURL, aArgs ); 705 } 706 catch ( com::sun::star::io::IOException& ) 707 { 708 rReq.Done(sal_False); 709 return; 710 } 711 712 ::com::sun::star::uno::Reference< XSystemShellExecute > xSystemShellExecute( 713 com::sun::star::system::SystemShellExecute::create( 714 ::comphelper::getProcessComponentContext() ) ); 715 716 sal_Bool bRet( sal_True ); 717 if ( xSystemShellExecute.is() ) 718 { 719 try 720 { 721 xSystemShellExecute->execute( 722 aFileURL, ::rtl::OUString(), SystemShellExecuteFlags::DEFAULTS ); 723 } 724 catch ( uno::Exception& ) 725 { 726 vos::OGuard aGuard( Application::GetSolarMutex() ); 727 Window *pParent = SFX_APP()->GetTopWindow(); 728 ErrorBox( pParent, SfxResId( MSG_ERROR_NO_WEBBROWSER_FOUND )).Execute(); 729 bRet = sal_False; 730 } 731 } 732 733 rReq.Done(bRet); 734 break; 735 } 736 else 737 { 738 rReq.Done(sal_False); 739 return; 740 } 741 } 742 743 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 744 case SID_PLUGINS_ACTIVE: 745 { 746 SFX_REQUEST_ARG(rReq, pShowItem, SfxBoolItem, nId, sal_False); 747 bool const bActive = (pShowItem) 748 ? pShowItem->GetValue() 749 : !pImp->m_bPlugInsActive; 750 // ggf. recorden 751 if ( !rReq.IsAPI() ) 752 rReq.AppendItem( SfxBoolItem( nId, bActive ) ); 753 754 // Jetzt schon DONE aufrufen, da die Argumente evtl. einen Pool 755 // benutzen, der demn"achst weg ist 756 rReq.Done(sal_True); 757 758 // ausfuehren 759 if (!pShowItem || (bActive != pImp->m_bPlugInsActive)) 760 { 761 SfxFrame* pTopFrame = &GetFrame()->GetTopFrame(); 762 if ( pTopFrame != &GetFrame()->GetFrame() ) 763 { 764 // FramesetDocument 765 SfxViewShell *pShell = pTopFrame->GetCurrentViewFrame()->GetViewShell(); 766 if ( pShell->GetInterface()->GetSlot( nId ) ) 767 pShell->ExecuteSlot( rReq ); 768 break; 769 } 770 771 SfxFrameIterator aIter( *pTopFrame ); 772 while ( pTopFrame ) 773 { 774 if ( pTopFrame->GetCurrentViewFrame() ) 775 { 776 SfxViewShell *pView = pTopFrame->GetCurrentViewFrame()->GetViewShell(); 777 if ( pView ) 778 { 779 pView->pImp->m_bPlugInsActive = bActive; 780 Rectangle aVisArea = GetObjectShell()->GetVisArea(); 781 VisAreaChanged(aVisArea); 782 783 // the plugins might need change in their state 784 SfxInPlaceClientList *pClients = pView->GetIPClientList_Impl(sal_False); 785 if ( pClients ) 786 { 787 for (sal_uInt16 n=0; n < pClients->Count(); n++) 788 { 789 SfxInPlaceClient* pIPClient = pClients->GetObject(n); 790 if ( pIPClient ) 791 pView->CheckIPClient_Impl( pIPClient, aVisArea ); 792 } 793 } 794 } 795 } 796 797 if ( !pTopFrame->GetParentFrame() ) 798 pTopFrame = aIter.FirstFrame(); 799 else 800 pTopFrame = aIter.NextFrame( *pTopFrame ); 801 } 802 } 803 804 break; 805 } 806 } 807 } 808 809 //-------------------------------------------------------------------- 810 811 void SfxViewShell::GetState_Impl( SfxItemSet &rSet ) 812 { 813 DBG_CHKTHIS(SfxViewShell, 0); 814 815 SfxWhichIter aIter( rSet ); 816 for ( sal_uInt16 nSID = aIter.FirstWhich(); nSID; nSID = aIter.NextWhich() ) 817 { 818 switch ( nSID ) 819 { 820 case SID_STYLE_CATALOG: 821 { 822 if ( !GetViewFrame()->KnowsChildWindow( SID_STYLE_DESIGNER ) ) 823 rSet.DisableItem( nSID ); 824 break; 825 } 826 827 // Printer-Funktionen 828 case SID_PRINTDOC: 829 case SID_PRINTDOCDIRECT: 830 case SID_SETUPPRINTER: 831 case SID_PRINTER_NAME: 832 { 833 bool bEnabled = pImp->m_bCanPrint && !pImp->m_nPrinterLocks; 834 bEnabled = bEnabled && !Application::GetSettings().GetMiscSettings().GetDisablePrinting(); 835 if ( bEnabled ) 836 { 837 SfxPrinter *pPrinter = GetPrinter(sal_False); 838 839 if ( SID_PRINTDOCDIRECT == nSID ) 840 { 841 rtl::OUString aPrinterName; 842 if ( pPrinter != NULL ) 843 aPrinterName = pPrinter->GetName(); 844 else 845 aPrinterName = Printer::GetDefaultPrinterName(); 846 if ( aPrinterName.getLength() > 0 ) 847 { 848 uno::Reference < frame::XFrame > xFrame( pFrame->GetFrame().GetFrameInterface() ); 849 850 ::rtl::OUStringBuffer aBuffer( 60 ); 851 aBuffer.append( RetrieveLabelFromCommand( 852 ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( ".uno:PrintDefault" )), 853 xFrame )); 854 aBuffer.appendAscii( " (" ); 855 aBuffer.append( aPrinterName ); 856 aBuffer.appendAscii( ")" ); 857 858 rSet.Put( SfxStringItem( SID_PRINTDOCDIRECT, aBuffer.makeStringAndClear() ) ); 859 } 860 } 861 bEnabled = !pPrinter || !pPrinter->IsPrinting(); 862 } 863 if ( !bEnabled ) 864 { 865 // will now be handled by requeing the request 866 /* rSet.DisableItem( SID_PRINTDOC ); 867 rSet.DisableItem( SID_PRINTDOCDIRECT ); 868 rSet.DisableItem( SID_SETUPPRINTER ); */ 869 } 870 break; 871 } 872 873 // Mail-Funktionen 874 case SID_MAIL_SENDDOCASPDF: 875 case SID_MAIL_SENDDOC: 876 case SID_MAIL_SENDDOCASFORMAT: 877 { 878 sal_Bool bEnable = !GetViewFrame()->HasChildWindow( SID_MAIL_CHILDWIN ); 879 if ( !bEnable ) 880 rSet.DisableItem( nSID ); 881 break; 882 } 883 884 // PlugIns running 885 case SID_PLUGINS_ACTIVE: 886 { 887 rSet.Put( SfxBoolItem( SID_PLUGINS_ACTIVE, 888 !pImp->m_bPlugInsActive) ); 889 break; 890 } 891 /* 892 // SelectionText 893 case SID_SELECTION_TEXT: 894 { 895 rSet.Put( SfxStringItem( SID_SELECTION_TEXT, GetSelectionText() ) ); 896 break; 897 } 898 899 // SelectionTextExt 900 case SID_SELECTION_TEXT_EXT: 901 { 902 rSet.Put( SfxStringItem( SID_SELECTION_TEXT_EXT, GetSelectionText(sal_True) ) ); 903 break; 904 } 905 */ 906 case SID_STYLE_FAMILY : 907 { 908 rSet.Put( SfxUInt16Item( SID_STYLE_FAMILY, pImp->m_nFamily ) ); 909 break; 910 } 911 } 912 } 913 } 914 915 //-------------------------------------------------------------------- 916 917 void SfxViewShell::SetZoomFactor( const Fraction &rZoomX, 918 const Fraction &rZoomY ) 919 { 920 DBG_ASSERT( GetWindow(), "no window" ); 921 MapMode aMap( GetWindow()->GetMapMode() ); 922 aMap.SetScaleX( rZoomX ); 923 aMap.SetScaleY( rZoomY ); 924 GetWindow()->SetMapMode( aMap ); 925 } 926 927 //-------------------------------------------------------------------- 928 ErrCode SfxViewShell::DoVerb(long /*nVerb*/) 929 930 /* [Beschreibung] 931 932 Virtuelle Methode, um am selektierten Objekt ein Verb auszuf"uhren. 933 Da dieses Objekt nur den abgeleiteten Klassen bekannt ist, muss DoVerb 934 dort "uberschrieben werden. 935 936 */ 937 938 { 939 return ERRCODE_SO_NOVERBS; 940 } 941 942 //-------------------------------------------------------------------- 943 944 void SfxViewShell::OutplaceActivated( sal_Bool bActive, SfxInPlaceClient* /*pClient*/ ) 945 { 946 if ( !bActive ) 947 GetFrame()->GetFrame().Appear(); 948 } 949 950 //-------------------------------------------------------------------- 951 952 void SfxViewShell::InplaceActivating( SfxInPlaceClient* /*pClient*/ ) 953 { 954 // TODO/LATER: painting of the bitmap can be stopped, it is required if CLIPCHILDREN problem #i25788# is not solved, 955 // but may be the bug will not affect the real office vcl windows, then it is not required 956 } 957 958 //-------------------------------------------------------------------- 959 960 void SfxViewShell::InplaceDeactivated( SfxInPlaceClient* /*pClient*/ ) 961 { 962 // TODO/LATER: paint the replacement image in normal way if the painting was stopped 963 } 964 965 //-------------------------------------------------------------------- 966 967 void SfxViewShell::UIActivating( SfxInPlaceClient* /*pClient*/ ) 968 { 969 uno::Reference < frame::XFrame > xOwnFrame( pFrame->GetFrame().GetFrameInterface() ); 970 uno::Reference < frame::XFramesSupplier > xParentFrame( xOwnFrame->getCreator(), uno::UNO_QUERY ); 971 if ( xParentFrame.is() ) 972 xParentFrame->setActiveFrame( xOwnFrame ); 973 974 pFrame->GetBindings().HidePopups(sal_True); 975 pFrame->GetDispatcher()->Update_Impl( sal_True ); 976 } 977 978 //-------------------------------------------------------------------- 979 980 void SfxViewShell::UIDeactivated( SfxInPlaceClient* /*pClient*/ ) 981 { 982 if ( !pFrame->GetFrame().IsClosing_Impl() || 983 SfxViewFrame::Current() != pFrame ) 984 pFrame->GetDispatcher()->Update_Impl( sal_True ); 985 pFrame->GetBindings().HidePopups(sal_False); 986 987 // uno::Reference < frame::XFrame > xOwnFrame( pFrame->GetFrame().GetFrameInterface() ); 988 // uno::Reference < frame::XFramesSupplier > xParentFrame( xOwnFrame->getCreator(), uno::UNO_QUERY ); 989 // if ( xParentFrame.is() ) 990 // xParentFrame->setActiveFrame( uno::Reference < frame::XFrame >() ); 991 } 992 993 //-------------------------------------------------------------------- 994 995 SfxInPlaceClient* SfxViewShell::FindIPClient 996 ( 997 const uno::Reference < embed::XEmbeddedObject >& xObj, 998 Window* pObjParentWin 999 ) const 1000 { 1001 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1002 if ( !pClients ) 1003 return 0; 1004 1005 if( !pObjParentWin ) 1006 pObjParentWin = GetWindow(); 1007 for (sal_uInt16 n=0; n < pClients->Count(); n++) 1008 { 1009 SfxInPlaceClient *pIPClient = (SfxInPlaceClient*) pClients->GetObject(n); 1010 if ( pIPClient->GetObject() == xObj && pIPClient->GetEditWin() == pObjParentWin ) 1011 return pIPClient; 1012 } 1013 1014 return 0; 1015 } 1016 1017 //-------------------------------------------------------------------- 1018 1019 SfxInPlaceClient* SfxViewShell::GetIPClient() const 1020 { 1021 return GetUIActiveClient(); 1022 } 1023 1024 //-------------------------------------------------------------------- 1025 1026 SfxInPlaceClient* SfxViewShell::GetUIActiveIPClient_Impl() const 1027 { 1028 // this method is needed as long as SFX still manages the border space for ChildWindows (see SfxFrame::Resize) 1029 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1030 if ( !pClients ) 1031 return 0; 1032 1033 for (sal_uInt16 n=0; n < pClients->Count(); n++) 1034 { 1035 SfxInPlaceClient* pIPClient = pClients->GetObject(n); 1036 if ( pIPClient->IsUIActive() ) 1037 return pIPClient; 1038 } 1039 1040 return NULL; 1041 } 1042 1043 SfxInPlaceClient* SfxViewShell::GetUIActiveClient() const 1044 { 1045 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1046 if ( !pClients ) 1047 return 0; 1048 1049 for (sal_uInt16 n=0; n < pClients->Count(); n++) 1050 { 1051 SfxInPlaceClient* pIPClient = pClients->GetObject(n); 1052 if ( pIPClient->IsObjectUIActive() ) 1053 return pIPClient; 1054 } 1055 1056 return NULL; 1057 } 1058 1059 //-------------------------------------------------------------------- 1060 1061 void SfxViewShell::Activate( sal_Bool bMDI ) 1062 { 1063 DBG_CHKTHIS(SfxViewShell, 0); 1064 if ( bMDI ) 1065 { 1066 SfxObjectShell *pSh = GetViewFrame()->GetObjectShell(); 1067 if ( pSh->GetModel().is() ) 1068 pSh->GetModel()->setCurrentController( GetViewFrame()->GetFrame().GetController() ); 1069 1070 SetCurrentDocument(); 1071 } 1072 } 1073 1074 //-------------------------------------------------------------------- 1075 1076 void SfxViewShell::Deactivate(sal_Bool /*bMDI*/) 1077 { 1078 DBG_CHKTHIS(SfxViewShell, 0); 1079 } 1080 1081 //-------------------------------------------------------------------- 1082 1083 void SfxViewShell::AdjustPosSizePixel 1084 ( 1085 const Point& /*rToolOffset*/,// linke obere Ecke der Tools im Frame-Window 1086 const Size& /*rSize*/ // gesamte zur Verf"ugung stehende Gr"o\se 1087 ) 1088 1089 { 1090 DBG_CHKTHIS(SfxViewShell, 0); 1091 } 1092 1093 //-------------------------------------------------------------------- 1094 1095 void SfxViewShell::Move() 1096 1097 /* [Beschreibung] 1098 1099 Diese virtuelle Methode wird gerufen, wenn das Fenster, in dem die 1100 SfxViewShell dargestellt wird eine StarView-Move() Nachricht erh"alt. 1101 1102 Die Basisimplementierung braucht nicht gerufen zu werden. 1103 1104 1105 [Anmerkung] 1106 1107 Diese Methode kann dazu verwendet werden, eine Selektion abzubrechen, 1108 um durch das Moven des Fensters erzeugte Maus-Bewegungen anzufangen. 1109 1110 Zur Zeit funktioniert die Benachrichtigung nicht In-Place. 1111 */ 1112 1113 { 1114 } 1115 1116 //-------------------------------------------------------------------- 1117 1118 void SfxViewShell::OuterResizePixel 1119 ( 1120 const Point& /*rToolOffset*/,// linke obere Ecke der Tools im Frame-Window 1121 const Size& /*rSize*/ // gesamte zur Verf"ugung stehende Gr"o\se 1122 ) 1123 1124 /* [Beschreibung] 1125 1126 Diese Methode muss ueberladen werden, um auf "Anderungen der Groesse 1127 der View zu reagieren. Dabei definieren wir die View als das Edit-Window 1128 zuz"uglich der um das Edit-Window angeordnenten Tools (z.B. Lineale). 1129 1130 Das Edit-Window darf weder in Gr"o\se noch Position ver"andert werden. 1131 1132 Die Vis-Area der SfxObjectShell, dessen Skalierung und Position 1133 d"urfen hier ver"andert werden. Der Hauptanwendungsfall ist dabei, 1134 das Ver"andern der Gr"o\se der Vis-Area. 1135 1136 "Andert sich durch die neue Berechnung der Border, so mu\s dieser 1137 mit <SfxViewShell::SetBorderPixel(const SvBorder&)> gesetzt werden. 1138 Erst nach Aufruf von 'SetBorderPixel' ist das Positionieren von 1139 Tools erlaubt. 1140 1141 1142 [Beispiel] 1143 1144 void AppViewSh::OuterViewResizePixel( const Point &rOfs, const Size &rSz ) 1145 { 1146 // Tool-Positionen und Gr"o\sen von au\sen berechnen, NICHT setzen! 1147 // (wegen folgender Border-Berechnung) 1148 Point aHLinPos...; Size aHLinSz...; 1149 ... 1150 1151 // Border f"ur Tools passend zu rSize berechnen und setzen 1152 SvBorder aBorder... 1153 SetBorderPixel( aBorder ); // ab jetzt sind Positionierungen erlaubt 1154 1155 // Tools anordnen 1156 pHLin->SetPosSizePixel( aHLinPos, aHLinSz ); 1157 ... 1158 } 1159 1160 1161 [Querverweise] 1162 1163 <SfxViewShell::InnerResizePixel(const Point&,const Size& rSize)> 1164 */ 1165 1166 { 1167 DBG_CHKTHIS(SfxViewShell, 0); 1168 SetBorderPixel( SvBorder() ); 1169 } 1170 1171 //-------------------------------------------------------------------- 1172 1173 void SfxViewShell::InnerResizePixel 1174 ( 1175 const Point& /*rToolOffset*/,// linke obere Ecke der Tools im Frame-Window 1176 const Size& /*rSize*/ // dem Edit-Win zur Verf"ugung stehende Gr"o\se 1177 ) 1178 1179 /* [Beschreibung] 1180 1181 Diese Methode muss ueberladen werden, um auf "Anderungen der Groesse 1182 des Edit-Windows zu reagieren. 1183 1184 Das Edit-Window darf weder in Gr"o\se noch Position ver"andert werden. 1185 Weder die Vis-Area der SfxObjectShell noch dessen Skalierung oder 1186 Position d"urfen ver"andert werden. 1187 1188 "Andert sich durch die neue Berechnung der Border, so mu\s dieser 1189 mit <SfxViewShell::SetBorderPixel(const SvBorder&)> gesetzt werden. 1190 Erst nach Aufruf von 'SetBorderPixel' ist das Positionieren von 1191 Tools erlaubt. 1192 1193 1194 [Beispiel] 1195 1196 void AppViewSh::InnerViewResizePixel( const Point &rOfs, const Size &rSz ) 1197 { 1198 // Tool-Positionen und Gr"o\sen von innen berechnen, NICHT setzen! 1199 // (wegen folgender Border-Berechnung) 1200 Point aHLinPos...; Size aHLinSz...; 1201 ... 1202 1203 // Border f"ur Tools passend zu rSz berechnen und setzen 1204 SvBorder aBorder... 1205 SetBorderPixel( aBorder ); // ab jetzt sind Positionierungen erlaubt 1206 1207 // Tools anordnen 1208 pHLin->SetPosSizePixel( aHLinPos, aHLinSz ); 1209 ... 1210 } 1211 1212 1213 [Querverweise] 1214 1215 <SfxViewShell::OuterResizePixel(const Point&,const Size& rSize)> 1216 */ 1217 1218 { 1219 DBG_CHKTHIS(SfxViewShell, 0); 1220 SetBorderPixel( SvBorder() ); 1221 } 1222 1223 //-------------------------------------------------------------------- 1224 1225 void SfxViewShell::InvalidateBorder() 1226 { 1227 DBG_CHKTHIS(SfxViewShell, 0); 1228 DBG_ASSERT( GetViewFrame(), "SfxViewShell without SfxViewFrame" ); 1229 1230 GetViewFrame()->InvalidateBorderImpl( this ); 1231 if (pImp->m_pController.is()) 1232 { 1233 pImp->m_pController->BorderWidthsChanged_Impl(); 1234 } 1235 } 1236 1237 //-------------------------------------------------------------------- 1238 1239 void SfxViewShell::SetBorderPixel( const SvBorder &rBorder ) 1240 { 1241 DBG_CHKTHIS(SfxViewShell, 0); 1242 DBG_ASSERT( GetViewFrame(), "SfxViewShell without SfxViewFrame" ); 1243 1244 //if ( rBorder != GetBorderPixel()) 1245 { 1246 GetViewFrame()->SetBorderPixelImpl( this, rBorder ); 1247 1248 // notify related controller that border size is changed 1249 if (pImp->m_pController.is()) 1250 { 1251 pImp->m_pController->BorderWidthsChanged_Impl(); 1252 } 1253 } 1254 } 1255 1256 //-------------------------------------------------------------------- 1257 1258 const SvBorder& SfxViewShell::GetBorderPixel() const 1259 { 1260 DBG_CHKTHIS(SfxViewShell, 0); 1261 DBG_ASSERT( GetViewFrame(), "SfxViewShell without SfxViewFrame" ); 1262 1263 return GetViewFrame()->GetBorderPixelImpl( this ); 1264 } 1265 1266 //-------------------------------------------------------------------- 1267 1268 void SfxViewShell::SetWindow 1269 ( 1270 Window* pViewPort // Pointer auf das Datenfenster bzw. 0 im Destruktor 1271 ) 1272 1273 /* [Beschreibung] 1274 1275 Mit dieser Methode wird der SfxViewShell das Datenfenster mitgeteilt. 1276 Dieses wird f"ur den In-Place-Container und f"ur das korrekte 1277 Wiederherstellen des Focus ben"otigt. 1278 1279 Selbst In-Place-aktiv ist das Umsetzen des ViewPort-Windows verboten. 1280 */ 1281 1282 { 1283 if( pWindow == pViewPort ) 1284 return; 1285 1286 // ggf. vorhandene IP-Clients disconnecten 1287 DisconnectAllClients(); 1288 1289 //TODO: should we have a "ReconnectAllClients" method? 1290 DiscardClients_Impl(); 1291 1292 // View-Port austauschen 1293 sal_Bool bHadFocus = pWindow ? pWindow->HasChildPathFocus( sal_True ) : sal_False; 1294 pWindow = pViewPort; 1295 1296 if( pWindow ) 1297 { 1298 // Disable automatic GUI mirroring (right-to-left) for document windows 1299 pWindow->EnableRTL( sal_False ); 1300 } 1301 1302 if ( bHadFocus && pWindow ) 1303 pWindow->GrabFocus(); 1304 //TODO/CLEANUP 1305 //brauchen wir die Methode doch noch?! 1306 //SFX_APP()->GrabFocus( pWindow ); 1307 } 1308 1309 //-------------------------------------------------------------------- 1310 1311 Size SfxViewShell::GetOptimalSizePixel() const 1312 { 1313 DBG_ERROR( "Useless call!" ); 1314 return Size(); 1315 } 1316 1317 //------------------------------------------------------------------------ 1318 1319 SfxViewShell::SfxViewShell 1320 ( 1321 SfxViewFrame* pViewFrame, /* <SfxViewFrame>, in dem diese View dargestellt wird */ 1322 sal_uInt16 nFlags /* siehe <SfxViewShell-Flags> */ 1323 ) 1324 1325 : SfxShell(this) 1326 , pImp( new SfxViewShell_Impl(nFlags) ) 1327 ,pIPClientList( 0 ) 1328 ,pFrame(pViewFrame) 1329 ,pSubShell(0) 1330 ,pWindow(0) 1331 ,bNoNewWindow( 0 != (nFlags & SFX_VIEW_NO_NEWWINDOW) ) 1332 { 1333 DBG_CTOR(SfxViewShell, 0); 1334 1335 //pImp->pPrinterCommandQueue = new SfxAsyncPrintExec_Impl( this ); 1336 1337 if ( pViewFrame->GetParentViewFrame() ) 1338 { 1339 pImp->m_bPlugInsActive = pViewFrame->GetParentViewFrame() 1340 ->GetViewShell()->pImp->m_bPlugInsActive; 1341 } 1342 SetMargin( pViewFrame->GetMargin_Impl() ); 1343 1344 SetPool( &pViewFrame->GetObjectShell()->GetPool() ); 1345 StartListening(*pViewFrame->GetObjectShell()); 1346 1347 // in Liste eintragen 1348 const SfxViewShell *pThis = this; // wegen der kranken Array-Syntax 1349 SfxViewShellArr_Impl &rViewArr = SFX_APP()->GetViewShells_Impl(); 1350 rViewArr.Insert(pThis, rViewArr.Count() ); 1351 } 1352 1353 //-------------------------------------------------------------------- 1354 1355 SfxViewShell::~SfxViewShell() 1356 { 1357 DBG_DTOR(SfxViewShell, 0); 1358 1359 // aus Liste austragen 1360 const SfxViewShell *pThis = this; 1361 SfxViewShellArr_Impl &rViewArr = SFX_APP()->GetViewShells_Impl(); 1362 rViewArr.Remove( rViewArr.GetPos(pThis) ); 1363 1364 if ( pImp->xClipboardListener.is() ) 1365 { 1366 pImp->xClipboardListener->DisconnectViewShell(); 1367 pImp->xClipboardListener = NULL; 1368 } 1369 1370 if (pImp->m_pController.is()) 1371 { 1372 pImp->m_pController->ReleaseShell_Impl(); 1373 pImp->m_pController.clear(); 1374 } 1375 1376 //DELETEZ( pImp->pPrinterCommandQueue ); 1377 DELETEZ( pImp ); 1378 DELETEZ( pIPClientList ); 1379 } 1380 1381 //-------------------------------------------------------------------- 1382 1383 sal_uInt16 SfxViewShell::PrepareClose 1384 ( 1385 sal_Bool bUI, // sal_True: Dialoge etc. erlaubt, sal_False: silent-mode 1386 sal_Bool /*bForBrowsing*/ 1387 ) 1388 { 1389 SfxPrinter *pPrinter = GetPrinter(); 1390 if ( pPrinter && pPrinter->IsPrinting() ) 1391 { 1392 if ( bUI ) 1393 { 1394 InfoBox aInfoBox( &GetViewFrame()->GetWindow(), SfxResId( MSG_CANT_CLOSE ) ); 1395 aInfoBox.Execute(); 1396 } 1397 1398 return sal_False; 1399 } 1400 1401 if( GetViewFrame()->IsInModalMode() ) 1402 return sal_False; 1403 1404 if( bUI && GetViewFrame()->GetDispatcher()->IsLocked() ) 1405 return sal_False; 1406 1407 return sal_True; 1408 } 1409 1410 //-------------------------------------------------------------------- 1411 1412 SfxViewShell* SfxViewShell::Current() 1413 { 1414 SfxViewFrame *pCurrent = SfxViewFrame::Current(); 1415 return pCurrent ? pCurrent->GetViewShell() : NULL; 1416 } 1417 1418 //-------------------------------------------------------------------- 1419 1420 SfxViewShell* SfxViewShell::Get( const Reference< XController>& i_rController ) 1421 { 1422 if ( !i_rController.is() ) 1423 return NULL; 1424 1425 for ( SfxViewShell* pViewShell = SfxViewShell::GetFirst( NULL, sal_False ); 1426 pViewShell; 1427 pViewShell = SfxViewShell::GetNext( *pViewShell, NULL, sal_False ) 1428 ) 1429 { 1430 if ( pViewShell->GetController() == i_rController ) 1431 return pViewShell; 1432 } 1433 return NULL; 1434 } 1435 1436 //-------------------------------------------------------------------- 1437 1438 SdrView* SfxViewShell::GetDrawView() const 1439 1440 /* [Beschreibung] 1441 1442 Diese virtuelle Methode mu\s von den Subklassen "uberladen werden, wenn 1443 der Property-Editor zur Verf"ugung stehen soll. 1444 1445 Die Default-Implementierung liefert immer 0. 1446 */ 1447 1448 { 1449 return 0; 1450 } 1451 1452 //-------------------------------------------------------------------- 1453 1454 String SfxViewShell::GetSelectionText 1455 ( 1456 sal_Bool /*bCompleteWords*/ /* sal_False (default) 1457 Nur der tats"achlich selektierte Text wird 1458 zur"uckgegeben. 1459 1460 TRUE 1461 Der selektierte Text wird soweit erweitert, 1462 da\s nur ganze W"orter zur"uckgegeben werden. 1463 Als Worttrenner gelten White-Spaces und die 1464 Satzzeichen ".,;" sowie einfache und doppelte 1465 Anf"uhrungszeichen. 1466 */ 1467 ) 1468 1469 /* [Beschreibung] 1470 1471 Diese Methode kann von Anwendungsprogrammierer "uberladen werden, 1472 um einen Text zur"uckzuliefern, der in der aktuellen Selektion 1473 steht. Dieser wird z.B. beim Versenden (email) verwendet. 1474 1475 Mit "CompleteWords == TRUE" ger"ufen, reicht z.B. auch der Cursor, 1476 der in einer URL steht, um die gesamte URL zu liefern. 1477 */ 1478 1479 { 1480 return String(); 1481 } 1482 1483 //-------------------------------------------------------------------- 1484 1485 sal_Bool SfxViewShell::HasSelection( sal_Bool ) const 1486 1487 /* [Beschreibung] 1488 1489 Mit dieser virtuellen Methode kann z.B. ein Dialog abfragen, ob in der 1490 aktuellen View etwas selektiert ist. Wenn der Parameter <sal_Bool> sal_True ist, 1491 wird abgefragt, ob Text selektiert ist. 1492 */ 1493 1494 { 1495 return sal_False; 1496 } 1497 1498 //-------------------------------------------------------------------- 1499 1500 void SfxViewShell::SetSubShell( SfxShell *pShell ) 1501 1502 /* [Beschreibung] 1503 1504 Mit dieser Methode kann eine Selektions- oder Cursor-Shell angemeldet 1505 werden, die automatisch unmittelbar nach der SfxViewShell auf den 1506 SfxDispatcher gepusht wird, und automatisch umittelbar vor ihr 1507 gepoppt wird. 1508 1509 Ist die SfxViewShell-Instanz bereits gepusht, dann wird pShell 1510 sofort ebenfalls gepusht. Wird mit SetSubShell eine andere SfxShell 1511 Instanz angemeldet, als vorher angemeldet war, wird die zuvor angemeldete 1512 ggf. automatisch gepoppt. Mit pShell==0 kann daher die aktuelle 1513 Sub-Shell abgemeldet werden. 1514 */ 1515 1516 { 1517 // ist diese ViewShell "uberhaupt aktiv? 1518 SfxDispatcher *pDisp = pFrame->GetDispatcher(); 1519 if ( pDisp->IsActive(*this) ) 1520 { 1521 // Dispatcher updaten 1522 if ( pSubShell ) 1523 pDisp->Pop(*pSubShell); 1524 if ( pShell ) 1525 pDisp->Push(*pShell); 1526 pDisp->Flush(); 1527 } 1528 1529 pSubShell = pShell; 1530 } 1531 1532 void SfxViewShell::AddSubShell( SfxShell& rShell ) 1533 { 1534 pImp->aArr.Insert( &rShell, pImp->aArr.Count() ); 1535 SfxDispatcher *pDisp = pFrame->GetDispatcher(); 1536 if ( pDisp->IsActive(*this) ) 1537 { 1538 pDisp->Push(rShell); 1539 pDisp->Flush(); 1540 } 1541 } 1542 1543 void SfxViewShell::RemoveSubShell( SfxShell* pShell ) 1544 { 1545 SfxDispatcher *pDisp = pFrame->GetDispatcher(); 1546 if ( !pShell ) 1547 { 1548 sal_uInt16 nCount = pImp->aArr.Count(); 1549 if ( pDisp->IsActive(*this) ) 1550 { 1551 for ( sal_uInt16 n=nCount; n>0; n-- ) 1552 pDisp->Pop( *pImp->aArr[n-1] ); 1553 pDisp->Flush(); 1554 } 1555 1556 pImp->aArr.Remove(0, nCount); 1557 } 1558 else 1559 { 1560 sal_uInt16 nPos = pImp->aArr.GetPos( pShell ); 1561 if ( nPos != 0xFFFF ) 1562 { 1563 pImp->aArr.Remove( nPos ); 1564 if ( pDisp->IsActive(*this) ) 1565 { 1566 pDisp->RemoveShell_Impl( *pShell ); 1567 pDisp->Flush(); 1568 } 1569 } 1570 } 1571 } 1572 1573 SfxShell* SfxViewShell::GetSubShell( sal_uInt16 nNo ) 1574 { 1575 sal_uInt16 nCount = pImp->aArr.Count(); 1576 if ( nNo<nCount ) 1577 return pImp->aArr[nCount-nNo-1]; 1578 return NULL; 1579 } 1580 1581 void SfxViewShell::PushSubShells_Impl( sal_Bool bPush ) 1582 { 1583 sal_uInt16 nCount = pImp->aArr.Count(); 1584 SfxDispatcher *pDisp = pFrame->GetDispatcher(); 1585 if ( bPush ) 1586 { 1587 for ( sal_uInt16 n=0; n<nCount; n++ ) 1588 pDisp->Push( *pImp->aArr[n] ); 1589 } 1590 else if ( nCount ) 1591 { 1592 SfxShell& rPopUntil = *pImp->aArr[0]; 1593 if ( pDisp->GetShellLevel( rPopUntil ) != USHRT_MAX ) 1594 pDisp->Pop( rPopUntil, SFX_SHELL_POP_UNTIL ); 1595 } 1596 1597 pDisp->Flush(); 1598 } 1599 1600 //-------------------------------------------------------------------- 1601 1602 void SfxViewShell::WriteUserData( String&, sal_Bool ) 1603 { 1604 } 1605 1606 //-------------------------------------------------------------------- 1607 1608 void SfxViewShell::ReadUserData(const String&, sal_Bool ) 1609 { 1610 } 1611 1612 void SfxViewShell::ReadUserDataSequence ( const ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool ) 1613 { 1614 } 1615 1616 void SfxViewShell::WriteUserDataSequence ( ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool ) 1617 { 1618 } 1619 1620 1621 //-------------------------------------------------------------------- 1622 // returns the first shell of spec. type viewing the specified doc. 1623 1624 SfxViewShell* SfxViewShell::GetFirst 1625 ( 1626 const TypeId* pType, 1627 sal_Bool bOnlyVisible 1628 ) 1629 { 1630 // search for a SfxViewShell of the specified type 1631 SfxViewShellArr_Impl &rShells = SFX_APP()->GetViewShells_Impl(); 1632 SfxViewFrameArr_Impl &rFrames = SFX_APP()->GetViewFrames_Impl(); 1633 for ( sal_uInt16 nPos = 0; nPos < rShells.Count(); ++nPos ) 1634 { 1635 SfxViewShell *pShell = rShells.GetObject(nPos); 1636 if ( pShell ) 1637 { 1638 // sometimes dangling SfxViewShells exist that point to a dead SfxViewFrame 1639 // these ViewShells shouldn't be accessible anymore 1640 // a destroyed ViewFrame is not in the ViewFrame array anymore, so checking this array helps 1641 for ( sal_uInt16 n=0; n<rFrames.Count(); ++n ) 1642 { 1643 SfxViewFrame *pFrame = rFrames.GetObject(n); 1644 if ( pFrame == pShell->GetViewFrame() ) 1645 { 1646 // only ViewShells with a valid ViewFrame will be returned 1647 if ( ( !bOnlyVisible || pFrame->IsVisible() ) && ( !pType || pShell->IsA(*pType) ) ) 1648 return pShell; 1649 break; 1650 } 1651 } 1652 } 1653 } 1654 1655 return 0; 1656 } 1657 1658 //-------------------------------------------------------------------- 1659 // returns the next shell of spec. type viewing the specified doc. 1660 1661 SfxViewShell* SfxViewShell::GetNext 1662 ( 1663 const SfxViewShell& rPrev, 1664 const TypeId* pType, 1665 sal_Bool bOnlyVisible 1666 ) 1667 { 1668 SfxViewShellArr_Impl &rShells = SFX_APP()->GetViewShells_Impl(); 1669 SfxViewFrameArr_Impl &rFrames = SFX_APP()->GetViewFrames_Impl(); 1670 sal_uInt16 nPos; 1671 for ( nPos = 0; nPos < rShells.Count(); ++nPos ) 1672 if ( rShells.GetObject(nPos) == &rPrev ) 1673 break; 1674 1675 for ( ++nPos; nPos < rShells.Count(); ++nPos ) 1676 { 1677 SfxViewShell *pShell = rShells.GetObject(nPos); 1678 if ( pShell ) 1679 { 1680 // sometimes dangling SfxViewShells exist that point to a dead SfxViewFrame 1681 // these ViewShells shouldn't be accessible anymore 1682 // a destroyed ViewFrame is not in the ViewFrame array anymore, so checking this array helps 1683 for ( sal_uInt16 n=0; n<rFrames.Count(); ++n ) 1684 { 1685 SfxViewFrame *pFrame = rFrames.GetObject(n); 1686 if ( pFrame == pShell->GetViewFrame() ) 1687 { 1688 // only ViewShells with a valid ViewFrame will be returned 1689 if ( ( !bOnlyVisible || pFrame->IsVisible() ) && ( !pType || pShell->IsA(*pType) ) ) 1690 return pShell; 1691 break; 1692 } 1693 } 1694 } 1695 } 1696 1697 return 0; 1698 } 1699 1700 //-------------------------------------------------------------------- 1701 1702 void SfxViewShell::Notify( SfxBroadcaster& rBC, 1703 const SfxHint& rHint ) 1704 { 1705 if ( rHint.IsA(TYPE(SfxEventHint)) ) 1706 { 1707 switch ( ((SfxEventHint&)rHint).GetEventId() ) 1708 { 1709 case SFX_EVENT_LOADFINISHED: 1710 { 1711 if ( GetController().is() ) 1712 { 1713 // avoid access to dangling ViewShells 1714 SfxViewFrameArr_Impl &rFrames = SFX_APP()->GetViewFrames_Impl(); 1715 for ( sal_uInt16 n=0; n<rFrames.Count(); ++n ) 1716 { 1717 SfxViewFrame *frame = rFrames.GetObject(n); 1718 if ( frame == GetViewFrame() && &rBC == GetObjectShell() ) 1719 { 1720 SfxItemSet* pSet = GetObjectShell()->GetMedium()->GetItemSet(); 1721 SFX_ITEMSET_ARG( pSet, pItem, SfxUnoAnyItem, SID_VIEW_DATA, sal_False ); 1722 if ( pItem ) 1723 { 1724 pImp->m_pController->restoreViewData( 1725 pItem->GetValue() ); 1726 pSet->ClearItem( SID_VIEW_DATA ); 1727 } 1728 1729 break; 1730 } 1731 } 1732 } 1733 1734 break; 1735 } 1736 } 1737 } 1738 } 1739 1740 //-------------------------------------------------------------------- 1741 1742 sal_Bool SfxViewShell::ExecKey_Impl(const KeyEvent& aKey) 1743 { 1744 if (!pImp->m_pAccExec.get()) 1745 { 1746 pImp->m_pAccExec.reset( 1747 ::svt::AcceleratorExecute::createAcceleratorHelper() ); 1748 pImp->m_pAccExec->init(::comphelper::getProcessServiceFactory(), 1749 pFrame->GetFrame().GetFrameInterface()); 1750 } 1751 1752 return pImp->m_pAccExec->execute(aKey.GetKeyCode()); 1753 } 1754 1755 //-------------------------------------------------------------------- 1756 1757 FASTBOOL SfxViewShell::KeyInput( const KeyEvent &rKeyEvent ) 1758 1759 /* [Beschreibung] 1760 1761 Diese Methode f"uhrt das KeyEvent 'rKeyEvent' "uber die an dieser 1762 SfxViewShell direkt oder indirekt (z.B. via Applikation) konfigurierten 1763 Tasten (Accelerator) aus. 1764 1765 1766 [R"uckgabewert] 1767 1768 FASTBOOL sal_True 1769 die Taste ist konfiguriert, der betreffende 1770 Handler wurde gerufen 1771 1772 FALSE 1773 die Taste ist nicht konfiguriert, es konnte 1774 also kein Handler gerufen werden 1775 1776 1777 [Querverweise] 1778 <SfxApplication::KeyInput(const KeyEvent&)> 1779 */ 1780 { 1781 return ExecKey_Impl(rKeyEvent); 1782 } 1783 1784 bool SfxViewShell::GlobalKeyInput_Impl( const KeyEvent &rKeyEvent ) 1785 { 1786 return ExecKey_Impl(rKeyEvent); 1787 } 1788 1789 //-------------------------------------------------------------------- 1790 1791 void SfxViewShell::ShowCursor( FASTBOOL /*bOn*/ ) 1792 1793 /* [Beschreibung] 1794 1795 Diese Methode mu\s von Subklassen "uberladen werden, damit vom SFx 1796 aus der Cursor ein- und ausgeschaltet werden kann. Dies geschieht 1797 z.B. bei laufendem <SfxProgress>. 1798 */ 1799 1800 { 1801 } 1802 1803 //-------------------------------------------------------------------- 1804 1805 void SfxViewShell::GotFocus() const 1806 1807 /* [Beschreibung] 1808 1809 Diese Methode mu\s vom Applikationsentwickler gerufen werden, wenn 1810 das Edit-Window den Focus erhalten hat. Der SFx hat so z.B. die 1811 M"oglichkeit, den Accelerator einzuschalten. 1812 1813 1814 [Anmerkung] 1815 1816 <StarView> liefert leider keine M"oglichkeit, solche Events 1817 'von der Seite' einzuh"angen. 1818 */ 1819 1820 { 1821 } 1822 1823 //-------------------------------------------------------------------- 1824 void SfxViewShell::ResetAllClients_Impl( SfxInPlaceClient *pIP ) 1825 { 1826 1827 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1828 if ( !pClients ) 1829 return; 1830 1831 for ( sal_uInt16 n=0; n < pClients->Count(); n++ ) 1832 { 1833 SfxInPlaceClient* pIPClient = pClients->GetObject(n); 1834 if( pIPClient != pIP ) 1835 pIPClient->ResetObject(); 1836 } 1837 } 1838 1839 //-------------------------------------------------------------------- 1840 1841 void SfxViewShell::DisconnectAllClients() 1842 { 1843 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1844 if ( !pClients ) 1845 return; 1846 1847 for ( sal_uInt16 n=0; n<pClients->Count(); ) 1848 // clients will remove themselves from the list 1849 delete pClients->GetObject(n); 1850 } 1851 1852 //-------------------------------------------------------------------- 1853 1854 void SfxViewShell::QueryObjAreaPixel( Rectangle& ) const 1855 { 1856 } 1857 1858 //-------------------------------------------------------------------- 1859 1860 void SfxViewShell::AdjustVisArea(const Rectangle& rRect) 1861 { 1862 DBG_ASSERT (pFrame, "Kein Frame?"); 1863 GetObjectShell()->SetVisArea( rRect ); 1864 } 1865 1866 //-------------------------------------------------------------------- 1867 1868 void SfxViewShell::VisAreaChanged(const Rectangle& /*rVisArea*/) 1869 { 1870 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1871 if ( !pClients ) 1872 return; 1873 1874 for (sal_uInt16 n=0; n < pClients->Count(); n++) 1875 { 1876 SfxInPlaceClient* pIPClient = pClients->GetObject(n); 1877 if ( pIPClient->IsObjectInPlaceActive() ) 1878 // client is active, notify client that the VisArea might have changed 1879 pIPClient->VisAreaChanged(); 1880 } 1881 } 1882 1883 //-------------------------------------------------------------------- 1884 void SfxViewShell::CheckIPClient_Impl( SfxInPlaceClient *pIPClient, const Rectangle& rVisArea ) 1885 { 1886 if ( GetObjectShell()->IsInClose() ) 1887 return; 1888 1889 sal_Bool bAlwaysActive = 1890 ( ( pIPClient->GetObjectMiscStatus() & embed::EmbedMisc::EMBED_ACTIVATEIMMEDIATELY ) != 0 ); 1891 sal_Bool bActiveWhenVisible = 1892 ( ( pIPClient->GetObjectMiscStatus() & embed::EmbedMisc::MS_EMBED_ACTIVATEWHENVISIBLE ) != 0 ); 1893 1894 // this method is called when either a client is created or the "Edit/Plugins" checkbox is checked 1895 if ( !pIPClient->IsObjectInPlaceActive() && pImp->m_bPlugInsActive ) 1896 { 1897 // object in client is currently not active 1898 // check if the object wants to be activated always or when it becomes at least partially visible 1899 // TODO/LATER: maybe we should use the scaled area instead of the ObjArea?! 1900 if ( bAlwaysActive || (bActiveWhenVisible && rVisArea.IsOver(pIPClient->GetObjArea())) ) 1901 { 1902 try 1903 { 1904 pIPClient->GetObject()->changeState( embed::EmbedStates::INPLACE_ACTIVE ); 1905 } 1906 catch ( uno::Exception& ) 1907 { 1908 } 1909 } 1910 } 1911 else if (!pImp->m_bPlugInsActive) 1912 { 1913 // object in client is currently active and "Edit/Plugins" checkbox is selected 1914 // check if the object wants to be activated always or when it becomes at least partially visible 1915 // in this case selecting of the "Edit/Plugin" checkbox should let such objects deactivate 1916 if ( bAlwaysActive || bActiveWhenVisible ) 1917 pIPClient->GetObject()->changeState( embed::EmbedStates::RUNNING ); 1918 } 1919 } 1920 1921 //-------------------------------------------------------------------- 1922 1923 sal_Bool SfxViewShell::PlugInsActive() const 1924 { 1925 return pImp->m_bPlugInsActive; 1926 } 1927 1928 //-------------------------------------------------------------------- 1929 void SfxViewShell::DiscardClients_Impl() 1930 1931 /* [Beschreibung] 1932 1933 Diese Methode dient dazu, vor dem Schlie\sen eines Dokuments das 1934 Speichern der Objekte zu verhindern, wenn der Benutzer Schlie\en ohne 1935 Speichern gew"ahlt hatte. 1936 */ 1937 1938 { 1939 SfxInPlaceClientList *pClients = GetIPClientList_Impl(sal_False); 1940 if ( !pClients ) 1941 return; 1942 1943 for (sal_uInt16 n=0; n < pClients->Count(); ) 1944 delete pClients->GetObject(n); 1945 } 1946 1947 //-------------------------------------------------------------------- 1948 1949 SfxScrollingMode SfxViewShell::GetScrollingMode() const 1950 { 1951 return pImp->m_eScroll; 1952 } 1953 1954 //-------------------------------------------------------------------- 1955 1956 void SfxViewShell::SetScrollingMode( SfxScrollingMode eMode ) 1957 { 1958 pImp->m_eScroll = eMode; 1959 } 1960 1961 //-------------------------------------------------------------------- 1962 1963 SfxObjectShell* SfxViewShell::GetObjectShell() 1964 { 1965 return pFrame ? pFrame->GetObjectShell() : NULL; 1966 } 1967 1968 //-------------------------------------------------------------------- 1969 1970 Reference< XModel > SfxViewShell::GetCurrentDocument() const 1971 { 1972 Reference< XModel > xDocument; 1973 1974 const SfxObjectShell* pDocShell( const_cast< SfxViewShell* >( this )->GetObjectShell() ); 1975 OSL_ENSURE( pDocShell, "SfxViewFrame::GetCurrentDocument: no DocShell!?" ); 1976 if ( pDocShell ) 1977 xDocument = pDocShell->GetModel(); 1978 return xDocument; 1979 } 1980 1981 //-------------------------------------------------------------------- 1982 1983 void SfxViewShell::SetCurrentDocument() const 1984 { 1985 uno::Reference< frame::XModel > xDocument( GetCurrentDocument() ); 1986 if ( xDocument.is() ) 1987 SfxObjectShell::SetCurrentComponent( xDocument ); 1988 } 1989 1990 //-------------------------------------------------------------------- 1991 1992 const Size& SfxViewShell::GetMargin() const 1993 { 1994 return pImp->aMargin; 1995 } 1996 1997 //-------------------------------------------------------------------- 1998 1999 void SfxViewShell::SetMargin( const Size& rSize ) 2000 { 2001 // Der default-Margin wurde "geeicht" mit www.apple.com !! 2002 Size aMargin = rSize; 2003 if ( aMargin.Width() == -1 ) 2004 aMargin.Width() = DEFAULT_MARGIN_WIDTH; 2005 if ( aMargin.Height() == -1 ) 2006 aMargin.Height() = DEFAULT_MARGIN_HEIGHT; 2007 2008 if ( aMargin != pImp->aMargin ) 2009 { 2010 pImp->aMargin = aMargin; 2011 MarginChanged(); 2012 } 2013 } 2014 2015 //-------------------------------------------------------------------- 2016 2017 void SfxViewShell::MarginChanged() 2018 { 2019 } 2020 2021 //-------------------------------------------------------------------- 2022 2023 sal_Bool SfxViewShell::IsShowView_Impl() const 2024 { 2025 return pImp->m_bIsShowView; 2026 } 2027 2028 //-------------------------------------------------------------------- 2029 2030 SfxFrame* SfxViewShell::GetSmartSelf( SfxFrame* pSelf, SfxMedium& /*rMedium*/ ) 2031 { 2032 return pSelf; 2033 } 2034 2035 //------------------------------------------------------------------------ 2036 2037 void SfxViewShell::JumpToMark( const String& rMark ) 2038 { 2039 SfxStringItem aMarkItem( SID_JUMPTOMARK, rMark ); 2040 GetViewFrame()->GetDispatcher()->Execute( 2041 SID_JUMPTOMARK, 2042 SFX_CALLMODE_SYNCHRON|SFX_CALLMODE_RECORD, 2043 &aMarkItem, 0L ); 2044 } 2045 2046 //------------------------------------------------------------------------ 2047 2048 SfxInPlaceClientList* SfxViewShell::GetIPClientList_Impl( sal_Bool bCreate ) const 2049 { 2050 if ( !pIPClientList && bCreate ) 2051 ( (SfxViewShell*) this )->pIPClientList = new SfxInPlaceClientList; 2052 return pIPClientList; 2053 } 2054 2055 void SfxViewShell::SetController( SfxBaseController* pController ) 2056 { 2057 pImp->m_pController = pController; 2058 pImp->m_bControllerSet = true; 2059 2060 // there should be no old listener, but if there is one, it should be disconnected 2061 if ( pImp->xClipboardListener.is() ) 2062 pImp->xClipboardListener->DisconnectViewShell(); 2063 2064 pImp->xClipboardListener = new SfxClipboardChangeListener( this, GetClipboardNotifier() ); 2065 } 2066 2067 Reference < XController > SfxViewShell::GetController() 2068 { 2069 return pImp->m_pController.get(); 2070 } 2071 2072 SfxBaseController* SfxViewShell::GetBaseController_Impl() const 2073 { 2074 return pImp->m_pController.get(); 2075 } 2076 2077 void SfxViewShell::AddContextMenuInterceptor_Impl( const REFERENCE< XCONTEXTMENUINTERCEPTOR >& xInterceptor ) 2078 { 2079 pImp->aInterceptorContainer.addInterface( xInterceptor ); 2080 } 2081 2082 void SfxViewShell::RemoveContextMenuInterceptor_Impl( const REFERENCE< XCONTEXTMENUINTERCEPTOR >& xInterceptor ) 2083 { 2084 pImp->aInterceptorContainer.removeInterface( xInterceptor ); 2085 } 2086 2087 ::cppu::OInterfaceContainerHelper& SfxViewShell::GetContextMenuInterceptors() const 2088 { 2089 return pImp->aInterceptorContainer; 2090 } 2091 2092 void Change( Menu* pMenu, SfxViewShell* pView ) 2093 { 2094 SfxDispatcher *pDisp = pView->GetViewFrame()->GetDispatcher(); 2095 sal_uInt16 nCount = pMenu->GetItemCount(); 2096 for ( sal_uInt16 nPos=0; nPos<nCount; ++nPos ) 2097 { 2098 sal_uInt16 nId = pMenu->GetItemId(nPos); 2099 String aCmd = pMenu->GetItemCommand(nId); 2100 PopupMenu* pPopup = pMenu->GetPopupMenu(nId); 2101 if ( pPopup ) 2102 { 2103 Change( pPopup, pView ); 2104 } 2105 else if ( nId < 5000 ) 2106 { 2107 if ( aCmd.CompareToAscii(".uno:", 5) == 0 ) 2108 { 2109 for (sal_uInt16 nIdx=0;;) 2110 { 2111 SfxShell *pShell=pDisp->GetShell(nIdx++); 2112 if (pShell == NULL) 2113 break; 2114 const SfxInterface *pIFace = pShell->GetInterface(); 2115 const SfxSlot* pSlot = pIFace->GetSlot( aCmd ); 2116 if ( pSlot ) 2117 { 2118 pMenu->InsertItem( pSlot->GetSlotId(), pMenu->GetItemText( nId ), pMenu->GetItemBits( nId ), nPos ); 2119 pMenu->SetItemCommand( pSlot->GetSlotId(), aCmd ); 2120 pMenu->RemoveItem( nPos+1 ); 2121 break; 2122 } 2123 } 2124 } 2125 } 2126 } 2127 } 2128 2129 2130 sal_Bool SfxViewShell::TryContextMenuInterception( Menu& rIn, const ::rtl::OUString& rMenuIdentifier, Menu*& rpOut, ui::ContextMenuExecuteEvent aEvent ) 2131 { 2132 rpOut = NULL; 2133 sal_Bool bModified = sal_False; 2134 2135 // create container from menu 2136 // #110897# 2137 // aEvent.ActionTriggerContainer = ::framework::ActionTriggerHelper::CreateActionTriggerContainerFromMenu( &rIn ); 2138 aEvent.ActionTriggerContainer = ::framework::ActionTriggerHelper::CreateActionTriggerContainerFromMenu( 2139 ::comphelper::getProcessServiceFactory(), &rIn, &rMenuIdentifier ); 2140 2141 // get selection from controller 2142 aEvent.Selection = uno::Reference < view::XSelectionSupplier > ( GetController(), uno::UNO_QUERY ); 2143 2144 // call interceptors 2145 ::cppu::OInterfaceIteratorHelper aIt( pImp->aInterceptorContainer ); 2146 while( aIt.hasMoreElements() ) 2147 { 2148 try 2149 { 2150 ui::ContextMenuInterceptorAction eAction = 2151 ((ui::XContextMenuInterceptor*)aIt.next())->notifyContextMenuExecute( aEvent ); 2152 switch ( eAction ) 2153 { 2154 case ui::ContextMenuInterceptorAction_CANCELLED : 2155 // interceptor does not want execution 2156 return sal_False; 2157 case ui::ContextMenuInterceptorAction_EXECUTE_MODIFIED : 2158 // interceptor wants his modified menu to be executed 2159 bModified = sal_True; 2160 break; 2161 case ui::ContextMenuInterceptorAction_CONTINUE_MODIFIED : 2162 // interceptor has modified menu, but allows for calling other interceptors 2163 bModified = sal_True; 2164 continue; 2165 case ui::ContextMenuInterceptorAction_IGNORED : 2166 // interceptor is indifferent 2167 continue; 2168 default: 2169 DBG_ERROR("Wrong return value of ContextMenuInterceptor!"); 2170 continue; 2171 } 2172 } 2173 catch( uno::RuntimeException& ) 2174 { 2175 aIt.remove(); 2176 } 2177 2178 break; 2179 } 2180 2181 if ( bModified ) 2182 { 2183 // container was modified, create a new window out of it 2184 rpOut = new PopupMenu; 2185 ::framework::ActionTriggerHelper::CreateMenuFromActionTriggerContainer( rpOut, aEvent.ActionTriggerContainer ); 2186 2187 Change( rpOut, this ); 2188 } 2189 2190 return sal_True; 2191 } 2192 2193 void SfxViewShell::TakeOwnerShip_Impl() 2194 { 2195 // currently there is only one reason to take OwnerShip: a hidden frame is printed 2196 // so the ViewShell will check this on EndPrint (->prnmon.cxx) 2197 pImp->m_bGotOwnership = true; 2198 } 2199 2200 void SfxViewShell::TakeFrameOwnerShip_Impl() 2201 { 2202 // currently there is only one reason to take OwnerShip: a hidden frame is printed 2203 // so the ViewShell will check this on EndPrint (->prnmon.cxx) 2204 pImp->m_bGotFrameOwnership = true; 2205 } 2206 2207 void SfxViewShell::CheckOwnerShip_Impl() 2208 { 2209 sal_Bool bSuccess = sal_False; 2210 if (pImp->m_bGotOwnership) 2211 { 2212 uno::Reference < util::XCloseable > xModel( 2213 GetObjectShell()->GetModel(), uno::UNO_QUERY ); 2214 if ( xModel.is() ) 2215 { 2216 try 2217 { 2218 // this call will destroy this object in case of success! 2219 xModel->close( sal_True ); 2220 bSuccess = sal_True; 2221 } 2222 catch ( util::CloseVetoException& ) 2223 { 2224 } 2225 } 2226 } 2227 2228 if (!bSuccess && pImp->m_bGotFrameOwnership) 2229 { 2230 // document couldn't be closed or it shouldn't, now try at least to close the frame 2231 uno::Reference < util::XCloseable > xFrame( 2232 GetViewFrame()->GetFrame().GetFrameInterface(), com::sun::star::uno::UNO_QUERY ); 2233 if ( xFrame.is() ) 2234 { 2235 try 2236 { 2237 xFrame->close( sal_True ); 2238 } 2239 catch ( util::CloseVetoException& ) 2240 { 2241 } 2242 } 2243 } 2244 } 2245 2246 long SfxViewShell::HandleNotifyEvent_Impl( NotifyEvent& rEvent ) 2247 { 2248 if (pImp->m_pController.is()) 2249 return pImp->m_pController->HandleEvent_Impl( rEvent ); 2250 return 0; 2251 } 2252 2253 sal_Bool SfxViewShell::HasKeyListeners_Impl() 2254 { 2255 return (pImp->m_pController.is()) 2256 ? pImp->m_pController->HasKeyListeners_Impl() : sal_False; 2257 } 2258 2259 sal_Bool SfxViewShell::HasMouseClickListeners_Impl() 2260 { 2261 return (pImp->m_pController.is()) 2262 ? pImp->m_pController->HasMouseClickListeners_Impl() : sal_False; 2263 } 2264 2265 void SfxViewShell::SetAdditionalPrintOptions( const com::sun::star::uno::Sequence < com::sun::star::beans::PropertyValue >& rOpts ) 2266 { 2267 pImp->aPrintOpts = rOpts; 2268 // GetObjectShell()->Broadcast( SfxPrintingHint( -3, NULL, NULL, rOpts ) ); 2269 } 2270 2271 sal_Bool SfxViewShell::Escape() 2272 { 2273 return GetViewFrame()->GetBindings().Execute( SID_TERMINATE_INPLACEACTIVATION ); 2274 } 2275 2276 Reference< view::XRenderable > SfxViewShell::GetRenderable() 2277 { 2278 Reference< view::XRenderable >xRender; 2279 SfxObjectShell* pObj = GetObjectShell(); 2280 if( pObj ) 2281 { 2282 Reference< frame::XModel > xModel( pObj->GetModel() ); 2283 if( xModel.is() ) 2284 xRender = Reference< view::XRenderable >( xModel, UNO_QUERY ); 2285 } 2286 return xRender; 2287 } 2288 2289 uno::Reference< datatransfer::clipboard::XClipboardNotifier > SfxViewShell::GetClipboardNotifier() 2290 { 2291 uno::Reference< datatransfer::clipboard::XClipboardNotifier > xClipboardNotifier; 2292 if ( GetViewFrame() ) 2293 xClipboardNotifier = uno::Reference< datatransfer::clipboard::XClipboardNotifier >( GetViewFrame()->GetWindow().GetClipboard(), uno::UNO_QUERY ); 2294 2295 return xClipboardNotifier; 2296 } 2297 2298 void SfxViewShell::AddRemoveClipboardListener( const uno::Reference < datatransfer::clipboard::XClipboardListener >& rClp, sal_Bool bAdd ) 2299 { 2300 try 2301 { 2302 if ( GetViewFrame() ) 2303 { 2304 uno::Reference< datatransfer::clipboard::XClipboard > xClipboard( GetViewFrame()->GetWindow().GetClipboard() ); 2305 if( xClipboard.is() ) 2306 { 2307 uno::Reference< datatransfer::clipboard::XClipboardNotifier > xClpbrdNtfr( xClipboard, uno::UNO_QUERY ); 2308 if( xClpbrdNtfr.is() ) 2309 { 2310 if( bAdd ) 2311 xClpbrdNtfr->addClipboardListener( rClp ); 2312 else 2313 xClpbrdNtfr->removeClipboardListener( rClp ); 2314 } 2315 } 2316 } 2317 } 2318 catch( const uno::Exception& ) 2319 { 2320 } 2321 } 2322 2323