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/filters/kspread/csv/csvexportdialog.cpp

333 lines
10 KiB

/* This file is part of the KDE project
Copyright (C) 1999 David Faure <faure@kde.org>
Copyright (C) 2004 Nicolas GOUTTE <goutte@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 <csvexportdialog.h>
#include <exportdialogui.h>
#include <kspread_map.h>
#include <kspread_sheet.h>
#include <tqbuttongroup.h>
#include <tqcheckbox.h>
#include <tqcombobox.h>
#include <tqcursor.h>
#include <tqlabel.h>
#include <tqlineedit.h>
#include <tqlistview.h>
#include <tqptrlist.h>
#include <tqradiobutton.h>
#include <tqtextstream.h>
#include <tqtabwidget.h>
#include <tqtextcodec.h>
#include <tqvalidator.h>
#include <tdeapplication.h>
#include <tdeconfig.h>
#include <klocale.h>
#include <kdebug.h>
#include <kcombobox.h>
#include <kmessagebox.h>
#include <kcharsets.h>
using namespace KSpread;
CSVExportDialog::CSVExportDialog( TQWidget * parent )
: KDialogBase( parent, 0, true, TQString(), Ok | Cancel, No, true ),
m_dialog( new ExportDialogUI( this ) ),
m_delimiter( "," ),
m_textquote('"')
{
kapp->restoreOverrideCursor();
TQStringList encodings;
encodings << i18n( "Descriptive encoding name", "Recommended ( %1 )" ).arg( "UTF-8" );
encodings << i18n( "Descriptive encoding name", "Locale ( %1 )" ).arg( TQTextCodec::codecForLocale()->name() );
encodings += TDEGlobal::charsets()->descriptiveEncodingNames();
// Add a few non-standard encodings, which might be useful for text files
const TQString description(i18n("Descriptive encoding name","Other ( %1 )"));
encodings << description.arg("Apple Roman"); // Apple
encodings << description.arg("IBM 850") << description.arg("IBM 866"); // MS DOS
encodings << description.arg("CP 1258"); // Windows
m_dialog->comboBoxEncoding->insertStringList(encodings);
setButtonBoxOrientation (Qt::Vertical );
setMainWidget(m_dialog);
// Invalid 'Other' delimiters
// - Quotes
// - CR,LF,Vetical-tab,Formfeed,ASCII bel
TQRegExp rx( "^[^\"'\r\n\v\f\a]{0,1}$" );
m_delimiterValidator = new TQRegExpValidator( rx, TQT_TQOBJECT(m_dialog->m_delimiterBox) );
m_dialog->m_delimiterEdit->setValidator( m_delimiterValidator );
connect( m_dialog->m_delimiterBox, TQT_SIGNAL( clicked(int) ),
this, TQT_SLOT( delimiterClicked( int ) ) );
connect( m_dialog->m_delimiterEdit, TQT_SIGNAL( returnPressed() ),
this, TQT_SLOT( returnPressed() ) );
connect( m_dialog->m_delimiterEdit, TQT_SIGNAL( textChanged ( const TQString & ) ),
this, TQT_SLOT(textChanged ( const TQString & ) ) );
connect( m_dialog->m_comboQuote, TQT_SIGNAL( activated( const TQString & ) ),
this, TQT_SLOT( textquoteSelected( const TQString & ) ) );
connect( m_dialog->m_selectionOnly, TQT_SIGNAL( toggled( bool ) ),
this, TQT_SLOT( selectionOnlyChanged( bool ) ) );
loadSettings();
}
CSVExportDialog::~CSVExportDialog()
{
saveSettings();
kapp->setOverrideCursor(TQt::waitCursor);
delete m_delimiterValidator;
}
void CSVExportDialog::loadSettings()
{
TDEConfig *config = kapp->config();
config->setGroup("CSVDialog Settings");
m_textquote = config->readEntry("textquote", "\"")[0];
m_delimiter = config->readEntry("delimiter", ",");
const TQString codecText = config->readEntry("codec", "");
bool selectionOnly = config->readBoolEntry("selectionOnly", false);
const TQString sheetDelim = config->readEntry("sheetDelimiter", m_dialog->m_sheetDelimiter->text());
bool delimAbove = config->readBoolEntry("sheetDelimiterAbove", false);
const TQString eol = config->readEntry("eol", "\r\n");
// update widgets
if (!codecText.isEmpty()) {
m_dialog->comboBoxEncoding->setCurrentText(codecText);
}
if (m_delimiter == ",") m_dialog->m_radioComma->setChecked(true);
else if (m_delimiter == "\t") m_dialog->m_radioTab->setChecked(true);
else if (m_delimiter == " ") m_dialog->m_radioSpace->setChecked(true);
else if (m_delimiter == ";") m_dialog->m_radioSemicolon->setChecked(true);
else {
m_dialog->m_radioOther->setChecked(true);
m_dialog->m_delimiterEdit->setText(m_delimiter);
}
m_dialog->m_comboQuote->setCurrentItem(m_textquote == '\'' ? 1
: m_textquote == '"' ? 0 : 2);
m_dialog->m_selectionOnly->setChecked(selectionOnly);
m_dialog->m_sheetDelimiter->setText(sheetDelim);
m_dialog->m_delimiterAboveAll->setChecked(delimAbove);
if (eol == "\r\n") m_dialog->radioEndOfLineCRLF->setChecked(true);
else if (eol == "\r") m_dialog->radioEndOfLineCR->setChecked(true);
else m_dialog->radioEndOfLineLF->setChecked(true);
}
void CSVExportDialog::saveSettings()
{
TDEConfig *config = kapp->config();
config->setGroup("CSVDialog Settings");
TQString q = m_textquote;
config->writeEntry("textquote", q);
config->writeEntry("delimiter", m_delimiter);
config->writeEntry("codec", m_dialog->comboBoxEncoding->currentText());
config->writeEntry("selectionOnly", exportSelectionOnly());
config->writeEntry("sheetDelimiter", getSheetDelimiter());
config->writeEntry("sheetDelimiterAbove", printAlwaysSheetDelimiter());
config->writeEntry("eol", getEndOfLine());
config->sync();
}
void CSVExportDialog::fillSheet( Map * map )
{
m_dialog->m_sheetList->clear();
TQCheckListItem * item;
TQPtrListIterator<Sheet> it( map->sheetList() );
for( ; it.current(); ++it )
{
item = new TQCheckListItem( m_dialog->m_sheetList,
it.current()->sheetName(),
TQCheckListItem::CheckBox );
item->setOn(true);
m_dialog->m_sheetList->insertItem( item );
}
m_dialog->m_sheetList->setSorting(0, true);
m_dialog->m_sheetList->sort();
m_dialog->m_sheetList->setSorting( -1 );
}
TQChar CSVExportDialog::getDelimiter() const
{
return m_delimiter[0];
}
TQChar CSVExportDialog::getTextQuote() const
{
return m_textquote;
}
bool CSVExportDialog::printAlwaysSheetDelimiter() const
{
return m_dialog->m_delimiterAboveAll->isChecked();
}
TQString CSVExportDialog::getSheetDelimiter() const
{
return m_dialog->m_sheetDelimiter->text();
}
bool CSVExportDialog::exportSheet(TQString const & sheetName) const
{
for (TQListViewItem * item = m_dialog->m_sheetList->firstChild(); item; item = item->nextSibling())
{
if (((TQCheckListItem * ) item)->isOn())
{
if ( ((TQCheckListItem * ) item)->text() == sheetName )
return true;
}
}
return false;
}
void CSVExportDialog::slotOk()
{
accept();
}
void CSVExportDialog::slotCancel()
{
reject();
}
void CSVExportDialog::returnPressed()
{
if ( m_dialog->m_delimiterBox->id( m_dialog->m_delimiterBox->selected() ) != 4 )
return;
m_delimiter = m_dialog->m_delimiterEdit->text();
}
void CSVExportDialog::textChanged ( const TQString & )
{
if ( m_dialog->m_delimiterEdit->text().isEmpty() )
{
enableButtonOK( ! m_dialog->m_radioOther->isChecked() );
return;
}
m_dialog->m_radioOther->setChecked ( true );
delimiterClicked(4);
}
void CSVExportDialog::delimiterClicked( int id )
{
enableButtonOK( true );
//Erase "Other Delimiter" text box if the user has selected one of
//the standard options instead (comma, semicolon, tab or space)
if (id != 4)
m_dialog->m_delimiterEdit->setText("");
switch (id)
{
case 0: // comma
m_delimiter = ",";
break;
case 1: // semicolon
m_delimiter = ";";
break;
case 2: // tab
m_delimiter = "\t";
break;
case 3: // space
m_delimiter = " ";
break;
case 4: // other
enableButtonOK( ! m_dialog->m_delimiterEdit->text().isEmpty() );
m_delimiter = m_dialog->m_delimiterEdit->text();
break;
}
}
void CSVExportDialog::textquoteSelected( const TQString & mark )
{
m_textquote = mark[0];
}
void CSVExportDialog::selectionOnlyChanged( bool on )
{
m_dialog->m_sheetList->setEnabled( !on );
m_dialog->m_delimiterLineBox->setEnabled( !on );
if ( on )
m_dialog->m_tabWidget->setCurrentPage( 1 );
}
bool CSVExportDialog::exportSelectionOnly() const
{
return m_dialog->m_selectionOnly->isChecked();
}
TQTextCodec* CSVExportDialog::getCodec(void) const
{
const TQString strCodec( TDEGlobal::charsets()->encodingForName( m_dialog->comboBoxEncoding->currentText() ) );
kdDebug(30502) << "Encoding: " << strCodec << endl;
bool ok = false;
TQTextCodec* codec = TQTextCodec::codecForName( strCodec.utf8() );
// If TQTextCodec has not found a valid encoding, so try with KCharsets.
if ( codec )
{
ok = true;
}
else
{
codec = TDEGlobal::charsets()->codecForName( strCodec, ok );
}
// Still nothing?
if ( !codec || !ok )
{
// Default: UTF-8
kdWarning(30502) << "Cannot find encoding:" << strCodec << endl;
// ### TODO: what parent to use?
KMessageBox::error( 0, i18n("Cannot find encoding: %1").arg( strCodec ) );
return 0;
}
return codec;
}
TQString CSVExportDialog::getEndOfLine(void) const
{
TQString strReturn;
if (m_dialog->radioEndOfLineLF==m_dialog->buttonGroupEndOfLine->selected())
strReturn="\n";
else if (m_dialog->radioEndOfLineCRLF==m_dialog->buttonGroupEndOfLine->selected())
strReturn="\r\n";
else if (m_dialog->radioEndOfLineCR==m_dialog->buttonGroupEndOfLine->selected())
strReturn="\r";
else
strReturn="\n";
return strReturn;
}
#include "csvexportdialog.moc"