-rw-r--r-- | korganizer/calendarview.cpp | 34 |
1 files changed, 18 insertions, 16 deletions
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index a350c3b..7044e90 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -1060,877 +1060,879 @@ void CalendarView::removeAlarm(const QDateTime &, const QString & ) | |||
1060 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { | 1060 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { |
1061 | #ifndef DESKTOP_VERSION | 1061 | #ifndef DESKTOP_VERSION |
1062 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.utf8() ); | 1062 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.utf8() ); |
1063 | #endif | 1063 | #endif |
1064 | return; | 1064 | return; |
1065 | } | 1065 | } |
1066 | mAlarmTimer->stop(); | 1066 | mAlarmTimer->stop(); |
1067 | } | 1067 | } |
1068 | void CalendarView::selectWeekNum ( int num ) | 1068 | void CalendarView::selectWeekNum ( int num ) |
1069 | { | 1069 | { |
1070 | dateNavigator()->blockSignals( true ); | 1070 | dateNavigator()->blockSignals( true ); |
1071 | dateNavigator()->selectWeek( num ); | 1071 | dateNavigator()->selectWeek( num ); |
1072 | dateNavigator()->blockSignals( false ); | 1072 | dateNavigator()->blockSignals( false ); |
1073 | mViewManager->showWeekView(); | 1073 | mViewManager->showWeekView(); |
1074 | } | 1074 | } |
1075 | KOViewManager *CalendarView::viewManager() | 1075 | KOViewManager *CalendarView::viewManager() |
1076 | { | 1076 | { |
1077 | return mViewManager; | 1077 | return mViewManager; |
1078 | } | 1078 | } |
1079 | 1079 | ||
1080 | KODialogManager *CalendarView::dialogManager() | 1080 | KODialogManager *CalendarView::dialogManager() |
1081 | { | 1081 | { |
1082 | return mDialogManager; | 1082 | return mDialogManager; |
1083 | } | 1083 | } |
1084 | 1084 | ||
1085 | QDate CalendarView::startDate() | 1085 | QDate CalendarView::startDate() |
1086 | { | 1086 | { |
1087 | DateList dates = mNavigator->selectedDates(); | 1087 | DateList dates = mNavigator->selectedDates(); |
1088 | 1088 | ||
1089 | return dates.first(); | 1089 | return dates.first(); |
1090 | } | 1090 | } |
1091 | 1091 | ||
1092 | QDate CalendarView::endDate() | 1092 | QDate CalendarView::endDate() |
1093 | { | 1093 | { |
1094 | DateList dates = mNavigator->selectedDates(); | 1094 | DateList dates = mNavigator->selectedDates(); |
1095 | 1095 | ||
1096 | return dates.last(); | 1096 | return dates.last(); |
1097 | } | 1097 | } |
1098 | 1098 | ||
1099 | 1099 | ||
1100 | void CalendarView::createPrinter() | 1100 | void CalendarView::createPrinter() |
1101 | { | 1101 | { |
1102 | #ifndef KORG_NOPRINTER | 1102 | #ifndef KORG_NOPRINTER |
1103 | if (!mCalPrinter) { | 1103 | if (!mCalPrinter) { |
1104 | mCalPrinter = new CalPrinter(this, mCalendar); | 1104 | mCalPrinter = new CalPrinter(this, mCalendar); |
1105 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); | 1105 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); |
1106 | } | 1106 | } |
1107 | #endif | 1107 | #endif |
1108 | } | 1108 | } |
1109 | 1109 | ||
1110 | 1110 | ||
1111 | //KOPrefs::instance()->mWriteBackFile | 1111 | //KOPrefs::instance()->mWriteBackFile |
1112 | //KOPrefs::instance()->mWriteBackExistingOnly | 1112 | //KOPrefs::instance()->mWriteBackExistingOnly |
1113 | 1113 | ||
1114 | // 0 syncPrefsGroup->addRadio(i18n("Take local entry on conflict")); | 1114 | // 0 syncPrefsGroup->addRadio(i18n("Take local entry on conflict")); |
1115 | // 1 syncPrefsGroup->addRadio(i18n("Take remote entry on conflict")); | 1115 | // 1 syncPrefsGroup->addRadio(i18n("Take remote entry on conflict")); |
1116 | // 2 syncPrefsGroup->addRadio(i18n("Take newest entry on conflict")); | 1116 | // 2 syncPrefsGroup->addRadio(i18n("Take newest entry on conflict")); |
1117 | // 3 syncPrefsGroup->addRadio(i18n("Ask for every entry on conflict")); | 1117 | // 3 syncPrefsGroup->addRadio(i18n("Ask for every entry on conflict")); |
1118 | // 4 syncPrefsGroup->addRadio(i18n("Force take local entry always")); | 1118 | // 4 syncPrefsGroup->addRadio(i18n("Force take local entry always")); |
1119 | // 5 syncPrefsGroup->addRadio(i18n("Force take remote entry always")); | 1119 | // 5 syncPrefsGroup->addRadio(i18n("Force take remote entry always")); |
1120 | 1120 | ||
1121 | int CalendarView::takeEvent( Incidence* local, Incidence* remote, int mode , bool full ) | 1121 | int CalendarView::takeEvent( Incidence* local, Incidence* remote, int mode , bool full ) |
1122 | { | 1122 | { |
1123 | 1123 | ||
1124 | // 0 equal | 1124 | // 0 equal |
1125 | // 1 take local | 1125 | // 1 take local |
1126 | // 2 take remote | 1126 | // 2 take remote |
1127 | // 3 cancel | 1127 | // 3 cancel |
1128 | QDateTime lastSync = mLastCalendarSync; | 1128 | QDateTime lastSync = mLastCalendarSync; |
1129 | QDateTime localMod = local->lastModified(); | 1129 | QDateTime localMod = local->lastModified(); |
1130 | QDateTime remoteMod = remote->lastModified(); | 1130 | QDateTime remoteMod = remote->lastModified(); |
1131 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1131 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1132 | bool remCh, locCh; | 1132 | bool remCh, locCh; |
1133 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); | 1133 | remCh = ( remote->getCsum(mCurrentSyncDevice) != local->getCsum(mCurrentSyncDevice) ); |
1134 | //if ( remCh ) | 1134 | //if ( remCh ) |
1135 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); | 1135 | //qDebug("loc %s rem %s", local->getCsum(mCurrentSyncDevice).latin1(), remote->getCsum(mCurrentSyncDevice).latin1() ); |
1136 | locCh = ( localMod > mLastCalendarSync ); | 1136 | locCh = ( localMod > mLastCalendarSync ); |
1137 | if ( !remCh && ! locCh ) { | 1137 | if ( !remCh && ! locCh ) { |
1138 | //qDebug("both not changed "); | 1138 | //qDebug("both not changed "); |
1139 | lastSync = localMod.addDays(1); | 1139 | lastSync = localMod.addDays(1); |
1140 | if ( mode <= SYNC_PREF_ASK ) | 1140 | if ( mode <= SYNC_PREF_ASK ) |
1141 | return 0; | 1141 | return 0; |
1142 | } else { | 1142 | } else { |
1143 | if ( locCh ) { | 1143 | if ( locCh ) { |
1144 | //qDebug("loc changed %d %s %s", local->revision() , localMod.toString().latin1(), mLastCalendarSync.toString().latin1()); | 1144 | //qDebug("loc changed %d %s %s", local->revision() , localMod.toString().latin1(), mLastCalendarSync.toString().latin1()); |
1145 | lastSync = localMod.addDays( -1 ); | 1145 | lastSync = localMod.addDays( -1 ); |
1146 | if ( !remCh ) | 1146 | if ( !remCh ) |
1147 | remoteMod = ( lastSync.addDays( -1 ) ); | 1147 | remoteMod = ( lastSync.addDays( -1 ) ); |
1148 | } else { | 1148 | } else { |
1149 | //qDebug(" not loc changed "); | 1149 | //qDebug(" not loc changed "); |
1150 | lastSync = localMod.addDays( 1 ); | 1150 | lastSync = localMod.addDays( 1 ); |
1151 | if ( remCh ) | 1151 | if ( remCh ) |
1152 | remoteMod =( lastSync.addDays( 1 ) ); | 1152 | remoteMod =( lastSync.addDays( 1 ) ); |
1153 | 1153 | ||
1154 | } | 1154 | } |
1155 | } | 1155 | } |
1156 | full = true; | 1156 | full = true; |
1157 | if ( mode < SYNC_PREF_ASK ) | 1157 | if ( mode < SYNC_PREF_ASK ) |
1158 | mode = SYNC_PREF_ASK; | 1158 | mode = SYNC_PREF_ASK; |
1159 | } else { | 1159 | } else { |
1160 | if ( localMod == remoteMod ) | 1160 | if ( localMod == remoteMod ) |
1161 | // if ( local->revision() == remote->revision() ) | 1161 | // if ( local->revision() == remote->revision() ) |
1162 | return 0; | 1162 | return 0; |
1163 | 1163 | ||
1164 | } | 1164 | } |
1165 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); | 1165 | // qDebug(" %d %d conflict on %s %s ", mode, full, local->summary().latin1(), remote->summary().latin1() ); |
1166 | 1166 | ||
1167 | //qDebug("%s %d %s %d", localMod.toString().latin1() , local->revision(), remoteMod.toString().latin1(), remote->revision()); | 1167 | //qDebug("%s %d %s %d", localMod.toString().latin1() , local->revision(), remoteMod.toString().latin1(), remote->revision()); |
1168 | //qDebug("%d %d %d %d ", localMod.time().second(), localMod.time().msec(), remoteMod.time().second(), remoteMod.time().msec() ); | 1168 | //qDebug("%d %d %d %d ", localMod.time().second(), localMod.time().msec(), remoteMod.time().second(), remoteMod.time().msec() ); |
1169 | //full = true; //debug only | 1169 | //full = true; //debug only |
1170 | if ( full ) { | 1170 | if ( full ) { |
1171 | bool equ = false; | 1171 | bool equ = false; |
1172 | if ( local->typeID() == eventID ) { | 1172 | if ( local->typeID() == eventID ) { |
1173 | equ = (*((Event*) local) == *((Event*) remote)); | 1173 | equ = (*((Event*) local) == *((Event*) remote)); |
1174 | } | 1174 | } |
1175 | else if ( local->typeID() == todoID ) | 1175 | else if ( local->typeID() == todoID ) |
1176 | equ = (*((Todo*) local) == (*(Todo*) remote)); | 1176 | equ = (*((Todo*) local) == (*(Todo*) remote)); |
1177 | else if ( local->typeID() == journalID ) | 1177 | else if ( local->typeID() == journalID ) |
1178 | equ = (*((Journal*) local) == *((Journal*) remote)); | 1178 | equ = (*((Journal*) local) == *((Journal*) remote)); |
1179 | if ( equ ) { | 1179 | if ( equ ) { |
1180 | //qDebug("equal "); | 1180 | //qDebug("equal "); |
1181 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1181 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1182 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); | 1182 | local->setCsum( mCurrentSyncDevice, remote->getCsum(mCurrentSyncDevice) ); |
1183 | } | 1183 | } |
1184 | if ( mode < SYNC_PREF_FORCE_LOCAL ) | 1184 | if ( mode < SYNC_PREF_FORCE_LOCAL ) |
1185 | return 0; | 1185 | return 0; |
1186 | 1186 | ||
1187 | }//else //debug only | 1187 | }//else //debug only |
1188 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); | 1188 | //qDebug("not equal %s %s ", local->summary().latin1(), remote->summary().latin1()); |
1189 | } | 1189 | } |
1190 | int result; | 1190 | int result; |
1191 | bool localIsNew; | 1191 | bool localIsNew; |
1192 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , localMod.toString().latin1() , remoteMod.toString().latin1() ); | 1192 | //qDebug("%s -- %s mLastCalendarSync %s lastsync %s --- local %s remote %s ",local->summary().latin1(), remote->summary().latin1(),mLastCalendarSync.toString().latin1() ,lastSync.toString().latin1() , localMod.toString().latin1() , remoteMod.toString().latin1() ); |
1193 | 1193 | ||
1194 | 1194 | ||
1195 | // ************************************************ | 1195 | // ************************************************ |
1196 | // ************************************************ | 1196 | // ************************************************ |
1197 | // ************************************************ | 1197 | // ************************************************ |
1198 | // We may have that lastSync > remoteMod AND lastSync > localMod | 1198 | // We may have that lastSync > remoteMod AND lastSync > localMod |
1199 | // BUT remoteMod != localMod | 1199 | // BUT remoteMod != localMod |
1200 | 1200 | ||
1201 | 1201 | ||
1202 | if ( full && mode < SYNC_PREF_NEWEST ) | 1202 | if ( full && mode < SYNC_PREF_NEWEST ) |
1203 | mode = SYNC_PREF_ASK; | 1203 | mode = SYNC_PREF_ASK; |
1204 | 1204 | ||
1205 | switch( mode ) { | 1205 | switch( mode ) { |
1206 | case SYNC_PREF_LOCAL: | 1206 | case SYNC_PREF_LOCAL: |
1207 | if ( lastSync > remoteMod ) | 1207 | if ( lastSync > remoteMod ) |
1208 | return 1; | 1208 | return 1; |
1209 | if ( lastSync > localMod ) | 1209 | if ( lastSync > localMod ) |
1210 | return 2; | 1210 | return 2; |
1211 | return 1; | 1211 | return 1; |
1212 | break; | 1212 | break; |
1213 | case SYNC_PREF_REMOTE: | 1213 | case SYNC_PREF_REMOTE: |
1214 | if ( lastSync > localMod ) | 1214 | if ( lastSync > localMod ) |
1215 | return 2; | 1215 | return 2; |
1216 | if ( lastSync > remoteMod ) | 1216 | if ( lastSync > remoteMod ) |
1217 | return 1; | 1217 | return 1; |
1218 | return 2; | 1218 | return 2; |
1219 | break; | 1219 | break; |
1220 | case SYNC_PREF_NEWEST: | 1220 | case SYNC_PREF_NEWEST: |
1221 | if ( localMod >= remoteMod ) | 1221 | if ( localMod >= remoteMod ) |
1222 | return 1; | 1222 | return 1; |
1223 | else | 1223 | else |
1224 | return 2; | 1224 | return 2; |
1225 | break; | 1225 | break; |
1226 | case SYNC_PREF_ASK: | 1226 | case SYNC_PREF_ASK: |
1227 | qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); | 1227 | qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); |
1228 | if ( lastSync > remoteMod && lastSync > localMod) | 1228 | if ( lastSync > remoteMod && lastSync > localMod) |
1229 | return 0; | 1229 | return 0; |
1230 | if ( lastSync > remoteMod ) | 1230 | if ( lastSync > remoteMod ) |
1231 | return 1; | 1231 | return 1; |
1232 | if ( lastSync > localMod ) | 1232 | if ( lastSync > localMod ) |
1233 | return 2; | 1233 | return 2; |
1234 | qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); | 1234 | qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), localMod.toString().latin1(), remoteMod.toString().latin1() ); |
1235 | localIsNew = localMod >= remoteMod; | 1235 | localIsNew = localMod >= remoteMod; |
1236 | if ( localIsNew ) | 1236 | if ( localIsNew ) |
1237 | getEventViewerDialog()->setColorMode( 1 ); | 1237 | getEventViewerDialog()->setColorMode( 1 ); |
1238 | else | 1238 | else |
1239 | getEventViewerDialog()->setColorMode( 2 ); | 1239 | getEventViewerDialog()->setColorMode( 2 ); |
1240 | getEventViewerDialog()->setIncidence(local); | 1240 | getEventViewerDialog()->setIncidence(local); |
1241 | if ( localIsNew ) | 1241 | if ( localIsNew ) |
1242 | getEventViewerDialog()->setColorMode( 2 ); | 1242 | getEventViewerDialog()->setColorMode( 2 ); |
1243 | else | 1243 | else |
1244 | getEventViewerDialog()->setColorMode( 1 ); | 1244 | getEventViewerDialog()->setColorMode( 1 ); |
1245 | getEventViewerDialog()->addIncidence(remote); | 1245 | getEventViewerDialog()->addIncidence(remote); |
1246 | getEventViewerDialog()->setColorMode( 0 ); | 1246 | getEventViewerDialog()->setColorMode( 0 ); |
1247 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); | 1247 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); |
1248 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); | 1248 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); |
1249 | getEventViewerDialog()->showMe(); | 1249 | getEventViewerDialog()->showMe(); |
1250 | result = getEventViewerDialog()->executeS( localIsNew ); | 1250 | result = getEventViewerDialog()->executeS( localIsNew ); |
1251 | return result; | 1251 | return result; |
1252 | 1252 | ||
1253 | break; | 1253 | break; |
1254 | case SYNC_PREF_FORCE_LOCAL: | 1254 | case SYNC_PREF_FORCE_LOCAL: |
1255 | return 1; | 1255 | return 1; |
1256 | break; | 1256 | break; |
1257 | case SYNC_PREF_FORCE_REMOTE: | 1257 | case SYNC_PREF_FORCE_REMOTE: |
1258 | return 2; | 1258 | return 2; |
1259 | break; | 1259 | break; |
1260 | 1260 | ||
1261 | default: | 1261 | default: |
1262 | // SYNC_PREF_TAKE_BOTH not implemented | 1262 | // SYNC_PREF_TAKE_BOTH not implemented |
1263 | break; | 1263 | break; |
1264 | } | 1264 | } |
1265 | return 0; | 1265 | return 0; |
1266 | } | 1266 | } |
1267 | Event* CalendarView::getLastSyncEvent() | 1267 | Event* CalendarView::getLastSyncEvent() |
1268 | { | 1268 | { |
1269 | Event* lse; | 1269 | Event* lse; |
1270 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 1270 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
1271 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); | 1271 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); |
1272 | if (!lse) { | 1272 | if (!lse) { |
1273 | lse = new Event(); | 1273 | lse = new Event(); |
1274 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); | 1274 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); |
1275 | QString sum = ""; | 1275 | QString sum = ""; |
1276 | if ( mSyncManager->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) | 1276 | if ( mSyncManager->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) |
1277 | sum = "E: "; | 1277 | sum = "E: "; |
1278 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); | 1278 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); |
1279 | lse->setDtStart( mLastCalendarSync ); | 1279 | lse->setDtStart( mLastCalendarSync ); |
1280 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1280 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1281 | lse->setCategories( i18n("SyncEvent") ); | 1281 | lse->setCategories( i18n("SyncEvent") ); |
1282 | lse->setReadOnly( true ); | 1282 | lse->setReadOnly( true ); |
1283 | mCalendar->addEvent( lse ); | 1283 | mCalendar->addEvent( lse ); |
1284 | } | 1284 | } |
1285 | 1285 | ||
1286 | return lse; | 1286 | return lse; |
1287 | 1287 | ||
1288 | } | 1288 | } |
1289 | 1289 | ||
1290 | // we check, if the to delete event has a id for a profile | 1290 | // we check, if the to delete event has a id for a profile |
1291 | // if yes, we set this id in the profile to delete | 1291 | // if yes, we set this id in the profile to delete |
1292 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) | 1292 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) |
1293 | { | 1293 | { |
1294 | if ( lastSync.count() == 0 ) { | 1294 | if ( lastSync.count() == 0 ) { |
1295 | //qDebug(" lastSync.count() == 0"); | 1295 | //qDebug(" lastSync.count() == 0"); |
1296 | return; | 1296 | return; |
1297 | } | 1297 | } |
1298 | if ( toDelete->typeID() == journalID ) | 1298 | if ( toDelete->typeID() == journalID ) |
1299 | return; | 1299 | return; |
1300 | 1300 | ||
1301 | Event* eve = lastSync.first(); | 1301 | Event* eve = lastSync.first(); |
1302 | 1302 | ||
1303 | while ( eve ) { | 1303 | while ( eve ) { |
1304 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name | 1304 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name |
1305 | if ( !id.isEmpty() ) { | 1305 | if ( !id.isEmpty() ) { |
1306 | QString des = eve->description(); | 1306 | QString des = eve->description(); |
1307 | QString pref = "e"; | 1307 | QString pref = "e"; |
1308 | if ( toDelete->typeID() == todoID ) | 1308 | if ( toDelete->typeID() == todoID ) |
1309 | pref = "t"; | 1309 | pref = "t"; |
1310 | des += pref+ id + ","; | 1310 | des += pref+ id + ","; |
1311 | eve->setReadOnly( false ); | 1311 | eve->setReadOnly( false ); |
1312 | eve->setDescription( des ); | 1312 | eve->setDescription( des ); |
1313 | //qDebug("setdes %s ", des.latin1()); | 1313 | //qDebug("setdes %s ", des.latin1()); |
1314 | eve->setReadOnly( true ); | 1314 | eve->setReadOnly( true ); |
1315 | } | 1315 | } |
1316 | eve = lastSync.next(); | 1316 | eve = lastSync.next(); |
1317 | } | 1317 | } |
1318 | 1318 | ||
1319 | } | 1319 | } |
1320 | void CalendarView::checkExternalId( Incidence * inc ) | 1320 | void CalendarView::checkExternalId( Incidence * inc ) |
1321 | { | 1321 | { |
1322 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; | 1322 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; |
1323 | checkExternSyncEvent( lastSync, inc ); | 1323 | checkExternSyncEvent( lastSync, inc ); |
1324 | 1324 | ||
1325 | } | 1325 | } |
1326 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) | 1326 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) |
1327 | { | 1327 | { |
1328 | bool syncOK = true; | 1328 | bool syncOK = true; |
1329 | int addedEvent = 0; | 1329 | int addedEvent = 0; |
1330 | int addedEventR = 0; | 1330 | int addedEventR = 0; |
1331 | int deletedEventR = 0; | 1331 | int deletedEventR = 0; |
1332 | int deletedEventL = 0; | 1332 | int deletedEventL = 0; |
1333 | int changedLocal = 0; | 1333 | int changedLocal = 0; |
1334 | int changedRemote = 0; | 1334 | int changedRemote = 0; |
1335 | int filteredIN = 0; | 1335 | int filteredIN = 0; |
1336 | int filteredOUT = 0; | 1336 | int filteredOUT = 0; |
1337 | //QPtrList<Event> el = local->rawEvents(); | 1337 | //QPtrList<Event> el = local->rawEvents(); |
1338 | Event* eventR; | 1338 | Event* eventR; |
1339 | QString uid; | 1339 | QString uid; |
1340 | int take; | 1340 | int take; |
1341 | Event* eventRSync; | 1341 | Event* eventRSync; |
1342 | Event* eventLSync; | 1342 | Event* eventLSync; |
1343 | clearAllViews(); | 1343 | clearAllViews(); |
1344 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); | 1344 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); |
1345 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); | 1345 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); |
1346 | bool fullDateRange = false; | 1346 | bool fullDateRange = false; |
1347 | local->resetTempSyncStat(); | 1347 | local->resetTempSyncStat(); |
1348 | mLastCalendarSync = QDateTime::currentDateTime(); | 1348 | mLastCalendarSync = QDateTime::currentDateTime(); |
1349 | if ( mSyncManager->syncWithDesktop() ) { | 1349 | if ( mSyncManager->syncWithDesktop() ) { |
1350 | remote->resetPilotStat(1); | 1350 | remote->resetPilotStat(1); |
1351 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { | 1351 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { |
1352 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; | 1352 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; |
1353 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); | 1353 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); |
1354 | } else { | 1354 | } else { |
1355 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); | 1355 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); |
1356 | } | 1356 | } |
1357 | } | 1357 | } |
1358 | QDateTime modifiedCalendar = mLastCalendarSync; | 1358 | QDateTime modifiedCalendar = mLastCalendarSync; |
1359 | eventLSync = getLastSyncEvent(); | 1359 | eventLSync = getLastSyncEvent(); |
1360 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); | 1360 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); |
1361 | if ( eventR ) { | 1361 | if ( eventR ) { |
1362 | qDebug("last-syncEvent on remote found "); | 1362 | qDebug("last-syncEvent on remote found "); |
1363 | eventRSync = (Event*) eventR->clone(); | 1363 | eventRSync = (Event*) eventR->clone(); |
1364 | remote->deleteEvent(eventR ); | 1364 | remote->deleteEvent(eventR ); |
1365 | 1365 | ||
1366 | } else { | 1366 | } else { |
1367 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { | 1367 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { |
1368 | eventRSync = (Event*)eventLSync->clone(); | 1368 | eventRSync = (Event*)eventLSync->clone(); |
1369 | } else { | 1369 | } else { |
1370 | fullDateRange = true; | 1370 | fullDateRange = true; |
1371 | eventRSync = new Event(); | 1371 | eventRSync = new Event(); |
1372 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); | 1372 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); |
1373 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); | 1373 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); |
1374 | eventRSync->setDtStart( mLastCalendarSync ); | 1374 | eventRSync->setDtStart( mLastCalendarSync ); |
1375 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1375 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1376 | eventRSync->setCategories( i18n("SyncEvent") ); | 1376 | eventRSync->setCategories( i18n("SyncEvent") ); |
1377 | } | 1377 | } |
1378 | } | 1378 | } |
1379 | if ( eventLSync->dtStart() == mLastCalendarSync ) | 1379 | if ( eventLSync->dtStart() == mLastCalendarSync ) |
1380 | fullDateRange = true; | 1380 | fullDateRange = true; |
1381 | 1381 | ||
1382 | if ( ! fullDateRange ) { | 1382 | if ( ! fullDateRange ) { |
1383 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { | 1383 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { |
1384 | 1384 | ||
1385 | qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); | 1385 | qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); |
1386 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); | 1386 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); |
1387 | fullDateRange = true; | 1387 | fullDateRange = true; |
1388 | } | 1388 | } |
1389 | } | 1389 | } |
1390 | if ( mSyncManager->syncWithDesktop() ) { | 1390 | if ( mSyncManager->syncWithDesktop() ) { |
1391 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); | 1391 | fullDateRange = ( eventLSync->dtStart() <= mLastCalendarSync && eventLSync->dtStart().addSecs(1) >= mLastCalendarSync ); |
1392 | } | 1392 | } |
1393 | if ( fullDateRange ) | 1393 | if ( fullDateRange ) |
1394 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); | 1394 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); |
1395 | else | 1395 | else |
1396 | mLastCalendarSync = eventLSync->dtStart(); | 1396 | mLastCalendarSync = eventLSync->dtStart(); |
1397 | // for resyncing if own file has changed | 1397 | // for resyncing if own file has changed |
1398 | if ( mCurrentSyncDevice == "deleteaftersync" ) { | 1398 | if ( mCurrentSyncDevice == "deleteaftersync" ) { |
1399 | mLastCalendarSync = loadedFileVersion; | 1399 | mLastCalendarSync = loadedFileVersion; |
1400 | //qDebug("setting mLastCalendarSync "); | 1400 | //qDebug("setting mLastCalendarSync "); |
1401 | } | 1401 | } |
1402 | //qDebug("*************************** "); | 1402 | //qDebug("*************************** "); |
1403 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); | 1403 | qDebug("KO: mLastCalendarSync %s .Full: %d",mLastCalendarSync.toString().latin1(), fullDateRange); |
1404 | QPtrList<Incidence> er = remote->rawIncidences(); | 1404 | QPtrList<Incidence> er = remote->rawIncidences(); |
1405 | Incidence* inR = er.first(); | 1405 | Incidence* inR = er.first(); |
1406 | Incidence* inL; | 1406 | Incidence* inL; |
1407 | QProgressBar bar( er.count(),0 ); | 1407 | QProgressBar bar( er.count(),0 ); |
1408 | bar.setCaption (i18n("Syncing - close to abort!") ); | 1408 | bar.setCaption (i18n("Syncing - close to abort!") ); |
1409 | 1409 | ||
1410 | // ************** setting up filter ************* | 1410 | // ************** setting up filter ************* |
1411 | CalFilter *filterIN = 0; | 1411 | CalFilter *filterIN = 0; |
1412 | CalFilter *filterOUT = 0; | 1412 | CalFilter *filterOUT = 0; |
1413 | CalFilter *filter = mFilters.first(); | 1413 | CalFilter *filter = mFilters.first(); |
1414 | while(filter) { | 1414 | while(filter) { |
1415 | if ( filter->name() == mSyncManager->mFilterInCal ) | 1415 | if ( filter->name() == mSyncManager->mFilterInCal ) |
1416 | filterIN = filter; | 1416 | filterIN = filter; |
1417 | if ( filter->name() == mSyncManager->mFilterOutCal ) | 1417 | if ( filter->name() == mSyncManager->mFilterOutCal ) |
1418 | filterOUT = filter; | 1418 | filterOUT = filter; |
1419 | filter = mFilters.next(); | 1419 | filter = mFilters.next(); |
1420 | } | 1420 | } |
1421 | int w = 300; | 1421 | int w = 300; |
1422 | if ( QApplication::desktop()->width() < 320 ) | 1422 | if ( QApplication::desktop()->width() < 320 ) |
1423 | w = 220; | 1423 | w = 220; |
1424 | int h = bar.sizeHint().height() ; | 1424 | int h = bar.sizeHint().height() ; |
1425 | int dw = QApplication::desktop()->width(); | 1425 | int dw = QApplication::desktop()->width(); |
1426 | int dh = QApplication::desktop()->height(); | 1426 | int dh = QApplication::desktop()->height(); |
1427 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1427 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1428 | bar.show(); | 1428 | bar.show(); |
1429 | int modulo = (er.count()/10)+1; | 1429 | int modulo = (er.count()/10)+1; |
1430 | int incCounter = 0; | 1430 | int incCounter = 0; |
1431 | while ( inR ) { | 1431 | while ( inR ) { |
1432 | if ( ! bar.isVisible() ) | 1432 | if ( ! bar.isVisible() ) |
1433 | return false; | 1433 | return false; |
1434 | if ( incCounter % modulo == 0 ) | 1434 | if ( incCounter % modulo == 0 ) |
1435 | bar.setProgress( incCounter ); | 1435 | bar.setProgress( incCounter ); |
1436 | ++incCounter; | 1436 | ++incCounter; |
1437 | uid = inR->uid(); | 1437 | uid = inR->uid(); |
1438 | bool skipIncidence = false; | 1438 | bool skipIncidence = false; |
1439 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1439 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1440 | skipIncidence = true; | 1440 | skipIncidence = true; |
1441 | QString idS; | 1441 | QString idS; |
1442 | qApp->processEvents(); | 1442 | qApp->processEvents(); |
1443 | if ( !skipIncidence ) { | 1443 | if ( !skipIncidence ) { |
1444 | inL = local->incidence( uid ); | 1444 | inL = local->incidenceForUid( uid , false ); |
1445 | if ( inL ) { // maybe conflict - same uid in both calendars | 1445 | if ( inL ) { // maybe conflict - same uid in both calendars |
1446 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { | 1446 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { |
1447 | //qDebug("take %d %s ", take, inL->summary().latin1()); | 1447 | //qDebug("take %d %s ", take, inL->summary().latin1()); |
1448 | if ( take == 3 ) | 1448 | if ( take == 3 ) |
1449 | return false; | 1449 | return false; |
1450 | if ( take == 1 ) {// take local ********************** | 1450 | if ( take == 1 ) {// take local ********************** |
1451 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 1451 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
1452 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1452 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1453 | else | 1453 | else |
1454 | idS = inR->IDStr(); | 1454 | idS = inR->IDStr(); |
1455 | int calID = inR->calID(); | 1455 | int calID = inR->calID(); |
1456 | remote->deleteIncidence( inR ); | 1456 | remote->deleteIncidence( inR ); |
1457 | inR = inL->clone(); | 1457 | inR = inL->clone(); |
1458 | inR->setCalID( calID ); | 1458 | inR->setCalID( calID ); |
1459 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1459 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1460 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) | 1460 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) |
1461 | inR->setIDStr( idS ); | 1461 | inR->setIDStr( idS ); |
1462 | remote->addIncidence( inR ); | 1462 | remote->addIncidence( inR ); |
1463 | if ( mSyncManager->syncWithDesktop() ) | 1463 | if ( mSyncManager->syncWithDesktop() ) |
1464 | inR->setPilotId( 2 ); | 1464 | inR->setPilotId( 2 ); |
1465 | ++changedRemote; | 1465 | ++changedRemote; |
1466 | } else {// take remote ********************** | 1466 | } else {// take remote ********************** |
1467 | idS = inL->IDStr(); | 1467 | if ( !inL->isReadOnly() ) { |
1468 | int pid = inL->pilotId(); | 1468 | idS = inL->IDStr(); |
1469 | int calID = inL->calID(); | 1469 | int pid = inL->pilotId(); |
1470 | local->deleteIncidence( inL ); | 1470 | int calID = inL->calID(); |
1471 | inL = inR->clone(); | 1471 | local->deleteIncidence( inL ); |
1472 | inL->setCalID( calID ); | 1472 | inL = inR->clone(); |
1473 | if ( mSyncManager->syncWithDesktop() ) | 1473 | inL->setCalID( calID ); |
1474 | inL->setPilotId( pid ); | 1474 | if ( mSyncManager->syncWithDesktop() ) |
1475 | inL->setIDStr( idS ); | 1475 | inL->setPilotId( pid ); |
1476 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1476 | inL->setIDStr( idS ); |
1477 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1477 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1478 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1478 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1479 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | ||
1480 | } | ||
1481 | local->addIncidence( inL ); | ||
1482 | ++changedLocal; | ||
1479 | } | 1483 | } |
1480 | local->addIncidence( inL ); | ||
1481 | ++changedLocal; | ||
1482 | } | 1484 | } |
1483 | } | 1485 | } |
1484 | } else { // no conflict ********** add or delete remote | 1486 | } else { // no conflict ********** add or delete remote |
1485 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ | 1487 | if ( !filterIN || filterIN->filterCalendarItem( inR ) ){ |
1486 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1488 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1487 | QString des = eventLSync->description(); | 1489 | QString des = eventLSync->description(); |
1488 | QString pref = "e"; | 1490 | QString pref = "e"; |
1489 | if ( inR->typeID() == todoID ) | 1491 | if ( inR->typeID() == todoID ) |
1490 | pref = "t"; | 1492 | pref = "t"; |
1491 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it | 1493 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it |
1492 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); | 1494 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); |
1493 | //remote->deleteIncidence( inR ); | 1495 | //remote->deleteIncidence( inR ); |
1494 | ++deletedEventR; | 1496 | ++deletedEventR; |
1495 | } else { | 1497 | } else { |
1496 | inR->setLastModified( modifiedCalendar ); | 1498 | inR->setLastModified( modifiedCalendar ); |
1497 | inL = inR->clone(); | 1499 | inL = inR->clone(); |
1498 | inL->setIDStr( ":" ); | 1500 | inL->setIDStr( ":" ); |
1499 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1501 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1500 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); | 1502 | inL->setID( mCurrentSyncDevice, inR->getID(mCurrentSyncDevice) ); |
1501 | 1503 | ||
1502 | inL->setCalID( 0 );// add to default cal | 1504 | inL->setCalID( 0 );// add to default cal |
1503 | local->addIncidence( inL ); | 1505 | local->addIncidence( inL ); |
1504 | ++addedEvent; | 1506 | ++addedEvent; |
1505 | 1507 | ||
1506 | } | 1508 | } |
1507 | } else { | 1509 | } else { |
1508 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { | 1510 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { |
1509 | inR->setLastModified( modifiedCalendar ); | 1511 | inR->setLastModified( modifiedCalendar ); |
1510 | inL = inR->clone(); | 1512 | inL = inR->clone(); |
1511 | inL->setIDStr( ":" ); | 1513 | inL->setIDStr( ":" ); |
1512 | inL->setCalID( 0 );// add to default cal | 1514 | inL->setCalID( 0 );// add to default cal |
1513 | local->addIncidence( inL ); | 1515 | local->addIncidence( inL ); |
1514 | ++addedEvent; | 1516 | ++addedEvent; |
1515 | 1517 | ||
1516 | } else { | 1518 | } else { |
1517 | checkExternSyncEvent(eventRSyncSharp, inR); | 1519 | checkExternSyncEvent(eventRSyncSharp, inR); |
1518 | remote->deleteIncidence( inR ); | 1520 | remote->deleteIncidence( inR ); |
1519 | ++deletedEventR; | 1521 | ++deletedEventR; |
1520 | } | 1522 | } |
1521 | } | 1523 | } |
1522 | } else { | 1524 | } else { |
1523 | ++filteredIN; | 1525 | ++filteredIN; |
1524 | } | 1526 | } |
1525 | } | 1527 | } |
1526 | } | 1528 | } |
1527 | inR = er.next(); | 1529 | inR = er.next(); |
1528 | } | 1530 | } |
1529 | QPtrList<Incidence> el = local->rawIncidences(); | 1531 | QPtrList<Incidence> el = local->rawIncidences(); |
1530 | inL = el.first(); | 1532 | inL = el.first(); |
1531 | modulo = (el.count()/10)+1; | 1533 | modulo = (el.count()/10)+1; |
1532 | bar.setCaption (i18n("Add / remove events") ); | 1534 | bar.setCaption (i18n("Add / remove events") ); |
1533 | bar.setTotalSteps ( el.count() ) ; | 1535 | bar.setTotalSteps ( el.count() ) ; |
1534 | bar.show(); | 1536 | bar.show(); |
1535 | incCounter = 0; | 1537 | incCounter = 0; |
1536 | 1538 | ||
1537 | while ( inL ) { | 1539 | while ( inL ) { |
1538 | 1540 | ||
1539 | qApp->processEvents(); | 1541 | qApp->processEvents(); |
1540 | if ( ! bar.isVisible() ) | 1542 | if ( ! bar.isVisible() ) |
1541 | return false; | 1543 | return false; |
1542 | if ( incCounter % modulo == 0 ) | 1544 | if ( incCounter % modulo == 0 ) |
1543 | bar.setProgress( incCounter ); | 1545 | bar.setProgress( incCounter ); |
1544 | ++incCounter; | 1546 | ++incCounter; |
1545 | uid = inL->uid(); | 1547 | uid = inL->uid(); |
1546 | bool skipIncidence = false; | 1548 | bool skipIncidence = false; |
1547 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1549 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1548 | skipIncidence = true; | 1550 | skipIncidence = true; |
1549 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->typeID() == journalID ) | 1551 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->typeID() == journalID ) |
1550 | skipIncidence = true; | 1552 | skipIncidence = true; |
1551 | if ( !skipIncidence ) { | 1553 | if ( !skipIncidence ) { |
1552 | inR = remote->incidence( uid ); | 1554 | inR = remote->incidenceForUid( uid , true ); |
1553 | if ( ! inR ) { | 1555 | if ( ! inR ) { |
1554 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ | 1556 | if ( !filterOUT || filterOUT->filterCalendarItem( inL ) ){ |
1555 | // no conflict ********** add or delete local | 1557 | // no conflict ********** add or delete local |
1556 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1558 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1557 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 1559 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
1558 | checkExternSyncEvent(eventLSyncSharp, inL); | 1560 | checkExternSyncEvent(eventLSyncSharp, inL); |
1559 | local->deleteIncidence( inL ); | 1561 | local->deleteIncidence( inL ); |
1560 | ++deletedEventL; | 1562 | ++deletedEventL; |
1561 | } else { | 1563 | } else { |
1562 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1564 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1563 | inL->removeID(mCurrentSyncDevice ); | 1565 | inL->removeID(mCurrentSyncDevice ); |
1564 | ++addedEventR; | 1566 | ++addedEventR; |
1565 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); | 1567 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); |
1566 | inL->setLastModified( modifiedCalendar ); | 1568 | inL->setLastModified( modifiedCalendar ); |
1567 | inR = inL->clone(); | 1569 | inR = inL->clone(); |
1568 | inR->setIDStr( ":" ); | 1570 | inR->setIDStr( ":" ); |
1569 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1571 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1570 | inR->setCalID( 0 );// add to default cal | 1572 | inR->setCalID( 0 );// add to default cal |
1571 | remote->addIncidence( inR ); | 1573 | remote->addIncidence( inR ); |
1572 | } | 1574 | } |
1573 | } | 1575 | } |
1574 | } else { | 1576 | } else { |
1575 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { | 1577 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { |
1576 | checkExternSyncEvent(eventLSyncSharp, inL); | 1578 | checkExternSyncEvent(eventLSyncSharp, inL); |
1577 | local->deleteIncidence( inL ); | 1579 | local->deleteIncidence( inL ); |
1578 | ++deletedEventL; | 1580 | ++deletedEventL; |
1579 | } else { | 1581 | } else { |
1580 | if ( ! mSyncManager->mWriteBackExistingOnly ) { | 1582 | if ( ! mSyncManager->mWriteBackExistingOnly ) { |
1581 | ++addedEventR; | 1583 | ++addedEventR; |
1582 | inL->setLastModified( modifiedCalendar ); | 1584 | inL->setLastModified( modifiedCalendar ); |
1583 | inR = inL->clone(); | 1585 | inR = inL->clone(); |
1584 | inR->setIDStr( ":" ); | 1586 | inR->setIDStr( ":" ); |
1585 | inR->setCalID( 0 );// add to default cal | 1587 | inR->setCalID( 0 );// add to default cal |
1586 | remote->addIncidence( inR ); | 1588 | remote->addIncidence( inR ); |
1587 | } | 1589 | } |
1588 | } | 1590 | } |
1589 | } | 1591 | } |
1590 | } else { | 1592 | } else { |
1591 | ++filteredOUT; | 1593 | ++filteredOUT; |
1592 | } | 1594 | } |
1593 | } | 1595 | } |
1594 | } | 1596 | } |
1595 | inL = el.next(); | 1597 | inL = el.next(); |
1596 | } | 1598 | } |
1597 | int delFut = 0; | 1599 | int delFut = 0; |
1598 | int remRem = 0; | 1600 | int remRem = 0; |
1599 | if ( mSyncManager->mWriteBackInFuture ) { | 1601 | if ( mSyncManager->mWriteBackInFuture ) { |
1600 | er = remote->rawIncidences(); | 1602 | er = remote->rawIncidences(); |
1601 | remRem = er.count(); | 1603 | remRem = er.count(); |
1602 | inR = er.first(); | 1604 | inR = er.first(); |
1603 | QDateTime dt; | 1605 | QDateTime dt; |
1604 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); | 1606 | QDateTime cur = QDateTime::currentDateTime().addDays( -(mSyncManager->mWriteBackInPast * 7) ); |
1605 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); | 1607 | QDateTime end = QDateTime::currentDateTime().addDays( (mSyncManager->mWriteBackInFuture ) *7 ); |
1606 | while ( inR ) { | 1608 | while ( inR ) { |
1607 | if ( inR->typeID() == todoID ) { | 1609 | if ( inR->typeID() == todoID ) { |
1608 | Todo * t = (Todo*)inR; | 1610 | Todo * t = (Todo*)inR; |
1609 | if ( t->hasDueDate() ) | 1611 | if ( t->hasDueDate() ) |
1610 | dt = t->dtDue(); | 1612 | dt = t->dtDue(); |
1611 | else | 1613 | else |
1612 | dt = cur.addSecs( 62 ); | 1614 | dt = cur.addSecs( 62 ); |
1613 | } | 1615 | } |
1614 | else if (inR->typeID() == eventID ) { | 1616 | else if (inR->typeID() == eventID ) { |
1615 | bool ok; | 1617 | bool ok; |
1616 | dt = inR->getNextOccurence( cur, &ok ); | 1618 | dt = inR->getNextOccurence( cur, &ok ); |
1617 | if ( !ok ) | 1619 | if ( !ok ) |
1618 | dt = cur.addSecs( -62 ); | 1620 | dt = cur.addSecs( -62 ); |
1619 | } | 1621 | } |
1620 | else | 1622 | else |
1621 | dt = inR->dtStart(); | 1623 | dt = inR->dtStart(); |
1622 | if ( dt < cur || dt > end ) { | 1624 | if ( dt < cur || dt > end ) { |
1623 | remote->deleteIncidence( inR ); | 1625 | remote->deleteIncidence( inR ); |
1624 | ++delFut; | 1626 | ++delFut; |
1625 | } | 1627 | } |
1626 | inR = er.next(); | 1628 | inR = er.next(); |
1627 | } | 1629 | } |
1628 | } | 1630 | } |
1629 | bar.hide(); | 1631 | bar.hide(); |
1630 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); | 1632 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); |
1631 | eventLSync->setReadOnly( false ); | 1633 | eventLSync->setReadOnly( false ); |
1632 | eventLSync->setDtStart( mLastCalendarSync ); | 1634 | eventLSync->setDtStart( mLastCalendarSync ); |
1633 | eventRSync->setDtStart( mLastCalendarSync ); | 1635 | eventRSync->setDtStart( mLastCalendarSync ); |
1634 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1636 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1635 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1637 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1636 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; | 1638 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; |
1637 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); | 1639 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); |
1638 | eventLSync->setReadOnly( true ); | 1640 | eventLSync->setReadOnly( true ); |
1639 | qDebug("KO: Normal sync: %d ",mGlobalSyncMode == SYNC_MODE_NORMAL ); | 1641 | qDebug("KO: Normal sync: %d ",mGlobalSyncMode == SYNC_MODE_NORMAL ); |
1640 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... | 1642 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL && !mSyncManager->syncWithDesktop()) // kde is abnormal... |
1641 | remote->addEvent( eventRSync ); | 1643 | remote->addEvent( eventRSync ); |
1642 | else | 1644 | else |
1643 | delete eventRSync; | 1645 | delete eventRSync; |
1644 | qDebug("KO: Sync with desktop %d ",mSyncManager->syncWithDesktop() ); | 1646 | qDebug("KO: Sync with desktop %d ",mSyncManager->syncWithDesktop() ); |
1645 | QString mes; | 1647 | QString mes; |
1646 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR, filteredIN, filteredOUT ); | 1648 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR, filteredIN, filteredOUT ); |
1647 | QString delmess; | 1649 | QString delmess; |
1648 | if ( delFut ) { | 1650 | if ( delFut ) { |
1649 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are more\nthan %d weeks in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInPast,mSyncManager->mWriteBackInFuture, remRem-delFut); | 1651 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are more\nthan %d weeks in the past or\nmore than %d weeks in the future.\nAfter skipping, remote has\n%d calendar/todo items."), delFut,mSyncManager->mWriteBackInPast,mSyncManager->mWriteBackInFuture, remRem-delFut); |
1650 | mes += delmess; | 1652 | mes += delmess; |
1651 | } | 1653 | } |
1652 | mes = i18n("Local calendar changed!\n") +mes; | 1654 | mes = i18n("Local calendar changed!\n") +mes; |
1653 | mCalendar->checkAlarmForIncidence( 0, true ); | 1655 | mCalendar->checkAlarmForIncidence( 0, true ); |
1654 | qDebug( mes ); | 1656 | qDebug( mes ); |
1655 | if ( mSyncManager->mShowSyncSummary ) { | 1657 | if ( mSyncManager->mShowSyncSummary ) { |
1656 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, | 1658 | if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(this, mes, |
1657 | i18n("KO/Pi Synchronization"),i18n("Write back"))) { | 1659 | i18n("KO/Pi Synchronization"),i18n("Write back"))) { |
1658 | qDebug("KO: WB cancelled "); | 1660 | qDebug("KO: WB cancelled "); |
1659 | mSyncManager->mWriteBackFile = false; | 1661 | mSyncManager->mWriteBackFile = false; |
1660 | return syncOK; | 1662 | return syncOK; |
1661 | } | 1663 | } |
1662 | } | 1664 | } |
1663 | return syncOK; | 1665 | return syncOK; |
1664 | } | 1666 | } |
1665 | 1667 | ||
1666 | void CalendarView::setSyncDevice( QString s ) | 1668 | void CalendarView::setSyncDevice( QString s ) |
1667 | { | 1669 | { |
1668 | mCurrentSyncDevice= s; | 1670 | mCurrentSyncDevice= s; |
1669 | } | 1671 | } |
1670 | void CalendarView::setSyncName( QString s ) | 1672 | void CalendarView::setSyncName( QString s ) |
1671 | { | 1673 | { |
1672 | mCurrentSyncName= s; | 1674 | mCurrentSyncName= s; |
1673 | } | 1675 | } |
1674 | bool CalendarView::syncCalendar(QString filename, int mode) | 1676 | bool CalendarView::syncCalendar(QString filename, int mode) |
1675 | { | 1677 | { |
1676 | //qDebug("syncCalendar %s ", filename.latin1()); | 1678 | //qDebug("syncCalendar %s ", filename.latin1()); |
1677 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 1679 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
1678 | CalendarLocal* calendar = new CalendarLocal(); | 1680 | CalendarLocal* calendar = new CalendarLocal(); |
1679 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1681 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1680 | FileStorage* storage = new FileStorage( calendar ); | 1682 | FileStorage* storage = new FileStorage( calendar ); |
1681 | bool syncOK = false; | 1683 | bool syncOK = false; |
1682 | storage->setFileName( filename ); | 1684 | storage->setFileName( filename ); |
1683 | // qDebug("loading ... "); | 1685 | // qDebug("loading ... "); |
1684 | if ( storage->load() ) { | 1686 | if ( storage->load() ) { |
1685 | getEventViewerDialog()->setSyncMode( true ); | 1687 | getEventViewerDialog()->setSyncMode( true ); |
1686 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); | 1688 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); |
1687 | getEventViewerDialog()->setSyncMode( false ); | 1689 | getEventViewerDialog()->setSyncMode( false ); |
1688 | if ( syncOK ) { | 1690 | if ( syncOK ) { |
1689 | if ( mSyncManager->mWriteBackFile ) | 1691 | if ( mSyncManager->mWriteBackFile ) |
1690 | { | 1692 | { |
1691 | storage->setSaveFormat( new ICalFormat() ); | 1693 | storage->setSaveFormat( new ICalFormat() ); |
1692 | storage->save(); | 1694 | storage->save(); |
1693 | } | 1695 | } |
1694 | } | 1696 | } |
1695 | setModified( true ); | 1697 | setModified( true ); |
1696 | } | 1698 | } |
1697 | delete storage; | 1699 | delete storage; |
1698 | delete calendar; | 1700 | delete calendar; |
1699 | if ( syncOK ) | 1701 | if ( syncOK ) |
1700 | updateView(); | 1702 | updateView(); |
1701 | return syncOK; | 1703 | return syncOK; |
1702 | } | 1704 | } |
1703 | 1705 | ||
1704 | void CalendarView::syncExternal( int mode ) | 1706 | void CalendarView::syncExternal( int mode ) |
1705 | { | 1707 | { |
1706 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 1708 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
1707 | 1709 | ||
1708 | qApp->processEvents(); | 1710 | qApp->processEvents(); |
1709 | CalendarLocal* calendar = new CalendarLocal(); | 1711 | CalendarLocal* calendar = new CalendarLocal(); |
1710 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 1712 | calendar->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
1711 | bool syncOK = false; | 1713 | bool syncOK = false; |
1712 | bool loadSuccess = false; | 1714 | bool loadSuccess = false; |
1713 | PhoneFormat* phoneFormat = 0; | 1715 | PhoneFormat* phoneFormat = 0; |
1714 | emit tempDisableBR(true); | 1716 | emit tempDisableBR(true); |
1715 | #ifndef DESKTOP_VERSION | 1717 | #ifndef DESKTOP_VERSION |
1716 | SharpFormat* sharpFormat = 0; | 1718 | SharpFormat* sharpFormat = 0; |
1717 | if ( mode == 0 ) { // sharp | 1719 | if ( mode == 0 ) { // sharp |
1718 | sharpFormat = new SharpFormat () ; | 1720 | sharpFormat = new SharpFormat () ; |
1719 | loadSuccess = sharpFormat->load( calendar, mCalendar ); | 1721 | loadSuccess = sharpFormat->load( calendar, mCalendar ); |
1720 | 1722 | ||
1721 | } else | 1723 | } else |
1722 | #endif | 1724 | #endif |
1723 | if ( mode == 1 ) { // phone | 1725 | if ( mode == 1 ) { // phone |
1724 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, | 1726 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, |
1725 | mSyncManager->mPhoneDevice, | 1727 | mSyncManager->mPhoneDevice, |
1726 | mSyncManager->mPhoneConnection, | 1728 | mSyncManager->mPhoneConnection, |
1727 | mSyncManager->mPhoneModel); | 1729 | mSyncManager->mPhoneModel); |
1728 | loadSuccess = phoneFormat->load( calendar,mCalendar); | 1730 | loadSuccess = phoneFormat->load( calendar,mCalendar); |
1729 | 1731 | ||
1730 | } else { | 1732 | } else { |
1731 | emit tempDisableBR(false); | 1733 | emit tempDisableBR(false); |
1732 | return; | 1734 | return; |
1733 | } | 1735 | } |
1734 | if ( loadSuccess ) { | 1736 | if ( loadSuccess ) { |
1735 | getEventViewerDialog()->setSyncMode( true ); | 1737 | getEventViewerDialog()->setSyncMode( true ); |
1736 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); | 1738 | syncOK = synchronizeCalendar( mCalendar, calendar, mSyncManager->mSyncAlgoPrefs ); |
1737 | getEventViewerDialog()->setSyncMode( false ); | 1739 | getEventViewerDialog()->setSyncMode( false ); |
1738 | qApp->processEvents(); | 1740 | qApp->processEvents(); |
1739 | if ( syncOK ) { | 1741 | if ( syncOK ) { |
1740 | if ( mSyncManager->mWriteBackFile ) | 1742 | if ( mSyncManager->mWriteBackFile ) |
1741 | { | 1743 | { |
1742 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); | 1744 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); |
1743 | Incidence* inc = iL.first(); | 1745 | Incidence* inc = iL.first(); |
1744 | if ( phoneFormat ) { | 1746 | if ( phoneFormat ) { |
1745 | while ( inc ) { | 1747 | while ( inc ) { |
1746 | inc->removeID(mCurrentSyncDevice); | 1748 | inc->removeID(mCurrentSyncDevice); |
1747 | inc = iL.next(); | 1749 | inc = iL.next(); |
1748 | } | 1750 | } |
1749 | } | 1751 | } |
1750 | #ifndef DESKTOP_VERSION | 1752 | #ifndef DESKTOP_VERSION |
1751 | if ( sharpFormat ) | 1753 | if ( sharpFormat ) |
1752 | sharpFormat->save(calendar); | 1754 | sharpFormat->save(calendar); |
1753 | #endif | 1755 | #endif |
1754 | if ( phoneFormat ) | 1756 | if ( phoneFormat ) |
1755 | phoneFormat->save(calendar); | 1757 | phoneFormat->save(calendar); |
1756 | iL = calendar->rawIncidences(); | 1758 | iL = calendar->rawIncidences(); |
1757 | inc = iL.first(); | 1759 | inc = iL.first(); |
1758 | Incidence* loc; | 1760 | Incidence* loc; |
1759 | while ( inc ) { | 1761 | while ( inc ) { |
1760 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { | 1762 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { |
1761 | loc = mCalendar->incidence(inc->uid() ); | 1763 | loc = mCalendar->incidence(inc->uid() ); |
1762 | if ( loc ) { | 1764 | if ( loc ) { |
1763 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); | 1765 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); |
1764 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); | 1766 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); |
1765 | } | 1767 | } |
1766 | } | 1768 | } |
1767 | inc = iL.next(); | 1769 | inc = iL.next(); |
1768 | } | 1770 | } |
1769 | Incidence* lse = getLastSyncEvent(); | 1771 | Incidence* lse = getLastSyncEvent(); |
1770 | if ( lse ) { | 1772 | if ( lse ) { |
1771 | lse->setReadOnly( false ); | 1773 | lse->setReadOnly( false ); |
1772 | lse->setDescription( "" ); | 1774 | lse->setDescription( "" ); |
1773 | lse->setReadOnly( true ); | 1775 | lse->setReadOnly( true ); |
1774 | } | 1776 | } |
1775 | } | 1777 | } |
1776 | } else { | 1778 | } else { |
1777 | topLevelWidget()->setCaption( i18n("Sync cancelled or failed.") ); | 1779 | topLevelWidget()->setCaption( i18n("Sync cancelled or failed.") ); |
1778 | } | 1780 | } |
1779 | setModified( true ); | 1781 | setModified( true ); |
1780 | } else { | 1782 | } else { |
1781 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; | 1783 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; |
1782 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), | 1784 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), |
1783 | question, i18n("Ok")) ; | 1785 | question, i18n("Ok")) ; |
1784 | 1786 | ||
1785 | } | 1787 | } |
1786 | delete calendar; | 1788 | delete calendar; |
1787 | updateView(); | 1789 | updateView(); |
1788 | emit tempDisableBR(false); | 1790 | emit tempDisableBR(false); |
1789 | return ;//syncOK; | 1791 | return ;//syncOK; |
1790 | 1792 | ||
1791 | } | 1793 | } |
1792 | 1794 | ||
1793 | bool CalendarView::importBday() | 1795 | bool CalendarView::importBday() |
1794 | { | 1796 | { |
1795 | #ifndef KORG_NOKABC | 1797 | #ifndef KORG_NOKABC |
1796 | 1798 | ||
1797 | #ifdef DESKTOP_VERSION | 1799 | #ifdef DESKTOP_VERSION |
1798 | int curCal = mCalendar->defaultCalendar(); | 1800 | int curCal = mCalendar->defaultCalendar(); |
1799 | int bd = mCalEditView->getBirtdayID(); | 1801 | int bd = mCalEditView->getBirtdayID(); |
1800 | if ( bd == 0 ) | 1802 | if ( bd == 0 ) |
1801 | return false; | 1803 | return false; |
1802 | mCalendar->setDefaultCalendar( bd ); | 1804 | mCalendar->setDefaultCalendar( bd ); |
1803 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); | 1805 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); |
1804 | KABC::AddressBook::Iterator it; | 1806 | KABC::AddressBook::Iterator it; |
1805 | int count = 0; | 1807 | int count = 0; |
1806 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1808 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1807 | ++count; | 1809 | ++count; |
1808 | } | 1810 | } |
1809 | QProgressBar bar(count,0 ); | 1811 | QProgressBar bar(count,0 ); |
1810 | int w = 300; | 1812 | int w = 300; |
1811 | if ( QApplication::desktop()->width() < 320 ) | 1813 | if ( QApplication::desktop()->width() < 320 ) |
1812 | w = 220; | 1814 | w = 220; |
1813 | int h = bar.sizeHint().height() ; | 1815 | int h = bar.sizeHint().height() ; |
1814 | int dw = QApplication::desktop()->width(); | 1816 | int dw = QApplication::desktop()->width(); |
1815 | int dh = QApplication::desktop()->height(); | 1817 | int dh = QApplication::desktop()->height(); |
1816 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1818 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1817 | bar.show(); | 1819 | bar.show(); |
1818 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); | 1820 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); |
1819 | qApp->processEvents(); | 1821 | qApp->processEvents(); |
1820 | count = 0; | 1822 | count = 0; |
1821 | int addCount = 0; | 1823 | int addCount = 0; |
1822 | KCal::Attendee* a = 0; | 1824 | KCal::Attendee* a = 0; |
1823 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1825 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1824 | if ( ! bar.isVisible() ) | 1826 | if ( ! bar.isVisible() ) |
1825 | return false; | 1827 | return false; |
1826 | bar.setProgress( count++ ); | 1828 | bar.setProgress( count++ ); |
1827 | qApp->processEvents(); | 1829 | qApp->processEvents(); |
1828 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); | 1830 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); |
1829 | if ( (*it).birthday().date().isValid() ){ | 1831 | if ( (*it).birthday().date().isValid() ){ |
1830 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1832 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1831 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) | 1833 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) |
1832 | ++addCount; | 1834 | ++addCount; |
1833 | } | 1835 | } |
1834 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); | 1836 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); |
1835 | if ( anni.isValid() ){ | 1837 | if ( anni.isValid() ){ |
1836 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1838 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1837 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) | 1839 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) |
1838 | ++addCount; | 1840 | ++addCount; |
1839 | } | 1841 | } |
1840 | } | 1842 | } |
1841 | mCalendar->setDefaultCalendar( curCal ); | 1843 | mCalendar->setDefaultCalendar( curCal ); |
1842 | updateView(); | 1844 | updateView(); |
1843 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); | 1845 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); |
1844 | #else //DESKTOP_VERSION | 1846 | #else //DESKTOP_VERSION |
1845 | 1847 | ||
1846 | ExternalAppHandler::instance()->requestBirthdayListFromKAPI("QPE/Application/kopi", this->name() /* name is here the unique uid*/); | 1848 | ExternalAppHandler::instance()->requestBirthdayListFromKAPI("QPE/Application/kopi", this->name() /* name is here the unique uid*/); |
1847 | // the result should now arrive through method insertBirthdays | 1849 | // the result should now arrive through method insertBirthdays |
1848 | 1850 | ||
1849 | #endif //DESKTOP_VERSION | 1851 | #endif //DESKTOP_VERSION |
1850 | 1852 | ||
1851 | #endif //KORG_NOKABC | 1853 | #endif //KORG_NOKABC |
1852 | 1854 | ||
1853 | 1855 | ||
1854 | return true; | 1856 | return true; |
1855 | } | 1857 | } |
1856 | 1858 | ||
1857 | // This method will be called from Ka/Pi as a response to requestBirthdayListFromKAPI | 1859 | // This method will be called from Ka/Pi as a response to requestBirthdayListFromKAPI |
1858 | void CalendarView::insertBirthdays(const QString& uid, const QStringList& birthdayList, | 1860 | void CalendarView::insertBirthdays(const QString& uid, const QStringList& birthdayList, |
1859 | const QStringList& anniversaryList, const QStringList& realNameList, | 1861 | const QStringList& anniversaryList, const QStringList& realNameList, |
1860 | const QStringList& emailList, const QStringList& assembledNameList, | 1862 | const QStringList& emailList, const QStringList& assembledNameList, |
1861 | const QStringList& uidList) | 1863 | const QStringList& uidList) |
1862 | { | 1864 | { |
1863 | 1865 | ||
1864 | //qDebug("KO::CalendarView::insertBirthdays"); | 1866 | //qDebug("KO::CalendarView::insertBirthdays"); |
1865 | if (uid == this->name()) | 1867 | if (uid == this->name()) |
1866 | { | 1868 | { |
1867 | int curCal = mCalendar->defaultCalendar(); | 1869 | int curCal = mCalendar->defaultCalendar(); |
1868 | int bd = mCalEditView->getBirtdayID(); | 1870 | int bd = mCalEditView->getBirtdayID(); |
1869 | if ( bd == 0 ) | 1871 | if ( bd == 0 ) |
1870 | return; | 1872 | return; |
1871 | mCalendar->setDefaultCalendar( bd ); | 1873 | mCalendar->setDefaultCalendar( bd ); |
1872 | 1874 | ||
1873 | 1875 | ||
1874 | int count = birthdayList.count(); | 1876 | int count = birthdayList.count(); |
1875 | int addCount = 0; | 1877 | int addCount = 0; |
1876 | KCal::Attendee* a = 0; | 1878 | KCal::Attendee* a = 0; |
1877 | 1879 | ||
1878 | //qDebug("CalView 1 %i", count); | 1880 | //qDebug("CalView 1 %i", count); |
1879 | 1881 | ||
1880 | QProgressBar bar(count,0 ); | 1882 | QProgressBar bar(count,0 ); |
1881 | int w = 300; | 1883 | int w = 300; |
1882 | if ( QApplication::desktop()->width() < 320 ) | 1884 | if ( QApplication::desktop()->width() < 320 ) |
1883 | w = 220; | 1885 | w = 220; |
1884 | int h = bar.sizeHint().height() ; | 1886 | int h = bar.sizeHint().height() ; |
1885 | int dw = QApplication::desktop()->width(); | 1887 | int dw = QApplication::desktop()->width(); |
1886 | int dh = QApplication::desktop()->height(); | 1888 | int dh = QApplication::desktop()->height(); |
1887 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1889 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1888 | bar.show(); | 1890 | bar.show(); |
1889 | bar.setCaption (i18n("inserting birthdays - close to abort!") ); | 1891 | bar.setCaption (i18n("inserting birthdays - close to abort!") ); |
1890 | qApp->processEvents(); | 1892 | qApp->processEvents(); |
1891 | 1893 | ||
1892 | QDate birthday; | 1894 | QDate birthday; |
1893 | QDate anniversary; | 1895 | QDate anniversary; |
1894 | QString realName; | 1896 | QString realName; |
1895 | QString email; | 1897 | QString email; |
1896 | QString assembledName; | 1898 | QString assembledName; |
1897 | QString uid; | 1899 | QString uid; |
1898 | bool ok = true; | 1900 | bool ok = true; |
1899 | for ( int i = 0; i < count; i++) | 1901 | for ( int i = 0; i < count; i++) |
1900 | { | 1902 | { |
1901 | if ( ! bar.isVisible() ) | 1903 | if ( ! bar.isVisible() ) |
1902 | return; | 1904 | return; |
1903 | bar.setProgress( i ); | 1905 | bar.setProgress( i ); |
1904 | qApp->processEvents(); | 1906 | qApp->processEvents(); |
1905 | 1907 | ||
1906 | birthday = KGlobal::locale()->readDate(birthdayList[i], KLocale::ISODate, &ok); | 1908 | birthday = KGlobal::locale()->readDate(birthdayList[i], KLocale::ISODate, &ok); |
1907 | if (!ok) { | 1909 | if (!ok) { |
1908 | ;//qDebug("CalendarView::insertBirthdays found invalid birthday: %s",birthdayList[i].latin1()); | 1910 | ;//qDebug("CalendarView::insertBirthdays found invalid birthday: %s",birthdayList[i].latin1()); |
1909 | } | 1911 | } |
1910 | 1912 | ||
1911 | anniversary = KGlobal::locale()->readDate(anniversaryList[i], KLocale::ISODate, &ok); | 1913 | anniversary = KGlobal::locale()->readDate(anniversaryList[i], KLocale::ISODate, &ok); |
1912 | if (!ok) { | 1914 | if (!ok) { |
1913 | ;//qDebug("CalendarView::insertBirthdays found invalid anniversary: %s",anniversaryList[i].latin1()); | 1915 | ;//qDebug("CalendarView::insertBirthdays found invalid anniversary: %s",anniversaryList[i].latin1()); |
1914 | } | 1916 | } |
1915 | realName = realNameList[i]; | 1917 | realName = realNameList[i]; |
1916 | email = emailList[i]; | 1918 | email = emailList[i]; |
1917 | assembledName = assembledNameList[i]; | 1919 | assembledName = assembledNameList[i]; |
1918 | uid = uidList[i]; | 1920 | uid = uidList[i]; |
1919 | //qDebug("insert birthday in KO/Pi: %s,%s,%s,%s: %s, %s", realName.latin1(), email.latin1(), assembledName.latin1(), uid.latin1(), birthdayList[i].latin1(), anniversaryList[i].latin1() ); | 1921 | //qDebug("insert birthday in KO/Pi: %s,%s,%s,%s: %s, %s", realName.latin1(), email.latin1(), assembledName.latin1(), uid.latin1(), birthdayList[i].latin1(), anniversaryList[i].latin1() ); |
1920 | 1922 | ||
1921 | if ( birthday.isValid() ){ | 1923 | if ( birthday.isValid() ){ |
1922 | a = new KCal::Attendee( realName, email,false,KCal::Attendee::NeedsAction, | 1924 | a = new KCal::Attendee( realName, email,false,KCal::Attendee::NeedsAction, |
1923 | KCal::Attendee::ReqParticipant,uid) ; | 1925 | KCal::Attendee::ReqParticipant,uid) ; |
1924 | if ( addAnniversary( birthday, assembledName, a, true ) ) | 1926 | if ( addAnniversary( birthday, assembledName, a, true ) ) |
1925 | ++addCount; | 1927 | ++addCount; |
1926 | } | 1928 | } |
1927 | 1929 | ||
1928 | if ( anniversary.isValid() ){ | 1930 | if ( anniversary.isValid() ){ |
1929 | a = new KCal::Attendee( realName, email,false,KCal::Attendee::NeedsAction, | 1931 | a = new KCal::Attendee( realName, email,false,KCal::Attendee::NeedsAction, |
1930 | KCal::Attendee::ReqParticipant,uid) ; | 1932 | KCal::Attendee::ReqParticipant,uid) ; |
1931 | if ( addAnniversary( anniversary, assembledName, a, false ) ) | 1933 | if ( addAnniversary( anniversary, assembledName, a, false ) ) |
1932 | ++addCount; | 1934 | ++addCount; |
1933 | } | 1935 | } |
1934 | } | 1936 | } |
1935 | 1937 | ||
1936 | mCalendar->setDefaultCalendar( curCal ); | 1938 | mCalendar->setDefaultCalendar( curCal ); |