diff options
Diffstat (limited to 'kspread/kspread_style.cpp')
-rw-r--r-- | kspread/kspread_style.cpp | 3214 |
1 files changed, 3214 insertions, 0 deletions
diff --git a/kspread/kspread_style.cpp b/kspread/kspread_style.cpp new file mode 100644 index 00000000..bd58ac88 --- /dev/null +++ b/kspread/kspread_style.cpp @@ -0,0 +1,3214 @@ +/* This file is part of the KDE project + Copyright (C) 2003 Norbert Andres, [email protected] + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + 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 + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. +*/ + +#include <tqdom.h> +#include <tqbuffer.h> + +#include <kdebug.h> +#include <tdelocale.h> + +#include <KoGlobal.h> +#include <KoGenStyles.h> +#include <KoOasisStyles.h> +#include <KoStyleStack.h> +#include <KoXmlWriter.h> +#include <KoXmlNS.h> + +#include "kspread_util.h" +#include "kspread_doc.h" + +#include "kspread_style.h" + +using namespace KSpread; + +static uint calculateValue( TQPen const & pen ) +{ + uint n = pen.color().red() + pen.color().green() + pen.color().blue(); + + n += 1000 * pen.width(); + n += 10000 * (uint) pen.style(); + + return n; +} + +Style::Style() + : m_parent( 0 ), + m_type( AUTO ), + m_usageCount( 1 ), + m_featuresSet( 0 ), + m_alignX( Format::Undefined ), + m_alignY( Format::Middle ), + m_floatFormat( Format::OnlyNegSigned ), + m_floatColor( Format::AllBlack ), + m_formatType( Generic_format ), + m_fontFlags( 0 ), + m_bgColor( TQt::white ), + m_backGroundBrush( TQt::red, TQt::NoBrush ), + m_rotateAngle( 0 ), + m_indent( 0.0 ), + m_precision( -1 ), + m_properties( 0 ) +{ + TQFont f( KoGlobal::defaultFont() ); + m_fontFamily = f.family(); + m_fontSize = f.pointSize(); + + TQPen pen( TQt::black, 1, TQt::NoPen ); + + m_textPen = pen; + m_leftBorderPen = pen; + m_topBorderPen = pen; + m_rightBorderPen = pen; + m_bottomBorderPen = pen; + m_fallDiagonalPen = pen; + m_goUpDiagonalPen = pen; + + m_leftPenValue = calculateValue( pen ); + m_topPenValue = calculateValue( pen ); + m_rightPenValue = calculateValue( pen ); + m_bottomPenValue = calculateValue( pen ); + + m_currency.type = 0; +} + +Style::Style( Style * style ) + : m_parent( ( style->m_type == BUILTIN || style->m_type == CUSTOM ) ? (CustomStyle *) style : 0 ), + m_type( AUTO ), + m_usageCount( 1 ), + m_featuresSet( ( style->m_type == BUILTIN || style->m_type == CUSTOM ) ? 0 : style->m_featuresSet ), + m_alignX( style->m_alignX ), + m_alignY( style->m_alignY ), + m_floatFormat( style->m_floatFormat ), + m_floatColor( style->m_floatColor ), + m_formatType( style->m_formatType ), + m_fontFamily( style->m_fontFamily ), + m_fontFlags( style->m_fontFlags ), + m_fontSize( style->m_fontSize ), + m_textPen( style->m_textPen ), + m_bgColor( style->m_bgColor ), + m_rightBorderPen( style->m_rightBorderPen ), + m_bottomBorderPen( style->m_bottomBorderPen ), + m_leftBorderPen( style->m_leftBorderPen ), + m_topBorderPen( style->m_topBorderPen ), + m_fallDiagonalPen( style->m_fallDiagonalPen ), + m_goUpDiagonalPen( style->m_goUpDiagonalPen ), + m_backGroundBrush( style->m_backGroundBrush ), + m_rotateAngle( style->m_rotateAngle ), + m_indent( style->m_indent ), + m_strFormat( style->m_strFormat ), + m_precision( style->m_precision ), + m_prefix( style->m_prefix ), + m_postfix( style->m_postfix ), + m_currency( style->m_currency ), + m_properties( style->m_properties ) +{ +} + +Style::~Style() +{ +} + +bool Style::operator == (const Style& style) const +{ + //This is prone to error because if someone adds additional + //properties to the style class they will have to remember + //to correct this function - can we do this a better way? + if ( m_featuresSet != style.m_featuresSet ) + return false; + if ( m_type != style.m_type ) + return false; + // NOTE Stefan: Only compare the values of the set features. + if ( // layout (4) + ( m_featuresSet & SAlignX ) && ( m_alignX != style.m_alignX ) || + ( m_featuresSet & SAlignY ) && ( m_alignY != style.m_alignY ) || + ( m_featuresSet & SAngle ) && ( m_rotateAngle != style.m_rotateAngle ) || + ( m_featuresSet & SIndent ) && ( m_indent != style.m_indent ) || + // background (2) + ( m_featuresSet & SBackgroundColor ) && ( m_bgColor != style.m_bgColor ) || + ( m_featuresSet & SBackgroundBrush ) && ( m_backGroundBrush != style.m_backGroundBrush ) || + // borders (6) + ( m_featuresSet & SRightBorder ) && ( m_rightBorderPen != style.m_rightBorderPen ) || + ( m_featuresSet & SBottomBorder ) && ( m_bottomBorderPen != style.m_bottomBorderPen ) || + ( m_featuresSet & SLeftBorder ) && ( m_leftBorderPen != style.m_leftBorderPen ) || + ( m_featuresSet & STopBorder ) && ( m_topBorderPen != style.m_topBorderPen ) || + ( m_featuresSet & SFallDiagonal ) && ( m_fallDiagonalPen != style.m_fallDiagonalPen ) || + ( m_featuresSet & SGoUpDiagonal ) && ( m_goUpDiagonalPen != style.m_goUpDiagonalPen ) || + // format (7) (SFormatType twice) + ( m_featuresSet & SPrecision ) && ( m_precision != style.m_precision ) || + ( m_featuresSet & SPrefix ) && ( m_prefix != style.m_prefix ) || + ( m_featuresSet & SPostfix ) && ( m_postfix != style.m_postfix ) || + ( m_featuresSet & SFloatFormat ) && ( m_floatFormat != style.m_floatFormat ) || + ( m_featuresSet & SFloatColor ) && ( m_floatColor != style.m_floatColor ) || + ( m_featuresSet & SFormatType ) && ( m_formatType != style.m_formatType ) || + ( m_featuresSet & SFormatType ) && ( m_currency.type != style.m_currency.type ) || + ( m_featuresSet & SCustomFormat ) && ( m_strFormat != style.m_strFormat ) || + // font (4) + ( m_featuresSet & SFontFamily ) && ( m_fontFamily != style.m_fontFamily ) || + ( m_featuresSet & SFontFlag ) && ( m_fontFlags != style.m_fontFlags ) || + ( m_featuresSet & SFontSize ) && ( m_fontSize != style.m_fontSize ) || + ( m_featuresSet & STextPen ) && ( m_textPen != style.m_textPen ) ) + { + return false; + } + // Properties (7) + const uint differingProperties = m_properties xor style.m_properties; + if ( ( m_featuresSet & SDontPrintText ) && ( differingProperties & PDontPrintText ) || + ( m_featuresSet & SCustomFormat ) && ( differingProperties & PCustomFormat ) || + ( m_featuresSet & SNotProtected ) && ( differingProperties & PNotProtected ) || + ( m_featuresSet & SHideAll ) && ( differingProperties & PHideAll ) || + ( m_featuresSet & SHideFormula ) && ( differingProperties & PHideFormula ) || + ( m_featuresSet & SMultiRow ) && ( differingProperties & PMultiRow ) || + ( m_featuresSet & SVerticalText ) && ( differingProperties & PVerticalText ) ) + { + return false; + } + return true; +} + +void Style::loadOasisStyle( KoOasisStyles& oasisStyles, const TQDomElement & element ) +{ + // NOTE Stefan: Don't fill the style stack with the parent styles! + KoStyleStack styleStack; + styleStack.push( element ); + styleStack.setTypeProperties( "table-cell" ); + loadOasisTableCellProperties( oasisStyles, styleStack ); + styleStack.setTypeProperties( "text" ); + loadOasisTextProperties( oasisStyles, styleStack ); + styleStack.setTypeProperties( "paragraph" ); + loadOasisParagraphProperties( oasisStyles, styleStack ); + + loadOasisDataStyle( oasisStyles, element ); +} + +void Style::loadOasisDataStyle( KoOasisStyles& oasisStyles, const TQDomElement& element ) +{ + TQString str; + if ( element.hasAttributeNS( KoXmlNS::style, "data-style-name" ) ) + { +// kdDebug()<<"element.attribute( style:data-style-name ) :"<<element.attributeNS( KoXmlNS::style, "data-style-name", TQString() )<<endl; +// kdDebug()<< " oasisStyles.dataFormats()[...] :"<< oasisStyles.dataFormats()[element.attributeNS( KoXmlNS::style, "data-style-name" , TQString())].formatStr<<endl; +// kdDebug()<< " oasisStyles.dataFormats()[...] prefix :"<< oasisStyles.dataFormats()[element.attributeNS( KoXmlNS::style, "data-style-name" , TQString())].prefix<<endl; +// kdDebug()<< " oasisStyles.dataFormats()[...] suffix :"<< oasisStyles.dataFormats()[element.attributeNS( KoXmlNS::style, "data-style-name" , TQString())].suffix<<endl; + + const TQString styleName = element.attributeNS( KoXmlNS::style, "data-style-name", TQString() ); + if ( oasisStyles.dataFormats().contains(styleName) ) + { + const KoOasisStyles::NumericStyleFormat dataStyle = oasisStyles.dataFormats()[styleName]; + + TQString tmp = dataStyle.prefix; + if ( !tmp.isEmpty() ) + { + m_prefix = tmp; + m_featuresSet |= SPrefix; + } + tmp = dataStyle.suffix; + if ( !tmp.isEmpty() ) + { + m_postfix = tmp; + m_featuresSet |= SPostfix; + } + // determine data formatting + switch (dataStyle.type) + { + case KoOasisStyles::NumericStyleFormat::Number: + m_formatType = Number_format; + m_featuresSet |= SFormatType; + break; + case KoOasisStyles::NumericStyleFormat::Scientific: + m_formatType = Scientific_format; + m_featuresSet |= SFormatType; + break; + case KoOasisStyles::NumericStyleFormat::Currency: + kdDebug() << " currency-symbol: " << dataStyle.currencySymbol << endl; + if (!dataStyle.currencySymbol.isEmpty()) + { + Currency currency(dataStyle.currencySymbol); + m_currency.type = currency.getIndex(); + m_currency.symbol = currency.getDisplayCode(); + } + m_formatType = Money_format; + m_featuresSet |= SFormatType; + break; + case KoOasisStyles::NumericStyleFormat::Percentage: + m_formatType = Percentage_format; + m_featuresSet |= SFormatType; + break; + case KoOasisStyles::NumericStyleFormat::Fraction: + // determine format of fractions, dates and times by using the + // formatting string + tmp = dataStyle.formatStr; + if ( !tmp.isEmpty() ) + { + m_formatType = Style::fractionType( tmp ); + m_featuresSet |= SFormatType; + } + break; + case KoOasisStyles::NumericStyleFormat::Date: + // determine format of fractions, dates and times by using the + // formatting string + tmp = dataStyle.formatStr; + if ( !tmp.isEmpty() ) + { + m_formatType = Style::dateType( tmp ); + m_featuresSet |= SFormatType; + } + break; + case KoOasisStyles::NumericStyleFormat::Time: + // determine format of fractions, dates and times by using the + // formatting string + tmp = dataStyle.formatStr; + if ( !tmp.isEmpty() ) + { + m_formatType = Style::timeType( tmp ); + m_featuresSet |= SFormatType; + } + break; + case KoOasisStyles::NumericStyleFormat::Boolean: + m_formatType = Number_format; + m_featuresSet |= SFormatType; + break; + case KoOasisStyles::NumericStyleFormat::Text: + m_formatType = Text_format; + m_featuresSet |= SFormatType; + break; + } + + if (dataStyle.precision > -1) + { + m_precision = dataStyle.precision; + m_featuresSet |= SPrecision; + } + } + } +} + +void Style::loadOasisParagraphProperties( KoOasisStyles& oasisStyles, const KoStyleStack& styleStack ) +{ + Q_UNUSED( oasisStyles ); + kdDebug() << "\t paragraph-properties" << endl; + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "text-align" ) ) + { + TQString str = styleStack.attributeNS( KoXmlNS::fo, "text-align" ); + if ( str == "center" ) + m_alignX = Format::Center; + else if ( str == "end" ) + m_alignX = Format::Right; + else if ( str == "start" ) + m_alignX = Format::Left; + else + m_alignX = Format::Undefined; + m_featuresSet |= SAlignX; + kdDebug() << "\t\t text-align: " << str << endl; + } +} + +void Style::loadOasisTableCellProperties( KoOasisStyles& oasisStyles, const KoStyleStack& styleStack ) +{ + TQString str; + if ( styleStack.hasAttributeNS( KoXmlNS::style, "vertical-align" ) ) + { + m_alignY = Format::UndefinedY; + + str = styleStack.attributeNS( KoXmlNS::style, "vertical-align" ); + if ( str == "bottom" ) + m_alignY = Format::Bottom; + else if ( str =="top" ) + m_alignY = Format::Top; + else if ( str =="middle" ) + m_alignY = Format::Middle; + + if (m_alignY != Format::UndefinedY) // file's property is invalid + m_featuresSet |= SAlignY; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "background-color" ) ) + { + m_bgColor = TQColor( styleStack.attributeNS( KoXmlNS::fo, "background-color" ) ); + if ( m_bgColor.isValid() && m_bgColor != TQt::white ) + m_featuresSet |= SBackgroundColor; + } + + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "wrap-option" )&&( styleStack.attributeNS( KoXmlNS::fo, "wrap-option" )=="wrap" ) ) + { + setProperty( PMultiRow ); + m_featuresSet |= SMultiRow; + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "cell-protect" ) ) + { + str = styleStack.attributeNS( KoXmlNS::style, "cell-protect" ); + if ( str=="hidden-and-protected" ) + { + setProperty( PHideAll ); + m_featuresSet |= SHideAll; + } + else if ( str == "protected formula-hidden" ) + { + setProperty( PHideFormula ); + m_featuresSet |= SHideFormula; + } + else if ( str == "protected" ) + { + setProperty( PNotProtected ); + m_featuresSet |= SNotProtected; + } + else if ( str =="formula-hidden" ) + { + //FIXME !!!! +#if 0 + setNotProtected( true ); + setHideFormula( true ); + setHideAll( false ); +#endif + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "print-content" ) && ( styleStack.attributeNS( KoXmlNS::style, "print-content" )=="false" ) ) + { + setProperty( PDontPrintText ); + m_featuresSet |= SDontPrintText; + + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "direction" ) && ( styleStack.attributeNS( KoXmlNS::style, "direction" )=="ttb" ) ) + { + setProperty( PVerticalText ); + m_featuresSet |= SVerticalText; + + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "rotation-angle" ) ) + { + bool ok; + int a = styleStack.attributeNS( KoXmlNS::style, "rotation-angle" ).toInt( &ok ); + kdDebug()<<" rotation-angle :"<<a<<endl; + if ( a != 0 ) + { + m_rotateAngle= ( -a ); + m_featuresSet |= SAngle; + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "margin-left" ) ) + { + //todo fix me + setIndent( KoUnit::parseValue( styleStack.attributeNS( KoXmlNS::fo, "margin-left" ),0.0 ) ); + m_featuresSet |= SIndent; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "border" ) ) + { + str=styleStack.attributeNS( KoXmlNS::fo, "border" ); + TQPen pen = convertOasisStringToPen( str ); + m_featuresSet |= SLeftBorder; + m_featuresSet |= SRightBorder; + m_featuresSet |= STopBorder; + m_featuresSet |= SBottomBorder; + m_leftBorderPen = pen; + m_topBorderPen = pen; + m_bottomBorderPen = pen; + m_rightBorderPen = pen; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "border-left" ) ) + { + str=styleStack.attributeNS( KoXmlNS::fo, "border-left" ); + m_leftBorderPen = convertOasisStringToPen( str ); + m_featuresSet |= SLeftBorder; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "border-right" ) ) + { + str=styleStack.attributeNS( KoXmlNS::fo, "border-right" ); + m_rightBorderPen = convertOasisStringToPen( str ); + m_featuresSet |= SRightBorder; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "border-top" ) ) + { + str=styleStack.attributeNS( KoXmlNS::fo, "border-top" ); + m_topBorderPen = convertOasisStringToPen( str ); + m_featuresSet |= STopBorder; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "border-bottom" ) ) + { + str=styleStack.attributeNS( KoXmlNS::fo, "border-bottom" ); + m_bottomBorderPen = convertOasisStringToPen( str ); + m_featuresSet |= SBottomBorder; + } + if (styleStack.hasAttributeNS( KoXmlNS::style, "diagonal-tl-br" ) ) + { + str=styleStack.attributeNS( KoXmlNS::style, "diagonal-tl-br" ); + m_fallDiagonalPen = convertOasisStringToPen( str ); + m_featuresSet |= SFallDiagonal; + } + if (styleStack.hasAttributeNS( KoXmlNS::style, "diagonal-bl-tr" ) ) + { + str=styleStack.attributeNS( KoXmlNS::style, "diagonal-bl-tr" ); + m_goUpDiagonalPen = convertOasisStringToPen( str ); + m_featuresSet |= SGoUpDiagonal; + } + + if ( styleStack.hasAttributeNS( KoXmlNS::draw, "style-name" ) ) + { + kdDebug()<<" style name :"<<styleStack.attributeNS( KoXmlNS::draw, "style-name" )<<endl; + + const TQDomElement * style = oasisStyles.findStyle( styleStack.attributeNS( KoXmlNS::draw, "style-name" ), "graphic" ); + kdDebug()<<" style :"<<style<<endl; + if ( style ) + { + KoStyleStack drawStyleStack; + drawStyleStack.push( *style ); + drawStyleStack.setTypeProperties( "graphic" ); + if ( drawStyleStack.hasAttributeNS( KoXmlNS::draw, "fill" ) ) + { + const TQString fill = drawStyleStack.attributeNS( KoXmlNS::draw, "fill" ); + kdDebug()<<" load object gradient fill type :"<<fill<<endl; + + if ( fill == "solid" || fill == "hatch" ) + { + kdDebug()<<" Style ******************************************************\n"; + m_backGroundBrush=KoOasisStyles::loadOasisFillStyle( drawStyleStack, fill, oasisStyles ); + m_featuresSet |= SBackgroundBrush; + } + else + kdDebug()<<" fill style not supported into kspread : "<<fill<<endl; + } + } + } +} + +void Style::loadOasisTextProperties( KoOasisStyles& oasisStyles, const KoStyleStack& styleStack ) +{ + Q_UNUSED( oasisStyles ); + // fo:font-size="13pt" + // fo:font-style="italic" + // style:text-underline="double" + // style:text-underline-color="font-color" + // fo:font-weight="bold" + kdDebug() << "\t text-properties" << endl; + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "font-family" ) ) + { + m_fontFamily = styleStack.attributeNS( KoXmlNS::fo, "font-family" ); // FIXME Stefan: sanity check + m_featuresSet |= SFontFamily; + m_featuresSet |= SFont; + kdDebug() << "\t\t fo:font-family: " << m_fontFamily << endl; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "font-size" ) ) + { + m_fontSize = (int) KoUnit::parseValue( styleStack.attributeNS( KoXmlNS::fo, "font-size" ), 10.0 ); // FIXME Stefan: fallback to default + m_featuresSet |= SFontSize; + m_featuresSet |= SFont; + kdDebug() << "\t\t fo:font-size: " << m_fontSize << endl; + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "font-style" ) ) + { + if ( styleStack.attributeNS( KoXmlNS::fo, "font-style" ) == "italic" ) // "normal", "oblique" + { + m_fontFlags |= FItalic; + m_featuresSet |= SFontFlag; + m_featuresSet |= SFont; + kdDebug() << "\t\t fo:font-style: " << "italic" << endl; + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "font-weight" ) ) + { + if ( styleStack.attributeNS( KoXmlNS::fo, "font-weight" ) == "bold" ) // "normal", "100", "200", ... + { + m_fontFlags |= FBold; + m_featuresSet |= SFontFlag; + m_featuresSet |= SFont; + kdDebug() << "\t\t fo:font-weight: " << "bold" << endl; + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "text-underline-style" ) ) + { + if ( styleStack.attributeNS( KoXmlNS::style, "text-underline-style" ) != "none" ) + { + m_fontFlags |= FUnderline; + m_featuresSet |= SFontFlag; + m_featuresSet |= SFont; + kdDebug() << "\t\t style:text-underline-style: " << "solid (actually: !none)" << endl; + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "text-underline-width" ) ) + { + //TODO + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "text-underline-color" ) ) + { + //TODO + } + if ( styleStack.hasAttributeNS( KoXmlNS::fo, "color" ) ) + { + TQColor color = TQColor( styleStack.attributeNS( KoXmlNS::fo, "color" ) ); + if ( color.isValid() ) + { + m_featuresSet |= STextPen; + m_textPen = TQPen( color ); + kdDebug() << "\t\t fo:color: " << TQString(color.name()) << endl; + } + } + if ( styleStack.hasAttributeNS( KoXmlNS::style, "text-line-through-style" ) ) + { + if ( styleStack.attributeNS( KoXmlNS::style, "text-line-through-style" ) != "none" + /*&& styleStack.attributeNS("text-line-through-style")=="solid"*/ ) + { + m_fontFlags |= FStrike; + m_featuresSet |= SFontFlag; + m_featuresSet |= SFont; + kdDebug() << "\t\t text-line-through-style: " << "solid (actually: !none)" << endl; + } + } +} + +static TQString convertDateFormat( const TQString& date ) +{ + TQString result = date; + result.replace( "%Y", "yyyy" ); + result.replace( "%y", "yy" ); + result.replace( "%n", "M" ); + result.replace( "%m", "MM" ); + result.replace( "%e", "d" ); + result.replace( "%d", "dd" ); + result.replace( "%b", "MMM" ); + result.replace( "%B", "MMMM" ); + result.replace( "%a", "ddd" ); + result.replace( "%A", "dddd" ); + return result; +} + +FormatType Style::dateType( const TQString &_format ) +{ + const TQString dateFormatShort = convertDateFormat( TDEGlobal::locale()->dateFormatShort() ); + const TQString dateFormat = convertDateFormat( TDEGlobal::locale()->dateFormat() ); + + if ( _format == "dd-MMM-yy" ) + return date_format1; + else if ( _format == "dd-MMM-yyyy" ) + return date_format2; + else if ( _format == "d-MM" ) + return date_format3; + else if ( _format == "dd-MM" ) //TODO ??????? + return date_format4; + else if ( _format == "dd/MM/yy" ) + return date_format5; + else if ( _format == "dd/MM/yyyy" ) + return date_format6; + else if ( _format == "MMM-yy" ) + return date_format7; + else if ( _format == "MMMM-yyyy" ) + return date_format9; + else if ( _format == "MMMMM-yy" ) + return date_format10; + else if ( _format == "dd/MMM" ) + return date_format11; + else if ( _format == "dd/MM" ) + return date_format12; + else if ( _format == "dd/MMM/yyyy" ) + return date_format13; + else if ( _format == "yyyy/MMM/dd" ) + return date_format14; + else if ( _format == "yyyy-MMM-dd" ) + return date_format15; + else if ( _format == "yyyy/MM/dd" ) + return date_format16; + else if ( _format == "d MMMM yyyy" ) + return date_format17; + else if ( _format == "MM/dd/yyyy" ) + return date_format18; + else if ( _format == "MM/dd/yy" ) + return date_format19; + else if ( _format == "MMM/dd/yy" ) + return date_format20; + else if ( _format == "MMM/dd/yyyy" ) + return date_format21; + else if ( _format == "MMM-yyyy" ) + return date_format22; + else if ( _format == "yyyy" ) + return date_format23; + else if ( _format == "yy" ) + return date_format24; + else if ( _format == "yyyy/MM/dd" ) + return date_format25; + else if ( _format == "yyyy/MMM/dd" ) + return date_format26; + else if ( _format == dateFormatShort ) + return ShortDate_format; + else if ( _format == dateFormat ) + return TextDate_format; + else + return ShortDate_format; +} + +FormatType Style::timeType( const TQString &_format ) +{ + if ( _format == "h:mm AP" ) + return Time_format1; + else if ( _format == "h:mm:ss AP" ) + return Time_format2; + else if ( _format == "hh \\h mm \\m\\i\\n ss \\s" ) + return Time_format3; + else if ( _format == "hh:mm" ) + return Time_format4; + else if ( _format == "hh:mm:ss" ) + return Time_format5; + else if ( _format == "m:ss" ) + return Time_format6; + else if ( _format == "h:mm:ss" ) + return Time_format7; + else if ( _format == "h:mm" ) + return Time_format8; + else + return Time_format; +} + +FormatType Style::fractionType( const TQString &_format ) +{ + if ( _format == "# ?/2" ) + return fraction_half; + else if ( _format =="# ?/4" ) + return fraction_quarter; + else if ( _format == "# ?/8" ) + return fraction_eighth; + else if ( _format == "# ?/16" ) + return fraction_sixteenth; + else if ( _format == "# ?/10" ) + return fraction_tenth; + else if ( _format == "# ?/100" ) + return fraction_hundredth; + else if ( _format == "# ?/?" ) + return fraction_one_digit; + else if ( _format == "# \?\?/\?\?" ) + return fraction_two_digits; + else if ( _format == "# \?\?\?/\?\?\?" ) + return fraction_three_digits; + else + return fraction_half; +} + +TQString Style::saveOasisStyleNumeric( KoGenStyle &style, KoGenStyles &mainStyles, + FormatType _style, + const TQString &_prefix, const TQString &_postfix, + int _precision, const TQString& symbol ) +{ +// kdDebug() << k_funcinfo << endl; + TQString styleName; + TQString valueType; + switch( _style ) + { + case Number_format: + styleName = saveOasisStyleNumericNumber( mainStyles, _style, _precision, _prefix, _postfix ); + valueType = "float"; + break; + case Text_format: + styleName = saveOasisStyleNumericText( mainStyles, _style, _precision, _prefix, _postfix ); + valueType = "string"; + break; + case Money_format: + styleName = saveOasisStyleNumericMoney( mainStyles, _style,symbol, _precision, _prefix, _postfix ); + valueType = "currency"; + break; + case Percentage_format: + styleName = saveOasisStyleNumericPercentage( mainStyles, _style, _precision, _prefix, _postfix ); + valueType = "percentage"; + break; + case Scientific_format: + styleName = saveOasisStyleNumericScientific( mainStyles, _style, _prefix, _postfix, _precision ); + valueType = "float"; + break; + case ShortDate_format: + case TextDate_format: + styleName = saveOasisStyleNumericDate( mainStyles, _style, _prefix, _postfix ); + valueType = "date"; + break; + case Time_format: + case SecondeTime_format: + case Time_format1: + case Time_format2: + case Time_format3: + case Time_format4: + case Time_format5: + case Time_format6: + case Time_format7: + case Time_format8: + styleName = saveOasisStyleNumericTime( mainStyles, _style, _prefix, _postfix ); + valueType = "time"; + break; + case fraction_half: + case fraction_quarter: + case fraction_eighth: + case fraction_sixteenth: + case fraction_tenth: + case fraction_hundredth: + case fraction_one_digit: + case fraction_two_digits: + case fraction_three_digits: + styleName = saveOasisStyleNumericFraction( mainStyles,_style, _prefix, _postfix ); + valueType = "float"; + break; + case date_format1: + case date_format2: + case date_format3: + case date_format4: + case date_format5: + case date_format6: + case date_format7: + case date_format8: + case date_format9: + case date_format10: + case date_format11: + case date_format12: + case date_format13: + case date_format14: + case date_format15: + case date_format16: + case date_format17: + case date_format18: + case date_format19: + case date_format20: + case date_format21: + case date_format22: + case date_format23: + case date_format24: + case date_format25: + case date_format26: + styleName = saveOasisStyleNumericDate( mainStyles, _style, _prefix, _postfix ); + valueType = "date"; + break; + case Custom_format: + styleName = saveOasisStyleNumericCustom( mainStyles, _style, _prefix, _postfix ); + break; + case Generic_format: + case No_format: + if (_precision > -1 || !_prefix.isEmpty() || !_postfix.isEmpty()) + { + styleName = saveOasisStyleNumericNumber( mainStyles, _style, _precision, _prefix, _postfix ); + valueType = "float"; + } + break; + } + if ( !styleName.isEmpty() ) + { + style.addAttribute( "style:data-style-name", styleName ); + } + return styleName; +} + +TQString Style::saveOasisStyleNumericNumber( KoGenStyles& mainStyles, FormatType /*_style*/, int _precision, + const TQString &_prefix, const TQString &_suffix ) +{ + TQString format; + if ( _precision == -1 ) + format="0"; + else + { + TQString tmp; + for ( int i = 0; i <_precision; i++ ) + { + tmp+="0"; + } + format = "0."+tmp; + } + return KoOasisStyles::saveOasisNumberStyle( mainStyles, format, _prefix, _suffix ); +} + +TQString Style::saveOasisStyleNumericText( KoGenStyles& /*mainStyles*/, FormatType /*_style*/, int /*_precision*/, + const TQString &/*_prefix*/, const TQString &/*_suffix*/ ) +{ + return ""; +} + +TQString Style::saveOasisStyleNumericMoney( KoGenStyles& mainStyles, FormatType /*_style*/, + const TQString& symbol, int _precision, + const TQString &_prefix, const TQString &_suffix ) +{ + TQString format; + if ( _precision == -1 ) + format="0"; + else + { + TQString tmp; + for ( int i = 0; i <_precision; i++ ) + { + tmp+="0"; + } + format = "0."+tmp; + } + return KoOasisStyles::saveOasisCurrencyStyle( mainStyles, format, symbol, _prefix, _suffix ); +} + +TQString Style::saveOasisStyleNumericPercentage( KoGenStyles&mainStyles, FormatType /*_style*/, + int _precision, + const TQString &_prefix, const TQString &_suffix ) +{ + //<number:percentage-style style:name="N106" style:family="data-style"> + //<number:number number:decimal-places="6" number:min-integer-digits="1"/> + //<number:text>%</number:text> + //</number:percentage-style> + //TODO add decimal etc. + TQString format; + if ( _precision == -1 ) + format="0"; + else + { + TQString tmp; + for ( int i = 0; i <_precision; i++ ) + { + tmp+="0"; + } + format = "0."+tmp; + } + return KoOasisStyles::saveOasisPercentageStyle( mainStyles, format, _prefix, _suffix ); +} + + +TQString Style::saveOasisStyleNumericScientific( KoGenStyles&mainStyles, FormatType /*_style*/, + const TQString &_prefix, const TQString _suffix, int _precision ) +{ + //<number:number-style style:name="N60" style:family="data-style"> + // <number:scientific-number number:decimal-places="2" number:min-integer-digits="1" number:min-exponent-digits="3"/> + //</number:number-style> + TQString format; + if ( _precision == -1 ) + format="0E+00"; + else + { + TQString tmp; + for ( int i = 0; i <_precision; i++ ) + { + tmp+="0"; + } + format = "0."+tmp+"E+00"; + } + return KoOasisStyles::saveOasisScientificStyle( mainStyles, format, _prefix, _suffix ); +} + +TQString Style::saveOasisStyleNumericDate( KoGenStyles&mainStyles, FormatType _style, + const TQString &_prefix, const TQString &_suffix ) +{ + TQString format; + bool locale = false; + switch( _style ) + { + //TODO fixme use locale of kspread and not kglobal + case ShortDate_format: + format = TDEGlobal::locale()->dateFormatShort(); + locale = true; + break; + case TextDate_format: + format = TDEGlobal::locale()->dateFormat(); + locale = true; + break; + case date_format1: + format = "dd-MMM-yy"; + break; + case date_format2: + format = "dd-MMM-yyyy"; + break; + case date_format3: + format = "dd-M"; + break; + case date_format4: + format = "dd-MM"; + break; + case date_format5: + format = "dd/MM/yy"; + break; + case date_format6: + format = "dd/MM/yyyy"; + break; + case date_format7: + format = "MMM-yy"; + break; + case date_format8: + format = "MMMM-yy"; + break; + case date_format9: + format = "MMMM-yyyy"; + break; + case date_format10: + format = "MMMMM-yy"; + break; + case date_format11: + format = "dd/MMM"; + break; + case date_format12: + format = "dd/MM"; + break; + case date_format13: + format = "dd/MMM/yyyy"; + break; + case date_format14: + format = "yyyy/MMM/dd"; + break; + case date_format15: + format = "yyyy-MMM-dd"; + break; + case date_format16: + format = "yyyy/MM/dd"; + break; + case date_format17: + format = "d MMMM yyyy"; + break; + case date_format18: + format = "MM/dd/yyyy"; + break; + case date_format19: + format = "MM/dd/yy"; + break; + case date_format20: + format = "MMM/dd/yy"; + break; + case date_format21: + format = "MMM/dd/yyyy"; + break; + case date_format22: + format = "MMM-yyyy"; + break; + case date_format23: + format = "yyyy"; + break; + case date_format24: + format = "yy"; + break; + case date_format25: + format = "yyyy/MM/dd"; + break; + case date_format26: + format = "yyyy/MMM/dd"; + break; + default: + kdDebug()<<"this date format is not defined ! :"<<_style<<endl; + break; + } + return KoOasisStyles::saveOasisDateStyle( mainStyles, format, locale, _prefix, _suffix ); +} + +TQString Style::saveOasisStyleNumericCustom( KoGenStyles& /*mainStyles*/, FormatType /*_style*/, + const TQString &/*_prefix*/, const TQString &/*_suffix*/ ) +{ + //TODO + //<number:date-style style:name="N50" style:family="data-style" number:automatic-order="true" number:format-source="language"> + //<number:month/> + //<number:text>/</number:text> + //<number:day/> + //<number:text>/</number:text> + //<number:year/> + //<number:text> </number:text> + //<number:hours number:style="long"/> + //<number:text>:</number:text> + //<number:minutes number:style="long"/> + // <number:text> </number:text> + //<number:am-pm/> + //</number:date-style> + return ""; +} + +TQString Style::saveOasisStyleNumericTime( KoGenStyles& mainStyles, FormatType _style, + const TQString &_prefix, const TQString &_suffix ) +{ + //<number:time-style style:name="N42" style:family="data-style"> + //<number:hours number:style="long"/> + //<number:text>:</number:text> + //<number:minutes number:style="long"/> + //<number:text> </number:text> + //<number:am-pm/> + //</number:time-style> + + TQString format; + bool locale = false; + //TODO use format + switch( _style ) + { + case Time_format: //TODO FIXME + format = "hh:mm:ss"; + break; + case SecondeTime_format: //TODO FIXME + format = "hh:mm"; + break; + case Time_format1: + format = "h:mm AP"; + break; + case Time_format2: + format = "h:mm:ss AP"; + break; + case Time_format3: // 9 h 01 min 28 s + format = "hh \\h mm \\m\\i\\n ss \\s"; + break; + case Time_format4: + format = "hh:mm"; + break; + case Time_format5: + format = "hh:mm:ss"; + break; + case Time_format6: + format = "m:ss"; + break; + case Time_format7: + format = "h:mm:ss"; + break; + case Time_format8: + format = "h:mm"; + break; + default: + kdDebug()<<"time format not defined :"<<_style<<endl; + break; + } + return KoOasisStyles::saveOasisTimeStyle( mainStyles, format, locale, _prefix, _suffix ); +} + + +TQString Style::saveOasisStyleNumericFraction( KoGenStyles &mainStyles, FormatType _style, + const TQString &_prefix, const TQString _suffix ) +{ + //<number:number-style style:name="N71" style:family="data-style"> + //<number:fraction number:min-integer-digits="0" number:min-numerator-digits="2" number:min-denominator-digits="2"/> + //</number:number-style> + TQString format; + switch( _style ) + { + case fraction_half: + format = "# ?/2"; + break; + case fraction_quarter: + format = "# ?/4"; + break; + case fraction_eighth: + format = "# ?/8"; + break; + case fraction_sixteenth: + format = "# ?/16"; + break; + case fraction_tenth: + format = "# ?/10"; + break; + case fraction_hundredth: + format = "# ?/100"; + break; + case fraction_one_digit: + format = "# ?/?"; + break; + case fraction_two_digits: + format = "# \?\?/\?\?"; + break; + case fraction_three_digits: + format = "# \?\?\?/\?\?\?"; + break; + default: + kdDebug()<<" fraction format not defined :"<<_style<<endl; + break; + } + + return KoOasisStyles::saveOasisFractionStyle( mainStyles, format, _prefix, _suffix ); +} + +TQString Style::saveOasis( KoGenStyle& style, KoGenStyles& mainStyles ) +{ + // KSpread::Style is definitly an OASIS auto style, + // but don't overwrite it, if it already exists + if (style.type() == 0) + style = KoGenStyle( Doc::STYLE_CELL_AUTO, "table-cell" ); + // doing the real work + saveOasisStyle( style, mainStyles ); + return TQString(); +} + +void Style::saveOasisStyle( KoGenStyle &style, KoGenStyles &mainStyles ) +{ +#ifndef NDEBUG + //if (type() == BUILTIN ) + // kdDebug() << "BUILTIN" << endl; + //else if (type() == CUSTOM ) + // kdDebug() << "CUSTOM" << endl; + //else if (type() == AUTO ) + // kdDebug() << "AUTO" << endl; +#endif + + // don't store parent, if it's the default style + if ( m_parent && (m_parent->type() != BUILTIN || m_parent->name() != "Default") ) + // FIXME this is not the OASIS parent style's name. it's its display name! + style.addAttribute( "style:parent-style-name", m_parent->name() ); + + if ( featureSet( SAlignX ) && alignX() != Format::Undefined ) + { + TQString value; + switch( alignX() ) + { + case Format::Center: + value = "center"; + break; + case Format::Right: + value = "end"; + break; + case Format::Left: + value = "start"; + break; + case Format::Undefined: + break; + } + if ( !value.isEmpty() ) + { + style.addProperty( "style:text-align-source", "fix" ); // table-cell-properties + style.addProperty( "fo:text-align", value, KoGenStyle::ParagraphType ); + } + } + + if ( featureSet( SAlignY ) ) + { + TQString value; + switch( alignY() ) + { + case Format::Top: + value = "top"; + break; + case Format::Middle: + value = "middle"; + break; + case Format::Bottom: + value = "bottom"; + break; + case Format::UndefinedY: + default: + break; + } + if (!value.isEmpty()) // sanity + style.addProperty( "style:vertical-align", value ); + } + + if ( featureSet( SBackgroundColor ) && m_bgColor != TQColor() && m_bgColor.isValid() ) + style.addProperty( "fo:background-color", colorName(m_bgColor) ); + + if ( featureSet( SMultiRow ) && hasProperty( PMultiRow ) ) + style.addProperty( "fo:wrap-option", "wrap" ); + + if ( featureSet( SVerticalText ) && hasProperty( PVerticalText ) ) + { + style.addProperty( "style:direction", "ttb" ); + style.addProperty( "style:rotation-angle", "0" ); + style.addProperty( "style:rotation-align", "none" ); + } +#if 0 + if ( featureSet( SFloatFormat ) ) + format.setAttribute( "float", (int) m_floatFormat ); + + if ( featureSet( SFloatColor ) ) + format.setAttribute( "floatcolor", (int)m_floatColor ); + + if ( featureSet( SCustomFormat ) && !strFormat().isEmpty() ) + format.setAttribute( "custom", m_strFormat ); + + if ( featureSet( SFormatType ) && formatType() == Format::Money ) + { + format.setAttribute( "type", (int) m_currency.type ); + format.setAttribute( "symbol", m_currency.symbol ); + } +#endif + if ( featureSet( SAngle ) && m_rotateAngle != 0 ) + { + style.addProperty( "style:rotation-align", "none" ); + style.addProperty( "style:rotation-angle", TQString::number( -1.0 *m_rotateAngle ) ); + } + + if ( featureSet( SIndent ) && m_indent != 0.0 ) + { + style.addPropertyPt("fo:margin-left", m_indent, KoGenStyle::ParagraphType ); + //FIXME + //if ( a == Format::Undefined ) + //currentCellStyle.addProperty("fo:text-align", "start" ); + } + + if ( featureSet( SDontPrintText ) && hasProperty( PDontPrintText ) ) + style.addProperty( "style:print-content", "false"); + + // protection + bool hideAll = false; + bool hideFormula = false; + bool isNotProtected = false; + + if ( featureSet( SNotProtected ) && hasProperty( PNotProtected ) ) + isNotProtected = true; + + if ( featureSet( SHideAll ) && hasProperty( PHideAll ) ) + hideAll=true; + + if ( featureSet( SHideFormula ) && hasProperty( PHideFormula ) ) + hideFormula = true; + + if ( hideAll ) + style.addProperty( "style:cell-protect", "hidden-and-protected" ); + else + { + if ( isNotProtected && !hideFormula ) + style.addProperty( "style:cell-protect", "none" ); + else if ( isNotProtected && hideFormula ) + style.addProperty( "style:cell-protect", "formula-hidden" ); + else if ( hideFormula ) + style.addProperty( "style:cell-protect", "protected formula-hidden" ); + else if ( featureSet( SNotProtected ) && !hasProperty( PNotProtected ) ) + // write out, only if it is explicity set + style.addProperty( "style:cell-protect", "protected" ); + } + + // borders + // NOTE Stefan: TQPen api docs: + // For horizontal and vertical lines a line width of 0 is + // the same as a line width of 1. + // A line width of 0 will produce a 1 pixel wide line using + // a fast algorithm for diagonals. A line width of 1 will + // also produce a 1 pixel wide line, but uses a slower more + // accurate algorithm for diagonals. + if ( featureSet( SLeftBorder ) && featureSet( SRightBorder ) && + featureSet( STopBorder ) && featureSet( SBottomBorder ) && + ( m_leftBorderPen == m_topBorderPen ) && + ( m_leftBorderPen == m_rightBorderPen ) && + ( m_leftBorderPen == m_bottomBorderPen ) ) + { + if ( m_leftBorderPen.style() != TQt::NoPen ) + style.addProperty("fo:border", convertOasisPenToString( m_leftBorderPen ) ); + } + else + { + if ( featureSet( SLeftBorder ) && ( m_leftBorderPen.style() != TQt::NoPen ) ) + style.addProperty( "fo:border-left", convertOasisPenToString( m_leftBorderPen ) ); + + if ( featureSet( SRightBorder ) && ( m_rightBorderPen.style() != TQt::NoPen ) ) + style.addProperty( "fo:border-right", convertOasisPenToString( m_rightBorderPen ) ); + + if ( featureSet( STopBorder ) && ( m_topBorderPen.style() != TQt::NoPen ) ) + style.addProperty( "fo:border-top", convertOasisPenToString( m_topBorderPen ) ); + + if ( featureSet( SBottomBorder ) && ( m_bottomBorderPen.style() != TQt::NoPen ) ) + style.addProperty( "fo:border-bottom", convertOasisPenToString( m_bottomBorderPen ) ); + } + if ( featureSet( SFallDiagonal ) && ( m_fallDiagonalPen.style() != TQt::NoPen ) ) + { + style.addProperty("style:diagonal-tl-br", convertOasisPenToString( m_fallDiagonalPen ) ); + } + if ( featureSet( SGoUpDiagonal ) && ( m_goUpDiagonalPen.style() != TQt::NoPen ) ) + { + style.addProperty("style:diagonal-bl-tr", convertOasisPenToString(m_goUpDiagonalPen ) ); + } + + // font + if ( featureSet( SFontFamily ) ) // !m_fontFamily.isEmpty() == true + { + style.addProperty("fo:font-family", m_fontFamily, KoGenStyle::TextType ); + } + if ( featureSet( SFontSize ) ) // m_fontSize != 0 + { + style.addPropertyPt("fo:font-size",m_fontSize, KoGenStyle::TextType ); + } + + if ( featureSet( SFontFlag ) && m_fontFlags & (uint) FBold ) + style.addProperty("fo:font-weight","bold", KoGenStyle::TextType ); + + if ( featureSet( SFontFlag ) && m_fontFlags & (uint) FItalic ) + style.addProperty("fo:font-style", "italic", KoGenStyle::TextType ); + + if ( featureSet( SFontFlag ) && m_fontFlags & (uint) FUnderline ) + { + //style:text-underline-style="solid" style:text-underline-width="auto" + style.addProperty( "style:text-underline-style", "solid", KoGenStyle::TextType ); + //copy from oo-129 + style.addProperty( "style:text-underline-width", "auto", KoGenStyle::TextType ); + style.addProperty( "style:text-underline-color", "font-color", KoGenStyle::TextType ); + } + + if ( featureSet( SFontFlag ) && m_fontFlags & (uint) FStrike ) + style.addProperty( "style:text-line-through-style", "solid", KoGenStyle::TextType ); + + if ( featureSet( STextPen ) && m_textPen.color().isValid() ) // always save; default: m_textPen.style() == TQt::NoPen + { + style.addProperty("fo:color", colorName(m_textPen.color()), KoGenStyle::TextType ); + } + + //I don't think there is a reason why the background brush should be saved if it is null, + //but remove the check if it causes problems. -- Robert Knight <[email protected]> + if ( featureSet( SBackgroundBrush ) && (m_backGroundBrush.style() != TQt::NoBrush) ) + { + TQString tmp = saveOasisBackgroundStyle( mainStyles, m_backGroundBrush ); + if ( !tmp.isEmpty() ) + style.addProperty("draw:style-name", tmp ); + } + + TQString _prefix; + TQString _postfix; + int _precision = -1; + if ( featureSet( SPrefix ) && !prefix().isEmpty() ) + _prefix = m_prefix; + if ( featureSet( SPostfix ) && !postfix().isEmpty() ) + _postfix = m_postfix; + if ( featureSet( SPrecision ) && m_precision != -1 ) + _precision = m_precision; + + TQString symbol; + if ( featureSet( SFormatType ) && m_formatType == Money_format ) + { + symbol = Currency::getCurrencyCode(m_currency.type); + } + + TQString numericStyle = saveOasisStyleNumeric( style, mainStyles, m_formatType, + _prefix, _postfix, _precision, + symbol ); + if ( !numericStyle.isEmpty() ) + style.addAttribute( "style:data-style-name", numericStyle ); +} + +TQString Style::saveOasisBackgroundStyle( KoGenStyles &mainStyles, const TQBrush &brush ) +{ + KoGenStyle styleobjectauto = KoGenStyle( KoGenStyle::STYLE_GRAPHICAUTO, "graphic" ); + KoOasisStyles::saveOasisFillStyle( styleobjectauto, mainStyles, brush ); + return mainStyles.lookup( styleobjectauto, "gr" ); +} + +void Style::saveXML( TQDomDocument & doc, TQDomElement & format ) const +{ + if ( featureSet( SAlignX ) && alignX() != Format::Undefined ) + format.setAttribute( "alignX", (int) m_alignX ); + + if ( featureSet( SAlignY ) && alignY() != Format::Middle ) + format.setAttribute( "alignY", (int) m_alignY ); + + if ( featureSet( SBackgroundColor ) && m_bgColor != TQColor() && m_bgColor.isValid() ) + format.setAttribute( "bgcolor", m_bgColor.name() ); + + if ( featureSet( SMultiRow ) && hasProperty( PMultiRow ) ) + format.setAttribute( "multirow", "yes" ); + + if ( featureSet( SVerticalText ) && hasProperty( PVerticalText ) ) + format.setAttribute( "verticaltext", "yes" ); + + if ( featureSet( SPrecision ) ) + format.setAttribute( "precision", m_precision ); + + if ( featureSet( SPrefix ) && !prefix().isEmpty() ) + format.setAttribute( "prefix", m_prefix ); + + if ( featureSet( SPostfix ) && !postfix().isEmpty() ) + format.setAttribute( "postfix", m_postfix ); + + if ( featureSet( SFloatFormat ) ) + format.setAttribute( "float", (int) m_floatFormat ); + + if ( featureSet( SFloatColor ) ) + format.setAttribute( "floatcolor", (int)m_floatColor ); + + if ( featureSet( SFormatType ) ) + format.setAttribute( "format",(int) m_formatType ); + + if ( featureSet( SCustomFormat ) && !strFormat().isEmpty() ) + format.setAttribute( "custom", m_strFormat ); + + if ( featureSet( SFormatType ) && formatType() == Money_format ) + { + format.setAttribute( "type", (int) m_currency.type ); + format.setAttribute( "symbol", m_currency.symbol ); + } + + if ( featureSet( SAngle ) ) + format.setAttribute( "angle", m_rotateAngle ); + + if ( featureSet( SIndent ) ) + format.setAttribute( "indent", m_indent ); + + if ( featureSet( SDontPrintText ) && hasProperty( PDontPrintText ) ) + format.setAttribute( "dontprinttext", "yes" ); + + if ( featureSet( SNotProtected ) && hasProperty( PNotProtected ) ) + format.setAttribute( "noprotection", "yes" ); + + if ( featureSet( SHideAll ) && hasProperty( PHideAll ) ) + format.setAttribute( "hideall", "yes" ); + + if ( featureSet( SHideFormula ) && hasProperty( PHideFormula ) ) + format.setAttribute( "hideformula", "yes" ); + + if ( featureSet( SFontFamily ) ) + format.setAttribute( "font-family", m_fontFamily ); + if ( featureSet( SFontSize ) ) + format.setAttribute( "font-size", m_fontSize ); + if ( featureSet( SFontFlag ) ) + format.setAttribute( "font-flags", m_fontFlags ); + + // if ( featureSet( SFont ) ) + // format.appendChild( util_createElement( "font", m_textFont, doc ) ); + + if ( featureSet( STextPen ) && m_textPen.color().isValid() ) + format.appendChild( util_createElement( "pen", m_textPen, doc ) ); + + if ( featureSet( SBackgroundBrush ) ) + { + format.setAttribute( "brushcolor", m_backGroundBrush.color().name() ); + format.setAttribute( "brushstyle", (int) m_backGroundBrush.style() ); + } + + if ( featureSet( SLeftBorder ) ) + { + TQDomElement left = doc.createElement( "left-border" ); + left.appendChild( util_createElement( "pen", m_leftBorderPen, doc ) ); + format.appendChild( left ); + } + + if ( featureSet( STopBorder ) ) + { + TQDomElement top = doc.createElement( "top-border" ); + top.appendChild( util_createElement( "pen", m_topBorderPen, doc ) ); + format.appendChild( top ); + } + + if ( featureSet( SRightBorder ) ) + { + TQDomElement right = doc.createElement( "right-border" ); + right.appendChild( util_createElement( "pen", m_rightBorderPen, doc ) ); + format.appendChild( right ); + } + + if ( featureSet( SBottomBorder ) ) + { + TQDomElement bottom = doc.createElement( "bottom-border" ); + bottom.appendChild( util_createElement( "pen", m_bottomBorderPen, doc ) ); + format.appendChild( bottom ); + } + + if ( featureSet( SFallDiagonal ) ) + { + TQDomElement fallDiagonal = doc.createElement( "fall-diagonal" ); + fallDiagonal.appendChild( util_createElement( "pen", m_fallDiagonalPen, doc ) ); + format.appendChild( fallDiagonal ); + } + + if ( featureSet( SGoUpDiagonal ) ) + { + TQDomElement goUpDiagonal = doc.createElement( "up-diagonal" ); + goUpDiagonal.appendChild( util_createElement( "pen", m_goUpDiagonalPen, doc ) ); + format.appendChild( goUpDiagonal ); + } +} + +bool Style::loadXML( TQDomElement & format ) +{ + bool ok; + if ( format.hasAttribute( "type" ) ) + { + m_type = (StyleType) format.attribute( "type" ).toInt( &ok ); + if ( !ok ) + return false; + } + + if ( format.hasAttribute( "alignX" ) ) + { + Format::Align a = (Format::Align) format.attribute( "alignX" ).toInt( &ok ); + if ( !ok ) + return false; + if ( (unsigned int) a >= 1 || (unsigned int) a <= 4 ) + { + m_alignX = a; + m_featuresSet |= SAlignX; + } + } + if ( format.hasAttribute( "alignY" ) ) + { + Format::AlignY a = (Format::AlignY) format.attribute( "alignY" ).toInt( &ok ); + if ( !ok ) + return false; + if ( (unsigned int) a >= 1 || (unsigned int) a < 4 ) + { + m_alignY = a; + m_featuresSet |= SAlignY; + } + } + + if ( format.hasAttribute( "bgcolor" ) ) + { + m_bgColor = TQColor( format.attribute( "bgcolor" ) ); + // FIXME: Is white always correct here? + if ( m_bgColor != TQt::white ) + m_featuresSet |= SBackgroundColor; + } + + if ( format.hasAttribute( "multirow" ) ) + { + setProperty( PMultiRow ); + m_featuresSet |= SMultiRow; + } + + if ( format.hasAttribute( "verticaltext" ) ) + { + setProperty( PVerticalText ); + m_featuresSet |= SVerticalText; + } + + if ( format.hasAttribute( "precision" ) ) + { + int i = format.attribute( "precision" ).toInt( &ok ); + if ( i < -1 ) + { + kdDebug(36001) << "Value out of range Cell::precision=" << i << endl; + return false; + } + m_precision = i; + m_featuresSet |= SPrecision; + } + + if ( format.hasAttribute( "float" ) ) + { + Format::FloatFormat a = (Format::FloatFormat)format.attribute( "float" ).toInt( &ok ); + if ( !ok ) + return false; + if ( (unsigned int) a >= 1 || (unsigned int) a <= 3 ) + { + m_floatFormat = a; + m_featuresSet |= SFloatFormat; + } + } + + if ( format.hasAttribute( "floatcolor" ) ) + { + Format::FloatColor a = (Format::FloatColor) format.attribute( "floatcolor" ).toInt( &ok ); + if ( !ok ) return false; + if ( (unsigned int) a >= 1 || (unsigned int) a <= 2 ) + { + m_floatColor = a; + m_featuresSet |= SFloatColor; + } + } + + if ( format.hasAttribute( "format" ) ) + { + int fo = format.attribute( "format" ).toInt( &ok ); + if ( ! ok ) + return false; + m_formatType = ( FormatType ) fo; + m_featuresSet |= SFormatType; + } + if ( format.hasAttribute( "custom" ) ) + { + m_strFormat = format.attribute( "custom" ); + m_featuresSet |= SCustomFormat; + } + if ( m_formatType == Money_format ) + { + if ( format.hasAttribute( "type" ) ) + { + m_currency.type = format.attribute( "type" ).toInt( &ok ); + if (!ok) + m_currency.type = 1; + } + if ( format.hasAttribute( "symbol" ) ) + { + m_currency.symbol = format.attribute( "symbol" ); + } + m_featuresSet |= SFormatType; + } + if ( format.hasAttribute( "angle" ) ) + { + m_rotateAngle = format.attribute( "angle" ).toInt( &ok ); + if ( !ok ) + return false; + m_featuresSet |= SAngle; + } + if ( format.hasAttribute( "indent" ) ) + { + m_indent = format.attribute( "indent" ).toDouble( &ok ); + if ( !ok ) + return false; + m_featuresSet |= SIndent; + } + if ( format.hasAttribute( "dontprinttext" ) ) + { + setProperty( PDontPrintText ); + m_featuresSet |= SDontPrintText; + } + + if ( format.hasAttribute( "noprotection" ) ) + { + setProperty( PNotProtected ); + m_featuresSet |= SNotProtected; + } + + if ( format.hasAttribute( "hideall" ) ) + { + setProperty( PHideAll ); + m_featuresSet |= SHideAll; + } + + if ( format.hasAttribute( "hideformula" ) ) + { + setProperty( PHideFormula ); + m_featuresSet |= SHideFormula; + } + + // TODO: remove that... + TQDomElement font = format.namedItem( "font" ).toElement(); + if ( !font.isNull() ) + { + TQFont f( util_toFont( font ) ); + m_fontFamily = f.family(); + m_fontSize = f.pointSize(); + if ( f.italic() ) + m_fontFlags |= FItalic; + if ( f.bold() ) + m_fontFlags |= FBold; + if ( f.underline() ) + m_fontFlags |= FUnderline; + if ( f.strikeOut() ) + m_fontFlags |= FStrike; + + m_featuresSet |= SFont; + m_featuresSet |= SFontFamily; + m_featuresSet |= SFontFlag; + m_featuresSet |= SFontSize; + } + + if ( format.hasAttribute( "font-family" ) ) + { + m_fontFamily = format.attribute( "font-family" ); + m_featuresSet |= SFont; + m_featuresSet |= SFontFamily; + } + if ( format.hasAttribute( "font-size" ) ) + { + m_fontSize = format.attribute( "font-size" ).toInt( &ok ); + if ( !ok ) + return false; + m_featuresSet |= SFont; + m_featuresSet |= SFontSize; + } + + if ( format.hasAttribute( "font-flags" ) ) + { + m_fontFlags = format.attribute( "font-flags" ).toInt( &ok ); + if ( !ok ) + return false; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + + if ( format.hasAttribute( "brushcolor" ) ) + { + m_backGroundBrush.setColor( TQColor( format.attribute( "brushcolor" ) ) ); + // It is not necessary to set this feature just because the color changes. + // FIXME: Or is it? + //m_featuresSet |= SBackgroundBrush; + } + + if ( format.hasAttribute( "brushstyle" ) ) + { + m_backGroundBrush.setStyle( (Qt::BrushStyle) format.attribute( "brushstyle" ).toInt( &ok ) ); + if ( !ok ) + return false; + + if ( m_backGroundBrush.style() != TQt::NoBrush ) + m_featuresSet |= SBackgroundBrush; + } + + TQDomElement pen = format.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_textPen = util_toPen( pen ); + if ( m_textPen.style() != TQt::NoPen ) + m_featuresSet |= STextPen; + } + + TQDomElement left = format.namedItem( "left-border" ).toElement(); + if ( !left.isNull() ) + { + TQDomElement pen = left.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_leftBorderPen = util_toPen( pen ); + if ( m_leftBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SLeftBorder; + } + } + + TQDomElement top = format.namedItem( "top-border" ).toElement(); + if ( !top.isNull() ) + { + TQDomElement pen = top.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_topBorderPen = util_toPen( pen ); + if ( m_topBorderPen.style() != TQt::NoPen ) + m_featuresSet |= STopBorder; + } + } + + TQDomElement right = format.namedItem( "right-border" ).toElement(); + if ( !right.isNull() ) + { + TQDomElement pen = right.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_rightBorderPen = util_toPen( pen ); + if ( m_rightBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SRightBorder; + } + } + + TQDomElement bottom = format.namedItem( "bottom-border" ).toElement(); + if ( !bottom.isNull() ) + { + TQDomElement pen = bottom.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_bottomBorderPen = util_toPen( pen ); + if ( m_bottomBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SBottomBorder; + } + } + + TQDomElement fallDiagonal = format.namedItem( "fall-diagonal" ).toElement(); + if ( !fallDiagonal.isNull() ) + { + TQDomElement pen = fallDiagonal.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_fallDiagonalPen = util_toPen( pen ); + if ( m_fallDiagonalPen.style() != TQt::NoPen ) + m_featuresSet |= SFallDiagonal; + } + } + + TQDomElement goUpDiagonal = format.namedItem( "up-diagonal" ).toElement(); + if ( !goUpDiagonal.isNull() ) + { + TQDomElement pen = goUpDiagonal.namedItem( "pen" ).toElement(); + if ( !pen.isNull() ) + { + m_goUpDiagonalPen = util_toPen( pen ); + if ( m_goUpDiagonalPen.style() != TQt::NoPen ) + m_featuresSet |= SGoUpDiagonal; + } + } + + if ( format.hasAttribute( "prefix" ) ) + { + m_prefix = format.attribute( "prefix" ); + m_featuresSet |= SPrefix; + } + if ( format.hasAttribute( "postfix" ) ) + { + m_postfix = format.attribute( "postfix" ); + m_featuresSet |= SPostfix; + } + + return true; +} + +void Style::setParent( CustomStyle * parent ) +{ + m_parent = parent; + if ( m_parent ) + m_parentName = m_parent->name(); +} + +CustomStyle * Style::parent() const +{ + return m_parent; +} + +bool Style::release() +{ + --m_usageCount; + + if ( m_type == CUSTOM || m_type == BUILTIN ) + return false; // never delete builtin styles... + + if ( m_usageCount < 1 ) + return true; + + return false; +} + +void Style::addRef() +{ + ++m_usageCount; +} + +bool Style::hasProperty( Properties p ) const +{ + FlagsSet f; + switch( p ) + { + case PDontPrintText: + f = SDontPrintText; + break; + case PCustomFormat: + f = SCustomFormat; + break; + case PNotProtected: + f = SNotProtected; + break; + case PHideAll: + f = SHideAll; + break; + case PHideFormula: + f = SHideFormula; + break; + case PMultiRow: + f = SMultiRow; + break; + case PVerticalText: + f = SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + return ( m_properties & (uint) p ); + } + + return ( !m_parent || featureSet( f ) ? ( m_properties & (uint) p ) : m_parent->hasProperty( p ) ); +} + +bool Style::hasFeature( FlagsSet f, bool withoutParent ) const +{ + bool b = ( m_featuresSet & (uint) f ); + + // check if feature is defined here or at parent level + if ( m_parent && !withoutParent ) + b = ( m_parent->hasFeature( f, withoutParent ) ? true : b ); + + return b; +} + +void Style::clearFeature( FlagsSet f ) +{ + m_featuresSet &= ~(uint)f; +} + +TQFont Style::font() const +{ + TQString family = fontFamily(); + int size = fontSize(); + uint ff = fontFlags(); + + TQFont f( family, size ); + if ( ff & (uint) FBold ) + f.setBold( true ); + if ( ff & (uint) FItalic ) + f.setItalic( true ); + if ( ff & (uint) FUnderline ) + f.setUnderline( true ); + if ( ff & (uint) FStrike ) + f.setStrikeOut( true ); + + return f; +} + +TQString const & Style::fontFamily() const +{ + return ( !m_parent || featureSet( SFontFamily ) ? m_fontFamily : m_parent->fontFamily() ); +} + +uint Style::fontFlags() const +{ + return ( !m_parent || featureSet( SFontFlag ) ? m_fontFlags : m_parent->fontFlags() ); +} + +int Style::fontSize() const +{ + return ( !m_parent || featureSet( SFontSize ) ? m_fontSize : m_parent->fontSize() ); +} + +TQPen const & Style::pen() const +{ + return ( !m_parent || featureSet( STextPen ) ? m_textPen : m_parent->pen() ); +} + +TQColor const & Style::bgColor() const +{ + return ( !m_parent || featureSet( SBackgroundColor ) ? m_bgColor : m_parent->bgColor() ); +} + +TQPen const & Style::rightBorderPen() const +{ + return ( !m_parent || featureSet( SRightBorder ) ? m_rightBorderPen : m_parent->rightBorderPen() ); +} + +TQPen const & Style::bottomBorderPen() const +{ + return ( !m_parent || featureSet( SBottomBorder ) ? m_bottomBorderPen : m_parent->bottomBorderPen() ); +} + +TQPen const & Style::leftBorderPen() const +{ + return ( !m_parent || featureSet( SLeftBorder ) ? m_leftBorderPen : m_parent->leftBorderPen() ); +} + +TQPen const & Style::topBorderPen() const +{ + return ( !m_parent || featureSet( STopBorder ) ? m_topBorderPen : m_parent->topBorderPen() ); +} + +TQPen const & Style::fallDiagonalPen() const +{ + return ( !m_parent || featureSet( SFallDiagonal ) ? m_fallDiagonalPen : m_parent->fallDiagonalPen() ); +} + +TQPen const & Style::goUpDiagonalPen() const +{ + return ( !m_parent || featureSet( SGoUpDiagonal ) ? m_goUpDiagonalPen : m_parent->goUpDiagonalPen() ); +} + +int Style::precision() const +{ + return ( !m_parent || featureSet( SPrecision ) ? m_precision : m_parent->precision() ); +} + +int Style::rotateAngle() const +{ + return ( !m_parent || featureSet( SAngle ) ? m_rotateAngle : m_parent->rotateAngle() ); +} + +double Style::indent() const +{ + return ( !m_parent || featureSet( SIndent ) ? m_indent : m_parent->indent() ); +} + +TQBrush const & Style::backGroundBrush() const +{ + return ( !m_parent || featureSet( SBackgroundBrush ) ? m_backGroundBrush : m_parent->backGroundBrush() ); +} + +Format::Align Style::alignX() const +{ + return ( !m_parent || featureSet( SAlignX ) ? m_alignX : m_parent->alignX() ); +} + +Format::AlignY Style::alignY() const +{ + return ( !m_parent || featureSet( SAlignY ) ? m_alignY : m_parent->alignY() ); +} + +Format::FloatFormat Style::floatFormat() const +{ + return ( !m_parent || featureSet( SFloatFormat ) ? m_floatFormat : m_parent->floatFormat() ); +} + +Format::FloatColor Style::floatColor() const +{ + return ( !m_parent || featureSet( SFloatColor ) ? m_floatColor : m_parent->floatColor() ); +} + +FormatType Style::formatType() const +{ + return ( !m_parent || featureSet( SFormatType ) ? m_formatType : m_parent->formatType() ); +} + +Format::Currency const & Style::currency() const +{ + return ( !m_parent || featureSet( SFormatType ) ? m_currency : m_parent->currency() ); +} + +TQString const & Style::strFormat() const +{ + return ( !m_parent || featureSet( SCustomFormat ) ? m_strFormat : m_parent->strFormat() ); +} + +TQString const & Style::prefix() const +{ + return ( !m_parent || featureSet( SPrefix ) ? m_prefix : m_parent->prefix() ); +} + +TQString const & Style::postfix() const +{ + return ( !m_parent || featureSet( SPostfix ) ? m_postfix : m_parent->postfix() ); +} + + + +Style * Style::setAlignX( Format::Align alignX ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_alignX = alignX; + style->m_featuresSet |= SAlignX; + return style; + } + + m_alignX = alignX; + m_featuresSet |= SAlignX; + return this; +} + +Style * Style::setAlignY( Format::AlignY alignY ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_alignY = alignY; + style->m_featuresSet |= SAlignY; + return style; + } + + m_alignY = alignY; + m_featuresSet |= SAlignY; + return this; +} + +Style * Style::setFont( TQFont const & f ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + if ( style->m_fontFamily != f.family() ) + { + style->m_fontFamily = f.family(); + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontFamily; + } + if ( style->m_fontSize != f.pointSize() ) + { + style->m_fontSize = f.pointSize(); + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontSize; + } + if ( f.italic() != (m_fontFlags & (uint) FItalic ) ) + { + if ( f.italic() ) + style->m_fontFlags |= FItalic; + else + style->m_fontFlags &= ~(uint) FItalic; + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontFlag; + } + if ( f.bold() != (m_fontFlags & (uint) FBold ) ) + { + if ( f.bold() ) + style->m_fontFlags |= FBold; + else + style->m_fontFlags &= ~(uint) FBold; + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontFlag; + } + if ( f.underline() != (m_fontFlags & (uint) FUnderline ) ) + { + if ( f.underline() ) + style->m_fontFlags |= FUnderline; + else + style->m_fontFlags &= ~(uint) FUnderline; + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontFlag; + } + if ( f.strikeOut() != (m_fontFlags & (uint) FStrike ) ) + { + if ( f.strikeOut() ) + style->m_fontFlags |= FStrike; + else + style->m_fontFlags &= ~(uint) FStrike; + style->m_featuresSet |= SFont; + style->m_featuresSet |= SFontFlag; + } + + return style; + } + + if ( m_fontFamily != f.family() ) + { + m_fontFamily = f.family(); + m_featuresSet |= SFont; + m_featuresSet |= SFontFamily; + } + if ( m_fontSize != f.pointSize() ) + { + m_fontSize = f.pointSize(); + m_featuresSet |= SFont; + m_featuresSet |= SFontSize; + } + if ( f.italic() != (m_fontFlags & (uint) FItalic ) ) + { + if ( f.italic() ) + m_fontFlags |= FItalic; + else + m_fontFlags &= ~(uint) FItalic; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.bold() != (m_fontFlags & (uint) FBold ) ) + { + if ( f.bold() ) + m_fontFlags |= FBold; + else + m_fontFlags &= ~(uint) FBold; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.underline() != (m_fontFlags & (uint) FUnderline ) ) + { + if ( f.underline() ) + m_fontFlags |= FUnderline; + else + m_fontFlags &= ~(uint) FUnderline; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.strikeOut() != (m_fontFlags & (uint) FStrike ) ) + { + if ( f.strikeOut() ) + m_fontFlags |= FStrike; + else + m_fontFlags &= ~(uint) FStrike; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + + return this; +} + +Style * Style::setFontFamily( TQString const & fam ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + if ( m_fontFamily != fam ) + { + Style * style = new Style( this ); + style->m_fontFamily = fam; + style->m_featuresSet |= SFontFamily; + style->m_featuresSet |= SFont; + return style; + } + return this; + } + + m_fontFamily = fam; + m_featuresSet |= SFont; + m_featuresSet |= SFontFamily; + return this; +} + +Style * Style::setFontFlags( uint flags ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + if ( m_fontFlags != flags ) + { + Style * style = new Style( this ); + style->m_fontFlags = flags; + style->m_featuresSet |= SFontFlag; + style->m_featuresSet |= SFont; + return style; + } + return this; + } + + m_fontFlags = flags; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + return this; +} + +Style * Style::setFontSize( int size ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + if ( m_fontSize != size ) + { + Style * style = new Style( this ); + style->m_fontSize = size; + style->m_featuresSet |= SFontSize; + style->m_featuresSet |= SFont; + return style; + } + return this; + } + + m_fontSize = size; + m_featuresSet |= SFont; + m_featuresSet |= SFontSize; + return this; +} + +Style * Style::setPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_textPen = pen; + if ( style->m_textPen.style() != TQt::NoPen ) + style->m_featuresSet |= STextPen; + return style; + } + + m_textPen = pen; + if ( m_textPen.style() != TQt::NoPen ) + m_featuresSet |= STextPen; + return this; +} + +Style * Style::setBgColor( TQColor const & color ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_bgColor = color; + if ( style->m_bgColor != TQt::white ) + style->m_featuresSet |= SBackgroundColor; + return style; + } + + m_bgColor = color; + if ( m_bgColor != TQt::white ) + m_featuresSet |= SBackgroundColor; + return this; +} + +Style * Style::setRightBorderPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_rightBorderPen = pen; + style->m_rightPenValue = calculateValue( pen ); + if ( style->m_rightBorderPen.style() != TQt::NoPen ) + style->m_featuresSet |= SRightBorder; + return style; + } + + m_rightBorderPen = pen; + m_rightPenValue = calculateValue( pen ); + if ( m_rightBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SRightBorder; + return this; +} + +Style * Style::setBottomBorderPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_bottomBorderPen = pen; + style->m_bottomPenValue = calculateValue( pen ); + if ( style->m_bottomBorderPen.style() != TQt::NoPen ) + style->m_featuresSet |= SBottomBorder; + return style; + } + + m_bottomBorderPen = pen; + m_bottomPenValue = calculateValue( pen ); + if ( m_bottomBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SBottomBorder; + return this; +} + +Style * Style::setLeftBorderPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_leftBorderPen = pen; + style->m_leftPenValue = calculateValue( pen ); + if ( style->m_leftBorderPen.style() != TQt::NoPen ) + style->m_featuresSet |= SLeftBorder; + return style; + } + + m_leftBorderPen = pen; + m_leftPenValue = calculateValue( pen ); + if ( m_leftBorderPen.style() != TQt::NoPen ) + m_featuresSet |= SLeftBorder; + return this; +} + +Style * Style::setTopBorderPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_topBorderPen = pen; + style->m_topPenValue = calculateValue( pen ); + if ( style->m_topBorderPen.style() != TQt::NoPen ) + style->m_featuresSet |= STopBorder; + return style; + } + + m_topBorderPen = pen; + m_topPenValue = calculateValue( pen ); + if ( m_topBorderPen.style() != TQt::NoPen ) + m_featuresSet |= STopBorder; + return this; +} + +Style * Style::setFallDiagonalPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_fallDiagonalPen = pen; + if ( style->m_fallDiagonalPen.style() != TQt::NoPen ) + style->m_featuresSet |= SFallDiagonal; + return style; + } + + m_fallDiagonalPen = pen; + if ( m_fallDiagonalPen.style() != TQt::NoPen ) + m_featuresSet |= SFallDiagonal; + return this; +} + +Style * Style::setGoUpDiagonalPen( TQPen const & pen ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_goUpDiagonalPen = pen; + if ( style->m_goUpDiagonalPen.style() != TQt::NoPen ) + style->m_featuresSet |= SGoUpDiagonal; + return style; + } + + m_goUpDiagonalPen = pen; + if ( m_goUpDiagonalPen.style() != TQt::NoPen ) + m_featuresSet |= SGoUpDiagonal; + return this; +} + +Style * Style::setRotateAngle( int angle ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_rotateAngle = angle; + style->m_featuresSet |= SAngle; + return style; + } + + m_rotateAngle = angle; + m_featuresSet |= SAngle; + return this; +} + +Style * Style::setIndent( double indent ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_indent = indent; + style->m_featuresSet |= SIndent; + return style; + } + + m_indent = indent; + m_featuresSet |= SIndent; + return this; +} + +Style * Style::setBackGroundBrush( TQBrush const & brush ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_backGroundBrush = brush; + if ( style->m_backGroundBrush.style() != TQt::NoBrush ) + style->m_featuresSet |= SBackgroundBrush; + return style; + } + + m_backGroundBrush = brush; + if ( m_backGroundBrush.style() != TQt::NoBrush ) + m_featuresSet |= SBackgroundBrush; + return this; +} + +Style * Style::setFloatFormat( Format::FloatFormat format ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_floatFormat = format; + style->m_featuresSet |= SFloatFormat; + return style; + } + + m_floatFormat = format; + m_featuresSet |= SFloatFormat; + return this; +} + +Style * Style::setFloatColor( Format::FloatColor color ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_floatColor = color; + style->m_featuresSet |= SFloatColor; + return style; + } + + m_floatColor = color; + m_featuresSet |= SFloatColor; + return this; +} + +Style * Style::setStrFormat( TQString const & strFormat ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_strFormat = strFormat; + style->m_featuresSet |= SCustomFormat; + return style; + } + + m_strFormat = strFormat; + m_featuresSet |= SCustomFormat; + return this; +} + +Style * Style::setPrecision( int precision ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_precision = precision; + style->m_featuresSet |= SPrecision; + return style; + } + + m_precision = precision; + m_featuresSet |= SPrecision; + return this; +} + +Style * Style::setPrefix( TQString const & prefix ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_prefix = prefix; + style->m_featuresSet |= SPrefix; + return style; + } + + m_prefix = prefix; + m_featuresSet |= SPrefix; + return this; +} + +Style * Style::setPostfix( TQString const & postfix ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_postfix = postfix; + style->m_featuresSet |= SPostfix; + return style; + } + + m_postfix = postfix; + m_featuresSet |= SPostfix; + return this; +} + +Style * Style::setCurrency( Format::Currency const & currency ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_currency = currency; + style->m_featuresSet |= SFormatType; + return style; + } + + m_currency = currency; + m_featuresSet |= SFormatType; + return this; +} + +Style * Style::setProperty( Properties p ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_properties |= (uint) p; + switch( p ) + { + case PDontPrintText: + style->m_featuresSet |= SDontPrintText; + break; + case PCustomFormat: + style->m_featuresSet |= SCustomFormat; + break; + case PNotProtected: + style->m_featuresSet |= SNotProtected; + break; + case PHideAll: + style->m_featuresSet |= SHideAll; + break; + case PHideFormula: + style->m_featuresSet |= SHideFormula; + break; + case PMultiRow: + style->m_featuresSet |= SMultiRow; + break; + case PVerticalText: + style->m_featuresSet |= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } + return style; + } + + m_properties |= (uint) p; + switch( p ) + { + case PDontPrintText: + m_featuresSet |= SDontPrintText; + break; + case PCustomFormat: + m_featuresSet |= SCustomFormat; + break; + case PNotProtected: + m_featuresSet |= SNotProtected; + break; + case PHideAll: + m_featuresSet |= SHideAll; + break; + case PHideFormula: + m_featuresSet |= SHideFormula; + break; + case PMultiRow: + m_featuresSet |= SMultiRow; + break; + case PVerticalText: + m_featuresSet |= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } + return this; +} + +Style * Style::clearProperty( Properties p ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_properties &= ~(uint) p; + switch( p ) + { + case PDontPrintText: + style->m_featuresSet |= SDontPrintText; + break; + case PCustomFormat: + style->m_featuresSet |= SCustomFormat; + break; + case PNotProtected: + style->m_featuresSet |= SNotProtected; + break; + case PHideAll: + style->m_featuresSet |= SHideAll; + break; + case PHideFormula: + style->m_featuresSet |= SHideFormula; + break; + case PMultiRow: + style->m_featuresSet |= SMultiRow; + break; + case PVerticalText: + style->m_featuresSet |= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } + return style; + } + + m_properties &= ~(uint) p; + switch( p ) + { + case PDontPrintText: + m_featuresSet |= SDontPrintText; + break; + case PCustomFormat: + m_featuresSet |= SCustomFormat; + break; + case PNotProtected: + m_featuresSet |= SNotProtected; + break; + case PHideAll: + m_featuresSet |= SHideAll; + break; + case PHideFormula: + m_featuresSet |= SHideFormula; + break; + case PMultiRow: + m_featuresSet |= SMultiRow; + break; + case PVerticalText: + m_featuresSet |= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } + return this; +} + + +Style * Style::setFormatType( FormatType format ) +{ + if ( m_type != AUTO || m_usageCount > 1 ) + { + Style * style = new Style( this ); + style->m_formatType = format; + style->m_featuresSet |= SFormatType; + return style; + } + + m_formatType = format; + m_featuresSet |= SFormatType; + return this; +} + +TQString Style::colorName( const TQColor& color ) +{ + static TQMap<TQRgb , TQString> map; + + TQRgb rgb = color.rgb(); + + if (!map.contains( rgb )) + { + map[rgb] = color.name(); + return map[rgb]; + } + else + { + return map[rgb]; + } +} + +/** + * ************************************************************ + * CustomStyle + * ************************************************************ + */ + +CustomStyle::CustomStyle() + : Style(), + m_name( "Default" ) +{ + m_type = BUILTIN; + m_parent = 0; +} + +CustomStyle::CustomStyle( Style * parent, TQString const & name ) + : Style(), + m_name( name ) +{ + m_type = CUSTOM; + m_parent = 0; + + // one to one copy + if ( parent->hasProperty( PDontPrintText ) ) + addProperty( PDontPrintText ); + if ( parent->hasProperty( PCustomFormat ) ) + addProperty( PCustomFormat ); + if ( parent->hasProperty( PNotProtected ) ) + addProperty( PNotProtected ); + if ( parent->hasProperty( PHideAll ) ) + addProperty( PHideAll ); + if ( parent->hasProperty( PHideFormula ) ) + addProperty( PHideFormula ); + if ( parent->hasProperty( PMultiRow ) ) + addProperty( PMultiRow ); + if ( parent->hasProperty( PVerticalText ) ) + addProperty( PVerticalText ); + + changeAlignX( parent->alignX() ); + changeAlignY( parent->alignY() ); + changeFloatFormat( parent->floatFormat() ); + changeFloatColor( parent->floatColor() ); + changeFormatType( parent->formatType() ); + changeFontFamily( parent->fontFamily() ); + changeFontSize( parent->fontSize() ); + changeFontFlags( parent->fontFlags() ); + changePen( parent->pen() ); + changeBgColor( parent->bgColor() ); + changeRightBorderPen( parent->rightBorderPen() ); + changeBottomBorderPen( parent->bottomBorderPen() ); + changeLeftBorderPen( parent->leftBorderPen() ); + changeTopBorderPen( parent->topBorderPen() ); + changeFallBorderPen( parent->fallDiagonalPen() ); + changeGoUpBorderPen( parent->goUpDiagonalPen() ); + changeBackGroundBrush( parent->backGroundBrush() ); + changeRotateAngle( parent->rotateAngle() ); + changeIndent( parent->indent() ); + changeStrFormat( parent->strFormat() ); + changePrecision( parent->precision() ); + changePrefix( parent->prefix() ); + changePostfix( parent->postfix() ); + changeCurrency( parent->currency() ); +} + +CustomStyle::CustomStyle( TQString const & name, CustomStyle * parent ) + : Style(), + m_name( name ) +{ + m_parent = parent; + if ( m_parent ) + m_parentName = m_parent->name(); +} + +CustomStyle::~CustomStyle() +{ +} + +TQString CustomStyle::saveOasis( KoGenStyle& style, KoGenStyles &mainStyles ) +{ + // If the type is undefined, we're called from Format + // and the OASIS style is not an automatic style. + // TODO: As the user styles are already created, look them up + // in what way ever and return here. +// if ( style.type() == 0 && ( m_type == BUILTIN ) && ( m_name == "Default" ) ) +// return "Default"; + if ( style.type() == 0 ) + style = KoGenStyle( Doc::STYLE_CELL_USER, "table-cell" ); + + if ( m_name.isEmpty() ) + return TQString(); // TODO fallback to Style::saveOasis() ??? + + // default style does not need display name + if( type() != BUILTIN || m_name != "Default" ) + style.addAttribute( "style:display-name", m_name ); + + // doing the real work + saveOasisStyle( style, mainStyles ); + + // The lookup is done in the calling object (Format). + if ( style.type() == Doc::STYLE_CELL_AUTO ) + return TQString(); + + if( ( m_type == BUILTIN ) && ( m_name == "Default" ) ) + { + style.setDefaultStyle(true); + // don't i18n'ize "Default" in this case + return mainStyles.lookup( style, "Default", KoGenStyles::DontForceNumbering ); + } + else + // this is a custom style + return mainStyles.lookup( style, "custom-style" ); +} + +void CustomStyle::loadOasis( KoOasisStyles& oasisStyles, const TQDomElement& style, const TQString & name ) +{ + m_name = name; + if ( style.hasAttributeNS( KoXmlNS::style, "parent-style-name" ) ) + m_parentName = style.attributeNS( KoXmlNS::style, "parent-style-name", TQString() ); + else if ( m_name != "Default" ) + m_parentName = "Default"; + + m_type = CUSTOM; + + Style::loadOasisStyle( oasisStyles, style ); +} + +void CustomStyle::save( TQDomDocument & doc, TQDomElement & styles ) +{ + if ( m_name.isEmpty() ) + return; + + TQDomElement style( doc.createElement( "style" ) ); + style.setAttribute( "type", (int) m_type ); + if ( m_parent ) + style.setAttribute( "parent", m_parent->name() ); + style.setAttribute( "name", m_name ); + + TQDomElement format( doc.createElement( "format" ) ); + saveXML( doc, format ); + style.appendChild( format ); + + styles.appendChild( style ); +} + +bool CustomStyle::loadXML( TQDomElement const & style, TQString const & name ) +{ + m_name = name; + + if ( style.hasAttribute( "parent" ) ) + m_parentName = style.attribute( "parent" ); + + if ( !style.hasAttribute( "type" ) ) + return false; + + bool ok = true; + m_type = (StyleType) style.attribute( "type" ).toInt( &ok ); + if ( !ok ) + return false; + + TQDomElement f( style.namedItem( "format" ).toElement() ); + if ( !f.isNull() ) + if ( !Style::loadXML( f ) ) + return false; + + return true; +} + +void CustomStyle::setName( TQString const & name ) +{ + m_name = name; +} + +void CustomStyle::refreshParentName() +{ + if ( m_parent ) + m_parentName = m_parent->name(); +} + +bool CustomStyle::definesAll() const +{ + if ( !( m_featuresSet & (uint) SAlignX ) ) + return false; + if ( !( m_featuresSet & (uint) SAlignY ) ) + return false; + if ( !( m_featuresSet & (uint) SPrefix ) ) + return false; + if ( !( m_featuresSet & (uint) SPostfix ) ) + return false; + if ( !( m_featuresSet & (uint) SLeftBorder ) ) + return false; + if ( !( m_featuresSet & (uint) SRightBorder ) ) + return false; + if ( !( m_featuresSet & (uint) STopBorder ) ) + return false; + if ( !( m_featuresSet & (uint) SBottomBorder ) ) + return false; + if ( !( m_featuresSet & (uint) SFallDiagonal ) ) + return false; + if ( !( m_featuresSet & (uint) SGoUpDiagonal ) ) + return false; + if ( !( m_featuresSet & (uint) SBackgroundBrush ) ) + return false; + if ( !( m_featuresSet & (uint) SFontFamily ) ) + return false; + if ( !( m_featuresSet & (uint) SFontSize ) ) + return false; + if ( !( m_featuresSet & (uint) SFontFlag ) ) + return false; + if ( !( m_featuresSet & (uint) STextPen ) ) + return false; + if ( !( m_featuresSet & (uint) SBackgroundColor ) ) + return false; + if ( !( m_featuresSet & (uint) SFloatFormat ) ) + return false; + if ( !( m_featuresSet & (uint) SFloatColor ) ) + return false; + if ( !( m_featuresSet & (uint) SMultiRow ) ) + return false; + if ( !( m_featuresSet & (uint) SVerticalText ) ) + return false; + if ( !( m_featuresSet & (uint) SPrecision ) ) + return false; + if ( !( m_featuresSet & (uint) SFormatType ) ) + return false; + if ( !( m_featuresSet & (uint) SAngle ) ) + return false; + if ( !( m_featuresSet & (uint) SIndent ) ) + return false; + if ( !( m_featuresSet & (uint) SDontPrintText ) ) + return false; + if ( !( m_featuresSet & (uint) SCustomFormat ) ) + return false; + if ( !( m_featuresSet & (uint) SNotProtected ) ) + return false; + if ( !( m_featuresSet & (uint) SHideAll ) ) + return false; + if ( !( m_featuresSet & (uint) SHideFormula ) ) + return false; + + return true; +} + +void CustomStyle::changeAlignX( Format::Align alignX ) +{ + m_alignX = alignX; + m_featuresSet |= SAlignX; +} + +void CustomStyle::changeAlignY( Format::AlignY alignY ) +{ + m_alignY = alignY; + m_featuresSet |= SAlignY; +} + +void CustomStyle::changeFont( TQFont const & f ) +{ + if ( m_fontFamily != f.family() ) + { + m_fontFamily = f.family(); + m_featuresSet |= SFontFamily; + m_featuresSet |= SFont; + } + if ( m_fontSize != f.pointSize() ) + { + m_fontSize = f.pointSize(); + m_featuresSet |= SFont; + m_featuresSet |= SFontSize; + } + + if ( f.italic() != (m_fontFlags & (uint) FItalic ) ) + { + if ( f.italic() ) + m_fontFlags |= FItalic; + else + m_fontFlags &= ~(uint) FItalic; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.bold() != (m_fontFlags & (uint) FBold ) ) + { + if ( f.bold() ) + m_fontFlags |= FBold; + else + m_fontFlags &= ~(uint) FBold; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.underline() != (m_fontFlags & (uint) FUnderline ) ) + { + if ( f.underline() ) + m_fontFlags |= FUnderline; + else + m_fontFlags &= ~(uint) FUnderline; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } + if ( f.strikeOut() != (m_fontFlags & (uint) FStrike ) ) + { + if ( f.strikeOut() ) + m_fontFlags |= FStrike; + else + m_fontFlags &= ~(uint) FStrike; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } +} + +void CustomStyle::changeFontFamily( TQString const & fam ) +{ + if ( m_fontFamily != fam ) + { + m_fontFamily = fam; + m_featuresSet |= SFont; + m_featuresSet |= SFontFamily; + } +} + +void CustomStyle::changeFontSize( int size ) +{ + if ( m_fontSize != size ) + { + m_fontSize = size; + m_featuresSet |= SFont; + m_featuresSet |= SFontSize; + } +} + +void CustomStyle::changeFontFlags( uint flags ) +{ + if ( m_fontFlags != flags ) + { + m_fontFlags = flags; + m_featuresSet |= SFont; + m_featuresSet |= SFontFlag; + } +} + +void CustomStyle::changeTextColor( TQColor const & color ) +{ + m_textPen.setColor( color ); + m_featuresSet |= STextPen; +} + +void CustomStyle::changePen( TQPen const & pen ) +{ + m_textPen = pen; + m_featuresSet |= STextPen; +} + +void CustomStyle::changeBgColor( TQColor const & color ) +{ + m_bgColor = color; + m_featuresSet |= SBackgroundColor; +} + +void CustomStyle::changeRightBorderPen( TQPen const & pen ) +{ + m_rightBorderPen = pen; + m_rightPenValue = calculateValue( pen ); + m_featuresSet |= SRightBorder; +} + +void CustomStyle::changeBottomBorderPen( TQPen const & pen ) +{ + m_bottomBorderPen = pen; + m_bottomPenValue = calculateValue( pen ); + m_featuresSet |= SBottomBorder; +} + +void CustomStyle::changeLeftBorderPen( TQPen const & pen ) +{ + m_leftBorderPen = pen; + m_leftPenValue = calculateValue( pen ); + m_featuresSet |= SLeftBorder; +} + +void CustomStyle::changeTopBorderPen( TQPen const & pen ) +{ + m_topBorderPen = pen; + m_topPenValue = calculateValue( pen ); + m_featuresSet |= STopBorder; +} + +void CustomStyle::changeFallBorderPen( TQPen const & pen ) +{ + m_fallDiagonalPen = pen; + m_featuresSet |= SFallDiagonal; +} + +void CustomStyle::changeGoUpBorderPen( TQPen const & pen ) +{ + m_goUpDiagonalPen = pen; + m_featuresSet |= SGoUpDiagonal; +} + +void CustomStyle::changeRotateAngle( int angle ) +{ + m_rotateAngle = angle; + m_featuresSet |= SAngle; +} + +void CustomStyle::changeIndent( double indent ) +{ + m_indent = indent; + m_featuresSet |= SIndent; +} + +void CustomStyle::changeBackGroundBrush( TQBrush const & brush ) +{ + m_backGroundBrush = brush; + m_featuresSet |= SBackgroundBrush; +} + +void CustomStyle::changeFloatFormat( Format::FloatFormat format ) +{ + m_floatFormat = format; + m_featuresSet |= SFloatFormat; +} + +void CustomStyle::changeFloatColor( Format::FloatColor color ) +{ + m_floatColor = color; + m_featuresSet |= SFloatColor; +} + +void CustomStyle::changeFormatType( FormatType format ) +{ + m_formatType = format; + m_featuresSet |= SFormatType; +} + +void CustomStyle::changeStrFormat( TQString const & strFormat ) +{ + m_strFormat = strFormat; + m_featuresSet |= SCustomFormat; +} + +void CustomStyle::changePrecision( int precision ) +{ + m_precision = precision; + m_featuresSet |= SPrecision; +} + +void CustomStyle::changePrefix( TQString const & prefix ) +{ + m_prefix = prefix; + m_featuresSet |= SPrefix; +} + +void CustomStyle::changePostfix( TQString const & postfix ) +{ + m_postfix = postfix; + m_featuresSet |= SPostfix; +} + +void CustomStyle::changeCurrency( Format::Currency const & currency ) +{ + m_currency = currency; +} + +void CustomStyle::addProperty( Properties p ) +{ + m_properties |= (uint) p; + switch( p ) + { + case PDontPrintText: + m_featuresSet |= SDontPrintText; + break; + case PCustomFormat: + m_featuresSet |= SCustomFormat; + break; + case PNotProtected: + m_featuresSet |= SNotProtected; + break; + case PHideAll: + m_featuresSet |= SHideAll; + break; + case PHideFormula: + m_featuresSet |= SHideFormula; + break; + case PMultiRow: + m_featuresSet |= SMultiRow; + break; + case PVerticalText: + m_featuresSet |= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } +} + +void CustomStyle::removeProperty( Properties p ) +{ + m_properties &= ~(uint) p; + switch( p ) + { + case PDontPrintText: + m_featuresSet &= SDontPrintText; + break; + case PCustomFormat: + m_featuresSet &= SCustomFormat; + break; + case PNotProtected: + m_featuresSet &= SNotProtected; + break; + case PHideAll: + m_featuresSet &= SHideAll; + break; + case PHideFormula: + m_featuresSet &= SHideFormula; + break; + case PMultiRow: + m_featuresSet &= SMultiRow; + break; + case PVerticalText: + m_featuresSet &= SVerticalText; + break; + default: + kdWarning() << "Unhandled property" << endl; + } +} + +bool CustomStyle::operator==( const CustomStyle& other ) const +{ + if ( m_name != other.m_name ) + return false; + return Style::operator==( other ); +} |