xref: /aoo41x/main/sc/source/ui/view/tabvwshb.cxx (revision b3f79822)
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
10*b3f79822SAndrew Rist  *
11*b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*b3f79822SAndrew Rist  *
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.
19*b3f79822SAndrew Rist  *
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 
146a5258243SPedro Giffuni             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 }
596cdf0e10cSrcweir 
597cdf0e10cSrcweir 
598cdf0e10cSrcweir 
599