xref: /trunk/main/sw/source/ui/shells/textsh1.cxx (revision 1ff378ef29d061c5ebed689ca488bcdadd10692f)
1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_sw.hxx"
26 
27 #include <com/sun/star/i18n/WordType.hpp>
28 #include <com/sun/star/ui/dialogs/XExecutableDialog.hpp>
29 
30 #include <comphelper/processfactory.hxx>
31 #include <svx/dialogs.hrc>
32 #include <hintids.hxx>
33 #include <cmdid.h>
34 #include <helpid.h>
35 
36 #include <i18npool/mslangid.hxx>
37 #include <svl/languageoptions.hxx>
38 #include <editeng/langitem.hxx>
39 #include <svtools/langtab.hxx>
40 #include <svl/slstitm.hxx>
41 #include <string.h>
42 #include <svl/stritem.hxx>
43 #include <svx/htmlmode.hxx>
44 #include <svl/whiter.hxx>
45 #include <sfx2/bindings.hxx>
46 #include <sfx2/dispatch.hxx>
47 #include <sfx2/objitem.hxx>
48 #include <vcl/msgbox.hxx>
49 #include <vcl/unohelp2.hxx>
50 #include <sfx2/request.hxx>
51 #include <svl/eitem.hxx>
52 #include <svl/macitem.hxx>
53 #include <editeng/lrspitem.hxx>
54 #include <editeng/ulspitem.hxx>
55 #include <editeng/colritem.hxx>
56 #include <editeng/tstpitem.hxx>
57 #include <editeng/brshitem.hxx>
58 #include <editeng/svxacorr.hxx>
59 #include <svl/cjkoptions.hxx>
60 #include <svl/ctloptions.hxx>
61 #include <IDocumentSettingAccess.hxx>
62 #include <charfmt.hxx>
63 #include <editeng/fontitem.hxx>
64 #include <svx/SmartTagItem.hxx>
65 #include <svx/dialmgr.hxx>
66 #include <fmtinfmt.hxx>
67 #include <swwait.hxx>
68 #include <wrtsh.hxx>
69 #include <wview.hxx>
70 #include <swmodule.hxx>
71 #include <viewopt.hxx>
72 #include <uitool.hxx>
73 #include <swevent.hxx>
74 #include <fmthdft.hxx>
75 #include <pagedesc.hxx>
76 #include <textsh.hxx>
77 #include <IMark.hxx>
78 #include <swdtflvr.hxx>
79 #include <docstat.hxx>
80 #include <outline.hxx>
81 #include <tablemgr.hxx>
82 #include <swundo.hxx>       // fuer Undo-IDs
83 #include <reffld.hxx>
84 #include <docsh.hxx>
85 #include <mdiexp.hxx>
86 #include <inputwin.hxx>
87 #include <pardlg.hxx>
88 #include <frmatr.hxx>
89 #include <fmtcol.hxx>
90 #include <cellatr.hxx>
91 #include <edtwin.hxx>
92 #include <redlndlg.hxx>
93 #include "fldmgr.hxx"
94 
95 #include <globals.hrc>
96 #include <shells.hrc>
97 #include <app.hrc>
98 #include <web.hrc>
99 #include "paratr.hxx"
100 #include <crsskip.hxx>
101 #include <docstat.hxx>
102 #include <vcl/svapp.hxx>
103 #include <sfx2/app.hxx>
104 #include <breakit.hxx>
105 
106 #include <SwSmartTagMgr.hxx>
107 
108 #include <editeng/acorrcfg.hxx>
109 #include "swabstdlg.hxx"
110 #include "misc.hrc"
111 #include "chrdlg.hrc"
112 #include <IDocumentStatistics.hxx>
113 
114 #include <sfx2/sfxdlg.hxx>
115 #include <svl/languageoptions.hxx>
116 #include <unotools/lingucfg.hxx>
117 #include <com/sun/star/beans/XPropertySet.hpp>
118 #include <com/sun/star/util/XChangesBatch.hpp>
119 #include <com/sun/star/uno/Any.hxx>
120 #include <editeng/unolingu.hxx>
121 #include <unotools/syslocaleoptions.hxx>
122 #include <doc.hxx>
123 #include <view.hxx>
124 #include <ndtxt.hxx>
125 #include <pam.hxx>
126 #include <sfx2/objface.hxx>
127 #include <langhelper.hxx>
128 
129 #ifndef _NBDTMGFACT_HXX
130 #include <svx/nbdtmgfact.hxx>
131 #endif
132 #ifndef _NBDTMG_HXX
133 #include <svx/nbdtmg.hxx>
134 #endif
135 
136 
137 #include <numrule.hxx>
138 
139 
140 using namespace ::com::sun::star;
141 using namespace svx::sidebar;
142 
143 
144 void lcl_CharDialog( SwWrtShell &rWrtSh, sal_Bool bUseDialog, sal_uInt16 nSlot,const SfxItemSet *pArgs, SfxRequest *pReq )
145 {
146     FieldUnit eMetric = ::GetDfltMetric(0 != PTR_CAST(SwWebView, &rWrtSh.GetView()));
147     SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< sal_uInt16 >(eMetric)));
148     SfxItemSet aCoreSet( rWrtSh.GetView().GetPool(),
149                         RES_CHRATR_BEGIN,      RES_CHRATR_END-1,
150                         RES_TXTATR_INETFMT,    RES_TXTATR_INETFMT,
151                         RES_BACKGROUND,        RES_BACKGROUND,
152                         FN_PARAM_SELECTION,    FN_PARAM_SELECTION,
153                         SID_HTML_MODE,         SID_HTML_MODE,
154                         SID_ATTR_CHAR_WIDTH_FIT_TO_LINE,   SID_ATTR_CHAR_WIDTH_FIT_TO_LINE,
155                         0 );
156     rWrtSh.GetCurAttr( aCoreSet );
157     sal_Bool bSel = rWrtSh.HasSelection();
158     sal_Bool bSelectionPut = sal_False;
159     if(bSel || rWrtSh.IsInWord())
160     {
161         if(!bSel)
162         {
163             rWrtSh.StartAction();
164             rWrtSh.Push();
165             if(!rWrtSh.SelectTxtAttr( RES_TXTATR_INETFMT ))
166                 rWrtSh.SelWrd();
167         }
168         aCoreSet.Put(SfxStringItem(FN_PARAM_SELECTION, rWrtSh.GetSelTxt()));
169         bSelectionPut = sal_True;
170         if(!bSel)
171         {
172             rWrtSh.Pop(sal_False);
173             rWrtSh.EndAction();
174         }
175     }
176         aCoreSet.Put( SfxUInt16Item( SID_ATTR_CHAR_WIDTH_FIT_TO_LINE,
177                     rWrtSh.GetScalingOfSelectedText() ) );
178     // Das CHRATR_BACKGROUND-Attribut wird fuer den Dialog in
179     // ein RES_BACKGROUND verwandelt und wieder zurueck ...
180     const SfxPoolItem *pTmpBrush;
181     if( SFX_ITEM_SET == aCoreSet.GetItemState( RES_CHRATR_BACKGROUND, sal_True, &pTmpBrush ) )
182     {
183         SvxBrushItem aTmpBrush( *((SvxBrushItem*)pTmpBrush) );
184         aTmpBrush.SetWhich( RES_BACKGROUND );
185         aCoreSet.Put( aTmpBrush );
186     }
187 
188     aCoreSet.Put(SfxUInt16Item(SID_HTML_MODE, ::GetHtmlMode(rWrtSh.GetView().GetDocShell())));
189     SfxAbstractTabDialog* pDlg = NULL;
190     if ( bUseDialog && GetActiveView() )
191     {
192         SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
193         DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
194 
195         pDlg = pFact->CreateSwCharDlg( rWrtSh.GetView().GetWindow(), rWrtSh.GetView(), aCoreSet, DLG_CHAR );
196         DBG_ASSERT(pDlg, "Dialogdiet fail!");
197         if( FN_INSERT_HYPERLINK == nSlot )
198             pDlg->SetCurPageId(TP_CHAR_URL);
199     }
200     if (nSlot == SID_CHAR_DLG_EFFECT)
201     {
202         pDlg->SetCurPageId(TP_CHAR_EXT);
203     }
204 
205     const SfxItemSet* pSet = NULL;
206     if ( !bUseDialog )
207         pSet = pArgs;
208     else if ( NULL != pDlg && pDlg->Execute() == RET_OK ) /* #110771# pDlg can be NULL */
209     {
210         pSet = pDlg->GetOutputItemSet();
211     }
212 
213     if ( pSet)
214     {
215         SfxItemSet aTmpSet( *pSet );
216         if( SFX_ITEM_SET == aTmpSet.GetItemState( RES_BACKGROUND, sal_False, &pTmpBrush ) )
217         {
218             SvxBrushItem aTmpBrush( *((SvxBrushItem*)pTmpBrush) );
219             aTmpBrush.SetWhich( RES_CHRATR_BACKGROUND );
220             aTmpSet.Put( aTmpBrush );
221         }
222 
223         aTmpSet.ClearItem( RES_BACKGROUND );
224 
225         const SfxPoolItem* pSelectionItem;
226         sal_Bool bInsert = sal_False;
227         xub_StrLen nInsert = 0;
228 
229         // aus ungeklaerter Ursache ist das alte Item wieder im Set
230         if( !bSelectionPut && SFX_ITEM_SET == aTmpSet.GetItemState(FN_PARAM_SELECTION, sal_False, &pSelectionItem) )
231         {
232             String sInsert = ((const SfxStringItem*)pSelectionItem)->GetValue();
233             bInsert = sInsert.Len() != 0;
234             if(bInsert)
235             {
236                 nInsert = sInsert.Len();
237                 rWrtSh.StartAction();
238                 rWrtSh.Insert( sInsert );
239                 rWrtSh.SetMark();
240                 rWrtSh.ExtendSelection(sal_False, sInsert.Len());
241                 SfxRequest aReq( rWrtSh.GetView().GetViewFrame(), FN_INSERT_STRING );
242                 aReq.AppendItem( SfxStringItem( FN_INSERT_STRING, sInsert ) );
243                 aReq.Done();
244                 SfxRequest aReq1( rWrtSh.GetView().GetViewFrame(), FN_CHAR_LEFT );
245                 aReq1.AppendItem( SfxInt16Item(FN_PARAM_MOVE_COUNT, nInsert) );
246                 aReq1.AppendItem( SfxBoolItem(FN_PARAM_MOVE_SELECTION, sal_True) );
247                 aReq1.Done();
248             }
249         }
250         aTmpSet.ClearItem(FN_PARAM_SELECTION);
251 
252         SwTxtFmtColl* pColl = rWrtSh.GetCurTxtFmtColl();
253         if(bSel && rWrtSh.IsSelFullPara() && pColl && pColl->IsAutoUpdateFmt())
254         {
255             rWrtSh.AutoUpdatePara(pColl, aTmpSet);
256         }
257         else
258             rWrtSh.SetAttr( aTmpSet );
259         if (pReq)
260             pReq->Done(aTmpSet);
261         if(bInsert)
262         {
263             SfxRequest aReq1( rWrtSh.GetView().GetViewFrame(), FN_CHAR_RIGHT );
264             aReq1.AppendItem( SfxInt16Item(FN_PARAM_MOVE_COUNT, nInsert) );
265             aReq1.AppendItem( SfxBoolItem(FN_PARAM_MOVE_SELECTION, sal_False) );
266             aReq1.Done();
267             rWrtSh.SwapPam();
268             rWrtSh.ClearMark();
269             rWrtSh.DontExpandFmt();
270             rWrtSh.EndAction();
271         }
272     }
273 
274     delete pDlg;
275 }
276 
277 /*--------------------------------------------------------------------
278     Beschreibung:
279  --------------------------------------------------------------------*/
280 
281 short lcl_AskRedlineMode(Window *pWin)
282 {
283     MessBox aQBox( pWin, 0,
284                     String( SW_RES( STR_REDLINE_TITLE ) ),
285                     String( SW_RES( STR_REDLINE_MSG ) ) );
286     aQBox.SetImage( QueryBox::GetStandardImage() );
287     sal_uInt16 nBtnFlags = BUTTONDIALOG_DEFBUTTON |
288                         BUTTONDIALOG_OKBUTTON |
289                         BUTTONDIALOG_FOCUSBUTTON;
290 
291     aQBox.AddButton(String(SW_RES(STR_REDLINE_ACCEPT_ALL)), RET_OK, nBtnFlags);
292     aQBox.GetPushButton( RET_OK )->SetHelpId(HID_AUTOFORMAT_ACCEPT);
293     aQBox.AddButton(String(SW_RES(STR_REDLINE_REJECT_ALL)), RET_CANCEL, BUTTONDIALOG_CANCELBUTTON);
294     aQBox.GetPushButton( RET_CANCEL )->SetHelpId(HID_AUTOFORMAT_REJECT  );
295     aQBox.AddButton(String(SW_RES(STR_REDLINE_EDIT)), 2, 0);
296     aQBox.GetPushButton( 2 )->SetHelpId(HID_AUTOFORMAT_EDIT_CHG);
297     aQBox.SetButtonHelpText( RET_OK, aEmptyStr );
298 
299     return aQBox.Execute();
300 }
301 
302 void SwTextShell::Execute(SfxRequest &rReq)
303 {
304     sal_Bool bUseDialog = sal_True;
305     const SfxItemSet *pArgs = rReq.GetArgs();
306     SwWrtShell& rWrtSh = GetShell();
307     const SfxPoolItem* pItem = 0;
308     sal_uInt16 nSlot = rReq.GetSlot();
309     if(pArgs)
310         pArgs->GetItemState(GetPool().GetWhich(nSlot), sal_False, &pItem);
311     switch( nSlot )
312     {
313         case SID_LANGUAGE_STATUS:
314         {
315             // get the language
316             String aNewLangTxt;
317             SFX_REQUEST_ARG( rReq, pItem2, SfxStringItem, SID_LANGUAGE_STATUS , sal_False );
318             if (pItem2)
319                 aNewLangTxt = pItem2->GetValue();
320 
321             //!! Remember the view frame right now...
322             //!! (call to GetView().GetViewFrame() will break if the
323             //!! SwTextShell got destroyed meanwhile.)
324             SfxViewFrame *pViewFrame = GetView().GetViewFrame();
325 
326             if (aNewLangTxt.EqualsAscii( "*" ))
327             {
328                 // open the dialog "Tools/Options/Language Settings - Language"
329                 // to set the documents default language
330                 SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create();
331                 if (pFact)
332                 {
333                     VclAbstractDialog* pDlg = pFact->CreateVclDialog( GetView().GetWindow(), SID_LANGUAGE_OPTIONS );
334                     pDlg->Execute();
335                     delete pDlg;
336                 }
337             }
338             else
339             {
340                 //!! We have to use StartAction / EndAction bracketing in
341                 //!! order to prevent possible destruction of the SwTextShell
342                 //!! due to the selection changes coming below.
343                 rWrtSh.StartAction();
344                 // prevent view from jumping because of (temporary) selection changes
345                 rWrtSh.LockView( sal_True );
346                 // save selection for later restoration
347                 rWrtSh.Push();
348 
349                 // setting the new language...
350                 if (aNewLangTxt.Len() > 0)
351                 {
352                     const String aSelectionLangPrefix( String::CreateFromAscii("Current_") );
353                     const String aParagraphLangPrefix( String::CreateFromAscii("Paragraph_") );
354                     const String aDocumentLangPrefix( String::CreateFromAscii("Default_") );
355                     const String aStrNone( String::CreateFromAscii("LANGUAGE_NONE") );
356                     const String aStrResetLangs( String::CreateFromAscii("RESET_LANGUAGES") );
357 
358                     SfxItemSet aCoreSet( GetPool(),
359                             RES_CHRATR_LANGUAGE,        RES_CHRATR_LANGUAGE,
360                             RES_CHRATR_CJK_LANGUAGE,    RES_CHRATR_CJK_LANGUAGE,
361                             RES_CHRATR_CTL_LANGUAGE,    RES_CHRATR_CTL_LANGUAGE,
362                             0 );
363 
364                     xub_StrLen nPos = 0;
365                     bool bForSelection = true;
366                     bool bForParagraph = false;
367                     if (STRING_NOTFOUND != (nPos = aNewLangTxt.Search( aSelectionLangPrefix, 0 )))
368                     {
369                         // ... for the current selection
370                         aNewLangTxt = aNewLangTxt.Erase( nPos, aSelectionLangPrefix.Len() );
371                         bForSelection = true;
372                     }
373                     else if (STRING_NOTFOUND != (nPos = aNewLangTxt.Search( aParagraphLangPrefix , 0 )))
374                     {
375                         // ... for the current paragraph language
376                         aNewLangTxt = aNewLangTxt.Erase( nPos, aParagraphLangPrefix.Len() );
377                         bForSelection = true;
378                         bForParagraph = true;
379                     }
380                     else if (STRING_NOTFOUND != (nPos = aNewLangTxt.Search( aDocumentLangPrefix , 0 )))
381                     {
382                         // ... as default document language
383                         aNewLangTxt = aNewLangTxt.Erase( nPos, aDocumentLangPrefix.Len() );
384                         bForSelection = false;
385                     }
386 
387                     if (bForParagraph)
388                         SwLangHelper::SelectCurrentPara( rWrtSh );
389 
390                     if (!bForSelection) // document language to be changed...
391                     {
392                         rWrtSh.SelAll();
393                         rWrtSh.ExtendedSelectAll();
394                     }
395                     if (aNewLangTxt == aStrNone)
396                         SwLangHelper::SetLanguage_None( rWrtSh, bForSelection, aCoreSet );
397                     else if (aNewLangTxt == aStrResetLangs)
398                         SwLangHelper::ResetLanguages( rWrtSh, bForSelection );
399                     else
400                         SwLangHelper::SetLanguage( rWrtSh, aNewLangTxt, bForSelection, aCoreSet );
401                 }
402 
403                 // restore selection...
404                 rWrtSh.Pop( sal_False );
405 
406                 rWrtSh.LockView( sal_False );
407                 rWrtSh.EndAction();
408             }
409 
410             // invalidate slot to get the new language displayed
411             pViewFrame->GetBindings().Invalidate( nSlot );
412 
413             rReq.Done();
414             break;
415         }
416 
417         case SID_THES:
418         {
419             // replace word/selection with text from selected sub menu entry
420             String aReplaceText;
421             SFX_REQUEST_ARG( rReq, pItem2, SfxStringItem, SID_THES , sal_False );
422             if (pItem2)
423                 aReplaceText = pItem2->GetValue();
424             if (aReplaceText.Len() > 0)
425             {
426                 SwView &rView2 = rWrtSh.GetView();
427                 const bool bSelection = rWrtSh.HasSelection();
428                 const String aLookUpText = rView2.GetThesaurusLookUpText( bSelection );
429                 rView2.InsertThesaurusSynonym( aReplaceText, aLookUpText, bSelection );
430             }
431         }
432         break;
433 
434         case SID_CHARMAP:
435         {
436             InsertSymbol( rReq );
437         }
438         break;
439         case FN_INSERT_FOOTNOTE:
440         case FN_INSERT_ENDNOTE:
441         {
442             String aStr;
443             SFX_REQUEST_ARG( rReq, pFont, SfxStringItem, FN_PARAM_1 , sal_False );
444 //            SFX_REQUEST_ARG( rReq, pCharset, SfxInt16Item, FN_PARAM_2 , sal_False );
445             SFX_REQUEST_ARG( rReq, pNameItem, SfxStringItem, nSlot , sal_False );
446             if ( pNameItem )
447                 aStr = pNameItem->GetValue();
448             sal_Bool bFont = pFont && pFont->GetValue().Len();
449             rWrtSh.StartUndo( UNDO_UI_INSERT_FOOTNOTE );
450             rWrtSh.InsertFootnote( aStr, nSlot == FN_INSERT_ENDNOTE, !bFont );
451             if ( bFont )
452             {
453                 rWrtSh.Left( CRSR_SKIP_CHARS, sal_True, 1, sal_False );
454                 SfxItemSet aSet( rWrtSh.GetAttrPool(), RES_CHRATR_FONT, RES_CHRATR_FONT );
455                 rWrtSh.GetCurAttr( aSet );
456                 SvxFontItem &rFont = (SvxFontItem &) aSet.Get( RES_CHRATR_FONT );
457                 SvxFontItem aFont( rFont.GetFamily(), pFont->GetValue(),
458                                     rFont.GetStyleName(), rFont.GetPitch(), RTL_TEXTENCODING_DONTKNOW, RES_CHRATR_FONT );
459                                     //pCharset ? (CharSet) pCharset->GetValue() : RTL_TEXTENCODING_DONTKNOW );
460                 rWrtSh.SetAttr( aSet, nsSetAttrMode::SETATTR_DONTEXPAND );
461                 rWrtSh.ResetSelect(0, sal_False);
462                 rWrtSh.EndSelect();
463                 rWrtSh.GotoFtnTxt();
464             }
465             rWrtSh.EndUndo( UNDO_UI_INSERT_FOOTNOTE );
466             rReq.Done();
467         }
468         break;
469         case FN_INSERT_FOOTNOTE_DLG:
470         {
471             SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
472             DBG_ASSERT(pFact, "Dialogdiet fail!");
473             AbstractInsFootNoteDlg* pDlg = pFact->CreateInsFootNoteDlg( DLG_INS_FOOTNOTE,
474                                                         GetView().GetWindow(), rWrtSh, sal_False );
475             DBG_ASSERT(pDlg, "Dialogdiet fail!");
476             pDlg->SetHelpId(GetStaticInterface()->GetSlot(nSlot)->GetCommand());
477             if ( pDlg->Execute() == RET_OK )
478             {
479                 sal_uInt16 nId = pDlg->IsEndNote() ? FN_INSERT_ENDNOTE : FN_INSERT_FOOTNOTE;
480                 SfxRequest aReq( GetView().GetViewFrame(), nId );
481                 if ( pDlg->GetStr().Len() )
482                     aReq.AppendItem( SfxStringItem( nId, pDlg->GetStr() ) );
483                 if ( pDlg->GetFontName().Len() )
484                     aReq.AppendItem( SfxStringItem( FN_PARAM_1, pDlg->GetFontName() ) );
485                 //aReq.AppendItem( SfxStringItem( FN_PARAM_2, pDlg->GetCharSet() ) );
486                 ExecuteSlot( aReq );
487             }
488 
489             rReq.Ignore();
490             delete pDlg;
491         }
492         break;
493         case FN_FORMAT_FOOTNOTE_DLG:
494         {
495             SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
496             DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
497 
498             VclAbstractDialog* pDlg = pFact->CreateSwFootNoteOptionDlg( GetView().GetWindow(), rWrtSh, DLG_DOC_FOOTNOTE );
499             DBG_ASSERT(pDlg, "Dialogdiet fail!");
500             pDlg->Execute();
501             delete pDlg;
502             break;
503         }
504         case SID_INSERTDOC:
505         {
506             GetView().ExecuteInsertDoc( rReq, pItem );
507             break;
508         }
509         case FN_FORMAT_RESET:
510         {
511             // #i78856, reset all attributes but not the language attributes
512             // (for this build an array of all relevant attributes and
513             // remove the languages from that)
514             SvUShortsSort aAttribs;
515 
516             sal_uInt16 __FAR_DATA aResetableSetRange[] = {
517                 RES_FRMATR_BEGIN, RES_FRMATR_END-1,
518                 RES_CHRATR_BEGIN, RES_CHRATR_LANGUAGE - 1,
519                 RES_CHRATR_LANGUAGE + 1, RES_CHRATR_CJK_LANGUAGE - 1,
520                 RES_CHRATR_CJK_LANGUAGE + 1, RES_CHRATR_CTL_LANGUAGE - 1,
521                 RES_CHRATR_CTL_LANGUAGE + 1, RES_CHRATR_END-1,
522                 RES_PARATR_BEGIN, RES_PARATR_END-1,
523                 RES_TXTATR_INETFMT, RES_TXTATR_INETFMT,
524                 RES_TXTATR_CHARFMT, RES_TXTATR_CHARFMT,
525                 RES_TXTATR_CJK_RUBY, RES_TXTATR_CJK_RUBY,
526                 RES_TXTATR_UNKNOWN_CONTAINER, RES_TXTATR_UNKNOWN_CONTAINER,
527                 RES_UNKNOWNATR_BEGIN, RES_UNKNOWNATR_END-1,
528                 0
529             };
530             sal_uInt16 __FAR_DATA *pUShorts = aResetableSetRange;
531             while (*pUShorts)
532             {
533                 sal_uInt16 nL = pUShorts[1] - pUShorts[0] + 1;
534                 sal_uInt16 nE = pUShorts[0];
535                 for (sal_uInt16 i = 0; i < nL; ++i)
536                     aAttribs.Insert( nE++ );
537                 pUShorts += 2;
538             }
539 
540             rWrtSh.ResetAttr( &aAttribs );
541             rReq.Done();
542             break;
543         }
544         case FN_INSERT_BREAK_DLG:
545         {
546             sal_uInt16 nKind=0, nPageNumber=0;
547             String aTemplateName;
548             if ( pItem )
549             {
550                 nKind = ((SfxInt16Item*)pItem)->GetValue();
551                 SFX_REQUEST_ARG( rReq, pTemplate, SfxStringItem, FN_PARAM_1 , sal_False );
552                 SFX_REQUEST_ARG( rReq, pNumber, SfxUInt16Item, FN_PARAM_2 , sal_False );
553                 if ( pTemplate )
554                     aTemplateName = pTemplate->GetValue();
555                 if ( pNumber )
556                     nPageNumber = pNumber->GetValue();
557             }
558             else
559             {
560                 SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
561                 DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
562 
563                 AbstractSwBreakDlg* pDlg = pFact->CreateSwBreakDlg( GetView().GetWindow(), rWrtSh, DLG_BREAK );
564                 DBG_ASSERT(pDlg, "Dialogdiet fail!");
565                 if ( pDlg->Execute() == RET_OK )
566                 {
567                     nKind = pDlg->GetKind();
568                     aTemplateName = pDlg->GetTemplateName();
569                     nPageNumber = pDlg->GetPageNumber();
570                     rReq.AppendItem( SfxInt16Item( FN_INSERT_BREAK_DLG, nKind ) );
571                     rReq.AppendItem( SfxUInt16Item( FN_PARAM_2, nPageNumber ) );
572                     rReq.AppendItem( SfxStringItem( FN_PARAM_1, aTemplateName ) );
573                     rReq.Done();
574                 }
575                 else
576                     rReq.Ignore();
577                 delete pDlg;
578             }
579 
580             switch ( nKind )
581             {
582                 case 1 :
583                     rWrtSh.InsertLineBreak(); break;
584                 case 2 :
585                     rWrtSh.InsertColumnBreak(); break;
586                 case 3 :
587                 {
588                     rWrtSh.StartAllAction();
589                     if( aTemplateName.Len() )
590                         rWrtSh.InsertPageBreak( &aTemplateName, nPageNumber );
591                     else
592                         rWrtSh.InsertPageBreak();
593                     rWrtSh.EndAllAction();
594                 }
595             }
596 
597             break;
598         }
599         case FN_INSERT_BOOKMARK:
600         {
601             if ( pItem )
602             {
603                 ::rtl::OUString sName = ((SfxStringItem*)pItem)->GetValue();
604                 rWrtSh.SetBookmark( KeyCode(), sName, aEmptyStr );
605             }
606             else
607             {
608                 SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
609                 DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
610 
611                 VclAbstractDialog* pDlg = pFact->CreateSwInsertBookmarkDlg( GetView().GetWindow(), rWrtSh, rReq, DLG_INSERT_BOOKMARK );
612                 DBG_ASSERT(pDlg, "Dialogdiet fail!");
613                 pDlg->Execute();
614                 delete pDlg;
615             }
616 
617             break;
618         }
619         case FN_DELETE_BOOKMARK:
620         {
621             if ( pItem )
622             {
623                 IDocumentMarkAccess* const pMarkAccess = rWrtSh.getIDocumentMarkAccess();
624                 pMarkAccess->deleteMark( pMarkAccess->findMark(((SfxStringItem*)pItem)->GetValue()) );
625             }
626             break;
627         }
628         case FN_AUTOFORMAT_REDLINE_APPLY:
629         {
630             SvxSwAutoFmtFlags aFlags(SvxAutoCorrCfg::Get()->GetAutoCorrect()->GetSwFlags());
631             // das muss fuer die Nachbearbeitung immer sal_False sein
632             aFlags.bAFmtByInput = sal_False;
633             aFlags.bWithRedlining = sal_True;
634             rWrtSh.AutoFormat( &aFlags );
635             aFlags.bWithRedlining = sal_False;
636 
637             SfxViewFrame* pVFrame = GetView().GetViewFrame();
638             if (pVFrame->HasChildWindow(FN_REDLINE_ACCEPT))
639                 pVFrame->ToggleChildWindow(FN_REDLINE_ACCEPT);
640 
641             SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
642             DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
643 
644             AbstractSwModalRedlineAcceptDlg* pDlg = pFact->CreateSwModalRedlineAcceptDlg( &GetView().GetEditWin(), DLG_MOD_REDLINE_ACCEPT );
645             DBG_ASSERT(pDlg, "Dialogdiet fail!");
646 
647             switch (lcl_AskRedlineMode(&GetView().GetEditWin()))
648             {
649                 case RET_OK:
650                 {
651                     pDlg->AcceptAll(sal_True);
652                     SfxRequest aReq( pVFrame, FN_AUTOFORMAT_APPLY );
653                     aReq.Done();
654                     rReq.Ignore();
655                     break;
656                 }
657 
658                 case RET_CANCEL:
659                     pDlg->AcceptAll(sal_False);
660                     rReq.Ignore();
661                     break;
662 
663                 case 2:
664                     pDlg->Execute();
665                     rReq.Done();
666                     break;
667             }
668             delete pDlg;
669         }
670         break;
671 
672         case FN_AUTOFORMAT_APPLY:
673         {
674             SvxSwAutoFmtFlags aFlags(SvxAutoCorrCfg::Get()->GetAutoCorrect()->GetSwFlags());
675             // das muss fuer die Nachbearbeitung immer sal_False sein
676             aFlags.bAFmtByInput = sal_False;
677             rWrtSh.AutoFormat( &aFlags );
678             rReq.Done();
679         }
680         break;
681         case FN_AUTOFORMAT_AUTO:
682         {
683             SvxAutoCorrCfg* pACfg = SvxAutoCorrCfg::Get();
684             sal_Bool bSet = pItem ? ((const SfxBoolItem*)pItem)->GetValue() : !pACfg->IsAutoFmtByInput();
685             if( bSet != pACfg->IsAutoFmtByInput() )
686             {
687                 pACfg->SetAutoFmtByInput( bSet );
688                 GetView().GetViewFrame()->GetBindings().Invalidate( nSlot );
689                 if ( !pItem )
690                     rReq.AppendItem( SfxBoolItem( GetPool().GetWhich(nSlot), bSet ) );
691                 rReq.Done();
692             }
693         }
694         break;
695         case FN_AUTO_CORRECT:
696         {
697             // erstmal auf Blank defaulten
698             sal_Unicode cChar = ' ';
699             rWrtSh.AutoCorrect( *SvxAutoCorrCfg::Get()->GetAutoCorrect(), cChar );
700             rReq.Done();
701         }
702         break;
703         case FN_TABLE_SORT_DIALOG:
704         case FN_SORTING_DLG:
705         {
706             SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
707             DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
708 
709             VclAbstractDialog* pDlg = pFact->CreateVclAbstractDialog( GetView().GetWindow(), rWrtSh, DLG_SORTING );
710             DBG_ASSERT(pDlg, "Dialogdiet fail!");
711             pDlg->Execute();
712             delete pDlg;
713             rReq.Done();
714         }
715         break;
716         case FN_NUMBERING_OUTLINE_DLG:
717         {
718             SfxItemSet aTmp(GetPool(), FN_PARAM_1, FN_PARAM_1);
719             SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
720             DBG_ASSERT(pFact, "Dialogdiet fail!");
721             SfxAbstractTabDialog* pDlg = pFact->CreateSwTabDialog( DLG_TAB_OUTLINE,
722                                                         GetView().GetWindow(), &aTmp, rWrtSh);
723             DBG_ASSERT(pDlg, "Dialogdiet fail!");
724             pDlg->Execute();
725             delete pDlg;
726             rReq.Done();
727         }
728             break;
729         case FN_CALCULATE:
730             {
731                 SwTransferable* pTransfer = new SwTransferable( rWrtSh );
732 /*??*/          uno::Reference<
733                     datatransfer::XTransferable > xRef(
734                                                     pTransfer );
735                 pTransfer->CalculateAndCopy();
736                 rReq.Done();
737             }
738             break;
739         case FN_GOTO_REFERENCE:
740         {
741             SwField *pFld = rWrtSh.GetCurFld();
742             if(pFld && pFld->GetTypeId() == TYP_GETREFFLD)
743             {
744                 rWrtSh.StartAllAction();
745                 rWrtSh.SwCrsrShell::GotoRefMark( ((SwGetRefField*)pFld)->GetSetRefName(),
746                                     ((SwGetRefField*)pFld)->GetSubType(),
747                                     ((SwGetRefField*)pFld)->GetSeqNo() );
748                 rWrtSh.EndAllAction();
749                 rReq.Done();
750             }
751         }
752             break;
753         case FN_EDIT_FORMULA:
754         {
755             const sal_uInt16 nId = SwInputChild::GetChildWindowId();
756             SfxViewFrame* pVFrame = GetView().GetViewFrame();
757             if(pItem)
758             {
759                 //if the ChildWindow is active it has to be removed
760                 if( pVFrame->HasChildWindow( nId ) )
761                 {
762                     pVFrame->ToggleChildWindow( nId );
763                     pVFrame->GetBindings().InvalidateAll( sal_True );
764                 }
765 
766                 String sFormula(((const SfxStringItem*)pItem)->GetValue());
767                 SwFldMgr aFldMgr;
768                 rWrtSh.StartAllAction();
769                 sal_Bool bDelSel;
770                 if( 0 != (bDelSel = rWrtSh.HasSelection()) )
771                 {
772                     rWrtSh.StartUndo( UNDO_START );
773                     rWrtSh.DelRight();
774                 }
775                 else
776                 {
777                     rWrtSh.EnterStdMode();
778                 }
779 
780                 if( !bDelSel && aFldMgr.GetCurFld() && TYP_FORMELFLD == aFldMgr.GetCurTypeId() )
781                     aFldMgr.UpdateCurFld( aFldMgr.GetCurFld()->GetFormat(), aEmptyStr, sFormula );
782                 else if( sFormula.Len() )
783                 {
784                     if( rWrtSh.IsCrsrInTbl() )
785                     {
786                         SfxItemSet aSet( rWrtSh.GetAttrPool(), RES_BOXATR_FORMULA, RES_BOXATR_FORMULA );
787                         aSet.Put( SwTblBoxFormula( sFormula ));
788                         rWrtSh.SetTblBoxFormulaAttrs( aSet );
789                         rWrtSh.UpdateTable();
790                     }
791                     else
792                     {
793                         SvNumberFormatter* pFormatter = rWrtSh.GetNumberFormatter();
794                         sal_uLong nSysNumFmt = pFormatter->GetFormatIndex( NF_NUMBER_STANDARD, LANGUAGE_SYSTEM);
795                         SwInsertFld_Data aData(TYP_FORMELFLD, nsSwGetSetExpType::GSE_FORMULA, aEmptyStr, sFormula, nSysNumFmt);
796                         aFldMgr.InsertFld(aData);
797                     }
798                 }
799 
800                 if( bDelSel )
801                     rWrtSh.EndUndo( UNDO_END );
802                 rWrtSh.EndAllAction();
803                 rReq.Done();
804             }
805             else
806             {
807                 rWrtSh.EndAllTblBoxEdit();
808                 pVFrame->ToggleChildWindow( nId );
809                 if( !pVFrame->HasChildWindow( nId ) )
810                     pVFrame->GetBindings().InvalidateAll( sal_True );
811                 rReq.Ignore();
812             }
813         }
814 
815         break;
816         case FN_TABLE_UNSET_READ_ONLY:
817         {
818             rWrtSh.UnProtectTbls();
819         }
820         break;
821         case FN_EDIT_HYPERLINK:
822             GetView().GetViewFrame()->ToggleChildWindow(SID_HYPERLINK_DIALOG);
823         break;
824         case FN_REMOVE_HYPERLINK:
825         {
826             sal_Bool bSel = rWrtSh.HasSelection();
827             if(!bSel)
828             {
829                 rWrtSh.StartAction();
830                 rWrtSh.Push();
831                 if(!rWrtSh.SelectTxtAttr( RES_TXTATR_INETFMT ))
832                     rWrtSh.SelWrd();
833             }
834             //now remove the attribute
835             SvUShortsSort aAttribs;
836             aAttribs.Insert( RES_TXTATR_INETFMT );
837             rWrtSh.ResetAttr( &aAttribs );
838             if(!bSel)
839             {
840                 rWrtSh.Pop(sal_False);
841                 rWrtSh.EndAction();
842             }
843         }
844         break;
845         case SID_ATTR_BRUSH_CHAR :
846         case SID_ATTR_CHAR_SCALEWIDTH :
847         case SID_ATTR_CHAR_ROTATED :
848         case FN_TXTATR_INET :
849         case FN_INSERT_HYPERLINK:
850         {
851             sal_uInt16 nWhich = GetPool().GetWhich( nSlot );
852             if ( pArgs && pArgs->GetItemState( nWhich ) == SFX_ITEM_SET )
853                 bUseDialog = sal_False;
854             // intentionally no break
855         }
856         case SID_CHAR_DLG:
857         case SID_CHAR_DLG_EFFECT:
858         {
859             lcl_CharDialog( rWrtSh, bUseDialog, nSlot, pArgs, &rReq );
860         }
861         break;
862         case SID_CHAR_DLG_FOR_PARAGRAPH:
863         {
864             rWrtSh.Push();          //save current cursor
865             SwLangHelper::SelectCurrentPara( rWrtSh );
866             lcl_CharDialog( rWrtSh, bUseDialog, nSlot, pArgs, &rReq );
867             rWrtSh.Pop( sal_False );    //restore old cursor
868         }
869         break;
870         case SID_ATTR_LRSPACE :
871         case SID_ATTR_ULSPACE :
872         case SID_ATTR_BRUSH :
873         case SID_PARA_VERTALIGN :
874         case SID_ATTR_PARA_NUMRULE :
875         case SID_ATTR_PARA_REGISTER :
876         case SID_ATTR_PARA_PAGENUM :
877         case FN_FORMAT_LINENUMBER :
878         case FN_NUMBER_NEWSTART :
879         case FN_NUMBER_NEWSTART_AT :
880         case FN_FORMAT_DROPCAPS :
881         case FN_DROP_TEXT:
882         {
883             sal_uInt16 nWhich = GetPool().GetWhich( nSlot );
884             if ( pArgs && pArgs->GetItemState( nWhich ) == SFX_ITEM_SET )
885                 bUseDialog = sal_False;
886             // intentionally no break
887 
888         }
889         case SID_PARA_DLG:
890         {
891             FieldUnit eMetric = ::GetDfltMetric(0 != PTR_CAST(SwWebView, &GetView()));
892             SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< sal_uInt16 >(eMetric)));
893             SfxItemSet aCoreSet( GetPool(),
894                             RES_PARATR_BEGIN,           RES_PARATR_END - 1,
895                             // --> OD 2008-02-25 #refactorlists#
896                             RES_PARATR_LIST_BEGIN,      RES_PARATR_LIST_END - 1,
897                             // <--
898                             RES_FRMATR_BEGIN,           RES_FRMATR_END - 1,
899                             SID_ATTR_TABSTOP_POS,       SID_ATTR_TABSTOP_POS,
900                             SID_ATTR_TABSTOP_DEFAULTS,  SID_ATTR_TABSTOP_DEFAULTS,
901                             SID_ATTR_TABSTOP_OFFSET,    SID_ATTR_TABSTOP_OFFSET,
902                             SID_ATTR_BORDER_INNER,      SID_ATTR_BORDER_INNER,
903                             SID_ATTR_PARA_MODEL,        SID_ATTR_PARA_KEEP,
904                             SID_ATTR_PARA_PAGENUM,      SID_ATTR_PARA_PAGENUM,
905                             SID_HTML_MODE,              SID_HTML_MODE,
906                             FN_PARAM_1,                 FN_PARAM_1,
907                             FN_NUMBER_NEWSTART,         FN_NUMBER_NEWSTART_AT,
908                             FN_DROP_TEXT,               FN_DROP_CHAR_STYLE_NAME,
909                             0);
910             // --> OD 2008-01-16 #newlistlevelattrs#
911             // get also the list level indent values merged as LR-SPACE item, if needed.
912             rWrtSh.GetCurAttr( aCoreSet, true );
913             // <--
914             aCoreSet.Put(SfxUInt16Item(SID_HTML_MODE,
915                             ::GetHtmlMode(GetView().GetDocShell())));
916 
917             // Tabulatoren, DefaultTabs ins ItemSet Stecken
918             const SvxTabStopItem& rDefTabs = (const SvxTabStopItem&)
919                             GetPool().GetDefaultItem(RES_PARATR_TABSTOP);
920 
921             sal_uInt16 nDefDist = ::GetTabDist( rDefTabs );
922             SfxUInt16Item aDefDistItem( SID_ATTR_TABSTOP_DEFAULTS, nDefDist );
923             aCoreSet.Put( aDefDistItem );
924 
925             // Aktueller Tab
926             SfxUInt16Item aTabPos( SID_ATTR_TABSTOP_POS, 0 );
927             aCoreSet.Put( aTabPos );
928 
929             // linker Rand als Offset
930             //#i24363# tab stops relative to indent
931             const long nOff = rWrtSh.getIDocumentSettingAccess()->get(IDocumentSettingAccess::TABS_RELATIVE_TO_INDENT) ?
932                 ((SvxLRSpaceItem&)aCoreSet.Get( RES_LR_SPACE )).GetTxtLeft() : 0;
933             SfxInt32Item aOff( SID_ATTR_TABSTOP_OFFSET, nOff );
934             aCoreSet.Put( aOff );
935 
936             // BoxInfo setzen
937             ::PrepareBoxInfo( aCoreSet, rWrtSh );
938 
939             //aktuelles Seitenformat
940             ::SwToSfxPageDescAttr( aCoreSet );
941 
942             sal_uInt16 nDefPage = 0;
943             if( pItem )
944                 nDefPage = ((SfxUInt16Item *)pItem)->GetValue();
945 
946             // Numerierungseigenschaften
947             if(rWrtSh.GetCurNumRule())
948             {
949                 SfxBoolItem aStart( FN_NUMBER_NEWSTART, rWrtSh.IsNumRuleStart() );
950                 aCoreSet.Put(aStart);
951                 // --> OD 2008-02-29 #refactorlists#
952 //                SfxUInt16Item aStartAt(FN_NUMBER_NEWSTART_AT,
953 //                                                rWrtSh.IsNodeNumStart());
954                 SfxUInt16Item aStartAt( FN_NUMBER_NEWSTART_AT,
955                                         rWrtSh.GetNodeNumStart() );
956                 // <--
957                 aCoreSet.Put(aStartAt);
958             }
959             SfxAbstractTabDialog* pDlg = NULL;
960 
961             if ( bUseDialog && GetActiveView() )
962             {
963                 SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
964                 DBG_ASSERT(pFact, "SwAbstractDialogFactory fail!");
965 
966                 pDlg = pFact->CreateSwParaDlg( GetView().GetWindow(),GetView(), aCoreSet,DLG_STD, DLG_PARA,NULL, sal_False, nDefPage );
967                 DBG_ASSERT(pDlg, "Dialogdiet fail!");
968             }
969             SfxItemSet* pSet = NULL;
970             if ( !bUseDialog )
971             {
972                 pSet = (SfxItemSet*) pArgs;
973 
974             }
975             else if ( NULL != pDlg && pDlg->Execute() == RET_OK )
976             {
977                 // Defaults evtl umsetzen
978                 pSet = (SfxItemSet*)pDlg->GetOutputItemSet();
979                 sal_uInt16 nNewDist;
980                 if( SFX_ITEM_SET == pSet->GetItemState( SID_ATTR_TABSTOP_DEFAULTS, sal_False, &pItem ) &&
981                     nDefDist != (nNewDist = ((SfxUInt16Item*)pItem)->GetValue()) )
982                 {
983                     SvxTabStopItem aDefTabs( 0, 0, SVX_TAB_ADJUST_DEFAULT, RES_PARATR_TABSTOP );
984                     MakeDefTabs( nNewDist, aDefTabs );
985                     rWrtSh.SetDefault( aDefTabs );
986                     pSet->ClearItem( SID_ATTR_TABSTOP_DEFAULTS );
987                 }
988 
989                 if ( SFX_ITEM_SET == pSet->GetItemState(FN_PARAM_1,sal_False,&pItem) )
990                 {
991                     pSet->Put(SfxStringItem(FN_DROP_TEXT, ((const SfxStringItem*)pItem)->GetValue()));
992                     pSet->ClearItem(FN_PARAM_1);
993                 }
994 
995                 if( SFX_ITEM_SET == pSet->GetItemState( RES_PARATR_DROP, sal_False, &pItem ))
996                 {
997                     String sCharStyleName;
998                     if(((const SwFmtDrop*)pItem)->GetCharFmt())
999                         sCharStyleName = ((const SwFmtDrop*)pItem)->GetCharFmt()->GetName();
1000                     pSet->Put(SfxStringItem(FN_DROP_CHAR_STYLE_NAME, sCharStyleName));
1001                 }
1002             }
1003 
1004             if ( pSet )
1005             {
1006                 rReq.Done( *pSet );
1007                 ::SfxToSwPageDescAttr( rWrtSh, *pSet );
1008                 // --> OD 2006-12-06 #i56253#
1009                 // enclose all undos.
1010                 // Thus, check conditions, if actions will be performed.
1011                 const bool bUndoNeeded( pSet->Count() ||
1012                         SFX_ITEM_SET == pSet->GetItemState(FN_NUMBER_NEWSTART) ||
1013                         SFX_ITEM_SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) );
1014                 if ( bUndoNeeded )
1015                 {
1016                     rWrtSh.StartUndo( UNDO_INSATTR );
1017                 }
1018                 // <--
1019                 if( pSet->Count() )
1020                 {
1021                     rWrtSh.StartAction();
1022 //                    rWrtSh.StartUndo( UNDO_START );
1023                     if ( SFX_ITEM_SET == pSet->GetItemState(FN_DROP_TEXT, sal_False, &pItem) )
1024                     {
1025                         if ( ((SfxStringItem*)pItem)->GetValue().Len() )
1026                             rWrtSh.ReplaceDropTxt(((SfxStringItem*)pItem)->GetValue());
1027                     }
1028                     rWrtSh.SetAttr( *pSet );
1029 //                    rWrtSh.EndUndo( UNDO_END );
1030                     rWrtSh.EndAction();
1031                     SwTxtFmtColl* pColl = rWrtSh.GetCurTxtFmtColl();
1032                     if(pColl && pColl->IsAutoUpdateFmt())
1033                     {
1034                         rWrtSh.AutoUpdatePara(pColl, *pSet);
1035                     }
1036                 }
1037 
1038                 if( SFX_ITEM_SET == pSet->GetItemState(FN_NUMBER_NEWSTART) )
1039                 {
1040                     //SetNumRuleStart(sal_True) restarts the numbering at the value
1041                     //that is defined at the starting point of the numbering level
1042                     //otherwise the SetNodeNumStart() value determines the start
1043                     //if it's set to something different than (sal_uInt16)0xFFFF
1044 
1045                     sal_Bool bStart = ((SfxBoolItem&)pSet->Get(FN_NUMBER_NEWSTART)).GetValue();
1046                     // --> OD 2007-06-11 #b6560525#
1047                     // Default value for restart value has to be (sal_uInt16)0xFFFF
1048                     // in order to indicate that the restart value of the list
1049                     // style has to be used on restart.
1050                     sal_uInt16 nNumStart = (sal_uInt16)0xFFFF;
1051                     // <--
1052                     if( SFX_ITEM_SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) )
1053                     {
1054                         nNumStart = ((SfxUInt16Item&)pSet->Get(FN_NUMBER_NEWSTART_AT)).GetValue();
1055                     }
1056                     rWrtSh.SetNumRuleStart(bStart);
1057                     rWrtSh.SetNodeNumStart(nNumStart);
1058                 }
1059                 else if( SFX_ITEM_SET == pSet->GetItemState(FN_NUMBER_NEWSTART_AT) )
1060                 {
1061                     sal_uInt16 nNumStart = ((SfxUInt16Item&)pSet->Get(FN_NUMBER_NEWSTART_AT)).GetValue();
1062                     rWrtSh.SetNodeNumStart(nNumStart);
1063                     rWrtSh.SetNumRuleStart(sal_False);
1064                 }
1065                 // --> OD 2006-12-06 #i56253#
1066                 if ( bUndoNeeded )
1067                 {
1068                     rWrtSh.EndUndo( UNDO_INSATTR );
1069                 }
1070                 // <--
1071             }
1072 
1073             delete pDlg;
1074         }
1075         break;
1076         case FN_NUM_CONTINUE:
1077         {
1078             // --> OD 2008-03-18 #refactorlists#
1079             String sContinuedListId;
1080             const SwNumRule* pRule =
1081                 rWrtSh.SearchNumRule( false, true, false, -1, sContinuedListId );
1082             // --> OD 2009-08-26 #i86492#
1083             // Search also for bullet list
1084             if ( !pRule )
1085             {
1086                 pRule = rWrtSh.SearchNumRule( false, false, false, -1, sContinuedListId );
1087             }
1088             // <--
1089             if ( pRule )
1090             {
1091                 rWrtSh.SetCurNumRule( *pRule, false, sContinuedListId );
1092             }
1093             // <--
1094         }
1095         break;
1096         case FN_SELECT_PARA:
1097         {
1098             if(!rWrtSh.IsSttOfPara())
1099                 rWrtSh.SttPara(sal_False);
1100             else
1101                 rWrtSh.EnterStdMode();
1102             rWrtSh.EndPara(sal_True);
1103         }
1104         break;
1105 
1106         case SID_DEC_INDENT:
1107         case SID_INC_INDENT:
1108             rWrtSh.MoveLeftMargin( SID_INC_INDENT == nSlot,
1109                                     rReq.GetModifier() != KEY_MOD1 );
1110             rReq.Done();
1111             break;
1112         case FN_DEC_INDENT_OFFSET:
1113         case FN_INC_INDENT_OFFSET:
1114             rWrtSh.MoveLeftMargin( FN_INC_INDENT_OFFSET == nSlot,
1115                                     rReq.GetModifier() == KEY_MOD1 );
1116             rReq.Done();
1117             break;
1118 
1119         case SID_ATTR_CHAR_COLOR2:
1120         {
1121             if(pItem)
1122             {
1123                 Color aSet = ((const SvxColorItem*)pItem)->GetValue();
1124                 SwEditWin& rEditWin = GetView().GetEditWin();
1125                 rEditWin.SetTextColor(aSet);
1126                 SwApplyTemplate* pApply = rEditWin.GetApplyTemplate();
1127                 SvxColorItem aItem(aSet, RES_CHRATR_COLOR);
1128 
1129                 // besteht eine Selektion, wird sie gleich gefaerbt
1130                 if(!pApply && rWrtSh.HasSelection())
1131                 {
1132                     rWrtSh.SetAttr(SvxColorItem (aSet, RES_CHRATR_COLOR));
1133                 }
1134                 else if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_EXT)
1135                 {
1136                     GetView().GetViewFrame()->GetDispatcher()->Execute(SID_ATTR_CHAR_COLOR_EXT);
1137                 }
1138 
1139                 rReq.Done();
1140 /*              OS 22.02.97 18:40 Das alte Verhalten ist unerwuenscht
1141                 SwEditWin& rEdtWin = GetView().GetEditWin();
1142 
1143                 SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
1144                 SvxColorItem aItem(aSet, RES_CHRATR_COLOR);
1145 
1146                 if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_EXT)
1147                 {
1148                     GetShell().SetAttr(aItem);
1149                 }
1150 */
1151             }
1152         }
1153         break;
1154         case SID_ATTR_CHAR_COLOR_BACKGROUND:
1155         {
1156             SwEditWin& rEdtWin = GetView().GetEditWin();
1157             SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
1158             rEdtWin.SetTextBackColorTransparent(0 == pItem);
1159             Color aSet;
1160             if(pItem)
1161             {
1162                 aSet = ((const SvxColorItem*)pItem)->GetValue();
1163                 rEdtWin.SetTextBackColor(aSet);
1164             }
1165             if(!pApply && (rWrtSh.HasSelection() || rReq.IsAPI()))
1166             {
1167                 SvxBrushItem aBrushItem(RES_CHRATR_BACKGROUND);
1168                 if(pItem)
1169                     aBrushItem.SetColor(aSet);
1170                 else
1171                     aBrushItem.SetColor(Color(COL_TRANSPARENT));
1172                 rWrtSh.SetAttr( aBrushItem );
1173             }
1174             else if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_BACKGROUND_EXT)
1175             {
1176                 GetView().GetViewFrame()->GetDispatcher()->Execute(SID_ATTR_CHAR_COLOR_BACKGROUND_EXT);
1177             }
1178 
1179             rReq.Done();
1180 
1181 /*          OS 22.02.97 18:40 Das alte Verhalten ist unerwuenscht
1182             if(!pApply || pApply->nColor != SID_ATTR_CHAR_COLOR_BACKGROUND_EXT)
1183             {
1184                 Brush aBrush(pItem ? BRUSH_SOLID : BRUSH_NULL);
1185                 if(pItem)
1186                     aBrush.SetColor( aSet );
1187                 GetShell().SetAttr( SvxBrushItem(aBrush, RES_CHRATR_BACKGROUND) );
1188             }
1189 */
1190         }
1191         break;
1192         case SID_ATTR_CHAR_COLOR_BACKGROUND_EXT:
1193         case SID_ATTR_CHAR_COLOR_EXT:
1194         {
1195             SwEditWin& rEdtWin = GetView().GetEditWin();
1196             SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
1197             SwApplyTemplate aTempl;
1198             sal_Bool bSelection = rWrtSh.HasSelection();
1199             if(bSelection)
1200             {
1201 
1202                 if(nSlot == SID_ATTR_CHAR_COLOR_BACKGROUND_EXT)
1203                 {
1204                     rWrtSh.SetAttr( SvxBrushItem(
1205                         rEdtWin.GetTextBackColor(), RES_CHRATR_BACKGROUND) );
1206                 }
1207                 else
1208                     rWrtSh.SetAttr( SvxColorItem( rEdtWin.GetTextColor(),
1209                                                                 RES_CHRATR_COLOR) );
1210             }
1211             else
1212             {
1213                 if(!pApply || pApply->nColor != nSlot)
1214                     aTempl.nColor = nSlot;
1215                 rEdtWin.SetApplyTemplate(aTempl);
1216             }
1217 
1218             rReq.Done();
1219         }
1220         break;
1221 
1222         case FN_NUM_BULLET_MOVEDOWN:
1223             if (!rWrtSh.IsAddMode())
1224                 rWrtSh.MoveParagraph(1);
1225             rReq.Done();
1226             break;
1227 
1228         case FN_NUM_BULLET_MOVEUP:
1229             if (!rWrtSh.IsAddMode())
1230                 rWrtSh.MoveParagraph(-1);
1231             rReq.Done();
1232             break;
1233         case SID_RUBY_DIALOG:
1234         case SID_HYPERLINK_DIALOG:
1235         {
1236             SfxRequest aReq(nSlot, SFX_CALLMODE_SLOT, SFX_APP()->GetPool());
1237             GetView().GetViewFrame()->ExecuteSlot( aReq);
1238             rReq.Ignore();
1239         }
1240         break;
1241     case FN_INSERT_PAGEHEADER:
1242     case FN_INSERT_PAGEFOOTER:
1243     if(pArgs && pArgs->Count())
1244     {
1245         String sStyleName;
1246         if(pItem)
1247             sStyleName = ((const SfxStringItem*)pItem)->GetValue();
1248         sal_Bool bOn = sal_True;
1249         if( SFX_ITEM_SET == pArgs->GetItemState(FN_PARAM_1, sal_False, &pItem))
1250             bOn = ((const SfxBoolItem*)pItem)->GetValue();
1251         ChangeHeaderOrFooter(sStyleName, FN_INSERT_PAGEHEADER == nSlot, bOn, !rReq.IsAPI());
1252         rReq.Done();
1253     }
1254     break;
1255     case FN_READONLY_SELECTION_MODE :
1256         if(GetView().GetDocShell()->IsReadOnly())
1257         {
1258             rWrtSh.SetReadonlySelectionOption(
1259                 !rWrtSh.GetViewOptions()->IsSelectionInReadonly());
1260             rWrtSh.ShowCrsr();
1261         }
1262     break;
1263     case FN_SELECTION_MODE_DEFAULT:
1264     case FN_SELECTION_MODE_BLOCK :
1265     {
1266         bool bSetBlockMode = !rWrtSh.IsBlockMode();
1267         if( pArgs && SFX_ITEM_SET == pArgs->GetItemState(nSlot, sal_False, &pItem))
1268             bSetBlockMode = ((const SfxBoolItem*)pItem)->GetValue();
1269         if( ( nSlot == FN_SELECTION_MODE_DEFAULT ) ^ bSetBlockMode )
1270             rWrtSh.EnterBlockMode();
1271         else
1272             rWrtSh.EnterStdMode();
1273         SfxBindings &rBnd = GetView().GetViewFrame()->GetBindings();
1274         rBnd.Invalidate(FN_STAT_SELMODE);
1275         rBnd.Update(FN_STAT_SELMODE);
1276     }
1277     break;
1278     case SID_OPEN_HYPERLINK:
1279     case FN_COPY_HYPERLINK_LOCATION:
1280     {
1281         SfxItemSet aSet(GetPool(),
1282                         RES_TXTATR_INETFMT,
1283                         RES_TXTATR_INETFMT);
1284         rWrtSh.GetCurAttr(aSet);
1285         if(SFX_ITEM_SET <= aSet.GetItemState( RES_TXTATR_INETFMT, sal_True ))
1286         {
1287             const SwFmtINetFmt& rINetFmt = dynamic_cast<const SwFmtINetFmt&>( aSet.Get(RES_TXTATR_INETFMT, sal_True) );
1288             if( nSlot == FN_COPY_HYPERLINK_LOCATION )
1289             {
1290                 ::uno::Reference< datatransfer::clipboard::XClipboard > xClipboard = GetView().GetEditWin().GetClipboard();
1291                 vcl::unohelper::TextDataObject::CopyStringTo(
1292                         rINetFmt.GetValue(),
1293                         xClipboard );
1294             }
1295             else
1296                 rWrtSh.ClickToINetAttr(rINetFmt, URLLOAD_NOFILTER);
1297         }
1298     }
1299     break;
1300     case SID_OPEN_XML_FILTERSETTINGS:
1301     {
1302         try
1303         {
1304             uno::Reference < ui::dialogs::XExecutableDialog > xDialog(::comphelper::getProcessServiceFactory()->createInstance(rtl::OUString::createFromAscii("com.sun.star.comp.ui.XSLTFilterDialog")), uno::UNO_QUERY);
1305             if( xDialog.is() )
1306             {
1307                 xDialog->execute();
1308             }
1309         }
1310         catch( uno::Exception& )
1311         {
1312         }
1313         rReq.Ignore ();
1314     }
1315     break;
1316     case FN_FORMAT_APPLY_HEAD1:
1317     {
1318     }
1319     break;
1320     case FN_FORMAT_APPLY_HEAD2:
1321     {
1322     }
1323     break;
1324     case FN_FORMAT_APPLY_HEAD3:
1325     {
1326     }
1327     break;
1328     case FN_FORMAT_APPLY_DEFAULT:
1329     {
1330     }
1331     break;
1332     case FN_FORMAT_APPLY_TEXTBODY:
1333     {
1334     }
1335     break;
1336     case FN_WORDCOUNT_DIALOG:
1337     {
1338         SwWrtShell &rSh = GetShell();
1339         SwDocStat aCurr;
1340         SwDocStat aDocStat( rSh.getIDocumentStatistics()->GetDocStat() );
1341         {
1342             SwWait aWait( *GetView().GetDocShell(), sal_True );
1343             rSh.StartAction();
1344             rSh.CountWords( aCurr );
1345             rSh.UpdateDocStat( aDocStat );
1346             rSh.EndAction();
1347         }
1348 
1349         SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create();
1350         DBG_ASSERT(pFact, "Dialogdiet fail!");
1351         AbstractSwWordCountDialog* pDialog = pFact->CreateSwWordCountDialog( GetView().GetWindow() );
1352         pDialog->SetValues(aCurr, aDocStat );
1353         pDialog->Execute();
1354         delete pDialog;
1355     }
1356     break;
1357     default:
1358         ASSERT(!this, falscher Dispatcher);
1359         return;
1360     }
1361 }
1362 
1363 
1364 /*--------------------------------------------------------------------
1365     Beschreibung:
1366  --------------------------------------------------------------------*/
1367 
1368 
1369 void SwTextShell::GetState( SfxItemSet &rSet )
1370 {
1371     SwWrtShell &rSh = GetShell();
1372     SfxWhichIter aIter( rSet );
1373     sal_uInt16 nWhich = aIter.FirstWhich();
1374     while ( nWhich )
1375     {
1376         switch ( nWhich )
1377         {
1378         case SID_LANGUAGE_STATUS:
1379             {
1380                 // the value of used script types
1381                 String aScriptTypesInUse( String::CreateFromInt32( rSh.GetScriptType() ) );
1382 
1383                 SvtLanguageTable aLangTable;
1384 
1385                 // get keyboard language
1386                 String aKeyboardLang;
1387                 LanguageType nLang = LANGUAGE_DONTKNOW;
1388                 SwEditWin& rEditWin = GetView().GetEditWin();
1389                 nLang = rEditWin.GetInputLanguage();
1390                 if (nLang != LANGUAGE_DONTKNOW && nLang != LANGUAGE_SYSTEM)
1391                     aKeyboardLang = aLangTable.GetString( nLang );
1392 
1393                 // get the language that is in use
1394                 const String aMultipleLanguages = String::CreateFromAscii("*");
1395                 String aCurrentLang = aMultipleLanguages;
1396                 nLang = SwLangHelper::GetCurrentLanguage( rSh );
1397                 if (nLang != LANGUAGE_DONTKNOW)
1398                     aCurrentLang = aLangTable.GetString( nLang );
1399 
1400                 // build sequence for status value
1401                 uno::Sequence< ::rtl::OUString > aSeq( 4 );
1402                 aSeq[0] = aCurrentLang;
1403                 aSeq[1] = aScriptTypesInUse;
1404                 aSeq[2] = aKeyboardLang;
1405                 aSeq[3] = SwLangHelper::GetTextForLanguageGuessing( rSh );
1406 
1407                 // set sequence as status value
1408                 SfxStringListItem aItem( SID_LANGUAGE_STATUS );
1409                 aItem.SetStringList( aSeq );
1410                 rSet.Put( aItem, SID_LANGUAGE_STATUS );
1411             }
1412         break;
1413 
1414         case SID_THES:
1415         {
1416             // is there a valid selection to get text from?
1417             String aText;
1418             sal_Bool bValid = !rSh.HasSelection() ||
1419                     (rSh.IsSelOnePara() && !rSh.IsMultiSelection());
1420             // prevent context menu from showing when cursor is not in or at the end of a word
1421             // (GetCurWord will return the next word if there is none at the current position...)
1422             const sal_Int16 nWordType = ::i18n::WordType::DICTIONARY_WORD;
1423             bool bWord = rSh.IsInWord( nWordType ) || rSh.IsStartWord( nWordType ) || rSh.IsEndWord( nWordType );
1424             if (bValid && bWord)
1425                aText = rSh.HasSelection()? rSh.GetSelTxt() : rSh.GetCurWord();
1426 
1427             LanguageType nLang = rSh.GetCurLang();
1428             lang::Locale aLocale = SvxCreateLocale( nLang );
1429             String aLangText( MsLangId::convertLanguageToIsoString( nLang ) );
1430 
1431             // set word and locale to look up as status value
1432             String aStatusVal( aText );
1433             aStatusVal.AppendAscii( "#" );
1434             aStatusVal += aLangText;
1435 
1436             rSet.Put( SfxStringItem( SID_THES, aStatusVal ) );
1437 
1438             // disable "Thesaurus" context menu entry if there is nothing to look up
1439             uno::Reference< linguistic2::XThesaurus >  xThes( ::GetThesaurus() );
1440             if (aText.Len() == 0 ||
1441                 !xThes.is() || nLang == LANGUAGE_NONE || !xThes->hasLocale( aLocale ))
1442                 rSet.DisableItem( SID_THES );
1443         }
1444         break;
1445 
1446         case FN_NUMBER_NEWSTART :
1447             if(!rSh.GetCurNumRule())
1448                     rSet.DisableItem(nWhich);
1449             else
1450                 rSet.Put(SfxBoolItem(FN_NUMBER_NEWSTART,
1451                     rSh.IsNumRuleStart()));
1452         break;
1453         case FN_EDIT_FORMULA:
1454         case SID_CHARMAP:
1455             {
1456                 const int nType = rSh.GetSelectionType();
1457                 if (!(nType & nsSelectionType::SEL_TXT) &&
1458                     !(nType & nsSelectionType::SEL_TBL) &&
1459                     !(nType & nsSelectionType::SEL_NUM))
1460                     rSet.DisableItem(nWhich);
1461             }
1462             break;
1463 
1464         case FN_INSERT_ENDNOTE:
1465         case FN_INSERT_FOOTNOTE:
1466         case FN_INSERT_FOOTNOTE_DLG:
1467             {
1468                 const sal_uInt16 nNoType = FRMTYPE_FLY_ANY | FRMTYPE_HEADER |
1469                                         FRMTYPE_FOOTER  | FRMTYPE_FOOTNOTE;
1470                 if ( (rSh.GetFrmType(0,sal_True) & nNoType) )
1471                     rSet.DisableItem(nWhich);
1472             }
1473             break;
1474         case FN_INSERT_TABLE:
1475             if ( rSh.GetTableFmt() ||
1476                     (rSh.GetFrmType(0,sal_True) & FRMTYPE_FOOTNOTE) )
1477                 rSet.DisableItem( nWhich );
1478             break;
1479 
1480         case FN_CALCULATE:
1481             if ( !rSh.IsSelection() )
1482                 rSet.DisableItem(nWhich);
1483             break;
1484         case FN_GOTO_REFERENCE:
1485             {
1486                 SwField *pFld = rSh.GetCurFld();
1487                 if ( !pFld || (pFld &&  pFld->GetTypeId() != TYP_GETREFFLD) )
1488                     rSet.DisableItem(nWhich);
1489             }
1490             break;
1491         case FN_AUTOFORMAT_AUTO:
1492             {
1493                 rSet.Put( SfxBoolItem( nWhich, SvxAutoCorrCfg::Get()->IsAutoFmtByInput() ));
1494             }
1495             break;
1496         case FN_GLOSSARY_DLG:
1497             {
1498                 rSet.Put(SfxBoolItem(nWhich), sal_True);
1499             }
1500             break;
1501 
1502         case SID_DEC_INDENT:
1503         case SID_INC_INDENT:
1504             {
1505                 sal_uInt16 nHtmlMode = ::GetHtmlMode(GetView().GetDocShell());
1506                 nHtmlMode &= HTMLMODE_ON|HTMLMODE_SOME_STYLES;
1507                 if( (nHtmlMode == HTMLMODE_ON) || !rSh.IsMoveLeftMargin(
1508                                         SID_INC_INDENT == nWhich, sal_True ))
1509                     rSet.DisableItem( nWhich );
1510             }
1511             break;
1512 
1513         case FN_DEC_INDENT_OFFSET:
1514         case FN_INC_INDENT_OFFSET:
1515             {
1516                 sal_uInt16 nHtmlMode = ::GetHtmlMode(GetView().GetDocShell());
1517                 nHtmlMode &= HTMLMODE_ON|HTMLMODE_SOME_STYLES;
1518                 if( (nHtmlMode == HTMLMODE_ON) ||
1519                     !rSh.IsMoveLeftMargin( FN_INC_INDENT_OFFSET == nWhich,
1520                                             sal_False ))
1521                     rSet.DisableItem( nWhich );
1522             }
1523             break;
1524 
1525         case SID_ATTR_CHAR_COLOR2:
1526             {
1527                 rSet.Put(SvxColorItem(GetView().GetEditWin().GetTextColor(), SID_ATTR_CHAR_COLOR2));
1528             }
1529             break;
1530         case SID_ATTR_CHAR_COLOR_BACKGROUND:
1531             {
1532               if(GetView().GetEditWin().IsTextBackColorTransparent())
1533                   rSet.Put(SvxColorItem(Color(COL_TRANSPARENT), SID_ATTR_CHAR_COLOR_BACKGROUND));
1534               else
1535                     rSet.Put(SvxColorItem(GetView().GetEditWin().GetTextBackColor(), SID_ATTR_CHAR_COLOR_BACKGROUND));
1536             }
1537             break;
1538         case SID_ATTR_CHAR_COLOR_BACKGROUND_EXT:
1539         case SID_ATTR_CHAR_COLOR_EXT:
1540             {
1541                 SwEditWin& rEdtWin = GetView().GetEditWin();
1542                 SwApplyTemplate* pApply = rEdtWin.GetApplyTemplate();
1543                 rSet.Put(SfxBoolItem(nWhich, pApply && pApply->nColor == nWhich));
1544             }
1545             break;
1546         case FN_INSERT_BOOKMARK:
1547             if( rSh.IsTableMode() )
1548                 rSet.DisableItem( nWhich );
1549             break;
1550 
1551         case FN_INSERT_PAGEHEADER:
1552         case FN_INSERT_PAGEFOOTER:
1553             {
1554 #ifndef CHECK_MENU
1555                 rSet.Put( SfxObjectShellItem( nWhich, GetView().GetDocShell() ));
1556 #else
1557                 // Seitenvorlagen besorgen
1558                 sal_Bool bFound = sal_False;
1559                 sal_uInt16 n, nCnt = rSh.GetPageDescCnt();
1560                 for( n = 0; n < nCnt; ++n )
1561                 {
1562                     const SwPageDesc& rDesc = rSh.GetPageDesc( n );
1563                     if( FN_INSERT_PAGEHEADER == nWhich
1564                         ? !rDesc.GetMaster().GetHeader().IsActive()
1565                         : !rDesc.GetMaster().GetFooter().IsActive() )
1566                     {
1567                         bFound = sal_True;
1568                         break;
1569                     }
1570                 }
1571 
1572                 if( bFound )
1573                     rSet.Put( SfxObjectShellItem( nWhich, GetView().GetDocShell() ));
1574                 else
1575                     rSet.DisableItem( nWhich );
1576 #endif
1577             }
1578             break;
1579             case FN_TABLE_SORT_DIALOG:
1580             case FN_SORTING_DLG:
1581                 if(!rSh.HasSelection() ||
1582                         (FN_TABLE_SORT_DIALOG == nWhich && !rSh.GetTableFmt()))
1583                     rSet.DisableItem( nWhich );
1584             break;
1585             case SID_RUBY_DIALOG:
1586             {
1587                 SvtCJKOptions aCJKOptions;
1588                 if(!aCJKOptions.IsRubyEnabled())
1589                 {
1590                     GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, sal_False );
1591                     rSet.DisableItem(nWhich);
1592                 }
1593                 else
1594                     GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, sal_True );
1595                 break;
1596             }
1597             //no break!
1598             case SID_HYPERLINK_DIALOG:
1599                 if( GetView().GetDocShell()->IsReadOnly() ||
1600                     (!GetView().GetViewFrame()->HasChildWindow(nWhich) &&
1601                      rSh.HasReadonlySel()) )
1602                     rSet.DisableItem(nWhich);
1603                 else
1604                     rSet.Put(SfxBoolItem( nWhich, 0 != GetView().
1605                                 GetViewFrame()->GetChildWindow( nWhich ) ));
1606                 break;
1607             case FN_EDIT_HYPERLINK:
1608             case FN_REMOVE_HYPERLINK:
1609             case FN_COPY_HYPERLINK_LOCATION:
1610             {
1611                 SfxItemSet aSet(GetPool(),
1612                                 RES_TXTATR_INETFMT,
1613                                 RES_TXTATR_INETFMT);
1614                 rSh.GetCurAttr(aSet);
1615                 if(SFX_ITEM_SET > aSet.GetItemState( RES_TXTATR_INETFMT, sal_True ) || rSh.HasReadonlySel())
1616                 {
1617                     rSet.DisableItem(nWhich);
1618                 }
1619             }
1620             break;
1621             case SID_TRANSLITERATE_HALFWIDTH:
1622             case SID_TRANSLITERATE_FULLWIDTH:
1623             case SID_TRANSLITERATE_HIRAGANA:
1624             case SID_TRANSLITERATE_KATAGANA:
1625             {
1626                 SvtCJKOptions aCJKOptions;
1627                 if(!aCJKOptions.IsChangeCaseMapEnabled())
1628                 {
1629                     GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, sal_False );
1630                     rSet.DisableItem(nWhich);
1631                 }
1632                 else
1633                     GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, sal_True );
1634             }
1635             break;
1636             case FN_READONLY_SELECTION_MODE :
1637                 if(!GetView().GetDocShell()->IsReadOnly())
1638                     rSet.DisableItem( nWhich );
1639                 else
1640                 {
1641                     rSet.Put(SfxBoolItem(nWhich, rSh.GetViewOptions()->IsSelectionInReadonly()));
1642                 }
1643             break;
1644             case FN_SELECTION_MODE_DEFAULT:
1645             case FN_SELECTION_MODE_BLOCK :
1646                     rSet.Put(SfxBoolItem(nWhich, (nWhich == FN_SELECTION_MODE_DEFAULT) != rSh.IsBlockMode()));
1647             break;
1648             case  SID_OPEN_HYPERLINK:
1649             {
1650                 SfxItemSet aSet(GetPool(),
1651                                 RES_TXTATR_INETFMT,
1652                                 RES_TXTATR_INETFMT);
1653                 rSh.GetCurAttr(aSet);
1654                 if(SFX_ITEM_SET > aSet.GetItemState( RES_TXTATR_INETFMT, sal_False ))
1655                     rSet.DisableItem(nWhich);
1656             }
1657             break;
1658             case  SID_OPEN_SMARTTAGMENU:
1659             {
1660                  uno::Sequence< rtl::OUString > aSmartTagTypes;
1661                  uno::Sequence< uno::Reference< container::XStringKeyMap > > aStringKeyMaps;
1662                  uno::Reference<text::XTextRange> xRange;
1663 
1664                  rSh.GetSmartTagTerm( aSmartTagTypes, aStringKeyMaps, xRange );
1665 
1666                  if ( xRange.is() && aSmartTagTypes.getLength() )
1667                  {
1668                      uno::Sequence < uno::Sequence< uno::Reference< smarttags::XSmartTagAction > > > aActionComponentsSequence;
1669                      uno::Sequence < uno::Sequence< sal_Int32 > > aActionIndicesSequence;
1670 
1671                      const SmartTagMgr& rSmartTagMgr = SwSmartTagMgr::Get();
1672                      rSmartTagMgr.GetActionSequences( aSmartTagTypes,
1673                                                       aActionComponentsSequence,
1674                                                       aActionIndicesSequence );
1675 
1676                      uno::Reference <frame::XController> xController = GetView().GetController();
1677                      const lang::Locale aLocale( SW_BREAKITER()->GetLocale( (LanguageType)GetAppLanguage() ) );
1678                      const rtl::OUString aApplicationName( rSmartTagMgr.GetApplicationName() );
1679                      const rtl::OUString aRangeText = xRange->getString();
1680 
1681                      const SvxSmartTagItem aItem( nWhich,
1682                                                   aActionComponentsSequence,
1683                                                   aActionIndicesSequence,
1684                                                   aStringKeyMaps,
1685                                                   xRange,
1686                                                   xController,
1687                                                   aLocale,
1688                                                   aApplicationName,
1689                                                   aRangeText );
1690 
1691                      rSet.Put( aItem );
1692                  }
1693                  else
1694                      rSet.DisableItem(nWhich);
1695             }
1696             break;
1697             case FN_NUM_NUMBERING_ON:
1698                 rSet.Put(SfxBoolItem(FN_NUM_NUMBERING_ON,rSh.SelectionHasNumber()));
1699             break;
1700             case FN_NUM_BULLET_ON:
1701                 rSet.Put(SfxBoolItem(FN_NUM_BULLET_ON,rSh.SelectionHasBullet()));
1702             break;
1703             case FN_BUL_NUM_RULE_INDEX:
1704             case FN_NUM_NUM_RULE_INDEX:
1705         {
1706             SwNumRule* pCurRule = (SwNumRule*)(GetShell().GetCurNumRule());
1707             sal_uInt16  nActNumLvl = (sal_uInt16)0xFFFF;
1708             rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX,DEFAULT_NONE));
1709             rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX,DEFAULT_NONE));
1710             if( pCurRule )
1711             {
1712                 nActNumLvl = GetShell().GetNumLevel();
1713                 if( nActNumLvl < MAXLEVEL )
1714                 {
1715                     nActNumLvl = 1<<nActNumLvl;
1716                 }
1717                 SvxNumRule aSvxRule = pCurRule->MakeSvxNumRule();
1718                 if ( GetShell().HasBullet())
1719                 {
1720                     rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX,(sal_uInt16)0xFFFF));
1721                     rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX,(sal_uInt16)0xFFFF));
1722                     NBOTypeMgrBase* pBullets = NBOutlineTypeMgrFact::CreateInstance(eNBOType::MIXBULLETS);
1723                     if ( pBullets )
1724                     {
1725                         sal_uInt16 nBulIndex = pBullets->GetNBOIndexForNumRule(aSvxRule,nActNumLvl);
1726                         rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX,nBulIndex));
1727                     }
1728                 }else if ( GetShell().HasNumber() )
1729                 {
1730                     rSet.Put(SfxUInt16Item(FN_BUL_NUM_RULE_INDEX,(sal_uInt16)0xFFFF));
1731                     rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX,(sal_uInt16)0xFFFF));
1732                     NBOTypeMgrBase* pNumbering = NBOutlineTypeMgrFact::CreateInstance(eNBOType::NUMBERING);
1733                     if ( pNumbering )
1734                     {
1735                         sal_uInt16 nBulIndex = pNumbering->GetNBOIndexForNumRule(aSvxRule,nActNumLvl);
1736                         rSet.Put(SfxUInt16Item(FN_NUM_NUM_RULE_INDEX,nBulIndex));
1737                     }
1738                 }
1739             }
1740         }
1741             break;
1742             case FN_NUM_CONTINUE:
1743             {
1744                 // --> OD 2009-08-26 #i86492#
1745                 // Allow continuation of previous list, even if at current cursor
1746                 // a list is active.
1747 //                if ( rSh.GetCurNumRule() )
1748 //                    rSet.DisableItem(nWhich);
1749 //                else
1750                 // <--
1751                 {
1752                     // --> OD 2009-08-26 #i86492#
1753                     // Search also for bullet list
1754                     String aDummy;
1755                     const SwNumRule* pRule =
1756                             rSh.SearchNumRule( false, true, false, -1, aDummy );
1757                     if ( !pRule )
1758                     {
1759                         pRule = rSh.SearchNumRule( false, false, false, -1, aDummy );
1760                     }
1761                     // <--
1762                     if ( !pRule )
1763                         rSet.DisableItem(nWhich);
1764                 }
1765             }
1766             break;
1767             case SID_INSERT_RLM :
1768             case SID_INSERT_LRM :
1769             case SID_INSERT_ZWNBSP :
1770             case SID_INSERT_ZWSP:
1771             {
1772                 SvtCTLOptions aCTLOptions;
1773                 sal_Bool bEnabled = aCTLOptions.IsCTLFontEnabled();
1774                 GetView().GetViewFrame()->GetBindings().SetVisibleState( nWhich, bEnabled );
1775                 if(!bEnabled)
1776                     rSet.DisableItem(nWhich);
1777             }
1778             break;
1779         }
1780         nWhich = aIter.NextWhich();
1781     }
1782 }
1783 /* -----------------------------2002/07/05 10:31------------------------------
1784     Switch on/off header of footer of a page style - if an empty name is
1785     given all styles are changed
1786  ---------------------------------------------------------------------------*/
1787 void SwTextShell::ChangeHeaderOrFooter(
1788     const String& rStyleName, sal_Bool bHeader, sal_Bool bOn, sal_Bool bShowWarning)
1789 {
1790     SwWrtShell& rSh = GetShell();
1791     rSh.StartAllAction();
1792     rSh.StartUndo( UNDO_HEADER_FOOTER ); // #i7983#
1793     sal_Bool bExecute = sal_True;
1794     sal_Bool bCrsrSet = sal_False;
1795     for( sal_uInt16 nFrom = 0, nTo = rSh.GetPageDescCnt();
1796             nFrom < nTo; ++nFrom )
1797     {
1798         int bChgd = sal_False;
1799         SwPageDesc aDesc( rSh.GetPageDesc( nFrom ));
1800         String sTmp(aDesc.GetName());
1801         if( !rStyleName.Len() || rStyleName == sTmp )
1802         {
1803             if( bShowWarning && !bOn && GetActiveView() && GetActiveView() == &GetView() &&
1804                     ((bHeader && aDesc.GetMaster().GetHeader().IsActive()) ||
1805                         (!bHeader && aDesc.GetMaster().GetFooter().IsActive())))
1806             {
1807                 bShowWarning = sal_False;
1808                 //Actions have to be closed while the dialog is showing
1809                 rSh.EndAllAction();
1810 
1811                 Window* pParent = &GetView().GetViewFrame()->GetWindow();
1812                 sal_Bool bRet = RET_YES == QueryBox( pParent, ResId( RID_SVXQBX_DELETE_HEADFOOT,
1813                                         DIALOG_MGR() ) ).Execute();
1814                 bExecute = bRet;
1815                 rSh.StartAllAction();
1816             }
1817             if( bExecute )
1818             {
1819                 bChgd = sal_True;
1820                 SwFrmFmt &rMaster = aDesc.GetMaster();
1821                 if(bHeader)
1822                     rMaster.SetFmtAttr( SwFmtHeader( bOn ));
1823                 else
1824                     rMaster.SetFmtAttr( SwFmtFooter( bOn ));
1825                 if( bOn )
1826                 {
1827                     SvxULSpaceItem aUL(bHeader ? 0 : MM50, bHeader ? MM50 : 0, RES_UL_SPACE );
1828                     SwFrmFmt* pFmt = bHeader ?
1829                         (SwFrmFmt*)rMaster.GetHeader().GetHeaderFmt() :
1830                         (SwFrmFmt*)rMaster.GetFooter().GetFooterFmt();
1831                     pFmt->SetFmtAttr( aUL );
1832                 }
1833             }
1834             if( bChgd )
1835             {
1836                 rSh.ChgPageDesc( nFrom, aDesc );
1837 
1838                 if( !bCrsrSet && bOn )
1839                     bCrsrSet = rSh.SetCrsrInHdFt(
1840                             !rStyleName.Len() ? (sal_uInt16)0xFFFF : nFrom,
1841                             bHeader );
1842             }
1843         }
1844     }
1845     rSh.EndUndo( UNDO_HEADER_FOOTER ); // #i7983#
1846     rSh.EndAllAction();
1847 }
1848 
1849