summaryrefslogtreecommitdiffabout
path: root/korganizer
Unidiff
Diffstat (limited to 'korganizer') (more/less context) (ignore whitespace changes)
-rw-r--r--korganizer/calendarview.cpp4
-rw-r--r--korganizer/incomingdialog.cpp3
-rw-r--r--korganizer/korganizerE.pro4
-rw-r--r--korganizer/publishdialog.cpp3
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}
853Event* CalendarView::getLastSyncEvent() 853Event* 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
876void CalendarView::setupExternSyncProfiles() 876void 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
892void CalendarView::checkExternSyncEvent( QPtrList<Event> lastSync , Incidence* toDelete ) 892void 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}
920void CalendarView::checkExternalId( Incidence * inc ) 920void 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}
926bool CalendarView::synchronizeCalendar( Calendar* local, Calendar* remote, int mode ) 926bool 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
1198void CalendarView::setSyncDevice( QString s ) 1198void CalendarView::setSyncDevice( QString s )
1199{ 1199{
1200 mCurrentSyncDevice= s; 1200 mCurrentSyncDevice= s;
1201} 1201}
1202void CalendarView::setSyncName( QString s ) 1202void CalendarView::setSyncName( QString s )
1203{ 1203{
1204 mCurrentSyncName= s; 1204 mCurrentSyncName= s;
1205} 1205}
1206bool CalendarView::syncCalendar(QString filename, int mode) 1206bool 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}
1234void CalendarView::syncPhone() 1234void CalendarView::syncPhone()
1235{ 1235{
1236 syncExternal( 1 ); 1236 syncExternal( 1 );
1237} 1237}
1238void CalendarView::syncExternal( int mode ) 1238void 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}
1322void CalendarView::syncSharp() 1322void 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>
1330bool CalendarView::importBday() 1330bool 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
1375bool CalendarView::addAnniversary( QDate date, QString name, KCal::Attendee* a, bool birthday) 1377bool 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}
1403bool CalendarView::importQtopia( const QString &categories, 1405bool 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
1463void CalendarView::setSyncEventsReadOnly() 1465void 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}
1474bool CalendarView::openCalendar(QString filename, bool merge) 1476bool 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}
1522void CalendarView::setLoadedFileVersion(QDateTime dt) 1524void CalendarView::setLoadedFileVersion(QDateTime dt)
1523{ 1525{
1524 loadedFileVersion = dt; 1526 loadedFileVersion = dt;
1525} 1527}
1526bool CalendarView::checkFileChanged(QString fn) 1528bool 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}
1537bool CalendarView::checkFileVersion(QString fn) 1539bool 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
1569bool CalendarView::saveCalendar( QString filename ) 1571bool 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
1590void CalendarView::closeCalendar() 1592void 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
1601void CalendarView::archiveCalendar() 1603void CalendarView::archiveCalendar()
1602{ 1604{
1603 mDialogManager->showArchiveDialog(); 1605 mDialogManager->showArchiveDialog();
1604} 1606}
1605 1607
1606 1608
1607void CalendarView::readSettings() 1609void 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
1693void CalendarView::writeSettings() 1695void 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
1790void CalendarView::readFilterSettings(KConfig *config) 1792void 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
1830void CalendarView::writeFilterSettings(KConfig *config) 1832void 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
1854void CalendarView::goToday() 1856void CalendarView::goToday()
1855{ 1857{
1856 mNavigator->selectToday(); 1858 mNavigator->selectToday();
1857} 1859}
1858 1860
1859void CalendarView::goNext() 1861void CalendarView::goNext()
1860{ 1862{
1861 mNavigator->selectNext(); 1863 mNavigator->selectNext();
1862} 1864}
1863 1865
1864void CalendarView::goPrevious() 1866void CalendarView::goPrevious()
1865{ 1867{
1866 mNavigator->selectPrevious(); 1868 mNavigator->selectPrevious();
1867} 1869}
1868void CalendarView::goNextMonth() 1870void CalendarView::goNextMonth()
1869{ 1871{
1870 mNavigator->selectNextMonth(); 1872 mNavigator->selectNextMonth();
1871} 1873}
1872 1874
1873void CalendarView::goPreviousMonth() 1875void CalendarView::goPreviousMonth()
1874{ 1876{
1875 mNavigator->selectPreviousMonth(); 1877 mNavigator->selectPreviousMonth();
1876} 1878}
1877void CalendarView::writeLocale() 1879void 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
58ScheduleItemIn::ScheduleItemIn(QListView *parent,IncidenceBase *ev, 59ScheduleItemIn::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 */
71ScheduleItemVisitor::ScheduleItemVisitor(ScheduleItemIn *item) 72ScheduleItemVisitor::ScheduleItemVisitor(ScheduleItemIn *item)
72{ 73{
73 mItem = item; 74 mItem = item;
74} 75}
75 76
76ScheduleItemVisitor::~ScheduleItemVisitor() 77ScheduleItemVisitor::~ScheduleItemVisitor()
77{ 78{
78} 79}
79 80
80bool ScheduleItemVisitor::visit(Event *e) 81bool 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
103bool ScheduleItemVisitor::visit(Todo *e) 104bool 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
123bool ScheduleItemVisitor::visit(Journal *) 124bool 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 */
136IncomingDialog::IncomingDialog(Calendar *calendar,OutgoingDialog *outgoing, 137IncomingDialog::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 */
159IncomingDialog::~IncomingDialog() 160IncomingDialog::~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
164void IncomingDialog::setOutgoingDialog(OutgoingDialog *outgoing) 165void IncomingDialog::setOutgoingDialog(OutgoingDialog *outgoing)
165{ 166{
166 mOutgoing = outgoing; 167 mOutgoing = outgoing;
167} 168}
168 169
169void IncomingDialog::retrieve() 170void 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
198void IncomingDialog::acceptAllMessages() 199void 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
212void IncomingDialog::acceptMessage() 213void 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
220bool IncomingDialog::acceptMessage(ScheduleItemIn *item) 221bool 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
244void IncomingDialog::rejectMessage() 245void 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
254void IncomingDialog::showEvent(QListViewItem *item) 255void 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
265bool IncomingDialog::incomeRefresh(ScheduleItemIn *item) 266bool 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
288bool IncomingDialog::incomeCounter(ScheduleItemIn *item) 289bool 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
351bool IncomingDialog::incomeDeclineCounter(ScheduleItemIn *item) 352bool 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
367bool IncomingDialog::incomeAdd(ScheduleItemIn *item) 368bool 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
387bool IncomingDialog::incomeDefault(ScheduleItemIn *item) 388bool 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
402bool IncomingDialog::incomeRequest(ScheduleItemIn *item) 403bool 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
433bool IncomingDialog::automaticAction(ScheduleItemIn *item) 434bool 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
498bool IncomingDialog::checkOrganizerInAddressbook(QString organizer) 499bool 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
510bool IncomingDialog::checkAttendeesInAddressbook(IncidenceBase *inc) 511bool 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
4OBJECTS_DIR = obj/$(PLATFORM) 4OBJECTS_DIR = obj/$(PLATFORM)
5MOC_DIR = moc/$(PLATFORM) 5MOC_DIR = moc/$(PLATFORM)
6DESTDIR=$(QPEDIR)/bin 6DESTDIR=$(QPEDIR)/bin
7 7
8INCLUDEPATH += $(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 8INCLUDEPATH += $(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
10DEFINES += KORG_NODND KORG_NOPLUGINS KORG_NOARCHIVE KORG_NOMAIL 10DEFINES += KORG_NODND KORG_NOPLUGINS KORG_NOARCHIVE KORG_NOMAIL
11DEFINES += KORG_NOPRINTER KORG_NODCOP KORG_NOKALARMD KORG_NORESOURCEVIEW KORG_NOSPLITTER 11DEFINES += KORG_NOPRINTER KORG_NODCOP KORG_NOKALARMD KORG_NORESOURCEVIEW KORG_NOSPLITTER
12DEFINES += KORG_NOLVALTERNATION 12DEFINES += KORG_NOLVALTERNATION
13#KORG_NOKABC 13#KORG_NOKABC
14LIBS += -lmicrokdepim 14LIBS += -lmicrokdepim
15LIBS += -lmicrokcal 15LIBS += -lmicrokcal
16LIBS += -lmicrokde 16LIBS += -lmicrokde
17LIBS += -lmicroqtcompat 17LIBS += -lmicroqtcompat
18LIBS += -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
24LIBS += $(GCC3EXTRALIB1)
25LIBS += $(GCC3EXTRALIB2)
24 26
25 27
26LIBS += -lqpe 28LIBS += -lqpe
27LIBS += -ljpeg 29LIBS += -ljpeg
28LIBS += $(QTOPIALIB) 30LIBS += $(QTOPIALIB)
29LIBS += -L$(QPEDIR)/lib 31LIBS += -L$(QPEDIR)/lib
30 32
31INTERFACES = kofilterview_base.ui 33INTERFACES = kofilterview_base.ui
32#filteredit_base.ui 34#filteredit_base.ui
33 35
34HEADERS = \ 36HEADERS = \
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
98SOURCES = \ 100SOURCES = \
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
36PublishDialog::PublishDialog(QWidget* parent, const char* name, 37PublishDialog::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
47PublishDialog::~PublishDialog() 48PublishDialog::~PublishDialog()
48{ 49{
49} 50}
50 51
51void PublishDialog::addAttendee(Attendee *attendee) 52void 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
61QString PublishDialog::addresses() 62QString 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
78void PublishDialog::addItem() 79void 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
89void PublishDialog::removeItem() 90void 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
108void PublishDialog::openAddressbook() 109void 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
131void PublishDialog::updateItem() 132void 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
140void PublishDialog::updateInput() 141void 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}