xref: /aoo4110/main/sw/source/core/doc/docchart.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_sw.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XModel.hpp>
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski #include <com/sun/star/chart2/XChartDocument.hpp>
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #include <float.h>
33*b1cdbd2cSJim Jagielski #include <hintids.hxx>
34*b1cdbd2cSJim Jagielski #include <vcl/window.hxx>
35*b1cdbd2cSJim Jagielski #include <doc.hxx>
36*b1cdbd2cSJim Jagielski #include <docary.hxx>
37*b1cdbd2cSJim Jagielski #include <ndindex.hxx>
38*b1cdbd2cSJim Jagielski #include <swtable.hxx>
39*b1cdbd2cSJim Jagielski #include <ndtxt.hxx>
40*b1cdbd2cSJim Jagielski #include <ndole.hxx>
41*b1cdbd2cSJim Jagielski #include <calc.hxx>
42*b1cdbd2cSJim Jagielski #include <frmfmt.hxx>
43*b1cdbd2cSJim Jagielski #include <cellfml.hxx>
44*b1cdbd2cSJim Jagielski #include <viewsh.hxx>
45*b1cdbd2cSJim Jagielski #include <ndole.hxx>
46*b1cdbd2cSJim Jagielski #include <calbck.hxx>
47*b1cdbd2cSJim Jagielski #include <cntfrm.hxx>
48*b1cdbd2cSJim Jagielski #include <swtblfmt.hxx>
49*b1cdbd2cSJim Jagielski #include <tblsel.hxx>
50*b1cdbd2cSJim Jagielski #include <cellatr.hxx>
51*b1cdbd2cSJim Jagielski #include <vos/mutex.hxx>
52*b1cdbd2cSJim Jagielski #include <vcl/svapp.hxx>
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski #include <unochart.hxx>
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski using namespace com::sun::star;
57*b1cdbd2cSJim Jagielski using namespace com::sun::star::uno;
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski 
UpdateCharts() const60*b1cdbd2cSJim Jagielski void SwTable::UpdateCharts() const
61*b1cdbd2cSJim Jagielski {
62*b1cdbd2cSJim Jagielski     GetFrmFmt()->GetDoc()->UpdateCharts( GetFrmFmt()->GetName() );
63*b1cdbd2cSJim Jagielski }
64*b1cdbd2cSJim Jagielski 
IsTblComplexForChart(const String & rSelection,SwChartLines * pGetCLines) const65*b1cdbd2cSJim Jagielski sal_Bool SwTable::IsTblComplexForChart( const String& rSelection,
66*b1cdbd2cSJim Jagielski 									SwChartLines* pGetCLines ) const
67*b1cdbd2cSJim Jagielski {
68*b1cdbd2cSJim Jagielski 	const SwTableBox* pSttBox, *pEndBox;
69*b1cdbd2cSJim Jagielski 	if( 2 < rSelection.Len() )
70*b1cdbd2cSJim Jagielski 	{
71*b1cdbd2cSJim Jagielski 		// spitze Klammern am Anfang & Ende enfernen
72*b1cdbd2cSJim Jagielski 		String sBox( rSelection );
73*b1cdbd2cSJim Jagielski 		if( '<' == sBox.GetChar( 0  ) ) sBox.Erase( 0, 1 );
74*b1cdbd2cSJim Jagielski 		if( '>' == sBox.GetChar( sBox.Len()-1  ) ) sBox.Erase( sBox.Len()-1 );
75*b1cdbd2cSJim Jagielski 
76*b1cdbd2cSJim Jagielski 		xub_StrLen nTrenner = sBox.Search( ':' );
77*b1cdbd2cSJim Jagielski 		ASSERT( STRING_NOTFOUND != nTrenner, "keine gueltige Selektion" );
78*b1cdbd2cSJim Jagielski 
79*b1cdbd2cSJim Jagielski 		pSttBox = GetTblBox( sBox.Copy( 0, nTrenner ));
80*b1cdbd2cSJim Jagielski 		pEndBox = GetTblBox( sBox.Copy( nTrenner+1 ));
81*b1cdbd2cSJim Jagielski 	}
82*b1cdbd2cSJim Jagielski 	else
83*b1cdbd2cSJim Jagielski 	{
84*b1cdbd2cSJim Jagielski 		const SwTableLines* pLns = &GetTabLines();
85*b1cdbd2cSJim Jagielski 		pSttBox = (*pLns)[ 0 ]->GetTabBoxes()[ 0 ];
86*b1cdbd2cSJim Jagielski 		while( !pSttBox->GetSttNd() )
87*b1cdbd2cSJim Jagielski 			// bis zur Content Box!
88*b1cdbd2cSJim Jagielski 			pSttBox = pSttBox->GetTabLines()[ 0 ]->GetTabBoxes()[ 0 ];
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski 		const SwTableBoxes* pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
91*b1cdbd2cSJim Jagielski 		pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
92*b1cdbd2cSJim Jagielski 		while( !pEndBox->GetSttNd() )
93*b1cdbd2cSJim Jagielski 		{
94*b1cdbd2cSJim Jagielski 			// bis zur Content Box!
95*b1cdbd2cSJim Jagielski 			pLns = &pEndBox->GetTabLines();
96*b1cdbd2cSJim Jagielski 			pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
97*b1cdbd2cSJim Jagielski 			pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
98*b1cdbd2cSJim Jagielski 		}
99*b1cdbd2cSJim Jagielski 	}
100*b1cdbd2cSJim Jagielski 
101*b1cdbd2cSJim Jagielski 	return !pSttBox || !pEndBox || !::ChkChartSel( *pSttBox->GetSttNd(),
102*b1cdbd2cSJim Jagielski 										*pEndBox->GetSttNd(), pGetCLines );
103*b1cdbd2cSJim Jagielski }
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski 
IMPL_LINK(SwDoc,DoUpdateAllCharts,Timer *,EMPTYARG)107*b1cdbd2cSJim Jagielski IMPL_LINK( SwDoc, DoUpdateAllCharts, Timer *, EMPTYARG )
108*b1cdbd2cSJim Jagielski {
109*b1cdbd2cSJim Jagielski 	ViewShell* pVSh;
110*b1cdbd2cSJim Jagielski 	GetEditShell( &pVSh );
111*b1cdbd2cSJim Jagielski 	if( pVSh )
112*b1cdbd2cSJim Jagielski 	{
113*b1cdbd2cSJim Jagielski 		const SwFrmFmts& rTblFmts = *GetTblFrmFmts();
114*b1cdbd2cSJim Jagielski 		for( sal_uInt16 n = 0; n < rTblFmts.Count(); ++n )
115*b1cdbd2cSJim Jagielski 		{
116*b1cdbd2cSJim Jagielski 			SwTable* pTmpTbl;
117*b1cdbd2cSJim Jagielski 			const SwTableNode* pTblNd;
118*b1cdbd2cSJim Jagielski 			SwFrmFmt* pFmt = rTblFmts[ n ];
119*b1cdbd2cSJim Jagielski 
120*b1cdbd2cSJim Jagielski 			if( 0 != ( pTmpTbl = SwTable::FindTable( pFmt ) ) &&
121*b1cdbd2cSJim Jagielski 				0 != ( pTblNd = pTmpTbl->GetTableNode() ) &&
122*b1cdbd2cSJim Jagielski 				pTblNd->GetNodes().IsDocNodes() )
123*b1cdbd2cSJim Jagielski 			{
124*b1cdbd2cSJim Jagielski 				_UpdateCharts( *pTmpTbl, *pVSh );
125*b1cdbd2cSJim Jagielski 			}
126*b1cdbd2cSJim Jagielski 		}
127*b1cdbd2cSJim Jagielski 	}
128*b1cdbd2cSJim Jagielski 	return 0;
129*b1cdbd2cSJim Jagielski }
130*b1cdbd2cSJim Jagielski 
_UpdateCharts(const SwTable & rTbl,ViewShell & rVSh) const131*b1cdbd2cSJim Jagielski void SwDoc::_UpdateCharts( const SwTable& rTbl, ViewShell& rVSh ) const
132*b1cdbd2cSJim Jagielski {
133*b1cdbd2cSJim Jagielski 	String aName( rTbl.GetFrmFmt()->GetName() );
134*b1cdbd2cSJim Jagielski 	SwOLENode *pONd;
135*b1cdbd2cSJim Jagielski 	SwStartNode *pStNd;
136*b1cdbd2cSJim Jagielski 	SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
137*b1cdbd2cSJim Jagielski 	while( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
138*b1cdbd2cSJim Jagielski 	{
139*b1cdbd2cSJim Jagielski 		aIdx++;
140*b1cdbd2cSJim Jagielski 		SwFrm* pFrm;
141*b1cdbd2cSJim Jagielski 		if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
142*b1cdbd2cSJim Jagielski 			aName.Equals( pONd->GetChartTblName() ) &&
143*b1cdbd2cSJim Jagielski 			0 != ( pFrm = pONd->getLayoutFrm( rVSh.GetLayout() ) ) )
144*b1cdbd2cSJim Jagielski 		{
145*b1cdbd2cSJim Jagielski             SwChartDataProvider *pPCD = GetChartDataProvider();
146*b1cdbd2cSJim Jagielski             if (pPCD)
147*b1cdbd2cSJim Jagielski                 pPCD->InvalidateTable( &rTbl );
148*b1cdbd2cSJim Jagielski 			// following this the framework will now take care of repainting
149*b1cdbd2cSJim Jagielski 			// the chart or it's replacement image...
150*b1cdbd2cSJim Jagielski 		}
151*b1cdbd2cSJim Jagielski 		aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
152*b1cdbd2cSJim Jagielski 	}
153*b1cdbd2cSJim Jagielski }
154*b1cdbd2cSJim Jagielski 
UpdateCharts(const String & rName) const155*b1cdbd2cSJim Jagielski void SwDoc::UpdateCharts( const String &rName ) const
156*b1cdbd2cSJim Jagielski {
157*b1cdbd2cSJim Jagielski 	SwTable* pTmpTbl = SwTable::FindTable( FindTblFmtByName( rName ) );
158*b1cdbd2cSJim Jagielski 	if( pTmpTbl )
159*b1cdbd2cSJim Jagielski 	{
160*b1cdbd2cSJim Jagielski 		ViewShell* pVSh;
161*b1cdbd2cSJim Jagielski 		GetEditShell( &pVSh );
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski 		if( pVSh )
164*b1cdbd2cSJim Jagielski 			_UpdateCharts( *pTmpTbl, *pVSh );
165*b1cdbd2cSJim Jagielski 	}
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski 
SetTableName(SwFrmFmt & rTblFmt,const String & rNewName)168*b1cdbd2cSJim Jagielski void SwDoc::SetTableName( SwFrmFmt& rTblFmt, const String &rNewName )
169*b1cdbd2cSJim Jagielski {
170*b1cdbd2cSJim Jagielski // 	sal_Bool bStop = 1;
171*b1cdbd2cSJim Jagielski 
172*b1cdbd2cSJim Jagielski 	const String aOldName( rTblFmt.GetName() );
173*b1cdbd2cSJim Jagielski 
174*b1cdbd2cSJim Jagielski 	sal_Bool bNameFound = 0 == rNewName.Len();
175*b1cdbd2cSJim Jagielski 	if( !bNameFound )
176*b1cdbd2cSJim Jagielski 	{
177*b1cdbd2cSJim Jagielski 		SwFrmFmt* pFmt;
178*b1cdbd2cSJim Jagielski 		const SwFrmFmts& rTbl = *GetTblFrmFmts();
179*b1cdbd2cSJim Jagielski 		for( sal_uInt16 i = rTbl.Count(); i; )
180*b1cdbd2cSJim Jagielski 			if( !( pFmt = rTbl[ --i ] )->IsDefault() &&
181*b1cdbd2cSJim Jagielski 				pFmt->GetName() == rNewName && IsUsed( *pFmt ) )
182*b1cdbd2cSJim Jagielski 			{
183*b1cdbd2cSJim Jagielski 				bNameFound = sal_True;
184*b1cdbd2cSJim Jagielski 				break;
185*b1cdbd2cSJim Jagielski 			}
186*b1cdbd2cSJim Jagielski 	}
187*b1cdbd2cSJim Jagielski 
188*b1cdbd2cSJim Jagielski 	if( !bNameFound )
189*b1cdbd2cSJim Jagielski 		rTblFmt.SetName( rNewName, sal_True );
190*b1cdbd2cSJim Jagielski 	else
191*b1cdbd2cSJim Jagielski 		rTblFmt.SetName( GetUniqueTblName(), sal_True );
192*b1cdbd2cSJim Jagielski 
193*b1cdbd2cSJim Jagielski 	SwStartNode *pStNd;
194*b1cdbd2cSJim Jagielski 	SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
195*b1cdbd2cSJim Jagielski 	while ( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
196*b1cdbd2cSJim Jagielski 	{
197*b1cdbd2cSJim Jagielski 		aIdx++;
198*b1cdbd2cSJim Jagielski 		SwOLENode *pNd = aIdx.GetNode().GetOLENode();
199*b1cdbd2cSJim Jagielski 		if( pNd && aOldName == pNd->GetChartTblName() )
200*b1cdbd2cSJim Jagielski 		{
201*b1cdbd2cSJim Jagielski 			pNd->SetChartTblName( rNewName );
202*b1cdbd2cSJim Jagielski 
203*b1cdbd2cSJim Jagielski             ViewShell* pVSh;
204*b1cdbd2cSJim Jagielski             GetEditShell( &pVSh );
205*b1cdbd2cSJim Jagielski 
206*b1cdbd2cSJim Jagielski             SwTable* pTable = SwTable::FindTable( &rTblFmt );
207*b1cdbd2cSJim Jagielski             SwChartDataProvider *pPCD = GetChartDataProvider();
208*b1cdbd2cSJim Jagielski             if (pPCD)
209*b1cdbd2cSJim Jagielski                 pPCD->InvalidateTable( pTable );
210*b1cdbd2cSJim Jagielski 			// following this the framework will now take care of repainting
211*b1cdbd2cSJim Jagielski 			// the chart or it's replacement image...
212*b1cdbd2cSJim Jagielski 		}
213*b1cdbd2cSJim Jagielski 		aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
214*b1cdbd2cSJim Jagielski 	}
215*b1cdbd2cSJim Jagielski 	SetModified();
216*b1cdbd2cSJim Jagielski }
217*b1cdbd2cSJim Jagielski 
218*b1cdbd2cSJim Jagielski 
GetChartDataProvider(bool bCreate) const219*b1cdbd2cSJim Jagielski SwChartDataProvider * SwDoc::GetChartDataProvider( bool bCreate ) const
220*b1cdbd2cSJim Jagielski {
221*b1cdbd2cSJim Jagielski     // since there must be only one instance of this object per document
222*b1cdbd2cSJim Jagielski     // we need a mutex here
223*b1cdbd2cSJim Jagielski     vos::OGuard aGuard( Application::GetSolarMutex() );
224*b1cdbd2cSJim Jagielski 
225*b1cdbd2cSJim Jagielski     if (bCreate && !aChartDataProviderImplRef.get())
226*b1cdbd2cSJim Jagielski     {
227*b1cdbd2cSJim Jagielski         aChartDataProviderImplRef = comphelper::ImplementationReference< SwChartDataProvider
228*b1cdbd2cSJim Jagielski             , chart2::data::XDataProvider >( new SwChartDataProvider( this ) );
229*b1cdbd2cSJim Jagielski     }
230*b1cdbd2cSJim Jagielski     return aChartDataProviderImplRef.get();
231*b1cdbd2cSJim Jagielski }
232*b1cdbd2cSJim Jagielski 
233*b1cdbd2cSJim Jagielski 
CreateChartInternalDataProviders(const SwTable * pTable)234*b1cdbd2cSJim Jagielski void SwDoc::CreateChartInternalDataProviders( const SwTable *pTable )
235*b1cdbd2cSJim Jagielski {
236*b1cdbd2cSJim Jagielski     if (pTable)
237*b1cdbd2cSJim Jagielski     {
238*b1cdbd2cSJim Jagielski         String aName( pTable->GetFrmFmt()->GetName() );
239*b1cdbd2cSJim Jagielski         SwOLENode *pONd;
240*b1cdbd2cSJim Jagielski         SwStartNode *pStNd;
241*b1cdbd2cSJim Jagielski         SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
242*b1cdbd2cSJim Jagielski         while (0 != (pStNd = aIdx.GetNode().GetStartNode()))
243*b1cdbd2cSJim Jagielski         {
244*b1cdbd2cSJim Jagielski             aIdx++;
245*b1cdbd2cSJim Jagielski             if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
246*b1cdbd2cSJim Jagielski                 aName.Equals( pONd->GetChartTblName() ) /* OLE node is chart? */ &&
247*b1cdbd2cSJim Jagielski                 0 != (pONd->getLayoutFrm( GetCurrentLayout() )) /* chart frame is not hidden */ )
248*b1cdbd2cSJim Jagielski             {
249*b1cdbd2cSJim Jagielski                 uno::Reference < embed::XEmbeddedObject > xIP = pONd->GetOLEObj().GetOleRef();
250*b1cdbd2cSJim Jagielski                 if ( svt::EmbeddedObjectRef::TryRunningState( xIP ) )
251*b1cdbd2cSJim Jagielski                 {
252*b1cdbd2cSJim Jagielski                     uno::Reference< chart2::XChartDocument > xChart( xIP->getComponent(), UNO_QUERY );
253*b1cdbd2cSJim Jagielski                     if (xChart.is())
254*b1cdbd2cSJim Jagielski                         xChart->createInternalDataProvider( sal_True );
255*b1cdbd2cSJim Jagielski 
256*b1cdbd2cSJim Jagielski                     // there may be more than one chart for each table thus we need to continue the loop...
257*b1cdbd2cSJim Jagielski                 }
258*b1cdbd2cSJim Jagielski             }
259*b1cdbd2cSJim Jagielski             aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
260*b1cdbd2cSJim Jagielski         }
261*b1cdbd2cSJim Jagielski     }
262*b1cdbd2cSJim Jagielski }
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 
GetChartControllerHelper()265*b1cdbd2cSJim Jagielski SwChartLockController_Helper & SwDoc::GetChartControllerHelper()
266*b1cdbd2cSJim Jagielski {
267*b1cdbd2cSJim Jagielski     if (!pChartControllerHelper)
268*b1cdbd2cSJim Jagielski     {
269*b1cdbd2cSJim Jagielski         pChartControllerHelper = new SwChartLockController_Helper( this );
270*b1cdbd2cSJim Jagielski     }
271*b1cdbd2cSJim Jagielski     return *pChartControllerHelper;
272*b1cdbd2cSJim Jagielski }
273*b1cdbd2cSJim Jagielski 
274