2008-12-19 10:32:51 +0100 od r265718 : #i70748# method <SwWW8Writer::StartTOX(..)> - correction for custom to outline style assigned paragraph styles 2008-12-19 09:24:41 +0100 od r265715 : #i70748# method <HandleModifyAtTxtNode(..)> - retrieve former applied list style before potential reset of empty list style due to set outline level 2008-12-17 15:33:57 +0100 hde r265608 : #i97013# 2008-12-17 14:43:42 +0100 od r265603 : #i70748# adjust fix i44177 - adjustment of to outline style assigned paragraph styles only for OOo-Templates. 2008-12-17 12:59:42 +0100 od r265598 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - special handling of OOo 2.x document regarding outline numbering of headings. 2008-12-17 12:45:53 +0100 od r265597 : #i70748# method <HandleModifyAtTxtNode(..)> - correct determination of new and former applied list style 2008-12-17 10:18:41 +0100 od r265581 : #i97312# method <XMLTextNumRuleInfo::Set(..)> - check, if numbering rules instance contains any numbering rule. 2008-12-16 14:34:22 +0100 hde r265542 : #i97013 2008-12-16 14:20:24 +0100 od r265541 : #i70748# adjust documentation of "Which"-ID numbers 2008-12-16 14:19:49 +0100 od r265539 : #i70748# Adjust Attribute-Function-Mapping table due to new attribute 2008-12-16 14:06:24 +0100 od r265538 : #i70748# - Correct handling of to outline style assigned paragraph styles on reset of all paragraph style attributes - WW8 import: Consider refactoring of paragraph style's outline level attribute - NO_NUMBERING define no longer exsits. 2008-12-16 10:37:19 +0100 od r265530 : #i70478# Correction on moving outline paragraph up respectively down in its outline level: - Check also outline paragraph, which are not an outline via a to outline style assigned paragraph style, if action is applicable. 2008-12-16 09:10:13 +0100 hde r265523 : #i97277 2008-12-16 09:09:30 +0100 hde r265522 : #i97277 2008-12-16 09:07:40 +0100 hde r265521 : Added control and purged obsolete id's 2008-12-10 13:09:36 +0100 od r265174 : #i70748# correction of previous fix due to warning-free code 2008-12-10 13:03:30 +0100 od r265172 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - Due to performance issues avoid retrieving outline level value from paragraph's paragraph style for each paragraph. Instead retrieve current outline level value from paragraph, which is the inherited value from its paragraph style, and only when it is needed. 2008-12-09 16:50:36 +0100 ufi r265117 : help 2008-12-09 16:49:50 +0100 ufi r265116 : help 2008-12-09 15:45:05 +0100 od r265107 : #i70748# method <XMLTextImportHelper::SetStyleAndAttrs(..)> - some minor rework and check access to paragraph styles 2008-12-09 15:42:04 +0100 od r265106 : #i70748# adjust name of local variable to avoid hiding of class variable 2008-12-09 15:40:51 +0100 od r265105 : #i70748# correct initialization order 2008-12-09 15:35:07 +0100 od r265101 : #i70748# remove duplicate entry in certain property map 2008-12-09 15:33:39 +0100 od r265100 : #i70748# add end of file token 2008-12-07 15:11:54 +0100 zhaojianwei r264952 : conflicts left not to be resolved when cws rebase 2008-12-04 14:52:21 +0100 zhaojianwei r264846 : CWS-TOOLING: rebase CWS outlinelevel to trunk@264325 (milestone: DEV300:m36) 2008-11-28 03:42:09 +0100 zhaojianwei r264525 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:39 +0100 zhaojianwei r264524 : #i70748#: migrate CWS outlinelevel to SVN 2008-11-28 03:41:11 +0100 zhaojianwei r264523 : #i70748#: migrate CWS outlinelevel to SVN
1316 lines
47 KiB
C++
1316 lines
47 KiB
C++
/*************************************************************************
|
|
*
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
|
*
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
|
*
|
|
* $RCSfile: docst.cxx,v $
|
|
* $Revision: 1.36.136.1 $
|
|
*
|
|
* 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
|
|
* <http://www.openoffice.org/license.html>
|
|
* for a copy of the LGPLv3 License.
|
|
*
|
|
************************************************************************/
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
#include "precompiled_sw.hxx"
|
|
#include <com/sun/star/style/XStyleFamiliesSupplier.hpp>
|
|
#include <com/sun/star/beans/XPropertySet.hpp>
|
|
#include <com/sun/star/container/XNameAccess.hpp>
|
|
|
|
#include <hintids.hxx>
|
|
#include <sfx2/app.hxx>
|
|
#include <svtools/whiter.hxx>
|
|
#include <sfx2/templdlg.hxx>
|
|
#include <sfx2/tplpitem.hxx>
|
|
#include <sfx2/request.hxx>
|
|
#include <sfx2/dispatch.hxx>
|
|
#include <sfx2/newstyle.hxx>
|
|
#include <svtools/macitem.hxx>
|
|
#include <svx/brshitem.hxx>
|
|
#include <svtools/stritem.hxx>
|
|
#include <svtools/languageoptions.hxx>
|
|
#include <svx/eeitem.hxx>
|
|
#include <svx/htmlmode.hxx>
|
|
#include <swmodule.hxx>
|
|
#include <wdocsh.hxx>
|
|
#include <fmtfsize.hxx>
|
|
#include <fchrfmt.hxx>
|
|
#include <svx/htmlcfg.hxx>
|
|
#include <SwStyleNameMapper.hxx>
|
|
#include <undobj.hxx>
|
|
#include <swundo.hxx>
|
|
|
|
#include "view.hxx"
|
|
#include "wrtsh.hxx"
|
|
#include "docsh.hxx"
|
|
#include "uitool.hxx"
|
|
#include "cmdid.h"
|
|
#include "globals.hrc"
|
|
#include "viewopt.hxx"
|
|
#include "doc.hxx"
|
|
#include "swstyle.h"
|
|
#include "frmfmt.hxx"
|
|
#include "charfmt.hxx"
|
|
#include "poolfmt.hxx"
|
|
#include "pagedesc.hxx"
|
|
#include "docstyle.hxx"
|
|
#include "uiitems.hxx"
|
|
#include "fmtcol.hxx"
|
|
#include "frmmgr.hxx" //SwFrmValid
|
|
#include "swevent.hxx"
|
|
#include "edtwin.hxx"
|
|
#include "unochart.hxx"
|
|
|
|
#include "app.hrc"
|
|
#include <fmtui.hrc>
|
|
#include "swabstdlg.hxx"
|
|
// --> OD 2008-03-27 #refactorlists#
|
|
#include <list.hxx>
|
|
// <--
|
|
|
|
#include <paratr.hxx> //#outline level,add by zhaojianwei
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung:
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
void SwDocShell::StateStyleSheet(SfxItemSet& rSet, SwWrtShell* pSh)
|
|
{
|
|
SfxWhichIter aIter(rSet);
|
|
USHORT nWhich = aIter.FirstWhich();
|
|
USHORT nActualFamily = USHRT_MAX;
|
|
|
|
SwWrtShell* pShell = pSh ? pSh : GetWrtShell();
|
|
if(!pShell)
|
|
{
|
|
while (nWhich)
|
|
{
|
|
rSet.DisableItem(nWhich);
|
|
nWhich = aIter.NextWhich();
|
|
}
|
|
return;
|
|
}
|
|
else
|
|
{
|
|
SfxViewFrame* pFrame = pShell->GetView().GetViewFrame();
|
|
const ISfxTemplateCommon* pCommon = SFX_APP()->GetCurrentTemplateCommon(pFrame->GetBindings());
|
|
if( pCommon )
|
|
nActualFamily = static_cast< USHORT >(pCommon->GetActualFamily());
|
|
}
|
|
|
|
while (nWhich)
|
|
{
|
|
// aktuelle Vorlage zu jeder Familie ermitteln
|
|
//
|
|
String aName;
|
|
switch (nWhich)
|
|
{
|
|
case SID_STYLE_APPLY:
|
|
{//hier wird die Vorlage und ihre Familie an die StyleBox
|
|
//uebergeben, damit diese Familie angezeigt wird
|
|
if(pShell->IsFrmSelected())
|
|
{
|
|
SwFrmFmt* pFmt = pShell->GetCurFrmFmt();
|
|
if( pFmt )
|
|
aName = pFmt->GetName();
|
|
}
|
|
else
|
|
{
|
|
SwTxtFmtColl* pColl = pShell->GetCurTxtFmtColl();
|
|
if(pColl)
|
|
aName = pColl->GetName();
|
|
}
|
|
rSet.Put(SfxTemplateItem(nWhich, aName));
|
|
}
|
|
break;
|
|
case SID_STYLE_FAMILY1:
|
|
if( !pShell->IsFrmSelected() )
|
|
{
|
|
SwCharFmt* pFmt = pShell->GetCurCharFmt();
|
|
if(pFmt)
|
|
aName = pFmt->GetName();
|
|
else
|
|
aName = *SwStyleNameMapper::GetTextUINameArray()[
|
|
RES_POOLCOLL_STANDARD - RES_POOLCOLL_TEXT_BEGIN ];
|
|
rSet.Put(SfxTemplateItem(nWhich, aName));
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_FAMILY2:
|
|
if(!pShell->IsFrmSelected())
|
|
{
|
|
SwTxtFmtColl* pColl = pShell->GetCurTxtFmtColl();
|
|
if(pColl)
|
|
aName = pColl->GetName();
|
|
|
|
SfxTemplateItem aItem(nWhich, aName);
|
|
|
|
USHORT nMask = 0;
|
|
if( pDoc->get(IDocumentSettingAccess::HTML_MODE) )
|
|
nMask = SWSTYLEBIT_HTML;
|
|
else
|
|
{
|
|
const int nSelection = pShell->GetFrmType(0,TRUE);
|
|
if(pShell->GetCurTOX())
|
|
nMask = SWSTYLEBIT_IDX ;
|
|
else if(nSelection & FRMTYPE_HEADER ||
|
|
nSelection & FRMTYPE_FOOTER ||
|
|
nSelection & FRMTYPE_TABLE ||
|
|
nSelection & FRMTYPE_FLY_ANY ||
|
|
nSelection & FRMTYPE_FOOTNOTE ||
|
|
nSelection & FRMTYPE_FTNPAGE)
|
|
nMask = SWSTYLEBIT_EXTRA;
|
|
else
|
|
nMask = SWSTYLEBIT_TEXT;
|
|
}
|
|
|
|
aItem.SetValue(nMask);
|
|
rSet.Put(aItem);
|
|
}
|
|
|
|
break;
|
|
|
|
case SID_STYLE_FAMILY3:
|
|
|
|
if( pDoc->get(IDocumentSettingAccess::HTML_MODE) )
|
|
rSet.DisableItem( nWhich );
|
|
else
|
|
{
|
|
SwFrmFmt* pFmt = pShell->GetCurFrmFmt();
|
|
if(pFmt && pShell->IsFrmSelected())
|
|
{
|
|
aName = pFmt->GetName();
|
|
rSet.Put(SfxTemplateItem(nWhich, aName));
|
|
}
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_FAMILY4:
|
|
{
|
|
SvxHtmlOptions* pHtmlOpt = SvxHtmlOptions::Get();
|
|
if( pDoc->get(IDocumentSettingAccess::HTML_MODE) && !pHtmlOpt->IsPrintLayoutExtension())
|
|
rSet.DisableItem( nWhich );
|
|
else
|
|
{
|
|
USHORT n = pShell->GetCurPageDesc( FALSE );
|
|
if( n < pShell->GetPageDescCnt() )
|
|
aName = pShell->GetPageDesc( n ).GetName();
|
|
|
|
rSet.Put(SfxTemplateItem(nWhich, aName));
|
|
}
|
|
}
|
|
break;
|
|
case SID_STYLE_FAMILY5:
|
|
{
|
|
const SwNumRule* pRule = pShell->GetCurNumRule();
|
|
if( pRule )
|
|
aName = pRule->GetName();
|
|
|
|
rSet.Put(SfxTemplateItem(nWhich, aName));
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_WATERCAN:
|
|
{
|
|
SwEditWin& rEdtWin = pShell->GetView().GetEditWin();
|
|
SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
|
|
rSet.Put(SfxBoolItem(nWhich, pApply && pApply->eType != 0));
|
|
}
|
|
break;
|
|
case SID_STYLE_UPDATE_BY_EXAMPLE:
|
|
if( pShell->IsFrmSelected()
|
|
? SFX_STYLE_FAMILY_FRAME != nActualFamily
|
|
: ( SFX_STYLE_FAMILY_FRAME == nActualFamily ||
|
|
SFX_STYLE_FAMILY_PAGE == nActualFamily ||
|
|
(SFX_STYLE_FAMILY_PSEUDO == nActualFamily && !pShell->GetCurNumRule())) )
|
|
{
|
|
rSet.DisableItem( nWhich );
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_NEW_BY_EXAMPLE:
|
|
if( (pShell->IsFrmSelected()
|
|
? SFX_STYLE_FAMILY_FRAME != nActualFamily
|
|
: SFX_STYLE_FAMILY_FRAME == nActualFamily) ||
|
|
(SFX_STYLE_FAMILY_PSEUDO == nActualFamily && !pShell->GetCurNumRule()) )
|
|
{
|
|
rSet.DisableItem( nWhich );
|
|
}
|
|
break;
|
|
|
|
default:
|
|
DBG_ERROR( "Invalid SlotId");
|
|
}
|
|
nWhich = aIter.NextWhich();
|
|
}
|
|
}
|
|
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: StyleSheet-Requeste auswerten
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
void SwDocShell::ExecStyleSheet( SfxRequest& rReq )
|
|
{
|
|
USHORT nSlot = rReq.GetSlot();
|
|
USHORT nRet = 0xffff;
|
|
|
|
const SfxItemSet* pArgs = rReq.GetArgs();
|
|
const SfxPoolItem* pItem;
|
|
SwWrtShell* pActShell = 0;
|
|
BOOL bSetReturn = TRUE;
|
|
switch (nSlot)
|
|
{
|
|
case SID_STYLE_NEW:
|
|
if( pArgs && SFX_ITEM_SET == pArgs->GetItemState( SID_STYLE_FAMILY,
|
|
FALSE, &pItem ))
|
|
{
|
|
USHORT nFamily = ((const SfxUInt16Item*)pItem)->GetValue();
|
|
|
|
String sName;
|
|
USHORT nMask = 0;
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_STYLE_NEW,
|
|
FALSE, &pItem ))
|
|
sName = ((const SfxStringItem*)pItem)->GetValue();
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_STYLE_MASK,
|
|
FALSE, &pItem ))
|
|
nMask = ((const SfxUInt16Item*)pItem)->GetValue();
|
|
String sParent;
|
|
if( SFX_ITEM_SET == pArgs->GetItemState( SID_STYLE_REFERENCE,
|
|
FALSE, &pItem ))
|
|
sParent = ((const SfxStringItem*)pItem)->GetValue();
|
|
|
|
nRet = Edit( sName, sParent, nFamily, nMask, TRUE, FALSE, 0, rReq.IsAPI() );
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_APPLY:
|
|
if( !pArgs )
|
|
{
|
|
GetView()->GetViewFrame()->GetDispatcher()->Execute(SID_STYLE_DESIGNER, FALSE);
|
|
break;
|
|
}
|
|
else
|
|
{
|
|
// convert internal StyleName to DisplayName (slot implementation uses the latter)
|
|
SFX_REQUEST_ARG( rReq, pNameItem, SfxStringItem, SID_APPLY_STYLE, sal_False );
|
|
SFX_REQUEST_ARG( rReq, pFamilyItem, SfxStringItem, SID_STYLE_FAMILYNAME, sal_False );
|
|
if ( pFamilyItem && pNameItem )
|
|
{
|
|
uno::Reference< style::XStyleFamiliesSupplier > xModel(GetModel(), uno::UNO_QUERY);
|
|
try
|
|
{
|
|
uno::Reference< container::XNameAccess > xStyles;
|
|
uno::Reference< container::XNameAccess > xCont = xModel->getStyleFamilies();
|
|
xCont->getByName(pFamilyItem->GetValue()) >>= xStyles;
|
|
uno::Reference< beans::XPropertySet > xInfo;
|
|
xStyles->getByName( pNameItem->GetValue() ) >>= xInfo;
|
|
::rtl::OUString aUIName;
|
|
xInfo->getPropertyValue( ::rtl::OUString::createFromAscii("DisplayName") ) >>= aUIName;
|
|
if ( aUIName.getLength() )
|
|
rReq.AppendItem( SfxStringItem( SID_STYLE_APPLY, aUIName ) );
|
|
}
|
|
catch( uno::Exception& )
|
|
{
|
|
}
|
|
}
|
|
}
|
|
|
|
// intentionally no break
|
|
|
|
case SID_STYLE_EDIT:
|
|
case SID_STYLE_DELETE:
|
|
case SID_STYLE_WATERCAN:
|
|
case SID_STYLE_FAMILY:
|
|
case SID_STYLE_UPDATE_BY_EXAMPLE:
|
|
case SID_STYLE_NEW_BY_EXAMPLE:
|
|
{
|
|
String aParam;
|
|
USHORT nFamily = SFX_STYLE_FAMILY_PARA;
|
|
USHORT nMask = 0;
|
|
|
|
if( !pArgs )
|
|
{
|
|
nFamily = SFX_STYLE_FAMILY_PARA;
|
|
|
|
switch (nSlot)
|
|
{
|
|
case SID_STYLE_NEW_BY_EXAMPLE:
|
|
{
|
|
SfxNewStyleDlg *pDlg = new SfxNewStyleDlg( 0,
|
|
*GetStyleSheetPool());
|
|
if(RET_OK == pDlg->Execute())
|
|
{
|
|
aParam = pDlg->GetName();
|
|
rReq.AppendItem(SfxStringItem(nSlot, aParam));
|
|
}
|
|
|
|
delete pDlg;
|
|
}
|
|
break;
|
|
|
|
case SID_STYLE_UPDATE_BY_EXAMPLE:
|
|
case SID_STYLE_EDIT:
|
|
{
|
|
SwTxtFmtColl* pColl = GetWrtShell()->GetCurTxtFmtColl();
|
|
if(pColl)
|
|
{
|
|
aParam = pColl->GetName();
|
|
rReq.AppendItem(SfxStringItem(nSlot, aParam));
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
ASSERT( pArgs->Count(), "SfxBug ItemSet ist leer");
|
|
|
|
SwWrtShell* pShell = GetWrtShell();
|
|
if( SFX_ITEM_SET == pArgs->GetItemState(nSlot, FALSE, &pItem ))
|
|
aParam = ((const SfxStringItem*)pItem)->GetValue();
|
|
|
|
if( SFX_ITEM_SET == pArgs->GetItemState(SID_STYLE_FAMILY,
|
|
FALSE, &pItem ))
|
|
nFamily = ((const SfxUInt16Item*)pItem)->GetValue();
|
|
|
|
if( SFX_ITEM_SET == pArgs->GetItemState(SID_STYLE_FAMILYNAME, FALSE, &pItem ))
|
|
{
|
|
String aFamily = ((const SfxStringItem*)pItem)->GetValue();
|
|
if(aFamily.CompareToAscii("CharacterStyles") == COMPARE_EQUAL)
|
|
nFamily = SFX_STYLE_FAMILY_CHAR;
|
|
else
|
|
if(aFamily.CompareToAscii("ParagraphStyles") == COMPARE_EQUAL)
|
|
nFamily = SFX_STYLE_FAMILY_PARA;
|
|
else
|
|
if(aFamily.CompareToAscii("PageStyles") == COMPARE_EQUAL)
|
|
nFamily = SFX_STYLE_FAMILY_PAGE;
|
|
else
|
|
if(aFamily.CompareToAscii("FrameStyles") == COMPARE_EQUAL)
|
|
nFamily = SFX_STYLE_FAMILY_FRAME;
|
|
else
|
|
if(aFamily.CompareToAscii("NumberingStyles") == COMPARE_EQUAL)
|
|
nFamily = SFX_STYLE_FAMILY_PSEUDO;
|
|
}
|
|
|
|
if( SFX_ITEM_SET == pArgs->GetItemState(SID_STYLE_MASK,
|
|
FALSE, &pItem ))
|
|
nMask = ((const SfxUInt16Item*)pItem)->GetValue();
|
|
if( SFX_ITEM_SET == pArgs->GetItemState(FN_PARAM_WRTSHELL,
|
|
FALSE, &pItem ))
|
|
pActShell = pShell = (SwWrtShell*)((SwPtrItem*)pItem)->GetValue();
|
|
|
|
if( nSlot == SID_STYLE_UPDATE_BY_EXAMPLE )
|
|
{
|
|
switch( nFamily )
|
|
{
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
{
|
|
SwTxtFmtColl* pColl = pShell->GetCurTxtFmtColl();
|
|
if(pColl)
|
|
aParam = pColl->GetName();
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_FRAME:
|
|
{
|
|
SwFrmFmt* pFrm = pWrtShell->GetCurFrmFmt();
|
|
if( pFrm )
|
|
aParam = pFrm->GetName();
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
{
|
|
SwCharFmt* pChar = pWrtShell->GetCurCharFmt();
|
|
if( pChar )
|
|
aParam = pChar->GetName();
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_PSEUDO:
|
|
if(SFX_ITEM_SET == pArgs->GetItemState(SID_STYLE_UPD_BY_EX_NAME, FALSE, &pItem))
|
|
{
|
|
aParam = ((const SfxStringItem*)pItem)->GetValue();
|
|
}
|
|
break;
|
|
}
|
|
rReq.AppendItem(SfxStringItem(nSlot, aParam));
|
|
}
|
|
}
|
|
if (aParam.Len() || nSlot == SID_STYLE_WATERCAN )
|
|
{
|
|
switch(nSlot)
|
|
{
|
|
case SID_STYLE_EDIT:
|
|
nRet = Edit(aParam, aEmptyStr, nFamily, nMask, FALSE, FALSE, pActShell );
|
|
break;
|
|
case SID_STYLE_DELETE:
|
|
nRet = Delete(aParam, nFamily);
|
|
break;
|
|
case SID_STYLE_APPLY:
|
|
// Shellwechsel in ApplyStyles
|
|
nRet = ApplyStyles(aParam, nFamily, pActShell, rReq.GetModifier() );
|
|
break;
|
|
case SID_STYLE_WATERCAN:
|
|
nRet = DoWaterCan(aParam, nFamily);
|
|
break;
|
|
case SID_STYLE_UPDATE_BY_EXAMPLE:
|
|
nRet = UpdateStyle(aParam, nFamily, pActShell);
|
|
break;
|
|
case SID_STYLE_NEW_BY_EXAMPLE:
|
|
{
|
|
nRet = MakeByExample(aParam, nFamily, nMask, pActShell );
|
|
SfxTemplateDialog* pDlg = SFX_APP()->GetTemplateDialog();
|
|
|
|
if(pDlg && pDlg->IsVisible())
|
|
pDlg->Update();
|
|
}
|
|
break;
|
|
|
|
default:
|
|
DBG_ERROR( "Falsche Slot-Id");
|
|
}
|
|
|
|
rReq.Done();
|
|
}
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(bSetReturn)
|
|
{
|
|
if(rReq.IsAPI()) // Basic bekommt nur TRUE oder FALSE
|
|
rReq.SetReturnValue(SfxUInt16Item(nSlot, nRet !=0));
|
|
else
|
|
rReq.SetReturnValue(SfxUInt16Item(nSlot, nRet));
|
|
}
|
|
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Edit
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
USHORT SwDocShell::Edit( const String &rName, const String &rParent, USHORT nFamily, USHORT nMask,
|
|
BOOL bNew, BOOL bColumn, SwWrtShell* pActShell,
|
|
BOOL bBasic )
|
|
{
|
|
ASSERT(GetWrtShell(), "Keine Shell, keine Styles");
|
|
SfxStyleSheetBase *pStyle = 0;
|
|
|
|
USHORT nRet = nMask;
|
|
BOOL bModified = pDoc->IsModified();
|
|
|
|
if( bNew )
|
|
{
|
|
if( SFXSTYLEBIT_ALL != nMask && SFXSTYLEBIT_USED != nMask )
|
|
nMask |= SFXSTYLEBIT_USERDEF;
|
|
else
|
|
nMask = SFXSTYLEBIT_USERDEF;
|
|
|
|
pStyle = &mxBasePool->Make( rName, (SfxStyleFamily)nFamily, nMask );
|
|
|
|
// die aktuellen als Parent setzen
|
|
SwDocStyleSheet* pDStyle = (SwDocStyleSheet*)pStyle;
|
|
switch( nFamily )
|
|
{
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
{
|
|
if(rParent.Len())
|
|
{
|
|
SwTxtFmtColl* pColl = pWrtShell->FindTxtFmtCollByName( rParent );
|
|
if(!pColl)
|
|
{
|
|
USHORT nId = SwStyleNameMapper::GetPoolIdFromUIName(rParent, nsSwGetPoolIdFromName::GET_POOLID_TXTCOLL);
|
|
if(USHRT_MAX != nId)
|
|
pColl = pWrtShell->GetTxtCollFromPool( nId );
|
|
}
|
|
pDStyle->GetCollection()->SetDerivedFrom( pColl );
|
|
pDStyle->PresetParent( rParent );
|
|
|
|
//#outline level,add by zhaojianwei
|
|
/*When a new paragraph style is created based on a "to outline style
|
|
assigned" paragraph style, the outline level attribute and the list
|
|
style attribute of the new paragraph style have to be set to 0
|
|
respectively "".*/
|
|
if( pColl->IsAssignedToListLevelOfOutlineStyle())
|
|
{
|
|
SwNumRuleItem aItem(aEmptyStr);
|
|
pDStyle->GetCollection()->SetFmtAttr( aItem );
|
|
pDStyle->GetCollection()->SetAttrOutlineLevel( 0 );
|
|
}
|
|
//<-end,zhaojianwei
|
|
|
|
}
|
|
else
|
|
{
|
|
SwTxtFmtColl* pColl = pWrtShell->GetCurTxtFmtColl();
|
|
pDStyle->GetCollection()->SetDerivedFrom( pColl );
|
|
if( pColl )
|
|
pDStyle->PresetParent( pColl->GetName() );
|
|
}
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
{
|
|
if(rParent.Len())
|
|
{
|
|
SwCharFmt* pCFmt = pWrtShell->FindCharFmtByName( rParent );
|
|
if(!pCFmt)
|
|
{
|
|
USHORT nId = SwStyleNameMapper::GetPoolIdFromUIName(rParent, nsSwGetPoolIdFromName::GET_POOLID_CHRFMT);
|
|
if(USHRT_MAX != nId)
|
|
pCFmt = pWrtShell->GetCharFmtFromPool( nId );
|
|
}
|
|
|
|
pDStyle->GetCharFmt()->SetDerivedFrom( pCFmt );
|
|
pDStyle->PresetParent( rParent );
|
|
}
|
|
else
|
|
{
|
|
SwCharFmt* pCFmt = pWrtShell->GetCurCharFmt();
|
|
pDStyle->GetCharFmt()->SetDerivedFrom( pCFmt );
|
|
if( pCFmt )
|
|
pDStyle->PresetParent( pCFmt->GetName() );
|
|
}
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_FRAME :
|
|
{
|
|
if(rParent.Len())
|
|
{
|
|
SwFrmFmt* pFFmt = pWrtShell->GetDoc()->FindFrmFmtByName( rParent );
|
|
if(!pFFmt)
|
|
{
|
|
USHORT nId = SwStyleNameMapper::GetPoolIdFromUIName(rParent, nsSwGetPoolIdFromName::GET_POOLID_FRMFMT);
|
|
if(USHRT_MAX != nId)
|
|
pFFmt = pWrtShell->GetFrmFmtFromPool( nId );
|
|
}
|
|
pDStyle->GetFrmFmt()->SetDerivedFrom( pFFmt );
|
|
pDStyle->PresetParent( rParent );
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
pStyle = mxBasePool->Find( rName, (SfxStyleFamily)nFamily );
|
|
ASSERT(pStyle, "Vorlage nicht gefunden");
|
|
}
|
|
|
|
if(!pStyle)
|
|
return FALSE;
|
|
|
|
// Dialoge zusammenstoepseln
|
|
//
|
|
rtl::Reference< SwDocStyleSheet > xTmp( new SwDocStyleSheet( *(SwDocStyleSheet*)pStyle ) );
|
|
if( SFX_STYLE_FAMILY_PARA == nFamily )
|
|
{
|
|
SfxItemSet& rSet = xTmp->GetItemSet();
|
|
::SwToSfxPageDescAttr( rSet );
|
|
// erstmal nur eine Null
|
|
rSet.Put(SwBackgroundDestinationItem(SID_PARA_BACKGRND_DESTINATION, 0));
|
|
// --> OD 2008-02-13 #newlistlevelattrs#
|
|
// merge list level indent attributes into the item set if needed
|
|
xTmp->MergeIndentAttrsOfListStyle( rSet );
|
|
// <--
|
|
}
|
|
/* else if( SFX_STYLE_FAMILY_FRAME == nFamily )
|
|
{
|
|
// Auskommentiert wegen Bug #45776 (per default keine Breite&Groesse in Rahmenvorlagen)
|
|
SfxItemSet& rSet = aTmp.GetItemSet();
|
|
if( SFX_ITEM_SET != rSet.GetItemState( RES_FRM_SIZE ))
|
|
{
|
|
// dann sollten wir spaetesten hier eines anlegen
|
|
SwFrmValid aFrmDefValues;
|
|
rSet.Put( SwFmtFrmSize( ATT_VAR_SIZE, aFrmDefValues.nWidth,
|
|
aFrmDefValues.nHeight ));
|
|
}
|
|
}*/
|
|
else if( SFX_STYLE_FAMILY_CHAR == nFamily )
|
|
{
|
|
SfxItemSet& rSet = xTmp->GetItemSet();
|
|
const SfxPoolItem *pTmpBrush;
|
|
if( SFX_ITEM_SET == rSet.GetItemState( RES_CHRATR_BACKGROUND,
|
|
TRUE, &pTmpBrush ) )
|
|
{
|
|
SvxBrushItem aTmpBrush( *((SvxBrushItem*)pTmpBrush) );
|
|
aTmpBrush.SetWhich( RES_BACKGROUND );
|
|
rSet.Put( aTmpBrush );
|
|
}
|
|
}
|
|
if (!bBasic)
|
|
{
|
|
// vor dem Dialog wird der HtmlMode an der DocShell versenkt
|
|
USHORT nHtmlMode = ::GetHtmlMode(this);
|
|
|
|
// In HTML mode, we do not always have a printer. In order to show
|
|
// the correct page size in the Format - Page dialog, we have to
|
|
// get one here.
|
|
SwWrtShell* pCurrShell = ( pActShell ? pActShell : pWrtShell );
|
|
if( ( HTMLMODE_ON & nHtmlMode ) &&
|
|
!pCurrShell->getIDocumentDeviceAccess()->getPrinter( false ) )
|
|
pCurrShell->InitPrt( pCurrShell->getIDocumentDeviceAccess()->getPrinter( true ) );
|
|
|
|
PutItem(SfxUInt16Item(SID_HTML_MODE, nHtmlMode));
|
|
FieldUnit eMetric = ::GetDfltMetric(0 != (HTMLMODE_ON&nHtmlMode));
|
|
SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< UINT16 >(eMetric)));
|
|
SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
|
|
DBG_ASSERT(pFact, "Dialogdiet fail!");
|
|
SfxAbstractTabDialog* pDlg = pFact->CreateTemplateDialog( DLG_TEMPLATE_BASE,
|
|
0, *(xTmp.get()), nFamily, bColumn,
|
|
pActShell ? pActShell : pWrtShell, bNew);
|
|
DBG_ASSERT(pDlg, "Dialogdiet fail!");
|
|
if(RET_OK == pDlg->Execute())
|
|
{
|
|
GetWrtShell()->StartAllAction();
|
|
|
|
// nur bei Absatz-Vorlagen die Maske neu setzen
|
|
if( bNew )
|
|
{
|
|
nRet = SFX_STYLE_FAMILY_PARA == pStyle->GetFamily()
|
|
? xTmp->GetMask()
|
|
: SFXSTYLEBIT_USERDEF;
|
|
}
|
|
else if( pStyle->GetMask() != xTmp->GetMask() )
|
|
nRet = xTmp->GetMask();
|
|
|
|
if( SFX_STYLE_FAMILY_PARA == nFamily )
|
|
{
|
|
SfxItemSet aSet( *pDlg->GetOutputItemSet() );
|
|
::SfxToSwPageDescAttr( *GetWrtShell(), aSet );
|
|
// --> OD 2008-02-12 #newlistlevelattrs#
|
|
// reset indent attributes at paragraph style, if a list style
|
|
// will be applied and no indent attributes will be applied.
|
|
xTmp->SetItemSet( aSet, true );
|
|
// <--
|
|
}
|
|
else
|
|
{
|
|
if(SFX_STYLE_FAMILY_PAGE == nFamily)
|
|
{
|
|
static const USHORT aInval[] = {
|
|
SID_IMAGE_ORIENTATION,
|
|
SID_ATTR_CHAR_FONT,
|
|
FN_INSERT_CTRL, FN_INSERT_OBJ_CTRL, 0};
|
|
pView->GetViewFrame()->GetBindings().Invalidate(aInval);
|
|
}
|
|
SfxItemSet aTmpSet( *pDlg->GetOutputItemSet() );
|
|
if( SFX_STYLE_FAMILY_CHAR == nFamily )
|
|
{
|
|
const SfxPoolItem *pTmpBrush;
|
|
if( SFX_ITEM_SET == aTmpSet.GetItemState( RES_BACKGROUND,
|
|
FALSE, &pTmpBrush ) )
|
|
{
|
|
SvxBrushItem aTmpBrush( *((SvxBrushItem*)pTmpBrush) );
|
|
aTmpBrush.SetWhich( RES_CHRATR_BACKGROUND );
|
|
aTmpSet.Put( aTmpBrush );
|
|
}
|
|
aTmpSet.ClearItem( RES_BACKGROUND );
|
|
}
|
|
xTmp->SetItemSet( aTmpSet );
|
|
|
|
if( SFX_STYLE_FAMILY_PAGE == nFamily && SvtLanguageOptions().IsCTLFontEnabled() )
|
|
{
|
|
const SfxPoolItem *pItem = NULL;
|
|
if( aTmpSet.GetItemState( GetPool().GetTrueWhich( SID_ATTR_FRAMEDIRECTION, FALSE ) , TRUE, &pItem ) == SFX_ITEM_SET )
|
|
SwChartHelper::DoUpdateAllCharts( pDoc );
|
|
}
|
|
}
|
|
if(SFX_STYLE_FAMILY_PAGE == nFamily)
|
|
pView->InvalidateRulerPos();
|
|
|
|
if( bNew )
|
|
mxBasePool->Broadcast( SfxStyleSheetHint( SFX_STYLESHEET_CREATED, *xTmp.get() ) );
|
|
|
|
// JP 19.09.97:
|
|
// Dialog vorm EndAction zerstoeren - bei Seitenvorlagen kann
|
|
// muss der ItemSet zerstoert werden, damit die Cursor aus den
|
|
// Kopf-/Fusszeilen entfernt werden. Sonst kommts zu GPFs!!!
|
|
delete pDlg;
|
|
|
|
pDoc->SetModified();
|
|
if( !bModified ) // Bug 57028
|
|
pDoc->SetUndoNoResetModified();
|
|
|
|
GetWrtShell()->EndAllAction();
|
|
}
|
|
else
|
|
{
|
|
if( bNew )
|
|
{
|
|
// #116530#
|
|
//pBasePool->Erase( &aTmp );
|
|
GetWrtShell()->Undo(UNDO_EMPTY, 1);
|
|
pDoc->ClearRedo();
|
|
}
|
|
|
|
if( !bModified )
|
|
pDoc->ResetModified();
|
|
delete pDlg;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// vor dem Dialog wird der HtmlMode an der DocShell versenkt
|
|
PutItem(SfxUInt16Item(SID_HTML_MODE, ::GetHtmlMode(this)));
|
|
|
|
GetWrtShell()->StartAllAction();
|
|
|
|
// nur bei Absatz-Vorlagen die Maske neu setzen
|
|
if( bNew )
|
|
{
|
|
nRet = SFX_STYLE_FAMILY_PARA == pStyle->GetFamily()
|
|
? xTmp->GetMask()
|
|
: SFXSTYLEBIT_USERDEF;
|
|
}
|
|
else if( pStyle->GetMask() != xTmp->GetMask() )
|
|
nRet = xTmp->GetMask();
|
|
|
|
if( SFX_STYLE_FAMILY_PARA == nFamily )
|
|
::SfxToSwPageDescAttr( *GetWrtShell(), xTmp->GetItemSet() );
|
|
else
|
|
{
|
|
SfxItemSet aTmpSet( xTmp->GetItemSet() );
|
|
if( SFX_STYLE_FAMILY_CHAR == nFamily )
|
|
{
|
|
const SfxPoolItem *pTmpBrush;
|
|
if( SFX_ITEM_SET == aTmpSet.GetItemState( RES_BACKGROUND,
|
|
FALSE, &pTmpBrush ) )
|
|
{
|
|
SvxBrushItem aTmpBrush( *((SvxBrushItem*)pTmpBrush) );
|
|
aTmpBrush.SetWhich( RES_CHRATR_BACKGROUND );
|
|
aTmpSet.Put( aTmpBrush );
|
|
}
|
|
aTmpSet.ClearItem( RES_BACKGROUND );
|
|
}
|
|
xTmp->SetItemSet( aTmpSet );
|
|
}
|
|
if(SFX_STYLE_FAMILY_PAGE == nFamily)
|
|
pView->InvalidateRulerPos();
|
|
|
|
if( bNew )
|
|
mxBasePool->Broadcast( SfxStyleSheetHint( SFX_STYLESHEET_CREATED, *xTmp.get() ) );
|
|
|
|
pDoc->SetModified();
|
|
if( !bModified ) // Bug 57028
|
|
pDoc->SetUndoNoResetModified();
|
|
GetWrtShell()->EndAllAction();
|
|
}
|
|
|
|
return nRet;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Delete
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
USHORT SwDocShell::Delete(const String &rName, USHORT nFamily)
|
|
{
|
|
SfxStyleSheetBase *pStyle = mxBasePool->Find(rName, (SfxStyleFamily)nFamily);
|
|
|
|
if(pStyle)
|
|
{
|
|
ASSERT(GetWrtShell(), "Keine Shell, keine Styles");
|
|
|
|
GetWrtShell()->StartAllAction();
|
|
mxBasePool->Remove(pStyle);
|
|
GetWrtShell()->EndAllAction();
|
|
|
|
return TRUE;
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Vorlage anwenden
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
USHORT SwDocShell::ApplyStyles(const String &rName, USHORT nFamily,
|
|
SwWrtShell* pShell, USHORT nMode )
|
|
{
|
|
SwDocStyleSheet* pStyle =
|
|
(SwDocStyleSheet*)mxBasePool->Find(rName, (SfxStyleFamily)nFamily);
|
|
|
|
ASSERT(pStyle, "Wo ist der StyleSheet");
|
|
if(!pStyle)
|
|
return FALSE;
|
|
|
|
SwWrtShell *pSh = pShell ? pShell : GetWrtShell();
|
|
|
|
ASSERT( pSh, "Keine Shell, keine Styles");
|
|
|
|
pSh->StartAllAction();
|
|
|
|
switch(nFamily)
|
|
{
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
{
|
|
SwFmtCharFmt aFmt(pStyle->GetCharFmt());
|
|
pSh->SetAttr( aFmt, (nMode & KEY_SHIFT) ?
|
|
nsSetAttrMode::SETATTR_DONTREPLACE : nsSetAttrMode::SETATTR_DEFAULT );
|
|
break;
|
|
}
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
{
|
|
// --> OD 2007-11-06 #i62675#
|
|
// clear also list attributes at affected text nodes, if paragraph
|
|
// style has the list style attribute set.
|
|
pSh->SetTxtFmtColl( pStyle->GetCollection(), true );
|
|
// <--
|
|
break;
|
|
}
|
|
case SFX_STYLE_FAMILY_FRAME:
|
|
{
|
|
if ( pSh->IsFrmSelected() )
|
|
pSh->SetFrmFmt( pStyle->GetFrmFmt() );
|
|
break;
|
|
}
|
|
case SFX_STYLE_FAMILY_PAGE:
|
|
{
|
|
pSh->SetPageStyle(pStyle->GetPageDesc()->GetName());
|
|
break;
|
|
}
|
|
case SFX_STYLE_FAMILY_PSEUDO:
|
|
{
|
|
// --> OD 2008-02-08 #newlistlevelattrs#
|
|
// reset indent attribute on applying list style
|
|
// --> OD 2008-03-17 #refactorlists#
|
|
// continue list of list style
|
|
const SwNumRule* pNumRule = pStyle->GetNumRule();
|
|
const String sListIdForStyle =pNumRule->GetDefaultListId();
|
|
pSh->SetCurNumRule( *pNumRule, false, sListIdForStyle, true );
|
|
// <--
|
|
break;
|
|
}
|
|
default:
|
|
DBG_ERROR("Unbekannte Familie");
|
|
}
|
|
pSh->EndAllAction();
|
|
|
|
return nFamily;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Giesskanne starten
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
USHORT SwDocShell::DoWaterCan(const String &rName, USHORT nFamily)
|
|
{
|
|
ASSERT(GetWrtShell(), "Keine Shell, keine Styles");
|
|
|
|
SwEditWin& rEdtWin = pView->GetEditWin();
|
|
SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
|
|
BOOL bWaterCan = !(pApply && pApply->eType != 0);
|
|
if( !rName.Len() )
|
|
bWaterCan = FALSE;
|
|
SwApplyTemplate aTemplate;
|
|
aTemplate.eType = nFamily;
|
|
|
|
if(bWaterCan)
|
|
{
|
|
SwDocStyleSheet* pStyle =
|
|
(SwDocStyleSheet*)mxBasePool->Find(rName, (SfxStyleFamily)nFamily);
|
|
|
|
ASSERT(pStyle, "Wo ist der StyleSheet");
|
|
if(!pStyle) return nFamily;
|
|
|
|
switch(nFamily)
|
|
{
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
aTemplate.aColl.pCharFmt = pStyle->GetCharFmt();
|
|
break;
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
aTemplate.aColl.pTxtColl = pStyle->GetCollection();
|
|
break;
|
|
case SFX_STYLE_FAMILY_FRAME:
|
|
aTemplate.aColl.pFrmFmt = pStyle->GetFrmFmt();
|
|
break;
|
|
case SFX_STYLE_FAMILY_PAGE:
|
|
aTemplate.aColl.pPageDesc = (SwPageDesc*)pStyle->GetPageDesc();
|
|
break;
|
|
case SFX_STYLE_FAMILY_PSEUDO:
|
|
aTemplate.aColl.pNumRule = (SwNumRule*)pStyle->GetNumRule();
|
|
break;
|
|
|
|
default:
|
|
DBG_ERROR( "Unbekannte Familie");
|
|
}
|
|
}
|
|
else
|
|
aTemplate.eType = 0;
|
|
|
|
// Template anwenden
|
|
pView->GetEditWin().SetApplyTemplate(aTemplate);
|
|
|
|
return nFamily;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: Vorlage Updaten
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
USHORT SwDocShell::UpdateStyle(const String &rName, USHORT nFamily, SwWrtShell* pShell)
|
|
{
|
|
SwWrtShell* pCurrWrtShell = pShell ? pShell : GetWrtShell();
|
|
ASSERT(GetWrtShell(), "Keine Shell, keine Styles");
|
|
|
|
SwDocStyleSheet* pStyle =
|
|
(SwDocStyleSheet*)mxBasePool->Find(rName, (SfxStyleFamily)nFamily);
|
|
|
|
if(!pStyle)
|
|
return nFamily;
|
|
|
|
switch(nFamily)
|
|
{
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
{
|
|
SwTxtFmtColl* pColl = pStyle->GetCollection();
|
|
if(pColl && !pColl->IsDefault())
|
|
{
|
|
GetWrtShell()->StartAllAction();
|
|
|
|
SwRewriter aRewriter;
|
|
aRewriter.AddRule(UNDO_ARG1, pColl->GetName());
|
|
|
|
GetWrtShell()->StartUndo(UNDO_INSFMTATTR, &aRewriter);
|
|
GetWrtShell()->FillByEx(pColl);
|
|
// Vorlage auch anwenden, um harte Attributierung
|
|
// zu entfernen
|
|
GetWrtShell()->SetTxtFmtColl( pColl );
|
|
GetWrtShell()->EndUndo(UNDO_INSFMTATTR, NULL);
|
|
GetWrtShell()->EndAllAction();
|
|
}
|
|
break;
|
|
}
|
|
case SFX_STYLE_FAMILY_FRAME:
|
|
{
|
|
SwFrmFmt* pFrm = pStyle->GetFrmFmt();
|
|
if( pCurrWrtShell->IsFrmSelected() && pFrm && !pFrm->IsDefault() )
|
|
{
|
|
SfxItemSet aSet( GetPool(), aFrmFmtSetRange );
|
|
pCurrWrtShell->StartAllAction();
|
|
pCurrWrtShell->GetFlyFrmAttr( aSet );
|
|
|
|
// JP 10.06.98: nur automatische Orientierungen uebernehmen
|
|
/* #61359# jetzt auch wieder alle Orientierungen
|
|
* const SfxPoolItem* pItem;
|
|
if( SFX_ITEM_SET == aSet.GetItemState( RES_VERT_ORIENT,
|
|
FALSE, &pItem ) &&
|
|
text::VertOrientation::NONE == ((SwFmtVertOrient*)pItem)->GetVertOrient())
|
|
aSet.ClearItem( RES_VERT_ORIENT );
|
|
|
|
if( SFX_ITEM_SET == aSet.GetItemState( RES_HORI_ORIENT,
|
|
FALSE, &pItem ) &&
|
|
text::HoriOrientation::NONE == ((SwFmtHoriOrient*)pItem)->GetHoriOrient())
|
|
aSet.ClearItem( RES_HORI_ORIENT );*/
|
|
|
|
pFrm->SetFmtAttr( aSet );
|
|
|
|
// Vorlage auch anwenden, um harte Attributierung
|
|
// zu entfernen
|
|
pCurrWrtShell->SetFrmFmt( pFrm, TRUE );
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
{
|
|
SwCharFmt* pChar = pStyle->GetCharFmt();
|
|
if( pChar && !pChar->IsDefault() )
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
pCurrWrtShell->FillByEx(pChar);
|
|
// Vorlage auch anwenden, um harte Attributierung
|
|
// zu entfernen
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_PSEUDO:
|
|
{
|
|
const SwNumRule* pCurRule;
|
|
if( pStyle->GetNumRule() &&
|
|
0 != ( pCurRule = pCurrWrtShell->GetCurNumRule() ))
|
|
{
|
|
SwNumRule aRule( *pCurRule );
|
|
// --> OD 2008-07-08 #i91400#
|
|
aRule.SetName( pStyle->GetNumRule()->GetName(),
|
|
*(pCurrWrtShell->GetDoc()) );
|
|
// <--
|
|
pCurrWrtShell->ChgNumRuleFmts( aRule );
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
return nFamily;
|
|
}
|
|
|
|
/*--------------------------------------------------------------------
|
|
Beschreibung: NewByExample
|
|
--------------------------------------------------------------------*/
|
|
|
|
|
|
USHORT SwDocShell::MakeByExample( const String &rName, USHORT nFamily,
|
|
USHORT nMask, SwWrtShell* pShell )
|
|
{
|
|
SwWrtShell* pCurrWrtShell = pShell ? pShell : GetWrtShell();
|
|
SwDocStyleSheet* pStyle = (SwDocStyleSheet*)mxBasePool->Find(
|
|
rName, (SfxStyleFamily)nFamily );
|
|
if(!pStyle)
|
|
{
|
|
// JP 07.07.95: behalte die akt. Maske vom PI bei, dadurch werden
|
|
// neue sofort in den sichtbaren Bereich einsortiert
|
|
if( SFXSTYLEBIT_ALL == nMask || SFXSTYLEBIT_USED == nMask )
|
|
nMask = SFXSTYLEBIT_USERDEF;
|
|
else
|
|
nMask |= SFXSTYLEBIT_USERDEF;
|
|
|
|
pStyle = (SwDocStyleSheet*)&mxBasePool->Make(rName,
|
|
(SfxStyleFamily)nFamily, nMask );
|
|
}
|
|
|
|
switch(nFamily)
|
|
{
|
|
case SFX_STYLE_FAMILY_PARA:
|
|
{
|
|
SwTxtFmtColl* pColl = pStyle->GetCollection();
|
|
if(pColl && !pColl->IsDefault())
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
pCurrWrtShell->FillByEx(pColl);
|
|
// Vorlage auch anwenden, um harte Attributierung
|
|
// zu entfernen
|
|
pColl->SetDerivedFrom(pCurrWrtShell->GetCurTxtFmtColl());
|
|
|
|
// setze die Maske noch an der Collection:
|
|
USHORT nId = pColl->GetPoolFmtId() & 0x87ff;
|
|
switch( nMask & 0x0fff )
|
|
{
|
|
case SWSTYLEBIT_TEXT:
|
|
nId |= COLL_TEXT_BITS;
|
|
break;
|
|
case SWSTYLEBIT_CHAPTER:
|
|
nId |= COLL_DOC_BITS;
|
|
break;
|
|
case SWSTYLEBIT_LIST:
|
|
nId |= COLL_LISTS_BITS;
|
|
break;
|
|
case SWSTYLEBIT_IDX:
|
|
nId |= COLL_REGISTER_BITS;
|
|
break;
|
|
case SWSTYLEBIT_EXTRA:
|
|
nId |= COLL_EXTRA_BITS;
|
|
break;
|
|
case SWSTYLEBIT_HTML:
|
|
nId |= COLL_HTML_BITS;
|
|
break;
|
|
}
|
|
pColl->SetPoolFmtId(nId);
|
|
|
|
pCurrWrtShell->SetTxtFmtColl(pColl);
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_FRAME:
|
|
{
|
|
SwFrmFmt* pFrm = pStyle->GetFrmFmt();
|
|
if(pCurrWrtShell->IsFrmSelected() && pFrm && !pFrm->IsDefault())
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
|
|
SfxItemSet aSet(GetPool(), aFrmFmtSetRange );
|
|
pCurrWrtShell->GetFlyFrmAttr( aSet );
|
|
|
|
SwFrmFmt* pFFmt = pCurrWrtShell->GetCurFrmFmt();
|
|
pFrm->SetDerivedFrom( pFFmt );
|
|
|
|
// JP 10.06.98: nur automatische Orientierungen uebernehmen
|
|
/* #61359# jetzt auch wieder alle Orientierungen
|
|
const SfxPoolItem* pItem;
|
|
if( SFX_ITEM_SET == aSet.GetItemState( RES_VERT_ORIENT,
|
|
FALSE, &pItem ) &&
|
|
text::VertOrientation::NONE == ((SwFmtVertOrient*)pItem)->GetVertOrient())
|
|
aSet.ClearItem( RES_VERT_ORIENT );
|
|
|
|
if( SFX_ITEM_SET == aSet.GetItemState( RES_HORI_ORIENT,
|
|
FALSE, &pItem ) &&
|
|
text::HoriOrientation::NONE == ((SwFmtHoriOrient*)pItem)->GetHoriOrient())
|
|
aSet.ClearItem( RES_HORI_ORIENT );
|
|
*/
|
|
|
|
pFrm->SetFmtAttr( aSet );
|
|
// Vorlage auch anwenden, um harte Attributierung
|
|
// zu entfernen
|
|
pCurrWrtShell->SetFrmFmt( pFrm );
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
}
|
|
break;
|
|
case SFX_STYLE_FAMILY_CHAR:
|
|
{
|
|
SwCharFmt* pChar = pStyle->GetCharFmt();
|
|
if(pChar && !pChar->IsDefault())
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
pCurrWrtShell->FillByEx( pChar );
|
|
pChar->SetDerivedFrom( pCurrWrtShell->GetCurCharFmt() );
|
|
SwFmtCharFmt aFmt( pChar );
|
|
pCurrWrtShell->SetAttr( aFmt );
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
}
|
|
break;
|
|
|
|
case SFX_STYLE_FAMILY_PAGE:
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
USHORT nPgDsc = pCurrWrtShell->GetCurPageDesc();
|
|
SwPageDesc& rSrc = (SwPageDesc&)pCurrWrtShell->GetPageDesc( nPgDsc );
|
|
SwPageDesc& rDest = *(SwPageDesc*)pStyle->GetPageDesc();
|
|
|
|
USHORT nPoolId = rDest.GetPoolFmtId();
|
|
USHORT nHId = rDest.GetPoolHelpId();
|
|
BYTE nHFId = rDest.GetPoolHlpFileId();
|
|
|
|
pCurrWrtShell->GetDoc()->CopyPageDesc( rSrc, rDest );
|
|
|
|
// PoolId darf NIE kopiert werden!
|
|
rDest.SetPoolFmtId( nPoolId );
|
|
rDest.SetPoolHelpId( nHId );
|
|
rDest.SetPoolHlpFileId( nHFId );
|
|
|
|
// werden Kopf-/Fusszeilen angelegt, so gibt es kein Undo mehr!
|
|
pCurrWrtShell->GetDoc()->DelAllUndoObj();
|
|
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
break;
|
|
|
|
case SFX_STYLE_FAMILY_PSEUDO:
|
|
{
|
|
pCurrWrtShell->StartAllAction();
|
|
|
|
SwNumRule aRule( *pCurrWrtShell->GetCurNumRule() );
|
|
String sOrigRule( aRule.GetName() );
|
|
// --> OD 2008-07-08 #i91400#
|
|
aRule.SetName( pStyle->GetNumRule()->GetName(),
|
|
*(pCurrWrtShell->GetDoc()) );
|
|
// <--
|
|
pCurrWrtShell->ChgNumRuleFmts( aRule );
|
|
|
|
pCurrWrtShell->ReplaceNumRule( sOrigRule, aRule.GetName() );
|
|
|
|
|
|
pCurrWrtShell->EndAllAction();
|
|
}
|
|
break;
|
|
}
|
|
return nFamily;
|
|
}
|
|
|
|
void SwDocShell::LoadStyles( SfxObjectShell& rSource )
|
|
{
|
|
_LoadStyles(rSource, FALSE);
|
|
}
|
|
/* -----------------16.05.2003 15:45-----------------
|
|
bPreserveCurrentDocument determines whether SetFixFields() is called
|
|
This call modifies the source document. This mustn't happen when the source
|
|
is a document the user is working on.
|
|
Calls of ::LoadStyles() normally use files especially loaded for the purpose
|
|
of importing styles.
|
|
--------------------------------------------------*/
|
|
void SwDocShell::_LoadStyles( SfxObjectShell& rSource, BOOL bPreserveCurrentDocument )
|
|
{
|
|
/* [Beschreibung]
|
|
|
|
Diese Methode wird vom SFx gerufen, wenn aus einer Dokument-Vorlage
|
|
Styles nachgeladen werden sollen. Bestehende Styles soll dabei
|
|
"uberschrieben werden. Das Dokument mu"s daher neu formatiert werden.
|
|
Daher werden die Applikationen in der Regel diese Methode "uberladen
|
|
und in ihrer Implementierung die Implementierung der Basisklasse
|
|
rufen.
|
|
*/
|
|
// ist die Source unser Document, dann uebernehmen wir das
|
|
// abpruefen selbst (wesentlich schneller und laeuft nicht ueber
|
|
// die Kruecke SfxStylePool
|
|
if( rSource.ISA( SwDocShell ))
|
|
{
|
|
//JP 28.05.99: damit die Kopf-/Fusszeilen nicht den fixen Inhalt
|
|
// der Vorlage erhalten, einmal alle FixFelder der
|
|
// Source aktualisieren
|
|
if(!bPreserveCurrentDocument)
|
|
((SwDocShell&)rSource).pDoc->SetFixFields(false, NULL);
|
|
if( pWrtShell )
|
|
{
|
|
pWrtShell->StartAllAction();
|
|
pDoc->ReplaceStyles( *((SwDocShell&)rSource).pDoc );
|
|
pWrtShell->EndAllAction();
|
|
}
|
|
else
|
|
{
|
|
BOOL bModified = pDoc->IsModified();
|
|
pDoc->ReplaceStyles( *((SwDocShell&)rSource).pDoc );
|
|
if( !bModified && pDoc->IsModified() && !pView )
|
|
{
|
|
// die View wird spaeter angelegt, ueberschreibt aber das
|
|
// Modify-Flag. Per Undo ist sowieso nichts mehr zu machen
|
|
pDoc->SetUndoNoResetModified();
|
|
}
|
|
}
|
|
}
|
|
else
|
|
SfxObjectShell::LoadStyles( rSource );
|
|
}
|
|
|
|
|
|
void SwDocShell::FormatPage( const String& rPage, BOOL bColumn, SwWrtShell* pActShell )
|
|
{
|
|
Edit( rPage, aEmptyStr, SFX_STYLE_FAMILY_PAGE, 0, FALSE, bColumn, pActShell);
|
|
}
|
|
|
|
Bitmap SwDocShell::GetStyleFamilyBitmap( SfxStyleFamily eFamily, BmpColorMode eColorMode )
|
|
{
|
|
if( SFX_STYLE_FAMILY_PSEUDO == eFamily )
|
|
{
|
|
if ( eColorMode == BMP_COLOR_NORMAL )
|
|
return Bitmap( SW_RES( BMP_STYLES_FAMILY_NUM ));
|
|
else
|
|
return Bitmap( SW_RES( BMP_STYLES_FAMILY_NUM_HC ));
|
|
}
|
|
|
|
return SfxObjectShell::GetStyleFamilyBitmap( eFamily, eColorMode );
|
|
}
|
|
|
|
|
|
|