Files
libreoffice/sc/source/ui/undo/undostyl.cxx
Rüdiger Timm e187ea1788 INTEGRATION: CWS ooo19126 (1.4.328); FILE MERGED
2005/09/05 15:08:44 rt 1.4.328.1: #i54170# Change license header: remove SISSL
2005-09-08 21:40:20 +00:00

317 lines
8.6 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: undostyl.cxx,v $
*
* $Revision: 1.5 $
*
* last change: $Author: rt $ $Date: 2005-09-08 22:40:20 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#ifdef PCH
#include "ui_pch.hxx"
#endif
#pragma hdrstop
// INCLUDE ---------------------------------------------------------------
#include <svtools/itemset.hxx>
#include <vcl/virdev.hxx>
#include "undostyl.hxx"
#include "docsh.hxx"
#include "stlpool.hxx"
#include "printfun.hxx"
#include "scmod.hxx"
#include "inputhdl.hxx"
#include "globstr.hrc"
// -----------------------------------------------------------------------
TYPEINIT1(ScUndoModifyStyle, ScSimpleUndo);
TYPEINIT1(ScUndoApplyPageStyle, ScSimpleUndo);
// -----------------------------------------------------------------------
//
// modify style (cell or page style)
//
ScStyleSaveData::ScStyleSaveData() :
pItems( NULL )
{
}
ScStyleSaveData::ScStyleSaveData( const ScStyleSaveData& rOther ) :
aName( rOther.aName ),
aParent( rOther.aParent )
{
if (rOther.pItems)
pItems = new SfxItemSet( *rOther.pItems );
else
pItems = NULL;
}
ScStyleSaveData::~ScStyleSaveData()
{
delete pItems;
}
ScStyleSaveData& ScStyleSaveData::operator=( const ScStyleSaveData& rOther )
{
aName = rOther.aName;
aParent = rOther.aParent;
delete pItems;
if (rOther.pItems)
pItems = new SfxItemSet( *rOther.pItems );
else
pItems = NULL;
return *this;
}
void ScStyleSaveData::InitFromStyle( const SfxStyleSheetBase* pSource )
{
if ( pSource )
{
aName = pSource->GetName();
aParent = pSource->GetParent();
delete pItems;
pItems = new SfxItemSet( ((SfxStyleSheetBase*)pSource)->GetItemSet() );
}
else
*this = ScStyleSaveData(); // empty
}
// -----------------------------------------------------------------------
ScUndoModifyStyle::ScUndoModifyStyle( ScDocShell* pDocSh, SfxStyleFamily eFam,
const ScStyleSaveData& rOld, const ScStyleSaveData& rNew ) :
ScSimpleUndo( pDocSh ),
eFamily( eFam ),
aOldData( rOld ),
aNewData( rNew )
{
}
ScUndoModifyStyle::~ScUndoModifyStyle()
{
}
String ScUndoModifyStyle::GetComment() const
{
USHORT nId = (eFamily == SFX_STYLE_FAMILY_PARA) ?
STR_UNDO_EDITCELLSTYLE :
STR_UNDO_EDITPAGESTYLE;
return ScGlobal::GetRscString( nId );
}
void lcl_DocStyleChanged( ScDocument* pDoc, SfxStyleSheetBase* pStyle, BOOL bRemoved )
{
//! move to document or docshell
VirtualDevice aVDev;
Point aLogic = aVDev.LogicToPixel( Point(1000,1000), MAP_TWIP );
double nPPTX = aLogic.X() / 1000.0;
double nPPTY = aLogic.Y() / 1000.0;
Fraction aZoom(1,1);
pDoc->StyleSheetChanged( pStyle, bRemoved, &aVDev, nPPTX, nPPTY, aZoom, aZoom );
ScInputHandler* pHdl = SC_MOD()->GetInputHdl();
if (pHdl)
pHdl->ForgetLastPattern();
}
// static
void ScUndoModifyStyle::DoChange( ScDocShell* pDocSh, const String& rName,
SfxStyleFamily eStyleFamily, const ScStyleSaveData& rData )
{
ScDocument* pDoc = pDocSh->GetDocument();
ScStyleSheetPool* pStlPool = pDoc->GetStyleSheetPool();
String aNewName = rData.GetName();
BOOL bDelete = ( aNewName.Len() == 0 ); // no new name -> delete style
BOOL bNew = ( rName.Len() == 0 && !bDelete ); // creating new style
SfxStyleSheetBase* pStyle = NULL;
if ( rName.Len() )
{
// find old style to modify
pStyle = pStlPool->Find( rName, eStyleFamily );
DBG_ASSERT( pStyle, "style not found" );
if ( pStyle && !bDelete )
{
// set new name
pStyle->SetName( aNewName );
}
}
else if ( !bDelete )
{
// create style (with new name)
pStyle = &pStlPool->Make( aNewName, eStyleFamily, SFXSTYLEBIT_USERDEF );
}
if ( pStyle )
{
if ( bDelete )
{
if ( eStyleFamily == SFX_STYLE_FAMILY_PARA )
lcl_DocStyleChanged( pDoc, pStyle, TRUE ); // TRUE: remove usage of style
else
pDoc->RemovePageStyleInUse( rName );
// delete style
pStlPool->Erase( pStyle );
}
else
{
// modify style
String aNewParent = rData.GetParent();
if ( aNewParent != pStyle->GetParent() )
pStyle->SetParent( aNewParent );
SfxItemSet& rStyleSet = pStyle->GetItemSet();
const SfxItemSet* pNewSet = rData.GetItems();
DBG_ASSERT( pNewSet, "no ItemSet for style" );
if (pNewSet)
rStyleSet.Set( *pNewSet, FALSE );
if ( eStyleFamily == SFX_STYLE_FAMILY_PARA )
{
lcl_DocStyleChanged( pDoc, pStyle, FALSE ); // cell styles: row heights
}
else
{
// page styles
if ( bNew && aNewName != rName )
pDoc->RenamePageStyleInUse( rName, aNewName );
if (pNewSet)
pDoc->ModifyStyleSheet( *pStyle, *pNewSet );
pDocSh->PageStyleModified( aNewName, TRUE );
}
}
}
pDocSh->PostPaint( 0,0,0, MAXCOL,MAXROW,MAXTAB, PAINT_GRID|PAINT_LEFT );
//! undo/redo document modifications for deleted styles
//! undo/redo modifications of number formatter
}
void ScUndoModifyStyle::Undo()
{
BeginUndo();
DoChange( pDocShell, aNewData.GetName(), eFamily, aOldData );
EndUndo();
}
void ScUndoModifyStyle::Redo()
{
BeginRedo();
DoChange( pDocShell, aOldData.GetName(), eFamily, aNewData );
EndRedo();
}
void ScUndoModifyStyle::Repeat(SfxRepeatTarget& rTarget)
{
}
BOOL ScUndoModifyStyle::CanRepeat(SfxRepeatTarget& rTarget) const
{
return FALSE; // no repeat possible
}
// -----------------------------------------------------------------------
//
// apply page style
//
ScUndoApplyPageStyle::ApplyStyleEntry::ApplyStyleEntry( SCTAB nTab, const String& rOldStyle ) :
mnTab( nTab ),
maOldStyle( rOldStyle )
{
}
ScUndoApplyPageStyle::ScUndoApplyPageStyle( ScDocShell* pDocSh, const String& rNewStyle ) :
ScSimpleUndo( pDocSh ),
maNewStyle( rNewStyle )
{
}
ScUndoApplyPageStyle::~ScUndoApplyPageStyle()
{
}
void ScUndoApplyPageStyle::AddSheetAction( SCTAB nTab, const String& rOldStyle )
{
maEntries.push_back( ApplyStyleEntry( nTab, rOldStyle ) );
}
String ScUndoApplyPageStyle::GetComment() const
{
return ScGlobal::GetRscString( STR_UNDO_APPLYPAGESTYLE );
}
void ScUndoApplyPageStyle::Undo()
{
BeginUndo();
for( ApplyStyleVec::const_iterator aIt = maEntries.begin(), aEnd = maEntries.end(); aIt != aEnd; ++aIt )
{
pDocShell->GetDocument()->SetPageStyle( aIt->mnTab, aIt->maOldStyle );
ScPrintFunc( pDocShell, pDocShell->GetPrinter(), aIt->mnTab ).UpdatePages();
}
EndUndo();
}
void ScUndoApplyPageStyle::Redo()
{
BeginRedo();
for( ApplyStyleVec::const_iterator aIt = maEntries.begin(), aEnd = maEntries.end(); aIt != aEnd; ++aIt )
{
pDocShell->GetDocument()->SetPageStyle( aIt->mnTab, maNewStyle );
ScPrintFunc( pDocShell, pDocShell->GetPrinter(), aIt->mnTab ).UpdatePages();
}
EndRedo();
}
void ScUndoApplyPageStyle::Repeat(SfxRepeatTarget& rTarget)
{
//! set same page style to current tab
}
BOOL ScUndoApplyPageStyle::CanRepeat(SfxRepeatTarget& rTarget) const
{
return FALSE;
}