/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include const sal_uInt32 nFontInc = 40; // 2pt const sal_uInt32 nFontMaxSz = 19998; // 999.9pt void SwTextShell::ExecCharAttr(SfxRequest &rReq) { SwWrtShell &rSh = GetShell(); const SfxItemSet *pArgs = rReq.GetArgs(); int eState = STATE_TOGGLE; sal_uInt16 nWhich = rReq.GetSlot(); if(pArgs ) { const SfxPoolItem* pItem; pArgs->GetItemState(nWhich, false, &pItem); eState = static_cast( pArgs-> Get( nWhich )).GetValue() ? STATE_ON : STATE_OFF; } SfxItemSetFixed aSet( GetPool() ); if (STATE_TOGGLE == eState) rSh.GetCurAttr( aSet ); switch ( nWhich ) { case FN_SET_SUB_SCRIPT: case FN_SET_SUPER_SCRIPT: { SvxEscapement eEscape = SvxEscapement::Subscript; switch (eState) { case STATE_TOGGLE: { short nTmpEsc = aSet.Get( RES_CHRATR_ESCAPEMENT ).GetEsc(); eEscape = nWhich == FN_SET_SUPER_SCRIPT ? SvxEscapement::Superscript: SvxEscapement::Subscript; if( (nWhich == FN_SET_SUB_SCRIPT && nTmpEsc < 0) || (nWhich == FN_SET_SUPER_SCRIPT && nTmpEsc > 0) ) eEscape = SvxEscapement::Off; SfxBindings& rBind = GetView().GetViewFrame().GetBindings(); if( nWhich == FN_SET_SUB_SCRIPT ) rBind.SetState( SfxBoolItem( FN_SET_SUPER_SCRIPT, false ) ); else rBind.SetState( SfxBoolItem( FN_SET_SUB_SCRIPT, false ) ); } break; case STATE_ON: eEscape = nWhich == FN_SET_SUPER_SCRIPT ? SvxEscapement::Superscript: SvxEscapement::Subscript; break; case STATE_OFF: eEscape = SvxEscapement::Off; break; } SvxEscapementItem aEscape( eEscape, RES_CHRATR_ESCAPEMENT ); rSh.SetAttrItem( aEscape ); rReq.AppendItem( aEscape ); rReq.Done(); } break; case FN_SET_SMALL_CAPS: { SvxCaseMap eCaseMap = SvxCaseMap::SmallCaps; switch (eState) { case STATE_TOGGLE: { SvxCaseMap eTmpCaseMap = aSet.Get(RES_CHRATR_CASEMAP).GetCaseMap(); if (eTmpCaseMap == SvxCaseMap::SmallCaps) eCaseMap = SvxCaseMap::NotMapped; } break; case STATE_ON: // Nothing to do, already set. break; case STATE_OFF: eCaseMap = SvxCaseMap::NotMapped; break; } SvxCaseMapItem aCaseMap(eCaseMap, RES_CHRATR_CASEMAP); rSh.SetAttrItem(aCaseMap); rReq.AppendItem(aCaseMap); rReq.Done(); } break; case FN_UPDATE_STYLE_BY_EXAMPLE: rSh.QuickUpdateStyle(); rReq.Done(); break; case SID_ULINE_VAL_NONE: { SvxUnderlineItem aUnderline(LINESTYLE_NONE, RES_CHRATR_UNDERLINE ); rSh.SetAttrItem( aUnderline ); rReq.AppendItem( aUnderline ); rReq.Done(); break; } case SID_ULINE_VAL_SINGLE: case SID_ULINE_VAL_DOUBLE: case SID_ULINE_VAL_DOTTED: { FontLineStyle eOld = aSet.Get(RES_CHRATR_UNDERLINE).GetLineStyle(); FontLineStyle eNew = eOld; switch (nWhich) { case SID_ULINE_VAL_SINGLE: eNew = ( eOld == LINESTYLE_SINGLE ) ? LINESTYLE_NONE : LINESTYLE_SINGLE; break; case SID_ULINE_VAL_DOUBLE: eNew = ( eOld == LINESTYLE_DOUBLE ) ? LINESTYLE_NONE : LINESTYLE_DOUBLE; break; case SID_ULINE_VAL_DOTTED: eNew = ( eOld == LINESTYLE_DOTTED ) ? LINESTYLE_NONE : LINESTYLE_DOTTED; break; } SvxUnderlineItem aUnderline(eNew, RES_CHRATR_UNDERLINE ); rSh.SetAttrItem( aUnderline ); rReq.AppendItem( aUnderline ); rReq.Done(); } break; case FN_REMOVE_DIRECT_CHAR_FORMATS: if( !rSh.HasReadonlySel() && rSh.IsEndPara()) rSh.DontExpandFormat(); break; case FN_NO_BREAK: { bool bNoHyphen = aSet.Get(RES_CHRATR_NOHYPHEN).GetValue(); SvxNoHyphenItem aNoHyphen( !bNoHyphen, RES_CHRATR_NOHYPHEN ); rSh.SetAttrItem( aNoHyphen ); } break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::ExecCharAttrArgs(SfxRequest &rReq) { sal_uInt16 nSlot = rReq.GetSlot(); const SfxItemSet* pArgs = rReq.GetArgs(); bool bArgs = pArgs != nullptr && pArgs->Count() > 0; SwWrtShell& rWrtSh = GetShell(); SwTextFormatColl* pColl = nullptr; // Is only set if the whole paragraph is selected and AutoUpdateFormat is set. if (rWrtSh.HasSelection() && rWrtSh.IsSelFullPara()) { pColl = rWrtSh.GetCurTextFormatColl(); if ( pColl && !pColl->IsAutoUpdateOnDirectFormat() ) pColl = nullptr; } SfxItemPool& rPool = GetPool(); sal_uInt16 nWhich = rPool.GetWhichIDFromSlotID( nSlot ); switch (nSlot) { case FN_TXTATR_INET: // Special treatment of the PoolId of the SwFormatInetFormat if(bArgs) { const SfxPoolItem& rItem = pArgs->Get( nWhich ); SwFormatINetFormat aINetFormat( static_cast(rItem) ); if ( USHRT_MAX == aINetFormat.GetVisitedFormatId() ) { OSL_ENSURE( false, " - unexpected visited character format ID at hyperlink attribute" ); aINetFormat.SetVisitedFormatAndId( aINetFormat.GetVisitedFormat(), SwStyleNameMapper::GetPoolIdFromUIName( aINetFormat.GetVisitedFormat(), SwGetPoolIdFromName::ChrFmt ) ); } if ( USHRT_MAX == aINetFormat.GetINetFormatId() ) { OSL_ENSURE( false, " - unexpected unvisited character format ID at hyperlink attribute" ); aINetFormat.SetINetFormatAndId( aINetFormat.GetINetFormat(), SwStyleNameMapper::GetPoolIdFromUIName( aINetFormat.GetINetFormat(), SwGetPoolIdFromName::ChrFmt ) ); } if ( pColl ) pColl->SetFormatAttr( aINetFormat ); else rWrtSh.SetAttrItem( aINetFormat ); rReq.Done(); } break; case FN_GROW_FONT_SIZE: case FN_SHRINK_FONT_SIZE: { SvxScriptSetItem aSetItem( SID_ATTR_CHAR_FONTHEIGHT, rPool ); rWrtSh.GetCurAttr( aSetItem.GetItemSet() ); SfxItemSet aAttrSet( rPool, aSetItem.GetItemSet().GetRanges() ); SvtScriptType nScriptTypes = rWrtSh.GetScriptType(); const SvxFontHeightItem* pSize( static_cast( aSetItem.GetItemOfScript( nScriptTypes ) ) ); std::vector >> vItems; // simple case where selected text has one size and // (tdf#124919) selection is not multiple table cells if (pSize && !rWrtSh.IsTableMode()) { // must create new one, otherwise document is without pam SwPaM* pPaM = rWrtSh.GetCursor(); vItems.emplace_back( pSize, std::make_unique( *(pPaM->GetMark()), *(pPaM->GetPoint())) ); } else vItems = rWrtSh.GetItemWithPaM( RES_CHRATR_FONTSIZE ); rWrtSh.StartUndo( SwUndoId::INSATTR ); for( std::pair< const SfxPoolItem*, std::unique_ptr >& iPair : vItems ) { std::unique_ptr pPaM = std::move(iPair.second); const SfxPoolItem* pItem = iPair.first; aSetItem.GetItemSet().ClearItem(); rWrtSh.GetPaMAttr( pPaM.get(), aSetItem.GetItemSet() ); aAttrSet.SetRanges( aSetItem.GetItemSet().GetRanges() ); pSize = static_cast( pItem ); if (pSize) { SvxFontHeightItem aSize(*pSize); sal_uInt32 nSize = aSize.GetHeight(); if ( nSlot == FN_GROW_FONT_SIZE && ( nSize += nFontInc ) > nFontMaxSz ) nSize = nFontMaxSz; else if ( nSlot == FN_SHRINK_FONT_SIZE && ( nSize -= nFontInc ) < nFontInc ) nSize = nFontInc; aSize.SetHeight( nSize ); aSetItem.PutItemForScriptType( nScriptTypes, aSize ); aAttrSet.Put( aSetItem.GetItemSet() ); if( pColl ) pColl->SetFormatAttr( aAttrSet ); else rWrtSh.SetAttrSet( aAttrSet, SetAttrMode::DEFAULT, pPaM.get() ); } } rWrtSh.EndUndo( SwUndoId::INSATTR ); rReq.Done(); } break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::ExecParaAttr(SfxRequest &rReq) { SvxAdjust eAdjst; sal_uInt16 ePropL; const SfxItemSet* pArgs = rReq.GetArgs(); // Get both attributes immediately isn't more expensive!! SfxItemSetFixed aSet( GetPool() ); sal_uInt16 nSlot = rReq.GetSlot(); switch (nSlot) { case SID_ATTR_PARA_ADJUST: { if( pArgs && SfxItemState::SET == pArgs->GetItemState(RES_PARATR_ADJUST) ) { const SvxAdjustItem& rAdj = pArgs->Get(RES_PARATR_ADJUST); SvxAdjustItem aAdj( rAdj.GetAdjust(), RES_PARATR_ADJUST ); if ( rAdj.GetAdjust() == SvxAdjust::Block ) { aAdj.SetLastBlock( rAdj.GetLastBlock() ); aAdj.SetOneWord( rAdj.GetOneWord() ); } aSet.Put(aAdj); } } break; case SID_ATTR_PARA_ADJUST_LEFT: eAdjst = SvxAdjust::Left; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_RIGHT: eAdjst = SvxAdjust::Right; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_CENTER: eAdjst = SvxAdjust::Center; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_BLOCK: eAdjst = SvxAdjust::Block; goto SET_ADJUST; SET_ADJUST: { aSet.Put(SvxAdjustItem(eAdjst,RES_PARATR_ADJUST)); rReq.AppendItem( SfxBoolItem( GetPool().GetWhichIDFromSlotID(nSlot), true ) ); } break; case SID_ATTR_PARA_LINESPACE: if(pArgs && SfxItemState::SET == pArgs->GetItemState( GetPool().GetWhichIDFromSlotID(nSlot) )) { SvxLineSpacingItem aLineSpace = static_cast( pArgs->Get( GetPool().GetWhichIDFromSlotID(nSlot))); aSet.Put( aLineSpace ); } break; case SID_ATTR_PARA_LINESPACE_10: ePropL = 100; goto SET_LINESPACE; case SID_ATTR_PARA_LINESPACE_15: ePropL = 150; goto SET_LINESPACE; case SID_ATTR_PARA_LINESPACE_115: ePropL = 115; goto SET_LINESPACE; case SID_ATTR_PARA_LINESPACE_20: ePropL = 200; goto SET_LINESPACE; SET_LINESPACE: { SvxLineSpacingItem aLineSpacing(ePropL, RES_PARATR_LINESPACING ); aLineSpacing.SetLineSpaceRule( SvxLineSpaceRule::Auto ); if( 100 == ePropL ) aLineSpacing.SetInterLineSpaceRule( SvxInterLineSpaceRule::Off ); else aLineSpacing.SetPropLineSpace(ePropL); aSet.Put( aLineSpacing ); } break; case SID_ATTR_PARA_LEFT_TO_RIGHT : case SID_ATTR_PARA_RIGHT_TO_LEFT : { SfxItemSetFixed aAdjustSet( GetPool() ); GetShell().GetCurAttr(aAdjustSet); bool bChgAdjust = false; SfxItemState eAdjustState = aAdjustSet.GetItemState(RES_PARATR_ADJUST, false); if(eAdjustState >= SfxItemState::DEFAULT) { SvxAdjust eAdjust = aAdjustSet.Get(RES_PARATR_ADJUST).GetAdjust(); bChgAdjust = (SvxAdjust::Left == eAdjust && SID_ATTR_PARA_RIGHT_TO_LEFT == nSlot) || (SvxAdjust::Right == eAdjust && SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot); } else bChgAdjust = true; SvxFrameDirection eFrameDirection = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot) ? SvxFrameDirection::Horizontal_LR_TB : SvxFrameDirection::Horizontal_RL_TB; aSet.Put( SvxFrameDirectionItem( eFrameDirection, RES_FRAMEDIR ) ); if (bChgAdjust) { SvxAdjust eAdjust = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot) ? SvxAdjust::Left : SvxAdjust::Right; SvxAdjustItem aAdjust( eAdjust, RES_PARATR_ADJUST ); aSet.Put( aAdjust ); aAdjust.SetWhich(SID_ATTR_PARA_ADJUST); GetView().GetViewFrame().GetBindings().SetState( aAdjust ); // Toggle numbering alignment const SwNumRule* pCurRule = GetShell().GetNumRuleAtCurrCursorPos(); if( pCurRule ) { SvxNumRule aRule = pCurRule->MakeSvxNumRule(); for(sal_uInt16 i = 0; i < aRule.GetLevelCount(); i++) { SvxNumberFormat aFormat(aRule.GetLevel(i)); if(SvxAdjust::Left == aFormat.GetNumAdjust()) aFormat.SetNumAdjust( SvxAdjust::Right ); else if(SvxAdjust::Right == aFormat.GetNumAdjust()) aFormat.SetNumAdjust( SvxAdjust::Left ); aRule.SetLevel(i, aFormat, aRule.Get(i) != nullptr); } SwNumRule aSetRule( pCurRule->GetName(), pCurRule->Get( 0 ).GetPositionAndSpaceMode() ); aSetRule.SetSvxRule( aRule, GetShell().GetDoc()); aSetRule.SetAutoRule( true ); // no start or continuation of a list - list style is only changed GetShell().SetCurNumRule( aSetRule, false ); } } } break; case SID_ATTR_PARA_HYPHENZONE: { SfxItemSetFixed aHyphSet( GetPool() ); GetShell().GetCurAttr(aHyphSet); SfxItemState eState = aHyphSet.GetItemState(RES_PARATR_HYPHENZONE, false); if ( eState >= SfxItemState::DEFAULT ) { SvxHyphenZoneItem aHyphen( pArgs->Get( RES_PARATR_HYPHENZONE ) ); aSet.Put( aHyphen ); } } break; default: OSL_FAIL("wrong dispatcher"); return; } SwWrtShell& rWrtSh = GetShell(); SwTextFormatColl* pColl = rWrtSh.GetCurTextFormatColl(); if(pColl && pColl->IsAutoUpdateOnDirectFormat()) { rWrtSh.AutoUpdatePara(pColl, aSet); } else rWrtSh.SetAttrSet( aSet, SetAttrMode::DEFAULT, nullptr, true); rReq.Done(); } void SwTextShell::ExecParaAttrArgs(SfxRequest &rReq) { SwWrtShell &rSh = GetShell(); const SfxItemSet *pArgs = rReq.GetArgs(); const SfxPoolItem *pItem = nullptr; sal_uInt16 nSlot = rReq.GetSlot(); if(pArgs) pArgs->GetItemState(GetPool().GetWhichIDFromSlotID(nSlot), false, &pItem); switch ( nSlot ) { case FN_DROP_CHAR_STYLE_NAME: if( pItem ) { OUString sCharStyleName = static_cast(pItem)->GetValue(); SfxItemSetFixed aSet(GetPool()); rSh.GetCurAttr(aSet); SwFormatDrop aDropItem(aSet.Get(RES_PARATR_DROP)); SwCharFormat* pFormat = nullptr; if(!sCharStyleName.isEmpty()) pFormat = rSh.FindCharFormatByName( sCharStyleName ); aDropItem.SetCharFormat( pFormat ); aSet.Put(aDropItem); rSh.SetAttrSet(aSet); } break; case FN_FORMAT_DROPCAPS: { if(pItem) { rSh.SetAttrItem(*pItem); rReq.Done(); } else { SfxItemSetFixed aSet(GetPool()); rSh.GetCurAttr(aSet); SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); ScopedVclPtr pDlg(pFact->CreateSwDropCapsDialog(GetView().GetFrameWeld(), aSet)); if (pDlg->Execute() == RET_OK) { rSh.StartAction(); rSh.StartUndo( SwUndoId::START ); if ( const SfxStringItem* pHintItem = aSet.GetItemIfSet(HINT_END,false) ) { if ( !pHintItem->GetValue().isEmpty() ) rSh.ReplaceDropText(pHintItem->GetValue()); } rSh.SetAttrSet(*pDlg->GetOutputItemSet()); rSh.EndUndo( SwUndoId::END ); rSh.EndAction(); rReq.Done(*pDlg->GetOutputItemSet()); } } } break; case SID_ATTR_PARA_PAGEBREAK: if(pItem) { rSh.SetAttrItem( *pItem ); rReq.Done(); } break; case SID_ATTR_PARA_MODEL: { if(pItem) { SfxItemSetFixed aCoreSet( GetPool() ); aCoreSet.Put(*pItem); SfxToSwPageDescAttr( rSh, aCoreSet); rSh.SetAttrSet(aCoreSet); rReq.Done(); } } break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::GetAttrState(SfxItemSet &rSet) { SwWrtShell &rSh = GetShell(); SfxItemPool& rPool = GetPool(); SfxItemSet aCoreSet(rPool, aTextFormatCollSetRange); // Request *all* text attributes from the core. // fdo#78737: this is called from SvxRuler, which requires the list indents! rSh.GetCurAttr(aCoreSet, /* bMergeIndentValuesOfNumRule = */ true); SfxWhichIter aIter(rSet); sal_uInt16 nSlot = aIter.FirstWhich(); bool bFlag = false; SfxBoolItem aFlagItem; const SfxPoolItem* pItem = nullptr; SvxAdjust eAdjust = SvxAdjust::Left; bool bAdjustGood = false; SfxItemState eState = aCoreSet.GetItemState(RES_PARATR_ADJUST, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetUserOrPoolDefaultItem(RES_PARATR_ADJUST); if( SfxItemState::DEFAULT <= eState ) { eAdjust = static_cast( pItem)->GetAdjust(); bAdjustGood = true; } short nEsc = 0; eState = aCoreSet.GetItemState(RES_CHRATR_ESCAPEMENT, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetUserOrPoolDefaultItem(RES_CHRATR_ESCAPEMENT); if( eState >= SfxItemState::DEFAULT ) nEsc = static_cast(pItem)->GetEsc(); sal_uInt16 nLineSpace = 0; eState = aCoreSet.GetItemState(RES_PARATR_LINESPACING, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetUserOrPoolDefaultItem(RES_PARATR_LINESPACING); if( SfxItemState::DEFAULT <= eState && static_cast(pItem)->GetLineSpaceRule() == SvxLineSpaceRule::Auto ) { if(SvxInterLineSpaceRule::Off == static_cast(pItem)->GetInterLineSpaceRule()) nLineSpace = 100; else nLineSpace = static_cast(pItem)->GetPropLineSpace(); } SvxCaseMap eCaseMap = SvxCaseMap::NotMapped; eState = aCoreSet.GetItemState(RES_CHRATR_CASEMAP, false, &pItem); if (eState == SfxItemState::DEFAULT) pItem = &rPool.GetUserOrPoolDefaultItem(RES_CHRATR_CASEMAP); if (eState >= SfxItemState::DEFAULT) eCaseMap = static_cast(pItem)->GetCaseMap(); while (nSlot) { switch(nSlot) { case FN_SET_SUPER_SCRIPT: bFlag = 0 < nEsc; break; case FN_SET_SUB_SCRIPT: bFlag = 0 > nEsc; break; case FN_SET_SMALL_CAPS: bFlag = eCaseMap == SvxCaseMap::SmallCaps; break; case SID_ATTR_PARA_ADJUST_LEFT: if (!bAdjustGood) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SvxAdjust::Left == eAdjust; break; case SID_ATTR_PARA_ADJUST_RIGHT: if (!bAdjustGood) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SvxAdjust::Right == eAdjust; break; case SID_ATTR_PARA_ADJUST_CENTER: if (!bAdjustGood) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SvxAdjust::Center == eAdjust; break; case SID_ATTR_PARA_ADJUST_BLOCK: { if (!bAdjustGood) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else { bFlag = SvxAdjust::Block == eAdjust; sal_uInt16 nHtmlMode = GetHtmlMode(rSh.GetView().GetDocShell()); if((nHtmlMode & HTMLMODE_ON) && !(nHtmlMode & HTMLMODE_FULL_STYLES )) { rSet.DisableItem( nSlot ); nSlot = 0; } } } break; case SID_ATTR_PARA_LINESPACE_10: bFlag = nLineSpace == 100; break; case SID_ATTR_PARA_LINESPACE_115: bFlag = nLineSpace == 115; break; case SID_ATTR_PARA_LINESPACE_15: bFlag = nLineSpace == 150; break; case SID_ATTR_PARA_LINESPACE_20: bFlag = nLineSpace == 200; break; case FN_GROW_FONT_SIZE: case FN_SHRINK_FONT_SIZE: { SvxScriptSetItem aSetItem( SID_ATTR_CHAR_FONTHEIGHT, *rSet.GetPool() ); aSetItem.GetItemSet().Put( aCoreSet, false ); const SvxFontHeightItem* pSize( static_cast( aSetItem.GetItemOfScript( rSh.GetScriptType() ) ) ); if( pSize ) // selection is of one size { sal_uInt32 nSize = pSize->GetHeight(); if( nSize == nFontMaxSz ) rSet.DisableItem( FN_GROW_FONT_SIZE ); else if( nSize == nFontInc ) rSet.DisableItem( FN_SHRINK_FONT_SIZE ); } else { std::vector >> vFontHeight = rSh.GetItemWithPaM( RES_CHRATR_FONTSIZE ); for ( const std::pair< const SfxPoolItem*, std::unique_ptr>& aIt : vFontHeight ) { if (!aIt.first) { rSet.DisableItem(FN_GROW_FONT_SIZE); rSet.DisableItem(FN_SHRINK_FONT_SIZE); break; } pSize = static_cast( aIt.first ); sal_uInt32 nSize = pSize->GetHeight(); if( nSize == nFontMaxSz ) rSet.DisableItem( FN_GROW_FONT_SIZE ); else if( nSize == nFontInc ) rSet.DisableItem( FN_SHRINK_FONT_SIZE ); } } nSlot = 0; } break; case SID_ULINE_VAL_NONE: case SID_ULINE_VAL_SINGLE: case SID_ULINE_VAL_DOUBLE: case SID_ULINE_VAL_DOTTED: { eState = aCoreSet.GetItemState(RES_CHRATR_UNDERLINE); if( eState >= SfxItemState::DEFAULT ) { FontLineStyle eLineStyle = aCoreSet.Get(RES_CHRATR_UNDERLINE).GetLineStyle(); switch (nSlot) { case SID_ULINE_VAL_NONE: rSet.Put(SfxBoolItem(nSlot, eLineStyle == LINESTYLE_NONE)); break; case SID_ULINE_VAL_SINGLE: rSet.Put(SfxBoolItem(nSlot, eLineStyle == LINESTYLE_SINGLE)); break; case SID_ULINE_VAL_DOUBLE: rSet.Put(SfxBoolItem(nSlot, eLineStyle == LINESTYLE_DOUBLE)); break; case SID_ULINE_VAL_DOTTED: rSet.Put(SfxBoolItem(nSlot, eLineStyle == LINESTYLE_DOTTED)); break; } } else rSet.InvalidateItem(nSlot); nSlot = 0; } break; case SID_ATTR_PARA_ADJUST: if (!bAdjustGood) rSet.InvalidateItem( nSlot ); else rSet.Put(SvxAdjustItem(eAdjust, SID_ATTR_PARA_ADJUST )); nSlot = 0; break; case SID_ATTR_PARA_LRSPACE: case SID_ATTR_PARA_LEFTSPACE: case SID_ATTR_PARA_RIGHTSPACE: case SID_ATTR_PARA_FIRSTLINESPACE: { eState = aCoreSet.GetItemState(RES_MARGIN_FIRSTLINE); eState = std::min(aCoreSet.GetItemState(RES_MARGIN_TEXTLEFT), eState); eState = std::min(aCoreSet.GetItemState(RES_MARGIN_RIGHT), eState); if( eState >= SfxItemState::DEFAULT ) { SvxLRSpaceItem aLR(RES_LR_SPACE); SvxFirstLineIndentItem const& rFirstLine(aCoreSet.Get(RES_MARGIN_FIRSTLINE)); SvxTextLeftMarginItem const& rLeftMargin(aCoreSet.Get(RES_MARGIN_TEXTLEFT)); SvxRightMarginItem const& rRightMargin(aCoreSet.Get(RES_MARGIN_RIGHT)); aLR.SetTextFirstLineOffset(rFirstLine.GetTextFirstLineOffset(), rFirstLine.GetPropTextFirstLineOffset()); aLR.SetAutoFirst(rFirstLine.IsAutoFirst()); aLR.SetTextLeft(rLeftMargin.GetTextLeft(), rLeftMargin.GetPropLeft()); aLR.SetRight(rRightMargin.GetRight(), rRightMargin.GetPropRight()); aLR.SetWhich(nSlot); rSet.Put(aLR); } else rSet.InvalidateItem(nSlot); nSlot = 0; } break; case SID_ATTR_PARA_LEFT_TO_RIGHT : case SID_ATTR_PARA_RIGHT_TO_LEFT : { if ( !SvtCTLOptions::IsCTLFontEnabled() ) { rSet.DisableItem( nSlot ); nSlot = 0; } else { // is the item set? sal_uInt16 nHtmlMode = GetHtmlMode(rSh.GetView().GetDocShell()); if((!(nHtmlMode & HTMLMODE_ON) || (0 != (nHtmlMode & HTMLMODE_SOME_STYLES))) && aCoreSet.GetItemState( RES_FRAMEDIR, false ) >= SfxItemState::DEFAULT) { SvxFrameDirection eFrameDir = aCoreSet.Get(RES_FRAMEDIR).GetValue(); if (SvxFrameDirection::Environment == eFrameDir) { eFrameDir = rSh.IsInRightToLeftText() ? SvxFrameDirection::Horizontal_RL_TB : SvxFrameDirection::Horizontal_LR_TB; } bFlag = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot && SvxFrameDirection::Horizontal_LR_TB == eFrameDir) || (SID_ATTR_PARA_RIGHT_TO_LEFT == nSlot && SvxFrameDirection::Horizontal_RL_TB == eFrameDir); } else { rSet.InvalidateItem(nSlot); nSlot = 0; } } } break; case SID_ATTR_CHAR_LANGUAGE: case SID_ATTR_CHAR_KERNING: case RES_PARATR_DROP: { rSet.Put(aCoreSet.Get( GetPool().GetWhichIDFromSlotID(nSlot))); nSlot = 0; } break; case SID_ATTR_PARA_MODEL: { SfxItemSetFixed aTemp(GetPool()); aTemp.Put(aCoreSet); ::SwToSfxPageDescAttr(aTemp); rSet.Put(aTemp.Get(SID_ATTR_PARA_MODEL)); nSlot = 0; } break; case RES_TXTATR_INETFMT: { SfxItemSetFixed aSet(GetPool()); rSh.GetCurAttr(aSet); const SfxPoolItem& rItem = aSet.Get(RES_TXTATR_INETFMT); rSet.Put(rItem); nSlot = 0; } break; case FN_NO_BREAK: { SfxItemSetFixed aSet(GetPool()); rSh.GetCurAttr(aSet); const SfxPoolItem& rItem = aSet.Get(RES_CHRATR_NOHYPHEN); SwWrtShell& rWrtSh = GetShell(); // add "No Break" menu item to the context menu, if the word // has "no break" setting, or it is hyphenated if ( static_cast(rItem).GetValue() || ( rWrtSh.GetCursor() && rWrtSh.GetCursor()->IsInHyphenatedWord(*rWrtSh.GetLayout()) ) ) { rSet.Put(rItem); } else rSet.DisableItem(nSlot); nSlot = 0; } break; default: // Do nothing nSlot = 0; break; } if( nSlot ) { aFlagItem.SetWhich( nSlot ); aFlagItem.SetValue( bFlag ); rSet.Put( aFlagItem ); } nSlot = aIter.NextWhich(); } rSet.Put(aCoreSet,false); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */