/* -*- 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 #include #include #include #include #include "excelvbahelper.hxx" #include "vbafont.hxx" #include "vbapalette.hxx" #include #include using namespace ::ooo::vba; using namespace ::com::sun::star; ScVbaFont::ScVbaFont( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext, const ScVbaPalette& dPalette, const uno::Reference< beans::XPropertySet >& xPropertySet, ScCellRangeObj* pRangeObj, bool bFormControl ) : ScVbaFont_BASE( xParent, xContext, dPalette.getPalette(), xPropertySet, Component::EXCEL, bFormControl ), mpRangeObj( pRangeObj ) { } SfxItemSet* ScVbaFont::GetDataSet() { return mpRangeObj ? excel::ScVbaCellRangeAccess::GetDataSet( mpRangeObj ) : nullptr; } ScVbaFont::~ScVbaFont() { } uno::Any SAL_CALL ScVbaFont::getSize() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_HEIGHT) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getSize(); } void SAL_CALL ScVbaFont::setColorIndex( const uno::Any& _colorindex ) { if(mbFormControl) return; sal_Int32 nIndex = 0; _colorindex >>= nIndex; // #FIXME xlColorIndexAutomatic & xlColorIndexNone are not really // handled properly here if ( !nIndex || ( nIndex == excel::XlColorIndex::xlColorIndexAutomatic ) ) { nIndex = 1; // check default ( assume black ) ScVbaFont_BASE::setColorIndex( uno::Any( nIndex ) ); } else ScVbaFont_BASE::setColorIndex( _colorindex ); } uno::Any SAL_CALL ScVbaFont::getColorIndex() { if(mbFormControl) return uno::Any( sal_Int32(0) ); if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_COLOR) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getColorIndex(); } void SAL_CALL ScVbaFont::setStandardFontSize( const uno::Any& /*aValue*/ ) { //XXX #TODO# #FIXME# //mxFont->setPropertyValue("CharSize", ( uno::Any )fValue ); throw uno::RuntimeException( "setStandardFontSize not supported" ); } uno::Any SAL_CALL ScVbaFont::getStandardFontSize() { //XXX #TODO# #FIXME# throw uno::RuntimeException( "getStandardFontSize not supported" ); // return uno::Any(); } void SAL_CALL ScVbaFont::setStandardFont( const uno::Any& /*aValue*/ ) { //XXX #TODO# #FIXME# throw uno::RuntimeException("setStandardFont not supported" ); } uno::Any SAL_CALL ScVbaFont::getStandardFont() { //XXX #TODO# #FIXME# throw uno::RuntimeException("getStandardFont not supported"); // return uno::Any(); } void SAL_CALL ScVbaFont::setFontStyle( const uno::Any& aValue ) { bool bBold = false; bool bItalic = false; OUString aStyles; aValue >>= aStyles; for (sal_Int32 nIdx{ 0 }; nIdx>=0; ) { const std::u16string_view aToken{ o3tl::getToken(aStyles, 0, ' ', nIdx ) }; if (o3tl::equalsIgnoreAsciiCase(aToken, u"Bold")) { bBold = true; if (bItalic) break; } else if (o3tl::equalsIgnoreAsciiCase(aToken, u"Italic")) { bItalic = true; if (bBold) break; } } setBold( uno::Any( bBold ) ); setItalic( uno::Any( bItalic ) ); } uno::Any SAL_CALL ScVbaFont::getFontStyle() { OUStringBuffer aStyles; bool bValue = false; getBold() >>= bValue; if( bValue ) aStyles.append("Bold"); getItalic() >>= bValue; if( bValue ) { if( !aStyles.isEmpty() ) aStyles.append(" "); aStyles.append("Italic"); } return uno::Any( aStyles.makeStringAndClear() ); } uno::Any SAL_CALL ScVbaFont::getBold() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_WEIGHT) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getBold(); } void SAL_CALL ScVbaFont::setUnderline( const uno::Any& aValue ) { if(mbFormControl) return; // default sal_Int32 nValue = excel::XlUnderlineStyle::xlUnderlineStyleNone; aValue >>= nValue; switch ( nValue ) { // NOTE:: #TODO #FIMXE // xlUnderlineStyleDoubleAccounting & xlUnderlineStyleSingleAccounting // don't seem to be supported in Openoffice. // The import filter converts them to single or double underlines as appropriate // So, here at the moment we are similarly silently converting // xlUnderlineStyleSingleAccounting to xlUnderlineStyleSingle. case excel::XlUnderlineStyle::xlUnderlineStyleNone: nValue = awt::FontUnderline::NONE; break; case excel::XlUnderlineStyle::xlUnderlineStyleSingle: case excel::XlUnderlineStyle::xlUnderlineStyleSingleAccounting: nValue = awt::FontUnderline::SINGLE; break; case excel::XlUnderlineStyle::xlUnderlineStyleDouble: case excel::XlUnderlineStyle::xlUnderlineStyleDoubleAccounting: nValue = awt::FontUnderline::DOUBLE; break; default: throw uno::RuntimeException("Unknown value for Underline" ); } mxFont->setPropertyValue("CharUnderline", uno::Any(nValue) ); } uno::Any SAL_CALL ScVbaFont::getUnderline() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_UNDERLINE) == SfxItemState::DONTCARE ) return aNULL(); sal_Int32 nValue = awt::FontUnderline::NONE; if(mbFormControl) return uno::Any( nValue ); mxFont->getPropertyValue("CharUnderline") >>= nValue; switch ( nValue ) { case awt::FontUnderline::DOUBLE: nValue = excel::XlUnderlineStyle::xlUnderlineStyleDouble; break; case awt::FontUnderline::SINGLE: nValue = excel::XlUnderlineStyle::xlUnderlineStyleSingle; break; case awt::FontUnderline::NONE: nValue = excel::XlUnderlineStyle::xlUnderlineStyleNone; break; default: throw uno::RuntimeException("Unknown value retrieved for Underline" ); } return uno::Any( nValue ); } uno::Any SAL_CALL ScVbaFont::getStrikethrough() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_CROSSEDOUT) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getStrikethrough(); } uno::Any SAL_CALL ScVbaFont::getShadow() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_SHADOWED) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getShadow(); } uno::Any SAL_CALL ScVbaFont::getItalic() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_POSTURE) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getItalic(); } uno::Any SAL_CALL ScVbaFont::getName() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT) == SfxItemState::DONTCARE ) return aNULL(); return ScVbaFont_BASE::getName(); } uno::Any ScVbaFont::getColor() { // #TODO #FIXME - behave like getXXX above ( wrt. GetDataSet ) uno::Any aAny = OORGBToXLRGB( mxFont->getPropertyValue("CharColor") ); return aAny; } void SAL_CALL ScVbaFont::setOutlineFont( const uno::Any& aValue ) { if(!mbFormControl) mxFont->setPropertyValue("CharContoured", aValue ); } uno::Any SAL_CALL ScVbaFont::getOutlineFont() { if ( GetDataSet() ) if ( GetDataSet()->GetItemState( ATTR_FONT_CONTOUR) == SfxItemState::DONTCARE ) return aNULL(); return mbFormControl ? uno::Any( false ) : mxFont->getPropertyValue("CharContoured"); } OUString ScVbaFont::getServiceImplName() { return "ScVbaFont"; } uno::Sequence< OUString > ScVbaFont::getServiceNames() { static uno::Sequence< OUString > const aServiceNames { "ooo.vba.excel.Font" }; return aServiceNames; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */