From 3379a4f0774ae37f3e53e31f2aece6caa1bdf8f9 Mon Sep 17 00:00:00 2001 From: ulf69 Date: Mon, 02 Aug 2004 18:35:42 +0000 Subject: a syncwidget, based on zautrix kopi sync-widget that scan be used from inside the "configure resource" dialog. --- (limited to 'kabc/syncprefwidget.cpp') diff --git a/kabc/syncprefwidget.cpp b/kabc/syncprefwidget.cpp new file mode 100644 index 0000000..51a8040 --- a/dev/null +++ b/kabc/syncprefwidget.cpp @@ -0,0 +1,495 @@ +/* + This file is part of KABC for platform independent KDE tools. + Copyright (c) 2004 Ulf Schenk + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + + As a special exception, permission is given to link this program + with any edition of Qt, and distribute the resulting executable, + without including the source code for Qt in the source distribution. +*/ + +/* +$Id$ +*/ + +/*US +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include + + +#include "koprefs.h" + +#include "kosyncprefsdialog.h" +#include "koglobals.h" +*/ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + + +#include +#include + + +#include "syncprefwidget.h" + + +SyncPrefWidget::SyncPrefWidget(QWidget *parent) : + KRES::SyncWidget(parent) +{ + +//US setCaption( i18n("Synchronization Preferences")); + +//US mSyncProfiles.setAutoDelete( true ); + init(); +} + + +SyncPrefWidget::~SyncPrefWidget() +{ +} + +//US #include +//US #include +void SyncPrefWidget::init() +{ + QLabel * lab; + QPushButton* button; + +/*US + //QFrame *page = addPage(i18n("Sync Prefs"),0,0); + QVBox * mainbox = new QVBox( this ); + QScrollView* sv = new QScrollView( mainbox ); + QHBoxLayout * lay = new QHBoxLayout( this ); + lay->addWidget( mainbox ); + QHBox * b_box = new QHBox( mainbox ); +*/ +/*US + QPushButton* button = new QPushButton( i18n("Ok"), b_box ); + connect ( button, SIGNAL( clicked()), this, SLOT (slotOK() ) ); + button = new QPushButton( i18n("Cancel"), b_box ); + connect ( button, SIGNAL( clicked()), this, SLOT (reject() ) ); +*/ + //QBoxLayout * sl = new QVBoxLayout(this ); + //sl->addWidget ( sv ); +/*US + sv->setResizePolicy ( QScrollView::AutoOneFit ); + QFrame *topFrame = new QFrame ( sv ); + sv->addChild( topFrame ); + mSetupSyncAlgTab = topFrame; + QGridLayout *topLayout = new QGridLayout(topFrame,6,2); + topLayout->setSpacing(spacingHint()); + topLayout->setMargin(marginHint()); +*/ +//US new code for the layout + QGridLayout *topLayout = new QGridLayout( this, 6,2 ); + topLayout->setMargin( KDialog::marginHint() ); + topLayout->setSpacing( KDialog::spacingHint() ); + + //lab = new QLabel(i18n("Sync settings not yet implemented. DO NOT USE!"), topFrame); + int iii = 0; + //topLayout->addMultiCellWidget(lab , iii,iii,0,1); + //++iii; + +/*US + mMyMachineName = new QLineEdit(topFrame); + lab = new QLabel(mMyMachineName, i18n("Local device name:"), topFrame); + topLayout->addWidget(lab ,iii,0); + topLayout->addWidget(mMyMachineName,iii,1); + ++iii; + + QHBox* buttonbox = new QHBox( topFrame); + topLayout->addMultiCellWidget(buttonbox, iii,iii,0,1); + ++iii; + button = new QPushButton( i18n("New profile"), buttonbox ); + connect ( button, SIGNAL( clicked()), this, SLOT (newProfile() ) ); + + button = new QPushButton( i18n("Clone profile"), buttonbox ); + connect ( button, SIGNAL( clicked()), this, SLOT ( cloneProfile() ) ); + + button = new QPushButton( i18n("Delete profile"), buttonbox ); + connect ( button, SIGNAL( clicked()), this, SLOT (deleteProfile() ) ); + + mProfileBox = new QComboBox(topFrame); + mProfileBox->setEditable ( true ); + connect ( mProfileBox, SIGNAL(activated ( int ) ), this, SLOT (profileChanged( int ) ) ); + connect ( mProfileBox, SIGNAL( textChanged ( const QString & ) ), this, SLOT (textChanged( const QString & ) ) ); + + lab = new QLabel(mProfileBox, i18n("Profile:"), topFrame); + topLayout->addWidget(lab ,iii,0); + topLayout->addWidget(mProfileBox, iii,1); + ++iii; +*/ + mIncludeInRing = new QCheckBox( i18n("Include in multiple sync"), this ); + topLayout->addMultiCellWidget(mIncludeInRing, iii,iii,0,1); + ++iii; + + mAskForPreferences = new QCheckBox( i18n("Ask for preferences before sync"), this ); + topLayout->addMultiCellWidget(mAskForPreferences, iii,iii,0,1); + ++iii; + QButtonGroup* gr = new QButtonGroup ( 1, Qt::Horizontal, i18n("Sync preferences"), this); + topLayout->addMultiCellWidget(gr, iii,iii,0,1); + ++iii; + loc = new QRadioButton ( i18n("Take local entry on conflict"), gr ); + rem = new QRadioButton ( i18n("Take remote entry on conflict"), gr ); + newest = new QRadioButton ( i18n("Take newest entry on conflict"), gr ); + ask = new QRadioButton ( i18n("Ask for every entry on conflict"), gr ); + f_loc= new QRadioButton ( i18n("Force: Take local entry always"), gr ); + f_rem = new QRadioButton ( i18n("Force: Take remote entry always"), gr ); + // both = new QRadioButton ( i18n("Take both on conflict"), gr ); + + mShowSummaryAfterSync = new QCheckBox( i18n("Show summary after sync"), this ); + topLayout->addMultiCellWidget(mShowSummaryAfterSync, iii,iii,0,1); + ++iii; + + mWriteBackExisting= new QCheckBox( i18n("Write back existing entries only"), this ); + topLayout->addMultiCellWidget(mWriteBackExisting, iii,iii,0,1); + ++iii; + + mWriteBackFile = new QCheckBox( i18n("Write back file"), this ); + topLayout->addMultiCellWidget(mWriteBackFile, iii,iii,0,1); + ++iii; + + mIsNotLocal = new QCheckBox( i18n("Remote file (w down/upload command)"), this ); + topLayout->addMultiCellWidget(mIsNotLocal, iii,iii,0,1); + connect (mIsNotLocal, SIGNAL( checked(bool)), this, SLOT (kindChanged(bool) ) ); +/*US + proGr = new QButtonGroup ( 1, Qt::Horizontal, i18n("Profile kind"), this); + gr = proGr; + topLayout->addMultiCellWidget(gr, iii,iii,0,1); + ++iii; + mIsLocal = new QRadioButton ( i18n("Local file"), gr ); + mIsNotLocal = new QRadioButton ( i18n("Remote file (w down/upload command)"), gr ); + connect (mIsLocal, SIGNAL( toggled(bool)), this, SLOT (kindChanged(bool) ) ); +*/ + +/*US + localFileWidget = new QVBox( topFrame); + topLayout->addMultiCellWidget(localFileWidget, iii,iii,0,1); + ++iii; + QHBox* temphb = new QHBox( localFileWidget ); + lab = new QLabel( i18n("Local file:"), temphb); + mRemoteFile = new QLineEdit(localFileWidget); + + button = new QPushButton( i18n("Choose..."), temphb ); + connect ( button, SIGNAL( clicked()), this, SLOT ( chooseFile() ) ); +*/ + QHBox* temphb; + + remoteFileWidget = new QVBox( this); + topLayout->addMultiCellWidget(remoteFileWidget, iii,iii,0,1); + ++iii; + lab = new QLabel( i18n("Pre sync (download) command:"), remoteFileWidget); + mRemotePrecommand = new QLineEdit(remoteFileWidget); + + lab = new QLabel( i18n("Local temp file:"), remoteFileWidget); + mLocalTempFile = new QLineEdit(remoteFileWidget); + + + lab = new QLabel( i18n("Post sync (upload) command:"), remoteFileWidget); + mRemotePostcommand = new QLineEdit(remoteFileWidget); + + lab = new QLabel( i18n("Fill in default values for:"), remoteFileWidget); + temphb = new QHBox( remoteFileWidget ); + button = new QPushButton( i18n("ssh/scp"), temphb ); + connect ( button, SIGNAL( clicked()), this, SLOT (fillSSH() ) ); + button = new QPushButton( i18n("ftp"), temphb ); + connect ( button, SIGNAL( clicked()), this, SLOT (fillFTP() ) ); + lab = new QLabel( i18n("Hint: Use $PWD$ for placeholder of password!"), remoteFileWidget); + + +} +/*US +void SyncPrefWidget::slotOK() +{ + if ( mMyMachineName->text() == "undefined" ) { + KMessageBox::error(this,i18n("Local device name undefined!\nPlease define device name!"),i18n("KO/Pi config error")); + return; + } + int i; + for (i = 0; i < mSyncProfileNames.count(); ++ i) { + if ( mSyncProfileNames.contains( mSyncProfileNames[i]) > 1 ) { + KMessageBox::error(this,i18n("Multiple profiles with same name!\nPlease use unique profile names!"),i18n("KO/Pi config error")); + return; + } + } + usrWriteConfig(); + QDialog::accept(); +} +void SyncPrefWidget::accept() +{ + slotOK(); +} +void KOSyncPrefsDialog::chooseFile() +{ + QString fn =KOPrefs::instance()->mLastSyncedLocalFile; + + fn =KFileDialog:: getOpenFileName( fn, i18n("Sync filename(*.ics/*.vcs)"), this ); + if ( fn == "" ) + return; + mRemoteFile->setText( fn ); +} + +void KOSyncPrefsDialog::textChanged( const QString & s ) +{ + if ( mProfileBox->count() == 0 ) + return; + if ( currentSelection < 3 ) { + //KMessageBox::error(this,i18n("This profil name\ncannot be edited!\n"),i18n("KO/Pi config error")); + mProfileBox->blockSignals( true ); + mProfileBox->setCurrentItem(mProfileBox-> currentItem ()); + mProfileBox->blockSignals( false ); + return; + } + //qDebug("cur i %d ",mProfileBox-> currentItem () ); + mProfileBox->changeItem ( s, mProfileBox-> currentItem () ) ; + KSyncProfile* prof = mSyncProfiles.at(mProfileBox-> currentItem ()) ; + prof->setName( s ); + mSyncProfileNames[mProfileBox-> currentItem ()] = s; +} +void KOSyncPrefsDialog::profileChanged( int item ) +{ + //qDebug("KOSyncPrefsDialog::profileChanged %d ", item ); + KSyncProfile* prof; + saveProfile(); + currentSelection = item; + prof = mSyncProfiles.at(item) ; + mRemotePrecommand->setText(prof->getPreSyncCommand()); + mRemotePostcommand->setText(prof->getPostSyncCommand()); + mLocalTempFile->setText(prof->getLocalTempFile()); + mRemoteFile->setText(prof->getRemoteFileName()) ; + mShowSummaryAfterSync->setChecked( prof->getShowSummaryAfterSync()); + mAskForPreferences->setChecked( prof->getAskForPreferences()); + mWriteBackExisting->setChecked( prof->getWriteBackExisting() ); + mWriteBackFile->setChecked( prof->getWriteBackFile()); + mIncludeInRing->setChecked( prof->getIncludeInRingSync() ); + + switch ( prof->getSyncPrefs() ) { + case 0: + loc->setChecked( true); + break; + case 1: + rem->setChecked( true ); + break; + case 2: + newest->setChecked( true); + break; + case 3: + ask->setChecked( true); + break; + case 4: + f_loc->setChecked( true); + break; + case 5: + f_rem->setChecked( true); + break; + case 6: + //both->setChecked( true); + break; + default: + break; + } + mIsLocal->setChecked(prof->getIsLocalFileSync()) ; + mIsNotLocal->setChecked(!prof->getIsLocalFileSync()); + proGr->setEnabled( item > 2 ); + if ( item < 3 ) { + localFileWidget->setEnabled(false); + remoteFileWidget->setEnabled(false); + + } else + kindChanged( prof->getIsLocalFileSync() ); +} + +void KOSyncPrefsDialog::fillSSH() +{ + mRemotePrecommand->setText("scp zaurus@192.168.0.65:/home/zaurus/kdepim/apps/korganizer/mycalendar.ics /tmp/mycalendar.ics" ); + mLocalTempFile->setText("/tmp/mycalendar.ics" ); + mRemotePostcommand->setText("scp /tmp/mycalendar.ics zaurus@192.168.0.65:/home/zaurus/kdepim/apps/korganizer/mycalendar.ics" ); +} +void KOSyncPrefsDialog::fillFTP() +{ + mRemotePrecommand->setText("cd /tmp;ftp ftp://zaurus:a@192.168.0.65/kdepim/apps/korganizer/mycalendar.ics" ); + mLocalTempFile->setText("/tmp/mycalendar.ics" ); + mRemotePostcommand->setText("ftp -u ftp://zaurus:a@192.168.0.65/kdepim/apps/korganizer/mycalendar.ics /tmp/mycalendar.ics" ); + +} +void KOSyncPrefsDialog::kindChanged( bool b ) +{ + + localFileWidget->setEnabled(b); + remoteFileWidget->setEnabled(!b); + +} +void KOSyncPrefsDialog::deleteProfile() +{ + //qDebug("KOSyncPrefsDialog::deleteProfile() "); + if ( currentSelection >= 0 ) { + if ( currentSelection < 3 ) { + KMessageBox::error(this,i18n("This profil cannot be deleted!\n"),i18n("KO/Pi config error")); + return; + } + KSyncProfile* temp = mSyncProfiles.at(currentSelection); + mSyncProfiles.remove( temp ); + mSyncProfileNames.remove( mSyncProfileNames.at( currentSelection )); + insertProfiles(); + } +} + +void KOSyncPrefsDialog::saveProfile() +{ + KSyncProfile* prof; + if ( currentSelection >= 0 ) { + prof = mSyncProfiles.at(currentSelection) ; + prof->setPreSyncCommand( mRemotePrecommand->text()); + prof->setPostSyncCommand( mRemotePostcommand->text() ); + prof->setLocalTempFile( mLocalTempFile->text()); + prof->setRemoteFileName( mRemoteFile->text() ); + prof->setShowSummaryAfterSync( mShowSummaryAfterSync->isChecked() ); + prof->setAskForPreferences( mAskForPreferences->isChecked()); + prof->setWriteBackExisting(mWriteBackExisting->isChecked() ); + prof->setWriteBackFile( mWriteBackFile->isChecked()); + prof->setIncludeInRingSync( mIncludeInRing->isChecked() ); + int syncprefs = rem->isChecked()*1+newest->isChecked()*2+ ask->isChecked()*3+ f_loc->isChecked()*4+ f_rem->isChecked()*5 ;//+ both->isChecked()*6 ; + prof->setSyncPrefs( syncprefs); + prof->setIsLocalFileSync( mIsLocal->isChecked() ); + } + +} + +void KOSyncPrefsDialog::insertProfiles() +{ + int curItem = mProfileBox->currentItem(); + mProfileBox->blockSignals( true ); + mProfileBox->clear(); + mProfileBox->insertStringList (mSyncProfileNames ); + int item = mSyncProfileNames.count() -1; + if ( curItem >= 0 && mSyncProfileNames.count() > 0 && curItem < mSyncProfileNames.count() ) + mProfileBox->setCurrentItem( curItem ); + else if ( item >= 0 ) { + mProfileBox->setCurrentItem( item ); + } + currentSelection = -1; + if ( mSyncProfileNames.count() > 0 ) { + //qDebug(" profileChanged( mProfileBox->currentItem() "); + profileChanged( mProfileBox->currentItem() ); + currentSelection = mProfileBox->currentItem(); + } + mProfileBox->blockSignals( false ); +} + +void KOSyncPrefsDialog::addProfile ( KSyncProfile* temp ) +{ + saveProfile(); + mSyncProfiles.append( temp ); + mSyncProfileNames << temp->getName(); + insertProfiles(); + int last = mProfileBox->count() -1; + mProfileBox->blockSignals( true ); + mProfileBox->setCurrentItem( last ); + mProfileBox->blockSignals( false ); + profileChanged(last); +} +void KOSyncPrefsDialog::newProfile() +{ + addProfile ( new KSyncProfile () ); +} + +void KOSyncPrefsDialog::cloneProfile() +{ + if ( currentSelection >= 0 ) + addProfile (mSyncProfiles.at(currentSelection)->clone()) ; + else + newProfile(); +} + + +void KOSyncPrefsDialog::usrReadConfig() +{ + KConfig *config = KOGlobals::config(); + config->setGroup("SyncProfiles"); + mSyncProfileNames = KOPrefs::instance()->mSyncProfileNames; + int i; + KSyncProfile* temp ; + mSyncProfiles.clear(); + for ( i = 0; i < mSyncProfileNames.count();++i ) { + temp = new KSyncProfile (); + temp->setName( mSyncProfileNames[i] ); + temp->readConfig( config ); + mSyncProfiles.append( temp ); + } + insertProfiles(); + mMyMachineName->setText(KOPrefs::instance()->mLocalMachineName ); +} + + +void KOSyncPrefsDialog::usrWriteConfig() +{ + saveProfile(); + if ( currentSelection >= 0 ) + profileChanged(currentSelection); + KConfig *config = KOGlobals::config(); + config->setGroup("SyncProfiles"); + KSyncProfile* prof = mSyncProfiles.first(); + while ( prof ) { + prof->writeConfig(config); + prof = mSyncProfiles.next(); + } + KOPrefs::instance()->mSyncProfileNames = mSyncProfileNames; + KOPrefs::instance()->mLocalMachineName = mMyMachineName->text(); + config->writeEntry("SyncProfileNames",&mSyncProfileNames); +} +*/ -- cgit v0.9.0.2