xref: /trunk/main/sc/source/ui/view/tabvwshb.cxx (revision cf6516809c57e1bb0a940545cca99cdad54d4ce2)
1*b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*b3f79822SAndrew Rist  * distributed with this work for additional information
6*b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9*b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15*b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17*b3f79822SAndrew Rist  * specific language governing permissions and limitations
18*b3f79822SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*b3f79822SAndrew Rist  *************************************************************/
21*b3f79822SAndrew Rist 
22*b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_sc.hxx"
26cdf0e10cSrcweir #include <com/sun/star/embed/NoVisualAreaSizeException.hpp>
27cdf0e10cSrcweir #include <com/sun/star/chart2/data/XDataReceiver.hpp>
28cdf0e10cSrcweir 
29cdf0e10cSrcweir 
30cdf0e10cSrcweir 
31cdf0e10cSrcweir //------------------------------------------------------------------
32cdf0e10cSrcweir 
33cdf0e10cSrcweir #ifdef _MSC_VER
34cdf0e10cSrcweir #pragma optimize ("", off)
35cdf0e10cSrcweir #endif
36cdf0e10cSrcweir 
37cdf0e10cSrcweir // INCLUDE ---------------------------------------------------------------
38cdf0e10cSrcweir 
39cdf0e10cSrcweir #include <com/sun/star/embed/EmbedMisc.hpp>
40cdf0e10cSrcweir #include <com/sun/star/embed/EmbedStates.hpp>
41cdf0e10cSrcweir #include <sfx2/app.hxx>
42cdf0e10cSrcweir #include <toolkit/helper/vclunohelper.hxx>
43cdf0e10cSrcweir #include <svx/svxdlg.hxx>
44cdf0e10cSrcweir #include <svx/dataaccessdescriptor.hxx>
45cdf0e10cSrcweir #include <svx/pfiledlg.hxx>
46cdf0e10cSrcweir #include <svx/svditer.hxx>
47cdf0e10cSrcweir #include <svx/svdmark.hxx>
48cdf0e10cSrcweir #include <svx/svdograf.hxx>
49cdf0e10cSrcweir #include <svx/svdogrp.hxx>
50cdf0e10cSrcweir #include <svx/svdoole2.hxx>
51cdf0e10cSrcweir #include <svx/svdouno.hxx>
52cdf0e10cSrcweir #include <svx/svdview.hxx>
53cdf0e10cSrcweir #include <sfx2/linkmgr.hxx>
54cdf0e10cSrcweir #include <svx/fontworkbar.hxx>
55cdf0e10cSrcweir #include <sfx2/bindings.hxx>
56cdf0e10cSrcweir #include <sfx2/dispatch.hxx>
57cdf0e10cSrcweir #include <sfx2/viewfrm.hxx>
58cdf0e10cSrcweir #include <svtools/soerr.hxx>
59cdf0e10cSrcweir #include <svl/rectitem.hxx>
60cdf0e10cSrcweir #include <svl/slstitm.hxx>
61cdf0e10cSrcweir #include <svl/whiter.hxx>
62cdf0e10cSrcweir #include <unotools/moduleoptions.hxx>
63cdf0e10cSrcweir #include <sot/exchange.hxx>
64cdf0e10cSrcweir #include <tools/diagnose_ex.h>
65cdf0e10cSrcweir 
66cdf0e10cSrcweir #include "tabvwsh.hxx"
67cdf0e10cSrcweir #include "globstr.hrc"
68cdf0e10cSrcweir #include "scmod.hxx"
69cdf0e10cSrcweir #include "document.hxx"
70cdf0e10cSrcweir #include "sc.hrc"
71cdf0e10cSrcweir #include "client.hxx"
72cdf0e10cSrcweir #include "fuinsert.hxx"
73cdf0e10cSrcweir #include "docsh.hxx"
74cdf0e10cSrcweir #include "chartarr.hxx"
75cdf0e10cSrcweir #include "drawview.hxx"
76cdf0e10cSrcweir #include "ChartRangeSelectionListener.hxx"
77cdf0e10cSrcweir 
78cdf0e10cSrcweir using namespace com::sun::star;
79cdf0e10cSrcweir 
80cdf0e10cSrcweir // STATIC DATA -----------------------------------------------------------
81cdf0e10cSrcweir 
ConnectObject(SdrOle2Obj * pObj)82cdf0e10cSrcweir void ScTabViewShell::ConnectObject( SdrOle2Obj* pObj )
83cdf0e10cSrcweir {
84cdf0e10cSrcweir     //  wird aus dem Paint gerufen
85cdf0e10cSrcweir 
86cdf0e10cSrcweir     uno::Reference < embed::XEmbeddedObject > xObj = pObj->GetObjRef();
87cdf0e10cSrcweir     Window* pWin = GetActiveWin();
88cdf0e10cSrcweir 
89cdf0e10cSrcweir     //  #41412# wenn schon connected ist, nicht nochmal SetObjArea/SetSizeScale
90cdf0e10cSrcweir 
91cdf0e10cSrcweir     SfxInPlaceClient* pClient = FindIPClient( xObj, pWin );
92cdf0e10cSrcweir     if ( !pClient )
93cdf0e10cSrcweir     {
94cdf0e10cSrcweir         pClient = new ScClient( this, pWin, GetSdrView()->GetModel(), pObj );
95cdf0e10cSrcweir         Rectangle aRect = pObj->GetLogicRect();
96cdf0e10cSrcweir         Size aDrawSize = aRect.GetSize();
97cdf0e10cSrcweir 
98cdf0e10cSrcweir         Size aOleSize = pObj->GetOrigObjSize();
99cdf0e10cSrcweir 
100cdf0e10cSrcweir         Fraction aScaleWidth (aDrawSize.Width(),  aOleSize.Width() );
101cdf0e10cSrcweir         Fraction aScaleHeight(aDrawSize.Height(), aOleSize.Height() );
102cdf0e10cSrcweir         aScaleWidth.ReduceInaccurate(10);       // kompatibel zum SdrOle2Obj
103cdf0e10cSrcweir         aScaleHeight.ReduceInaccurate(10);
104cdf0e10cSrcweir         pClient->SetSizeScale(aScaleWidth,aScaleHeight);
105cdf0e10cSrcweir 
106cdf0e10cSrcweir         // sichtbarer Ausschnitt wird nur inplace veraendert!
107cdf0e10cSrcweir         // the object area must be set after the scaling since it triggers the resizing
108cdf0e10cSrcweir         aRect.SetSize( aOleSize );
109cdf0e10cSrcweir         pClient->SetObjArea( aRect );
110cdf0e10cSrcweir 
111cdf0e10cSrcweir         ((ScClient*)pClient)->SetGrafEdit( NULL );
112cdf0e10cSrcweir     }
113cdf0e10cSrcweir }
114cdf0e10cSrcweir 
ActivateObject(SdrOle2Obj * pObj,long nVerb)115cdf0e10cSrcweir sal_Bool ScTabViewShell::ActivateObject( SdrOle2Obj* pObj, long nVerb )
116cdf0e10cSrcweir {
117cdf0e10cSrcweir     // #41081# Gueltigkeits-Hinweisfenster nicht ueber dem Objekt stehenlassen
118cdf0e10cSrcweir     RemoveHintWindow();
119cdf0e10cSrcweir 
120cdf0e10cSrcweir     uno::Reference < embed::XEmbeddedObject > xObj = pObj->GetObjRef();
121cdf0e10cSrcweir     Window* pWin = GetActiveWin();
122cdf0e10cSrcweir     ErrCode nErr = ERRCODE_NONE;
123cdf0e10cSrcweir     sal_Bool bErrorShown = sal_False;
124cdf0e10cSrcweir 
125cdf0e10cSrcweir     // linked objects aren't supported
126cdf0e10cSrcweir //  if ( xIPObj->IsLink() )
127cdf0e10cSrcweir //      nErr = xIPObj->DoVerb(nVerb);           // gelinkt -> ohne Client etc.
128cdf0e10cSrcweir //  else
129cdf0e10cSrcweir     {
130cdf0e10cSrcweir         SfxInPlaceClient* pClient = FindIPClient( xObj, pWin );
131cdf0e10cSrcweir         if ( !pClient )
132cdf0e10cSrcweir             pClient = new ScClient( this, pWin, GetSdrView()->GetModel(), pObj );
133cdf0e10cSrcweir 
134cdf0e10cSrcweir         if ( !(nErr & ERRCODE_ERROR_MASK) && xObj.is() )
135cdf0e10cSrcweir         {
136cdf0e10cSrcweir             Rectangle aRect = pObj->GetLogicRect();
137a5258243SPedro Giffuni 
138a5258243SPedro Giffuni             {
139a5258243SPedro Giffuni                 // #i118485# center on BoundRect for activation,
140a5258243SPedro Giffuni                 // OLE may be sheared/rotated now
141a5258243SPedro Giffuni                 const Rectangle& rBoundRect = pObj->GetCurrentBoundRect();
142a5258243SPedro Giffuni                 const Point aDelta(rBoundRect.Center() - aRect.Center());
143a5258243SPedro Giffuni                 aRect.Move(aDelta.X(), aDelta.Y());
144a5258243SPedro Giffuni             }
145a5258243SPedro Giffuni 
146cdf0e10cSrcweir             Size aDrawSize = aRect.GetSize();
147cdf0e10cSrcweir 
148cdf0e10cSrcweir             MapMode aMapMode( MAP_100TH_MM );
149cdf0e10cSrcweir             Size aOleSize = pObj->GetOrigObjSize( &aMapMode );
150cdf0e10cSrcweir 
151cdf0e10cSrcweir             if ( pClient->GetAspect() != embed::Aspects::MSOLE_ICON
152cdf0e10cSrcweir               && ( xObj->getStatus( pClient->GetAspect() ) & embed::EmbedMisc::MS_EMBED_RECOMPOSEONRESIZE ) )
153cdf0e10cSrcweir             {
154cdf0e10cSrcweir                 //  scale must always be 1 - change VisArea if different from client size
155cdf0e10cSrcweir 
156cdf0e10cSrcweir                 if ( aDrawSize != aOleSize )
157cdf0e10cSrcweir                 {
158cdf0e10cSrcweir                     MapUnit aUnit = VCLUnoHelper::UnoEmbed2VCLMapUnit( xObj->getMapUnit( pClient->GetAspect() ) );
159cdf0e10cSrcweir                     aOleSize = OutputDevice::LogicToLogic( aDrawSize,
160cdf0e10cSrcweir                                             MAP_100TH_MM, aUnit );
161cdf0e10cSrcweir                     awt::Size aSz( aOleSize.Width(), aOleSize.Height() );
162cdf0e10cSrcweir                     xObj->setVisualAreaSize( pClient->GetAspect(), aSz );
163cdf0e10cSrcweir                 }
164cdf0e10cSrcweir                 Fraction aOne( 1, 1 );
165cdf0e10cSrcweir                 pClient->SetSizeScale( aOne, aOne );
166cdf0e10cSrcweir             }
167cdf0e10cSrcweir             else
168cdf0e10cSrcweir             {
169cdf0e10cSrcweir                 //  calculate scale from client and VisArea size
170cdf0e10cSrcweir 
171cdf0e10cSrcweir                 Fraction aScaleWidth (aDrawSize.Width(),  aOleSize.Width() );
172cdf0e10cSrcweir                 Fraction aScaleHeight(aDrawSize.Height(), aOleSize.Height() );
173cdf0e10cSrcweir                 aScaleWidth.ReduceInaccurate(10);       // kompatibel zum SdrOle2Obj
174cdf0e10cSrcweir                 aScaleHeight.ReduceInaccurate(10);
175cdf0e10cSrcweir                 pClient->SetSizeScale(aScaleWidth,aScaleHeight);
176cdf0e10cSrcweir             }
177cdf0e10cSrcweir 
178cdf0e10cSrcweir             // sichtbarer Ausschnitt wird nur inplace veraendert!
179cdf0e10cSrcweir             // the object area must be set after the scaling since it triggers the resizing
180cdf0e10cSrcweir             aRect.SetSize( aOleSize );
181cdf0e10cSrcweir             pClient->SetObjArea( aRect );
182cdf0e10cSrcweir 
183cdf0e10cSrcweir             ((ScClient*)pClient)->SetGrafEdit( NULL );
184cdf0e10cSrcweir 
185cdf0e10cSrcweir             nErr = pClient->DoVerb( nVerb );
186cdf0e10cSrcweir             bErrorShown = sal_True;
187cdf0e10cSrcweir             // SfxViewShell::DoVerb zeigt seine Fehlermeldungen selber an
188cdf0e10cSrcweir 
189cdf0e10cSrcweir             SetNewVisArea();
190cdf0e10cSrcweir 
191cdf0e10cSrcweir             // attach listener to selection changes in chart that affect cell
192cdf0e10cSrcweir             // ranges, so those can be highlighted
193cdf0e10cSrcweir             // note: do that after DoVerb, so that the chart controller exists
194cdf0e10cSrcweir             if ( SvtModuleOptions().IsChart() )
195cdf0e10cSrcweir             {
196cdf0e10cSrcweir                 SvGlobalName aObjClsId ( xObj->getClassID() );
197cdf0e10cSrcweir                 if (SotExchange::IsChart( aObjClsId ))
198cdf0e10cSrcweir                 {
199cdf0e10cSrcweir                     try
200cdf0e10cSrcweir                     {
201cdf0e10cSrcweir                         uno::Reference < embed::XComponentSupplier > xSup( xObj, uno::UNO_QUERY_THROW );
202cdf0e10cSrcweir                         uno::Reference< chart2::data::XDataReceiver > xDataReceiver(
203cdf0e10cSrcweir                             xSup->getComponent(), uno::UNO_QUERY_THROW );
204cdf0e10cSrcweir                         uno::Reference< chart2::data::XRangeHighlighter > xRangeHightlighter(
205cdf0e10cSrcweir                             xDataReceiver->getRangeHighlighter());
206cdf0e10cSrcweir                         if( xRangeHightlighter.is())
207cdf0e10cSrcweir                         {
208cdf0e10cSrcweir                             uno::Reference< view::XSelectionChangeListener > xListener(
209cdf0e10cSrcweir                                 new ScChartRangeSelectionListener( this ));
210cdf0e10cSrcweir                             xRangeHightlighter->addSelectionChangeListener( xListener );
211cdf0e10cSrcweir                         }
212cdf0e10cSrcweir                     }
213cdf0e10cSrcweir                     catch( const uno::Exception & )
214cdf0e10cSrcweir                     {
215cdf0e10cSrcweir                         DBG_ERROR( "Exception caught while querying chart" );
216cdf0e10cSrcweir                     }
217cdf0e10cSrcweir                 }
218cdf0e10cSrcweir             }
219cdf0e10cSrcweir         }
220cdf0e10cSrcweir     }
221cdf0e10cSrcweir     if (nErr != ERRCODE_NONE && !bErrorShown)
222cdf0e10cSrcweir         ErrorHandler::HandleError(nErr);
223cdf0e10cSrcweir 
224079eb148SJürgen Schmidt     // #i118524# refresh handles to suppress for activated OLE
225079eb148SJürgen Schmidt     if(GetSdrView())
226079eb148SJürgen Schmidt     {
227079eb148SJürgen Schmidt         GetSdrView()->AdjustMarkHdl();
228079eb148SJürgen Schmidt     }
229cdf0e10cSrcweir     //! SetDocumentName sollte schon im Sfx passieren ???
230cdf0e10cSrcweir     //TODO/LATER: how "SetDocumentName"?
231cdf0e10cSrcweir     //xIPObj->SetDocumentName( GetViewData()->GetDocShell()->GetTitle() );
232cdf0e10cSrcweir 
233cdf0e10cSrcweir     return ( !(nErr & ERRCODE_ERROR_MASK) );
234cdf0e10cSrcweir }
235cdf0e10cSrcweir 
DoVerb(long nVerb)236cdf0e10cSrcweir ErrCode __EXPORT ScTabViewShell::DoVerb(long nVerb)
237cdf0e10cSrcweir {
238cdf0e10cSrcweir     SdrView* pView = GetSdrView();
239cdf0e10cSrcweir     if (!pView)
240cdf0e10cSrcweir         return ERRCODE_SO_NOTIMPL;          // soll nicht sein
241cdf0e10cSrcweir 
242cdf0e10cSrcweir     SdrOle2Obj* pOle2Obj = NULL;
243cdf0e10cSrcweir     SdrGrafObj* pGrafObj = NULL;
244cdf0e10cSrcweir     SdrObject* pObj = NULL;
245cdf0e10cSrcweir     ErrCode nErr = ERRCODE_NONE;
246cdf0e10cSrcweir 
247cdf0e10cSrcweir     const SdrMarkList& rMarkList = pView->GetMarkedObjectList();
248cdf0e10cSrcweir     if (rMarkList.GetMarkCount() == 1)
249cdf0e10cSrcweir     {
250cdf0e10cSrcweir         pObj = rMarkList.GetMark(0)->GetMarkedSdrObj();
251cdf0e10cSrcweir         if (pObj->GetObjIdentifier() == OBJ_OLE2)
252cdf0e10cSrcweir             pOle2Obj = (SdrOle2Obj*) pObj;
253cdf0e10cSrcweir         else if (pObj->GetObjIdentifier() == OBJ_GRAF)
254cdf0e10cSrcweir         {
255cdf0e10cSrcweir             pGrafObj = (SdrGrafObj*) pObj;
256cdf0e10cSrcweir         }
257cdf0e10cSrcweir     }
258cdf0e10cSrcweir 
259cdf0e10cSrcweir     if (pOle2Obj)
260cdf0e10cSrcweir     {
261cdf0e10cSrcweir         ActivateObject( pOle2Obj, nVerb );
262cdf0e10cSrcweir     }
263cdf0e10cSrcweir     else
264cdf0e10cSrcweir     {
265cdf0e10cSrcweir         DBG_ERROR("kein Objekt fuer Verb gefunden");
266cdf0e10cSrcweir     }
267cdf0e10cSrcweir 
268cdf0e10cSrcweir     return nErr;
269cdf0e10cSrcweir }
270cdf0e10cSrcweir 
DeactivateOle()271cdf0e10cSrcweir void ScTabViewShell::DeactivateOle()
272cdf0e10cSrcweir {
273cdf0e10cSrcweir     // deactivate inplace editing if currently active
274cdf0e10cSrcweir 
275cdf0e10cSrcweir     ScModule* pScMod = SC_MOD();
276cdf0e10cSrcweir     bool bUnoRefDialog = pScMod->IsRefDialogOpen() && pScMod->GetCurRefDlgId() == WID_SIMPLE_REF;
277cdf0e10cSrcweir 
278cdf0e10cSrcweir     ScClient* pClient = (ScClient*) GetIPClient();
279cdf0e10cSrcweir     if ( pClient && pClient->IsObjectInPlaceActive() && !bUnoRefDialog )
280cdf0e10cSrcweir         pClient->DeactivateObject();
281cdf0e10cSrcweir }
282cdf0e10cSrcweir 
ExecDrawIns(SfxRequest & rReq)283cdf0e10cSrcweir void ScTabViewShell::ExecDrawIns(SfxRequest& rReq)
284cdf0e10cSrcweir {
285cdf0e10cSrcweir     sal_uInt16 nSlot = rReq.GetSlot();
286cdf0e10cSrcweir     if (nSlot != SID_OBJECTRESIZE )
287cdf0e10cSrcweir     {
288cdf0e10cSrcweir         SC_MOD()->InputEnterHandler();
289cdf0e10cSrcweir         UpdateInputHandler();
290cdf0e10cSrcweir     }
291cdf0e10cSrcweir 
292cdf0e10cSrcweir     //  Rahmen fuer Chart einfuegen wird abgebrochen:
293cdf0e10cSrcweir     FuPoor* pPoor = GetDrawFuncPtr();
294cdf0e10cSrcweir     if ( pPoor && pPoor->GetSlotID() == SID_DRAW_CHART )
295cdf0e10cSrcweir         GetViewData()->GetDispatcher().Execute(SID_DRAW_CHART, SFX_CALLMODE_SLOT | SFX_CALLMODE_RECORD);
296cdf0e10cSrcweir 
297cdf0e10cSrcweir     MakeDrawLayer();
298cdf0e10cSrcweir 
299cdf0e10cSrcweir     SfxBindings& rBindings = GetViewFrame()->GetBindings();
300cdf0e10cSrcweir     ScTabView*   pTabView  = GetViewData()->GetView();
301cdf0e10cSrcweir     Window*      pWin      = pTabView->GetActiveWin();
302cdf0e10cSrcweir     ScDrawView*  pView     = pTabView->GetScDrawView();
303cdf0e10cSrcweir     ScDocShell*  pDocSh    = GetViewData()->GetDocShell();
304cdf0e10cSrcweir     ScDocument*  pDoc      = pDocSh->GetDocument();
305cdf0e10cSrcweir //  SdrModel*    pDrModel  = pDocSh->MakeDrawLayer();
306cdf0e10cSrcweir     SdrModel*    pDrModel  = pView->GetModel();
307cdf0e10cSrcweir 
308cdf0e10cSrcweir     switch ( nSlot )
309cdf0e10cSrcweir     {
310cdf0e10cSrcweir         case SID_INSERT_GRAPHIC:
311cdf0e10cSrcweir             FuInsertGraphic(this, pWin, pView, pDrModel, rReq);
312cdf0e10cSrcweir             // shell is set in MarkListHasChanged
313cdf0e10cSrcweir             break;
314cdf0e10cSrcweir 
315cdf0e10cSrcweir         case SID_INSERT_AVMEDIA:
316cdf0e10cSrcweir             FuInsertMedia(this, pWin, pView, pDrModel, rReq);
317cdf0e10cSrcweir             // shell is set in MarkListHasChanged
318cdf0e10cSrcweir             break;
319cdf0e10cSrcweir 
320cdf0e10cSrcweir         case SID_INSERT_DIAGRAM:
321cdf0e10cSrcweir             FuInsertChart(this, pWin, pView, pDrModel, rReq);
322cdf0e10cSrcweir //?         SC_MOD()->SetFunctionDlg( NULL );//XXX
323cdf0e10cSrcweir             break;
324cdf0e10cSrcweir 
325cdf0e10cSrcweir         case SID_INSERT_OBJECT:
326cdf0e10cSrcweir         case SID_INSERT_PLUGIN:
327cdf0e10cSrcweir         case SID_INSERT_SOUND:
328cdf0e10cSrcweir         case SID_INSERT_VIDEO:
329cdf0e10cSrcweir         case SID_INSERT_SMATH:
330cdf0e10cSrcweir         case SID_INSERT_FLOATINGFRAME:
331cdf0e10cSrcweir             FuInsertOLE(this, pWin, pView, pDrModel, rReq);
332cdf0e10cSrcweir             break;
333cdf0e10cSrcweir 
334cdf0e10cSrcweir         case SID_OBJECTRESIZE:
335cdf0e10cSrcweir             {
336cdf0e10cSrcweir                 //          Der Server moechte die Clientgrosse verandern
337cdf0e10cSrcweir 
338cdf0e10cSrcweir                 SfxInPlaceClient* pClient = GetIPClient();
339cdf0e10cSrcweir 
340cdf0e10cSrcweir                 if ( pClient && pClient->IsObjectInPlaceActive() )
341cdf0e10cSrcweir                 {
342cdf0e10cSrcweir                     const SfxRectangleItem& rRect =
343cdf0e10cSrcweir                         (SfxRectangleItem&)rReq.GetArgs()->Get(SID_OBJECTRESIZE);
344cdf0e10cSrcweir                     Rectangle aRect( pWin->PixelToLogic( rRect.GetValue() ) );
345cdf0e10cSrcweir 
346cdf0e10cSrcweir                     if ( pView->AreObjectsMarked() )
347cdf0e10cSrcweir                     {
348cdf0e10cSrcweir                         const SdrMarkList& rMarkList = pView->GetMarkedObjectList();
349cdf0e10cSrcweir 
350cdf0e10cSrcweir                         if (rMarkList.GetMarkCount() == 1)
351cdf0e10cSrcweir                         {
352cdf0e10cSrcweir                             SdrMark* pMark = rMarkList.GetMark(0);
353cdf0e10cSrcweir                             SdrObject* pObj = pMark->GetMarkedSdrObj();
354cdf0e10cSrcweir 
355cdf0e10cSrcweir                             sal_uInt16 nSdrObjKind = pObj->GetObjIdentifier();
356cdf0e10cSrcweir 
357cdf0e10cSrcweir                             if (nSdrObjKind == OBJ_OLE2)
358cdf0e10cSrcweir                             {
359cdf0e10cSrcweir                                 if ( ( (SdrOle2Obj*) pObj)->GetObjRef().is() )
360cdf0e10cSrcweir                                 {
361cdf0e10cSrcweir                                     pObj->SetLogicRect(aRect);
362cdf0e10cSrcweir                                 }
363cdf0e10cSrcweir                             }
364cdf0e10cSrcweir                         }
365cdf0e10cSrcweir                     }
366cdf0e10cSrcweir                 }
367cdf0e10cSrcweir             }
368cdf0e10cSrcweir             break;
369cdf0e10cSrcweir 
370cdf0e10cSrcweir         case SID_LINKS:
371cdf0e10cSrcweir             {
372cdf0e10cSrcweir                 SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
373cdf0e10cSrcweir                 SfxAbstractLinksDialog* pDlg = pFact->CreateLinksDialog( pWin, pDoc->GetLinkManager() );
374cdf0e10cSrcweir                 if ( pDlg )
375cdf0e10cSrcweir                 {
376cdf0e10cSrcweir                     pDlg->Execute();
377cdf0e10cSrcweir                     rBindings.Invalidate( nSlot );
378cdf0e10cSrcweir                     SFX_APP()->Broadcast( SfxSimpleHint( SC_HINT_AREALINKS_CHANGED ) );     // Navigator
379cdf0e10cSrcweir                     rReq.Done();
380cdf0e10cSrcweir                 }
381cdf0e10cSrcweir             }
382cdf0e10cSrcweir             break;
383cdf0e10cSrcweir 
384cdf0e10cSrcweir         // #98721#
385cdf0e10cSrcweir         case SID_FM_CREATE_FIELDCONTROL:
386cdf0e10cSrcweir             {
387cdf0e10cSrcweir                 SFX_REQUEST_ARG( rReq, pDescriptorItem, SfxUnoAnyItem, SID_FM_DATACCESS_DESCRIPTOR, sal_False );
388cdf0e10cSrcweir                 DBG_ASSERT( pDescriptorItem, "SID_FM_CREATE_FIELDCONTROL: invalid request args!" );
389cdf0e10cSrcweir 
390cdf0e10cSrcweir                 if(pDescriptorItem)
391cdf0e10cSrcweir                 {
392cdf0e10cSrcweir                     //! merge with ScViewFunc::PasteDataFormat (SOT_FORMATSTR_ID_SBA_FIELDDATAEXCHANGE)?
393cdf0e10cSrcweir 
394cdf0e10cSrcweir                     ScDrawView* pDrView = GetScDrawView();
395cdf0e10cSrcweir                     SdrPageView* pPageView = pDrView ? pDrView->GetSdrPageView() : NULL;
396cdf0e10cSrcweir                     if(pPageView)
397cdf0e10cSrcweir                     {
398cdf0e10cSrcweir                         ::svx::ODataAccessDescriptor aDescriptor(pDescriptorItem->GetValue());
399cdf0e10cSrcweir                         SdrObject* pNewDBField = pDrView->CreateFieldControl(aDescriptor);
400cdf0e10cSrcweir 
401cdf0e10cSrcweir                         if(pNewDBField)
402cdf0e10cSrcweir                         {
403cdf0e10cSrcweir                             Rectangle aVisArea = pWin->PixelToLogic(Rectangle(Point(0,0), pWin->GetOutputSizePixel()));
404cdf0e10cSrcweir                             Point aObjPos(aVisArea.Center());
405cdf0e10cSrcweir                             Size aObjSize(pNewDBField->GetLogicRect().GetSize());
406cdf0e10cSrcweir                             aObjPos.X() -= aObjSize.Width() / 2;
407cdf0e10cSrcweir                             aObjPos.Y() -= aObjSize.Height() / 2;
408cdf0e10cSrcweir                             Rectangle aNewObjectRectangle(aObjPos, aObjSize);
409cdf0e10cSrcweir 
410cdf0e10cSrcweir                             pNewDBField->SetLogicRect(aNewObjectRectangle);
411cdf0e10cSrcweir 
412cdf0e10cSrcweir                             // controls must be on control layer, groups on front layer
413cdf0e10cSrcweir                             if ( pNewDBField->ISA(SdrUnoObj) )
414cdf0e10cSrcweir                                 pNewDBField->NbcSetLayer(SC_LAYER_CONTROLS);
415cdf0e10cSrcweir                             else
416cdf0e10cSrcweir                                 pNewDBField->NbcSetLayer(SC_LAYER_FRONT);
417cdf0e10cSrcweir                             if (pNewDBField->ISA(SdrObjGroup))
418cdf0e10cSrcweir                             {
419cdf0e10cSrcweir                                 SdrObjListIter aIter( *pNewDBField, IM_DEEPWITHGROUPS );
420cdf0e10cSrcweir                                 SdrObject* pSubObj = aIter.Next();
421cdf0e10cSrcweir                                 while (pSubObj)
422cdf0e10cSrcweir                                 {
423cdf0e10cSrcweir                                     if ( pSubObj->ISA(SdrUnoObj) )
424cdf0e10cSrcweir                                         pSubObj->NbcSetLayer(SC_LAYER_CONTROLS);
425cdf0e10cSrcweir                                     else
426cdf0e10cSrcweir                                         pSubObj->NbcSetLayer(SC_LAYER_FRONT);
427cdf0e10cSrcweir                                     pSubObj = aIter.Next();
428cdf0e10cSrcweir                                 }
429cdf0e10cSrcweir                             }
430cdf0e10cSrcweir 
431cdf0e10cSrcweir                             pView->InsertObjectAtView(pNewDBField, *pPageView);
432cdf0e10cSrcweir                         }
433cdf0e10cSrcweir                     }
434cdf0e10cSrcweir                 }
435cdf0e10cSrcweir                 rReq.Done();
436cdf0e10cSrcweir             }
437cdf0e10cSrcweir             break;
438cdf0e10cSrcweir 
439cdf0e10cSrcweir         case SID_FONTWORK_GALLERY_FLOATER:
440cdf0e10cSrcweir             svx::FontworkBar::execute( pView, rReq, GetViewFrame()->GetBindings() );
441cdf0e10cSrcweir             rReq.Ignore();
442cdf0e10cSrcweir             break;
443cdf0e10cSrcweir     }
444cdf0e10cSrcweir }
445cdf0e10cSrcweir 
GetDrawInsState(SfxItemSet & rSet)446cdf0e10cSrcweir void ScTabViewShell::GetDrawInsState(SfxItemSet &rSet)
447cdf0e10cSrcweir {
448cdf0e10cSrcweir     sal_Bool bOle = GetViewFrame()->GetFrame().IsInPlace();
449cdf0e10cSrcweir     sal_Bool bTabProt = GetViewData()->GetDocument()->IsTabProtected(GetViewData()->GetTabNo());
450cdf0e10cSrcweir     ScDocShell* pDocShell = ( GetViewData() ? GetViewData()->GetDocShell() : NULL );
451cdf0e10cSrcweir     bool bShared = ( pDocShell ? pDocShell->IsDocShared() : false );
452cdf0e10cSrcweir 
453cdf0e10cSrcweir     SfxWhichIter aIter(rSet);
454cdf0e10cSrcweir     sal_uInt16 nWhich = aIter.FirstWhich();
455cdf0e10cSrcweir     while ( nWhich )
456cdf0e10cSrcweir     {
457cdf0e10cSrcweir         switch ( nWhich )
458cdf0e10cSrcweir         {
459cdf0e10cSrcweir             case SID_INSERT_DIAGRAM:
460cdf0e10cSrcweir                 if ( bOle || bTabProt || !SvtModuleOptions().IsChart() || bShared )
461cdf0e10cSrcweir                     rSet.DisableItem( nWhich );
462cdf0e10cSrcweir                 break;
463cdf0e10cSrcweir 
464cdf0e10cSrcweir             case SID_INSERT_SMATH:
465cdf0e10cSrcweir                 if ( bOle || bTabProt || !SvtModuleOptions().IsMath() || bShared )
466cdf0e10cSrcweir                     rSet.DisableItem( nWhich );
467cdf0e10cSrcweir                 break;
468cdf0e10cSrcweir 
469cdf0e10cSrcweir             case SID_INSERT_OBJECT:
470cdf0e10cSrcweir             case SID_INSERT_PLUGIN:
471cdf0e10cSrcweir             case SID_INSERT_FLOATINGFRAME:
472cdf0e10cSrcweir                 if ( bOle || bTabProt || bShared )
473cdf0e10cSrcweir                     rSet.DisableItem( nWhich );
474cdf0e10cSrcweir                 break;
475cdf0e10cSrcweir 
476cdf0e10cSrcweir             case SID_INSERT_SOUND:
477cdf0e10cSrcweir             case SID_INSERT_VIDEO:
478cdf0e10cSrcweir                  /* #i102735# discussed with NN: removed for performance reasons
479cdf0e10cSrcweir                  || !SvxPluginFileDlg::IsAvailable(nWhich)
480cdf0e10cSrcweir                  */
481cdf0e10cSrcweir                 if ( bOle || bTabProt || bShared )
482cdf0e10cSrcweir                     rSet.DisableItem( nWhich );
483cdf0e10cSrcweir                 break;
484cdf0e10cSrcweir 
485cdf0e10cSrcweir             case SID_INSERT_GRAPHIC:
486cdf0e10cSrcweir             case SID_INSERT_AVMEDIA:
487cdf0e10cSrcweir             case SID_FONTWORK_GALLERY_FLOATER:
488cdf0e10cSrcweir                 if ( bTabProt || bShared )
489cdf0e10cSrcweir                     rSet.DisableItem( nWhich );
490cdf0e10cSrcweir                 break;
491cdf0e10cSrcweir 
492cdf0e10cSrcweir             case SID_LINKS:
493cdf0e10cSrcweir                 {
494cdf0e10cSrcweir                     if (GetViewData()->GetDocument()->GetLinkManager()->GetLinks().Count() == 0 )
495cdf0e10cSrcweir                         rSet.DisableItem( SID_LINKS );
496cdf0e10cSrcweir                 }
497cdf0e10cSrcweir                 break;
498cdf0e10cSrcweir         }
499cdf0e10cSrcweir         nWhich = aIter.NextWhich();
500cdf0e10cSrcweir     }
501cdf0e10cSrcweir }
502cdf0e10cSrcweir 
503cdf0e10cSrcweir 
504cdf0e10cSrcweir //------------------------------------------------------------------
505cdf0e10cSrcweir 
ExecuteUndo(SfxRequest & rReq)506cdf0e10cSrcweir void ScTabViewShell::ExecuteUndo(SfxRequest& rReq)
507cdf0e10cSrcweir {
508cdf0e10cSrcweir     SfxShell* pSh = GetViewData()->GetDispatcher().GetShell(0);
509cdf0e10cSrcweir     ::svl::IUndoManager* pUndoManager = pSh->GetUndoManager();
510cdf0e10cSrcweir 
511cdf0e10cSrcweir     const SfxItemSet* pReqArgs = rReq.GetArgs();
512cdf0e10cSrcweir     ScDocShell* pDocSh = GetViewData()->GetDocShell();
513cdf0e10cSrcweir 
514cdf0e10cSrcweir     sal_uInt16 nSlot = rReq.GetSlot();
515cdf0e10cSrcweir     switch ( nSlot )
516cdf0e10cSrcweir     {
517cdf0e10cSrcweir         case SID_UNDO:
518cdf0e10cSrcweir         case SID_REDO:
519cdf0e10cSrcweir             if ( pUndoManager )
520cdf0e10cSrcweir             {
521cdf0e10cSrcweir                 sal_Bool bIsUndo = ( nSlot == SID_UNDO );
522cdf0e10cSrcweir 
523cdf0e10cSrcweir                 sal_uInt16 nCount = 1;
524cdf0e10cSrcweir                 const SfxPoolItem* pItem;
525cdf0e10cSrcweir                 if ( pReqArgs && pReqArgs->GetItemState( nSlot, sal_True, &pItem ) == SFX_ITEM_SET )
526cdf0e10cSrcweir                     nCount = ((const SfxUInt16Item*)pItem)->GetValue();
527cdf0e10cSrcweir 
528cdf0e10cSrcweir                 // lock paint for more than one cell undo action (not for editing within a cell)
529cdf0e10cSrcweir                 sal_Bool bLockPaint = ( nCount > 1 && pUndoManager == GetUndoManager() );
530cdf0e10cSrcweir                 if ( bLockPaint )
531cdf0e10cSrcweir                     pDocSh->LockPaint();
532cdf0e10cSrcweir 
533cdf0e10cSrcweir                 try
534cdf0e10cSrcweir                 {
535cdf0e10cSrcweir                     for (sal_uInt16 i=0; i<nCount; i++)
536cdf0e10cSrcweir                     {
537cdf0e10cSrcweir                         if ( bIsUndo )
538cdf0e10cSrcweir                             pUndoManager->Undo();
539cdf0e10cSrcweir                         else
540cdf0e10cSrcweir                             pUndoManager->Redo();
541cdf0e10cSrcweir                     }
542cdf0e10cSrcweir                 }
543cdf0e10cSrcweir                 catch ( const uno::Exception& )
544cdf0e10cSrcweir                 {
545cdf0e10cSrcweir                     // no need to handle. By definition, the UndoManager handled this by clearing the
546cdf0e10cSrcweir                     // Undo/Redo stacks
547cdf0e10cSrcweir                 }
548cdf0e10cSrcweir 
549cdf0e10cSrcweir                 if ( bLockPaint )
550cdf0e10cSrcweir                     pDocSh->UnlockPaint();
551cdf0e10cSrcweir 
552cdf0e10cSrcweir                 GetViewFrame()->GetBindings().InvalidateAll(sal_False);
553cdf0e10cSrcweir             }
554cdf0e10cSrcweir             break;
555cdf0e10cSrcweir //      default:
556cdf0e10cSrcweir //          GetViewFrame()->ExecuteSlot( rReq );
557cdf0e10cSrcweir     }
558cdf0e10cSrcweir }
559cdf0e10cSrcweir 
GetUndoState(SfxItemSet & rSet)560cdf0e10cSrcweir void ScTabViewShell::GetUndoState(SfxItemSet &rSet)
561cdf0e10cSrcweir {
562cdf0e10cSrcweir     SfxShell* pSh = GetViewData()->GetDispatcher().GetShell(0);
563cdf0e10cSrcweir     ::svl::IUndoManager* pUndoManager = pSh->GetUndoManager();
564cdf0e10cSrcweir 
565cdf0e10cSrcweir     SfxWhichIter aIter(rSet);
566cdf0e10cSrcweir     sal_uInt16 nWhich = aIter.FirstWhich();
567cdf0e10cSrcweir     while ( nWhich )
568cdf0e10cSrcweir     {
569cdf0e10cSrcweir         switch (nWhich)
570cdf0e10cSrcweir         {
571cdf0e10cSrcweir             case SID_GETUNDOSTRINGS:
572cdf0e10cSrcweir             case SID_GETREDOSTRINGS:
573cdf0e10cSrcweir                 {
574cdf0e10cSrcweir                     SfxStringListItem aStrLst( nWhich );
575cdf0e10cSrcweir                     if ( pUndoManager )
576cdf0e10cSrcweir                     {
577cdf0e10cSrcweir                         List* pList = aStrLst.GetList();
578cdf0e10cSrcweir                         sal_Bool bIsUndo = ( nWhich == SID_GETUNDOSTRINGS );
579cdf0e10cSrcweir                         size_t nCount = bIsUndo ? pUndoManager->GetUndoActionCount() : pUndoManager->GetRedoActionCount();
580cdf0e10cSrcweir                         for (size_t i=0; i<nCount; i++)
581cdf0e10cSrcweir                             pList->Insert( new String( bIsUndo ? pUndoManager->GetUndoActionComment(i) :
582cdf0e10cSrcweir                                                                  pUndoManager->GetRedoActionComment(i) ),
583cdf0e10cSrcweir                                            LIST_APPEND );
584cdf0e10cSrcweir                     }
585cdf0e10cSrcweir                     rSet.Put( aStrLst );
586cdf0e10cSrcweir                 }
587cdf0e10cSrcweir                 break;
588cdf0e10cSrcweir             default:
589cdf0e10cSrcweir                 // get state from sfx view frame
590cdf0e10cSrcweir                 GetViewFrame()->GetSlotState( nWhich, NULL, &rSet );
591cdf0e10cSrcweir         }
592cdf0e10cSrcweir 
593cdf0e10cSrcweir         nWhich = aIter.NextWhich();
594cdf0e10cSrcweir     }
595cdf0e10cSrcweir }
596