/* -*- 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 #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 "fldmgr.hxx" #include #include #include #include #include "paratr.hxx" #include #include #include #include #include #include #include "swabstdlg.hxx" #include "misc.hrc" #include "chrdlg.hrc" #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 using namespace ::com::sun::star; using namespace svx::sidebar; void sw_CharDialog( SwWrtShell &rWrtSh, bool bUseDialog, sal_uInt16 nSlot,const SfxItemSet *pArgs, SfxRequest *pReq ) { FieldUnit eMetric = ::GetDfltMetric(dynamic_cast( &rWrtSh.GetView()) != nullptr ); SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< sal_uInt16 >(eMetric))); SfxItemSet aCoreSet( rWrtSh.GetView().GetPool(), RES_CHRATR_BEGIN, RES_CHRATR_END-1, RES_TXTATR_INETFMT, RES_TXTATR_INETFMT, RES_BACKGROUND, RES_BACKGROUND, RES_BOX, RES_BOX, RES_SHADOW, RES_SHADOW, SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_INNER, FN_PARAM_SELECTION, FN_PARAM_SELECTION, SID_HTML_MODE, SID_HTML_MODE, SID_ATTR_CHAR_WIDTH_FIT_TO_LINE, SID_ATTR_CHAR_WIDTH_FIT_TO_LINE, 0 ); rWrtSh.GetCurAttr( aCoreSet ); bool bSel = rWrtSh.HasSelection(); bool bSelectionPut = false; if(bSel || rWrtSh.IsInWord()) { if(!bSel) { rWrtSh.StartAction(); rWrtSh.Push(); if(!rWrtSh.SelectTextAttr( RES_TXTATR_INETFMT )) rWrtSh.SelWrd(); } aCoreSet.Put(SfxStringItem(FN_PARAM_SELECTION, rWrtSh.GetSelText())); bSelectionPut = true; if(!bSel) { rWrtSh.Pop(false); rWrtSh.EndAction(); } } aCoreSet.Put( SfxUInt16Item( SID_ATTR_CHAR_WIDTH_FIT_TO_LINE, rWrtSh.GetScalingOfSelectedText() ) ); ::ConvertAttrCharToGen(aCoreSet, CONV_ATTR_STD); // Setting the BoxInfo ::PrepareBoxInfo( aCoreSet, rWrtSh ); aCoreSet.Put(SfxUInt16Item(SID_HTML_MODE, ::GetHtmlMode(rWrtSh.GetView().GetDocShell()))); std::unique_ptr pDlg; if ( bUseDialog && GetActiveView() ) { SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); pDlg.reset(pFact->CreateSwCharDlg(rWrtSh.GetView().GetWindow(), rWrtSh.GetView(), aCoreSet, DLG_CHAR_STD)); OSL_ENSURE(pDlg, "Dialog creation failed!"); if( FN_INSERT_HYPERLINK == nSlot ) pDlg->SetCurPageId("hyperlink"); } if (pDlg && nSlot == SID_CHAR_DLG_EFFECT) { pDlg->SetCurPageId("fonteffects"); } else if (pDlg && (nSlot == SID_ATTR_CHAR_FONT || nSlot == SID_CHAR_DLG_FOR_PARAGRAPH)) { pDlg->SetCurPageId("font"); } else if (pDlg && pReq) { const SfxStringItem* pItem = (*pReq).GetArg(FN_PARAM_1); if (pItem) pDlg->SetCurPageId(OUStringToOString(pItem->GetValue(), RTL_TEXTENCODING_UTF8)); } const SfxItemSet* pSet = nullptr; if ( !bUseDialog ) pSet = pArgs; else if ( pDlg && pDlg->Execute() == RET_OK ) /* #110771# pDlg can be NULL */ { pSet = pDlg->GetOutputItemSet(); } if ( pSet) { SfxItemSet aTmpSet( *pSet ); ::ConvertAttrGenToChar(aTmpSet, aCoreSet, CONV_ATTR_STD); const SfxPoolItem* pSelectionItem; bool bInsert = false; sal_Int32 nInsert = 0; // The old item is for unknown reasons back in the set again. if( !bSelectionPut && SfxItemState::SET == aTmpSet.GetItemState(FN_PARAM_SELECTION, false, &pSelectionItem) ) { OUString sInsert = static_cast(pSelectionItem)->GetValue(); bInsert = !sInsert.isEmpty(); if(bInsert) { nInsert = sInsert.getLength(); rWrtSh.StartAction(); rWrtSh.Insert( sInsert ); rWrtSh.SetMark(); rWrtSh.ExtendSelection(false, sInsert.getLength()); SfxRequest aReq( rWrtSh.GetView().GetViewFrame(), FN_INSERT_STRING ); aReq.AppendItem( SfxStringItem( FN_INSERT_STRING, sInsert ) ); aReq.Done(); SfxRequest aReq1( rWrtSh.GetView().GetViewFrame(), FN_CHAR_LEFT ); aReq1.AppendItem( SfxInt32Item(FN_PARAM_MOVE_COUNT, nInsert) ); aReq1.AppendItem( SfxBoolItem(FN_PARAM_MOVE_SELECTION, true) ); aReq1.Done(); } } aTmpSet.ClearItem(FN_PARAM_SELECTION); SwTextFormatColl* pColl = rWrtSh.GetCurTextFormatColl(); if(bSel && rWrtSh.IsSelFullPara() && pColl && pColl->IsAutoUpdateFormat()) { rWrtSh.AutoUpdatePara(pColl, aTmpSet); } else rWrtSh.SetAttrSet( aTmpSet ); if (pReq) pReq->Done(aTmpSet); if(bInsert) { SfxRequest aReq1( rWrtSh.GetView().GetViewFrame(), FN_CHAR_RIGHT ); aReq1.AppendItem( SfxInt32Item(FN_PARAM_MOVE_COUNT, nInsert) ); aReq1.AppendItem( SfxBoolItem(FN_PARAM_MOVE_SELECTION, false) ); aReq1.Done(); rWrtSh.SwapPam(); rWrtSh.ClearMark(); rWrtSh.DontExpandFormat(); rWrtSh.EndAction(); } } } static short lcl_AskRedlineMode(vcl::Window *pWin) { ScopedVclPtrInstance aQBox( pWin, 0, OUString( SW_RES( STR_REDLINE_TITLE ) ), OUString( SW_RES( STR_REDLINE_MSG ) ) ); aQBox->SetImage( QueryBox::GetStandardImage() ); const ButtonDialogFlags nBtnFlags = ButtonDialogFlags::Default | ButtonDialogFlags::OK | ButtonDialogFlags::Focus; aQBox->AddButton(OUString(SW_RES(STR_REDLINE_ACCEPT_ALL)), RET_OK, nBtnFlags); aQBox->GetPushButton( RET_OK )->SetHelpId(HID_AUTOFORMAT_ACCEPT); aQBox->AddButton(OUString(SW_RES(STR_REDLINE_REJECT_ALL)), RET_CANCEL, ButtonDialogFlags::Cancel); aQBox->GetPushButton( RET_CANCEL )->SetHelpId(HID_AUTOFORMAT_REJECT ); aQBox->AddButton(OUString(SW_RES(STR_REDLINE_EDIT)), 2); aQBox->GetPushButton( 2 )->SetHelpId(HID_AUTOFORMAT_EDIT_CHG); aQBox->SetButtonHelpText( RET_OK, OUString() ); return aQBox->Execute(); } void SwTextShell::Execute(SfxRequest &rReq) { bool bUseDialog = true; const SfxItemSet *pArgs = rReq.GetArgs(); SwWrtShell& rWrtSh = GetShell(); const SfxPoolItem* pItem = nullptr; const sal_uInt16 nSlot = rReq.GetSlot(); if(pArgs) pArgs->GetItemState(GetPool().GetWhich(nSlot), false, &pItem); switch( nSlot ) { case SID_UNICODE_NOTATION_TOGGLE: { long nMaxUnits = 256; sal_Int32 nSelLength = rWrtSh.GetSelText().getLength(); if( rWrtSh.IsSelection() && !rWrtSh.IsMultiSelection() && (nSelLength < nMaxUnits) ) nMaxUnits = nSelLength; long index = 0; ToggleUnicodeCodepoint aToggle; while( nMaxUnits-- && aToggle.AllowMoreInput(rWrtSh.GetChar(true, index-1)) ) --index; OUString sReplacement = aToggle.ReplacementString(); if( !sReplacement.isEmpty() ) { SwRewriter aRewriter; aRewriter.AddRule( UndoArg1, aToggle.StringToReplace() ); aRewriter.AddRule( UndoArg2, SW_RES(STR_YIELDS) ); aRewriter.AddRule( UndoArg3, sReplacement ); rWrtSh.StartUndo(UNDO_REPLACE, &aRewriter); rWrtSh.GetCursor()->Normalize(false); rWrtSh.ClearMark(); for( sal_uInt32 i=aToggle.CharsToDelete(); i > 0; --i ) rWrtSh.DelLeft(); rWrtSh.Insert2( sReplacement ); rWrtSh.EndUndo(UNDO_REPLACE, &aRewriter); } } break; case SID_LANGUAGE_STATUS: { // get the language OUString aNewLangText; const SfxStringItem* pItem2 = rReq.GetArg(SID_LANGUAGE_STATUS); if (pItem2) aNewLangText = pItem2->GetValue(); //!! Remember the view frame right now... //!! (call to GetView().GetViewFrame() will break if the //!! SwTextShell got destroyed meanwhile.) SfxViewFrame *pViewFrame = GetView().GetViewFrame(); if (aNewLangText == "*") { // open the dialog "Tools/Options/Language Settings - Language" // to set the documents default language SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create(); if (pFact) { std::unique_ptr pDlg(pFact->CreateVclDialog( GetView().GetWindow(), SID_LANGUAGE_OPTIONS )); pDlg->Execute(); } } else { //!! We have to use StartAction / EndAction bracketing in //!! order to prevent possible destruction of the SwTextShell //!! due to the selection changes coming below. rWrtSh.StartAction(); // prevent view from jumping because of (temporary) selection changes rWrtSh.LockView( true ); // setting the new language... if (!aNewLangText.isEmpty()) { const OUString aSelectionLangPrefix("Current_"); const OUString aParagraphLangPrefix("Paragraph_"); const OUString aDocumentLangPrefix("Default_"); const OUString aStrNone("LANGUAGE_NONE"); const OUString aStrResetLangs("RESET_LANGUAGES"); SfxItemSet aCoreSet( GetPool(), RES_CHRATR_LANGUAGE, RES_CHRATR_LANGUAGE, RES_CHRATR_CJK_LANGUAGE, RES_CHRATR_CJK_LANGUAGE, RES_CHRATR_CTL_LANGUAGE, RES_CHRATR_CTL_LANGUAGE, 0 ); sal_Int32 nPos = 0; bool bForSelection = true; bool bForParagraph = false; if (-1 != (nPos = aNewLangText.indexOf( aSelectionLangPrefix ))) { // ... for the current selection aNewLangText = aNewLangText.replaceAt(nPos, aSelectionLangPrefix.getLength(), ""); bForSelection = true; } else if (-1 != (nPos = aNewLangText.indexOf(aParagraphLangPrefix))) { // ... for the current paragraph language aNewLangText = aNewLangText.replaceAt(nPos, aParagraphLangPrefix.getLength(), ""); bForSelection = true; bForParagraph = true; } else if (-1 != (nPos = aNewLangText.indexOf(aDocumentLangPrefix))) { // ... as default document language aNewLangText = aNewLangText.replaceAt(nPos, aDocumentLangPrefix.getLength(), ""); bForSelection = false; } if (bForParagraph || !bForSelection) { rWrtSh.Push(); // save selection for later restoration rWrtSh.ClearMark(); // fdo#67796: invalidate table crsr } if (bForParagraph) SwLangHelper::SelectCurrentPara( rWrtSh ); if (!bForSelection) // document language to be changed... { rWrtSh.SelAll(); rWrtSh.ExtendedSelectAll(); } rWrtSh.StartUndo( ( !bForParagraph && !bForSelection ) ? UNDO_SETDEFTATTR : UNDO_EMPTY ); if (aNewLangText == aStrNone) SwLangHelper::SetLanguage_None( rWrtSh, bForSelection, aCoreSet ); else if (aNewLangText == aStrResetLangs) SwLangHelper::ResetLanguages( rWrtSh, bForSelection ); else SwLangHelper::SetLanguage( rWrtSh, aNewLangText, bForSelection, aCoreSet ); rWrtSh.EndUndo(); if (bForParagraph || !bForSelection) { rWrtSh.Pop(false); // restore selection... } } rWrtSh.LockView( false ); rWrtSh.EndAction(); } // invalidate slot to get the new language displayed pViewFrame->GetBindings().Invalidate( nSlot ); rReq.Done(); break; } case SID_THES: { // replace word/selection with text from selected sub menu entry OUString aReplaceText; const SfxStringItem* pItem2 = rReq.GetArg(SID_THES); if (pItem2) aReplaceText = pItem2->GetValue(); if (!aReplaceText.isEmpty()) { SwView &rView2 = rWrtSh.GetView(); const bool bSelection = rWrtSh.HasSelection(); const OUString aLookUpText = rView2.GetThesaurusLookUpText( bSelection ); rView2.InsertThesaurusSynonym( aReplaceText, aLookUpText, bSelection ); } } break; case SID_CHARMAP: { InsertSymbol( rReq ); } break; case FN_INSERT_FOOTNOTE: case FN_INSERT_ENDNOTE: { OUString aStr; const SfxStringItem* pFont = rReq.GetArg(FN_PARAM_1); const SfxStringItem* pNameItem = rReq.GetArg(nSlot); if ( pNameItem ) aStr = pNameItem->GetValue(); bool bFont = pFont && !pFont->GetValue().isEmpty(); rWrtSh.StartUndo( UNDO_UI_INSERT_FOOTNOTE ); rWrtSh.InsertFootnote( aStr, nSlot == FN_INSERT_ENDNOTE, !bFont ); if ( bFont ) { rWrtSh.Left( CRSR_SKIP_CHARS, true, 1, false ); SfxItemSet aSet( rWrtSh.GetAttrPool(), RES_CHRATR_FONT, RES_CHRATR_FONT ); rWrtSh.GetCurAttr( aSet ); const SvxFontItem &rFont = static_cast( aSet.Get( RES_CHRATR_FONT )); SvxFontItem aFont( rFont.GetFamily(), pFont->GetValue(), rFont.GetStyleName(), rFont.GetPitch(), RTL_TEXTENCODING_DONTKNOW, RES_CHRATR_FONT ); rWrtSh.SetAttrSet( aSet, SetAttrMode::DONTEXPAND ); rWrtSh.ResetSelect(nullptr, false); rWrtSh.EndSelect(); rWrtSh.GotoFootnoteText(); } rWrtSh.EndUndo( UNDO_UI_INSERT_FOOTNOTE ); rReq.Done(); } break; case FN_INSERT_FOOTNOTE_DLG: { SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "Dialog creation failed!"); std::unique_ptr pDlg(pFact->CreateInsFootNoteDlg( GetView().GetWindow(), rWrtSh)); OSL_ENSURE(pDlg, "Dialog creation failed!"); pDlg->SetHelpId(GetStaticInterface()->GetSlot(nSlot)->GetCommand()); if ( pDlg->Execute() == RET_OK ) { const sal_uInt16 nId = pDlg->IsEndNote() ? FN_INSERT_ENDNOTE : FN_INSERT_FOOTNOTE; SfxRequest aReq( GetView().GetViewFrame(), nId ); if ( !pDlg->GetStr().isEmpty() ) aReq.AppendItem( SfxStringItem( nId, pDlg->GetStr() ) ); if ( !pDlg->GetFontName().isEmpty() ) aReq.AppendItem( SfxStringItem( FN_PARAM_1, pDlg->GetFontName() ) ); ExecuteSlot( aReq ); } rReq.Ignore(); } break; case FN_FORMAT_FOOTNOTE_DLG: { GetView().ExecFormatFootnote(); break; } case SID_INSERTDOC: { GetView().ExecuteInsertDoc( rReq, pItem ); break; } case FN_FORMAT_RESET: { // #i78856, reset all attributes but not the language attributes // (for this build an array of all relevant attributes and // remove the languages from that) std::set aAttribs; sal_uInt16 aResetableSetRange[] = { RES_FRMATR_BEGIN, RES_FRMATR_END-1, RES_CHRATR_BEGIN, RES_CHRATR_LANGUAGE - 1, RES_CHRATR_LANGUAGE + 1, RES_CHRATR_CJK_LANGUAGE - 1, RES_CHRATR_CJK_LANGUAGE + 1, RES_CHRATR_CTL_LANGUAGE - 1, RES_CHRATR_CTL_LANGUAGE + 1, RES_CHRATR_END-1, RES_PARATR_BEGIN, RES_PARATR_END-1, RES_TXTATR_UNKNOWN_CONTAINER, RES_TXTATR_UNKNOWN_CONTAINER, RES_UNKNOWNATR_BEGIN, RES_UNKNOWNATR_END-1, 0 }; const sal_uInt16 *pUShorts = aResetableSetRange; while (*pUShorts) { for (sal_uInt16 i = pUShorts[0]; i <= pUShorts[1]; ++i) aAttribs.insert( aAttribs.end(), i ); pUShorts += 2; } // we don't want to change writing direction. aAttribs.erase( RES_FRAMEDIR ); rWrtSh.ResetAttr( aAttribs ); // also clear the direct formatting flag inside SwTableBox(es) GetView().GetDocShell()->GetFEShell()->UpdateTableStyleFormatting(nullptr, true); rReq.Done(); break; } case FN_INSERT_BREAK_DLG: { sal_uInt16 nKind=0; ::boost::optional oPageNumber; OUString aTemplateName; if ( pItem ) { nKind = static_cast(pItem)->GetValue(); const SfxStringItem* pTemplate = rReq.GetArg(FN_PARAM_1); const SfxUInt16Item* pNumber = rReq.GetArg(FN_PARAM_2); const SfxBoolItem* pIsNumberFilled = rReq.GetArg(FN_PARAM_3); if ( pTemplate ) aTemplateName = pTemplate->GetValue(); if ( pNumber && pIsNumberFilled && pIsNumberFilled->GetValue() ) oPageNumber = pNumber->GetValue(); } else { SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); std::unique_ptr pDlg(pFact->CreateSwBreakDlg(GetView().GetWindow(), rWrtSh)); OSL_ENSURE(pDlg, "Dialog creation failed!"); if ( pDlg->Execute() == RET_OK ) { nKind = pDlg->GetKind(); aTemplateName = pDlg->GetTemplateName(); oPageNumber = pDlg->GetPageNumber(); bool bIsNumberFilled = false; sal_uInt16 nPageNumber = 0; if (oPageNumber) { bIsNumberFilled = true; nPageNumber = oPageNumber.get(); } rReq.AppendItem( SfxInt16Item ( FN_INSERT_BREAK_DLG, nKind ) ); rReq.AppendItem( SfxStringItem( FN_PARAM_1, aTemplateName ) ); rReq.AppendItem( SfxUInt16Item( FN_PARAM_2, nPageNumber ) ); rReq.AppendItem( SfxBoolItem ( FN_PARAM_3, bIsNumberFilled ) ); rReq.Done(); } else rReq.Ignore(); } switch ( nKind ) { case 1 : rWrtSh.InsertLineBreak(); break; case 2 : rWrtSh.InsertColumnBreak(); break; case 3 : { rWrtSh.StartAllAction(); if( !aTemplateName.isEmpty() ) rWrtSh.InsertPageBreak( &aTemplateName, oPageNumber ); else rWrtSh.InsertPageBreak(); rWrtSh.EndAllAction(); } } break; } case FN_INSERT_BOOKMARK: { if ( pItem ) { OUString sName = static_cast(pItem)->GetValue(); rWrtSh.SetBookmark( vcl::KeyCode(), sName, OUString() ); } else { SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); std::unique_ptr pDlg(pFact->CreateSwInsertBookmarkDlg( GetView().GetWindow(), rWrtSh, rReq, DLG_INSERT_BOOKMARK )); OSL_ENSURE(pDlg, "Dialog creation failed!"); pDlg->Execute(); } break; } case FN_DELETE_BOOKMARK: { if ( pItem ) { IDocumentMarkAccess* const pMarkAccess = rWrtSh.getIDocumentMarkAccess(); pMarkAccess->deleteMark( pMarkAccess->findMark(static_cast(pItem)->GetValue()) ); } break; } case FN_AUTOFORMAT_REDLINE_APPLY: { SvxSwAutoFormatFlags aFlags(SvxAutoCorrCfg::Get().GetAutoCorrect()->GetSwFlags()); // This must always be false for the postprocessing. aFlags.bAFormatByInput = false; aFlags.bWithRedlining = true; rWrtSh.AutoFormat( &aFlags ); aFlags.bWithRedlining = false; SfxViewFrame* pVFrame = GetView().GetViewFrame(); if (pVFrame->HasChildWindow(FN_REDLINE_ACCEPT)) pVFrame->ToggleChildWindow(FN_REDLINE_ACCEPT); SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); std::unique_ptr pDlg(pFact->CreateSwModalRedlineAcceptDlg(&GetView().GetEditWin())); OSL_ENSURE(pDlg, "Dialog creation failed!"); switch (lcl_AskRedlineMode(&GetView().GetEditWin())) { case RET_OK: { pDlg->AcceptAll(true); SfxRequest aReq( pVFrame, FN_AUTOFORMAT_APPLY ); aReq.Done(); rReq.Ignore(); break; } case RET_CANCEL: pDlg->AcceptAll(false); rReq.Ignore(); break; case 2: pDlg->Execute(); rReq.Done(); break; } } break; case FN_AUTOFORMAT_APPLY: { SvxSwAutoFormatFlags aFlags(SvxAutoCorrCfg::Get().GetAutoCorrect()->GetSwFlags()); // This must always be false for the postprocessing. aFlags.bAFormatByInput = false; rWrtSh.AutoFormat( &aFlags ); rReq.Done(); } break; case FN_AUTOFORMAT_AUTO: { SvxAutoCorrCfg& rACfg = SvxAutoCorrCfg::Get(); bool bSet = pItem ? static_cast(pItem)->GetValue() : !rACfg.IsAutoFormatByInput(); if( bSet != rACfg.IsAutoFormatByInput() ) { rACfg.SetAutoFormatByInput( bSet ); rACfg.Commit(); GetView().GetViewFrame()->GetBindings().Invalidate( nSlot ); if ( !pItem ) rReq.AppendItem( SfxBoolItem( GetPool().GetWhich(nSlot), bSet ) ); rReq.Done(); } } break; case FN_AUTO_CORRECT: { // At first set to blank as default. sal_Unicode cChar = ' '; rWrtSh.AutoCorrect( *SvxAutoCorrCfg::Get().GetAutoCorrect(), cChar ); rReq.Done(); } break; case FN_TABLE_SORT_DIALOG: case FN_SORTING_DLG: { SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); std::unique_ptr pDlg(pFact->CreateVclAbstractDialog( GetView().GetWindow(), rWrtSh, DLG_SORTING )); OSL_ENSURE(pDlg, "Dialog creation failed!"); pDlg->Execute(); pDlg.reset(); rReq.Done(); } break; case FN_NUMBERING_OUTLINE_DLG: { GetView().ExecNumberingOutline(GetPool()); rReq.Done(); } break; case FN_CALCULATE: { SwTransferable* pTransfer = new SwTransferable( rWrtSh ); /*??*/ uno::Reference< datatransfer::XTransferable > xRef( pTransfer ); pTransfer->CalculateAndCopy(); rReq.Done(); } break; case FN_GOTO_REFERENCE: { SwField *pField = rWrtSh.GetCurField(); if(pField && pField->GetTypeId() == TYP_GETREFFLD) { rWrtSh.StartAllAction(); rWrtSh.SwCursorShell::GotoRefMark( static_cast(pField)->GetSetRefName(), static_cast(pField)->GetSubType(), static_cast(pField)->GetSeqNo() ); rWrtSh.EndAllAction(); rReq.Done(); } } break; case FN_EDIT_FORMULA: { const sal_uInt16 nId = SwInputChild::GetChildWindowId(); SfxViewFrame* pVFrame = GetView().GetViewFrame(); if(pItem) { //if the ChildWindow is active it has to be removed if( pVFrame->HasChildWindow( nId ) ) { pVFrame->ToggleChildWindow( nId ); pVFrame->GetBindings().InvalidateAll( true ); } OUString sFormula(static_cast(pItem)->GetValue()); SwFieldMgr aFieldMgr; rWrtSh.StartAllAction(); bool bDelSel; if( (bDelSel = rWrtSh.HasSelection()) ) { rWrtSh.StartUndo( UNDO_START ); rWrtSh.DelRight(); } else { rWrtSh.EnterStdMode(); } if( !bDelSel && aFieldMgr.GetCurField() && TYP_FORMELFLD == aFieldMgr.GetCurTypeId() ) aFieldMgr.UpdateCurField( aFieldMgr.GetCurField()->GetFormat(), OUString(), sFormula ); else if( !sFormula.isEmpty() ) { if( rWrtSh.IsCursorInTable() ) { SfxItemSet aSet( rWrtSh.GetAttrPool(), RES_BOXATR_FORMULA, RES_BOXATR_FORMULA ); aSet.Put( SwTableBoxFormula( sFormula )); rWrtSh.SetTableBoxFormulaAttrs( aSet ); rWrtSh.UpdateTable(); } else { SvNumberFormatter* pFormatter = rWrtSh.GetNumberFormatter(); sal_uLong nSysNumFormat = pFormatter->GetFormatIndex( NF_NUMBER_STANDARD, LANGUAGE_SYSTEM); SwInsertField_Data aData(TYP_FORMELFLD, nsSwGetSetExpType::GSE_FORMULA, OUString(), sFormula, nSysNumFormat); aFieldMgr.InsertField(aData); } } if( bDelSel ) rWrtSh.EndUndo( UNDO_END ); rWrtSh.EndAllAction(); rReq.Done(); } else { rWrtSh.EndAllTableBoxEdit(); pVFrame->ToggleChildWindow( nId ); if( !pVFrame->HasChildWindow( nId ) ) pVFrame->GetBindings().InvalidateAll( true ); rReq.Ignore(); } } break; case FN_TABLE_UNSET_READ_ONLY: { rWrtSh.UnProtectTables(); } break; case FN_EDIT_HYPERLINK: GetView().GetViewFrame()->SetChildWindow(SID_HYPERLINK_DIALOG, true); break; case FN_REMOVE_HYPERLINK: { bool bSel = rWrtSh.HasSelection(); if(!bSel) { rWrtSh.StartAction(); rWrtSh.Push(); if(!rWrtSh.SelectTextAttr( RES_TXTATR_INETFMT )) rWrtSh.SelWrd(); } //now remove the attribute std::set aAttribs; aAttribs.insert( RES_TXTATR_INETFMT ); rWrtSh.ResetAttr( aAttribs ); if(!bSel) { rWrtSh.Pop(false); rWrtSh.EndAction(); } } break; case SID_ATTR_BRUSH_CHAR : case SID_ATTR_CHAR_SCALEWIDTH : case SID_ATTR_CHAR_ROTATED : case FN_TXTATR_INET : case FN_INSERT_HYPERLINK: { const sal_uInt16 nWhich = GetPool().GetWhich( nSlot ); if ( pArgs && pArgs->GetItemState( nWhich ) == SfxItemState::SET ) bUseDialog = false; // intentionally no break } case SID_CHAR_DLG: case SID_CHAR_DLG_EFFECT: { sw_CharDialog( rWrtSh, bUseDialog, nSlot, pArgs, &rReq ); } break; case SID_CHAR_DLG_FOR_PARAGRAPH: { rWrtSh.Push(); //save current cursor SwLangHelper::SelectCurrentPara( rWrtSh ); sw_CharDialog( rWrtSh, bUseDialog, nSlot, pArgs, &rReq ); rWrtSh.Pop( false ); //restore old cursor } break; case SID_ATTR_LRSPACE : case SID_ATTR_ULSPACE : case SID_ATTR_BRUSH : case SID_PARA_VERTALIGN : case SID_ATTR_PARA_NUMRULE : case SID_ATTR_PARA_REGISTER : case SID_ATTR_PARA_PAGENUM : case FN_FORMAT_LINENUMBER : case FN_NUMBER_NEWSTART : case FN_NUMBER_NEWSTART_AT : case FN_FORMAT_DROPCAPS : case FN_DROP_TEXT: case SID_ATTR_PARA_LRSPACE: { const sal_uInt16 nWhich = GetPool().GetWhich( nSlot ); if ( pArgs && pArgs->GetItemState( nWhich ) == SfxItemState::SET ) bUseDialog = false; // intentionally no break } case SID_PARA_DLG: { SwPaM* pPaM = nullptr; if ( pArgs ) { const SfxPoolItem* pPaMItem = nullptr; pArgs->GetItemState( GetPool().GetWhich( FN_PARAM_PAM ), false, &pPaMItem ); if ( pPaMItem ) pPaM = static_cast< const SwPaMItem* >( pPaMItem )->GetValue( ); } if ( !pPaM ) pPaM = rWrtSh.GetCursor(); FieldUnit eMetric = ::GetDfltMetric( dynamic_cast( &GetView()) != nullptr ); SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< sal_uInt16 >(eMetric))); bool bApplyCharUnit = ::HasCharUnit( dynamic_cast( &GetView()) != nullptr ); SW_MOD()->PutItem(SfxBoolItem(SID_ATTR_APPLYCHARUNIT, bApplyCharUnit)); SfxItemSet aCoreSet( GetPool(), //UUUU sorted by indices, one group of three concatenated RES_PARATR_BEGIN, RES_PARATR_END - 1, // [60 RES_PARATR_LIST_BEGIN, RES_PARATR_LIST_END - 1, // [77 RES_FRMATR_BEGIN, RES_FRMATR_END - 1, // [82 //UUUU FillAttribute support XATTR_FILL_FIRST, XATTR_FILL_LAST, // [1014 // includes SID_ATTR_TABSTOP_POS SID_ATTR_TABSTOP_DEFAULTS, SID_ATTR_TABSTOP_OFFSET, // [10003 .. 10005 SID_ATTR_BORDER_INNER, SID_ATTR_BORDER_INNER, // [10023 SID_ATTR_PARA_MODEL, SID_ATTR_PARA_KEEP, // [10065 //UUUU items to hand over XPropertyList things like // XColorList, XHatchList, XGradientList and XBitmapList // to the Area TabPage SID_COLOR_TABLE, SID_BITMAP_LIST, // [10179 SID_HTML_MODE, SID_HTML_MODE, // [10414 SID_ATTR_PARA_PAGENUM, SID_ATTR_PARA_PAGENUM, // [10457 FN_PARAM_1, FN_PARAM_1, // [21160 FN_NUMBER_NEWSTART, FN_NUMBER_NEWSTART_AT, // [21738 FN_DROP_TEXT, FN_DROP_CHAR_STYLE_NAME, // [22418 0); // get also the list level indent values merged as LR-SPACE item, if needed. rWrtSh.GetCurAttr( aCoreSet, true ); //UUUU create needed items for XPropertyList entries from the DrawModel so that // the Area TabPage can access them // Do this after GetCurAttr, this resets the ItemSet content again const SwDrawModel* pDrawModel = GetView().GetDocShell()->GetDoc()->getIDocumentDrawModelAccess().GetDrawModel(); aCoreSet.Put(SvxColorListItem(pDrawModel->GetColorList(), SID_COLOR_TABLE)); aCoreSet.Put(SvxGradientListItem(pDrawModel->GetGradientList(), SID_GRADIENT_LIST)); aCoreSet.Put(SvxHatchListItem(pDrawModel->GetHatchList(), SID_HATCH_LIST)); aCoreSet.Put(SvxBitmapListItem(pDrawModel->GetBitmapList(), SID_BITMAP_LIST)); aCoreSet.Put(SfxUInt16Item(SID_HTML_MODE, ::GetHtmlMode(GetView().GetDocShell()))); // Tabulators: Put DefaultTabs into ItemSet const SvxTabStopItem& rDefTabs = static_cast( GetPool().GetDefaultItem(RES_PARATR_TABSTOP)); const sal_uInt16 nDefDist = static_cast(::GetTabDist( rDefTabs )); SfxUInt16Item aDefDistItem( SID_ATTR_TABSTOP_DEFAULTS, nDefDist ); aCoreSet.Put( aDefDistItem ); // Current tabulator SfxUInt16Item aTabPos( SID_ATTR_TABSTOP_POS, 0 ); aCoreSet.Put( aTabPos ); // Left border as offset //#i24363# tab stops relative to indent const long nOff = rWrtSh.getIDocumentSettingAccess().get(DocumentSettingId::TABS_RELATIVE_TO_INDENT) ? static_cast(aCoreSet.Get( RES_LR_SPACE )).GetTextLeft() : 0; SfxInt32Item aOff( SID_ATTR_TABSTOP_OFFSET, nOff ); aCoreSet.Put( aOff ); // Setting the BoxInfo ::PrepareBoxInfo( aCoreSet, rWrtSh ); // Current page format ::SwToSfxPageDescAttr( aCoreSet ); // Properties of numbering if (rWrtSh.GetNumRuleAtCurrCursorPos()) { SfxBoolItem aStart( FN_NUMBER_NEWSTART, rWrtSh.IsNumRuleStart( pPaM ) ); aCoreSet.Put(aStart); SfxUInt16Item aStartAt( FN_NUMBER_NEWSTART_AT, rWrtSh.GetNodeNumStart( pPaM ) ); aCoreSet.Put(aStartAt); } std::unique_ptr pDlg; if ( bUseDialog && GetActiveView() ) { OString sDefPage; if (pItem) sDefPage = OUStringToOString(static_cast(pItem)->GetValue(), RTL_TEXTENCODING_UTF8); SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); pDlg.reset(pFact->CreateSwParaDlg( GetView().GetWindow(),GetView(), aCoreSet, DLG_STD, nullptr, false, sDefPage )); OSL_ENSURE(pDlg, "Dialog creation failed!"); } SfxItemSet* pSet = nullptr; if ( !bUseDialog ) { if ( nSlot == SID_ATTR_PARA_LRSPACE) { SvxLRSpaceItem aParaMargin(static_cast(pArgs->Get(nSlot))); aParaMargin.SetWhich( RES_LR_SPACE); aCoreSet.Put(aParaMargin); pSet = &aCoreSet; } else pSet = const_cast(pArgs); } else if ( pDlg && pDlg->Execute() == RET_OK ) { // Apply defaults if necessary. pSet = const_cast(pDlg->GetOutputItemSet()); sal_uInt16 nNewDist; if( SfxItemState::SET == pSet->GetItemState( SID_ATTR_TABSTOP_DEFAULTS, false, &pItem ) && nDefDist != (nNewDist = static_cast(pItem)->GetValue()) ) { SvxTabStopItem aDefTabs( 0, 0, SVX_TAB_ADJUST_DEFAULT, RES_PARATR_TABSTOP ); MakeDefTabs( nNewDist, aDefTabs ); rWrtSh.SetDefault( aDefTabs ); pSet->ClearItem( SID_ATTR_TABSTOP_DEFAULTS ); } if ( SfxItemState::SET == pSet->GetItemState(FN_PARAM_1,false,&pItem) ) { pSet->Put(SfxStringItem(FN_DROP_TEXT, static_cast(pItem)->GetValue())); pSet->ClearItem(FN_PARAM_1); } if( SfxItemState::SET == pSet->GetItemState( RES_PARATR_DROP, false, &pItem )) { OUString sCharStyleName; if(static_cast(pItem)->GetCharFormat()) sCharStyleName = static_cast(pItem)->GetCharFormat()->GetName(); pSet->Put(SfxStringItem(FN_DROP_CHAR_STYLE_NAME, sCharStyleName)); } } if ( pSet ) { rReq.Done( *pSet ); ::SfxToSwPageDescAttr( rWrtSh, *pSet ); // #i56253# // enclose all undos. // Thus, check conditions, if actions will be performed. const bool bUndoNeeded( pSet->Count() || SfxItemState::SET == pSet->GetItemState(FN_NUMBER_NEWSTART) || SfxItemState::SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) ); if ( bUndoNeeded ) { rWrtSh.StartUndo( UNDO_INSATTR ); } if( pSet->Count() ) { rWrtSh.StartAction(); if ( SfxItemState::SET == pSet->GetItemState(FN_DROP_TEXT, false, &pItem) ) { if ( !static_cast(pItem)->GetValue().isEmpty() ) rWrtSh.ReplaceDropText(static_cast(pItem)->GetValue(), pPaM); } rWrtSh.SetAttrSet( *pSet, SetAttrMode::DEFAULT, pPaM ); rWrtSh.EndAction(); SwTextFormatColl* pColl = rWrtSh.GetPaMTextFormatColl( pPaM ); if(pColl && pColl->IsAutoUpdateFormat()) { rWrtSh.AutoUpdatePara(pColl, *pSet, pPaM); } } if( SfxItemState::SET == pSet->GetItemState(FN_NUMBER_NEWSTART) ) { //SetNumRuleStart(true) restarts the numbering at the value //that is defined at the starting point of the numbering level //otherwise the SetNodeNumStart() value determines the start //if it's set to something different than USHRT_MAX bool bStart = static_cast(pSet->Get(FN_NUMBER_NEWSTART)).GetValue(); // Default value for restart value has to be USHRT_MAX // in order to indicate that the restart value of the list // style has to be used on restart. sal_uInt16 nNumStart = USHRT_MAX; if( SfxItemState::SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) ) { nNumStart = static_cast(pSet->Get(FN_NUMBER_NEWSTART_AT)).GetValue(); } rWrtSh.SetNumRuleStart(bStart, pPaM); rWrtSh.SetNodeNumStart(nNumStart); } else if( SfxItemState::SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) ) { rWrtSh.SetNodeNumStart(static_cast(pSet->Get(FN_NUMBER_NEWSTART_AT)).GetValue()); rWrtSh.SetNumRuleStart(false, pPaM); } // #i56253# if ( bUndoNeeded ) { rWrtSh.EndUndo( UNDO_INSATTR ); } } } break; case FN_NUM_CONTINUE: { OUString sContinuedListId; const SwNumRule* pRule = rWrtSh.SearchNumRule( false, true, false, -1, sContinuedListId ); // #i86492# // Search also for bullet list if ( !pRule ) { pRule = rWrtSh.SearchNumRule( false, false, false, -1, sContinuedListId ); } if ( pRule ) { rWrtSh.SetCurNumRule( *pRule, false, sContinuedListId ); } } break; case FN_SELECT_PARA: { if ( !rWrtSh.IsSttOfPara() ) rWrtSh.SttPara(); else rWrtSh.EnterStdMode(); rWrtSh.EndPara( true ); } break; case SID_DEC_INDENT: case SID_INC_INDENT: //According to the requirement, modified the behavior when user //using the indent button on the toolbar. Now if we increase/decrease indent for a //paragraph which has bullet style it will increase/decrease the bullet level. { //If the current paragraph has bullet call the function to //increase or decrease the bullet level. //Why could I know whether a paragraph has bullet or not by checking the below conditions? //Please refer to the "case KEY_TAB:" section in SwEditWin::KeyInput(..) : // if( rSh.GetCurNumRule() && rSh.IsSttOfPara() && // !rSh.HasReadonlySel() ) // eKeyState = KS_NumDown; //Above code demonstrates that when the cursor is at the start of a paragraph which has bullet, //press TAB will increase the bullet level. //So I copied from that ^^ if ( rWrtSh.GetNumRuleAtCurrCursorPos() && !rWrtSh.HasReadonlySel() ) { rWrtSh.NumUpDown( SID_INC_INDENT == nSlot ); } else //execute the original processing functions { //below is copied of the old codes rWrtSh.MoveLeftMargin( SID_INC_INDENT == nSlot, rReq.GetModifier() != KEY_MOD1 ); } } rReq.Done(); break; case FN_DEC_INDENT_OFFSET: case FN_INC_INDENT_OFFSET: rWrtSh.MoveLeftMargin( FN_INC_INDENT_OFFSET == nSlot, rReq.GetModifier() == KEY_MOD1 ); rReq.Done(); break; case SID_ATTR_CHAR_COLOR2: { if(pItem) { Color aSet = static_cast(pItem)->GetValue(); SwEditWin& rEditWin = GetView().GetEditWin(); SwEditWin::SetWaterCanTextColor(aSet); SwApplyTemplate* pApply = rEditWin.GetApplyTemplate(); // If there is a selection, then set the color on it // otherwise, it'll be the color for the next text to be typed if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_EXT) { rWrtSh.SetAttrItem(SvxColorItem (aSet, RES_CHRATR_COLOR)); } rReq.Done(); } } break; case SID_ATTR_CHAR_COLOR_BACKGROUND: { Color aSet; if(pItem) aSet = static_cast(pItem)->GetValue(); else aSet = COL_TRANSPARENT; SwEditWin& rEdtWin = GetView().GetEditWin(); SwEditWin::SetWaterCanTextBackColor(aSet); SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate(); if(!pApply && (rWrtSh.HasSelection() || rReq.IsAPI())) { rWrtSh.StartUndo( UNDO_INSATTR ); SvxBrushItem aBrushItem(RES_CHRATR_BACKGROUND); aBrushItem.SetColor(aSet); rWrtSh.SetAttrItem( aBrushItem ); // Remove MS specific highlight when background is set rWrtSh.SetAttrItem( SvxBrushItem(RES_CHRATR_HIGHLIGHT) ); // Remove shading marker SfxItemSet aCoreSet( rWrtSh.GetView().GetPool(), RES_CHRATR_GRABBAG, RES_CHRATR_GRABBAG ); rWrtSh.GetCurAttr( aCoreSet ); const SfxPoolItem *pTmpItem; if( SfxItemState::SET == aCoreSet.GetItemState( RES_CHRATR_GRABBAG, false, &pTmpItem ) ) { SfxGrabBagItem aGrabBag(*static_cast(pTmpItem)); std::map& rMap = aGrabBag.GetGrabBag(); auto aIterator = rMap.find("CharShadingMarker"); if( aIterator != rMap.end() ) { aIterator->second = uno::makeAny(false); } rWrtSh.SetAttrItem( aGrabBag ); } rWrtSh.EndUndo( UNDO_INSATTR ); } else if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_BACKGROUND_EXT) { GetView().GetViewFrame()->GetDispatcher()->Execute(SID_ATTR_CHAR_COLOR_BACKGROUND_EXT); } rReq.Done(); } break; case SID_ATTR_CHAR_COLOR_BACKGROUND_EXT: case SID_ATTR_CHAR_COLOR_EXT: { SwEditWin& rEdtWin = GetView().GetEditWin(); if (pItem) { // The reason we need this argument here is that when a toolbar is closed // and reopened, its color resets, while SwEditWin still holds the old one. Color aSet = static_cast(pItem)->GetValue(); if( nSlot == SID_ATTR_CHAR_COLOR_BACKGROUND_EXT ) SwEditWin::SetWaterCanTextBackColor(aSet); else SwEditWin::SetWaterCanTextColor(aSet); } SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate(); SwApplyTemplate aTempl; if ( rWrtSh.HasSelection() ) { if(nSlot == SID_ATTR_CHAR_COLOR_BACKGROUND_EXT) { rWrtSh.StartUndo( UNDO_INSATTR ); rWrtSh.SetAttrItem( SvxBrushItem( SwEditWin::GetWaterCanTextBackColor(), RES_CHRATR_BACKGROUND) ); // Remove MS specific highlight when background is set rWrtSh.SetAttrItem( SvxBrushItem(RES_CHRATR_HIGHLIGHT) ); // Remove shading marker SfxItemSet aCoreSet( rWrtSh.GetView().GetPool(), RES_CHRATR_GRABBAG, RES_CHRATR_GRABBAG ); rWrtSh.GetCurAttr( aCoreSet ); const SfxPoolItem *pTmpItem; if( SfxItemState::SET == aCoreSet.GetItemState( RES_CHRATR_GRABBAG, false, &pTmpItem ) ) { SfxGrabBagItem aGrabBag(*static_cast(pTmpItem)); std::map& rMap = aGrabBag.GetGrabBag(); auto aIterator = rMap.find("CharShadingMarker"); if( aIterator != rMap.end() ) { aIterator->second = uno::makeAny(false); } rWrtSh.SetAttrItem( aGrabBag ); } rWrtSh.EndUndo( UNDO_INSATTR ); } else rWrtSh.SetAttrItem( SvxColorItem( SwEditWin::GetWaterCanTextColor(), RES_CHRATR_COLOR) ); } else { if(!pApply || pApply->nColor != nSlot) aTempl.nColor = nSlot; rEdtWin.SetApplyTemplate(aTempl); } rReq.Done(); } break; case FN_NUM_BULLET_MOVEDOWN: if (!rWrtSh.IsAddMode()) rWrtSh.MoveParagraph(); rReq.Done(); break; case FN_NUM_BULLET_MOVEUP: if (!rWrtSh.IsAddMode()) rWrtSh.MoveParagraph(-1); rReq.Done(); break; case SID_RUBY_DIALOG: case SID_HYPERLINK_DIALOG: { SfxRequest aReq(nSlot, SfxCallMode::SLOT, SfxGetpApp()->GetPool()); GetView().GetViewFrame()->ExecuteSlot( aReq); rReq.Ignore(); } break; case FN_INSERT_PAGEHEADER: case FN_INSERT_PAGEFOOTER: if(pArgs && pArgs->Count()) { OUString sStyleName; if(pItem) sStyleName = static_cast(pItem)->GetValue(); bool bOn = true; if( SfxItemState::SET == pArgs->GetItemState(FN_PARAM_1, false, &pItem)) bOn = static_cast(pItem)->GetValue(); rWrtSh.ChangeHeaderOrFooter(sStyleName, FN_INSERT_PAGEHEADER == nSlot, bOn, !rReq.IsAPI()); rReq.Done(); } break; case FN_READONLY_SELECTION_MODE : if(GetView().GetDocShell()->IsReadOnly()) { rWrtSh.SetReadonlySelectionOption( !rWrtSh.GetViewOptions()->IsSelectionInReadonly()); rWrtSh.ShowCursor(); } break; case FN_SELECTION_MODE_DEFAULT: case FN_SELECTION_MODE_BLOCK : { bool bSetBlockMode = !rWrtSh.IsBlockMode(); if( pArgs && SfxItemState::SET == pArgs->GetItemState(nSlot, false, &pItem)) bSetBlockMode = static_cast(pItem)->GetValue(); if( ( nSlot == FN_SELECTION_MODE_DEFAULT ) != bSetBlockMode ) rWrtSh.EnterBlockMode(); else rWrtSh.EnterStdMode(); SfxBindings &rBnd = GetView().GetViewFrame()->GetBindings(); rBnd.Invalidate(FN_STAT_SELMODE); rBnd.Update(FN_STAT_SELMODE); } break; case SID_OPEN_HYPERLINK: case FN_COPY_HYPERLINK_LOCATION: { SfxItemSet aSet(GetPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT); rWrtSh.GetCurAttr(aSet); if(SfxItemState::SET <= aSet.GetItemState( RES_TXTATR_INETFMT )) { const SwFormatINetFormat& rINetFormat = dynamic_cast( aSet.Get(RES_TXTATR_INETFMT) ); if( nSlot == FN_COPY_HYPERLINK_LOCATION ) { ::uno::Reference< datatransfer::clipboard::XClipboard > xClipboard = GetView().GetEditWin().GetClipboard(); vcl::unohelper::TextDataObject::CopyStringTo( rINetFormat.GetValue(), xClipboard ); } else rWrtSh.ClickToINetAttr(rINetFormat); } } break; case SID_OPEN_XML_FILTERSETTINGS: { HandleOpenXmlFilterSettings(rReq); } break; case FN_FORMAT_APPLY_HEAD1: { } break; case FN_FORMAT_APPLY_HEAD2: { } break; case FN_FORMAT_APPLY_HEAD3: { } break; case FN_FORMAT_APPLY_DEFAULT: { } break; case FN_FORMAT_APPLY_TEXTBODY: { } break; case FN_WORDCOUNT_DIALOG: { GetView().UpdateWordCount(this, nSlot); } break; default: OSL_ENSURE(false, "wrong dispatcher"); return; } } void SwTextShell::GetState( SfxItemSet &rSet ) { SwWrtShell &rSh = GetShell(); SfxWhichIter aIter( rSet ); sal_uInt16 nWhich = aIter.FirstWhich(); while ( nWhich ) { switch ( nWhich ) { case SID_LANGUAGE_STATUS: { // the value of used script types OUString aScriptTypesInUse( OUString::number( static_cast(rSh.GetScriptType()) ) ); // get keyboard language OUString aKeyboardLang; SwEditWin& rEditWin = GetView().GetEditWin(); LanguageType nLang = rEditWin.GetInputLanguage(); if (nLang != LANGUAGE_DONTKNOW && nLang != LANGUAGE_SYSTEM) aKeyboardLang = SvtLanguageTable::GetLanguageString( nLang ); // get the language that is in use OUString aCurrentLang = "*"; nLang = SwLangHelper::GetCurrentLanguage( rSh ); if (nLang != LANGUAGE_DONTKNOW) aCurrentLang = SvtLanguageTable::GetLanguageString( nLang ); // build sequence for status value uno::Sequence< OUString > aSeq( 4 ); aSeq[0] = aCurrentLang; aSeq[1] = aScriptTypesInUse; aSeq[2] = aKeyboardLang; aSeq[3] = SwLangHelper::GetTextForLanguageGuessing( rSh ); // set sequence as status value SfxStringListItem aItem( SID_LANGUAGE_STATUS ); aItem.SetStringList( aSeq ); rSet.Put( aItem, SID_LANGUAGE_STATUS ); } break; case SID_THES: { // is there a valid selection to get text from? OUString aText; bool bValid = !rSh.HasSelection() || (rSh.IsSelOnePara() && !rSh.IsMultiSelection()); // prevent context menu from showing when cursor is not in or at the end of a word // (GetCurWord will return the next word if there is none at the current position...) const sal_Int16 nWordType = ::i18n::WordType::DICTIONARY_WORD; bool bWord = rSh.IsInWord( nWordType ) || rSh.IsStartWord( nWordType ) || rSh.IsEndWord( nWordType ); if (bValid && bWord) aText = rSh.HasSelection()? OUString(rSh.GetSelText()) : rSh.GetCurWord(); LanguageType nLang = rSh.GetCurLang(); LanguageTag aLanguageTag( nLang); lang::Locale aLocale( aLanguageTag.getLocale()); OUString aLangText( aLanguageTag.getBcp47() ); // set word and locale to look up as status value OUString aStatusVal = aText + "#" + aLangText; rSet.Put( SfxStringItem( SID_THES, aStatusVal ) ); // disable "Thesaurus" context menu entry if there is nothing to look up uno::Reference< linguistic2::XThesaurus > xThes( ::GetThesaurus() ); if (aText.isEmpty() || !xThes.is() || nLang == LANGUAGE_NONE || !xThes->hasLocale( aLocale )) rSet.DisableItem( SID_THES ); } break; case FN_NUMBER_NEWSTART : if(!rSh.GetNumRuleAtCurrCursorPos()) rSet.DisableItem(nWhich); else rSet.Put(SfxBoolItem(FN_NUMBER_NEWSTART, rSh.IsNumRuleStart())); break; case FN_EDIT_FORMULA: case SID_CHARMAP: { const int nType = rSh.GetSelectionType(); if (!(nType & nsSelectionType::SEL_TXT) && !(nType & nsSelectionType::SEL_TBL) && !(nType & nsSelectionType::SEL_NUM)) { rSet.DisableItem(nWhich); } else if ( nWhich == FN_EDIT_FORMULA && rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } } break; case FN_INSERT_ENDNOTE: case FN_INSERT_FOOTNOTE: case FN_INSERT_FOOTNOTE_DLG: { const FrameTypeFlags nNoType = FrameTypeFlags::FLY_ANY | FrameTypeFlags::HEADER | FrameTypeFlags::FOOTER | FrameTypeFlags::FOOTNOTE; if ( rSh.GetFrameType(nullptr,true) & nNoType ) rSet.DisableItem(nWhich); if ( rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } } break; case FN_INSERT_HYPERLINK: case SID_INSERTDOC: case FN_INSERT_GLOSSARY: case FN_EXPAND_GLOSSARY: if ( rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } break; case FN_INSERT_TABLE: if ( rSh.CursorInsideInputField() || rSh.GetTableFormat() || (rSh.GetFrameType(nullptr,true) & FrameTypeFlags::FOOTNOTE) ) { rSet.DisableItem( nWhich ); } break; case FN_CALCULATE: if ( !rSh.IsSelection() ) rSet.DisableItem(nWhich); break; case FN_GOTO_REFERENCE: { SwField *pField = rSh.GetCurField(); if ( !pField || (pField->GetTypeId() != TYP_GETREFFLD) ) rSet.DisableItem(nWhich); } break; case FN_AUTOFORMAT_AUTO: { rSet.Put( SfxBoolItem( nWhich, SvxAutoCorrCfg::Get().IsAutoFormatByInput() )); } break; case SID_DEC_INDENT: case SID_INC_INDENT: { //if the paragrah has bullet we'll do the following things: //1: if the bullet level is the first level, disable the decrease-indent button //2: if the bullet level is the last level, disable the increase-indent button if ( rSh.GetNumRuleAtCurrCursorPos() && !rSh.HasReadonlySel() ) { const sal_uInt8 nLevel = rSh.GetNumLevel(); if ( ( nLevel == ( MAXLEVEL - 1 ) && nWhich == SID_INC_INDENT ) || ( nLevel == 0 && nWhich == SID_DEC_INDENT ) ) { rSet.DisableItem( nWhich ); } } else { sal_uInt16 nHtmlMode = ::GetHtmlMode( GetView().GetDocShell() ); nHtmlMode &= HTMLMODE_ON | HTMLMODE_SOME_STYLES; if ( ( nHtmlMode == HTMLMODE_ON ) || !rSh.IsMoveLeftMargin( SID_INC_INDENT == nWhich ) ) { rSet.DisableItem( nWhich ); } } } break; case FN_DEC_INDENT_OFFSET: case FN_INC_INDENT_OFFSET: { sal_uInt16 nHtmlMode = ::GetHtmlMode(GetView().GetDocShell()); nHtmlMode &= HTMLMODE_ON|HTMLMODE_SOME_STYLES; if( (nHtmlMode == HTMLMODE_ON) || !rSh.IsMoveLeftMargin( FN_INC_INDENT_OFFSET == nWhich, false )) rSet.DisableItem( nWhich ); } break; case SID_ATTR_CHAR_COLOR2: { SfxItemSet aSet( GetPool() ); rSh.GetCurAttr( aSet ); const SvxColorItem& aColorItem = static_cast< const SvxColorItem& >( aSet.Get(RES_CHRATR_COLOR) ); rSet.Put( aColorItem, SID_ATTR_CHAR_COLOR2 ); } break; case SID_ATTR_CHAR_COLOR_BACKGROUND: { // Always use the visible background SfxItemSet aSet( GetPool() ); rSh.GetCurAttr( aSet ); const SvxBrushItem& aBrushItem = static_cast< const SvxBrushItem& >( aSet.Get(RES_CHRATR_HIGHLIGHT) ); if( aBrushItem.GetColor() != COL_TRANSPARENT ) { rSet.Put( SvxColorItem(aBrushItem.GetColor(), nWhich) ); } else { const SvxBrushItem& aBrushItem2 = static_cast< const SvxBrushItem& >( aSet.Get(RES_CHRATR_BACKGROUND) ); rSet.Put( SvxColorItem(aBrushItem2.GetColor(), nWhich) ); } } break; case SID_ATTR_CHAR_COLOR_BACKGROUND_EXT: case SID_ATTR_CHAR_COLOR_EXT: { SwEditWin& rEdtWin = GetView().GetEditWin(); SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate(); rSet.Put(SfxBoolItem(nWhich, pApply && pApply->nColor == nWhich)); } break; case FN_INSERT_BOOKMARK: if( rSh.IsTableMode() || rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } break; case FN_INSERT_BREAK: if ( rSh.HasReadonlySel() && !rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } break; case FN_INSERT_BREAK_DLG: case FN_INSERT_COLUMN_BREAK: case FN_INSERT_PAGEBREAK: if( rSh.CursorInsideInputField() ) { rSet.DisableItem( nWhich ); } break; case FN_INSERT_PAGEHEADER: case FN_INSERT_PAGEFOOTER: { rSet.Put( SfxObjectShellItem( nWhich, GetView().GetDocShell() )); } break; case FN_TABLE_SORT_DIALOG: case FN_SORTING_DLG: if(!rSh.HasSelection() || (FN_TABLE_SORT_DIALOG == nWhich && !rSh.GetTableFormat())) rSet.DisableItem( nWhich ); break; case SID_RUBY_DIALOG: { SvtCJKOptions aCJKOptions; if( !aCJKOptions.IsRubyEnabled() || rSh.CursorInsideInputField() ) { GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, false ); rSet.DisableItem(nWhich); } else GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, true ); } break; case SID_HYPERLINK_DIALOG: if( GetView().GetDocShell()->IsReadOnly() || ( !GetView().GetViewFrame()->HasChildWindow(nWhich) && rSh.HasReadonlySel() ) || rSh.CursorInsideInputField() ) { rSet.DisableItem(nWhich); } else { rSet.Put(SfxBoolItem( nWhich, nullptr != GetView().GetViewFrame()->GetChildWindow( nWhich ) )); } break; case FN_EDIT_HYPERLINK: case FN_COPY_HYPERLINK_LOCATION: { SfxItemSet aSet(GetPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT); rSh.GetCurAttr(aSet); if(SfxItemState::SET > aSet.GetItemState( RES_TXTATR_INETFMT ) || rSh.HasReadonlySel()) { rSet.DisableItem(nWhich); } } break; case FN_REMOVE_HYPERLINK: { SfxItemSet aSet(GetPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT); rSh.GetCurAttr(aSet); // If a hyperlink is selected, either alone or along with other text... if ((aSet.GetItemState(RES_TXTATR_INETFMT) < SfxItemState::SET && aSet.GetItemState(RES_TXTATR_INETFMT) != SfxItemState::DONTCARE) || rSh.HasReadonlySel()) { rSet.DisableItem(nWhich); } } break; case SID_TRANSLITERATE_HALFWIDTH: case SID_TRANSLITERATE_FULLWIDTH: case SID_TRANSLITERATE_HIRAGANA: case SID_TRANSLITERATE_KATAGANA: { SvtCJKOptions aCJKOptions; if(!aCJKOptions.IsChangeCaseMapEnabled()) { GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, false ); rSet.DisableItem(nWhich); } else GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, true ); } break; case FN_READONLY_SELECTION_MODE : if(!GetView().GetDocShell()->IsReadOnly()) rSet.DisableItem( nWhich ); else { rSet.Put(SfxBoolItem(nWhich, rSh.GetViewOptions()->IsSelectionInReadonly())); } break; case FN_SELECTION_MODE_DEFAULT: case FN_SELECTION_MODE_BLOCK : rSet.Put(SfxBoolItem(nWhich, (nWhich == FN_SELECTION_MODE_DEFAULT) != rSh.IsBlockMode())); break; case SID_OPEN_HYPERLINK: { SfxItemSet aSet(GetPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT); rSh.GetCurAttr(aSet); if(SfxItemState::SET > aSet.GetItemState( RES_TXTATR_INETFMT, false )) rSet.DisableItem(nWhich); } break; case SID_OPEN_SMARTTAGMENU: { uno::Sequence< OUString > aSmartTagTypes; uno::Sequence< uno::Reference< container::XStringKeyMap > > aStringKeyMaps; uno::Reference xRange; rSh.GetSmartTagTerm( aSmartTagTypes, aStringKeyMaps, xRange ); if ( xRange.is() && aSmartTagTypes.getLength() ) { uno::Sequence < uno::Sequence< uno::Reference< smarttags::XSmartTagAction > > > aActionComponentsSequence; uno::Sequence < uno::Sequence< sal_Int32 > > aActionIndicesSequence; const SmartTagMgr& rSmartTagMgr = SwSmartTagMgr::Get(); rSmartTagMgr.GetActionSequences( aSmartTagTypes, aActionComponentsSequence, aActionIndicesSequence ); uno::Reference xController = GetView().GetController(); const lang::Locale aLocale( SW_BREAKITER()->GetLocale( GetAppLanguageTag() ) ); const OUString aApplicationName( rSmartTagMgr.GetApplicationName() ); const OUString aRangeText = xRange->getString(); const SvxSmartTagItem aItem( nWhich, aActionComponentsSequence, aActionIndicesSequence, aStringKeyMaps, xRange, xController, aLocale, aApplicationName, aRangeText ); rSet.Put( aItem ); } else rSet.DisableItem(nWhich); } break; case FN_NUM_NUMBERING_ON: rSet.Put(SfxBoolItem(FN_NUM_NUMBERING_ON,rSh.SelectionHasNumber())); break; case FN_NUM_BULLET_ON: rSet.Put(SfxBoolItem(FN_NUM_BULLET_ON,rSh.SelectionHasBullet())); break; case FN_BUL_NUM_RULE_INDEX: case FN_NUM_NUM_RULE_INDEX: case FN_OUTLINE_RULE_INDEX: { SwNumRule* pCurRule = const_cast(GetShell().GetNumRuleAtCurrCursorPos()); sal_uInt16 nActNumLvl = USHRT_MAX; if( pCurRule ) { nActNumLvl = GetShell().GetNumLevel(); if( nActNumLvl < MAXLEVEL ) { nActNumLvl = 1<MakeSvxNumRule(); if ( GetShell().HasBullet()) { rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX, USHRT_MAX)); rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX, USHRT_MAX)); NBOTypeMgrBase* pBullets = NBOutlineTypeMgrFact::CreateInstance(eNBOType::BULLETS); if ( pBullets ) { const sal_uInt16 nBulIndex = pBullets->GetNBOIndexForNumRule(aSvxRule,nActNumLvl); rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX,nBulIndex)); } }else if ( GetShell().HasNumber() ) { rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX, USHRT_MAX)); rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX, USHRT_MAX)); NBOTypeMgrBase* pNumbering = NBOutlineTypeMgrFact::CreateInstance(eNBOType::NUMBERING); if ( pNumbering ) { const sal_uInt16 nBulIndex = pNumbering->GetNBOIndexForNumRule(aSvxRule,nActNumLvl); rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX,nBulIndex)); } } if ( nWhich == FN_OUTLINE_RULE_INDEX ) { rSet.Put(SfxUInt16Item(FN_OUTLINE_RULE_INDEX, USHRT_MAX)); NBOTypeMgrBase* pOutline = NBOutlineTypeMgrFact::CreateInstance(eNBOType::OUTLINE); if ( pOutline ) { const sal_uInt16 nIndex = pOutline->GetNBOIndexForNumRule(aSvxRule,nActNumLvl); rSet.Put(SfxUInt16Item(FN_OUTLINE_RULE_INDEX,nIndex)); } } } } break; case FN_NUM_CONTINUE: { { // #i86492# // Search also for bullet list OUString aDummy; const SwNumRule* pRule = rSh.SearchNumRule( false, true, false, -1, aDummy ); if ( !pRule ) { pRule = rSh.SearchNumRule( false, false, false, -1, aDummy ); } if ( !pRule ) rSet.DisableItem(nWhich); } } break; case SID_INSERT_RLM : case SID_INSERT_LRM : case SID_INSERT_ZWNBSP : case SID_INSERT_ZWSP: { SvtCTLOptions aCTLOptions; bool bEnabled = aCTLOptions.IsCTLFontEnabled(); GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, bEnabled ); if(!bEnabled) rSet.DisableItem(nWhich); } break; } nWhich = aIter.NextWhich(); } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */