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_sd.hxx" 26 27 #include "OutlineViewShell.hxx" 28 29 #include "ViewShellImplementation.hxx" 30 #include <memory> 31 #include "helpids.h" 32 #include "app.hrc" 33 #include <svx/hyprlink.hxx> 34 #include <svx/hyperdlg.hxx> 35 #include <svx/zoomslideritem.hxx> 36 37 #include <sfx2/objface.hxx> 38 #include <sot/exchange.hxx> 39 #include <svx/ruler.hxx> 40 #include <svx/zoomitem.hxx> 41 #include <editeng/eeitem.hxx> 42 #include <editeng/flditem.hxx> 43 #include <sfx2/shell.hxx> 44 #include <sfx2/templdlg.hxx> 45 #include <sfx2/viewfac.hxx> 46 #include <sfx2/request.hxx> 47 #include <svx/hlnkitem.hxx> 48 #include <svx/svdotext.hxx> 49 #include <sfx2/dispatch.hxx> 50 #include <vcl/scrbar.hxx> 51 #include <svl/whiter.hxx> 52 #include <editeng/editstat.hxx> 53 #include <svl/itempool.hxx> 54 #include <sfx2/tplpitem.hxx> 55 #include <sfx2/sidebar/SidebarChildWindow.hxx> 56 #include <sfx2/sidebar/EnumContext.hxx> 57 #include <svx/svdorect.hxx> 58 #include <sot/formats.hxx> 59 #include <com/sun/star/linguistic2/XThesaurus.hpp> 60 #include <com/sun/star/i18n/TransliterationModules.hpp> 61 #include <com/sun/star/i18n/TransliterationModulesExtra.hpp> 62 #include <editeng/unolingu.hxx> 63 #include <comphelper/processfactory.hxx> 64 #include <editeng/outlobj.hxx> 65 #include <svl/cjkoptions.hxx> 66 #include <svtools/cliplistener.hxx> 67 #include <svl/srchitem.hxx> 68 #include <editeng/editobj.hxx> 69 #include "fubullet.hxx" 70 #include "optsitem.hxx" 71 72 #include "strings.hrc" 73 #include "glob.hrc" 74 #include "res_bmp.hrc" 75 #include "Outliner.hxx" 76 #include "Window.hxx" 77 #include "TextObjectBar.hxx" 78 #include "drawdoc.hxx" 79 #include "sdresid.hxx" 80 #include "sdpage.hxx" 81 #include "fuoltext.hxx" 82 #include "FrameView.hxx" 83 #include "zoomlist.hxx" 84 #include "stlsheet.hxx" 85 #include "slideshow.hxx" 86 #include "SdUnoOutlineView.hxx" 87 #include "SpellDialogChildWindow.hxx" 88 89 #include "AccessibleOutlineView.hxx" 90 #include "ViewShellBase.hxx" 91 #include "ViewShellManager.hxx" 92 #include "DrawController.hxx" 93 #include "framework/FrameworkHelper.hxx" 94 95 using ::rtl::OUString; 96 using namespace ::com::sun::star; 97 using namespace ::com::sun::star::uno; 98 using namespace ::com::sun::star::lang; 99 using namespace ::com::sun::star::linguistic2; 100 101 using namespace sd; 102 #define OutlineViewShell 103 #include "sdslots.hxx" 104 105 namespace sd { 106 107 #define MIN_ZOOM 10 // Minimaler Zoomfaktor 108 #define MAX_ZOOM 1000 // Maximaler Zoomfaktor 109 110 /************************************************************************/ 111 112 113 /************************************************************************* 114 |* 115 |* SFX-Slotmap und Standardinterface deklarieren 116 |* 117 \************************************************************************/ 118 119 120 SFX_IMPL_INTERFACE(OutlineViewShell, SfxShell, SdResId(STR_OUTLINEVIEWSHELL)) 121 { 122 SFX_POPUPMENU_REGISTRATION( SdResId(RID_OUTLINE_POPUP) ); 123 SFX_OBJECTBAR_REGISTRATION( SFX_OBJECTBAR_TOOLS | SFX_VISIBILITY_STANDARD | 124 SFX_VISIBILITY_FULLSCREEN | SFX_VISIBILITY_SERVER, 125 SdResId(RID_OUTLINE_TOOLBOX) ); 126 SFX_OBJECTBAR_REGISTRATION( SFX_OBJECTBAR_APPLICATION | SFX_VISIBILITY_DESKTOP | SFX_VISIBILITY_STANDARD | SFX_VISIBILITY_CLIENT | SFX_VISIBILITY_VIEWER | SFX_VISIBILITY_READONLYDOC, 127 SdResId(RID_DRAW_VIEWER_TOOLBOX) ); 128 SFX_CHILDWINDOW_REGISTRATION( SfxTemplateDialogWrapper::GetChildWindowId() ); 129 SFX_CHILDWINDOW_REGISTRATION( SvxHyperlinkDlgWrapper::GetChildWindowId() ); 130 SFX_CHILDWINDOW_REGISTRATION( SvxHlinkDlgWrapper::GetChildWindowId() ); 131 SFX_CHILDWINDOW_REGISTRATION( ::sd::SpellDialogChildWindow::GetChildWindowId() ); 132 SFX_CHILDWINDOW_REGISTRATION( SID_SEARCH_DLG ); 133 SFX_CHILDWINDOW_REGISTRATION(::sfx2::sidebar::SidebarChildWindow::GetChildWindowId()); 134 } 135 136 137 TYPEINIT1( OutlineViewShell, ViewShell ); 138 139 140 /************************************************************************* 141 |* 142 |* gemeinsamer Initialiserungsanteil der beiden Konstruktoren 143 |* 144 \************************************************************************/ 145 146 void OutlineViewShell::Construct(DrawDocShell* ) 147 { 148 sal_Bool bModified = GetDoc()->IsChanged(); 149 150 meShellType = ST_OUTLINE; 151 Size aSize(29700, 21000); 152 Point aWinPos (0, 0); 153 Point aViewOrigin(0, 0); 154 GetActiveWindow()->SetMinZoomAutoCalc(sal_False); 155 GetActiveWindow()->SetMinZoom( MIN_ZOOM ); 156 GetActiveWindow()->SetMaxZoom( MAX_ZOOM ); 157 InitWindows(aViewOrigin, aSize, aWinPos); 158 pOlView = new OutlineView(GetDocSh(), GetActiveWindow(), this); 159 mpView = pOlView; // Pointer der Basisklasse ViewShell 160 161 SetPool( &GetDoc()->GetPool() ); 162 163 SetZoom(69); 164 165 // Einstellungen der FrameView uebernehmen 166 ReadFrameViewData(mpFrameView); 167 168 ::Outliner* pOutl = pOlView->GetOutliner(); 169 pOutl->SetUpdateMode(sal_True); 170 171 if (!bModified) 172 { 173 pOutl->ClearModifyFlag(); 174 } 175 176 pLastPage = GetActualPage(); 177 178 String aName( RTL_CONSTASCII_USTRINGPARAM( "OutlineViewShell" )); 179 SetName (aName); 180 181 SetHelpId( SD_IF_SDOUTLINEVIEWSHELL ); 182 GetActiveWindow()->SetHelpId( HID_SDOUTLINEVIEWSHELL ); 183 GetActiveWindow()->SetUniqueId( HID_SDOUTLINEVIEWSHELL ); 184 } 185 186 187 188 189 Reference<drawing::XDrawSubController> OutlineViewShell::CreateSubController (void) 190 { 191 Reference<drawing::XDrawSubController> xSubController; 192 193 if (IsMainViewShell()) 194 { 195 // Create uno sub controller for the main view shell. 196 xSubController = Reference<drawing::XDrawSubController>( 197 new SdUnoOutlineView ( 198 GetViewShellBase().GetDrawController(), 199 *this, 200 *GetView())); 201 } 202 203 return xSubController; 204 } 205 206 207 208 209 /************************************************************************* 210 |* 211 |* Standard-Konstruktor, Fenster duerfen nicht automatisch zentrieren 212 |* 213 \************************************************************************/ 214 215 OutlineViewShell::OutlineViewShell ( 216 SfxViewFrame* pFrame, 217 ViewShellBase& rViewShellBase, 218 ::Window* pParentWindow, 219 FrameView* pFrameViewArgument) 220 : ViewShell(pFrame, pParentWindow, rViewShellBase), 221 pOlView(NULL), 222 pLastPage( NULL ), 223 pClipEvtLstnr(NULL), 224 bPastePossible(false), 225 mbInitialized(false) 226 227 { 228 if (pFrameViewArgument != NULL) 229 mpFrameView = pFrameViewArgument; 230 else 231 mpFrameView = new FrameView(GetDoc()); 232 233 mpFrameView->Connect(); 234 235 Construct(GetDocSh()); 236 237 SetContextName(sfx2::sidebar::EnumContext::GetContextName(sfx2::sidebar::EnumContext::Context_OutlineText)); 238 m_StrOldPageName.EmptyString(); 239 } 240 241 /************************************************************************* 242 |* 243 |* Destruktor 244 |* 245 \************************************************************************/ 246 247 OutlineViewShell::~OutlineViewShell() 248 { 249 DisposeFunctions(); 250 251 delete pOlView; 252 253 mpFrameView->Disconnect(); 254 255 if ( pClipEvtLstnr ) 256 { 257 pClipEvtLstnr->AddRemoveListener( GetActiveWindow(), sal_False ); 258 pClipEvtLstnr->ClearCallbackLink(); // #103849# prevent callback if another thread is waiting 259 pClipEvtLstnr->release(); 260 } 261 } 262 263 264 265 266 void OutlineViewShell::Shutdown (void) 267 { 268 ViewShell::Shutdown(); 269 270 PrepareClose(); 271 } 272 273 274 275 276 /************************************************************************* 277 |* 278 |* Paint-Methode: das Ereignis wird vom Fenster pWindow an 279 |* die Viewshell und die aktuelle Funktion weitergeleitet 280 |* 281 \************************************************************************/ 282 283 void OutlineViewShell::Paint(const Rectangle& rRect, ::sd::Window* pWin) 284 { 285 if (pOlView) 286 { 287 pOlView->Paint(rRect, pWin); 288 } 289 290 if(HasCurrentFunction()) 291 { 292 GetCurrentFunction()->Paint(rRect, pWin); 293 } 294 } 295 296 void OutlineViewShell::ArrangeGUIElements () 297 { 298 // Retrieve the current size (thickness) of the scroll bars. That is 299 // the width of the vertical and the height of the horizontal scroll 300 // bar. 301 int nScrollBarSize = 302 GetParentWindow()->GetSettings().GetStyleSettings().GetScrollBarSize(); 303 maScrBarWH = Size (nScrollBarSize, nScrollBarSize); 304 305 ViewShell::ArrangeGUIElements (); 306 307 ::sd::Window* pWindow = mpContentWindow.get(); 308 if (pWindow != NULL) 309 { 310 pWindow->SetMinZoomAutoCalc(sal_False); 311 312 // pWindow->SetPosSizePixel(rNewPos, Size(nSizeX, nSizeY)); 313 314 // OutputArea der OutlinerView aendern 315 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(pWindow); 316 317 Rectangle aWin(Point(0,0), pWindow->GetOutputSizePixel()); 318 // aWin.nLeft = pOlView->GetPageNumberWidthPixel(); 319 320 aWin = pWindow->PixelToLogic(aWin); 321 pOutlinerView->SetOutputArea(aWin); 322 323 Rectangle aVis = pOutlinerView->GetVisArea(); 324 325 Rectangle aText = Rectangle(Point(0,0), 326 Size(pOlView->GetPaperWidth(), 327 pOlView->GetOutliner()->GetTextHeight())); 328 aText.Bottom() += aWin.GetHeight(); 329 330 if (!aWin.IsEmpty()) // nicht beim Oeffnen 331 { 332 InitWindows(Point(0,0), aText.GetSize(), Point(aVis.TopLeft())); 333 UpdateScrollBars(); 334 } 335 } 336 } 337 338 /************************************************************************* 339 |* 340 |* SfxRequests fuer Controller bearbeiten 341 |* 342 \************************************************************************/ 343 344 void OutlineViewShell::ExecCtrl(SfxRequest &rReq) 345 { 346 sal_uInt16 nSlot = rReq.GetSlot(); 347 switch ( nSlot ) 348 { 349 case SID_MAIL_SCROLLBODY_PAGEDOWN: 350 { 351 ExecReq( rReq ); 352 break; 353 } 354 355 case SID_OPT_LOCALE_CHANGED: 356 { 357 pOlView->GetOutliner()->UpdateFields(); 358 UpdatePreview( GetActualPage() ); 359 rReq.Done(); 360 break; 361 } 362 363 default: 364 break; 365 } 366 } 367 368 369 370 371 void OutlineViewShell::AddWindow (::sd::Window* pWin) 372 { 373 pOlView->AddWindowToPaintView(pWin); 374 } 375 376 377 378 379 void OutlineViewShell::RemoveWindow (::sd::Window* pWin) 380 { 381 pOlView->DeleteWindowFromPaintView(pWin); 382 } 383 384 385 386 387 /************************************************************************* 388 |* 389 |* Activate(), beim ersten Aufruf erfolgt ein Update der Felder 390 |* 391 \************************************************************************/ 392 void OutlineViewShell::Activate( sal_Bool bIsMDIActivate ) 393 { 394 if ( ! mbInitialized) 395 { 396 mbInitialized = true; 397 SfxRequest aRequest (SID_EDIT_OUTLINER, 0, GetDoc()->GetItemPool()); 398 FuPermanent (aRequest); 399 } 400 401 ViewShell::Activate( bIsMDIActivate ); 402 SfxShell::BroadcastContextForActivation(true); 403 404 pOlView->SetLinks(); 405 pOlView->ConnectToApplication(); 406 407 if( bIsMDIActivate ) 408 { 409 OutlinerView* pOutlinerView = pOlView->GetViewByWindow( GetActiveWindow() ); 410 ::Outliner* pOutl = pOutlinerView->GetOutliner(); 411 pOutl->UpdateFields(); 412 } 413 } 414 415 /************************************************************************* 416 |* 417 |* Deactivate() 418 |* 419 \************************************************************************/ 420 void OutlineViewShell::Deactivate( sal_Bool bIsMDIActivate ) 421 { 422 pOlView->DisconnectFromApplication(); 423 424 // #96416# Links must be kept also on deactivated viewshell, to allow drag'n'drop 425 // to function properly 426 // pOlView->ResetLinks(); 427 428 ViewShell::Deactivate( bIsMDIActivate ); 429 } 430 431 /************************************************************************* 432 |* 433 |* Status von Controller-SfxSlots setzen 434 |* 435 \************************************************************************/ 436 void OutlineViewShell::GetCtrlState(SfxItemSet &rSet) 437 { 438 if (SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_HYPERLINK_GETLINK)) 439 { 440 SvxHyperlinkItem aHLinkItem; 441 442 OutlinerView* pOLV = pOlView->GetViewByWindow(GetActiveWindow()); 443 if (pOLV) 444 { 445 const SvxFieldItem* pFieldItem = pOLV->GetFieldAtSelection(); 446 if (pFieldItem) 447 { 448 ESelection aSel = pOLV->GetSelection(); 449 if ( abs( aSel.nEndPos - aSel.nStartPos ) == 1 ) 450 { 451 const SvxFieldData* pField = pFieldItem->GetField(); 452 if ( pField->ISA(SvxURLField) ) 453 { 454 aHLinkItem.SetName(((const SvxURLField*) pField)->GetRepresentation()); 455 aHLinkItem.SetURL(((const SvxURLField*) pField)->GetURL()); 456 aHLinkItem.SetTargetFrame(((const SvxURLField*) pField)->GetTargetFrame()); 457 } 458 } 459 } 460 } 461 rSet.Put(aHLinkItem); 462 } 463 rSet.Put( SfxBoolItem( SID_READONLY_MODE, GetDocSh()->IsReadOnly() ) ); 464 465 if ( SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_MAIL_SCROLLBODY_PAGEDOWN) ) 466 rSet.Put( SfxBoolItem( SID_MAIL_SCROLLBODY_PAGEDOWN, sal_True ) ); 467 468 if ( SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_TRANSLITERATE_HALFWIDTH) || 469 SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_TRANSLITERATE_FULLWIDTH) || 470 SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_TRANSLITERATE_HIRAGANA) || 471 SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_TRANSLITERATE_KATAGANA) ) 472 { 473 SvtCJKOptions aCJKOptions; 474 if( !aCJKOptions.IsChangeCaseMapEnabled() ) 475 { 476 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_HALFWIDTH, sal_False ); 477 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_FULLWIDTH, sal_False ); 478 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_HIRAGANA, sal_False ); 479 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_KATAGANA, sal_False ); 480 rSet.DisableItem( SID_TRANSLITERATE_HALFWIDTH ); 481 rSet.DisableItem( SID_TRANSLITERATE_FULLWIDTH ); 482 rSet.DisableItem( SID_TRANSLITERATE_HIRAGANA ); 483 rSet.DisableItem( SID_TRANSLITERATE_KATAGANA ); 484 } 485 else 486 { 487 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_HALFWIDTH, sal_True ); 488 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_FULLWIDTH, sal_True ); 489 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_HIRAGANA, sal_True ); 490 GetViewFrame()->GetBindings().SetVisibleState( SID_TRANSLITERATE_KATAGANA, sal_True ); 491 } 492 } 493 } 494 495 /************************************************************************* 496 |* 497 |* SfxRequests fuer Support-Funktionen 498 |* 499 \************************************************************************/ 500 501 void OutlineViewShell::FuSupport(SfxRequest &rReq) 502 { 503 if( rReq.GetSlot() == SID_STYLE_FAMILY && rReq.GetArgs()) 504 GetDocSh()->SetStyleFamily(((SfxUInt16Item&)rReq.GetArgs()->Get( SID_STYLE_FAMILY )).GetValue()); 505 506 sal_Bool bPreviewState = sal_False; 507 sal_uLong nSlot = rReq.GetSlot(); 508 509 std::auto_ptr< OutlineViewModelChangeGuard > aGuard; 510 if( pOlView && ( 511 (nSlot == SID_TRANSLITERATE_SENTENCE_CASE) || 512 (nSlot == SID_TRANSLITERATE_TITLE_CASE) || 513 (nSlot == SID_TRANSLITERATE_TOGGLE_CASE) || 514 (nSlot == SID_TRANSLITERATE_UPPER) || 515 (nSlot == SID_TRANSLITERATE_LOWER) || 516 (nSlot == SID_TRANSLITERATE_HALFWIDTH) || 517 (nSlot == SID_TRANSLITERATE_FULLWIDTH) || 518 (nSlot == SID_TRANSLITERATE_HIRAGANA) || 519 (nSlot == SID_TRANSLITERATE_KATAGANA) || 520 (nSlot == SID_CUT) || 521 // (nSlot == SID_COPY) || 522 (nSlot == SID_PASTE) || 523 (nSlot == SID_DELETE))) 524 { 525 aGuard.reset( new OutlineViewModelChangeGuard( *pOlView ) ); 526 } 527 528 switch ( nSlot ) 529 { 530 case SID_CUT: 531 { 532 if(HasCurrentFunction()) 533 { 534 GetCurrentFunction()->DoCut(); 535 } 536 else if (pOlView) 537 { 538 pOlView->DoCut(); 539 } 540 rReq.Done(); 541 bPreviewState = sal_True; 542 } 543 break; 544 545 case SID_COPY: 546 { 547 if(HasCurrentFunction()) 548 { 549 GetCurrentFunction()->DoCopy(); 550 } 551 else if (pOlView) 552 { 553 pOlView->DoCopy(); 554 } 555 rReq.Done(); 556 bPreviewState = sal_True; 557 } 558 break; 559 560 case SID_PASTE: 561 { 562 OutlineViewPageChangesGuard aGuard2(pOlView); 563 564 if(HasCurrentFunction()) 565 { 566 GetCurrentFunction()->DoPaste(); 567 } 568 else if (pOlView) 569 { 570 pOlView->DoPaste(); 571 } 572 rReq.Done(); 573 bPreviewState = sal_True; 574 } 575 break; 576 577 case SID_DELETE: 578 { 579 if( pOlView ) 580 { 581 OutlinerView* pOutlView = pOlView->GetViewByWindow(GetActiveWindow()); 582 if (pOutlView) 583 { 584 OutlineViewPageChangesGuard aGuard2(pOlView); 585 586 KeyCode aKCode(KEY_DELETE); 587 KeyEvent aKEvt( 0, aKCode ); 588 pOutlView->PostKeyEvent(aKEvt); 589 590 FunctionReference xFunc( GetCurrentFunction() ); 591 FuOutlineText* pFuOutlineText = dynamic_cast< FuOutlineText* >( xFunc.get() ); 592 if( pFuOutlineText ) 593 pFuOutlineText->UpdateForKeyPress (aKEvt); 594 } 595 } 596 rReq.Done(); 597 bPreviewState = sal_True; 598 } 599 break; 600 601 case SID_DRAWINGMODE: 602 case SID_NOTESMODE: 603 case SID_HANDOUTMODE: 604 case SID_DIAMODE: 605 case SID_OUTLINEMODE: 606 framework::FrameworkHelper::Instance(GetViewShellBase())->HandleModeChangeSlot( 607 nSlot, 608 rReq); 609 rReq.Done(); 610 break; 611 612 case SID_RULER: 613 SetRuler( !HasRuler() ); 614 Invalidate( SID_RULER ); 615 rReq.Done(); 616 break; 617 618 case SID_ZOOM_PREV: 619 { 620 if (mpZoomList->IsPreviousPossible()) 621 { 622 // Vorheriges ZoomRect einstellen 623 SetZoomRect(mpZoomList->GetPreviousZoomRect()); 624 } 625 rReq.Done (); 626 } 627 break; 628 629 case SID_ZOOM_NEXT: 630 { 631 if (mpZoomList->IsNextPossible()) 632 { 633 // Naechstes ZoomRect einstellen 634 SetZoomRect(mpZoomList->GetNextZoomRect()); 635 } 636 rReq.Done (); 637 } 638 break; 639 640 case SID_AUTOSPELL_CHECK: 641 { 642 GetDoc()->SetOnlineSpell(!GetDoc()->GetOnlineSpell()); 643 rReq.Done (); 644 } 645 break; 646 647 case SID_TRANSLITERATE_SENTENCE_CASE: 648 case SID_TRANSLITERATE_TITLE_CASE: 649 case SID_TRANSLITERATE_TOGGLE_CASE: 650 case SID_TRANSLITERATE_UPPER: 651 case SID_TRANSLITERATE_LOWER: 652 case SID_TRANSLITERATE_HALFWIDTH: 653 case SID_TRANSLITERATE_FULLWIDTH: 654 case SID_TRANSLITERATE_HIRAGANA: 655 case SID_TRANSLITERATE_KATAGANA: 656 { 657 OutlinerView* pOLV = pOlView->GetViewByWindow( GetActiveWindow() ); 658 if( pOLV ) 659 { 660 using namespace ::com::sun::star::i18n; 661 sal_Int32 nType = 0; 662 663 switch( nSlot ) 664 { 665 case SID_TRANSLITERATE_SENTENCE_CASE: 666 nType = TransliterationModulesExtra::SENTENCE_CASE; 667 break; 668 case SID_TRANSLITERATE_TITLE_CASE: 669 nType = TransliterationModulesExtra::TITLE_CASE; 670 break; 671 case SID_TRANSLITERATE_TOGGLE_CASE: 672 nType = TransliterationModulesExtra::TOGGLE_CASE; 673 break; 674 case SID_TRANSLITERATE_UPPER: 675 nType = TransliterationModules_LOWERCASE_UPPERCASE; 676 break; 677 case SID_TRANSLITERATE_LOWER: 678 nType = TransliterationModules_UPPERCASE_LOWERCASE; 679 break; 680 case SID_TRANSLITERATE_HALFWIDTH: 681 nType = TransliterationModules_FULLWIDTH_HALFWIDTH; 682 break; 683 case SID_TRANSLITERATE_FULLWIDTH: 684 nType = TransliterationModules_HALFWIDTH_FULLWIDTH; 685 break; 686 case SID_TRANSLITERATE_HIRAGANA: 687 nType = TransliterationModules_KATAKANA_HIRAGANA; 688 break; 689 case SID_TRANSLITERATE_KATAGANA: 690 nType = TransliterationModules_HIRAGANA_KATAKANA; 691 break; 692 } 693 694 pOLV->TransliterateText( nType ); 695 } 696 697 rReq.Done(); 698 bPreviewState = sal_True; 699 } 700 break; 701 702 // #96090# added Undo/Redo handling 703 case SID_UNDO : 704 { 705 OutlineViewPageChangesGuard aGuard2(pOlView); 706 ImpSidUndo(sal_False, rReq); 707 } 708 break; 709 case SID_REDO : 710 { 711 OutlineViewPageChangesGuard aGuard2(pOlView); 712 ImpSidRedo(sal_False, rReq); 713 } 714 break; 715 716 default: 717 break; 718 } 719 720 if( bPreviewState ) 721 Invalidate( SID_PREVIEW_STATE ); 722 723 Invalidate(SID_CUT); 724 Invalidate(SID_COPY); 725 Invalidate(SID_PASTE); 726 } 727 728 /************************************************************************* 729 |* 730 |* SfxRequests fuer permanente Funktionen 731 |* 732 \************************************************************************/ 733 734 void OutlineViewShell::FuPermanent(SfxRequest &rReq) 735 { 736 if(HasCurrentFunction()) 737 { 738 DeactivateCurrentFunction(true); 739 } 740 741 switch ( rReq.GetSlot() ) 742 { 743 case SID_EDIT_OUTLINER: 744 { 745 ::Outliner* pOutl = pOlView->GetOutliner(); 746 if( pOutl ) 747 { 748 pOutl->GetUndoManager().Clear(); 749 pOutl->UpdateFields(); 750 } 751 752 SetCurrentFunction( FuOutlineText::Create(this,GetActiveWindow(),pOlView,GetDoc(),rReq) ); 753 754 rReq.Done(); 755 } 756 break; 757 758 default: 759 break; 760 } 761 762 if(HasOldFunction()) 763 { 764 GetOldFunction()->Deactivate(); 765 SetOldFunction(0); 766 } 767 768 if(HasCurrentFunction()) 769 { 770 GetCurrentFunction()->Activate(); 771 SetOldFunction(GetCurrentFunction()); 772 } 773 } 774 775 776 IMPL_LINK( OutlineViewShell, ClipboardChanged, TransferableDataHelper*, pDataHelper ) 777 { 778 if ( pDataHelper ) 779 { 780 bPastePossible = ( pDataHelper->GetFormatCount() != 0 && 781 ( pDataHelper->HasFormat( FORMAT_STRING ) || 782 pDataHelper->HasFormat( FORMAT_RTF ) || 783 pDataHelper->HasFormat( SOT_FORMATSTR_ID_HTML ) ) ); 784 785 SfxBindings& rBindings = GetViewFrame()->GetBindings(); 786 rBindings.Invalidate( SID_PASTE ); 787 rBindings.Invalidate( SID_PASTE_SPECIAL ); 788 rBindings.Invalidate( SID_CLIPBOARD_FORMAT_ITEMS ); 789 } 790 return 0; 791 } 792 793 /************************************************************************* 794 |* 795 |* Status (Enabled/Disabled) von Menue-SfxSlots setzen 796 |* 797 \************************************************************************/ 798 799 void OutlineViewShell::GetMenuState( SfxItemSet &rSet ) 800 { 801 ViewShell::GetMenuState(rSet); 802 803 // Vorlagenkatalog darf nicht aufgerufen werden 804 rSet.DisableItem( SID_STYLE_CATALOG ); 805 806 rSet.Put(SfxBoolItem(SID_DIAMODE, sal_False)); 807 rSet.Put(SfxBoolItem(SID_DRAWINGMODE, sal_False)); 808 rSet.Put(SfxBoolItem(SID_OUTLINEMODE, sal_True)); 809 rSet.Put(SfxBoolItem(SID_NOTESMODE, sal_False)); 810 rSet.Put(SfxBoolItem(SID_HANDOUTMODE, sal_False)); 811 812 if (!mpZoomList->IsNextPossible()) 813 { 814 rSet.DisableItem(SID_ZOOM_NEXT); 815 } 816 if (!mpZoomList->IsPreviousPossible()) 817 { 818 rSet.DisableItem(SID_ZOOM_PREV); 819 } 820 821 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_ZOOM_IN ) || 822 SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_ZOOM_OUT ) ) 823 { 824 if( GetActiveWindow()->GetZoom() <= GetActiveWindow()->GetMinZoom() || GetDocSh()->IsUIActive() ) 825 rSet.DisableItem( SID_ZOOM_IN ); 826 if( GetActiveWindow()->GetZoom() >= GetActiveWindow()->GetMaxZoom() || GetDocSh()->IsUIActive() ) 827 rSet.DisableItem( SID_ZOOM_OUT ); 828 } 829 830 ::Outliner* pOutl = pOlView->GetOutliner(); 831 DBG_ASSERT(pOutl, "OutlineViewShell::GetMenuState(), no outliner? Fatality!"); 832 if( !pOutl ) 833 return; 834 835 // 'Alles auswaehlen' zulassen? 836 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_SELECTALL ) ) 837 { 838 sal_uLong nParaCount = pOutl->GetParagraphCount(); 839 sal_Bool bDisable = nParaCount == 0; 840 if (!bDisable && nParaCount == 1) 841 { 842 String aTest( pOutl->GetText( pOutl->GetParagraph( 0 ) ) ); 843 if (aTest.Len() == 0) 844 { 845 bDisable = sal_True; 846 } 847 } 848 if (bDisable) 849 rSet.DisableItem(SID_SELECTALL); 850 } 851 852 // Status des Lineals setzen 853 rSet.Put( SfxBoolItem( SID_RULER, HasRuler() ) ); 854 855 // Formatierung ein oder aus? 856 rSet.Put( SfxBoolItem( SID_OUTLINE_FORMAT, !pOutl->IsFlatMode() ) ); 857 858 if( pOutl->IsFlatMode() ) 859 rSet.DisableItem( SID_COLORVIEW ); 860 else 861 { 862 // Farbansicht ein/aus 863 sal_uLong nCntrl = pOutl->GetControlWord(); 864 sal_Bool bNoColor = sal_False; 865 if (nCntrl & EE_CNTRL_NOCOLORS) 866 bNoColor = sal_True; 867 868 rSet.Put( SfxBoolItem( SID_COLORVIEW, bNoColor ) ); 869 } 870 871 // Buttons der Werkzeugleiste 872 // zunaechst selektionsabhaengige: COLLAPSE, EXPAND 873 sal_Bool bDisableCollapse = sal_True; 874 sal_Bool bDisableExpand = sal_True; 875 sal_Bool bUnique = sal_True; 876 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(GetActiveWindow()); 877 List* pList = pOutlinerView->CreateSelectionList(); 878 Paragraph* pPara = (Paragraph*)pList->First(); 879 880 sal_Int16 nDepth; 881 sal_Int16 nTmpDepth = pOutl->GetDepth( (sal_uInt16) pOutl->GetAbsPos( pPara ) ); 882 bool bPage = pOutl->HasParaFlag( pPara, PARAFLAG_ISPAGE ); 883 while (pPara) 884 { 885 nDepth = pOutl->GetDepth( (sal_uInt16) pOutl->GetAbsPos( pPara ) ); 886 887 if( nDepth != nTmpDepth ) 888 bUnique = sal_False; 889 if( bPage != pOutl->HasParaFlag( pPara, PARAFLAG_ISPAGE ) ) 890 bUnique = sal_False; 891 if (!pOutl->IsExpanded(pPara) && pOutl->HasChilds(pPara)) 892 bDisableExpand = sal_False; 893 if (pOutl->IsExpanded(pPara) && pOutl->HasChilds(pPara)) 894 bDisableCollapse = sal_False; 895 896 pPara = (Paragraph*)pList->Next(); 897 } 898 899 delete pList; 900 901 if (bDisableExpand) 902 rSet.DisableItem(SID_OUTLINE_EXPAND); 903 if (bDisableCollapse) 904 rSet.DisableItem(SID_OUTLINE_COLLAPSE); 905 906 // ergibt die Selektion ein eindeutiges Praesentationslayout? 907 // wenn nicht, duerfen die Vorlagen nicht bearbeitet werden 908 SfxItemSet aSet(*rSet.GetPool(), SID_STATUS_LAYOUT, SID_STATUS_LAYOUT); 909 GetStatusBarState(aSet); 910 String aTest(((SfxStringItem&)aSet.Get(SID_STATUS_LAYOUT)).GetValue()); 911 if (aTest.Len() == 0) 912 { 913 bUnique = sal_False; 914 rSet.DisableItem(SID_PRESENTATION_TEMPLATES); 915 } 916 917 if (!bUnique) 918 rSet.DisableItem( SID_PRESENTATIONOBJECT ); 919 920 // jetzt die selektionsunabhaengigen: COLLAPSE_ALL, EXPAND_ALL 921 sal_Bool bDisableCollapseAll = sal_True; 922 sal_Bool bDisableExpandAll = sal_True; 923 924 // wenn schon die Selektion etwas kollabierbares/expandierbares enthaelt 925 if (!bDisableCollapse) 926 bDisableCollapseAll = sal_False; 927 if (!bDisableExpand) 928 bDisableExpandAll = sal_False; 929 930 // schade, so billig kommen wir nicht davon; alle Absaetze durchsuchen 931 if (bDisableCollapseAll || bDisableExpandAll) 932 { 933 sal_uLong nParaPos = 0; 934 pPara = pOutl->GetParagraph( nParaPos ); 935 while (pPara && (bDisableCollapseAll || bDisableExpandAll)) 936 { 937 if (!pOutl->IsExpanded(pPara) && pOutl->HasChilds(pPara)) 938 bDisableExpandAll = sal_False; 939 940 if (pOutl->IsExpanded(pPara) && pOutl->HasChilds(pPara)) 941 bDisableCollapseAll = sal_False; 942 943 pPara = pOutl->GetParagraph( ++nParaPos ); 944 } 945 } 946 947 if (bDisableExpandAll) 948 rSet.DisableItem(SID_OUTLINE_EXPAND_ALL); 949 if (bDisableCollapseAll) 950 rSet.DisableItem(SID_OUTLINE_COLLAPSE_ALL); 951 952 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_PASTE ) ) 953 { 954 if ( !pClipEvtLstnr ) 955 { 956 // create listener 957 pClipEvtLstnr = new TransferableClipboardListener( LINK( this, OutlineViewShell, ClipboardChanged ) ); 958 pClipEvtLstnr->acquire(); 959 pClipEvtLstnr->AddRemoveListener( GetActiveWindow(), sal_True ); 960 961 // get initial state 962 TransferableDataHelper aDataHelper( TransferableDataHelper::CreateFromSystemClipboard( GetActiveWindow() ) ); 963 bPastePossible = ( aDataHelper.GetFormatCount() != 0 && 964 ( aDataHelper.HasFormat( FORMAT_STRING ) || 965 aDataHelper.HasFormat( FORMAT_RTF ) || 966 aDataHelper.HasFormat( SOT_FORMATSTR_ID_HTML ) ) ); 967 } 968 969 if( !bPastePossible ) 970 { 971 rSet.DisableItem( SID_PASTE ); 972 } 973 } 974 975 if (!pOlView->GetViewByWindow(GetActiveWindow())->HasSelection()) 976 { 977 rSet.DisableItem(SID_CUT); 978 rSet.DisableItem(SID_COPY); 979 } 980 981 if (pOlView->GetOutliner()->IsModified()) 982 { 983 GetDoc()->SetChanged(sal_True); 984 } 985 986 // Da �berladen, muss hier der Status gesetzt werden 987 if( !GetDocSh()->IsModified() ) 988 { 989 rSet.DisableItem( SID_SAVEDOC ); 990 } 991 992 if ( GetDocSh()->IsReadOnly() ) 993 { 994 rSet.DisableItem( SID_AUTOSPELL_CHECK ); 995 } 996 else 997 { 998 if (GetDoc()->GetOnlineSpell()) 999 { 1000 rSet.Put(SfxBoolItem(SID_AUTOSPELL_CHECK, sal_True)); 1001 } 1002 else 1003 { 1004 rSet.Put(SfxBoolItem(SID_AUTOSPELL_CHECK, sal_False)); 1005 } 1006 } 1007 1008 // Feldbefehle 1009 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_MODIFY_FIELD ) ) 1010 { 1011 const SvxFieldItem* pFldItem = pOutlinerView->GetFieldAtSelection(); 1012 1013 if( !( pFldItem && (pFldItem->GetField()->ISA( SvxDateField ) || 1014 pFldItem->GetField()->ISA( SvxAuthorField ) || 1015 pFldItem->GetField()->ISA( SvxExtFileField ) || 1016 pFldItem->GetField()->ISA( SvxExtTimeField ) ) ) ) 1017 { 1018 rSet.DisableItem( SID_MODIFY_FIELD ); 1019 } 1020 } 1021 1022 if (SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_EXPAND_PAGE)) 1023 { 1024 sal_Bool bDisable = sal_True; 1025 sal_uInt16 i = 0; 1026 sal_uInt16 nCount = GetDoc()->GetSdPageCount(PK_STANDARD); 1027 pOlView->SetSelectedPages(); 1028 1029 while (i < nCount && bDisable) 1030 { 1031 SdPage* pPage = GetDoc()->GetSdPage(i, PK_STANDARD); 1032 1033 if (pPage->IsSelected()) 1034 { 1035 SdrObject* pObj = pPage->GetPresObj(PRESOBJ_OUTLINE); 1036 1037 if (pObj!=NULL ) 1038 { 1039 if( !pObj->IsEmptyPresObj() ) 1040 { 1041 bDisable = false; 1042 } 1043 else 1044 { 1045 // check if the object is in edit, than its temporarely not empty 1046 SdrTextObj* pTextObj = dynamic_cast< SdrTextObj* >( pObj ); 1047 if( pTextObj ) 1048 { 1049 OutlinerParaObject* pParaObj = pTextObj->GetEditOutlinerParaObject(); 1050 if( pParaObj ) 1051 { 1052 delete pParaObj; 1053 bDisable = false; 1054 } 1055 } 1056 } 1057 } 1058 } 1059 1060 i++; 1061 } 1062 1063 if (bDisable) 1064 { 1065 rSet.DisableItem(SID_EXPAND_PAGE); 1066 } 1067 } 1068 1069 if (SFX_ITEM_AVAILABLE == rSet.GetItemState(SID_SUMMARY_PAGE)) 1070 { 1071 sal_Bool bDisable = sal_True; 1072 sal_uInt16 i = 0; 1073 sal_uInt16 nCount = GetDoc()->GetSdPageCount(PK_STANDARD); 1074 pOlView->SetSelectedPages(); 1075 1076 while (i < nCount && bDisable) 1077 { 1078 SdPage* pPage = GetDoc()->GetSdPage(i, PK_STANDARD); 1079 1080 if (pPage->IsSelected()) 1081 { 1082 SdrObject* pObj = pPage->GetPresObj(PRESOBJ_TITLE); 1083 1084 if (pObj && !pObj->IsEmptyPresObj()) 1085 { 1086 bDisable = sal_False; 1087 } 1088 } 1089 1090 i++; 1091 } 1092 1093 if (bDisable) 1094 { 1095 rSet.DisableItem(SID_SUMMARY_PAGE); 1096 } 1097 } 1098 1099 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_THESAURUS ) ) 1100 { 1101 if ( !pOlView->IsTextEdit() ) 1102 { 1103 rSet.DisableItem( SID_THESAURUS ); 1104 } 1105 else 1106 { 1107 LanguageType eLang = GetDoc()->GetLanguage( EE_CHAR_LANGUAGE ); 1108 Reference< XThesaurus > xThesaurus( LinguMgr::GetThesaurus() ); 1109 Locale aLocale; 1110 1111 SvxLanguageToLocale( aLocale, eLang ); 1112 1113 if (!xThesaurus.is() || eLang == LANGUAGE_NONE || !xThesaurus->hasLocale(aLocale)) 1114 rSet.DisableItem( SID_THESAURUS ); 1115 } 1116 } 1117 1118 // Starten der Praesentation moeglich? 1119 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_PRESENTATION ) ) 1120 { 1121 sal_Bool bDisable = sal_True; 1122 sal_uInt16 nCount = GetDoc()->GetSdPageCount( PK_STANDARD ); 1123 1124 for( sal_uInt16 i = 0; i < nCount && bDisable; i++ ) 1125 { 1126 SdPage* pPage = GetDoc()->GetSdPage(i, PK_STANDARD); 1127 1128 if( !pPage->IsExcluded() ) 1129 bDisable = sal_False; 1130 } 1131 if( bDisable || GetDocSh()->IsPreview()) 1132 { 1133 rSet.DisableItem( SID_PRESENTATION ); 1134 } 1135 } 1136 1137 FuBullet::GetSlotState( rSet, this, GetViewFrame() ); 1138 1139 //rSet.DisableItem( SID_PRINTDOC ); 1140 //rSet.DisableItem( SID_PRINTDOCDIRECT ); 1141 //rSet.DisableItem( SID_SETUPPRINTER ); 1142 } 1143 1144 /************************************************************************* 1145 |* 1146 |* wird gerufen, wenn ScrollBar benutzt wird 1147 |* 1148 \************************************************************************/ 1149 1150 long OutlineViewShell::VirtHScrollHdl(ScrollBar* pHScroll) 1151 { 1152 long nThumb = pHScroll->GetThumbPos(); 1153 long nRange = pHScroll->GetRange().Len(); 1154 double fX = (double) nThumb / nRange; 1155 1156 Window* pWin = mpContentWindow.get(); 1157 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(pWin); 1158 long nViewWidth = pWin->PixelToLogic( 1159 pWin->GetSizePixel()).Width(); 1160 long nTextWidth = pOlView->GetPaperWidth(); 1161 nViewWidth = Max(nViewWidth, nTextWidth); 1162 long nCurrentPos = pOutlinerView->GetVisArea().Left(); 1163 long nTargetPos = (long)(fX * nViewWidth); 1164 long nDelta = nTargetPos - nCurrentPos; 1165 1166 pOutlinerView->HideCursor(); 1167 pOutlinerView->Scroll(-nDelta, 0); 1168 pOutlinerView->ShowCursor(sal_False); 1169 1170 pOlView->InvalidateSlideNumberArea(); 1171 return 0; 1172 } 1173 1174 /************************************************************************* 1175 |* 1176 |* wird gerufen, wenn ScrollBar benutzt wird 1177 |* 1178 \************************************************************************/ 1179 1180 long OutlineViewShell::VirtVScrollHdl(ScrollBar* pVScroll) 1181 { 1182 long nThumb = pVScroll->GetThumbPos(); 1183 long nRange = pVScroll->GetRange().Len(); 1184 double fY = (double) nThumb / nRange; 1185 1186 Window* pWin = mpContentWindow.get(); 1187 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(pWin); 1188 long nViewHeight = pWin->PixelToLogic( 1189 pWin->GetSizePixel()).Height(); 1190 long nTextHeight = pOlView->GetOutliner()->GetTextHeight(); 1191 nViewHeight += nTextHeight; 1192 long nCurrentPos = pOutlinerView->GetVisArea().Top(); 1193 long nTargetPos = (long)(fY * nViewHeight); 1194 long nDelta = nTargetPos - nCurrentPos; 1195 1196 pOutlinerView->HideCursor(); 1197 pOutlinerView->Scroll(0, -nDelta); 1198 pOutlinerView->ShowCursor(sal_False); 1199 1200 pOlView->InvalidateSlideNumberArea(); 1201 1202 return 0; 1203 } 1204 1205 /************************************************************************* 1206 |* 1207 |* PrepareClose, wird gerufen, wenn die Shell zestoert werden soll, 1208 |* leitet den Aufruf an die View weiter 1209 |* 1210 \************************************************************************/ 1211 1212 sal_uInt16 OutlineViewShell::PrepareClose( sal_Bool bUI, sal_Bool bForBrowsing ) 1213 { 1214 if( ViewShell::PrepareClose(bUI, bForBrowsing) != sal_True ) 1215 return sal_False; 1216 1217 return pOlView == NULL || pOlView->PrepareClose(bUI); 1218 } 1219 1220 1221 /************************************************************************* 1222 |* 1223 |* Zoomen mit Zoomfaktor, OutlinerView informieren 1224 |* 1225 \************************************************************************/ 1226 1227 void OutlineViewShell::SetZoom(long nZoom) 1228 { 1229 ViewShell::SetZoom(nZoom); 1230 1231 ::sd::Window* pWindow = mpContentWindow.get(); 1232 if (pWindow) 1233 { 1234 // OutputArea der OutlinerView aendern 1235 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(pWindow); 1236 Rectangle aWin(Point(0,0), pWindow->GetOutputSizePixel()); 1237 aWin = pWindow->PixelToLogic(aWin); 1238 pOutlinerView->SetOutputArea(aWin); 1239 } 1240 1241 // #106268# 1242 GetViewFrame()->GetBindings().Invalidate( SID_ATTR_ZOOM ); 1243 GetViewFrame()->GetBindings().Invalidate( SID_ATTR_ZOOMSLIDER ); 1244 } 1245 1246 /************************************************************************* 1247 |* 1248 |* Zoomen mit Zoomrechteck, OutlinerView informieren 1249 |* 1250 \************************************************************************/ 1251 1252 void OutlineViewShell::SetZoomRect(const Rectangle& rZoomRect) 1253 { 1254 ViewShell::SetZoomRect(rZoomRect); 1255 1256 ::sd::Window* pWindow = mpContentWindow.get(); 1257 if (pWindow) 1258 { 1259 // OutputArea der OutlinerView aendern 1260 OutlinerView* pOutlinerView = pOlView->GetViewByWindow(pWindow); 1261 Rectangle aWin(Point(0,0), pWindow->GetOutputSizePixel()); 1262 aWin = pWindow->PixelToLogic(aWin); 1263 pOutlinerView->SetOutputArea(aWin); 1264 } 1265 1266 // #106268# 1267 GetViewFrame()->GetBindings().Invalidate( SID_ATTR_ZOOM ); 1268 GetViewFrame()->GetBindings().Invalidate( SID_ATTR_ZOOMSLIDER ); 1269 } 1270 1271 /************************************************************************* 1272 |* 1273 |* Vorm Speichern das Model der Drawing Engine aktualisieren, dann den 1274 |* Call weiterleiten an die ObjectShell. 1275 |* 1276 \************************************************************************/ 1277 1278 void OutlineViewShell::Execute(SfxRequest& rReq) 1279 { 1280 bool bForwardCall = true; 1281 1282 switch(rReq.GetSlot()) 1283 { 1284 case SID_SAVEDOC: 1285 case SID_SAVEASDOC: 1286 PrepareClose(); 1287 break; 1288 1289 case SID_SEARCH_ITEM: 1290 // Forward this request to the the common (old) code of the 1291 // document shell. 1292 GetDocSh()->Execute (rReq); 1293 bForwardCall = false; 1294 break; 1295 1296 case SID_SPELL_DIALOG: 1297 { 1298 SfxViewFrame* pViewFrame = GetViewFrame(); 1299 if (rReq.GetArgs() != NULL) 1300 pViewFrame->SetChildWindow (SID_SPELL_DIALOG, 1301 ((const SfxBoolItem&) (rReq.GetArgs()-> 1302 Get(SID_SPELL_DIALOG))).GetValue()); 1303 else 1304 pViewFrame->ToggleChildWindow(SID_SPELL_DIALOG); 1305 1306 pViewFrame->GetBindings().Invalidate(SID_SPELL_DIALOG); 1307 rReq.Done (); 1308 1309 bForwardCall = false; 1310 } 1311 break; 1312 1313 default: 1314 OSL_TRACE ("OutlineViewShell::Execute(): can not handle slot %d", rReq.GetSlot()); 1315 break; 1316 1317 } 1318 1319 if (bForwardCall) 1320 ((DrawDocShell*)GetViewFrame()->GetObjectShell())->ExecuteSlot( rReq ); 1321 } 1322 1323 /************************************************************************* 1324 |* 1325 |* Read FrameViews data and set actual views data 1326 |* 1327 \************************************************************************/ 1328 1329 void OutlineViewShell::ReadFrameViewData(FrameView* pView) 1330 { 1331 ::Outliner* pOutl = pOlView->GetOutliner(); 1332 1333 if ( pView->IsNoAttribs() ) 1334 pOutl->SetFlatMode( sal_True ); // Attribut-Darstellung ausschalten 1335 else 1336 pOutl->SetFlatMode( sal_False ); // Attribut-Darstellung einschalten 1337 1338 sal_uLong nCntrl = pOutl->GetControlWord(); 1339 1340 if ( pView->IsNoColors() ) 1341 pOutl->SetControlWord(nCntrl | EE_CNTRL_NOCOLORS); // Farbansicht ausschalten 1342 else 1343 pOutl->SetControlWord(nCntrl & ~EE_CNTRL_NOCOLORS); // Farbansicht einschalten 1344 1345 sal_uInt16 nPage = mpFrameView->GetSelectedPage(); 1346 pLastPage = GetDoc()->GetSdPage( nPage, PK_STANDARD ); 1347 pOlView->SetActualPage(pLastPage); 1348 } 1349 1350 1351 1352 /************************************************************************* 1353 |* 1354 |* Write actual views data to FrameView 1355 |* 1356 \************************************************************************/ 1357 1358 void OutlineViewShell::WriteFrameViewData() 1359 { 1360 ::Outliner* pOutl = pOlView->GetOutliner(); 1361 1362 sal_uLong nCntrl = pOutl->GetControlWord(); 1363 sal_Bool bNoColor = sal_False; 1364 if (nCntrl & EE_CNTRL_NOCOLORS) 1365 bNoColor = sal_True; 1366 mpFrameView->SetNoColors(bNoColor); 1367 mpFrameView->SetNoAttribs( pOutl->IsFlatMode() ); 1368 SdPage* pActualPage = pOlView->GetActualPage(); 1369 DBG_ASSERT(pActualPage, "No current page"); 1370 if( pActualPage ) 1371 mpFrameView->SetSelectedPage((pActualPage->GetPageNum() - 1) / 2); 1372 } 1373 1374 1375 /************************************************************************* 1376 |* 1377 |* SfxRequests fuer StatusBar bearbeiten 1378 |* 1379 \************************************************************************/ 1380 1381 void OutlineViewShell::ExecStatusBar(SfxRequest&) 1382 { 1383 } 1384 1385 /************************************************************************* 1386 |* 1387 |* Statuswerte der Statusbar zurueckgeben 1388 |* 1389 \************************************************************************/ 1390 1391 void OutlineViewShell::GetStatusBarState(SfxItemSet& rSet) 1392 { 1393 // Zoom-Item 1394 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_ATTR_ZOOM ) ) 1395 { 1396 SvxZoomItem* pZoomItem; 1397 sal_uInt16 nZoom = (sal_uInt16) GetActiveWindow()->GetZoom(); 1398 1399 pZoomItem = new SvxZoomItem( SVX_ZOOM_PERCENT, nZoom ); 1400 1401 // Bereich einschraenken 1402 sal_uInt16 nZoomValues = SVX_ZOOM_ENABLE_ALL; 1403 nZoomValues &= ~SVX_ZOOM_ENABLE_OPTIMAL; 1404 nZoomValues &= ~SVX_ZOOM_ENABLE_WHOLEPAGE; 1405 nZoomValues &= ~SVX_ZOOM_ENABLE_PAGEWIDTH; 1406 1407 pZoomItem->SetValueSet( nZoomValues ); 1408 rSet.Put( *pZoomItem ); 1409 delete pZoomItem; 1410 } 1411 1412 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_ATTR_ZOOMSLIDER ) ) 1413 { 1414 if (GetDocSh()->IsUIActive() || !GetActiveWindow() ) 1415 { 1416 rSet.DisableItem( SID_ATTR_ZOOMSLIDER ); 1417 } 1418 else 1419 { 1420 sd::Window * pActiveWindow = GetActiveWindow(); 1421 SvxZoomSliderItem aZoomItem( (sal_uInt16) pActiveWindow->GetZoom(), (sal_uInt16)pActiveWindow->GetMinZoom(), (sal_uInt16)pActiveWindow->GetMaxZoom() ) ; 1422 aZoomItem.AddSnappingPoint(100); 1423 rSet.Put( aZoomItem ); 1424 } 1425 } 1426 1427 1428 // Seitenanzeige und Layout 1429 /* 1430 if( SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_STATUS_PAGE ) || 1431 SFX_ITEM_AVAILABLE == rSet.GetItemState( SID_STATUS_LAYOUT ) ) 1432 */ 1433 sal_uInt16 nPageCount = GetDoc()->GetSdPageCount( PK_STANDARD ); 1434 String aPageStr, aLayoutStr; 1435 1436 ::sd::Window* pWin = GetActiveWindow(); 1437 OutlinerView* pActiveView = pOlView->GetViewByWindow( pWin ); 1438 ::Outliner* pOutliner = pOlView->GetOutliner(); 1439 List* pSelList = (List*)pActiveView->CreateSelectionList(); 1440 Paragraph* pFirstPara = (Paragraph*)pSelList->First(); 1441 Paragraph* pLastPara = (Paragraph*)pSelList->Last(); 1442 1443 if( !pOutliner->HasParaFlag(pFirstPara,PARAFLAG_ISPAGE) ) 1444 pFirstPara = pOlView->GetPrevTitle( pFirstPara ); 1445 1446 if( !pOutliner->HasParaFlag(pLastPara, PARAFLAG_ISPAGE) ) 1447 pLastPara = pOlView->GetPrevTitle( pLastPara ); 1448 1449 delete pSelList; // die wurde extra fuer uns erzeugt 1450 1451 // nur eine Seite selektiert? 1452 if( pFirstPara == pLastPara ) 1453 { 1454 // wieviele Seiten sind vor der selektierten Seite? 1455 sal_uLong nPos = 0L; 1456 while( pFirstPara ) 1457 { 1458 pFirstPara = pOlView->GetPrevTitle( pFirstPara ); 1459 if( pFirstPara ) 1460 nPos++; 1461 } 1462 1463 if( nPos >= GetDoc()->GetSdPageCount( PK_STANDARD ) ) 1464 nPos = 0; 1465 1466 SdrPage* pPage = GetDoc()->GetSdPage( (sal_uInt16) nPos, PK_STANDARD ); 1467 1468 aPageStr = String(SdResId( STR_SD_PAGE )); 1469 aPageStr += sal_Unicode(' '); 1470 aPageStr += String::CreateFromInt32( (sal_Int32)(nPos + 1) ); // sal_uLong -> sal_Int32 1471 aPageStr.AppendAscii( RTL_CONSTASCII_STRINGPARAM( " / " )); 1472 aPageStr += String::CreateFromInt32( nPageCount ); 1473 1474 aLayoutStr = pPage->GetLayoutName(); 1475 aLayoutStr.Erase( aLayoutStr.SearchAscii( SD_LT_SEPARATOR ) ); 1476 //Now, CurrentPage property change is already sent for DrawView and OutlineView, so it is not necessary to send again here 1477 if(m_StrOldPageName!=aPageStr) 1478 { 1479 GetViewShellBase().GetDrawController().fireSwitchCurrentPage(nPos); 1480 m_StrOldPageName = aPageStr; 1481 } 1482 } 1483 rSet.Put( SfxStringItem( SID_STATUS_PAGE, aPageStr ) ); 1484 rSet.Put( SfxStringItem( SID_STATUS_LAYOUT, aLayoutStr ) ); 1485 } 1486 1487 /************************************************************************* 1488 |* 1489 |* Command event 1490 |* 1491 \************************************************************************/ 1492 1493 void OutlineViewShell::Command( const CommandEvent& rCEvt, ::sd::Window* pWin ) 1494 { 1495 if ( rCEvt.GetCommand() == COMMAND_CONTEXTMENU ) 1496 { 1497 GetActiveWindow()->ReleaseMouse(); 1498 1499 OutlinerView* pOLV = pOlView->GetViewByWindow(GetActiveWindow()); 1500 Point aPos(rCEvt.GetMousePosPixel()); 1501 1502 if (pOLV && pOLV->IsWrongSpelledWordAtPos(aPos)) 1503 { 1504 // #91457# Popup for Online-Spelling now handled by DrawDocShell 1505 // Link aLink = LINK(GetDoc(), SdDrawDocument, OnlineSpellCallback); 1506 Link aLink = LINK(GetDocSh(), DrawDocShell, OnlineSpellCallback); 1507 1508 pOLV->ExecuteSpellPopup(aPos, &aLink); 1509 } 1510 else 1511 { 1512 GetViewFrame()->GetDispatcher()->ExecutePopup(SdResId(RID_OUTLINE_POPUP)); 1513 } 1514 } 1515 else 1516 { 1517 ViewShell::Command( rCEvt, pWin ); 1518 1519 // ggfs. Preview den neuen Kontext mitteilen 1520 Invalidate( SID_PREVIEW_STATE ); 1521 1522 } 1523 } 1524 1525 1526 /************************************************************************* 1527 |* 1528 |* Keyboard event 1529 |* 1530 \************************************************************************/ 1531 1532 sal_Bool OutlineViewShell::KeyInput(const KeyEvent& rKEvt, ::sd::Window* pWin) 1533 { 1534 sal_Bool bReturn = sal_False; 1535 OutlineViewPageChangesGuard aGuard(pOlView); 1536 1537 if (pWin == NULL && HasCurrentFunction()) 1538 { 1539 bReturn = GetCurrentFunction()->KeyInput(rKEvt); 1540 } 1541 1542 // nein, weiterleiten an Basisklasse 1543 else 1544 { 1545 bReturn = ViewShell::KeyInput(rKEvt, pWin); 1546 } 1547 1548 Invalidate(SID_STYLE_EDIT); 1549 Invalidate(SID_STYLE_NEW); 1550 Invalidate(SID_STYLE_DELETE); 1551 Invalidate(SID_STYLE_UPDATE_BY_EXAMPLE); 1552 Invalidate(SID_STYLE_NEW_BY_EXAMPLE); 1553 Invalidate(SID_STYLE_WATERCAN); 1554 Invalidate(SID_STYLE_FAMILY5); 1555 1556 // Pruefen und Unterscheiden von CursorBewegungs- oder Eingabe-Keys 1557 KeyCode aKeyGroup( rKEvt.GetKeyCode().GetGroup() ); 1558 if( (aKeyGroup != KEYGROUP_CURSOR && aKeyGroup != KEYGROUP_FKEYS) || 1559 (GetActualPage() != pLastPage) ) 1560 { 1561 Invalidate( SID_PREVIEW_STATE ); 1562 } 1563 1564 return(bReturn); 1565 } 1566 1567 1568 /************************************************************************* 1569 |* 1570 |* Optimale Groesse zurueckgeben 1571 |* 1572 \************************************************************************/ 1573 1574 Size OutlineViewShell::GetOptimalSizePixel() const 1575 { 1576 Size aResult(200, 200); 1577 if (pOlView) 1578 { 1579 ::Outliner* pOutliner = pOlView->GetOutliner(); 1580 if (pOutliner) 1581 { 1582 Size aTemp = pOutliner->CalcTextSize(); 1583 aTemp = GetActiveWindow()->LogicToPixel(aTemp); 1584 aResult.Width() = Max(aResult.Width(), aTemp.Width()); 1585 aResult.Height() = Max(aResult.Height(), aTemp.Height()); 1586 if (4 * aResult.Height() > 3 * aResult.Width()) 1587 { 1588 aResult.Height() = 3 * aResult.Width() / 4; 1589 } 1590 } 1591 } 1592 1593 // und jetzt jetzt das Standardgelumpe draufaddieren 1594 aResult.Width() += mpVerticalScrollBar->GetSizePixel().Width(); 1595 aResult.Height() += mpHorizontalScrollBar->GetSizePixel().Height(); 1596 //!!! + System::GetMenuBarHeightPixel(); // statt Titlebar 1597 return aResult; 1598 } 1599 1600 1601 /************************************************************************* 1602 |* 1603 |* Text der Selektion zurueckgeben 1604 |* 1605 \************************************************************************/ 1606 1607 String OutlineViewShell::GetSelectionText(sal_Bool bCompleteWords) 1608 { 1609 String aStrSelection; 1610 ::Outliner* pOl = pOlView->GetOutliner(); 1611 OutlinerView* pOutlinerView = pOlView->GetViewByWindow( GetActiveWindow() ); 1612 1613 if (pOl && pOlView) 1614 { 1615 if (bCompleteWords) 1616 { 1617 ESelection aSel = pOutlinerView->GetSelection(); 1618 String aStrCurrentDelimiters = pOl->GetWordDelimiters(); 1619 1620 pOl->SetWordDelimiters( String( RTL_CONSTASCII_USTRINGPARAM( " .,;\"'" ))); 1621 aStrSelection = pOl->GetWord( aSel.nEndPara, aSel.nEndPos ); 1622 pOl->SetWordDelimiters( aStrCurrentDelimiters ); 1623 } 1624 else 1625 { 1626 aStrSelection = pOutlinerView->GetSelected(); 1627 } 1628 } 1629 1630 return (aStrSelection); 1631 } 1632 1633 1634 /************************************************************************* 1635 |* 1636 |* Ist etwas selektiert? 1637 |* 1638 \************************************************************************/ 1639 1640 sal_Bool OutlineViewShell::HasSelection(sal_Bool bText) const 1641 { 1642 sal_Bool bReturn = sal_False; 1643 1644 if (bText) 1645 { 1646 OutlinerView* pOutlinerView = pOlView->GetViewByWindow( GetActiveWindow() ); 1647 1648 if (pOutlinerView && pOutlinerView->GetSelected().Len() != 0) 1649 { 1650 bReturn = sal_True; 1651 } 1652 } 1653 1654 return bReturn; 1655 } 1656 1657 1658 /************************************************************************* 1659 |* 1660 |* Status der Attribut-Items 1661 |* 1662 \************************************************************************/ 1663 1664 void OutlineViewShell::GetAttrState( SfxItemSet& rSet ) 1665 { 1666 SfxWhichIter aIter( rSet ); 1667 sal_uInt16 nWhich = aIter.FirstWhich(); 1668 SfxAllItemSet aAllSet( *rSet.GetPool() ); 1669 1670 while ( nWhich ) 1671 { 1672 sal_uInt16 nSlotId = SfxItemPool::IsWhich(nWhich) 1673 ? GetPool().GetSlotId(nWhich) 1674 : nWhich; 1675 1676 switch ( nSlotId ) 1677 { 1678 case SID_STYLE_FAMILY2: 1679 case SID_STYLE_FAMILY3: 1680 { 1681 rSet.DisableItem( nWhich ); 1682 } 1683 break; 1684 1685 case SID_STYLE_FAMILY5: 1686 { 1687 SfxStyleSheet* pStyleSheet = pOlView->GetViewByWindow(GetActiveWindow())->GetStyleSheet(); 1688 1689 if( pStyleSheet ) 1690 { 1691 pStyleSheet = ((SdStyleSheet*)pStyleSheet)->GetPseudoStyleSheet(); 1692 1693 if (pStyleSheet) 1694 { 1695 SfxTemplateItem aItem( nWhich, pStyleSheet->GetName() ); 1696 aAllSet.Put( aItem, aItem.Which() ); 1697 } 1698 } 1699 1700 if( !pStyleSheet ) 1701 { 1702 SfxTemplateItem aItem( nWhich, String() ); 1703 aAllSet.Put( aItem, aItem.Which() ); 1704 // rSet.DisableItem( nWhich ); 1705 } 1706 } 1707 break; 1708 1709 case SID_STYLE_EDIT: 1710 { 1711 ISfxTemplateCommon* pTmplCommon = SFX_APP()->GetCurrentTemplateCommon(GetViewFrame()->GetBindings()); 1712 1713 if (pTmplCommon && pTmplCommon->GetActualFamily() == SD_STYLE_FAMILY_PSEUDO) 1714 { 1715 SfxItemSet aSet(*rSet.GetPool(), SID_STATUS_LAYOUT, SID_STATUS_LAYOUT); 1716 GetStatusBarState(aSet); 1717 String aRealStyle(((SfxStringItem&) aSet.Get(SID_STATUS_LAYOUT)).GetValue()); 1718 1719 if (!aRealStyle.Len()) 1720 { 1721 // Kein eindeutiger Layoutname gefunden 1722 rSet.DisableItem(nWhich); 1723 } 1724 } 1725 } 1726 break; 1727 1728 case SID_STYLE_UPDATE_BY_EXAMPLE: 1729 { 1730 ::sd::Window* pActWin = GetActiveWindow(); 1731 OutlinerView* pOV = pOlView->GetViewByWindow(pActWin); 1732 ESelection aESel(pOV->GetSelection()); 1733 1734 if (aESel.nStartPara != aESel.nEndPara || 1735 aESel.nStartPos != aESel.nEndPos) 1736 // aufgespannte Selektion, also StyleSheet und/oder 1737 // Attributierung nicht zwingend eindeutig 1738 rSet.DisableItem(nWhich); 1739 } 1740 break; 1741 1742 case SID_STYLE_NEW: 1743 case SID_STYLE_DELETE: 1744 case SID_STYLE_NEW_BY_EXAMPLE: 1745 case SID_STYLE_WATERCAN: 1746 { 1747 rSet.DisableItem(nWhich); 1748 } 1749 break; 1750 } 1751 1752 nWhich = aIter.NextWhich(); 1753 } 1754 1755 rSet.Put( aAllSet, sal_False ); 1756 } 1757 1758 1759 1760 /************************************************************************* 1761 |* 1762 |* MouseButtonUp event 1763 |* 1764 \************************************************************************/ 1765 1766 void OutlineViewShell::MouseButtonUp(const MouseEvent& rMEvt, ::sd::Window* pWin) 1767 { 1768 // Zuerst die Basisklasse 1769 ViewShell::MouseButtonUp(rMEvt, pWin); 1770 1771 Invalidate(SID_STYLE_EDIT); 1772 Invalidate(SID_STYLE_NEW); 1773 Invalidate(SID_STYLE_DELETE); 1774 Invalidate(SID_STYLE_UPDATE_BY_EXAMPLE); 1775 Invalidate(SID_STYLE_NEW_BY_EXAMPLE); 1776 Invalidate(SID_STYLE_WATERCAN); 1777 Invalidate(SID_STYLE_FAMILY5); 1778 1779 // ggfs. Preview den neuen Kontext mitteilen 1780 if( GetActualPage() != pLastPage ) 1781 Invalidate( SID_PREVIEW_STATE ); 1782 } 1783 1784 1785 1786 SdPage* OutlineViewShell::getCurrentPage() const 1787 { 1788 // since there are no master pages in outline view, we can 1789 // for now use the GetActualPage method 1790 return const_cast<OutlineViewShell*>(this)->GetActualPage(); 1791 } 1792 1793 /************************************************************************* 1794 |* 1795 |* Liefert die erste selektierte Seite zurueck. 1796 |* Wenn nichts selektiert ist, wird die erste Seite zurueckgeliefert. 1797 |* 1798 \************************************************************************/ 1799 SdPage* OutlineViewShell::GetActualPage() 1800 { 1801 return pOlView->GetActualPage(); 1802 } 1803 1804 1805 void OutlineViewShell::UpdatePreview( SdPage* pPage, sal_Bool ) 1806 { 1807 const bool bNewPage = pPage != pLastPage; 1808 pLastPage = pPage; 1809 if (bNewPage) 1810 { 1811 OutlineViewPageChangesGuard aGuard(pOlView); 1812 SetCurrentPage(pPage); 1813 } 1814 } 1815 1816 /************************************************************************* 1817 |* 1818 |* Update Title 1819 |* 1820 \************************************************************************/ 1821 1822 bool OutlineViewShell::UpdateTitleObject( SdPage* pPage, Paragraph* pPara ) 1823 { 1824 DBG_ASSERT( pPage, "sd::OutlineViewShell::UpdateTitleObject(), pPage == 0?" ); 1825 DBG_ASSERT( pPara, "sd::OutlineViewShell::UpdateTitleObject(), pPara == 0?" ); 1826 1827 if( !pPage || !pPara ) 1828 return false; 1829 1830 ::Outliner* pOutliner = pOlView->GetOutliner(); 1831 SdrTextObj* pTO = pOlView->GetTitleTextObject( pPage ); 1832 OutlinerParaObject* pOPO = NULL; 1833 1834 String aTest( pOutliner->GetText( pPara ) ); 1835 bool bText = aTest.Len() > 0; 1836 bool bNewObject = false; 1837 1838 if( bText ) 1839 { 1840 // create a title object if we don't have one but have text 1841 if( !pTO ) 1842 { 1843 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateTitleObject(), no undo for model change!?" ); 1844 pTO = pOlView->CreateTitleTextObject(pPage); 1845 bNewObject = sal_True; 1846 } 1847 1848 // if we have a title object and a text, set the text 1849 if( pTO ) 1850 { 1851 pOPO = pOutliner->CreateParaObject( (sal_uInt16) pOutliner->GetAbsPos( pPara ), 1 ); 1852 pOPO->SetOutlinerMode( OUTLINERMODE_TITLEOBJECT ); 1853 pOPO->SetVertical( pTO->IsVerticalWriting() ); 1854 if( pTO->GetOutlinerParaObject() && (pOPO->GetTextObject() == pTO->GetOutlinerParaObject()->GetTextObject()) ) 1855 { 1856 // do nothing, same text already set 1857 delete pOPO; 1858 } 1859 else 1860 { 1861 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateTitleObject(), no undo for model change!?" ); 1862 if( !bNewObject && pOlView->isRecordingUndo() ) 1863 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoObjectSetText(*pTO,0)); 1864 1865 pTO->SetOutlinerParaObject( pOPO ); 1866 pTO->SetEmptyPresObj( sal_False ); 1867 pTO->ActionChanged(); 1868 } 1869 } 1870 } 1871 else if( pTO ) 1872 { 1873 // no text but object available? 1874 // outline object available, but we have no text 1875 if(pPage->IsPresObj(pTO)) 1876 { 1877 // if it is not already empty 1878 if( !pTO->IsEmptyPresObj() ) 1879 { 1880 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateTitleObject(), no undo for model change!?" ); 1881 1882 // make it empty 1883 if( pOlView->isRecordingUndo() ) 1884 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoObjectSetText(*pTO,0)); 1885 pPage->RestoreDefaultText( pTO ); 1886 pTO->SetEmptyPresObj(sal_True); 1887 pTO->ActionChanged(); 1888 } 1889 } 1890 else 1891 { 1892 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateTitleObject(), no undo for model change!?" ); 1893 // outline object is not part of the layout, delete it 1894 if( pOlView->isRecordingUndo() ) 1895 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoRemoveObject(*pTO)); 1896 pPage->RemoveObject(pTO->GetOrdNum()); 1897 } 1898 } 1899 1900 return bNewObject; 1901 } 1902 1903 /************************************************************************* 1904 |* 1905 |* Update LayoutObject 1906 |* 1907 \************************************************************************/ 1908 1909 bool OutlineViewShell::UpdateOutlineObject( SdPage* pPage, Paragraph* pPara ) 1910 { 1911 DBG_ASSERT( pPage, "sd::OutlineViewShell::UpdateOutlineObject(), pPage == 0?" ); 1912 DBG_ASSERT( pPara, "sd::OutlineViewShell::UpdateOutlineObject(), pPara == 0?" ); 1913 1914 if( !pPage || !pPara ) 1915 return false; 1916 1917 ::Outliner* pOutliner = pOlView->GetOutliner(); 1918 OutlinerParaObject* pOPO = NULL; 1919 SdrTextObj* pTO = NULL; 1920 1921 sal_Bool bNewObject = sal_False; 1922 1923 sal_uInt16 eOutlinerMode = OUTLINERMODE_TITLEOBJECT; 1924 pTO = (SdrTextObj*)pPage->GetPresObj( PRESOBJ_TEXT ); 1925 if( !pTO ) 1926 { 1927 eOutlinerMode = OUTLINERMODE_OUTLINEOBJECT; 1928 pTO = pOlView->GetOutlineTextObject( pPage ); 1929 } 1930 1931 // wieviele Absaetze in der Gliederung? 1932 sal_uLong nTitlePara = pOutliner->GetAbsPos( pPara ); 1933 sal_uLong nPara = nTitlePara + 1; 1934 sal_uLong nParasInLayout = 0L; 1935 pPara = pOutliner->GetParagraph( nPara ); 1936 while( pPara && !pOutliner->HasParaFlag(pPara, PARAFLAG_ISPAGE) ) 1937 { 1938 nParasInLayout++; 1939 pPara = pOutliner->GetParagraph( ++nPara ); 1940 } 1941 if( nParasInLayout ) 1942 { 1943 // ein OutlinerParaObject erzeugen 1944 pPara = pOutliner->GetParagraph( nTitlePara + 1 ); 1945 pOPO = pOutliner->CreateParaObject( (sal_uInt16) nTitlePara + 1, (sal_uInt16) nParasInLayout ); 1946 } 1947 1948 if( pOPO ) 1949 { 1950 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateOutlineObject(), no undo for model change!?" ); 1951 1952 // do we need an outline text object? 1953 if( !pTO ) 1954 { 1955 pTO = pOlView->CreateOutlineTextObject( pPage ); 1956 bNewObject = sal_True; 1957 } 1958 1959 // Seitenobjekt, Gliederungstext im Outliner: 1960 // Text uebernehmen 1961 if( pTO ) 1962 { 1963 pOPO->SetVertical( pTO->IsVerticalWriting() ); 1964 pOPO->SetOutlinerMode( eOutlinerMode ); 1965 if( pTO->GetOutlinerParaObject() && (pOPO->GetTextObject() == pTO->GetOutlinerParaObject()->GetTextObject()) ) 1966 { 1967 // do nothing, same text already set 1968 delete pOPO; 1969 } 1970 else 1971 { 1972 if( !bNewObject && pOlView->isRecordingUndo() ) 1973 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoObjectSetText(*pTO,0)); 1974 1975 pTO->SetOutlinerParaObject( pOPO ); 1976 pTO->SetEmptyPresObj( sal_False ); 1977 pTO->ActionChanged(); 1978 } 1979 } 1980 } 1981 else if( pTO ) 1982 { 1983 // Seitenobjekt, aber kein Gliederungstext: 1984 // wenn Objekt in Praesentationsliste der Seite ist -> Defaulttext, 1985 // sonst Objekt loeschen 1986 if( pPage->IsPresObj(pTO) ) 1987 { 1988 if( !pTO->IsEmptyPresObj() ) 1989 { 1990 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateOutlineObject(), no undo for model change!?" ); 1991 1992 // loescht auch altes OutlinerParaObject 1993 if( pOlView->isRecordingUndo() ) 1994 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoObjectSetText(*pTO,0)); 1995 pPage->RestoreDefaultText( pTO ); 1996 pTO->SetEmptyPresObj(sal_True); 1997 pTO->ActionChanged(); 1998 } 1999 } 2000 else 2001 { 2002 DBG_ASSERT( pOlView->isRecordingUndo(), "sd::OutlineViewShell::UpdateOutlineObject(), no undo for model change!?" ); 2003 if( pOlView->isRecordingUndo() ) 2004 pOlView->AddUndo(GetDoc()->GetSdrUndoFactory().CreateUndoRemoveObject(*pTO)); 2005 pPage->RemoveObject(pTO->GetOrdNum()); 2006 } 2007 } 2008 2009 return bNewObject; 2010 } 2011 2012 2013 /************************************************************************* 2014 |* 2015 |* Outliner aus Stream fuellen 2016 |* 2017 \************************************************************************/ 2018 2019 sal_uLong OutlineViewShell::Read(SvStream& rInput, const String& rBaseURL, sal_uInt16 eFormat) 2020 { 2021 sal_uLong bRet = 0; 2022 2023 ::Outliner* pOutl = pOlView->GetOutliner(); 2024 2025 { 2026 OutlineViewPageChangesGuard aGuard( pOlView ); 2027 OutlineViewModelChangeGuard aGuard2( *pOlView ); 2028 2029 bRet = pOutl->Read( rInput, rBaseURL, eFormat, GetDocSh()->GetHeaderAttributes() ); 2030 2031 SdPage* pPage = GetDoc()->GetSdPage( GetDoc()->GetSdPageCount(PK_STANDARD) - 1, PK_STANDARD );; 2032 SfxStyleSheet* pTitleSheet = pPage->GetStyleSheetForPresObj( PRESOBJ_TITLE ); 2033 SfxStyleSheet* pOutlSheet = pPage->GetStyleSheetForPresObj( PRESOBJ_OUTLINE ); 2034 2035 sal_uInt16 nParaCount = (sal_uInt16)pOutl->GetParagraphCount(); 2036 if ( nParaCount > 0 ) 2037 { 2038 for ( sal_uInt16 nPara = 0; nPara < nParaCount; nPara++ ) 2039 { 2040 pOlView->UpdateParagraph( nPara ); 2041 2042 sal_Int16 nDepth = pOutl->GetDepth( nPara ); 2043 2044 if( (nDepth == 0) || !nPara ) 2045 { 2046 Paragraph* pPara = pOutl->GetParagraph( nPara ); 2047 pOutl->SetDepth(pPara, -1); 2048 pOutl->SetParaFlag(pPara, PARAFLAG_ISPAGE); 2049 2050 pOutl->SetStyleSheet( nPara, pTitleSheet ); 2051 2052 if( nPara ) // first slide already exists 2053 pOlView->InsertSlideForParagraph( pPara ); 2054 } 2055 else 2056 { 2057 pOutl->SetDepth( pOutl->GetParagraph( nPara ), nDepth - 1 ); 2058 String aStyleSheetName( pOutlSheet->GetName() ); 2059 aStyleSheetName.Erase( aStyleSheetName.Len() - 1, 1 ); 2060 aStyleSheetName += String::CreateFromInt32( nDepth ); 2061 SfxStyleSheetBasePool* pStylePool = GetDoc()->GetStyleSheetPool(); 2062 SfxStyleSheet* pStyle = (SfxStyleSheet*) pStylePool->Find( aStyleSheetName, pOutlSheet->GetFamily() ); 2063 DBG_ASSERT( pStyle, "AutoStyleSheetName - Style not found!" ); 2064 if ( pStyle ) 2065 pOutl->SetStyleSheet( nPara, pStyle ); 2066 } 2067 } 2068 } 2069 } 2070 2071 pOutl->GetUndoManager().Clear(); 2072 2073 return( bRet ); 2074 } 2075 2076 void OutlineViewShell::WriteUserDataSequence ( ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >& rSequence, sal_Bool bBrowse ) 2077 { 2078 WriteFrameViewData(); 2079 2080 ViewShell::WriteUserDataSequence( rSequence, bBrowse ); 2081 } 2082 2083 void OutlineViewShell::ReadUserDataSequence ( const ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >& rSequence, sal_Bool bBrowse ) 2084 { 2085 WriteFrameViewData(); 2086 2087 ViewShell::ReadUserDataSequence( rSequence, bBrowse ); 2088 2089 ReadFrameViewData( mpFrameView ); 2090 } 2091 2092 void OutlineViewShell::VisAreaChanged(const Rectangle& rRect) 2093 { 2094 ViewShell::VisAreaChanged( rRect ); 2095 2096 GetViewShellBase().GetDrawController().FireVisAreaChanged(rRect); 2097 } 2098 2099 /** If there is a valid controller then create a new instance of 2100 <type>AccessibleDrawDocumentView</type>. Otherwise delegate this call 2101 to the base class to return a default object (probably an empty 2102 reference). 2103 */ 2104 ::com::sun::star::uno::Reference< 2105 ::com::sun::star::accessibility::XAccessible> 2106 OutlineViewShell::CreateAccessibleDocumentView (::sd::Window* pWindow) 2107 { 2108 OSL_ASSERT (GetViewShell()!=NULL); 2109 if (GetViewShell()->GetController() != NULL) 2110 { 2111 ::accessibility::AccessibleOutlineView* pDocumentView = 2112 new ::accessibility::AccessibleOutlineView ( 2113 pWindow, 2114 this, 2115 GetViewShell()->GetController(), 2116 pWindow->GetAccessibleParentWindow()->GetAccessible()); 2117 pDocumentView->Init(); 2118 return ::com::sun::star::uno::Reference< 2119 ::com::sun::star::accessibility::XAccessible> 2120 (static_cast< ::com::sun::star::uno::XWeak*>(pDocumentView), 2121 ::com::sun::star::uno::UNO_QUERY); 2122 } 2123 else 2124 { 2125 OSL_TRACE ("OutlineViewShell::CreateAccessibleDocumentView: no controller"); 2126 return ViewShell::CreateAccessibleDocumentView (pWindow); 2127 } 2128 } 2129 2130 2131 2132 2133 void OutlineViewShell::GetState (SfxItemSet& rSet) 2134 { 2135 // Iterate over all requested items in the set. 2136 SfxWhichIter aIter( rSet ); 2137 sal_uInt16 nWhich = aIter.FirstWhich(); 2138 while (nWhich) 2139 { 2140 switch (nWhich) 2141 { 2142 case SID_SEARCH_ITEM: 2143 case SID_SEARCH_OPTIONS: 2144 // Call common (old) implementation in the document shell. 2145 GetDocSh()->GetState (rSet); 2146 break; 2147 default: 2148 OSL_TRACE ("OutlineViewShell::GetState(): can not handle which id %d", nWhich); 2149 break; 2150 } 2151 nWhich = aIter.NextWhich(); 2152 } 2153 } 2154 2155 2156 2157 2158 void OutlineViewShell::SetCurrentPage (SdPage* pPage) 2159 { 2160 // Adapt the selection of the model. 2161 for (sal_uInt16 i=0; i<GetDoc()->GetSdPageCount(PK_STANDARD); i++) 2162 GetDoc()->SetSelected( 2163 GetDoc()->GetSdPage(i, PK_STANDARD), 2164 sal_False); 2165 GetDoc()->SetSelected (pPage, sal_True); 2166 2167 DrawController& rController(GetViewShellBase().GetDrawController()); 2168 rController.FireSelectionChangeListener(); 2169 rController.FireSwitchCurrentPage (pPage); 2170 2171 pOlView->SetActualPage(pPage); 2172 } 2173 2174 2175 } // end of namespace sd 2176