/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sw.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace com::sun::star; using namespace com::sun::star::uno; void SwTable::UpdateCharts() const { GetFrmFmt()->GetDoc()->UpdateCharts( GetFrmFmt()->GetName() ); } sal_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( ':' ); OSL_ENSURE( 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( sal_uInt16 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++; if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) && aName.Equals( pONd->GetChartTblName() ) && pONd->getLayoutFrm( rVSh.GetLayout() ) ) { 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 ) { // sal_Bool bStop = 1; const String aOldName( rTblFmt.GetName() ); sal_Bool bNameFound = 0 == rNewName.Len(); if( !bNameFound ) { SwFrmFmt* pFmt; const SwFrmFmts& rTbl = *GetTblFrmFmts(); for( sal_uInt16 i = rTbl.Count(); i; ) if( !( pFmt = rTbl[ --i ] )->IsDefault() && pFmt->GetName() == rNewName && IsUsed( *pFmt ) ) { bNameFound = sal_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 SolarMutexGuard aGuard; 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->getLayoutFrm( GetCurrentLayout() )) /* 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; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */