2010-10-14 08:30:41 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2000-09-18 23:08:29 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* 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.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* 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).
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
2008-04-10 12:07:22 +00:00
|
|
|
* 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.
|
2000-09-18 23:08:29 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
2006-09-16 19:50:22 +00:00
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
#include <com/sun/star/frame/XModel.hpp>
|
|
|
|
|
|
|
|
#include <com/sun/star/chart2/XChartDocument.hpp>
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
#include <float.h>
|
|
|
|
#include <hintids.hxx>
|
2001-07-05 09:34:53 +00:00
|
|
|
#include <vcl/window.hxx>
|
2000-09-18 23:08:29 +00:00
|
|
|
#include <doc.hxx>
|
|
|
|
#include <docary.hxx>
|
|
|
|
#include <ndindex.hxx>
|
|
|
|
#include <swtable.hxx>
|
|
|
|
#include <ndtxt.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>
|
2010-10-16 03:22:02 -05:00
|
|
|
#include <osl/mutex.hxx>
|
2007-05-22 15:24:32 +00:00
|
|
|
#include <vcl/svapp.hxx>
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
#include <unochart.hxx>
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
using namespace com::sun::star;
|
|
|
|
using namespace com::sun::star::uno;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2000-11-07 09:05:20 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
void SwTable::UpdateCharts() const
|
|
|
|
{
|
|
|
|
GetFrmFmt()->GetDoc()->UpdateCharts( GetFrmFmt()->GetName() );
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
|
2012-04-25 11:55:03 +02:00
|
|
|
sal_Bool SwTable::IsTblComplexForChart( const String& rSelection ) const
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
const SwTableBox* pSttBox, *pEndBox;
|
|
|
|
if( 2 < rSelection.Len() )
|
|
|
|
{
|
2011-11-04 14:46:42 +01:00
|
|
|
// Remove brackets at the beginning and from the end
|
2000-09-18 23:08:29 +00:00
|
|
|
String sBox( rSelection );
|
|
|
|
if( '<' == sBox.GetChar( 0 ) ) sBox.Erase( 0, 1 );
|
|
|
|
if( '>' == sBox.GetChar( sBox.Len()-1 ) ) sBox.Erase( sBox.Len()-1 );
|
|
|
|
|
2011-11-04 14:46:42 +01:00
|
|
|
xub_StrLen nSeperator = sBox.Search( ':' );
|
|
|
|
OSL_ENSURE( STRING_NOTFOUND != nSeperator, "no valid selection" );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2011-11-04 14:46:42 +01:00
|
|
|
pSttBox = GetTblBox( sBox.Copy( 0, nSeperator ));
|
|
|
|
pEndBox = GetTblBox( sBox.Copy( nSeperator+1 ));
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
const SwTableLines* pLns = &GetTabLines();
|
|
|
|
pSttBox = (*pLns)[ 0 ]->GetTabBoxes()[ 0 ];
|
|
|
|
while( !pSttBox->GetSttNd() )
|
2011-11-04 14:46:42 +01:00
|
|
|
// Until the Content Box!
|
2000-09-18 23:08:29 +00:00
|
|
|
pSttBox = pSttBox->GetTabLines()[ 0 ]->GetTabBoxes()[ 0 ];
|
|
|
|
|
|
|
|
const SwTableBoxes* pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
|
|
|
|
pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
|
|
|
|
while( !pEndBox->GetSttNd() )
|
|
|
|
{
|
2011-11-04 14:46:42 +01:00
|
|
|
// Until the Content Box!
|
2000-09-18 23:08:29 +00:00
|
|
|
pLns = &pEndBox->GetTabLines();
|
|
|
|
pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
|
|
|
|
pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return !pSttBox || !pEndBox || !::ChkChartSel( *pSttBox->GetSttNd(),
|
2012-04-25 11:55:03 +02:00
|
|
|
*pEndBox->GetSttNd() );
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
|
2011-11-06 23:09:41 +00:00
|
|
|
void SwDoc::DoUpdateAllCharts()
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
ViewShell* pVSh;
|
|
|
|
GetEditShell( &pVSh );
|
|
|
|
if( pVSh )
|
|
|
|
{
|
|
|
|
const SwFrmFmts& rTblFmts = *GetTblFrmFmts();
|
2011-01-17 15:06:54 +01:00
|
|
|
for( sal_uInt16 n = 0; n < rTblFmts.Count(); ++n )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
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 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-06-13 15:22:56 +02:00
|
|
|
void SwDoc::_UpdateCharts( const SwTable& rTbl, ViewShell& rVSh ) const
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
|
|
|
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() ) &&
|
2011-08-26 22:13:20 +02:00
|
|
|
pONd->getLayoutFrm( rVSh.GetLayout() ) )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2007-05-22 15:24:32 +00:00
|
|
|
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...
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
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 )
|
|
|
|
{
|
2011-01-17 15:06:54 +01:00
|
|
|
// sal_Bool bStop = 1;
|
2007-05-22 15:24:32 +00:00
|
|
|
|
2000-09-18 23:08:29 +00:00
|
|
|
const String aOldName( rTblFmt.GetName() );
|
|
|
|
|
2011-01-17 15:06:54 +01:00
|
|
|
sal_Bool bNameFound = 0 == rNewName.Len();
|
2000-09-18 23:08:29 +00:00
|
|
|
if( !bNameFound )
|
|
|
|
{
|
|
|
|
SwFrmFmt* pFmt;
|
|
|
|
const SwFrmFmts& rTbl = *GetTblFrmFmts();
|
2011-01-17 15:06:54 +01:00
|
|
|
for( sal_uInt16 i = rTbl.Count(); i; )
|
2000-09-18 23:08:29 +00:00
|
|
|
if( !( pFmt = rTbl[ --i ] )->IsDefault() &&
|
|
|
|
pFmt->GetName() == rNewName && IsUsed( *pFmt ) )
|
|
|
|
{
|
2011-01-17 15:06:54 +01:00
|
|
|
bNameFound = sal_True;
|
2000-09-18 23:08:29 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !bNameFound )
|
2002-07-24 12:14:57 +00:00
|
|
|
rTblFmt.SetName( rNewName, sal_True );
|
2000-09-18 23:08:29 +00:00
|
|
|
else
|
2002-07-24 12:14:57 +00:00
|
|
|
rTblFmt.SetName( GetUniqueTblName(), sal_True );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
|
|
|
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 );
|
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
ViewShell* pVSh;
|
|
|
|
GetEditShell( &pVSh );
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
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
|
2010-10-13 01:44:10 -05:00
|
|
|
SolarMutexGuard aGuard;
|
2000-09-18 23:08:29 +00:00
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
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? */ &&
|
2010-06-13 15:22:56 +02:00
|
|
|
0 != (pONd->getLayoutFrm( GetCurrentLayout() )) /* chart frame is not hidden */ )
|
2007-05-22 15:24:32 +00:00
|
|
|
{
|
|
|
|
uno::Reference < embed::XEmbeddedObject > xIP = pONd->GetOLEObj().GetOleRef();
|
|
|
|
if ( svt::EmbeddedObjectRef::TryRunningState( xIP ) )
|
2000-09-18 23:08:29 +00:00
|
|
|
{
|
2007-05-22 15:24:32 +00:00
|
|
|
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...
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
}
|
2007-05-22 15:24:32 +00:00
|
|
|
aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
|
2000-09-18 23:08:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-05-22 15:24:32 +00:00
|
|
|
SwChartLockController_Helper & SwDoc::GetChartControllerHelper()
|
|
|
|
{
|
|
|
|
if (!pChartControllerHelper)
|
|
|
|
{
|
|
|
|
pChartControllerHelper = new SwChartLockController_Helper( this );
|
|
|
|
}
|
|
|
|
return *pChartControllerHelper;
|
|
|
|
}
|
|
|
|
|
2010-10-14 08:30:41 +02:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|