diff options
Diffstat (limited to '')
-rw-r--r-- | sc/source/ui/vba/vbapagebreak.cxx | 143 |
1 files changed, 143 insertions, 0 deletions
diff --git a/sc/source/ui/vba/vbapagebreak.cxx b/sc/source/ui/vba/vbapagebreak.cxx new file mode 100644 index 0000000000..2b7d3ff4a6 --- /dev/null +++ b/sc/source/ui/vba/vbapagebreak.cxx @@ -0,0 +1,143 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * 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 "vbapagebreak.hxx" +#include "vbarange.hxx" +#include <basic/sberrors.hxx> +#include <ooo/vba/excel/XlPageBreak.hpp> +#include <com/sun/star/beans/XPropertySet.hpp> +#include <com/sun/star/table/XCellRange.hpp> +#include <utility> + +using namespace ::com::sun::star; +using namespace ::ooo::vba; + +template< typename... Ifc > +ScVbaPageBreak< Ifc... >::ScVbaPageBreak( const uno::Reference< XHelperInterface >& xParent, + const uno::Reference< uno::XComponentContext >& xContext, + uno::Reference< beans::XPropertySet > xProps, + sheet::TablePageBreakData aTablePageBreakData): + ScVbaPageBreak_BASE( xParent, xContext ), + mxRowColPropertySet(std::move( xProps )), + maTablePageBreakData( aTablePageBreakData ) +{ +} + +template< typename... Ifc > +sal_Int32 ScVbaPageBreak< Ifc... >::getType() +{ + uno::Any aValue = mxRowColPropertySet->getPropertyValue("IsStartOfNewPage"); + bool hasPageBreak = false; + aValue >>= hasPageBreak; + + if( !hasPageBreak ) + return excel::XlPageBreak::xlPageBreakNone; + + if( maTablePageBreakData.ManualBreak ) + return excel::XlPageBreak::xlPageBreakManual; + + return excel::XlPageBreak::xlPageBreakAutomatic; +} + +template< typename... Ifc > +void ScVbaPageBreak< Ifc... >::setType(sal_Int32 type) +{ + if( (type != excel::XlPageBreak::xlPageBreakNone) && + (type != excel::XlPageBreak::xlPageBreakManual) && + (type != excel::XlPageBreak::xlPageBreakAutomatic) ) + { + DebugHelper::runtimeexception(ERRCODE_BASIC_BAD_PARAMETER); + } + + if( type == excel::XlPageBreak::xlPageBreakNone ) + { + mxRowColPropertySet->setPropertyValue("IsStartOfNewPage", uno::Any(false)); + return; + } + + mxRowColPropertySet->setPropertyValue("IsStartOfNewPage", uno::Any(true)); + if( type == excel::XlPageBreak::xlPageBreakManual ) + maTablePageBreakData.ManualBreak = true; + else + maTablePageBreakData.ManualBreak = false; +} + +template< typename... Ifc > +void ScVbaPageBreak< Ifc... >::Delete() +{ + mxRowColPropertySet->setPropertyValue("IsStartOfNewPage", uno::Any(false)); +} + +template< typename... Ifc > +uno::Reference< excel::XRange> ScVbaPageBreak< Ifc... >::Location() +{ + uno::Reference< table::XCellRange > xRange( mxRowColPropertySet, uno::UNO_QUERY_THROW ); + return new ScVbaRange( ScVbaPageBreak_BASE::getParent(), ScVbaPageBreak_BASE::mxContext, xRange); +} + +template class ScVbaPageBreak< excel::XHPageBreak >; + +/* class ScVbaHPageBreak */ +OUString +ScVbaHPageBreak::getServiceImplName() +{ + return "ScVbaHPageBreak"; +} + +uno::Sequence< OUString > +ScVbaHPageBreak::getServiceNames() +{ + static uno::Sequence< OUString > const aServiceNames + { + "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, + const css::uno::Reference< css::beans::XPropertySet >& xProps, + css::sheet::TablePageBreakData aTablePageBreakData ) +: ScVbaVPageBreak_BASE( xParent, xContext, xProps, aTablePageBreakData ) +{ +} + +ScVbaVPageBreak::~ScVbaVPageBreak() +{ +} + +OUString +ScVbaVPageBreak::getServiceImplName() +{ + return "ScVbaVPageBreak"; +} + +uno::Sequence< OUString > +ScVbaVPageBreak::getServiceNames() +{ + static uno::Sequence< OUString > const aServiceNames + { + "ooo.vba.excel.VPageBreak" + }; + return aServiceNames; +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |