xref: /aoo42x/main/sw/source/ui/docvw/edtwin.cxx (revision 86e1cf34)
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 
28 #include <tools/list.hxx>
29 #include <swtypes.hxx>
30 #include <hintids.hxx>
31 #include <com/sun/star/accessibility/XAccessible.hpp>
32 #include <comphelper/processfactory.hxx>
33 #include <com/sun/star/i18n/XBreakIterator.hpp>
34 #include <com/sun/star/i18n/ScriptType.hpp>
35 #include <com/sun/star/i18n/InputSequenceCheckMode.hpp>
36 
37 #include <com/sun/star/i18n/UnicodeScript.hpp>
38 
39 #include <vcl/help.hxx>
40 #include <vcl/graph.hxx>
41 #include <vcl/msgbox.hxx>
42 #include <vcl/cmdevt.h>
43 #include <sot/storage.hxx>
44 #include <svl/macitem.hxx>
45 #include <unotools/securityoptions.hxx>
46 #include <basic/sbxvar.hxx>
47 #include <svl/ctloptions.hxx>
48 #include <basic/sbx.hxx>
49 #include <svl/eitem.hxx>
50 #include <svl/stritem.hxx>
51 #include <sfx2/ipclient.hxx>
52 #include <sfx2/viewfrm.hxx>
53 #include <sfx2/request.hxx>
54 #include <sfx2/bindings.hxx>
55 #include <sfx2/dispatch.hxx>
56 #include <svl/ptitem.hxx>
57 #include <editeng/sizeitem.hxx>
58 #include <editeng/langitem.hxx>
59 #include <svx/htmlmode.hxx>
60 #include <svx/svdview.hxx>
61 #include <svx/svdhdl.hxx>
62 #include <svx/svdoutl.hxx>
63 #include <editeng/editeng.hxx>
64 #include <editeng/svxacorr.hxx>
65 #include <editeng/scripttypeitem.hxx>
66 #include <editeng/flditem.hxx>
67 #include <editeng/colritem.hxx>
68 #include <editeng/brshitem.hxx>
69 #include <editeng/wghtitem.hxx>
70 #include <editeng/udlnitem.hxx>
71 #include <editeng/postitem.hxx>
72 #include <editeng/protitem.hxx>
73 #include <unotools/charclass.hxx>
74 
75 #include <editeng/acorrcfg.hxx>
76 #include <SwSmartTagMgr.hxx>
77 #include <edtwin.hxx>
78 #include <view.hxx>
79 #include <wrtsh.hxx>
80 #include <IDocumentSettingAccess.hxx>
81 #include <fldbas.hxx>
82 #include <swmodule.hxx>
83 #include <docsh.hxx>
84 #include <viewopt.hxx>
85 #include <drawbase.hxx>
86 #include <dselect.hxx>
87 #include <textsh.hxx>
88 #include <shdwcrsr.hxx>
89 #include <txatbase.hxx>
90 #include <fmtanchr.hxx>
91 #include <fmtornt.hxx>
92 #include <fmtfsize.hxx>
93 #include <fmtclds.hxx>
94 #include <frmfmt.hxx>
95 #include <modcfg.hxx>
96 #include <fmtcol.hxx>
97 #include <wview.hxx>
98 #include <listsh.hxx>
99 #include <gloslst.hxx>
100 #include <inputwin.hxx>
101 #include <gloshdl.hxx>
102 #include <swundo.hxx>
103 #include <drwtxtsh.hxx>
104 #include <fchrfmt.hxx>
105 #include <fmturl.hxx>
106 #include <romenu.hxx>
107 #include <initui.hxx>
108 #include <frmatr.hxx>
109 #include <extinput.hxx>
110 #include <acmplwrd.hxx>
111 #include <swcalwrp.hxx>
112 #include <swdtflvr.hxx>
113 #include <wdocsh.hxx>
114 #include <crsskip.hxx>
115 #include <breakit.hxx>
116 #include <checkit.hxx>
117 
118 #include <helpid.h>
119 #include <cmdid.h>
120 #include <docvw.hrc>
121 #include <uitool.hxx>
122 #include <fmtfollowtextflow.hxx>
123 #include <toolkit/helper/vclunohelper.hxx>
124 #include <charfmt.hxx>
125 #include <numrule.hxx>
126 #include <pagedesc.hxx>
127 #include <svtools/ruler.hxx>
128 #include "formatclipboard.hxx"
129 #include <vos/mutex.hxx>
130 #include <vcl/svapp.hxx>
131 
132 #include <IMark.hxx>
133 #include <doc.hxx>
134 #include <xmloff/odffields.hxx>
135 
136 #include <PostItMgr.hxx>
137 
138 using namespace sw::mark;
139 using namespace ::com::sun::star;
140 
141 /*--------------------------------------------------------------------
142     Beschreibung:   Globals
143  --------------------------------------------------------------------*/
144 
145 static bool bInputLanguageSwitched = false;
146 extern sal_Bool bNoInterrupt;       // in mainwn.cxx
147 
148 //Normalerweise wird im MouseButtonUp eine Selektion aufgehoben wenn die
149 //Selektion nicht gerade aufgezogen wird. Leider wird im MouseButtonDown
150 //bei doppel-/dreifach-Klick Selektiert, diese Selektion wird in dem Handler
151 //komplett abgeschlossen und kann deshalb im Up nicht mehr unterschieden
152 //werden. Um dies Aufzuloese wird bHoldSelection im Down gesetzt und im
153 //Up ausgewertet.
154 static sal_Bool bHoldSelection      = sal_False;
155 
156 sal_Bool bFrmDrag                   = sal_False;
157 sal_Bool bValidCrsrPos              = sal_False;
158 sal_Bool bModePushed                = sal_False;
159 sal_Bool bDDTimerStarted            = sal_False;
160 sal_Bool bFlushCharBuffer           = sal_False;
161 sal_Bool SwEditWin::bReplaceQuote   = sal_False;
162 sal_Bool bDDINetAttr                = sal_False;
163 SdrHdlKind eSdrMoveHdl          = HDL_USER;
164 
165 QuickHelpData* SwEditWin::pQuickHlpData = 0;
166 
167 long    SwEditWin::nDDStartPosY = 0;
168 long    SwEditWin::nDDStartPosX = 0;
169 Color   SwEditWin::aTextBackColor(COL_YELLOW);
170 Color   SwEditWin::aTextColor(COL_RED);
171 sal_Bool    SwEditWin::bTransparentBackColor = sal_False; // Hintergrund nicht transparent
172 
173 
174 extern sal_Bool     bExecuteDrag;
175 
176 SfxShell* lcl_GetShellFromDispatcher( SwView& rView, TypeId nType );
177 
178 DBG_NAME(edithdl)
179 
180 class SwAnchorMarker
181 {
182     SdrHdl* pHdl;
183     Point aHdlPos;
184     Point aLastPos;
185     bool bTopRightHandle;
186 public:
187     SwAnchorMarker( SdrHdl* pH )
188         : pHdl( pH )
189         , aHdlPos( pH->GetPos() )
190         , aLastPos( pH->GetPos() )
191         , bTopRightHandle( pH->GetKind() == HDL_ANCHOR_TR )
192     {}
193     const Point& GetLastPos() const { return aLastPos; }
194     void SetLastPos( const Point& rNew ) { aLastPos = rNew; }
195     void SetPos( const Point& rNew ) { pHdl->SetPos( rNew ); }
196     const Point& GetPos() { return pHdl->GetPos(); }
197     const Point& GetHdlPos() { return aHdlPos; }
198     SdrHdl* GetHdl() const { return pHdl; }
199     void ChgHdl( SdrHdl* pNew )
200     {
201         pHdl = pNew;
202         if ( pHdl )
203         {
204             bTopRightHandle = (pHdl->GetKind() == HDL_ANCHOR_TR);
205         }
206     }
207     const Point GetPosForHitTest( const OutputDevice& rOut )
208     {
209         Point aHitTestPos( GetPos() );
210         aHitTestPos = rOut.LogicToPixel( aHitTestPos );
211         if ( bTopRightHandle )
212         {
213             aHitTestPos += Point( -1, 1 );
214         }
215         else
216         {
217             aHitTestPos += Point( 1, 1 );
218         }
219         aHitTestPos = rOut.PixelToLogic( aHitTestPos );
220 
221         return aHitTestPos;
222     }
223 };
224 
225 struct QuickHelpData
226 {
227     SvStringsISortDtor aArr;
228     sal_uInt16* pAttrs;
229     CommandExtTextInputData* pCETID;
230     sal_uLong nTipId;
231     sal_uInt16 nLen, nCurArrPos;
232     sal_Bool bClear : 1, bChkInsBlank : 1, bIsTip : 1, bIsAutoText : 1;
233 
234     QuickHelpData() : pAttrs( 0 ), pCETID( 0 )  { ClearCntnt(); }
235 
236     void Move( QuickHelpData& rCpy );
237     void ClearCntnt();
238     void Start( SwWrtShell& rSh, sal_uInt16 nWrdLen );
239     void Stop( SwWrtShell& rSh );
240 
241     sal_Bool HasCntnt() const       { return aArr.Count() && 0 != nLen; }
242 
243     void Inc( sal_Bool bEndLess )
244         {
245             if( ++nCurArrPos >= aArr.Count() )
246                 nCurArrPos = (bEndLess && !bIsAutoText )? 0 : nCurArrPos-1;
247         }
248     void Dec( sal_Bool bEndLess )
249         {
250             if( 0 == nCurArrPos-- )
251                 nCurArrPos = (bEndLess && !bIsAutoText ) ? aArr.Count()-1 : 0;
252         }
253     void FillStrArr( SwWrtShell& rSh, const String& rWord );
254 };
255 
256 
257 /*--------------------------------------------------------------------
258     Beschreibung:   Minimale Bewegung Zittern vermeiden
259  --------------------------------------------------------------------*/
260 
261 #define HIT_PIX  2 /* Hit-Toleranz in Pixel */
262 #define MIN_MOVE 4
263 
264 inline sal_Bool IsMinMove(const Point &rStartPos, const Point &rLPt)
265 {
266     return Abs(rStartPos.X() - rLPt.X()) > MIN_MOVE ||
267            Abs(rStartPos.Y() - rLPt.Y()) > MIN_MOVE;
268 }
269 
270 /*--------------------------------------------------------------------
271     JP 30.07.98: fuer MouseButtonDown - feststellen, ob ein DrawObject
272                 und KEIN SwgFrame getroffen wurde! Shift/Ctrl sollen
273                 nur bei DrawObjecte zum Selektieren fuehren, bei SwgFlys
274                 ggfs zum ausloesen von Hyperlinks (DownLoad/NewWindow!)
275  --------------------------------------------------------------------*/
276 inline sal_Bool IsDrawObjSelectable( const SwWrtShell& rSh, const Point& rPt )
277 {
278     sal_Bool bRet = sal_True;
279     SdrObject* pObj;
280     switch( rSh.GetObjCntType( rPt, pObj ))
281     {
282     case OBJCNT_NONE:
283     case OBJCNT_FLY:
284     case OBJCNT_GRF:
285     case OBJCNT_OLE:
286         bRet = sal_False;
287         break;
288     default:; //prevent warning
289     }
290     return bRet;
291 }
292 
293 /*--------------------------------------------------------------------
294     Beschreibung:   Pointer umschalten
295  --------------------------------------------------------------------*/
296 
297 
298 void SwEditWin::UpdatePointer(const Point &rLPt, sal_uInt16 nModifier )
299 {
300     SwWrtShell &rSh = rView.GetWrtShell();
301     if( pApplyTempl )
302     {
303         PointerStyle eStyle = POINTER_FILL;
304         if ( rSh.IsOverReadOnlyPos( rLPt ) )
305         {
306             if( pUserMarker )
307             {
308                 delete pUserMarker;
309                 pUserMarker = 0L;
310             }
311             eStyle = POINTER_NOTALLOWED;
312         }
313         else
314         {
315             SwRect aRect;
316             SwRect* pRect = &aRect;
317             const SwFrmFmt* pFmt = 0;
318 
319             bool bFrameIsValidTarget = false;
320             if( pApplyTempl->pFormatClipboard )
321                 bFrameIsValidTarget = pApplyTempl->pFormatClipboard->HasContentForThisType( nsSelectionType::SEL_FRM );
322             else if( !pApplyTempl->nColor )
323                 bFrameIsValidTarget = ( pApplyTempl->eType == SFX_STYLE_FAMILY_FRAME );
324 
325             if( bFrameIsValidTarget &&
326                         0 !=(pFmt = rSh.GetFmtFromObj( rLPt, &pRect )) &&
327                         PTR_CAST(SwFlyFrmFmt, pFmt))
328             {
329                 //Highlight fuer Rahmen anwerfen
330                 Rectangle aTmp( pRect->SVRect() );
331 
332                 if ( !pUserMarker )
333                 {
334                     pUserMarker = new SdrDropMarkerOverlay( *rSh.GetDrawView(), aTmp );
335                 }
336             }
337             else if(pUserMarker)
338             {
339                 delete pUserMarker;
340                 pUserMarker = 0L;
341             }
342 
343             rSh.SwCrsrShell::SetVisCrsr( rLPt );
344         }
345         SetPointer( eStyle );
346         return;
347     }
348 
349     if( !rSh.VisArea().Width() )
350         return;
351 
352     SET_CURR_SHELL(&rSh);
353 
354     if ( IsChainMode() )
355     {
356         SwRect aRect;
357         int nChainable = rSh.Chainable( aRect, *rSh.GetFlyFrmFmt(), rLPt );
358         PointerStyle eStyle = nChainable
359                 ? POINTER_CHAIN_NOTALLOWED : POINTER_CHAIN;
360         if ( !nChainable )
361         {
362             Rectangle aTmp( aRect.SVRect() );
363 
364             if ( !pUserMarker )
365             {
366                 pUserMarker = new SdrDropMarkerOverlay( *rSh.GetDrawView(), aTmp );
367             }
368         }
369         else
370         {
371             delete pUserMarker;
372             pUserMarker = 0L;
373         }
374 
375         rView.GetViewFrame()->ShowStatusText(
376                                         SW_RESSTR(STR_CHAIN_OK+nChainable));
377         SetPointer( eStyle );
378         return;
379     }
380 
381     // Removed ExecHyperlink option.
382     //sal_Bool bExecHyperlinks = rSh.GetViewOptions()->IsExecHyperlinks() ^
383     //                     (nModifier == KEY_MOD2 ? sal_True : sal_False);
384     sal_Bool bExecHyperlinks = rView.GetDocShell()->IsReadOnly();
385     if ( !bExecHyperlinks )
386     {
387         SvtSecurityOptions aSecOpts;
388         const sal_Bool bSecureOption = aSecOpts.IsOptionSet( SvtSecurityOptions::E_CTRLCLICK_HYPERLINK );
389         if ( (  bSecureOption && nModifier == KEY_MOD1 ) ||
390              ( !bSecureOption && nModifier != KEY_MOD1 ) )
391             bExecHyperlinks = sal_True;
392     }
393 
394     const sal_Bool bExecSmarttags  = nModifier == KEY_MOD1;
395 
396     SdrView *pSdrView = rSh.GetDrawView();
397     sal_Bool bPrefSdrPointer = sal_False;
398     sal_Bool bHitHandle = sal_False;
399     sal_Bool bCntAtPos = sal_False;
400     sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly() &&
401                           rSh.IsCrsrReadonly();
402     aActHitType = SDRHIT_NONE;
403     PointerStyle eStyle = POINTER_TEXT;
404     if ( !pSdrView )
405         bCntAtPos = sal_True;
406     else if ( sal_True == (bHitHandle = pSdrView->PickHandle( rLPt ) != 0) )
407     {
408         aActHitType = SDRHIT_OBJECT;
409         bPrefSdrPointer = sal_True;
410     }
411     else
412     {
413         const sal_Bool bNotInSelObj = !rSh.IsInsideSelectedObj( rLPt );
414         if ( rView.GetDrawFuncPtr() && !bInsDraw && bNotInSelObj )
415         {
416             aActHitType = SDRHIT_OBJECT;
417             if (IsObjectSelect())
418                 eStyle = POINTER_ARROW;
419             else
420                 bPrefSdrPointer = sal_True;
421         }
422         else
423         {
424             SdrObject* pObj; SdrPageView* pPV;
425             pSdrView->SetHitTolerancePixel( HIT_PIX );
426             if ( bNotInSelObj && bExecHyperlinks &&
427                  pSdrView->PickObj( rLPt, pSdrView->getHitTolLog(), pObj, pPV, SDRSEARCH_PICKMACRO ))
428             {
429                 SdrObjMacroHitRec aTmp;
430                 aTmp.aPos = rLPt;
431                 aTmp.pPageView = pPV;
432                 SetPointer( pObj->GetMacroPointer( aTmp ) );
433                 return;
434             }
435             else
436             {
437                 // dvo: IsObjSelectable() eventually calls SdrView::PickObj, so
438                 // apparently this is used to determine whether this is a
439                 // drawling layer object or not.
440                 if ( rSh.IsObjSelectable( rLPt ) )
441                 {
442                     if (pSdrView->IsTextEdit())
443                     {
444                         aActHitType = SDRHIT_NONE;
445                         bPrefSdrPointer = sal_True;
446                     }
447                     else
448                     {
449                         SdrViewEvent aVEvt;
450                         SdrHitKind eHit = pSdrView->PickAnything(rLPt, aVEvt);
451 
452                         if (eHit == SDRHIT_URLFIELD && bExecHyperlinks)
453                         {
454                             aActHitType = SDRHIT_OBJECT;
455                             bPrefSdrPointer = sal_True;
456                         }
457                         else
458                         {
459                             // if we're over a selected object, we show an
460                             // ARROW by default. We only show a MOVE if 1) the
461                             // object is selected, and 2) it may be moved
462                             // (i.e., position is not protected).
463                             bool bMovable =
464                                 (!bNotInSelObj) &&
465                                 (rSh.IsObjSelected() || rSh.IsFrmSelected()) &&
466                                 (!rSh.IsSelObjProtected(FLYPROTECT_POS));
467 
468                             eStyle = bMovable ? POINTER_MOVE : POINTER_ARROW;
469                             aActHitType = SDRHIT_OBJECT;
470                         }
471                     }
472                 }
473                 else
474                 {
475                     if ( rSh.IsFrmSelected() && !bNotInSelObj )
476                     {
477                         // dvo: this branch appears to be dead and should be
478                         // removed in a future version. Reason: The condition
479                         // !bNotInSelObj means that this branch will only be
480                         // executed in the cursor points inside a selected
481                         // object. However, if this is the case, the previous
482                         // if( rSh.IsObjSelectable(rLPt) ) must always be true:
483                         // rLPt is inside a selected object, then obviously
484                         // rLPt is over a selectable object.
485                         if (rSh.IsSelObjProtected(FLYPROTECT_SIZE))
486                             eStyle = POINTER_NOTALLOWED;
487                         else
488                             eStyle = POINTER_MOVE;
489                         aActHitType = SDRHIT_OBJECT;
490                     }
491                     else
492                     {
493                         if ( rView.GetDrawFuncPtr() )
494                             bPrefSdrPointer = sal_True;
495                         else
496                             bCntAtPos = sal_True;
497                     }
498                 }
499             }
500         }
501     }
502     if ( bPrefSdrPointer )
503     {
504         if (bIsDocReadOnly || (rSh.IsObjSelected() && rSh.IsSelObjProtected(FLYPROTECT_CONTENT)))
505             SetPointer( POINTER_NOTALLOWED );
506         else
507         {
508             if (rView.GetDrawFuncPtr() && rView.GetDrawFuncPtr()->IsInsertForm() && !bHitHandle)
509                 SetPointer( POINTER_DRAW_RECT );
510             else
511                 SetPointer( pSdrView->GetPreferedPointer( rLPt, rSh.GetOut() ) );
512         }
513     }
514     else
515     {
516         if( !rSh.IsPageAtPos( rLPt ) || pAnchorMarker )
517             eStyle = POINTER_ARROW;
518         else
519         {
520             if( bCntAtPos )
521             {
522                 SwContentAtPos aSwContentAtPos(
523                     SwContentAtPos::SW_CLICKFIELD|
524                     SwContentAtPos::SW_INETATTR|
525                     SwContentAtPos::SW_FTN |
526                     SwContentAtPos::SW_SMARTTAG );
527                 if( rSh.GetContentAtPos( rLPt, aSwContentAtPos) )
528                 {
529                     const bool bClickToFollow = SwContentAtPos::SW_INETATTR == aSwContentAtPos.eCntntAtPos ||
530                                                 SwContentAtPos::SW_SMARTTAG == aSwContentAtPos.eCntntAtPos;
531 
532                      if( !bClickToFollow ||
533                          (SwContentAtPos::SW_INETATTR == aSwContentAtPos.eCntntAtPos && bExecHyperlinks) ||
534                          (SwContentAtPos::SW_SMARTTAG == aSwContentAtPos.eCntntAtPos && bExecSmarttags) )
535                         eStyle = POINTER_REFHAND;
536                 }
537             }
538         }
539 
540         // which kind of text pointer have we to show - horz / vert - ?
541         if( POINTER_TEXT == eStyle && rSh.IsInVerticalText( &rLPt ))
542             eStyle = POINTER_TEXT_VERTICAL;
543 
544         SetPointer( eStyle );
545     }
546 }
547 
548 /*--------------------------------------------------------------------
549     Beschreibung: Timer fuer Selektion vergroessern
550  --------------------------------------------------------------------*/
551 
552 
553 IMPL_LINK( SwEditWin, TimerHandler, Timer *, EMPTYARG )
554 {
555     DBG_PROFSTART(edithdl);
556 
557     SwWrtShell &rSh = rView.GetWrtShell();
558     Point aModPt( aMovePos );
559     const SwRect aOldVis( rSh.VisArea() );
560     sal_Bool bDone = sal_False;
561 
562     if ( !rSh.VisArea().IsInside( aModPt ) )
563     {
564         if ( bInsDraw )
565         {
566             const int nMaxScroll = 40;
567             rView.Scroll( Rectangle(aModPt,Size(1,1)), nMaxScroll, nMaxScroll);
568             bDone = sal_True;
569         }
570         else if ( bFrmDrag )
571         {
572             (rSh.*rSh.fnDrag)(&aModPt,sal_False);
573             bDone = sal_True;
574         }
575         if ( !bDone )
576             aModPt = rSh.GetCntntPos( aModPt,aModPt.Y() > rSh.VisArea().Bottom() );
577     }
578     if ( !bDone && !(bFrmDrag || bInsDraw) )
579     {
580         if ( pRowColumnSelectionStart )
581         {
582             Point aPos( aModPt );
583             rSh.SelectTableRowCol( *pRowColumnSelectionStart, &aPos, bIsRowDrag );
584         }
585         else
586             (rSh.*rSh.fnSetCrsr)( &aModPt, sal_False );
587 
588         //fix(24138): Es kann sein, dass der "Sprung" ueber eine Tabelle so
589         //nicht geschafft wird. Deshalb wir hier eben per Up/Down ueber die
590         //Tabelle gesprungen.
591         const SwRect& rVisArea = rSh.VisArea();
592         if( aOldVis == rVisArea && !rSh.IsStartOfDoc() && !rSh.IsEndOfDoc() )
593         {
594             //JP 11.10.2001 Bug 72294 - take the center point of VisArea to
595             //              decide in which direction the user want.
596             if( aModPt.Y() < ( rVisArea.Top() + rVisArea.Height() / 2 ) )
597                 rSh.Up( sal_True, 1 );
598             else
599                 rSh.Down( sal_True, 1 );
600         }
601     }
602 
603     aMovePos += rSh.VisArea().Pos() - aOldVis.Pos();
604     JustifyAreaTimer();
605     DBG_PROFSTOP(edithdl);
606     return 0;
607 }
608 
609 /*--------------------------------------------------------------------
610     Beschreibung:
611  --------------------------------------------------------------------*/
612 
613 
614 void SwEditWin::JustifyAreaTimer()
615 {
616     const Rectangle &rVisArea = GetView().GetVisArea();
617 #ifdef UNX
618     const long coMinLen = 100;
619 #else
620     const long coMinLen = 50;
621 #endif
622     long nTimeout = 800,
623          nDiff = Max(
624          Max( aMovePos.Y() - rVisArea.Bottom(), rVisArea.Top() - aMovePos.Y() ),
625          Max( aMovePos.X() - rVisArea.Right(),  rVisArea.Left() - aMovePos.X()));
626     aTimer.SetTimeout( Max( coMinLen, nTimeout - nDiff) );
627 }
628 
629 void SwEditWin::LeaveArea(const Point &rPos)
630 {
631     aMovePos = rPos;
632     JustifyAreaTimer();
633     if( !aTimer.IsActive() )
634         aTimer.Start();
635     if( pShadCrsr )
636         delete pShadCrsr, pShadCrsr = 0;
637 }
638 
639 inline void SwEditWin::EnterArea()
640 {
641     aTimer.Stop();
642 }
643 
644 /*------------------------------------------------------------------------
645  Beschreibung:  Modus fuer Rahmen einfuegen
646 ------------------------------------------------------------------------*/
647 
648 
649 void SwEditWin::InsFrm(sal_uInt16 nCols)
650 {
651     StdDrawMode( OBJ_NONE, sal_False );
652     bInsFrm = sal_True;
653     nInsFrmColCount = nCols;
654 }
655 
656 
657 
658 void SwEditWin::StdDrawMode( SdrObjKind eSdrObjectKind, sal_Bool bObjSelect )
659 {
660     SetSdrDrawMode( eSdrObjectKind );
661 
662     if (bObjSelect)
663         rView.SetDrawFuncPtr(new DrawSelection( &rView.GetWrtShell(), this, &rView ));
664     else
665         rView.SetDrawFuncPtr(new SwDrawBase( &rView.GetWrtShell(), this, &rView ));
666 
667     rView.SetSelDrawSlot();
668     SetSdrDrawMode( eSdrObjectKind );
669     if (bObjSelect)
670         rView.GetDrawFuncPtr()->Activate( SID_OBJECT_SELECT );
671     else
672         rView.GetDrawFuncPtr()->Activate( sal::static_int_cast< sal_uInt16 >(eSdrObjectKind) );     // don't know if this is useful at all; but it keeps functionality as it was...
673     bInsFrm = sal_False;
674     nInsFrmColCount = 1;
675 }
676 
677 
678 
679 void SwEditWin::StopInsFrm()
680 {
681     if (rView.GetDrawFuncPtr())
682     {
683         rView.GetDrawFuncPtr()->Deactivate();
684         rView.SetDrawFuncPtr(NULL);
685     }
686     rView.LeaveDrawCreate();    // Konstruktionsmode verlassen
687     bInsFrm = sal_False;
688     nInsFrmColCount = 1;
689 }
690 
691 /*--------------------------------------------------------------------
692  --------------------------------------------------------------------*/
693 
694 
695 sal_Bool SwEditWin::IsInputSequenceCheckingRequired( const String &rText, const SwPaM& rCrsr ) const
696 {
697     const SvtCTLOptions& rCTLOptions = SW_MOD()->GetCTLOptions();
698     if ( !rCTLOptions.IsCTLFontEnabled() ||
699          !rCTLOptions.IsCTLSequenceChecking() )
700          return sal_False;
701 
702     const xub_StrLen nFirstPos = rCrsr.Start()->nContent.GetIndex();
703     if ( 0 == nFirstPos ) /* first char needs not to be checked */
704         return sal_False;
705 
706     SwBreakIt *pBreakIter = SwBreakIt::Get();
707     uno::Reference < i18n::XBreakIterator > xBI = pBreakIter->GetBreakIter();
708     long nCTLScriptPos = -1;
709 
710     if (xBI.is())
711     {
712         if (xBI->getScriptType( rText, 0 ) == i18n::ScriptType::COMPLEX)
713             nCTLScriptPos = 0;
714         else
715             nCTLScriptPos = xBI->nextScript( rText, 0, i18n::ScriptType::COMPLEX );
716     }
717 
718     return (0 <= nCTLScriptPos && nCTLScriptPos <= rText.Len());
719 }
720 
721 
722 /*--------------------------------------------------------------------
723      Beschreibung:  Der Character Buffer wird in das Dokument eingefuegt
724  --------------------------------------------------------------------*/
725 
726 
727 void SwEditWin::FlushInBuffer()
728 {
729     if ( aInBuffer.Len() )
730     {
731         SwWrtShell& rSh = rView.GetWrtShell();
732 
733         // generate new sequence input checker if not already done
734         if ( !pCheckIt )
735             pCheckIt = new SwCheckIt;
736 
737         uno::Reference < i18n::XExtendedInputSequenceChecker > xISC = pCheckIt->xCheck;
738         if ( xISC.is() && IsInputSequenceCheckingRequired( aInBuffer, *rSh.GetCrsr() ) )
739         {
740             //
741             // apply (Thai) input sequence checking/correction
742             //
743 
744             rSh.Push(); // push current cursor to stack
745 
746             // get text from the beginning (i.e left side) of current selection
747             // to the start of the paragraph
748             rSh.NormalizePam();     // make point be the first (left) one
749             if (!rSh.GetCrsr()->HasMark())
750                 rSh.GetCrsr()->SetMark();
751             rSh.GetCrsr()->GetMark()->nContent = 0;
752             String aLeftText( rSh.GetCrsr()->GetTxt() );
753 
754             SvtCTLOptions& rCTLOptions = SW_MOD()->GetCTLOptions();
755 
756             xub_StrLen nExpandSelection = 0;
757             if (aLeftText.Len() > 0)
758             {
759                 sal_Unicode cChar = '\0';
760 
761                 xub_StrLen nTmpPos = aLeftText.Len();
762                 sal_Int16 nCheckMode = rCTLOptions.IsCTLSequenceCheckingRestricted() ?
763                         i18n::InputSequenceCheckMode::STRICT : i18n::InputSequenceCheckMode::BASIC;
764 
765                 rtl::OUString aOldText( aLeftText );
766                 rtl::OUString aNewText( aOldText );
767                 if (rCTLOptions.IsCTLSequenceCheckingTypeAndReplace())
768                 {
769                     for (xub_StrLen k = 0;  k < aInBuffer.Len();  ++k)
770                     {
771                         cChar = aInBuffer.GetChar(k);
772                         const xub_StrLen nPrevPos = static_cast<xub_StrLen>(xISC->correctInputSequence( aNewText, nTmpPos - 1, cChar, nCheckMode ));
773 
774                         // valid sequence or sequence could be corrected:
775                         if (nPrevPos != aNewText.getLength())
776                             nTmpPos = nPrevPos + 1;
777                     }
778 
779                     // find position of first character that has changed
780                     sal_Int32 nOldLen = aOldText.getLength();
781                     sal_Int32 nNewLen = aNewText.getLength();
782                     const sal_Unicode *pOldTxt = aOldText.getStr();
783                     const sal_Unicode *pNewTxt = aNewText.getStr();
784                     sal_Int32 nChgPos = 0;
785                     while ( nChgPos < nOldLen && nChgPos < nNewLen &&
786                             pOldTxt[nChgPos] == pNewTxt[nChgPos] )
787                         ++nChgPos;
788 
789                     xub_StrLen nChgLen = static_cast< xub_StrLen >(nNewLen - nChgPos);
790                     String aChgText( aNewText.copy( static_cast< xub_StrLen >(nChgPos), nChgLen ) );
791 
792                     if (aChgText.Len())
793                     {
794                         aInBuffer = aChgText;
795                         nExpandSelection = aLeftText.Len() - static_cast< xub_StrLen >(nChgPos);
796                     }
797                     else
798                         aInBuffer.Erase();
799                 }
800                 else
801                 {
802                     for (xub_StrLen k = 0;  k < aInBuffer.Len();  ++k)
803                     {
804                         cChar = aInBuffer.GetChar(k);
805                         if (xISC->checkInputSequence( aNewText, nTmpPos - 1, cChar, nCheckMode ))
806                         {
807                             // character can be inserted:
808                             aNewText += rtl::OUString( (sal_Unicode) cChar );
809                             ++nTmpPos;
810                         }
811                     }
812                     aInBuffer = aNewText.copy( aOldText.getLength() );  // copy new text to be inserted to buffer
813                 }
814             }
815 
816             // at this point now we will insert the buffer text 'normally' some lines below...
817 
818             rSh.Pop( sal_False );  // pop old cursor from stack
819 
820             if (!aInBuffer.Len())
821                 return;
822 
823             // if text prior to the original selection needs to be changed
824             // as well, we now expand the selection accordingly.
825             SwPaM &rCrsr = *rSh.GetCrsr();
826             xub_StrLen nCrsrStartPos = rCrsr.Start()->nContent.GetIndex();
827             DBG_ASSERT( nCrsrStartPos >= nExpandSelection, "cannot expand selection as specified!!" );
828             if (nExpandSelection && nCrsrStartPos >= nExpandSelection)
829             {
830                 if (!rCrsr.HasMark())
831                     rCrsr.SetMark();
832                 rCrsr.Start()->nContent -= nExpandSelection;
833             }
834         }
835 
836         uno::Reference< frame::XDispatchRecorder > xRecorder =
837                 rView.GetViewFrame()->GetBindings().GetRecorder();
838         if ( xRecorder.is() )
839         {
840             //Shell ermitteln
841             SfxShell *pSfxShell = lcl_GetShellFromDispatcher( rView, TYPE(SwTextShell) );
842             // Request generieren und recorden
843             if (pSfxShell)
844             {
845                 SfxRequest aReq( rView.GetViewFrame(), FN_INSERT_STRING );
846                 aReq.AppendItem( SfxStringItem( FN_INSERT_STRING, aInBuffer ) );
847                 aReq.Done();
848             }
849         }
850         //#21019# apply CTL and CJK language to the text input
851         sal_Bool bLang = true;
852         if(eBufferLanguage != LANGUAGE_DONTKNOW)
853         {
854             sal_uInt16 nWhich = 0;
855             switch( GetI18NScriptTypeOfLanguage( eBufferLanguage ))
856             {
857                 case  i18n::ScriptType::ASIAN:     nWhich = RES_CHRATR_CJK_LANGUAGE; break;
858                 case  i18n::ScriptType::COMPLEX:   nWhich = RES_CHRATR_CTL_LANGUAGE; break;
859                 case  i18n::ScriptType::LATIN:     nWhich = RES_CHRATR_LANGUAGE; break;
860                 default: bLang = sal_False;
861             }
862             if(bLang)
863             {
864                 SfxItemSet aLangSet(rView.GetPool(), nWhich, nWhich);
865                 rSh.GetCurAttr(aLangSet);
866                 if(SFX_ITEM_DEFAULT <= aLangSet.GetItemState(nWhich, sal_True))
867                 {
868                     LanguageType eLang = static_cast<const SvxLanguageItem&>(aLangSet.Get(nWhich)).GetLanguage();
869                     if ( eLang == eBufferLanguage )
870                         // current language attribute equal to language reported from system
871                         bLang = sal_False;
872                     else if ( !bInputLanguageSwitched && RES_CHRATR_LANGUAGE == nWhich /* && (eLang&LANGUAGE_MASK_PRIMARY) == LANGUAGE_ENGLISH */ )
873                     {
874                         // special case: switching between two "LATIN" languages
875                         // In case the current keyboard setting might be suitable for both languages we can't safely assume that the user
876                         // wants to use the language reported from the system, except if we knew that it was explicitly switched (thus the check for "bInputLangeSwitched").
877                         // The language reported by the system could be just the system default language that the user is not even aware of,
878                         // because no language selection tool is installed at all. In this case the OOo language should get preference as
879                         // it might have been selected by the user explicitly.
880                         // Usually this case happens if the OOo language is different to the system language but the system keyboard is still suitable
881                         // for the OOo language (e.g. writing English texts with a German keyboard).
882                         // For non-latin keyboards overwriting the attribute is still valid. We do this for kyrillic and greek ATM.
883                         // In future versions of OOo this should be replaced by a configuration switch that allows to give the preference to
884                         // the OOo setting or the system setting explicitly and/or a better handling of the script type.
885                         sal_Int16 nScript = GetAppCharClass().getScript( aInBuffer, 0 );
886                         i18n::UnicodeScript eType = (i18n::UnicodeScript) nScript;
887 
888                         bool bSystemIsNonLatin = false, bOOoLangIsNonLatin = false;
889                         switch ( eType )
890                         {
891                             case i18n::UnicodeScript_kGreek:
892                             case i18n::UnicodeScript_kCyrillic:
893                                 // in case other UnicodeScripts require special keyboards they can be added here
894                                 bSystemIsNonLatin = true;
895                                 break;
896                             default:
897                                 break;
898                         }
899 
900                         switch ( eLang )
901                         {
902                             case LANGUAGE_AZERI_CYRILLIC:
903                             case LANGUAGE_BOSNIAN_CYRILLIC_BOSNIA_HERZEGOVINA:
904                             case LANGUAGE_BULGARIAN:
905                             case LANGUAGE_GREEK:
906                             case LANGUAGE_RUSSIAN:
907                             case LANGUAGE_RUSSIAN_MOLDOVA:
908                             case LANGUAGE_SERBIAN_CYRILLIC:
909                             case LANGUAGE_SERBIAN_CYRILLIC_BOSNIA_HERZEGOVINA:
910                             case LANGUAGE_UZBEK_CYRILLIC:
911                             case LANGUAGE_UKRAINIAN:
912                             case LANGUAGE_BELARUSIAN:
913                                 bOOoLangIsNonLatin = true;
914                                 break;
915                             default:
916                                 break;
917                         }
918 
919                         bLang = (bSystemIsNonLatin != bOOoLangIsNonLatin);
920                     }
921                 }
922                 if(bLang)
923                 {
924                     SvxLanguageItem aLangItem( eBufferLanguage, nWhich );
925                     rSh.SetAttrItem( aLangItem );
926                 }
927             }
928         }
929 
930         rSh.Insert( aInBuffer );
931         eBufferLanguage = LANGUAGE_DONTKNOW;
932         aInBuffer.Erase();
933         bFlushCharBuffer = sal_False;
934     }
935 }
936 
937 #define MOVE_LEFT_SMALL     0
938 #define MOVE_UP_SMALL       1
939 #define MOVE_RIGHT_BIG      2
940 #define MOVE_DOWN_BIG       3
941 #define MOVE_LEFT_BIG       4
942 #define MOVE_UP_BIG         5
943 #define MOVE_RIGHT_SMALL    6
944 #define MOVE_DOWN_SMALL     7
945 
946 // #121236# Support for shift key in writer
947 #define MOVE_LEFT_HUGE      8
948 #define MOVE_UP_HUGE        9
949 #define MOVE_RIGHT_HUGE     10
950 #define MOVE_DOWN_HUGE      11
951 
952 void SwEditWin::ChangeFly( sal_uInt8 nDir, sal_Bool bWeb )
953 {
954     SwWrtShell &rSh = rView.GetWrtShell();
955     SwRect aTmp = rSh.GetFlyRect();
956     if( aTmp.HasArea() &&
957         !rSh.IsSelObjProtected( FLYPROTECT_POS ) )
958     {
959         SfxItemSet aSet(rSh.GetAttrPool(),
960                         RES_FRM_SIZE, RES_FRM_SIZE,
961                         RES_VERT_ORIENT, RES_ANCHOR,
962                         RES_COL, RES_COL,
963                         RES_PROTECT, RES_PROTECT,
964                         RES_FOLLOW_TEXT_FLOW, RES_FOLLOW_TEXT_FLOW, 0);
965         rSh.GetFlyFrmAttr( aSet );
966         RndStdIds eAnchorId = ((SwFmtAnchor&)aSet.Get(RES_ANCHOR)).GetAnchorId();
967         Size aSnap;
968         bool bHuge(MOVE_LEFT_HUGE == nDir ||
969             MOVE_UP_HUGE == nDir ||
970             MOVE_RIGHT_HUGE == nDir ||
971             MOVE_DOWN_HUGE == nDir);
972 
973         if(MOVE_LEFT_SMALL == nDir ||
974             MOVE_UP_SMALL == nDir ||
975             MOVE_RIGHT_SMALL == nDir ||
976             MOVE_DOWN_SMALL == nDir )
977         {
978             aSnap = PixelToLogic(Size(1,1));
979         }
980         else
981         {
982             aSnap = rSh.GetViewOptions()->GetSnapSize();
983             short nDiv = rSh.GetViewOptions()->GetDivisionX();
984             if ( nDiv > 0 )
985                 aSnap.Width() = Max( (sal_uLong)1, (sal_uLong)aSnap.Width() / nDiv );
986             nDiv = rSh.GetViewOptions()->GetDivisionY();
987             if ( nDiv > 0 )
988                 aSnap.Height() = Max( (sal_uLong)1, (sal_uLong)aSnap.Height() / nDiv );
989         }
990 
991         if(bHuge)
992         {
993             // #121236# 567twips == 1cm, but just take three times the normal snap
994             aSnap = Size(aSnap.Width() * 3, aSnap.Height() * 3);
995         }
996 
997         SwRect aBoundRect;
998         Point aRefPoint;
999         {
1000             SwFmtVertOrient aVert( (SwFmtVertOrient&)aSet.Get(RES_VERT_ORIENT) );
1001             const bool bFollowTextFlow =
1002                     static_cast<const SwFmtFollowTextFlow&>(aSet.Get(RES_FOLLOW_TEXT_FLOW)).GetValue();
1003             const SwPosition* pToCharCntntPos = ((SwFmtAnchor&)aSet.Get(RES_ANCHOR)).GetCntntAnchor();
1004             rSh.CalcBoundRect( aBoundRect, eAnchorId,
1005                                text::RelOrientation::FRAME, aVert.GetRelationOrient(),
1006                                pToCharCntntPos, bFollowTextFlow,
1007                                false, &aRefPoint );
1008         }
1009         long nLeft = Min( aTmp.Left() - aBoundRect.Left(), aSnap.Width() );
1010         long nRight = Min( aBoundRect.Right() - aTmp.Right(), aSnap.Width() );
1011         long nUp = Min( aTmp.Top() - aBoundRect.Top(), aSnap.Height() );
1012         long nDown = Min( aBoundRect.Bottom() - aTmp.Bottom(), aSnap.Height() );
1013 
1014         switch ( nDir )
1015         {
1016             case MOVE_LEFT_BIG:
1017             case MOVE_LEFT_HUGE:
1018             case MOVE_LEFT_SMALL: aTmp.Left( aTmp.Left() - nLeft );
1019                 break;
1020 
1021             case MOVE_UP_BIG:
1022             case MOVE_UP_HUGE:
1023             case MOVE_UP_SMALL: aTmp.Top( aTmp.Top() - nUp );
1024                 break;
1025 
1026             case MOVE_RIGHT_SMALL:
1027                 if( aTmp.Width() < aSnap.Width() + MINFLY )
1028                     break;
1029                 nRight = aSnap.Width(); // kein break
1030             case MOVE_RIGHT_HUGE:
1031             case MOVE_RIGHT_BIG: aTmp.Left( aTmp.Left() + nRight );
1032                 break;
1033 
1034             case MOVE_DOWN_SMALL:
1035                 if( aTmp.Height() < aSnap.Height() + MINFLY )
1036                     break;
1037                 nDown = aSnap.Height(); // kein break
1038             case MOVE_DOWN_HUGE:
1039             case MOVE_DOWN_BIG: aTmp.Top( aTmp.Top() + nDown );
1040                 break;
1041 
1042             default: ASSERT( sal_True, "ChangeFly: Unknown direction." );
1043         }
1044         sal_Bool bSet = sal_False;
1045         if ((FLY_AS_CHAR == eAnchorId) && ( nDir % 2 ))
1046         {
1047             long aDiff = aTmp.Top() - aRefPoint.Y();
1048             if( aDiff > 0 )
1049                 aDiff = 0;
1050             else if ( aDiff < -aTmp.Height() )
1051                 aDiff = -aTmp.Height();
1052             SwFmtVertOrient aVert( (SwFmtVertOrient&)aSet.Get(RES_VERT_ORIENT) );
1053             sal_Int16 eNew;
1054             if( bWeb )
1055             {
1056                 eNew = aVert.GetVertOrient();
1057                 sal_Bool bDown = 0 != ( nDir & 0x02 );
1058                 switch( eNew )
1059                 {
1060                     case text::VertOrientation::CHAR_TOP:
1061                         if( bDown ) eNew = text::VertOrientation::CENTER;
1062                     break;
1063                     case text::VertOrientation::CENTER:
1064                         eNew = bDown ? text::VertOrientation::TOP : text::VertOrientation::CHAR_TOP;
1065                     break;
1066                     case text::VertOrientation::TOP:
1067                         if( !bDown ) eNew = text::VertOrientation::CENTER;
1068                     break;
1069                     case text::VertOrientation::LINE_TOP:
1070                         if( bDown ) eNew = text::VertOrientation::LINE_CENTER;
1071                     break;
1072                     case text::VertOrientation::LINE_CENTER:
1073                         eNew = bDown ? text::VertOrientation::LINE_BOTTOM : text::VertOrientation::LINE_TOP;
1074                     break;
1075                     case text::VertOrientation::LINE_BOTTOM:
1076                         if( !bDown ) eNew = text::VertOrientation::LINE_CENTER;
1077                     break;
1078                     default:; //prevent warning
1079                 }
1080             }
1081             else
1082             {
1083                 aVert.SetPos( aDiff );
1084                 eNew = text::VertOrientation::NONE;
1085             }
1086             aVert.SetVertOrient( eNew );
1087             aSet.Put( aVert );
1088             bSet = sal_True;
1089         }
1090         if (bWeb && (FLY_AT_PARA == eAnchorId)
1091             && ( nDir==MOVE_LEFT_SMALL || nDir==MOVE_RIGHT_BIG ))
1092         {
1093             SwFmtHoriOrient aHori( (SwFmtHoriOrient&)aSet.Get(RES_HORI_ORIENT) );
1094             sal_Int16 eNew;
1095             eNew = aHori.GetHoriOrient();
1096             switch( eNew )
1097             {
1098                 case text::HoriOrientation::RIGHT:
1099                     if( nDir==MOVE_LEFT_SMALL )
1100                         eNew = text::HoriOrientation::LEFT;
1101                 break;
1102                 case text::HoriOrientation::LEFT:
1103                     if( nDir==MOVE_RIGHT_BIG )
1104                         eNew = text::HoriOrientation::RIGHT;
1105                 break;
1106                 default:; //prevent warning
1107             }
1108             if( eNew != aHori.GetHoriOrient() )
1109             {
1110                 aHori.SetHoriOrient( eNew );
1111                 aSet.Put( aHori );
1112                 bSet = sal_True;
1113             }
1114         }
1115         rSh.StartAllAction();
1116         if( bSet )
1117             rSh.SetFlyFrmAttr( aSet );
1118         sal_Bool bSetPos = (FLY_AS_CHAR != eAnchorId);
1119         if(bSetPos && bWeb)
1120         {
1121             if (FLY_AT_PAGE != eAnchorId)
1122             {
1123                 bSetPos = sal_False;
1124             }
1125             else
1126             {
1127                 bSetPos = (::GetHtmlMode(rView.GetDocShell()) & HTMLMODE_SOME_ABS_POS) ?
1128                     sal_True : sal_False;
1129             }
1130         }
1131         if( bSetPos )
1132             rSh.SetFlyPos( aTmp.Pos() );
1133         rSh.EndAllAction();
1134     }
1135 }
1136 /* -----------------------------23.05.2002 11:35------------------------------
1137 
1138  ---------------------------------------------------------------------------*/
1139 void SwEditWin::ChangeDrawing( sal_uInt8 nDir )
1140 {
1141     SwWrtShell &rSh = rView.GetWrtShell();
1142     rSh.StartUndo();
1143 
1144     long nX = 0;
1145     long nY = 0;
1146     const sal_Bool bOnePixel(
1147         MOVE_LEFT_SMALL == nDir ||
1148         MOVE_UP_SMALL == nDir ||
1149         MOVE_RIGHT_SMALL == nDir ||
1150         MOVE_DOWN_SMALL == nDir);
1151     const sal_Bool bHuge(
1152         MOVE_LEFT_HUGE == nDir ||
1153         MOVE_UP_HUGE == nDir ||
1154         MOVE_RIGHT_HUGE == nDir ||
1155         MOVE_DOWN_HUGE == nDir);
1156     sal_uInt16 nAnchorDir = SW_MOVE_UP;
1157     switch(nDir)
1158     {
1159         case MOVE_LEFT_SMALL:
1160         case MOVE_LEFT_HUGE:
1161         case MOVE_LEFT_BIG:
1162             nX = -1;
1163             nAnchorDir = SW_MOVE_LEFT;
1164         break;
1165         case MOVE_UP_SMALL:
1166         case MOVE_UP_HUGE:
1167         case MOVE_UP_BIG:
1168             nY = -1;
1169         break;
1170         case MOVE_RIGHT_SMALL:
1171         case MOVE_RIGHT_HUGE:
1172         case MOVE_RIGHT_BIG:
1173             nX = +1;
1174             nAnchorDir = SW_MOVE_RIGHT;
1175         break;
1176         case MOVE_DOWN_SMALL:
1177         case MOVE_DOWN_HUGE:
1178         case MOVE_DOWN_BIG:
1179             nY = +1;
1180             nAnchorDir = SW_MOVE_DOWN;
1181         break;
1182     }
1183 
1184     if(0 != nX || 0 != nY)
1185     {
1186         sal_uInt8 nProtect = rSh.IsSelObjProtected( FLYPROTECT_POS|FLYPROTECT_SIZE );
1187         Size aSnap( rSh.GetViewOptions()->GetSnapSize() );
1188         short nDiv = rSh.GetViewOptions()->GetDivisionX();
1189         if ( nDiv > 0 )
1190             aSnap.Width() = Max( (sal_uLong)1, (sal_uLong)aSnap.Width() / nDiv );
1191         nDiv = rSh.GetViewOptions()->GetDivisionY();
1192         if ( nDiv > 0 )
1193             aSnap.Height() = Max( (sal_uLong)1, (sal_uLong)aSnap.Height() / nDiv );
1194 
1195         if(bOnePixel)
1196         {
1197             aSnap = PixelToLogic(Size(1,1));
1198         }
1199         else if(bHuge)
1200         {
1201             // #121236# 567twips == 1cm, but just take three times the normal snap
1202             aSnap = Size(aSnap.Width() * 3, aSnap.Height() * 3);
1203         }
1204 
1205         nX *= aSnap.Width();
1206         nY *= aSnap.Height();
1207 
1208         SdrView *pSdrView = rSh.GetDrawView();
1209         const SdrHdlList& rHdlList = pSdrView->GetHdlList();
1210         SdrHdl* pHdl = rHdlList.GetFocusHdl();
1211         rSh.StartAllAction();
1212         if(0L == pHdl)
1213         {
1214             // now move the selected draw objects
1215             // if the object's position is not protected
1216             if(0 == (nProtect&FLYPROTECT_POS))
1217             {
1218                 sal_Bool bDummy1, bDummy2;
1219                 const bool bVertAnchor = rSh.IsFrmVertical( sal_True, bDummy1, bDummy2 );
1220                 const bool bHoriMove = !bVertAnchor == !( nDir % 2 );
1221                 const bool bMoveAllowed =
1222                     !bHoriMove || (rSh.GetAnchorId() != FLY_AS_CHAR);
1223                 if ( bMoveAllowed )
1224                 {
1225                     pSdrView->MoveAllMarked(Size(nX, nY));
1226                     rSh.SetModified();
1227                 }
1228             }
1229         }
1230         else
1231         {
1232             // move handle with index nHandleIndex
1233             if(pHdl && (nX || nY))
1234             {
1235                 if( HDL_ANCHOR == pHdl->GetKind() ||
1236                     HDL_ANCHOR_TR == pHdl->GetKind() )
1237                 {
1238                     // anchor move cannot be allowed when position is protected
1239                     if(0 == (nProtect&FLYPROTECT_POS))
1240                         rSh.MoveAnchor( nAnchorDir );
1241                 }
1242                 //now resize if size is protected
1243                 else if(0 == (nProtect&FLYPROTECT_SIZE))
1244                 {
1245                     // now move the Handle (nX, nY)
1246                     Point aStartPoint(pHdl->GetPos());
1247                     Point aEndPoint(pHdl->GetPos() + Point(nX, nY));
1248                     const SdrDragStat& rDragStat = pSdrView->GetDragStat();
1249 
1250                     // start dragging
1251                     pSdrView->BegDragObj(aStartPoint, 0, pHdl, 0);
1252 
1253                     if(pSdrView->IsDragObj())
1254                     {
1255                         sal_Bool bWasNoSnap = static_cast< sal_Bool >(rDragStat.IsNoSnap());
1256                         sal_Bool bWasSnapEnabled = pSdrView->IsSnapEnabled();
1257 
1258                         // switch snapping off
1259                         if(!bWasNoSnap)
1260                             ((SdrDragStat&)rDragStat).SetNoSnap(sal_True);
1261                         if(bWasSnapEnabled)
1262                             pSdrView->SetSnapEnabled(sal_False);
1263 
1264                         pSdrView->MovAction(aEndPoint);
1265                         pSdrView->EndDragObj();
1266                         rSh.SetModified();
1267 
1268                         // restore snap
1269                         if(!bWasNoSnap)
1270                             ((SdrDragStat&)rDragStat).SetNoSnap(bWasNoSnap);
1271                         if(bWasSnapEnabled)
1272                             pSdrView->SetSnapEnabled(bWasSnapEnabled);
1273                     }
1274                 }
1275             }
1276         }
1277         rSh.EndAllAction();
1278     }
1279 
1280     rSh.EndUndo();
1281 }
1282 
1283 /*--------------------------------------------------------------------
1284     Beschreibung:   KeyEvents
1285  --------------------------------------------------------------------*/
1286 
1287 
1288 
1289 void SwEditWin::KeyInput(const KeyEvent &rKEvt)
1290 {
1291     if( rKEvt.GetKeyCode().GetCode() == KEY_ESCAPE &&
1292         pApplyTempl && pApplyTempl->pFormatClipboard )
1293     {
1294         pApplyTempl->pFormatClipboard->Erase();
1295         SetApplyTemplate(SwApplyTemplate());
1296         rView.GetViewFrame()->GetBindings().Invalidate(SID_FORMATPAINTBRUSH);
1297     }
1298 
1299     SfxObjectShell *pObjSh = (SfxObjectShell*)rView.GetViewFrame()->GetObjectShell();
1300     if ( bLockInput || (pObjSh && pObjSh->GetProgress()) )
1301         // Wenn die Rechenleiste aktiv ist oder
1302         // auf dem Document ein Progress laeuft wird keine
1303         // Bestellungen angenommen.
1304         return;
1305 
1306     if( pShadCrsr )
1307         delete pShadCrsr, pShadCrsr = 0;
1308     aKeyInputFlushTimer.Stop();
1309 
1310     SwWrtShell &rSh = rView.GetWrtShell();
1311     sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly() &&
1312                           rSh.IsCrsrReadonly();
1313 
1314     //if the language changes the buffer must be flushed
1315     LanguageType eNewLanguage = GetInputLanguage();
1316     if(!bIsDocReadOnly && eBufferLanguage != eNewLanguage && aInBuffer.Len())
1317     {
1318         FlushInBuffer();
1319     }
1320     eBufferLanguage = eNewLanguage;
1321 
1322     QuickHelpData aTmpQHD;
1323     if( pQuickHlpData->bClear )
1324     {
1325         aTmpQHD.Move( *pQuickHlpData );
1326         pQuickHlpData->Stop( rSh );
1327     }
1328 
1329     // OS:auch die DrawView braucht noch ein readonly-Flag
1330     if ( !bIsDocReadOnly && rSh.GetDrawView() && rSh.GetDrawView()->KeyInput( rKEvt, this ) )
1331     {
1332         rSh.GetView().GetViewFrame()->GetBindings().InvalidateAll( sal_False );
1333         rSh.SetModified();
1334         return; // Event von der SdrView ausgewertet
1335     }
1336 
1337     if ( rView.GetDrawFuncPtr() && bInsFrm )
1338     {
1339         StopInsFrm();
1340         rSh.Edit();
1341     }
1342 
1343     sal_Bool bFlushBuffer = sal_False;
1344     sal_Bool bNormalChar = sal_False;
1345     sal_Bool bChkInsBlank = pQuickHlpData->bChkInsBlank;
1346     pQuickHlpData->bChkInsBlank = sal_False;
1347 
1348     KeyEvent aKeyEvent( rKEvt );
1349     // look for vertical mappings
1350     if( !bIsDocReadOnly && !rSh.IsSelFrmMode() && !rSh.IsObjSelected() )
1351     {
1352         //JP 21.2.2002: must changed from switch to if, because the Linux
1353         // compiler has problem with the code. Has to remove if the new general
1354         // handler exist.
1355         sal_uInt16 nKey = rKEvt.GetKeyCode().GetCode();
1356 
1357         if( KEY_UP == nKey || KEY_DOWN == nKey ||
1358             KEY_LEFT == nKey || KEY_RIGHT == nKey )
1359         {
1360             // In general, we want to map the direction keys if we are inside
1361             // some vertical formatted text.
1362             // 1. Exception: For a table cursor in a horizontal table, the
1363             //               directions should never be mapped.
1364             // 2. Exception: For a table cursor in a vertical table, the
1365             //               directions should always be mapped.
1366             const bool bVertText = rSh.IsInVerticalText();
1367             const bool bTblCrsr = rSh.GetTableCrsr();
1368             const bool bVertTable = rSh.IsTableVertical();
1369             if( ( bVertText && ( !bTblCrsr || bVertTable ) ) ||
1370                 ( bTblCrsr && bVertTable ) )
1371             {
1372                 // Attempt to integrate cursor travelling for mongolian layout does not work.
1373                 // Thus, back to previous mapping of cursor keys to direction keys.
1374                 if( KEY_UP == nKey ) nKey = KEY_LEFT;
1375                 else if( KEY_DOWN == nKey ) nKey = KEY_RIGHT;
1376                 else if( KEY_LEFT == nKey ) nKey = KEY_DOWN;
1377                 else if( KEY_RIGHT == nKey ) nKey = KEY_UP;
1378             }
1379 
1380             if ( rSh.IsInRightToLeftText() )
1381             {
1382                 if( KEY_LEFT == nKey ) nKey = KEY_RIGHT;
1383                 else if( KEY_RIGHT == nKey ) nKey = KEY_LEFT;
1384             }
1385 
1386             aKeyEvent = KeyEvent( rKEvt.GetCharCode(),
1387                                   KeyCode( nKey, rKEvt.GetKeyCode().GetModifier() ),
1388                                   rKEvt.GetRepeat() );
1389         }
1390     }
1391 
1392     const KeyCode& rKeyCode = aKeyEvent.GetKeyCode();
1393     sal_Unicode aCh = aKeyEvent.GetCharCode();
1394 
1395     // enable switching to notes ankor with Ctrl - Alt - Page Up/Down
1396     // pressing this inside a note will switch to next/previous note
1397     if ((rKeyCode.IsMod1() && rKeyCode.IsMod2()) && ((rKeyCode.GetCode() == KEY_PAGEUP) || (rKeyCode.GetCode() == KEY_PAGEDOWN)))
1398     {
1399         const bool bNext = rKeyCode.GetCode()==KEY_PAGEDOWN ? true : false;
1400         const SwFieldType* pFldType = rSh.GetFldType( 0, RES_POSTITFLD );
1401         rSh.MoveFldType( pFldType, bNext );
1402         return;
1403     }
1404 
1405     const SwFrmFmt* pFlyFmt = rSh.GetFlyFrmFmt();
1406     if( pFlyFmt )
1407     {
1408         sal_uInt16 nEvent;
1409 
1410         if( 32 <= aCh &&
1411             0 == (( KEY_MOD1 | KEY_MOD2 ) & rKeyCode.GetModifier() ))
1412             nEvent = SW_EVENT_FRM_KEYINPUT_ALPHA;
1413         else
1414             nEvent = SW_EVENT_FRM_KEYINPUT_NOALPHA;
1415 
1416         const SvxMacro* pMacro = pFlyFmt->GetMacro().GetMacroTable().Get( nEvent );
1417         if( pMacro )
1418         {
1419             String sRet;
1420             SbxArrayRef xArgs = new SbxArray;
1421             SbxVariableRef xVar = new SbxVariable;
1422             xVar->PutString( pFlyFmt->GetName() );
1423             xArgs->Put( &xVar, 1 );
1424 
1425             xVar = new SbxVariable;
1426             if( SW_EVENT_FRM_KEYINPUT_ALPHA == nEvent )
1427                 xVar->PutChar( aCh );
1428             else
1429                 xVar->PutUShort( rKeyCode.GetModifier() | rKeyCode.GetCode() );
1430             xArgs->Put( &xVar, 2 );
1431 
1432             rSh.ExecMacro( *pMacro, &sRet, &xArgs );
1433             if( sRet.Len() && 0 != sRet.ToInt32() )
1434                 return ;
1435         }
1436     }
1437     int nLclSelectionType;
1438     //A is converted to 1
1439     if( rKeyCode.GetFullCode() == (KEY_A | KEY_MOD1 |KEY_SHIFT)
1440         && rSh.HasDrawView() &&
1441         (0 != (nLclSelectionType = rSh.GetSelectionType()) &&
1442         ((nLclSelectionType & (nsSelectionType::SEL_FRM|nsSelectionType::SEL_GRF)) ||
1443         ((nLclSelectionType & (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM)) &&
1444                 rSh.GetDrawView()->GetMarkedObjectList().GetMarkCount() == 1))))
1445     {
1446         SdrHdlList& rHdlList = (SdrHdlList&)rSh.GetDrawView()->GetHdlList();
1447         SdrHdl* pAnchor = rHdlList.GetHdl(HDL_ANCHOR);
1448         if ( ! pAnchor )
1449             pAnchor = rHdlList.GetHdl(HDL_ANCHOR_TR);
1450         if(pAnchor)
1451             rHdlList.SetFocusHdl(pAnchor);
1452         return;
1453     }
1454 
1455     SvxAutoCorrCfg* pACfg = 0;
1456     SvxAutoCorrect* pACorr = 0;
1457 
1458     uno::Reference< frame::XDispatchRecorder > xRecorder =
1459             rView.GetViewFrame()->GetBindings().GetRecorder();
1460     if ( !xRecorder.is() )
1461     {
1462         pACfg = SvxAutoCorrCfg::Get();
1463         pACorr = pACfg->GetAutoCorrect();
1464     }
1465 
1466     SwModuleOptions* pModOpt = SW_MOD()->GetModuleConfig();
1467 
1468     TblChgWidthHeightType eTblChgMode = nsTblChgWidthHeightType::WH_COL_LEFT;    // initialization just for warning-free code
1469     sal_uInt16 nTblChgSize = 0;
1470     sal_Bool bStopKeyInputTimer = sal_True;
1471     String sFmlEntry;
1472 
1473     enum SW_KeyState { KS_Start,
1474                        KS_CheckKey, KS_InsChar, KS_InsTab,
1475                        KS_NoNum, KS_NumOff, KS_NumOrNoNum, KS_NumDown, KS_NumUp,
1476                        // -> #i23725#
1477                        KS_NumIndentInc, KS_NumIndentDec,
1478                        // <- #i23725#
1479 
1480                        KS_OutlineLvOff,
1481                        KS_NextCell, KS_PrevCell, KS_OutlineUp, KS_OutlineDown,
1482                        KS_GlossaryExpand, KS_NextPrevGlossary,
1483                        KS_AutoFmtByInput,
1484                        KS_NextObject, KS_PrevObject,
1485                        KS_KeyToView,
1486                        KS_LaunchOLEObject, KS_GoIntoFly, KS_GoIntoDrawing,
1487                        KS_EnterDrawHandleMode,
1488                        KS_CheckDocReadOnlyKeys,
1489                        KS_CheckAutoCorrect, KS_EditFormula,
1490                        KS_ColLeftBig, KS_ColRightBig,
1491                        KS_ColLeftSmall, KS_ColRightSmall,
1492                        KS_ColTopBig, KS_ColBottomBig,
1493                        KS_ColTopSmall, KS_ColBottomSmall,
1494                        KS_CellLeftBig, KS_CellRightBig,
1495                        KS_CellLeftSmall, KS_CellRightSmall,
1496                        KS_CellTopBig, KS_CellBottomBig,
1497                        KS_CellTopSmall, KS_CellBottomSmall,
1498 
1499                        KS_InsDel_ColLeftBig, KS_InsDel_ColRightBig,
1500                        KS_InsDel_ColLeftSmall, KS_InsDel_ColRightSmall,
1501                        KS_InsDel_ColTopBig, KS_InsDel_ColBottomBig,
1502                        KS_InsDel_ColTopSmall, KS_InsDel_ColBottomSmall,
1503                        KS_InsDel_CellLeftBig, KS_InsDel_CellRightBig,
1504                        KS_InsDel_CellLeftSmall, KS_InsDel_CellRightSmall,
1505                        KS_InsDel_CellTopBig, KS_InsDel_CellBottomBig,
1506                        KS_InsDel_CellTopSmall, KS_InsDel_CellBottomSmall,
1507                        KS_TblColCellInsDel,
1508 
1509                        KS_Fly_Change, KS_Draw_Change,
1510                        KS_SpecialInsert,
1511                        KS_EnterCharCell,
1512                        KS_GotoNextFieldMark,
1513                        KS_GotoPrevFieldMark,
1514                        KS_Ende };
1515 
1516 
1517 
1518     SW_KeyState eKeyState = bIsDocReadOnly ? KS_CheckDocReadOnlyKeys : KS_CheckKey;
1519     SW_KeyState eNextKeyState = KS_Ende;
1520     sal_uInt8 nDir = 0;
1521 
1522     if (nKS_NUMDOWN_Count > 0)
1523         nKS_NUMDOWN_Count--;
1524 
1525     if (nKS_NUMINDENTINC_Count > 0)
1526         nKS_NUMINDENTINC_Count--;
1527 
1528     while( KS_Ende != eKeyState )
1529     {
1530         SW_KeyState eFlyState = KS_KeyToView;
1531 
1532         switch( eKeyState )
1533         {
1534         case KS_CheckKey:
1535             eKeyState = KS_KeyToView;       // default weiter zur View
1536 
1537 #ifdef DBG_UTIL
1538 //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1539             // JP 19.01.99: zum Umschalten des Cursor Verhaltens in ReadOnly
1540             //              Bereichen
1541             if( 0x7210 == rKeyCode.GetFullCode() )
1542                 rSh.SetReadOnlyAvailable( !rSh.IsReadOnlyAvailable() );
1543             else
1544 //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1545 #endif
1546 
1547             if( !rKeyCode.IsMod2() && '=' == aCh &&
1548                 !rSh.IsTableMode() && rSh.GetTableFmt() &&
1549                 rSh.IsSttPara() /*&& rSh.IsEndPara()*/ &&
1550                 !rSh.HasReadonlySel() )
1551             {
1552                 // in der Tabelle am Anfang der Zelle ein '=' ->
1553                 //  EditZeile aufrufen (F2-Funktionalitaet)
1554                 rSh.Push();
1555                 if( !rSh.MoveSection( fnSectionCurr, fnSectionStart) &&
1556                     !rSh.IsTableBoxTextFormat() )
1557                 {
1558                     // steht also am Anfang der Box
1559                     eKeyState = KS_EditFormula;
1560                     if( rSh.HasMark() )
1561                         rSh.SwapPam();
1562                     else
1563                         rSh.SttSelect();
1564                     rSh.MoveSection( fnSectionCurr, fnSectionEnd );
1565                     rSh.Pop( sal_True );
1566                     rSh.EndSelect();
1567                     sFmlEntry = '=';
1568                 }
1569                 else
1570                     rSh.Pop( sal_False );
1571             }
1572             else
1573             {
1574                 if( pACorr && aTmpQHD.HasCntnt() && !rSh.HasSelection() &&
1575                     !rSh.HasReadonlySel() && !aTmpQHD.bIsAutoText &&
1576                     pACorr->GetSwFlags().nAutoCmpltExpandKey ==
1577                     (rKeyCode.GetModifier() | rKeyCode.GetCode()) )
1578                 {
1579                     eKeyState = KS_GlossaryExpand;
1580                     break;
1581                 }
1582 
1583                 switch( rKeyCode.GetModifier() | rKeyCode.GetCode() )
1584                 {
1585                 case KEY_RIGHT | KEY_MOD2:
1586                     eKeyState = KS_ColRightBig;
1587                     eFlyState = KS_Fly_Change;
1588                     nDir = MOVE_RIGHT_SMALL;
1589                     goto KEYINPUT_CHECKTABLE;
1590 
1591                 case KEY_LEFT | KEY_MOD2:
1592                     eKeyState = KS_ColRightSmall;
1593                     eFlyState = KS_Fly_Change;
1594                     nDir = MOVE_LEFT_SMALL;
1595                     goto KEYINPUT_CHECKTABLE;
1596 
1597                 case KEY_RIGHT | KEY_MOD2 | KEY_SHIFT:
1598                     eKeyState = KS_ColLeftSmall;
1599                     goto KEYINPUT_CHECKTABLE;
1600 
1601                 case KEY_LEFT | KEY_MOD2 | KEY_SHIFT:
1602                     eKeyState = KS_ColLeftBig;
1603                     goto KEYINPUT_CHECKTABLE;
1604 
1605                 case KEY_RIGHT | KEY_MOD2 | KEY_MOD1:
1606                     eKeyState = KS_CellRightBig;
1607                     goto KEYINPUT_CHECKTABLE;
1608 
1609                 case KEY_LEFT | KEY_MOD2 | KEY_MOD1:
1610                     eKeyState = KS_CellRightSmall;
1611                     goto KEYINPUT_CHECKTABLE;
1612 
1613                 case KEY_RIGHT | KEY_MOD2 | KEY_SHIFT | KEY_MOD1:
1614                     eKeyState = KS_CellLeftSmall;
1615                     goto KEYINPUT_CHECKTABLE;
1616 
1617                 case KEY_LEFT | KEY_MOD2 | KEY_SHIFT | KEY_MOD1:
1618                     eKeyState = KS_CellLeftBig;
1619                     goto KEYINPUT_CHECKTABLE;
1620 
1621                 case KEY_UP | KEY_MOD2:
1622                     eKeyState = KS_ColBottomSmall;
1623                     eFlyState = KS_Fly_Change;
1624                     nDir = MOVE_UP_SMALL;
1625                     goto KEYINPUT_CHECKTABLE;
1626 
1627                 case KEY_DOWN | KEY_MOD2:
1628                     eKeyState = KS_ColBottomBig;
1629                     eFlyState = KS_Fly_Change;
1630                     nDir = MOVE_DOWN_SMALL;
1631                     goto KEYINPUT_CHECKTABLE;
1632 
1633                 case KEY_UP | KEY_MOD2 | KEY_MOD1:
1634                     eKeyState = KS_CellBottomSmall;
1635                     goto KEYINPUT_CHECKTABLE;
1636 
1637                 case KEY_DOWN | KEY_MOD2 | KEY_MOD1:
1638                     eKeyState = KS_CellBottomBig;
1639                     goto KEYINPUT_CHECKTABLE;
1640 
1641                 case KEY_UP | KEY_MOD2 | KEY_SHIFT | KEY_MOD1:
1642                     eKeyState = KS_CellTopBig;
1643                     goto KEYINPUT_CHECKTABLE;
1644 
1645                 case KEY_DOWN | KEY_MOD2 | KEY_SHIFT | KEY_MOD1:
1646                     eKeyState = KS_CellTopSmall;
1647                     goto KEYINPUT_CHECKTABLE;
1648 
1649 KEYINPUT_CHECKTABLE:
1650                     if( rSh.IsTableMode() || !rSh.GetTableFmt() )
1651                     {
1652                         if(KS_KeyToView != eFlyState)
1653                         {
1654                             if(!pFlyFmt && KS_KeyToView != eFlyState &&
1655                                 (rSh.GetSelectionType() & (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM))  &&
1656                                     rSh.GetDrawView()->AreObjectsMarked())
1657                                 eKeyState = KS_Draw_Change;
1658                         }
1659 
1660                         if( pFlyFmt )
1661                             eKeyState = eFlyState;
1662                         else if( KS_Draw_Change != eKeyState)
1663                             eKeyState = KS_EnterCharCell;
1664                     }
1665                     break;
1666 
1667                 // huge object move
1668                 case KEY_RIGHT | KEY_SHIFT:
1669                 case KEY_LEFT | KEY_SHIFT:
1670                 case KEY_UP | KEY_SHIFT:
1671                 case KEY_DOWN | KEY_SHIFT:
1672                 {
1673                     const int nSelectionType = rSh.GetSelectionType();
1674                     if ( ( pFlyFmt
1675                            && ( nSelectionType & (nsSelectionType::SEL_FRM|nsSelectionType::SEL_OLE|nsSelectionType::SEL_GRF) ) )
1676                          || ( ( nSelectionType & (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM) )
1677                               && rSh.GetDrawView()->AreObjectsMarked() ) )
1678                     {
1679                         eKeyState = pFlyFmt ? KS_Fly_Change : KS_Draw_Change;
1680                         switch ( rKeyCode.GetCode() )
1681                         {
1682                             case KEY_RIGHT: nDir = MOVE_RIGHT_HUGE; break;
1683                             case KEY_LEFT: nDir = MOVE_LEFT_HUGE; break;
1684                             case KEY_UP: nDir = MOVE_UP_HUGE; break;
1685                             case KEY_DOWN: nDir = MOVE_DOWN_HUGE; break;
1686                         }
1687                     }
1688                     break;
1689                 }
1690 
1691 //-------
1692 // Insert/Delete
1693                 case KEY_LEFT:
1694                 case KEY_LEFT | KEY_MOD1:
1695                 {
1696                     sal_Bool bMod1 = 0 != (rKeyCode.GetModifier() & KEY_MOD1);
1697                     if(!bMod1)
1698                     {
1699                         eFlyState = KS_Fly_Change;
1700                         nDir = MOVE_LEFT_BIG;
1701                     }
1702                     eTblChgMode = nsTblChgWidthHeightType::WH_FLAG_INSDEL |
1703                             ( bMod1
1704                                 ? nsTblChgWidthHeightType::WH_CELL_LEFT
1705                                 : nsTblChgWidthHeightType::WH_COL_LEFT );
1706                     nTblChgSize = pModOpt->GetTblVInsert();
1707                 }
1708                     goto KEYINPUT_CHECKTABLE_INSDEL;
1709                 case KEY_RIGHT | KEY_MOD1:
1710                 {
1711                     eTblChgMode = nsTblChgWidthHeightType::WH_FLAG_INSDEL | nsTblChgWidthHeightType::WH_CELL_RIGHT;
1712                     nTblChgSize = pModOpt->GetTblVInsert();
1713                 }
1714                     goto KEYINPUT_CHECKTABLE_INSDEL;
1715                 case KEY_UP:
1716                 case KEY_UP | KEY_MOD1:
1717                 {
1718                     sal_Bool bMod1 = 0 != (rKeyCode.GetModifier() & KEY_MOD1);
1719                     if(!bMod1)
1720                     {
1721                         eFlyState = KS_Fly_Change;
1722                         nDir = MOVE_UP_BIG;
1723                     }
1724                     eTblChgMode = nsTblChgWidthHeightType::WH_FLAG_INSDEL |
1725                             ( bMod1
1726                                 ? nsTblChgWidthHeightType::WH_CELL_TOP
1727                                 : nsTblChgWidthHeightType::WH_ROW_TOP );
1728                     nTblChgSize = pModOpt->GetTblHInsert();
1729                 }
1730                     goto KEYINPUT_CHECKTABLE_INSDEL;
1731                 case KEY_DOWN:
1732                 case KEY_DOWN | KEY_MOD1:
1733                 {
1734                     sal_Bool bMod1 = 0 != (rKeyCode.GetModifier() & KEY_MOD1);
1735                     if(!bMod1)
1736                     {
1737                         eFlyState = KS_Fly_Change;
1738                         nDir = MOVE_DOWN_BIG;
1739                     }
1740                     eTblChgMode = nsTblChgWidthHeightType::WH_FLAG_INSDEL |
1741                             ( bMod1
1742                                 ? nsTblChgWidthHeightType::WH_CELL_BOTTOM
1743                                 : nsTblChgWidthHeightType::WH_ROW_BOTTOM );
1744                     nTblChgSize = pModOpt->GetTblHInsert();
1745                 }
1746                     goto KEYINPUT_CHECKTABLE_INSDEL;
1747 
1748 KEYINPUT_CHECKTABLE_INSDEL:
1749                     if( rSh.IsTableMode() || !rSh.GetTableFmt() ||
1750                         !bTblInsDelMode ||
1751                         sal_False /* Tabelle geschuetzt */
1752                             )
1753                     {
1754                         const int nSelectionType = rSh.GetSelectionType();
1755 
1756                         eKeyState = KS_KeyToView;
1757                         if(KS_KeyToView != eFlyState)
1758                         {
1759                             if((nSelectionType & (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM))  &&
1760                                     rSh.GetDrawView()->AreObjectsMarked())
1761                                 eKeyState = KS_Draw_Change;
1762                             else if(nSelectionType & (nsSelectionType::SEL_FRM|nsSelectionType::SEL_OLE|nsSelectionType::SEL_GRF))
1763                                 eKeyState = KS_Fly_Change;
1764                         }
1765                     }
1766                     else
1767                     {
1768                         if( !bTblIsInsMode )
1769                             eTblChgMode = eTblChgMode | nsTblChgWidthHeightType::WH_FLAG_BIGGER;
1770                         eKeyState = KS_TblColCellInsDel;
1771                     }
1772                     break;
1773 
1774                 case KEY_DELETE:
1775                     if (rSh.IsInFrontOfLabel() &&
1776                         rSh.NumOrNoNum(sal_False))
1777                         eKeyState = KS_NumOrNoNum;
1778                     break;
1779 
1780                 case KEY_DELETE | KEY_MOD2:
1781                     if( !rSh.IsTableMode() && rSh.GetTableFmt() )
1782                     {
1783                         eKeyState = KS_Ende;
1784                         bTblInsDelMode = sal_True;
1785                         bTblIsInsMode = sal_False;
1786                         bTblIsColMode = sal_True;
1787                         aKeyInputTimer.Start();
1788                         bStopKeyInputTimer = sal_False;
1789                     }
1790                     break;
1791                 case KEY_INSERT | KEY_MOD2:
1792                     if( !rSh.IsTableMode() && rSh.GetTableFmt() )
1793                     {
1794                         eKeyState = KS_Ende;
1795                         bTblInsDelMode = sal_True;
1796                         bTblIsInsMode = sal_True;
1797                         bTblIsColMode = sal_True;
1798                         aKeyInputTimer.Start();
1799                         bStopKeyInputTimer = sal_False;
1800                     }
1801                     break;
1802 
1803                 case KEY_RETURN:                // Return
1804                     if ( !rSh.HasReadonlySel()
1805                          && !rSh.CrsrInsideInputFld() )
1806                     {
1807                         const int nSelectionType = rSh.GetSelectionType();
1808                         if(nSelectionType & nsSelectionType::SEL_OLE)
1809                             eKeyState = KS_LaunchOLEObject;
1810                         else if(nSelectionType & nsSelectionType::SEL_FRM)
1811                             eKeyState = KS_GoIntoFly;
1812                         else if((nSelectionType & nsSelectionType::SEL_DRW) &&
1813                                 0 == (nSelectionType & nsSelectionType::SEL_DRW_TXT) &&
1814                                 rSh.GetDrawView()->GetMarkedObjectList().GetMarkCount() == 1)
1815                             eKeyState = KS_GoIntoDrawing;
1816                         else if( aTmpQHD.HasCntnt() && !rSh.HasSelection() &&
1817                             aTmpQHD.bIsAutoText )
1818                             eKeyState = KS_GlossaryExpand;
1819 
1820                         //RETURN und leerer Absatz in Numerierung -> Num. beenden
1821                         else if( !aInBuffer.Len() &&
1822                                  rSh.GetNumRuleAtCurrCrsrPos() &&
1823                                  !rSh.GetNumRuleAtCurrCrsrPos()->IsOutlineRule() &&
1824                                  !rSh.HasSelection() &&
1825                                 rSh.IsSttPara() && rSh.IsEndPara() )
1826                             eKeyState = KS_NumOff, eNextKeyState = KS_OutlineLvOff;
1827 
1828                         //RETURN fuer neuen Absatz mit AutoFormatierung
1829                         else if( pACfg && pACfg->IsAutoFmtByInput() &&
1830                                 !(nSelectionType & (nsSelectionType::SEL_GRF |
1831                                     nsSelectionType::SEL_OLE | nsSelectionType::SEL_FRM |
1832                                     nsSelectionType::SEL_TBL_CELLS | nsSelectionType::SEL_DRW |
1833                                     nsSelectionType::SEL_DRW_TXT)) )
1834                             eKeyState = KS_CheckAutoCorrect, eNextKeyState = KS_AutoFmtByInput;
1835                         else
1836                             eNextKeyState = eKeyState, eKeyState = KS_CheckAutoCorrect;
1837                     }
1838                     break;
1839 
1840                 case KEY_RETURN | KEY_MOD2:     // ALT-Return
1841                     if ( !rSh.HasReadonlySel()
1842                          && !rSh.IsSttPara()
1843                          && rSh.GetNumRuleAtCurrCrsrPos()
1844                          && !rSh.CrsrInsideInputFld() )
1845                     {
1846                         eKeyState = KS_NoNum;
1847                     }
1848                     else if( rSh.CanSpecialInsert() )
1849                         eKeyState = KS_SpecialInsert;
1850                     break;
1851 
1852                 case KEY_BACKSPACE:
1853                 case KEY_BACKSPACE | KEY_SHIFT:
1854                     if ( !rSh.HasReadonlySel()
1855                          && !rSh.CrsrInsideInputFld() )
1856                     {
1857                         sal_Bool bDone = sal_False;
1858                         // Remove the paragraph indent, if the cursor is at the
1859                         // beginning of a paragraph, there is no selection
1860                         // and no numbering rule found at the current paragraph
1861                         // Also try to remove indent, if current paragraph
1862                         // has numbering rule, but isn't counted and only
1863                         // key <backspace> is hit.
1864                         const bool bOnlyBackspaceKey( KEY_BACKSPACE == rKeyCode.GetFullCode() );
1865                         if ( rSh.IsSttPara()
1866                              && !rSh.HasSelection()
1867                              && ( rSh.GetNumRuleAtCurrCrsrPos() == NULL
1868                                   || ( rSh.IsNoNum() && bOnlyBackspaceKey ) ) )
1869                         {
1870                             bDone = rSh.TryRemoveIndent();
1871                         }
1872 
1873                         if (bDone)
1874                             eKeyState = KS_Ende;
1875                         else
1876                         {
1877                             if ( rSh.IsSttPara() && !rSh.IsNoNum() )
1878                             {
1879                                 if (nKS_NUMDOWN_Count > 0
1880                                     && rSh.GetNumLevel() > 0)
1881                                 {
1882                                     eKeyState = KS_NumUp;
1883                                     nKS_NUMDOWN_Count = 2;
1884                                     bDone = sal_True;
1885                                 }
1886                                 else if (nKS_NUMINDENTINC_Count > 0)
1887                                 {
1888                                     eKeyState = KS_NumIndentDec;
1889                                     nKS_NUMINDENTINC_Count = 2;
1890                                     bDone = sal_True;
1891                                 }
1892                             }
1893                             // If the cursor is in an empty paragraph, which has
1894                             // a numbering, but not the outline numbering, and
1895                             // there is no selection, the numbering has to be
1896                             // deleted on key <Backspace>.
1897                             // Otherwise method <SwEditShell::NumOrNoNum(..)>
1898                             // should only change the <IsCounted()> state of
1899                             // the current paragraph depending of the key.
1900                             // On <backspace> it is set to <false>,
1901                             // on <shift-backspace> it is set to <true>.
1902                             // Thus, assure that method <SwEditShell::NumOrNum(..)>
1903                             // is only called for the intended purpose.
1904                             if ( !bDone && rSh.IsSttPara() )
1905                             {
1906                                 bool bCallNumOrNoNum( false );
1907                                 if ( bOnlyBackspaceKey && !rSh.IsNoNum() )
1908                                 {
1909                                     bCallNumOrNoNum = true;
1910                                 }
1911                                 else if ( !bOnlyBackspaceKey && rSh.IsNoNum() )
1912                                 {
1913                                     bCallNumOrNoNum = true;
1914                                 }
1915                                 else if ( bOnlyBackspaceKey
1916                                           && rSh.IsSttPara()
1917                                           && rSh.IsEndPara()
1918                                           && !rSh.HasSelection() )
1919                                 {
1920                                     const SwNumRule* pCurrNumRule( rSh.GetNumRuleAtCurrCrsrPos() );
1921                                     if ( pCurrNumRule != NULL
1922                                          && pCurrNumRule != rSh.GetOutlineNumRule() )
1923                                     {
1924                                         bCallNumOrNoNum = true;
1925                                     }
1926                                 }
1927                                 if ( bCallNumOrNoNum
1928                                      && rSh.NumOrNoNum( !bOnlyBackspaceKey, sal_True ) )
1929                                 {
1930                                     eKeyState = KS_NumOrNoNum;
1931                                 }
1932                             }
1933                         }
1934                     }
1935                     break;
1936 
1937                 case KEY_RIGHT:
1938                     {
1939                         eFlyState = KS_Fly_Change;
1940                         nDir = MOVE_RIGHT_BIG;
1941                         eTblChgMode = nsTblChgWidthHeightType::WH_FLAG_INSDEL | nsTblChgWidthHeightType::WH_COL_RIGHT;
1942                         nTblChgSize = pModOpt->GetTblVInsert();
1943                         goto KEYINPUT_CHECKTABLE_INSDEL;
1944                     }
1945                 case KEY_TAB:
1946                 {
1947 
1948 #ifdef SW_CRSR_TIMER
1949                     sal_Bool bOld = rSh.ChgCrsrTimerFlag( sal_False );
1950 #endif
1951                     if (rSh.IsFormProtected() || rSh.GetCurrentFieldmark() || rSh.GetChar(sal_False)==CH_TXT_ATR_FORMELEMENT)
1952                     {
1953                         eKeyState=KS_GotoNextFieldMark;
1954                     }
1955                     else if ( !rSh.IsMultiSelection() && rSh.CrsrInsideInputFld() )
1956                     {
1957                         GetView().GetViewFrame()->GetDispatcher()->Execute( FN_GOTO_NEXT_INPUTFLD );
1958                         eKeyState = KS_Ende;
1959                     }
1960                     else if( rSh.GetNumRuleAtCurrCrsrPos()
1961                              && rSh.IsSttOfPara()
1962                              && !rSh.HasReadonlySel() )
1963                     {
1964                         if ( !rSh.IsMultiSelection()
1965                              && rSh.IsFirstOfNumRuleAtCrsrPos()
1966                              && numfunc::ChangeIndentOnTabAtFirstPosOfFirstListItem() )
1967                             eKeyState = KS_NumIndentInc;
1968                         else
1969                             eKeyState = KS_NumDown;
1970                     }
1971                     else if ( rSh.GetTableFmt() )
1972                     {
1973                         if( rSh.HasSelection() || rSh.HasReadonlySel() )
1974                             eKeyState = KS_NextCell;
1975                         else
1976                             eKeyState = KS_CheckAutoCorrect, eNextKeyState = KS_NextCell;
1977                     }
1978                     else if ( rSh.GetSelectionType() &
1979                                 (nsSelectionType::SEL_GRF |
1980                                     nsSelectionType::SEL_FRM |
1981                                     nsSelectionType::SEL_OLE |
1982                                     nsSelectionType::SEL_DRW |
1983                                     nsSelectionType::SEL_DRW_FORM))
1984 
1985                             eKeyState = KS_NextObject;
1986                     else
1987                     {
1988                         eKeyState = KS_InsTab;
1989                         if( rSh.IsSttOfPara() && !rSh.HasReadonlySel() )
1990                         {
1991                             SwTxtFmtColl* pColl = rSh.GetCurTxtFmtColl();
1992                             if( pColl &&
1993                                 //0 <= pColl->GetOutlineLevel() && #i24560#
1994                                 //MAXLEVEL - 1 > pColl->GetOutlineLevel() )//#outline level,zhaojianwei
1995                                 pColl->IsAssignedToListLevelOfOutlineStyle()
1996                                 && MAXLEVEL-1 > pColl->GetAssignedOutlineStyleLevel() )//<-end,zhaojianwei
1997                                 eKeyState = KS_OutlineDown;
1998                         }
1999                     }
2000 #ifdef SW_CRSR_TIMER
2001                     rSh.ChgCrsrTimerFlag( bOld );
2002 #endif
2003                 }
2004                 break;
2005                 case KEY_TAB | KEY_SHIFT:
2006                 {
2007 #ifdef SW_CRSR_TIMER
2008                     sal_Bool bOld = rSh.ChgCrsrTimerFlag( sal_False );
2009                     sal_Bool bOld = rSh.ChgCrsrTimerFlag( sal_False );
2010 #endif
2011                     if (rSh.IsFormProtected() || rSh.GetCurrentFieldmark()|| rSh.GetChar(sal_False)==CH_TXT_ATR_FORMELEMENT)
2012                     {
2013                         eKeyState=KS_GotoPrevFieldMark;
2014                     }
2015                     else if ( !rSh.IsMultiSelection() && rSh.CrsrInsideInputFld() )
2016                     {
2017                         GetView().GetViewFrame()->GetDispatcher()->Execute( FN_GOTO_PREV_INPUTFLD );
2018                         eKeyState = KS_Ende;
2019                     }
2020                     else if( rSh.GetNumRuleAtCurrCrsrPos()
2021                              && rSh.IsSttOfPara()
2022                              && !rSh.HasReadonlySel() )
2023                     {
2024                         if ( !rSh.IsMultiSelection()
2025                              && rSh.IsFirstOfNumRuleAtCrsrPos()
2026                              && numfunc::ChangeIndentOnTabAtFirstPosOfFirstListItem() )
2027                             eKeyState = KS_NumIndentDec;
2028                         else
2029                             eKeyState = KS_NumUp;
2030                     }
2031                     else if ( rSh.GetTableFmt() )
2032                     {
2033                         if( rSh.HasSelection() || rSh.HasReadonlySel() )
2034                             eKeyState = KS_PrevCell;
2035                         else
2036                             eKeyState = KS_CheckAutoCorrect, eNextKeyState = KS_PrevCell;
2037                     }
2038                     else if ( rSh.GetSelectionType() &
2039                                 (nsSelectionType::SEL_GRF |
2040                                     nsSelectionType::SEL_FRM |
2041                                     nsSelectionType::SEL_OLE |
2042                                     nsSelectionType::SEL_DRW |
2043                                     nsSelectionType::SEL_DRW_FORM))
2044 
2045                             eKeyState = KS_PrevObject;
2046                     else
2047                     {
2048                         eKeyState = KS_Ende;
2049                         if( rSh.IsSttOfPara() && !rSh.HasReadonlySel() )
2050                         {
2051                             SwTxtFmtColl* pColl = rSh.GetCurTxtFmtColl();
2052                             //if( pColl && 0 < pColl->GetOutlineLevel() &&  //#outline level,zhaojianwei
2053                             //  MAXLEVEL - 1 >= pColl->GetOutlineLevel() )
2054                             if( pColl &&
2055                                 pColl->IsAssignedToListLevelOfOutlineStyle() &&
2056                                 0 < pColl->GetAssignedOutlineStyleLevel())
2057                                 eKeyState = KS_OutlineUp;
2058                         }
2059                     }
2060 #ifdef SW_CRSR_TIMER
2061                     rSh.ChgCrsrTimerFlag( bOld );
2062 #endif
2063                 }
2064                 break;
2065                 case KEY_TAB | KEY_MOD1:
2066                 case KEY_TAB | KEY_MOD2:
2067                     if( !rSh.HasReadonlySel() )
2068                     {
2069                         if( aTmpQHD.HasCntnt() && !rSh.HasSelection() )
2070                         {
2071                             // zum naechsten Tip
2072                             aTmpQHD.Inc( pACorr && pACorr->GetSwFlags().
2073                                                    bAutoCmpltEndless );
2074                             eKeyState = KS_NextPrevGlossary;
2075                         }
2076                         else if( rSh.GetTableFmt() )
2077                             eKeyState = KS_InsTab;
2078                         else if((rSh.GetSelectionType() &
2079                                     (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM|
2080                                         nsSelectionType::SEL_FRM|nsSelectionType::SEL_OLE|nsSelectionType::SEL_GRF))  &&
2081                                 rSh.GetDrawView()->AreObjectsMarked())
2082                             eKeyState = KS_EnterDrawHandleMode;
2083                         else
2084                         {
2085                             eKeyState = KS_InsTab;
2086                         }
2087                     }
2088                     break;
2089 
2090                     case KEY_TAB | KEY_MOD1 | KEY_SHIFT:
2091                         if( aTmpQHD.HasCntnt() && !rSh.HasSelection() &&
2092                             !rSh.HasReadonlySel() )
2093                         {
2094                             // zum vorherigen Tip
2095                             aTmpQHD.Dec( pACorr && pACorr->GetSwFlags().
2096                                                         bAutoCmpltEndless );
2097                             eKeyState = KS_NextPrevGlossary;
2098                         }
2099                         else if((rSh.GetSelectionType() & (nsSelectionType::SEL_DRW|nsSelectionType::SEL_DRW_FORM|
2100                                         nsSelectionType::SEL_FRM|nsSelectionType::SEL_OLE|nsSelectionType::SEL_GRF)) &&
2101                                 rSh.GetDrawView()->AreObjectsMarked())
2102                             eKeyState = KS_EnterDrawHandleMode;
2103                     break;
2104                     case KEY_F2 :
2105                     if( !rSh.HasReadonlySel() )
2106                     {
2107                         const int nSelectionType = rSh.GetSelectionType();
2108                         if(nSelectionType & nsSelectionType::SEL_FRM)
2109                             eKeyState = KS_GoIntoFly;
2110                         else if((nSelectionType & nsSelectionType::SEL_DRW))
2111                             eKeyState = KS_GoIntoDrawing;
2112                     }
2113                     break;
2114                 }
2115             }
2116             break;
2117         case KS_CheckDocReadOnlyKeys:
2118             {
2119                 eKeyState = KS_KeyToView;
2120                 switch( rKeyCode.GetModifier() | rKeyCode.GetCode() )
2121                 {
2122                     case KEY_TAB:
2123                     case KEY_TAB | KEY_SHIFT:
2124                         bNormalChar = sal_False;
2125                         eKeyState = KS_Ende;
2126                         if ( rSh.GetSelectionType() &
2127                                 (nsSelectionType::SEL_GRF |
2128                                     nsSelectionType::SEL_FRM |
2129                                     nsSelectionType::SEL_OLE |
2130                                     nsSelectionType::SEL_DRW |
2131                                     nsSelectionType::SEL_DRW_FORM))
2132 
2133                         {
2134                             eKeyState = rKeyCode.GetModifier() & KEY_SHIFT ?
2135                                                 KS_PrevObject : KS_NextObject;
2136                         }
2137                         else if ( !rSh.IsMultiSelection() && rSh.CrsrInsideInputFld() )
2138                         {
2139                             GetView().GetViewFrame()->GetDispatcher()->Execute(
2140                                 KEY_SHIFT != rKeyCode.GetModifier() ? FN_GOTO_NEXT_INPUTFLD : FN_GOTO_PREV_INPUTFLD );
2141                         }
2142                         else
2143                         {
2144                             rSh.SelectNextPrevHyperlink( KEY_SHIFT != rKeyCode.GetModifier() );
2145                         }
2146                     break;
2147                     case KEY_RETURN:
2148                     {
2149                         const int nSelectionType = rSh.GetSelectionType();
2150                         if(nSelectionType & nsSelectionType::SEL_FRM)
2151                             eKeyState = KS_GoIntoFly;
2152                         else
2153                         {
2154                             SfxItemSet aSet(rSh.GetAttrPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT);
2155                             rSh.GetCurAttr(aSet);
2156                             if(SFX_ITEM_SET == aSet.GetItemState(RES_TXTATR_INETFMT, sal_False))
2157                             {
2158                                 const SfxPoolItem& rItem = aSet.Get(RES_TXTATR_INETFMT, sal_True);
2159                                 bNormalChar = sal_False;
2160                                 eKeyState = KS_Ende;
2161                                 rSh.ClickToINetAttr((const SwFmtINetFmt&)rItem, URLLOAD_NOFILTER);
2162                             }
2163                         }
2164                     }
2165                     break;
2166                 }
2167             }
2168             break;
2169 
2170         case KS_EnterCharCell:
2171             {
2172                 eKeyState = KS_KeyToView;
2173                 switch ( rKeyCode.GetModifier() | rKeyCode.GetCode() )
2174                 {
2175                     case KEY_RIGHT | KEY_MOD2:
2176                         rSh.Right( CRSR_SKIP_CHARS, sal_False, 1, sal_False );
2177                         eKeyState = KS_Ende;
2178                         FlushInBuffer();
2179                         break;
2180                     case KEY_LEFT | KEY_MOD2:
2181                         rSh.Left( CRSR_SKIP_CHARS, sal_False, 1, sal_False );
2182                         eKeyState = KS_Ende;
2183                         FlushInBuffer();
2184                         break;
2185                 }
2186             }
2187             break;
2188 
2189         case KS_KeyToView:
2190             {
2191                 eKeyState = KS_Ende;
2192                 bNormalChar =
2193                     !rKeyCode.IsMod2() &&
2194                     rKeyCode.GetModifier() != (KEY_MOD1) &&
2195                     rKeyCode.GetModifier() != (KEY_MOD1|KEY_SHIFT) &&
2196                                 SW_ISPRINTABLE( aCh );
2197 
2198                 if (bNormalChar && rSh.IsInFrontOfLabel())
2199                 {
2200                     rSh.NumOrNoNum(sal_False);
2201                 }
2202 
2203                 if( aInBuffer.Len() && ( !bNormalChar || bIsDocReadOnly ))
2204                     FlushInBuffer();
2205 
2206                 if( rView.KeyInput( aKeyEvent ) )
2207                     bFlushBuffer = sal_True, bNormalChar = sal_False;
2208                 else
2209                 {
2210 // OS 22.09.95: Da der Sfx Acceleratoren nur aufruft, wenn sie beim letzten
2211 //              Statusupdate enabled wurden, muss copy ggf. von uns
2212 //              'gewaltsam' gerufen werden.
2213                     if( rKeyCode.GetFunction() == KEYFUNC_COPY )
2214                         GetView().GetViewFrame()->GetBindings().Execute(SID_COPY);
2215 
2216 
2217                     if( !bIsDocReadOnly && bNormalChar )
2218                     {
2219                         const int nSelectionType = rSh.GetSelectionType();
2220                         if((nSelectionType & nsSelectionType::SEL_DRW) &&
2221                             0 == (nSelectionType & nsSelectionType::SEL_DRW_TXT) &&
2222                             rSh.GetDrawView()->GetMarkedObjectList().GetMarkCount() == 1)
2223                         {
2224                             SdrObject* pObj = rSh.GetDrawView()->GetMarkedObjectList().GetMark(0)->GetMarkedSdrObj();
2225                             if(pObj)
2226                             {
2227                                 EnterDrawTextMode(pObj->GetLogicRect().Center());
2228                                 if ( rView.GetCurShell()->ISA(SwDrawTextShell) )
2229                                     ((SwDrawTextShell*)rView.GetCurShell())->Init();
2230                                 rSh.GetDrawView()->KeyInput( rKEvt, this );
2231                             }
2232                         }
2233                         else if(nSelectionType & nsSelectionType::SEL_FRM)
2234                         {
2235                             rSh.UnSelectFrm();
2236                             rSh.LeaveSelFrmMode();
2237                             rView.AttrChangedNotify(&rSh);
2238                             rSh.MoveSection( fnSectionCurr, fnSectionEnd );
2239                         }
2240                         eKeyState = KS_InsChar;
2241                     }
2242                     else
2243                     {
2244                         bNormalChar = sal_False;
2245                         Window::KeyInput( aKeyEvent );
2246                     }
2247                 }
2248             }
2249             break;
2250         case KS_LaunchOLEObject:
2251             rSh.LaunchOLEObj();
2252             eKeyState = KS_Ende;
2253         break;
2254         case KS_GoIntoFly :
2255             rSh.UnSelectFrm();
2256             rSh.LeaveSelFrmMode();
2257             rView.AttrChangedNotify(&rSh);
2258             rSh.MoveSection( fnSectionCurr, fnSectionEnd );
2259             eKeyState = KS_Ende;
2260         break;
2261         case KS_GoIntoDrawing :
2262         {
2263             SdrObject* pObj = rSh.GetDrawView()->GetMarkedObjectList().GetMark(0)->GetMarkedSdrObj();
2264             if(pObj)
2265             {
2266                 EnterDrawTextMode(pObj->GetLogicRect().Center());
2267                 if ( rView.GetCurShell()->ISA(SwDrawTextShell) )
2268                     ((SwDrawTextShell*)rView.GetCurShell())->Init();
2269             }
2270             eKeyState = KS_Ende;
2271         }
2272         break;
2273         case KS_EnterDrawHandleMode:
2274         {
2275             const SdrHdlList& rHdlList = rSh.GetDrawView()->GetHdlList();
2276             sal_Bool bForward(!aKeyEvent.GetKeyCode().IsShift());
2277 
2278             ((SdrHdlList&)rHdlList).TravelFocusHdl(bForward);
2279             eKeyState = KS_Ende;
2280         }
2281         break;
2282         case KS_InsTab:
2283             if( rView.ISA( SwWebView ))     //Kein Tabulator fuer Web!
2284             {
2285                 Window::KeyInput( aKeyEvent );
2286                 eKeyState = KS_Ende;
2287                 break;
2288             }
2289             aCh = '\t';
2290             // kein break!
2291         case KS_InsChar:
2292             if (rSh.GetChar(sal_False)==CH_TXT_ATR_FORMELEMENT)
2293             {
2294                 ::sw::mark::ICheckboxFieldmark* pFieldmark =
2295                     dynamic_cast< ::sw::mark::ICheckboxFieldmark* >
2296                         (rSh.GetCurrentFieldmark());
2297                 OSL_ENSURE(pFieldmark,
2298                     "Where is my FieldMark??");
2299                 if(pFieldmark)
2300                 {
2301                     pFieldmark->SetChecked(!pFieldmark->IsChecked());
2302                     OSL_ENSURE(pFieldmark->IsExpanded(),
2303                         "where is the otherpos?");
2304                     if (pFieldmark->IsExpanded())
2305                     {
2306                         rSh.CalcLayout();
2307                     }
2308                 }
2309                 eKeyState = KS_Ende;
2310             }
2311             else if ( !rSh.HasReadonlySel()
2312                       || rSh.CrsrInsideInputFld() )
2313             {
2314                 const sal_Bool bIsNormalChar =
2315                     GetAppCharClass().isLetterNumeric( String( aCh ), 0 );
2316                 if( bChkInsBlank && bIsNormalChar &&
2317                     (aInBuffer.Len() || !rSh.IsSttPara() || !rSh.IsEndPara() ))
2318                 {
2319                     // vor dem Zeichen noch ein Blank einfuegen. Dieses
2320                     // kommt zwischen den Expandierten Text und dem neuen
2321                     // "nicht Worttrenner".
2322                     aInBuffer.Expand( aInBuffer.Len() + 1, ' ' );
2323                 }
2324 
2325                 const sal_Bool bIsAutoCorrectChar =  SvxAutoCorrect::IsAutoCorrectChar( aCh );
2326                 const sal_Bool bRunNext = pACorr != NULL && pACorr->HasRunNext();
2327                 if( !aKeyEvent.GetRepeat() && pACorr && ( bIsAutoCorrectChar || bRunNext ) &&
2328                         pACfg->IsAutoFmtByInput() &&
2329                     (( pACorr->IsAutoCorrFlag( ChgWeightUnderl ) &&
2330                         ( '*' == aCh || '_' == aCh ) ) ||
2331                      ( pACorr->IsAutoCorrFlag( ChgQuotes ) && ('\"' == aCh ))||
2332                      ( pACorr->IsAutoCorrFlag( ChgSglQuotes ) && ( '\'' == aCh))))
2333                 {
2334                     FlushInBuffer();
2335                     rSh.AutoCorrect( *pACorr, aCh );
2336                     if( '\"' != aCh && '\'' != aCh )        // nur bei "*_" rufen!
2337                         rSh.UpdateAttr();
2338                 }
2339                 else if( !aKeyEvent.GetRepeat() && pACorr && ( bIsAutoCorrectChar || bRunNext ) &&
2340                         pACfg->IsAutoFmtByInput() &&
2341                     pACorr->IsAutoCorrFlag( CptlSttSntnc | CptlSttWrd |
2342                                             ChgOrdinalNumber | AddNonBrkSpace |
2343                                             ChgToEnEmDash | SetINetAttr |
2344                                             Autocorrect ) &&
2345                     '\"' != aCh && '\'' != aCh && '*' != aCh && '_' != aCh
2346                     )
2347                 {
2348                     FlushInBuffer();
2349                     rSh.AutoCorrect( *pACorr, aCh );
2350                 }
2351                 else
2352                 {
2353                     aInBuffer.Expand( aInBuffer.Len() + aKeyEvent.GetRepeat() + 1,aCh );
2354                     bFlushCharBuffer = Application::AnyInput( INPUT_KEYBOARD );
2355                     bFlushBuffer = !bFlushCharBuffer;
2356                     if( bFlushCharBuffer )
2357                         aKeyInputFlushTimer.Start();
2358                 }
2359                 eKeyState = KS_Ende;
2360             }
2361             else
2362             {
2363                 InfoBox( this, SW_RES( MSG_READONLY_CONTENT )).Execute();
2364                 eKeyState = KS_Ende;
2365             }
2366         break;
2367 
2368         case KS_CheckAutoCorrect:
2369         {
2370             if( pACorr && pACfg->IsAutoFmtByInput() &&
2371                 pACorr->IsAutoCorrFlag( CptlSttSntnc | CptlSttWrd |
2372                                         ChgOrdinalNumber |
2373                                         ChgToEnEmDash | SetINetAttr |
2374                                         Autocorrect ) &&
2375                 !rSh.HasReadonlySel() )
2376             {
2377                 FlushInBuffer();
2378                 rSh.AutoCorrect( *pACorr, static_cast< sal_Unicode >('\0') );
2379             }
2380             eKeyState = eNextKeyState;
2381         }
2382         break;
2383 
2384         default:
2385         {
2386             sal_uInt16 nSlotId = 0;
2387             FlushInBuffer();
2388             switch( eKeyState )
2389             {
2390             case KS_SpecialInsert:
2391                 rSh.DoSpecialInsert();
2392                 break;
2393 
2394             case KS_NoNum:
2395                 rSh.NoNum();
2396                 break;
2397 
2398             case KS_NumOff:
2399                 // Shellwechsel - also vorher aufzeichnen
2400                 rSh.DelNumRules();
2401                 eKeyState = eNextKeyState;
2402                 break;
2403             case KS_OutlineLvOff: // delete autofmt outlinelevel later
2404                 break;
2405 
2406             case KS_NumDown:
2407                 rSh.NumUpDown( sal_True );
2408                 nKS_NUMDOWN_Count = 2; // #i23725#
2409                 break;
2410             case KS_NumUp:
2411                 rSh.NumUpDown( sal_False );
2412                 break;
2413 
2414             case KS_NumIndentInc:
2415                 rSh.ChangeIndentOfAllListLevels(360);
2416                 nKS_NUMINDENTINC_Count = 2;
2417                 break;
2418 
2419             case KS_GotoNextFieldMark:
2420                 {
2421                     ::sw::mark::IFieldmark const * const pFieldmark = rSh.GetFieldmarkAfter();
2422                     if(pFieldmark) rSh.GotoFieldmark(pFieldmark);
2423                 }
2424                 break;
2425 
2426             case KS_GotoPrevFieldMark:
2427                 {
2428                     ::sw::mark::IFieldmark const * const pFieldmark = rSh.GetFieldmarkBefore();
2429                     if(pFieldmark) rSh.GotoFieldmark(pFieldmark);
2430                 }
2431                 break;
2432 
2433             case KS_NumIndentDec:
2434                 rSh.ChangeIndentOfAllListLevels(-360);
2435                 // <--
2436                 break;
2437 
2438             case KS_OutlineDown:
2439                 rSh.OutlineUpDown( 1 );
2440                 break;
2441             case KS_OutlineUp:
2442                 rSh.OutlineUpDown( -1 );
2443                 break;
2444 
2445             case KS_NextCell:
2446                 //In Tabelle immer 'flushen'
2447                 rSh.GoNextCell();
2448                 nSlotId = FN_GOTO_NEXT_CELL;
2449                 break;
2450             case KS_PrevCell:
2451                 rSh.GoPrevCell();
2452                 nSlotId = FN_GOTO_PREV_CELL;
2453                 break;
2454             case KS_AutoFmtByInput:
2455                 rSh.SplitNode( sal_True );
2456                 break;
2457 
2458             case KS_NextObject:
2459             case KS_PrevObject:
2460                 if(rSh.GotoObj( KS_NextObject == eKeyState, GOTOOBJ_GOTO_ANY))
2461                 {
2462                     if( rSh.IsFrmSelected() &&
2463                         rView.GetDrawFuncPtr() )
2464                     {
2465                         rView.GetDrawFuncPtr()->Deactivate();
2466                         rView.SetDrawFuncPtr(NULL);
2467                         rView.LeaveDrawCreate();
2468                         rView.AttrChangedNotify( &rSh );
2469                     }
2470                     rSh.HideCrsr();
2471                     rSh.EnterSelFrmMode();
2472                 }
2473             break;
2474             case KS_GlossaryExpand:
2475             {
2476                 // ersetze das Wort oder Kuerzel durch den den Textbaustein
2477                 rSh.StartUndo( UNDO_START );
2478 
2479                 String sFnd( *aTmpQHD.aArr[ aTmpQHD.nCurArrPos ] );
2480                 if( aTmpQHD.bIsAutoText )
2481                 {
2482                     SwGlossaryList* pList = ::GetGlossaryList();
2483                     String sShrtNm;
2484                     String sGroup;
2485                     if(pList->GetShortName( sFnd, sShrtNm, sGroup))
2486                     {
2487                         rSh.SttSelect();
2488                         rSh.ExtendSelection( sal_False, aTmpQHD.nLen );
2489                         SwGlossaryHdl* pGlosHdl = GetView().GetGlosHdl();
2490                         pGlosHdl->SetCurGroup(sGroup, sal_True);
2491                         pGlosHdl->InsertGlossary( sShrtNm);
2492                         pQuickHlpData->bChkInsBlank = sal_True;
2493                     }
2494                 }
2495                 else
2496                 {
2497                     rSh.Insert( sFnd.Erase( 0, aTmpQHD.nLen ));
2498                     pQuickHlpData->bChkInsBlank = !pACorr ||
2499                             pACorr->GetSwFlags().bAutoCmpltAppendBlanc;
2500                 }
2501                 rSh.EndUndo( UNDO_END );
2502             }
2503             break;
2504 
2505             case KS_NextPrevGlossary:
2506                 pQuickHlpData->Move( aTmpQHD );
2507                 pQuickHlpData->Start( rSh, USHRT_MAX );
2508                 break;
2509 
2510             case KS_EditFormula:
2511             {
2512                 const sal_uInt16 nId = SwInputChild::GetChildWindowId();
2513 
2514                 SfxViewFrame* pVFrame = GetView().GetViewFrame();
2515                 pVFrame->ToggleChildWindow( nId );
2516                 SwInputChild* pChildWin = (SwInputChild*)pVFrame->
2517                                                     GetChildWindow( nId );
2518                 if( pChildWin )
2519                     pChildWin->SetFormula( sFmlEntry );
2520             }
2521             break;
2522 
2523             case KS_ColLeftBig:         rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_COL_LEFT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHMove() );   break;
2524             case KS_ColRightBig:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_COL_RIGHT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHMove() );  break;
2525             case KS_ColLeftSmall:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_COL_LEFT, pModOpt->GetTblHMove() );   break;
2526             case KS_ColRightSmall:      rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_COL_RIGHT, pModOpt->GetTblHMove() );  break;
2527             case KS_ColBottomBig:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_ROW_BOTTOM|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVMove() ); break;
2528             case KS_ColBottomSmall:     rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_ROW_BOTTOM, pModOpt->GetTblVMove() ); break;
2529             case KS_CellLeftBig:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_LEFT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHMove() );  break;
2530             case KS_CellRightBig:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_RIGHT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHMove() ); break;
2531             case KS_CellLeftSmall:      rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_LEFT, pModOpt->GetTblHMove() );  break;
2532             case KS_CellRightSmall:     rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_RIGHT, pModOpt->GetTblHMove() ); break;
2533             case KS_CellTopBig:         rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_TOP|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVMove() );   break;
2534             case KS_CellBottomBig:      rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_BOTTOM|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVMove() );    break;
2535             case KS_CellTopSmall:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_TOP, pModOpt->GetTblVMove() );   break;
2536             case KS_CellBottomSmall:    rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_CELL_BOTTOM, pModOpt->GetTblVMove() );    break;
2537 
2538 //---------------
2539             case KS_InsDel_ColLeftBig:          rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_COL_LEFT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHInsert() ); break;
2540             case KS_InsDel_ColRightBig:         rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_COL_RIGHT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHInsert() );    break;
2541             case KS_InsDel_ColLeftSmall:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_COL_LEFT, pModOpt->GetTblHInsert() ); break;
2542             case KS_InsDel_ColRightSmall:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_COL_RIGHT, pModOpt->GetTblHInsert() );    break;
2543             case KS_InsDel_ColTopBig:           rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_ROW_TOP|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVInsert() );  break;
2544             case KS_InsDel_ColBottomBig:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_ROW_BOTTOM|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVInsert() );   break;
2545             case KS_InsDel_ColTopSmall:         rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_ROW_TOP, pModOpt->GetTblVInsert() );  break;
2546             case KS_InsDel_ColBottomSmall:      rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_ROW_BOTTOM, pModOpt->GetTblVInsert() );   break;
2547             case KS_InsDel_CellLeftBig:         rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_LEFT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHInsert() );    break;
2548             case KS_InsDel_CellRightBig:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_RIGHT|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblHInsert() );   break;
2549             case KS_InsDel_CellLeftSmall:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_LEFT, pModOpt->GetTblHInsert() );    break;
2550             case KS_InsDel_CellRightSmall:      rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_RIGHT, pModOpt->GetTblHInsert() );   break;
2551             case KS_InsDel_CellTopBig:          rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_TOP|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVInsert() ); break;
2552             case KS_InsDel_CellBottomBig:       rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_BOTTOM|nsTblChgWidthHeightType::WH_FLAG_BIGGER, pModOpt->GetTblVInsert() );  break;
2553             case KS_InsDel_CellTopSmall:        rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_TOP, pModOpt->GetTblVInsert() ); break;
2554             case KS_InsDel_CellBottomSmall:     rSh.SetColRowWidthHeight( nsTblChgWidthHeightType::WH_FLAG_INSDEL|nsTblChgWidthHeightType::WH_CELL_BOTTOM, pModOpt->GetTblVInsert() );  break;
2555 //---------------
2556             case KS_TblColCellInsDel:
2557                 rSh.SetColRowWidthHeight( eTblChgMode, nTblChgSize );
2558                 break;
2559             case KS_Fly_Change:
2560             {
2561                 SdrView *pSdrView = rSh.GetDrawView();
2562                 const SdrHdlList& rHdlList = pSdrView->GetHdlList();
2563                 if(rHdlList.GetFocusHdl())
2564                     ChangeDrawing( nDir );
2565                 else
2566                     ChangeFly( nDir, rView.ISA( SwWebView ) );
2567             }
2568             break;
2569             case KS_Draw_Change :
2570                 ChangeDrawing( nDir );
2571                 break;
2572             default:; //prevent warning
2573             }
2574             if( nSlotId && rView.GetViewFrame()->GetBindings().GetRecorder().is() )
2575             {
2576                 SfxRequest aReq(rView.GetViewFrame(), nSlotId );
2577                 aReq.Done();
2578             }
2579             eKeyState = KS_Ende;
2580         }
2581         }
2582     }
2583 
2584     if( bStopKeyInputTimer )
2585     {
2586         aKeyInputTimer.Stop();
2587         bTblInsDelMode = sal_False;
2588     }
2589 
2590     // falls die gepufferten Zeichen eingefuegt werden sollen
2591     if( bFlushBuffer && aInBuffer.Len() )
2592     {
2593         //OS 16.02.96 11.04: bFlushCharBuffer wurde hier nicht zurueckgesetzt
2594         // warum nicht?
2595         sal_Bool bSave = bFlushCharBuffer;
2596         FlushInBuffer();
2597         bFlushCharBuffer = bSave;
2598 
2599         // evt. Tip-Hilfe anzeigen
2600         String sWord;
2601         if( bNormalChar && pACfg && pACorr &&
2602             ( pACfg->IsAutoTextTip() ||
2603               pACorr->GetSwFlags().bAutoCompleteWords ) &&
2604             rSh.GetPrevAutoCorrWord( *pACorr, sWord ) )
2605         {
2606             ShowAutoTextCorrectQuickHelp(sWord, pACfg, pACorr);
2607         }
2608     }
2609 }
2610 
2611 /*--------------------------------------------------------------------
2612      Beschreibung:  MouseEvents
2613  --------------------------------------------------------------------*/
2614 
2615 
2616 void SwEditWin::RstMBDownFlags()
2617 {
2618     //Nicht auf allen Systemen kommt vor dem modalen
2619     //Dialog noch ein MouseButton Up (wie unter WINDOWS).
2620     //Daher hier die Stati zuruecksetzen und die Maus
2621     //fuer den Dialog freigeben.
2622     bMBPressed = bNoInterrupt = sal_False;
2623     EnterArea();
2624     ReleaseMouse();
2625 }
2626 
2627 
2628 
2629 void SwEditWin::MouseButtonDown(const MouseEvent& _rMEvt)
2630 {
2631     SwWrtShell &rSh = rView.GetWrtShell();
2632 
2633     // We have to check if a context menu is shown and we have an UI
2634     // active inplace client. In that case we have to ignore the mouse
2635     // button down event. Otherwise we would crash (context menu has been
2636     // opened by inplace client and we would deactivate the inplace client,
2637     // the contex menu is closed by VCL asynchronously which in the end
2638     // would work on deleted objects or the context menu has no parent anymore)
2639     // See #126086# and #128122#
2640     SfxInPlaceClient* pIPClient = rSh.GetSfxViewShell()->GetIPClient();
2641     sal_Bool bIsOleActive = ( pIPClient && pIPClient->IsObjectInPlaceActive() );
2642 
2643     if ( bIsOleActive && PopupMenu::IsInExecute() )
2644         return;
2645 
2646     MouseEvent rMEvt(_rMEvt);
2647 
2648     if (rView.GetPostItMgr()->IsHit(rMEvt.GetPosPixel()))
2649         return;
2650 
2651     rView.GetPostItMgr()->SetActiveSidebarWin(0);
2652 
2653     GrabFocus();
2654 
2655     //ignore key modifiers for format paintbrush
2656     {
2657         sal_Bool bExecFormatPaintbrush = pApplyTempl && pApplyTempl->pFormatClipboard
2658                                 &&  pApplyTempl->pFormatClipboard->HasContent();
2659         if( bExecFormatPaintbrush )
2660             rMEvt = MouseEvent( _rMEvt.GetPosPixel(), _rMEvt.GetClicks(),
2661                                     _rMEvt.GetMode(), _rMEvt.GetButtons() );
2662     }
2663 
2664     bWasShdwCrsr = 0 != pShadCrsr;
2665     if( bWasShdwCrsr )
2666         delete pShadCrsr, pShadCrsr = 0;
2667 
2668     const Point aDocPos( PixelToLogic( rMEvt.GetPosPixel() ) );
2669 
2670     if ( IsChainMode() )
2671     {
2672         SetChainMode( sal_False );
2673         SwRect aDummy;
2674         SwFlyFrmFmt *pFmt = (SwFlyFrmFmt*)rSh.GetFlyFrmFmt();
2675         if ( !rSh.Chainable( aDummy, *pFmt, aDocPos ) )
2676             rSh.Chain( *pFmt, aDocPos );
2677         UpdatePointer( aDocPos, rMEvt.GetModifier() );
2678         return;
2679     }
2680 
2681     //Nach GrabFocus sollte eine Shell gepusht sein. Das muss eigentlich
2682     //klappen aber in der Praxis ...
2683     lcl_SelectShellForDrop( rView );
2684 
2685     sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly();
2686     sal_Bool bCallBase = sal_True;
2687 
2688     if( pQuickHlpData->bClear )
2689         pQuickHlpData->Stop( rSh );
2690     pQuickHlpData->bChkInsBlank = sal_False;
2691 
2692     if( rSh.FinishOLEObj() )
2693         return; //InPlace beenden und der Klick zaehlt nicht mehr
2694 
2695     SET_CURR_SHELL( &rSh );
2696 
2697     SdrView *pSdrView = rSh.GetDrawView();
2698     if ( pSdrView )
2699     {
2700         if (pSdrView->MouseButtonDown( rMEvt, this ) )
2701         {
2702             rSh.GetView().GetViewFrame()->GetBindings().InvalidateAll(sal_False);
2703             return; // Event von der SdrView ausgewertet
2704         }
2705     }
2706 
2707 
2708     bIsInMove = sal_False;
2709     aStartPos = rMEvt.GetPosPixel();
2710     aRszMvHdlPt.X() = 0, aRszMvHdlPt.Y() = 0;
2711 
2712     sal_uInt8 nMouseTabCol = 0;
2713     const sal_Bool bTmp = !rSh.IsDrawCreate() && !pApplyTempl && !rSh.IsInSelect() &&
2714          rMEvt.GetClicks() == 1 && MOUSE_LEFT == rMEvt.GetButtons();
2715     if (  bTmp &&
2716          0 != (nMouseTabCol = rSh.WhichMouseTabCol( aDocPos ) ) &&
2717          !rSh.IsObjSelectable( aDocPos ) )
2718     {
2719         // Enhanced table selection
2720         if ( SW_TABSEL_HORI <= nMouseTabCol && SW_TABCOLSEL_VERT >= nMouseTabCol )
2721         {
2722             rSh.EnterStdMode();
2723             rSh.SelectTableRowCol( aDocPos );
2724             if( SW_TABSEL_HORI  != nMouseTabCol && SW_TABSEL_HORI_RTL  != nMouseTabCol)
2725             {
2726                 pRowColumnSelectionStart = new Point( aDocPos );
2727                 bIsRowDrag = SW_TABROWSEL_HORI == nMouseTabCol||
2728                             SW_TABROWSEL_HORI_RTL == nMouseTabCol ||
2729                             SW_TABCOLSEL_VERT == nMouseTabCol;
2730                 bMBPressed = sal_True;
2731                 CaptureMouse();
2732             }
2733             return;
2734         }
2735 
2736         if ( !rSh.IsTableMode() )
2737         {
2738             //Zuppeln von Tabellenspalten aus dem Dokument heraus.
2739             if(SW_TABCOL_VERT == nMouseTabCol || SW_TABCOL_HORI == nMouseTabCol)
2740                 rView.SetTabColFromDoc( sal_True );
2741             else
2742                 rView.SetTabRowFromDoc( sal_True );
2743 
2744             rView.SetTabColFromDocPos( aDocPos );
2745             rView.InvalidateRulerPos();
2746             SfxBindings& rBind = rView.GetViewFrame()->GetBindings();
2747             rBind.Update();
2748             if ( RulerColumnDrag( rMEvt,
2749                     (SW_TABCOL_VERT == nMouseTabCol || SW_TABROW_HORI == nMouseTabCol)) )
2750             {
2751                 rView.SetTabColFromDoc( sal_False );
2752                 rView.SetTabRowFromDoc( sal_False );
2753                 rView.InvalidateRulerPos();
2754                 rBind.Update();
2755                 bCallBase = sal_False;
2756             }
2757             else
2758             {
2759                 return;
2760             }
2761         }
2762     }
2763     else if (bTmp &&
2764              rSh.IsNumLabel(aDocPos))
2765     {
2766         SwTxtNode* pNodeAtPos = rSh.GetNumRuleNodeAtPos( aDocPos );
2767         rView.SetNumRuleNodeFromDoc( pNodeAtPos );
2768         rView.InvalidateRulerPos();
2769         SfxBindings& rBind = rView.GetViewFrame()->GetBindings();
2770         rBind.Update();
2771 
2772         if ( RulerMarginDrag( rMEvt,
2773                         rSh.IsVerticalModeAtNdAndPos( *pNodeAtPos, aDocPos ) ) )
2774         {
2775             rView.SetNumRuleNodeFromDoc( NULL );
2776             rView.InvalidateRulerPos();
2777             rBind.Update();
2778             bCallBase = sal_False;
2779         }
2780         else
2781         {
2782             // Make sure the pointer is set to 0, otherwise it may point to
2783             // nowhere after deleting the corresponding text node.
2784             rView.SetNumRuleNodeFromDoc( NULL );
2785             return;
2786         }
2787     }
2788 
2789     if ( rSh.IsInSelect() )
2790         rSh.EndSelect();
2791 
2792     //Abfrage auf LEFT, da sonst auch bei einem Click mit der rechten Taste
2793     //beispielsweise die Selektion aufgehoben wird.
2794     if ( MOUSE_LEFT == rMEvt.GetButtons() )
2795     {
2796         sal_Bool bOnlyText = sal_False;
2797         bMBPressed = bNoInterrupt = sal_True;
2798         nKS_NUMDOWN_Count = 0; // #i23725#
2799 
2800         CaptureMouse();
2801 
2802         //ggf. Cursorpositionen zuruecksetzen
2803         rSh.ResetCursorStack();
2804 
2805         switch ( rMEvt.GetModifier() + rMEvt.GetButtons() )
2806         {
2807             case MOUSE_LEFT:
2808             case MOUSE_LEFT + KEY_SHIFT:
2809             case MOUSE_LEFT + KEY_MOD2:
2810                 if( rSh.IsObjSelected() )
2811                 {
2812                     SdrHdl* pHdl;
2813                     if( !bIsDocReadOnly &&
2814                         !pAnchorMarker &&
2815                         0 != ( pHdl = pSdrView->PickHandle(aDocPos) ) &&
2816                             ( pHdl->GetKind() == HDL_ANCHOR ||
2817                               pHdl->GetKind() == HDL_ANCHOR_TR ) )
2818                     {
2819                         // Set selected during drag
2820                         pHdl->SetSelected(true);
2821                         pAnchorMarker = new SwAnchorMarker( pHdl );
2822                         UpdatePointer( aDocPos, rMEvt.GetModifier() );
2823                         return;
2824                     }
2825                 }
2826                 if ( EnterDrawMode( rMEvt, aDocPos ) )
2827                 {
2828                     bNoInterrupt = sal_False;
2829                     return;
2830                 }
2831                 else  if ( rView.GetDrawFuncPtr() && bInsFrm )
2832                 {
2833                     StopInsFrm();
2834                     rSh.Edit();
2835                 }
2836 
2837                 // Ohne SHIFT, da sonst Toggle bei Selektion nicht funktioniert
2838                 if (rMEvt.GetClicks() == 1)
2839                 {
2840                     if ( rSh.IsSelFrmMode())
2841                     {
2842                         SdrHdl* pHdl = rSh.GetDrawView()->PickHandle(aDocPos);
2843                         sal_Bool bHitHandle = pHdl && pHdl->GetKind() != HDL_ANCHOR &&
2844                                                   pHdl->GetKind() != HDL_ANCHOR_TR;
2845 
2846                         if ((rSh.IsInsideSelectedObj(aDocPos) || bHitHandle) &&
2847                             !(rMEvt.GetModifier() == KEY_SHIFT && !bHitHandle))
2848                         {
2849                             rSh.EnterSelFrmMode( &aDocPos );
2850                             if ( !pApplyTempl )
2851                             {
2852                                 //nur, wenn keine Position zum Sizen getroffen ist.
2853                                 if (!bHitHandle)
2854                                 {
2855                                     StartDDTimer();
2856                                     SwEditWin::nDDStartPosY = aDocPos.Y();
2857                                     SwEditWin::nDDStartPosX = aDocPos.X();
2858                                 }
2859                                 bFrmDrag = sal_True;
2860                             }
2861                             bNoInterrupt = sal_False;
2862                             return;
2863                         }
2864                     }
2865                 }
2866         }
2867 
2868         sal_Bool bExecHyperlinks = rView.GetDocShell()->IsReadOnly();
2869         if ( !bExecHyperlinks )
2870         {
2871             SvtSecurityOptions aSecOpts;
2872             const sal_Bool bSecureOption = aSecOpts.IsOptionSet( SvtSecurityOptions::E_CTRLCLICK_HYPERLINK );
2873             if ( (  bSecureOption && rMEvt.GetModifier() == KEY_MOD1 ) ||
2874                  ( !bSecureOption && rMEvt.GetModifier() != KEY_MOD1 ) )
2875                 bExecHyperlinks = sal_True;
2876         }
2877 
2878         // Enhanced selection
2879         sal_uInt8 nNumberOfClicks = static_cast< sal_uInt8 >(rMEvt.GetClicks() % 4);
2880         if ( 0 == nNumberOfClicks && 0 < rMEvt.GetClicks() )
2881             nNumberOfClicks = 4;
2882 
2883         sal_Bool bExecDrawTextLink = sal_False;
2884 
2885         switch ( rMEvt.GetModifier() + rMEvt.GetButtons() )
2886         {
2887             case MOUSE_LEFT:
2888             case MOUSE_LEFT + KEY_MOD1:
2889             case MOUSE_LEFT + KEY_MOD2:
2890                 switch ( nNumberOfClicks )
2891                 {
2892                     case 1:
2893                     {
2894                         UpdatePointer( aDocPos, rMEvt.GetModifier() );
2895                         SwEditWin::nDDStartPosY = aDocPos.Y();
2896                         SwEditWin::nDDStartPosX = aDocPos.X();
2897 
2898                         // URL in DrawText-Objekt getroffen?
2899                         if (bExecHyperlinks && pSdrView)
2900                         {
2901                             SdrViewEvent aVEvt;
2902                             pSdrView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
2903 
2904                             if (aVEvt.eEvent == SDREVENT_EXECUTEURL)
2905                                 bExecDrawTextLink = sal_True;
2906                         }
2907 
2908                         //Rahmen nur zu selektieren versuchen, wenn
2909                         //der Pointer bereits entsprechend geschaltet wurde
2910                         if ( aActHitType != SDRHIT_NONE && !rSh.IsSelFrmMode() &&
2911                             !GetView().GetViewFrame()->GetDispatcher()->IsLocked() &&
2912                             !bExecDrawTextLink)
2913                         {
2914                             // Test if there is a draw object at that position and if it should be selected.
2915                             sal_Bool bShould = rSh.ShouldObjectBeSelected(aDocPos);
2916 
2917                             if(bShould)
2918                             {
2919                                 rView.NoRotate();
2920                                 rSh.HideCrsr();
2921 
2922                                 sal_Bool bUnLockView = !rSh.IsViewLocked();
2923                                 rSh.LockView( sal_True );
2924                                 sal_Bool bSelObj = rSh.SelectObj( aDocPos,
2925                                                rMEvt.IsMod1() ? SW_ENTER_GROUP : 0);
2926                                 if( bUnLockView )
2927                                     rSh.LockView( sal_False );
2928 
2929                                 if( bSelObj )
2930                                 {
2931                                     // falls im Macro der Rahmen deselektiert
2932                                     // wurde, muss nur noch der Cursor
2933                                     // wieder angezeigt werden.
2934                                     if( FRMTYPE_NONE == rSh.GetSelFrmType() )
2935                                         rSh.ShowCrsr();
2936                                     else
2937                                     {
2938                                         if (rSh.IsFrmSelected() && rView.GetDrawFuncPtr())
2939                                         {
2940                                             rView.GetDrawFuncPtr()->Deactivate();
2941                                             rView.SetDrawFuncPtr(NULL);
2942                                             rView.LeaveDrawCreate();
2943                                             rView.AttrChangedNotify( &rSh );
2944                                         }
2945 
2946                                         rSh.EnterSelFrmMode( &aDocPos );
2947                                         bFrmDrag = sal_True;
2948                                         UpdatePointer( aDocPos, rMEvt.GetModifier() );
2949                                     }
2950                                     return;
2951                                 }
2952                                 else
2953                                     bOnlyText = static_cast< sal_Bool >(rSh.IsObjSelectable( aDocPos ));
2954 
2955                                 if (!rView.GetDrawFuncPtr())
2956                                     rSh.ShowCrsr();
2957                             }
2958                             else
2959                                 bOnlyText = KEY_MOD1 != rMEvt.GetModifier();
2960                         }
2961                         else if ( rSh.IsSelFrmMode() &&
2962                                   (aActHitType == SDRHIT_NONE ||
2963                                    !rSh.IsInsideSelectedObj( aDocPos )))
2964                         {
2965                             rView.NoRotate();
2966                             SdrHdl *pHdl;
2967                             if( !bIsDocReadOnly && !pAnchorMarker && 0 !=
2968                                 ( pHdl = pSdrView->PickHandle(aDocPos) ) &&
2969                                     ( pHdl->GetKind() == HDL_ANCHOR ||
2970                                       pHdl->GetKind() == HDL_ANCHOR_TR ) )
2971                             {
2972                                 pAnchorMarker = new SwAnchorMarker( pHdl );
2973                                 UpdatePointer( aDocPos, rMEvt.GetModifier() );
2974                                 return;
2975                             }
2976                             else
2977                             {
2978                                 sal_Bool bUnLockView = !rSh.IsViewLocked();
2979                                 rSh.LockView( sal_True );
2980                                 sal_uInt8 nFlag = rMEvt.IsShift() ? SW_ADD_SELECT :0;
2981                                 if( rMEvt.IsMod1() )
2982                                     nFlag = nFlag | SW_ENTER_GROUP;
2983 
2984                                 if ( rSh.IsSelFrmMode() )
2985                                 {
2986                                     rSh.UnSelectFrm();
2987                                     rSh.LeaveSelFrmMode();
2988                                     rView.AttrChangedNotify(&rSh);
2989                                 }
2990 
2991                                 sal_Bool bSelObj = rSh.SelectObj( aDocPos, nFlag );
2992                                 if( bUnLockView )
2993                                     rSh.LockView( sal_False );
2994 
2995                                 if( !bSelObj )
2996                                 {
2997                                     // Cursor hier umsetzen, damit er nicht zuerst
2998                                     // im Rahmen gezeichnet wird; ShowCrsr() geschieht
2999                                     // in LeaveSelFrmMode()
3000                                     bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPos,sal_False));
3001                                     rSh.LeaveSelFrmMode();
3002                                     rView.AttrChangedNotify( &rSh );
3003                                     bCallBase = sal_False;
3004                                 }
3005                                 else
3006                                 {
3007                                     rSh.HideCrsr();
3008                                     rSh.EnterSelFrmMode( &aDocPos );
3009                                     rSh.SelFlyGrabCrsr();
3010                                     rSh.MakeSelVisible();
3011                                     bFrmDrag = sal_True;
3012                                     if( rSh.IsFrmSelected() &&
3013                                         rView.GetDrawFuncPtr() )
3014                                     {
3015                                         rView.GetDrawFuncPtr()->Deactivate();
3016                                         rView.SetDrawFuncPtr(NULL);
3017                                         rView.LeaveDrawCreate();
3018                                         rView.AttrChangedNotify( &rSh );
3019                                     }
3020                                     UpdatePointer( aDocPos, rMEvt.GetModifier() );
3021                                     return;
3022                                 }
3023                             }
3024                         }
3025 
3026                         break;
3027                     }
3028                     case 2:
3029                     {
3030                         bFrmDrag = sal_False;
3031                         if ( !bIsDocReadOnly && rSh.IsInsideSelectedObj(aDocPos) &&
3032                              0 == rSh.IsSelObjProtected( FLYPROTECT_CONTENT|FLYPROTECT_PARENT ) )
3033 
3034 /* SJ: 01.03.2005: this is no good, on the one hand GetSelectionType is used as flag field (take a look into the GetSelectionType method)
3035    on the other hand the return value is used in a switch without proper masking (very nice), this must lead to trouble
3036 */
3037                         switch ( rSh.GetSelectionType() &~ ( nsSelectionType::SEL_FONTWORK | nsSelectionType::SEL_EXTRUDED_CUSTOMSHAPE ) )
3038                         {
3039                             case nsSelectionType::SEL_GRF:
3040                                 RstMBDownFlags();
3041                                 GetView().GetViewFrame()->GetBindings().Execute(
3042                                     FN_FORMAT_GRAFIC_DLG, 0, 0,
3043                                     SFX_CALLMODE_RECORD|SFX_CALLMODE_SLOT);
3044                                 return;
3045 
3046                                 // Doppelklick auf OLE-Objekt --> OLE-InPlace
3047                             case nsSelectionType::SEL_OLE:
3048                                 if (!rSh.IsSelObjProtected(FLYPROTECT_CONTENT))
3049                                 {
3050                                     RstMBDownFlags();
3051                                     rSh.LaunchOLEObj();
3052                                 }
3053                                 return;
3054 
3055                             case nsSelectionType::SEL_FRM:
3056                                 RstMBDownFlags();
3057                                 GetView().GetViewFrame()->GetBindings().Execute(
3058                                     FN_FORMAT_FRAME_DLG, 0, 0, SFX_CALLMODE_RECORD|SFX_CALLMODE_SLOT);
3059                                 return;
3060 
3061                             case nsSelectionType::SEL_DRW:
3062                                 RstMBDownFlags();
3063                                 EnterDrawTextMode(aDocPos);
3064                                 if ( rView.GetCurShell()->ISA(SwDrawTextShell) )
3065                                     ((SwDrawTextShell*)rView.GetCurShell())->Init();
3066                                 return;
3067                         }
3068 
3069                         //falls die Cursorposition korrigiert wurde oder
3070                         // ein Fly im ReadOnlyModus selektiert ist,
3071                         //keine Wortselektion.
3072                         if ( !bValidCrsrPos ||
3073                             (rSh.IsFrmSelected() && rSh.IsFrmSelected() ))
3074                             return;
3075 
3076                         SwField *pFld;
3077                         sal_Bool bFtn = sal_False;
3078 
3079                         if( !bIsDocReadOnly &&
3080                             ( 0 != ( pFld = rSh.GetCurFld() ) ||
3081                               0 != ( bFtn = rSh.GetCurFtn() )) )
3082                         {
3083                             RstMBDownFlags();
3084                             if( bFtn )
3085                                 GetView().GetViewFrame()->GetBindings().Execute( FN_EDIT_FOOTNOTE );
3086                             else
3087                             {
3088                                 sal_uInt16 nTypeId = pFld->GetTypeId();
3089                                 SfxViewFrame* pVFrame = GetView().GetViewFrame();
3090                                 switch( nTypeId )
3091                                 {
3092                                 case TYP_POSTITFLD:
3093                                 case TYP_SCRIPTFLD:
3094                                 {
3095                                     //falls es ein Readonly-Bereich ist, dann muss der Status
3096                                     //enabled werden
3097                                     sal_uInt16 nSlot = TYP_POSTITFLD == nTypeId ? FN_POSTIT : FN_JAVAEDIT;
3098                                     SfxBoolItem aItem(nSlot, sal_True);
3099                                     pVFrame->GetBindings().SetState(aItem);
3100                                     pVFrame->GetBindings().Execute(nSlot);
3101                                     break;
3102                                 }
3103                                 case TYP_AUTHORITY :
3104                                     pVFrame->GetBindings().Execute(FN_EDIT_AUTH_ENTRY_DLG);
3105                                 break;
3106                                 default:
3107                                     pVFrame->GetBindings().Execute(FN_EDIT_FIELD);
3108                                 }
3109                             }
3110                             return;
3111                         }
3112                         //im Extended Mode hat Doppel- und
3113                         //Dreifachklick keine Auswirkungen.
3114                         if ( rSh.IsExtMode() || rSh.IsBlockMode() )
3115                             return;
3116 
3117                         //Wort selektieren, gfs. Additional Mode
3118                         if ( KEY_MOD1 == rMEvt.GetModifier() && !rSh.IsAddMode() )
3119                         {
3120                             rSh.EnterAddMode();
3121                             rSh.SelWrd( &aDocPos );
3122                             rSh.LeaveAddMode();
3123                         }
3124                         else
3125                             rSh.SelWrd( &aDocPos );
3126                         bHoldSelection = sal_True;
3127                         return;
3128                     }
3129                     case 3:
3130                     case 4:
3131                     {
3132                         bFrmDrag = sal_False;
3133                         //im Extended Mode hat Doppel- und
3134                         //Dreifachklick keine Auswirkungen.
3135                         if ( rSh.IsExtMode() )
3136                             return;
3137 
3138                         //falls die Cursorposition korrigiert wurde oder
3139                         // ein Fly im ReadOnlyModus selektiert ist,
3140                         //keine Wortselektion.
3141                         if ( !bValidCrsrPos || rSh.IsFrmSelected() )
3142                             return;
3143 
3144                         //Zeile selektieren, gfs. Additional Mode
3145                         const bool bMod = KEY_MOD1 == rMEvt.GetModifier() &&
3146                                          !rSh.IsAddMode();
3147 
3148                         if ( bMod )
3149                             rSh.EnterAddMode();
3150 
3151                         // Enhanced selection
3152                         if ( 3 == nNumberOfClicks )
3153                             rSh.SelSentence( &aDocPos );
3154                         else
3155                             rSh.SelPara( &aDocPos );
3156 
3157                         if ( bMod )
3158                             rSh.LeaveAddMode();
3159 
3160                         bHoldSelection = sal_True;
3161                         return;
3162                     }
3163 
3164                     default:
3165                         return;
3166                 }
3167                 /* no break */
3168             case MOUSE_LEFT + KEY_SHIFT:
3169             case MOUSE_LEFT + KEY_SHIFT + KEY_MOD1:
3170             {
3171                 sal_Bool bLockView = bWasShdwCrsr;
3172 
3173                 switch ( rMEvt.GetModifier() )
3174                 {
3175                     case KEY_MOD1 + KEY_SHIFT:
3176                     {
3177                         if ( !bInsDraw && IsDrawObjSelectable( rSh, aDocPos ) )
3178                         {
3179                             rView.NoRotate();
3180                             rSh.HideCrsr();
3181                             if ( rSh.IsSelFrmMode() )
3182                                 rSh.SelectObj(aDocPos, SW_ADD_SELECT | SW_ENTER_GROUP);
3183                             else
3184                             {   if ( rSh.SelectObj( aDocPos, SW_ADD_SELECT | SW_ENTER_GROUP ) )
3185                                 {
3186                                     rSh.EnterSelFrmMode( &aDocPos );
3187                                     SwEditWin::nDDStartPosY = aDocPos.Y();
3188                                     SwEditWin::nDDStartPosX = aDocPos.X();
3189                                     bFrmDrag = sal_True;
3190                                     return;
3191                                 }
3192                             }
3193                         }
3194                         else if( rSh.IsSelFrmMode() &&
3195                                  rSh.GetDrawView()->PickHandle( aDocPos ))
3196                         {
3197                             bFrmDrag = sal_True;
3198                             bNoInterrupt = sal_False;
3199                             return;
3200                         }
3201                     }
3202                     break;
3203                     case KEY_MOD1:
3204                     if ( !bExecDrawTextLink )
3205                     {
3206                         if ( !bInsDraw && IsDrawObjSelectable( rSh, aDocPos ) )
3207                         {
3208                             rView.NoRotate();
3209                             rSh.HideCrsr();
3210                             if ( rSh.IsSelFrmMode() )
3211                                 rSh.SelectObj(aDocPos, SW_ENTER_GROUP);
3212                             else
3213                             {   if ( rSh.SelectObj( aDocPos, SW_ENTER_GROUP ) )
3214                                 {
3215                                     rSh.EnterSelFrmMode( &aDocPos );
3216                                     SwEditWin::nDDStartPosY = aDocPos.Y();
3217                                     SwEditWin::nDDStartPosX = aDocPos.X();
3218                                     bFrmDrag = sal_True;
3219                                     return;
3220                                 }
3221                             }
3222                         }
3223                         else if( rSh.IsSelFrmMode() &&
3224                                  rSh.GetDrawView()->PickHandle( aDocPos ))
3225                         {
3226                             bFrmDrag = sal_True;
3227                             bNoInterrupt = sal_False;
3228                             return;
3229                         }
3230                         else
3231                         {
3232                             if ( !rSh.IsAddMode() && !rSh.IsExtMode() && !rSh.IsBlockMode() )
3233                             {
3234                                 rSh.PushMode();
3235                                 bModePushed = sal_True;
3236 
3237                                 sal_Bool bUnLockView = !rSh.IsViewLocked();
3238                                 rSh.LockView( sal_True );
3239                                 rSh.EnterAddMode();
3240                                 if( bUnLockView )
3241                                     rSh.LockView( sal_False );
3242                             }
3243                             bCallBase = sal_False;
3244                         }
3245                     }
3246                     break;
3247                     case KEY_MOD2:
3248                     {
3249                         if ( !rSh.IsAddMode() && !rSh.IsExtMode() && !rSh.IsBlockMode() )
3250                         {
3251                             rSh.PushMode();
3252                             bModePushed = sal_True;
3253                             sal_Bool bUnLockView = !rSh.IsViewLocked();
3254                             rSh.LockView( sal_True );
3255                             rSh.EnterBlockMode();
3256                             if( bUnLockView )
3257                                 rSh.LockView( sal_False );
3258                         }
3259                         bCallBase = sal_False;
3260                     }
3261                     break;
3262                     case KEY_SHIFT:
3263                     {
3264                         if ( !bInsDraw && IsDrawObjSelectable( rSh, aDocPos ) )
3265                         {
3266                             rView.NoRotate();
3267                             rSh.HideCrsr();
3268                             if ( rSh.IsSelFrmMode() )
3269                             {
3270                                 rSh.SelectObj(aDocPos, SW_ADD_SELECT);
3271 
3272                                 const SdrMarkList& rMarkList = pSdrView->GetMarkedObjectList();
3273                                 if (rMarkList.GetMark(0) == NULL)
3274                                 {
3275                                     rSh.LeaveSelFrmMode();
3276                                     rView.AttrChangedNotify(&rSh);
3277                                     bFrmDrag = sal_False;
3278                                 }
3279                             }
3280                             else
3281                             {   if ( rSh.SelectObj( aDocPos ) )
3282                                 {
3283                                     rSh.EnterSelFrmMode( &aDocPos );
3284                                     SwEditWin::nDDStartPosY = aDocPos.Y();
3285                                     SwEditWin::nDDStartPosX = aDocPos.X();
3286                                     bFrmDrag = sal_True;
3287                                     return;
3288                                 }
3289                             }
3290                         }
3291                         else
3292                         {
3293                             if ( rSh.IsSelFrmMode() &&
3294                                  rSh.IsInsideSelectedObj( aDocPos ) )
3295                             {
3296                                 rSh.EnterSelFrmMode( &aDocPos );
3297                                 SwEditWin::nDDStartPosY = aDocPos.Y();
3298                                 SwEditWin::nDDStartPosX = aDocPos.X();
3299                                 bFrmDrag = sal_True;
3300                                 return;
3301                             }
3302                             if ( rSh.IsSelFrmMode() )
3303                             {
3304                                 rSh.UnSelectFrm();
3305                                 rSh.LeaveSelFrmMode();
3306                                 rView.AttrChangedNotify(&rSh);
3307                                 bFrmDrag = sal_False;
3308                             }
3309                             if ( !rSh.IsExtMode() )
3310                             {
3311                                 // keine Selection anfangen, wenn in ein URL-
3312                                 // Feld oder eine -Grafik geklickt wird
3313                                 sal_Bool bSttSelect = rSh.HasSelection() ||
3314                                                 Pointer(POINTER_REFHAND) != GetPointer();
3315 
3316                                 if( !bSttSelect )
3317                                 {
3318                                     bSttSelect = sal_True;
3319                                     if( bExecHyperlinks )
3320                                     {
3321                                         SwContentAtPos aCntntAtPos(
3322                                             SwContentAtPos::SW_FTN |
3323                                             SwContentAtPos::SW_INETATTR );
3324 
3325                                         if( rSh.GetContentAtPos( aDocPos, aCntntAtPos ) )
3326                                         {
3327                                             if( !rSh.IsViewLocked() &&
3328                                                 !rSh.IsReadOnlyAvailable() &&
3329                                                 aCntntAtPos.IsInProtectSect() )
3330                                                     bLockView = sal_True;
3331 
3332                                             bSttSelect = sal_False;
3333                                         }
3334                                         else if( rSh.IsURLGrfAtPos( aDocPos ))
3335                                             bSttSelect = sal_False;
3336                                     }
3337                                 }
3338 
3339                                 if( bSttSelect )
3340                                     rSh.SttSelect();
3341                             }
3342                         }
3343                         bCallBase = sal_False;
3344                         break;
3345                     }
3346                     default:
3347                         if( !rSh.IsViewLocked() )
3348                         {
3349                             SwContentAtPos aCntntAtPos( SwContentAtPos::SW_CLICKFIELD |
3350                                                         SwContentAtPos::SW_INETATTR );
3351                             if( rSh.GetContentAtPos( aDocPos, aCntntAtPos, sal_False ) &&
3352                                 !rSh.IsReadOnlyAvailable() &&
3353                                 aCntntAtPos.IsInProtectSect() )
3354                                 bLockView = sal_True;
3355                         }
3356                 }
3357 
3358                 if ( rSh.IsGCAttr() )
3359                 {
3360                     rSh.GCAttr();
3361                     rSh.ClearGCAttr();
3362                 }
3363 
3364                 sal_Bool bOverSelect = rSh.ChgCurrPam( aDocPos ), bOverURLGrf = sal_False;
3365                 if( !bOverSelect )
3366                     bOverURLGrf = bOverSelect = 0 != rSh.IsURLGrfAtPos( aDocPos );
3367 
3368                 if ( !bOverSelect )
3369                 {
3370                     const sal_Bool bTmpNoInterrupt = bNoInterrupt;
3371                     bNoInterrupt = sal_False;
3372 
3373                     if( !rSh.IsViewLocked() && bLockView )
3374                         rSh.LockView( sal_True );
3375                     else
3376                         bLockView = sal_False;
3377 
3378                     int nTmpSetCrsr = 0;
3379 
3380                     {   // nur temp. Move-Kontext aufspannen, da sonst die
3381                         // Abfrage auf die Inhaltsform nicht funktioniert!!!
3382                         MV_KONTEXT( &rSh );
3383                         nTmpSetCrsr = (rSh.*rSh.fnSetCrsr)(&aDocPos,bOnlyText);
3384                         bValidCrsrPos = !(CRSR_POSCHG & nTmpSetCrsr);
3385                         bCallBase = sal_False;
3386                     }
3387 
3388                     //#i42732# - notify the edit window that from now on we do not use the input language
3389                     if ( !(CRSR_POSOLD & nTmpSetCrsr) )
3390                         SetUseInputLanguage( sal_False );
3391 
3392                     if( bLockView )
3393                         rSh.LockView( sal_False );
3394 
3395                     bNoInterrupt = bTmpNoInterrupt;
3396                 }
3397                 if ( !bOverURLGrf && !bOnlyText )
3398                 {
3399                     const int nSelType = rSh.GetSelectionType();
3400                     // Check in general, if an object is selectable at given position.
3401                     // Thus, also text fly frames in background become selectable via Ctrl-Click.
3402                     if ( ( nSelType & nsSelectionType::SEL_OLE )
3403                          || ( nSelType & nsSelectionType::SEL_GRF )
3404                          || rSh.IsObjSelectable( aDocPos ) )
3405                     {
3406                         MV_KONTEXT( &rSh );
3407                         if( !rSh.IsFrmSelected() )
3408                             rSh.GotoNextFly();
3409                         rSh.EnterSelFrmMode();
3410                         bCallBase = sal_False;
3411                     }
3412                 }
3413                 break;
3414             }
3415         }
3416     }
3417     if (bCallBase)
3418         Window::MouseButtonDown(rMEvt);
3419 }
3420 
3421 /*--------------------------------------------------------------------
3422     Beschreibung:   MouseMove
3423  --------------------------------------------------------------------*/
3424 
3425 
3426 void SwEditWin::MouseMove(const MouseEvent& _rMEvt)
3427 {
3428     MouseEvent rMEvt(_rMEvt);
3429 
3430     //ignore key modifiers for format paintbrush
3431     {
3432         sal_Bool bExecFormatPaintbrush = pApplyTempl && pApplyTempl->pFormatClipboard
3433                                 &&  pApplyTempl->pFormatClipboard->HasContent();
3434         if( bExecFormatPaintbrush )
3435             rMEvt = MouseEvent( _rMEvt.GetPosPixel(), _rMEvt.GetClicks(),
3436                                     _rMEvt.GetMode(), _rMEvt.GetButtons() );
3437     }
3438 
3439     // solange eine Action laeuft sollte das MouseMove abgeklemmt sein
3440     // Ansonsten gibt es den Bug 40102
3441     SwWrtShell &rSh = rView.GetWrtShell();
3442     if( rSh.ActionPend() )
3443         return ;
3444 
3445     if( pShadCrsr && 0 != (rMEvt.GetModifier() + rMEvt.GetButtons() ) )
3446         delete pShadCrsr, pShadCrsr = 0;
3447 
3448     sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly();
3449 
3450     SET_CURR_SHELL( &rSh );
3451 
3452     //aPixPt == Point in Pixel, rel. zu ChildWin
3453     //aDocPt == Point in Twips, Dokumentkoordinaten
3454     const Point aPixPt( rMEvt.GetPosPixel() );
3455     const Point aDocPt( PixelToLogic( aPixPt ) );
3456 
3457     if ( IsChainMode() )
3458     {
3459         UpdatePointer( aDocPt, rMEvt.GetModifier() );
3460         if ( rMEvt.IsLeaveWindow() )
3461             rView.GetViewFrame()->HideStatusText();
3462         return;
3463     }
3464 
3465     SdrView *pSdrView = rSh.GetDrawView();
3466 
3467     const SwCallMouseEvent aLastCallEvent( aSaveCallEvent );
3468     aSaveCallEvent.Clear();
3469 
3470     if ( !bIsDocReadOnly && pSdrView && pSdrView->MouseMove(rMEvt,this) )
3471     {
3472         SetPointer( POINTER_TEXT );
3473         return; // Event von der SdrView ausgewertet
3474     }
3475 
3476     const Point aOldPt( rSh.VisArea().Pos() );
3477     const sal_Bool bInsWin = rSh.VisArea().IsInside( aDocPt );
3478 
3479     if( pShadCrsr && !bInsWin )
3480         delete pShadCrsr, pShadCrsr = 0;
3481 
3482     if( bInsWin && pRowColumnSelectionStart )
3483     {
3484         EnterArea();
3485         Point aPos( aDocPt );
3486         if( rSh.SelectTableRowCol( *pRowColumnSelectionStart, &aPos, bIsRowDrag ))
3487             return;
3488     }
3489 
3490     // Position ist noetig fuer OS/2, da dort nach einem MB-Down
3491     // offensichtlich sofort ein MB-Move gerufen wird.
3492     if( bDDTimerStarted )
3493     {
3494         Point aDD( SwEditWin::nDDStartPosX, SwEditWin::nDDStartPosY );
3495         aDD = LogicToPixel( aDD );
3496         Rectangle aRect( aDD.X()-3, aDD.Y()-3, aDD.X()+3, aDD.Y()+3 );
3497         if ( !aRect.IsInside( aPixPt ) )    // MA 23. May. 95: Tatterschutz.
3498             StopDDTimer( &rSh, aDocPt );
3499     }
3500 
3501     if(rView.GetDrawFuncPtr())
3502     {
3503         if( bInsDraw  )
3504         {
3505             rView.GetDrawFuncPtr()->MouseMove( rMEvt );
3506             if ( !bInsWin )
3507             {
3508                 Point aTmp( aDocPt );
3509                 aTmp += rSh.VisArea().Pos() - aOldPt;
3510                 LeaveArea( aTmp );
3511             }
3512             else
3513                 EnterArea();
3514             return;
3515         }
3516         else if(!rSh.IsFrmSelected() && !rSh.IsObjSelected())
3517         {
3518             SfxBindings &rBnd = rSh.GetView().GetViewFrame()->GetBindings();
3519             Point aRelPos = rSh.GetRelativePagePosition(aDocPt);
3520             if(aRelPos.X() >= 0)
3521             {
3522                 FieldUnit eMetric = ::GetDfltMetric(0 != PTR_CAST(SwWebView, &GetView()));
3523                 SW_MOD()->PutItem(SfxUInt16Item(SID_ATTR_METRIC, static_cast< sal_uInt16 >(eMetric)));
3524                 const SfxPointItem aTmp1( SID_ATTR_POSITION, aRelPos );
3525                 rBnd.SetState( aTmp1 );
3526             }
3527             else
3528             {
3529                 rBnd.Invalidate(SID_ATTR_POSITION);
3530             }
3531             rBnd.Invalidate(SID_ATTR_SIZE);
3532             const SfxStringItem aCell( SID_TABLE_CELL, aEmptyStr );
3533             rBnd.SetState( aCell );
3534         }
3535     }
3536 
3537     sal_uInt8 nMouseTabCol;
3538     if( !bIsDocReadOnly && bInsWin && !pApplyTempl && !rSh.IsInSelect() )
3539     {
3540         if ( SW_TABCOL_NONE != (nMouseTabCol = rSh.WhichMouseTabCol( aDocPt ) ) &&
3541              !rSh.IsObjSelectable( aDocPt ) )
3542         {
3543             sal_uInt16 nPointer = USHRT_MAX;
3544             bool bChkTblSel = false;
3545 
3546             switch ( nMouseTabCol )
3547             {
3548                 case SW_TABCOL_VERT :
3549                 case SW_TABROW_HORI :
3550                     nPointer = POINTER_VSIZEBAR;
3551                     bChkTblSel = true;
3552                     break;
3553                 case SW_TABROW_VERT :
3554                 case SW_TABCOL_HORI :
3555                     nPointer = POINTER_HSIZEBAR;
3556                     bChkTblSel = true;
3557                     break;
3558                 // Enhanced table selection
3559                 case SW_TABSEL_HORI :
3560                     nPointer = POINTER_TAB_SELECT_SE;
3561                     break;
3562                 case SW_TABSEL_HORI_RTL :
3563                 case SW_TABSEL_VERT :
3564                     nPointer = POINTER_TAB_SELECT_SW;
3565                     break;
3566                 case SW_TABCOLSEL_HORI :
3567                 case SW_TABROWSEL_VERT :
3568                     nPointer = POINTER_TAB_SELECT_S;
3569                     break;
3570                 case SW_TABROWSEL_HORI :
3571                     nPointer = POINTER_TAB_SELECT_E;
3572                     break;
3573                 case SW_TABROWSEL_HORI_RTL :
3574                 case SW_TABCOLSEL_VERT :
3575                     nPointer = POINTER_TAB_SELECT_W;
3576                     break;
3577             }
3578 
3579             if ( USHRT_MAX != nPointer &&
3580                 // Enhanced table selection is explicitely allowed in table mode
3581                 ( !bChkTblSel || !rSh.IsTableMode() ) )
3582             {
3583                 SetPointer( nPointer );
3584             }
3585 
3586             return;
3587         }
3588         else if (rSh.IsNumLabel(aDocPt, RULER_MOUSE_MARGINWIDTH))
3589         {
3590             SwTxtNode* pNodeAtPos = rSh.GetNumRuleNodeAtPos( aDocPt );
3591             const sal_uInt16 nPointer =
3592                     rSh.IsVerticalModeAtNdAndPos( *pNodeAtPos, aDocPt )
3593                     ? POINTER_VSIZEBAR
3594                     : POINTER_HSIZEBAR;
3595             SetPointer( nPointer );
3596 
3597             return;
3598         }
3599     }
3600 
3601     sal_Bool bDelShadCrsr = sal_True;
3602 
3603     switch ( rMEvt.GetModifier() + rMEvt.GetButtons() )
3604     {
3605         case MOUSE_LEFT:
3606             if( pAnchorMarker )
3607             {
3608                 // Now we need to refresh the SdrHdl pointer of pAnchorMarker.
3609                 // This looks a little bit tricky, but it solves the following
3610                 // problem: the pAnchorMarker contains a pointer to an SdrHdl,
3611                 // if the FindAnchorPos-call cause a scrolling of the visible
3612                 // area, it's possible that the SdrHdl will be destroyed and a
3613                 // new one will initialized at the original position(GetHdlPos).
3614                 // So the pAnchorMarker has to find the right SdrHdl, if it's
3615                 // the old one, it will find it with position aOld, if this one
3616                 // is destroyed, it will find a new one at position GetHdlPos().
3617                 const Point aOld = pAnchorMarker->GetPosForHitTest( *(rSh.GetOut()) );
3618                 Point aNew = rSh.FindAnchorPos( aDocPt );
3619                 SdrHdl* pHdl;
3620                 if( (0!=( pHdl = pSdrView->PickHandle( aOld ) )||
3621                     0 !=(pHdl = pSdrView->PickHandle( pAnchorMarker->GetHdlPos()) ) ) &&
3622                         ( pHdl->GetKind() == HDL_ANCHOR ||
3623                           pHdl->GetKind() == HDL_ANCHOR_TR ) )
3624                 {
3625                     pAnchorMarker->ChgHdl( pHdl );
3626                     if( aNew.X() || aNew.Y() )
3627                     {
3628                         pAnchorMarker->SetPos( aNew );
3629                         pAnchorMarker->SetLastPos( aDocPt );
3630                     }
3631                 }
3632                 else
3633                 {
3634                     delete pAnchorMarker;
3635                     pAnchorMarker = NULL;
3636                 }
3637             }
3638             if ( bInsDraw )
3639             {
3640                 if ( !bMBPressed )
3641                     break;
3642                 if ( bIsInMove || IsMinMove( aStartPos, aPixPt ) )
3643                 {
3644                     if ( !bInsWin )
3645                         LeaveArea( aDocPt );
3646                     else
3647                         EnterArea();
3648                     if ( rView.GetDrawFuncPtr() )
3649                     {
3650                         pSdrView->SetOrtho(sal_False);
3651                         rView.GetDrawFuncPtr()->MouseMove( rMEvt );
3652                     }
3653                     bIsInMove = sal_True;
3654                 }
3655                 return;
3656             }
3657         case MOUSE_LEFT + KEY_SHIFT:
3658         case MOUSE_LEFT + KEY_SHIFT + KEY_MOD1:
3659             if ( !bMBPressed )
3660                 break;
3661         case MOUSE_LEFT + KEY_MOD1:
3662             if ( bFrmDrag && rSh.IsSelFrmMode() )
3663             {
3664                 if( !bMBPressed )
3665                     break;
3666 
3667                 if ( bIsInMove || IsMinMove( aStartPos, aPixPt ) )
3668                 {
3669                     // Event-Verarbeitung fuers Resizen
3670                     if( pSdrView->AreObjectsMarked() )
3671                     {
3672                         const SwFrmFmt* pFlyFmt;
3673                         const SvxMacro* pMacro;
3674 
3675                         const Point aSttPt( PixelToLogic( aStartPos ) );
3676 
3677                         // geht es los?
3678                         if( HDL_USER == eSdrMoveHdl )
3679                         {
3680                             SdrHdl* pHdl = pSdrView->PickHandle( aSttPt );
3681                             eSdrMoveHdl = pHdl ? pHdl->GetKind() : HDL_MOVE;
3682                         }
3683 
3684                         sal_uInt16 nEvent = HDL_MOVE == eSdrMoveHdl
3685                                             ? SW_EVENT_FRM_MOVE
3686                                             : SW_EVENT_FRM_RESIZE;
3687 
3688                         if( 0 != ( pFlyFmt = rSh.GetFlyFrmFmt() ) &&
3689                             0 != ( pMacro = pFlyFmt->GetMacro().GetMacroTable().
3690                             Get( nEvent )) &&
3691                             aRszMvHdlPt != aDocPt )
3692                         {
3693                             aRszMvHdlPt = aDocPt;
3694                             sal_uInt16 nPos = 0;
3695                             String sRet;
3696                             SbxArrayRef xArgs = new SbxArray;
3697                             SbxVariableRef xVar = new SbxVariable;
3698                             xVar->PutString( pFlyFmt->GetName() );
3699                             xArgs->Put( &xVar, ++nPos );
3700 
3701                             if( SW_EVENT_FRM_RESIZE == nEvent )
3702                             {
3703                                 xVar = new SbxVariable;
3704                                 xVar->PutUShort( static_cast< sal_uInt16 >(eSdrMoveHdl) );
3705                                 xArgs->Put( &xVar, ++nPos );
3706                             }
3707 
3708                             xVar = new SbxVariable;
3709                             xVar->PutLong( aDocPt.X() - aSttPt.X() );
3710                             xArgs->Put( &xVar, ++nPos );
3711                             xVar = new SbxVariable;
3712                             xVar->PutLong( aDocPt.Y() - aSttPt.Y() );
3713                             xArgs->Put( &xVar, ++nPos );
3714 
3715                             ReleaseMouse();
3716 
3717                             rSh.ExecMacro( *pMacro, &sRet, &xArgs );
3718 
3719                             CaptureMouse();
3720 
3721                             if( sRet.Len() && 0 != sRet.ToInt32() )
3722                                 return ;
3723                         }
3724                     }
3725                     // Event-Verarbeitung fuers Resizen
3726 
3727                     if( bIsDocReadOnly )
3728                         break;
3729 
3730                     if ( rMEvt.IsShift() )
3731                     {
3732                         pSdrView->SetOrtho(sal_True);
3733                         pSdrView->SetAngleSnapEnabled(sal_True);
3734                     }
3735                     else
3736                     {
3737                         pSdrView->SetOrtho(sal_False);
3738                         pSdrView->SetAngleSnapEnabled(sal_False);
3739                     }
3740 
3741                     (rSh.*rSh.fnDrag)( &aDocPt, rMEvt.IsShift() );
3742                     bIsInMove = sal_True;
3743                 }
3744                 else if( bIsDocReadOnly )
3745                     break;
3746 
3747                 if ( !bInsWin )
3748                 {
3749                     Point aTmp( aDocPt );
3750                     aTmp += rSh.VisArea().Pos() - aOldPt;
3751                     LeaveArea( aTmp );
3752                 }
3753                 else if(bIsInMove)
3754                     EnterArea();
3755                 return;
3756             }
3757             if ( !rSh.IsSelFrmMode() && !bDDINetAttr &&
3758                 (IsMinMove( aStartPos,aPixPt ) || bIsInMove) &&
3759                 (rSh.IsInSelect() || !rSh.ChgCurrPam( aDocPt )) )
3760             {
3761                 if ( pSdrView )
3762                 {
3763                     if ( rMEvt.IsShift() )
3764                         pSdrView->SetOrtho(sal_True);
3765                     else
3766                         pSdrView->SetOrtho(sal_False);
3767                 }
3768                 if ( !bInsWin )
3769                 {
3770                     Point aTmp( aDocPt );
3771                     aTmp += rSh.VisArea().Pos() - aOldPt;
3772                     LeaveArea( aTmp );
3773                 }
3774                 else
3775                 {
3776                     //JP 24.09.98: Fix fuer die Bugs 55592 / 55931
3777                     //JP 23.04.99: Fix fuer den Bugs 65289
3778                     //JP 06.07.99: Fix fuer den Bugs 67360
3779                     if( !rMEvt.IsSynthetic() &&
3780                             !(( MOUSE_LEFT + KEY_MOD1 ==
3781                             rMEvt.GetModifier() + rMEvt.GetButtons() ) &&
3782                             rSh.Is_FnDragEQBeginDrag() && !rSh.IsAddMode() ))
3783                     {
3784                         (rSh.*rSh.fnDrag)( &aDocPt,sal_False );
3785 
3786                         bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPt,sal_False));
3787                         EnterArea();
3788                     }
3789                 }
3790             }
3791             bDDINetAttr = sal_False;
3792             break;
3793         case 0:
3794         {
3795             if ( pApplyTempl )
3796                         {
3797                 UpdatePointer(aDocPt, 0); // evtl. muss hier ein Rahmen markiert werden
3798                                 break;
3799                         }
3800             //#i6193#, change ui if mouse is over SwPostItField
3801             // TODO: do the same thing for redlines SW_REDLINE
3802             SwRect aFldRect;
3803             SwContentAtPos aCntntAtPos( SwContentAtPos::SW_FIELD);
3804             if( rSh.GetContentAtPos( aDocPt, aCntntAtPos, sal_False, &aFldRect ) )
3805             {
3806                 const SwField* pFld = aCntntAtPos.aFnd.pFld;
3807                 if (pFld->Which()== RES_POSTITFLD)
3808                 {
3809                     rView.GetPostItMgr()->SetShadowState(reinterpret_cast<const SwPostItField*>(pFld),false);
3810                 }
3811                 else
3812                     rView.GetPostItMgr()->SetShadowState(0,false);
3813             }
3814             else
3815                 rView.GetPostItMgr()->SetShadowState(0,false);
3816                 // no break;
3817         }
3818         case KEY_SHIFT:
3819         case KEY_MOD2:
3820         case KEY_MOD1:
3821             if ( !bInsDraw )
3822             {
3823                 sal_Bool bTstShdwCrsr = sal_True;
3824 
3825                 UpdatePointer( aDocPt, rMEvt.GetModifier() );
3826 
3827                 const SwFrmFmt* pFmt = 0;
3828                 const SwFmtINetFmt* pINet = 0;
3829                 SwContentAtPos aCntntAtPos( SwContentAtPos::SW_INETATTR );
3830                 if( rSh.GetContentAtPos( aDocPt, aCntntAtPos ) )
3831                     pINet = (SwFmtINetFmt*)aCntntAtPos.aFnd.pAttr;
3832 
3833                 const void* pTmp = pINet;
3834 
3835                 if( pINet ||
3836                     0 != ( pTmp = pFmt = rSh.GetFmtFromAnyObj( aDocPt )))
3837                 {
3838                     bTstShdwCrsr = sal_False;
3839                     if( pTmp == pINet )
3840                         aSaveCallEvent.Set( pINet );
3841                     else
3842                     {
3843                         IMapObject* pIMapObj = pFmt->GetIMapObject( aDocPt );
3844                         if( pIMapObj )
3845                             aSaveCallEvent.Set( pFmt, pIMapObj );
3846                         else
3847                             aSaveCallEvent.Set( EVENT_OBJECT_URLITEM, pFmt );
3848                     }
3849 
3850                     // sollte wir ueber einem InternetFeld mit einem
3851                     // gebundenen Macro stehen?
3852                     if( aSaveCallEvent != aLastCallEvent )
3853                     {
3854                         if( aLastCallEvent.HasEvent() )
3855                             rSh.CallEvent( SFX_EVENT_MOUSEOUT_OBJECT,
3856                                             aLastCallEvent, sal_True );
3857                         // 0 besagt, das das Object gar keine Tabelle hat
3858                         if( !rSh.CallEvent( SFX_EVENT_MOUSEOVER_OBJECT,
3859                                         aSaveCallEvent ))
3860                             aSaveCallEvent.Clear();
3861                     }
3862                 }
3863                 else if( aLastCallEvent.HasEvent() )
3864                 {
3865                     // Cursor stand auf einem Object
3866                     rSh.CallEvent( SFX_EVENT_MOUSEOUT_OBJECT,
3867                                     aLastCallEvent, sal_True );
3868                 }
3869 
3870                 if( bTstShdwCrsr && bInsWin && !bIsDocReadOnly &&
3871                     !bInsFrm &&
3872                     !rSh.GetViewOptions()->getBrowseMode() &&
3873                     rSh.GetViewOptions()->IsShadowCursor() &&
3874                     !(rMEvt.GetModifier() + rMEvt.GetButtons()) &&
3875                     !rSh.HasSelection() && !GetConnectMetaFile() )
3876                 {
3877                     SwRect aRect;
3878                     sal_Int16 eOrient;
3879                     SwFillMode eMode = (SwFillMode)rSh.GetViewOptions()->GetShdwCrsrFillMode();
3880                     if( rSh.GetShadowCrsrPos( aDocPt, eMode, aRect, eOrient ))
3881                     {
3882                         if( !pShadCrsr )
3883                             pShadCrsr = new SwShadowCursor( *this,
3884                                 SwViewOption::GetDirectCursorColor() );
3885                         if( text::HoriOrientation::RIGHT != eOrient && text::HoriOrientation::CENTER != eOrient )
3886                             eOrient = text::HoriOrientation::LEFT;
3887                         pShadCrsr->SetPos( aRect.Pos(), aRect.Height(), static_cast< sal_uInt16 >(eOrient) );
3888                         bDelShadCrsr = sal_False;
3889                     }
3890                 }
3891             }
3892             break;
3893         case MOUSE_LEFT + KEY_MOD2:
3894             if( rSh.IsBlockMode() && !rMEvt.IsSynthetic() )
3895             {
3896                 (rSh.*rSh.fnDrag)( &aDocPt,sal_False );
3897                 bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPt,sal_False));
3898                 EnterArea();
3899             }
3900         break;
3901     }
3902 
3903     if( bDelShadCrsr && pShadCrsr )
3904         delete pShadCrsr, pShadCrsr = 0;
3905     bWasShdwCrsr = sal_False;
3906 }
3907 
3908 /*--------------------------------------------------------------------
3909     Beschreibung:   Button Up
3910  --------------------------------------------------------------------*/
3911 
3912 
3913 void SwEditWin::MouseButtonUp(const MouseEvent& rMEvt)
3914 {
3915     sal_Bool bCallBase = sal_True;
3916 
3917     sal_Bool bCallShadowCrsr = bWasShdwCrsr;
3918     bWasShdwCrsr = sal_False;
3919     if( pShadCrsr )
3920         delete pShadCrsr, pShadCrsr = 0;
3921 
3922     if( pRowColumnSelectionStart )
3923         DELETEZ( pRowColumnSelectionStart );
3924 
3925     SdrHdlKind eOldSdrMoveHdl = eSdrMoveHdl;
3926     eSdrMoveHdl = HDL_USER;     // fuer die MoveEvents - wieder zuruecksetzen
3927 
3928     // sicherheitshalber zuruecksetzen Bug 27900
3929     rView.SetTabColFromDoc( sal_False );
3930     rView.SetNumRuleNodeFromDoc(NULL);
3931 
3932     SwWrtShell &rSh = rView.GetWrtShell();
3933     SET_CURR_SHELL( &rSh );
3934     SdrView *pSdrView = rSh.GetDrawView();
3935     if ( pSdrView )
3936     {
3937         pSdrView->SetOrtho(sal_False);
3938 
3939         if ( pSdrView->MouseButtonUp( rMEvt,this ) )
3940         {
3941             rSh.GetView().GetViewFrame()->GetBindings().InvalidateAll(sal_False);
3942             return; // Event von der SdrView ausgewertet
3943         }
3944     }
3945     //MouseButtonUp nur bearbeiten, wenn auch das Down an dieses Fenster ging.
3946     if ( !bMBPressed )
3947     {
3948         return;
3949     }
3950 
3951     Point aDocPt( PixelToLogic( rMEvt.GetPosPixel() ) );
3952 
3953     if ( bDDTimerStarted )
3954     {
3955         StopDDTimer( &rSh, aDocPt );
3956         bMBPressed = sal_False;
3957         if ( rSh.IsSelFrmMode() )
3958         {
3959             (rSh.*rSh.fnEndDrag)( &aDocPt, sal_False );
3960             bFrmDrag = sal_False;
3961         }
3962         bNoInterrupt = sal_False;
3963         ReleaseMouse();
3964         return;
3965     }
3966 
3967     if( pAnchorMarker )
3968     {
3969         if(pAnchorMarker->GetHdl())
3970         {
3971             // delete selected after drag
3972             pAnchorMarker->GetHdl()->SetSelected(false);
3973         }
3974 
3975         Point aPnt( pAnchorMarker->GetLastPos() );
3976         DELETEZ( pAnchorMarker );
3977         if( aPnt.X() || aPnt.Y() )
3978             rSh.FindAnchorPos( aPnt, sal_True );
3979     }
3980     if ( bInsDraw && rView.GetDrawFuncPtr() )
3981     {
3982         if ( rView.GetDrawFuncPtr()->MouseButtonUp( rMEvt ) )
3983         {
3984             if (rView.GetDrawFuncPtr()) // Koennte im MouseButtonUp zerstoert worden sein
3985             {
3986                 rView.GetDrawFuncPtr()->Deactivate();
3987 
3988                 if (!rView.IsDrawMode())
3989                 {
3990                     rView.SetDrawFuncPtr(NULL);
3991                     SfxBindings& rBind = rView.GetViewFrame()->GetBindings();
3992                     rBind.Invalidate( SID_ATTR_SIZE );
3993                     rBind.Invalidate( SID_TABLE_CELL );
3994                 }
3995             }
3996 
3997             if ( rSh.IsObjSelected() )
3998             {
3999                 rSh.EnterSelFrmMode();
4000                 if (!rView.GetDrawFuncPtr())
4001                     StdDrawMode( OBJ_NONE, sal_True );
4002             }
4003             else if ( rSh.IsFrmSelected() )
4004             {
4005                 rSh.EnterSelFrmMode();
4006                 StopInsFrm();
4007             }
4008             else
4009             {
4010                 const Point aDocPos( PixelToLogic( aStartPos ) );
4011                 bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPos,sal_False));
4012                 rSh.Edit();
4013             }
4014 
4015             rView.AttrChangedNotify( &rSh );
4016         }
4017         else if (rMEvt.GetButtons() == MOUSE_RIGHT && rSh.IsDrawCreate())
4018             rView.GetDrawFuncPtr()->BreakCreate();   // Zeichnen abbrechen
4019 
4020         bNoInterrupt = sal_False;
4021         ReleaseMouse();
4022         return;
4023     }
4024     sal_Bool bPopMode = sal_False;
4025     switch ( rMEvt.GetModifier() + rMEvt.GetButtons() )
4026     {
4027         case MOUSE_LEFT:
4028             if ( bInsDraw && rSh.IsDrawCreate() )
4029             {
4030                 if ( rView.GetDrawFuncPtr() && rView.GetDrawFuncPtr()->MouseButtonUp(rMEvt) == sal_True )
4031                 {
4032                     rView.GetDrawFuncPtr()->Deactivate();
4033                     rView.AttrChangedNotify( &rSh );
4034                     if ( rSh.IsObjSelected() )
4035                         rSh.EnterSelFrmMode();
4036                     if ( rView.GetDrawFuncPtr() && bInsFrm )
4037                         StopInsFrm();
4038                 }
4039                 bCallBase = sal_False;
4040                 break;
4041             }
4042         case MOUSE_LEFT + KEY_MOD1:
4043         case MOUSE_LEFT + KEY_MOD2:
4044         case MOUSE_LEFT + KEY_SHIFT + KEY_MOD1:
4045             if ( bFrmDrag && rSh.IsSelFrmMode() )
4046             {
4047                 if ( rMEvt.IsMod1() ) //Kopieren und nicht moven.
4048                 {
4049                     //Drag abbrechen, statt dessen internes Copy verwenden
4050                     Rectangle aRect;
4051                     rSh.GetDrawView()->TakeActionRect( aRect );
4052                     if (!aRect.IsEmpty())
4053                     {
4054                         rSh.BreakDrag();
4055                         Point aEndPt, aSttPt;
4056                         if ( rSh.GetSelFrmType() & FRMTYPE_FLY_ATCNT )
4057                         {
4058                             aEndPt = aRect.TopLeft();
4059                             aSttPt = rSh.GetDrawView()->GetAllMarkedRect().TopLeft();
4060                         }
4061                         else
4062                         {
4063                             aEndPt = aRect.Center();
4064                             aSttPt = rSh.GetDrawView()->GetAllMarkedRect().Center();
4065                         }
4066                         if ( aSttPt != aEndPt )
4067                         {
4068                             rSh.StartUndo( UNDO_UI_DRAG_AND_COPY );
4069                             rSh.Copy(&rSh, aSttPt, aEndPt, sal_False);
4070                             rSh.EndUndo( UNDO_UI_DRAG_AND_COPY );
4071                         }
4072                     }
4073                     else
4074                         (rSh.*rSh.fnEndDrag)( &aDocPt,sal_False );
4075                 }
4076                 else
4077                 {
4078                     {
4079                         const SwFrmFmt* pFlyFmt;
4080                         const SvxMacro* pMacro;
4081 
4082                         sal_uInt16 nEvent = HDL_MOVE == eOldSdrMoveHdl
4083                                             ? SW_EVENT_FRM_MOVE
4084                                             : SW_EVENT_FRM_RESIZE;
4085 
4086                         if( 0 != ( pFlyFmt = rSh.GetFlyFrmFmt() ) &&
4087                             0 != ( pMacro = pFlyFmt->GetMacro().GetMacroTable().
4088                             Get( nEvent )) )
4089                         {
4090                             const Point aSttPt( PixelToLogic( aStartPos ) );
4091                             aRszMvHdlPt = aDocPt;
4092                             sal_uInt16 nPos = 0;
4093                             SbxArrayRef xArgs = new SbxArray;
4094                             SbxVariableRef xVar = new SbxVariable;
4095                             xVar->PutString( pFlyFmt->GetName() );
4096                             xArgs->Put( &xVar, ++nPos );
4097 
4098                             if( SW_EVENT_FRM_RESIZE == nEvent )
4099                             {
4100                                 xVar = new SbxVariable;
4101                                 xVar->PutUShort( static_cast< sal_uInt16 >(eOldSdrMoveHdl) );
4102                                 xArgs->Put( &xVar, ++nPos );
4103                             }
4104 
4105                             xVar = new SbxVariable;
4106                             xVar->PutLong( aDocPt.X() - aSttPt.X() );
4107                             xArgs->Put( &xVar, ++nPos );
4108                             xVar = new SbxVariable;
4109                             xVar->PutLong( aDocPt.Y() - aSttPt.Y() );
4110                             xArgs->Put( &xVar, ++nPos );
4111 
4112                             xVar = new SbxVariable;
4113                             xVar->PutUShort( 1 );
4114                             xArgs->Put( &xVar, ++nPos );
4115 
4116                             ReleaseMouse();
4117 
4118                             rSh.ExecMacro( *pMacro, 0, &xArgs );
4119 
4120                             CaptureMouse();
4121                         }
4122                     }
4123                     (rSh.*rSh.fnEndDrag)( &aDocPt,sal_False );
4124                 }
4125                 bFrmDrag = sal_False;
4126                 bCallBase = sal_False;
4127                 break;
4128             }
4129             bPopMode = sal_True;
4130             // no break
4131         case MOUSE_LEFT + KEY_SHIFT:
4132             if (rSh.IsSelFrmMode())
4133             {
4134 
4135                 (rSh.*rSh.fnEndDrag)( &aDocPt, sal_False );
4136                 bFrmDrag = sal_False;
4137                 bCallBase = sal_False;
4138                 break;
4139             }
4140 
4141             if( bHoldSelection )
4142             {
4143                 //JP 27.04.99: Bug 65389 - das EndDrag sollte auf jedenfall
4144                 //              gerufen werden.
4145                 bHoldSelection = sal_False;
4146                 (rSh.*rSh.fnEndDrag)( &aDocPt, sal_False );
4147             }
4148             else
4149             {
4150                 if ( !rSh.IsInSelect() && rSh.ChgCurrPam( aDocPt ) )
4151                 {
4152                     const sal_Bool bTmpNoInterrupt = bNoInterrupt;
4153                     bNoInterrupt = sal_False;
4154                     {   // nur temp. Move-Kontext aufspannen, da sonst die
4155                         // Abfrage auf die Inhaltsform nicht funktioniert!!!
4156                         MV_KONTEXT( &rSh );
4157                         const Point aDocPos( PixelToLogic( aStartPos ) );
4158                         bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPos,sal_False));
4159                     }
4160                     bNoInterrupt = bTmpNoInterrupt;
4161 
4162                 }
4163                 else
4164                 {
4165                     sal_Bool bInSel = rSh.IsInSelect();
4166                     (rSh.*rSh.fnEndDrag)( &aDocPt, sal_False );
4167 
4168                     // Internetfield? --> Link-Callen (DocLaden!!)
4169 //JP 18.10.96: Bug 32437 -
4170 //                  if( !rSh.HasSelection() )
4171                     if( !bInSel )
4172                     {
4173                         sal_uInt16 nFilter = URLLOAD_NOFILTER;
4174                         if( KEY_MOD1 == rMEvt.GetModifier() )
4175                             nFilter |= URLLOAD_NEWVIEW;
4176 
4177                         sal_Bool bExecHyperlinks = rView.GetDocShell()->IsReadOnly();
4178                         if ( !bExecHyperlinks )
4179                         {
4180                             SvtSecurityOptions aSecOpts;
4181                             const sal_Bool bSecureOption = aSecOpts.IsOptionSet( SvtSecurityOptions::E_CTRLCLICK_HYPERLINK );
4182                             if ( (  bSecureOption && rMEvt.GetModifier() == KEY_MOD1 ) ||
4183                                  ( !bSecureOption && rMEvt.GetModifier() != KEY_MOD1 ) )
4184                                 bExecHyperlinks = sal_True;
4185                         }
4186 
4187                         const sal_Bool bExecSmarttags = rMEvt.GetModifier() == KEY_MOD1;
4188 
4189                         if(pApplyTempl)
4190                             bExecHyperlinks = sal_False;
4191 
4192                         SwContentAtPos aCntntAtPos( SwContentAtPos::SW_CLICKFIELD |
4193                                                     SwContentAtPos::SW_INETATTR |
4194                                                     SwContentAtPos::SW_SMARTTAG  | SwContentAtPos::SW_FORMCTRL);
4195 
4196                         if( rSh.GetContentAtPos( aDocPt, aCntntAtPos, sal_True ) )
4197                         {
4198                             sal_Bool bViewLocked = rSh.IsViewLocked();
4199                             if( !bViewLocked && !rSh.IsReadOnlyAvailable() &&
4200                                 aCntntAtPos.IsInProtectSect() )
4201                                 rSh.LockView( sal_True );
4202 
4203                             ReleaseMouse();
4204 
4205                             if( SwContentAtPos::SW_FIELD == aCntntAtPos.eCntntAtPos )
4206                             {
4207                                 if ( aCntntAtPos.pFndTxtAttr != NULL
4208                                      && aCntntAtPos.pFndTxtAttr->Which() == RES_TXTATR_INPUTFIELD )
4209                                 {
4210                                     // select content of Input Field, but exclude CH_TXT_ATR_INPUTFIELDSTART
4211                                     // and CH_TXT_ATR_INPUTFIELDEND
4212                                     rSh.SttSelect();
4213                                     rSh.SelectTxt( *(aCntntAtPos.pFndTxtAttr->GetStart()) + 1,
4214                                                    *(aCntntAtPos.pFndTxtAttr->End()) - 1 );
4215                                 }
4216                                 else
4217                                 {
4218                                     rSh.ClickToField( *aCntntAtPos.aFnd.pFld );
4219                                 }
4220                             }
4221                             else if ( SwContentAtPos::SW_SMARTTAG == aCntntAtPos.eCntntAtPos )
4222                             {
4223                                     // execute smarttag menu
4224                                     if ( bExecSmarttags && SwSmartTagMgr::Get().IsSmartTagsEnabled() )
4225                                         rView.ExecSmartTagPopup( aDocPt );
4226                             }
4227                             else if ( SwContentAtPos::SW_FORMCTRL == aCntntAtPos.eCntntAtPos )
4228                             {
4229                                 ASSERT( aCntntAtPos.aFnd.pFldmark != NULL, "where is my field ptr???");
4230                                 if ( aCntntAtPos.aFnd.pFldmark != NULL)
4231                                 {
4232                                     IFieldmark *fieldBM = const_cast< IFieldmark* > ( aCntntAtPos.aFnd.pFldmark );
4233                                     if (fieldBM->GetFieldname( ).equalsAscii( ODF_FORMCHECKBOX ) )
4234                                     {
4235                                         ICheckboxFieldmark* pCheckboxFm = dynamic_cast<ICheckboxFieldmark*>(fieldBM);
4236                                         pCheckboxFm->SetChecked(!pCheckboxFm->IsChecked());
4237                                         pCheckboxFm->Invalidate();
4238                                         rSh.InvalidateWindows( rView.GetVisArea() );
4239                                     } else if (fieldBM->GetFieldname().equalsAscii( ODF_FORMDROPDOWN) ) {
4240                                         rView.ExecFieldPopup( aDocPt, fieldBM );
4241                                         fieldBM->Invalidate();
4242                                         rSh.InvalidateWindows( rView.GetVisArea() );
4243                                     } else {
4244                                         // unknown type..
4245                                     }
4246                                 }
4247                             }
4248                             else // if ( SwContentAtPos::SW_INETATTR == aCntntAtPos.eCntntAtPos )
4249                             {
4250                                 if ( bExecHyperlinks )
4251                                     rSh.ClickToINetAttr( *(SwFmtINetFmt*)aCntntAtPos.aFnd.pAttr, nFilter );
4252                             }
4253 
4254                             rSh.LockView( bViewLocked );
4255                             bCallShadowCrsr = sal_False;
4256                         }
4257                         else
4258                         {
4259                             aCntntAtPos = SwContentAtPos( SwContentAtPos::SW_FTN );
4260                             if( !rSh.GetContentAtPos( aDocPt, aCntntAtPos, sal_True ) && bExecHyperlinks )
4261                             {
4262                                 SdrViewEvent aVEvt;
4263 
4264                                 if (pSdrView)
4265                                     pSdrView->PickAnything(rMEvt, SDRMOUSEBUTTONDOWN, aVEvt);
4266 
4267                                 if (pSdrView && aVEvt.eEvent == SDREVENT_EXECUTEURL)
4268                                 {
4269                                     // URL-Feld getroffen
4270                                     const SvxURLField *pField = aVEvt.pURLField;
4271                                     if (pField)
4272                                     {
4273                                         String sURL(pField->GetURL());
4274                                         String sTarget(pField->GetTargetFrame());
4275                                         ::LoadURL( sURL, &rSh, nFilter, &sTarget);
4276                                     }
4277                                     bCallShadowCrsr = sal_False;
4278                                 }
4279                                 else
4280                                 {
4281                                     // Grafik getroffen
4282                                     ReleaseMouse();
4283                                     if( rSh.ClickToINetGrf( aDocPt, nFilter ))
4284                                         bCallShadowCrsr = sal_False;
4285                                 }
4286                             }
4287                         }
4288 
4289                         if( bCallShadowCrsr &&
4290                             rSh.GetViewOptions()->IsShadowCursor() &&
4291                             MOUSE_LEFT == (rMEvt.GetModifier() + rMEvt.GetButtons()) &&
4292                             !rSh.HasSelection() &&
4293                             !GetConnectMetaFile() &&
4294                             rSh.VisArea().IsInside( aDocPt ))
4295                         {
4296                             SwUndoId nLastUndoId(UNDO_EMPTY);
4297                             if (rSh.GetLastUndoInfo(0, & nLastUndoId))
4298                             {
4299                                 if (UNDO_INS_FROM_SHADOWCRSR == nLastUndoId)
4300                                 {
4301                                     rSh.Undo();
4302                                 }
4303                             }
4304                             SwFillMode eMode = (SwFillMode)rSh.GetViewOptions()->GetShdwCrsrFillMode();
4305                             rSh.SetShadowCrsrPos( aDocPt, eMode );
4306                         }
4307                     }
4308                 }
4309                 bCallBase = sal_False;
4310 
4311             }
4312 
4313             // gfs. im Down gepushten Mode wieder zuruecksetzen
4314             if ( bPopMode && bModePushed )
4315             {
4316                 rSh.PopMode();
4317                 bModePushed = sal_False;
4318                 bCallBase = sal_False;
4319             }
4320             break;
4321 
4322         default:
4323             ReleaseMouse();
4324             return;
4325     }
4326 
4327     if( pApplyTempl )
4328     {
4329         int eSelection = rSh.GetSelectionType();
4330         SwFormatClipboard* pFormatClipboard = pApplyTempl->pFormatClipboard;
4331         if( pFormatClipboard )//apply format paintbrush
4332         {
4333             //get some parameters
4334             SwWrtShell& rWrtShell = rView.GetWrtShell();
4335             SfxStyleSheetBasePool* pPool=0;
4336             bool bNoCharacterFormats = false;
4337             bool bNoParagraphFormats = false;
4338             {
4339                 SwDocShell* pDocSh = rView.GetDocShell();
4340                 if(pDocSh)
4341                     pPool = pDocSh->GetStyleSheetPool();
4342                 if( (rMEvt.GetModifier()&KEY_MOD1) && (rMEvt.GetModifier()&KEY_SHIFT) )
4343                     bNoCharacterFormats = true;
4344                 else if( rMEvt.GetModifier() & KEY_MOD1 )
4345                     bNoParagraphFormats = true;
4346             }
4347             //execute paste
4348             pFormatClipboard->Paste( rWrtShell, pPool, bNoCharacterFormats, bNoParagraphFormats );
4349 
4350             //if the clipboard is empty after paste remove the ApplyTemplate
4351             if(!pFormatClipboard->HasContent())
4352                 SetApplyTemplate(SwApplyTemplate());
4353         }
4354         else if( pApplyTempl->nColor )
4355         {
4356             sal_uInt16 nId = 0;
4357             switch( pApplyTempl->nColor )
4358             {
4359                 case SID_ATTR_CHAR_COLOR_EXT:
4360                     nId = RES_CHRATR_COLOR;
4361                 break;
4362                 case SID_ATTR_CHAR_COLOR_BACKGROUND_EXT:
4363                     nId = RES_CHRATR_BACKGROUND;
4364                 break;
4365             }
4366             if( nId && (nsSelectionType::SEL_TXT|nsSelectionType::SEL_TBL) & eSelection)
4367             {
4368                 if( rSh.IsSelection() && !rSh.HasReadonlySel() )
4369                 {
4370                     if(nId == RES_CHRATR_BACKGROUND)
4371                     {
4372                         Color aColor( COL_TRANSPARENT  );
4373                         if( !SwEditWin::bTransparentBackColor )
4374                             aColor = SwEditWin::aTextBackColor;
4375                         rSh.SetAttrItem( SvxBrushItem( aColor, nId ) );
4376                     }
4377                     else
4378                         rSh.SetAttrItem( SvxColorItem(SwEditWin::aTextColor, nId) );
4379                     rSh.UnSetVisCrsr();
4380                     rSh.EnterStdMode();
4381                     rSh.SetVisCrsr(aDocPt);
4382 
4383                     pApplyTempl->bUndo = sal_True;
4384                     bCallBase = sal_False;
4385                     aTemplateTimer.Stop();
4386                 }
4387                 else if(rMEvt.GetClicks() == 1)
4388                 {
4389                     // keine Selektion -> also Giesskanne abschalten
4390                     aTemplateTimer.Start();
4391                 }
4392             }
4393         }
4394         else
4395         {
4396             String aStyleName;
4397             switch ( pApplyTempl->eType )
4398             {
4399                 case SFX_STYLE_FAMILY_PARA:
4400                     if( (( nsSelectionType::SEL_TXT | nsSelectionType::SEL_TBL )
4401                          & eSelection ) && !rSh.HasReadonlySel() )
4402                     {
4403                         rSh.SetTxtFmtColl( pApplyTempl->aColl.pTxtColl );
4404                         pApplyTempl->bUndo = sal_True;
4405                         bCallBase = sal_False;
4406                         if ( pApplyTempl->aColl.pTxtColl )
4407                             aStyleName = pApplyTempl->aColl.pTxtColl->GetName();
4408                     }
4409                     break;
4410                 case SFX_STYLE_FAMILY_CHAR:
4411                     if( (( nsSelectionType::SEL_TXT | nsSelectionType::SEL_TBL )
4412                          & eSelection ) && !rSh.HasReadonlySel() )
4413                     {
4414                         rSh.SetAttrItem( SwFmtCharFmt(pApplyTempl->aColl.pCharFmt) );
4415                         rSh.UnSetVisCrsr();
4416                         rSh.EnterStdMode();
4417                         rSh.SetVisCrsr(aDocPt);
4418                         pApplyTempl->bUndo = sal_True;
4419                         bCallBase = sal_False;
4420                         if ( pApplyTempl->aColl.pCharFmt )
4421                             aStyleName = pApplyTempl->aColl.pCharFmt->GetName();
4422                     }
4423                     break;
4424                 case SFX_STYLE_FAMILY_FRAME :
4425                 {
4426                     const SwFrmFmt* pFmt = rSh.GetFmtFromObj( aDocPt );
4427                     if(PTR_CAST(SwFlyFrmFmt, pFmt))
4428                     {
4429                         rSh.SetFrmFmt( pApplyTempl->aColl.pFrmFmt, sal_False, &aDocPt );
4430                         pApplyTempl->bUndo = sal_True;
4431                         bCallBase = sal_False;
4432                         if( pApplyTempl->aColl.pFrmFmt )
4433                             aStyleName = pApplyTempl->aColl.pFrmFmt->GetName();
4434                     }
4435                     break;
4436                 }
4437                 case SFX_STYLE_FAMILY_PAGE:
4438                             // Kein Undo bei Seitenvorlagen
4439                     rSh.ChgCurPageDesc( *pApplyTempl->aColl.pPageDesc );
4440                     if ( pApplyTempl->aColl.pPageDesc )
4441                         aStyleName = pApplyTempl->aColl.pPageDesc->GetName();
4442                     bCallBase = sal_False;
4443                     break;
4444                 case SFX_STYLE_FAMILY_PSEUDO:
4445                     if( !rSh.HasReadonlySel() )
4446                     {
4447                         rSh.SetCurNumRule( *pApplyTempl->aColl.pNumRule,
4448                                            false,
4449                                            pApplyTempl->aColl.pNumRule->GetDefaultListId() );
4450                         bCallBase = sal_False;
4451                         pApplyTempl->bUndo = sal_True;
4452                         if( pApplyTempl->aColl.pNumRule )
4453                             aStyleName = pApplyTempl->aColl.pNumRule->GetName();
4454                     }
4455                     break;
4456             }
4457 
4458             uno::Reference< frame::XDispatchRecorder > xRecorder =
4459                     rView.GetViewFrame()->GetBindings().GetRecorder();
4460             if ( aStyleName.Len() && xRecorder.is() )
4461             {
4462                 SfxShell *pSfxShell = lcl_GetShellFromDispatcher( rView, TYPE(SwTextShell) );
4463                 if ( pSfxShell )
4464                 {
4465                     SfxRequest aReq( rView.GetViewFrame(), SID_STYLE_APPLY );
4466                     aReq.AppendItem( SfxStringItem( SID_STYLE_APPLY, aStyleName ) );
4467                     aReq.AppendItem( SfxUInt16Item( SID_STYLE_FAMILY, (sal_uInt16) pApplyTempl->eType ) );
4468                     aReq.Done();
4469                 }
4470             }
4471         }
4472 
4473     }
4474     ReleaseMouse();
4475     // Hier kommen nur verarbeitete MouseEvents an; nur bei diesen duerfen
4476     // die Modi zurueckgesetzt werden.
4477     bMBPressed = sal_False;
4478 
4479     //sicherheitshalber aufrufen, da jetzt das Selektieren bestimmt zu Ende ist.
4480     //Andernfalls koennte der Timeout des Timers Kummer machen.
4481     EnterArea();
4482     bNoInterrupt = sal_False;
4483 
4484     if (bCallBase)
4485         Window::MouseButtonUp(rMEvt);
4486 }
4487 
4488 
4489 /*--------------------------------------------------------------------
4490     Beschreibung:   Vorlage anwenden
4491  --------------------------------------------------------------------*/
4492 
4493 
4494 void SwEditWin::SetApplyTemplate(const SwApplyTemplate &rTempl)
4495 {
4496     static sal_Bool bIdle = sal_False;
4497     DELETEZ(pApplyTempl);
4498     SwWrtShell &rSh = rView.GetWrtShell();
4499 
4500     if(rTempl.pFormatClipboard)
4501     {
4502         pApplyTempl = new SwApplyTemplate( rTempl );
4503               SetPointer( POINTER_FILL );//@todo #i20119# maybe better a new brush pointer here in future
4504               rSh.NoEdit( sal_False );
4505               bIdle = rSh.GetViewOptions()->IsIdle();
4506               ((SwViewOption *)rSh.GetViewOptions())->SetIdle( sal_False );
4507     }
4508     else if(rTempl.nColor)
4509     {
4510         pApplyTempl = new SwApplyTemplate( rTempl );
4511         SetPointer( POINTER_FILL );
4512         rSh.NoEdit( sal_False );
4513         bIdle = rSh.GetViewOptions()->IsIdle();
4514         ((SwViewOption *)rSh.GetViewOptions())->SetIdle( sal_False );
4515     }
4516     else if( rTempl.eType )
4517     {
4518         pApplyTempl = new SwApplyTemplate( rTempl );
4519         SetPointer( POINTER_FILL  );
4520         rSh.NoEdit( sal_False );
4521         bIdle = rSh.GetViewOptions()->IsIdle();
4522         ((SwViewOption *)rSh.GetViewOptions())->SetIdle( sal_False );
4523     }
4524     else
4525     {
4526         SetPointer( POINTER_TEXT );
4527         rSh.UnSetVisCrsr();
4528 
4529         ((SwViewOption *)rSh.GetViewOptions())->SetIdle( bIdle );
4530         if ( !rSh.IsSelFrmMode() )
4531             rSh.Edit();
4532     }
4533 
4534     static sal_uInt16 __READONLY_DATA aInva[] =
4535     {
4536         SID_STYLE_WATERCAN,
4537         SID_ATTR_CHAR_COLOR_EXT,
4538         SID_ATTR_CHAR_COLOR_BACKGROUND_EXT,
4539         0
4540     };
4541     rView.GetViewFrame()->GetBindings().Invalidate(aInva);
4542 }
4543 
4544 /*--------------------------------------------------------------------
4545     Beschreibung:   ctor
4546  --------------------------------------------------------------------*/
4547 
4548 
4549 SwEditWin::SwEditWin(Window *pParent, SwView &rMyView):
4550     Window(pParent, WinBits(WB_CLIPCHILDREN | WB_DIALOGCONTROL)),
4551     DropTargetHelper( this ),
4552     DragSourceHelper( this ),
4553 
4554     eBufferLanguage(LANGUAGE_DONTKNOW),
4555     pApplyTempl(0),
4556     pAnchorMarker( 0 ),
4557     pUserMarker( 0 ),
4558     pUserMarkerObj( 0 ),
4559     pShadCrsr( 0 ),
4560     pRowColumnSelectionStart( 0 ),
4561 
4562     rView( rMyView ),
4563 
4564     aActHitType(SDRHIT_NONE),
4565     m_nDropFormat( 0 ),
4566     m_nDropAction( 0 ),
4567     m_nDropDestination( 0 ),
4568 
4569     nInsFrmColCount( 1 ),
4570     eDrawMode(OBJ_NONE),
4571 
4572     bLockInput(sal_False),
4573     bObjectSelect( sal_False ),
4574     nKS_NUMDOWN_Count(0),
4575     nKS_NUMINDENTINC_Count(0)
4576 {
4577     SetHelpId(HID_EDIT_WIN);
4578     EnableChildTransparentMode();
4579     SetDialogControlFlags( WINDOW_DLGCTRL_RETURN | WINDOW_DLGCTRL_WANTFOCUS );
4580 
4581     bLinkRemoved = bMBPressed = bInsDraw = bInsFrm =
4582     bIsInDrag = bOldIdle = bOldIdleSet = bChainMode = bWasShdwCrsr = sal_False;
4583     //#i42732# initially use the input language
4584     bUseInputLanguage = sal_True;
4585 
4586     SetMapMode(MapMode(MAP_TWIP));
4587 
4588     SetPointer( POINTER_TEXT );
4589     aTimer.SetTimeoutHdl(LINK(this, SwEditWin, TimerHandler));
4590 
4591     bTblInsDelMode = sal_False;
4592     aKeyInputTimer.SetTimeout( 3000 );
4593     aKeyInputTimer.SetTimeoutHdl(LINK(this, SwEditWin, KeyInputTimerHandler));
4594 
4595     aKeyInputFlushTimer.SetTimeout( 200 );
4596     aKeyInputFlushTimer.SetTimeoutHdl(LINK(this, SwEditWin, KeyInputFlushHandler));
4597 
4598     // TemplatePointer fuer Farben soll nach Einfachclick
4599     // ohne Selektion zurueckgesetzt werden
4600     aTemplateTimer.SetTimeout(400);
4601     aTemplateTimer.SetTimeoutHdl(LINK(this, SwEditWin, TemplateTimerHdl));
4602 
4603     //JP 16.12.98: temporaere Loesung!!! Sollte bei jeder Cursorbewegung
4604     //          den Font von der akt. einfuege Position setzen!
4605     if( !rMyView.GetDocShell()->IsReadOnly() )
4606     {
4607         Font aFont;
4608         SetInputContext( InputContext( aFont, INPUTCONTEXT_TEXT |
4609                                             INPUTCONTEXT_EXTTEXTINPUT ) );
4610     }
4611 }
4612 
4613 
4614 
4615 SwEditWin::~SwEditWin()
4616 {
4617     aKeyInputTimer.Stop();
4618     delete pShadCrsr;
4619     delete pRowColumnSelectionStart;
4620     if( pQuickHlpData->bClear && rView.GetWrtShellPtr() )
4621         pQuickHlpData->Stop( rView.GetWrtShell() );
4622     bExecuteDrag = sal_False;
4623     delete pApplyTempl;
4624     rView.SetDrawFuncPtr(NULL);
4625 
4626     if(pUserMarker)
4627     {
4628         delete pUserMarker;
4629     }
4630 
4631     delete pAnchorMarker;
4632 }
4633 
4634 
4635 /******************************************************************************
4636  *  Beschreibung: DrawTextEditMode einschalten
4637  ******************************************************************************/
4638 
4639 
4640 void SwEditWin::EnterDrawTextMode( const Point& aDocPos )
4641 {
4642     if ( rView.EnterDrawTextMode(aDocPos) == sal_True )
4643     {
4644         if (rView.GetDrawFuncPtr())
4645         {
4646             rView.GetDrawFuncPtr()->Deactivate();
4647             rView.SetDrawFuncPtr(NULL);
4648             rView.LeaveDrawCreate();
4649         }
4650         rView.NoRotate();
4651         rView.AttrChangedNotify( &rView.GetWrtShell() );
4652     }
4653 }
4654 
4655 /******************************************************************************
4656  *  Beschreibung: DrawMode einschalten
4657  ******************************************************************************/
4658 
4659 
4660 
4661 sal_Bool SwEditWin::EnterDrawMode(const MouseEvent& rMEvt, const Point& aDocPos)
4662 {
4663     SwWrtShell &rSh = rView.GetWrtShell();
4664     SdrView *pSdrView = rSh.GetDrawView();
4665 
4666     if ( rView.GetDrawFuncPtr() )
4667     {
4668         if (rSh.IsDrawCreate())
4669             return sal_True;
4670 
4671         sal_Bool bRet = rView.GetDrawFuncPtr()->MouseButtonDown( rMEvt );
4672         rView.AttrChangedNotify( &rSh );
4673         return bRet;
4674     }
4675 
4676     if ( pSdrView && pSdrView->IsTextEdit() )
4677     {
4678         sal_Bool bUnLockView = !rSh.IsViewLocked();
4679         rSh.LockView( sal_True );
4680 
4681         rSh.EndTextEdit(); // Danebengeklickt, Ende mit Edit
4682         rSh.SelectObj( aDocPos );
4683         if ( !rSh.IsObjSelected() && !rSh.IsFrmSelected() )
4684             rSh.LeaveSelFrmMode();
4685         else
4686         {
4687             SwEditWin::nDDStartPosY = aDocPos.Y();
4688             SwEditWin::nDDStartPosX = aDocPos.X();
4689             bFrmDrag = sal_True;
4690         }
4691         if( bUnLockView )
4692             rSh.LockView( sal_False );
4693         rView.AttrChangedNotify( &rSh );
4694         return sal_True;
4695     }
4696     return sal_False;
4697 }
4698 
4699 /******************************************************************************
4700  *  Beschreibung:
4701  ******************************************************************************/
4702 
4703 
4704 
4705 sal_Bool SwEditWin::IsDrawSelMode()
4706 {
4707     return IsObjectSelect();
4708 }
4709 
4710 /******************************************************************************
4711  *  Beschreibung:
4712  ******************************************************************************/
4713 
4714 
4715 void SwEditWin::GetFocus()
4716 {
4717     if ( rView.GetPostItMgr()->HasActiveSidebarWin() )
4718     {
4719         rView.GetPostItMgr()->GrabFocusOnActiveSidebarWin();
4720     }
4721 	else
4722 	{
4723 		rView.GotFocus();
4724 		Window::GetFocus();
4725 		rView.GetWrtShell().InvalidateAccessibleFocus();
4726 	}
4727 }
4728 
4729 /******************************************************************************
4730  *  Beschreibung:
4731  ******************************************************************************/
4732 
4733 
4734 
4735 void SwEditWin::LoseFocus()
4736 {
4737     rView.GetWrtShell().InvalidateAccessibleFocus();
4738     Window::LoseFocus();
4739     if( pQuickHlpData->bClear )
4740         pQuickHlpData->Stop( rView.GetWrtShell() );
4741     rView.LostFocus();
4742 }
4743 
4744 /******************************************************************************
4745  *  Beschreibung:
4746  ******************************************************************************/
4747 
4748 
4749 
4750 void SwEditWin::Command( const CommandEvent& rCEvt )
4751 {
4752     SwWrtShell &rSh = rView.GetWrtShell();
4753 
4754 	if ( !rView.GetViewFrame() )
4755 	{
4756 		//Wenn der ViewFrame in Kuerze stirbt kein Popup mehr!
4757 		Window::Command(rCEvt);
4758 		return;
4759 	}
4760 
4761     // The command event is send to the window after a possible context
4762     // menu from an inplace client has been closed. Now we have the chance
4763     // to deactivate the inplace client without any problem regarding parent
4764     // windows and code on the stack.
4765     // For more information, see #126086# and #128122#
4766     SfxInPlaceClient* pIPClient = rSh.GetSfxViewShell()->GetIPClient();
4767     sal_Bool bIsOleActive = ( pIPClient && pIPClient->IsObjectInPlaceActive() );
4768     if ( bIsOleActive && ( rCEvt.GetCommand() == COMMAND_CONTEXTMENU ))
4769     {
4770         rSh.FinishOLEObj();
4771         return;
4772     }
4773 
4774     sal_Bool bCallBase      = sal_True;
4775 
4776     switch ( rCEvt.GetCommand() )
4777     {
4778         case COMMAND_CONTEXTMENU:
4779         {
4780             const sal_uInt16 nId = SwInputChild::GetChildWindowId();
4781             SwInputChild* pChildWin = (SwInputChild*)GetView().GetViewFrame()->
4782                                                 GetChildWindow( nId );
4783 
4784             if (rView.GetPostItMgr()->IsHit(rCEvt.GetMousePosPixel()))
4785                 return;
4786 
4787             if((!pChildWin || pChildWin->GetView() != &rView) &&
4788                 !rSh.IsDrawCreate() && !IsDrawAction())
4789             {
4790                 SET_CURR_SHELL( &rSh );
4791                 if (!pApplyTempl)
4792                 {
4793                     if (bNoInterrupt == sal_True)
4794                     {
4795                         ReleaseMouse();
4796                         bNoInterrupt = sal_False;
4797                         bMBPressed = sal_False;
4798                     }
4799                     Point aDocPos( PixelToLogic( rCEvt.GetMousePosPixel() ) );
4800                     if ( !rCEvt.IsMouseEvent() )
4801                         aDocPos = rSh.GetCharRect().Center();
4802                     else
4803                     {
4804                         SelectMenuPosition(rSh, rCEvt.GetMousePosPixel());
4805                         rView.StopShellTimer();
4806 
4807                     }
4808                     const Point aPixPos = LogicToPixel( aDocPos );
4809 
4810                     if ( rView.GetDocShell()->IsReadOnly() )
4811                     {
4812                         SwReadOnlyPopup* pROPopup = new SwReadOnlyPopup( aDocPos, rView );
4813 
4814                         ui::ContextMenuExecuteEvent aEvent;
4815                         aEvent.SourceWindow = VCLUnoHelper::GetInterface( this );
4816                         aEvent.ExecutePosition.X = aPixPos.X();
4817                         aEvent.ExecutePosition.Y = aPixPos.Y();
4818                         Menu* pMenu = 0;
4819                         ::rtl::OUString sMenuName =
4820                             ::rtl::OUString::createFromAscii( "private:resource/ReadonlyContextMenu");
4821                         if( GetView().TryContextMenuInterception( *pROPopup, sMenuName, pMenu, aEvent ) )
4822                         {
4823                             if ( pMenu )
4824                             {
4825                                 sal_uInt16 nExecId = ((PopupMenu*)pMenu)->Execute(this, aPixPos);
4826                                 if( !::ExecuteMenuCommand( *static_cast<PopupMenu*>(pMenu), *rView.GetViewFrame(), nExecId ))
4827                                     pROPopup->Execute(this, nExecId);
4828                             }
4829                             else
4830                                 pROPopup->Execute(this, aPixPos);
4831                         }
4832                         delete pROPopup;
4833                     }
4834                     else if ( !rView.ExecSpellPopup( aDocPos ) )
4835                         GetView().GetViewFrame()->GetDispatcher()->ExecutePopup( 0, this, &aPixPos);
4836                 }
4837                 else if (pApplyTempl->bUndo)
4838                     rSh.Do(SwWrtShell::UNDO);
4839                 bCallBase = sal_False;
4840             }
4841         }
4842         break;
4843 
4844         case COMMAND_WHEEL:
4845         case COMMAND_STARTAUTOSCROLL:
4846         case COMMAND_AUTOSCROLL:
4847             if( pShadCrsr )
4848                 delete pShadCrsr, pShadCrsr = 0;
4849             bCallBase = !rView.HandleWheelCommands( rCEvt );
4850             break;
4851 
4852         case COMMAND_VOICE:
4853             {
4854                 //ggf. an Outliner weiterleiten
4855                 if ( rSh.HasDrawView() && rSh.GetDrawView()->IsTextEdit() )
4856                 {
4857                     bCallBase = sal_False;
4858                     rSh.GetDrawView()->GetTextEditOutlinerView()->Command( rCEvt );
4859                     break;
4860                 }
4861 
4862                 const CommandVoiceData *pCData = rCEvt.GetVoiceData();
4863                 if ( VOICECOMMANDTYPE_CONTROL == pCData->GetType() )
4864                     break;
4865 
4866 
4867                 sal_uInt16 nSlotId = 0;
4868                 SfxPoolItem *pItem = 0;
4869 
4870                 switch ( pCData->GetCommand() )
4871                 {
4872                     case DICTATIONCOMMAND_NEWPARAGRAPH: nSlotId = FN_INSERT_BREAK; break;
4873                     case DICTATIONCOMMAND_NEWLINE:      nSlotId = FN_INSERT_LINEBREAK; break;
4874                     case DICTATIONCOMMAND_LEFT:         nSlotId = FN_PREV_WORD; break;
4875                     case DICTATIONCOMMAND_RIGHT:        nSlotId = FN_NEXT_WORD; break;
4876                     case DICTATIONCOMMAND_UP:           nSlotId = FN_LINE_UP; break;
4877                     case DICTATIONCOMMAND_DOWN:         nSlotId = FN_LINE_DOWN; break;
4878                     case DICTATIONCOMMAND_UNDO:         nSlotId = SID_UNDO; break;
4879                     case DICTATIONCOMMAND_REPEAT:       nSlotId = SID_REPEAT; break;
4880                     case DICTATIONCOMMAND_DEL:          nSlotId = FN_DELETE_BACK_WORD; break;
4881 
4882                     case DICTATIONCOMMAND_BOLD_ON:      nSlotId = SID_ATTR_CHAR_WEIGHT;
4883                                                         pItem = new SvxWeightItem( WEIGHT_BOLD, RES_CHRATR_WEIGHT );
4884                                                         break;
4885                     case DICTATIONCOMMAND_BOLD_OFF:     nSlotId = SID_ATTR_CHAR_WEIGHT;
4886                                                         pItem = new SvxWeightItem( WEIGHT_NORMAL, RES_CHRATR_WEIGHT );
4887                                                         break;
4888                     case DICTATIONCOMMAND_UNDERLINE_ON: nSlotId = SID_ATTR_CHAR_UNDERLINE;
4889                                                         pItem = new SvxUnderlineItem( UNDERLINE_SINGLE, RES_CHRATR_WEIGHT );
4890                                                         break;
4891                     case DICTATIONCOMMAND_UNDERLINE_OFF:nSlotId = SID_ATTR_CHAR_UNDERLINE;
4892                                                         pItem = new SvxUnderlineItem( UNDERLINE_NONE, RES_CHRATR_UNDERLINE );
4893                                                         break;
4894                     case DICTATIONCOMMAND_ITALIC_ON:    nSlotId = SID_ATTR_CHAR_POSTURE;
4895                                                         pItem = new SvxPostureItem( ITALIC_NORMAL, RES_CHRATR_POSTURE );
4896                                                         break;
4897                     case DICTATIONCOMMAND_ITALIC_OFF:   nSlotId = SID_ATTR_CHAR_POSTURE;
4898                                                         pItem = new SvxPostureItem( ITALIC_NONE, RES_CHRATR_POSTURE );
4899                                                         break;
4900                     case DICTATIONCOMMAND_NUMBERING_ON:
4901                                     if ( !rSh.GetNumRuleAtCurrCrsrPos() )
4902                                         nSlotId = FN_NUM_NUMBERING_ON;
4903                                     break;
4904                     case DICTATIONCOMMAND_NUMBERING_OFF:
4905                                     if ( rSh.GetNumRuleAtCurrCrsrPos() )
4906                                        nSlotId = FN_NUM_NUMBERING_ON;
4907                                     break;
4908                     case DICTATIONCOMMAND_TAB:
4909                                     {
4910                                        rSh.Insert( '\t' );
4911                                     }
4912                                     break;
4913                     case DICTATIONCOMMAND_UNKNOWN:
4914                                     {
4915                                         rView.GetWrtShell().Insert( pCData->GetText() );
4916                                     }
4917                                     break;
4918 
4919 #ifdef DBG_UTIL
4920                     default:
4921                         ASSERT( !this, "unknown speech command." );
4922 #endif
4923                 }
4924                 if ( nSlotId )
4925                 {
4926                     bCallBase = sal_False;
4927                     if ( pItem )
4928                     {
4929                         const SfxPoolItem* aArgs[2];
4930                         aArgs[0] = pItem;
4931                         aArgs[1] = 0;
4932                         GetView().GetViewFrame()->GetBindings().Execute(
4933                                     nSlotId, aArgs, 0, SFX_CALLMODE_STANDARD );
4934                         delete pItem;
4935                     }
4936                     else
4937                         GetView().GetViewFrame()->GetBindings().Execute( nSlotId );
4938                 }
4939             }
4940             break;
4941 
4942     case COMMAND_STARTEXTTEXTINPUT:
4943     {
4944         sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly() &&
4945                               rSh.IsCrsrReadonly();
4946         if(!bIsDocReadOnly)
4947         {
4948             if( rSh.HasDrawView() && rSh.GetDrawView()->IsTextEdit() )
4949             {
4950                 bCallBase = sal_False;
4951                 rSh.GetDrawView()->GetTextEditOutlinerView()->Command( rCEvt );
4952             }
4953             else
4954             {
4955                 if( rSh.HasSelection() )
4956                     rSh.DelRight();
4957 
4958                 bCallBase = sal_False;
4959                 LanguageType eInputLanguage = GetInputLanguage();
4960                 rSh.CreateExtTextInput(eInputLanguage);
4961             }
4962         }
4963         break;
4964     }
4965     case COMMAND_ENDEXTTEXTINPUT:
4966     {
4967         sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly() &&
4968                               rSh.IsCrsrReadonly();
4969         if(!bIsDocReadOnly)
4970         {
4971             if( rSh.HasDrawView() && rSh.GetDrawView()->IsTextEdit() )
4972             {
4973                 bCallBase = sal_False;
4974                 rSh.GetDrawView()->GetTextEditOutlinerView()->Command( rCEvt );
4975             }
4976             else
4977             {
4978                 bCallBase = sal_False;
4979                 String sRecord = rSh.DeleteExtTextInput();
4980                 uno::Reference< frame::XDispatchRecorder > xRecorder =
4981                         rView.GetViewFrame()->GetBindings().GetRecorder();
4982 
4983                 if ( sRecord.Len() )
4984                 {
4985                     // #102812# convert quotes in IME text
4986                     // works on the last input character, this is escpecially in Korean text often done
4987                     // quotes that are inside of the string are not replaced!
4988                     const sal_Unicode aCh = sRecord.GetChar(sRecord.Len() - 1);
4989                     SvxAutoCorrCfg* pACfg = SvxAutoCorrCfg::Get();
4990                     SvxAutoCorrect* pACorr = pACfg->GetAutoCorrect();
4991                     if(pACorr &&
4992                         (( pACorr->IsAutoCorrFlag( ChgQuotes ) && ('\"' == aCh ))||
4993                         ( pACorr->IsAutoCorrFlag( ChgSglQuotes ) && ( '\'' == aCh))))
4994                     {
4995                         rSh.DelLeft();
4996                         rSh.AutoCorrect( *pACorr, aCh );
4997                     }
4998 
4999                     if ( xRecorder.is() )
5000                     {
5001                         //Shell ermitteln
5002                         SfxShell *pSfxShell = lcl_GetShellFromDispatcher( rView, TYPE(SwTextShell) );
5003                         // Request generieren und recorden
5004                         if (pSfxShell)
5005                         {
5006                             SfxRequest aReq( rView.GetViewFrame(), FN_INSERT_STRING );
5007                             aReq.AppendItem( SfxStringItem( FN_INSERT_STRING, sRecord ) );
5008                             aReq.Done();
5009                         }
5010                     }
5011                 }
5012             }
5013         }
5014     }
5015     break;
5016     case COMMAND_EXTTEXTINPUT:
5017     {
5018         sal_Bool bIsDocReadOnly = rView.GetDocShell()->IsReadOnly() &&
5019                               rSh.IsCrsrReadonly();
5020         if(!bIsDocReadOnly)
5021         {
5022             QuickHelpData aTmpQHD;
5023             if( pQuickHlpData->bClear )
5024             {
5025                 aTmpQHD.Move( *pQuickHlpData );
5026                 pQuickHlpData->Stop( rSh );
5027             }
5028             String sWord;
5029             if( rSh.HasDrawView() && rSh.GetDrawView()->IsTextEdit() )
5030             {
5031                 bCallBase = sal_False;
5032                 rSh.GetDrawView()->GetTextEditOutlinerView()->Command( rCEvt );
5033             }
5034             else
5035             {
5036                 const CommandExtTextInputData* pData = rCEvt.GetExtTextInputData();
5037                 if( pData )
5038                 {
5039                     sWord = pData->GetText();
5040                     bCallBase = sal_False;
5041                     rSh.SetExtTextInputData( *pData );
5042                 }
5043             }
5044                 uno::Reference< frame::XDispatchRecorder > xRecorder =
5045                         rView.GetViewFrame()->GetBindings().GetRecorder();
5046                 if(!xRecorder.is())
5047                 {
5048                     SvxAutoCorrCfg* pACfg = SvxAutoCorrCfg::Get();
5049                     SvxAutoCorrect* pACorr = pACfg->GetAutoCorrect();
5050                     if( pACfg && pACorr &&
5051                         ( pACfg->IsAutoTextTip() ||
5052                           pACorr->GetSwFlags().bAutoCompleteWords ) &&
5053                         rSh.GetPrevAutoCorrWord( *pACorr, sWord ) )
5054                     {
5055                         ShowAutoTextCorrectQuickHelp(sWord, pACfg, pACorr, sal_True);
5056                     }
5057                 }
5058         }
5059     }
5060     break;
5061     case COMMAND_CURSORPOS:
5062         // will be handled by the base class
5063         break;
5064 
5065     case COMMAND_PASTESELECTION:
5066         if( !rView.GetDocShell()->IsReadOnly() )
5067         {
5068             TransferableDataHelper aDataHelper(
5069                         TransferableDataHelper::CreateFromSelection( this ));
5070             if( !aDataHelper.GetXTransferable().is() )
5071                 break;
5072 
5073             sal_uLong nDropFormat;
5074             sal_uInt16 nEventAction, nDropAction, nDropDestination;
5075             nDropDestination = GetDropDestination( rCEvt.GetMousePosPixel() );
5076             if( !nDropDestination )
5077                 break;
5078 
5079             nDropAction = SotExchange::GetExchangeAction(
5080                                 aDataHelper.GetDataFlavorExVector(),
5081                                 nDropDestination, EXCHG_IN_ACTION_COPY,
5082                                 EXCHG_IN_ACTION_COPY, nDropFormat,
5083                                 nEventAction );
5084             if( EXCHG_INOUT_ACTION_NONE != nDropAction )
5085             {
5086                 const Point aDocPt( PixelToLogic( rCEvt.GetMousePosPixel() ) );
5087                 SwTransferable::PasteData( aDataHelper, rSh, nDropAction,
5088                                     nDropFormat, nDropDestination, sal_False,
5089                                     sal_False, &aDocPt, EXCHG_IN_ACTION_COPY,
5090                                     sal_True );
5091             }
5092         }
5093         break;
5094         case COMMAND_MODKEYCHANGE :
5095         {
5096             const CommandModKeyData* pCommandData = (const CommandModKeyData*)rCEvt.GetData();
5097             if(pCommandData->IsMod1() && !pCommandData->IsMod2())
5098             {
5099                 sal_uInt16 nSlot = 0;
5100                 if(pCommandData->IsLeftShift() && !pCommandData->IsRightShift())
5101                     nSlot = SID_ATTR_PARA_LEFT_TO_RIGHT;
5102                 else if(!pCommandData->IsLeftShift() && pCommandData->IsRightShift())
5103                     nSlot = SID_ATTR_PARA_RIGHT_TO_LEFT;
5104                 if(nSlot && SW_MOD()->GetCTLOptions().IsCTLFontEnabled())
5105                     GetView().GetViewFrame()->GetDispatcher()->Execute(nSlot);
5106             }
5107         }
5108         break;
5109         case COMMAND_HANGUL_HANJA_CONVERSION :
5110             GetView().GetViewFrame()->GetDispatcher()->Execute(SID_HANGUL_HANJA_CONVERSION);
5111         break;
5112         case COMMAND_INPUTLANGUAGECHANGE :
5113             //#i42732# update state of fontname if input language changes
5114             bInputLanguageSwitched = true;
5115             SetUseInputLanguage( sal_True );
5116         break;
5117         case COMMAND_SELECTIONCHANGE:
5118         {
5119             const CommandSelectionChangeData *pData = rCEvt.GetSelectionChangeData();
5120             rSh.SttCrsrMove();
5121             rSh.GoStartSentence();
5122             rSh.GetCrsr()->GetPoint()->nContent += sal::static_int_cast<sal_uInt16, sal_uLong>(pData->GetStart());
5123             rSh.SetMark();
5124             rSh.GetCrsr()->GetMark()->nContent += sal::static_int_cast<sal_uInt16, sal_uLong>(pData->GetEnd() - pData->GetStart());
5125             rSh.EndCrsrMove( sal_True );
5126         }
5127         break;
5128         case COMMAND_PREPARERECONVERSION:
5129         if( rSh.HasSelection() )
5130         {
5131             SwPaM *pCrsr = (SwPaM*)rSh.GetCrsr();
5132 
5133             if( rSh.IsMultiSelection() )
5134             {
5135                 if( pCrsr && !pCrsr->HasMark() &&
5136                 pCrsr->GetPoint() == pCrsr->GetMark() )
5137                 {
5138                 rSh.GoPrevCrsr();
5139                 pCrsr = (SwPaM*)rSh.GetCrsr();
5140                 }
5141 
5142                 // Cancel all selections other than the last selected one.
5143                 while( rSh.GetCrsr()->GetNext() != rSh.GetCrsr() )
5144                 delete rSh.GetCrsr()->GetNext();
5145             }
5146 
5147             if( pCrsr )
5148             {
5149                 sal_uLong nPosNodeIdx = pCrsr->GetPoint()->nNode.GetIndex();
5150                 xub_StrLen nPosIdx = pCrsr->GetPoint()->nContent.GetIndex();
5151                 sal_uLong nMarkNodeIdx = pCrsr->GetMark()->nNode.GetIndex();
5152                 xub_StrLen nMarkIdx = pCrsr->GetMark()->nContent.GetIndex();
5153 
5154                 if( !rSh.GetCrsr()->HasMark() )
5155                 rSh.GetCrsr()->SetMark();
5156 
5157                 rSh.SttCrsrMove();
5158 
5159                 if( nPosNodeIdx < nMarkNodeIdx )
5160                 {
5161                 rSh.GetCrsr()->GetPoint()->nNode = nPosNodeIdx;
5162                 rSh.GetCrsr()->GetPoint()->nContent = nPosIdx;
5163                 rSh.GetCrsr()->GetMark()->nNode = nPosNodeIdx;
5164                 rSh.GetCrsr()->GetMark()->nContent =
5165                     rSh.GetCrsr()->GetCntntNode( sal_True )->Len();
5166                 }
5167                 else if( nPosNodeIdx == nMarkNodeIdx )
5168                 {
5169                 rSh.GetCrsr()->GetPoint()->nNode = nPosNodeIdx;
5170                 rSh.GetCrsr()->GetPoint()->nContent = nPosIdx;
5171                 rSh.GetCrsr()->GetMark()->nNode = nMarkNodeIdx;
5172                 rSh.GetCrsr()->GetMark()->nContent = nMarkIdx;
5173                 }
5174                 else
5175                 {
5176                 rSh.GetCrsr()->GetMark()->nNode = nMarkNodeIdx;
5177                 rSh.GetCrsr()->GetMark()->nContent = nMarkIdx;
5178                 rSh.GetCrsr()->GetPoint()->nNode = nMarkNodeIdx;
5179                 rSh.GetCrsr()->GetPoint()->nContent =
5180                     rSh.GetCrsr()->GetCntntNode( sal_False )->Len();
5181                 }
5182 
5183                 rSh.EndCrsrMove( sal_True );
5184             }
5185         }
5186         break;
5187 #ifdef DBG_UTIL
5188         default:
5189             ASSERT( !this, "unknown command." );
5190 #endif
5191     }
5192     if (bCallBase)
5193         Window::Command(rCEvt);
5194 }
5195 
5196 /* -----------------25.08.2003 10:12-----------------
5197     #i18686#: select the object/cursor at the mouse
5198     position of the context menu request
5199  --------------------------------------------------*/
5200 sal_Bool SwEditWin::SelectMenuPosition(SwWrtShell& rSh, const Point& rMousePos )
5201 {
5202     sal_Bool bRet = sal_False;
5203     const Point aDocPos( PixelToLogic( rMousePos ) );
5204     const bool bIsInsideSelectedObj( rSh.IsInsideSelectedObj( aDocPos ) );
5205     //create a synthetic mouse event out of the coordinates
5206     MouseEvent aMEvt(rMousePos);
5207     SdrView *pSdrView = rSh.GetDrawView();
5208     if ( pSdrView )
5209     {
5210         // no close of insert_draw and reset of draw mode,
5211         // if context menu position is inside a selected object.
5212         if ( !bIsInsideSelectedObj && rView.GetDrawFuncPtr() )
5213         {
5214 
5215             rView.GetDrawFuncPtr()->Deactivate();
5216             rView.SetDrawFuncPtr(NULL);
5217             rView.LeaveDrawCreate();
5218             SfxBindings& rBind = rView.GetViewFrame()->GetBindings();
5219             rBind.Invalidate( SID_ATTR_SIZE );
5220             rBind.Invalidate( SID_TABLE_CELL );
5221         }
5222 
5223         // if draw text is active and there's a text selection
5224         // at the mouse position then do nothing
5225         if(rSh.GetSelectionType() & nsSelectionType::SEL_DRW_TXT)
5226         {
5227             OutlinerView* pOLV = pSdrView->GetTextEditOutlinerView();
5228             ESelection aSelection = pOLV->GetSelection();
5229             if(!aSelection.IsZero())
5230             {
5231                 SdrOutliner* pOutliner = pSdrView->GetTextEditOutliner();
5232                 sal_Bool bVertical = pOutliner->IsVertical();
5233                 const EditEngine& rEditEng = pOutliner->GetEditEngine();
5234                 Point aEEPos(aDocPos);
5235                 const Rectangle& rOutputArea = pOLV->GetOutputArea();
5236                 // regard vertical mode
5237                 if(bVertical)
5238                 {
5239                     aEEPos -= rOutputArea.TopRight();
5240                     //invert the horizontal direction and exchange X and Y
5241                     long nTemp = -aEEPos.X();
5242                     aEEPos.X() = aEEPos.Y();
5243                     aEEPos.Y() = nTemp;
5244                 }
5245                 else
5246                     aEEPos -= rOutputArea.TopLeft();
5247 
5248                 EPosition aDocPosition = rEditEng.FindDocPosition(aEEPos);
5249                 ESelection aCompare(aDocPosition.nPara, aDocPosition.nIndex);
5250                 // make it a forward selection - otherwise the IsLess/IsGreater do not work :-(
5251                 aSelection.Adjust();
5252                 if(!aCompare.IsLess(aSelection)  && !aCompare.IsGreater(aSelection))
5253                 {
5254                     return sal_False;
5255                 }
5256             }
5257 
5258         }
5259 
5260         if (pSdrView->MouseButtonDown( aMEvt, this ) )
5261         {
5262             pSdrView->MouseButtonUp( aMEvt, this );
5263             rSh.GetView().GetViewFrame()->GetBindings().InvalidateAll(sal_False);
5264             return sal_True;
5265         }
5266     }
5267     rSh.ResetCursorStack();
5268 
5269     if ( EnterDrawMode( aMEvt, aDocPos ) )
5270     {
5271         return sal_True;
5272     }
5273     if ( rView.GetDrawFuncPtr() && bInsFrm )
5274     {
5275         StopInsFrm();
5276         rSh.Edit();
5277     }
5278 
5279     UpdatePointer( aDocPos, 0 );
5280 
5281     if( !rSh.IsSelFrmMode() &&
5282         !GetView().GetViewFrame()->GetDispatcher()->IsLocked() )
5283     {
5284         // #107513#
5285         // Test if there is a draw object at that position and if it should be selected.
5286         sal_Bool bShould = rSh.ShouldObjectBeSelected(aDocPos);
5287 
5288         if(bShould)
5289         {
5290             rView.NoRotate();
5291             rSh.HideCrsr();
5292 
5293             sal_Bool bUnLockView = !rSh.IsViewLocked();
5294             rSh.LockView( sal_True );
5295             sal_Bool bSelObj = rSh.SelectObj( aDocPos, 0);
5296             if( bUnLockView )
5297                 rSh.LockView( sal_False );
5298 
5299             if( bSelObj )
5300             {
5301                 bRet = sal_True;
5302                 // falls im Macro der Rahmen deselektiert
5303                 // wurde, muss nur noch der Cursor
5304                 // wieder angezeigt werden.
5305                 if( FRMTYPE_NONE == rSh.GetSelFrmType() )
5306                     rSh.ShowCrsr();
5307                 else
5308                 {
5309                     if (rSh.IsFrmSelected() && rView.GetDrawFuncPtr())
5310                     {
5311                         rView.GetDrawFuncPtr()->Deactivate();
5312                         rView.SetDrawFuncPtr(NULL);
5313                         rView.LeaveDrawCreate();
5314                         rView.AttrChangedNotify( &rSh );
5315                     }
5316 
5317                     rSh.EnterSelFrmMode( &aDocPos );
5318                     bFrmDrag = sal_True;
5319                     UpdatePointer( aDocPos, 0 );
5320                     return bRet;
5321                 }
5322             }
5323 
5324             if (!rView.GetDrawFuncPtr())
5325                 rSh.ShowCrsr();
5326         }
5327     }
5328     else if ( rSh.IsSelFrmMode() &&
5329               (aActHitType == SDRHIT_NONE ||
5330                !bIsInsideSelectedObj))
5331     {
5332         rView.NoRotate();
5333         sal_Bool bUnLockView = !rSh.IsViewLocked();
5334         rSh.LockView( sal_True );
5335         sal_uInt8 nFlag = 0;
5336 
5337         if ( rSh.IsSelFrmMode() )
5338         {
5339             rSh.UnSelectFrm();
5340             rSh.LeaveSelFrmMode();
5341             rView.AttrChangedNotify(&rSh);
5342             bRet = sal_True;
5343         }
5344 
5345         sal_Bool bSelObj = rSh.SelectObj( aDocPos, nFlag );
5346         if( bUnLockView )
5347             rSh.LockView( sal_False );
5348 
5349         if( !bSelObj )
5350         {
5351             // Cursor hier umsetzen, damit er nicht zuerst
5352             // im Rahmen gezeichnet wird; ShowCrsr() geschieht
5353             // in LeaveSelFrmMode()
5354             bValidCrsrPos = !(CRSR_POSCHG & (rSh.*rSh.fnSetCrsr)(&aDocPos,sal_False));
5355             rSh.LeaveSelFrmMode();
5356             rView.LeaveDrawCreate();
5357             rView.AttrChangedNotify( &rSh );
5358             bRet = sal_True;
5359         }
5360         else
5361         {
5362             rSh.HideCrsr();
5363             rSh.EnterSelFrmMode( &aDocPos );
5364             rSh.SelFlyGrabCrsr();
5365             rSh.MakeSelVisible();
5366             bFrmDrag = sal_True;
5367             if( rSh.IsFrmSelected() &&
5368                 rView.GetDrawFuncPtr() )
5369             {
5370                 rView.GetDrawFuncPtr()->Deactivate();
5371                 rView.SetDrawFuncPtr(NULL);
5372                 rView.LeaveDrawCreate();
5373                 rView.AttrChangedNotify( &rSh );
5374             }
5375             UpdatePointer( aDocPos, 0 );
5376             bRet = sal_True;
5377         }
5378     }
5379     else if ( rSh.IsSelFrmMode() && bIsInsideSelectedObj )
5380     {
5381         // ## object at the mouse cursor is already selected - do nothing
5382         return sal_False;
5383     }
5384 
5385     if ( rSh.IsGCAttr() )
5386     {
5387         rSh.GCAttr();
5388         rSh.ClearGCAttr();
5389     }
5390 
5391     sal_Bool bOverSelect = rSh.ChgCurrPam( aDocPos ), bOverURLGrf = sal_False;
5392     if( !bOverSelect )
5393         bOverURLGrf = bOverSelect = 0 != rSh.IsURLGrfAtPos( aDocPos );
5394 
5395     if ( !bOverSelect )
5396     {
5397         {   // nur temp. Move-Kontext aufspannen, da sonst die
5398             // Abfrage auf die Inhaltsform nicht funktioniert!!!
5399             MV_KONTEXT( &rSh );
5400             (rSh.*rSh.fnSetCrsr)(&aDocPos, sal_False);
5401             bRet = sal_True;
5402         }
5403     }
5404     if( !bOverURLGrf )
5405     {
5406         const int nSelType = rSh.GetSelectionType();
5407         if( nSelType == nsSelectionType::SEL_OLE ||
5408             nSelType == nsSelectionType::SEL_GRF )
5409         {
5410             MV_KONTEXT( &rSh );
5411             if( !rSh.IsFrmSelected() )
5412                 rSh.GotoNextFly();
5413             rSh.EnterSelFrmMode();
5414             bRet = sal_True;
5415         }
5416     }
5417     return bRet;
5418 }
5419 
5420 SfxShell* lcl_GetShellFromDispatcher( SwView& rView, TypeId nType )
5421 {
5422     //Shell ermitteln
5423     SfxShell* pShell;
5424     SfxDispatcher* pDispatcher = rView.GetViewFrame()->GetDispatcher();
5425     for(sal_uInt16  i = 0; sal_True; ++i )
5426     {
5427         pShell = pDispatcher->GetShell( i );
5428         if( !pShell || pShell->IsA( nType ) )
5429             break;
5430     }
5431     return pShell;
5432 }
5433 
5434 
5435 
5436 void SwEditWin::ClearTip()
5437 {
5438 }
5439 
5440 IMPL_LINK( SwEditWin, KeyInputFlushHandler, Timer *, EMPTYARG )
5441 {
5442     FlushInBuffer();
5443     return 0;
5444 }
5445 
5446 
5447 IMPL_LINK( SwEditWin, KeyInputTimerHandler, Timer *, EMPTYARG )
5448 {
5449     bTblInsDelMode = sal_False;
5450     return 0;
5451 }
5452 
5453 void SwEditWin::_InitStaticData()
5454 {
5455     pQuickHlpData = new QuickHelpData();
5456 }
5457 
5458 void SwEditWin::_FinitStaticData()
5459 {
5460     delete pQuickHlpData;
5461 }
5462 /* -----------------23.01.2003 12:15-----------------
5463  * #i3370# remove quick help to prevent saving
5464  * of autocorrection suggestions
5465  * --------------------------------------------------*/
5466 void SwEditWin::StopQuickHelp()
5467 {
5468     if( HasFocus() && pQuickHlpData && pQuickHlpData->bClear  )
5469         pQuickHlpData->Stop( rView.GetWrtShell() );
5470 }
5471 
5472 /*-----------------23.02.97 18:39-------------------
5473 
5474 --------------------------------------------------*/
5475 
5476 
5477 IMPL_LINK(SwEditWin, TemplateTimerHdl, Timer*, EMPTYARG)
5478 {
5479     SetApplyTemplate(SwApplyTemplate());
5480     return 0;
5481 }
5482 
5483 
5484 void SwEditWin::SetChainMode( sal_Bool bOn )
5485 {
5486     if ( !bChainMode )
5487         StopInsFrm();
5488 
5489     if ( pUserMarker )
5490     {
5491         delete pUserMarker;
5492         pUserMarker = 0L;
5493     }
5494 
5495     bChainMode = bOn;
5496     if ( !bChainMode )
5497         rView.GetViewFrame()->HideStatusText();
5498 
5499     static sal_uInt16 __READONLY_DATA aInva[] =
5500     {
5501         FN_FRAME_CHAIN, FN_FRAME_UNCHAIN, 0
5502     };
5503     rView.GetViewFrame()->GetBindings().Invalidate(aInva);
5504 }
5505 
5506 uno::Reference< ::com::sun::star::accessibility::XAccessible > SwEditWin::CreateAccessible()
5507 {
5508     vos::OGuard aGuard(Application::GetSolarMutex());   // this should have
5509                                                         // happened already!!!
5510     SwWrtShell *pSh = rView.GetWrtShellPtr();
5511     ASSERT( pSh, "no writer shell, no accessible object" );
5512     uno::Reference<
5513         ::com::sun::star::accessibility::XAccessible > xAcc;
5514     if( pSh )
5515         xAcc = pSh->CreateAccessible();
5516 
5517     return xAcc;
5518 }
5519 
5520 //-------------------------------------------------------------
5521 
5522 void QuickHelpData::Move( QuickHelpData& rCpy )
5523 {
5524     // Pointer verschieben
5525     aArr.Insert( &rCpy.aArr );
5526     rCpy.aArr.Remove( (sal_uInt16)0, rCpy.aArr.Count() );
5527 //  nTipId = rCpy.nTipId;
5528     bClear = rCpy.bClear;
5529     nLen = rCpy.nLen;
5530     nCurArrPos = rCpy.nCurArrPos;
5531     bChkInsBlank = rCpy.bChkInsBlank;
5532     bIsTip = rCpy.bIsTip;
5533     bIsAutoText = rCpy.bIsAutoText;
5534 
5535     if( pCETID ) delete pCETID;
5536     pCETID = rCpy.pCETID;
5537     rCpy.pCETID = 0;
5538 
5539     if( pAttrs )
5540         delete[] pAttrs;
5541     pAttrs = rCpy.pAttrs;
5542     rCpy.pAttrs = 0;
5543 }
5544 
5545 void QuickHelpData::ClearCntnt()
5546 {
5547     nLen = nCurArrPos = 0;
5548     bClear = bChkInsBlank = sal_False;
5549     nTipId = 0;
5550     aArr.DeleteAndDestroy( 0 , aArr.Count() );
5551     bIsTip = sal_True;
5552     bIsAutoText = sal_True;
5553     delete pCETID, pCETID = 0;
5554     delete[] pAttrs, pAttrs = 0;
5555 }
5556 
5557 
5558 void QuickHelpData::Start( SwWrtShell& rSh, sal_uInt16 nWrdLen )
5559 {
5560     if( pCETID ) delete pCETID, pCETID = 0;
5561     if( pAttrs ) delete[] pAttrs, pAttrs = 0;
5562 
5563     if( USHRT_MAX != nWrdLen )
5564     {
5565         nLen = nWrdLen;
5566         nCurArrPos = 0;
5567     }
5568     bClear = sal_True;
5569 
5570     Window& rWin = rSh.GetView().GetEditWin();
5571     if( bIsTip )
5572     {
5573         Point aPt( rWin.OutputToScreenPixel( rWin.LogicToPixel(
5574                     rSh.GetCharRect().Pos() )));
5575         aPt.Y() -= 3;
5576         nTipId = Help::ShowTip( &rWin, Rectangle( aPt, Size( 1, 1 )),
5577                         *aArr[ nCurArrPos ],
5578                         QUICKHELP_LEFT | QUICKHELP_BOTTOM );
5579     }
5580     else
5581     {
5582         String sStr( *aArr[ nCurArrPos ] );
5583         sStr.Erase( 0, nLen );
5584         sal_uInt16 nL = sStr.Len();
5585         pAttrs = new sal_uInt16[ nL ];
5586         for( sal_uInt16 n = nL; n;  )
5587             *(pAttrs + --n ) = EXTTEXTINPUT_ATTR_DOTTEDUNDERLINE |
5588                                 EXTTEXTINPUT_ATTR_HIGHLIGHT;
5589         pCETID = new CommandExtTextInputData( sStr, pAttrs, nL,
5590                                                 0, 0, 0, sal_False );
5591         rSh.CreateExtTextInput(rWin.GetInputLanguage());
5592         rSh.SetExtTextInputData( *pCETID );
5593     }
5594 }
5595 
5596 void QuickHelpData::Stop( SwWrtShell& rSh )
5597 {
5598     if( !bIsTip )
5599         rSh.DeleteExtTextInput( 0, sal_False );
5600     else if( nTipId )
5601         Help::HideTip( nTipId );
5602     ClearCntnt();
5603 }
5604 
5605 void QuickHelpData::FillStrArr( SwWrtShell& rSh, const String& rWord )
5606 {
5607     // #i22961# get the letter-case context
5608     const CharClass& rCharClass = GetAppCharClass();
5609     const String aLWord = rCharClass.toLower( rWord, 0, rWord.Len() );
5610     const bool bIsUpper = (rWord == rCharClass.toUpper( rWord, 0, rWord.Len() ) );
5611     const bool bIsLower = (rWord == aLWord);
5612 
5613     // add all matching month/day names from the calendar
5614     salhelper::SingletonRef<SwCalendarWrapper>* pCalendar = s_getCalendarWrapper();
5615     (*pCalendar)->LoadDefaultCalendar( rSh.GetCurLang() );
5616 
5617     {
5618         uno::Sequence< i18n::CalendarItem > aNames(
5619                                             (*pCalendar)->getMonths() );
5620         for( int n = 0; n < 2; ++n )
5621         {
5622             for( long nPos = 0, nEnd = aNames.getLength(); nPos < nEnd; ++nPos )
5623             {
5624                 const String& rS = aNames[ nPos ].FullName;
5625                 if( rS.Len() <= rWord.Len() + 1 )
5626                     continue;
5627                 const String aLName = rCharClass.toLower( rS, 0, rWord.Len() );
5628                 if( aLName != aLWord )
5629                     continue;
5630                 // #i22961# provide case-sensitive autocompletion suggestions
5631                 String* pNew = new String( (bIsUpper==bIsLower) ? rS : (bIsUpper ? rCharClass.toUpper(rS,0,rS.Len()) : rCharClass.toLower(rS,0,rS.Len())) );
5632                 if( !aArr.Insert( pNew ) )
5633                     delete pNew;
5634             }
5635             if( !n )                    // get data for the second loop
5636                 aNames = (*pCalendar)->getDays();
5637         }
5638     }
5639 
5640     // and then add all words from the AutoCompleteWord-List
5641     const SwAutoCompleteWord& rACLst = rSh.GetAutoCompleteWords();
5642     sal_uInt16 nStt, nEnd;
5643     if( rACLst.GetRange( rWord, nStt, nEnd ) )
5644     {
5645         for(; nStt < nEnd; ++nStt )
5646         {
5647             const String& rS = rACLst[ nStt ];
5648             if( rS.Len() <= rWord.Len() )
5649                 continue;
5650             // #i22961# provide case-sensitive autocompletion suggestions
5651             String* pNew = new String( (bIsUpper==bIsLower) ? rS : (bIsUpper ? rCharClass.toUpper(rS,0,rS.Len()) : rCharClass.toLower(rS,0,rS.Len())) );
5652             if( !aArr.Insert( pNew ) )
5653                 delete pNew;
5654         }
5655     }
5656 }
5657 
5658 void SwEditWin::ShowAutoTextCorrectQuickHelp(
5659         const String& rWord, SvxAutoCorrCfg* pACfg, SvxAutoCorrect* pACorr,
5660         sal_Bool bFromIME )
5661 {
5662     SwWrtShell& rSh = rView.GetWrtShell();
5663     pQuickHlpData->ClearCntnt();
5664     if( pACfg->IsAutoTextTip() )
5665     {
5666         SwGlossaryList* pList = ::GetGlossaryList();
5667         pList->HasLongName( rWord, &pQuickHlpData->aArr );
5668     }
5669 
5670     if( pQuickHlpData->aArr.Count() )
5671     {
5672         pQuickHlpData->bIsTip = sal_True;
5673         pQuickHlpData->bIsAutoText = sal_True;
5674     }
5675     else if( pACorr->GetSwFlags().bAutoCompleteWords )
5676     {
5677         pQuickHlpData->bIsAutoText = sal_False;
5678         pQuickHlpData->bIsTip = bFromIME ||
5679                     !pACorr ||
5680                     pACorr->GetSwFlags().bAutoCmpltShowAsTip;
5681 
5682         pQuickHlpData->FillStrArr( rSh, rWord );
5683     }
5684 
5685     if( pQuickHlpData->aArr.Count() )
5686         pQuickHlpData->Start( rSh, rWord.Len() );
5687 }
5688 
5689 /* -----------------29.03.2006 11:01-----------------
5690  *
5691  * --------------------------------------------------*/
5692 
5693 void SwEditWin::SetUseInputLanguage( sal_Bool bNew )
5694 {
5695     if ( bNew || bUseInputLanguage )
5696     {
5697         SfxBindings& rBind = GetView().GetViewFrame()->GetBindings();
5698         rBind.Invalidate( SID_ATTR_CHAR_FONT );
5699         rBind.Invalidate( SID_ATTR_CHAR_FONTHEIGHT );
5700     }
5701     bUseInputLanguage = bNew;
5702 }
5703 
5704 /*-- 13.11.2008 10:18:17---------------------------------------------------
5705 
5706   -----------------------------------------------------------------------*/
5707 XubString SwEditWin::GetSurroundingText() const
5708 {
5709     String sReturn;
5710     SwWrtShell& rSh = rView.GetWrtShell();
5711     if( rSh.HasSelection() && !rSh.IsMultiSelection() && rSh.IsSelOnePara() )
5712         rSh.GetSelectedText( sReturn, GETSELTXT_PARABRK_TO_ONLYCR  );
5713     else if( !rSh.HasSelection() )
5714     {
5715         SwPosition *pPos = rSh.GetCrsr()->GetPoint();
5716         xub_StrLen nPos = pPos->nContent.GetIndex();
5717 
5718         // get the sentence around the cursor
5719         rSh.HideCrsr();
5720         rSh.GoStartSentence();
5721         rSh.SetMark();
5722         rSh.GoEndSentence();
5723         rSh.GetSelectedText( sReturn, GETSELTXT_PARABRK_TO_ONLYCR  );
5724 
5725         pPos->nContent = nPos;
5726         rSh.ClearMark();
5727         rSh.HideCrsr();
5728     }
5729 
5730     return sReturn;
5731 }
5732 /*-- 13.11.2008 10:18:17---------------------------------------------------
5733 
5734   -----------------------------------------------------------------------*/
5735 Selection SwEditWin::GetSurroundingTextSelection() const
5736 {
5737     SwWrtShell& rSh = rView.GetWrtShell();
5738     if( rSh.HasSelection() )
5739     {
5740         String sReturn;
5741         rSh.GetSelectedText( sReturn, GETSELTXT_PARABRK_TO_ONLYCR  );
5742         return Selection( 0, sReturn.Len() );
5743     }
5744     else
5745     {
5746         // Return the position of the visible cursor in the sentence
5747         // around the visible cursor.
5748         SwPosition *pPos = rSh.GetCrsr()->GetPoint();
5749         xub_StrLen nPos = pPos->nContent.GetIndex();
5750 
5751         rSh.HideCrsr();
5752         rSh.GoStartSentence();
5753         xub_StrLen nStartPos = rSh.GetCrsr()->GetPoint()->nContent.GetIndex();
5754 
5755         pPos->nContent = nPos;
5756         rSh.ClearMark();
5757         rSh.ShowCrsr();
5758 
5759         return Selection( nPos - nStartPos, nPos - nStartPos );
5760     }
5761 }
5762 // MT: Removed Windows::SwitchView() introduced with IA2 CWS.
5763 // There are other notifications for this when the active view has chnaged, so please update the code to use that event mechanism
5764 void SwEditWin::SwitchView()
5765 {
5766 #ifdef ACCESSIBLE_LAYOUT
5767 	if (!Application::IsAccessibilityEnabled())
5768 	{
5769 		return ;
5770 	}
5771 	rView.GetWrtShell().InvalidateAccessibleFocus();
5772 #endif
5773 }
5774