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