-rw-r--r-- | libkdepim/kpimprefs.h | 21 | ||||
-rw-r--r-- | libkdepim/ksyncmanager.cpp | 274 | ||||
-rw-r--r-- | libkdepim/ksyncmanager.h | 75 | ||||
-rw-r--r-- | libkdepim/libkdepimE.pro | 2 |
4 files changed, 260 insertions, 112 deletions
diff --git a/libkdepim/kpimprefs.h b/libkdepim/kpimprefs.h index 860665b..01c57a3 100644 --- a/libkdepim/kpimprefs.h +++ b/libkdepim/kpimprefs.h | |||
@@ -56,9 +56,30 @@ class KPimPrefs : public KPrefs | |||
56 | public: | 56 | public: |
57 | QStringList mCustomCategories; | 57 | QStringList mCustomCategories; |
58 | 58 | ||
59 | // sync stuff | ||
60 | QString mLocalMachineName; | ||
61 | QStringList mExternSyncProfiles; | ||
62 | QStringList mSyncProfileNames; | ||
63 | bool mAskForPreferences; | ||
64 | bool mShowSyncSummary; | ||
65 | bool mShowSyncEvents; | ||
66 | bool mShowTodoInAgenda; | ||
67 | bool mWriteBackExistingOnly; | ||
68 | int mSyncAlgoPrefs; | ||
69 | int mRingSyncAlgoPrefs; | ||
70 | bool mWriteBackFile; | ||
71 | int mWriteBackInFuture; | ||
72 | QString mPhoneDevice; | ||
73 | QString mPhoneConnection; | ||
74 | QString mPhoneModel; | ||
75 | QString mLastSyncedLocalFile; // save! | ||
76 | |||
59 | 77 | ||
60 | protected: | 78 | protected: |
61 | virtual void setCategoryDefaults(); | 79 | virtual void setCategoryDefaults(); |
80 | |||
81 | |||
82 | |||
62 | }; | 83 | }; |
63 | 84 | ||
64 | #endif | 85 | #endif |
diff --git a/libkdepim/ksyncmanager.cpp b/libkdepim/ksyncmanager.cpp index 52e3bd9..87f200a 100644 --- a/libkdepim/ksyncmanager.cpp +++ b/libkdepim/ksyncmanager.cpp | |||
@@ -22,9 +22,36 @@ | |||
22 | 22 | ||
23 | #include "ksyncmanager.h" | 23 | #include "ksyncmanager.h" |
24 | 24 | ||
25 | #include <stdlib.h> | ||
25 | 26 | ||
26 | KSyncManager::KSyncManager(TargetApp ta, QPopupMenu* syncmenu) | 27 | #ifndef _WIN32_ |
27 | : mSyncMenu(syncmenu), mTargetApp(ta) | 28 | #include <unistd.h> |
29 | #endif | ||
30 | |||
31 | |||
32 | #include "ksyncprofile.h" | ||
33 | #include "ksyncprefsdialog.h" | ||
34 | #include "kpimprefs.h" | ||
35 | |||
36 | #include <qdir.h> | ||
37 | #include <qpopupmenu.h> | ||
38 | #include <qpushbutton.h> | ||
39 | #include <qradiobutton.h> | ||
40 | #include <qbuttongroup.h> | ||
41 | #include <qtimer.h> | ||
42 | #include <qmessagebox.h> | ||
43 | #include <qapplication.h> | ||
44 | #include <qlineedit.h> | ||
45 | #include <qdialog.h> | ||
46 | #include <qlayout.h> | ||
47 | |||
48 | #include <klocale.h> | ||
49 | #include <kglobal.h> | ||
50 | #include <kconfig.h> | ||
51 | #include <kfiledialog.h> | ||
52 | |||
53 | KSyncManager::KSyncManager(QWidget* parent, KSyncInterface* implementation, TargetApp ta, KPimPrefs* prefs, QPopupMenu* syncmenu) | ||
54 | : QObject(), mParent(parent), mImplementation(implementation), mTargetApp(ta), mPrefs(prefs), mSyncMenu(syncmenu) | ||
28 | { | 55 | { |
29 | 56 | ||
30 | } | 57 | } |
@@ -35,10 +62,10 @@ KSyncManager::~KSyncManager() | |||
35 | } | 62 | } |
36 | 63 | ||
37 | 64 | ||
38 | void KABCore::fillSyncMenu() | 65 | void KSyncManager::fillSyncMenu() |
39 | { | 66 | { |
40 | if ( mSyncMenu->count() ) | 67 | if ( mSyncMenu->count() ) |
41 | msyncMenu->clear(); | 68 | mSyncMenu->clear(); |
42 | 69 | ||
43 | mSyncMenu->insertItem( i18n("Configure..."), 0 ); | 70 | mSyncMenu->insertItem( i18n("Configure..."), 0 ); |
44 | mSyncMenu->insertSeparator(); | 71 | mSyncMenu->insertSeparator(); |
@@ -48,7 +75,7 @@ void KABCore::fillSyncMenu() | |||
48 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 75 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
49 | config.setGroup("General"); | 76 | config.setGroup("General"); |
50 | QStringList prof = config.readListEntry("SyncProfileNames"); | 77 | QStringList prof = config.readListEntry("SyncProfileNames"); |
51 | //US KABPrefs::instance()->mLocalMachineName = config.readEntry("LocalMachineName","undefined"); | 78 | mPrefs->mLocalMachineName = config.readEntry("LocalMachineName","undefined"); |
52 | if ( prof.count() < 3 ) { | 79 | if ( prof.count() < 3 ) { |
53 | prof.clear(); | 80 | prof.clear(); |
54 | prof << i18n("Sharp_DTM"); | 81 | prof << i18n("Sharp_DTM"); |
@@ -67,11 +94,9 @@ void KABCore::fillSyncMenu() | |||
67 | config.sync(); | 94 | config.sync(); |
68 | delete temp; | 95 | delete temp; |
69 | } | 96 | } |
70 | /*US | 97 | mPrefs->mExternSyncProfiles = config.readListEntry("ExternSyncProfiles"); |
71 | KABPrefs::instance()->mExternSyncProfiles = config.readListEntry("ExternSyncProfiles"); | 98 | mPrefs->mSyncProfileNames = prof; |
72 | KABPrefs::instance()->mSyncProfileNames = prof; | 99 | unsigned int i; |
73 | */ | ||
74 | int i; | ||
75 | for ( i = 0; i < prof.count(); ++i ) { | 100 | for ( i = 0; i < prof.count(); ++i ) { |
76 | 101 | ||
77 | mSyncMenu->insertItem( prof[i], 1000+i ); | 102 | mSyncMenu->insertItem( prof[i], 1000+i ); |
@@ -85,7 +110,8 @@ void KABCore::fillSyncMenu() | |||
85 | //probaly useless | 110 | //probaly useless |
86 | //mView->setupExternSyncProfiles(); | 111 | //mView->setupExternSyncProfiles(); |
87 | } | 112 | } |
88 | void KABCore::slotSyncMenu( int action ) | 113 | |
114 | void KSyncManager::slotSyncMenu( int action ) | ||
89 | { | 115 | { |
90 | //qDebug("syncaction %d ", action); | 116 | //qDebug("syncaction %d ", action); |
91 | if ( action == 0 ) { | 117 | if ( action == 0 ) { |
@@ -104,26 +130,26 @@ void KABCore::slotSyncMenu( int action ) | |||
104 | return; | 130 | return; |
105 | } | 131 | } |
106 | 132 | ||
107 | if (mBlockSaveFlag) | 133 | if (blockSave()) |
108 | return; | 134 | return; |
109 | mBlockSaveFlag = true; | 135 | |
136 | setBlockSave(true); | ||
137 | |||
110 | mCurrentSyncProfile = action - 1000 ; | 138 | mCurrentSyncProfile = action - 1000 ; |
111 | //US mCurrentSyncDevice = KABPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile] ; | 139 | mCurrentSyncDevice = mPrefs->mSyncProfileNames[mCurrentSyncProfile] ; |
112 | //US mCurrentSyncName = KABPrefs::instance()->mLocalMachineName ; | 140 | mCurrentSyncName = mPrefs->mLocalMachineName ; |
113 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 141 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
114 | KSyncProfile* temp = new KSyncProfile (); | 142 | KSyncProfile* temp = new KSyncProfile (); |
115 | //US temp->setName(KABPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile]); | 143 | temp->setName(mPrefs->mSyncProfileNames[mCurrentSyncProfile]); |
116 | temp->readConfig(&config); | 144 | temp->readConfig(&config); |
117 | /*US | 145 | mPrefs->mAskForPreferences = temp->getAskForPreferences(); |
118 | KABPrefs::instance()->mAskForPreferences = temp->getAskForPreferences(); | 146 | mPrefs->mSyncAlgoPrefs = temp->getSyncPrefs(); |
119 | KABPrefs::instance()->mSyncAlgoPrefs = temp->getSyncPrefs(); | 147 | mPrefs->mWriteBackFile = temp->getWriteBackFile(); |
120 | KABPrefs::instance()->mWriteBackFile = temp->getWriteBackFile(); | 148 | mPrefs->mWriteBackExistingOnly = temp->getWriteBackExisting(); |
121 | KABPrefs::instance()->mWriteBackExistingOnly = temp->getWriteBackExisting(); | 149 | mPrefs->mWriteBackInFuture = 0; |
122 | KABPrefs::instance()->mWriteBackInFuture = 0; | ||
123 | if ( temp->getWriteBackFuture() ) | 150 | if ( temp->getWriteBackFuture() ) |
124 | KABPrefs::instance()->mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); | 151 | mPrefs->mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); |
125 | KABPrefs::instance()->mShowSyncSummary = temp->getShowSummaryAfterSync(); | 152 | mPrefs->mShowSyncSummary = temp->getShowSummaryAfterSync(); |
126 | */ | ||
127 | if ( action == 1000 ) { | 153 | if ( action == 1000 ) { |
128 | syncSharp(); | 154 | syncSharp(); |
129 | 155 | ||
@@ -135,16 +161,14 @@ void KABCore::slotSyncMenu( int action ) | |||
135 | 161 | ||
136 | } else if ( action >= 1003 ) { | 162 | } else if ( action >= 1003 ) { |
137 | if ( temp->getIsLocalFileSync() ) { | 163 | if ( temp->getIsLocalFileSync() ) { |
138 | /*US if ( syncWithFile( temp->getRemoteFileNameAB( ), false ) ) | 164 | if ( syncWithFile( temp->getRemoteFileNameAB( ), false ) ) |
139 | KABPrefs::instance()->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); | 165 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); |
140 | */ | 166 | |
141 | } else { | 167 | } else { |
142 | if ( temp->getIsPhoneSync() ) { | 168 | if ( temp->getIsPhoneSync() ) { |
143 | /* | 169 | mPrefs->mPhoneDevice = temp->getPhoneDevice( ) ; |
144 | KABPrefs::instance()->mPhoneDevice = temp->getPhoneDevice( ) ; | 170 | mPrefs->mPhoneConnection = temp->getPhoneConnection( ); |
145 | KABPrefs::instance()->mPhoneConnection = temp->getPhoneConnection( ); | 171 | mPrefs->mPhoneModel = temp->getPhoneModel( ); |
146 | KABPrefs::instance()->mPhoneModel = temp->getPhoneModel( ); | ||
147 | */ | ||
148 | syncPhone(); | 172 | syncPhone(); |
149 | } else | 173 | } else |
150 | syncRemote( temp ); | 174 | syncRemote( temp ); |
@@ -152,15 +176,15 @@ void KABCore::slotSyncMenu( int action ) | |||
152 | } | 176 | } |
153 | } | 177 | } |
154 | delete temp; | 178 | delete temp; |
155 | mBlockSaveFlag = false; | 179 | setBlockSave(false); |
156 | } | 180 | } |
157 | 181 | ||
158 | void KABCore::syncLocalFile() | 182 | void KSyncManager::syncLocalFile() |
159 | { | 183 | { |
160 | 184 | ||
161 | QString fn =KABPrefs::instance()->mLastSyncedLocalFile; | 185 | QString fn =mPrefs->mLastSyncedLocalFile; |
162 | 186 | ||
163 | fn =KFileDialog:: getOpenFileName( fn, i18n("Sync filename(*.ics/*.vcs)"), this ); | 187 | fn =KFileDialog:: getOpenFileName( fn, i18n("Sync filename(*.ics/*.vcs)"), mParent ); |
164 | if ( fn == "" ) | 188 | if ( fn == "" ) |
165 | return; | 189 | return; |
166 | if ( syncWithFile( fn, false ) ) { | 190 | if ( syncWithFile( fn, false ) ) { |
@@ -168,7 +192,7 @@ void KABCore::syncLocalFile() | |||
168 | } | 192 | } |
169 | 193 | ||
170 | } | 194 | } |
171 | bool KABCore::syncWithFile( QString fn , bool quick ) | 195 | bool KSyncManager::syncWithFile( QString fn , bool quick ) |
172 | { | 196 | { |
173 | bool ret = false; | 197 | bool ret = false; |
174 | QFileInfo info; | 198 | QFileInfo info; |
@@ -177,112 +201,112 @@ bool KABCore::syncWithFile( QString fn , bool quick ) | |||
177 | bool loadbup = true; | 201 | bool loadbup = true; |
178 | if ( !info. exists() ) { | 202 | if ( !info. exists() ) { |
179 | mess = i18n( "Sync file \n...%1\ndoes not exist!\nNothing synced!\n").arg(fn.right( 30) ); | 203 | mess = i18n( "Sync file \n...%1\ndoes not exist!\nNothing synced!\n").arg(fn.right( 30) ); |
180 | int result = QMessageBox::warning( this, i18n("Warning!"), | 204 | int result = QMessageBox::warning( mParent, i18n("Warning!"), |
181 | mess ); | 205 | mess ); |
182 | return ret; | 206 | return ret; |
183 | } | 207 | } |
184 | int result = 0; | 208 | int result = 0; |
185 | if ( !quick ) { | 209 | if ( !quick ) { |
186 | mess = i18n("Sync with file \n...%1\nfrom:\n%2\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); | 210 | mess = i18n("Sync with file \n...%1\nfrom:\n%2\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); |
187 | result = QMessageBox::warning( this, i18n("Warning!"), | 211 | result = QMessageBox::warning( mParent, i18n("Warning!"), |
188 | mess, | 212 | mess, |
189 | i18n("Sync"), i18n("Cancel"), 0, | 213 | i18n("Sync"), i18n("Cancel"), 0, |
190 | 0, 1 ); | 214 | 0, 1 ); |
191 | if ( result ) | 215 | if ( result ) |
192 | return false; | 216 | return false; |
193 | } | 217 | } |
194 | if ( KABPrefs::instance()->mAskForPreferences ) | 218 | if ( mPrefs->mAskForPreferences ) |
195 | edit_sync_options(); | 219 | edit_sync_options(); |
196 | if ( result == 0 ) { | 220 | if ( result == 0 ) { |
197 | //qDebug("Now sycing ... "); | 221 | //qDebug("Now sycing ... "); |
198 | if ( ret = syncAB( fn, KABPrefs::instance()->mSyncAlgoPrefs ) ) | 222 | if ( ret = mImplementation->sync( this, fn, mPrefs->mSyncAlgoPrefs ) ) |
199 | setCaption( i18n("Synchronization successful") ); | 223 | mParent->setCaption( i18n("Synchronization successful") ); |
200 | else | 224 | else |
201 | setCaption( i18n("Sync cancelled or failed. Nothing synced.") ); | 225 | mParent->setCaption( i18n("Sync cancelled or failed. Nothing synced.") ); |
202 | if ( ! quick ) | 226 | if ( ! quick ) |
203 | KABPrefs::instance()->mLastSyncedLocalFile = fn; | 227 | mPrefs->mLastSyncedLocalFile = fn; |
204 | setModified(); | 228 | mImplementation->sync_setModified(); |
205 | } | 229 | } |
206 | return ret; | 230 | return ret; |
207 | } | 231 | } |
208 | void KABCore::quickSyncLocalFile() | 232 | void KSyncManager::quickSyncLocalFile() |
209 | { | 233 | { |
210 | 234 | ||
211 | if ( syncWithFile( KABPrefs::instance()->mLastSyncedLocalFile, false ) ) { | 235 | if ( syncWithFile( mPrefs->mLastSyncedLocalFile, false ) ) { |
212 | qDebug("quick syncLocalFile() successful "); | 236 | qDebug("quick syncLocalFile() successful "); |
213 | 237 | ||
214 | } | 238 | } |
215 | } | 239 | } |
216 | void KABCore::multiSync( bool askforPrefs ) | 240 | void KSyncManager::multiSync( bool askforPrefs ) |
217 | { | 241 | { |
218 | if (mBlockSaveFlag) | 242 | if (blockSave()) |
219 | return; | 243 | return; |
220 | mBlockSaveFlag = true; | 244 | setBlockSave(true); |
221 | QString question = i18n("Do you really want\nto multiple sync\nwith all checked profiles?\nSyncing takes some\ntime - all profiles\nare synced twice!"); | 245 | QString question = i18n("Do you really want\nto multiple sync\nwith all checked profiles?\nSyncing takes some\ntime - all profiles\nare synced twice!"); |
222 | if ( QMessageBox::information( this, i18n("KO/Pi Sync"), | 246 | if ( QMessageBox::information( mParent, i18n("Sync"), |
223 | question, | 247 | question, |
224 | i18n("Yes"), i18n("No"), | 248 | i18n("Yes"), i18n("No"), |
225 | 0, 0 ) != 0 ) { | 249 | 0, 0 ) != 0 ) { |
226 | mBlockSaveFlag = false; | 250 | setBlockSave(false); |
227 | setCaption(i18n("Aborted! Nothing synced!")); | 251 | mParent->setCaption(i18n("Aborted! Nothing synced!")); |
228 | return; | 252 | return; |
229 | } | 253 | } |
230 | mCurrentSyncDevice = i18n("Multiple profiles") ; | 254 | mCurrentSyncDevice = i18n("Multiple profiles") ; |
231 | KABPrefs::instance()->mSyncAlgoPrefs = KABPrefs::instance()->mRingSyncAlgoPrefs; | 255 | mPrefs->mSyncAlgoPrefs = mPrefs->mRingSyncAlgoPrefs; |
232 | if ( askforPrefs ) { | 256 | if ( askforPrefs ) { |
233 | edit_sync_options(); | 257 | edit_sync_options(); |
234 | KABPrefs::instance()->mRingSyncAlgoPrefs = KABPrefs::instance()->mSyncAlgoPrefs; | 258 | mPrefs->mRingSyncAlgoPrefs = mPrefs->mSyncAlgoPrefs; |
235 | } | 259 | } |
236 | setCaption(i18n("Multiple sync started.") ); | 260 | mParent->setCaption(i18n("Multiple sync started.") ); |
237 | qApp->processEvents(); | 261 | qApp->processEvents(); |
238 | int num = ringSync() ; | 262 | int num = ringSync() ; |
239 | if ( num > 1 ) | 263 | if ( num > 1 ) |
240 | ringSync(); | 264 | ringSync(); |
241 | mBlockSaveFlag = false; | 265 | setBlockSave(false); |
242 | if ( num ) | 266 | if ( num ) |
243 | save(); | 267 | mImplementation->sync_save(); |
244 | if ( num ) | 268 | if ( num ) |
245 | setCaption(i18n("%1 profiles synced. Multiple sync completed!").arg(num) ); | 269 | mParent->setCaption(i18n("%1 profiles synced. Multiple sync completed!").arg(num) ); |
246 | else | 270 | else |
247 | setCaption(i18n("Nothing synced! No profiles defined for multisync!")); | 271 | mParent->setCaption(i18n("Nothing synced! No profiles defined for multisync!")); |
248 | return; | 272 | return; |
249 | } | 273 | } |
250 | int KABCore::ringSync() | 274 | int KSyncManager::ringSync() |
251 | { | 275 | { |
252 | int syncedProfiles = 0; | 276 | int syncedProfiles = 0; |
253 | int i; | 277 | unsigned int i; |
254 | QTime timer; | 278 | QTime timer; |
255 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); | 279 | KConfig config ( locateLocal( "config","ksyncprofilesrc" ) ); |
256 | QStringList syncProfileNames = KABPrefs::instance()->mSyncProfileNames; | 280 | QStringList syncProfileNames = mPrefs->mSyncProfileNames; |
257 | KSyncProfile* temp = new KSyncProfile (); | 281 | KSyncProfile* temp = new KSyncProfile (); |
258 | KABPrefs::instance()->mAskForPreferences = false; | 282 | mPrefs->mAskForPreferences = false; |
259 | for ( i = 0; i < syncProfileNames.count(); ++i ) { | 283 | for ( i = 0; i < syncProfileNames.count(); ++i ) { |
260 | mCurrentSyncProfile = i; | 284 | mCurrentSyncProfile = i; |
261 | temp->setName(syncProfileNames[mCurrentSyncProfile]); | 285 | temp->setName(syncProfileNames[mCurrentSyncProfile]); |
262 | temp->readConfig(&config); | 286 | temp->readConfig(&config); |
263 | if ( temp->getIncludeInRingSyncAB() && ( i < 1 || i > 2 )) { | 287 | if ( temp->getIncludeInRingSyncAB() && ( i < 1 || i > 2 )) { |
264 | setCaption(i18n("Profile ")+syncProfileNames[mCurrentSyncProfile]+ i18n(" is synced ... ")); | 288 | mParent->setCaption(i18n("Profile ")+syncProfileNames[mCurrentSyncProfile]+ i18n(" is synced ... ")); |
265 | ++syncedProfiles; | 289 | ++syncedProfiles; |
266 | // KABPrefs::instance()->mAskForPreferences = temp->getAskForPreferences(); | 290 | // mPrefs->mAskForPreferences = temp->getAskForPreferences(); |
267 | KABPrefs::instance()->mWriteBackFile = temp->getWriteBackFile(); | 291 | mPrefs->mWriteBackFile = temp->getWriteBackFile(); |
268 | KABPrefs::instance()->mWriteBackExistingOnly = temp->getWriteBackExisting(); | 292 | mPrefs->mWriteBackExistingOnly = temp->getWriteBackExisting(); |
269 | KABPrefs::instance()->mWriteBackInFuture = 0; | 293 | mPrefs->mWriteBackInFuture = 0; |
270 | if ( temp->getWriteBackFuture() ) | 294 | if ( temp->getWriteBackFuture() ) |
271 | KABPrefs::instance()->mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); | 295 | mPrefs->mWriteBackInFuture = temp->getWriteBackFutureWeeks( ); |
272 | KABPrefs::instance()->mShowSyncSummary = false; | 296 | mPrefs->mShowSyncSummary = false; |
273 | mCurrentSyncDevice = syncProfileNames[i] ; | 297 | mCurrentSyncDevice = syncProfileNames[i] ; |
274 | mCurrentSyncName = KABPrefs::instance()->mLocalMachineName; | 298 | mCurrentSyncName = mPrefs->mLocalMachineName; |
275 | if ( i == 0 ) { | 299 | if ( i == 0 ) { |
276 | syncSharp(); | 300 | syncSharp(); |
277 | } else { | 301 | } else { |
278 | if ( temp->getIsLocalFileSync() ) { | 302 | if ( temp->getIsLocalFileSync() ) { |
279 | if ( syncWithFile( temp->getRemoteFileNameAB( ), true ) ) | 303 | if ( syncWithFile( temp->getRemoteFileNameAB( ), true ) ) |
280 | KABPrefs::instance()->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); | 304 | mPrefs->mLastSyncedLocalFile = temp->getRemoteFileNameAB(); |
281 | } else { | 305 | } else { |
282 | if ( temp->getIsPhoneSync() ) { | 306 | if ( temp->getIsPhoneSync() ) { |
283 | KABPrefs::instance()->mPhoneDevice = temp->getPhoneDevice( ) ; | 307 | mPrefs->mPhoneDevice = temp->getPhoneDevice( ) ; |
284 | KABPrefs::instance()->mPhoneConnection = temp->getPhoneConnection( ); | 308 | mPrefs->mPhoneConnection = temp->getPhoneConnection( ); |
285 | KABPrefs::instance()->mPhoneModel = temp->getPhoneModel( ); | 309 | mPrefs->mPhoneModel = temp->getPhoneModel( ); |
286 | syncPhone(); | 310 | syncPhone(); |
287 | } else | 311 | } else |
288 | syncRemote( temp, false ); | 312 | syncRemote( temp, false ); |
@@ -290,7 +314,7 @@ int KABCore::ringSync() | |||
290 | } | 314 | } |
291 | } | 315 | } |
292 | timer.start(); | 316 | timer.start(); |
293 | setCaption(i18n("Multiple sync in progress ... please wait!") ); | 317 | mParent->setCaption(i18n("Multiple sync in progress ... please wait!") ); |
294 | while ( timer.elapsed () < 2000 ) { | 318 | while ( timer.elapsed () < 2000 ) { |
295 | qApp->processEvents(); | 319 | qApp->processEvents(); |
296 | #ifndef _WIN32_ | 320 | #ifndef _WIN32_ |
@@ -305,12 +329,12 @@ int KABCore::ringSync() | |||
305 | return syncedProfiles; | 329 | return syncedProfiles; |
306 | } | 330 | } |
307 | 331 | ||
308 | void KABCore::syncRemote( KSyncProfile* prof, bool ask) | 332 | void KSyncManager::syncRemote( KSyncProfile* prof, bool ask) |
309 | { | 333 | { |
310 | QString question; | 334 | QString question; |
311 | if ( ask ) { | 335 | if ( ask ) { |
312 | question = i18n("Do you really want\nto remote sync\nwith profile \n")+ prof->getName()+" ?\n"; | 336 | question = i18n("Do you really want\nto remote sync\nwith profile \n")+ prof->getName()+" ?\n"; |
313 | if ( QMessageBox::information( this, i18n("KO/Pi Sync"), | 337 | if ( QMessageBox::information( mParent, i18n("Sync"), |
314 | question, | 338 | question, |
315 | i18n("Yes"), i18n("No"), | 339 | i18n("Yes"), i18n("No"), |
316 | 0, 0 ) != 0 ) | 340 | 0, 0 ) != 0 ) |
@@ -326,7 +350,7 @@ void KABCore::syncRemote( KSyncProfile* prof, bool ask) | |||
326 | int maxlen = 30; | 350 | int maxlen = 30; |
327 | if ( QApplication::desktop()->width() > 320 ) | 351 | if ( QApplication::desktop()->width() > 320 ) |
328 | maxlen += 25; | 352 | maxlen += 25; |
329 | setCaption ( i18n( "Copy remote file to local machine..." ) ); | 353 | mParent->setCaption ( i18n( "Copy remote file to local machine..." ) ); |
330 | int fileSize = 0; | 354 | int fileSize = 0; |
331 | int result = system ( command ); | 355 | int result = system ( command ); |
332 | // 0 : okay | 356 | // 0 : okay |
@@ -334,26 +358,26 @@ void KABCore::syncRemote( KSyncProfile* prof, bool ask) | |||
334 | // | 358 | // |
335 | qDebug("KO: Remote copy result(0 = okay): %d ",result ); | 359 | qDebug("KO: Remote copy result(0 = okay): %d ",result ); |
336 | if ( result != 0 ) { | 360 | if ( result != 0 ) { |
337 | int len = maxlen; | 361 | unsigned int len = maxlen; |
338 | while ( len < command.length() ) { | 362 | while ( len < command.length() ) { |
339 | command.insert( len , "\n" ); | 363 | command.insert( len , "\n" ); |
340 | len += maxlen +2; | 364 | len += maxlen +2; |
341 | } | 365 | } |
342 | question = i18n("Sorry, the copy command failed!\nCommand was:\n%1\n \nTry command on console to get more\ndetailed info about the reason.\n").arg (command) ; | 366 | question = i18n("Sorry, the copy command failed!\nCommand was:\n%1\n \nTry command on console to get more\ndetailed info about the reason.\n").arg (command) ; |
343 | QMessageBox::information( this, i18n("KO/Pi Sync - ERROR"), | 367 | QMessageBox::information( mParent, i18n("Sync - ERROR"), |
344 | question, | 368 | question, |
345 | i18n("Okay!")) ; | 369 | i18n("Okay!")) ; |
346 | setCaption ("KO/Pi"); | 370 | mParent->setCaption (""); |
347 | return; | 371 | return; |
348 | } | 372 | } |
349 | setCaption ( i18n( "Copying succeed." ) ); | 373 | mParent->setCaption ( i18n( "Copying succeed." ) ); |
350 | //qDebug(" file **%s** ",prof->getLocalTempFile().latin1() ); | 374 | //qDebug(" file **%s** ",prof->getLocalTempFile().latin1() ); |
351 | if ( syncWithFile( prof->getLocalTempFileAB(), true ) ) { | 375 | if ( syncWithFile( prof->getLocalTempFileAB(), true ) ) { |
352 | // Event* e = mView->getLastSyncEvent(); | 376 | // Event* e = mView->getLastSyncEvent(); |
353 | // e->setReadOnly( false ); | 377 | // e->setReadOnly( false ); |
354 | // e->setLocation( KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile]); | 378 | // e->setLocation( KOPrefs::instance()->mSyncProfileNames[mCurrentSyncProfile]); |
355 | // e->setReadOnly( true ); | 379 | // e->setReadOnly( true ); |
356 | if ( KABPrefs::instance()->mWriteBackFile ) { | 380 | if ( mPrefs->mWriteBackFile ) { |
357 | command = prof->getPostSyncCommandAB(); | 381 | command = prof->getPostSyncCommandAB(); |
358 | int fi; | 382 | int fi; |
359 | if ( (fi = command.find("$PWD$")) > 0 ) { | 383 | if ( (fi = command.find("$PWD$")) > 0 ) { |
@@ -361,27 +385,25 @@ void KABCore::syncRemote( KSyncProfile* prof, bool ask) | |||
361 | command = command.left( fi )+ pwd + command.mid( fi+5 ); | 385 | command = command.left( fi )+ pwd + command.mid( fi+5 ); |
362 | 386 | ||
363 | } | 387 | } |
364 | setCaption ( i18n( "Writing back file ..." ) ); | 388 | mParent->setCaption ( i18n( "Writing back file ..." ) ); |
365 | result = system ( command ); | 389 | result = system ( command ); |
366 | qDebug("KO: Writing back file result: %d ", result); | 390 | qDebug("Writing back file result: %d ", result); |
367 | if ( result != 0 ) { | 391 | if ( result != 0 ) { |
368 | setCaption ( i18n( "Writing back file result: " )+QString::number( result ) ); | 392 | mParent->setCaption ( i18n( "Writing back file result: " )+QString::number( result ) ); |
369 | return; | 393 | return; |
370 | } else { | 394 | } else { |
371 | setCaption ( i18n( "Syncronization sucessfully completed" ) ); | 395 | mParent->setCaption ( i18n( "Syncronization sucessfully completed" ) ); |
372 | } | 396 | } |
373 | } | 397 | } |
374 | } | 398 | } |
375 | return; | 399 | return; |
376 | } | 400 | } |
377 | #include <qpushbutton.h> | 401 | |
378 | #include <qradiobutton.h> | 402 | void KSyncManager::edit_sync_options() |
379 | #include <qbuttongroup.h> | ||
380 | void KABCore::edit_sync_options() | ||
381 | { | 403 | { |
382 | //mDialogManager->showSyncOptions(); | 404 | //mDialogManager->showSyncOptions(); |
383 | //KABPrefs::instance()->mSyncAlgoPrefs | 405 | //mPrefs->mSyncAlgoPrefs |
384 | QDialog dia( this, "dia", true ); | 406 | QDialog dia( mParent, "dia", true ); |
385 | dia.setCaption( i18n("Device: " ) +mCurrentSyncDevice ); | 407 | dia.setCaption( i18n("Device: " ) +mCurrentSyncDevice ); |
386 | QButtonGroup gr ( 1, Qt::Horizontal, i18n("Sync preferences"), &dia); | 408 | QButtonGroup gr ( 1, Qt::Horizontal, i18n("Sync preferences"), &dia); |
387 | QVBoxLayout lay ( &dia ); | 409 | QVBoxLayout lay ( &dia ); |
@@ -398,7 +420,7 @@ void KABCore::edit_sync_options() | |||
398 | QPushButton pb ( "OK", &dia); | 420 | QPushButton pb ( "OK", &dia); |
399 | lay.addWidget( &pb ); | 421 | lay.addWidget( &pb ); |
400 | connect(&pb, SIGNAL( clicked() ), &dia, SLOT ( accept() ) ); | 422 | connect(&pb, SIGNAL( clicked() ), &dia, SLOT ( accept() ) ); |
401 | switch ( KABPrefs::instance()->mSyncAlgoPrefs ) { | 423 | switch ( mPrefs->mSyncAlgoPrefs ) { |
402 | case 0: | 424 | case 0: |
403 | loc.setChecked( true); | 425 | loc.setChecked( true); |
404 | break; | 426 | break; |
@@ -424,15 +446,15 @@ void KABCore::edit_sync_options() | |||
424 | break; | 446 | break; |
425 | } | 447 | } |
426 | if ( dia.exec() ) { | 448 | if ( dia.exec() ) { |
427 | KABPrefs::instance()->mSyncAlgoPrefs = rem.isChecked()*1+newest.isChecked()*2+ ask.isChecked()*3+ f_loc.isChecked()*4+ f_rem.isChecked()*5;//+ both.isChecked()*6 ; | 449 | mPrefs->mSyncAlgoPrefs = rem.isChecked()*1+newest.isChecked()*2+ ask.isChecked()*3+ f_loc.isChecked()*4+ f_rem.isChecked()*5;//+ both.isChecked()*6 ; |
428 | } | 450 | } |
429 | 451 | ||
430 | 452 | ||
431 | } | 453 | } |
432 | QString KABCore::getPassword( ) | 454 | QString KSyncManager::getPassword( ) |
433 | { | 455 | { |
434 | QString retfile = ""; | 456 | QString retfile = ""; |
435 | QDialog dia ( this, "input-dialog", true ); | 457 | QDialog dia ( mParent, "input-dialog", true ); |
436 | QLineEdit lab ( &dia ); | 458 | QLineEdit lab ( &dia ); |
437 | lab.setEchoMode( QLineEdit::Password ); | 459 | lab.setEchoMode( QLineEdit::Password ); |
438 | QVBoxLayout lay( &dia ); | 460 | QVBoxLayout lay( &dia ); |
@@ -453,3 +475,55 @@ QString KABCore::getPassword( ) | |||
453 | return retfile; | 475 | return retfile; |
454 | 476 | ||
455 | } | 477 | } |
478 | |||
479 | |||
480 | void KSyncManager::confSync() | ||
481 | { | ||
482 | static KSyncPrefsDialog* sp = 0; | ||
483 | if ( ! sp ) { | ||
484 | sp = new KSyncPrefsDialog( mParent, "syncprefs", true ); | ||
485 | } | ||
486 | sp->usrReadConfig(); | ||
487 | #ifndef DESKTOP_VERSION | ||
488 | sp->showMaximized(); | ||
489 | #else | ||
490 | sp->show(); | ||
491 | #endif | ||
492 | sp->exec(); | ||
493 | mPrefs->mSyncProfileNames = sp->getSyncProfileNames(); | ||
494 | mPrefs->mLocalMachineName = sp->getLocalMachineName (); | ||
495 | fillSyncMenu(); | ||
496 | } | ||
497 | |||
498 | void KSyncManager::syncSharp() | ||
499 | { | ||
500 | if ( ! syncExternalApplication("sharp") ) | ||
501 | qDebug("ERROR sync sharp ");; | ||
502 | } | ||
503 | |||
504 | bool KSyncManager::syncExternalApplication(QString resource) | ||
505 | { | ||
506 | if ( mImplementation->sync_isModified() ) | ||
507 | mImplementation->sync_save(); | ||
508 | |||
509 | if ( mPrefs->mAskForPreferences ) | ||
510 | edit_sync_options(); | ||
511 | |||
512 | qDebug("sync %s", resource.latin1()); | ||
513 | |||
514 | bool syncOK = mImplementation->syncExternal(this, resource); | ||
515 | |||
516 | return syncOK; | ||
517 | |||
518 | } | ||
519 | |||
520 | void KSyncManager::syncPhone() | ||
521 | { | ||
522 | if ( mImplementation->sync_isModified() ) | ||
523 | mImplementation->sync_save(); | ||
524 | |||
525 | qDebug("pending syncPhone(); "); | ||
526 | //mView->syncPhone(); | ||
527 | mImplementation->sync_setModified(); | ||
528 | |||
529 | } | ||
diff --git a/libkdepim/ksyncmanager.h b/libkdepim/ksyncmanager.h index d7c2a02..389a005 100644 --- a/libkdepim/ksyncmanager.h +++ b/libkdepim/ksyncmanager.h | |||
@@ -22,47 +22,98 @@ $Id$ | |||
22 | #ifndef _KSYNCMANAGER_H | 22 | #ifndef _KSYNCMANAGER_H |
23 | #define _KSYNCMANAGER_H | 23 | #define _KSYNCMANAGER_H |
24 | 24 | ||
25 | #include <qobject.h> | ||
25 | #include <qstring.h> | 26 | #include <qstring.h> |
26 | 27 | ||
27 | class QPopupMenu; | 28 | class QPopupMenu; |
28 | class KSyncProfile; | 29 | class KSyncProfile; |
30 | class KPimPrefs; | ||
31 | class QWidget; | ||
32 | class KSyncManager; | ||
33 | class KSyncInterface; | ||
29 | 34 | ||
30 | 35 | class KSyncManager : public QObject | |
31 | |||
32 | class KSyncManager | ||
33 | { | 36 | { |
37 | Q_OBJECT | ||
34 | 38 | ||
35 | public: | 39 | public: |
36 | KSyncManager(TargetApp ta, QPopupMenu* syncmenu); | ||
37 | ~KSyncManager() ; | ||
38 | |||
39 | enum TargetApp { | 40 | enum TargetApp { |
40 | KOPI = 0, | 41 | KOPI = 0, |
41 | KAPI = 1, | 42 | KAPI = 1, |
42 | PWMPI = 2 }; | 43 | PWMPI = 2 }; |
43 | 44 | ||
44 | private: | 45 | |
46 | KSyncManager(QWidget* parent, KSyncInterface* implementation, TargetApp ta, KPimPrefs* prefs, QPopupMenu* syncmenu); | ||
47 | ~KSyncManager() ; | ||
48 | |||
49 | bool blockSave() { return mBlockSaveFlag; } | ||
50 | void setBlockSave(bool sa) { mBlockSaveFlag = sa; } | ||
51 | |||
45 | void fillSyncMenu(); | 52 | void fillSyncMenu(); |
46 | void syncLocalFile(); | 53 | |
47 | bool syncWithFile( QString fn , bool quick ); | 54 | QString getCurrentSyncDevice() { return mCurrentSyncDevice; } |
55 | QString getCurrentSyncName() { return mCurrentSyncName; } | ||
56 | |||
57 | public slots: | ||
58 | void slotSyncMenu( int ); | ||
59 | |||
60 | private: | ||
61 | // LR ******************************* | ||
62 | // sync stuff! | ||
63 | QString mCurrentSyncDevice; | ||
64 | QString mCurrentSyncName; | ||
48 | void quickSyncLocalFile(); | 65 | void quickSyncLocalFile(); |
66 | bool syncWithFile( QString fn , bool quick ); | ||
67 | void syncLocalFile(); | ||
68 | void syncPhone(); | ||
69 | void syncSharp(); | ||
70 | bool syncExternalApplication(QString); | ||
49 | void multiSync( bool askforPrefs ); | 71 | void multiSync( bool askforPrefs ); |
50 | int ringSync(); | 72 | int mCurrentSyncProfile ; |
51 | void syncRemote( KSyncProfile* prof, bool ask); | 73 | void syncRemote( KSyncProfile* prof, bool ask = true); |
52 | void edit_sync_options(); | 74 | void edit_sync_options(); |
75 | int ringSync(); | ||
53 | QString getPassword(); | 76 | QString getPassword(); |
54 | 77 | ||
78 | private slots: | ||
79 | void confSync(); | ||
80 | // ********************* | ||
81 | |||
55 | private: | 82 | private: |
56 | QPopupMenu* mSyncMenu; | 83 | bool mBlockSaveFlag; |
84 | |||
85 | |||
86 | QWidget* mParent; | ||
87 | KSyncInterface* mImplementation; | ||
57 | TargetApp mTargetApp; | 88 | TargetApp mTargetApp; |
89 | KPimPrefs* mPrefs; | ||
90 | QPopupMenu* mSyncMenu; | ||
91 | |||
58 | 92 | ||
59 | 93 | ||
60 | 94 | ||
61 | 95 | ||
62 | 96 | ||
63 | 97 | ||
98 | }; | ||
99 | |||
100 | |||
101 | class KSyncInterface | ||
102 | { | ||
103 | public: | ||
104 | virtual bool sync(KSyncManager* manager, QString filename, int mode) = 0; | ||
105 | virtual bool syncExternal(KSyncManager* manager, QString resource) = 0; | ||
106 | |||
64 | 107 | ||
108 | //called by the syncmanager to indicate that the work has to be marked as dirty. | ||
109 | virtual void sync_setModified() = 0; | ||
65 | 110 | ||
111 | //called by the syncmanager to ask if the dirty flag is set. | ||
112 | virtual bool sync_isModified() = 0; | ||
113 | |||
114 | //called by the syncmanager to indicate that the work has to be saved. | ||
115 | virtual void sync_save() = 0; | ||
66 | }; | 116 | }; |
67 | 117 | ||
118 | |||
68 | #endif | 119 | #endif |
diff --git a/libkdepim/libkdepimE.pro b/libkdepim/libkdepimE.pro index 2a30ee8..156e247 100644 --- a/libkdepim/libkdepimE.pro +++ b/libkdepim/libkdepimE.pro | |||
@@ -25,6 +25,7 @@ HEADERS = \ | |||
25 | kpimglobalprefs.h \ | 25 | kpimglobalprefs.h \ |
26 | kprefsdialog.h \ | 26 | kprefsdialog.h \ |
27 | kprefswidget.h \ | 27 | kprefswidget.h \ |
28 | ksyncmanager.h \ | ||
28 | ksyncprofile.h \ | 29 | ksyncprofile.h \ |
29 | ksyncprefsdialog.h \ | 30 | ksyncprefsdialog.h \ |
30 | kcmconfigs/kcmkdepimconfig.h \ | 31 | kcmconfigs/kcmkdepimconfig.h \ |
@@ -45,6 +46,7 @@ SOURCES = \ | |||
45 | kpimglobalprefs.cpp \ | 46 | kpimglobalprefs.cpp \ |
46 | kprefsdialog.cpp \ | 47 | kprefsdialog.cpp \ |
47 | kprefswidget.cpp \ | 48 | kprefswidget.cpp \ |
49 | ksyncmanager.cpp \ | ||
48 | ksyncprofile.cpp \ | 50 | ksyncprofile.cpp \ |
49 | ksyncprefsdialog.cpp \ | 51 | ksyncprefsdialog.cpp \ |
50 | kcmconfigs/kcmkdepimconfig.cpp \ | 52 | kcmconfigs/kcmkdepimconfig.cpp \ |