|
|
|
/* This file is part of the KDE project
|
|
|
|
|
|
|
|
Copyright 2004 Laurent Montel <montel@kde.org>
|
|
|
|
|
|
|
|
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 "kspread_genvalidationstyle.h"
|
|
|
|
#include "kspread_cell.h"
|
|
|
|
#include <KoXmlWriter.h>
|
|
|
|
|
|
|
|
using namespace KSpread;
|
|
|
|
|
|
|
|
GenValidationStyles::GenValidationStyles()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
GenValidationStyles::~GenValidationStyles()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyles::lookup( const GenValidationStyle& style )
|
|
|
|
{
|
|
|
|
StyleMap::iterator it = m_styles.find( style );
|
|
|
|
if ( it == m_styles.end() ) {
|
|
|
|
|
|
|
|
TQString styleName( "val" );
|
|
|
|
styleName = makeUniqueName( styleName );
|
|
|
|
m_names.insert( styleName, true );
|
|
|
|
it = m_styles.insert( style, styleName );
|
|
|
|
}
|
|
|
|
return it.data();
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyles::makeUniqueName( const TQString& base ) const
|
|
|
|
{
|
|
|
|
int num = 1;
|
|
|
|
TQString name;
|
|
|
|
do {
|
|
|
|
name = base;
|
|
|
|
name += TQString::number( num++ );
|
|
|
|
} while ( m_names.find( name ) != m_names.end() );
|
|
|
|
return name;
|
|
|
|
}
|
|
|
|
|
|
|
|
void GenValidationStyles::writeStyle( KoXmlWriter& writer )
|
|
|
|
{
|
|
|
|
if ( m_styles.count()>0 )
|
|
|
|
{
|
|
|
|
writer.startElement( "table:content-validations" );
|
|
|
|
StyleMap::Iterator it;
|
|
|
|
for ( it = m_styles.begin(); it != m_styles.end(); ++it )
|
|
|
|
{
|
|
|
|
writer.startElement( "table:content-validation" );
|
|
|
|
writer.addAttribute( "table:name", it.data() );
|
|
|
|
writer.addAttribute( "table:allow-empty-cell", it.key().allowEmptyCell );
|
|
|
|
writer.addAttribute( "table:condition", it.key().condition );
|
|
|
|
|
|
|
|
writer.startElement( "table:help-message" );
|
|
|
|
writer.addAttribute( "table:title", it.key().title );
|
|
|
|
writer.addAttribute( "table:display", it.key().displayValidationInformation );
|
|
|
|
|
|
|
|
TQStringList text = TQStringList::split( "\n", it.key().messageInfo );
|
|
|
|
for ( TQStringList::Iterator it2 = text.begin(); it2 != text.end(); ++it2 ) {
|
|
|
|
writer.startElement( "text:p" );
|
|
|
|
writer.addTextNode( *it2 );
|
|
|
|
writer.endElement();
|
|
|
|
}
|
|
|
|
writer.endElement();
|
|
|
|
|
|
|
|
writer.startElement( "table:error-message" );
|
|
|
|
writer.addAttribute( "table:message-type", it.key().messageType );
|
|
|
|
|
|
|
|
writer.addAttribute("table:title", it.key().titleInfo);
|
|
|
|
writer.addAttribute("table:display", it.key().displayMessage);
|
|
|
|
text = TQStringList::split( "\n", it.key().message );
|
|
|
|
for ( TQStringList::Iterator it3 = text.begin(); it3 != text.end(); ++it3 ) {
|
|
|
|
writer.startElement( "text:p" );
|
|
|
|
writer.addTextNode( *it3 );
|
|
|
|
writer.endElement();
|
|
|
|
}
|
|
|
|
writer.endElement();
|
|
|
|
|
|
|
|
writer.endElement();
|
|
|
|
}
|
|
|
|
writer.endElement();//close sheet:content-validation
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void GenValidationStyle::initVal( Validity *_val )
|
|
|
|
{
|
|
|
|
if ( _val )
|
|
|
|
{
|
|
|
|
allowEmptyCell = ( _val->allowEmptyCell ? "true" : "false" );
|
|
|
|
condition = createValidationCondition( _val );
|
|
|
|
title = _val->title;
|
|
|
|
displayValidationInformation = ( _val->displayValidationInformation ? "true" : "false" );
|
|
|
|
messageInfo = _val->messageInfo;
|
|
|
|
|
|
|
|
switch( _val->m_action )
|
|
|
|
{
|
|
|
|
case Action::Warning:
|
|
|
|
messageType = "warning";
|
|
|
|
break;
|
|
|
|
case Action::Information:
|
|
|
|
messageType = "information";
|
|
|
|
break;
|
|
|
|
case Action::Stop:
|
|
|
|
messageType = "stop";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
titleInfo = _val->titleInfo;
|
|
|
|
displayMessage = ( _val->displayMessage ? "true" : "false" );
|
|
|
|
message = _val->message;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result;
|
|
|
|
switch( _val->m_restriction )
|
|
|
|
{
|
|
|
|
case Restriction::None:
|
|
|
|
//nothing
|
|
|
|
break;
|
|
|
|
case Restriction::Text:
|
|
|
|
//doesn't exist into oo spec
|
|
|
|
result = "cell-content-is-text()";
|
|
|
|
break;
|
|
|
|
case Restriction::Time:
|
|
|
|
result = createTimeValidationCondition( _val );
|
|
|
|
break;
|
|
|
|
case Restriction::Date:
|
|
|
|
result = createDateValidationCondition( _val );
|
|
|
|
break;
|
|
|
|
case Restriction::Integer:
|
|
|
|
case Restriction::Number:
|
|
|
|
result = createNumberValidationCondition( _val );
|
|
|
|
break;
|
|
|
|
case Restriction::TextLength:
|
|
|
|
result = createTextValidationCondition( _val );
|
|
|
|
break;
|
|
|
|
case Restriction::List:
|
|
|
|
result = createListValidationCondition( _val );
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createListValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result = "oooc:cell-content-is-in-list(";
|
|
|
|
result = _val->listValidity.join( ";" );
|
|
|
|
result +=")";
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createNumberValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result;
|
|
|
|
if ( _val->m_restriction == Restriction::Number )
|
|
|
|
result = "oooc:cell-content-is-whole-number() and ";
|
|
|
|
else if ( _val->m_restriction == Restriction::Integer )
|
|
|
|
result = "oooc:cell-content-is-decimal-number() and ";
|
|
|
|
switch( _val->m_cond )
|
|
|
|
{
|
|
|
|
case Conditional::None:
|
|
|
|
//nothing
|
|
|
|
break;
|
|
|
|
case Conditional::Equal:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Superior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Inferior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::SuperiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::InferiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Different:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="!=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Between:
|
|
|
|
result+="cell-content-is-between(";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
result+=",";
|
|
|
|
result+=TQString::number( _val->valMax );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
case Conditional::DifferentTo:
|
|
|
|
result+="cell-content-is-not-between(";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
result+=",";
|
|
|
|
result+=TQString::number( _val->valMax );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createTimeValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result( "oooc:cell-content-is-time() and " );
|
|
|
|
switch( _val->m_cond )
|
|
|
|
{
|
|
|
|
case Conditional::None:
|
|
|
|
//nothing
|
|
|
|
break;
|
|
|
|
case Conditional::Equal:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="=";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::Superior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::Inferior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::SuperiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">=";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::InferiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<=";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::Different:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="!=";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
break;
|
|
|
|
case Conditional::Between:
|
|
|
|
result+="cell-content-is-between(";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
result+=",";
|
|
|
|
result+=_val->timeMax.toString( );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
case Conditional::DifferentTo:
|
|
|
|
result+="cell-content-is-not-between(";
|
|
|
|
result+=_val->timeMin.toString( );
|
|
|
|
result+=",";
|
|
|
|
result+=_val->timeMax.toString( );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createDateValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result( "oooc:cell-content-is-date() and " );
|
|
|
|
switch( _val->m_cond )
|
|
|
|
{
|
|
|
|
case Conditional::None:
|
|
|
|
//nothing
|
|
|
|
break;
|
|
|
|
case Conditional::Equal:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="=";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::Superior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::Inferior:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::SuperiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+=">=";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::InferiorEqual:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="<=";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::Different:
|
|
|
|
result+="cell-content()";
|
|
|
|
result+="!=";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
break;
|
|
|
|
case Conditional::Between:
|
|
|
|
result+="cell-content-is-between(";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
result+=",";
|
|
|
|
result+=_val->dateMax.toString();
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
case Conditional::DifferentTo:
|
|
|
|
result+="cell-content-is-not-between(";
|
|
|
|
result+=_val->dateMin.toString();
|
|
|
|
result+=",";
|
|
|
|
result+=_val->dateMax.toString();
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
TQString GenValidationStyle::createTextValidationCondition( Validity* _val )
|
|
|
|
{
|
|
|
|
TQString result;
|
|
|
|
switch( _val->m_cond )
|
|
|
|
{
|
|
|
|
case Conditional::None:
|
|
|
|
//nothing
|
|
|
|
break;
|
|
|
|
case Conditional::Equal:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+="=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Superior:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+=">";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Inferior:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+="<";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::SuperiorEqual:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+=">=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::InferiorEqual:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+="<=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Different:
|
|
|
|
result+="oooc:cell-content-text-length()";
|
|
|
|
result+="!=";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
break;
|
|
|
|
case Conditional::Between:
|
|
|
|
result+="oooc:cell-content-text-length-is-between(";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
result+=",";
|
|
|
|
result+=TQString::number( _val->valMax );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
case Conditional::DifferentTo:
|
|
|
|
result+="oooc:cell-content-text-length-is-not-between(";
|
|
|
|
result+=TQString::number( _val->valMin );
|
|
|
|
result+=",";
|
|
|
|
result+=TQString::number( _val->valMax );
|
|
|
|
result+=")";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|