-rw-r--r-- | korganizer/calendarview.cpp | 4 | ||||
-rw-r--r-- | korganizer/incomingdialog.cpp | 3 | ||||
-rw-r--r-- | korganizer/korganizerE.pro | 4 | ||||
-rw-r--r-- | korganizer/publishdialog.cpp | 3 |
4 files changed, 10 insertions, 4 deletions
diff --git a/korganizer/calendarview.cpp b/korganizer/calendarview.cpp index 369c7a0..56b3fb0 100644 --- a/korganizer/calendarview.cpp +++ b/korganizer/calendarview.cpp | |||
@@ -817,1067 +817,1069 @@ int CalendarView::takeEvent( Incidence* local, Incidence* remote, int mode , b | |||
817 | return 1; | 817 | return 1; |
818 | if ( lastSync > local->lastModified() ) | 818 | if ( lastSync > local->lastModified() ) |
819 | return 2; | 819 | return 2; |
820 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), local->lastModified().toString().latin1(), remote->lastModified().toString().latin1() ); | 820 | //qDebug("lsy %s --- lo %s --- re %s ", lastSync.toString().latin1(), local->lastModified().toString().latin1(), remote->lastModified().toString().latin1() ); |
821 | localIsNew = local->lastModified() >= remote->lastModified(); | 821 | localIsNew = local->lastModified() >= remote->lastModified(); |
822 | if ( localIsNew ) | 822 | if ( localIsNew ) |
823 | getEventViewerDialog()->setColorMode( 1 ); | 823 | getEventViewerDialog()->setColorMode( 1 ); |
824 | else | 824 | else |
825 | getEventViewerDialog()->setColorMode( 2 ); | 825 | getEventViewerDialog()->setColorMode( 2 ); |
826 | getEventViewerDialog()->setIncidence(local); | 826 | getEventViewerDialog()->setIncidence(local); |
827 | if ( localIsNew ) | 827 | if ( localIsNew ) |
828 | getEventViewerDialog()->setColorMode( 2 ); | 828 | getEventViewerDialog()->setColorMode( 2 ); |
829 | else | 829 | else |
830 | getEventViewerDialog()->setColorMode( 1 ); | 830 | getEventViewerDialog()->setColorMode( 1 ); |
831 | getEventViewerDialog()->addIncidence(remote); | 831 | getEventViewerDialog()->addIncidence(remote); |
832 | getEventViewerDialog()->setColorMode( 0 ); | 832 | getEventViewerDialog()->setColorMode( 0 ); |
833 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); | 833 | //qDebug("local %d remote %d ",local->relatedTo(),remote->relatedTo() ); |
834 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); | 834 | getEventViewerDialog()->setCaption( mCurrentSyncDevice +i18n(" : Conflict! Please choose entry!")); |
835 | getEventViewerDialog()->showMe(); | 835 | getEventViewerDialog()->showMe(); |
836 | result = getEventViewerDialog()->executeS( localIsNew ); | 836 | result = getEventViewerDialog()->executeS( localIsNew ); |
837 | return result; | 837 | return result; |
838 | 838 | ||
839 | break; | 839 | break; |
840 | case SYNC_PREF_FORCE_LOCAL: | 840 | case SYNC_PREF_FORCE_LOCAL: |
841 | return 1; | 841 | return 1; |
842 | break; | 842 | break; |
843 | case SYNC_PREF_FORCE_REMOTE: | 843 | case SYNC_PREF_FORCE_REMOTE: |
844 | return 2; | 844 | return 2; |
845 | break; | 845 | break; |
846 | 846 | ||
847 | default: | 847 | default: |
848 | // SYNC_PREF_TAKE_BOTH not implemented | 848 | // SYNC_PREF_TAKE_BOTH not implemented |
849 | break; | 849 | break; |
850 | } | 850 | } |
851 | return 0; | 851 | return 0; |
852 | } | 852 | } |
853 | Event* CalendarView::getLastSyncEvent() | 853 | Event* CalendarView::getLastSyncEvent() |
854 | { | 854 | { |
855 | Event* lse; | 855 | Event* lse; |
856 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); | 856 | //qDebug("CurrentSyncDevice %s ",mCurrentSyncDevice .latin1() ); |
857 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); | 857 | lse = mCalendar->event( "last-syncEvent-"+mCurrentSyncDevice ); |
858 | if (!lse) { | 858 | if (!lse) { |
859 | lse = new Event(); | 859 | lse = new Event(); |
860 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); | 860 | lse->setUid( "last-syncEvent-"+mCurrentSyncDevice ); |
861 | QString sum = ""; | 861 | QString sum = ""; |
862 | if ( KOPrefs::instance()->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) | 862 | if ( KOPrefs::instance()->mExternSyncProfiles.contains( mCurrentSyncDevice ) ) |
863 | sum = "E: "; | 863 | sum = "E: "; |
864 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); | 864 | lse->setSummary(sum+mCurrentSyncDevice + i18n(" - sync event")); |
865 | lse->setDtStart( mLastCalendarSync ); | 865 | lse->setDtStart( mLastCalendarSync ); |
866 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 866 | lse->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
867 | lse->setCategories( i18n("SyncEvent") ); | 867 | lse->setCategories( i18n("SyncEvent") ); |
868 | lse->setReadOnly( true ); | 868 | lse->setReadOnly( true ); |
869 | mCalendar->addEvent( lse ); | 869 | mCalendar->addEvent( lse ); |
870 | } | 870 | } |
871 | 871 | ||
872 | return lse; | 872 | return lse; |
873 | 873 | ||
874 | } | 874 | } |
875 | // probaly useless | 875 | // probaly useless |
876 | void CalendarView::setupExternSyncProfiles() | 876 | void CalendarView::setupExternSyncProfiles() |
877 | { | 877 | { |
878 | Event* lse; | 878 | Event* lse; |
879 | mExternLastSyncEvent.clear(); | 879 | mExternLastSyncEvent.clear(); |
880 | int i; | 880 | int i; |
881 | for ( i = 0; i < KOPrefs::instance()->mExternSyncProfiles.count(); ++i ) { | 881 | for ( i = 0; i < KOPrefs::instance()->mExternSyncProfiles.count(); ++i ) { |
882 | lse = mCalendar->event( "last-syncEvent-"+ KOPrefs::instance()->mExternSyncProfiles[i] ); | 882 | lse = mCalendar->event( "last-syncEvent-"+ KOPrefs::instance()->mExternSyncProfiles[i] ); |
883 | if ( lse ) | 883 | if ( lse ) |
884 | mExternLastSyncEvent.append( lse ); | 884 | mExternLastSyncEvent.append( lse ); |
885 | else | 885 | else |
886 | qDebug("Last Sync event not found for %s ", KOPrefs::instance()->mExternSyncProfiles[i].latin1()); | 886 | qDebug("Last Sync event not found for %s ", KOPrefs::instance()->mExternSyncProfiles[i].latin1()); |
887 | } | 887 | } |
888 | 888 | ||
889 | } | 889 | } |
890 | // we check, if the to delete event has a id for a profile | 890 | // we check, if the to delete event has a id for a profile |
891 | // if yes, we set this id in the profile to delete | 891 | // if yes, we set this id in the profile to delete |
892 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) | 892 | void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) |
893 | { | 893 | { |
894 | if ( lastSync.count() == 0 ) { | 894 | if ( lastSync.count() == 0 ) { |
895 | //qDebug(" lastSync.count() == 0"); | 895 | //qDebug(" lastSync.count() == 0"); |
896 | return; | 896 | return; |
897 | } | 897 | } |
898 | if ( toDelete->type() == "Journal" ) | 898 | if ( toDelete->type() == "Journal" ) |
899 | return; | 899 | return; |
900 | 900 | ||
901 | Event* eve = lastSync.first(); | 901 | Event* eve = lastSync.first(); |
902 | 902 | ||
903 | while ( eve ) { | 903 | while ( eve ) { |
904 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name | 904 | QString id = toDelete->getID( eve->uid().mid( 15 ) ); // this is the sync profile name |
905 | if ( !id.isEmpty() ) { | 905 | if ( !id.isEmpty() ) { |
906 | QString des = eve->description(); | 906 | QString des = eve->description(); |
907 | QString pref = "e"; | 907 | QString pref = "e"; |
908 | if ( toDelete->type() == "Todo" ) | 908 | if ( toDelete->type() == "Todo" ) |
909 | pref = "t"; | 909 | pref = "t"; |
910 | des += pref+ id + ","; | 910 | des += pref+ id + ","; |
911 | eve->setReadOnly( false ); | 911 | eve->setReadOnly( false ); |
912 | eve->setDescription( des ); | 912 | eve->setDescription( des ); |
913 | //qDebug("setdes %s ", des.latin1()); | 913 | //qDebug("setdes %s ", des.latin1()); |
914 | eve->setReadOnly( true ); | 914 | eve->setReadOnly( true ); |
915 | } | 915 | } |
916 | eve = lastSync.next(); | 916 | eve = lastSync.next(); |
917 | } | 917 | } |
918 | 918 | ||
919 | } | 919 | } |
920 | void CalendarView::checkExternalId( Incidence * inc ) | 920 | void CalendarView::checkExternalId( Incidence * inc ) |
921 | { | 921 | { |
922 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; | 922 | QPtrList<Event> lastSync = mCalendar->getExternLastSyncEvents() ; |
923 | checkExternSyncEvent( lastSync, inc ); | 923 | checkExternSyncEvent( lastSync, inc ); |
924 | 924 | ||
925 | } | 925 | } |
926 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) | 926 | bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) |
927 | { | 927 | { |
928 | bool syncOK = true; | 928 | bool syncOK = true; |
929 | int addedEvent = 0; | 929 | int addedEvent = 0; |
930 | int addedEventR = 0; | 930 | int addedEventR = 0; |
931 | int deletedEventR = 0; | 931 | int deletedEventR = 0; |
932 | int deletedEventL = 0; | 932 | int deletedEventL = 0; |
933 | int changedLocal = 0; | 933 | int changedLocal = 0; |
934 | int changedRemote = 0; | 934 | int changedRemote = 0; |
935 | //QPtrList<Event> el = local->rawEvents(); | 935 | //QPtrList<Event> el = local->rawEvents(); |
936 | Event* eventR; | 936 | Event* eventR; |
937 | QString uid; | 937 | QString uid; |
938 | int take; | 938 | int take; |
939 | Event* eventL; | 939 | Event* eventL; |
940 | Event* eventRSync; | 940 | Event* eventRSync; |
941 | Event* eventLSync; | 941 | Event* eventLSync; |
942 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); | 942 | QPtrList<Event> eventRSyncSharp = remote->getExternLastSyncEvents(); |
943 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); | 943 | QPtrList<Event> eventLSyncSharp = local->getExternLastSyncEvents(); |
944 | bool fullDateRange = false; | 944 | bool fullDateRange = false; |
945 | local->resetTempSyncStat(); | 945 | local->resetTempSyncStat(); |
946 | mLastCalendarSync = QDateTime::currentDateTime(); | 946 | mLastCalendarSync = QDateTime::currentDateTime(); |
947 | QDateTime modifiedCalendar = mLastCalendarSync;; | 947 | QDateTime modifiedCalendar = mLastCalendarSync;; |
948 | eventLSync = getLastSyncEvent(); | 948 | eventLSync = getLastSyncEvent(); |
949 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); | 949 | eventR = remote->event("last-syncEvent-"+mCurrentSyncName ); |
950 | if ( eventR ) { | 950 | if ( eventR ) { |
951 | eventRSync = (Event*) eventR->clone(); | 951 | eventRSync = (Event*) eventR->clone(); |
952 | remote->deleteEvent(eventR ); | 952 | remote->deleteEvent(eventR ); |
953 | 953 | ||
954 | } else { | 954 | } else { |
955 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 955 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
956 | eventRSync = (Event*)eventLSync->clone(); | 956 | eventRSync = (Event*)eventLSync->clone(); |
957 | } else { | 957 | } else { |
958 | fullDateRange = true; | 958 | fullDateRange = true; |
959 | eventRSync = new Event(); | 959 | eventRSync = new Event(); |
960 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); | 960 | eventRSync->setSummary(mCurrentSyncName + i18n(" - sync event")); |
961 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); | 961 | eventRSync->setUid("last-syncEvent-"+mCurrentSyncName ); |
962 | eventRSync->setDtStart( mLastCalendarSync ); | 962 | eventRSync->setDtStart( mLastCalendarSync ); |
963 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); | 963 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 7200 ) ); |
964 | eventRSync->setCategories( i18n("SyncEvent") ); | 964 | eventRSync->setCategories( i18n("SyncEvent") ); |
965 | } | 965 | } |
966 | } | 966 | } |
967 | if ( eventLSync->dtStart() == mLastCalendarSync ) | 967 | if ( eventLSync->dtStart() == mLastCalendarSync ) |
968 | fullDateRange = true; | 968 | fullDateRange = true; |
969 | 969 | ||
970 | if ( ! fullDateRange ) { | 970 | if ( ! fullDateRange ) { |
971 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { | 971 | if ( eventLSync->dtStart() != eventRSync->dtStart() ) { |
972 | 972 | ||
973 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); | 973 | // qDebug("set fulldate to true %s %s" ,eventLSync->dtStart().toString().latin1(), eventRSync->dtStart().toString().latin1() ); |
974 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); | 974 | //qDebug("%d %d %d %d ", eventLSync->dtStart().time().second(), eventLSync->dtStart().time().msec() , eventRSync->dtStart().time().second(), eventRSync->dtStart().time().msec()); |
975 | fullDateRange = true; | 975 | fullDateRange = true; |
976 | } | 976 | } |
977 | } | 977 | } |
978 | if ( fullDateRange ) | 978 | if ( fullDateRange ) |
979 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); | 979 | mLastCalendarSync = QDateTime::currentDateTime().addDays( -100*365); |
980 | else | 980 | else |
981 | mLastCalendarSync = eventLSync->dtStart(); | 981 | mLastCalendarSync = eventLSync->dtStart(); |
982 | // for resyncing if own file has changed | 982 | // for resyncing if own file has changed |
983 | if ( mCurrentSyncDevice == "deleteaftersync" ) { | 983 | if ( mCurrentSyncDevice == "deleteaftersync" ) { |
984 | mLastCalendarSync = loadedFileVersion; | 984 | mLastCalendarSync = loadedFileVersion; |
985 | qDebug("setting mLastCalendarSync "); | 985 | qDebug("setting mLastCalendarSync "); |
986 | } | 986 | } |
987 | //qDebug("*************************** "); | 987 | //qDebug("*************************** "); |
988 | qDebug("mLastCalendarSync %s ",mLastCalendarSync.toString().latin1() ); | 988 | qDebug("mLastCalendarSync %s ",mLastCalendarSync.toString().latin1() ); |
989 | QPtrList<Incidence> er = remote->rawIncidences(); | 989 | QPtrList<Incidence> er = remote->rawIncidences(); |
990 | Incidence* inR = er.first(); | 990 | Incidence* inR = er.first(); |
991 | Incidence* inL; | 991 | Incidence* inL; |
992 | QProgressBar bar( er.count(),0 ); | 992 | QProgressBar bar( er.count(),0 ); |
993 | bar.setCaption (i18n("Syncing - close to abort!") ); | 993 | bar.setCaption (i18n("Syncing - close to abort!") ); |
994 | 994 | ||
995 | int w = 300; | 995 | int w = 300; |
996 | if ( QApplication::desktop()->width() < 320 ) | 996 | if ( QApplication::desktop()->width() < 320 ) |
997 | w = 220; | 997 | w = 220; |
998 | int h = bar.sizeHint().height() ; | 998 | int h = bar.sizeHint().height() ; |
999 | int dw = QApplication::desktop()->width(); | 999 | int dw = QApplication::desktop()->width(); |
1000 | int dh = QApplication::desktop()->height(); | 1000 | int dh = QApplication::desktop()->height(); |
1001 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1001 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1002 | bar.show(); | 1002 | bar.show(); |
1003 | int modulo = (er.count()/10)+1; | 1003 | int modulo = (er.count()/10)+1; |
1004 | int incCounter = 0; | 1004 | int incCounter = 0; |
1005 | while ( inR ) { | 1005 | while ( inR ) { |
1006 | if ( ! bar.isVisible() ) | 1006 | if ( ! bar.isVisible() ) |
1007 | return false; | 1007 | return false; |
1008 | if ( incCounter % modulo == 0 ) | 1008 | if ( incCounter % modulo == 0 ) |
1009 | bar.setProgress( incCounter ); | 1009 | bar.setProgress( incCounter ); |
1010 | ++incCounter; | 1010 | ++incCounter; |
1011 | uid = inR->uid(); | 1011 | uid = inR->uid(); |
1012 | bool skipIncidence = false; | 1012 | bool skipIncidence = false; |
1013 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1013 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1014 | skipIncidence = true; | 1014 | skipIncidence = true; |
1015 | QString idS; | 1015 | QString idS; |
1016 | qApp->processEvents(); | 1016 | qApp->processEvents(); |
1017 | if ( !skipIncidence ) { | 1017 | if ( !skipIncidence ) { |
1018 | inL = local->incidence( uid ); | 1018 | inL = local->incidence( uid ); |
1019 | if ( inL ) { // maybe conflict - same uid in both calendars | 1019 | if ( inL ) { // maybe conflict - same uid in both calendars |
1020 | int maxrev = inL->revision(); | 1020 | int maxrev = inL->revision(); |
1021 | if ( maxrev < inR->revision() ) | 1021 | if ( maxrev < inR->revision() ) |
1022 | maxrev = inR->revision(); | 1022 | maxrev = inR->revision(); |
1023 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { | 1023 | if ( (take = takeEvent( inL, inR, mode, fullDateRange )) > 0 ) { |
1024 | //qDebug("take %d %s ", take, inL->summary().latin1()); | 1024 | //qDebug("take %d %s ", take, inL->summary().latin1()); |
1025 | if ( take == 3 ) | 1025 | if ( take == 3 ) |
1026 | return false; | 1026 | return false; |
1027 | if ( take == 1 ) {// take local | 1027 | if ( take == 1 ) {// take local |
1028 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) | 1028 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) |
1029 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); | 1029 | inL->setCsum( mCurrentSyncDevice, inR->getCsum(mCurrentSyncDevice) ); |
1030 | else | 1030 | else |
1031 | idS = inR->IDStr(); | 1031 | idS = inR->IDStr(); |
1032 | remote->deleteIncidence( inR ); | 1032 | remote->deleteIncidence( inR ); |
1033 | if ( inL->revision() < maxrev ) | 1033 | if ( inL->revision() < maxrev ) |
1034 | inL->setRevision( maxrev ); | 1034 | inL->setRevision( maxrev ); |
1035 | inR = inL->clone(); | 1035 | inR = inL->clone(); |
1036 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1036 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1037 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) | 1037 | if ( mGlobalSyncMode != SYNC_MODE_EXTERNAL ) |
1038 | inR->setIDStr( idS ); | 1038 | inR->setIDStr( idS ); |
1039 | remote->addIncidence( inR ); | 1039 | remote->addIncidence( inR ); |
1040 | ++changedRemote; | 1040 | ++changedRemote; |
1041 | } else { | 1041 | } else { |
1042 | if ( inR->revision() < maxrev ) | 1042 | if ( inR->revision() < maxrev ) |
1043 | inR->setRevision( maxrev ); | 1043 | inR->setRevision( maxrev ); |
1044 | idS = inL->IDStr(); | 1044 | idS = inL->IDStr(); |
1045 | local->deleteIncidence( inL ); | 1045 | local->deleteIncidence( inL ); |
1046 | inL = inR->clone(); | 1046 | inL = inR->clone(); |
1047 | inL->setIDStr( idS ); | 1047 | inL->setIDStr( idS ); |
1048 | local->addIncidence( inL ); | 1048 | local->addIncidence( inL ); |
1049 | ++changedLocal; | 1049 | ++changedLocal; |
1050 | } | 1050 | } |
1051 | } | 1051 | } |
1052 | } else { // no conflict | 1052 | } else { // no conflict |
1053 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1053 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1054 | QString des = eventLSync->description(); | 1054 | QString des = eventLSync->description(); |
1055 | QString pref = "e"; | 1055 | QString pref = "e"; |
1056 | if ( inR->type() == "Todo" ) | 1056 | if ( inR->type() == "Todo" ) |
1057 | pref = "t"; | 1057 | pref = "t"; |
1058 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it | 1058 | if ( des.find(pref+ inR->getID(mCurrentSyncDevice) +"," ) >= 0 && mode != 5) { // delete it |
1059 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); | 1059 | inR->setTempSyncStat( SYNC_TEMPSTATE_DELETE ); |
1060 | //remote->deleteIncidence( inR ); | 1060 | //remote->deleteIncidence( inR ); |
1061 | ++deletedEventR; | 1061 | ++deletedEventR; |
1062 | } else { | 1062 | } else { |
1063 | inR->setLastModified( modifiedCalendar ); | 1063 | inR->setLastModified( modifiedCalendar ); |
1064 | inL = inR->clone(); | 1064 | inL = inR->clone(); |
1065 | local->addIncidence( inL ); | 1065 | local->addIncidence( inL ); |
1066 | ++addedEvent; | 1066 | ++addedEvent; |
1067 | } | 1067 | } |
1068 | } else { | 1068 | } else { |
1069 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { | 1069 | if ( inR->lastModified() > mLastCalendarSync || mode == 5 ) { |
1070 | inR->setLastModified( modifiedCalendar ); | 1070 | inR->setLastModified( modifiedCalendar ); |
1071 | local->addIncidence( inR->clone() ); | 1071 | local->addIncidence( inR->clone() ); |
1072 | ++addedEvent; | 1072 | ++addedEvent; |
1073 | } else { | 1073 | } else { |
1074 | checkExternSyncEvent(eventRSyncSharp, inR); | 1074 | checkExternSyncEvent(eventRSyncSharp, inR); |
1075 | remote->deleteIncidence( inR ); | 1075 | remote->deleteIncidence( inR ); |
1076 | ++deletedEventR; | 1076 | ++deletedEventR; |
1077 | } | 1077 | } |
1078 | } | 1078 | } |
1079 | } | 1079 | } |
1080 | } | 1080 | } |
1081 | inR = er.next(); | 1081 | inR = er.next(); |
1082 | } | 1082 | } |
1083 | QPtrList<Incidence> el = local->rawIncidences(); | 1083 | QPtrList<Incidence> el = local->rawIncidences(); |
1084 | inL = el.first(); | 1084 | inL = el.first(); |
1085 | modulo = (el.count()/10)+1; | 1085 | modulo = (el.count()/10)+1; |
1086 | bar.setCaption (i18n("Add / remove events") ); | 1086 | bar.setCaption (i18n("Add / remove events") ); |
1087 | bar.setTotalSteps ( el.count() ) ; | 1087 | bar.setTotalSteps ( el.count() ) ; |
1088 | bar.show(); | 1088 | bar.show(); |
1089 | incCounter = 0; | 1089 | incCounter = 0; |
1090 | 1090 | ||
1091 | while ( inL ) { | 1091 | while ( inL ) { |
1092 | 1092 | ||
1093 | qApp->processEvents(); | 1093 | qApp->processEvents(); |
1094 | if ( ! bar.isVisible() ) | 1094 | if ( ! bar.isVisible() ) |
1095 | return false; | 1095 | return false; |
1096 | if ( incCounter % modulo == 0 ) | 1096 | if ( incCounter % modulo == 0 ) |
1097 | bar.setProgress( incCounter ); | 1097 | bar.setProgress( incCounter ); |
1098 | ++incCounter; | 1098 | ++incCounter; |
1099 | uid = inL->uid(); | 1099 | uid = inL->uid(); |
1100 | bool skipIncidence = false; | 1100 | bool skipIncidence = false; |
1101 | if ( uid.left(15) == QString("last-syncEvent-") ) | 1101 | if ( uid.left(15) == QString("last-syncEvent-") ) |
1102 | skipIncidence = true; | 1102 | skipIncidence = true; |
1103 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->type() == "Journal" ) | 1103 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL && inL->type() == "Journal" ) |
1104 | skipIncidence = true; | 1104 | skipIncidence = true; |
1105 | if ( !skipIncidence ) { | 1105 | if ( !skipIncidence ) { |
1106 | inR = remote->incidence( uid ); | 1106 | inR = remote->incidence( uid ); |
1107 | if ( ! inR ) { | 1107 | if ( ! inR ) { |
1108 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { | 1108 | if ( mGlobalSyncMode == SYNC_MODE_EXTERNAL ) { |
1109 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { | 1109 | if ( !inL->getID(mCurrentSyncDevice).isEmpty() && mode != 4 ) { |
1110 | checkExternSyncEvent(eventLSyncSharp, inL); | 1110 | checkExternSyncEvent(eventLSyncSharp, inL); |
1111 | local->deleteIncidence( inL ); | 1111 | local->deleteIncidence( inL ); |
1112 | ++deletedEventL; | 1112 | ++deletedEventL; |
1113 | } else { | 1113 | } else { |
1114 | if ( ! KOPrefs::instance()->mWriteBackExistingOnly ) { | 1114 | if ( ! KOPrefs::instance()->mWriteBackExistingOnly ) { |
1115 | inL->removeID(mCurrentSyncDevice ); | 1115 | inL->removeID(mCurrentSyncDevice ); |
1116 | ++addedEventR; | 1116 | ++addedEventR; |
1117 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); | 1117 | //qDebug("remote added Incidence %s ", inL->summary().latin1()); |
1118 | inL->setLastModified( modifiedCalendar ); | 1118 | inL->setLastModified( modifiedCalendar ); |
1119 | inR = inL->clone(); | 1119 | inR = inL->clone(); |
1120 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); | 1120 | inR->setTempSyncStat( SYNC_TEMPSTATE_INITIAL ); |
1121 | remote->addIncidence( inR ); | 1121 | remote->addIncidence( inR ); |
1122 | } | 1122 | } |
1123 | } | 1123 | } |
1124 | } else { | 1124 | } else { |
1125 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { | 1125 | if ( inL->lastModified() < mLastCalendarSync && mode != 4 ) { |
1126 | checkExternSyncEvent(eventLSyncSharp, inL); | 1126 | checkExternSyncEvent(eventLSyncSharp, inL); |
1127 | local->deleteIncidence( inL ); | 1127 | local->deleteIncidence( inL ); |
1128 | ++deletedEventL; | 1128 | ++deletedEventL; |
1129 | } else { | 1129 | } else { |
1130 | if ( ! KOPrefs::instance()->mWriteBackExistingOnly ) { | 1130 | if ( ! KOPrefs::instance()->mWriteBackExistingOnly ) { |
1131 | ++addedEventR; | 1131 | ++addedEventR; |
1132 | inL->setLastModified( modifiedCalendar ); | 1132 | inL->setLastModified( modifiedCalendar ); |
1133 | remote->addIncidence( inL->clone() ); | 1133 | remote->addIncidence( inL->clone() ); |
1134 | } | 1134 | } |
1135 | } | 1135 | } |
1136 | } | 1136 | } |
1137 | } | 1137 | } |
1138 | } | 1138 | } |
1139 | inL = el.next(); | 1139 | inL = el.next(); |
1140 | } | 1140 | } |
1141 | int delFut = 0; | 1141 | int delFut = 0; |
1142 | if ( KOPrefs::instance()->mWriteBackInFuture ) { | 1142 | if ( KOPrefs::instance()->mWriteBackInFuture ) { |
1143 | er = remote->rawIncidences(); | 1143 | er = remote->rawIncidences(); |
1144 | inR = er.first(); | 1144 | inR = er.first(); |
1145 | QDateTime dt; | 1145 | QDateTime dt; |
1146 | QDateTime cur = QDateTime::currentDateTime(); | 1146 | QDateTime cur = QDateTime::currentDateTime(); |
1147 | QDateTime end = cur.addSecs( KOPrefs::instance()->mWriteBackInFuture * 3600 *24 *7 ); | 1147 | QDateTime end = cur.addSecs( KOPrefs::instance()->mWriteBackInFuture * 3600 *24 *7 ); |
1148 | while ( inR ) { | 1148 | while ( inR ) { |
1149 | if ( inR->type() == "Todo" ) { | 1149 | if ( inR->type() == "Todo" ) { |
1150 | Todo * t = (Todo*)inR; | 1150 | Todo * t = (Todo*)inR; |
1151 | if ( t->hasDueDate() ) | 1151 | if ( t->hasDueDate() ) |
1152 | dt = t->dtDue(); | 1152 | dt = t->dtDue(); |
1153 | else | 1153 | else |
1154 | dt = cur.addSecs( 62 ); | 1154 | dt = cur.addSecs( 62 ); |
1155 | } | 1155 | } |
1156 | else if (inR->type() == "Event" ) { | 1156 | else if (inR->type() == "Event" ) { |
1157 | bool ok; | 1157 | bool ok; |
1158 | dt = inR->getNextOccurence( cur, &ok ); | 1158 | dt = inR->getNextOccurence( cur, &ok ); |
1159 | if ( !ok ) | 1159 | if ( !ok ) |
1160 | dt = cur.addSecs( -62 ); | 1160 | dt = cur.addSecs( -62 ); |
1161 | } | 1161 | } |
1162 | else | 1162 | else |
1163 | dt = inR->dtStart(); | 1163 | dt = inR->dtStart(); |
1164 | if ( dt < cur || dt > end ) { | 1164 | if ( dt < cur || dt > end ) { |
1165 | remote->deleteIncidence( inR ); | 1165 | remote->deleteIncidence( inR ); |
1166 | ++delFut; | 1166 | ++delFut; |
1167 | } | 1167 | } |
1168 | inR = er.next(); | 1168 | inR = er.next(); |
1169 | } | 1169 | } |
1170 | } | 1170 | } |
1171 | bar.hide(); | 1171 | bar.hide(); |
1172 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); | 1172 | mLastCalendarSync = QDateTime::currentDateTime().addSecs( 1 ); |
1173 | eventLSync->setReadOnly( false ); | 1173 | eventLSync->setReadOnly( false ); |
1174 | eventLSync->setDtStart( mLastCalendarSync ); | 1174 | eventLSync->setDtStart( mLastCalendarSync ); |
1175 | eventRSync->setDtStart( mLastCalendarSync ); | 1175 | eventRSync->setDtStart( mLastCalendarSync ); |
1176 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1176 | eventLSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1177 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); | 1177 | eventRSync->setDtEnd( mLastCalendarSync.addSecs( 3600 ) ); |
1178 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; | 1178 | eventRSync->setLocation( i18n("Remote from: ")+mCurrentSyncName ) ; |
1179 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); | 1179 | eventLSync->setLocation(i18n("Local from: ") + mCurrentSyncName ); |
1180 | eventLSync->setReadOnly( true ); | 1180 | eventLSync->setReadOnly( true ); |
1181 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) | 1181 | if ( mGlobalSyncMode == SYNC_MODE_NORMAL) |
1182 | remote->addEvent( eventRSync ); | 1182 | remote->addEvent( eventRSync ); |
1183 | QString mes; | 1183 | QString mes; |
1184 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR ); | 1184 | mes .sprintf( i18n("Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n"),addedEvent, addedEventR, changedLocal, changedRemote, deletedEventL, deletedEventR ); |
1185 | QString delmess; | 1185 | QString delmess; |
1186 | if ( delFut ) { | 1186 | if ( delFut ) { |
1187 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are in the past or\nmore than %d weeks in the future.\n"),delFut, KOPrefs::instance()->mWriteBackInFuture ); | 1187 | delmess.sprintf( i18n("%d items skipped on remote,\nbecause they are in the past or\nmore than %d weeks in the future.\n"),delFut, KOPrefs::instance()->mWriteBackInFuture ); |
1188 | mes += delmess; | 1188 | mes += delmess; |
1189 | } | 1189 | } |
1190 | if ( KOPrefs::instance()->mShowSyncSummary ) { | 1190 | if ( KOPrefs::instance()->mShowSyncSummary ) { |
1191 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); | 1191 | KMessageBox::information(this, mes, i18n("KO/Pi Synchronization") ); |
1192 | } | 1192 | } |
1193 | qDebug( mes ); | 1193 | qDebug( mes ); |
1194 | mCalendar->checkAlarmForIncidence( 0, true ); | 1194 | mCalendar->checkAlarmForIncidence( 0, true ); |
1195 | return syncOK; | 1195 | return syncOK; |
1196 | } | 1196 | } |
1197 | 1197 | ||
1198 | void CalendarView::setSyncDevice( QString s ) | 1198 | void CalendarView::setSyncDevice( QString s ) |
1199 | { | 1199 | { |
1200 | mCurrentSyncDevice= s; | 1200 | mCurrentSyncDevice= s; |
1201 | } | 1201 | } |
1202 | void CalendarView::setSyncName( QString s ) | 1202 | void CalendarView::setSyncName( QString s ) |
1203 | { | 1203 | { |
1204 | mCurrentSyncName= s; | 1204 | mCurrentSyncName= s; |
1205 | } | 1205 | } |
1206 | bool CalendarView::syncCalendar(QString filename, int mode) | 1206 | bool CalendarView::syncCalendar(QString filename, int mode) |
1207 | { | 1207 | { |
1208 | mGlobalSyncMode = SYNC_MODE_NORMAL; | 1208 | mGlobalSyncMode = SYNC_MODE_NORMAL; |
1209 | CalendarLocal* calendar = new CalendarLocal(); | 1209 | CalendarLocal* calendar = new CalendarLocal(); |
1210 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); | 1210 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); |
1211 | FileStorage* storage = new FileStorage( calendar ); | 1211 | FileStorage* storage = new FileStorage( calendar ); |
1212 | bool syncOK = false; | 1212 | bool syncOK = false; |
1213 | storage->setFileName( filename ); | 1213 | storage->setFileName( filename ); |
1214 | // qDebug("loading ... "); | 1214 | // qDebug("loading ... "); |
1215 | if ( storage->load(KOPrefs::instance()->mUseQuicksave) ) { | 1215 | if ( storage->load(KOPrefs::instance()->mUseQuicksave) ) { |
1216 | getEventViewerDialog()->setSyncMode( true ); | 1216 | getEventViewerDialog()->setSyncMode( true ); |
1217 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); | 1217 | syncOK = synchronizeCalendar( mCalendar, calendar, mode ); |
1218 | getEventViewerDialog()->setSyncMode( false ); | 1218 | getEventViewerDialog()->setSyncMode( false ); |
1219 | if ( syncOK ) { | 1219 | if ( syncOK ) { |
1220 | if ( KOPrefs::instance()->mWriteBackFile ) | 1220 | if ( KOPrefs::instance()->mWriteBackFile ) |
1221 | { | 1221 | { |
1222 | storage->setSaveFormat( new ICalFormat( KOPrefs::instance()->mUseQuicksave) ); | 1222 | storage->setSaveFormat( new ICalFormat( KOPrefs::instance()->mUseQuicksave) ); |
1223 | storage->save(); | 1223 | storage->save(); |
1224 | } | 1224 | } |
1225 | } | 1225 | } |
1226 | setModified( true ); | 1226 | setModified( true ); |
1227 | } | 1227 | } |
1228 | delete storage; | 1228 | delete storage; |
1229 | delete calendar; | 1229 | delete calendar; |
1230 | if ( syncOK ) | 1230 | if ( syncOK ) |
1231 | updateView(); | 1231 | updateView(); |
1232 | return syncOK; | 1232 | return syncOK; |
1233 | } | 1233 | } |
1234 | void CalendarView::syncPhone() | 1234 | void CalendarView::syncPhone() |
1235 | { | 1235 | { |
1236 | syncExternal( 1 ); | 1236 | syncExternal( 1 ); |
1237 | } | 1237 | } |
1238 | void CalendarView::syncExternal( int mode ) | 1238 | void CalendarView::syncExternal( int mode ) |
1239 | { | 1239 | { |
1240 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; | 1240 | mGlobalSyncMode = SYNC_MODE_EXTERNAL; |
1241 | //mCurrentSyncDevice = "sharp-DTM"; | 1241 | //mCurrentSyncDevice = "sharp-DTM"; |
1242 | if ( KOPrefs::instance()->mAskForPreferences ) | 1242 | if ( KOPrefs::instance()->mAskForPreferences ) |
1243 | edit_sync_options(); | 1243 | edit_sync_options(); |
1244 | qApp->processEvents(); | 1244 | qApp->processEvents(); |
1245 | CalendarLocal* calendar = new CalendarLocal(); | 1245 | CalendarLocal* calendar = new CalendarLocal(); |
1246 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); | 1246 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); |
1247 | bool syncOK = false; | 1247 | bool syncOK = false; |
1248 | bool loadSuccess = false; | 1248 | bool loadSuccess = false; |
1249 | PhoneFormat* phoneFormat = 0; | 1249 | PhoneFormat* phoneFormat = 0; |
1250 | #ifndef DESKTOP_VERSION | 1250 | #ifndef DESKTOP_VERSION |
1251 | SharpFormat* sharpFormat = 0; | 1251 | SharpFormat* sharpFormat = 0; |
1252 | if ( mode == 0 ) { // sharp | 1252 | if ( mode == 0 ) { // sharp |
1253 | sharpFormat = new SharpFormat () ; | 1253 | sharpFormat = new SharpFormat () ; |
1254 | loadSuccess = sharpFormat->load( calendar, mCalendar ); | 1254 | loadSuccess = sharpFormat->load( calendar, mCalendar ); |
1255 | 1255 | ||
1256 | } else | 1256 | } else |
1257 | #endif | 1257 | #endif |
1258 | if ( mode == 1 ) { // phone | 1258 | if ( mode == 1 ) { // phone |
1259 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, | 1259 | phoneFormat = new PhoneFormat (mCurrentSyncDevice, |
1260 | KOPrefs::instance()->mPhoneDevice, | 1260 | KOPrefs::instance()->mPhoneDevice, |
1261 | KOPrefs::instance()->mPhoneConnection, | 1261 | KOPrefs::instance()->mPhoneConnection, |
1262 | KOPrefs::instance()->mPhoneModel); | 1262 | KOPrefs::instance()->mPhoneModel); |
1263 | loadSuccess = phoneFormat->load( calendar,mCalendar); | 1263 | loadSuccess = phoneFormat->load( calendar,mCalendar); |
1264 | 1264 | ||
1265 | } else | 1265 | } else |
1266 | return; | 1266 | return; |
1267 | if ( loadSuccess ) { | 1267 | if ( loadSuccess ) { |
1268 | getEventViewerDialog()->setSyncMode( true ); | 1268 | getEventViewerDialog()->setSyncMode( true ); |
1269 | syncOK = synchronizeCalendar( mCalendar, calendar, KOPrefs::instance()->mSyncAlgoPrefs ); | 1269 | syncOK = synchronizeCalendar( mCalendar, calendar, KOPrefs::instance()->mSyncAlgoPrefs ); |
1270 | getEventViewerDialog()->setSyncMode( false ); | 1270 | getEventViewerDialog()->setSyncMode( false ); |
1271 | qApp->processEvents(); | 1271 | qApp->processEvents(); |
1272 | if ( syncOK ) { | 1272 | if ( syncOK ) { |
1273 | if ( KOPrefs::instance()->mWriteBackFile ) | 1273 | if ( KOPrefs::instance()->mWriteBackFile ) |
1274 | { | 1274 | { |
1275 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); | 1275 | QPtrList<Incidence> iL = mCalendar->rawIncidences(); |
1276 | Incidence* inc = iL.first(); | 1276 | Incidence* inc = iL.first(); |
1277 | if ( phoneFormat ) { | 1277 | if ( phoneFormat ) { |
1278 | while ( inc ) { | 1278 | while ( inc ) { |
1279 | inc->removeID(mCurrentSyncDevice); | 1279 | inc->removeID(mCurrentSyncDevice); |
1280 | inc = iL.next(); | 1280 | inc = iL.next(); |
1281 | } | 1281 | } |
1282 | } | 1282 | } |
1283 | #ifndef DESKTOP_VERSION | 1283 | #ifndef DESKTOP_VERSION |
1284 | if ( sharpFormat ) | 1284 | if ( sharpFormat ) |
1285 | sharpFormat->save(calendar); | 1285 | sharpFormat->save(calendar); |
1286 | #endif | 1286 | #endif |
1287 | if ( phoneFormat ) | 1287 | if ( phoneFormat ) |
1288 | phoneFormat->save(calendar); | 1288 | phoneFormat->save(calendar); |
1289 | iL = calendar->rawIncidences(); | 1289 | iL = calendar->rawIncidences(); |
1290 | inc = iL.first(); | 1290 | inc = iL.first(); |
1291 | Incidence* loc; | 1291 | Incidence* loc; |
1292 | while ( inc ) { | 1292 | while ( inc ) { |
1293 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { | 1293 | if ( inc->tempSyncStat() == SYNC_TEMPSTATE_NEW_ID ) { |
1294 | loc = mCalendar->incidence(inc->uid() ); | 1294 | loc = mCalendar->incidence(inc->uid() ); |
1295 | if ( loc ) { | 1295 | if ( loc ) { |
1296 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); | 1296 | loc->setID(mCurrentSyncDevice, inc->getID(mCurrentSyncDevice) ); |
1297 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); | 1297 | loc->setCsum( mCurrentSyncDevice, inc->getCsum(mCurrentSyncDevice) ); |
1298 | } | 1298 | } |
1299 | } | 1299 | } |
1300 | inc = iL.next(); | 1300 | inc = iL.next(); |
1301 | } | 1301 | } |
1302 | Incidence* lse = getLastSyncEvent(); | 1302 | Incidence* lse = getLastSyncEvent(); |
1303 | if ( lse ) { | 1303 | if ( lse ) { |
1304 | lse->setReadOnly( false ); | 1304 | lse->setReadOnly( false ); |
1305 | lse->setDescription( "" ); | 1305 | lse->setDescription( "" ); |
1306 | lse->setReadOnly( true ); | 1306 | lse->setReadOnly( true ); |
1307 | } | 1307 | } |
1308 | } | 1308 | } |
1309 | } | 1309 | } |
1310 | setModified( true ); | 1310 | setModified( true ); |
1311 | } else { | 1311 | } else { |
1312 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; | 1312 | QString question = i18n("Sorry, the database access\ncommand failed!\n\nNothing synced!\n") ; |
1313 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), | 1313 | QMessageBox::information( 0, i18n("KO/Pi Import - ERROR"), |
1314 | question, i18n("Ok")) ; | 1314 | question, i18n("Ok")) ; |
1315 | 1315 | ||
1316 | } | 1316 | } |
1317 | delete calendar; | 1317 | delete calendar; |
1318 | updateView(); | 1318 | updateView(); |
1319 | return ;//syncOK; | 1319 | return ;//syncOK; |
1320 | 1320 | ||
1321 | } | 1321 | } |
1322 | void CalendarView::syncSharp() | 1322 | void CalendarView::syncSharp() |
1323 | { | 1323 | { |
1324 | syncExternal( 0 ); | 1324 | syncExternal( 0 ); |
1325 | 1325 | ||
1326 | } | 1326 | } |
1327 | 1327 | ||
1328 | 1328 | ||
1329 | #include <kabc/stdaddressbook.h> | 1329 | //#include <kabc/stdaddressbook.h> |
1330 | bool CalendarView::importBday() | 1330 | bool CalendarView::importBday() |
1331 | { | 1331 | { |
1332 | #if 0 | ||
1332 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); | 1333 | KABC::StdAddressBook* AddressBook = KABC::StdAddressBook::self( true ); |
1333 | KABC::AddressBook::Iterator it; | 1334 | KABC::AddressBook::Iterator it; |
1334 | int count = 0; | 1335 | int count = 0; |
1335 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1336 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1336 | ++count; | 1337 | ++count; |
1337 | } | 1338 | } |
1338 | QProgressBar bar(count,0 ); | 1339 | QProgressBar bar(count,0 ); |
1339 | int w = 300; | 1340 | int w = 300; |
1340 | if ( QApplication::desktop()->width() < 320 ) | 1341 | if ( QApplication::desktop()->width() < 320 ) |
1341 | w = 220; | 1342 | w = 220; |
1342 | int h = bar.sizeHint().height() ; | 1343 | int h = bar.sizeHint().height() ; |
1343 | int dw = QApplication::desktop()->width(); | 1344 | int dw = QApplication::desktop()->width(); |
1344 | int dh = QApplication::desktop()->height(); | 1345 | int dh = QApplication::desktop()->height(); |
1345 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); | 1346 | bar.setGeometry( (dw-w)/2, (dh - h )/2 ,w,h ); |
1346 | bar.show(); | 1347 | bar.show(); |
1347 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); | 1348 | bar.setCaption (i18n("Reading addressbook - close to abort!") ); |
1348 | qApp->processEvents(); | 1349 | qApp->processEvents(); |
1349 | count = 0; | 1350 | count = 0; |
1350 | int addCount = 0; | 1351 | int addCount = 0; |
1351 | KCal::Attendee* a = 0; | 1352 | KCal::Attendee* a = 0; |
1352 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { | 1353 | for( it = AddressBook->begin(); it != AddressBook->end(); ++it ) { |
1353 | if ( ! bar.isVisible() ) | 1354 | if ( ! bar.isVisible() ) |
1354 | return false; | 1355 | return false; |
1355 | bar.setProgress( count++ ); | 1356 | bar.setProgress( count++ ); |
1356 | qApp->processEvents(); | 1357 | qApp->processEvents(); |
1357 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); | 1358 | //qDebug("add BDay %s %s", (*it).realName().latin1(),(*it).birthday().date().toString().latin1() ); |
1358 | if ( (*it).birthday().date().isValid() ){ | 1359 | if ( (*it).birthday().date().isValid() ){ |
1359 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1360 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1360 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) | 1361 | if ( addAnniversary( (*it).birthday().date(), (*it).assembledName(), a, true ) ) |
1361 | ++addCount; | 1362 | ++addCount; |
1362 | } | 1363 | } |
1363 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); | 1364 | QDate anni = KGlobal::locale()->readDate( (*it).custom("KADDRESSBOOK", "X-Anniversary" ), "%Y-%m-%d"); |
1364 | if ( anni.isValid() ){ | 1365 | if ( anni.isValid() ){ |
1365 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; | 1366 | a = new KCal::Attendee( (*it).realName(), (*it).preferredEmail(),false,KCal::Attendee::NeedsAction,KCal::Attendee::ReqParticipant,(*it).uid()) ; |
1366 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) | 1367 | if ( addAnniversary( anni, (*it).assembledName(), a, false ) ) |
1367 | ++addCount; | 1368 | ++addCount; |
1368 | } | 1369 | } |
1369 | } | 1370 | } |
1370 | updateView(); | 1371 | updateView(); |
1371 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); | 1372 | topLevelWidget()->setCaption(QString::number( addCount )+ i18n(" birthdays/anniversaries added!")); |
1373 | #endif | ||
1372 | return true; | 1374 | return true; |
1373 | } | 1375 | } |
1374 | 1376 | ||
1375 | bool CalendarView::addAnniversary( QDate date, QString name, KCal::Attendee* a, bool birthday) | 1377 | bool CalendarView::addAnniversary( QDate date, QString name, KCal::Attendee* a, bool birthday) |
1376 | { | 1378 | { |
1377 | //qDebug("addAnni "); | 1379 | //qDebug("addAnni "); |
1378 | Event * ev = new Event(); | 1380 | Event * ev = new Event(); |
1379 | if ( a ) { | 1381 | if ( a ) { |
1380 | ev->addAttendee( a ); | 1382 | ev->addAttendee( a ); |
1381 | } | 1383 | } |
1382 | QString kind; | 1384 | QString kind; |
1383 | if ( birthday ) | 1385 | if ( birthday ) |
1384 | kind = i18n( "Birthday" ); | 1386 | kind = i18n( "Birthday" ); |
1385 | else | 1387 | else |
1386 | kind = i18n( "Anniversary" ); | 1388 | kind = i18n( "Anniversary" ); |
1387 | ev->setSummary( name + " - " + kind ); | 1389 | ev->setSummary( name + " - " + kind ); |
1388 | ev->setOrganizer( "nobody@nowhere" ); | 1390 | ev->setOrganizer( "nobody@nowhere" ); |
1389 | ev->setCategories( kind ); | 1391 | ev->setCategories( kind ); |
1390 | ev->setDtStart( QDateTime(date) ); | 1392 | ev->setDtStart( QDateTime(date) ); |
1391 | ev->setDtEnd( QDateTime(date) ); | 1393 | ev->setDtEnd( QDateTime(date) ); |
1392 | ev->setFloats( true ); | 1394 | ev->setFloats( true ); |
1393 | Recurrence * rec = ev->recurrence(); | 1395 | Recurrence * rec = ev->recurrence(); |
1394 | rec->setYearly(Recurrence::rYearlyMonth,1,-1); | 1396 | rec->setYearly(Recurrence::rYearlyMonth,1,-1); |
1395 | rec->addYearlyNum( date.month() ); | 1397 | rec->addYearlyNum( date.month() ); |
1396 | if ( !mCalendar->addAnniversaryNoDup( ev ) ) { | 1398 | if ( !mCalendar->addAnniversaryNoDup( ev ) ) { |
1397 | delete ev; | 1399 | delete ev; |
1398 | return false; | 1400 | return false; |
1399 | } | 1401 | } |
1400 | return true; | 1402 | return true; |
1401 | 1403 | ||
1402 | } | 1404 | } |
1403 | bool CalendarView::importQtopia( const QString &categories, | 1405 | bool CalendarView::importQtopia( const QString &categories, |
1404 | const QString &datebook, | 1406 | const QString &datebook, |
1405 | const QString &todolist ) | 1407 | const QString &todolist ) |
1406 | { | 1408 | { |
1407 | 1409 | ||
1408 | QtopiaFormat qtopiaFormat; | 1410 | QtopiaFormat qtopiaFormat; |
1409 | qtopiaFormat.setCategoriesList ( &(KOPrefs::instance()->mCustomCategories)); | 1411 | qtopiaFormat.setCategoriesList ( &(KOPrefs::instance()->mCustomCategories)); |
1410 | if ( !categories.isEmpty() ) qtopiaFormat.load( mCalendar, categories ); | 1412 | if ( !categories.isEmpty() ) qtopiaFormat.load( mCalendar, categories ); |
1411 | if ( !datebook.isEmpty() ) qtopiaFormat.load( mCalendar, datebook ); | 1413 | if ( !datebook.isEmpty() ) qtopiaFormat.load( mCalendar, datebook ); |
1412 | if ( !todolist.isEmpty() ) qtopiaFormat.load( mCalendar, todolist ); | 1414 | if ( !todolist.isEmpty() ) qtopiaFormat.load( mCalendar, todolist ); |
1413 | 1415 | ||
1414 | updateView(); | 1416 | updateView(); |
1415 | return true; | 1417 | return true; |
1416 | 1418 | ||
1417 | #if 0 | 1419 | #if 0 |
1418 | mGlobalSyncMode = SYNC_MODE_QTOPIA; | 1420 | mGlobalSyncMode = SYNC_MODE_QTOPIA; |
1419 | mCurrentSyncDevice = "qtopia-XML"; | 1421 | mCurrentSyncDevice = "qtopia-XML"; |
1420 | if ( KOPrefs::instance()->mAskForPreferences ) | 1422 | if ( KOPrefs::instance()->mAskForPreferences ) |
1421 | edit_sync_options(); | 1423 | edit_sync_options(); |
1422 | qApp->processEvents(); | 1424 | qApp->processEvents(); |
1423 | CalendarLocal* calendar = new CalendarLocal(); | 1425 | CalendarLocal* calendar = new CalendarLocal(); |
1424 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); | 1426 | calendar->setTimeZoneId(KOPrefs::instance()->mTimeZoneId); |
1425 | bool syncOK = false; | 1427 | bool syncOK = false; |
1426 | QtopiaFormat qtopiaFormat; | 1428 | QtopiaFormat qtopiaFormat; |
1427 | qtopiaFormat.setCategoriesList ( &(KOPrefs::instance()->mCustomCategories)); | 1429 | qtopiaFormat.setCategoriesList ( &(KOPrefs::instance()->mCustomCategories)); |
1428 | bool loadOk = true; | 1430 | bool loadOk = true; |
1429 | if ( !categories.isEmpty() ) | 1431 | if ( !categories.isEmpty() ) |
1430 | loadOk = qtopiaFormat.load( calendar, categories ); | 1432 | loadOk = qtopiaFormat.load( calendar, categories ); |
1431 | if ( loadOk && !datebook.isEmpty() ) | 1433 | if ( loadOk && !datebook.isEmpty() ) |
1432 | loadOk = qtopiaFormat.load( calendar, datebook ); | 1434 | loadOk = qtopiaFormat.load( calendar, datebook ); |
1433 | if ( loadOk && !todolist.isEmpty() ) | 1435 | if ( loadOk && !todolist.isEmpty() ) |
1434 | loadOk = qtopiaFormat.load( calendar, todolist ); | 1436 | loadOk = qtopiaFormat.load( calendar, todolist ); |
1435 | 1437 | ||
1436 | if ( loadOk ) { | 1438 | if ( loadOk ) { |
1437 | getEventViewerDialog()->setSyncMode( true ); | 1439 | getEventViewerDialog()->setSyncMode( true ); |
1438 | syncOK = synchronizeCalendar( mCalendar, calendar, KOPrefs::instance()->mSyncAlgoPrefs ); | 1440 | syncOK = synchronizeCalendar( mCalendar, calendar, KOPrefs::instance()->mSyncAlgoPrefs ); |
1439 | getEventViewerDialog()->setSyncMode( false ); | 1441 | getEventViewerDialog()->setSyncMode( false ); |
1440 | qApp->processEvents(); | 1442 | qApp->processEvents(); |
1441 | if ( syncOK ) { | 1443 | if ( syncOK ) { |
1442 | if ( KOPrefs::instance()->mWriteBackFile ) | 1444 | if ( KOPrefs::instance()->mWriteBackFile ) |
1443 | { | 1445 | { |
1444 | // write back XML file | 1446 | // write back XML file |
1445 | 1447 | ||
1446 | } | 1448 | } |
1447 | setModified( true ); | 1449 | setModified( true ); |
1448 | } | 1450 | } |
1449 | } else { | 1451 | } else { |
1450 | QString question = i18n("Sorry, the file loading\ncommand failed!\n\nNothing synced!\n") ; | 1452 | QString question = i18n("Sorry, the file loading\ncommand failed!\n\nNothing synced!\n") ; |
1451 | QMessageBox::information( 0, i18n("KO/Pi Sync - ERROR"), | 1453 | QMessageBox::information( 0, i18n("KO/Pi Sync - ERROR"), |
1452 | question, i18n("Ok")) ; | 1454 | question, i18n("Ok")) ; |
1453 | } | 1455 | } |
1454 | delete calendar; | 1456 | delete calendar; |
1455 | updateView(); | 1457 | updateView(); |
1456 | return syncOK; | 1458 | return syncOK; |
1457 | 1459 | ||
1458 | 1460 | ||
1459 | #endif | 1461 | #endif |
1460 | 1462 | ||
1461 | } | 1463 | } |
1462 | 1464 | ||
1463 | void CalendarView::setSyncEventsReadOnly() | 1465 | void CalendarView::setSyncEventsReadOnly() |
1464 | { | 1466 | { |
1465 | Event * ev; | 1467 | Event * ev; |
1466 | QPtrList<Event> eL = mCalendar->rawEvents(); | 1468 | QPtrList<Event> eL = mCalendar->rawEvents(); |
1467 | ev = eL.first(); | 1469 | ev = eL.first(); |
1468 | while ( ev ) { | 1470 | while ( ev ) { |
1469 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) | 1471 | if ( ev->uid().left(15) == QString("last-syncEvent-") ) |
1470 | ev->setReadOnly( true ); | 1472 | ev->setReadOnly( true ); |
1471 | ev = eL.next(); | 1473 | ev = eL.next(); |
1472 | } | 1474 | } |
1473 | } | 1475 | } |
1474 | bool CalendarView::openCalendar(QString filename, bool merge) | 1476 | bool CalendarView::openCalendar(QString filename, bool merge) |
1475 | { | 1477 | { |
1476 | 1478 | ||
1477 | if (filename.isEmpty()) { | 1479 | if (filename.isEmpty()) { |
1478 | return false; | 1480 | return false; |
1479 | } | 1481 | } |
1480 | 1482 | ||
1481 | if (!QFile::exists(filename)) { | 1483 | if (!QFile::exists(filename)) { |
1482 | KMessageBox::error(this,i18n("File does not exist:\n '%1'.").arg(filename)); | 1484 | KMessageBox::error(this,i18n("File does not exist:\n '%1'.").arg(filename)); |
1483 | return false; | 1485 | return false; |
1484 | } | 1486 | } |
1485 | 1487 | ||
1486 | globalFlagBlockAgenda = 1; | 1488 | globalFlagBlockAgenda = 1; |
1487 | if (!merge) mCalendar->close(); | 1489 | if (!merge) mCalendar->close(); |
1488 | 1490 | ||
1489 | mStorage->setFileName( filename ); | 1491 | mStorage->setFileName( filename ); |
1490 | 1492 | ||
1491 | if ( mStorage->load(KOPrefs::instance()->mUseQuicksave) ) { | 1493 | if ( mStorage->load(KOPrefs::instance()->mUseQuicksave) ) { |
1492 | if ( merge ) ;//setModified( true ); | 1494 | if ( merge ) ;//setModified( true ); |
1493 | else { | 1495 | else { |
1494 | //setModified( true ); | 1496 | //setModified( true ); |
1495 | mViewManager->setDocumentId( filename ); | 1497 | mViewManager->setDocumentId( filename ); |
1496 | mDialogManager->setDocumentId( filename ); | 1498 | mDialogManager->setDocumentId( filename ); |
1497 | mTodoList->setDocumentId( filename ); | 1499 | mTodoList->setDocumentId( filename ); |
1498 | } | 1500 | } |
1499 | globalFlagBlockAgenda = 2; | 1501 | globalFlagBlockAgenda = 2; |
1500 | // if ( getLastSyncEvent() ) | 1502 | // if ( getLastSyncEvent() ) |
1501 | // getLastSyncEvent()->setReadOnly( true ); | 1503 | // getLastSyncEvent()->setReadOnly( true ); |
1502 | mCalendar->reInitAlarmSettings(); | 1504 | mCalendar->reInitAlarmSettings(); |
1503 | setSyncEventsReadOnly(); | 1505 | setSyncEventsReadOnly(); |
1504 | updateUnmanagedViews(); | 1506 | updateUnmanagedViews(); |
1505 | updateView(); | 1507 | updateView(); |
1506 | if ( filename != MainWindow::defaultFileName() ) | 1508 | if ( filename != MainWindow::defaultFileName() ) |
1507 | saveCalendar( MainWindow::defaultFileName() ); | 1509 | saveCalendar( MainWindow::defaultFileName() ); |
1508 | loadedFileVersion = QDateTime::currentDateTime(); | 1510 | loadedFileVersion = QDateTime::currentDateTime(); |
1509 | return true; | 1511 | return true; |
1510 | } else { | 1512 | } else { |
1511 | // while failing to load, the calendar object could | 1513 | // while failing to load, the calendar object could |
1512 | // have become partially populated. Clear it out. | 1514 | // have become partially populated. Clear it out. |
1513 | if ( !merge ) mCalendar->close(); | 1515 | if ( !merge ) mCalendar->close(); |
1514 | 1516 | ||
1515 | KMessageBox::error(this,i18n("Couldn't load calendar\n '%1'.").arg(filename)); | 1517 | KMessageBox::error(this,i18n("Couldn't load calendar\n '%1'.").arg(filename)); |
1516 | 1518 | ||
1517 | globalFlagBlockAgenda = 2; | 1519 | globalFlagBlockAgenda = 2; |
1518 | updateView(); | 1520 | updateView(); |
1519 | } | 1521 | } |
1520 | return false; | 1522 | return false; |
1521 | } | 1523 | } |
1522 | void CalendarView::setLoadedFileVersion(QDateTime dt) | 1524 | void CalendarView::setLoadedFileVersion(QDateTime dt) |
1523 | { | 1525 | { |
1524 | loadedFileVersion = dt; | 1526 | loadedFileVersion = dt; |
1525 | } | 1527 | } |
1526 | bool CalendarView::checkFileChanged(QString fn) | 1528 | bool CalendarView::checkFileChanged(QString fn) |
1527 | { | 1529 | { |
1528 | QFileInfo finf ( fn ); | 1530 | QFileInfo finf ( fn ); |
1529 | if ( !finf.exists() ) | 1531 | if ( !finf.exists() ) |
1530 | return true; | 1532 | return true; |
1531 | QDateTime dt = finf.lastModified (); | 1533 | QDateTime dt = finf.lastModified (); |
1532 | if ( dt <= loadedFileVersion ) | 1534 | if ( dt <= loadedFileVersion ) |
1533 | return false; | 1535 | return false; |
1534 | return true; | 1536 | return true; |
1535 | 1537 | ||
1536 | } | 1538 | } |
1537 | bool CalendarView::checkFileVersion(QString fn) | 1539 | bool CalendarView::checkFileVersion(QString fn) |
1538 | { | 1540 | { |
1539 | QFileInfo finf ( fn ); | 1541 | QFileInfo finf ( fn ); |
1540 | if ( !finf.exists() ) | 1542 | if ( !finf.exists() ) |
1541 | return true; | 1543 | return true; |
1542 | QDateTime dt = finf.lastModified (); | 1544 | QDateTime dt = finf.lastModified (); |
1543 | //qDebug("loaded file version %s",loadedFileVersion.toString().latin1()); | 1545 | //qDebug("loaded file version %s",loadedFileVersion.toString().latin1()); |
1544 | //qDebug("file on disk version %s",dt.toString().latin1()); | 1546 | //qDebug("file on disk version %s",dt.toString().latin1()); |
1545 | if ( dt <= loadedFileVersion ) | 1547 | if ( dt <= loadedFileVersion ) |
1546 | return true; | 1548 | return true; |
1547 | int km = KMessageBox::warningYesNoCancel(this, i18n("\nThe file on disk has changed!\nFile size: %1 bytes.\nLast modified: %2\nDo you want to:\n\n - Save and overwrite file?\n - Sync with file, then save?\n - Cancel without saving? \n").arg( QString::number( finf.size())).arg( KGlobal::locale()->formatDateTime(finf.lastModified (), true, false)) , | 1549 | int km = KMessageBox::warningYesNoCancel(this, i18n("\nThe file on disk has changed!\nFile size: %1 bytes.\nLast modified: %2\nDo you want to:\n\n - Save and overwrite file?\n - Sync with file, then save?\n - Cancel without saving? \n").arg( QString::number( finf.size())).arg( KGlobal::locale()->formatDateTime(finf.lastModified (), true, false)) , |
1548 | i18n("KO/Pi Warning"),i18n("Overwrite"), | 1550 | i18n("KO/Pi Warning"),i18n("Overwrite"), |
1549 | i18n("Sync+save")); | 1551 | i18n("Sync+save")); |
1550 | 1552 | ||
1551 | if ( km == KMessageBox::Cancel ) | 1553 | if ( km == KMessageBox::Cancel ) |
1552 | return false; | 1554 | return false; |
1553 | if ( km == KMessageBox::Yes ) | 1555 | if ( km == KMessageBox::Yes ) |
1554 | return true; | 1556 | return true; |
1555 | 1557 | ||
1556 | setSyncDevice("deleteaftersync" ); | 1558 | setSyncDevice("deleteaftersync" ); |
1557 | KOPrefs::instance()->mAskForPreferences = true; | 1559 | KOPrefs::instance()->mAskForPreferences = true; |
1558 | KOPrefs::instance()->mSyncAlgoPrefs = 3; | 1560 | KOPrefs::instance()->mSyncAlgoPrefs = 3; |
1559 | KOPrefs::instance()->mWriteBackFile = false; | 1561 | KOPrefs::instance()->mWriteBackFile = false; |
1560 | KOPrefs::instance()->mWriteBackExistingOnly = false; | 1562 | KOPrefs::instance()->mWriteBackExistingOnly = false; |
1561 | KOPrefs::instance()->mShowSyncSummary = false; | 1563 | KOPrefs::instance()->mShowSyncSummary = false; |
1562 | syncCalendar( fn, 3 ); | 1564 | syncCalendar( fn, 3 ); |
1563 | Event * e = getLastSyncEvent(); | 1565 | Event * e = getLastSyncEvent(); |
1564 | mCalendar->deleteEvent ( e ); | 1566 | mCalendar->deleteEvent ( e ); |
1565 | updateView(); | 1567 | updateView(); |
1566 | return true; | 1568 | return true; |
1567 | } | 1569 | } |
1568 | 1570 | ||
1569 | bool CalendarView::saveCalendar( QString filename ) | 1571 | bool CalendarView::saveCalendar( QString filename ) |
1570 | { | 1572 | { |
1571 | 1573 | ||
1572 | // Store back all unsaved data into calendar object | 1574 | // Store back all unsaved data into calendar object |
1573 | // qDebug("file %s %d ", filename.latin1() , mViewManager->currentView() ); | 1575 | // qDebug("file %s %d ", filename.latin1() , mViewManager->currentView() ); |
1574 | if ( mViewManager->currentView() ) | 1576 | if ( mViewManager->currentView() ) |
1575 | mViewManager->currentView()->flushView(); | 1577 | mViewManager->currentView()->flushView(); |
1576 | 1578 | ||
1577 | //mStorage->setFileName( filename ); | 1579 | //mStorage->setFileName( filename ); |
1578 | 1580 | ||
1579 | mStorage->setSaveFormat( new ICalFormat( KOPrefs::instance()->mUseQuicksave) ); | 1581 | mStorage->setSaveFormat( new ICalFormat( KOPrefs::instance()->mUseQuicksave) ); |
1580 | mStorage->setFileName( filename ); | 1582 | mStorage->setFileName( filename ); |
1581 | bool success; | 1583 | bool success; |
1582 | success = mStorage->save(); | 1584 | success = mStorage->save(); |
1583 | if ( !success ) { | 1585 | if ( !success ) { |
1584 | return false; | 1586 | return false; |
1585 | } | 1587 | } |
1586 | 1588 | ||
1587 | return true; | 1589 | return true; |
1588 | } | 1590 | } |
1589 | 1591 | ||
1590 | void CalendarView::closeCalendar() | 1592 | void CalendarView::closeCalendar() |
1591 | { | 1593 | { |
1592 | 1594 | ||
1593 | // child windows no longer valid | 1595 | // child windows no longer valid |
1594 | emit closingDown(); | 1596 | emit closingDown(); |
1595 | 1597 | ||
1596 | mCalendar->close(); | 1598 | mCalendar->close(); |
1597 | setModified(false); | 1599 | setModified(false); |
1598 | updateView(); | 1600 | updateView(); |
1599 | } | 1601 | } |
1600 | 1602 | ||
1601 | void CalendarView::archiveCalendar() | 1603 | void CalendarView::archiveCalendar() |
1602 | { | 1604 | { |
1603 | mDialogManager->showArchiveDialog(); | 1605 | mDialogManager->showArchiveDialog(); |
1604 | } | 1606 | } |
1605 | 1607 | ||
1606 | 1608 | ||
1607 | void CalendarView::readSettings() | 1609 | void CalendarView::readSettings() |
1608 | { | 1610 | { |
1609 | 1611 | ||
1610 | 1612 | ||
1611 | // mViewManager->showAgendaView(); | 1613 | // mViewManager->showAgendaView(); |
1612 | QString str; | 1614 | QString str; |
1613 | //qDebug("CalendarView::readSettings() "); | 1615 | //qDebug("CalendarView::readSettings() "); |
1614 | // read settings from the KConfig, supplying reasonable | 1616 | // read settings from the KConfig, supplying reasonable |
1615 | // defaults where none are to be found | 1617 | // defaults where none are to be found |
1616 | KConfig *config = KOGlobals::config(); | 1618 | KConfig *config = KOGlobals::config(); |
1617 | #ifndef KORG_NOSPLITTER | 1619 | #ifndef KORG_NOSPLITTER |
1618 | config->setGroup("KOrganizer Geometry"); | 1620 | config->setGroup("KOrganizer Geometry"); |
1619 | 1621 | ||
1620 | QValueList<int> sizes = config->readIntListEntry("Separator1"); | 1622 | QValueList<int> sizes = config->readIntListEntry("Separator1"); |
1621 | if (sizes.count() != 2) { | 1623 | if (sizes.count() != 2) { |
1622 | sizes << mDateNavigator->minimumSizeHint().width(); | 1624 | sizes << mDateNavigator->minimumSizeHint().width(); |
1623 | sizes << 300; | 1625 | sizes << 300; |
1624 | } | 1626 | } |
1625 | mPanner->setSizes(sizes); | 1627 | mPanner->setSizes(sizes); |
1626 | 1628 | ||
1627 | sizes = config->readIntListEntry("Separator2"); | 1629 | sizes = config->readIntListEntry("Separator2"); |
1628 | if ( ( mResourceView && sizes.count() == 4 ) || | 1630 | if ( ( mResourceView && sizes.count() == 4 ) || |
1629 | ( !mResourceView && sizes.count() == 3 ) ) { | 1631 | ( !mResourceView && sizes.count() == 3 ) ) { |
1630 | mLeftSplitter->setSizes(sizes); | 1632 | mLeftSplitter->setSizes(sizes); |
1631 | } | 1633 | } |
1632 | #endif | 1634 | #endif |
1633 | globalFlagBlockAgenda = 1; | 1635 | globalFlagBlockAgenda = 1; |
1634 | mViewManager->showAgendaView(); | 1636 | mViewManager->showAgendaView(); |
1635 | //mViewManager->readSettings( config ); | 1637 | //mViewManager->readSettings( config ); |
1636 | mTodoList->restoreLayout(config,QString("Todo Layout")); | 1638 | mTodoList->restoreLayout(config,QString("Todo Layout")); |
1637 | readFilterSettings(config); | 1639 | readFilterSettings(config); |
1638 | config->setGroup( "Views" ); | 1640 | config->setGroup( "Views" ); |
1639 | int dateCount = config->readNumEntry( "ShownDatesCount", 7 ); | 1641 | int dateCount = config->readNumEntry( "ShownDatesCount", 7 ); |
1640 | if ( dateCount == 5 ) mNavigator->selectWorkWeek(); | 1642 | if ( dateCount == 5 ) mNavigator->selectWorkWeek(); |
1641 | else if ( dateCount == 7 ) mNavigator->selectWeek(); | 1643 | else if ( dateCount == 7 ) mNavigator->selectWeek(); |
1642 | else mNavigator->selectDates( dateCount ); | 1644 | else mNavigator->selectDates( dateCount ); |
1643 | // mViewManager->readSettings( config ); | 1645 | // mViewManager->readSettings( config ); |
1644 | updateConfig(); | 1646 | updateConfig(); |
1645 | globalFlagBlockAgenda = 2; | 1647 | globalFlagBlockAgenda = 2; |
1646 | mViewManager->readSettings( config ); | 1648 | mViewManager->readSettings( config ); |
1647 | #ifdef DESKTOP_VERSION | 1649 | #ifdef DESKTOP_VERSION |
1648 | config->setGroup("WidgetLayout"); | 1650 | config->setGroup("WidgetLayout"); |
1649 | QStringList list; | 1651 | QStringList list; |
1650 | list = config->readListEntry("MainLayout"); | 1652 | list = config->readListEntry("MainLayout"); |
1651 | int x,y,w,h; | 1653 | int x,y,w,h; |
1652 | if ( ! list.isEmpty() ) { | 1654 | if ( ! list.isEmpty() ) { |
1653 | x = list[0].toInt(); | 1655 | x = list[0].toInt(); |
1654 | y = list[1].toInt(); | 1656 | y = list[1].toInt(); |
1655 | w = list[2].toInt(); | 1657 | w = list[2].toInt(); |
1656 | h = list[3].toInt(); | 1658 | h = list[3].toInt(); |
1657 | topLevelWidget()->setGeometry(x,y,w,h); | 1659 | topLevelWidget()->setGeometry(x,y,w,h); |
1658 | 1660 | ||
1659 | } else { | 1661 | } else { |
1660 | topLevelWidget()->setGeometry( 40 ,40 , 640, 440); | 1662 | topLevelWidget()->setGeometry( 40 ,40 , 640, 440); |
1661 | } | 1663 | } |
1662 | list = config->readListEntry("EditEventLayout"); | 1664 | list = config->readListEntry("EditEventLayout"); |
1663 | if ( ! list.isEmpty() ) { | 1665 | if ( ! list.isEmpty() ) { |
1664 | x = list[0].toInt(); | 1666 | x = list[0].toInt(); |
1665 | y = list[1].toInt(); | 1667 | y = list[1].toInt(); |
1666 | w = list[2].toInt(); | 1668 | w = list[2].toInt(); |
1667 | h = list[3].toInt(); | 1669 | h = list[3].toInt(); |
1668 | mEventEditor->setGeometry(x,y,w,h); | 1670 | mEventEditor->setGeometry(x,y,w,h); |
1669 | 1671 | ||
1670 | } | 1672 | } |
1671 | list = config->readListEntry("EditTodoLayout"); | 1673 | list = config->readListEntry("EditTodoLayout"); |
1672 | if ( ! list.isEmpty() ) { | 1674 | if ( ! list.isEmpty() ) { |
1673 | x = list[0].toInt(); | 1675 | x = list[0].toInt(); |
1674 | y = list[1].toInt(); | 1676 | y = list[1].toInt(); |
1675 | w = list[2].toInt(); | 1677 | w = list[2].toInt(); |
1676 | h = list[3].toInt(); | 1678 | h = list[3].toInt(); |
1677 | mTodoEditor->setGeometry(x,y,w,h); | 1679 | mTodoEditor->setGeometry(x,y,w,h); |
1678 | 1680 | ||
1679 | } | 1681 | } |
1680 | list = config->readListEntry("ViewerLayout"); | 1682 | list = config->readListEntry("ViewerLayout"); |
1681 | if ( ! list.isEmpty() ) { | 1683 | if ( ! list.isEmpty() ) { |
1682 | x = list[0].toInt(); | 1684 | x = list[0].toInt(); |
1683 | y = list[1].toInt(); | 1685 | y = list[1].toInt(); |
1684 | w = list[2].toInt(); | 1686 | w = list[2].toInt(); |
1685 | h = list[3].toInt(); | 1687 | h = list[3].toInt(); |
1686 | getEventViewerDialog()->setGeometry(x,y,w,h); | 1688 | getEventViewerDialog()->setGeometry(x,y,w,h); |
1687 | } | 1689 | } |
1688 | #endif | 1690 | #endif |
1689 | 1691 | ||
1690 | } | 1692 | } |
1691 | 1693 | ||
1692 | 1694 | ||
1693 | void CalendarView::writeSettings() | 1695 | void CalendarView::writeSettings() |
1694 | { | 1696 | { |
1695 | // kdDebug() << "CalendarView::writeSettings" << endl; | 1697 | // kdDebug() << "CalendarView::writeSettings" << endl; |
1696 | 1698 | ||
1697 | KConfig *config = KOGlobals::config(); | 1699 | KConfig *config = KOGlobals::config(); |
1698 | 1700 | ||
1699 | #ifndef KORG_NOSPLITTER | 1701 | #ifndef KORG_NOSPLITTER |
1700 | config->setGroup("KOrganizer Geometry"); | 1702 | config->setGroup("KOrganizer Geometry"); |
1701 | 1703 | ||
1702 | QValueList<int> list = mPanner->sizes(); | 1704 | QValueList<int> list = mPanner->sizes(); |
1703 | config->writeEntry("Separator1",list); | 1705 | config->writeEntry("Separator1",list); |
1704 | 1706 | ||
1705 | list = mLeftSplitter->sizes(); | 1707 | list = mLeftSplitter->sizes(); |
1706 | config->writeEntry("Separator2",list); | 1708 | config->writeEntry("Separator2",list); |
1707 | #endif | 1709 | #endif |
1708 | 1710 | ||
1709 | mViewManager->writeSettings( config ); | 1711 | mViewManager->writeSettings( config ); |
1710 | mTodoList->saveLayout(config,QString("Todo Layout")); | 1712 | mTodoList->saveLayout(config,QString("Todo Layout")); |
1711 | mDialogManager->writeSettings( config ); | 1713 | mDialogManager->writeSettings( config ); |
1712 | //KOPrefs::instance()->usrWriteConfig(); | 1714 | //KOPrefs::instance()->usrWriteConfig(); |
1713 | KOPrefs::instance()->writeConfig(); | 1715 | KOPrefs::instance()->writeConfig(); |
1714 | 1716 | ||
1715 | writeFilterSettings(config); | 1717 | writeFilterSettings(config); |
1716 | 1718 | ||
1717 | config->setGroup( "Views" ); | 1719 | config->setGroup( "Views" ); |
1718 | config->writeEntry( "ShownDatesCount", mNavigator->selectedDates().count() ); | 1720 | config->writeEntry( "ShownDatesCount", mNavigator->selectedDates().count() ); |
1719 | 1721 | ||
1720 | #ifdef DESKTOP_VERSION | 1722 | #ifdef DESKTOP_VERSION |
1721 | config->setGroup("WidgetLayout"); | 1723 | config->setGroup("WidgetLayout"); |
1722 | QStringList list ;//= config->readListEntry("MainLayout"); | 1724 | QStringList list ;//= config->readListEntry("MainLayout"); |
1723 | int x,y,w,h; | 1725 | int x,y,w,h; |
1724 | QWidget* wid; | 1726 | QWidget* wid; |
1725 | wid = topLevelWidget(); | 1727 | wid = topLevelWidget(); |
1726 | x = wid->geometry().x(); | 1728 | x = wid->geometry().x(); |
1727 | y = wid->geometry().y(); | 1729 | y = wid->geometry().y(); |
1728 | w = wid->width(); | 1730 | w = wid->width(); |
1729 | h = wid->height(); | 1731 | h = wid->height(); |
1730 | list.clear(); | 1732 | list.clear(); |
1731 | list << QString::number( x ); | 1733 | list << QString::number( x ); |
1732 | list << QString::number( y ); | 1734 | list << QString::number( y ); |
1733 | list << QString::number( w ); | 1735 | list << QString::number( w ); |
1734 | list << QString::number( h ); | 1736 | list << QString::number( h ); |
1735 | config->writeEntry("MainLayout",list ); | 1737 | config->writeEntry("MainLayout",list ); |
1736 | 1738 | ||
1737 | wid = mEventEditor; | 1739 | wid = mEventEditor; |
1738 | x = wid->geometry().x(); | 1740 | x = wid->geometry().x(); |
1739 | y = wid->geometry().y(); | 1741 | y = wid->geometry().y(); |
1740 | w = wid->width(); | 1742 | w = wid->width(); |
1741 | h = wid->height(); | 1743 | h = wid->height(); |
1742 | list.clear(); | 1744 | list.clear(); |
1743 | list << QString::number( x ); | 1745 | list << QString::number( x ); |
1744 | list << QString::number( y ); | 1746 | list << QString::number( y ); |
1745 | list << QString::number( w ); | 1747 | list << QString::number( w ); |
1746 | list << QString::number( h ); | 1748 | list << QString::number( h ); |
1747 | config->writeEntry("EditEventLayout",list ); | 1749 | config->writeEntry("EditEventLayout",list ); |
1748 | 1750 | ||
1749 | wid = mTodoEditor; | 1751 | wid = mTodoEditor; |
1750 | x = wid->geometry().x(); | 1752 | x = wid->geometry().x(); |
1751 | y = wid->geometry().y(); | 1753 | y = wid->geometry().y(); |
1752 | w = wid->width(); | 1754 | w = wid->width(); |
1753 | h = wid->height(); | 1755 | h = wid->height(); |
1754 | list.clear(); | 1756 | list.clear(); |
1755 | list << QString::number( x ); | 1757 | list << QString::number( x ); |
1756 | list << QString::number( y ); | 1758 | list << QString::number( y ); |
1757 | list << QString::number( w ); | 1759 | list << QString::number( w ); |
1758 | list << QString::number( h ); | 1760 | list << QString::number( h ); |
1759 | config->writeEntry("EditTodoLayout",list ); | 1761 | config->writeEntry("EditTodoLayout",list ); |
1760 | wid = getEventViewerDialog(); | 1762 | wid = getEventViewerDialog(); |
1761 | x = wid->geometry().x(); | 1763 | x = wid->geometry().x(); |
1762 | y = wid->geometry().y(); | 1764 | y = wid->geometry().y(); |
1763 | w = wid->width(); | 1765 | w = wid->width(); |
1764 | h = wid->height(); | 1766 | h = wid->height(); |
1765 | list.clear(); | 1767 | list.clear(); |
1766 | list << QString::number( x ); | 1768 | list << QString::number( x ); |
1767 | list << QString::number( y ); | 1769 | list << QString::number( y ); |
1768 | list << QString::number( w ); | 1770 | list << QString::number( w ); |
1769 | list << QString::number( h ); | 1771 | list << QString::number( h ); |
1770 | config->writeEntry("ViewerLayout",list ); | 1772 | config->writeEntry("ViewerLayout",list ); |
1771 | wid = mDialogManager->getSearchDialog(); | 1773 | wid = mDialogManager->getSearchDialog(); |
1772 | if ( wid ) { | 1774 | if ( wid ) { |
1773 | x = wid->geometry().x(); | 1775 | x = wid->geometry().x(); |
1774 | y = wid->geometry().y(); | 1776 | y = wid->geometry().y(); |
1775 | w = wid->width(); | 1777 | w = wid->width(); |
1776 | h = wid->height(); | 1778 | h = wid->height(); |
1777 | list.clear(); | 1779 | list.clear(); |
1778 | list << QString::number( x ); | 1780 | list << QString::number( x ); |
1779 | list << QString::number( y ); | 1781 | list << QString::number( y ); |
1780 | list << QString::number( w ); | 1782 | list << QString::number( w ); |
1781 | list << QString::number( h ); | 1783 | list << QString::number( h ); |
1782 | config->writeEntry("SearchLayout",list ); | 1784 | config->writeEntry("SearchLayout",list ); |
1783 | } | 1785 | } |
1784 | #endif | 1786 | #endif |
1785 | 1787 | ||
1786 | 1788 | ||
1787 | config->sync(); | 1789 | config->sync(); |
1788 | } | 1790 | } |
1789 | 1791 | ||
1790 | void CalendarView::readFilterSettings(KConfig *config) | 1792 | void CalendarView::readFilterSettings(KConfig *config) |
1791 | { | 1793 | { |
1792 | // kdDebug() << "CalendarView::readFilterSettings()" << endl; | 1794 | // kdDebug() << "CalendarView::readFilterSettings()" << endl; |
1793 | 1795 | ||
1794 | mFilters.clear(); | 1796 | mFilters.clear(); |
1795 | 1797 | ||
1796 | config->setGroup("General"); | 1798 | config->setGroup("General"); |
1797 | QStringList filterList = config->readListEntry("CalendarFilters"); | 1799 | QStringList filterList = config->readListEntry("CalendarFilters"); |
1798 | 1800 | ||
1799 | QStringList::ConstIterator it = filterList.begin(); | 1801 | QStringList::ConstIterator it = filterList.begin(); |
1800 | QStringList::ConstIterator end = filterList.end(); | 1802 | QStringList::ConstIterator end = filterList.end(); |
1801 | while(it != end) { | 1803 | while(it != end) { |
1802 | // kdDebug() << " filter: " << (*it) << endl; | 1804 | // kdDebug() << " filter: " << (*it) << endl; |
1803 | 1805 | ||
1804 | CalFilter *filter; | 1806 | CalFilter *filter; |
1805 | filter = new CalFilter(*it); | 1807 | filter = new CalFilter(*it); |
1806 | config->setGroup("Filter_" + (*it)); | 1808 | config->setGroup("Filter_" + (*it)); |
1807 | //qDebug("readFilterSettings %d ",config->readNumEntry("Criteria",0) ); | 1809 | //qDebug("readFilterSettings %d ",config->readNumEntry("Criteria",0) ); |
1808 | filter->setCriteria(config->readNumEntry("Criteria",0)); | 1810 | filter->setCriteria(config->readNumEntry("Criteria",0)); |
1809 | filter->setCategoryList(config->readListEntry("CategoryList")); | 1811 | filter->setCategoryList(config->readListEntry("CategoryList")); |
1810 | mFilters.append(filter); | 1812 | mFilters.append(filter); |
1811 | 1813 | ||
1812 | ++it; | 1814 | ++it; |
1813 | } | 1815 | } |
1814 | 1816 | ||
1815 | if (mFilters.count() == 0) { | 1817 | if (mFilters.count() == 0) { |
1816 | CalFilter *filter = new CalFilter(i18n("Default")); | 1818 | CalFilter *filter = new CalFilter(i18n("Default")); |
1817 | mFilters.append(filter); | 1819 | mFilters.append(filter); |
1818 | } | 1820 | } |
1819 | mFilterView->updateFilters(); | 1821 | mFilterView->updateFilters(); |
1820 | config->setGroup("FilterView"); | 1822 | config->setGroup("FilterView"); |
1821 | 1823 | ||
1822 | mFilterView->blockSignals(true); | 1824 | mFilterView->blockSignals(true); |
1823 | mFilterView->setFiltersEnabled(config->readBoolEntry("FilterEnabled")); | 1825 | mFilterView->setFiltersEnabled(config->readBoolEntry("FilterEnabled")); |
1824 | mFilterView->setSelectedFilter(config->readEntry("Current Filter")); | 1826 | mFilterView->setSelectedFilter(config->readEntry("Current Filter")); |
1825 | mFilterView->blockSignals(false); | 1827 | mFilterView->blockSignals(false); |
1826 | // We do it manually to avoid it being done twice by the above calls | 1828 | // We do it manually to avoid it being done twice by the above calls |
1827 | updateFilter(); | 1829 | updateFilter(); |
1828 | } | 1830 | } |
1829 | 1831 | ||
1830 | void CalendarView::writeFilterSettings(KConfig *config) | 1832 | void CalendarView::writeFilterSettings(KConfig *config) |
1831 | { | 1833 | { |
1832 | // kdDebug() << "CalendarView::writeFilterSettings()" << endl; | 1834 | // kdDebug() << "CalendarView::writeFilterSettings()" << endl; |
1833 | 1835 | ||
1834 | QStringList filterList; | 1836 | QStringList filterList; |
1835 | 1837 | ||
1836 | CalFilter *filter = mFilters.first(); | 1838 | CalFilter *filter = mFilters.first(); |
1837 | while(filter) { | 1839 | while(filter) { |
1838 | // kdDebug() << " fn: " << filter->name() << endl; | 1840 | // kdDebug() << " fn: " << filter->name() << endl; |
1839 | filterList << filter->name(); | 1841 | filterList << filter->name(); |
1840 | config->setGroup("Filter_" + filter->name()); | 1842 | config->setGroup("Filter_" + filter->name()); |
1841 | config->writeEntry("Criteria",filter->criteria()); | 1843 | config->writeEntry("Criteria",filter->criteria()); |
1842 | config->writeEntry("CategoryList",filter->categoryList()); | 1844 | config->writeEntry("CategoryList",filter->categoryList()); |
1843 | filter = mFilters.next(); | 1845 | filter = mFilters.next(); |
1844 | } | 1846 | } |
1845 | config->setGroup("General"); | 1847 | config->setGroup("General"); |
1846 | config->writeEntry("CalendarFilters",filterList); | 1848 | config->writeEntry("CalendarFilters",filterList); |
1847 | 1849 | ||
1848 | config->setGroup("FilterView"); | 1850 | config->setGroup("FilterView"); |
1849 | config->writeEntry("FilterEnabled",mFilterView->filtersEnabled()); | 1851 | config->writeEntry("FilterEnabled",mFilterView->filtersEnabled()); |
1850 | config->writeEntry("Current Filter",mFilterView->selectedFilter()->name()); | 1852 | config->writeEntry("Current Filter",mFilterView->selectedFilter()->name()); |
1851 | } | 1853 | } |
1852 | 1854 | ||
1853 | 1855 | ||
1854 | void CalendarView::goToday() | 1856 | void CalendarView::goToday() |
1855 | { | 1857 | { |
1856 | mNavigator->selectToday(); | 1858 | mNavigator->selectToday(); |
1857 | } | 1859 | } |
1858 | 1860 | ||
1859 | void CalendarView::goNext() | 1861 | void CalendarView::goNext() |
1860 | { | 1862 | { |
1861 | mNavigator->selectNext(); | 1863 | mNavigator->selectNext(); |
1862 | } | 1864 | } |
1863 | 1865 | ||
1864 | void CalendarView::goPrevious() | 1866 | void CalendarView::goPrevious() |
1865 | { | 1867 | { |
1866 | mNavigator->selectPrevious(); | 1868 | mNavigator->selectPrevious(); |
1867 | } | 1869 | } |
1868 | void CalendarView::goNextMonth() | 1870 | void CalendarView::goNextMonth() |
1869 | { | 1871 | { |
1870 | mNavigator->selectNextMonth(); | 1872 | mNavigator->selectNextMonth(); |
1871 | } | 1873 | } |
1872 | 1874 | ||
1873 | void CalendarView::goPreviousMonth() | 1875 | void CalendarView::goPreviousMonth() |
1874 | { | 1876 | { |
1875 | mNavigator->selectPreviousMonth(); | 1877 | mNavigator->selectPreviousMonth(); |
1876 | } | 1878 | } |
1877 | void CalendarView::writeLocale() | 1879 | void CalendarView::writeLocale() |
1878 | { | 1880 | { |
1879 | KGlobal::locale()->setHore24Format( !KOPrefs::instance()->mPreferredTime ); | 1881 | KGlobal::locale()->setHore24Format( !KOPrefs::instance()->mPreferredTime ); |
1880 | KGlobal::locale()->setWeekStartMonday( !KOPrefs::instance()->mWeekStartsOnSunday ); | 1882 | KGlobal::locale()->setWeekStartMonday( !KOPrefs::instance()->mWeekStartsOnSunday ); |
1881 | KGlobal::locale()->setIntDateFormat( (KLocale::IntDateFormat)KOPrefs::instance()->mPreferredDate ); | 1883 | KGlobal::locale()->setIntDateFormat( (KLocale::IntDateFormat)KOPrefs::instance()->mPreferredDate ); |
1882 | KGlobal::locale()->setLanguage( KOPrefs::instance()->mPreferredLanguage ); | 1884 | KGlobal::locale()->setLanguage( KOPrefs::instance()->mPreferredLanguage ); |
1883 | QString dummy = KOPrefs::instance()->mUserDateFormatLong; | 1885 | QString dummy = KOPrefs::instance()->mUserDateFormatLong; |
diff --git a/korganizer/incomingdialog.cpp b/korganizer/incomingdialog.cpp index f3bd09f..50e3077 100644 --- a/korganizer/incomingdialog.cpp +++ b/korganizer/incomingdialog.cpp | |||
@@ -1,527 +1,528 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
6 | it under the terms of the GNU General Public License as published by | 6 | it under the terms of the GNU General Public License as published by |
7 | the Free Software Foundation; either version 2 of the License, or | 7 | the Free Software Foundation; either version 2 of the License, or |
8 | (at your option) any later version. | 8 | (at your option) any later version. |
9 | 9 | ||
10 | This program is distributed in the hope that it will be useful, | 10 | This program is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | GNU General Public License for more details. | 13 | GNU General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU General Public License | 15 | You should have received a copy of the GNU General Public License |
16 | along with this program; if not, write to the Free Software | 16 | along with this program; if not, write to the Free Software |
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | */ | 18 | */ |
19 | 19 | ||
20 | #include <qlistview.h> | 20 | #include <qlistview.h> |
21 | #include <qfile.h> | 21 | #include <qfile.h> |
22 | #include <qdir.h> | 22 | #include <qdir.h> |
23 | #include <qmap.h> | 23 | #include <qmap.h> |
24 | 24 | ||
25 | #include <kglobal.h> | 25 | #include <kglobal.h> |
26 | #include <klocale.h> | 26 | #include <klocale.h> |
27 | #include <kdebug.h> | 27 | #include <kdebug.h> |
28 | #include <kstandarddirs.h> | 28 | #include <kstandarddirs.h> |
29 | #include <kmessagebox.h> | 29 | #include <kmessagebox.h> |
30 | 30 | ||
31 | #include <libkcal/incidence.h> | 31 | #include <libkcal/incidence.h> |
32 | #include <libkcal/event.h> | 32 | #include <libkcal/event.h> |
33 | #include <libkcal/calendar.h> | 33 | #include <libkcal/calendar.h> |
34 | #include <libkcal/freebusy.h> | 34 | #include <libkcal/freebusy.h> |
35 | #include <libkcal/attendee.h> | 35 | #include <libkcal/attendee.h> |
36 | #include <libkcal/calendarresources.h> | 36 | #include <libkcal/calendarresources.h> |
37 | #include <libkcal/resourcecalendar.h> | 37 | #include <libkcal/resourcecalendar.h> |
38 | #include <kresources/resourceselectdialog.h> | 38 | #include <kresources/resourceselectdialog.h> |
39 | 39 | ||
40 | #ifndef KORG_NOMAIL | 40 | #ifndef KORG_NOMAIL |
41 | #include "mailscheduler.h" | 41 | #include "mailscheduler.h" |
42 | #else | 42 | #else |
43 | #include <libkcal/dummyscheduler.h> | 43 | #include <libkcal/dummyscheduler.h> |
44 | #endif | 44 | #endif |
45 | 45 | ||
46 | 46 | ||
47 | #include "incomingdialog.h" | 47 | #include "incomingdialog.h" |
48 | #include "koeventviewerdialog.h" | 48 | #include "koeventviewerdialog.h" |
49 | #include "kocounterdialog.h" | 49 | #include "kocounterdialog.h" |
50 | #include "koprefs.h" | 50 | #include "koprefs.h" |
51 | 51 | ||
52 | #ifndef KORG_NOKABC | 52 | #ifndef KORG_NOKABC |
53 | #include <kabc/stdaddressbook.h> | 53 | #define KORG_NOKABC |
54 | //#include <kabc/stdaddressbook.h> | ||
54 | #define size count | 55 | #define size count |
55 | #endif | 56 | #endif |
56 | 57 | ||
57 | 58 | ||
58 | ScheduleItemIn::ScheduleItemIn(QListView *parent,IncidenceBase *ev, | 59 | ScheduleItemIn::ScheduleItemIn(QListView *parent,IncidenceBase *ev, |
59 | Scheduler::Method method,ScheduleMessage::Status status) | 60 | Scheduler::Method method,ScheduleMessage::Status status) |
60 | : QListViewItem(parent) | 61 | : QListViewItem(parent) |
61 | { | 62 | { |
62 | mIncidence = ev; | 63 | mIncidence = ev; |
63 | mMethod = method; | 64 | mMethod = method; |
64 | mStatus = status; | 65 | mStatus = status; |
65 | setText(6,Scheduler::translatedMethodName(mMethod)+" "); | 66 | setText(6,Scheduler::translatedMethodName(mMethod)+" "); |
66 | setText(7,ScheduleMessage::statusName(status)); | 67 | setText(7,ScheduleMessage::statusName(status)); |
67 | } | 68 | } |
68 | 69 | ||
69 | 70 | ||
70 | /* Visitor */ | 71 | /* Visitor */ |
71 | ScheduleItemVisitor::ScheduleItemVisitor(ScheduleItemIn *item) | 72 | ScheduleItemVisitor::ScheduleItemVisitor(ScheduleItemIn *item) |
72 | { | 73 | { |
73 | mItem = item; | 74 | mItem = item; |
74 | } | 75 | } |
75 | 76 | ||
76 | ScheduleItemVisitor::~ScheduleItemVisitor() | 77 | ScheduleItemVisitor::~ScheduleItemVisitor() |
77 | { | 78 | { |
78 | } | 79 | } |
79 | 80 | ||
80 | bool ScheduleItemVisitor::visit(Event *e) | 81 | bool ScheduleItemVisitor::visit(Event *e) |
81 | { | 82 | { |
82 | mItem->setText(0,e->summary()); | 83 | mItem->setText(0,e->summary()); |
83 | mItem->setText(1,e->dtStartDateStr()); | 84 | mItem->setText(1,e->dtStartDateStr()); |
84 | if (e->doesFloat()) { | 85 | if (e->doesFloat()) { |
85 | mItem->setText(2,i18n("no time ")); | 86 | mItem->setText(2,i18n("no time ")); |
86 | mItem->setText(4,i18n("no time ")); | 87 | mItem->setText(4,i18n("no time ")); |
87 | } | 88 | } |
88 | else { | 89 | else { |
89 | mItem->setText(2,e->dtStartTimeStr()); | 90 | mItem->setText(2,e->dtStartTimeStr()); |
90 | mItem->setText(4,e->dtEndTimeStr()); | 91 | mItem->setText(4,e->dtEndTimeStr()); |
91 | } | 92 | } |
92 | if (e->hasEndDate()) { | 93 | if (e->hasEndDate()) { |
93 | mItem->setText(3,e->dtEndDateStr()); | 94 | mItem->setText(3,e->dtEndDateStr()); |
94 | } | 95 | } |
95 | else { | 96 | else { |
96 | mItem->setText(3,""); | 97 | mItem->setText(3,""); |
97 | } | 98 | } |
98 | mItem->setText(5,e->organizer()+" "); | 99 | mItem->setText(5,e->organizer()+" "); |
99 | 100 | ||
100 | return true; | 101 | return true; |
101 | } | 102 | } |
102 | 103 | ||
103 | bool ScheduleItemVisitor::visit(Todo *e) | 104 | bool ScheduleItemVisitor::visit(Todo *e) |
104 | { | 105 | { |
105 | mItem->setText(0,e->summary()); | 106 | mItem->setText(0,e->summary()); |
106 | if (e->hasStartDate()) { | 107 | if (e->hasStartDate()) { |
107 | mItem->setText(1,e->dtStartDateStr()); | 108 | mItem->setText(1,e->dtStartDateStr()); |
108 | if (!e->doesFloat()) { | 109 | if (!e->doesFloat()) { |
109 | mItem->setText(2,e->dtStartTimeStr()); | 110 | mItem->setText(2,e->dtStartTimeStr()); |
110 | } | 111 | } |
111 | } | 112 | } |
112 | if (e->hasDueDate()) { | 113 | if (e->hasDueDate()) { |
113 | mItem->setText(1,e->dtDueDateStr()); | 114 | mItem->setText(1,e->dtDueDateStr()); |
114 | if (!e->doesFloat()) { | 115 | if (!e->doesFloat()) { |
115 | mItem->setText(2,e->dtDueTimeStr()); | 116 | mItem->setText(2,e->dtDueTimeStr()); |
116 | } | 117 | } |
117 | } | 118 | } |
118 | mItem->setText(5,e->organizer()+" "); | 119 | mItem->setText(5,e->organizer()+" "); |
119 | 120 | ||
120 | return true; | 121 | return true; |
121 | } | 122 | } |
122 | 123 | ||
123 | bool ScheduleItemVisitor::visit(Journal *) | 124 | bool ScheduleItemVisitor::visit(Journal *) |
124 | { | 125 | { |
125 | return false; | 126 | return false; |
126 | } | 127 | } |
127 | 128 | ||
128 | 129 | ||
129 | /* | 130 | /* |
130 | * Constructs a IncomingDialog which is a child of 'parent', with the | 131 | * Constructs a IncomingDialog which is a child of 'parent', with the |
131 | * name 'name' and widget flags set to 'f' | 132 | * name 'name' and widget flags set to 'f' |
132 | * | 133 | * |
133 | * The dialog will by default be modeless, unless you set 'modal' to | 134 | * The dialog will by default be modeless, unless you set 'modal' to |
134 | * TRUE to construct a modal dialog. | 135 | * TRUE to construct a modal dialog. |
135 | */ | 136 | */ |
136 | IncomingDialog::IncomingDialog(Calendar *calendar,OutgoingDialog *outgoing, | 137 | IncomingDialog::IncomingDialog(Calendar *calendar,OutgoingDialog *outgoing, |
137 | QWidget* parent,const char* name,bool modal,WFlags fl) : | 138 | QWidget* parent,const char* name,bool modal,WFlags fl) : |
138 | IncomingDialog_base(parent,name,modal,fl) | 139 | IncomingDialog_base(parent,name,modal,fl) |
139 | { | 140 | { |
140 | mCalendar = calendar; | 141 | mCalendar = calendar; |
141 | mOutgoing = outgoing; | 142 | mOutgoing = outgoing; |
142 | #ifndef KORG_NOMAIL | 143 | #ifndef KORG_NOMAIL |
143 | mScheduler = new MailScheduler(mCalendar); | 144 | mScheduler = new MailScheduler(mCalendar); |
144 | #else | 145 | #else |
145 | mScheduler = new DummyScheduler(mCalendar); | 146 | mScheduler = new DummyScheduler(mCalendar); |
146 | #endif | 147 | #endif |
147 | mMessageListView->setColumnAlignment(1,AlignHCenter); | 148 | mMessageListView->setColumnAlignment(1,AlignHCenter); |
148 | mMessageListView->setColumnAlignment(2,AlignHCenter); | 149 | mMessageListView->setColumnAlignment(2,AlignHCenter); |
149 | mMessageListView->setColumnAlignment(3,AlignHCenter); | 150 | mMessageListView->setColumnAlignment(3,AlignHCenter); |
150 | mMessageListView->setColumnAlignment(4,AlignHCenter); | 151 | mMessageListView->setColumnAlignment(4,AlignHCenter); |
151 | QObject::connect(mMessageListView,SIGNAL(doubleClicked(QListViewItem *)), | 152 | QObject::connect(mMessageListView,SIGNAL(doubleClicked(QListViewItem *)), |
152 | this,SLOT(showEvent(QListViewItem *))); | 153 | this,SLOT(showEvent(QListViewItem *))); |
153 | retrieve(); | 154 | retrieve(); |
154 | } | 155 | } |
155 | 156 | ||
156 | /* | 157 | /* |
157 | * Destroys the object and frees any allocated resources | 158 | * Destroys the object and frees any allocated resources |
158 | */ | 159 | */ |
159 | IncomingDialog::~IncomingDialog() | 160 | IncomingDialog::~IncomingDialog() |
160 | { | 161 | { |
161 | // no need to delete child widgets, Qt does it all for us | 162 | // no need to delete child widgets, Qt does it all for us |
162 | } | 163 | } |
163 | 164 | ||
164 | void IncomingDialog::setOutgoingDialog(OutgoingDialog *outgoing) | 165 | void IncomingDialog::setOutgoingDialog(OutgoingDialog *outgoing) |
165 | { | 166 | { |
166 | mOutgoing = outgoing; | 167 | mOutgoing = outgoing; |
167 | } | 168 | } |
168 | 169 | ||
169 | void IncomingDialog::retrieve() | 170 | void IncomingDialog::retrieve() |
170 | { | 171 | { |
171 | QPtrList <ScheduleMessage> messages = mScheduler->retrieveTransactions(); | 172 | QPtrList <ScheduleMessage> messages = mScheduler->retrieveTransactions(); |
172 | 173 | ||
173 | ScheduleMessage *message; | 174 | ScheduleMessage *message; |
174 | for(message = messages.first();message;message = messages.next()) { | 175 | for(message = messages.first();message;message = messages.next()) { |
175 | IncidenceBase *inc = message->event(); | 176 | IncidenceBase *inc = message->event(); |
176 | Scheduler::Method method = (Scheduler::Method)message->method(); | 177 | Scheduler::Method method = (Scheduler::Method)message->method(); |
177 | ScheduleMessage::Status status = message->status(); | 178 | ScheduleMessage::Status status = message->status(); |
178 | 179 | ||
179 | ScheduleItemIn *item = new ScheduleItemIn(mMessageListView,inc,method,status); | 180 | ScheduleItemIn *item = new ScheduleItemIn(mMessageListView,inc,method,status); |
180 | if(inc->type()!="FreeBusy") { | 181 | if(inc->type()!="FreeBusy") { |
181 | Incidence *incidence = static_cast<Incidence *>(inc); | 182 | Incidence *incidence = static_cast<Incidence *>(inc); |
182 | ScheduleItemVisitor v(item); | 183 | ScheduleItemVisitor v(item); |
183 | if (!incidence->accept(v)) delete item; | 184 | if (!incidence->accept(v)) delete item; |
184 | } else { | 185 | } else { |
185 | FreeBusy *fb = static_cast<FreeBusy *>(item->event()); | 186 | FreeBusy *fb = static_cast<FreeBusy *>(item->event()); |
186 | item->setText(0, "FreeBusy"); | 187 | item->setText(0, "FreeBusy"); |
187 | item->setText(1, KGlobal::locale()->formatDate( fb->dtStart().date() ) ); | 188 | item->setText(1, KGlobal::locale()->formatDate( fb->dtStart().date() ) ); |
188 | item->setText(2, KGlobal::locale()->formatTime( fb->dtStart().time() ) ); | 189 | item->setText(2, KGlobal::locale()->formatTime( fb->dtStart().time() ) ); |
189 | item->setText(3, KGlobal::locale()->formatDate( fb->dtEnd().date() ) ); | 190 | item->setText(3, KGlobal::locale()->formatDate( fb->dtEnd().date() ) ); |
190 | item->setText(4, KGlobal::locale()->formatTime( fb->dtEnd().time() ) ); | 191 | item->setText(4, KGlobal::locale()->formatTime( fb->dtEnd().time() ) ); |
191 | item->setText(5, fb->organizer()); | 192 | item->setText(5, fb->organizer()); |
192 | } | 193 | } |
193 | automaticAction(item); | 194 | automaticAction(item); |
194 | } | 195 | } |
195 | emit numMessagesChanged(mMessageListView->childCount()); | 196 | emit numMessagesChanged(mMessageListView->childCount()); |
196 | } | 197 | } |
197 | 198 | ||
198 | void IncomingDialog::acceptAllMessages() | 199 | void IncomingDialog::acceptAllMessages() |
199 | { | 200 | { |
200 | bool success = false; | 201 | bool success = false; |
201 | 202 | ||
202 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->firstChild(); | 203 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->firstChild(); |
203 | while(item) { | 204 | while(item) { |
204 | ScheduleItemIn *nextitem = (ScheduleItemIn *)(item->nextSibling()); | 205 | ScheduleItemIn *nextitem = (ScheduleItemIn *)(item->nextSibling()); |
205 | if (acceptMessage(item)) success = true; | 206 | if (acceptMessage(item)) success = true; |
206 | item = nextitem; | 207 | item = nextitem; |
207 | } | 208 | } |
208 | 209 | ||
209 | if (success) emit calendarUpdated(); | 210 | if (success) emit calendarUpdated(); |
210 | } | 211 | } |
211 | 212 | ||
212 | void IncomingDialog::acceptMessage() | 213 | void IncomingDialog::acceptMessage() |
213 | { | 214 | { |
214 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->selectedItem(); | 215 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->selectedItem(); |
215 | if (item) { | 216 | if (item) { |
216 | if (acceptMessage(item)) emit calendarUpdated(); | 217 | if (acceptMessage(item)) emit calendarUpdated(); |
217 | } | 218 | } |
218 | } | 219 | } |
219 | 220 | ||
220 | bool IncomingDialog::acceptMessage(ScheduleItemIn *item) | 221 | bool IncomingDialog::acceptMessage(ScheduleItemIn *item) |
221 | { | 222 | { |
222 | switch (item->method()) { | 223 | switch (item->method()) { |
223 | case Scheduler::Refresh: | 224 | case Scheduler::Refresh: |
224 | return incomeRefresh(item); | 225 | return incomeRefresh(item); |
225 | break; | 226 | break; |
226 | case Scheduler::Counter: | 227 | case Scheduler::Counter: |
227 | return incomeCounter(item); | 228 | return incomeCounter(item); |
228 | break; | 229 | break; |
229 | case Scheduler::Declinecounter: | 230 | case Scheduler::Declinecounter: |
230 | return incomeDeclineCounter(item); | 231 | return incomeDeclineCounter(item); |
231 | break; | 232 | break; |
232 | case Scheduler::Add: | 233 | case Scheduler::Add: |
233 | return incomeAdd(item); | 234 | return incomeAdd(item); |
234 | break; | 235 | break; |
235 | case Scheduler::Request: | 236 | case Scheduler::Request: |
236 | return incomeRequest(item); | 237 | return incomeRequest(item); |
237 | break; | 238 | break; |
238 | default: | 239 | default: |
239 | return incomeDefault(item); | 240 | return incomeDefault(item); |
240 | } | 241 | } |
241 | return false; | 242 | return false; |
242 | } | 243 | } |
243 | 244 | ||
244 | void IncomingDialog::rejectMessage() | 245 | void IncomingDialog::rejectMessage() |
245 | { | 246 | { |
246 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->selectedItem(); | 247 | ScheduleItemIn *item = (ScheduleItemIn *)mMessageListView->selectedItem(); |
247 | if (item) { | 248 | if (item) { |
248 | mScheduler->deleteTransaction(item->event()); | 249 | mScheduler->deleteTransaction(item->event()); |
249 | delete item; | 250 | delete item; |
250 | emit numMessagesChanged(mMessageListView->childCount()); | 251 | emit numMessagesChanged(mMessageListView->childCount()); |
251 | } | 252 | } |
252 | } | 253 | } |
253 | 254 | ||
254 | void IncomingDialog::showEvent(QListViewItem *item) | 255 | void IncomingDialog::showEvent(QListViewItem *item) |
255 | { | 256 | { |
256 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); | 257 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); |
257 | if( incidence && incidence->type() == "Event" ) { | 258 | if( incidence && incidence->type() == "Event" ) { |
258 | Event *event = static_cast<Event *>(incidence); | 259 | Event *event = static_cast<Event *>(incidence); |
259 | KOEventViewerDialog *eventViewer = new KOEventViewerDialog(this); | 260 | KOEventViewerDialog *eventViewer = new KOEventViewerDialog(this); |
260 | eventViewer->setEvent(event); | 261 | eventViewer->setEvent(event); |
261 | eventViewer->show(); | 262 | eventViewer->show(); |
262 | } | 263 | } |
263 | } | 264 | } |
264 | 265 | ||
265 | bool IncomingDialog::incomeRefresh(ScheduleItemIn *item) | 266 | bool IncomingDialog::incomeRefresh(ScheduleItemIn *item) |
266 | { | 267 | { |
267 | Event *ev = mCalendar->event(item->event()->uid()); | 268 | Event *ev = mCalendar->event(item->event()->uid()); |
268 | if (ev) { | 269 | if (ev) { |
269 | //user interaction before?? | 270 | //user interaction before?? |
270 | Attendee *att; | 271 | Attendee *att; |
271 | QPtrList<Attendee> attlist = ev->attendees(); | 272 | QPtrList<Attendee> attlist = ev->attendees(); |
272 | for (att=attlist.first(); att; att=attlist.next()) { | 273 | for (att=attlist.first(); att; att=attlist.next()) { |
273 | Event *event = new Event(*ev); | 274 | Event *event = new Event(*ev); |
274 | mOutgoing->addMessage(event,Scheduler::Request,att->email()); | 275 | mOutgoing->addMessage(event,Scheduler::Request,att->email()); |
275 | delete(event); | 276 | delete(event); |
276 | } | 277 | } |
277 | mScheduler->deleteTransaction(item->event()); | 278 | mScheduler->deleteTransaction(item->event()); |
278 | delete item; | 279 | delete item; |
279 | emit numMessagesChanged(mMessageListView->childCount()); | 280 | emit numMessagesChanged(mMessageListView->childCount()); |
280 | return true; | 281 | return true; |
281 | } | 282 | } |
282 | mScheduler->deleteTransaction(item->event()); | 283 | mScheduler->deleteTransaction(item->event()); |
283 | delete item; | 284 | delete item; |
284 | emit numMessagesChanged(mMessageListView->childCount()); | 285 | emit numMessagesChanged(mMessageListView->childCount()); |
285 | return false; | 286 | return false; |
286 | } | 287 | } |
287 | 288 | ||
288 | bool IncomingDialog::incomeCounter(ScheduleItemIn *item) | 289 | bool IncomingDialog::incomeCounter(ScheduleItemIn *item) |
289 | { | 290 | { |
290 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); | 291 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); |
291 | // currently only events supportet - attetion at insertion below! | 292 | // currently only events supportet - attetion at insertion below! |
292 | if ( incidence->type() != "Event" ) return false; | 293 | if ( incidence->type() != "Event" ) return false; |
293 | 294 | ||
294 | Event *counterEvent = static_cast<Event *>( incidence ); | 295 | Event *counterEvent = static_cast<Event *>( incidence ); |
295 | 296 | ||
296 | Event *even = mCalendar->event(counterEvent->uid()); | 297 | Event *even = mCalendar->event(counterEvent->uid()); |
297 | 298 | ||
298 | KOCounterDialog *eventViewer = new KOCounterDialog(this); | 299 | KOCounterDialog *eventViewer = new KOCounterDialog(this); |
299 | eventViewer->addText(i18n("counter proposal event","<b>Counter-event:</b><p>")); | 300 | eventViewer->addText(i18n("counter proposal event","<b>Counter-event:</b><p>")); |
300 | eventViewer->addEvent(counterEvent); | 301 | eventViewer->addEvent(counterEvent); |
301 | eventViewer->addText("<hr>"); | 302 | eventViewer->addText("<hr>"); |
302 | eventViewer->addText(i18n("<b>Original event:</b><p>")); | 303 | eventViewer->addText(i18n("<b>Original event:</b><p>")); |
303 | if (even) eventViewer->addEvent(even); | 304 | if (even) eventViewer->addEvent(even); |
304 | else eventViewer->addText(i18n("A corresponding event is missing in your calendar!")); | 305 | else eventViewer->addText(i18n("A corresponding event is missing in your calendar!")); |
305 | eventViewer->addText("<hr>"); | 306 | eventViewer->addText("<hr>"); |
306 | eventViewer->addText(i18n("If this counter-event is a good proposal for your event, press 'Accept'. All Attendees will then get the new version of this event")); | 307 | eventViewer->addText(i18n("If this counter-event is a good proposal for your event, press 'Accept'. All Attendees will then get the new version of this event")); |
307 | eventViewer->show(); | 308 | eventViewer->show(); |
308 | 309 | ||
309 | eventViewer->exec(); | 310 | eventViewer->exec(); |
310 | if (eventViewer->result()) { | 311 | if (eventViewer->result()) { |
311 | kdDebug() << "IncomingDialog::Counter:Accept" << endl; | 312 | kdDebug() << "IncomingDialog::Counter:Accept" << endl; |
312 | int revision = 0; | 313 | int revision = 0; |
313 | if (even) { | 314 | if (even) { |
314 | revision = even->revision(); | 315 | revision = even->revision(); |
315 | mCalendar->deleteEvent(even); | 316 | mCalendar->deleteEvent(even); |
316 | } | 317 | } |
317 | mCalendar->addIncidence(counterEvent); | 318 | mCalendar->addIncidence(counterEvent); |
318 | 319 | ||
319 | even = mCalendar->event(item->event()->uid()); | 320 | even = mCalendar->event(item->event()->uid()); |
320 | if (even) { | 321 | if (even) { |
321 | if (revision < even->revision()) | 322 | if (revision < even->revision()) |
322 | even->setRevision(even->revision()+1); | 323 | even->setRevision(even->revision()+1); |
323 | else | 324 | else |
324 | even->setRevision(revision+1); | 325 | even->setRevision(revision+1); |
325 | Event *ev = new Event(*even); | 326 | Event *ev = new Event(*even); |
326 | mOutgoing->addMessage(ev,Scheduler::Request); | 327 | mOutgoing->addMessage(ev,Scheduler::Request); |
327 | delete(ev); | 328 | delete(ev); |
328 | } | 329 | } |
329 | mScheduler->deleteTransaction(item->event()); | 330 | mScheduler->deleteTransaction(item->event()); |
330 | delete item; | 331 | delete item; |
331 | emit numMessagesChanged(mMessageListView->childCount()); | 332 | emit numMessagesChanged(mMessageListView->childCount()); |
332 | return true; | 333 | return true; |
333 | } else { | 334 | } else { |
334 | kdDebug() << "IncomingDialog::Counter:Decline" << endl; | 335 | kdDebug() << "IncomingDialog::Counter:Decline" << endl; |
335 | //the counter-sender's email is missing... | 336 | //the counter-sender's email is missing... |
336 | //now every attendee gets an declinecounter :-( | 337 | //now every attendee gets an declinecounter :-( |
337 | mOutgoing->addMessage(counterEvent,Scheduler::Declinecounter); | 338 | mOutgoing->addMessage(counterEvent,Scheduler::Declinecounter); |
338 | delete item; | 339 | delete item; |
339 | emit numMessagesChanged(mMessageListView->childCount()); | 340 | emit numMessagesChanged(mMessageListView->childCount()); |
340 | mScheduler->deleteTransaction(item->event()); | 341 | mScheduler->deleteTransaction(item->event()); |
341 | delete item; | 342 | delete item; |
342 | emit numMessagesChanged(mMessageListView->childCount()); | 343 | emit numMessagesChanged(mMessageListView->childCount()); |
343 | return true; | 344 | return true; |
344 | } | 345 | } |
345 | //mScheduler->deleteTransaction(item->event()); | 346 | //mScheduler->deleteTransaction(item->event()); |
346 | delete item; | 347 | delete item; |
347 | emit numMessagesChanged(mMessageListView->childCount()); | 348 | emit numMessagesChanged(mMessageListView->childCount()); |
348 | return false; | 349 | return false; |
349 | } | 350 | } |
350 | 351 | ||
351 | bool IncomingDialog::incomeDeclineCounter(ScheduleItemIn *item) | 352 | bool IncomingDialog::incomeDeclineCounter(ScheduleItemIn *item) |
352 | { | 353 | { |
353 | Event *even = mCalendar->event(item->event()->uid()); | 354 | Event *even = mCalendar->event(item->event()->uid()); |
354 | if (even) { | 355 | if (even) { |
355 | mOutgoing->addMessage(even,Scheduler::Refresh); | 356 | mOutgoing->addMessage(even,Scheduler::Refresh); |
356 | mScheduler->deleteTransaction(item->event()); | 357 | mScheduler->deleteTransaction(item->event()); |
357 | delete item; | 358 | delete item; |
358 | emit numMessagesChanged(mMessageListView->childCount()); | 359 | emit numMessagesChanged(mMessageListView->childCount()); |
359 | return true; | 360 | return true; |
360 | } | 361 | } |
361 | mScheduler->deleteTransaction(item->event()); | 362 | mScheduler->deleteTransaction(item->event()); |
362 | delete item; | 363 | delete item; |
363 | emit numMessagesChanged(mMessageListView->childCount()); | 364 | emit numMessagesChanged(mMessageListView->childCount()); |
364 | return false; | 365 | return false; |
365 | } | 366 | } |
366 | 367 | ||
367 | bool IncomingDialog::incomeAdd(ScheduleItemIn *item) | 368 | bool IncomingDialog::incomeAdd(ScheduleItemIn *item) |
368 | { | 369 | { |
369 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); | 370 | IncidenceBase *incidence = ((ScheduleItemIn *)item)->event(); |
370 | if (incidence->type() == "Event" ) { | 371 | if (incidence->type() == "Event" ) { |
371 | Event *refr = static_cast<Event *>( incidence ); | 372 | Event *refr = static_cast<Event *>( incidence ); |
372 | mOutgoing->addMessage(refr,Scheduler::Refresh); | 373 | mOutgoing->addMessage(refr,Scheduler::Refresh); |
373 | mScheduler->deleteTransaction( incidence ); | 374 | mScheduler->deleteTransaction( incidence ); |
374 | delete item; | 375 | delete item; |
375 | emit numMessagesChanged(mMessageListView->childCount()); | 376 | emit numMessagesChanged(mMessageListView->childCount()); |
376 | return true; | 377 | return true; |
377 | } | 378 | } |
378 | else { | 379 | else { |
379 | kdDebug() << "IncomingDialog::incomeAdd - only Events are supportet yet" << endl; | 380 | kdDebug() << "IncomingDialog::incomeAdd - only Events are supportet yet" << endl; |
380 | mScheduler->deleteTransaction( incidence ); | 381 | mScheduler->deleteTransaction( incidence ); |
381 | delete item; | 382 | delete item; |
382 | emit numMessagesChanged(mMessageListView->childCount()); | 383 | emit numMessagesChanged(mMessageListView->childCount()); |
383 | return false; | 384 | return false; |
384 | } | 385 | } |
385 | } | 386 | } |
386 | 387 | ||
387 | bool IncomingDialog::incomeDefault(ScheduleItemIn *item) | 388 | bool IncomingDialog::incomeDefault(ScheduleItemIn *item) |
388 | { | 389 | { |
389 | if (mScheduler->acceptTransaction(item->event(),item->method(),item->status())) { | 390 | if (mScheduler->acceptTransaction(item->event(),item->method(),item->status())) { |
390 | delete item; | 391 | delete item; |
391 | emit numMessagesChanged(mMessageListView->childCount()); | 392 | emit numMessagesChanged(mMessageListView->childCount()); |
392 | return true; | 393 | return true; |
393 | } | 394 | } |
394 | else { | 395 | else { |
395 | KMessageBox::error(this,i18n("Unable to accept the IMIP-message. It may be a problem with the email addresses.")); | 396 | KMessageBox::error(this,i18n("Unable to accept the IMIP-message. It may be a problem with the email addresses.")); |
396 | kdDebug() << "IncomingDialog::acceptMessage(): Error!" << endl; | 397 | kdDebug() << "IncomingDialog::acceptMessage(): Error!" << endl; |
397 | return false; | 398 | return false; |
398 | } | 399 | } |
399 | return false; | 400 | return false; |
400 | } | 401 | } |
401 | 402 | ||
402 | bool IncomingDialog::incomeRequest(ScheduleItemIn *item) | 403 | bool IncomingDialog::incomeRequest(ScheduleItemIn *item) |
403 | { | 404 | { |
404 | if (item->event()->type()=="FreeBusy") { | 405 | if (item->event()->type()=="FreeBusy") { |
405 | //handel freebusy request | 406 | //handel freebusy request |
406 | IncidenceBase *inc = item->event(); | 407 | IncidenceBase *inc = item->event(); |
407 | QDateTime start = inc->dtStart(); | 408 | QDateTime start = inc->dtStart(); |
408 | QDateTime end = start.addDays(inc->duration()/86400); | 409 | QDateTime end = start.addDays(inc->duration()/86400); |
409 | 410 | ||
410 | FreeBusy *freebusy = new FreeBusy(mCalendar, start, end); | 411 | FreeBusy *freebusy = new FreeBusy(mCalendar, start, end); |
411 | freebusy->setOrganizer(inc->organizer()); | 412 | freebusy->setOrganizer(inc->organizer()); |
412 | Attendee *att = new Attendee(KOPrefs::instance()->fullName(), | 413 | Attendee *att = new Attendee(KOPrefs::instance()->fullName(), |
413 | KOPrefs::instance()->email()); | 414 | KOPrefs::instance()->email()); |
414 | freebusy->addAttendee(att); | 415 | freebusy->addAttendee(att); |
415 | 416 | ||
416 | kdDebug() << "calendarview: schedule_publish_freebusy: startDate: " | 417 | kdDebug() << "calendarview: schedule_publish_freebusy: startDate: " |
417 | << KGlobal::locale()->formatDateTime( start ) << " End Date: " | 418 | << KGlobal::locale()->formatDateTime( start ) << " End Date: " |
418 | << KGlobal::locale()->formatDateTime( end ) << endl; | 419 | << KGlobal::locale()->formatDateTime( end ) << endl; |
419 | 420 | ||
420 | if (mOutgoing->addMessage(freebusy,Scheduler::Reply)) { | 421 | if (mOutgoing->addMessage(freebusy,Scheduler::Reply)) { |
421 | delete item; | 422 | delete item; |
422 | emit numMessagesChanged(mMessageListView->childCount()); | 423 | emit numMessagesChanged(mMessageListView->childCount()); |
423 | delete(freebusy); | 424 | delete(freebusy); |
424 | return true; | 425 | return true; |
425 | } | 426 | } |
426 | return false; | 427 | return false; |
427 | } else { | 428 | } else { |
428 | return incomeDefault(item); | 429 | return incomeDefault(item); |
429 | } | 430 | } |
430 | return false; | 431 | return false; |
431 | } | 432 | } |
432 | 433 | ||
433 | bool IncomingDialog::automaticAction(ScheduleItemIn *item) | 434 | bool IncomingDialog::automaticAction(ScheduleItemIn *item) |
434 | { | 435 | { |
435 | bool autoAction = false; | 436 | bool autoAction = false; |
436 | IncidenceBase *inc = item->event(); | 437 | IncidenceBase *inc = item->event(); |
437 | Scheduler::Method method = item->method(); | 438 | Scheduler::Method method = item->method(); |
438 | 439 | ||
439 | if( inc->type()=="FreeBusy" ) { | 440 | if( inc->type()=="FreeBusy" ) { |
440 | if ( method==Scheduler::Request ) { | 441 | if ( method==Scheduler::Request ) { |
441 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { | 442 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { |
442 | // reply freebusy information | 443 | // reply freebusy information |
443 | if ( checkOrganizerInAddressbook(inc->organizer()) ) { | 444 | if ( checkOrganizerInAddressbook(inc->organizer()) ) { |
444 | incomeRequest(item); | 445 | incomeRequest(item); |
445 | } | 446 | } |
446 | } else return false; | 447 | } else return false; |
447 | } else { | 448 | } else { |
448 | 449 | ||
449 | if ( method==Scheduler::Reply ) { | 450 | if ( method==Scheduler::Reply ) { |
450 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { | 451 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { |
451 | // insert freebusy information | 452 | // insert freebusy information |
452 | //if ( checkAttendeesInAddressbook(inc) ) | 453 | //if ( checkAttendeesInAddressbook(inc) ) |
453 | 454 | ||
454 | } else return false; | 455 | } else return false; |
455 | } else { | 456 | } else { |
456 | if ( method==Scheduler::Publish) { | 457 | if ( method==Scheduler::Publish) { |
457 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { | 458 | if ( KOPrefs::instance()->mIMIPAutoFreeBusy==KOPrefs::addressbookAuto ) { |
458 | // insert freebusy information | 459 | // insert freebusy information |
459 | //if ( checkOrganizerInAddressbook(inc->organizer()) ) | 460 | //if ( checkOrganizerInAddressbook(inc->organizer()) ) |
460 | 461 | ||
461 | } | 462 | } |
462 | } else return false; | 463 | } else return false; |
463 | } | 464 | } |
464 | } | 465 | } |
465 | } | 466 | } |
466 | 467 | ||
467 | if ( inc->type()=="Event" ) { | 468 | if ( inc->type()=="Event" ) { |
468 | if ( method==Scheduler::Request || method==Scheduler::Publish ) { | 469 | if ( method==Scheduler::Request || method==Scheduler::Publish ) { |
469 | if ( KOPrefs::instance()->mIMIPAutoInsertRequest==KOPrefs::addressbookAuto ) { | 470 | if ( KOPrefs::instance()->mIMIPAutoInsertRequest==KOPrefs::addressbookAuto ) { |
470 | // insert event | 471 | // insert event |
471 | if ( checkOrganizerInAddressbook(inc->organizer()) ) | 472 | if ( checkOrganizerInAddressbook(inc->organizer()) ) |
472 | autoAction = acceptMessage(item); | 473 | autoAction = acceptMessage(item); |
473 | } else return false; | 474 | } else return false; |
474 | } else { | 475 | } else { |
475 | 476 | ||
476 | if ( method==Scheduler::Reply ) { | 477 | if ( method==Scheduler::Reply ) { |
477 | if ( KOPrefs::instance()->mIMIPAutoInsertReply==KOPrefs::addressbookAuto ) { | 478 | if ( KOPrefs::instance()->mIMIPAutoInsertReply==KOPrefs::addressbookAuto ) { |
478 | // update event information | 479 | // update event information |
479 | if ( checkAttendeesInAddressbook(inc) ) | 480 | if ( checkAttendeesInAddressbook(inc) ) |
480 | autoAction = acceptMessage(item); | 481 | autoAction = acceptMessage(item); |
481 | } else return false; | 482 | } else return false; |
482 | } else { | 483 | } else { |
483 | 484 | ||
484 | if ( method==Scheduler::Refresh ) { | 485 | if ( method==Scheduler::Refresh ) { |
485 | if ( KOPrefs::instance()->mIMIPAutoRefresh==KOPrefs::addressbookAuto ) { | 486 | if ( KOPrefs::instance()->mIMIPAutoRefresh==KOPrefs::addressbookAuto ) { |
486 | // send refresh-information | 487 | // send refresh-information |
487 | if ( checkAttendeesInAddressbook(inc) ) | 488 | if ( checkAttendeesInAddressbook(inc) ) |
488 | autoAction = acceptMessage(item); | 489 | autoAction = acceptMessage(item); |
489 | else return false; | 490 | else return false; |
490 | } else return false; | 491 | } else return false; |
491 | } else return false; | 492 | } else return false; |
492 | } | 493 | } |
493 | } | 494 | } |
494 | } | 495 | } |
495 | return autoAction; | 496 | return autoAction; |
496 | } | 497 | } |
497 | 498 | ||
498 | bool IncomingDialog::checkOrganizerInAddressbook(QString organizer) | 499 | bool IncomingDialog::checkOrganizerInAddressbook(QString organizer) |
499 | { | 500 | { |
500 | bool inBook = false; | 501 | bool inBook = false; |
501 | #ifndef KORG_NOKABC | 502 | #ifndef KORG_NOKABC |
502 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); | 503 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); |
503 | KABC::Addressee::List addressList; | 504 | KABC::Addressee::List addressList; |
504 | addressList = add_book->findByEmail(organizer); | 505 | addressList = add_book->findByEmail(organizer); |
505 | if ( addressList.size()>0 ) inBook = true; | 506 | if ( addressList.size()>0 ) inBook = true; |
506 | #endif | 507 | #endif |
507 | return inBook; | 508 | return inBook; |
508 | } | 509 | } |
509 | 510 | ||
510 | bool IncomingDialog::checkAttendeesInAddressbook(IncidenceBase *inc) | 511 | bool IncomingDialog::checkAttendeesInAddressbook(IncidenceBase *inc) |
511 | { | 512 | { |
512 | bool inBook = false; | 513 | bool inBook = false; |
513 | #ifndef KORG_NOKABC | 514 | #ifndef KORG_NOKABC |
514 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); | 515 | KABC::AddressBook *add_book = KABC::StdAddressBook::self(); |
515 | KABC::Addressee::List addressList; | 516 | KABC::Addressee::List addressList; |
516 | QPtrList <Attendee> attendees; | 517 | QPtrList <Attendee> attendees; |
517 | Attendee *att; | 518 | Attendee *att; |
518 | attendees = inc->attendees(); | 519 | attendees = inc->attendees(); |
519 | for (att=attendees.first();att;att=attendees.next()) { | 520 | for (att=attendees.first();att;att=attendees.next()) { |
520 | addressList = add_book->findByEmail(att->email()); | 521 | addressList = add_book->findByEmail(att->email()); |
521 | if (addressList.size()>0 ) inBook = true; | 522 | if (addressList.size()>0 ) inBook = true; |
522 | } | 523 | } |
523 | #endif | 524 | #endif |
524 | return inBook; | 525 | return inBook; |
525 | } | 526 | } |
526 | 527 | ||
527 | //#include "incomingdialog.moc" | 528 | //#include "incomingdialog.moc" |
diff --git a/korganizer/korganizerE.pro b/korganizer/korganizerE.pro index 4247838..d841193 100644 --- a/korganizer/korganizerE.pro +++ b/korganizer/korganizerE.pro | |||
@@ -1,155 +1,157 @@ | |||
1 | TEMPLATE= app | 1 | TEMPLATE= app |
2 | CONFIG += qt warn_on | 2 | CONFIG += qt warn_on |
3 | TARGET = kopi | 3 | TARGET = kopi |
4 | OBJECTS_DIR = obj/$(PLATFORM) | 4 | OBJECTS_DIR = obj/$(PLATFORM) |
5 | MOC_DIR = moc/$(PLATFORM) | 5 | MOC_DIR = moc/$(PLATFORM) |
6 | DESTDIR=$(QPEDIR)/bin | 6 | DESTDIR=$(QPEDIR)/bin |
7 | 7 | ||
8 | INCLUDEPATH += $(KDEPIMDIR) $(KDEPIMDIR)/microkde $(KDEPIMDIR)/microkde/kdecore $(KDEPIMDIR)/microkde/kio/kfile $(KDEPIMDIR)/microkde/kio/kio $(KDEPIMDIR)/microkde/kdeui $(KDEPIMDIR)/qtcompat $(KDEPIMDIR)/libkdepim interfaces $(KDEPIMDIR)/kabc $(QPEDIR)/include | 8 | INCLUDEPATH += $(KDEPIMDIR) $(KDEPIMDIR)/microkde $(KDEPIMDIR)/microkde/kdecore $(KDEPIMDIR)/microkde/kio/kfile $(KDEPIMDIR)/microkde/kio/kio $(KDEPIMDIR)/microkde/kdeui $(KDEPIMDIR)/qtcompat $(KDEPIMDIR)/libkdepim interfaces $(KDEPIMDIR)/kabc $(QPEDIR)/include |
9 | 9 | ||
10 | DEFINES += KORG_NODND KORG_NOPLUGINS KORG_NOARCHIVE KORG_NOMAIL | 10 | DEFINES += KORG_NODND KORG_NOPLUGINS KORG_NOARCHIVE KORG_NOMAIL |
11 | DEFINES += KORG_NOPRINTER KORG_NODCOP KORG_NOKALARMD KORG_NORESOURCEVIEW KORG_NOSPLITTER | 11 | DEFINES += KORG_NOPRINTER KORG_NODCOP KORG_NOKALARMD KORG_NORESOURCEVIEW KORG_NOSPLITTER |
12 | DEFINES += KORG_NOLVALTERNATION | 12 | DEFINES += KORG_NOLVALTERNATION |
13 | #KORG_NOKABC | 13 | #KORG_NOKABC |
14 | LIBS += -lmicrokdepim | 14 | LIBS += -lmicrokdepim |
15 | LIBS += -lmicrokcal | 15 | LIBS += -lmicrokcal |
16 | LIBS += -lmicrokde | 16 | LIBS += -lmicrokde |
17 | LIBS += -lmicroqtcompat | 17 | LIBS += -lmicroqtcompat |
18 | LIBS += -lmicrokabc | 18 | #LIBS += -lmicrokabc |
19 | 19 | ||
20 | #LIBS += $(QPEDIR)/lib/gammu | 20 | #LIBS += $(QPEDIR)/lib/gammu |
21 | #LIBS += -lmicrogammu | 21 | #LIBS += -lmicrogammu |
22 | #LIBS += -lbluetooth | 22 | #LIBS += -lbluetooth |
23 | #LIBS += -lsdp | 23 | #LIBS += -lsdp |
24 | LIBS += $(GCC3EXTRALIB1) | ||
25 | LIBS += $(GCC3EXTRALIB2) | ||
24 | 26 | ||
25 | 27 | ||
26 | LIBS += -lqpe | 28 | LIBS += -lqpe |
27 | LIBS += -ljpeg | 29 | LIBS += -ljpeg |
28 | LIBS += $(QTOPIALIB) | 30 | LIBS += $(QTOPIALIB) |
29 | LIBS += -L$(QPEDIR)/lib | 31 | LIBS += -L$(QPEDIR)/lib |
30 | 32 | ||
31 | INTERFACES = kofilterview_base.ui | 33 | INTERFACES = kofilterview_base.ui |
32 | #filteredit_base.ui | 34 | #filteredit_base.ui |
33 | 35 | ||
34 | HEADERS = \ | 36 | HEADERS = \ |
35 | wordsgerman.h \ | 37 | wordsgerman.h \ |
36 | filteredit_base.h \ | 38 | filteredit_base.h \ |
37 | alarmclient.h \ | 39 | alarmclient.h \ |
38 | calendarview.h \ | 40 | calendarview.h \ |
39 | customlistviewitem.h \ | 41 | customlistviewitem.h \ |
40 | datenavigator.h \ | 42 | datenavigator.h \ |
41 | docprefs.h \ | 43 | docprefs.h \ |
42 | filtereditdialog.h \ | 44 | filtereditdialog.h \ |
43 | incomingdialog.h \ | 45 | incomingdialog.h \ |
44 | incomingdialog_base.h \ | 46 | incomingdialog_base.h \ |
45 | interfaces/korganizer/baseview.h \ | 47 | interfaces/korganizer/baseview.h \ |
46 | interfaces/korganizer/calendarviewbase.h \ | 48 | interfaces/korganizer/calendarviewbase.h \ |
47 | journalentry.h \ | 49 | journalentry.h \ |
48 | kdateedit.h \ | 50 | kdateedit.h \ |
49 | kdatenavigator.h \ | 51 | kdatenavigator.h \ |
50 | koagenda.h \ | 52 | koagenda.h \ |
51 | koagendaitem.h \ | 53 | koagendaitem.h \ |
52 | koagendaview.h \ | 54 | koagendaview.h \ |
53 | kocounterdialog.h \ | 55 | kocounterdialog.h \ |
54 | kodaymatrix.h \ | 56 | kodaymatrix.h \ |
55 | kodialogmanager.h \ | 57 | kodialogmanager.h \ |
56 | koeditordetails.h \ | 58 | koeditordetails.h \ |
57 | koeditorgeneral.h \ | 59 | koeditorgeneral.h \ |
58 | koeditorgeneralevent.h \ | 60 | koeditorgeneralevent.h \ |
59 | koeditorgeneraltodo.h \ | 61 | koeditorgeneraltodo.h \ |
60 | koeditorrecurrence.h \ | 62 | koeditorrecurrence.h \ |
61 | koeventeditor.h \ | 63 | koeventeditor.h \ |
62 | koeventpopupmenu.h \ | 64 | koeventpopupmenu.h \ |
63 | koeventview.h \ | 65 | koeventview.h \ |
64 | koeventviewer.h \ | 66 | koeventviewer.h \ |
65 | koeventviewerdialog.h \ | 67 | koeventviewerdialog.h \ |
66 | kofilterview.h \ | 68 | kofilterview.h \ |
67 | koglobals.h \ | 69 | koglobals.h \ |
68 | koincidenceeditor.h \ | 70 | koincidenceeditor.h \ |
69 | kojournalview.h \ | 71 | kojournalview.h \ |
70 | kolistview.h \ | 72 | kolistview.h \ |
71 | kolocationbox.h \ | 73 | kolocationbox.h \ |
72 | komonthview.h \ | 74 | komonthview.h \ |
73 | koprefs.h \ | 75 | koprefs.h \ |
74 | koprefsdialog.h \ | 76 | koprefsdialog.h \ |
75 | kotimespanview.h \ | 77 | kotimespanview.h \ |
76 | kotodoeditor.h \ | 78 | kotodoeditor.h \ |
77 | kotodoview.h \ | 79 | kotodoview.h \ |
78 | kotodoviewitem.h \ | 80 | kotodoviewitem.h \ |
79 | koviewmanager.h \ | 81 | koviewmanager.h \ |
80 | kowhatsnextview.h \ | 82 | kowhatsnextview.h \ |
81 | ktimeedit.h \ | 83 | ktimeedit.h \ |
82 | lineview.h \ | 84 | lineview.h \ |
83 | mainwindow.h \ | 85 | mainwindow.h \ |
84 | navigatorbar.h \ | 86 | navigatorbar.h \ |
85 | outgoingdialog.h \ | 87 | outgoingdialog.h \ |
86 | outgoingdialog_base.h \ | 88 | outgoingdialog_base.h \ |
87 | publishdialog.h \ | 89 | publishdialog.h \ |
88 | publishdialog_base.h \ | 90 | publishdialog_base.h \ |
89 | savetemplatedialog.h \ | 91 | savetemplatedialog.h \ |
90 | searchdialog.h \ | 92 | searchdialog.h \ |
91 | simplealarmclient.h \ | 93 | simplealarmclient.h \ |
92 | statusdialog.h \ | 94 | statusdialog.h \ |
93 | timeline.h \ | 95 | timeline.h \ |
94 | timespanview.h \ | 96 | timespanview.h \ |
95 | version.h \ | 97 | version.h \ |
96 | ../kalarmd/alarmdialog.h | 98 | ../kalarmd/alarmdialog.h |
97 | 99 | ||
98 | SOURCES = \ | 100 | SOURCES = \ |
99 | filteredit_base.cpp \ | 101 | filteredit_base.cpp \ |
100 | calendarview.cpp \ | 102 | calendarview.cpp \ |
101 | datenavigator.cpp \ | 103 | datenavigator.cpp \ |
102 | docprefs.cpp \ | 104 | docprefs.cpp \ |
103 | filtereditdialog.cpp \ | 105 | filtereditdialog.cpp \ |
104 | incomingdialog.cpp \ | 106 | incomingdialog.cpp \ |
105 | incomingdialog_base.cpp \ | 107 | incomingdialog_base.cpp \ |
106 | journalentry.cpp \ | 108 | journalentry.cpp \ |
107 | kdatenavigator.cpp \ | 109 | kdatenavigator.cpp \ |
108 | koagenda.cpp \ | 110 | koagenda.cpp \ |
109 | koagendaitem.cpp \ | 111 | koagendaitem.cpp \ |
110 | koagendaview.cpp \ | 112 | koagendaview.cpp \ |
111 | kocounterdialog.cpp \ | 113 | kocounterdialog.cpp \ |
112 | kodaymatrix.cpp \ | 114 | kodaymatrix.cpp \ |
113 | kodialogmanager.cpp \ | 115 | kodialogmanager.cpp \ |
114 | koeditordetails.cpp \ | 116 | koeditordetails.cpp \ |
115 | koeditorgeneral.cpp \ | 117 | koeditorgeneral.cpp \ |
116 | koeditorgeneralevent.cpp \ | 118 | koeditorgeneralevent.cpp \ |
117 | koeditorgeneraltodo.cpp \ | 119 | koeditorgeneraltodo.cpp \ |
118 | koeditorrecurrence.cpp \ | 120 | koeditorrecurrence.cpp \ |
119 | koeventeditor.cpp \ | 121 | koeventeditor.cpp \ |
120 | koeventpopupmenu.cpp \ | 122 | koeventpopupmenu.cpp \ |
121 | koeventview.cpp \ | 123 | koeventview.cpp \ |
122 | koeventviewer.cpp \ | 124 | koeventviewer.cpp \ |
123 | koeventviewerdialog.cpp \ | 125 | koeventviewerdialog.cpp \ |
124 | kofilterview.cpp \ | 126 | kofilterview.cpp \ |
125 | koglobals.cpp \ | 127 | koglobals.cpp \ |
126 | koincidenceeditor.cpp \ | 128 | koincidenceeditor.cpp \ |
127 | kojournalview.cpp \ | 129 | kojournalview.cpp \ |
128 | kolistview.cpp \ | 130 | kolistview.cpp \ |
129 | kolocationbox.cpp \ | 131 | kolocationbox.cpp \ |
130 | komonthview.cpp \ | 132 | komonthview.cpp \ |
131 | koprefs.cpp \ | 133 | koprefs.cpp \ |
132 | koprefsdialog.cpp \ | 134 | koprefsdialog.cpp \ |
133 | kotimespanview.cpp \ | 135 | kotimespanview.cpp \ |
134 | kotodoeditor.cpp \ | 136 | kotodoeditor.cpp \ |
135 | kotodoview.cpp \ | 137 | kotodoview.cpp \ |
136 | kotodoviewitem.cpp \ | 138 | kotodoviewitem.cpp \ |
137 | koviewmanager.cpp \ | 139 | koviewmanager.cpp \ |
138 | kowhatsnextview.cpp \ | 140 | kowhatsnextview.cpp \ |
139 | ktimeedit.cpp \ | 141 | ktimeedit.cpp \ |
140 | lineview.cpp \ | 142 | lineview.cpp \ |
141 | main.cpp \ | 143 | main.cpp \ |
142 | mainwindow.cpp \ | 144 | mainwindow.cpp \ |
143 | navigatorbar.cpp \ | 145 | navigatorbar.cpp \ |
144 | outgoingdialog.cpp \ | 146 | outgoingdialog.cpp \ |
145 | outgoingdialog_base.cpp \ | 147 | outgoingdialog_base.cpp \ |
146 | publishdialog.cpp \ | 148 | publishdialog.cpp \ |
147 | publishdialog_base.cpp \ | 149 | publishdialog_base.cpp \ |
148 | savetemplatedialog.cpp \ | 150 | savetemplatedialog.cpp \ |
149 | searchdialog.cpp \ | 151 | searchdialog.cpp \ |
150 | simplealarmclient.cpp \ | 152 | simplealarmclient.cpp \ |
151 | statusdialog.cpp \ | 153 | statusdialog.cpp \ |
152 | timeline.cpp \ | 154 | timeline.cpp \ |
153 | timespanview.cpp \ | 155 | timespanview.cpp \ |
154 | ../kalarmd/alarmdialog.cpp | 156 | ../kalarmd/alarmdialog.cpp |
155 | 157 | ||
diff --git a/korganizer/publishdialog.cpp b/korganizer/publishdialog.cpp index 4323b91..2ae6720 100644 --- a/korganizer/publishdialog.cpp +++ b/korganizer/publishdialog.cpp | |||
@@ -1,150 +1,151 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2001 Cornelius Schumacher <schumacher@kde.org> |
4 | 4 | ||
5 | This program is free software; you can redistribute it and/or modify | 5 | This program is free software; you can redistribute it and/or modify |
6 | it under the terms of the GNU General Public License as published by | 6 | it under the terms of the GNU General Public License as published by |
7 | the Free Software Foundation; either version 2 of the License, or | 7 | the Free Software Foundation; either version 2 of the License, or |
8 | (at your option) any later version. | 8 | (at your option) any later version. |
9 | 9 | ||
10 | This program is distributed in the hope that it will be useful, | 10 | This program is distributed in the hope that it will be useful, |
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | GNU General Public License for more details. | 13 | GNU General Public License for more details. |
14 | 14 | ||
15 | You should have received a copy of the GNU General Public License | 15 | You should have received a copy of the GNU General Public License |
16 | along with this program; if not, write to the Free Software | 16 | along with this program; if not, write to the Free Software |
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | 18 | ||
19 | As a special exception, permission is given to link this program | 19 | As a special exception, permission is given to link this program |
20 | with any edition of Qt, and distribute the resulting executable, | 20 | with any edition of Qt, and distribute the resulting executable, |
21 | without including the source code for Qt in the source distribution. | 21 | without including the source code for Qt in the source distribution. |
22 | */ | 22 | */ |
23 | 23 | ||
24 | #include <qlineedit.h> | 24 | #include <qlineedit.h> |
25 | #include <kdebug.h> | 25 | #include <kdebug.h> |
26 | 26 | ||
27 | #include <kglobal.h> | 27 | #include <kglobal.h> |
28 | #include <klocale.h> | 28 | #include <klocale.h> |
29 | #ifndef KORG_NOKABC | 29 | #ifndef KORG_NOKABC |
30 | #include <kabc/addresseedialog.h> | 30 | #define KORG_NOKABC |
31 | //#include <kabc/addresseedialog.h> | ||
31 | #endif | 32 | #endif |
32 | 33 | ||
33 | #include "koprefs.h" | 34 | #include "koprefs.h" |
34 | #include "publishdialog.h" | 35 | #include "publishdialog.h" |
35 | 36 | ||
36 | PublishDialog::PublishDialog(QWidget* parent, const char* name, | 37 | PublishDialog::PublishDialog(QWidget* parent, const char* name, |
37 | bool modal, WFlags fl) | 38 | bool modal, WFlags fl) |
38 | : PublishDialog_base(parent,name,modal,fl) | 39 | : PublishDialog_base(parent,name,modal,fl) |
39 | { | 40 | { |
40 | setCaption(i18n("Select Addresses")); | 41 | setCaption(i18n("Select Addresses")); |
41 | mNameLineEdit->setEnabled(false); | 42 | mNameLineEdit->setEnabled(false); |
42 | mEmailLineEdit->setEnabled(false); | 43 | mEmailLineEdit->setEnabled(false); |
43 | connect(mAddressListView,SIGNAL(selectionChanged(QListViewItem *)), | 44 | connect(mAddressListView,SIGNAL(selectionChanged(QListViewItem *)), |
44 | SLOT(updateInput())); | 45 | SLOT(updateInput())); |
45 | } | 46 | } |
46 | 47 | ||
47 | PublishDialog::~PublishDialog() | 48 | PublishDialog::~PublishDialog() |
48 | { | 49 | { |
49 | } | 50 | } |
50 | 51 | ||
51 | void PublishDialog::addAttendee(Attendee *attendee) | 52 | void PublishDialog::addAttendee(Attendee *attendee) |
52 | { | 53 | { |
53 | mNameLineEdit->setEnabled(true); | 54 | mNameLineEdit->setEnabled(true); |
54 | mEmailLineEdit->setEnabled(true); | 55 | mEmailLineEdit->setEnabled(true); |
55 | QListViewItem *item = new QListViewItem(mAddressListView); | 56 | QListViewItem *item = new QListViewItem(mAddressListView); |
56 | item->setText(0,attendee->name()); | 57 | item->setText(0,attendee->name()); |
57 | item->setText(1,attendee->email()); | 58 | item->setText(1,attendee->email()); |
58 | mAddressListView->insertItem(item); | 59 | mAddressListView->insertItem(item); |
59 | } | 60 | } |
60 | 61 | ||
61 | QString PublishDialog::addresses() | 62 | QString PublishDialog::addresses() |
62 | { | 63 | { |
63 | QString to = ""; | 64 | QString to = ""; |
64 | QListViewItem *item; | 65 | QListViewItem *item; |
65 | int i, count; | 66 | int i, count; |
66 | count = mAddressListView->childCount(); | 67 | count = mAddressListView->childCount(); |
67 | for (i=0;i<count;i++) { | 68 | for (i=0;i<count;i++) { |
68 | item = mAddressListView->firstChild(); | 69 | item = mAddressListView->firstChild(); |
69 | mAddressListView->takeItem(item); | 70 | mAddressListView->takeItem(item); |
70 | to += item->text(1); | 71 | to += item->text(1); |
71 | if (i<count-1) { | 72 | if (i<count-1) { |
72 | to += ", "; | 73 | to += ", "; |
73 | } | 74 | } |
74 | } | 75 | } |
75 | return to; | 76 | return to; |
76 | } | 77 | } |
77 | 78 | ||
78 | void PublishDialog::addItem() | 79 | void PublishDialog::addItem() |
79 | { | 80 | { |
80 | mNameLineEdit->setEnabled(true); | 81 | mNameLineEdit->setEnabled(true); |
81 | mEmailLineEdit->setEnabled(true); | 82 | mEmailLineEdit->setEnabled(true); |
82 | QListViewItem *item = new QListViewItem(mAddressListView); | 83 | QListViewItem *item = new QListViewItem(mAddressListView); |
83 | mAddressListView->insertItem(item); | 84 | mAddressListView->insertItem(item); |
84 | mAddressListView->setSelected(item,true); | 85 | mAddressListView->setSelected(item,true); |
85 | mNameLineEdit->setText(i18n("(EmptyName)")); | 86 | mNameLineEdit->setText(i18n("(EmptyName)")); |
86 | mEmailLineEdit->setText(i18n("(EmptyEmail)")); | 87 | mEmailLineEdit->setText(i18n("(EmptyEmail)")); |
87 | } | 88 | } |
88 | 89 | ||
89 | void PublishDialog::removeItem() | 90 | void PublishDialog::removeItem() |
90 | { | 91 | { |
91 | QListViewItem *item; | 92 | QListViewItem *item; |
92 | item = mAddressListView->selectedItem(); | 93 | item = mAddressListView->selectedItem(); |
93 | if (!item) return; | 94 | if (!item) return; |
94 | mAddressListView->takeItem(item); | 95 | mAddressListView->takeItem(item); |
95 | item = mAddressListView->selectedItem(); | 96 | item = mAddressListView->selectedItem(); |
96 | if (!item) { | 97 | if (!item) { |
97 | mNameLineEdit->setText(""); | 98 | mNameLineEdit->setText(""); |
98 | mEmailLineEdit->setText(""); | 99 | mEmailLineEdit->setText(""); |
99 | mNameLineEdit->setEnabled(false); | 100 | mNameLineEdit->setEnabled(false); |
100 | mEmailLineEdit->setEnabled(false); | 101 | mEmailLineEdit->setEnabled(false); |
101 | } | 102 | } |
102 | if (mAddressListView->childCount() == 0) { | 103 | if (mAddressListView->childCount() == 0) { |
103 | mNameLineEdit->setEnabled(false); | 104 | mNameLineEdit->setEnabled(false); |
104 | mEmailLineEdit->setEnabled(false); | 105 | mEmailLineEdit->setEnabled(false); |
105 | } | 106 | } |
106 | } | 107 | } |
107 | 108 | ||
108 | void PublishDialog::openAddressbook() | 109 | void PublishDialog::openAddressbook() |
109 | { | 110 | { |
110 | #ifndef KORG_NOKABC | 111 | #ifndef KORG_NOKABC |
111 | KABC::Addressee::List addressList; | 112 | KABC::Addressee::List addressList; |
112 | addressList = KABC::AddresseeDialog::getAddressees(this); | 113 | addressList = KABC::AddresseeDialog::getAddressees(this); |
113 | //KABC::Addressee a = KABC::AddresseeDialog::getAddressee(this); | 114 | //KABC::Addressee a = KABC::AddresseeDialog::getAddressee(this); |
114 | KABC::Addressee a = addressList.first(); | 115 | KABC::Addressee a = addressList.first(); |
115 | if (!a.isEmpty()) { | 116 | if (!a.isEmpty()) { |
116 | uint i; | 117 | uint i; |
117 | for (i=0;i<addressList.count();i++) { | 118 | for (i=0;i<addressList.count();i++) { |
118 | a = addressList[i]; | 119 | a = addressList[i]; |
119 | mNameLineEdit->setEnabled(true); | 120 | mNameLineEdit->setEnabled(true); |
120 | mEmailLineEdit->setEnabled(true); | 121 | mEmailLineEdit->setEnabled(true); |
121 | QListViewItem *item = new QListViewItem(mAddressListView); | 122 | QListViewItem *item = new QListViewItem(mAddressListView); |
122 | mAddressListView->setSelected(item,true); | 123 | mAddressListView->setSelected(item,true); |
123 | mNameLineEdit->setText(a.realName()); | 124 | mNameLineEdit->setText(a.realName()); |
124 | mEmailLineEdit->setText(a.preferredEmail()); | 125 | mEmailLineEdit->setText(a.preferredEmail()); |
125 | mAddressListView->insertItem(item); | 126 | mAddressListView->insertItem(item); |
126 | } | 127 | } |
127 | } | 128 | } |
128 | #endif | 129 | #endif |
129 | } | 130 | } |
130 | 131 | ||
131 | void PublishDialog::updateItem() | 132 | void PublishDialog::updateItem() |
132 | { | 133 | { |
133 | QListViewItem *item; | 134 | QListViewItem *item; |
134 | item = mAddressListView->selectedItem(); | 135 | item = mAddressListView->selectedItem(); |
135 | if (!item) return; | 136 | if (!item) return; |
136 | item->setText(0,mNameLineEdit->text()); | 137 | item->setText(0,mNameLineEdit->text()); |
137 | item->setText(1,mEmailLineEdit->text()); | 138 | item->setText(1,mEmailLineEdit->text()); |
138 | } | 139 | } |
139 | 140 | ||
140 | void PublishDialog::updateInput() | 141 | void PublishDialog::updateInput() |
141 | { | 142 | { |
142 | QListViewItem *item; | 143 | QListViewItem *item; |
143 | item = mAddressListView->selectedItem(); | 144 | item = mAddressListView->selectedItem(); |
144 | if (!item) return; | 145 | if (!item) return; |
145 | mNameLineEdit->setEnabled(true); | 146 | mNameLineEdit->setEnabled(true); |
146 | mEmailLineEdit->setEnabled(true); | 147 | mEmailLineEdit->setEnabled(true); |
147 | QString mail = item->text(1); | 148 | QString mail = item->text(1); |
148 | mNameLineEdit->setText(item->text(0)); | 149 | mNameLineEdit->setText(item->text(0)); |
149 | mEmailLineEdit->setText(mail); | 150 | mEmailLineEdit->setText(mail); |
150 | } | 151 | } |