/* -*- 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. * ************************************************************************/ #include "vbapagebreak.hxx" #include "vbarange.hxx" #include using namespace ::com::sun::star; using namespace ::ooo::vba; template< typename Ifc1 > ScVbaPageBreak::ScVbaPageBreak( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext, uno::Reference< beans::XPropertySet >& xProps, sheet::TablePageBreakData aTablePageBreakData) throw (uno::RuntimeException): ScVbaPageBreak_BASE( xParent, xContext ), mxRowColPropertySet( xProps ), maTablePageBreakData( aTablePageBreakData ) { } template< typename Ifc1 > sal_Int32 ScVbaPageBreak::getType() throw (uno::RuntimeException) { uno::Any aValue = mxRowColPropertySet->getPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsStartOfNewPage" ))); sal_Bool hasPageBreak = false; aValue >>= hasPageBreak; if( !hasPageBreak ) return excel::XlPageBreak::xlPageBreakNone; if( maTablePageBreakData.ManualBreak ) return excel::XlPageBreak::xlPageBreakManual; return excel::XlPageBreak::xlPageBreakAutomatic; } template< typename Ifc1 > void ScVbaPageBreak::setType(sal_Int32 type) throw (uno::RuntimeException) { if( (type != excel::XlPageBreak::xlPageBreakNone) && (type != excel::XlPageBreak::xlPageBreakManual) && (type != excel::XlPageBreak::xlPageBreakAutomatic) ) { DebugHelper::exception(SbERR_BAD_PARAMETER, rtl::OUString() ); } if( type == excel::XlPageBreak::xlPageBreakNone ) { mxRowColPropertySet->setPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsStartOfNewPage" )), uno::makeAny(sal_False)); return; } mxRowColPropertySet->setPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsStartOfNewPage" )), uno::makeAny(sal_True)); if( type == excel::XlPageBreak::xlPageBreakManual ) maTablePageBreakData.ManualBreak = sal_True; else maTablePageBreakData.ManualBreak = false; } template< typename Ifc1 > void ScVbaPageBreak::Delete() throw ( script::BasicErrorException, uno::RuntimeException) { mxRowColPropertySet->setPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsStartOfNewPage" )), uno::makeAny(sal_False)); } template< typename Ifc1 > uno::Reference< excel::XRange> ScVbaPageBreak::Location() throw ( script::BasicErrorException, uno::RuntimeException) { uno::Reference< table::XCellRange > xRange( mxRowColPropertySet, uno::UNO_QUERY_THROW ); return new ScVbaRange( ScVbaPageBreak_BASE::getParent(), ScVbaPageBreak_BASE::mxContext, xRange); } template< typename Ifc1 > rtl::OUString ScVbaPageBreak::getServiceImplName() { return rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ScVbaPageBreak")); } template< typename Ifc1 > uno::Sequence< rtl::OUString > ScVbaPageBreak::getServiceNames() { static uno::Sequence< rtl::OUString > aServiceNames; if ( aServiceNames.getLength() == 0 ) { aServiceNames.realloc( 1 ); aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.PageBreak" ) ); } return aServiceNames; } template class ScVbaPageBreak< excel::XHPageBreak >; /* class ScVbaHPageBreak */ rtl::OUString ScVbaHPageBreak::getServiceImplName() { return rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ScVbaHPageBreak")); } uno::Sequence< rtl::OUString > ScVbaHPageBreak::getServiceNames() { static uno::Sequence< rtl::OUString > aServiceNames; if ( aServiceNames.getLength() == 0 ) { aServiceNames.realloc( 1 ); aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.HPageBreak" ) ); } return aServiceNames; } template class ScVbaPageBreak< excel::XVPageBreak >; /* class ScVbaVPageBreak */ ScVbaVPageBreak::ScVbaVPageBreak( const css::uno::Reference< ov::XHelperInterface >& xParent, const css::uno::Reference< css::uno::XComponentContext >& xContext, css::uno::Reference< css::beans::XPropertySet >& xProps, css::sheet::TablePageBreakData aTablePageBreakData ) throw ( css::uno::RuntimeException ) : ScVbaVPageBreak_BASE( xParent, xContext, xProps, aTablePageBreakData ) { } ScVbaVPageBreak::~ScVbaVPageBreak() { } rtl::OUString ScVbaVPageBreak::getServiceImplName() { return rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("ScVbaVPageBreak")); } uno::Sequence< rtl::OUString > ScVbaVPageBreak::getServiceNames() { static uno::Sequence< rtl::OUString > aServiceNames; if ( aServiceNames.getLength() == 0 ) { aServiceNames.realloc( 1 ); aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "ooo.vba.excel.VPageBreak" ) ); } return aServiceNames; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */