Files
libreoffice/svx/source/table/tablecolumn.cxx

302 lines
8.1 KiB
C++
Raw Normal View History

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
re-base on ALv2 code. Includes: Patch contributed by Christian Lippka impress212: #i113063# patch: dubios self assign in svx/source/dialog/framelink.cxx http://svn.apache.org/viewvc?view=revision&revision=1167619 Patches contributed by Mathias Bauer gnumake4 work variously http://svn.apache.org/viewvc?view=revision&revision=1394707 http://svn.apache.org/viewvc?view=revision&revision=1394326 cws mba34issues01: #i117712#: fix several resource errors introduced by IAccessible2 implementation http://svn.apache.org/viewvc?view=revision&revision=1172343 cws mba34issues01: #i117719#: use correct resource ID http://svn.apache.org/viewvc?view=revision&revision=1172351 Patch contributed by Andre Fischer Do not add targets for junit tests when junit is disabled. http://svn.apache.org/viewvc?view=revision&revision=1241508 Patches contributed by Armin Le-Grand #118804# corrected GraphicExporter behaviour on shortcut when pixel graphic is requested http://svn.apache.org/viewvc?view=revision&revision=1240195 fix for #118525#: Using primitives for chart sub-geometry visualisation http://svn.apache.org/viewvc?view=revision&revision=1226879 #118485# - Styles for OLEs are not saved. http://svn.apache.org/viewvc?view=revision&revision=1182166 #118524: apply patch, followup fixes to 118485 http://svn.apache.org/viewvc?view=revision&revision=1186077 13f79535-47bb-0310-9956-ffa450edef68 Patch contributed by Regina Henschel linecap: Reintegrating finished LineCap feature http://svn.apache.org/viewvc?view=revision&revision=1232507 Patch contributed by Wang Lei (leiw) #i118760# split the first table cell vertically, then undo&redo, the Presentation app will crash http://svn.apache.org/viewvc?view=revision&revision=1301361 cleanup globlmn hacks, undo dependent fixmes.
2012-11-21 22:06:52 +00:00
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <com/sun/star/lang/DisposedException.hpp>
#include "tablecolumn.hxx"
#include "tableundo.hxx"
#include "svx/svdmodel.hxx"
#include "svx/svdotable.hxx"
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::lang;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::table;
using namespace ::com::sun::star::beans;
namespace sdr { namespace table {
const sal_Int32 Property_Width = 0;
const sal_Int32 Property_OptimalWidth = 1;
const sal_Int32 Property_IsVisible = 2;
const sal_Int32 Property_IsStartOfNewPage = 3;
// TableRow
TableColumn::TableColumn( const TableModelRef& xTableModel, sal_Int32 nColumn )
: TableColumnBase( getStaticPropertySetInfo() )
, mxTableModel( xTableModel )
, mnColumn( nColumn )
, mnWidth( 0 )
, mbOptimalWidth( true )
, mbIsVisible( true )
, mbIsStartOfNewPage( false )
{
}
TableColumn::~TableColumn()
{
}
void TableColumn::dispose()
{
mxTableModel.clear();
}
void TableColumn::throwIfDisposed() const throw (::com::sun::star::uno::RuntimeException)
{
if( !mxTableModel.is() )
throw DisposedException();
}
TableColumn& TableColumn::operator=( const TableColumn& r )
{
mnWidth = r.mnWidth;
mbOptimalWidth = r.mbOptimalWidth;
mbIsVisible = r.mbIsVisible;
mbIsStartOfNewPage = r.mbIsStartOfNewPage;
2011-01-04 08:51:03 +01:00
maName = r.maName;
mnColumn = r.mnColumn;
return *this;
}
// XCellRange
Reference< XCell > SAL_CALL TableColumn::getCellByPosition( sal_Int32 nColumn, sal_Int32 nRow ) throw (IndexOutOfBoundsException, RuntimeException, std::exception)
{
throwIfDisposed();
if( nColumn != 0 )
throw IndexOutOfBoundsException();
return mxTableModel->getCellByPosition( mnColumn, nRow );
}
Reference< XCellRange > SAL_CALL TableColumn::getCellRangeByPosition( sal_Int32 nLeft, sal_Int32 nTop, sal_Int32 nRight, sal_Int32 nBottom ) throw (IndexOutOfBoundsException, RuntimeException, std::exception)
{
throwIfDisposed();
if( (nTop >= 0 ) && (nLeft == 0) && (nBottom >= nTop) && (nRight == 0) )
{
return mxTableModel->getCellRangeByPosition( mnColumn, nTop, mnColumn, nBottom );
}
throw IndexOutOfBoundsException();
}
Reference< XCellRange > SAL_CALL TableColumn::getCellRangeByName( const OUString& /*aRange*/ ) throw (RuntimeException, std::exception)
{
return Reference< XCellRange >();
}
// XNamed
OUString SAL_CALL TableColumn::getName() throw (RuntimeException, std::exception)
{
return maName;
}
void SAL_CALL TableColumn::setName( const OUString& aName ) throw (RuntimeException, std::exception)
{
maName = aName;
}
// XFastPropertySet
void SAL_CALL TableColumn::setFastPropertyValue( sal_Int32 nHandle, const Any& aValue ) throw (UnknownPropertyException, PropertyVetoException, IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, RuntimeException, std::exception)
{
bool bOk = false;
bool bChange = false;
SdrModel* pModel = mxTableModel->getSdrTableObj()->GetModel();
TableColumnUndo* pUndo = 0;
if( mxTableModel.is() && mxTableModel->getSdrTableObj() && mxTableModel->getSdrTableObj()->IsInserted() && pModel && pModel->IsUndoEnabled() )
{
TableColumnRef xThis( this );
pUndo = new TableColumnUndo( xThis );
}
switch( nHandle )
{
case Property_Width:
{
sal_Int32 nWidth = mnWidth;
bOk = aValue >>= nWidth;
if( bOk && (nWidth != mnWidth) )
{
mnWidth = nWidth;
mbOptimalWidth = mnWidth == 0;
bChange = true;
}
break;
}
case Property_OptimalWidth:
{
bool bOptimalWidth = mbOptimalWidth;
bOk = aValue >>= bOptimalWidth;
if( bOk && (mbOptimalWidth != bOptimalWidth) )
{
mbOptimalWidth = bOptimalWidth;
if( bOptimalWidth )
mnWidth = 0;
bChange = true;
}
break;
}
case Property_IsVisible:
{
bool bIsVisible = mbIsVisible;
bOk = aValue >>= bIsVisible;
if( bOk && (mbIsVisible != bIsVisible) )
{
mbIsVisible = bIsVisible;
bChange = true;
}
break;
}
case Property_IsStartOfNewPage:
{
bool bIsStartOfNewPage = mbIsStartOfNewPage;
bOk = aValue >>= bIsStartOfNewPage;
if( bOk && (mbIsStartOfNewPage != bIsStartOfNewPage) )
{
mbIsStartOfNewPage = bIsStartOfNewPage;
bChange = true;
}
break;
}
default:
delete pUndo;
throw UnknownPropertyException();
}
if( !bOk )
{
delete pUndo;
throw IllegalArgumentException();
}
if( bChange )
{
if( pUndo )
{
pModel->AddUndo( pUndo );
pUndo = 0;
}
mxTableModel->setModified(sal_True);
}
delete pUndo;
}
Any SAL_CALL TableColumn::getFastPropertyValue( sal_Int32 nHandle ) throw (UnknownPropertyException, WrappedTargetException, RuntimeException, std::exception)
{
switch( nHandle )
{
case Property_Width: return Any( mnWidth );
case Property_OptimalWidth: return Any( mbOptimalWidth );
case Property_IsVisible: return Any( mbIsVisible );
case Property_IsStartOfNewPage: return Any( mbIsStartOfNewPage );
default: throw UnknownPropertyException();
}
}
rtl::Reference< FastPropertySetInfo > TableColumn::getStaticPropertySetInfo()
{
static rtl::Reference< FastPropertySetInfo > xInfo;
if( !xInfo.is() )
{
::osl::MutexGuard aGuard( ::osl::Mutex::getGlobalMutex() );
if( !xInfo.is() )
{
PropertyVector aProperties(6);
aProperties[0].Name = "Width";
aProperties[0].Handle = Property_Width;
aProperties[0].Type = ::cppu::UnoType<sal_Int32>::get();
aProperties[0].Attributes = 0;
aProperties[1].Name = "OptimalWidth";
aProperties[1].Handle = Property_OptimalWidth;
aProperties[1].Type = cppu::UnoType<bool>::get();
aProperties[1].Attributes = 0;
aProperties[2].Name = "IsVisible";
aProperties[2].Handle = Property_IsVisible;
aProperties[2].Type = cppu::UnoType<bool>::get();
aProperties[2].Attributes = 0;
aProperties[3].Name = "IsStartOfNewPage";
aProperties[3].Handle = Property_IsStartOfNewPage;
aProperties[3].Type = cppu::UnoType<bool>::get();
aProperties[3].Attributes = 0;
aProperties[4].Name = "Size";
aProperties[4].Handle = Property_Width;
aProperties[4].Type = ::cppu::UnoType<sal_Int32>::get();
aProperties[4].Attributes = 0;
aProperties[5].Name = "OptimalSize";
aProperties[5].Handle = Property_OptimalWidth;
aProperties[5].Type = cppu::UnoType<bool>::get();
aProperties[5].Attributes = 0;
xInfo.set( new FastPropertySetInfo(aProperties) );
}
}
return xInfo;
}
} }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */