summaryrefslogtreecommitdiff
path: root/sw/source/core/doc/docchart.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sw/source/core/doc/docchart.cxx')
-rw-r--r--sw/source/core/doc/docchart.cxx277
1 files changed, 277 insertions, 0 deletions
diff --git a/sw/source/core/doc/docchart.cxx b/sw/source/core/doc/docchart.cxx
new file mode 100644
index 000000000000..85b59cc556df
--- /dev/null
+++ b/sw/source/core/doc/docchart.cxx
@@ -0,0 +1,277 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_sw.hxx"
+
+
+#include <com/sun/star/frame/XModel.hpp>
+
+#include <com/sun/star/chart2/XChartDocument.hpp>
+
+#include <float.h>
+#include <hintids.hxx>
+#include <vcl/window.hxx>
+#include <doc.hxx>
+#include <docary.hxx>
+#include <ndindex.hxx>
+#include <swtable.hxx>
+#include <ndtxt.hxx>
+#include <ndole.hxx>
+#include <calc.hxx>
+#include <frmfmt.hxx>
+#include <cellfml.hxx>
+#include <viewsh.hxx>
+#include <ndole.hxx>
+#include <calbck.hxx>
+#include <cntfrm.hxx>
+#include <swtblfmt.hxx>
+#include <tblsel.hxx>
+#include <cellatr.hxx>
+#include <vos/mutex.hxx>
+#include <vcl/svapp.hxx>
+
+#include <unochart.hxx>
+
+using namespace com::sun::star;
+using namespace com::sun::star::uno;
+
+
+void SwTable::UpdateCharts() const
+{
+ GetFrmFmt()->GetDoc()->UpdateCharts( GetFrmFmt()->GetName() );
+}
+
+BOOL SwTable::IsTblComplexForChart( const String& rSelection,
+ SwChartLines* pGetCLines ) const
+{
+ const SwTableBox* pSttBox, *pEndBox;
+ if( 2 < rSelection.Len() )
+ {
+ // spitze Klammern am Anfang & Ende enfernen
+ String sBox( rSelection );
+ if( '<' == sBox.GetChar( 0 ) ) sBox.Erase( 0, 1 );
+ if( '>' == sBox.GetChar( sBox.Len()-1 ) ) sBox.Erase( sBox.Len()-1 );
+
+ xub_StrLen nTrenner = sBox.Search( ':' );
+ ASSERT( STRING_NOTFOUND != nTrenner, "keine gueltige Selektion" );
+
+ pSttBox = GetTblBox( sBox.Copy( 0, nTrenner ));
+ pEndBox = GetTblBox( sBox.Copy( nTrenner+1 ));
+ }
+ else
+ {
+ const SwTableLines* pLns = &GetTabLines();
+ pSttBox = (*pLns)[ 0 ]->GetTabBoxes()[ 0 ];
+ while( !pSttBox->GetSttNd() )
+ // bis zur Content Box!
+ pSttBox = pSttBox->GetTabLines()[ 0 ]->GetTabBoxes()[ 0 ];
+
+ const SwTableBoxes* pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
+ pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
+ while( !pEndBox->GetSttNd() )
+ {
+ // bis zur Content Box!
+ pLns = &pEndBox->GetTabLines();
+ pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
+ pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
+ }
+ }
+
+ return !pSttBox || !pEndBox || !::ChkChartSel( *pSttBox->GetSttNd(),
+ *pEndBox->GetSttNd(), pGetCLines );
+}
+
+
+
+IMPL_LINK( SwDoc, DoUpdateAllCharts, Timer *, EMPTYARG )
+{
+ ViewShell* pVSh;
+ GetEditShell( &pVSh );
+ if( pVSh )
+ {
+ const SwFrmFmts& rTblFmts = *GetTblFrmFmts();
+ for( USHORT n = 0; n < rTblFmts.Count(); ++n )
+ {
+ SwTable* pTmpTbl;
+ const SwTableNode* pTblNd;
+ SwFrmFmt* pFmt = rTblFmts[ n ];
+
+ if( 0 != ( pTmpTbl = SwTable::FindTable( pFmt ) ) &&
+ 0 != ( pTblNd = pTmpTbl->GetTableNode() ) &&
+ pTblNd->GetNodes().IsDocNodes() )
+ {
+ _UpdateCharts( *pTmpTbl, *pVSh );
+ }
+ }
+ }
+ return 0;
+}
+
+void SwDoc::_UpdateCharts( const SwTable& rTbl, ViewShell& /*rVSh*/ ) const
+{
+ String aName( rTbl.GetFrmFmt()->GetName() );
+ SwOLENode *pONd;
+ SwStartNode *pStNd;
+ SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
+ while( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
+ {
+ aIdx++;
+ SwFrm* pFrm;
+ if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
+ aName.Equals( pONd->GetChartTblName() ) &&
+ 0 != ( pFrm = pONd->GetFrm() ) )
+ {
+ SwChartDataProvider *pPCD = GetChartDataProvider();
+ if (pPCD)
+ pPCD->InvalidateTable( &rTbl );
+ // following this the framework will now take care of repainting
+ // the chart or it's replacement image...
+ }
+ aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
+ }
+}
+
+void SwDoc::UpdateCharts( const String &rName ) const
+{
+ SwTable* pTmpTbl = SwTable::FindTable( FindTblFmtByName( rName ) );
+ if( pTmpTbl )
+ {
+ ViewShell* pVSh;
+ GetEditShell( &pVSh );
+
+ if( pVSh )
+ _UpdateCharts( *pTmpTbl, *pVSh );
+ }
+}
+
+void SwDoc::SetTableName( SwFrmFmt& rTblFmt, const String &rNewName )
+{
+// BOOL bStop = 1;
+
+ const String aOldName( rTblFmt.GetName() );
+
+ BOOL bNameFound = 0 == rNewName.Len();
+ if( !bNameFound )
+ {
+ SwFrmFmt* pFmt;
+ const SwFrmFmts& rTbl = *GetTblFrmFmts();
+ for( USHORT i = rTbl.Count(); i; )
+ if( !( pFmt = rTbl[ --i ] )->IsDefault() &&
+ pFmt->GetName() == rNewName && IsUsed( *pFmt ) )
+ {
+ bNameFound = TRUE;
+ break;
+ }
+ }
+
+ if( !bNameFound )
+ rTblFmt.SetName( rNewName, sal_True );
+ else
+ rTblFmt.SetName( GetUniqueTblName(), sal_True );
+
+ SwStartNode *pStNd;
+ SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
+ while ( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
+ {
+ aIdx++;
+ SwOLENode *pNd = aIdx.GetNode().GetOLENode();
+ if( pNd && aOldName == pNd->GetChartTblName() )
+ {
+ pNd->SetChartTblName( rNewName );
+
+ ViewShell* pVSh;
+ GetEditShell( &pVSh );
+
+ SwTable* pTable = SwTable::FindTable( &rTblFmt );
+ SwChartDataProvider *pPCD = GetChartDataProvider();
+ if (pPCD)
+ pPCD->InvalidateTable( pTable );
+ // following this the framework will now take care of repainting
+ // the chart or it's replacement image...
+ }
+ aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
+ }
+ SetModified();
+}
+
+
+SwChartDataProvider * SwDoc::GetChartDataProvider( bool bCreate ) const
+{
+ // since there must be only one instance of this object per document
+ // we need a mutex here
+ vos::OGuard aGuard( Application::GetSolarMutex() );
+
+ if (bCreate && !aChartDataProviderImplRef.get())
+ {
+ aChartDataProviderImplRef = comphelper::ImplementationReference< SwChartDataProvider
+ , chart2::data::XDataProvider >( new SwChartDataProvider( this ) );
+ }
+ return aChartDataProviderImplRef.get();
+}
+
+
+void SwDoc::CreateChartInternalDataProviders( const SwTable *pTable )
+{
+ if (pTable)
+ {
+ String aName( pTable->GetFrmFmt()->GetName() );
+ SwOLENode *pONd;
+ SwStartNode *pStNd;
+ SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
+ while (0 != (pStNd = aIdx.GetNode().GetStartNode()))
+ {
+ aIdx++;
+ if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
+ aName.Equals( pONd->GetChartTblName() ) /* OLE node is chart? */ &&
+ 0 != (pONd->GetFrm()) /* chart frame is not hidden */ )
+ {
+ uno::Reference < embed::XEmbeddedObject > xIP = pONd->GetOLEObj().GetOleRef();
+ if ( svt::EmbeddedObjectRef::TryRunningState( xIP ) )
+ {
+ uno::Reference< chart2::XChartDocument > xChart( xIP->getComponent(), UNO_QUERY );
+ if (xChart.is())
+ xChart->createInternalDataProvider( sal_True );
+
+ // there may be more than one chart for each table thus we need to continue the loop...
+ }
+ }
+ aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
+ }
+ }
+}
+
+
+SwChartLockController_Helper & SwDoc::GetChartControllerHelper()
+{
+ if (!pChartControllerHelper)
+ {
+ pChartControllerHelper = new SwChartLockController_Helper( this );
+ }
+ return *pChartControllerHelper;
+}
+