2000-09-18 16:07:07 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: numehelp.cxx,v $
|
|
|
|
*
|
2004-07-13 07:24:27 +00:00
|
|
|
* $Revision: 1.19 $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2004-07-13 07:24:27 +00:00
|
|
|
* last change: $Author: rt $ $Date: 2004-07-13 08:24:27 $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This library 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 for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#include "numehelp.hxx"
|
|
|
|
|
|
|
|
#include "nmspmap.hxx"
|
|
|
|
#include "xmlnmspe.hxx"
|
|
|
|
#include "xmluconv.hxx"
|
|
|
|
|
2001-05-17 13:20:22 +00:00
|
|
|
#ifndef _XMLOFF_XMLTOKEN_HXX
|
|
|
|
#include "xmltoken.hxx"
|
|
|
|
#endif
|
2000-09-18 16:07:07 +00:00
|
|
|
#ifndef _XMLOFF_XMLEXP_HXX
|
|
|
|
#include "xmlexp.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UNO_REFERENCE_H_
|
|
|
|
#include <com/sun/star/uno/Reference.h>
|
|
|
|
#endif
|
|
|
|
#ifndef _RTL_USTRING_HXX_
|
|
|
|
#include <rtl/ustring.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _TOOLS_INTN_HXX
|
|
|
|
#include <tools/intn.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _ZFORLIST_HXX
|
|
|
|
#include <svtools/zforlist.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UTIL_NUMBERFORMAT_HPP_
|
|
|
|
#include <com/sun/star/util/NumberFormat.hpp>
|
|
|
|
#endif
|
2003-03-27 17:21:03 +00:00
|
|
|
#ifndef INCLUDED_RTL_MATH_HXX
|
|
|
|
#include <rtl/math.hxx>
|
2000-09-18 16:07:07 +00:00
|
|
|
#endif
|
2000-10-23 14:34:14 +00:00
|
|
|
#ifndef _TOOLS_DEBUG_HXX
|
|
|
|
#include <tools/debug.hxx>
|
|
|
|
#endif
|
2000-09-18 16:07:07 +00:00
|
|
|
#ifndef _RTL_USTRBUF_HXX_
|
|
|
|
#include <rtl/ustrbuf.hxx>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
using namespace com::sun::star;
|
2001-05-17 13:20:22 +00:00
|
|
|
using namespace xmloff::token;
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
#define XML_TYPE "Type"
|
|
|
|
#define XML_CURRENCYSYMBOL "CurrencySymbol"
|
2001-01-26 16:21:37 +00:00
|
|
|
#define XML_CURRENCYABBREVIATION "CurrencyAbbreviation"
|
2000-09-18 16:07:07 +00:00
|
|
|
#define XML_STANDARDFORMAT "StandardFormat"
|
|
|
|
|
2001-05-16 09:05:41 +00:00
|
|
|
XMLNumberFormatAttributesExportHelper::XMLNumberFormatAttributesExportHelper(
|
2001-05-23 10:36:01 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormatsSupplier >& xTempNumberFormatsSupplier)
|
|
|
|
: pExport(NULL),
|
2003-04-28 15:21:17 +00:00
|
|
|
xNumberFormats(xTempNumberFormatsSupplier.is() ? xTempNumberFormatsSupplier->getNumberFormats() : ::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormats > ()),
|
2003-03-27 17:21:03 +00:00
|
|
|
aNumberFormats(),
|
|
|
|
sStandardFormat(RTL_CONSTASCII_USTRINGPARAM(XML_STANDARDFORMAT)),
|
|
|
|
sType(RTL_CONSTASCII_USTRINGPARAM(XML_TYPE))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
XMLNumberFormatAttributesExportHelper::XMLNumberFormatAttributesExportHelper(
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormatsSupplier >& xTempNumberFormatsSupplier,
|
2004-07-13 07:24:27 +00:00
|
|
|
SvXMLExport& rTempExport )
|
2003-03-27 17:21:03 +00:00
|
|
|
: pExport(&rTempExport),
|
2003-04-28 15:21:17 +00:00
|
|
|
xNumberFormats(xTempNumberFormatsSupplier.is() ? xTempNumberFormatsSupplier->getNumberFormats() : ::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormats > ()),
|
2003-03-27 17:21:03 +00:00
|
|
|
aNumberFormats(),
|
2004-07-13 07:24:27 +00:00
|
|
|
sAttrValueType(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_VALUE_TYPE))),
|
|
|
|
sAttrValue(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_VALUE))),
|
|
|
|
sAttrDateValue(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_DATE_VALUE))),
|
|
|
|
sAttrTimeValue(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_TIME_VALUE))),
|
|
|
|
sAttrBooleanValue(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_BOOLEAN_VALUE))),
|
|
|
|
sAttrStringValue(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_STRING_VALUE))),
|
|
|
|
sAttrCurrency(rTempExport.GetNamespaceMap().GetQNameByKey( XML_NAMESPACE_OFFICE, GetXMLToken(XML_CURRENCY))),
|
2003-03-27 17:21:03 +00:00
|
|
|
sStandardFormat(RTL_CONSTASCII_USTRINGPARAM(XML_STANDARDFORMAT)),
|
|
|
|
sType(RTL_CONSTASCII_USTRINGPARAM(XML_TYPE))
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2001-05-16 09:05:41 +00:00
|
|
|
XMLNumberFormatAttributesExportHelper::~XMLNumberFormatAttributesExportHelper()
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2001-05-17 13:20:22 +00:00
|
|
|
sal_Int16 XMLNumberFormatAttributesExportHelper::GetCellType(const sal_Int32 nNumberFormat, rtl::OUString& sCurrency, sal_Bool& bIsStandard)
|
|
|
|
{
|
|
|
|
XMLNumberFormat aFormat(sEmpty, nNumberFormat, 0);
|
|
|
|
XMLNumberFormatSet::iterator aItr = aNumberFormats.find(aFormat);
|
|
|
|
if (aItr != aNumberFormats.end())
|
2001-05-18 08:43:27 +00:00
|
|
|
{
|
|
|
|
bIsStandard = aItr->bIsStandard;
|
2001-06-08 06:13:34 +00:00
|
|
|
sCurrency = aItr->sCurrency;
|
2001-05-17 13:20:22 +00:00
|
|
|
return aItr->nType;
|
2001-05-18 08:43:27 +00:00
|
|
|
}
|
2001-05-17 13:20:22 +00:00
|
|
|
else
|
|
|
|
{
|
2003-03-27 17:21:03 +00:00
|
|
|
aFormat.nType = GetCellType(nNumberFormat, bIsStandard);
|
2001-05-18 08:43:27 +00:00
|
|
|
aFormat.bIsStandard = bIsStandard;
|
2001-06-08 11:05:54 +00:00
|
|
|
if ((aFormat.nType & ~util::NumberFormat::DEFINED) == util::NumberFormat::CURRENCY)
|
2003-03-27 17:21:03 +00:00
|
|
|
if (GetCurrencySymbol(nNumberFormat, aFormat.sCurrency))
|
2001-05-17 13:20:22 +00:00
|
|
|
sCurrency = aFormat.sCurrency;
|
2001-05-18 08:43:27 +00:00
|
|
|
aNumberFormats.insert(aFormat);
|
2001-05-17 13:20:22 +00:00
|
|
|
return aFormat.nType;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2001-05-16 09:05:41 +00:00
|
|
|
void XMLNumberFormatAttributesExportHelper::WriteAttributes(SvXMLExport& rXMLExport,
|
|
|
|
const sal_Int16 nTypeKey,
|
|
|
|
const double& rValue,
|
|
|
|
const rtl::OUString& rCurrency,
|
|
|
|
sal_Bool bExportValue)
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
|
|
|
sal_Bool bWasSetTypeAttribute = sal_False;
|
|
|
|
switch(nTypeKey & ~util::NumberFormat::DEFINED)
|
|
|
|
{
|
2001-03-19 14:05:55 +00:00
|
|
|
case 0:
|
2000-09-18 16:07:07 +00:00
|
|
|
case util::NumberFormat::NUMBER:
|
|
|
|
case util::NumberFormat::SCIENTIFIC:
|
|
|
|
case util::NumberFormat::FRACTION:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_FLOAT);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
} // No Break
|
|
|
|
case util::NumberFormat::PERCENT:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_PERCENTAGE);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
} // No Break
|
|
|
|
case util::NumberFormat::CURRENCY:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_CURRENCY);
|
2001-05-16 09:05:41 +00:00
|
|
|
if (rCurrency.getLength() > 0)
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_CURRENCY, rCurrency);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
2003-03-27 17:21:03 +00:00
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString( rValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.', sal_True));
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE, sValue);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::DATE:
|
|
|
|
case util::NumberFormat::DATETIME:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_DATE);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
if ( rXMLExport.GetMM100UnitConverter().setNullDate(rXMLExport.GetModel()) )
|
|
|
|
{
|
|
|
|
rtl::OUStringBuffer sBuffer;
|
2001-05-16 09:05:41 +00:00
|
|
|
rXMLExport.GetMM100UnitConverter().convertDateTime(sBuffer, rValue);
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_DATE_VALUE, sBuffer.makeStringAndClear());
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::TIME:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_TIME);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
rtl::OUStringBuffer sBuffer;
|
2001-05-16 09:05:41 +00:00
|
|
|
rXMLExport.GetMM100UnitConverter().convertTime(sBuffer, rValue);
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_TIME_VALUE, sBuffer.makeStringAndClear());
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::LOGICAL:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_BOOLEAN);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
2001-05-16 09:05:41 +00:00
|
|
|
double fTempValue = rValue;
|
2003-03-27 17:21:03 +00:00
|
|
|
if (::rtl::math::approxEqual( fTempValue, 1.0 ))
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_BOOLEAN_VALUE, XML_TRUE);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-03-27 17:21:03 +00:00
|
|
|
if (::rtl::math::approxEqual( rValue, 0.0 ))
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_BOOLEAN_VALUE, XML_FALSE);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-03-27 17:21:03 +00:00
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString(
|
|
|
|
fTempValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.',
|
|
|
|
sal_True));
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_BOOLEAN_VALUE, sValue);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::TEXT:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_FLOAT);
|
2000-09-18 16:07:07 +00:00
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
2003-03-27 17:21:03 +00:00
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString( rValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.', sal_True));
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE, sValue);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2001-05-16 09:05:41 +00:00
|
|
|
}
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2001-05-16 09:05:41 +00:00
|
|
|
sal_Bool XMLNumberFormatAttributesExportHelper::GetCurrencySymbol(const sal_Int32 nNumberFormat, rtl::OUString& sCurrencySymbol,
|
|
|
|
uno::Reference <util::XNumberFormatsSupplier>& xNumberFormatsSupplier)
|
|
|
|
{
|
|
|
|
if (xNumberFormatsSupplier.is())
|
|
|
|
{
|
|
|
|
uno::Reference <util::XNumberFormats> xNumberFormats = xNumberFormatsSupplier->getNumberFormats();
|
|
|
|
if (xNumberFormats.is())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
uno::Reference <beans::XPropertySet> xNumberPropertySet = xNumberFormats->getByKey(nNumberFormat);
|
|
|
|
uno::Any aCurrencySymbol = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_CURRENCYSYMBOL)));
|
|
|
|
if ( aCurrencySymbol >>= sCurrencySymbol)
|
|
|
|
{
|
|
|
|
rtl::OUString sCurrencyAbbreviation;
|
|
|
|
uno::Any aCurrencyAbbreviation = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_CURRENCYABBREVIATION)));
|
|
|
|
if ( aCurrencyAbbreviation >>= sCurrencyAbbreviation)
|
|
|
|
{
|
|
|
|
if ( sCurrencyAbbreviation.getLength() != 0 )
|
|
|
|
sCurrencySymbol = sCurrencyAbbreviation;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ( sCurrencySymbol.getLength() == 1 && sCurrencySymbol.toChar() == NfCurrencyEntry::GetEuroSymbol() )
|
|
|
|
sCurrencySymbol = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("EUR"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sal_True;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch ( uno::Exception& )
|
|
|
|
{
|
|
|
|
DBG_ERROR("Numberformat not found");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sal_Int16 XMLNumberFormatAttributesExportHelper::GetCellType(const sal_Int32 nNumberFormat, sal_Bool& bIsStandard,
|
|
|
|
uno::Reference <util::XNumberFormatsSupplier>& xNumberFormatsSupplier)
|
|
|
|
{
|
|
|
|
if (xNumberFormatsSupplier.is())
|
|
|
|
{
|
|
|
|
uno::Reference <util::XNumberFormats> xNumberFormats = xNumberFormatsSupplier->getNumberFormats();
|
|
|
|
if (xNumberFormats.is())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
uno::Reference <beans::XPropertySet> xNumberPropertySet = xNumberFormats->getByKey(nNumberFormat);
|
|
|
|
uno::Any aIsStandardFormat = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_STANDARDFORMAT)));
|
|
|
|
aIsStandardFormat >>= bIsStandard;
|
2001-06-12 15:34:16 +00:00
|
|
|
uno::Any aNumberType = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_TYPE)));
|
|
|
|
sal_Int16 nNumberType;
|
|
|
|
if ( aNumberType >>= nNumberType )
|
2001-05-16 09:05:41 +00:00
|
|
|
{
|
2001-06-12 15:34:16 +00:00
|
|
|
return nNumberType;
|
2001-05-16 09:05:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
catch ( uno::Exception& )
|
|
|
|
{
|
|
|
|
DBG_ERROR("Numberformat not found");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLNumberFormatAttributesExportHelper::SetNumberFormatAttributes(SvXMLExport& rXMLExport,
|
2004-07-13 07:24:27 +00:00
|
|
|
const sal_Int32 nNumberFormat, const double& rValue, sal_Bool bExportValue)
|
2001-05-16 09:05:41 +00:00
|
|
|
{
|
|
|
|
sal_Bool bIsStandard;
|
|
|
|
sal_Int16 nTypeKey = GetCellType(nNumberFormat, bIsStandard, rXMLExport.GetNumberFormatsSupplier());
|
|
|
|
rtl::OUString sCurrency;
|
2001-06-08 11:05:54 +00:00
|
|
|
if ((nTypeKey & ~util::NumberFormat::DEFINED) == util::NumberFormat::CURRENCY)
|
2001-05-16 09:05:41 +00:00
|
|
|
GetCurrencySymbol(nNumberFormat, sCurrency, rXMLExport.GetNumberFormatsSupplier());
|
2004-07-13 07:24:27 +00:00
|
|
|
WriteAttributes(rXMLExport, nTypeKey, rValue, sCurrency, bExportValue);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void XMLNumberFormatAttributesExportHelper::SetNumberFormatAttributes(SvXMLExport& rXMLExport,
|
2004-07-13 07:24:27 +00:00
|
|
|
const rtl::OUString& rValue, const rtl::OUString& rCharacters,
|
2001-05-16 09:05:41 +00:00
|
|
|
sal_Bool bExportValue, sal_Bool bExportTypeAttribute)
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2001-05-16 09:05:41 +00:00
|
|
|
if (bExportTypeAttribute)
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_VALUE_TYPE, XML_STRING);
|
2001-11-26 07:09:54 +00:00
|
|
|
if (bExportValue && rValue.getLength() && (rValue != rCharacters))
|
2004-07-13 07:24:27 +00:00
|
|
|
rXMLExport.AddAttribute(XML_NAMESPACE_OFFICE, XML_STRING_VALUE, rValue);
|
2000-09-18 16:07:07 +00:00
|
|
|
}
|
|
|
|
|
2003-03-27 17:21:03 +00:00
|
|
|
sal_Bool XMLNumberFormatAttributesExportHelper::GetCurrencySymbol(const sal_Int32 nNumberFormat, rtl::OUString& sCurrencySymbol)
|
|
|
|
{
|
|
|
|
if (!xNumberFormats.is() && pExport && pExport->GetNumberFormatsSupplier().is())
|
|
|
|
xNumberFormats = pExport->GetNumberFormatsSupplier()->getNumberFormats();
|
|
|
|
|
|
|
|
if (xNumberFormats.is())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
uno::Reference <beans::XPropertySet> xNumberPropertySet = xNumberFormats->getByKey(nNumberFormat);
|
|
|
|
uno::Any aCurrencySymbol = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_CURRENCYSYMBOL)));
|
|
|
|
if ( aCurrencySymbol >>= sCurrencySymbol)
|
|
|
|
{
|
|
|
|
rtl::OUString sCurrencyAbbreviation;
|
|
|
|
uno::Any aCurrencyAbbreviation = xNumberPropertySet->getPropertyValue(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM(XML_CURRENCYABBREVIATION)));
|
|
|
|
if ( aCurrencyAbbreviation >>= sCurrencyAbbreviation)
|
|
|
|
{
|
|
|
|
if ( sCurrencyAbbreviation.getLength() != 0 )
|
|
|
|
sCurrencySymbol = sCurrencyAbbreviation;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ( sCurrencySymbol.getLength() == 1 && sCurrencySymbol.toChar() == NfCurrencyEntry::GetEuroSymbol() )
|
|
|
|
sCurrencySymbol = rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("EUR"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sal_True;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch ( uno::Exception& )
|
|
|
|
{
|
|
|
|
DBG_ERROR("Numberformat not found");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return sal_False;
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int16 XMLNumberFormatAttributesExportHelper::GetCellType(const sal_Int32 nNumberFormat, sal_Bool& bIsStandard)
|
|
|
|
{
|
|
|
|
if (!xNumberFormats.is() && pExport && pExport->GetNumberFormatsSupplier().is())
|
|
|
|
xNumberFormats = pExport->GetNumberFormatsSupplier()->getNumberFormats();
|
|
|
|
|
|
|
|
if (xNumberFormats.is())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
uno::Reference <beans::XPropertySet> xNumberPropertySet = xNumberFormats->getByKey(nNumberFormat);
|
|
|
|
uno::Any aIsStandardFormat = xNumberPropertySet->getPropertyValue(sStandardFormat);
|
|
|
|
aIsStandardFormat >>= bIsStandard;
|
|
|
|
uno::Any aNumberType = xNumberPropertySet->getPropertyValue(sType);
|
|
|
|
sal_Int16 nNumberType;
|
|
|
|
if ( aNumberType >>= nNumberType )
|
|
|
|
{
|
|
|
|
return nNumberType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch ( uno::Exception& )
|
|
|
|
{
|
|
|
|
DBG_ERROR("Numberformat not found");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLNumberFormatAttributesExportHelper::WriteAttributes(
|
|
|
|
const sal_Int16 nTypeKey,
|
|
|
|
const double& rValue,
|
|
|
|
const rtl::OUString& rCurrency,
|
|
|
|
sal_Bool bExportValue)
|
|
|
|
{
|
|
|
|
if (!pExport)
|
|
|
|
return;
|
|
|
|
|
|
|
|
sal_Bool bWasSetTypeAttribute = sal_False;
|
|
|
|
switch(nTypeKey & ~util::NumberFormat::DEFINED)
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
case util::NumberFormat::NUMBER:
|
|
|
|
case util::NumberFormat::SCIENTIFIC:
|
|
|
|
case util::NumberFormat::FRACTION:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_FLOAT);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
} // No Break
|
|
|
|
case util::NumberFormat::PERCENT:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_PERCENTAGE);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
} // No Break
|
|
|
|
case util::NumberFormat::CURRENCY:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_CURRENCY);
|
|
|
|
if (rCurrency.getLength() > 0)
|
|
|
|
pExport->AddAttribute(sAttrCurrency, rCurrency);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString( rValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.', sal_True));
|
|
|
|
pExport->AddAttribute(sAttrValue, sValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::DATE:
|
|
|
|
case util::NumberFormat::DATETIME:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_DATE);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
if ( pExport->GetMM100UnitConverter().setNullDate(pExport->GetModel()) )
|
|
|
|
{
|
|
|
|
rtl::OUStringBuffer sBuffer;
|
|
|
|
pExport->GetMM100UnitConverter().convertDateTime(sBuffer, rValue);
|
|
|
|
pExport->AddAttribute(sAttrDateValue, sBuffer.makeStringAndClear());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::TIME:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_TIME);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
rtl::OUStringBuffer sBuffer;
|
|
|
|
pExport->GetMM100UnitConverter().convertTime(sBuffer, rValue);
|
|
|
|
pExport->AddAttribute(sAttrTimeValue, sBuffer.makeStringAndClear());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::LOGICAL:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_BOOLEAN);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
}
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
double fTempValue = rValue;
|
|
|
|
if (::rtl::math::approxEqual( fTempValue, 1.0 ))
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrBooleanValue, XML_TRUE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (::rtl::math::approxEqual( rValue, 0.0 ))
|
|
|
|
{
|
2004-07-13 07:24:27 +00:00
|
|
|
pExport->AddAttribute(sAttrBooleanValue, XML_FALSE);
|
2003-03-27 17:21:03 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString(
|
|
|
|
fTempValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.',
|
|
|
|
sal_True));
|
|
|
|
pExport->AddAttribute(sAttrBooleanValue, sValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case util::NumberFormat::TEXT:
|
|
|
|
{
|
|
|
|
if (!bWasSetTypeAttribute)
|
|
|
|
{
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_FLOAT);
|
|
|
|
bWasSetTypeAttribute = sal_True;
|
|
|
|
if (bExportValue)
|
|
|
|
{
|
|
|
|
rtl::OUString sValue( ::rtl::math::doubleToUString( rValue,
|
|
|
|
rtl_math_StringFormat_Automatic,
|
|
|
|
rtl_math_DecimalPlaces_Max, '.', sal_True));
|
|
|
|
pExport->AddAttribute(sAttrValue, sValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLNumberFormatAttributesExportHelper::SetNumberFormatAttributes(
|
|
|
|
const sal_Int32 nNumberFormat, const double& rValue, sal_Bool bExportValue)
|
|
|
|
{
|
|
|
|
if (pExport)
|
|
|
|
{
|
|
|
|
sal_Bool bIsStandard;
|
|
|
|
rtl::OUString sCurrency;
|
|
|
|
sal_Int16 nTypeKey = GetCellType(nNumberFormat, sCurrency, bIsStandard);
|
|
|
|
WriteAttributes(nTypeKey, rValue, sCurrency, bExportValue);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
DBG_ERROR("no SvXMLExport given");
|
|
|
|
}
|
|
|
|
|
|
|
|
void XMLNumberFormatAttributesExportHelper::SetNumberFormatAttributes(
|
|
|
|
const rtl::OUString& rValue, const rtl::OUString& rCharacters,
|
|
|
|
sal_Bool bExportValue, sal_Bool bExportTypeAttribute)
|
|
|
|
{
|
|
|
|
if (pExport)
|
|
|
|
{
|
|
|
|
if (bExportTypeAttribute)
|
|
|
|
pExport->AddAttribute(sAttrValueType, XML_STRING);
|
|
|
|
if (bExportValue && rValue.getLength() && (rValue != rCharacters))
|
|
|
|
pExport->AddAttribute(sAttrStringValue, rValue);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
DBG_ERROR("no SvXMLExport given");
|
|
|
|
}
|