You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
3215 lines
91 KiB
3215 lines
91 KiB
/* This file is part of the KDE project
|
|
Copyright (C) 2003 Norbert Andres, nandres@web.de
|
|
|
|
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 <klocale.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 <robertknight@gmail.com>
|
|
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 );
|
|
}
|