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.
koffice/kspread/kspread_genvalidationstyle.cc

402 lines
12 KiB

/* 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;
}