/* This file is part of the KDE project Copyright (C) 1999 David Faure Copyright (C) 2004 Nicolas GOUTTE 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 #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include 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 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"