/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sd.hxx" #include "fuexpand.hxx" #include #include #include #include #include #include #include #include "app.hrc" #include "strings.hrc" #include "pres.hxx" #include "View.hxx" #include "sdpage.hxx" #include "Outliner.hxx" #include "drawview.hxx" #include "drawdoc.hxx" #include "ViewShell.hxx" #include "DrawDocShell.hxx" #include "sdresid.hxx" #include "optsitem.hxx" #include "sdmod.hxx" #include #include namespace sd { TYPEINIT1( FuExpandPage, FuPoor ); /************************************************************************* |* |* Konstruktor |* \************************************************************************/ FuExpandPage::FuExpandPage ( ViewShell* pViewSh, ::sd::Window* pWin, ::sd::View* pView, SdDrawDocument* pDoc, SfxRequest& rReq) : FuPoor(pViewSh, pWin, pView, pDoc, rReq) { } FunctionReference FuExpandPage::Create( ViewShell* pViewSh, ::sd::Window* pWin, ::sd::View* pView, SdDrawDocument* pDoc, SfxRequest& rReq ) { FunctionReference xFunc( new FuExpandPage( pViewSh, pWin, pView, pDoc, rReq ) ); xFunc->DoExecute(rReq); return xFunc; } void FuExpandPage::DoExecute( SfxRequest& ) { // Selektierte Seite finden (nur Standard-Seiten) SdPage* pActualPage = NULL; USHORT i = 0; USHORT nCount = mpDoc->GetSdPageCount(PK_STANDARD); while (!pActualPage && i < nCount) { if (mpDoc->GetSdPage(i, PK_STANDARD)->IsSelected()) { pActualPage = mpDoc->GetSdPage(i, PK_STANDARD); } i++; } if (pActualPage) { ::sd::Outliner* pOutl = new ::sd::Outliner( mpDoc, OUTLINERMODE_OUTLINEOBJECT ); pOutl->SetUpdateMode(FALSE); pOutl->EnableUndo(FALSE); if (mpDocSh) pOutl->SetRefDevice( SD_MOD()->GetRefDevice( *mpDocSh ) ); pOutl->SetDefTab( mpDoc->GetDefaultTabulator() ); pOutl->SetStyleSheetPool((SfxStyleSheetPool*) mpDoc->GetStyleSheetPool()); SetOfByte aVisibleLayers = pActualPage->TRG_GetMasterPageVisibleLayers(); USHORT nActualPageNum = pActualPage->GetPageNum(); SdPage* pActualNotesPage = (SdPage*) mpDoc->GetPage(nActualPageNum + 1); SdrTextObj* pActualOutline = (SdrTextObj*) pActualPage->GetPresObj(PRESOBJ_OUTLINE); if (pActualOutline) { const bool bUndo = mpView->IsUndoEnabled(); if( bUndo ) mpView->BegUndo(String(SdResId(STR_UNDO_EXPAND_PAGE))); // Aktuelles Gliederungsobjekt in Outliner setzen OutlinerParaObject* pParaObj = pActualOutline->GetOutlinerParaObject(); pOutl->SetText(*pParaObj); // Harte Absatz- und Zeichenattribute entfernen SfxItemSet aEmptyEEAttr(mpDoc->GetPool(), EE_ITEMS_START, EE_ITEMS_END); ULONG nParaCount1 = pOutl->GetParagraphCount(); for (USHORT nPara = 0; nPara < nParaCount1; nPara++) { pOutl->QuickRemoveCharAttribs(nPara); pOutl->SetParaAttribs(nPara, aEmptyEEAttr); } USHORT nPos = 2; Paragraph* pPara = pOutl->GetParagraph( 0 ); while (pPara) { ULONG nParaPos = pOutl->GetAbsPos( pPara ); sal_Int16 nDepth = pOutl->GetDepth( (USHORT) nParaPos ); if ( nDepth == 0 ) { // Seite mit Titel & Gliederung! SdPage* pPage = (SdPage*) mpDoc->AllocPage(FALSE); pPage->SetSize(pActualPage->GetSize() ); pPage->SetBorder(pActualPage->GetLftBorder(), pActualPage->GetUppBorder(), pActualPage->GetRgtBorder(), pActualPage->GetLwrBorder() ); pPage->SetName(String()); // Seite hinter aktueller Seite einfuegen mpDoc->InsertPage(pPage, nActualPageNum + nPos); nPos++; if( bUndo ) mpView->AddUndo(mpDoc->GetSdrUndoFactory().CreateUndoNewPage(*pPage)); // MasterPage der aktuellen Seite verwenden pPage->TRG_SetMasterPage(pActualPage->TRG_GetMasterPage()); pPage->SetLayoutName(pActualPage->GetLayoutName()); pPage->SetAutoLayout(AUTOLAYOUT_ENUM, TRUE); pPage->TRG_SetMasterPageVisibleLayers(aVisibleLayers); // Notiz-Seite SdPage* pNotesPage = (SdPage*) mpDoc->AllocPage(FALSE); pNotesPage->SetSize(pActualNotesPage->GetSize()); pNotesPage->SetBorder(pActualNotesPage->GetLftBorder(), pActualNotesPage->GetUppBorder(), pActualNotesPage->GetRgtBorder(), pActualNotesPage->GetLwrBorder() ); pNotesPage->SetPageKind(PK_NOTES); pNotesPage->SetName(String()); // Seite hinter aktueller Seite einfuegen mpDoc->InsertPage(pNotesPage, nActualPageNum + nPos); nPos++; if( bUndo ) mpView->AddUndo(mpDoc->GetSdrUndoFactory().CreateUndoNewPage(*pNotesPage)); // MasterPage der aktuellen Seite verwenden pNotesPage->TRG_SetMasterPage(pActualNotesPage->TRG_GetMasterPage()); pNotesPage->SetLayoutName(pActualNotesPage->GetLayoutName()); pNotesPage->SetAutoLayout(pActualNotesPage->GetAutoLayout(), TRUE); pNotesPage->TRG_SetMasterPageVisibleLayers(aVisibleLayers); // Title-Textobjekt erstellen SdrTextObj* pTextObj = (SdrTextObj*) pPage->GetPresObj(PRESOBJ_TITLE); // OutlinerParaObject* pOutlinerParaObject = pOutl->CreateParaObject( (USHORT) nParaPos, 1); pOutlinerParaObject->SetOutlinerMode(OUTLINERMODE_TITLEOBJECT); if( pOutlinerParaObject->GetDepth(0) != -1 ) { SdrOutliner* pTempOutl = SdrMakeOutliner( OUTLINERMODE_TITLEOBJECT, mpDoc ); pTempOutl->SetText( *pOutlinerParaObject ); delete pOutlinerParaObject; pTempOutl->SetDepth( pTempOutl->GetParagraph( 0 ), -1 ); pOutlinerParaObject = pTempOutl->CreateParaObject(); delete pTempOutl; } pTextObj->SetOutlinerParaObject(pOutlinerParaObject); pTextObj->SetEmptyPresObj(FALSE); SfxStyleSheet* pSheet = pPage->GetStyleSheetForPresObj(PRESOBJ_TITLE); pTextObj->NbcSetStyleSheet(pSheet, FALSE); ULONG nChildCount = pOutl->GetChildCount(pPara); if (nChildCount > 0) { // Gliederungs-Textobjekt erstellen SdrTextObj* pOutlineObj = (SdrTextObj*) pPage->GetPresObj(PRESOBJ_OUTLINE); pPara = pOutl->GetParagraph( ++nParaPos ); OutlinerParaObject* pOPO = pOutl->CreateParaObject( (USHORT) nParaPos, (USHORT) nChildCount); // -- SdrOutliner* pTempOutl = SdrMakeOutliner( OUTLINERMODE_OUTLINEOBJECT, mpDoc ); pTempOutl->SetText( *pOPO ); ULONG nParaCount2 = pTempOutl->GetParagraphCount(); ULONG nPara; for( nPara = 0; nPara < nParaCount2; nPara++ ) { pTempOutl->SetDepth ( pTempOutl->GetParagraph( nPara ), pTempOutl->GetDepth((USHORT) nPara ) - 1); } delete pOPO; pOPO = pTempOutl->CreateParaObject(); delete pTempOutl; // -- pOutlineObj->SetOutlinerParaObject( pOPO ); pOutlineObj->SetEmptyPresObj(FALSE); // Harte Attribute entfernen (Flag auf TRUE) SfxItemSet aAttr(mpDoc->GetPool()); aAttr.Put(XLineStyleItem(XLINE_NONE)); aAttr.Put(XFillStyleItem(XFILL_NONE)); pOutlineObj->SetMergedItemSet(aAttr); } } pPara = pOutl->GetParagraph( ++nParaPos ); } if( bUndo ) mpView->EndUndo(); } delete pOutl; mpViewShell->GetViewFrame()->GetDispatcher()->Execute(SID_DELETE_PAGE, SFX_CALLMODE_SYNCHRON | SFX_CALLMODE_RECORD); } } } // end of namespace sd /* vim:set shiftwidth=4 softtabstop=4 expandtab: */