-rw-r--r-- | korganizer/calendarview.cpp | 47 | ||||
-rw-r--r-- | korganizer/calendarview.h | 2 | ||||
-rw-r--r-- | korganizer/kodialogmanager.cpp | 4 | ||||
-rw-r--r-- | korganizer/kolistview.cpp | 3 | ||||
-rw-r--r-- | korganizer/mainwindow.cpp | 17 | ||||
-rw-r--r-- | korganizer/mainwindow.h | 2 |
6 files changed, 36 insertions, 39 deletions
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index fd026fa..70a1d2d 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -738,97 +738,97 @@ void CalendarView::checkAlarms() | |||
738 | MissedAlarmTextBrowser* matb = new MissedAlarmTextBrowser ( dia, al, latest ); | 738 | MissedAlarmTextBrowser* matb = new MissedAlarmTextBrowser ( dia, al, latest ); |
739 | connect( matb, SIGNAL( showIncidence( QString ) ),SLOT( showIncidence( QString ) )); | 739 | connect( matb, SIGNAL( showIncidence( QString ) ),SLOT( showIncidence( QString ) )); |
740 | lay->addWidget( matb ); | 740 | lay->addWidget( matb ); |
741 | if ( QApplication::desktop()->width() == 480 || QApplication::desktop()->width() == 640 ) { | 741 | if ( QApplication::desktop()->width() == 480 || QApplication::desktop()->width() == 640 ) { |
742 | int wid = 210; | 742 | int wid = 210; |
743 | int x = QApplication::desktop()->width() - wid - 7; | 743 | int x = QApplication::desktop()->width() - wid - 7; |
744 | int y = QApplication::desktop()->height() - wid - 70; | 744 | int y = QApplication::desktop()->height() - wid - 70; |
745 | dia->setGeometry ( x,y,wid,wid); | 745 | dia->setGeometry ( x,y,wid,wid); |
746 | } else { | 746 | } else { |
747 | int si = 220; | 747 | int si = 220; |
748 | if ( QApplication::desktop()->width() > 470 ) | 748 | if ( QApplication::desktop()->width() > 470 ) |
749 | si = 400; | 749 | si = 400; |
750 | dia->resize(si,si/2); | 750 | dia->resize(si,si/2); |
751 | } | 751 | } |
752 | dia->setBackgroundColor( QColor( 255, 255, 255 ) ); | 752 | dia->setBackgroundColor( QColor( 255, 255, 255 ) ); |
753 | dia->show(); | 753 | dia->show(); |
754 | 754 | ||
755 | } | 755 | } |
756 | } | 756 | } |
757 | void CalendarView::showDay( QDate d ) | 757 | void CalendarView::showDay( QDate d ) |
758 | { | 758 | { |
759 | dateNavigator()->blockSignals( true ); | 759 | dateNavigator()->blockSignals( true ); |
760 | dateNavigator()->selectDate( d ); | 760 | dateNavigator()->selectDate( d ); |
761 | dateNavigator()->blockSignals( false ); | 761 | dateNavigator()->blockSignals( false ); |
762 | mViewManager->showDayView(); | 762 | mViewManager->showDayView(); |
763 | //dateNavigator()->selectDate( d ); | 763 | //dateNavigator()->selectDate( d ); |
764 | } | 764 | } |
765 | void CalendarView::timerAlarm() | 765 | void CalendarView::timerAlarm() |
766 | { | 766 | { |
767 | //qDebug("CalendarView::timerAlarm() "); | 767 | //qDebug("CalendarView::timerAlarm() "); |
768 | computeAlarm(mAlarmNotification ); | 768 | computeAlarm(mAlarmNotification ); |
769 | } | 769 | } |
770 | 770 | ||
771 | void CalendarView::suspendAlarm() | 771 | void CalendarView::suspendAlarm() |
772 | { | 772 | { |
773 | //qDebug(" CalendarView::suspendAlarm() "); | 773 | //qDebug(" CalendarView::suspendAlarm() "); |
774 | computeAlarm(mSuspendAlarmNotification ); | 774 | computeAlarm(mSuspendAlarmNotification ); |
775 | 775 | ||
776 | } | 776 | } |
777 | 777 | ||
778 | void CalendarView::startAlarm( QString mess , QString filename) | 778 | void CalendarView::startAlarm( QString mess , QString filename) |
779 | { | 779 | { |
780 | 780 | ||
781 | topLevelWidget()->showNormal(); | 781 | topLevelWidget()->showNormal(); |
782 | topLevelWidget()->setActiveWindow(); | 782 | topLevelWidget()->setActiveWindow(); |
783 | topLevelWidget()->raise(); | 783 | topLevelWidget()->raise(); |
784 | 784 | ||
785 | mAlarmDialog->eventNotification( mess, KOPrefs::instance()->mAlarmPlayBeeps, filename, true,KOPrefs::instance()->mAlarmBeepInterval ,KOPrefs::instance()->mAlarmSuspendCount ); | 785 | mAlarmDialog->eventNotification( mess, KOPrefs::instance()->mAlarmPlayBeeps, filename, true,KOPrefs::instance()->mAlarmBeepInterval ,KOPrefs::instance()->mAlarmSuspendCount ); |
786 | QTimer::singleShot( 3000, this, SLOT( checkNextTimerAlarm() ) ); | 786 | QTimer::singleShot( 2000, this, SLOT( checkNextTimerAlarm() ) ); |
787 | 787 | ||
788 | } | 788 | } |
789 | 789 | ||
790 | void CalendarView::checkNextTimerAlarm() | 790 | void CalendarView::checkNextTimerAlarm() |
791 | { | 791 | { |
792 | mCalendar->checkAlarmForIncidence( 0, true ); | 792 | mCalendar->checkAlarmForIncidence( 0, true ); |
793 | } | 793 | } |
794 | 794 | ||
795 | void CalendarView::computeAlarm( QString msg ) | 795 | void CalendarView::computeAlarm( QString msg ) |
796 | { | 796 | { |
797 | 797 | ||
798 | QString mess = msg; | 798 | QString mess = msg; |
799 | QString mAlarmMessage = mess.mid( 9 ); | 799 | QString mAlarmMessage = mess.mid( 9 ); |
800 | QString filename = MainWindow::resourcePath(); | 800 | QString filename = MainWindow::resourcePath(); |
801 | filename += "koalarm.wav"; | 801 | filename += "koalarm.wav"; |
802 | QString tempfilename; | 802 | QString tempfilename; |
803 | if ( mess.left( 13 ) == "suspend_alarm") { | 803 | if ( mess.left( 13 ) == "suspend_alarm") { |
804 | bool error = false; | 804 | bool error = false; |
805 | int len = mess.mid( 13 ).find("+++"); | 805 | int len = mess.mid( 13 ).find("+++"); |
806 | if ( len < 2 ) | 806 | if ( len < 2 ) |
807 | error = true; | 807 | error = true; |
808 | else { | 808 | else { |
809 | tempfilename = mess.mid( 13, len ); | 809 | tempfilename = mess.mid( 13, len ); |
810 | if ( !QFile::exists( tempfilename ) ) | 810 | if ( !QFile::exists( tempfilename ) ) |
811 | error = true; | 811 | error = true; |
812 | } | 812 | } |
813 | if ( ! error ) { | 813 | if ( ! error ) { |
814 | filename = tempfilename; | 814 | filename = tempfilename; |
815 | } | 815 | } |
816 | mAlarmMessage = mess.mid( 13+len+3 ); | 816 | mAlarmMessage = mess.mid( 13+len+3 ); |
817 | //qDebug("suspend file %s ",tempfilename.latin1() ); | 817 | //qDebug("suspend file %s ",tempfilename.latin1() ); |
818 | startAlarm( mAlarmMessage, filename); | 818 | startAlarm( mAlarmMessage, filename); |
819 | return; | 819 | return; |
820 | } | 820 | } |
821 | if ( mess.left( 11 ) == "timer_alarm") { | 821 | if ( mess.left( 11 ) == "timer_alarm") { |
822 | //mTimerTime = 0; | 822 | //mTimerTime = 0; |
823 | startAlarm( mess.mid( 11 ), filename ); | 823 | startAlarm( mess.mid( 11 ), filename ); |
824 | return; | 824 | return; |
825 | } | 825 | } |
826 | if ( mess.left( 10 ) == "proc_alarm") { | 826 | if ( mess.left( 10 ) == "proc_alarm") { |
827 | bool error = false; | 827 | bool error = false; |
828 | int len = mess.mid( 10 ).find("+++"); | 828 | int len = mess.mid( 10 ).find("+++"); |
829 | if ( len < 2 ) | 829 | if ( len < 2 ) |
830 | error = true; | 830 | error = true; |
831 | else { | 831 | else { |
832 | tempfilename = mess.mid( 10, len ); | 832 | tempfilename = mess.mid( 10, len ); |
833 | if ( !QFile::exists( tempfilename ) ) | 833 | if ( !QFile::exists( tempfilename ) ) |
834 | error = true; | 834 | error = true; |
@@ -881,102 +881,106 @@ void CalendarView::computeAlarm( QString msg ) | |||
881 | 881 | ||
882 | } | 882 | } |
883 | 883 | ||
884 | void CalendarView::addSuspendAlarm(const QDateTime &qdt, const QString ¬i ) | 884 | void CalendarView::addSuspendAlarm(const QDateTime &qdt, const QString ¬i ) |
885 | { | 885 | { |
886 | //qDebug("+++++addSUSPENDAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); | 886 | //qDebug("+++++addSUSPENDAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); |
887 | 887 | ||
888 | mSuspendAlarmNotification = noti; | 888 | mSuspendAlarmNotification = noti; |
889 | int ms = QDateTime::currentDateTime().secsTo( qdt )*1000; | 889 | int ms = QDateTime::currentDateTime().secsTo( qdt )*1000; |
890 | //qDebug("Suspend Alarm timer started with secs: %d ", ms/1000); | 890 | //qDebug("Suspend Alarm timer started with secs: %d ", ms/1000); |
891 | mSuspendTimer->start( ms , true ); | 891 | mSuspendTimer->start( ms , true ); |
892 | 892 | ||
893 | } | 893 | } |
894 | 894 | ||
895 | void CalendarView::addAlarm(const QDateTime &qdt, const QString ¬i ) | 895 | void CalendarView::addAlarm(const QDateTime &qdt, const QString ¬i ) |
896 | { | 896 | { |
897 | mNextAlarmDateTime = qdt; | 897 | mNextAlarmDateTime = qdt; |
898 | //qDebug("+++++addAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); | 898 | //qDebug("+++++addAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); |
899 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { | 899 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { |
900 | #ifndef DESKTOP_VERSION | 900 | #ifndef DESKTOP_VERSION |
901 | AlarmServer::addAlarm ( qdt,"koalarm", noti.utf8() ); | 901 | AlarmServer::addAlarm ( qdt,"koalarm", noti.utf8() ); |
902 | #endif | 902 | #endif |
903 | return; | 903 | return; |
904 | } | 904 | } |
905 | int maxSec; | 905 | int maxSec; |
906 | //maxSec = 5; //testing only | 906 | //maxSec = 5; //testing only |
907 | maxSec = 86400+3600; // one day+1hour | 907 | maxSec = 86400+3600; // one day+1hour |
908 | mAlarmNotification = noti; | 908 | mAlarmNotification = noti; |
909 | int sec = QDateTime::currentDateTime().secsTo( qdt ); | 909 | int sec = QDateTime::currentDateTime().secsTo( qdt ); |
910 | if ( sec > maxSec ) { | 910 | if ( sec > maxSec ) { |
911 | mRecheckAlarmTimer->start( maxSec * 1000 ); | 911 | mRecheckAlarmTimer->start( maxSec * 1000 ); |
912 | // qDebug("recheck Alarm timer started with secs: %d next alarm in sec:%d", maxSec,sec ); | 912 | // qDebug("recheck Alarm timer started with secs: %d next alarm in sec:%d", maxSec,sec ); |
913 | return; | 913 | return; |
914 | } else { | 914 | } else { |
915 | mRecheckAlarmTimer->stop(); | 915 | mRecheckAlarmTimer->stop(); |
916 | } | 916 | } |
917 | //qDebug("Alarm timer started with secs: %d ", sec); | 917 | //qDebug("Alarm timer started with secs: %d ", sec); |
918 | mAlarmTimer->start( sec *1000 , true ); | 918 | mAlarmTimer->start( sec *1000 , true ); |
919 | 919 | ||
920 | } | 920 | } |
921 | // called by mRecheckAlarmTimer to get next alarm | 921 | // called by mRecheckAlarmTimer to get next alarm |
922 | // we need this, because a QTimer has only a max range of 25 days | 922 | // we need this, because a QTimer has only a max range of 25 days |
923 | void CalendarView::recheckTimerAlarm() | 923 | void CalendarView::recheckTimerAlarm() |
924 | { | 924 | { |
925 | mAlarmTimer->stop(); | 925 | mAlarmTimer->stop(); |
926 | mRecheckAlarmTimer->stop(); | 926 | mRecheckAlarmTimer->stop(); |
927 | mCalendar->checkAlarmForIncidence( 0, true ); | 927 | mCalendar->checkAlarmForIncidence( 0, true ); |
928 | } | 928 | } |
929 | #ifndef DESKTOP_VERSION | ||
929 | void CalendarView::removeAlarm(const QDateTime &qdt, const QString ¬i ) | 930 | void CalendarView::removeAlarm(const QDateTime &qdt, const QString ¬i ) |
931 | #else | ||
932 | void CalendarView::removeAlarm(const QDateTime &, const QString & ) | ||
933 | #endif | ||
930 | { | 934 | { |
931 | //qDebug("-----removeAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); | 935 | //qDebug("-----removeAlarm %s %s ", qdt.toString().latin1() , noti.latin1() ); |
932 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { | 936 | if ( ! KOPrefs::instance()->mUseInternalAlarmNotification ) { |
933 | #ifndef DESKTOP_VERSION | 937 | #ifndef DESKTOP_VERSION |
934 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.latin1() ); | 938 | AlarmServer::deleteAlarm (qdt ,"koalarm" ,noti.utf8() ); |
935 | #endif | 939 | #endif |
936 | return; | 940 | return; |
937 | } | 941 | } |
938 | mAlarmTimer->stop(); | 942 | mAlarmTimer->stop(); |
939 | } | 943 | } |
940 | void CalendarView::selectWeekNum ( int num ) | 944 | void CalendarView::selectWeekNum ( int num ) |
941 | { | 945 | { |
942 | dateNavigator()->blockSignals( true ); | 946 | dateNavigator()->blockSignals( true ); |
943 | dateNavigator()->selectWeek( num ); | 947 | dateNavigator()->selectWeek( num ); |
944 | dateNavigator()->blockSignals( false ); | 948 | dateNavigator()->blockSignals( false ); |
945 | mViewManager->showWeekView(); | 949 | mViewManager->showWeekView(); |
946 | } | 950 | } |
947 | KOViewManager *CalendarView::viewManager() | 951 | KOViewManager *CalendarView::viewManager() |
948 | { | 952 | { |
949 | return mViewManager; | 953 | return mViewManager; |
950 | } | 954 | } |
951 | 955 | ||
952 | KODialogManager *CalendarView::dialogManager() | 956 | KODialogManager *CalendarView::dialogManager() |
953 | { | 957 | { |
954 | return mDialogManager; | 958 | return mDialogManager; |
955 | } | 959 | } |
956 | 960 | ||
957 | QDate CalendarView::startDate() | 961 | QDate CalendarView::startDate() |
958 | { | 962 | { |
959 | DateList dates = mNavigator->selectedDates(); | 963 | DateList dates = mNavigator->selectedDates(); |
960 | 964 | ||
961 | return dates.first(); | 965 | return dates.first(); |
962 | } | 966 | } |
963 | 967 | ||
964 | QDate CalendarView::endDate() | 968 | QDate CalendarView::endDate() |
965 | { | 969 | { |
966 | DateList dates = mNavigator->selectedDates(); | 970 | DateList dates = mNavigator->selectedDates(); |
967 | 971 | ||
968 | return dates.last(); | 972 | return dates.last(); |
969 | } | 973 | } |
970 | 974 | ||
971 | 975 | ||
972 | void CalendarView::createPrinter() | 976 | void CalendarView::createPrinter() |
973 | { | 977 | { |
974 | #ifndef KORG_NOPRINTER | 978 | #ifndef KORG_NOPRINTER |
975 | if (!mCalPrinter) { | 979 | if (!mCalPrinter) { |
976 | mCalPrinter = new CalPrinter(this, mCalendar); | 980 | mCalPrinter = new CalPrinter(this, mCalendar); |
977 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); | 981 | connect(this, SIGNAL(configChanged()), mCalPrinter, SLOT(updateConfig())); |
978 | } | 982 | } |
979 | #endif | 983 | #endif |
980 | } | 984 | } |
981 | 985 | ||
982 | 986 | ||
@@ -1165,97 +1169,96 @@ void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* t | |||
1165 | { | 1169 | { |
1166 | if ( lastSync.count() == 0 ) { | 1170 | if ( lastSync.count() == 0 ) { |
1167 | //qDebug(" lastSync.count() == 0"); | 1171 | //qDebug(" lastSync.count() == 0"); |
1168 | return; | 1172 | return; |
1169 | } | 1173 | } |
1170 | if ( toDelete->typeID() == journalID ) | 1174 | if ( toDelete->typeID() == journalID ) |
1171 | return; | 1175 | return; |
1172 | 1176 | ||
1173 | Event* eve = lastSync.first(); | 1177 | Event* eve = lastSync.first(); |
1174 | 1178 | ||
1175 | while ( eve ) { | 1179 | while ( eve ) { |
1176 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name | 1180 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name |
1177 | if ( !id.isEmpty() ) { | 1181 | if ( !id.isEmpty() ) { |
1178 | QString des = eve->description(); | 1182 | QString des = eve->description(); |
1179 | QString pref = "e"; | 1183 | QString pref = "e"; |
1180 | if ( toDelete->typeID() == todoID ) | 1184 | if ( toDelete->typeID() == todoID ) |
1181 | pref = "t"; | 1185 | pref = "t"; |
1182 | des += pref+ id + ","; | 1186 | des += pref+ id + ","; |
1183 | eve->setReadOnly( false ); | 1187 | eve->setReadOnly( false ); |
1184 | eve->setDescription( des ); | 1188 | eve->setDescription( des ); |
1185 | //qDebug("setdes %s ", des.latin1()); | 1189 | //qDebug("setdes %s ", des.latin1()); |
1186 | eve->setReadOnly( true ); | 1190 | eve->setReadOnly( true ); |
1187 | } | 1191 | } |
1188 | eve = lastSync.next(); | 1192 | eve = lastSync.next(); |
1189 | } | 1193 | } |
1190 | 1194 | ||
1191 | } | 1195 | } |
1192 | void CalendarView::checkExternalId( Incidence * inc ) | 1196 | void CalendarView::checkExternalId( Incidence * inc ) |
1193 | { | 1197 | { |
1194 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; | 1198 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; |
1195 | checkExternSyncEvent( lastSync, inc ); | 1199 | checkExternSyncEvent( lastSync, inc ); |
1196 | 1200 | ||
1197 | } | 1201 | } |
1198 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) | 1202 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) |
1199 | { | 1203 | { |
1200 | bool syncOK = true; | 1204 | bool syncOK = true; |
1201 | int addedEvent = 0; | 1205 | int addedEvent = 0; |
1202 | int addedEventR = 0; | 1206 | int addedEventR = 0; |
1203 | int deletedEventR = 0; | 1207 | int deletedEventR = 0; |
1204 | int deletedEventL = 0; | 1208 | int deletedEventL = 0; |
1205 | int changedLocal = 0; | 1209 | int changedLocal = 0; |
1206 | int changedRemote = 0; | 1210 | int changedRemote = 0; |
1207 | int filteredIN = 0; | 1211 | int filteredIN = 0; |
1208 | int filteredOUT = 0; | 1212 | int filteredOUT = 0; |
1209 | //QPtrList<Event> el = local->rawEvents(); | 1213 | //QPtrList<Event> el = local->rawEvents(); |
1210 | Event* eventR; | 1214 | Event* eventR; |
1211 | QString uid; | 1215 | QString uid; |
1212 | int take; | 1216 | int take; |
1213 | Event* eventL; | ||
1214 | Event* eventRSync; | 1217 | Event* eventRSync; |
1215 | Event* eventLSync; | 1218 | Event* eventLSync; |
1216 | clearAllViews(); | 1219 | clearAllViews(); |
1217 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); | 1220 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); |
1218 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); | 1221 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); |
1219 | bool fullDateRange = false; | 1222 | bool fullDateRange = false; |
1220 | local->resetTempSyncStat(); | 1223 | local->resetTempSyncStat(); |
1221 | mLastCalendarSync = QDateTime::currentDateTime(); | 1224 | mLastCalendarSync = QDateTime::currentDateTime(); |
1222 | if ( mSyncManager->syncWithDesktop() ) { | 1225 | if ( mSyncManager->syncWithDesktop() ) { |
1223 | remote->resetPilotStat(1); | 1226 | remote->resetPilotStat(1); |
1224 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { | 1227 | if ( KSyncManager::mRequestedSyncEvent.isValid() ) { |
1225 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; | 1228 | mLastCalendarSync = KSyncManager::mRequestedSyncEvent; |
1226 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); | 1229 | qDebug("KO: using extern time for calendar sync: %s ", mLastCalendarSync.toString().latin1() ); |
1227 | } else { | 1230 | } else { |
1228 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); | 1231 | qDebug("KSyncManager::mRequestedSyncEvent has invalid datatime "); |
1229 | } | 1232 | } |
1230 | } | 1233 | } |
1231 | QDateTime modifiedCalendar = mLastCalendarSync; | 1234 | QDateTime modifiedCalendar = mLastCalendarSync; |
1232 | eventLSync = getLastSyncEvent(); | 1235 | eventLSync = getLastSyncEvent(); |
1233 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); | 1236 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); |
1234 | if ( eventR ) { | 1237 | if ( eventR ) { |
1235 | eventRSync = (Event*) eventR->clone(); | 1238 | eventRSync = (Event*) eventR->clone(); |
1236 | remote->deleteEvent(eventR ); | 1239 | remote->deleteEvent(eventR ); |
1237 | 1240 | ||
1238 | } else { | 1241 | } else { |
1239 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { | 1242 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL || mSyncManager->syncWithDesktop()) { |
1240 | eventRSync = (Event*)eventLSync->clone(); | 1243 | eventRSync = (Event*)eventLSync->clone(); |
1241 | } else { | 1244 | } else { |
1242 | fullDateRange = true; | 1245 | fullDateRange = true; |
1243 | eventRSync = new Event(); | 1246 | eventRSync = new Event(); |
1244 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); | 1247 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); |
1245 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); | 1248 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); |
1246 | eventRSync->setDtStart( mLastCalendarSync ); | 1249 | eventRSync->setDtStart( mLastCalendarSync ); |
1247 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 1250 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
1248 | eventRSync->setCategories( i18n("SyncEvent") ); | 1251 | eventRSync->setCategories( i18n("SyncEvent") ); |
1249 | } | 1252 | } |
1250 | } | 1253 | } |
1251 | if ( eventLSync->dtStart() == mLastCalendarSync ) | 1254 | if ( eventLSync->dtStart() == mLastCalendarSync ) |
1252 | fullDateRange = true; | 1255 | fullDateRange = true; |
1253 | 1256 | ||
1254 | if ( ! fullDateRange ) { | 1257 | if ( ! fullDateRange ) { |
1255 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { | 1258 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { |
1256 | 1259 | ||
1257 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); | 1260 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); |
1258 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); | 1261 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); |
1259 | fullDateRange = true; | 1262 | fullDateRange = true; |
1260 | } | 1263 | } |
1261 | } | 1264 | } |
@@ -2265,101 +2268,106 @@ void CalendarView::readSettings() | |||
2265 | } | 2268 | } |
2266 | if ( resetval ) { | 2269 | if ( resetval ) { |
2267 | sizes.clear(); | 2270 | sizes.clear(); |
2268 | if ( KOPrefs::instance()->mVerticalScreen ) { | 2271 | if ( KOPrefs::instance()->mVerticalScreen ) { |
2269 | maxVal = QApplication::desktop()->width() -10; | 2272 | maxVal = QApplication::desktop()->width() -10; |
2270 | } else { | 2273 | } else { |
2271 | maxVal = QApplication::desktop()->height()-10; | 2274 | maxVal = QApplication::desktop()->height()-10; |
2272 | } | 2275 | } |
2273 | sizes << resetval; | 2276 | sizes << resetval; |
2274 | if ( maxVal < resetval + resetval) | 2277 | if ( maxVal < resetval + resetval) |
2275 | resetval = maxVal - resetval; | 2278 | resetval = maxVal - resetval; |
2276 | sizes << resetval; | 2279 | sizes << resetval; |
2277 | sizes << 100; | 2280 | sizes << 100; |
2278 | } | 2281 | } |
2279 | mLeftFrame->setSizes(sizes); | 2282 | mLeftFrame->setSizes(sizes); |
2280 | sizes = config->readIntListEntry("Main Splitter Frame"); | 2283 | sizes = config->readIntListEntry("Main Splitter Frame"); |
2281 | resetval = 0; | 2284 | resetval = 0; |
2282 | maxVal = 0; | 2285 | maxVal = 0; |
2283 | if (sizes.count() != 2) { | 2286 | if (sizes.count() != 2) { |
2284 | if ( !KOPrefs::instance()->mVerticalScreen ) { | 2287 | if ( !KOPrefs::instance()->mVerticalScreen ) { |
2285 | resetval = mDateNavigator->sizeHint().width()+2; | 2288 | resetval = mDateNavigator->sizeHint().width()+2; |
2286 | } else { | 2289 | } else { |
2287 | resetval = mDateNavigator->sizeHint().height()+2; | 2290 | resetval = mDateNavigator->sizeHint().height()+2; |
2288 | } | 2291 | } |
2289 | } | 2292 | } |
2290 | if ( resetval ) { | 2293 | if ( resetval ) { |
2291 | sizes.clear(); | 2294 | sizes.clear(); |
2292 | if ( !KOPrefs::instance()->mVerticalScreen ) { | 2295 | if ( !KOPrefs::instance()->mVerticalScreen ) { |
2293 | maxVal = QApplication::desktop()->width() -10; | 2296 | maxVal = QApplication::desktop()->width() -10; |
2294 | } else { | 2297 | } else { |
2295 | maxVal = QApplication::desktop()->height()-10; | 2298 | maxVal = QApplication::desktop()->height()-10; |
2296 | } | 2299 | } |
2297 | sizes << resetval; | 2300 | sizes << resetval; |
2298 | if ( maxVal < resetval + resetval) | 2301 | if ( maxVal < resetval + resetval) |
2299 | resetval = maxVal - resetval; | 2302 | resetval = maxVal - resetval; |
2300 | sizes << resetval; | 2303 | sizes << resetval; |
2301 | } | 2304 | } |
2302 | mMainFrame->setSizes(sizes); | 2305 | mMainFrame->setSizes(sizes); |
2303 | if ( dateCount == 5 ) mNavigator->selectWorkWeek(); | 2306 | if ( dateCount == 5 ) mNavigator->selectWorkWeek(); |
2304 | else if ( dateCount == 7 ) mNavigator->selectWeek(); | 2307 | else if ( dateCount == 7 ) mNavigator->selectWeek(); |
2305 | else mNavigator->selectDates( dateCount ); | 2308 | else mNavigator->selectDates( dateCount ); |
2306 | // mViewManager->readSettings( config ); | 2309 | // mViewManager->readSettings( config ); |
2307 | updateConfig(); | 2310 | updateConfig(); |
2308 | globalFlagBlockAgenda = 2; | 2311 | globalFlagBlockAgenda = 2; |
2309 | mViewManager->readSettings( config ); | 2312 | mViewManager->readSettings( config ); |
2310 | QTimer::singleShot( 1, mDateNavigator, SLOT ( setResizeEnabled() ) ); | 2313 | QTimer::singleShot( 1, mDateNavigator, SLOT ( setResizeEnabled() ) ); |
2311 | } | 2314 | } |
2312 | 2315 | ||
2313 | 2316 | void CalendarView::checkSuspendAlarm() | |
2317 | { | ||
2318 | if ( mSuspendTimer->isActive() ) { | ||
2319 | KMessageBox::information( this, i18n("<b>WARNING:</b> There is a pending suspended alarm!"), i18n("Pending Suspend Alarm")); | ||
2320 | } | ||
2321 | } | ||
2314 | void CalendarView::writeSettings() | 2322 | void CalendarView::writeSettings() |
2315 | { | 2323 | { |
2316 | // kdDebug() << "CalendarView::writeSettings" << endl; | 2324 | // kdDebug() << "CalendarView::writeSettings" << endl; |
2317 | 2325 | ||
2318 | KConfig *config = KOGlobals::config(); | 2326 | KConfig *config = KOGlobals::config(); |
2319 | 2327 | ||
2320 | mViewManager->writeSettings( config ); | 2328 | mViewManager->writeSettings( config ); |
2321 | mTodoList->saveLayout(config,QString("Todo Layout")); | 2329 | mTodoList->saveLayout(config,QString("Todo Layout")); |
2322 | mDialogManager->writeSettings( config ); | 2330 | mDialogManager->writeSettings( config ); |
2323 | //KOPrefs::instance()->usrWriteConfig(); | 2331 | //KOPrefs::instance()->usrWriteConfig(); |
2324 | KOPrefs::instance()->writeConfig(); | 2332 | KOPrefs::instance()->writeConfig(); |
2325 | 2333 | ||
2326 | writeFilterSettings(config); | 2334 | writeFilterSettings(config); |
2327 | config->setGroup( "AppRun" ); | 2335 | config->setGroup( "AppRun" ); |
2328 | QDateTime dt ( QDate (2005,1,1), QTime( 0,0,0 ) ); | 2336 | QDateTime dt ( QDate (2005,1,1), QTime( 0,0,0 ) ); |
2329 | int days = dt.daysTo( QDate::currentDate() ); | 2337 | int days = dt.daysTo( QDate::currentDate() ); |
2330 | dt = dt.addDays( days ); | 2338 | dt = dt.addDays( days ); |
2331 | int secs = dt.secsTo( QDateTime::currentDateTime() ); | 2339 | int secs = dt.secsTo( QDateTime::currentDateTime() ); |
2332 | config->writeEntry( "LatestProgramStopDays", days ); | 2340 | config->writeEntry( "LatestProgramStopDays", days ); |
2333 | config->writeEntry( "LatestProgramStopSecs", secs ); | 2341 | config->writeEntry( "LatestProgramStopSecs", secs ); |
2334 | //qDebug("KO: Writing stop time: %d ", secs); | 2342 | //qDebug("KO: Writing stop time: %d ", secs); |
2335 | //qDebug("KO: Current Time %s ",QDateTime::currentDateTime().toString().latin1() ); | 2343 | //qDebug("KO: Current Time %s ",QDateTime::currentDateTime().toString().latin1() ); |
2336 | //QDateTime latest = dt.addSecs ( secs ); | 2344 | //QDateTime latest = dt.addSecs ( secs ); |
2337 | //qDebug("KO: Termination on %s ", latest.toString().latin1()); | 2345 | //qDebug("KO: Termination on %s ", latest.toString().latin1()); |
2338 | config->setGroup( "Views" ); | 2346 | config->setGroup( "Views" ); |
2339 | config->writeEntry( "ShownDatesCount", mNavigator->selectedDates().count() ); | 2347 | config->writeEntry( "ShownDatesCount", mNavigator->selectedDates().count() ); |
2340 | 2348 | ||
2341 | #if 0 | 2349 | #if 0 |
2342 | qDebug("********************* "); | 2350 | qDebug("********************* "); |
2343 | qDebug("Testcode secsto "); | 2351 | qDebug("Testcode secsto "); |
2344 | QDateTime dt_nodaylight ( QDate (2005,3,26), QTime( 0,0,0 ) ); | 2352 | QDateTime dt_nodaylight ( QDate (2005,3,26), QTime( 0,0,0 ) ); |
2345 | QDateTime dt_daylight ( QDate (2005,3,29), QTime( 0,0,0 ) ); | 2353 | QDateTime dt_daylight ( QDate (2005,3,29), QTime( 0,0,0 ) ); |
2346 | int secsto = dt_nodaylight.secsTo( dt_daylight ); | 2354 | int secsto = dt_nodaylight.secsTo( dt_daylight ); |
2347 | QDateTime dt_daylight_wrong = dt_nodaylight.addSecs( secsto ); | 2355 | QDateTime dt_daylight_wrong = dt_nodaylight.addSecs( secsto ); |
2348 | qDebug("dt nodaylight %s ",dt_nodaylight.toString().latin1() ); | 2356 | qDebug("dt nodaylight %s ",dt_nodaylight.toString().latin1() ); |
2349 | qDebug("dt daylight %s ",dt_daylight.toString().latin1() ); | 2357 | qDebug("dt daylight %s ",dt_daylight.toString().latin1() ); |
2350 | qDebug("dt daylight_wrong %s ",dt_daylight_wrong.toString().latin1() ); | 2358 | qDebug("dt daylight_wrong %s ",dt_daylight_wrong.toString().latin1() ); |
2351 | qDebug("Computed secsTo %d . in minutes: %d . in hours: %d ", secsto, secsto/60, secsto/3600); | 2359 | qDebug("Computed secsTo %d . in minutes: %d . in hours: %d ", secsto, secsto/60, secsto/3600); |
2352 | qDebug("********************* testcode end"); | 2360 | qDebug("********************* testcode end"); |
2353 | 2361 | ||
2354 | #endif | 2362 | #endif |
2355 | 2363 | ||
2356 | QValueList<int> listINT = mLeftFrame->sizes(); | 2364 | QValueList<int> listINT = mLeftFrame->sizes(); |
2357 | config->writeEntry("Left Splitter Frame",listINT); | 2365 | config->writeEntry("Left Splitter Frame",listINT); |
2358 | QValueList<int> listINT2 = mMainFrame->sizes(); | 2366 | QValueList<int> listINT2 = mMainFrame->sizes(); |
2359 | config->writeEntry("Main Splitter Frame",listINT2); | 2367 | config->writeEntry("Main Splitter Frame",listINT2); |
2360 | #ifdef DESKTOP_VERSION | 2368 | #ifdef DESKTOP_VERSION |
2361 | config->setGroup("WidgetLayout"); | 2369 | config->setGroup("WidgetLayout"); |
2362 | QStringList list ;//= config->readListEntry("MainLayout"); | 2370 | QStringList list ;//= config->readListEntry("MainLayout"); |
2363 | int x,y,w,h; | 2371 | int x,y,w,h; |
2364 | QWidget* wid; | 2372 | QWidget* wid; |
2365 | wid = topLevelWidget(); | 2373 | wid = topLevelWidget(); |
@@ -2749,118 +2757,117 @@ void CalendarView::slotSelectPickerDate( QDate d) | |||
2749 | to->setFloats( true ); | 2757 | to->setFloats( true ); |
2750 | to->setHasDueDate( true ); | 2758 | to->setHasDueDate( true ); |
2751 | } | 2759 | } |
2752 | QDateTime dt ( d,tim ); | 2760 | QDateTime dt ( d,tim ); |
2753 | to->setDtDue( dt ); | 2761 | to->setDtDue( dt ); |
2754 | 2762 | ||
2755 | if ( to->hasStartDate() ) { | 2763 | if ( to->hasStartDate() ) { |
2756 | if ( len>0 ) | 2764 | if ( len>0 ) |
2757 | to->setDtStart(to->dtDue().addSecs( -len )); | 2765 | to->setDtStart(to->dtDue().addSecs( -len )); |
2758 | else | 2766 | else |
2759 | if (to->dtStart() > to->dtDue() ) | 2767 | if (to->dtStart() > to->dtDue() ) |
2760 | to->setDtStart(to->dtDue().addDays( -3 )); | 2768 | to->setDtStart(to->dtDue().addDays( -3 )); |
2761 | } | 2769 | } |
2762 | 2770 | ||
2763 | todoChanged( to ); | 2771 | todoChanged( to ); |
2764 | } else { | 2772 | } else { |
2765 | if ( mMoveIncidence->doesRecur() ) { | 2773 | if ( mMoveIncidence->doesRecur() ) { |
2766 | #if 0 | 2774 | #if 0 |
2767 | // PENDING implement this | 2775 | // PENDING implement this |
2768 | Incidence* newInc = mMoveIncidence->recreateCloneException( mMoveIncidenceOldDate ); | 2776 | Incidence* newInc = mMoveIncidence->recreateCloneException( mMoveIncidenceOldDate ); |
2769 | mCalendar()->addIncidence( newInc ); | 2777 | mCalendar()->addIncidence( newInc ); |
2770 | if ( mMoveIncidence->typeID() == todoID ) | 2778 | if ( mMoveIncidence->typeID() == todoID ) |
2771 | emit todoMoved((Todo*)mMoveIncidence, KOGlobals::EVENTEDITED ); | 2779 | emit todoMoved((Todo*)mMoveIncidence, KOGlobals::EVENTEDITED ); |
2772 | else | 2780 | else |
2773 | emit incidenceChanged(mMoveIncidence, KOGlobals::EVENTEDITED); | 2781 | emit incidenceChanged(mMoveIncidence, KOGlobals::EVENTEDITED); |
2774 | mMoveIncidence = newInc; | 2782 | mMoveIncidence = newInc; |
2775 | 2783 | ||
2776 | #endif | 2784 | #endif |
2777 | } | 2785 | } |
2778 | QTime tim = mMoveIncidence->dtStart().time(); | 2786 | QTime tim = mMoveIncidence->dtStart().time(); |
2779 | int secs = mMoveIncidence->dtStart().secsTo( mMoveIncidence->dtEnd()); | 2787 | int secs = mMoveIncidence->dtStart().secsTo( mMoveIncidence->dtEnd()); |
2780 | QDateTime dt ( d,tim ); | 2788 | QDateTime dt ( d,tim ); |
2781 | mMoveIncidence->setDtStart( dt ); | 2789 | mMoveIncidence->setDtStart( dt ); |
2782 | ((Event*)mMoveIncidence)->setDtEnd( dt.addSecs( secs ) ); | 2790 | ((Event*)mMoveIncidence)->setDtEnd( dt.addSecs( secs ) ); |
2783 | changeEventDisplay((Event*)mMoveIncidence, KOGlobals::EVENTEDITED); | 2791 | changeEventDisplay((Event*)mMoveIncidence, KOGlobals::EVENTEDITED); |
2784 | } | 2792 | } |
2785 | 2793 | ||
2786 | mMoveIncidence->setRevision( mMoveIncidence->revision()+1 ); | 2794 | mMoveIncidence->setRevision( mMoveIncidence->revision()+1 ); |
2787 | } | 2795 | } |
2788 | } | 2796 | } |
2789 | 2797 | ||
2790 | void CalendarView::removeCategories() | 2798 | void CalendarView::removeCategories() |
2791 | { | 2799 | { |
2792 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); | 2800 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); |
2793 | QStringList catList = KOPrefs::instance()->mCustomCategories; | 2801 | QStringList catList = KOPrefs::instance()->mCustomCategories; |
2794 | QStringList catIncList; | 2802 | QStringList catIncList; |
2795 | QStringList newCatList; | 2803 | QStringList newCatList; |
2796 | Incidence* inc = incList.first(); | 2804 | Incidence* inc = incList.first(); |
2797 | int i; | 2805 | uint i; |
2798 | int count = 0; | ||
2799 | while ( inc ) { | 2806 | while ( inc ) { |
2800 | newCatList.clear(); | 2807 | newCatList.clear(); |
2801 | catIncList = inc->categories() ; | 2808 | catIncList = inc->categories() ; |
2802 | for( i = 0; i< catIncList.count(); ++i ) { | 2809 | for( i = 0; i< catIncList.count(); ++i ) { |
2803 | if ( catList.contains (catIncList[i])) | 2810 | if ( catList.contains (catIncList[i])) |
2804 | newCatList.append( catIncList[i] ); | 2811 | newCatList.append( catIncList[i] ); |
2805 | } | 2812 | } |
2806 | newCatList.sort(); | 2813 | newCatList.sort(); |
2807 | inc->setCategories( newCatList.join(",") ); | 2814 | inc->setCategories( newCatList.join(",") ); |
2808 | inc = incList.next(); | 2815 | inc = incList.next(); |
2809 | } | 2816 | } |
2810 | } | 2817 | } |
2811 | 2818 | ||
2812 | int CalendarView::addCategories() | 2819 | int CalendarView::addCategories() |
2813 | { | 2820 | { |
2814 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); | 2821 | QPtrList<Incidence> incList = mCalendar->rawIncidences(); |
2815 | QStringList catList = KOPrefs::instance()->mCustomCategories; | 2822 | QStringList catList = KOPrefs::instance()->mCustomCategories; |
2816 | QStringList catIncList; | 2823 | QStringList catIncList; |
2817 | Incidence* inc = incList.first(); | 2824 | Incidence* inc = incList.first(); |
2818 | int i; | 2825 | uint i; |
2819 | int count = 0; | 2826 | int count = 0; |
2820 | while ( inc ) { | 2827 | while ( inc ) { |
2821 | catIncList = inc->categories() ; | 2828 | catIncList = inc->categories() ; |
2822 | for( i = 0; i< catIncList.count(); ++i ) { | 2829 | for( i = 0; i< catIncList.count(); ++i ) { |
2823 | if ( !catList.contains (catIncList[i])) { | 2830 | if ( !catList.contains (catIncList[i])) { |
2824 | catList.append( catIncList[i] ); | 2831 | catList.append( catIncList[i] ); |
2825 | //qDebug("add cat %s ", catIncList[i].latin1()); | 2832 | //qDebug("add cat %s ", catIncList[i].latin1()); |
2826 | ++count; | 2833 | ++count; |
2827 | } | 2834 | } |
2828 | } | 2835 | } |
2829 | inc = incList.next(); | 2836 | inc = incList.next(); |
2830 | } | 2837 | } |
2831 | catList.sort(); | 2838 | catList.sort(); |
2832 | KOPrefs::instance()->mCustomCategories = catList; | 2839 | KOPrefs::instance()->mCustomCategories = catList; |
2833 | return count; | 2840 | return count; |
2834 | } | 2841 | } |
2835 | 2842 | ||
2836 | void CalendarView::editCategories() | 2843 | void CalendarView::editCategories() |
2837 | { | 2844 | { |
2838 | qDebug("CalendarView::editCategories() "); | 2845 | qDebug("CalendarView::editCategories() "); |
2839 | KPIM::CategoryEditDialog ced (KOPrefs::instance(),this ); | 2846 | KPIM::CategoryEditDialog ced (KOPrefs::instance(),this ); |
2840 | ced.exec(); | 2847 | ced.exec(); |
2841 | } | 2848 | } |
2842 | void CalendarView::manageCategories() | 2849 | void CalendarView::manageCategories() |
2843 | { | 2850 | { |
2844 | KOCatPrefs* cp = new KOCatPrefs(); | 2851 | KOCatPrefs* cp = new KOCatPrefs(); |
2845 | cp->show(); | 2852 | cp->show(); |
2846 | int w =cp->sizeHint().width() ; | 2853 | int w =cp->sizeHint().width() ; |
2847 | int h = cp->sizeHint().height() ; | 2854 | int h = cp->sizeHint().height() ; |
2848 | int dw = QApplication::desktop()->width(); | 2855 | int dw = QApplication::desktop()->width(); |
2849 | int dh = QApplication::desktop()->height(); | 2856 | int dh = QApplication::desktop()->height(); |
2850 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 2857 | cp->setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
2851 | if ( !cp->exec() ) { | 2858 | if ( !cp->exec() ) { |
2852 | delete cp; | 2859 | delete cp; |
2853 | return; | 2860 | return; |
2854 | } | 2861 | } |
2855 | int count = 0; | 2862 | int count = 0; |
2856 | if ( cp->addCat() ) { | 2863 | if ( cp->addCat() ) { |
2857 | count = addCategories(); | 2864 | count = addCategories(); |
2858 | if ( count ) { | 2865 | if ( count ) { |
2859 | topLevelWidget()->setCaption(QString::number( count )+ i18n(" Categories added to list! ")); | 2866 | topLevelWidget()->setCaption(QString::number( count )+ i18n(" Categories added to list! ")); |
2860 | writeSettings(); | 2867 | writeSettings(); |
2861 | } else | 2868 | } else |
2862 | topLevelWidget()->setCaption(QString::number( 0 )+ i18n(" Categories added to list! ")); | 2869 | topLevelWidget()->setCaption(QString::number( 0 )+ i18n(" Categories added to list! ")); |
2863 | } else { | 2870 | } else { |
2864 | removeCategories(); | 2871 | removeCategories(); |
2865 | updateView(); | 2872 | updateView(); |
2866 | } | 2873 | } |
@@ -2900,105 +2907,107 @@ void CalendarView::beamIncidenceList(QPtrList<Incidence> delSel ) | |||
2900 | bool createbup = true; | 2907 | bool createbup = true; |
2901 | if ( createbup ) { | 2908 | if ( createbup ) { |
2902 | QString description = "\n"; | 2909 | QString description = "\n"; |
2903 | CalendarLocal* cal = new CalendarLocal(); | 2910 | CalendarLocal* cal = new CalendarLocal(); |
2904 | if ( beamDialog.beamLocal() ) | 2911 | if ( beamDialog.beamLocal() ) |
2905 | cal->setLocalTime(); | 2912 | cal->setLocalTime(); |
2906 | else | 2913 | else |
2907 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); | 2914 | cal->setTimeZoneId(KPimGlobalPrefs::instance()->mTimeZoneId); |
2908 | Incidence *incidence = delSel.first(); | 2915 | Incidence *incidence = delSel.first(); |
2909 | bool addText = false; | 2916 | bool addText = false; |
2910 | if ( delSel.count() < 10 ) | 2917 | if ( delSel.count() < 10 ) |
2911 | addText = true; | 2918 | addText = true; |
2912 | else { | 2919 | else { |
2913 | description.sprintf(i18n(" %d items?"),delSel.count() ); | 2920 | description.sprintf(i18n(" %d items?"),delSel.count() ); |
2914 | } | 2921 | } |
2915 | while ( incidence ) { | 2922 | while ( incidence ) { |
2916 | Incidence *in = incidence->clone(); | 2923 | Incidence *in = incidence->clone(); |
2917 | if ( ! in->summary().isEmpty() ) { | 2924 | if ( ! in->summary().isEmpty() ) { |
2918 | in->setDescription(""); | 2925 | in->setDescription(""); |
2919 | } else { | 2926 | } else { |
2920 | in->setSummary( in->description().left(20)); | 2927 | in->setSummary( in->description().left(20)); |
2921 | in->setDescription(""); | 2928 | in->setDescription(""); |
2922 | } | 2929 | } |
2923 | if ( addText ) | 2930 | if ( addText ) |
2924 | description += in->summary() + "\n"; | 2931 | description += in->summary() + "\n"; |
2925 | cal->addIncidence( in ); | 2932 | cal->addIncidence( in ); |
2926 | incidence = delSel.next(); | 2933 | incidence = delSel.next(); |
2927 | } | 2934 | } |
2928 | if ( beamDialog.beamVcal() ) { | 2935 | if ( beamDialog.beamVcal() ) { |
2929 | fn += ".vcs"; | 2936 | fn += ".vcs"; |
2930 | FileStorage storage( cal, fn, new VCalFormat ); | 2937 | FileStorage storage( cal, fn, new VCalFormat ); |
2931 | storage.save(); | 2938 | storage.save(); |
2932 | } else { | 2939 | } else { |
2933 | fn += ".ics"; | 2940 | fn += ".ics"; |
2934 | FileStorage storage( cal, fn, new ICalFormat( ) ); | 2941 | FileStorage storage( cal, fn, new ICalFormat( ) ); |
2935 | storage.save(); | 2942 | storage.save(); |
2936 | } | 2943 | } |
2937 | delete cal; | 2944 | delete cal; |
2938 | mes = i18n("KO/Pi: Ready for beaming"); | 2945 | mes = i18n("KO/Pi: Ready for beaming"); |
2939 | topLevelWidget()->setCaption(mes); | 2946 | topLevelWidget()->setCaption(mes); |
2940 | KApplication::convert2latin1( fn ); | 2947 | KApplication::convert2latin1( fn ); |
2941 | #ifndef DESKTOP_VERSION | 2948 | #ifndef DESKTOP_VERSION |
2942 | Ir *ir = new Ir( this ); | 2949 | Ir *ir = new Ir( this ); |
2943 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); | 2950 | connect( ir, SIGNAL( done( Ir * ) ), this, SLOT( beamDone( Ir * ) ) ); |
2944 | ir->send( fn, description, "text/x-vCalendar" ); | 2951 | ir->send( fn, description, "text/x-vCalendar" ); |
2945 | #endif | 2952 | #endif |
2946 | } | 2953 | } |
2947 | } | 2954 | } |
2955 | |||
2956 | #ifndef DESKTOP_VERSION | ||
2948 | void CalendarView::beamDone( Ir *ir ) | 2957 | void CalendarView::beamDone( Ir *ir ) |
2949 | { | 2958 | { |
2950 | #ifndef DESKTOP_VERSION | ||
2951 | delete ir; | 2959 | delete ir; |
2952 | #endif | ||
2953 | topLevelWidget()->setCaption( i18n("KO/Pi: Beaming done.") ); | 2960 | topLevelWidget()->setCaption( i18n("KO/Pi: Beaming done.") ); |
2954 | topLevelWidget()->raise(); | 2961 | topLevelWidget()->raise(); |
2955 | } | 2962 | } |
2956 | 2963 | #else | |
2964 | void CalendarView::beamDone( Ir *){;} | ||
2965 | #endif | ||
2957 | void CalendarView::moveIncidence(Incidence * inc ) | 2966 | void CalendarView::moveIncidence(Incidence * inc ) |
2958 | { | 2967 | { |
2959 | if ( !inc ) return; | 2968 | if ( !inc ) return; |
2960 | showDatePickerPopup(); | 2969 | showDatePickerPopup(); |
2961 | mDatePickerMode = 2; | 2970 | mDatePickerMode = 2; |
2962 | mMoveIncidence = inc ; | 2971 | mMoveIncidence = inc ; |
2963 | QDate da; | 2972 | QDate da; |
2964 | if ( mMoveIncidence->typeID() == todoID ) { | 2973 | if ( mMoveIncidence->typeID() == todoID ) { |
2965 | Todo * to = (Todo *) mMoveIncidence; | 2974 | Todo * to = (Todo *) mMoveIncidence; |
2966 | if ( to->hasDueDate() ) | 2975 | if ( to->hasDueDate() ) |
2967 | da = to->dtDue().date(); | 2976 | da = to->dtDue().date(); |
2968 | else | 2977 | else |
2969 | da = QDate::currentDate(); | 2978 | da = QDate::currentDate(); |
2970 | } else { | 2979 | } else { |
2971 | da = mMoveIncidence->dtStart().date(); | 2980 | da = mMoveIncidence->dtStart().date(); |
2972 | } | 2981 | } |
2973 | //PENDING set date for recurring incidence to date of recurrence | 2982 | //PENDING set date for recurring incidence to date of recurrence |
2974 | //mMoveIncidenceOldDate; | 2983 | //mMoveIncidenceOldDate; |
2975 | mDatePicker->setDate( da ); | 2984 | mDatePicker->setDate( da ); |
2976 | } | 2985 | } |
2977 | void CalendarView::showDatePickerPopup() | 2986 | void CalendarView::showDatePickerPopup() |
2978 | { | 2987 | { |
2979 | if ( mDateFrame->isVisible() ) | 2988 | if ( mDateFrame->isVisible() ) |
2980 | mDateFrame->hide(); | 2989 | mDateFrame->hide(); |
2981 | else { | 2990 | else { |
2982 | int offX = 0, offY = 0; | 2991 | int offX = 0, offY = 0; |
2983 | #ifdef DESKTOP_VERSION | 2992 | #ifdef DESKTOP_VERSION |
2984 | int w =mDatePicker->sizeHint().width() ; | 2993 | int w =mDatePicker->sizeHint().width() ; |
2985 | int h = mDatePicker->sizeHint().height() ; | 2994 | int h = mDatePicker->sizeHint().height() ; |
2986 | int dw = topLevelWidget()->width(); | 2995 | int dw = topLevelWidget()->width(); |
2987 | int dh = topLevelWidget()->height(); | 2996 | int dh = topLevelWidget()->height(); |
2988 | offX = topLevelWidget()->x(); | 2997 | offX = topLevelWidget()->x(); |
2989 | offY = topLevelWidget()->y(); | 2998 | offY = topLevelWidget()->y(); |
2990 | #else | 2999 | #else |
2991 | int w =mDatePicker->sizeHint().width() ; | 3000 | int w =mDatePicker->sizeHint().width() ; |
2992 | int h = mDatePicker->sizeHint().height() ; | 3001 | int h = mDatePicker->sizeHint().height() ; |
2993 | int dw = QApplication::desktop()->width(); | 3002 | int dw = QApplication::desktop()->width(); |
2994 | int dh = QApplication::desktop()->height(); | 3003 | int dh = QApplication::desktop()->height(); |
2995 | #endif | 3004 | #endif |
2996 | mDateFrame->setGeometry( (dw-w)/2+offX, (dh - h )/2+offY ,w,h ); | 3005 | mDateFrame->setGeometry( (dw-w)/2+offX, (dh - h )/2+offY ,w,h ); |
2997 | mDateFrame->show(); | 3006 | mDateFrame->show(); |
2998 | } | 3007 | } |
2999 | } | 3008 | } |
3000 | void CalendarView::showDatePicker( ) | 3009 | void CalendarView::showDatePicker( ) |
3001 | { | 3010 | { |
3002 | showDatePickerPopup(); | 3011 | showDatePickerPopup(); |
3003 | mDatePickerMode = 1; | 3012 | mDatePickerMode = 1; |
3004 | mDatePicker->setDate( mNavigator->selectedDates().first() ); | 3013 | mDatePicker->setDate( mNavigator->selectedDates().first() ); |
@@ -4262,101 +4271,96 @@ Incidence *CalendarView::currentSelection() | |||
4262 | } | 4271 | } |
4263 | void CalendarView::toggleAllDaySize() | 4272 | void CalendarView::toggleAllDaySize() |
4264 | { | 4273 | { |
4265 | /* | 4274 | /* |
4266 | if ( KOPrefs::instance()->mAllDaySize > 47 ) | 4275 | if ( KOPrefs::instance()->mAllDaySize > 47 ) |
4267 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize /2; | 4276 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize /2; |
4268 | else | 4277 | else |
4269 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize *2; | 4278 | KOPrefs::instance()->mAllDaySize = KOPrefs::instance()->mAllDaySize *2; |
4270 | */ | 4279 | */ |
4271 | viewManager()->agendaView()->toggleAllDay(); | 4280 | viewManager()->agendaView()->toggleAllDay(); |
4272 | } | 4281 | } |
4273 | void CalendarView::toggleExpand() | 4282 | void CalendarView::toggleExpand() |
4274 | { | 4283 | { |
4275 | // if ( mLeftFrame->isHidden() ) { | 4284 | // if ( mLeftFrame->isHidden() ) { |
4276 | // mLeftFrame->show(); | 4285 | // mLeftFrame->show(); |
4277 | // emit calendarViewExpanded( false ); | 4286 | // emit calendarViewExpanded( false ); |
4278 | // } else { | 4287 | // } else { |
4279 | // mLeftFrame->hide(); | 4288 | // mLeftFrame->hide(); |
4280 | // emit calendarViewExpanded( true ); | 4289 | // emit calendarViewExpanded( true ); |
4281 | // } | 4290 | // } |
4282 | //qDebug(" CalendarView::toggleExpand()"); | 4291 | //qDebug(" CalendarView::toggleExpand()"); |
4283 | globalFlagBlockAgenda = 1; | 4292 | globalFlagBlockAgenda = 1; |
4284 | emit calendarViewExpanded( !mLeftFrame->isHidden() ); | 4293 | emit calendarViewExpanded( !mLeftFrame->isHidden() ); |
4285 | globalFlagBlockAgenda = 5; | 4294 | globalFlagBlockAgenda = 5; |
4286 | mViewManager->raiseCurrentView( !mLeftFrame->isHidden() ); | 4295 | mViewManager->raiseCurrentView( !mLeftFrame->isHidden() ); |
4287 | //mViewManager->showView( 0, true ); | 4296 | //mViewManager->showView( 0, true ); |
4288 | } | 4297 | } |
4289 | 4298 | ||
4290 | void CalendarView::calendarModified( bool modified, Calendar * ) | 4299 | void CalendarView::calendarModified( bool modified, Calendar * ) |
4291 | { | 4300 | { |
4292 | setModified( modified ); | 4301 | setModified( modified ); |
4293 | } | 4302 | } |
4294 | 4303 | ||
4295 | Todo *CalendarView::selectedTodo() | 4304 | Todo *CalendarView::selectedTodo() |
4296 | { | 4305 | { |
4297 | Incidence *incidence = currentSelection(); | 4306 | Incidence *incidence = currentSelection(); |
4298 | if ( incidence && incidence->typeID() == todoID ) { | 4307 | if ( incidence && incidence->typeID() == todoID ) { |
4299 | return static_cast<Todo *>( incidence ); | 4308 | return static_cast<Todo *>( incidence ); |
4300 | } | 4309 | } |
4301 | 4310 | ||
4302 | incidence = mTodoList->selectedIncidences().first(); | 4311 | incidence = mTodoList->selectedIncidences().first(); |
4303 | if ( incidence && incidence->typeID() == todoID ) { | 4312 | if ( incidence && incidence->typeID() == todoID ) { |
4304 | return static_cast<Todo *>( incidence ); | 4313 | return static_cast<Todo *>( incidence ); |
4305 | } | 4314 | } |
4306 | 4315 | ||
4307 | return 0; | 4316 | return 0; |
4308 | } | 4317 | } |
4309 | 4318 | ||
4310 | void CalendarView::dialogClosing(Incidence *in) | ||
4311 | { | ||
4312 | // mDialogList.remove(in); | ||
4313 | } | ||
4314 | |||
4315 | void CalendarView::showIncidence() | 4319 | void CalendarView::showIncidence() |
4316 | { | 4320 | { |
4317 | mViewerCallerIsSearchDialog = false; | 4321 | mViewerCallerIsSearchDialog = false; |
4318 | Incidence *incidence = currentSelection(); | 4322 | Incidence *incidence = currentSelection(); |
4319 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4323 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4320 | if ( incidence ) { | 4324 | if ( incidence ) { |
4321 | ShowIncidenceVisitor v; | 4325 | ShowIncidenceVisitor v; |
4322 | v.act( incidence, this ); | 4326 | v.act( incidence, this ); |
4323 | } | 4327 | } |
4324 | } | 4328 | } |
4325 | void CalendarView::editIncidenceDescription() | 4329 | void CalendarView::editIncidenceDescription() |
4326 | { | 4330 | { |
4327 | mFlagEditDescription = true; | 4331 | mFlagEditDescription = true; |
4328 | editIncidence(); | 4332 | editIncidence(); |
4329 | mFlagEditDescription = false; | 4333 | mFlagEditDescription = false; |
4330 | } | 4334 | } |
4331 | void CalendarView::editIncidence() | 4335 | void CalendarView::editIncidence() |
4332 | { | 4336 | { |
4333 | // qDebug("editIncidence() "); | 4337 | // qDebug("editIncidence() "); |
4334 | Incidence *incidence = currentSelection(); | 4338 | Incidence *incidence = currentSelection(); |
4335 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4339 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4336 | if ( incidence ) { | 4340 | if ( incidence ) { |
4337 | EditIncidenceVisitor v; | 4341 | EditIncidenceVisitor v; |
4338 | v.act( incidence, this ); | 4342 | v.act( incidence, this ); |
4339 | } | 4343 | } |
4340 | } | 4344 | } |
4341 | 4345 | ||
4342 | void CalendarView::deleteIncidence() | 4346 | void CalendarView::deleteIncidence() |
4343 | { | 4347 | { |
4344 | Incidence *incidence = currentSelection(); | 4348 | Incidence *incidence = currentSelection(); |
4345 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); | 4349 | if ( !incidence ) incidence = mTodoList->selectedIncidences().first(); |
4346 | if ( incidence ) { | 4350 | if ( incidence ) { |
4347 | deleteIncidence(incidence); | 4351 | deleteIncidence(incidence); |
4348 | } | 4352 | } |
4349 | } | 4353 | } |
4350 | void CalendarView::showIncidence(QString uid) | 4354 | void CalendarView::showIncidence(QString uid) |
4351 | { | 4355 | { |
4352 | Incidence *inc = mCalendar->incidence( uid ); | 4356 | Incidence *inc = mCalendar->incidence( uid ); |
4353 | if ( inc ) | 4357 | if ( inc ) |
4354 | showIncidence( inc ); | 4358 | showIncidence( inc ); |
4355 | } | 4359 | } |
4356 | void CalendarView::showIncidence(Incidence *incidence) | 4360 | void CalendarView::showIncidence(Incidence *incidence) |
4357 | { | 4361 | { |
4358 | mViewerCallerIsSearchDialog = false; | 4362 | mViewerCallerIsSearchDialog = false; |
4359 | //qDebug("%x %x ",sender (), mDialogManager->getSearchDialog() ); | 4363 | //qDebug("%x %x ",sender (), mDialogManager->getSearchDialog() ); |
4360 | if ( sender() && mDialogManager->getSearchDialog() ) { | 4364 | if ( sender() && mDialogManager->getSearchDialog() ) { |
4361 | if ( sender () == mDialogManager->getSearchDialog()->listview() ) { | 4365 | if ( sender () == mDialogManager->getSearchDialog()->listview() ) { |
4362 | mViewerCallerIsSearchDialog = true; | 4366 | mViewerCallerIsSearchDialog = true; |
@@ -4387,138 +4391,139 @@ void CalendarView::deleteIncidence(Incidence *incidence) | |||
4387 | } | 4391 | } |
4388 | } | 4392 | } |
4389 | 4393 | ||
4390 | 4394 | ||
4391 | void CalendarView::lookForOutgoingMessages() | 4395 | void CalendarView::lookForOutgoingMessages() |
4392 | { | 4396 | { |
4393 | OutgoingDialog *ogd = mDialogManager->outgoingDialog(); | 4397 | OutgoingDialog *ogd = mDialogManager->outgoingDialog(); |
4394 | ogd->loadMessages(); | 4398 | ogd->loadMessages(); |
4395 | } | 4399 | } |
4396 | 4400 | ||
4397 | void CalendarView::lookForIncomingMessages() | 4401 | void CalendarView::lookForIncomingMessages() |
4398 | { | 4402 | { |
4399 | IncomingDialog *icd = mDialogManager->incomingDialog(); | 4403 | IncomingDialog *icd = mDialogManager->incomingDialog(); |
4400 | icd->retrieve(); | 4404 | icd->retrieve(); |
4401 | } | 4405 | } |
4402 | 4406 | ||
4403 | bool CalendarView::removeCompletedSubTodos( Todo* t ) | 4407 | bool CalendarView::removeCompletedSubTodos( Todo* t ) |
4404 | { | 4408 | { |
4405 | bool deleteTodo = true; | 4409 | bool deleteTodo = true; |
4406 | QPtrList<Incidence> subTodos; | 4410 | QPtrList<Incidence> subTodos; |
4407 | Incidence *aTodo; | 4411 | Incidence *aTodo; |
4408 | subTodos = t->relations(); | 4412 | subTodos = t->relations(); |
4409 | for (aTodo = subTodos.first(); aTodo; aTodo = subTodos.next()) { | 4413 | for (aTodo = subTodos.first(); aTodo; aTodo = subTodos.next()) { |
4410 | if (! removeCompletedSubTodos( (Todo*) aTodo )) | 4414 | if (! removeCompletedSubTodos( (Todo*) aTodo )) |
4411 | deleteTodo = false; | 4415 | deleteTodo = false; |
4412 | } | 4416 | } |
4413 | if ( deleteTodo ) { | 4417 | if ( deleteTodo ) { |
4414 | if ( t->isCompleted() && !t->doesRecur()) { | 4418 | if ( t->isCompleted() && !t->doesRecur()) { |
4415 | checkExternalId( t ); | 4419 | checkExternalId( t ); |
4416 | mCalendar->deleteTodo( t ); | 4420 | mCalendar->deleteTodo( t ); |
4417 | changeTodoDisplay( t,KOGlobals::EVENTDELETED ); | 4421 | changeTodoDisplay( t,KOGlobals::EVENTDELETED ); |
4418 | } | 4422 | } |
4419 | else | 4423 | else |
4420 | deleteTodo = false; | 4424 | deleteTodo = false; |
4421 | } | 4425 | } |
4422 | return deleteTodo; | 4426 | return deleteTodo; |
4423 | 4427 | ||
4424 | } | 4428 | } |
4425 | void CalendarView::purgeCompleted() | 4429 | void CalendarView::purgeCompleted() |
4426 | { | 4430 | { |
4427 | int result = KMessageBox::warningContinueCancel(this, | 4431 | int result = KMessageBox::warningContinueCancel(this, |
4428 | i18n("Delete all completed todos?\n(Completed recurring todos\nwill not be deleted!)"),i18n("Purge Todos"),i18n("Purge")); | 4432 | i18n("Delete all completed todos?\n(Completed recurring todos\nwill not be deleted!)"),i18n("Purge Todos"),i18n("Purge")); |
4429 | 4433 | ||
4430 | if (result == KMessageBox::Continue) { | 4434 | if (result == KMessageBox::Continue) { |
4431 | 4435 | ||
4432 | QPtrList<Todo> todoCal; | 4436 | QPtrList<Todo> todoCal; |
4433 | QPtrList<Todo> rootTodos; | 4437 | QPtrList<Todo> rootTodos; |
4434 | //QPtrList<Incidence> rel; | 4438 | //QPtrList<Incidence> rel; |
4435 | Todo *aTodo;//, *rTodo; | 4439 | Todo *aTodo; |
4436 | Incidence *rIncidence; | ||
4437 | bool childDelete = false; | ||
4438 | bool deletedOne = true; | ||
4439 | todoCal = calendar()->todos(); | 4440 | todoCal = calendar()->todos(); |
4440 | for (aTodo = todoCal.first(); aTodo; aTodo = todoCal.next()) { | 4441 | for (aTodo = todoCal.first(); aTodo; aTodo = todoCal.next()) { |
4441 | if ( !aTodo->relatedTo() ) | 4442 | if ( !aTodo->relatedTo() ) |
4442 | rootTodos.append( aTodo ); | 4443 | rootTodos.append( aTodo ); |
4443 | } | 4444 | } |
4444 | for (aTodo = rootTodos.first(); aTodo; aTodo = rootTodos.next()) { | 4445 | for (aTodo = rootTodos.first(); aTodo; aTodo = rootTodos.next()) { |
4445 | removeCompletedSubTodos( aTodo ); | 4446 | removeCompletedSubTodos( aTodo ); |
4446 | } | 4447 | } |
4447 | 4448 | ||
4448 | updateView(); | 4449 | updateView(); |
4449 | } | 4450 | } |
4450 | } | 4451 | } |
4451 | 4452 | ||
4452 | void CalendarView::slotCalendarChanged() | 4453 | void CalendarView::slotCalendarChanged() |
4453 | { | 4454 | { |
4454 | ; | 4455 | ; |
4455 | } | 4456 | } |
4456 | 4457 | ||
4457 | void CalendarView::keyPressEvent ( QKeyEvent *e) | 4458 | void CalendarView::keyPressEvent ( QKeyEvent *e) |
4458 | { | 4459 | { |
4459 | //qDebug(" alendarView::keyPressEvent "); | 4460 | //qDebug(" alendarView::keyPressEvent "); |
4460 | e->ignore(); | 4461 | e->ignore(); |
4461 | } | 4462 | } |
4462 | 4463 | ||
4463 | 4464 | ||
4464 | bool CalendarView::sync(KSyncManager* manager, QString filename, int mode) | 4465 | bool CalendarView::sync(KSyncManager* manager, QString filename, int mode) |
4465 | { | 4466 | { |
4466 | // mSyncManager = manager; | 4467 | |
4468 | if ( manager != mSyncManager) | ||
4469 | qDebug("KO: Internal error-1. SyncManager mismatch "); | ||
4467 | if ( filename == QDir::homeDirPath ()+"/.kdecalendardump.ics" ) { | 4470 | if ( filename == QDir::homeDirPath ()+"/.kdecalendardump.ics" ) { |
4468 | qDebug("KO: SyncKDE request detected!"); | 4471 | qDebug("KO: SyncKDE request detected!"); |
4469 | } | 4472 | } |
4470 | mCurrentSyncDevice = mSyncManager->getCurrentSyncDevice(); | 4473 | mCurrentSyncDevice = mSyncManager->getCurrentSyncDevice(); |
4471 | mCurrentSyncName = mSyncManager->getCurrentSyncName(); | 4474 | mCurrentSyncName = mSyncManager->getCurrentSyncName(); |
4472 | return syncCalendar( filename, mode ); | 4475 | return syncCalendar( filename, mode ); |
4473 | } | 4476 | } |
4474 | bool CalendarView::syncExternal(KSyncManager* manager, QString resource) | 4477 | bool CalendarView::syncExternal(KSyncManager* manager, QString resource) |
4475 | { | 4478 | { |
4476 | //mSyncManager = manager; | 4479 | //mSyncManager = manager; |
4480 | if ( manager != mSyncManager) | ||
4481 | qDebug("KO: Internal error-2. SyncManager mismatch "); | ||
4477 | mCurrentSyncDevice = mSyncManager->getCurrentSyncDevice(); | 4482 | mCurrentSyncDevice = mSyncManager->getCurrentSyncDevice(); |
4478 | mCurrentSyncName = mSyncManager->getCurrentSyncName(); | 4483 | mCurrentSyncName = mSyncManager->getCurrentSyncName(); |
4479 | if ( resource == "sharp" ) | 4484 | if ( resource == "sharp" ) |
4480 | syncExternal( 0 ); | 4485 | syncExternal( 0 ); |
4481 | if ( resource == "phone" ) | 4486 | if ( resource == "phone" ) |
4482 | syncExternal( 1 ); | 4487 | syncExternal( 1 ); |
4483 | // pending setmodified | 4488 | // pending setmodified |
4484 | return true; | 4489 | return true; |
4485 | } | 4490 | } |
4486 | void CalendarView::setSyncManager(KSyncManager* manager) | 4491 | void CalendarView::setSyncManager(KSyncManager* manager) |
4487 | { | 4492 | { |
4488 | mSyncManager = manager; | 4493 | mSyncManager = manager; |
4489 | } | 4494 | } |
4490 | 4495 | ||
4491 | void CalendarView::removeSyncInfo( QString syncProfile) | 4496 | void CalendarView::removeSyncInfo( QString syncProfile) |
4492 | { | 4497 | { |
4493 | qDebug("KO: removeSyncInfo for profile %s ", syncProfile.latin1()); | 4498 | qDebug("KO: removeSyncInfo for profile %s ", syncProfile.latin1()); |
4494 | mCalendar->removeSyncInfo( syncProfile ); | 4499 | mCalendar->removeSyncInfo( syncProfile ); |
4495 | 4500 | ||
4496 | } | 4501 | } |
4497 | 4502 | ||
4498 | void CalendarView::undo_delete() | 4503 | void CalendarView::undo_delete() |
4499 | { | 4504 | { |
4500 | //qDebug("undo_delete() "); | 4505 | //qDebug("undo_delete() "); |
4501 | Incidence* undo = mCalendar->undoIncidence(); | 4506 | Incidence* undo = mCalendar->undoIncidence(); |
4502 | if ( !undo ) { | 4507 | if ( !undo ) { |
4503 | KMessageBox::sorry(this,i18n("There is nothing to undo!"), | 4508 | KMessageBox::sorry(this,i18n("There is nothing to undo!"), |
4504 | i18n("KO/Pi")); | 4509 | i18n("KO/Pi")); |
4505 | return; | 4510 | return; |
4506 | } | 4511 | } |
4507 | if ( KMessageBox::Continue ==KMessageBox::warningContinueCancel(this,undo->summary().left(25) + | 4512 | if ( KMessageBox::Continue ==KMessageBox::warningContinueCancel(this,undo->summary().left(25) + |
4508 | i18n("\nAre you sure you want\nto restore this?"), | 4513 | i18n("\nAre you sure you want\nto restore this?"), |
4509 | i18n("KO/Pi Confirmation"),i18n("Restore"))) { | 4514 | i18n("KO/Pi Confirmation"),i18n("Restore"))) { |
4510 | mCalendar->undoDeleteIncidence(); | 4515 | mCalendar->undoDeleteIncidence(); |
4511 | updateView(); | 4516 | updateView(); |
4512 | } | 4517 | } |
4513 | } | 4518 | } |
4514 | 4519 | ||
4515 | void CalendarView::slotViewerClosed() | 4520 | void CalendarView::slotViewerClosed() |
4516 | { | 4521 | { |
4517 | QTimer::singleShot( 50, this, SLOT ( resetFocus() ) ); | 4522 | QTimer::singleShot( 50, this, SLOT ( resetFocus() ) ); |
4518 | } | 4523 | } |
4519 | 4524 | ||
4520 | void CalendarView::resetFocus() | 4525 | void CalendarView::resetFocus() |
4521 | { | 4526 | { |
4522 | if ( mViewerCallerIsSearchDialog ) { | 4527 | if ( mViewerCallerIsSearchDialog ) { |
4523 | if ( mDialogManager->getSearchDialog()->isVisible() ){ | 4528 | if ( mDialogManager->getSearchDialog()->isVisible() ){ |
4524 | mDialogManager->getSearchDialog()->raise(); | 4529 | mDialogManager->getSearchDialog()->raise(); |
diff --git a/korganizer/calendarview.h b/korganizer/calendarview.h index 3323a98..c9e9870 100644 --- a/korganizer/calendarview.h +++ b/korganizer/calendarview.h | |||
@@ -92,96 +92,97 @@ class MissedAlarmTextBrowser : public QTextBrowser { | |||
92 | public: | 92 | public: |
93 | MissedAlarmTextBrowser(QWidget *parent, QPtrList<Incidence> alarms ,QDateTime start); | 93 | MissedAlarmTextBrowser(QWidget *parent, QPtrList<Incidence> alarms ,QDateTime start); |
94 | ~MissedAlarmTextBrowser(); | 94 | ~MissedAlarmTextBrowser(); |
95 | void setSource(const QString & n); | 95 | void setSource(const QString & n); |
96 | 96 | ||
97 | private: | 97 | private: |
98 | Incidence * getNextInc(QDateTime start ); | 98 | Incidence * getNextInc(QDateTime start ); |
99 | QPtrList<Incidence> mAlarms; | 99 | QPtrList<Incidence> mAlarms; |
100 | signals: | 100 | signals: |
101 | void showIncidence( QString uid); | 101 | void showIncidence( QString uid); |
102 | }; | 102 | }; |
103 | 103 | ||
104 | 104 | ||
105 | class CalendarView : public KOrg::CalendarViewBase, public KCal::Calendar::Observer, public KSyncInterface | 105 | class CalendarView : public KOrg::CalendarViewBase, public KCal::Calendar::Observer, public KSyncInterface |
106 | { | 106 | { |
107 | Q_OBJECT | 107 | Q_OBJECT |
108 | public: | 108 | public: |
109 | /** | 109 | /** |
110 | Constructs a new calendar view widget. | 110 | Constructs a new calendar view widget. |
111 | 111 | ||
112 | @param calendar calendar document | 112 | @param calendar calendar document |
113 | @param parent parent window | 113 | @param parent parent window |
114 | @param name Qt internal widget object name | 114 | @param name Qt internal widget object name |
115 | */ | 115 | */ |
116 | CalendarView( CalendarResources *calendar, QWidget *parent = 0, | 116 | CalendarView( CalendarResources *calendar, QWidget *parent = 0, |
117 | const char *name = 0 ); | 117 | const char *name = 0 ); |
118 | CalendarView( Calendar *calendar, QWidget *parent = 0, | 118 | CalendarView( Calendar *calendar, QWidget *parent = 0, |
119 | const char *name = 0 ); | 119 | const char *name = 0 ); |
120 | virtual ~CalendarView(); | 120 | virtual ~CalendarView(); |
121 | 121 | ||
122 | Calendar *calendar() { return mCalendar; } | 122 | Calendar *calendar() { return mCalendar; } |
123 | 123 | ||
124 | KOViewManager *viewManager(); | 124 | KOViewManager *viewManager(); |
125 | KODialogManager *dialogManager(); | 125 | KODialogManager *dialogManager(); |
126 | 126 | ||
127 | QDate startDate(); | 127 | QDate startDate(); |
128 | QDate endDate(); | 128 | QDate endDate(); |
129 | 129 | ||
130 | QWidgetStack *viewStack(); | 130 | QWidgetStack *viewStack(); |
131 | QWidget *leftFrame(); | 131 | QWidget *leftFrame(); |
132 | 132 | ||
133 | DateNavigator *dateNavigator(); | 133 | DateNavigator *dateNavigator(); |
134 | KDateNavigator *dateNavigatorWidget(); | 134 | KDateNavigator *dateNavigatorWidget(); |
135 | 135 | ||
136 | void addView(KOrg::BaseView *); | 136 | void addView(KOrg::BaseView *); |
137 | void showView(KOrg::BaseView *); | 137 | void showView(KOrg::BaseView *); |
138 | KOEventViewerDialog* getEventViewerDialog(); | 138 | KOEventViewerDialog* getEventViewerDialog(); |
139 | Incidence *currentSelection(); | 139 | Incidence *currentSelection(); |
140 | void checkSuspendAlarm(); | ||
140 | 141 | ||
141 | signals: | 142 | signals: |
142 | void save (); | 143 | void save (); |
143 | void saveStopTimer (); | 144 | void saveStopTimer (); |
144 | void tempDisableBR(bool); | 145 | void tempDisableBR(bool); |
145 | /** This todo has been modified */ | 146 | /** This todo has been modified */ |
146 | void todoModified(Todo *, int); | 147 | void todoModified(Todo *, int); |
147 | 148 | ||
148 | /** when change is made to options dialog, the topwidget will catch this | 149 | /** when change is made to options dialog, the topwidget will catch this |
149 | * and emit this signal which notifies all widgets which have registered | 150 | * and emit this signal which notifies all widgets which have registered |
150 | * for notification to update their settings. */ | 151 | * for notification to update their settings. */ |
151 | void configChanged(); | 152 | void configChanged(); |
152 | /** emitted when the topwidget is closing down, so that any attached | 153 | /** emitted when the topwidget is closing down, so that any attached |
153 | child windows can also close. */ | 154 | child windows can also close. */ |
154 | void closingDown(); | 155 | void closingDown(); |
155 | /** emitted right before we die */ | 156 | /** emitted right before we die */ |
156 | void closed(QWidget *); | 157 | void closed(QWidget *); |
157 | 158 | ||
158 | /** Emitted when state of modified flag changes */ | 159 | /** Emitted when state of modified flag changes */ |
159 | void modifiedChanged(bool); | 160 | void modifiedChanged(bool); |
160 | void signalmodified(); | 161 | void signalmodified(); |
161 | 162 | ||
162 | /** Emitted when state of read-only flag changes */ | 163 | /** Emitted when state of read-only flag changes */ |
163 | void readOnlyChanged(bool); | 164 | void readOnlyChanged(bool); |
164 | 165 | ||
165 | /** Emitted when the unit of navigation changes */ | 166 | /** Emitted when the unit of navigation changes */ |
166 | void changeNavStringPrev(const QString &); | 167 | void changeNavStringPrev(const QString &); |
167 | void changeNavStringNext(const QString &); | 168 | void changeNavStringNext(const QString &); |
168 | 169 | ||
169 | /** Emitted when state of events selection has changed and user is organizer*/ | 170 | /** Emitted when state of events selection has changed and user is organizer*/ |
170 | void organizerEventsSelected(bool); | 171 | void organizerEventsSelected(bool); |
171 | /** Emitted when state of events selection has changed and user is attendee*/ | 172 | /** Emitted when state of events selection has changed and user is attendee*/ |
172 | void groupEventsSelected(bool); | 173 | void groupEventsSelected(bool); |
173 | /** | 174 | /** |
174 | Emitted when an incidence gets selected. If the selection is cleared the | 175 | Emitted when an incidence gets selected. If the selection is cleared the |
175 | signal is emitted with 0 as argument. | 176 | signal is emitted with 0 as argument. |
176 | */ | 177 | */ |
177 | void incidenceSelected( Incidence * ); | 178 | void incidenceSelected( Incidence * ); |
178 | /** Emitted, when a todoitem is selected or deselected. */ | 179 | /** Emitted, when a todoitem is selected or deselected. */ |
179 | void todoSelected( bool ); | 180 | void todoSelected( bool ); |
180 | 181 | ||
181 | /** | 182 | /** |
182 | Emitted, when clipboard content changes. Parameter indicates if paste | 183 | Emitted, when clipboard content changes. Parameter indicates if paste |
183 | is possible or not. | 184 | is possible or not. |
184 | */ | 185 | */ |
185 | void pasteEnabled(bool); | 186 | void pasteEnabled(bool); |
186 | 187 | ||
187 | /** Emitted, when the number of incoming messages has changed. */ | 188 | /** Emitted, when the number of incoming messages has changed. */ |
@@ -410,97 +411,96 @@ class CalendarView : public KOrg::CalendarViewBase, public KCal::Calendar::Obser | |||
410 | bool isReadOnly(); | 411 | bool isReadOnly(); |
411 | /** set state of calendar to read-only */ | 412 | /** set state of calendar to read-only */ |
412 | void setReadOnly(bool readOnly=true); | 413 | void setReadOnly(bool readOnly=true); |
413 | 414 | ||
414 | void eventUpdated(Incidence *); | 415 | void eventUpdated(Incidence *); |
415 | 416 | ||
416 | /* iTIP scheduling actions */ | 417 | /* iTIP scheduling actions */ |
417 | void schedule_publish(Incidence *incidence = 0); | 418 | void schedule_publish(Incidence *incidence = 0); |
418 | void schedule_request(Incidence *incidence = 0); | 419 | void schedule_request(Incidence *incidence = 0); |
419 | void schedule_refresh(Incidence *incidence = 0); | 420 | void schedule_refresh(Incidence *incidence = 0); |
420 | void schedule_cancel(Incidence *incidence = 0); | 421 | void schedule_cancel(Incidence *incidence = 0); |
421 | void schedule_add(Incidence *incidence = 0); | 422 | void schedule_add(Incidence *incidence = 0); |
422 | void schedule_reply(Incidence *incidence = 0); | 423 | void schedule_reply(Incidence *incidence = 0); |
423 | void schedule_counter(Incidence *incidence = 0); | 424 | void schedule_counter(Incidence *incidence = 0); |
424 | void schedule_declinecounter(Incidence *incidence = 0); | 425 | void schedule_declinecounter(Incidence *incidence = 0); |
425 | void schedule_publish_freebusy(int daysToPublish = 30); | 426 | void schedule_publish_freebusy(int daysToPublish = 30); |
426 | 427 | ||
427 | void openAddressbook(); | 428 | void openAddressbook(); |
428 | 429 | ||
429 | void editFilters(); | 430 | void editFilters(); |
430 | void toggleFilerEnabled(); | 431 | void toggleFilerEnabled(); |
431 | QPtrList<CalFilter> filters(); | 432 | QPtrList<CalFilter> filters(); |
432 | void toggleFilter(); | 433 | void toggleFilter(); |
433 | void showFilter(bool visible); | 434 | void showFilter(bool visible); |
434 | void updateFilter(); | 435 | void updateFilter(); |
435 | void filterEdited(); | 436 | void filterEdited(); |
436 | void selectFilter( int ); | 437 | void selectFilter( int ); |
437 | KOFilterView *filterView(); | 438 | KOFilterView *filterView(); |
438 | 439 | ||
439 | void showIntro(); | 440 | void showIntro(); |
440 | 441 | ||
441 | /** Move the curdatepient view date to today */ | 442 | /** Move the curdatepient view date to today */ |
442 | void goToday(); | 443 | void goToday(); |
443 | 444 | ||
444 | /** Move to the next date(s) in the current view */ | 445 | /** Move to the next date(s) in the current view */ |
445 | void goNext(); | 446 | void goNext(); |
446 | 447 | ||
447 | /** Move to the previous date(s) in the current view */ | 448 | /** Move to the previous date(s) in the current view */ |
448 | void goPrevious(); | 449 | void goPrevious(); |
449 | /** Move to the next date(s) in the current view */ | 450 | /** Move to the next date(s) in the current view */ |
450 | void goNextMonth(); | 451 | void goNextMonth(); |
451 | 452 | ||
452 | /** Move to the previous date(s) in the current view */ | 453 | /** Move to the previous date(s) in the current view */ |
453 | void goPreviousMonth(); | 454 | void goPreviousMonth(); |
454 | 455 | ||
455 | void toggleExpand(); | 456 | void toggleExpand(); |
456 | void toggleDateNavigatorWidget(); | 457 | void toggleDateNavigatorWidget(); |
457 | void toggleAllDaySize(); | 458 | void toggleAllDaySize(); |
458 | void dialogClosing(Incidence *); | ||
459 | 459 | ||
460 | /** Look for new messages in the inbox */ | 460 | /** Look for new messages in the inbox */ |
461 | void lookForIncomingMessages(); | 461 | void lookForIncomingMessages(); |
462 | /** Look for new messages in the outbox */ | 462 | /** Look for new messages in the outbox */ |
463 | void lookForOutgoingMessages(); | 463 | void lookForOutgoingMessages(); |
464 | 464 | ||
465 | void processMainViewSelection( Incidence * ); | 465 | void processMainViewSelection( Incidence * ); |
466 | void processTodoListSelection( Incidence * ); | 466 | void processTodoListSelection( Incidence * ); |
467 | 467 | ||
468 | void processIncidenceSelection( Incidence * ); | 468 | void processIncidenceSelection( Incidence * ); |
469 | 469 | ||
470 | void purgeCompleted(); | 470 | void purgeCompleted(); |
471 | bool removeCompletedSubTodos( Todo* ); | 471 | bool removeCompletedSubTodos( Todo* ); |
472 | void slotCalendarChanged(); | 472 | void slotCalendarChanged(); |
473 | bool importBday(); | 473 | bool importBday(); |
474 | bool addAnniversary( QDate data, QString name, KCal::Attendee* a , bool birthday ); | 474 | bool addAnniversary( QDate data, QString name, KCal::Attendee* a , bool birthday ); |
475 | bool importQtopia( const QString &categoriesFile, | 475 | bool importQtopia( const QString &categoriesFile, |
476 | const QString &datebookFile, | 476 | const QString &datebookFile, |
477 | const QString &tasklistFile ); | 477 | const QString &tasklistFile ); |
478 | void syncExternal( int mode ); | 478 | void syncExternal( int mode ); |
479 | void slotSelectPickerDate( QDate ) ; | 479 | void slotSelectPickerDate( QDate ) ; |
480 | void showDatePicker() ; | 480 | void showDatePicker() ; |
481 | void showDatePickerPopup() ; | 481 | void showDatePickerPopup() ; |
482 | void moveIncidence(Incidence *) ; | 482 | void moveIncidence(Incidence *) ; |
483 | void beamIncidence(Incidence *) ; | 483 | void beamIncidence(Incidence *) ; |
484 | void beamCalendar() ; | 484 | void beamCalendar() ; |
485 | void beamFilteredCalendar() ; | 485 | void beamFilteredCalendar() ; |
486 | void beamIncidenceList(QPtrList<Incidence>) ; | 486 | void beamIncidenceList(QPtrList<Incidence>) ; |
487 | void manageCategories(); | 487 | void manageCategories(); |
488 | void editCategories(); | 488 | void editCategories(); |
489 | int addCategories(); | 489 | int addCategories(); |
490 | void removeCategories(); | 490 | void removeCategories(); |
491 | void setSyncDevice( QString ); | 491 | void setSyncDevice( QString ); |
492 | void setSyncName( QString ); | 492 | void setSyncName( QString ); |
493 | void showDay( QDate ); | 493 | void showDay( QDate ); |
494 | void undo_delete(); | 494 | void undo_delete(); |
495 | protected slots: | 495 | protected slots: |
496 | void resetFocus(); | 496 | void resetFocus(); |
497 | void scrollBarValue(int); | 497 | void scrollBarValue(int); |
498 | void slotViewerClosed(); | 498 | void slotViewerClosed(); |
499 | void timerAlarm(); | 499 | void timerAlarm(); |
500 | void suspendAlarm(); | 500 | void suspendAlarm(); |
501 | void beamDone( Ir *ir ); | 501 | void beamDone( Ir *ir ); |
502 | /** Select a view or adapt the current view to display the specified dates. */ | 502 | /** Select a view or adapt the current view to display the specified dates. */ |
503 | void showDates( const KCal::DateList & ); | 503 | void showDates( const KCal::DateList & ); |
504 | void selectWeekNum ( int ); | 504 | void selectWeekNum ( int ); |
505 | 505 | ||
506 | public: | 506 | public: |
diff --git a/korganizer/kodialogmanager.cpp b/korganizer/kodialogmanager.cpp index 5455098..ea30fac 100644 --- a/korganizer/kodialogmanager.cpp +++ b/korganizer/kodialogmanager.cpp | |||
@@ -253,104 +253,100 @@ void KODialogManager::showFilterEditDialog(QPtrList<CalFilter> *filters) | |||
253 | connect(mFilterEditDialog,SIGNAL(filterChanged()), | 253 | connect(mFilterEditDialog,SIGNAL(filterChanged()), |
254 | mMainView,SLOT(filterEdited())); | 254 | mMainView,SLOT(filterEdited())); |
255 | 255 | ||
256 | } | 256 | } |
257 | 257 | ||
258 | #ifndef DESKTOP_VERSION | 258 | #ifndef DESKTOP_VERSION |
259 | mFilterEditDialog->showMaximized(); | 259 | mFilterEditDialog->showMaximized(); |
260 | #else | 260 | #else |
261 | mFilterEditDialog->show(); | 261 | mFilterEditDialog->show(); |
262 | #endif | 262 | #endif |
263 | mFilterEditDialog->raise(); | 263 | mFilterEditDialog->raise(); |
264 | } | 264 | } |
265 | 265 | ||
266 | void KODialogManager::showPluginDialog() | 266 | void KODialogManager::showPluginDialog() |
267 | { | 267 | { |
268 | #ifndef KORG_NOPLUGINS | 268 | #ifndef KORG_NOPLUGINS |
269 | if (!mPluginDialog) { | 269 | if (!mPluginDialog) { |
270 | mPluginDialog = new PluginDialog(mMainView); | 270 | mPluginDialog = new PluginDialog(mMainView); |
271 | connect(mPluginDialog,SIGNAL(configChanged()), | 271 | connect(mPluginDialog,SIGNAL(configChanged()), |
272 | mMainView,SLOT(updateConfig())); | 272 | mMainView,SLOT(updateConfig())); |
273 | } | 273 | } |
274 | mPluginDialog->show(); | 274 | mPluginDialog->show(); |
275 | mPluginDialog->raise(); | 275 | mPluginDialog->raise(); |
276 | #endif | 276 | #endif |
277 | } | 277 | } |
278 | 278 | ||
279 | KOEventEditor *KODialogManager::getEventEditor() | 279 | KOEventEditor *KODialogManager::getEventEditor() |
280 | { | 280 | { |
281 | KOEventEditor *eventEditor = new KOEventEditor( mMainView->calendar(), | 281 | KOEventEditor *eventEditor = new KOEventEditor( mMainView->calendar(), |
282 | mMainView ); | 282 | mMainView ); |
283 | 283 | ||
284 | connect(eventEditor,SIGNAL(eventAdded(Event *)), | 284 | connect(eventEditor,SIGNAL(eventAdded(Event *)), |
285 | mMainView,SLOT(eventAdded(Event *))); | 285 | mMainView,SLOT(eventAdded(Event *))); |
286 | connect(eventEditor,SIGNAL(eventChanged(Event *)), | 286 | connect(eventEditor,SIGNAL(eventChanged(Event *)), |
287 | mMainView,SLOT(eventChanged(Event *))); | 287 | mMainView,SLOT(eventChanged(Event *))); |
288 | connect(eventEditor,SIGNAL(eventDeleted()), | 288 | connect(eventEditor,SIGNAL(eventDeleted()), |
289 | mMainView,SLOT(eventDeleted())); | 289 | mMainView,SLOT(eventDeleted())); |
290 | connect(eventEditor,SIGNAL(deleteAttendee(Incidence *)), | 290 | connect(eventEditor,SIGNAL(deleteAttendee(Incidence *)), |
291 | mMainView,SLOT(schedule_cancel(Incidence *))); | 291 | mMainView,SLOT(schedule_cancel(Incidence *))); |
292 | connect( eventEditor, SIGNAL(jumpToTime( const QDate &)), | 292 | connect( eventEditor, SIGNAL(jumpToTime( const QDate &)), |
293 | mMainView->dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); | 293 | mMainView->dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); |
294 | connect( eventEditor, SIGNAL( showAgendaView( bool)), | 294 | connect( eventEditor, SIGNAL( showAgendaView( bool)), |
295 | mMainView->viewManager(), SLOT( showAgendaView( bool) ) ); | 295 | mMainView->viewManager(), SLOT( showAgendaView( bool) ) ); |
296 | 296 | ||
297 | // connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), | 297 | // connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), |
298 | // eventEditor,SLOT(updateCategoryConfig())); | 298 | // eventEditor,SLOT(updateCategoryConfig())); |
299 | // connect(eventEditor,SIGNAL(editCategories()), | 299 | // connect(eventEditor,SIGNAL(editCategories()), |
300 | // mCategoryEditDialog,SLOT(show())); | 300 | // mCategoryEditDialog,SLOT(show())); |
301 | connect(eventEditor,SIGNAL(dialogClose(Incidence*)), | ||
302 | mMainView,SLOT(dialogClosing(Incidence*))); | ||
303 | 301 | ||
304 | //connect(mMainView,SIGNAL(closingDown()),eventEditor,SLOT(reject())); | 302 | //connect(mMainView,SIGNAL(closingDown()),eventEditor,SLOT(reject())); |
305 | 303 | ||
306 | #ifndef DESKTOP_VERSION | 304 | #ifndef DESKTOP_VERSION |
307 | eventEditor->resize( QApplication::desktop()->width() -20, 100 ); | 305 | eventEditor->resize( QApplication::desktop()->width() -20, 100 ); |
308 | #endif | 306 | #endif |
309 | return eventEditor; | 307 | return eventEditor; |
310 | } | 308 | } |
311 | 309 | ||
312 | KOTodoEditor *KODialogManager::getTodoEditor() | 310 | KOTodoEditor *KODialogManager::getTodoEditor() |
313 | { | 311 | { |
314 | KOTodoEditor *todoEditor = new KOTodoEditor( mMainView->calendar(), | 312 | KOTodoEditor *todoEditor = new KOTodoEditor( mMainView->calendar(), |
315 | mMainView ); | 313 | mMainView ); |
316 | 314 | ||
317 | // connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), | 315 | // connect(mCategoryEditDialog,SIGNAL(categoryConfigChanged()), |
318 | // todoEditor,SLOT(updateCategoryConfig())); | 316 | // todoEditor,SLOT(updateCategoryConfig())); |
319 | // connect(todoEditor,SIGNAL(editCategories()),mCategoryEditDialog,SLOT(show())); | 317 | // connect(todoEditor,SIGNAL(editCategories()),mCategoryEditDialog,SLOT(show())); |
320 | 318 | ||
321 | connect(todoEditor,SIGNAL(todoAdded(Todo *)), | 319 | connect(todoEditor,SIGNAL(todoAdded(Todo *)), |
322 | mMainView,SLOT(todoAdded(Todo *))); | 320 | mMainView,SLOT(todoAdded(Todo *))); |
323 | connect(todoEditor,SIGNAL(todoChanged(Todo *)), | 321 | connect(todoEditor,SIGNAL(todoChanged(Todo *)), |
324 | mMainView,SLOT(todoChanged(Todo *))); | 322 | mMainView,SLOT(todoChanged(Todo *))); |
325 | connect(todoEditor,SIGNAL(todoDeleted()), | 323 | connect(todoEditor,SIGNAL(todoDeleted()), |
326 | mMainView,SLOT(todoDeleted())); | 324 | mMainView,SLOT(todoDeleted())); |
327 | connect(todoEditor,SIGNAL(dialogClose(Incidence*)), | ||
328 | mMainView,SLOT(dialogClosing(Incidence*))); | ||
329 | connect( todoEditor, SIGNAL(jumpToTime( const QDate &)), | 325 | connect( todoEditor, SIGNAL(jumpToTime( const QDate &)), |
330 | mMainView->dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); | 326 | mMainView->dateNavigator(), SLOT( selectWeek( const QDate & ) ) ); |
331 | connect( todoEditor, SIGNAL( showAgendaView( bool)), | 327 | connect( todoEditor, SIGNAL( showAgendaView( bool)), |
332 | mMainView->viewManager(), SLOT( showAgendaView( bool) ) ); | 328 | mMainView->viewManager(), SLOT( showAgendaView( bool) ) ); |
333 | // connect(todoEditor,SIGNAL(deleteAttendee(Incidence *)), | 329 | // connect(todoEditor,SIGNAL(deleteAttendee(Incidence *)), |
334 | // mMainView,SLOT(schedule_cancel(Incidence *))); | 330 | // mMainView,SLOT(schedule_cancel(Incidence *))); |
335 | //connect(mMainView,SIGNAL(closingDown()),todoEditor,SLOT(reject())); | 331 | //connect(mMainView,SIGNAL(closingDown()),todoEditor,SLOT(reject())); |
336 | #ifndef DESKTOP_VERSION | 332 | #ifndef DESKTOP_VERSION |
337 | todoEditor->resize( QApplication::desktop()->width() -20, 100 ); | 333 | todoEditor->resize( QApplication::desktop()->width() -20, 100 ); |
338 | #endif | 334 | #endif |
339 | return todoEditor; | 335 | return todoEditor; |
340 | } | 336 | } |
341 | 337 | ||
342 | void KODialogManager::updateSearchDialog() | 338 | void KODialogManager::updateSearchDialog() |
343 | { | 339 | { |
344 | if (mSearchDialog) mSearchDialog->updateView(); | 340 | if (mSearchDialog) mSearchDialog->updateView(); |
345 | } | 341 | } |
346 | 342 | ||
347 | void KODialogManager::setDocumentId( const QString &id ) | 343 | void KODialogManager::setDocumentId( const QString &id ) |
348 | { | 344 | { |
349 | if (mOutgoingDialog) mOutgoingDialog->setDocumentId( id ); | 345 | if (mOutgoingDialog) mOutgoingDialog->setDocumentId( id ); |
350 | } | 346 | } |
351 | 347 | ||
352 | void KODialogManager::writeSettings( KConfig *config ) | 348 | void KODialogManager::writeSettings( KConfig *config ) |
353 | { | 349 | { |
354 | if (mSearchDialog) | 350 | if (mSearchDialog) |
355 | mSearchDialog->listview()->writeSettings(config,"SearchListView Layout"); | 351 | mSearchDialog->listview()->writeSettings(config,"SearchListView Layout"); |
356 | } | 352 | } |
diff --git a/korganizer/kolistview.cpp b/korganizer/kolistview.cpp index 517677c..e5e3704 100644 --- a/korganizer/kolistview.cpp +++ b/korganizer/kolistview.cpp | |||
@@ -394,97 +394,98 @@ QString KOListView::getWhatsThisText(QPoint p) | |||
394 | return i18n("That is the list view" ); | 394 | return i18n("That is the list view" ); |
395 | 395 | ||
396 | } | 396 | } |
397 | 397 | ||
398 | void KOListView::setCalendar( int c ) | 398 | void KOListView::setCalendar( int c ) |
399 | { | 399 | { |
400 | int result = QMessageBox::warning( this, i18n("KO/Pi: Information!"), | 400 | int result = QMessageBox::warning( this, i18n("KO/Pi: Information!"), |
401 | i18n("This adds the selected\nitems to the calendar\n%1\nand removes them from\ntheir current calendar!").arg( KOPrefs::instance()->calName( c ) ), | 401 | i18n("This adds the selected\nitems to the calendar\n%1\nand removes them from\ntheir current calendar!").arg( KOPrefs::instance()->calName( c ) ), |
402 | i18n("Continue"), i18n("Cancel"), 0, | 402 | i18n("Continue"), i18n("Cancel"), 0, |
403 | 0, 1 ); | 403 | 0, 1 ); |
404 | if ( result != 0 ) { | 404 | if ( result != 0 ) { |
405 | return; | 405 | return; |
406 | } | 406 | } |
407 | 407 | ||
408 | QPtrList<Incidence> delSel = getSelectedIncidences() ; | 408 | QPtrList<Incidence> delSel = getSelectedIncidences() ; |
409 | int icount = delSel.count(); | 409 | int icount = delSel.count(); |
410 | if ( icount ) { | 410 | if ( icount ) { |
411 | Incidence *incidence = delSel.first(); | 411 | Incidence *incidence = delSel.first(); |
412 | while ( incidence ) { | 412 | while ( incidence ) { |
413 | incidence->setCalID( c ); | 413 | incidence->setCalID( c ); |
414 | KOListViewItem * item = getItemForEvent( incidence ); | 414 | KOListViewItem * item = getItemForEvent( incidence ); |
415 | if ( item ) { | 415 | if ( item ) { |
416 | ListItemVisitor v(item, mStartDate ); | 416 | ListItemVisitor v(item, mStartDate ); |
417 | incidence->accept(v); | 417 | incidence->accept(v); |
418 | } | 418 | } |
419 | incidence = delSel.next(); | 419 | incidence = delSel.next(); |
420 | } | 420 | } |
421 | } | 421 | } |
422 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; | 422 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; |
423 | KopiCalendarFile * cal = calendars.first(); | 423 | KopiCalendarFile * cal = calendars.first(); |
424 | while ( cal ) { | 424 | while ( cal ) { |
425 | mCalendar->setCalendarEnabled( cal->mCalNumber,cal->isEnabled ); | 425 | mCalendar->setCalendarEnabled( cal->mCalNumber,cal->isEnabled ); |
426 | mCalendar->setAlarmEnabled( cal->mCalNumber, cal->isAlarmEnabled ); | 426 | mCalendar->setAlarmEnabled( cal->mCalNumber, cal->isAlarmEnabled ); |
427 | mCalendar->setReadOnly( cal->mCalNumber, cal->isReadOnly ); | 427 | mCalendar->setReadOnly( cal->mCalNumber, cal->isReadOnly ); |
428 | if ( cal->isStandard ) | 428 | if ( cal->isStandard ) |
429 | mCalendar->setDefaultCalendar( cal->mCalNumber ); | 429 | mCalendar->setDefaultCalendar( cal->mCalNumber ); |
430 | cal = calendars.next(); | 430 | cal = calendars.next(); |
431 | } | 431 | } |
432 | mCalendar->setSyncEventsReadOnly(); | 432 | mCalendar->setSyncEventsReadOnly(); |
433 | mCalendar->reInitAlarmSettings(); | 433 | mCalendar->reInitAlarmSettings(); |
434 | 434 | ||
435 | } | 435 | } |
436 | void KOListView::populateCalPopup() | 436 | void KOListView::populateCalPopup() |
437 | { | 437 | { |
438 | mCalPopup->clear(); | 438 | mCalPopup->clear(); |
439 | KopiCalendarFile * kkf = KOPrefs::instance()->mCalendars.first(); | 439 | KopiCalendarFile * kkf = KOPrefs::instance()->mCalendars.first(); |
440 | while ( kkf ) { | 440 | while ( kkf ) { |
441 | int index = mCalPopup->insertItem( kkf->mName, kkf->mCalNumber); | 441 | int index = mCalPopup->insertItem( kkf->mName, kkf->mCalNumber); |
442 | mCalPopup->setItemEnabled( index, !kkf->isReadOnly ); | 442 | if ( kkf->mErrorOnLoad || kkf->isReadOnly ) |
443 | mCalPopup->setItemEnabled( index, false ); | ||
443 | kkf = KOPrefs::instance()->mCalendars.next(); | 444 | kkf = KOPrefs::instance()->mCalendars.next(); |
444 | } | 445 | } |
445 | } | 446 | } |
446 | void KOListView::updateList() | 447 | void KOListView::updateList() |
447 | { | 448 | { |
448 | // qDebug(" KOListView::updateList() "); | 449 | // qDebug(" KOListView::updateList() "); |
449 | 450 | ||
450 | } | 451 | } |
451 | 452 | ||
452 | void KOListView::clearList() | 453 | void KOListView::clearList() |
453 | { | 454 | { |
454 | clear (); | 455 | clear (); |
455 | } | 456 | } |
456 | void KOListView::addCat( ) | 457 | void KOListView::addCat( ) |
457 | { | 458 | { |
458 | setCategories( false ); | 459 | setCategories( false ); |
459 | } | 460 | } |
460 | void KOListView::setCat() | 461 | void KOListView::setCat() |
461 | { | 462 | { |
462 | setCategories( true ); | 463 | setCategories( true ); |
463 | } | 464 | } |
464 | 465 | ||
465 | void KOListView::setAlarm() | 466 | void KOListView::setAlarm() |
466 | { | 467 | { |
467 | KOAlarmPrefs kap( this); | 468 | KOAlarmPrefs kap( this); |
468 | if ( !kap.exec() ) | 469 | if ( !kap.exec() ) |
469 | return; | 470 | return; |
470 | QStringList itemList; | 471 | QStringList itemList; |
471 | QPtrList<KOListViewItem> sel ; | 472 | QPtrList<KOListViewItem> sel ; |
472 | QListViewItem *qitem = mListView->firstChild (); | 473 | QListViewItem *qitem = mListView->firstChild (); |
473 | while ( qitem ) { | 474 | while ( qitem ) { |
474 | if ( qitem->isSelected() ) { | 475 | if ( qitem->isSelected() ) { |
475 | Incidence* inc = ((KOListViewItem *) qitem)->data(); | 476 | Incidence* inc = ((KOListViewItem *) qitem)->data(); |
476 | if ( inc->typeID() != journalID ) { | 477 | if ( inc->typeID() != journalID ) { |
477 | if ( inc->typeID() == todoID ) { | 478 | if ( inc->typeID() == todoID ) { |
478 | if ( ((Todo*)inc)->hasDueDate() ) | 479 | if ( ((Todo*)inc)->hasDueDate() ) |
479 | sel.append(((KOListViewItem *)qitem)); | 480 | sel.append(((KOListViewItem *)qitem)); |
480 | } else | 481 | } else |
481 | sel.append(((KOListViewItem *)qitem)); | 482 | sel.append(((KOListViewItem *)qitem)); |
482 | } | 483 | } |
483 | } | 484 | } |
484 | qitem = qitem->nextSibling(); | 485 | qitem = qitem->nextSibling(); |
485 | } | 486 | } |
486 | int count = 0; | 487 | int count = 0; |
487 | KOListViewItem * item, *temp; | 488 | KOListViewItem * item, *temp; |
488 | item = sel.first(); | 489 | item = sel.first(); |
489 | Incidence* inc; | 490 | Incidence* inc; |
490 | while ( item ) { | 491 | while ( item ) { |
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index b6ce7d5..b797d8c 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -89,114 +89,111 @@ class KOex2phonePrefs : public QDialog | |||
89 | lay->addWidget(lab = new QLabel( i18n("Please read Help-Sync Howto\nto know what settings to use."), this ) ); | 89 | lay->addWidget(lab = new QLabel( i18n("Please read Help-Sync Howto\nto know what settings to use."), this ) ); |
90 | lab->setAlignment (AlignHCenter ); | 90 | lab->setAlignment (AlignHCenter ); |
91 | QHBox* temphb; | 91 | QHBox* temphb; |
92 | temphb = new QHBox( this ); | 92 | temphb = new QHBox( this ); |
93 | new QLabel( i18n("I/O device: "), temphb ); | 93 | new QLabel( i18n("I/O device: "), temphb ); |
94 | mPhoneDevice = new QLineEdit( temphb); | 94 | mPhoneDevice = new QLineEdit( temphb); |
95 | lay->addWidget( temphb ); | 95 | lay->addWidget( temphb ); |
96 | temphb = new QHBox( this ); | 96 | temphb = new QHBox( this ); |
97 | new QLabel( i18n("Connection: "), temphb ); | 97 | new QLabel( i18n("Connection: "), temphb ); |
98 | mPhoneConnection = new QLineEdit( temphb); | 98 | mPhoneConnection = new QLineEdit( temphb); |
99 | lay->addWidget( temphb ); | 99 | lay->addWidget( temphb ); |
100 | temphb = new QHBox( this ); | 100 | temphb = new QHBox( this ); |
101 | new QLabel( i18n("Model(opt.): "), temphb ); | 101 | new QLabel( i18n("Model(opt.): "), temphb ); |
102 | mPhoneModel = new QLineEdit( temphb); | 102 | mPhoneModel = new QLineEdit( temphb); |
103 | lay->addWidget( temphb ); | 103 | lay->addWidget( temphb ); |
104 | mWriteBackFuture= new QCheckBox( i18n("Write back events in future only"), this ); | 104 | mWriteBackFuture= new QCheckBox( i18n("Write back events in future only"), this ); |
105 | mWriteBackFuture->setChecked( true ); | 105 | mWriteBackFuture->setChecked( true ); |
106 | lay->addWidget( mWriteBackFuture ); | 106 | lay->addWidget( mWriteBackFuture ); |
107 | temphb = new QHBox( this ); | 107 | temphb = new QHBox( this ); |
108 | new QLabel( i18n("Max. weeks in future: ") , temphb ); | 108 | new QLabel( i18n("Max. weeks in future: ") , temphb ); |
109 | mWriteBackFutureWeeks= new QSpinBox(1,104, 1, temphb); | 109 | mWriteBackFutureWeeks= new QSpinBox(1,104, 1, temphb); |
110 | mWriteBackFutureWeeks->setValue( 8 ); | 110 | mWriteBackFutureWeeks->setValue( 8 ); |
111 | lay->addWidget( temphb ); | 111 | lay->addWidget( temphb ); |
112 | lay->addWidget(lab = new QLabel( i18n("NOTE: This will remove all old\ntodo/calendar data on phone!"), this ) ); | 112 | lay->addWidget(lab = new QLabel( i18n("NOTE: This will remove all old\ntodo/calendar data on phone!"), this ) ); |
113 | lab->setAlignment (AlignHCenter ); | 113 | lab->setAlignment (AlignHCenter ); |
114 | QPushButton * ok = new QPushButton( i18n("Export to mobile phone!"), this ); | 114 | QPushButton * ok = new QPushButton( i18n("Export to mobile phone!"), this ); |
115 | lay->addWidget( ok ); | 115 | lay->addWidget( ok ); |
116 | QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); | 116 | QPushButton * cancel = new QPushButton( i18n("Cancel"), this ); |
117 | lay->addWidget( cancel ); | 117 | lay->addWidget( cancel ); |
118 | connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); | 118 | connect ( ok,SIGNAL(clicked() ),this , SLOT ( accept() ) ); |
119 | connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); | 119 | connect (cancel, SIGNAL(clicked() ), this, SLOT ( reject()) ); |
120 | resize( 220, 240 ); | 120 | resize( 220, 240 ); |
121 | qApp->processEvents(); | 121 | qApp->processEvents(); |
122 | int dw = QApplication::desktop()->width(); | 122 | int dw = QApplication::desktop()->width(); |
123 | int dh = QApplication::desktop()->height(); | 123 | int dh = QApplication::desktop()->height(); |
124 | move( (dw-width())/2, (dh - height() )/2 ); | 124 | move( (dw-width())/2, (dh - height() )/2 ); |
125 | } | 125 | } |
126 | 126 | ||
127 | public: | 127 | public: |
128 | QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel; | 128 | QLineEdit* mPhoneConnection, *mPhoneDevice, *mPhoneModel; |
129 | QCheckBox* mWriteBackFuture; | 129 | QCheckBox* mWriteBackFuture; |
130 | QSpinBox* mWriteBackFutureWeeks; | 130 | QSpinBox* mWriteBackFutureWeeks; |
131 | }; | 131 | }; |
132 | 132 | ||
133 | QPixmap* sgListViewCompletedPix[6]; | 133 | QPixmap* sgListViewCompletedPix[6]; |
134 | 134 | ||
135 | 135 | ||
136 | int globalFlagBlockStartup; | 136 | int globalFlagBlockStartup; |
137 | MainWindow::MainWindow( QWidget *parent, const char *name, QString msg) : | 137 | MainWindow::MainWindow( QWidget *parent, const char *name ) : |
138 | QMainWindow( parent, name ) | 138 | QMainWindow( parent, name ) |
139 | { | 139 | { |
140 | sgListViewCompletedPix[5] = &listviewPix; | 140 | sgListViewCompletedPix[5] = &listviewPix; |
141 | sgListViewCompletedPix[0] = &listviewPix0; | 141 | sgListViewCompletedPix[0] = &listviewPix0; |
142 | sgListViewCompletedPix[1] = &listviewPix20; | 142 | sgListViewCompletedPix[1] = &listviewPix20; |
143 | sgListViewCompletedPix[2] = &listviewPix40; | 143 | sgListViewCompletedPix[2] = &listviewPix40; |
144 | sgListViewCompletedPix[3] = &listviewPix60; | 144 | sgListViewCompletedPix[3] = &listviewPix60; |
145 | sgListViewCompletedPix[4] = &listviewPix80; | 145 | sgListViewCompletedPix[4] = &listviewPix80; |
146 | if ( sgListViewCompletedPix[5]->height() < 5 ) { | 146 | if ( sgListViewCompletedPix[5]->height() < 5 ) { |
147 | int size = 12; | 147 | //int size = 12; |
148 | sgListViewCompletedPix[5]->resize( 11, 11 ); | 148 | sgListViewCompletedPix[5]->resize( 11, 11 ); |
149 | sgListViewCompletedPix[5]->fill( Qt::white ); | 149 | sgListViewCompletedPix[5]->fill( Qt::white ); |
150 | QPainter p ( sgListViewCompletedPix[5] ); | 150 | QPainter p ( sgListViewCompletedPix[5] ); |
151 | p.drawRect( 0,0,11,11); | 151 | p.drawRect( 0,0,11,11); |
152 | int half = size/2; | ||
153 | int heihei = size/2; | ||
154 | int x = 1; | ||
155 | p.drawLine ( 2, 5, 4 , 7 ) ; | 152 | p.drawLine ( 2, 5, 4 , 7 ) ; |
156 | p.drawLine ( 4 , 7 , 8, 3) ; | 153 | p.drawLine ( 4 , 7 , 8, 3) ; |
157 | int iii = 0; | 154 | int iii = 0; |
158 | for ( iii = 0; iii < 5; ++iii ) { | 155 | for ( iii = 0; iii < 5; ++iii ) { |
159 | sgListViewCompletedPix[iii]->resize( 11, 11 ); | 156 | sgListViewCompletedPix[iii]->resize( 11, 11 ); |
160 | sgListViewCompletedPix[iii]->fill( Qt::white ); | 157 | sgListViewCompletedPix[iii]->fill( Qt::white ); |
161 | QPainter p ( sgListViewCompletedPix[iii] ); | 158 | QPainter p ( sgListViewCompletedPix[iii] ); |
162 | p.drawRect( 0,0,11,11); | 159 | p.drawRect( 0,0,11,11); |
163 | if ( iii ) | 160 | if ( iii ) |
164 | p.fillRect( 1,1,iii*2,9,Qt::gray ); | 161 | p.fillRect( 1,1,iii*2,9,Qt::gray ); |
165 | } | 162 | } |
166 | } | 163 | } |
167 | mClosed = false; | 164 | mClosed = false; |
168 | //QString confFile = KStandardDirs::appDir() + "config/korganizerrc"; | 165 | //QString confFile = KStandardDirs::appDir() + "config/korganizerrc"; |
169 | QString confFile = locateLocal("config","korganizerrc"); | 166 | QString confFile = locateLocal("config","korganizerrc"); |
170 | QFileInfo finf ( confFile ); | 167 | QFileInfo finf ( confFile ); |
171 | bool showWarning = !finf.exists(); | 168 | bool showWarning = !finf.exists(); |
172 | setIcon(SmallIcon( "ko24" ) ); | 169 | setIcon(SmallIcon( "ko24" ) ); |
173 | mBlockAtStartup = true; | 170 | mBlockAtStartup = true; |
174 | mFlagKeyPressed = false; | 171 | mFlagKeyPressed = false; |
175 | setCaption("KO/Pi"); | 172 | setCaption("KO/Pi"); |
176 | KOPrefs *p = KOPrefs::instance(); | 173 | KOPrefs *p = KOPrefs::instance(); |
177 | //KPimGlobalPrefs::instance()->setGlobalConfig(); | 174 | //KPimGlobalPrefs::instance()->setGlobalConfig(); |
178 | p->mCurrentDisplayedView = 0; | 175 | p->mCurrentDisplayedView = 0; |
179 | if ( p->mHourSize > 22 ) | 176 | if ( p->mHourSize > 22 ) |
180 | p->mHourSize = 22; | 177 | p->mHourSize = 22; |
181 | QMainWindow::ToolBarDock tbd; | 178 | QMainWindow::ToolBarDock tbd; |
182 | if ( p->mToolBarHor ) { | 179 | if ( p->mToolBarHor ) { |
183 | if ( p->mToolBarUp ) | 180 | if ( p->mToolBarUp ) |
184 | tbd = Bottom; | 181 | tbd = Bottom; |
185 | else | 182 | else |
186 | tbd = Top; | 183 | tbd = Top; |
187 | } | 184 | } |
188 | else { | 185 | else { |
189 | if ( p->mToolBarUp ) | 186 | if ( p->mToolBarUp ) |
190 | tbd = Right; | 187 | tbd = Right; |
191 | else | 188 | else |
192 | tbd = Left; | 189 | tbd = Left; |
193 | } | 190 | } |
194 | if ( KOPrefs::instance()->mUseAppColors ) | 191 | if ( KOPrefs::instance()->mUseAppColors ) |
195 | QApplication::setPalette( QPalette (KOPrefs::instance()->mAppColor1, KOPrefs::instance()->mAppColor2), true ); | 192 | QApplication::setPalette( QPalette (KOPrefs::instance()->mAppColor1, KOPrefs::instance()->mAppColor2), true ); |
196 | globalFlagBlockStartup = 1; | 193 | globalFlagBlockStartup = 1; |
197 | iconToolBar = new QPEToolBar( this ); | 194 | iconToolBar = new QPEToolBar( this ); |
198 | addToolBar (iconToolBar , tbd ); | 195 | addToolBar (iconToolBar , tbd ); |
199 | 196 | ||
200 | #ifdef DESKTOP_VERSION | 197 | #ifdef DESKTOP_VERSION |
201 | if ( KOPrefs::instance()->mShowIconFilter ) | 198 | if ( KOPrefs::instance()->mShowIconFilter ) |
202 | #else | 199 | #else |
@@ -299,97 +296,96 @@ MainWindow::MainWindow( QWidget *parent, const char *name, QString msg) : | |||
299 | mView->setSyncManager(mSyncManager); | 296 | mView->setSyncManager(mSyncManager); |
300 | #ifndef DESKTOP_VERSION | 297 | #ifndef DESKTOP_VERSION |
301 | iconToolBar->show(); | 298 | iconToolBar->show(); |
302 | qApp->processEvents(); | 299 | qApp->processEvents(); |
303 | #endif | 300 | #endif |
304 | //qDebug("Splashwidget x %d y %d w %d h %d", splash-> x(), splash->y(), splash->width(),splash-> height ()); | 301 | //qDebug("Splashwidget x %d y %d w %d h %d", splash-> x(), splash->y(), splash->width(),splash-> height ()); |
305 | int vh = height() ; | 302 | int vh = height() ; |
306 | int vw = width(); | 303 | int vw = width(); |
307 | //qDebug("Toolbar hei %d ",iconToolBar->height() ); | 304 | //qDebug("Toolbar hei %d ",iconToolBar->height() ); |
308 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { | 305 | if ( iconToolBar->orientation () == Qt:: Horizontal ) { |
309 | vh -= iconToolBar->height(); | 306 | vh -= iconToolBar->height(); |
310 | } else { | 307 | } else { |
311 | vw -= iconToolBar->height(); | 308 | vw -= iconToolBar->height(); |
312 | } | 309 | } |
313 | //mView->setMaximumSize( splash->size() ); | 310 | //mView->setMaximumSize( splash->size() ); |
314 | //mView->resize( splash->size() ); | 311 | //mView->resize( splash->size() ); |
315 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); | 312 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); |
316 | mView->readSettings(); | 313 | mView->readSettings(); |
317 | bool newFile = false; | 314 | bool newFile = false; |
318 | if( !QFile::exists( defaultFileName() ) ) { | 315 | if( !QFile::exists( defaultFileName() ) ) { |
319 | QFileInfo finfo ( defaultFileName() ); | 316 | QFileInfo finfo ( defaultFileName() ); |
320 | QString oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/Applications/korganizer/mycalendar.ics"); | 317 | QString oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/Applications/korganizer/mycalendar.ics"); |
321 | QString message = "You are starting KO/Pi for the\nfirst time after updating to a\nversion >= 1.9.1. The location of the\ndefault calendar file has changed.\nA mycalendar.ics file was detected\nat the old location.\nThis file will be loaded now\nand stored at the new location!\n(Config file location has changed, too!)\nPlease read menu Help-What's New!\n"; | 318 | QString message = "You are starting KO/Pi for the\nfirst time after updating to a\nversion >= 1.9.1. The location of the\ndefault calendar file has changed.\nA mycalendar.ics file was detected\nat the old location.\nThis file will be loaded now\nand stored at the new location!\n(Config file location has changed, too!)\nPlease read menu Help-What's New!\n"; |
322 | finfo.setFile( oldFile ); | 319 | finfo.setFile( oldFile ); |
323 | if (finfo.exists() ) { | 320 | if (finfo.exists() ) { |
324 | KMessageBox::information( this, message); | 321 | KMessageBox::information( this, message); |
325 | mView->openCalendar( oldFile ); | 322 | mView->openCalendar( oldFile ); |
326 | qApp->processEvents(); | 323 | qApp->processEvents(); |
327 | } else { | 324 | } else { |
328 | oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/korganizer/mycalendar.ics"); | 325 | oldFile = QDir::convertSeparators( QDir::homeDirPath()+"/korganizer/mycalendar.ics"); |
329 | finfo.setFile( oldFile ); | 326 | finfo.setFile( oldFile ); |
330 | if (finfo.exists() ) { | 327 | if (finfo.exists() ) { |
331 | KMessageBox::information( this, message); | 328 | KMessageBox::information( this, message); |
332 | mView->openCalendar( oldFile ); | 329 | mView->openCalendar( oldFile ); |
333 | qApp->processEvents(); | 330 | qApp->processEvents(); |
334 | } | 331 | } |
335 | } | 332 | } |
336 | mView->saveCalendar( defaultFileName() ); | 333 | mView->saveCalendar( defaultFileName() ); |
337 | newFile = true; | 334 | newFile = true; |
338 | } | 335 | } |
339 | 336 | ||
340 | QTime neededSaveTime = QDateTime::currentDateTime().time(); | 337 | QTime neededSaveTime = QDateTime::currentDateTime().time(); |
341 | mView->loadCalendars(); | 338 | mView->loadCalendars(); |
342 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); | 339 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); |
343 | qDebug("KO: Calendar loading time: %d ms",msNeeded ); | 340 | qDebug("KO: Calendar loading time: %d ms",msNeeded ); |
344 | 341 | ||
345 | if ( KPimGlobalPrefs::instance()->mPreferredLanguage != KOPrefs::instance()->mOldLoadedLanguage ) { | 342 | if ( KPimGlobalPrefs::instance()->mPreferredLanguage != KOPrefs::instance()->mOldLoadedLanguage ) { |
346 | KOPrefs::instance()->setAllDefaults(); | 343 | KOPrefs::instance()->setAllDefaults(); |
347 | int count = mView->addCategories(); | ||
348 | } | 344 | } |
349 | processIncidenceSelection( 0 ); | 345 | processIncidenceSelection( 0 ); |
350 | connect( mView, SIGNAL( incidenceSelected( Incidence * ) ), | 346 | connect( mView, SIGNAL( incidenceSelected( Incidence * ) ), |
351 | SLOT( processIncidenceSelection( Incidence * ) ) ); | 347 | SLOT( processIncidenceSelection( Incidence * ) ) ); |
352 | connect( mView, SIGNAL( modifiedChanged( bool ) ), | 348 | connect( mView, SIGNAL( modifiedChanged( bool ) ), |
353 | SLOT( slotModifiedChanged( bool ) ) ); | 349 | SLOT( slotModifiedChanged( bool ) ) ); |
354 | 350 | ||
355 | 351 | ||
356 | connect( mView, SIGNAL( tempDisableBR(bool) ), | 352 | connect( mView, SIGNAL( tempDisableBR(bool) ), |
357 | SLOT( disableBR(bool) ) ); | 353 | SLOT( disableBR(bool) ) ); |
358 | connect( &mSaveTimer, SIGNAL( timeout() ), SLOT( save() ) ); | 354 | connect( &mSaveTimer, SIGNAL( timeout() ), SLOT( save() ) ); |
359 | mView->setModified( false ); | 355 | mView->setModified( false ); |
360 | mBlockAtStartup = false; | 356 | mBlockAtStartup = false; |
361 | mView->setModified( false ); | 357 | mView->setModified( false ); |
362 | setCentralWidget( mView ); | 358 | setCentralWidget( mView ); |
363 | globalFlagBlockStartup = 0; | 359 | globalFlagBlockStartup = 0; |
364 | mView->show(); | 360 | mView->show(); |
365 | delete splash; | 361 | delete splash; |
366 | if ( newFile ) | 362 | if ( newFile ) |
367 | mView->updateConfig(); | 363 | mView->updateConfig(); |
368 | // qApp->processEvents(); | 364 | // qApp->processEvents(); |
369 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); | 365 | //qDebug("MainView x %d y %d w %d h %d", mView->x(),mView-> y(), mView->width(), mView->height ()); |
370 | //fillSyncMenu(); | 366 | //fillSyncMenu(); |
371 | 367 | ||
372 | 368 | ||
373 | connect(mSyncManager , SIGNAL( save() ), this, SLOT( save() ) ); | 369 | connect(mSyncManager , SIGNAL( save() ), this, SLOT( save() ) ); |
374 | connect(mView , SIGNAL( save() ), this, SLOT( save() ) ); | 370 | connect(mView , SIGNAL( save() ), this, SLOT( save() ) ); |
375 | connect(mView , SIGNAL( saveStopTimer() ), this, SLOT( saveStopTimer() ) ); | 371 | connect(mView , SIGNAL( saveStopTimer() ), this, SLOT( saveStopTimer() ) ); |
376 | connect(mSyncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); | 372 | connect(mSyncManager , SIGNAL( request_file() ), this, SLOT( syncFileRequest() ) ); |
377 | connect(mSyncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); | 373 | connect(mSyncManager , SIGNAL( getFile( bool )), this, SLOT(getFile( bool ) ) ); |
378 | mSyncManager->setDefaultFileName( sentSyncFile()); | 374 | mSyncManager->setDefaultFileName( sentSyncFile()); |
379 | connect ( syncMenu, SIGNAL( activated ( int ) ), mSyncManager, SLOT (slotSyncMenu( int ) ) ); | 375 | connect ( syncMenu, SIGNAL( activated ( int ) ), mSyncManager, SLOT (slotSyncMenu( int ) ) ); |
380 | mSyncManager->fillSyncMenu(); | 376 | mSyncManager->fillSyncMenu(); |
381 | 377 | ||
382 | 378 | ||
383 | 379 | ||
384 | mView->viewManager()->agendaView()->setStartHour( KOPrefs::instance()->mDayBegins ); | 380 | mView->viewManager()->agendaView()->setStartHour( KOPrefs::instance()->mDayBegins ); |
385 | if ( showWarning ) { | 381 | if ( showWarning ) { |
386 | KMessageBox::information( this, | 382 | KMessageBox::information( this, |
387 | "You are starting KO/Pi for the first time.\nPlease read menu: Help-What's New,\nif you did an update!\nPlease choose your timezone in the \nConfigure Dialog TAB Time Zone!\nPlease choose your language\nin the TAB Locale!\nYou get the Configure Dialog\nvia Menu: Actions - Configure....\nClick OK to show the Configure Dialog!\n", "KO/Pi information"); | 383 | "You are starting KO/Pi for the first time.\nPlease read menu: Help-What's New,\nif you did an update!\nPlease choose your timezone in the \nConfigure Dialog TAB Time Zone!\nPlease choose your language\nin the TAB Locale!\nYou get the Configure Dialog\nvia Menu: Actions - Configure....\nClick OK to show the Configure Dialog!\n", "KO/Pi information"); |
388 | qApp->processEvents(); | 384 | qApp->processEvents(); |
389 | mView->dialogManager()->showSyncOptions(); | 385 | mView->dialogManager()->showSyncOptions(); |
390 | } | 386 | } |
391 | 387 | ||
392 | //US listen for result adressed from Ka/Pi | 388 | //US listen for result adressed from Ka/Pi |
393 | #ifndef DESKTOP_VERSION | 389 | #ifndef DESKTOP_VERSION |
394 | connect(qApp, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); | 390 | connect(qApp, SIGNAL (appMessage ( const QCString &, const QByteArray & )), ExternalAppHandler::instance(), SLOT (appMessage ( const QCString &, const QByteArray & ))); |
395 | #endif | 391 | #endif |
@@ -1810,145 +1806,145 @@ void MainWindow::saveOnClose() | |||
1810 | p->mToolBarHorF = ( filterToolBar->orientation () == Qt:: Horizontal ); | 1806 | p->mToolBarHorF = ( filterToolBar->orientation () == Qt:: Horizontal ); |
1811 | } | 1807 | } |
1812 | #ifdef DESKTOP_VERSION | 1808 | #ifdef DESKTOP_VERSION |
1813 | 1809 | ||
1814 | QPoint myP; | 1810 | QPoint myP; |
1815 | myP = mapFromGlobal( iconToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1811 | myP = mapFromGlobal( iconToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1816 | if ( p->mToolBarHor ) | 1812 | if ( p->mToolBarHor ) |
1817 | p->mToolBarUp = myP.y() > height()/2; | 1813 | p->mToolBarUp = myP.y() > height()/2; |
1818 | else | 1814 | else |
1819 | p->mToolBarUp = myP.x() > width()/2; | 1815 | p->mToolBarUp = myP.x() > width()/2; |
1820 | myP = mapFromGlobal( viewToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1816 | myP = mapFromGlobal( viewToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1821 | if ( p->mToolBarHorV ) | 1817 | if ( p->mToolBarHorV ) |
1822 | p->mToolBarUpV = myP.y() > height()/2; | 1818 | p->mToolBarUpV = myP.y() > height()/2; |
1823 | else | 1819 | else |
1824 | p->mToolBarUpV = myP.x() > width()/2 ; | 1820 | p->mToolBarUpV = myP.x() > width()/2 ; |
1825 | myP = mapFromGlobal( navigatorToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1821 | myP = mapFromGlobal( navigatorToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1826 | if ( p->mToolBarHorN ) | 1822 | if ( p->mToolBarHorN ) |
1827 | p->mToolBarUpN = myP.y() > height()/2; | 1823 | p->mToolBarUpN = myP.y() > height()/2; |
1828 | else | 1824 | else |
1829 | p->mToolBarUpN = myP.x() > width()/2 ; | 1825 | p->mToolBarUpN = myP.x() > width()/2 ; |
1830 | if ( filterToolBar ) { | 1826 | if ( filterToolBar ) { |
1831 | myP = mapFromGlobal( filterToolBar->mapToGlobal( QPoint( 0,0) ) ); | 1827 | myP = mapFromGlobal( filterToolBar->mapToGlobal( QPoint( 0,0) ) ); |
1832 | if ( p->mToolBarHorF ) | 1828 | if ( p->mToolBarHorF ) |
1833 | p->mToolBarUpF = myP.y() > height()/2; | 1829 | p->mToolBarUpF = myP.y() > height()/2; |
1834 | else | 1830 | else |
1835 | p->mToolBarUpF = myP.x() > width()/2 ; | 1831 | p->mToolBarUpF = myP.x() > width()/2 ; |
1836 | } | 1832 | } |
1837 | #else | 1833 | #else |
1838 | if ( p->mToolBarHor ) | 1834 | if ( p->mToolBarHor ) |
1839 | p->mToolBarUp = iconToolBar->y() > height()/2; | 1835 | p->mToolBarUp = iconToolBar->y() > height()/2; |
1840 | else | 1836 | else |
1841 | p->mToolBarUp = iconToolBar->x() > width()/2; | 1837 | p->mToolBarUp = iconToolBar->x() > width()/2; |
1842 | if ( p->mToolBarHorV ) | 1838 | if ( p->mToolBarHorV ) |
1843 | p->mToolBarUpV = viewToolBar->y() > height()/2; | 1839 | p->mToolBarUpV = viewToolBar->y() > height()/2; |
1844 | else | 1840 | else |
1845 | p->mToolBarUpV = viewToolBar->x() > width()/2 ; | 1841 | p->mToolBarUpV = viewToolBar->x() > width()/2 ; |
1846 | 1842 | ||
1847 | if ( p->mToolBarHorN ) | 1843 | if ( p->mToolBarHorN ) |
1848 | p->mToolBarUpN = navigatorToolBar->y() > height()/2; | 1844 | p->mToolBarUpN = navigatorToolBar->y() > height()/2; |
1849 | else | 1845 | else |
1850 | p->mToolBarUpN = navigatorToolBar->x() > width()/2 ; | 1846 | p->mToolBarUpN = navigatorToolBar->x() > width()/2 ; |
1851 | if ( filterToolBar ) { | 1847 | if ( filterToolBar ) { |
1852 | if ( p->mToolBarHorF ) | 1848 | if ( p->mToolBarHorF ) |
1853 | p->mToolBarUpF = filterToolBar->y() > height()/2; | 1849 | p->mToolBarUpF = filterToolBar->y() > height()/2; |
1854 | else | 1850 | else |
1855 | p->mToolBarUpF = filterToolBar->x() > width()/2 ; | 1851 | p->mToolBarUpF = filterToolBar->x() > width()/2 ; |
1856 | } | 1852 | } |
1857 | #endif | 1853 | #endif |
1858 | |||
1859 | save(); | 1854 | save(); |
1860 | mView->writeSettings(); | 1855 | mView->writeSettings(); |
1856 | mView->checkSuspendAlarm(); | ||
1861 | } | 1857 | } |
1862 | void MainWindow::slotModifiedChanged( bool changed ) | 1858 | void MainWindow::slotModifiedChanged( bool ) |
1863 | { | 1859 | { |
1864 | if ( mBlockAtStartup ) | 1860 | if ( mBlockAtStartup ) |
1865 | return; | 1861 | return; |
1866 | 1862 | ||
1867 | int msec; | 1863 | int msec; |
1868 | // we store the changes after 1 minute, | 1864 | // we store the changes after 1 minute, |
1869 | // and for safety reasons after 10 minutes again | 1865 | // and for safety reasons after 10 minutes again |
1870 | if ( !mSyncManager->blockSave() ) | 1866 | if ( !mSyncManager->blockSave() ) |
1871 | msec = (1000 * 60*KOPrefs::instance()->mAutoSaveInterval) +1000; | 1867 | msec = (1000 * 60*KOPrefs::instance()->mAutoSaveInterval) +1000; |
1872 | else | 1868 | else |
1873 | msec = 1000 * 600; | 1869 | msec = 1000 * 600; |
1874 | mSaveTimer.start( msec, true ); // 1 minute | 1870 | mSaveTimer.start( msec, true ); // 1 minute |
1875 | qDebug("KO: Saving File in %d secs!", msec/1000); | 1871 | qDebug("KO: Saving File in %d secs!", msec/1000); |
1876 | mCalendarModifiedFlag = true; | 1872 | mCalendarModifiedFlag = true; |
1877 | } | 1873 | } |
1878 | void MainWindow::saveStopTimer() | 1874 | void MainWindow::saveStopTimer() |
1879 | { | 1875 | { |
1880 | mSaveTimer.stop(); | 1876 | mSaveTimer.stop(); |
1881 | } | 1877 | } |
1882 | void MainWindow::backupAllFiles() | 1878 | void MainWindow::backupAllFiles() |
1883 | { | 1879 | { |
1884 | QDate reference ( 2000,1,1); | 1880 | QDate reference ( 2000,1,1); |
1885 | int daysTo = reference.daysTo ( QDate::currentDate() ); | 1881 | int daysTo = reference.daysTo ( QDate::currentDate() ); |
1886 | setCaption(i18n("Creating backup ... please wait ..." )); | 1882 | setCaption(i18n("Creating backup ... please wait ..." )); |
1887 | qDebug("KO: Last backup was %d days ago ", daysTo - KOPrefs::instance()->mLastBackupDate); | 1883 | qDebug("KO: Last backup was %d days ago ", daysTo - KOPrefs::instance()->mLastBackupDate); |
1888 | // we need the file path, the backup dir and the number of bups as param | 1884 | // we need the file path, the backup dir and the number of bups as param |
1889 | QString bupDir = KPimGlobalPrefs::instance()->mBackupDatadir; | 1885 | QString bupDir = KPimGlobalPrefs::instance()->mBackupDatadir; |
1890 | if ( KPimGlobalPrefs::instance()->mBackupUseDefaultDir) | 1886 | if ( KPimGlobalPrefs::instance()->mBackupUseDefaultDir) |
1891 | bupDir = KGlobalSettings::backupDataDir(); | 1887 | bupDir = KGlobalSettings::backupDataDir(); |
1892 | int retval = KApplication::createBackup( defaultFileName(), bupDir, KPimGlobalPrefs::instance()->mBackupNumbers ); | 1888 | int retval = KApplication::createBackup( defaultFileName(), bupDir, KPimGlobalPrefs::instance()->mBackupNumbers ); |
1893 | if ( retval == 0 ) { | 1889 | if ( retval == 0 ) { |
1894 | setCaption(i18n("Backup cancelled" )); | 1890 | setCaption(i18n("Backup cancelled" )); |
1895 | qDebug("KO: Backup cancelled. Will try again tomorrow "); | 1891 | qDebug("KO: Backup cancelled. Will try again tomorrow "); |
1896 | // retval == 0 : backup skipped for today, try again tomorrow | 1892 | // retval == 0 : backup skipped for today, try again tomorrow |
1897 | KOPrefs::instance()->mLastBackupDate = daysTo- KPimGlobalPrefs::instance()->mBackupDayCount+1; | 1893 | KOPrefs::instance()->mLastBackupDate = daysTo- KPimGlobalPrefs::instance()->mBackupDayCount+1; |
1898 | } else if ( retval == 1 ){ | 1894 | } else if ( retval == 1 ){ |
1899 | qDebug("KO: Backup created."); | 1895 | qDebug("KO: Backup created."); |
1900 | // backup ok | 1896 | // backup ok |
1901 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; | 1897 | QPtrList<KopiCalendarFile> calendars = KOPrefs::instance()->mCalendars; |
1902 | KopiCalendarFile * cal = calendars.first(); | 1898 | KopiCalendarFile * cal = calendars.first(); |
1903 | cal = calendars.next(); | 1899 | cal = calendars.next(); |
1904 | while ( cal ) { | 1900 | while ( cal ) { |
1905 | if ( !cal->mErrorOnLoad ) { | 1901 | if ( !cal->mErrorOnLoad ) { |
1906 | int retval = KApplication::createBackup( cal->mFileName, bupDir, KPimGlobalPrefs::instance()->mBackupNumbers ); | 1902 | KApplication::createBackup( cal->mFileName, bupDir, KPimGlobalPrefs::instance()->mBackupNumbers ); |
1907 | } | 1903 | } |
1908 | cal = calendars.next(); | 1904 | cal = calendars.next(); |
1909 | } | 1905 | } |
1910 | KOPrefs::instance()->mLastBackupDate = daysTo; | 1906 | KOPrefs::instance()->mLastBackupDate = daysTo; |
1911 | setCaption(i18n("Backup succesfully finished" )); | 1907 | setCaption(i18n("Backup succesfully finished" )); |
1912 | } else if ( retval == 2 ){ | 1908 | } else if ( retval == 2 ){ |
1913 | setCaption(i18n("Backup globally disabled" )); | 1909 | setCaption(i18n("Backup globally disabled" )); |
1914 | qDebug("KO: Backup globally cancelled."); | 1910 | qDebug("KO: Backup globally cancelled."); |
1915 | // backup globally cancelled | 1911 | // backup globally cancelled |
1916 | KPimGlobalPrefs::instance()->mBackupEnabled = false; | 1912 | KPimGlobalPrefs::instance()->mBackupEnabled = false; |
1917 | } | 1913 | } |
1918 | // retval == 3: do nothing, try again later | 1914 | // retval == 3: do nothing, try again later |
1919 | } | 1915 | } |
1920 | void MainWindow::save() | 1916 | void MainWindow::save() |
1921 | { | 1917 | { |
1922 | if ( mView->viewManager()->journalView() ) | 1918 | if ( mView->viewManager()->journalView() ) |
1923 | mView->viewManager()->journalView()->checkModified(); | 1919 | mView->viewManager()->journalView()->checkModified(); |
1924 | if ( !mCalendarModifiedFlag ) { | 1920 | if ( !mCalendarModifiedFlag ) { |
1925 | qDebug("KO: Calendar not modified. Nothing saved."); | 1921 | qDebug("KO: Calendar not modified. Nothing saved."); |
1926 | return; | 1922 | return; |
1927 | } | 1923 | } |
1928 | if ( mSyncManager->blockSave() ) | 1924 | if ( mSyncManager->blockSave() ) |
1929 | return; | 1925 | return; |
1930 | mSyncManager->setBlockSave(true); | 1926 | mSyncManager->setBlockSave(true); |
1931 | if ( mView->checkAllFileVersions() ) { | 1927 | if ( mView->checkAllFileVersions() ) { |
1932 | if ( KPimGlobalPrefs::instance()->mBackupEnabled ){ | 1928 | if ( KPimGlobalPrefs::instance()->mBackupEnabled ){ |
1933 | QDate reference ( 2000,1,1); | 1929 | QDate reference ( 2000,1,1); |
1934 | int daysTo = reference.daysTo ( QDate::currentDate() ); | 1930 | int daysTo = reference.daysTo ( QDate::currentDate() ); |
1935 | if ( daysTo - KPimGlobalPrefs::instance()->mBackupDayCount >= KOPrefs::instance()->mLastBackupDate ) { | 1931 | if ( daysTo - KPimGlobalPrefs::instance()->mBackupDayCount >= KOPrefs::instance()->mLastBackupDate ) { |
1936 | backupAllFiles(); | 1932 | backupAllFiles(); |
1937 | } | 1933 | } |
1938 | ; // KPimGlobalPrefs::instance()->mLastBackupDate | 1934 | ; // KPimGlobalPrefs::instance()->mLastBackupDate |
1939 | } | 1935 | } |
1940 | QTime neededSaveTime = QDateTime::currentDateTime().time(); | 1936 | QTime neededSaveTime = QDateTime::currentDateTime().time(); |
1941 | setCaption(i18n("KO/Pi:Saving Data to File ..." )); | 1937 | setCaption(i18n("KO/Pi:Saving Data to File ..." )); |
1942 | qDebug("KO: Start saving data to file!"); | 1938 | qDebug("KO: Start saving data to file!"); |
1943 | mView->saveCalendars(); | 1939 | mView->saveCalendars(); |
1944 | mCalendarModifiedFlag = false; | 1940 | mCalendarModifiedFlag = false; |
1945 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); | 1941 | int msNeeded = neededSaveTime.msecsTo( QDateTime::currentDateTime().time() ); |
1946 | qDebug("KO: Needed %d ms for saving.",msNeeded ); | 1942 | qDebug("KO: Needed %d ms for saving.",msNeeded ); |
1947 | QString savemes; | 1943 | QString savemes; |
1948 | savemes.sprintf(i18n("KO/Pi:File Saved. Needed %d sec, %d ms"),(msNeeded/1000)%100,msNeeded%1000 ); | 1944 | savemes.sprintf(i18n("KO/Pi:File Saved. Needed %d sec, %d ms"),(msNeeded/1000)%100,msNeeded%1000 ); |
1949 | setCaption(savemes); | 1945 | setCaption(savemes); |
1950 | } else | 1946 | } else |
1951 | setCaption(i18n("Saving cancelled!")); | 1947 | setCaption(i18n("Saving cancelled!")); |
1952 | mSyncManager->setBlockSave( false ); | 1948 | mSyncManager->setBlockSave( false ); |
1953 | } | 1949 | } |
1954 | 1950 | ||
@@ -2363,100 +2359,99 @@ void MainWindow::saveCalendar() | |||
2363 | void MainWindow::loadCalendar() | 2359 | void MainWindow::loadCalendar() |
2364 | { | 2360 | { |
2365 | 2361 | ||
2366 | 2362 | ||
2367 | #if 0 | 2363 | #if 0 |
2368 | QString fn = KOPrefs::instance()->mLastLoadFile; | 2364 | QString fn = KOPrefs::instance()->mLastLoadFile; |
2369 | fn = KFileDialog::getOpenFileName( fn, i18n("Load backup filename"), this ); | 2365 | fn = KFileDialog::getOpenFileName( fn, i18n("Load backup filename"), this ); |
2370 | 2366 | ||
2371 | if ( fn == "" ) | 2367 | if ( fn == "" ) |
2372 | return; | 2368 | return; |
2373 | QFileInfo info; | 2369 | QFileInfo info; |
2374 | info.setFile( fn ); | 2370 | info.setFile( fn ); |
2375 | QString mess; | 2371 | QString mess; |
2376 | bool loadbup = true; | 2372 | bool loadbup = true; |
2377 | if ( info. exists() ) { | 2373 | if ( info. exists() ) { |
2378 | mess = i18n("Backup file from:\n%1\nLoading backup\nfile will delete\nyour current Data!\n").arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); | 2374 | mess = i18n("Backup file from:\n%1\nLoading backup\nfile will delete\nyour current Data!\n").arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); |
2379 | int result = QMessageBox::warning( this, "KO/Pi: Warning!", | 2375 | int result = QMessageBox::warning( this, "KO/Pi: Warning!", |
2380 | mess, | 2376 | mess, |
2381 | i18n("Load!"), i18n("Cancel"), 0, | 2377 | i18n("Load!"), i18n("Cancel"), 0, |
2382 | 0, 1 ); | 2378 | 0, 1 ); |
2383 | if ( result != 0 ) { | 2379 | if ( result != 0 ) { |
2384 | loadbup = false; | 2380 | loadbup = false; |
2385 | } | 2381 | } |
2386 | } else { | 2382 | } else { |
2387 | QMessageBox::warning( this, i18n("KO/Pi: Warning!"), | 2383 | QMessageBox::warning( this, i18n("KO/Pi: Warning!"), |
2388 | i18n("Backup file\ndoes not exist!\nNothing loaded!"), 0, 0, | 2384 | i18n("Backup file\ndoes not exist!\nNothing loaded!"), 0, 0, |
2389 | 0, 1 ); | 2385 | 0, 1 ); |
2390 | 2386 | ||
2391 | return; | 2387 | return; |
2392 | } | 2388 | } |
2393 | if ( loadbup ) { | 2389 | if ( loadbup ) { |
2394 | mView->openCalendar( fn ); | 2390 | mView->openCalendar( fn ); |
2395 | KOPrefs::instance()->mLastLoadFile = fn; | 2391 | KOPrefs::instance()->mLastLoadFile = fn; |
2396 | mess = i18n("KO/Pi:Loaded %1").arg(fn) ; | 2392 | mess = i18n("KO/Pi:Loaded %1").arg(fn) ; |
2397 | setCaption(mess); | 2393 | setCaption(mess); |
2398 | } | 2394 | } |
2399 | #endif | 2395 | #endif |
2400 | 2396 | ||
2401 | } | 2397 | } |
2402 | void MainWindow::quickImportIcal() | 2398 | void MainWindow::quickImportIcal() |
2403 | { | 2399 | { |
2404 | importFile( KOPrefs::instance()->mLastImportFile, false ); | 2400 | importFile( KOPrefs::instance()->mLastImportFile, false ); |
2405 | } | 2401 | } |
2406 | void MainWindow::importFile( QString fn, bool quick ) | 2402 | void MainWindow::importFile( QString fn, bool quick ) |
2407 | { | 2403 | { |
2408 | QFileInfo info; | 2404 | QFileInfo info; |
2409 | info.setFile( fn ); | 2405 | info.setFile( fn ); |
2410 | QString mess; | 2406 | QString mess; |
2411 | bool loadbup = true; | ||
2412 | if ( !info. exists() ) { | 2407 | if ( !info. exists() ) { |
2413 | mess = i18n("Import file \n...%1\ndoes not exist!\nNothing imported!\n").arg(fn.right( 30)); | 2408 | mess = i18n("Import file \n...%1\ndoes not exist!\nNothing imported!\n").arg(fn.right( 30)); |
2414 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"), | 2409 | QMessageBox::warning( this, i18n("KO/Pi: Warning!"), |
2415 | mess ); | 2410 | mess ); |
2416 | return; | 2411 | return; |
2417 | } | 2412 | } |
2418 | int result = 0; | 2413 | int result = 0; |
2419 | if ( !quick ) { | 2414 | if ( !quick ) { |
2420 | mess = i18n( "Import file \n...%1\nfrom:\n%2\nDuplicated entries\nwill not be imported!\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); | 2415 | mess = i18n( "Import file \n...%1\nfrom:\n%2\nDuplicated entries\nwill not be imported!\n").arg(fn.right( 25)).arg(KGlobal::locale()->formatDateTime(info.lastModified (), true, false )); |
2421 | result = QMessageBox::warning( this, "KO/Pi: Warning!", | 2416 | result = QMessageBox::warning( this, "KO/Pi: Warning!", |
2422 | mess, | 2417 | mess, |
2423 | "Import", "Cancel", 0, | 2418 | "Import", "Cancel", 0, |
2424 | 0, 1 ); | 2419 | 0, 1 ); |
2425 | } | 2420 | } |
2426 | if ( result == 0 ) { | 2421 | if ( result == 0 ) { |
2427 | if ( mView->openCalendar( fn, true )) { | 2422 | if ( mView->openCalendar( fn, true )) { |
2428 | KOPrefs::instance()->mLastImportFile = fn; | 2423 | KOPrefs::instance()->mLastImportFile = fn; |
2429 | setCaption(i18n("Imported file successfully")); | 2424 | setCaption(i18n("Imported file successfully")); |
2430 | } else { | 2425 | } else { |
2431 | setCaption(i18n("Error importing file")); | 2426 | setCaption(i18n("Error importing file")); |
2432 | } | 2427 | } |
2433 | } | 2428 | } |
2434 | } | 2429 | } |
2435 | 2430 | ||
2436 | void MainWindow::importIcal() | 2431 | void MainWindow::importIcal() |
2437 | { | 2432 | { |
2438 | 2433 | ||
2439 | QString fn =KOPrefs::instance()->mLastImportFile; | 2434 | QString fn =KOPrefs::instance()->mLastImportFile; |
2440 | 2435 | ||
2441 | fn =KFileDialog:: getOpenFileName( fn, i18n("Import filename(*.ics/*.vcs)"), this ); | 2436 | fn =KFileDialog:: getOpenFileName( fn, i18n("Import filename(*.ics/*.vcs)"), this ); |
2442 | if ( fn == "" ) | 2437 | if ( fn == "" ) |
2443 | return; | 2438 | return; |
2444 | importFile( fn, true ); | 2439 | importFile( fn, true ); |
2445 | 2440 | ||
2446 | } | 2441 | } |
2447 | 2442 | ||
2448 | void MainWindow::exportVCalendar() | 2443 | void MainWindow::exportVCalendar() |
2449 | { | 2444 | { |
2450 | QString fn = KOPrefs::instance()->mLastVcalFile; | 2445 | QString fn = KOPrefs::instance()->mLastVcalFile; |
2451 | fn = KFileDialog::getSaveFileName( fn, i18n("Export vcal filename(*.vcs)"), this ); | 2446 | fn = KFileDialog::getSaveFileName( fn, i18n("Export vcal filename(*.vcs)"), this ); |
2452 | if ( fn == "" ) | 2447 | if ( fn == "" ) |
2453 | return; | 2448 | return; |
2454 | QFileInfo info; | 2449 | QFileInfo info; |
2455 | info.setFile( fn ); | 2450 | info.setFile( fn ); |
2456 | QString mes; | 2451 | QString mes; |
2457 | bool createbup = true; | 2452 | bool createbup = true; |
2458 | if ( info. exists() ) { | 2453 | if ( info. exists() ) { |
2459 | mes = i18n("Save file\nalready exists!\nOld save file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); | 2454 | mes = i18n("Save file\nalready exists!\nOld save file from:\n%1\nOverwrite?\n").arg (KGlobal::locale()->formatDateTime(info.lastModified (), true, false ) ); |
2460 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, | 2455 | int result = QMessageBox::warning( this, i18n("KO/Pi: Warning!"),mes, |
2461 | i18n("Overwrite!"), i18n("Cancel"), 0, | 2456 | i18n("Overwrite!"), i18n("Cancel"), 0, |
2462 | 0, 1 ); | 2457 | 0, 1 ); |
diff --git a/korganizer/mainwindow.h b/korganizer/mainwindow.h index 953774f..a948a52 100644 --- a/korganizer/mainwindow.h +++ b/korganizer/mainwindow.h | |||
@@ -1,87 +1,87 @@ | |||
1 | #ifndef KORGE_MAINWINDOW_H | 1 | #ifndef KORGE_MAINWINDOW_H |
2 | #define KORGE_MAINWINDOW_H | 2 | #define KORGE_MAINWINDOW_H |
3 | 3 | ||
4 | #include <qmainwindow.h> | 4 | #include <qmainwindow.h> |
5 | #include <qtimer.h> | 5 | #include <qtimer.h> |
6 | #include <qdict.h> | 6 | #include <qdict.h> |
7 | #include <qfile.h> | 7 | #include <qfile.h> |
8 | #include <qmenubar.h> | 8 | #include <qmenubar.h> |
9 | #include <qtextstream.h> | 9 | #include <qtextstream.h> |
10 | #include <qregexp.h> | 10 | #include <qregexp.h> |
11 | 11 | ||
12 | #include <libkcal/incidence.h> | 12 | #include <libkcal/incidence.h> |
13 | #include <ksyncmanager.h> | 13 | #include <ksyncmanager.h> |
14 | #ifndef DESKTOP_VERSION | 14 | #ifndef DESKTOP_VERSION |
15 | #include <qcopchannel_qws.h> | 15 | #include <qcopchannel_qws.h> |
16 | #endif | 16 | #endif |
17 | class QAction; | 17 | class QAction; |
18 | class CalendarView; | 18 | class CalendarView; |
19 | class KSyncProfile; | 19 | class KSyncProfile; |
20 | #ifdef DESKTOP_VERSION | 20 | #ifdef DESKTOP_VERSION |
21 | 21 | ||
22 | #define QPEToolBar QToolBar | 22 | #define QPEToolBar QToolBar |
23 | #define QPEMenuBar QMenuBar | 23 | #define QPEMenuBar QMenuBar |
24 | #endif | 24 | #endif |
25 | class QPEToolBar; | 25 | class QPEToolBar; |
26 | class QPEMenuBar; | 26 | class QPEMenuBar; |
27 | 27 | ||
28 | 28 | ||
29 | namespace KCal { | 29 | namespace KCal { |
30 | class CalendarLocal; | 30 | class CalendarLocal; |
31 | } | 31 | } |
32 | 32 | ||
33 | using namespace KCal; | 33 | using namespace KCal; |
34 | 34 | ||
35 | class MainWindow : public QMainWindow | 35 | class MainWindow : public QMainWindow |
36 | { | 36 | { |
37 | Q_OBJECT | 37 | Q_OBJECT |
38 | public: | 38 | public: |
39 | MainWindow( QWidget *parent = 0, const char *name = 0, QString command = ""); | 39 | MainWindow( QWidget *parent = 0, const char *name = 0 ); |
40 | ~MainWindow(); | 40 | ~MainWindow(); |
41 | bool beamReceiveEnabled(); | 41 | bool beamReceiveEnabled(); |
42 | static QString defaultFileName(); | 42 | static QString defaultFileName(); |
43 | static QString syncFileName(); | 43 | static QString syncFileName(); |
44 | static QString resourcePath(); | 44 | static QString resourcePath(); |
45 | public slots: | 45 | public slots: |
46 | void setUsesBigPixmaps ( bool ); | 46 | void setUsesBigPixmaps ( bool ); |
47 | void setCaption ( const QString & ); | 47 | void setCaption ( const QString & ); |
48 | void updateWeekNum(const KCal::DateList &); | 48 | void updateWeekNum(const KCal::DateList &); |
49 | void updateWeek(QDate); | 49 | void updateWeek(QDate); |
50 | void updateFilterToolbar(); | 50 | void updateFilterToolbar(); |
51 | virtual void showMaximized (); | 51 | virtual void showMaximized (); |
52 | void configureAgenda( int ); | 52 | void configureAgenda( int ); |
53 | void recieve( const QCString& msg, const QByteArray& data ); | 53 | void recieve( const QCString& msg, const QByteArray& data ); |
54 | protected slots: | 54 | protected slots: |
55 | void startMultiSync(); | 55 | void startMultiSync(); |
56 | void setCaptionToDates(); | 56 | void setCaptionToDates(); |
57 | void weekAction(); | 57 | void weekAction(); |
58 | void about(); | 58 | void about(); |
59 | void licence(); | 59 | void licence(); |
60 | void faq(); | 60 | void faq(); |
61 | void usertrans(); | 61 | void usertrans(); |
62 | void features(); | 62 | void features(); |
63 | void synchowto(); | 63 | void synchowto(); |
64 | void storagehowto(); | 64 | void storagehowto(); |
65 | void timetrackinghowto(); | 65 | void timetrackinghowto(); |
66 | void kdesynchowto(); | 66 | void kdesynchowto(); |
67 | void multisynchowto(); | 67 | void multisynchowto(); |
68 | void whatsNew(); | 68 | void whatsNew(); |
69 | void keyBindings(); | 69 | void keyBindings(); |
70 | void aboutAutoSaving();; | 70 | void aboutAutoSaving();; |
71 | void aboutKnownBugs(); | 71 | void aboutKnownBugs(); |
72 | 72 | ||
73 | void processIncidenceSelection( Incidence * ); | 73 | void processIncidenceSelection( Incidence * ); |
74 | 74 | ||
75 | void importQtopia(); | 75 | void importQtopia(); |
76 | void importBday(); | 76 | void importBday(); |
77 | void importOL(); | 77 | void importOL(); |
78 | void importIcal(); | 78 | void importIcal(); |
79 | void importFile( QString, bool ); | 79 | void importFile( QString, bool ); |
80 | void quickImportIcal(); | 80 | void quickImportIcal(); |
81 | 81 | ||
82 | void slotModifiedChanged( bool ); | 82 | void slotModifiedChanged( bool ); |
83 | 83 | ||
84 | void save(); | 84 | void save(); |
85 | void backupAllFiles(); | 85 | void backupAllFiles(); |
86 | void saveStopTimer(); | 86 | void saveStopTimer(); |
87 | void configureToolBar( int ); | 87 | void configureToolBar( int ); |