summaryrefslogtreecommitdiffstats
path: root/kpilot/kpilot/kpilotConfigWizard.cc
diff options
context:
space:
mode:
Diffstat (limited to 'kpilot/kpilot/kpilotConfigWizard.cc')
-rw-r--r--kpilot/kpilot/kpilotConfigWizard.cc233
1 files changed, 233 insertions, 0 deletions
diff --git a/kpilot/kpilot/kpilotConfigWizard.cc b/kpilot/kpilot/kpilotConfigWizard.cc
new file mode 100644
index 000000000..d21ec5d81
--- /dev/null
+++ b/kpilot/kpilot/kpilotConfigWizard.cc
@@ -0,0 +1,233 @@
+/* KPilot
+**
+** Copyright (C) 2004 by Reinhold Kainhofer
+**
+** A simple configuration wizard.
+*/
+
+/*
+** 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 in a file called COPYING; if not, write to
+** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+** MA 02110-1301, USA.
+*/
+
+/*
+** Bug reports and questions can be sent to kde-pim@kde.org
+*/
+
+//#include "options.h"
+
+#include <qpushbutton.h>
+#include <qbuttongroup.h>
+#include <qcheckbox.h>
+#include <qlineedit.h>
+
+#include <kmessagebox.h>
+#include <kglobal.h>
+#include <klocale.h>
+#include <kconfigskeleton.h>
+
+#include "kpilotConfig.h"
+#include "options.h"
+
+#include "kpilotConfigWizard_app.h"
+#include "kpilotConfigWizard_user.h"
+#include "kpilotConfigWizard_address.h"
+#include "kpilotConfigWizard_notes.h"
+#include "kpilotConfigWizard_vcal.h"
+
+
+#include "kpilotConfigWizard.moc"
+#include "kpilotProbeDialog.h"
+
+
+ConfigWizard::ConfigWizard(QWidget *parent, const char *n, int m) :
+ KWizard(parent, n),
+ fMode((Mode)m)
+{
+// page1=new ConfigWizard_base1(this);
+// addPage( page1, i18n("Select Connection Type") );
+ page2=new ConfigWizard_base2(this);
+ addPage( page2, i18n("Pilot Info") );
+ page3=new ConfigWizard_base3(this);
+ addPage( page3, i18n("Application to Sync With") );
+ setFinishEnabled( page3, true );
+
+ setHelpEnabled( page2, false );
+ setHelpEnabled( page3, false );
+
+ connect( page2->fProbeButton, SIGNAL( pressed() ),
+ this, SLOT( probeHandheld() ) );
+
+ KPilotSettings::self()->readConfig();
+ page2->fUserName->setText( KPilotSettings::userName() );
+ page2->fDeviceName->setText( KPilotSettings::pilotDevice() );
+ page2->fPilotRunningPermanently->setChecked( KPilotSettings::startDaemonAtLogin() );
+
+}
+
+ConfigWizard::~ConfigWizard()
+{
+}
+
+void ConfigWizard::accept()
+{
+ FUNCTIONSETUP;
+ QString username( page2->fUserName->text() );
+ QString devicename( page2->fDeviceName->text() );
+// int devicetype( page1->fConnectionType->selectedId() );
+ enum eSyncApp {
+ eAppKDE=0,
+ //eAppKontact,
+ eAppEvolution,
+ eAppNone
+ } app;
+ app=(eSyncApp)( page3->fAppType->selectedId() );
+ bool keepPermanently( page2->fPilotRunningPermanently->isChecked() );
+#ifdef DEBUG
+ DEBUGKPILOT<<fname<<"Keep permanently: "<<keepPermanently<<endl;
+#endif
+
+ KPilotSettings::setPilotDevice( devicename );
+ KPilotSettings::setUserName(username);
+// KPilotSettings::setEncoding("iso 8859-15");
+ KPilotSettings::setDockDaemon( true );
+ KPilotSettings::setKillDaemonAtExit( !keepPermanently);
+ KPilotSettings::setQuitAfterSync( !keepPermanently );
+ KPilotSettings::setStartDaemonAtLogin( keepPermanently );
+ KPilotSettings::setSyncType(0);
+ KPilotSettings::setFullSyncOnPCChange( true );
+ KPilotSettings::setConflictResolution(0);
+ if ( !mDBs.isEmpty() )
+ KPilotSettings::setDeviceDBs( mDBs );
+
+ KPilotWizard_vcalConfig*calendarConfig = new KPilotWizard_vcalConfig("Calendar");
+ KPilotWizard_vcalConfig*todoConfig = new KPilotWizard_vcalConfig("ToDo");
+ KPilotWizard_addressConfig*addressConfig = new KPilotWizard_addressConfig();
+ KPilotWizard_notesConfig*notesConfig = new KPilotWizard_notesConfig();
+ addressConfig->readConfig();
+ notesConfig->readConfig();
+ todoConfig->readConfig();
+ calendarConfig->readConfig();
+
+ QStringList conduits = KPilotSettings::installedConduits();
+ int version(0);
+#define APPEND_CONDUIT(a) if (!conduits.contains(a)) conduits.append(a)
+ QString applicationName(i18n("general KDE-PIM"));
+ APPEND_CONDUIT("internal_fileinstall");
+ APPEND_CONDUIT("todo-conduit");
+ APPEND_CONDUIT("vcal-conduit");
+ switch (app) {
+ case eAppEvolution:
+ applicationName=i18n("Gnome's PIM suite", "Evolution");
+
+ // TODO: Once the Evolution abook resource is finished, enable it...
+ conduits.remove("abbrowser_conduit");
+ // addressConfig->setDefaults();
+ // addressConfig->setAddressbookType( KPilotWizard_addressConfig::eAbookResource );
+ //// addressConfig->revertToDefault("ArchiveDeleted");
+ //// addressConfig->revertToDefault("ConflictResolution");
+
+ // nothing to do for knotes conduit yet (evolution doesn't have notes)
+ conduits.remove("knotes-conduit");
+
+ // the vcalconduits use the same config file, so set the correct groups
+ version = calendarConfig->conduitVersion();
+ calendarConfig->setDefaults();
+ calendarConfig->setCalendarType( KPilotWizard_vcalConfig::eCalendarLocal );
+ calendarConfig->setCalendarFile( "$HOME/evolution/local/Calendar/calendar.ics" );
+ calendarConfig->setConduitVersion( version );
+ version = todoConfig->conduitVersion();
+ todoConfig->setDefaults();
+ todoConfig->setCalendarType( KPilotWizard_vcalConfig::eCalendarLocal );
+ todoConfig->setCalendarFile( "$HOME/evolution/local/Tasks/tasks.ics" );
+ todoConfig->setConduitVersion( version );
+
+ KMessageBox::information(this, i18n("KPilot cannot yet synchronize the addressbook with Evolution, so the addressbook conduit was disabled.\nWhen syncing the calendar or to-do list using KPilot please quit Evolution before the sync, otherwise you will lose data."), i18n("Restrictions with Evolution"));
+ break;
+ case eAppNone:
+ conduits.clear();
+ APPEND_CONDUIT("internal_fileinstall");
+ applicationName=i18n("Kpilot will sync with nothing","nothing (it will backup only)");
+ break;
+// case eAppKontact:
+ case eAppKDE:
+ applicationName=i18n("KDE's PIM suite", "Kontact");
+ default:
+ APPEND_CONDUIT("knotes-conduit");
+ APPEND_CONDUIT("abbrowser_conduit");
+ // Set to the stdaddressbook, reset others to defaults
+ addressConfig->setAddressbookType( KPilotWizard_addressConfig::eAbookResource );
+ addressConfig->setArchiveDeleted( true );
+ addressConfig->setConflictResolution( -1 );
+ // nothing to do for knotes conduit yet
+ // notesConfig->set...
+ // the vcalconduits use the same config file, so set the correct groups
+ int version = calendarConfig->conduitVersion();
+ calendarConfig->setDefaults();
+ calendarConfig->setCalendarType( KPilotWizard_vcalConfig::eCalendarResource );
+ calendarConfig->setConduitVersion( version );
+ version = todoConfig->conduitVersion();
+ todoConfig->setDefaults();
+ todoConfig->setCalendarType( KPilotWizard_vcalConfig::eCalendarResource );
+ todoConfig->setConduitVersion( version );
+ break;
+ }
+ addressConfig->writeConfig();
+ notesConfig->writeConfig();
+ todoConfig->writeConfig();
+ calendarConfig->writeConfig();
+
+ KPILOT_DELETE(addressConfig);
+ KPILOT_DELETE(notesConfig);
+ KPILOT_DELETE(todoConfig);
+ KPILOT_DELETE(calendarConfig);
+
+ KPilotSettings::setInstalledConduits( conduits );
+#undef APPEND_CONDUIT
+
+ QString finishMessage = i18n("KPilot is now configured to sync with %1.").arg(applicationName);
+ if (fMode == InDialog)
+ {
+ finishMessage.append(CSL1("\n"));
+ finishMessage.append(i18n(
+ "The remaining options in the config dialog are advanced options and can "
+ "be used to fine-tune KPilot."));
+ }
+
+ KMessageBox::information(this, finishMessage,
+ i18n("Automatic Configuration Finished"));
+ KPilotSettings::self()->writeConfig();
+ QDialog::accept();
+}
+
+void ConfigWizard::probeHandheld()
+{
+ if ( KMessageBox::warningContinueCancel( this, i18n("Please put the handheld "
+ "in the cradle, press the hotsync button and click on \"Continue\".\n\nSome "
+ "kernel versions (Linux 2.6.x) have problems with the visor kernel module "
+ "(for Sony Clie devices). Running an autodetection in that case might block "
+ "the computer from doing hotsyncs until it is rebooted. In that case it might "
+ "be advisable not to continue."),
+ i18n("Handheld Detection") ) == KMessageBox::Continue ) {
+ ProbeDialog *probeDialog = new ProbeDialog( this );
+ if ( probeDialog->exec() && probeDialog->detected() ) {
+ page2->fUserName->setText( probeDialog->userName() );
+ page2->fDeviceName->setText( probeDialog->device() );
+ mDBs = probeDialog->dbs();
+ }
+ KPILOT_DELETE(probeDialog);
+ }
+}
+