author | zautrix <zautrix> | 2005-03-31 23:55:51 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2005-03-31 23:55:51 (UTC) |
commit | b76ad1e7e329051a47e28c9d132ce3fcd0b25c5c (patch) (unidiff) | |
tree | b0b3d0eb7a3d29981c183275aadeed0cbbef0007 | |
parent | c0fa26aa3b33c293853bdd7d028ddb0545e33c85 (diff) | |
download | kdepimpi-b76ad1e7e329051a47e28c9d132ce3fcd0b25c5c.zip kdepimpi-b76ad1e7e329051a47e28c9d132ce3fcd0b25c5c.tar.gz kdepimpi-b76ad1e7e329051a47e28c9d132ce3fcd0b25c5c.tar.bz2 |
fixes
-rw-r--r-- | bin/kdepim/korganizer/germantranslation.txt | 2 | ||||
-rw-r--r-- | bin/kdepim/pwmanager/pwmanagerFAQ.txt | 15 | ||||
-rw-r--r-- | kmicromail/libmailwrapper/genericwrapper.cpp | 7 | ||||
-rw-r--r-- | korganizer/koagenda.cpp | 5 | ||||
-rw-r--r-- | korganizer/koagenda.h | 2 | ||||
-rw-r--r-- | korganizer/koagendaview.cpp | 15 | ||||
-rw-r--r-- | korganizer/koagendaview.h | 1 | ||||
-rw-r--r-- | korganizer/komonthview.cpp | 7 | ||||
-rw-r--r-- | korganizer/kotodoview.cpp | 103 | ||||
-rw-r--r-- | korganizer/kotodoview.h | 5 | ||||
-rw-r--r-- | korganizer/koviewmanager.cpp | 4 |
11 files changed, 125 insertions, 41 deletions
diff --git a/bin/kdepim/korganizer/germantranslation.txt b/bin/kdepim/korganizer/germantranslation.txt index f8f8b96..fbab7dd 100644 --- a/bin/kdepim/korganizer/germantranslation.txt +++ b/bin/kdepim/korganizer/germantranslation.txt | |||
@@ -1072,257 +1072,257 @@ | |||
1072 | { "Outgoing addressbook filter:","Ausgehender Adressbuch Filter:" }, | 1072 | { "Outgoing addressbook filter:","Ausgehender Adressbuch Filter:" }, |
1073 | { "Write back (calendar) entries for time period only","Schreibe nur Kalender Einträge für Zeitspanne zurück" }, | 1073 | { "Write back (calendar) entries for time period only","Schreibe nur Kalender Einträge für Zeitspanne zurück" }, |
1074 | { "Time period","Zeitspanne" }, | 1074 | { "Time period","Zeitspanne" }, |
1075 | { "From ","Von " }, | 1075 | { "From ","Von " }, |
1076 | { " weeks in the past to "," Wochen in der Vergangenheit bis zu " }, | 1076 | { " weeks in the past to "," Wochen in der Vergangenheit bis zu " }, |
1077 | { " weeks in the future "," Wochen in der Zukunft " }, | 1077 | { " weeks in the future "," Wochen in der Zukunft " }, |
1078 | { "Profile kind specific settings","Profil Art abhängige Einstellungen" }, | 1078 | { "Profile kind specific settings","Profil Art abhängige Einstellungen" }, |
1079 | { "Local temp file:","Lokale temp Datei:" }, | 1079 | { "Local temp file:","Lokale temp Datei:" }, |
1080 | { "Multiple profiles with same name!\nPlease use unique profile names!","Mehrere Profile mit demselben Namen!\nBitte verschiedene Namen benutzen!" }, | 1080 | { "Multiple profiles with same name!\nPlease use unique profile names!","Mehrere Profile mit demselben Namen!\nBitte verschiedene Namen benutzen!" }, |
1081 | { "Aborted! Nothing synced!","Abgebrochen! Nichts wurde gesynct!" }, | 1081 | { "Aborted! Nothing synced!","Abgebrochen! Nichts wurde gesynct!" }, |
1082 | { "Language","Sprache" }, | 1082 | { "Language","Sprache" }, |
1083 | { "Time Format","Zeit Format" }, | 1083 | { "Time Format","Zeit Format" }, |
1084 | { "Time Zone","Zeit Zone" }, | 1084 | { "Time Zone","Zeit Zone" }, |
1085 | { "%1 groups subscribed","%1 Guppen abboniert" }, | 1085 | { "%1 groups subscribed","%1 Guppen abboniert" }, |
1086 | { "Your current storage dir is:\n%1\nYour mail is stored in:\n(storagedir)/apps/kopiemail/localmail","Aktuelles Speicherverzeichnis ist:\n%1\nIhre Mail wird gespeichert in:\n(speicherverz.)/apps/kopiemail/localmail" }, | 1086 | { "Your current storage dir is:\n%1\nYour mail is stored in:\n(storagedir)/apps/kopiemail/localmail","Aktuelles Speicherverzeichnis ist:\n%1\nIhre Mail wird gespeichert in:\n(speicherverz.)/apps/kopiemail/localmail" }, |
1087 | { "<b>New data storage dir:</b>","<b>Neues Datenspeicherverzeichnis:</b>" }, | 1087 | { "<b>New data storage dir:</b>","<b>Neues Datenspeicherverzeichnis:</b>" }, |
1088 | { "New dirs are created automatically","Neue Verzeichnisse werden aut. erstellt" }, | 1088 | { "New dirs are created automatically","Neue Verzeichnisse werden aut. erstellt" }, |
1089 | { "Save settings","Speichere Einstellungen" }, | 1089 | { "Save settings","Speichere Einstellungen" }, |
1090 | { "Save standard","Speichere Standard" }, | 1090 | { "Save standard","Speichere Standard" }, |
1091 | { "<b>New settings are used\nafter a restart</b>","<b>Neue Einstellungen werden nach\neinem Neustart genutzt</b>" }, | 1091 | { "<b>New settings are used\nafter a restart</b>","<b>Neue Einstellungen werden nach\neinem Neustart genutzt</b>" }, |
1092 | { "Settings are stored in\n%1","Einstellungen werden gespeichert in:\n%1" }, | 1092 | { "Settings are stored in\n%1","Einstellungen werden gespeichert in:\n%1" }, |
1093 | { "Data storage path","Daten Speicherpfad" }, | 1093 | { "Data storage path","Daten Speicherpfad" }, |
1094 | { "Language","Sprache" }, | 1094 | { "Language","Sprache" }, |
1095 | { "Show time in agenda items","Zeige Zeit in Agenda Items" }, | 1095 | { "Show time in agenda items","Zeige Zeit in Agenda Items" }, |
1096 | { "Color for Sundays + category "Holiday"","Farbe für Sonntags + Kategorie "Feiertag"" }, | 1096 | { "Color for Sundays + category "Holiday"","Farbe für Sonntags + Kategorie "Feiertag"" }, |
1097 | { "Show events, that are done in \nWhat's Next view","Zeige abgelaufene Termine in\nWhat's Next Ansicht" }, | 1097 | { "Show events, that are done in \nWhat's Next view","Zeige abgelaufene Termine in\nWhat's Next Ansicht" }, |
1098 | { "Hide not running Todos in To-do view","Verstecke nicht laufende Todos" }, | 1098 | { "Hide not running Todos in To-do view","Verstecke nicht laufende Todos" }, |
1099 | { "+01:00 Europe/Oslo(CET)","+01:00 Europe/Oslo(CET)" }, | 1099 | { "+01:00 Europe/Oslo(CET)","+01:00 Europe/Oslo(CET)" }, |
1100 | { "KO/Pi","KO/Pi" }, | 1100 | { "KO/Pi","KO/Pi" }, |
1101 | { "There is nothing to undo!","Es gibt nichts zum\nRückgängigmachen!" }, | 1101 | { "There is nothing to undo!","Es gibt nichts zum\nRückgängigmachen!" }, |
1102 | { "Recreating edit dialog. Please wait...","Recreating edit dialog. Please wait..." }, | 1102 | { "Recreating edit dialog. Please wait...","Recreating edit dialog. Please wait..." }, |
1103 | { "Sound.Al.: ","Sound.Al.: " }, | 1103 | { "Sound.Al.: ","Sound.Al.: " }, |
1104 | { "From: %1 To: %2 %3","Von: %1 Bis: %2 %3" }, | 1104 | { "From: %1 To: %2 %3","Von: %1 Bis: %2 %3" }, |
1105 | { "Restore","Wiederherstellen" }, | 1105 | { "Restore","Wiederherstellen" }, |
1106 | { "\nAre you sure you want\nto restore this?","\nMöchten Sie das wirklicht\nwiederherstellen?" }, | 1106 | { "\nAre you sure you want\nto restore this?","\nMöchten Sie das wirklicht\nwiederherstellen?" }, |
1107 | { "% completed","% erledigt" }, | 1107 | { "% completed","% erledigt" }, |
1108 | { "%d item(s) found.","%d Item(s) gefunden." }, | 1108 | { "%d item(s) found.","%d Item(s) gefunden." }, |
1109 | { "Set complete","Setze auf erledigt" }, | 1109 | { "Set complete","Setze auf erledigt" }, |
1110 | { "(cancelled)","(gecancelt)" }, | 1110 | { "(cancelled)","(gecancelt)" }, |
1111 | { "Click on the week number to\nshow week in agenda view","Klicke auf die Wochennummer\num die Woche in der Agenda anzuzeigen" }, | 1111 | { "Click on the week number to\nshow week in agenda view","Klicke auf die Wochennummer\num die Woche in der Agenda anzuzeigen" }, |
1112 | { " Local time "," Locale Zeit " }, | 1112 | { " Local time "," Locale Zeit " }, |
1113 | { "Form2","Form2" }, | 1113 | { "Form2","Form2" }, |
1114 | { "Filter enabled","Filter angeschaltet" }, | 1114 | { "Filter enabled","Filter angeschaltet" }, |
1115 | { "Edit Filters","Ändere Filter" }, | 1115 | { "Edit Filters","Ändere Filter" }, |
1116 | { "Print What's Next View...","Drucke What's Next Ansicht..." }, | 1116 | { "Print What's Next View...","Drucke What's Next Ansicht..." }, |
1117 | { "Agenda","Agenda" }, | 1117 | { "Agenda","Agenda" }, |
1118 | { " ("," (" }, | 1118 | { " ("," (" }, |
1119 | { "<p><b>Due on:</b> %1</p>","<p><b>Fällig am:</b> %1</p>" }, | 1119 | { "<p><b>Due on:</b> %1</p>","<p><b>Fällig am:</b> %1</p>" }, |
1120 | { "Print","Print" }, | 1120 | { "Print","Print" }, |
1121 | { "&Setup Printer...","Drucker &Setup..." }, | 1121 | { "&Setup Printer...","Drucker &Setup..." }, |
1122 | { "View Type","Zeige Typ" }, | 1122 | { "View Type","Zeige Typ" }, |
1123 | { "Page &orientation:","Seiten Ausrichtung:" }, | 1123 | { "Page &orientation:","Seiten Ausrichtung:" }, |
1124 | { "Use Default of Selected Style","Default des selektierten Stils" }, | 1124 | { "Use Default of Selected Style","Default des selektierten Stils" }, |
1125 | { "Use Default Setting of Printer","Default Einstellung des Druckers" }, | 1125 | { "Use Default Setting of Printer","Default Einstellung des Druckers" }, |
1126 | { "Portrait","Portrait" }, | 1126 | { "Portrait","Portrait" }, |
1127 | { "Landscape","Landschaft" }, | 1127 | { "Landscape","Landschaft" }, |
1128 | { "Print day","Drucke Tag" }, | 1128 | { "Print day","Drucke Tag" }, |
1129 | { "CalPrintDay_Base","CalPrintDay_Base" }, | 1129 | { "CalPrintDay_Base","CalPrintDay_Base" }, |
1130 | { "Date && Time Range","Datum && Zeitspanne" }, | 1130 | { "Date && Time Range","Datum && Zeitspanne" }, |
1131 | { "&End date:","&Enddatum:" }, | 1131 | { "&End date:","&Enddatum:" }, |
1132 | { "&Start date:","&Startdatum:" }, | 1132 | { "&Start date:","&Startdatum:" }, |
1133 | { "Start &time:","Startzeit:" }, | 1133 | { "Start &time:","Startzeit:" }, |
1134 | { "End ti&me:","Endzeit:" }, | 1134 | { "End ti&me:","Endzeit:" }, |
1135 | { "E&xtend time range to include all events","Erweitere Zeitspanne um alle Termine einzuschliessen" }, | 1135 | { "E&xtend time range to include all events","Erweitere Zeitspanne um alle Termine einzuschliessen" }, |
1136 | { "Include to&dos that are due on the printed day(s)","Inclusive To&dos, die an den selektierten Tagen fällig sind" }, | 1136 | { "Include to&dos that are due on the printed day(s)","Inclusive To&dos, die an den selektierten Tagen fällig sind" }, |
1137 | { "Alt+D","Alt+D" }, | 1137 | { "Alt+D","Alt+D" }, |
1138 | { "&Use colors","Nutze Farben" }, | 1138 | { "&Use colors","Nutze Farben" }, |
1139 | { "Alt+U","Alt+U" }, | 1139 | { "Alt+U","Alt+U" }, |
1140 | { "Print week","Drucke Woche" }, | 1140 | { "Print week","Drucke Woche" }, |
1141 | { "CalPrintWeek_Base","CalPrintWeek_Base" }, | 1141 | { "CalPrintWeek_Base","CalPrintWeek_Base" }, |
1142 | { "Use &colors","Nutze Farben" }, | 1142 | { "Use &colors","Nutze Farben" }, |
1143 | { "Type of View","Typ der Ansicht" }, | 1143 | { "Type of View","Typ der Ansicht" }, |
1144 | { "Print as &Filofax page","Drucke als &Filofax Seite" }, | 1144 | { "Print as &Filofax page","Drucke als &Filofax Seite" }, |
1145 | { "Alt+F","Alt+F" }, | 1145 | { "Alt+F","Alt+F" }, |
1146 | { "Print as &timetable view:","Drucke als Zeittabelle:" }, | 1146 | { "Print as &timetable view:","Drucke als Zeittabelle:" }, |
1147 | { "Alt+T","Alt+T" }, | 1147 | { "Alt+T","Alt+T" }, |
1148 | { "Print as split week view","Drucke als gesplittete Wochenansicht" }, | 1148 | { "Print as split week view","Drucke als gesplittete Wochenansicht" }, |
1149 | { "Print month","Drucke Monat" }, | 1149 | { "Print month","Drucke Monat" }, |
1150 | { "CalPrintMonth_Base","CalPrintMonth_Base" }, | 1150 | { "CalPrintMonth_Base","CalPrintMonth_Base" }, |
1151 | { "&Start month:","&Startmonat:" }, | 1151 | { "&Start month:","&Startmonat:" }, |
1152 | { "&End month:","&Endmonat:" }, | 1152 | { "&End month:","&Endmonat:" }, |
1153 | { "Print week &numbers","Drucke Wochen Nummer(n)" }, | 1153 | { "Print week &numbers","Drucke Wochen Nummer(n)" }, |
1154 | { "Print todos","Drucke Todos" }, | 1154 | { "Print todos","Drucke Todos" }, |
1155 | { "CalPrintTodoConfig_Base","CalPrintTodoConfig_Base" }, | 1155 | { "CalPrintTodoConfig_Base","CalPrintTodoConfig_Base" }, |
1156 | { "Include &description of the item","Inclusive Itembeschreibung" }, | 1156 | { "Include &description of the item","Inclusive Itembeschreibung" }, |
1157 | { "Include d&ue date of the item","Inclusive Fälligkeitsdatum des Items" }, | 1157 | { "Include d&ue date of the item","Inclusive Fälligkeitsdatum des Items" }, |
1158 | { "Include &priority of the item","Inclusive Priorität des Items" }, | 1158 | { "Include &priority of the item","Inclusive Priorität des Items" }, |
1159 | { "Items to Print","Zu druckende Items" }, | 1159 | { "Items to Print","Zu druckende Items" }, |
1160 | { "&From:","Von:" }, | 1160 | { "&From:","Von:" }, |
1161 | { "&To:","Bis:" }, | 1161 | { "&To:","Bis:" }, |
1162 | { "Print &all todo items","Drucke alle Todo Items" }, | 1162 | { "Print &all todo items","Drucke alle Todo Items" }, |
1163 | { "Print only &uncompleted items","Drucke nur nicht erledigte Todos" }, | 1163 | { "Print only &uncompleted items","Drucke nur nicht erledigte Todos" }, |
1164 | { "Only items due in the &range:","Nur Items in dem Zeitraum:" }, | 1164 | { "Only items due in the &range:","Nur Items in dem Zeitraum:" }, |
1165 | { "Todo List","Todo Liste" }, | 1165 | { "Todo List","Todo Liste" }, |
1166 | { "&Title:","&Titel:" }, | 1166 | { "&Title:","&Titel:" }, |
1167 | { "Co&nnect subtodos with its parent","Verbinde Unter-Todos mit ihren Ober-Todos" }, | 1167 | { "Co&nnect subtodos with its parent","Verbinde Unter-Todos mit ihren Ober-Todos" }, |
1168 | { "Todo list","Todo Liste" }, | 1168 | { "Todo list","Todo Liste" }, |
1169 | { "&Print...","Drucke..." }, | 1169 | { "&Print...","Drucke..." }, |
1170 | { "<qt>Printing on printer <b>%1</b></qt>","<qt>Drucke auf Drucker <b>%1</b></qt>" }, | 1170 | { "<qt>Printing on printer <b>%1</b></qt>","<qt>Drucke auf Drucker <b>%1</b></qt>" }, |
1171 | { "[Unconfigured]","[Unkonfiguriert]" }, | 1171 | { "[Unconfigured]","[Unkonfiguriert]" }, |
1172 | { "OK","OK" }, | 1172 | { "OK","OK" }, |
1173 | { "FilterEditor","FilterEditor" }, | 1173 | { "FilterEditor","FilterEditor" }, |
1174 | { "Include","Inclusive" }, | 1174 | { "Include","Inclusive" }, |
1175 | { "Exclude","Exclusive" }, | 1175 | { "Exclude","Exclusive" }, |
1176 | { "Edit Selection...","Editiere Auswahl" }, | 1176 | { "Edit Selection...","Editiere Auswahl" }, |
1177 | { "recurring events","wiederholende Termine" }, | 1177 | { "recurring events","wiederholende Termine" }, |
1178 | { "recurr. events","wiederh.Termine" }, | 1178 | { "recurr. events","wiederh.Termine" }, |
1179 | { "completed to-dos","erledigte Todos" }, | 1179 | { "completed to-dos","erledigte Todos" }, |
1180 | { "events","Termine" }, | 1180 | { "events","Termine" }, |
1181 | { "todos","Todos" }, | 1181 | { "todos","Todos" }, |
1182 | { "journals","Journale" }, | 1182 | { "journals","Journale" }, |
1183 | { "public","öffentl." }, | 1183 | { "public","öffentl." }, |
1184 | { "private","privat" }, | 1184 | { "private","privat" }, |
1185 | { "confidential","vertraul." }, | 1185 | { "confidential","vertraul." }, |
1186 | { "\nhas sub-todos.\nAll completed sub-todos\nwill be deleted as well!","\nhat Unter-Todos.\nAlle erledigten Unter-Todos\nwerden auch gelöscht!" }, | 1186 | { "\nhas sub-todos.\nAll completed sub-todos\nwill be deleted as well!","\nhat Unter-Todos.\nAlle erledigten Unter-Todos\nwerden auch gelöscht!" }, |
1187 | { "Yesterday","Gestern" }, | 1187 | { "Yesterday","Gestern" }, |
1188 | { "Day after tomorrow","Übermorgen" }, | 1188 | { "Day after tomorrow","Übermorgen" }, |
1189 | { "Tomorrow","Morgen" }, | 1189 | { "Tomorrow","Morgen" }, |
1190 | { "Day before yesterday","Vorgestern" }, | 1190 | { "Day before yesterday","Vorgestern" }, |
1191 | { "Size %1","Größe %1" }, | 1191 | { "Size %1","Größe %1" }, |
1192 | { "New Agendasize: %1","Neue Agendagröße: %1" }, | 1192 | { "New Agendasize: %1","Neue Agendagröße: %1" }, |
1193 | { " (%1 y.)"," (%1 J.)" }, | 1193 | { " (%1 y.)"," (%1 J.)" }, |
1194 | { "Allday:","Ganztägig:" }, | 1194 | { "Allday:","Ganztägig:" }, |
1195 | { "compl.todos","erled.Todos" }, | 1195 | { "compl.todos","erled.Todos" }, |
1196 | { "Day view","Tagesansicht" }, | 1196 | { "Day view","Tagesansicht" }, |
1197 | { "Next days","Nächste Tage" }, | 1197 | { "Next days","Nächste Tage" }, |
1198 | { "Next week","Nächste Woche" }, | 1198 | { "Next week","Nächste Woche" }, |
1199 | { "Next two weeks","Nächste zwei Wochen" }, | 1199 | { "Next two weeks","Nächste zwei Wochen" }, |
1200 | { "Next month","Nächster Monat" }, | 1200 | { "This month","Dieser Monat" }, |
1201 | { "Journal view","Journal" }, | 1201 | { "Journal view","Journal" }, |
1202 | { "Display all opened","Zeige alle geöffnet" }, | 1202 | { "Display all opened","Zeige alle geöffnet" }, |
1203 | { "Display all closed","Zeige alle geschlossen" }, | 1203 | { "Display all closed","Zeige alle geschlossen" }, |
1204 | { "Display all flat","Zeige alle flach" }, | 1204 | { "Display all flat","Zeige alle flach" }, |
1205 | { "<p><i>Completed on %1</i></p>","<p><i>Erledigt am %1</i></p>" }, | 1205 | { "<p><i>Completed on %1</i></p>","<p><i>Erledigt am %1</i></p>" }, |
1206 | { "Default todo done color:","Standard Todo erledigt Farbe" }, | 1206 | { "Default todo done color:","Standard Todo erledigt Farbe" }, |
1207 | { "Select week %1-%2","Wähle Woche %1-%2" }, | 1207 | { "Select week %1-%2","Wähle Woche %1-%2" }, |
1208 | { "Select Week","Wähle Woche" }, | 1208 | { "Select Week","Wähle Woche" }, |
1209 | { "Set alarm for selected...","Setze Alarm für Selekt..." }, | 1209 | { "Set alarm for selected...","Setze Alarm für Selekt..." }, |
1210 | { "Set Alarm!","Setze Alarm!" }, | 1210 | { "Set Alarm!","Setze Alarm!" }, |
1211 | { "Canged alarm for %1 items","Alarm für %1 Items geändert" }, | 1211 | { "Canged alarm for %1 items","Alarm für %1 Items geändert" }, |
1212 | { " and "," und " }, | 1212 | { " and "," und " }, |
1213 | { "<IMG src="%1"> only )","nur <IMG src="%1"> )" }, | 1213 | { "<IMG src="%1"> only )","nur <IMG src="%1"> )" }, |
1214 | { "Mail to selected","Mail an Ausgewählte" }, | 1214 | { "Mail to selected","Mail an Ausgewählte" }, |
1215 | { "Mail to all","Mail an Alle" }, | 1215 | { "Mail to all","Mail an Alle" }, |
1216 | { "Week view mode uses bigger font","Wochenansicht Modus nutzt größeren Font" }, | 1216 | { "Week view mode uses bigger font","Wochenansicht Modus nutzt größeren Font" }, |
1217 | { "Set reminder ON with offset to:","Alarm AN mit Offset auf:" }, | 1217 | { "Set reminder ON with offset to:","Alarm AN mit Offset auf:" }, |
1218 | { " on"," am" }, | 1218 | { " on"," am" }, |
1219 | { " completed on "," erledigt am " }, | 1219 | { " completed on "," erledigt am " }, |
1220 | { "Save as Event template","Speichere als Vorlage" }, | 1220 | { "Save as Event template","Speichere als Vorlage" }, |
1221 | { "Load Event template","Lade Termin Vorlage" }, | 1221 | { "Load Event template","Lade Termin Vorlage" }, |
1222 | { "Save as Journal template","Speichere als Journal Vorlage" }, | 1222 | { "Save as Journal template","Speichere als Journal Vorlage" }, |
1223 | { "Insert Journal template","Füge Journal Vorlage ein" }, | 1223 | { "Insert Journal template","Füge Journal Vorlage ein" }, |
1224 | { "Sub todos:<br>","Unter Todos:<br>" }, | 1224 | { "Sub todos:<br>","Unter Todos:<br>" }, |
1225 | { "Parent todo:<br>","Über Todo:<br>" }, | 1225 | { "Parent todo:<br>","Über Todo:<br>" }, |
1226 | { "Set current as color category","Setze Gewählte als Farbkategorie" }, | 1226 | { "Set current as color category","Setze Gewählte als Farbkategorie" }, |
1227 | { " completed"," erledigt" }, | 1227 | { " completed"," erledigt" }, |
1228 | { "(c)2004 Lutz Rogowski (rogowski@kde.org)\nKO/Pi is based on KOrganizer\n(c)2002,2003 Cornelius Schumacher\n(schumacher@kde.org) and the KDE team.\nKOrganizer/Pi is licensed under the GPL.\nKO/Pi can be compiled for\nLinux, Zaurus-PDA and Windows\nwww.pi-sync.info --- www.korganizer.org\nSpecial thanks to Michael and Ben\nfor intensive testing!","(c)2004 Lutz Rogowski (rogowski@kde.org)\nKO/Pi basiert auf KOrganizer\n(c)2002,2003 Cornelius Schumacher\n(schumacher@kde.org) und das KDE Team.\nKOrganizer/Pi ist lizensiert unter der GPL.\nKO/Pi kann kompiliert werden für\nLinux, Zaurus-PDA und Windows\nwww.pi-sync.info --- www.korganizer.org\nBesonderen Dank an Michael und Ben\nfür intensives Testen!" }, | 1228 | { "(c)2004 Lutz Rogowski (rogowski@kde.org)\nKO/Pi is based on KOrganizer\n(c)2002,2003 Cornelius Schumacher\n(schumacher@kde.org) and the KDE team.\nKOrganizer/Pi is licensed under the GPL.\nKO/Pi can be compiled for\nLinux, Zaurus-PDA and Windows\nwww.pi-sync.info --- www.korganizer.org\nSpecial thanks to Michael and Ben\nfor intensive testing!","(c)2004 Lutz Rogowski (rogowski@kde.org)\nKO/Pi basiert auf KOrganizer\n(c)2002,2003 Cornelius Schumacher\n(schumacher@kde.org) und das KDE Team.\nKOrganizer/Pi ist lizensiert unter der GPL.\nKO/Pi kann kompiliert werden für\nLinux, Zaurus-PDA und Windows\nwww.pi-sync.info --- www.korganizer.org\nBesonderen Dank an Michael und Ben\nfür intensives Testen!" }, |
1229 | { "Syncing aborted. Nothing synced.","Syncing abgebrochen.Nichts wurde gesynct." }, | 1229 | { "Syncing aborted. Nothing synced.","Syncing abgebrochen.Nichts wurde gesynct." }, |
1230 | { "Connected! Sending request for remote file ...","Verbunden! Sende Daten Anfrage..." }, | 1230 | { "Connected! Sending request for remote file ...","Verbunden! Sende Daten Anfrage..." }, |
1231 | { "Trying to connect to remote...","Versuche mit Gegenstelle zu verbinden..." }, | 1231 | { "Trying to connect to remote...","Versuche mit Gegenstelle zu verbinden..." }, |
1232 | { "Connection to remote\nhost timed out!\nDid you forgot to enable\nsyncing on remote host?","Verbindungsversuch wegen\nZeitüberschreitung gescheitert!\nWurde vergessen Pi-Sync auf\nder Gegenstelle anzuschalten?" }, | 1232 | { "Connection to remote\nhost timed out!\nDid you forgot to enable\nsyncing on remote host?","Verbindungsversuch wegen\nZeitüberschreitung gescheitert!\nWurde vergessen Pi-Sync auf\nder Gegenstelle anzuschalten?" }, |
1233 | { "ERROR: Receiving remote file failed.","FEHLER: Empfang der entfernten Daten fehlgeschlagen." }, | 1233 | { "ERROR: Receiving remote file failed.","FEHLER: Empfang der entfernten Daten fehlgeschlagen." }, |
1234 | { "Error","Fehler" }, | 1234 | { "Error","Fehler" }, |
1235 | { ""You entered an invalid date!\n Date changed to current date.","Ungültiges Datum eingegeben.\nSetze heutiges Datum." }, | 1235 | { ""You entered an invalid date!\n Date changed to current date.","Ungültiges Datum eingegeben.\nSetze heutiges Datum." }, |
1236 | { "You entered an invalid date!\n Will use current date instead.","Ungültiges Datum eingegeben.\nSetze stattdessen heutiges Datum." }, | 1236 | { "You entered an invalid date!\n Will use current date instead.","Ungültiges Datum eingegeben.\nSetze stattdessen heutiges Datum." }, |
1237 | { "Warning","Warnung" }, | 1237 | { "Warning","Warnung" }, |
1238 | { "Select week number","Wähle Wochen Nummer" }, | 1238 | { "Select week number","Wähle Wochen Nummer" }, |
1239 | { "Februar","Februar" }, | 1239 | { "Februar","Februar" }, |
1240 | { "Click on the week number to\nshow week zoomed","Klicke auf die Wochennummer\num die Woche groß zu zeigen" }, | 1240 | { "Click on the week number to\nshow week zoomed","Klicke auf die Wochennummer\num die Woche groß zu zeigen" }, |
1241 | { "W","W" }, | 1241 | { "W","W" }, |
1242 | { "Click on this to\nselect week number","Klicke hierauf um\ndie Woche auszuwählen" }, | 1242 | { "Click on this to\nselect week number","Klicke hierauf um\ndie Woche auszuwählen" }, |
1243 | { "T: %1","T: %1" }, | 1243 | { "T: %1","T: %1" }, |
1244 | { "Start: ","Start: " }, | 1244 | { "Start: ","Start: " }, |
1245 | { "Pi-Sync options for device: ","Pi-Sync Einstellungen für Gerät: " }, | 1245 | { "Pi-Sync options for device: ","Pi-Sync Einstellungen für Gerät: " }, |
1246 | { "Password for remote access:","Passwort für fernen Zugriff:" }, | 1246 | { "Password for remote access:","Passwort für fernen Zugriff:" }, |
1247 | { "Remote IP address:","Ferne IP Adresse:" }, | 1247 | { "Remote IP address:","Ferne IP Adresse:" }, |
1248 | { "Remote port number:","Ferne Port Nummer:" }, | 1248 | { "Remote port number:","Ferne Port Nummer:" }, |
1249 | { "Remote file saved to temp file.","Ferne Daten in temp Datei gespeichert." }, | 1249 | { "Remote file saved to temp file.","Ferne Daten in temp Datei gespeichert." }, |
1250 | { "Remote from: ","Fern von: " }, | 1250 | { "Remote from: ","Fern von: " }, |
1251 | { "Local from: ","Lokal von: " }, | 1251 | { "Local from: ","Lokal von: " }, |
1252 | { "Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n","Synchronisationsübersicht:\n\n %d lokal hinzugefügt\n %d fern hinzugefügt\n %d lokal geändert\n %d fern geändert\n %d lokal gelöscht\n %d fern gelöscht\n %d eingehende ausgefiltert\n %d ausgehende ausgefiltert\n" }, | 1252 | { "Synchronization summary:\n\n %d items added to local\n %d items added to remote\n %d items updated on local\n %d items updated on remote\n %d items deleted on local\n %d items deleted on remote\n %d incoming filtered out\n %d outgoing filtered out\n","Synchronisationsübersicht:\n\n %d lokal hinzugefügt\n %d fern hinzugefügt\n %d lokal geändert\n %d fern geändert\n %d lokal gelöscht\n %d fern gelöscht\n %d eingehende ausgefiltert\n %d ausgehende ausgefiltert\n" }, |
1253 | { "Local calendar changed!\n","Lokaler Kalender geändert!\n" }, | 1253 | { "Local calendar changed!\n","Lokaler Kalender geändert!\n" }, |
1254 | { "Write back","Schreibe zurück" }, | 1254 | { "Write back","Schreibe zurück" }, |
1255 | { "KO/Pi Synchronization","KO/Pi Synchronisation" }, | 1255 | { "KO/Pi Synchronization","KO/Pi Synchronisation" }, |
1256 | { "Pi-Sync succesful!","Pi-Sync erfolgreich!" }, | 1256 | { "Pi-Sync succesful!","Pi-Sync erfolgreich!" }, |
1257 | { "Received sync request","Sync Anfrage erhalten" }, | 1257 | { "Received sync request","Sync Anfrage erhalten" }, |
1258 | { "Synchronizing from remote ...\n\nDo not use this application!\n\nIf syncing fails\nyou can close this dialog.","Ferne Synchronisation ...\n\nBenutze diese Anwendung nicht!\n\nWenn das Syncen fehlschlägt kann\ndieser Dialog geschlossen werden." }, | 1258 | { "Synchronizing from remote ...\n\nDo not use this application!\n\nIf syncing fails\nyou can close this dialog.","Ferne Synchronisation ...\n\nBenutze diese Anwendung nicht!\n\nWenn das Syncen fehlschlägt kann\ndieser Dialog geschlossen werden." }, |
1259 | { "Saving Data to temp file ...","Speichere Daten in temp Datei..." }, | 1259 | { "Saving Data to temp file ...","Speichere Daten in temp Datei..." }, |
1260 | { "Data saved to temp file!","Daten in temp Datei gespeichert!" }, | 1260 | { "Data saved to temp file!","Daten in temp Datei gespeichert!" }, |
1261 | { "Sending file...","Sende Datei..." }, | 1261 | { "Sending file...","Sende Datei..." }, |
1262 | { "Waiting for synced file...","Warte auf gesyncte Daten..." }, | 1262 | { "Waiting for synced file...","Warte auf gesyncte Daten..." }, |
1263 | { "Receiving synced file...","Gesyncte Daten erhalten..." }, | 1263 | { "Receiving synced file...","Gesyncte Daten erhalten..." }, |
1264 | { "Received %1 bytes","%1 Bytes erhalten" }, | 1264 | { "Received %1 bytes","%1 Bytes erhalten" }, |
1265 | { "Writing file to disk...","Speichere Datei..." }, | 1265 | { "Writing file to disk...","Speichere Datei..." }, |
1266 | { "Pi-Sync successful!","Pi-Sync erfolgreich!" }, | 1266 | { "Pi-Sync successful!","Pi-Sync erfolgreich!" }, |
1267 | { "Clock skew of\nsyncing devices\nis %1 seconds!","Uhrzeitunterschied der\nsyncenden Geräte\nist %1 Sekunden!" }, | 1267 | { "Clock skew of\nsyncing devices\nis %1 seconds!","Uhrzeitunterschied der\nsyncenden Geräte\nist %1 Sekunden!" }, |
1268 | { "Synchronize!","Synchronisiere!" }, | 1268 | { "Synchronize!","Synchronisiere!" }, |
1269 | { "High clock skew!","Großer Uhrzeitunterschied!" }, | 1269 | { "High clock skew!","Großer Uhrzeitunterschied!" }, |
1270 | { "ADJUST\nYOUR\nCLOCKS!","JUSTIERE\nDIE\nUHREN!" }, | 1270 | { "ADJUST\nYOUR\nCLOCKS!","JUSTIERE\nDIE\nUHREN!" }, |
1271 | { "The clocks of the syncing\ndevices have a difference\nof more than 5 minutes.\nPlease adjust your clocks.\nYou may get wrong syncing results!\nPlease confirm synchronization!","Die Uhren der syncenden Geräte\nhaben einen Unterschied von\nmehr als 5 Minuten. Bitte die\nUhrzeiten anpassen. Sie können\nfalsche Sync-Resultate erhalten!\nBitte das Syncen bestätigen!" }, | 1271 | { "The clocks of the syncing\ndevices have a difference\nof more than 5 minutes.\nPlease adjust your clocks.\nYou may get wrong syncing results!\nPlease confirm synchronization!","Die Uhren der syncenden Geräte\nhaben einen Unterschied von\nmehr als 5 Minuten. Bitte die\nUhrzeiten anpassen. Sie können\nfalsche Sync-Resultate erhalten!\nBitte das Syncen bestätigen!" }, |
1272 | { "This is a %1 recurring todo.","Das ist eine %1 wiederholende Aufgabe." }, | 1272 | { "This is a %1 recurring todo.","Das ist eine %1 wiederholende Aufgabe." }, |
1273 | { "<p><b>Start on:</b> %1</p>","<p><b>Start am:</b> %1</p>" }, | 1273 | { "<p><b>Start on:</b> %1</p>","<p><b>Start am:</b> %1</p>" }, |
1274 | { "List week view","Listenwochenansicht" }, | 1274 | { "List week view","Listenwochenansicht" }, |
1275 | { "List week","Listenwochenansicht" }, | 1275 | { "List week","Listenwochenansicht" }, |
1276 | { "Next Week","Nächste Woche" }, | 1276 | { "Next Week","Nächste Woche" }, |
1277 | { "Previous Week","Vorherige Woche" }, | 1277 | { "Previous Week","Vorherige Woche" }, |
1278 | { "No items were found matching\nyour search expression.\nUse the wildcard characters\n'*' and '?' where needed.","Keine Einträge gefunden die\ndem Suchausdruck entsprechen.\nBenutze Platzhalter Zeichen\n'*' und '?' wo benötigt." }, | 1278 | { "No items were found matching\nyour search expression.\nUse the wildcard characters\n'*' and '?' where needed.","Keine Einträge gefunden die\ndem Suchausdruck entsprechen.\nBenutze Platzhalter Zeichen\n'*' und '?' wo benötigt." }, |
1279 | { "Show in todo/event viewer:","Zeige in Termin/Todo Anzeige:" }, | 1279 | { "Show in todo/event viewer:","Zeige in Termin/Todo Anzeige:" }, |
1280 | { "Details","Details" }, | 1280 | { "Details","Details" }, |
1281 | { "Created time","Erstellt Zeit" }, | 1281 | { "Created time","Erstellt Zeit" }, |
1282 | { "Last modified time","Geändert Zeit" }, | 1282 | { "Last modified time","Geändert Zeit" }, |
1283 | { "Show in What'sThis quick overview:","Zeige in What'sThis Schnellübersicht:" }, | 1283 | { "Show in What'sThis quick overview:","Zeige in What'sThis Schnellübersicht:" }, |
1284 | { "View Options","Anzeige Optionen" }, | 1284 | { "View Options","Anzeige Optionen" }, |
1285 | { "<b>Created: ","<b>Erstellt am: " }, | 1285 | { "<b>Created: ","<b>Erstellt am: " }, |
1286 | { "<b>Last modified: ","<b>Zuletzt geändert am: " }, | 1286 | { "<b>Last modified: ","<b>Zuletzt geändert am: " }, |
1287 | { "Journal: ","Journal: " }, | 1287 | { "Journal: ","Journal: " }, |
1288 | { "yearly","jährlich" }, | 1288 | { "yearly","jährlich" }, |
1289 | { "(%1) ","%1-" }, | 1289 | { "(%1) ","%1-" }, |
1290 | { "<p><b>K</b>: Week view in Month view syle</p>\n","<p><b>K</b>: Wochenansicht in Art der Monatsansicht</p>\n" }, | 1290 | { "<p><b>K</b>: Week view in Month view syle</p>\n","<p><b>K</b>: Wochenansicht in Art der Monatsansicht</p>\n" }, |
1291 | { "Enable tooltips displaying summary of ev.","Titel-Tooltips anzeigen" }, | 1291 | { "Enable tooltips displaying summary of ev.","Titel-Tooltips anzeigen" }, |
1292 | { "Enable scrollbars in month view cells","Scrollbar in Zellen anzeigen" }, | 1292 | { "Enable scrollbars in month view cells","Scrollbar in Zellen anzeigen" }, |
1293 | { "Summary/Loc.","Titel/Ort" }, | 1293 | { "Summary/Loc.","Titel/Ort" }, |
1294 | { "No items found. Use '*' and '?' where needed.","Nichts gefunden. Benutze '*' and '?' wo benötigt." }, | 1294 | { "No items found. Use '*' and '?' where needed.","Nichts gefunden. Benutze '*' and '?' wo benötigt." }, |
1295 | { "Week Number","Wochennummer" }, | 1295 | { "Week Number","Wochennummer" }, |
1296 | { "Import","Importiere" }, | 1296 | { "Import","Importiere" }, |
1297 | { "Export","Exportiere" }, | 1297 | { "Export","Exportiere" }, |
1298 | { "Beam","Beame" }, | 1298 | { "Beam","Beame" }, |
1299 | { "Export selected","Exportiere Selektierte" }, | 1299 | { "Export selected","Exportiere Selektierte" }, |
1300 | { "As iCal (ics) file...","Als iCal (ics) Datei..." }, | 1300 | { "As iCal (ics) file...","Als iCal (ics) Datei..." }, |
1301 | { "As vCal (vcs) file...","Als vCal (vcs) Datei..." }, | 1301 | { "As vCal (vcs) file...","Als vCal (vcs) Datei..." }, |
1302 | { "Journal/Details...","Journale/Details..." }, | 1302 | { "Journal/Details...","Journale/Details..." }, |
1303 | { "Agenda View","Agenda Ansicht" }, | 1303 | { "Agenda View","Agenda Ansicht" }, |
1304 | { "Show current time","Zeige aktuelle Zeit" }, | 1304 | { "Show current time","Zeige aktuelle Zeit" }, |
1305 | { "Edit new item","Bearbeite neuen Eintrag" }, | 1305 | { "Edit new item","Bearbeite neuen Eintrag" }, |
1306 | { "Please select at least one\nof the types to search for:\n\nEvents\nTodos\nJournals","Bitte wählen Sie mindestens\neinen dieser Typen\num darin zu suchen:\n\nTermine\nTodos\nJournale" }, | 1306 | { "Please select at least one\nof the types to search for:\n\nEvents\nTodos\nJournals","Bitte wählen Sie mindestens\neinen dieser Typen\num darin zu suchen:\n\nTermine\nTodos\nJournale" }, |
1307 | { "There is no next alarm.","Es gibt keinen nächsten Alarm." }, | 1307 | { "There is no next alarm.","Es gibt keinen nächsten Alarm." }, |
1308 | { "%1 %2 - %3 (next event/todo with alarm)","%1 %2 - %3 (nächster Termin/Todo mit Alarm)" }, | 1308 | { "%1 %2 - %3 (next event/todo with alarm)","%1 %2 - %3 (nächster Termin/Todo mit Alarm)" }, |
1309 | { "The next alarm is in:\n","Der nächste Alarm ist in:\n" }, | 1309 | { "The next alarm is in:\n","Der nächste Alarm ist in:\n" }, |
1310 | { "%1 days\n","%1 Tagen\n" }, | 1310 | { "%1 days\n","%1 Tagen\n" }, |
1311 | { "1 day\n","1 Tag\n" }, | 1311 | { "1 day\n","1 Tag\n" }, |
1312 | { "%1 hours\n","%1 Stunden\n" }, | 1312 | { "%1 hours\n","%1 Stunden\n" }, |
1313 | { "1 hour\n","1 Stunde\n" }, | 1313 | { "1 hour\n","1 Stunde\n" }, |
1314 | { "%1 minutes\n","%1 Minuten\n" }, | 1314 | { "%1 minutes\n","%1 Minuten\n" }, |
1315 | { "1 minute\n","1 Minute\n" }, | 1315 | { "1 minute\n","1 Minute\n" }, |
1316 | { "Only one toolbar","Nur eine Toolbar" }, | 1316 | { "Only one toolbar","Nur eine Toolbar" }, |
1317 | { "Print","Drucke" }, | 1317 | { "Print","Drucke" }, |
1318 | { "Print selected event / todo...","Drucke ausgewählten Termin / Todo..." }, | 1318 | { "Print selected event / todo...","Drucke ausgewählten Termin / Todo..." }, |
1319 | { "There is nothing selected!","Es ist nichts ausgewählt!" }, | 1319 | { "There is nothing selected!","Es ist nichts ausgewählt!" }, |
1320 | { "\n\nDo you really want to print this item?","\n\nMöchten Sie wirklich diesen Eintrag ausdrucken? " }, | 1320 | { "\n\nDo you really want to print this item?","\n\nMöchten Sie wirklich diesen Eintrag ausdrucken? " }, |
1321 | { "KO/Pi Print Confirmation","KO/Pi Druckbestätigung" }, | 1321 | { "KO/Pi Print Confirmation","KO/Pi Druckbestätigung" }, |
1322 | { "This prints the view as you see it.\n(With the complete content, of course.)\nYou may change the print layout by resizing the view.\nPrint unscaled may print several pages\ndepending on the amount of data.\nPrint scaled down will print all on one page.\nPrint scaled up/down will print all on one page,\nbut will scale up the text to page boundaries,\nif the text is smaller than the page.\nYou can select page geometry setup in the next dialog.\n","Dies druckt die Ansicht wie man sie sieht.\n(Mit dem kompletten Inhalt natürlich.)\nMan kann das Layout ändern durch ändern der Fenstergröße.\nDrucke unskaliert druckt ggf. mehrere Seiten\nabhängig von der Menge der Daten.\nDrucke runterskaliert um auf eine Seite zu passen\ndruckt alles auf eine Seite.\nDrucke hoch/runterskaliert um genau auf eine Seite zu passen\nvergrößert den Text gegebenenfalls.\nDas Seitenlayout kann im nächsten Dialog gewählt werden.\n" }, | 1322 | { "This prints the view as you see it.\n(With the complete content, of course.)\nYou may change the print layout by resizing the view.\nPrint unscaled may print several pages\ndepending on the amount of data.\nPrint scaled down will print all on one page.\nPrint scaled up/down will print all on one page,\nbut will scale up the text to page boundaries,\nif the text is smaller than the page.\nYou can select page geometry setup in the next dialog.\n","Dies druckt die Ansicht wie man sie sieht.\n(Mit dem kompletten Inhalt natürlich.)\nMan kann das Layout ändern durch ändern der Fenstergröße.\nDrucke unskaliert druckt ggf. mehrere Seiten\nabhängig von der Menge der Daten.\nDrucke runterskaliert um auf eine Seite zu passen\ndruckt alles auf eine Seite.\nDrucke hoch/runterskaliert um genau auf eine Seite zu passen\nvergrößert den Text gegebenenfalls.\nDas Seitenlayout kann im nächsten Dialog gewählt werden.\n" }, |
1323 | { "KO/Pi Printout","KO/Pi Ausdruck" }, | 1323 | { "KO/Pi Printout","KO/Pi Ausdruck" }, |
1324 | { "Print unscaled","Drucke unskaliert" }, | 1324 | { "Print unscaled","Drucke unskaliert" }, |
1325 | { "Print scaled down to fit one page","Drucke runterskaliert um auf eine Seite zu passen." }, | 1325 | { "Print scaled down to fit one page","Drucke runterskaliert um auf eine Seite zu passen." }, |
1326 | { "Print scaled up/down to fit one page","Drucke hoch/runterskaliert um genau auf eine Seite zu passen." }, | 1326 | { "Print scaled up/down to fit one page","Drucke hoch/runterskaliert um genau auf eine Seite zu passen." }, |
1327 | { "Printout Mode","Druck Modus" }, | 1327 | { "Printout Mode","Druck Modus" }, |
1328 | { "Filter menu icon","Filtermenu Icon" }, | 1328 | { "Filter menu icon","Filtermenu Icon" }, |
diff --git a/bin/kdepim/pwmanager/pwmanagerFAQ.txt b/bin/kdepim/pwmanager/pwmanagerFAQ.txt index 15cfd80..b196a77 100644 --- a/bin/kdepim/pwmanager/pwmanagerFAQ.txt +++ b/bin/kdepim/pwmanager/pwmanagerFAQ.txt | |||
@@ -1,84 +1,91 @@ | |||
1 | Q: | 1 | Q: |
2 | What is PWM/Pi? | 2 | What is PWM/Pi? |
3 | Q: | 3 | Q: |
4 | For which platform is PWM/Pi available? | 4 | For which platform is PWM/Pi available? |
5 | Q: | ||
6 | How can I create categories in PWM/Pi? | ||
5 | Q: | 7 | Q: |
6 | Can I exchange the password files from PWM/Pi and PwManager? | 8 | Can I exchange the password files from PWM/Pi and PwManager? |
7 | Q: | 9 | Q: |
8 | Does Export/Import keep sync information in place? | 10 | Does Export/Import keep sync information in place? |
9 | Q: | 11 | Q: |
10 | Can PWM/Pi sync categories? | 12 | Can PWM/Pi sync categories? |
11 | Q: | 13 | Q: |
12 | Which crypto, hash and compress algorithm is applied to the remote file | 14 | Which crypto, hash and compress algorithm is applied to the remote file |
13 | while syncing? | 15 | while syncing? |
14 | Q: | 16 | Q: |
15 | What is the format of the CSV format to import passwords? | 17 | What is the format of the CSV format to import passwords? |
16 | 18 | ||
17 | ************************************************************************* | 19 | ************************************************************************* |
18 | Q: | 20 | Q: |
19 | What is PWM/Pi | 21 | What is PWM/Pi |
20 | A: | 22 | A: |
21 | PWM/Pi is the platform-independend version of PwManager 1.0.1, written by | 23 | PWM/Pi is the platform-independend version of PwManager 1.0.1, written by |
22 | Michael Buesch and the PwManager Team (http://passwordmanager.sourceforge.net) | 24 | Michael Buesch and the PwManager Team (http://passwordmanager.sourceforge.net) |
23 | ************************************************************************* | 25 | ************************************************************************* |
24 | Q: | 26 | Q: |
25 | For which platform is PWM/Pi available? | 27 | For which platform is PWM/Pi available? |
26 | A: | 28 | A: |
27 | PWM/Pi is the platform-independend version of PWManager and it | 29 | PWM/Pi is the platform-independend version of PWManager and it |
28 | includes a replacement for the KDE libraries called microkde. | 30 | includes a replacement for the KDE libraries called microkde. |
29 | It can be compiled to any platform, where Qt is available. | 31 | Precompiled versions are available |
30 | The source code compiles without modifications on Windows, | 32 | on www.pi-sync.info for Linux and Sharp Zaurus PDA. |
31 | Linux Desktop and Sharp Zaurus PDA. Precompiled versions are available | ||
32 | on www.pi-sync.info for Windows and Sharp Zaurus PDA. | ||
33 | Latest versions and the source code cvs can be found at: | 33 | Latest versions and the source code cvs can be found at: |
34 | http://sourceforge.net/projects/kdepimpi/ | 34 | http://sourceforge.net/projects/kdepimpi/ |
35 | ************************************************************************* | 35 | ************************************************************************* |
36 | Q: | ||
37 | How can I create categories in PWM/Pi? | ||
38 | A: | ||
39 | In PWM/Pi you cannot create categories. | ||
40 | You can set (or change) a category for a specific password entry. | ||
41 | PwM/Pi reads all categories from all password entries and creates a category list from that. | ||
42 | ************************************************************************* | ||
36 | Q: | 43 | Q: |
37 | Can I exchange the password files from PWM/Pi and PwManager | 44 | Can I exchange the password files from PWM/Pi and PwManager |
38 | A: | 45 | A: |
39 | The password files of PWM/Pi can not be exchanged with all versions up | 46 | The password files of PWM/Pi can not be exchanged with all versions up |
40 | to 1.0.1 of PwManager. | 47 | to 1.0.1 of PwManager. |
41 | However, Michael will integrate our changes into a PwManager release | 48 | However, Michael will integrate our changes into a PwManager release |
42 | 1.1, and the password files of that release will then be interchangable | 49 | 1.1, and the password files of that release will then be interchangable |
43 | with PWM/Pi | 50 | with PWM/Pi |
44 | ************************************************************************* | 51 | ************************************************************************* |
45 | Q: | 52 | Q: |
46 | Does Export/Import keep sync information in place | 53 | Does Export/Import keep sync information in place |
47 | A: | 54 | A: |
48 | Exporting data from PwManager removes all sync related information | 55 | Exporting data from PwManager removes all sync related information |
49 | (Meta information) from the data. Because of that, a subsequent import | 56 | (Meta information) from the data. Because of that, a subsequent import |
50 | results in "new" entries that will be handled as new entries when | 57 | results in "new" entries that will be handled as new entries when |
51 | syncing them with an existing password file. | 58 | syncing them with an existing password file. |
52 | ************************************************************************* | 59 | ************************************************************************* |
53 | Q: | 60 | Q: |
54 | Can PWM/Pi sync categories? | 61 | Can PWM/Pi sync categories? |
55 | A: | 62 | A: |
56 | No. PWM/Pi does not sync categories. It syncs all pw entries of the file | 63 | No. PWM/Pi does not sync categories. It syncs all pw entries of the file |
57 | without checking for the entries categories. | 64 | without checking for the entries categories. |
58 | A sync operation does not move modified entries from one category to another. | 65 | A sync operation does not move modified entries from one category to another. |
59 | Only if the sync operation has to create a new pw entry, it checks for the | 66 | Only if the sync operation has to create a new pw entry, it checks for the |
60 | existance of the category and creates it if not existent. | 67 | existance of the category and creates it if not existent. |
61 | ************************************************************************* | 68 | ************************************************************************* |
62 | Q: | 69 | Q: |
63 | Which crypto, hash and compress algorithm is applied to the remote file | 70 | Which crypto, hash and compress algorithm is applied to the remote file |
64 | while syncing? | 71 | while syncing? |
65 | A: The sync operation applies the local crypt, hash and compress algorithm | 72 | A: The sync operation applies the local crypt, hash and compress algorithm |
66 | to both, the local and remote copy of the passwordfile and with thus | 73 | to both, the local and remote copy of the passwordfile and with thus |
67 | overwrites the settings of the remote PwManager application. | 74 | overwrites the settings of the remote PwManager application. |
68 | ************************************************************************* | 75 | ************************************************************************* |
69 | Q: | 76 | Q: |
70 | What is the format of the CSV file to import passwords? | 77 | What is the format of the CSV file to import passwords? |
71 | A: | 78 | A: |
72 | "Category 1",, "Desc 1", "Username 1", "Password 1", "URL 1", "Launcher 1", "Comment 1" | 79 | "Category 1",, "Desc 1", "Username 1", "Password 1", "URL 1", "Launcher 1", "Comment 1" |
73 | "Category 1",, "Desc 2", "Username 2", "Password 2", "URL 2", "Launcher 2", "Comment 2" | 80 | "Category 1",, "Desc 2", "Username 2", "Password 2", "URL 2", "Launcher 2", "Comment 2" |
74 | ... | 81 | ... |
75 | 82 | ||
76 | 83 | ||
77 | -The empty "" is neccessary, because in future versions PwManager will | 84 | -The empty "" is neccessary, because in future versions PwManager will |
78 | support nested Categories. | 85 | support nested Categories. |
79 | -The first line must !!not!! contain the field names. | 86 | -The first line must !!not!! contain the field names. |
80 | 87 | ||
81 | 88 | ||
82 | 89 | ||
83 | 90 | ||
84 | 91 | ||
diff --git a/kmicromail/libmailwrapper/genericwrapper.cpp b/kmicromail/libmailwrapper/genericwrapper.cpp index 1ed9f34..0b6adf7 100644 --- a/kmicromail/libmailwrapper/genericwrapper.cpp +++ b/kmicromail/libmailwrapper/genericwrapper.cpp | |||
@@ -235,314 +235,315 @@ void Genericwrapper::traverseBody(RecBodyP&target,mailmessage*message,mailmime*m | |||
235 | //qDebug("res %d %s ", index, resu); | 235 | //qDebug("res %d %s ", index, resu); |
236 | b = QString::fromUtf8(resu); | 236 | b = QString::fromUtf8(resu); |
237 | } | 237 | } |
238 | if (resu) free(resu); | 238 | if (resu) free(resu); |
239 | } | 239 | } |
240 | #endif | 240 | #endif |
241 | target->setBodytext(b); | 241 | target->setBodytext(b); |
242 | target->setDescription(part); | 242 | target->setDescription(part); |
243 | } else { | 243 | } else { |
244 | bodyCache[b]=new encodedString(data,len); | 244 | bodyCache[b]=new encodedString(data,len); |
245 | target->addPart(part); | 245 | target->addPart(part); |
246 | } | 246 | } |
247 | } | 247 | } |
248 | break; | 248 | break; |
249 | case MAILMIME_MULTIPLE: | 249 | case MAILMIME_MULTIPLE: |
250 | { | 250 | { |
251 | unsigned int ccount = 1; | 251 | unsigned int ccount = 1; |
252 | mailmime*cbody=0; | 252 | mailmime*cbody=0; |
253 | QValueList<int>countlist = recList; | 253 | QValueList<int>countlist = recList; |
254 | for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) { | 254 | for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) { |
255 | cbody = (mailmime*)clist_content(cur); | 255 | cbody = (mailmime*)clist_content(cur); |
256 | if (cbody->mm_type==MAILMIME_MULTIPLE) { | 256 | if (cbody->mm_type==MAILMIME_MULTIPLE) { |
257 | RecPartP targetPart = new RecPart(); | 257 | RecPartP targetPart = new RecPart(); |
258 | targetPart->setType("multipart"); | 258 | targetPart->setType("multipart"); |
259 | countlist.append(current_count); | 259 | countlist.append(current_count); |
260 | targetPart->setPositionlist(countlist); | 260 | targetPart->setPositionlist(countlist); |
261 | target->addPart(targetPart); | 261 | target->addPart(targetPart); |
262 | } | 262 | } |
263 | traverseBody(target,message, cbody,countlist,current_rec+1,ccount); | 263 | traverseBody(target,message, cbody,countlist,current_rec+1,ccount); |
264 | if (cbody->mm_type==MAILMIME_MULTIPLE) { | 264 | if (cbody->mm_type==MAILMIME_MULTIPLE) { |
265 | countlist = recList; | 265 | countlist = recList; |
266 | } | 266 | } |
267 | ++ccount; | 267 | ++ccount; |
268 | } | 268 | } |
269 | } | 269 | } |
270 | break; | 270 | break; |
271 | case MAILMIME_MESSAGE: | 271 | case MAILMIME_MESSAGE: |
272 | { | 272 | { |
273 | QValueList<int>countlist = recList; | 273 | QValueList<int>countlist = recList; |
274 | countlist.append(current_count); | 274 | countlist.append(current_count); |
275 | /* the own header is always at recursion 0 - we don't need that */ | 275 | /* the own header is always at recursion 0 - we don't need that */ |
276 | if (current_rec > 0) { | 276 | if (current_rec > 0) { |
277 | part->setPositionlist(countlist); | 277 | part->setPositionlist(countlist); |
278 | r = mailmessage_fetch_section(message,mime,&data,&len); | 278 | r = mailmessage_fetch_section(message,mime,&data,&len); |
279 | part->setSize(len); | 279 | part->setSize(len); |
280 | part->setPositionlist(countlist); | 280 | part->setPositionlist(countlist); |
281 | b = gen_attachment_id(); | 281 | b = gen_attachment_id(); |
282 | part->setIdentifier(b); | 282 | part->setIdentifier(b); |
283 | part->setType("message"); | 283 | part->setType("message"); |
284 | part->setSubtype("rfc822"); | 284 | part->setSubtype("rfc822"); |
285 | bodyCache[b]=new encodedString(data,len); | 285 | bodyCache[b]=new encodedString(data,len); |
286 | target->addPart(part); | 286 | target->addPart(part); |
287 | } | 287 | } |
288 | if (mime->mm_data.mm_message.mm_msg_mime != NULL) { | 288 | if (mime->mm_data.mm_message.mm_msg_mime != NULL) { |
289 | traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1); | 289 | traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1); |
290 | } | 290 | } |
291 | } | 291 | } |
292 | break; | 292 | break; |
293 | } | 293 | } |
294 | } | 294 | } |
295 | 295 | ||
296 | RecBodyP Genericwrapper::parseMail( mailmessage * msg ) | 296 | RecBodyP Genericwrapper::parseMail( mailmessage * msg ) |
297 | { | 297 | { |
298 | int err = MAILIMF_NO_ERROR; | 298 | int err = MAILIMF_NO_ERROR; |
299 | //mailmime_single_fields fields; | 299 | //mailmime_single_fields fields; |
300 | /* is bound to msg and will be freed there */ | 300 | /* is bound to msg and will be freed there */ |
301 | mailmime * mime=0; | 301 | mailmime * mime=0; |
302 | RecBodyP body = new RecBody(); | 302 | RecBodyP body = new RecBody(); |
303 | //memset(&fields, 0, sizeof(struct mailmime_single_fields)); | 303 | //memset(&fields, 0, sizeof(struct mailmime_single_fields)); |
304 | err = mailmessage_get_bodystructure(msg,&mime); | 304 | err = mailmessage_get_bodystructure(msg,&mime); |
305 | QValueList<int>recList; | 305 | QValueList<int>recList; |
306 | traverseBody(body,msg,mime,recList); | 306 | traverseBody(body,msg,mime,recList); |
307 | return body; | 307 | return body; |
308 | } | 308 | } |
309 | 309 | ||
310 | 310 | ||
311 | QString Genericwrapper::parseAddressList( mailimf_address_list *list ) | 311 | QString Genericwrapper::parseAddressList( mailimf_address_list *list ) |
312 | { | 312 | { |
313 | QString result( "" ); | 313 | QString result( "" ); |
314 | 314 | ||
315 | bool first = true; | 315 | bool first = true; |
316 | if (list == 0) return result; | 316 | if (list == 0) return result; |
317 | for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { | 317 | for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { |
318 | mailimf_address *addr = (mailimf_address *) current->data; | 318 | mailimf_address *addr = (mailimf_address *) current->data; |
319 | 319 | ||
320 | if ( !first ) { | 320 | if ( !first ) { |
321 | result.append( "," ); | 321 | result.append( "," ); |
322 | } else { | 322 | } else { |
323 | first = false; | 323 | first = false; |
324 | } | 324 | } |
325 | 325 | ||
326 | switch ( addr->ad_type ) { | 326 | switch ( addr->ad_type ) { |
327 | case MAILIMF_ADDRESS_MAILBOX: | 327 | case MAILIMF_ADDRESS_MAILBOX: |
328 | result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); | 328 | result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); |
329 | break; | 329 | break; |
330 | case MAILIMF_ADDRESS_GROUP: | 330 | case MAILIMF_ADDRESS_GROUP: |
331 | result.append( parseGroup( addr->ad_data.ad_group ) ); | 331 | result.append( parseGroup( addr->ad_data.ad_group ) ); |
332 | break; | 332 | break; |
333 | default: | 333 | default: |
334 | ; // odebug << "Generic: unkown mailimf address type" << oendl; | 334 | ; // odebug << "Generic: unkown mailimf address type" << oendl; |
335 | break; | 335 | break; |
336 | } | 336 | } |
337 | } | 337 | } |
338 | 338 | ||
339 | return result; | 339 | return result; |
340 | } | 340 | } |
341 | 341 | ||
342 | QString Genericwrapper::parseGroup( mailimf_group *group ) | 342 | QString Genericwrapper::parseGroup( mailimf_group *group ) |
343 | { | 343 | { |
344 | QString result( "" ); | 344 | QString result( "" ); |
345 | 345 | ||
346 | result.append( group->grp_display_name ); | 346 | result.append( group->grp_display_name ); |
347 | result.append( ": " ); | 347 | result.append( ": " ); |
348 | 348 | ||
349 | if ( group->grp_mb_list != NULL ) { | 349 | if ( group->grp_mb_list != NULL ) { |
350 | result.append( parseMailboxList( group->grp_mb_list ) ); | 350 | result.append( parseMailboxList( group->grp_mb_list ) ); |
351 | } | 351 | } |
352 | 352 | ||
353 | result.append( ";" ); | 353 | result.append( ";" ); |
354 | 354 | ||
355 | return result; | 355 | return result; |
356 | } | 356 | } |
357 | 357 | ||
358 | QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) | 358 | QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) |
359 | { | 359 | { |
360 | QString result( "" ); | 360 | QString result( "" ); |
361 | 361 | ||
362 | if ( box->mb_display_name == NULL ) { | 362 | if ( box->mb_display_name == NULL ) { |
363 | result.append( box->mb_addr_spec ); | 363 | result.append( convert_String(box->mb_addr_spec) ); |
364 | } else { | 364 | } else { |
365 | result.append( convert_String(box->mb_display_name) ); | 365 | result.append( convert_String(box->mb_display_name) ); |
366 | result.append( " <" ); | 366 | result.append( " <" ); |
367 | result.append( box->mb_addr_spec ); | 367 | result.append( convert_String( box->mb_addr_spec) ); |
368 | result.append( ">" ); | 368 | result.append( ">" ); |
369 | } | 369 | } |
370 | 370 | ||
371 | return result; | 371 | return result; |
372 | } | 372 | } |
373 | 373 | ||
374 | QString Genericwrapper::parseMailboxList( mailimf_mailbox_list *list ) | 374 | QString Genericwrapper::parseMailboxList( mailimf_mailbox_list *list ) |
375 | { | 375 | { |
376 | QString result( "" ); | 376 | QString result( "" ); |
377 | 377 | ||
378 | bool first = true; | 378 | bool first = true; |
379 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { | 379 | for ( clistiter *current = clist_begin( list->mb_list ); current != NULL; current = current->next ) { |
380 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; | 380 | mailimf_mailbox *box = (mailimf_mailbox *) current->data; |
381 | 381 | ||
382 | if ( !first ) { | 382 | if ( !first ) { |
383 | result.append( "," ); | 383 | result.append( "," ); |
384 | } else { | 384 | } else { |
385 | first = false; | 385 | first = false; |
386 | } | 386 | } |
387 | 387 | ||
388 | result.append( parseMailbox( box ) ); | 388 | result.append( parseMailbox( box ) ); |
389 | } | 389 | } |
390 | 390 | ||
391 | return result; | 391 | return result; |
392 | } | 392 | } |
393 | 393 | ||
394 | encodedString* Genericwrapper::fetchDecodedPart(const RecMailP&,const RecPartP&part) | 394 | encodedString* Genericwrapper::fetchDecodedPart(const RecMailP&,const RecPartP&part) |
395 | { | 395 | { |
396 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); | 396 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); |
397 | if (it==bodyCache.end()) return new encodedString(); | 397 | if (it==bodyCache.end()) return new encodedString(); |
398 | encodedString*t = decode_String(it.data(),part->Encoding()); | 398 | encodedString*t = decode_String(it.data(),part->Encoding()); |
399 | return t; | 399 | return t; |
400 | } | 400 | } |
401 | 401 | ||
402 | encodedString* Genericwrapper::fetchRawPart(const RecMailP&,const RecPartP&part) | 402 | encodedString* Genericwrapper::fetchRawPart(const RecMailP&,const RecPartP&part) |
403 | { | 403 | { |
404 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); | 404 | QMap<QString,encodedString*>::ConstIterator it = bodyCache.find(part->Identifier()); |
405 | if (it==bodyCache.end()) return new encodedString(); | 405 | if (it==bodyCache.end()) return new encodedString(); |
406 | encodedString*t = it.data(); | 406 | encodedString*t = it.data(); |
407 | return t; | 407 | return t; |
408 | } | 408 | } |
409 | 409 | ||
410 | QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part) | 410 | QString Genericwrapper::fetchTextPart(const RecMailP&mail,const RecPartP&part) |
411 | { | 411 | { |
412 | encodedString*t = fetchDecodedPart(mail,part); | 412 | encodedString*t = fetchDecodedPart(mail,part); |
413 | QString text=t->Content(); | 413 | QString text=t->Content(); |
414 | delete t; | 414 | delete t; |
415 | return text; | 415 | return text; |
416 | } | 416 | } |
417 | 417 | ||
418 | void Genericwrapper::cleanMimeCache() | 418 | void Genericwrapper::cleanMimeCache() |
419 | { | 419 | { |
420 | QMap<QString,encodedString*>::Iterator it = bodyCache.begin(); | 420 | QMap<QString,encodedString*>::Iterator it = bodyCache.begin(); |
421 | for (;it!=bodyCache.end();++it) { | 421 | for (;it!=bodyCache.end();++it) { |
422 | encodedString*t = it.data(); | 422 | encodedString*t = it.data(); |
423 | //it.setValue(0); | 423 | //it.setValue(0); |
424 | if (t) delete t; | 424 | if (t) delete t; |
425 | } | 425 | } |
426 | bodyCache.clear(); | 426 | bodyCache.clear(); |
427 | ; // odebug << "Genericwrapper: cache cleaned" << oendl; | 427 | ; // odebug << "Genericwrapper: cache cleaned" << oendl; |
428 | } | 428 | } |
429 | 429 | ||
430 | QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies) | 430 | QStringList Genericwrapper::parseInreplies(mailimf_in_reply_to * in_replies) |
431 | { | 431 | { |
432 | QStringList res; | 432 | QStringList res; |
433 | if (!in_replies || !in_replies->mid_list) return res; | 433 | if (!in_replies || !in_replies->mid_list) return res; |
434 | clistiter * current = 0; | 434 | clistiter * current = 0; |
435 | for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) { | 435 | for ( current = clist_begin( in_replies->mid_list ); current != NULL; current = current->next ) { |
436 | QString h((char*)current->data); | 436 | QString h((char*)current->data); |
437 | while (h.length()>0 && h[0]=='<') { | 437 | while (h.length()>0 && h[0]=='<') { |
438 | h.remove(0,1); | 438 | h.remove(0,1); |
439 | } | 439 | } |
440 | while (h.length()>0 && h[h.length()-1]=='>') { | 440 | while (h.length()>0 && h[h.length()-1]=='>') { |
441 | h.remove(h.length()-1,1); | 441 | h.remove(h.length()-1,1); |
442 | } | 442 | } |
443 | if (h.length()>0) { | 443 | if (h.length()>0) { |
444 | res.append(h); | 444 | res.append(h); |
445 | } | 445 | } |
446 | } | 446 | } |
447 | return res; | 447 | return res; |
448 | } | 448 | } |
449 | 449 | ||
450 | void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to, int maxSizeInKb) | 450 | void Genericwrapper::parseList(QValueList<Opie::Core::OSmartPointer<RecMail> > &target,mailsession*session,const QString&mailbox,bool mbox_as_to, int maxSizeInKb) |
451 | { | 451 | { |
452 | int r; | 452 | int r; |
453 | mailmessage_list * env_list = 0; | 453 | mailmessage_list * env_list = 0; |
454 | r = mailsession_get_messages_list(session,&env_list); | 454 | r = mailsession_get_messages_list(session,&env_list); |
455 | if (r != MAIL_NO_ERROR) { | 455 | if (r != MAIL_NO_ERROR) { |
456 | ; // odebug << "Error message list" << oendl; | 456 | ; // odebug << "Error message list" << oendl; |
457 | return; | 457 | return; |
458 | } | 458 | } |
459 | r = mailsession_get_envelopes_list(session, env_list); | 459 | r = mailsession_get_envelopes_list(session, env_list); |
460 | if (r != MAIL_NO_ERROR) { | 460 | if (r != MAIL_NO_ERROR) { |
461 | ; // odebug << "Error filling message list" << oendl; | 461 | ; // odebug << "Error filling message list" << oendl; |
462 | if (env_list) { | 462 | if (env_list) { |
463 | mailmessage_list_free(env_list); | 463 | mailmessage_list_free(env_list); |
464 | } | 464 | } |
465 | return; | 465 | return; |
466 | } | 466 | } |
467 | mailimf_references * refs = 0; | 467 | mailimf_references * refs = 0; |
468 | mailimf_in_reply_to * in_replies = 0; | 468 | mailimf_in_reply_to * in_replies = 0; |
469 | uint32_t i = 0; | 469 | uint32_t i = 0; |
470 | for(; i < carray_count(env_list->msg_tab) ; ++i) { | 470 | for(; i < carray_count(env_list->msg_tab) ; ++i) { |
471 | mailmessage * msg; | 471 | mailmessage * msg; |
472 | QBitArray mFlags(7); | 472 | QBitArray mFlags(7); |
473 | msg = (mailmessage*)carray_get(env_list->msg_tab, i); | 473 | msg = (mailmessage*)carray_get(env_list->msg_tab, i); |
474 | if (msg->msg_fields == NULL) { | 474 | if (msg->msg_fields == NULL) { |
475 | //; // odebug << "could not fetch envelope of message " << i << "" << oendl; | 475 | //; // odebug << "could not fetch envelope of message " << i << "" << oendl; |
476 | continue; | 476 | continue; |
477 | } | 477 | } |
478 | RecMailP mail = new RecMail(); | 478 | RecMailP mail = new RecMail(); |
479 | mail->setWrapper(this); | 479 | mail->setWrapper(this); |
480 | mail_flags * flag_result = 0; | 480 | mail_flags * flag_result = 0; |
481 | r = mailmessage_get_flags(msg,&flag_result); | 481 | r = mailmessage_get_flags(msg,&flag_result); |
482 | if (r == MAIL_ERROR_NOT_IMPLEMENTED) { | 482 | if (r == MAIL_ERROR_NOT_IMPLEMENTED) { |
483 | mFlags.setBit(FLAG_SEEN); | 483 | mFlags.setBit(FLAG_SEEN); |
484 | } | 484 | } |
485 | mailimf_single_fields single_fields; | 485 | mailimf_single_fields single_fields; |
486 | mailimf_single_fields_init(&single_fields, msg->msg_fields); | 486 | mailimf_single_fields_init(&single_fields, msg->msg_fields); |
487 | mail->setMsgsize(msg->msg_size); | 487 | mail->setMsgsize(msg->msg_size); |
488 | mail->setFlags(mFlags); | 488 | mail->setFlags(mFlags); |
489 | mail->setMbox(mailbox); | 489 | mail->setMbox(mailbox); |
490 | mail->setNumber(msg->msg_index); | 490 | mail->setNumber(msg->msg_index); |
491 | if (single_fields.fld_subject) | 491 | if (single_fields.fld_subject) |
492 | mail->setSubject( convert_String(single_fields.fld_subject->sbj_value)); | 492 | mail->setSubject( convert_String(single_fields.fld_subject->sbj_value)); |
493 | if (single_fields.fld_from) | 493 | if (single_fields.fld_from) { |
494 | mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list)); | 494 | mail->setFrom(parseMailboxList(single_fields.fld_from->frm_mb_list)); |
495 | } | ||
495 | if (!mbox_as_to) { | 496 | if (!mbox_as_to) { |
496 | if (single_fields.fld_to) | 497 | if (single_fields.fld_to) |
497 | mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) ); | 498 | mail->setTo( parseAddressList( single_fields.fld_to->to_addr_list ) ); |
498 | } else { | 499 | } else { |
499 | mail->setTo(mailbox); | 500 | mail->setTo(mailbox); |
500 | } | 501 | } |
501 | if (single_fields.fld_cc) | 502 | if (single_fields.fld_cc) |
502 | mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) ); | 503 | mail->setCC( parseAddressList( single_fields.fld_cc->cc_addr_list ) ); |
503 | if (single_fields.fld_bcc) | 504 | if (single_fields.fld_bcc) |
504 | mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) ); | 505 | mail->setBcc( parseAddressList( single_fields.fld_bcc->bcc_addr_list ) ); |
505 | if (single_fields.fld_orig_date) { | 506 | if (single_fields.fld_orig_date) { |
506 | QDateTime dt = Genericwrapper::parseDateTime( single_fields.fld_orig_date->dt_date_time ); | 507 | QDateTime dt = Genericwrapper::parseDateTime( single_fields.fld_orig_date->dt_date_time ); |
507 | QString ret; | 508 | QString ret; |
508 | if ( dt.date() == QDate::currentDate () ) | 509 | if ( dt.date() == QDate::currentDate () ) |
509 | ret = KGlobal::locale()->formatTime( dt.time(),true); | 510 | ret = KGlobal::locale()->formatTime( dt.time(),true); |
510 | else { | 511 | else { |
511 | ret = KGlobal::locale()->formatDateTime( dt,true,true); | 512 | ret = KGlobal::locale()->formatDateTime( dt,true,true); |
512 | } | 513 | } |
513 | mail->setDate( ret ); | 514 | mail->setDate( ret ); |
514 | char tmp[20]; | 515 | char tmp[20]; |
515 | snprintf( tmp, 20, "%04i-%02i-%02i %02i:%02i:%02i", | 516 | snprintf( tmp, 20, "%04i-%02i-%02i %02i:%02i:%02i", |
516 | dt.date().year(),dt.date().month(), dt.date().day(), dt.time().hour(), dt.time().minute(), dt.time().second() ); | 517 | dt.date().year(),dt.date().month(), dt.date().day(), dt.time().hour(), dt.time().minute(), dt.time().second() ); |
517 | //qDebug(" iso %s ", tmp); | 518 | //qDebug(" iso %s ", tmp); |
518 | mail->setIsoDate( QString( tmp ) ); | 519 | mail->setIsoDate( QString( tmp ) ); |
519 | } | 520 | } |
520 | // crashes when accessing pop3 account? | 521 | // crashes when accessing pop3 account? |
521 | if (single_fields.fld_message_id) { | 522 | if (single_fields.fld_message_id) { |
522 | mail->setMsgid(QString(single_fields.fld_message_id->mid_value)); | 523 | mail->setMsgid(QString(single_fields.fld_message_id->mid_value)); |
523 | ; // odebug << "Msgid == " << mail->Msgid().latin1() << "" << oendl; | 524 | ; // odebug << "Msgid == " << mail->Msgid().latin1() << "" << oendl; |
524 | } | 525 | } |
525 | if (single_fields.fld_reply_to) { | 526 | if (single_fields.fld_reply_to) { |
526 | QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list); | 527 | QStringList t = parseAddressList(single_fields.fld_reply_to->rt_addr_list); |
527 | if (t.count()>0) { | 528 | if (t.count()>0) { |
528 | mail->setReplyto(t[0]); | 529 | mail->setReplyto(t[0]); |
529 | } | 530 | } |
530 | } | 531 | } |
531 | #if 0 | 532 | #if 0 |
532 | refs = single_fields.fld_references; | 533 | refs = single_fields.fld_references; |
533 | if (refs && refs->mid_list && clist_count(refs->mid_list)) { | 534 | if (refs && refs->mid_list && clist_count(refs->mid_list)) { |
534 | char * text = (char*)refs->mid_list->first->data; | 535 | char * text = (char*)refs->mid_list->first->data; |
535 | mail->setReplyto(QString(text)); | 536 | mail->setReplyto(QString(text)); |
536 | } | 537 | } |
537 | #endif | 538 | #endif |
538 | if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list && | 539 | if (single_fields.fld_in_reply_to && single_fields.fld_in_reply_to->mid_list && |
539 | clist_count(single_fields.fld_in_reply_to->mid_list)) { | 540 | clist_count(single_fields.fld_in_reply_to->mid_list)) { |
540 | mail->setInreply(parseInreplies(single_fields.fld_in_reply_to)); | 541 | mail->setInreply(parseInreplies(single_fields.fld_in_reply_to)); |
541 | } | 542 | } |
542 | if ( maxSizeInKb == 0 || mail->Msgsize()<=maxSizeInKb*1024 ) | 543 | if ( maxSizeInKb == 0 || mail->Msgsize()<=maxSizeInKb*1024 ) |
543 | target.append(mail); | 544 | target.append(mail); |
544 | } | 545 | } |
545 | if (env_list) { | 546 | if (env_list) { |
546 | mailmessage_list_free(env_list); | 547 | mailmessage_list_free(env_list); |
547 | } | 548 | } |
548 | } | 549 | } |
diff --git a/korganizer/koagenda.cpp b/korganizer/koagenda.cpp index 1a24887..9720f43 100644 --- a/korganizer/koagenda.cpp +++ b/korganizer/koagenda.cpp | |||
@@ -115,257 +115,257 @@ void MarcusBains::updateLocation(bool recalculate) | |||
115 | if((tim.hour() == 0) && (oldTime.hour()==23)) | 115 | if((tim.hour() == 0) && (oldTime.hour()==23)) |
116 | recalculate = true; | 116 | recalculate = true; |
117 | 117 | ||
118 | int mins = tim.hour()*60 + tim.minute(); | 118 | int mins = tim.hour()*60 + tim.minute(); |
119 | int minutesPerCell = 24 * 60 / agenda->rows(); | 119 | int minutesPerCell = 24 * 60 / agenda->rows(); |
120 | int y = mins*agenda->gridSpacingY()/minutesPerCell; | 120 | int y = mins*agenda->gridSpacingY()/minutesPerCell; |
121 | int today = recalculate ? todayColumn() : oldToday; | 121 | int today = recalculate ? todayColumn() : oldToday; |
122 | int x = agenda->gridSpacingX()*today; | 122 | int x = agenda->gridSpacingX()*today; |
123 | bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled); | 123 | bool disabled = !(KOPrefs::instance()->mMarcusBainsEnabled); |
124 | 124 | ||
125 | oldTime = tim; | 125 | oldTime = tim; |
126 | oldToday = today; | 126 | oldToday = today; |
127 | 127 | ||
128 | if(disabled || (today<0)) { | 128 | if(disabled || (today<0)) { |
129 | hide(); mTimeBox->hide(); | 129 | hide(); mTimeBox->hide(); |
130 | return; | 130 | return; |
131 | } else { | 131 | } else { |
132 | show(); mTimeBox->show(); | 132 | show(); mTimeBox->show(); |
133 | } | 133 | } |
134 | 134 | ||
135 | if(recalculate) | 135 | if(recalculate) |
136 | setFixedSize(agenda->gridSpacingX(),1); | 136 | setFixedSize(agenda->gridSpacingX(),1); |
137 | agenda->moveChild(this, x, y); | 137 | agenda->moveChild(this, x, y); |
138 | raise(); | 138 | raise(); |
139 | 139 | ||
140 | if(recalculate) | 140 | if(recalculate) |
141 | //mTimeBox->setFont(QFont("helvetica",10)); | 141 | //mTimeBox->setFont(QFont("helvetica",10)); |
142 | mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont); | 142 | mTimeBox->setFont(KOPrefs::instance()->mMarcusBainsFont); |
143 | 143 | ||
144 | mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds)); | 144 | mTimeBox->setText(KGlobal::locale()->formatTime(tim, KOPrefs::instance()->mMarcusBainsShowSeconds)); |
145 | mTimeBox->adjustSize(); | 145 | mTimeBox->adjustSize(); |
146 | // the -2 below is there because there is a bug in this program | 146 | // the -2 below is there because there is a bug in this program |
147 | // somewhere, where the last column of this widget is a few pixels | 147 | // somewhere, where the last column of this widget is a few pixels |
148 | // narrower than the other columns. | 148 | // narrower than the other columns. |
149 | int offs = (today==agenda->columns()-1) ? -4 : 0; | 149 | int offs = (today==agenda->columns()-1) ? -4 : 0; |
150 | agenda->moveChild(mTimeBox, | 150 | agenda->moveChild(mTimeBox, |
151 | x+agenda->gridSpacingX()-mTimeBox->width()+offs-1, | 151 | x+agenda->gridSpacingX()-mTimeBox->width()+offs-1, |
152 | y-mTimeBox->height()); | 152 | y-mTimeBox->height()); |
153 | 153 | ||
154 | mTimeBox->raise(); | 154 | mTimeBox->raise(); |
155 | //mTimeBox->setAutoMask(true); | 155 | //mTimeBox->setAutoMask(true); |
156 | minutes->start(5000,true); | 156 | minutes->start(5000,true); |
157 | } | 157 | } |
158 | 158 | ||
159 | 159 | ||
160 | //////////////////////////////////////////////////////////////////////////// | 160 | //////////////////////////////////////////////////////////////////////////// |
161 | 161 | ||
162 | 162 | ||
163 | /* | 163 | /* |
164 | Create an agenda widget with rows rows and columns columns. | 164 | Create an agenda widget with rows rows and columns columns. |
165 | */ | 165 | */ |
166 | KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, | 166 | KOAgenda::KOAgenda(int columns,int rows,int rowSize,QWidget *parent, |
167 | const char *name,WFlags f) : | 167 | const char *name,WFlags f) : |
168 | QScrollView(parent,name,f) | 168 | QScrollView(parent,name,f) |
169 | { | 169 | { |
170 | 170 | ||
171 | 171 | ||
172 | mColumns = columns; | 172 | mColumns = columns; |
173 | mRows = rows; | 173 | mRows = rows; |
174 | mGridSpacingY = rowSize; | 174 | mGridSpacingY = rowSize; |
175 | mAllDayMode = false; | 175 | mAllDayMode = false; |
176 | #ifndef DESKTOP_VERSION | 176 | #ifndef DESKTOP_VERSION |
177 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); | 177 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); |
178 | #endif | 178 | #endif |
179 | mHolidayMask = 0; | 179 | mHolidayMask = 0; |
180 | init(); | 180 | init(); |
181 | } | 181 | } |
182 | 182 | ||
183 | /* | 183 | /* |
184 | Create an agenda widget with columns columns and one row. This is used for | 184 | Create an agenda widget with columns columns and one row. This is used for |
185 | all-day events. | 185 | all-day events. |
186 | */ | 186 | */ |
187 | KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : | 187 | KOAgenda::KOAgenda(int columns,QWidget *parent,const char *name,WFlags f) : |
188 | QScrollView(parent,name,f) | 188 | QScrollView(parent,name,f) |
189 | { | 189 | { |
190 | blockResize = false; | 190 | blockResize = false; |
191 | mColumns = columns; | 191 | mColumns = columns; |
192 | mRows = 1; | 192 | mRows = 1; |
193 | //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize); | 193 | //qDebug("aaaaaaaaaaaaaaaaaaldays %d ", KOPrefs::instance()->mAllDaySize); |
194 | mGridSpacingY = KOPrefs::instance()->mAllDaySize; | 194 | mGridSpacingY = KOPrefs::instance()->mAllDaySize; |
195 | mAllDayMode = true; | 195 | mAllDayMode = true; |
196 | #ifndef DESKTOP_VERSION | 196 | #ifndef DESKTOP_VERSION |
197 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); | 197 | //QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); |
198 | #endif | 198 | #endif |
199 | mHolidayMask = 0; | 199 | mHolidayMask = 0; |
200 | init(); | 200 | init(); |
201 | } | 201 | } |
202 | 202 | ||
203 | 203 | ||
204 | KOAgenda::~KOAgenda() | 204 | KOAgenda::~KOAgenda() |
205 | { | 205 | { |
206 | if(mMarcusBains) delete mMarcusBains; | 206 | if(mMarcusBains) delete mMarcusBains; |
207 | 207 | ||
208 | } | 208 | } |
209 | 209 | ||
210 | Incidence *KOAgenda::selectedIncidence() const | 210 | Incidence *KOAgenda::selectedIncidence() const |
211 | { | 211 | { |
212 | return (mSelectedItem ? mSelectedItem->incidence() : 0); | 212 | return (mSelectedItem ? mSelectedItem->incidence() : 0); |
213 | } | 213 | } |
214 | 214 | ||
215 | 215 | ||
216 | QDate KOAgenda::selectedIncidenceDate() const | 216 | QDate KOAgenda::selectedIncidenceDate() const |
217 | { | 217 | { |
218 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); | 218 | return (mSelectedItem ? mSelectedItem->itemDate() : QDate()); |
219 | } | 219 | } |
220 | 220 | ||
221 | 221 | ||
222 | void KOAgenda::init() | 222 | void KOAgenda::init() |
223 | { | 223 | { |
224 | mPopupTimer = new QTimer(this); | 224 | mPopupTimer = new QTimer(this); |
225 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); | 225 | connect(mPopupTimer , SIGNAL(timeout()), this, SLOT(popupMenu())); |
226 | 226 | ||
227 | mNewItemPopup = new QPopupMenu( this ); | 227 | mNewItemPopup = new QPopupMenu( this ); |
228 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); | 228 | connect ( mNewItemPopup, SIGNAL (activated ( int ) ), this, SLOT ( newItem(int)) ); |
229 | QString pathString = ""; | 229 | QString pathString = ""; |
230 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { | 230 | if ( !KOPrefs::instance()->mToolBarMiniIcons ) { |
231 | if ( QApplication::desktop()->width() < 480 ) | 231 | if ( QApplication::desktop()->width() < 480 ) |
232 | pathString += "icons16/"; | 232 | pathString += "icons16/"; |
233 | } else | 233 | } else |
234 | pathString += "iconsmini/"; | 234 | pathString += "iconsmini/"; |
235 | 235 | ||
236 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); | 236 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newevent" ), i18n("New Event..."), 1 ); |
237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); | 237 | mNewItemPopup->insertItem ( SmallIcon( pathString +"newtodo" ), i18n("New Todo..."),2 ); |
238 | mNewItemPopup->insertSeparator ( ); | 238 | mNewItemPopup->insertSeparator ( ); |
239 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); | 239 | mNewItemPopup->insertItem ( SmallIcon( pathString +"day" ), i18n("Day view"),3 ); |
240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); | 240 | mNewItemPopup->insertItem ( SmallIcon( pathString +"xdays" ), i18n("Next days"),8 ); |
241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); | 241 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next week"),4 ); |
242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); | 242 | mNewItemPopup->insertItem ( SmallIcon( pathString +"week" ), i18n("Next two weeks"),5 ); |
243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("Next month"),6 ); | 243 | mNewItemPopup->insertItem ( SmallIcon( pathString +"month" ), i18n("This month"),6 ); |
244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); | 244 | mNewItemPopup->insertItem ( SmallIcon( pathString +"journal" ), i18n("Journal view"),7 ); |
245 | #ifndef _WIN32_ | 245 | #ifndef _WIN32_ |
246 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase | 246 | int wflags = viewport()-> getWFlags() |WRepaintNoErase;//WResizeNoErase |
247 | viewport()->setWFlags ( wflags); | 247 | viewport()->setWFlags ( wflags); |
248 | #endif | 248 | #endif |
249 | mGridSpacingX = 80; | 249 | mGridSpacingX = 80; |
250 | mResizeBorderWidth = 8; | 250 | mResizeBorderWidth = 8; |
251 | mScrollBorderWidth = 8; | 251 | mScrollBorderWidth = 8; |
252 | mScrollDelay = 30; | 252 | mScrollDelay = 30; |
253 | mScrollOffset = 10; | 253 | mScrollOffset = 10; |
254 | mPaintPixmap.resize( 20,20); | 254 | mPaintPixmap.resize( 20,20); |
255 | //enableClipper(true); | 255 | //enableClipper(true); |
256 | 256 | ||
257 | // Grab key strokes for keyboard navigation of agenda. Seems to have no | 257 | // Grab key strokes for keyboard navigation of agenda. Seems to have no |
258 | // effect. Has to be fixed. | 258 | // effect. Has to be fixed. |
259 | setFocusPolicy(WheelFocus); | 259 | setFocusPolicy(WheelFocus); |
260 | 260 | ||
261 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); | 261 | connect(&mScrollUpTimer,SIGNAL(timeout()),SLOT(scrollUp())); |
262 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); | 262 | connect(&mScrollDownTimer,SIGNAL(timeout()),SLOT(scrollDown())); |
263 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); | 263 | connect(&mResizeTimer,SIGNAL(timeout()),SLOT(finishResize())); |
264 | 264 | ||
265 | mStartCellX = 0; | 265 | mStartCellX = 0; |
266 | mStartCellY = 0; | 266 | mStartCellY = 0; |
267 | mCurrentCellX = 0; | 267 | mCurrentCellX = 0; |
268 | mCurrentCellY = 0; | 268 | mCurrentCellY = 0; |
269 | 269 | ||
270 | mSelectionCellX = 0; | 270 | mSelectionCellX = 0; |
271 | mSelectionYTop = 0; | 271 | mSelectionYTop = 0; |
272 | mSelectionHeight = 0; | 272 | mSelectionHeight = 0; |
273 | 273 | ||
274 | mOldLowerScrollValue = -1; | 274 | mOldLowerScrollValue = -1; |
275 | mOldUpperScrollValue = -1; | 275 | mOldUpperScrollValue = -1; |
276 | 276 | ||
277 | mClickedItem = 0; | 277 | mClickedItem = 0; |
278 | 278 | ||
279 | mActionItem = 0; | 279 | mActionItem = 0; |
280 | mActionType = NOP; | 280 | mActionType = NOP; |
281 | mItemMoved = false; | 281 | mItemMoved = false; |
282 | 282 | ||
283 | mSelectedItem = 0; | 283 | mSelectedItem = 0; |
284 | 284 | ||
285 | // mItems.setAutoDelete(true); | 285 | // mItems.setAutoDelete(true); |
286 | 286 | ||
287 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); | 287 | resizeContents( mGridSpacingX * mColumns + 1 , mGridSpacingY * mRows + 1 ); |
288 | 288 | ||
289 | viewport()->update(); | 289 | viewport()->update(); |
290 | 290 | ||
291 | setMinimumSize(30, 1); | 291 | setMinimumSize(30, 1); |
292 | // setMaximumHeight(mGridSpacingY * mRows + 5); | 292 | // setMaximumHeight(mGridSpacingY * mRows + 5); |
293 | 293 | ||
294 | // Disable horizontal scrollbar. This is a hack. The geometry should be | 294 | // Disable horizontal scrollbar. This is a hack. The geometry should be |
295 | // controlled in a way that the contents horizontally always fits. Then it is | 295 | // controlled in a way that the contents horizontally always fits. Then it is |
296 | // not necessary to turn off the scrollbar. | 296 | // not necessary to turn off the scrollbar. |
297 | setHScrollBarMode(AlwaysOff); | 297 | setHScrollBarMode(AlwaysOff); |
298 | if ( ! mAllDayMode ) | 298 | if ( ! mAllDayMode ) |
299 | setVScrollBarMode(AlwaysOn); | 299 | setVScrollBarMode(AlwaysOn); |
300 | else | 300 | else |
301 | setVScrollBarMode(AlwaysOff); | 301 | setVScrollBarMode(AlwaysOff); |
302 | 302 | ||
303 | setStartHour(KOPrefs::instance()->mDayBegins); | 303 | setStartHour(KOPrefs::instance()->mDayBegins); |
304 | 304 | ||
305 | calculateWorkingHours(); | 305 | calculateWorkingHours(); |
306 | 306 | ||
307 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), | 307 | connect(verticalScrollBar(),SIGNAL(valueChanged(int)), |
308 | SLOT(checkScrollBoundaries(int))); | 308 | SLOT(checkScrollBoundaries(int))); |
309 | 309 | ||
310 | // Create the Marcus Bains line. | 310 | // Create the Marcus Bains line. |
311 | if(mAllDayMode) | 311 | if(mAllDayMode) |
312 | mMarcusBains = 0; | 312 | mMarcusBains = 0; |
313 | else { | 313 | else { |
314 | mMarcusBains = new MarcusBains(this); | 314 | mMarcusBains = new MarcusBains(this); |
315 | addChild(mMarcusBains); | 315 | addChild(mMarcusBains); |
316 | } | 316 | } |
317 | mPopupKind = 0; | 317 | mPopupKind = 0; |
318 | mPopupItem = 0; | 318 | mPopupItem = 0; |
319 | } | 319 | } |
320 | 320 | ||
321 | void KOAgenda::clear() | 321 | void KOAgenda::clear() |
322 | { | 322 | { |
323 | KOAgendaItem *item; | 323 | KOAgendaItem *item; |
324 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { | 324 | for ( item=mItems.first(); item != 0; item=mItems.next() ) { |
325 | mUnusedItems.append( item ); | 325 | mUnusedItems.append( item ); |
326 | //item->hide(); | 326 | //item->hide(); |
327 | } | 327 | } |
328 | mItems.clear(); | 328 | mItems.clear(); |
329 | mSelectedItem = 0; | 329 | mSelectedItem = 0; |
330 | clearSelection(); | 330 | clearSelection(); |
331 | } | 331 | } |
332 | 332 | ||
333 | void KOAgenda::clearSelection() | 333 | void KOAgenda::clearSelection() |
334 | { | 334 | { |
335 | mSelectionCellX = 0; | 335 | mSelectionCellX = 0; |
336 | mSelectionYTop = 0; | 336 | mSelectionYTop = 0; |
337 | mSelectionHeight = 0; | 337 | mSelectionHeight = 0; |
338 | } | 338 | } |
339 | 339 | ||
340 | void KOAgenda::marcus_bains() | 340 | void KOAgenda::marcus_bains() |
341 | { | 341 | { |
342 | if(mMarcusBains) mMarcusBains->updateLocation(true); | 342 | if(mMarcusBains) mMarcusBains->updateLocation(true); |
343 | } | 343 | } |
344 | 344 | ||
345 | 345 | ||
346 | void KOAgenda::changeColumns(int columns) | 346 | void KOAgenda::changeColumns(int columns) |
347 | { | 347 | { |
348 | if (columns == 0) { | 348 | if (columns == 0) { |
349 | qDebug("KOAgenda::changeColumns() called with argument 0 "); | 349 | qDebug("KOAgenda::changeColumns() called with argument 0 "); |
350 | return; | 350 | return; |
351 | } | 351 | } |
352 | clear(); | 352 | clear(); |
353 | mColumns = columns; | 353 | mColumns = columns; |
354 | computeSizes(); | 354 | computeSizes(); |
355 | } | 355 | } |
356 | 356 | ||
357 | /* | 357 | /* |
358 | This is the eventFilter function, which gets all events from the KOAgendaItems | 358 | This is the eventFilter function, which gets all events from the KOAgendaItems |
359 | contained in the agenda. It has to handle moving and resizing for all items. | 359 | contained in the agenda. It has to handle moving and resizing for all items. |
360 | */ | 360 | */ |
361 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) | 361 | bool KOAgenda::eventFilter ( QObject *object, QEvent *event ) |
362 | { | 362 | { |
363 | // kdDebug() << "KOAgenda::eventFilter" << endl; | 363 | // kdDebug() << "KOAgenda::eventFilter" << endl; |
364 | switch(event->type()) { | 364 | switch(event->type()) { |
365 | case QEvent::MouseButtonPress: | 365 | case QEvent::MouseButtonPress: |
366 | case QEvent::MouseButtonDblClick: | 366 | case QEvent::MouseButtonDblClick: |
367 | case QEvent::MouseButtonRelease: | 367 | case QEvent::MouseButtonRelease: |
368 | case QEvent::MouseMove: | 368 | case QEvent::MouseMove: |
369 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); | 369 | return eventFilter_mouse(object, static_cast<QMouseEvent *>(event)); |
370 | 370 | ||
371 | case (QEvent::Leave): | 371 | case (QEvent::Leave): |
@@ -629,258 +629,257 @@ bool KOAgenda::eventFilter_mouse(QObject *object, QMouseEvent *me) | |||
629 | } else { // ---------- viewport() | 629 | } else { // ---------- viewport() |
630 | selectItem(0); | 630 | selectItem(0); |
631 | mActionItem = 0; | 631 | mActionItem = 0; |
632 | if (me->button() == LeftButton ) { | 632 | if (me->button() == LeftButton ) { |
633 | setCursor(arrowCursor); | 633 | setCursor(arrowCursor); |
634 | startSelectAction(viewportPos); | 634 | startSelectAction(viewportPos); |
635 | } else if (me->button() == RightButton ) { | 635 | } else if (me->button() == RightButton ) { |
636 | setCursor(arrowCursor); | 636 | setCursor(arrowCursor); |
637 | if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action | 637 | if ( leftMouseDown ) { // we have a simulated right click - clear left mouse action |
638 | endSelectAction( false ); // do not emit new event signal | 638 | endSelectAction( false ); // do not emit new event signal |
639 | leftMouseDown = false; // no more leftMouse computation | 639 | leftMouseDown = false; // no more leftMouse computation |
640 | } | 640 | } |
641 | int x,y; | 641 | int x,y; |
642 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 642 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
643 | int gx,gy; | 643 | int gx,gy; |
644 | contentsToGrid(x,y,gx,gy); | 644 | contentsToGrid(x,y,gx,gy); |
645 | mCurrentCellX = gx; | 645 | mCurrentCellX = gx; |
646 | mCurrentCellY = gy; | 646 | mCurrentCellY = gy; |
647 | mStartCellX = gx; | 647 | mStartCellX = gx; |
648 | mStartCellY = gy; | 648 | mStartCellY = gy; |
649 | mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) ); | 649 | mNewItemPopup->popup( viewport()->mapToGlobal( me->pos() ) ); |
650 | } | 650 | } |
651 | } | 651 | } |
652 | break; | 652 | break; |
653 | 653 | ||
654 | case QEvent::MouseButtonRelease: | 654 | case QEvent::MouseButtonRelease: |
655 | 655 | ||
656 | if (object != viewport()) { | 656 | if (object != viewport()) { |
657 | if (me->button() == LeftButton && leftMouseDown) { | 657 | if (me->button() == LeftButton && leftMouseDown) { |
658 | if (mActionItem) { | 658 | if (mActionItem) { |
659 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 659 | QPoint clipperPos = clipper()->mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
660 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); | 660 | //qDebug(" %d %d %d ",clipperPos.y(),visibleHeight() , 9 ); |
661 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { | 661 | if ( mActionType == MOVE && (clipperPos.y() > visibleHeight()-2 ||clipperPos.y() < 0 ) ) { |
662 | mScrollUpTimer.stop(); | 662 | mScrollUpTimer.stop(); |
663 | mScrollDownTimer.stop(); | 663 | mScrollDownTimer.stop(); |
664 | mActionItem->resetMove(); | 664 | mActionItem->resetMove(); |
665 | placeSubCells( mActionItem ); | 665 | placeSubCells( mActionItem ); |
666 | // emit startDragSignal( mActionItem->incidence() ); | 666 | // emit startDragSignal( mActionItem->incidence() ); |
667 | setCursor( arrowCursor ); | 667 | setCursor( arrowCursor ); |
668 | mActionItem = 0; | 668 | mActionItem = 0; |
669 | mActionType = NOP; | 669 | mActionType = NOP; |
670 | mItemMoved = 0; | 670 | mItemMoved = 0; |
671 | leftMouseDown = false; | 671 | leftMouseDown = false; |
672 | return true; | 672 | return true; |
673 | } | 673 | } |
674 | endItemAction(); | 674 | endItemAction(); |
675 | } | 675 | } |
676 | } | 676 | } |
677 | 677 | ||
678 | } else { // ---------- viewport() | 678 | } else { // ---------- viewport() |
679 | if (me->button() == LeftButton && leftMouseDown ) { //left click | 679 | if (me->button() == LeftButton && leftMouseDown ) { //left click |
680 | endSelectAction( true ); // emit new event signal | 680 | endSelectAction( true ); // emit new event signal |
681 | } | 681 | } |
682 | } | 682 | } |
683 | if (me->button() == LeftButton) | 683 | if (me->button() == LeftButton) |
684 | leftMouseDown = false; | 684 | leftMouseDown = false; |
685 | 685 | ||
686 | break; | 686 | break; |
687 | 687 | ||
688 | case QEvent::MouseMove: | 688 | case QEvent::MouseMove: |
689 | if ( !leftMouseDown ) | 689 | if ( !leftMouseDown ) |
690 | return true; | 690 | return true; |
691 | if ( blockMoving ) { | 691 | if ( blockMoving ) { |
692 | int dX, dY; | 692 | int dX, dY; |
693 | dX = startX - viewportPos.x(); | 693 | dX = startX - viewportPos.x(); |
694 | if ( dX < 0 ) | 694 | if ( dX < 0 ) |
695 | dX = -dX; | 695 | dX = -dX; |
696 | dY = viewportPos.y() - startY; | 696 | dY = viewportPos.y() - startY; |
697 | if ( dY < 0 ) | 697 | if ( dY < 0 ) |
698 | dY = -dY; | 698 | dY = -dY; |
699 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); | 699 | //qDebug("%d %d %d ", dX, dY , blockmoveDist ); |
700 | if ( dX > blockmoveDist || dY > blockmoveDist ) { | 700 | if ( dX > blockmoveDist || dY > blockmoveDist ) { |
701 | blockMoving = false; | 701 | blockMoving = false; |
702 | } | 702 | } |
703 | } | 703 | } |
704 | if (object != viewport()) { | 704 | if (object != viewport()) { |
705 | KOAgendaItem *moveItem = (KOAgendaItem *)object; | 705 | KOAgendaItem *moveItem = (KOAgendaItem *)object; |
706 | if (!moveItem->incidence()->isReadOnly() ) { | 706 | if (!moveItem->incidence()->isReadOnly() ) { |
707 | if (!mActionItem) | 707 | if (!mActionItem) |
708 | setNoActionCursor(moveItem,viewportPos); | 708 | setNoActionCursor(moveItem,viewportPos); |
709 | else { | 709 | else { |
710 | if ( !blockMoving ) | 710 | if ( !blockMoving ) |
711 | performItemAction(viewportPos); | 711 | performItemAction(viewportPos); |
712 | } | 712 | } |
713 | } | 713 | } |
714 | } else { // ---------- viewport() | 714 | } else { // ---------- viewport() |
715 | if ( mActionType == SELECT ) { | 715 | if ( mActionType == SELECT ) { |
716 | performSelectAction( viewportPos ); | 716 | performSelectAction( viewportPos ); |
717 | } | 717 | } |
718 | } | 718 | } |
719 | break; | 719 | break; |
720 | 720 | ||
721 | case QEvent::MouseButtonDblClick: | 721 | case QEvent::MouseButtonDblClick: |
722 | blockMoving = false; | 722 | blockMoving = false; |
723 | leftMouseDown = false; | 723 | leftMouseDown = false; |
724 | if (object == viewport()) { | 724 | if (object == viewport()) { |
725 | selectItem(0); | 725 | selectItem(0); |
726 | int x,y; | 726 | int x,y; |
727 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 727 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
728 | int gx,gy; | 728 | int gx,gy; |
729 | contentsToGrid(x,y,gx,gy); | 729 | contentsToGrid(x,y,gx,gy); |
730 | emit newEventSignal(gx,gy); | 730 | emit newEventSignal(gx,gy); |
731 | } else { | 731 | } else { |
732 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; | 732 | KOAgendaItem *doubleClickedItem = (KOAgendaItem *)object; |
733 | selectItem(doubleClickedItem); | 733 | selectItem(doubleClickedItem); |
734 | if ( KOPrefs::instance()->mEditOnDoubleClick ) | 734 | if ( KOPrefs::instance()->mEditOnDoubleClick ) |
735 | emit editIncidenceSignal(doubleClickedItem->incidence()); | 735 | emit editIncidenceSignal(doubleClickedItem->incidence()); |
736 | else | 736 | else |
737 | emit showIncidenceSignal(doubleClickedItem->incidence()); | 737 | emit showIncidenceSignal(doubleClickedItem->incidence()); |
738 | } | 738 | } |
739 | break; | 739 | break; |
740 | 740 | ||
741 | default: | 741 | default: |
742 | break; | 742 | break; |
743 | } | 743 | } |
744 | return true; | 744 | return true; |
745 | #endif | 745 | #endif |
746 | } | 746 | } |
747 | 747 | ||
748 | void KOAgenda::newItem( int item ) | 748 | void KOAgenda::newItem( int item ) |
749 | { | 749 | { |
750 | if ( item == 1 ) { //new event | 750 | if ( item == 1 ) { //new event |
751 | newEventSignal(mStartCellX ,mStartCellY ); | 751 | newEventSignal(mStartCellX ,mStartCellY ); |
752 | } else | 752 | } else |
753 | if ( item == 2 ) { //new event | 753 | if ( item == 2 ) { //new event |
754 | newTodoSignal(mStartCellX ,mStartCellY ); | 754 | newTodoSignal(mStartCellX ,mStartCellY ); |
755 | } else | 755 | } else |
756 | { | 756 | { |
757 | QDate day = mSelectedDates[mStartCellX]; | 757 | emit showDateView( item, mStartCellX ); |
758 | emit showDateView( item, day ); | ||
759 | // 3Day view | 758 | // 3Day view |
760 | // 4Week view | 759 | // 4Week view |
761 | // 5Month view | 760 | // 5Month view |
762 | // 6Journal view | 761 | // 6Journal view |
763 | } | 762 | } |
764 | } | 763 | } |
765 | void KOAgenda::startSelectAction(QPoint viewportPos) | 764 | void KOAgenda::startSelectAction(QPoint viewportPos) |
766 | { | 765 | { |
767 | //emit newStartSelectSignal(); | 766 | //emit newStartSelectSignal(); |
768 | 767 | ||
769 | mActionType = SELECT; | 768 | mActionType = SELECT; |
770 | 769 | ||
771 | int x,y; | 770 | int x,y; |
772 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 771 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
773 | int gx,gy; | 772 | int gx,gy; |
774 | contentsToGrid(x,y,gx,gy); | 773 | contentsToGrid(x,y,gx,gy); |
775 | 774 | ||
776 | mStartCellX = gx; | 775 | mStartCellX = gx; |
777 | mStartCellY = gy; | 776 | mStartCellY = gy; |
778 | mCurrentCellX = gx; | 777 | mCurrentCellX = gx; |
779 | mCurrentCellY = gy; | 778 | mCurrentCellY = gy; |
780 | 779 | ||
781 | // Store coordinates of old selection | 780 | // Store coordinates of old selection |
782 | int selectionX = mSelectionCellX * mGridSpacingX; | 781 | int selectionX = mSelectionCellX * mGridSpacingX; |
783 | int selectionYTop = mSelectionYTop; | 782 | int selectionYTop = mSelectionYTop; |
784 | int selectionHeight = mSelectionHeight; | 783 | int selectionHeight = mSelectionHeight; |
785 | 784 | ||
786 | // Store new selection | 785 | // Store new selection |
787 | mSelectionCellX = gx; | 786 | mSelectionCellX = gx; |
788 | mSelectionYTop = gy * mGridSpacingY; | 787 | mSelectionYTop = gy * mGridSpacingY; |
789 | mSelectionHeight = mGridSpacingY; | 788 | mSelectionHeight = mGridSpacingY; |
790 | 789 | ||
791 | // Clear old selection | 790 | // Clear old selection |
792 | repaintContents( selectionX, selectionYTop, | 791 | repaintContents( selectionX, selectionYTop, |
793 | mGridSpacingX, selectionHeight,false ); | 792 | mGridSpacingX, selectionHeight,false ); |
794 | 793 | ||
795 | // Paint new selection | 794 | // Paint new selection |
796 | // repaintContents( mSelectionCellX * mGridSpacingX, mSelectionYTop, | 795 | // repaintContents( mSelectionCellX * mGridSpacingX, mSelectionYTop, |
797 | // mGridSpacingX, mSelectionHeight ); | 796 | // mGridSpacingX, mSelectionHeight ); |
798 | } | 797 | } |
799 | 798 | ||
800 | void KOAgenda::performSelectAction(QPoint viewportPos) | 799 | void KOAgenda::performSelectAction(QPoint viewportPos) |
801 | { | 800 | { |
802 | int x,y; | 801 | int x,y; |
803 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 802 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
804 | int gx,gy; | 803 | int gx,gy; |
805 | contentsToGrid(x,y,gx,gy); | 804 | contentsToGrid(x,y,gx,gy); |
806 | 805 | ||
807 | QPoint clipperPos = clipper()-> | 806 | QPoint clipperPos = clipper()-> |
808 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); | 807 | mapFromGlobal(viewport()->mapToGlobal(viewportPos)); |
809 | 808 | ||
810 | // Scroll if cursor was moved to upper or lower end of agenda. | 809 | // Scroll if cursor was moved to upper or lower end of agenda. |
811 | if (clipperPos.y() < mScrollBorderWidth) { | 810 | if (clipperPos.y() < mScrollBorderWidth) { |
812 | mScrollUpTimer.start(mScrollDelay); | 811 | mScrollUpTimer.start(mScrollDelay); |
813 | } else if (visibleHeight() - clipperPos.y() < | 812 | } else if (visibleHeight() - clipperPos.y() < |
814 | mScrollBorderWidth) { | 813 | mScrollBorderWidth) { |
815 | mScrollDownTimer.start(mScrollDelay); | 814 | mScrollDownTimer.start(mScrollDelay); |
816 | } else { | 815 | } else { |
817 | mScrollUpTimer.stop(); | 816 | mScrollUpTimer.stop(); |
818 | mScrollDownTimer.stop(); | 817 | mScrollDownTimer.stop(); |
819 | } | 818 | } |
820 | 819 | ||
821 | if ( gy > mCurrentCellY ) { | 820 | if ( gy > mCurrentCellY ) { |
822 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 821 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
823 | 822 | ||
824 | #if 0 | 823 | #if 0 |
825 | // FIXME: Repaint only the newly selected region | 824 | // FIXME: Repaint only the newly selected region |
826 | repaintContents( mSelectionCellX * mGridSpacingX, | 825 | repaintContents( mSelectionCellX * mGridSpacingX, |
827 | mCurrentCellY + mGridSpacingY, | 826 | mCurrentCellY + mGridSpacingY, |
828 | mGridSpacingX, | 827 | mGridSpacingX, |
829 | mSelectionHeight - ( gy - mCurrentCellY - 1 ) * mGridSpacingY ); | 828 | mSelectionHeight - ( gy - mCurrentCellY - 1 ) * mGridSpacingY ); |
830 | #else | 829 | #else |
831 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 830 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
832 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 831 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
833 | mGridSpacingX, mSelectionYTop, | 832 | mGridSpacingX, mSelectionYTop, |
834 | mGridSpacingX, mSelectionHeight , false); | 833 | mGridSpacingX, mSelectionHeight , false); |
835 | #endif | 834 | #endif |
836 | 835 | ||
837 | mCurrentCellY = gy; | 836 | mCurrentCellY = gy; |
838 | } else if ( gy < mCurrentCellY ) { | 837 | } else if ( gy < mCurrentCellY ) { |
839 | if ( gy >= mStartCellY ) { | 838 | if ( gy >= mStartCellY ) { |
840 | int selectionHeight = mSelectionHeight; | 839 | int selectionHeight = mSelectionHeight; |
841 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; | 840 | mSelectionHeight = ( gy + 1 ) * mGridSpacingY - mSelectionYTop; |
842 | 841 | ||
843 | repaintContents( (KOGlobals::self()->reverseLayout() ? | 842 | repaintContents( (KOGlobals::self()->reverseLayout() ? |
844 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * | 843 | mColumns - 1 - mSelectionCellX : mSelectionCellX) * |
845 | mGridSpacingX, mSelectionYTop, | 844 | mGridSpacingX, mSelectionYTop, |
846 | mGridSpacingX, selectionHeight,false ); | 845 | mGridSpacingX, selectionHeight,false ); |
847 | 846 | ||
848 | mCurrentCellY = gy; | 847 | mCurrentCellY = gy; |
849 | } else { | 848 | } else { |
850 | } | 849 | } |
851 | } | 850 | } |
852 | } | 851 | } |
853 | 852 | ||
854 | void KOAgenda::endSelectAction( bool emitNewEvent ) | 853 | void KOAgenda::endSelectAction( bool emitNewEvent ) |
855 | { | 854 | { |
856 | mActionType = NOP; | 855 | mActionType = NOP; |
857 | mScrollUpTimer.stop(); | 856 | mScrollUpTimer.stop(); |
858 | mScrollDownTimer.stop(); | 857 | mScrollDownTimer.stop(); |
859 | 858 | ||
860 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 859 | emit newTimeSpanSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
861 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { | 860 | if ( emitNewEvent && mStartCellY < mCurrentCellY ) { |
862 | qDebug("ew event signal "); | 861 | qDebug("ew event signal "); |
863 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); | 862 | emit newEventSignal(mStartCellX,mStartCellY,mCurrentCellX,mCurrentCellY); |
864 | } | 863 | } |
865 | } | 864 | } |
866 | 865 | ||
867 | void KOAgenda::startItemAction(QPoint viewportPos) | 866 | void KOAgenda::startItemAction(QPoint viewportPos) |
868 | { | 867 | { |
869 | int x,y; | 868 | int x,y; |
870 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); | 869 | viewportToContents(viewportPos.x(),viewportPos.y(),x,y); |
871 | int gx,gy; | 870 | int gx,gy; |
872 | contentsToGrid(x,y,gx,gy); | 871 | contentsToGrid(x,y,gx,gy); |
873 | 872 | ||
874 | mStartCellX = gx; | 873 | mStartCellX = gx; |
875 | mStartCellY = gy; | 874 | mStartCellY = gy; |
876 | mCurrentCellX = gx; | 875 | mCurrentCellX = gx; |
877 | mCurrentCellY = gy; | 876 | mCurrentCellY = gy; |
878 | 877 | ||
879 | if (mAllDayMode) { | 878 | if (mAllDayMode) { |
880 | int gridDistanceX = (x - gx * mGridSpacingX); | 879 | int gridDistanceX = (x - gx * mGridSpacingX); |
881 | if (gridDistanceX < mResizeBorderWidth && | 880 | if (gridDistanceX < mResizeBorderWidth && |
882 | mActionItem->cellX() == mCurrentCellX) { | 881 | mActionItem->cellX() == mCurrentCellX) { |
883 | mActionType = RESIZELEFT; | 882 | mActionType = RESIZELEFT; |
884 | setCursor(sizeHorCursor); | 883 | setCursor(sizeHorCursor); |
885 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && | 884 | } else if ((mGridSpacingX - gridDistanceX) < mResizeBorderWidth && |
886 | mActionItem->cellXWidth() == mCurrentCellX) { | 885 | mActionItem->cellXWidth() == mCurrentCellX) { |
diff --git a/korganizer/koagenda.h b/korganizer/koagenda.h index 3d33ae5..35c08b6 100644 --- a/korganizer/koagenda.h +++ b/korganizer/koagenda.h | |||
@@ -20,257 +20,257 @@ | |||
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 | #ifndef KOAGENDA_H | 23 | #ifndef KOAGENDA_H |
24 | #define KOAGENDA_H | 24 | #define KOAGENDA_H |
25 | 25 | ||
26 | #include <qscrollview.h> | 26 | #include <qscrollview.h> |
27 | #include <qtimer.h> | 27 | #include <qtimer.h> |
28 | #include <qmemarray.h> | 28 | #include <qmemarray.h> |
29 | #include <qpainter.h> | 29 | #include <qpainter.h> |
30 | #include <qpixmap.h> | 30 | #include <qpixmap.h> |
31 | #include <qguardedptr.h> | 31 | #include <qguardedptr.h> |
32 | 32 | ||
33 | #include "koagendaitem.h" | 33 | #include "koagendaitem.h" |
34 | 34 | ||
35 | class QPopupMenu; | 35 | class QPopupMenu; |
36 | class QTime; | 36 | class QTime; |
37 | class KConfig; | 37 | class KConfig; |
38 | class QFrame; | 38 | class QFrame; |
39 | class KOAgenda; | 39 | class KOAgenda; |
40 | class KCal::Event; | 40 | class KCal::Event; |
41 | class KCal::Todo; | 41 | class KCal::Todo; |
42 | 42 | ||
43 | using namespace KCal; | 43 | using namespace KCal; |
44 | 44 | ||
45 | class MarcusBains : public QFrame { | 45 | class MarcusBains : public QFrame { |
46 | Q_OBJECT | 46 | Q_OBJECT |
47 | public: | 47 | public: |
48 | MarcusBains(KOAgenda *agenda=0,const char *name=0); | 48 | MarcusBains(KOAgenda *agenda=0,const char *name=0); |
49 | virtual ~MarcusBains(); | 49 | virtual ~MarcusBains(); |
50 | 50 | ||
51 | public slots: | 51 | public slots: |
52 | void updateLocation(bool recalculate=false); | 52 | void updateLocation(bool recalculate=false); |
53 | void updateLoc(); | 53 | void updateLoc(); |
54 | 54 | ||
55 | private: | 55 | private: |
56 | int todayColumn(); | 56 | int todayColumn(); |
57 | QTimer *minutes; | 57 | QTimer *minutes; |
58 | QLabel *mTimeBox; | 58 | QLabel *mTimeBox; |
59 | KOAgenda *agenda; | 59 | KOAgenda *agenda; |
60 | QTime oldTime; | 60 | QTime oldTime; |
61 | int oldToday; | 61 | int oldToday; |
62 | }; | 62 | }; |
63 | 63 | ||
64 | 64 | ||
65 | class KOAgenda : public QScrollView | 65 | class KOAgenda : public QScrollView |
66 | { | 66 | { |
67 | Q_OBJECT | 67 | Q_OBJECT |
68 | public: | 68 | public: |
69 | enum MouseActionType { NOP, MOVE, SELECT, | 69 | enum MouseActionType { NOP, MOVE, SELECT, |
70 | RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT }; | 70 | RESIZETOP, RESIZEBOTTOM, RESIZELEFT, RESIZERIGHT }; |
71 | 71 | ||
72 | KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0, | 72 | KOAgenda ( int columns, int rows, int columnSize, QWidget * parent=0, |
73 | const char * name=0, WFlags f=0 ); | 73 | const char * name=0, WFlags f=0 ); |
74 | KOAgenda ( int columns, QWidget * parent=0, | 74 | KOAgenda ( int columns, QWidget * parent=0, |
75 | const char * name=0, WFlags f=0 ); | 75 | const char * name=0, WFlags f=0 ); |
76 | virtual ~KOAgenda(); | 76 | virtual ~KOAgenda(); |
77 | 77 | ||
78 | Incidence *selectedIncidence() const; | 78 | Incidence *selectedIncidence() const; |
79 | QDate selectedIncidenceDate() const; | 79 | QDate selectedIncidenceDate() const; |
80 | 80 | ||
81 | virtual bool eventFilter ( QObject *, QEvent * ); | 81 | virtual bool eventFilter ( QObject *, QEvent * ); |
82 | 82 | ||
83 | void contentsToGrid (int x, int y, int& gx, int& gy); | 83 | void contentsToGrid (int x, int y, int& gx, int& gy); |
84 | void gridToContents (int gx, int gy, int& x, int& y); | 84 | void gridToContents (int gx, int gy, int& x, int& y); |
85 | 85 | ||
86 | int timeToY (const QTime &time); | 86 | int timeToY (const QTime &time); |
87 | QTime gyToTime (int y); | 87 | QTime gyToTime (int y); |
88 | 88 | ||
89 | void setStartHour(int startHour); | 89 | void setStartHour(int startHour); |
90 | 90 | ||
91 | KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom); | 91 | KOAgendaItem *insertItem (Incidence *event,QDate qd,int X,int YTop,int YBottom); |
92 | KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd); | 92 | KOAgendaItem *insertAllDayItem (Incidence *event,QDate qd,int XBegin,int XEnd); |
93 | void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, | 93 | void insertMultiItem (Event *event,QDate qd,int XBegin,int XEnd, |
94 | int YTop,int YBottom); | 94 | int YTop,int YBottom); |
95 | 95 | ||
96 | void changeColumns(int columns); | 96 | void changeColumns(int columns); |
97 | 97 | ||
98 | int columns() { return mColumns; } | 98 | int columns() { return mColumns; } |
99 | int rows() { return mRows; } | 99 | int rows() { return mRows; } |
100 | 100 | ||
101 | int gridSpacingX() const { return mGridSpacingX; } | 101 | int gridSpacingX() const { return mGridSpacingX; } |
102 | int gridSpacingY() const { return mGridSpacingY; } | 102 | int gridSpacingY() const { return mGridSpacingY; } |
103 | 103 | ||
104 | // virtual QSizePolicy sizePolicy() const; | 104 | // virtual QSizePolicy sizePolicy() const; |
105 | 105 | ||
106 | void clear(); | 106 | void clear(); |
107 | 107 | ||
108 | void clearSelection(); | 108 | void clearSelection(); |
109 | void hideUnused(); | 109 | void hideUnused(); |
110 | 110 | ||
111 | /** Calculates the minimum width */ | 111 | /** Calculates the minimum width */ |
112 | virtual int minimumWidth() const; | 112 | virtual int minimumWidth() const; |
113 | /** Update configuration from preference settings */ | 113 | /** Update configuration from preference settings */ |
114 | void updateConfig(); | 114 | void updateConfig(); |
115 | 115 | ||
116 | void checkScrollBoundaries(); | 116 | void checkScrollBoundaries(); |
117 | 117 | ||
118 | void setHolidayMask(QMemArray<bool> *); | 118 | void setHolidayMask(QMemArray<bool> *); |
119 | void setDateList(const DateList &selectedDates); | 119 | void setDateList(const DateList &selectedDates); |
120 | DateList dateList() const; | 120 | DateList dateList() const; |
121 | void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false); | 121 | void drawContentsToPainter( QPainter* paint = 0, bool backgroundOnly = false); |
122 | void finishUpdate(); | 122 | void finishUpdate(); |
123 | void printSelection(); | 123 | void printSelection(); |
124 | void storePosition(); | 124 | void storePosition(); |
125 | void restorePosition(); | 125 | void restorePosition(); |
126 | 126 | ||
127 | 127 | ||
128 | public slots: | 128 | public slots: |
129 | void popupMenu(); | 129 | void popupMenu(); |
130 | void newItem( int ); | 130 | void newItem( int ); |
131 | void moveChild( QWidget *, int, int ); | 131 | void moveChild( QWidget *, int, int ); |
132 | void scrollUp(); | 132 | void scrollUp(); |
133 | void scrollDown(); | 133 | void scrollDown(); |
134 | void updateTodo( Todo * t, int , bool ); | 134 | void updateTodo( Todo * t, int , bool ); |
135 | void popupAlarm(); | 135 | void popupAlarm(); |
136 | 136 | ||
137 | void checkScrollBoundaries(int); | 137 | void checkScrollBoundaries(int); |
138 | 138 | ||
139 | /** Deselect selected items. This function does not emit any signals. */ | 139 | /** Deselect selected items. This function does not emit any signals. */ |
140 | void deselectItem(); | 140 | void deselectItem(); |
141 | /** Select item. If the argument is 0, the currently selected item gets | 141 | /** Select item. If the argument is 0, the currently selected item gets |
142 | deselected. This function emits the itemSelected(bool) signal to inform | 142 | deselected. This function emits the itemSelected(bool) signal to inform |
143 | about selection/deseelction of events. */ | 143 | about selection/deseelction of events. */ |
144 | void selectItem(KOAgendaItem *); | 144 | void selectItem(KOAgendaItem *); |
145 | void finishResize(); | 145 | void finishResize(); |
146 | 146 | ||
147 | signals: | 147 | signals: |
148 | void showDateView( int, QDate ); | 148 | void showDateView( int, int); |
149 | void newEventSignal(); | 149 | void newEventSignal(); |
150 | void newEventSignal(int gx,int gy); | 150 | void newEventSignal(int gx,int gy); |
151 | void newTodoSignal(int gx,int gy); | 151 | void newTodoSignal(int gx,int gy); |
152 | void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); | 152 | void newEventSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); |
153 | void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); | 153 | void newTimeSpanSignal(int gxStart, int gyStart, int gxEnd, int gyEnd); |
154 | void newStartSelectSignal(); | 154 | void newStartSelectSignal(); |
155 | void showIncidenceSignal(Incidence *); | 155 | void showIncidenceSignal(Incidence *); |
156 | void editIncidenceSignal(Incidence *); | 156 | void editIncidenceSignal(Incidence *); |
157 | void deleteIncidenceSignal(Incidence *); | 157 | void deleteIncidenceSignal(Incidence *); |
158 | void showIncidencePopupSignal(Incidence *); | 158 | void showIncidencePopupSignal(Incidence *); |
159 | 159 | ||
160 | void itemModified(KOAgendaItem *item, int ); | 160 | void itemModified(KOAgendaItem *item, int ); |
161 | void incidenceSelected(Incidence *); | 161 | void incidenceSelected(Incidence *); |
162 | 162 | ||
163 | void lowerYChanged(int); | 163 | void lowerYChanged(int); |
164 | void upperYChanged(int); | 164 | void upperYChanged(int); |
165 | 165 | ||
166 | void startDragSignal(Incidence *); | 166 | void startDragSignal(Incidence *); |
167 | void addToCalSignal(Incidence *, Incidence *); | 167 | void addToCalSignal(Incidence *, Incidence *); |
168 | void resizedSignal(); | 168 | void resizedSignal(); |
169 | 169 | ||
170 | protected: | 170 | protected: |
171 | QPainter mPixPainter; | 171 | QPainter mPixPainter; |
172 | QPixmap mPaintPixmap; | 172 | QPixmap mPaintPixmap; |
173 | QPixmap mHighlightPixmap; | 173 | QPixmap mHighlightPixmap; |
174 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); | 174 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); |
175 | virtual void resizeEvent ( QResizeEvent * ); | 175 | virtual void resizeEvent ( QResizeEvent * ); |
176 | 176 | ||
177 | /** Handles mouse events. Called from eventFilter */ | 177 | /** Handles mouse events. Called from eventFilter */ |
178 | virtual bool eventFilter_mouse ( QObject *, QMouseEvent * ); | 178 | virtual bool eventFilter_mouse ( QObject *, QMouseEvent * ); |
179 | 179 | ||
180 | /** Start selecting time span. */ | 180 | /** Start selecting time span. */ |
181 | void startSelectAction(QPoint viewportPos); | 181 | void startSelectAction(QPoint viewportPos); |
182 | 182 | ||
183 | /** Select time span. */ | 183 | /** Select time span. */ |
184 | void performSelectAction(QPoint viewportPos); | 184 | void performSelectAction(QPoint viewportPos); |
185 | 185 | ||
186 | /** Emd selecting time span. */ | 186 | /** Emd selecting time span. */ |
187 | void endSelectAction( bool emitNewEvent = false ); | 187 | void endSelectAction( bool emitNewEvent = false ); |
188 | 188 | ||
189 | /** Start moving/resizing agenda item */ | 189 | /** Start moving/resizing agenda item */ |
190 | void startItemAction(QPoint viewportPos); | 190 | void startItemAction(QPoint viewportPos); |
191 | 191 | ||
192 | /** Move/resize agenda item */ | 192 | /** Move/resize agenda item */ |
193 | void performItemAction(QPoint viewportPos); | 193 | void performItemAction(QPoint viewportPos); |
194 | 194 | ||
195 | /** End moving/resizing agenda item */ | 195 | /** End moving/resizing agenda item */ |
196 | void endItemAction(); | 196 | void endItemAction(); |
197 | 197 | ||
198 | /** Set cursor, when no item action is in progress */ | 198 | /** Set cursor, when no item action is in progress */ |
199 | void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos); | 199 | void setNoActionCursor(KOAgendaItem *moveItem,QPoint viewportPos); |
200 | 200 | ||
201 | /** Place agenda item in agenda and adjust other cells if necessary */ | 201 | /** Place agenda item in agenda and adjust other cells if necessary */ |
202 | void placeSubCells(KOAgendaItem *placeItem); | 202 | void placeSubCells(KOAgendaItem *placeItem); |
203 | 203 | ||
204 | /** Process the keyevent, including the ignored keyevents of eventwidgets. | 204 | /** Process the keyevent, including the ignored keyevents of eventwidgets. |
205 | * Implements pgup/pgdn and cursor key navigation in the view. | 205 | * Implements pgup/pgdn and cursor key navigation in the view. |
206 | */ | 206 | */ |
207 | void keyPressEvent( QKeyEvent * ); | 207 | void keyPressEvent( QKeyEvent * ); |
208 | 208 | ||
209 | void calculateWorkingHours(); | 209 | void calculateWorkingHours(); |
210 | 210 | ||
211 | virtual void contentsMousePressEvent ( QMouseEvent * ); | 211 | virtual void contentsMousePressEvent ( QMouseEvent * ); |
212 | 212 | ||
213 | private: | 213 | private: |
214 | void init(); | 214 | void init(); |
215 | void marcus_bains(); | 215 | void marcus_bains(); |
216 | bool mAllDayMode; | 216 | bool mAllDayMode; |
217 | bool blockResize; | 217 | bool blockResize; |
218 | bool mLeftMouseDown; | 218 | bool mLeftMouseDown; |
219 | KOAgendaItem *mPopupItem; | 219 | KOAgendaItem *mPopupItem; |
220 | QTimer* mPopupTimer; | 220 | QTimer* mPopupTimer; |
221 | int mPopupKind; | 221 | int mPopupKind; |
222 | QPoint mPopupPos; | 222 | QPoint mPopupPos; |
223 | QTimer mResizeTimer; | 223 | QTimer mResizeTimer; |
224 | double mContentPosition; | 224 | double mContentPosition; |
225 | 225 | ||
226 | // Width and height of agenda cells | 226 | // Width and height of agenda cells |
227 | int mGridSpacingX; | 227 | int mGridSpacingX; |
228 | int mGridSpacingY; | 228 | int mGridSpacingY; |
229 | 229 | ||
230 | // size of border, where mouse action will resize the KOAgendaItem | 230 | // size of border, where mouse action will resize the KOAgendaItem |
231 | int mResizeBorderWidth; | 231 | int mResizeBorderWidth; |
232 | 232 | ||
233 | // size of border, where mouse mve will cause a scroll of the agenda | 233 | // size of border, where mouse mve will cause a scroll of the agenda |
234 | int mScrollBorderWidth; | 234 | int mScrollBorderWidth; |
235 | int mScrollDelay; | 235 | int mScrollDelay; |
236 | int mScrollOffset; | 236 | int mScrollOffset; |
237 | 237 | ||
238 | QTimer mScrollUpTimer; | 238 | QTimer mScrollUpTimer; |
239 | QTimer mScrollDownTimer; | 239 | QTimer mScrollDownTimer; |
240 | 240 | ||
241 | // Number of Columns/Rows of agenda grid | 241 | // Number of Columns/Rows of agenda grid |
242 | int mColumns; | 242 | int mColumns; |
243 | int mRows; | 243 | int mRows; |
244 | 244 | ||
245 | // Cells to store Move and Resize coordiantes | 245 | // Cells to store Move and Resize coordiantes |
246 | int mStartCellX; | 246 | int mStartCellX; |
247 | int mStartCellY; | 247 | int mStartCellY; |
248 | int mCurrentCellX; | 248 | int mCurrentCellX; |
249 | int mCurrentCellY; | 249 | int mCurrentCellY; |
250 | 250 | ||
251 | // Working Hour coordiantes | 251 | // Working Hour coordiantes |
252 | bool mWorkingHoursEnable; | 252 | bool mWorkingHoursEnable; |
253 | int mWorkingHoursYTop; | 253 | int mWorkingHoursYTop; |
254 | int mWorkingHoursYBottom; | 254 | int mWorkingHoursYBottom; |
255 | 255 | ||
256 | // Selection | 256 | // Selection |
257 | int mSelectionCellX; | 257 | int mSelectionCellX; |
258 | int mSelectionYTop; | 258 | int mSelectionYTop; |
259 | int mSelectionHeight; | 259 | int mSelectionHeight; |
260 | 260 | ||
261 | // List of dates to be displayed | 261 | // List of dates to be displayed |
262 | DateList mSelectedDates; | 262 | DateList mSelectedDates; |
263 | 263 | ||
264 | // The KOAgendaItem, which has been right-clicked last | 264 | // The KOAgendaItem, which has been right-clicked last |
265 | KOAgendaItem *mClickedItem; | 265 | KOAgendaItem *mClickedItem; |
266 | 266 | ||
267 | // The KOAgendaItem, which is being moved/resized | 267 | // The KOAgendaItem, which is being moved/resized |
268 | QGuardedPtr<KOAgendaItem> mActionItem; | 268 | QGuardedPtr<KOAgendaItem> mActionItem; |
269 | 269 | ||
270 | // Currently selected item | 270 | // Currently selected item |
271 | QGuardedPtr<KOAgendaItem> mSelectedItem; | 271 | QGuardedPtr<KOAgendaItem> mSelectedItem; |
272 | 272 | ||
273 | // The Marcus Bains Line widget. | 273 | // The Marcus Bains Line widget. |
274 | MarcusBains *mMarcusBains; | 274 | MarcusBains *mMarcusBains; |
275 | void computeSizes(); | 275 | void computeSizes(); |
276 | 276 | ||
diff --git a/korganizer/koagendaview.cpp b/korganizer/koagendaview.cpp index b9909d6..2996acb 100644 --- a/korganizer/koagendaview.cpp +++ b/korganizer/koagendaview.cpp | |||
@@ -363,258 +363,258 @@ void EventIndicator::enableColumn(int column, bool enable) | |||
363 | mEnabled[column] = enable; | 363 | mEnabled[column] = enable; |
364 | } | 364 | } |
365 | 365 | ||
366 | 366 | ||
367 | //////////////////////////////////////////////////////////////////////////// | 367 | //////////////////////////////////////////////////////////////////////////// |
368 | //////////////////////////////////////////////////////////////////////////// | 368 | //////////////////////////////////////////////////////////////////////////// |
369 | //////////////////////////////////////////////////////////////////////////// | 369 | //////////////////////////////////////////////////////////////////////////// |
370 | 370 | ||
371 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : | 371 | KOAgendaView::KOAgendaView(Calendar *cal,QWidget *parent,const char *name) : |
372 | KOEventView (cal,parent,name) | 372 | KOEventView (cal,parent,name) |
373 | { | 373 | { |
374 | mBlockUpdating = true; | 374 | mBlockUpdating = true; |
375 | mStartHour = 8; | 375 | mStartHour = 8; |
376 | mSelectedDates.append(QDate::currentDate()); | 376 | mSelectedDates.append(QDate::currentDate()); |
377 | 377 | ||
378 | mLayoutDayLabels = 0; | 378 | mLayoutDayLabels = 0; |
379 | mDayLabelsFrame = 0; | 379 | mDayLabelsFrame = 0; |
380 | mDayLabels = 0; | 380 | mDayLabels = 0; |
381 | bool isRTL = KOGlobals::self()->reverseLayout(); | 381 | bool isRTL = KOGlobals::self()->reverseLayout(); |
382 | QPixmap expandPix; | 382 | QPixmap expandPix; |
383 | if ( KOPrefs::instance()->mVerticalScreen ) { | 383 | if ( KOPrefs::instance()->mVerticalScreen ) { |
384 | expandPix = SmallIcon( "1updownarrow" ); | 384 | expandPix = SmallIcon( "1updownarrow" ); |
385 | } else { | 385 | } else { |
386 | expandPix = SmallIcon("1leftrightarrow" ); | 386 | expandPix = SmallIcon("1leftrightarrow" ); |
387 | } | 387 | } |
388 | 388 | ||
389 | QBoxLayout *topLayout = new QVBoxLayout(this); | 389 | QBoxLayout *topLayout = new QVBoxLayout(this); |
390 | 390 | ||
391 | // Create day name labels for agenda columns | 391 | // Create day name labels for agenda columns |
392 | // Create agenda splitter | 392 | // Create agenda splitter |
393 | 393 | ||
394 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); | 394 | mSplitterAgenda = new KDGanttMinimizeSplitter( Qt::Vertical, this); |
395 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); | 395 | mSplitterAgenda->setMinimizeDirection ( KDGanttMinimizeSplitter::Up ); |
396 | topLayout->addWidget( mSplitterAgenda ); | 396 | topLayout->addWidget( mSplitterAgenda ); |
397 | mAllDayFrame = new QHBox(mSplitterAgenda); | 397 | mAllDayFrame = new QHBox(mSplitterAgenda); |
398 | mAllDayFrame->setFocusPolicy(NoFocus); | 398 | mAllDayFrame->setFocusPolicy(NoFocus); |
399 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); | 399 | QWidget *agendaFrame = new QWidget(mSplitterAgenda); |
400 | agendaFrame->setFocusPolicy(NoFocus); | 400 | agendaFrame->setFocusPolicy(NoFocus); |
401 | 401 | ||
402 | // Create all-day agenda widget | 402 | // Create all-day agenda widget |
403 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); | 403 | mDummyAllDayLeft = new QVBox( mAllDayFrame ); |
404 | 404 | ||
405 | mExpandButton = new QPushButton(mDummyAllDayLeft); | 405 | mExpandButton = new QPushButton(mDummyAllDayLeft); |
406 | mExpandButton->setPixmap( expandPix ); | 406 | mExpandButton->setPixmap( expandPix ); |
407 | int widebut = mExpandButton->sizeHint().width()+4; | 407 | int widebut = mExpandButton->sizeHint().width()+4; |
408 | int heibut = mExpandButton->sizeHint().height()+4; | 408 | int heibut = mExpandButton->sizeHint().height()+4; |
409 | if ( heibut > widebut ) | 409 | if ( heibut > widebut ) |
410 | widebut = heibut ; | 410 | widebut = heibut ; |
411 | if ( QApplication::desktop()->width() < 480 ) | 411 | if ( QApplication::desktop()->width() < 480 ) |
412 | widebut = widebut*3/2; | 412 | widebut = widebut*3/2; |
413 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, | 413 | //mExpandButton->setSizePolicy( QSizePolicy( QSizePolicy::Fixed, |
414 | // QSizePolicy::Fixed ) ); | 414 | // QSizePolicy::Fixed ) ); |
415 | mExpandButton->setFixedSize( widebut, widebut); | 415 | mExpandButton->setFixedSize( widebut, widebut); |
416 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); | 416 | connect( mExpandButton, SIGNAL( clicked() ), SIGNAL( toggleExpand() ) ); |
417 | mExpandButton->setFocusPolicy(NoFocus); | 417 | mExpandButton->setFocusPolicy(NoFocus); |
418 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); | 418 | mAllDayAgenda = new KOAgenda(1,mAllDayFrame); |
419 | mAllDayAgenda->setFocusPolicy(NoFocus); | 419 | mAllDayAgenda->setFocusPolicy(NoFocus); |
420 | QLabel *dummyAllDayRight = new QLabel (mAllDayFrame); | 420 | QLabel *dummyAllDayRight = new QLabel (mAllDayFrame); |
421 | 421 | ||
422 | // Create event context menu for all day agenda | 422 | // Create event context menu for all day agenda |
423 | mAllDayAgendaPopup = eventPopup(); | 423 | mAllDayAgendaPopup = eventPopup(); |
424 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 424 | connect(mAllDayAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
425 | mAllDayAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 425 | mAllDayAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
426 | 426 | ||
427 | // Create agenda frame | 427 | // Create agenda frame |
428 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3); | 428 | QGridLayout *agendaLayout = new QGridLayout(agendaFrame,4,3); |
429 | // QHBox *agendaFrame = new QHBox(splitterAgenda); | 429 | // QHBox *agendaFrame = new QHBox(splitterAgenda); |
430 | 430 | ||
431 | // create event indicator bars | 431 | // create event indicator bars |
432 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); | 432 | mEventIndicatorTop = new EventIndicator(EventIndicator::Top,agendaFrame); |
433 | #ifndef DESKTOP_VERSION | 433 | #ifndef DESKTOP_VERSION |
434 | // FIX | 434 | // FIX |
435 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); | 435 | mEventIndicatorTop->setPaintWidget( mSplitterAgenda ); |
436 | #endif | 436 | #endif |
437 | mDayLabelsFrame = new QHBox(agendaFrame); | 437 | mDayLabelsFrame = new QHBox(agendaFrame); |
438 | //topLayout->addWidget(mDayLabelsFrame); | 438 | //topLayout->addWidget(mDayLabelsFrame); |
439 | mDayLabels = new QFrame (mDayLabelsFrame); | 439 | mDayLabels = new QFrame (mDayLabelsFrame); |
440 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); | 440 | mLayoutDayLabels = new QHBoxLayout(mDayLabels); |
441 | agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2); | 441 | agendaLayout->addMultiCellWidget(mDayLabelsFrame ,0,0,0,2); |
442 | agendaLayout->addWidget(mEventIndicatorTop,1,1); | 442 | agendaLayout->addWidget(mEventIndicatorTop,1,1); |
443 | 443 | ||
444 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, | 444 | mEventIndicatorBottom = new EventIndicator(EventIndicator::Bottom, |
445 | agendaFrame); | 445 | agendaFrame); |
446 | agendaLayout->addWidget(mEventIndicatorBottom,3,1); | 446 | agendaLayout->addWidget(mEventIndicatorBottom,3,1); |
447 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); | 447 | QWidget *dummyAgendaRight = new QWidget(agendaFrame); |
448 | agendaLayout->addWidget(dummyAgendaRight,1,2); | 448 | agendaLayout->addWidget(dummyAgendaRight,1,2); |
449 | 449 | ||
450 | // Create time labels | 450 | // Create time labels |
451 | mTimeLabels = new TimeLabels(24,agendaFrame); | 451 | mTimeLabels = new TimeLabels(24,agendaFrame); |
452 | agendaLayout->addWidget(mTimeLabels,2,0); | 452 | agendaLayout->addWidget(mTimeLabels,2,0); |
453 | connect(mTimeLabels,SIGNAL( scaleChanged()), | 453 | connect(mTimeLabels,SIGNAL( scaleChanged()), |
454 | this,SLOT(updateConfig())); | 454 | this,SLOT(updateConfig())); |
455 | 455 | ||
456 | // Create agenda | 456 | // Create agenda |
457 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); | 457 | mAgenda = new KOAgenda(1,96,KOPrefs::instance()->mHourSize,agendaFrame); |
458 | agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2); | 458 | agendaLayout->addMultiCellWidget(mAgenda,2,2,1,2); |
459 | agendaLayout->setColStretch(1,1); | 459 | agendaLayout->setColStretch(1,1); |
460 | mAgenda->setFocusPolicy(NoFocus); | 460 | mAgenda->setFocusPolicy(NoFocus); |
461 | // Create event context menu for agenda | 461 | // Create event context menu for agenda |
462 | mAgendaPopup = eventPopup(); | 462 | mAgendaPopup = eventPopup(); |
463 | 463 | ||
464 | mAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), | 464 | mAgendaPopup->addAdditionalItem(QIconSet(SmallIcon("bell")), |
465 | i18n("Toggle Alarm"),mAgenda, | 465 | i18n("Toggle Alarm"),mAgenda, |
466 | SLOT(popupAlarm()),true); | 466 | SLOT(popupAlarm()),true); |
467 | 467 | ||
468 | 468 | ||
469 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), | 469 | connect(mAgenda,SIGNAL(showIncidencePopupSignal(Incidence *)), |
470 | mAgendaPopup,SLOT(showIncidencePopup(Incidence *))); | 470 | mAgendaPopup,SLOT(showIncidencePopup(Incidence *))); |
471 | 471 | ||
472 | // make connections between dependent widgets | 472 | // make connections between dependent widgets |
473 | mTimeLabels->setAgenda(mAgenda); | 473 | mTimeLabels->setAgenda(mAgenda); |
474 | 474 | ||
475 | // Update widgets to reflect user preferences | 475 | // Update widgets to reflect user preferences |
476 | // updateConfig(); | 476 | // updateConfig(); |
477 | 477 | ||
478 | // createDayLabels(); | 478 | // createDayLabels(); |
479 | 479 | ||
480 | // these blank widgets make the All Day Event box line up with the agenda | 480 | // these blank widgets make the All Day Event box line up with the agenda |
481 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 481 | dummyAllDayRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
482 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); | 482 | dummyAgendaRight->setFixedWidth(mAgenda->verticalScrollBar()->width()); |
483 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); | 483 | mDummyAllDayLeft->setFixedWidth(mTimeLabels->width()); |
484 | 484 | ||
485 | // Scrolling | 485 | // Scrolling |
486 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), | 486 | connect(mAgenda->verticalScrollBar(),SIGNAL(valueChanged(int)), |
487 | mTimeLabels, SLOT(positionChanged())); | 487 | mTimeLabels, SLOT(positionChanged())); |
488 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), | 488 | connect(mTimeLabels->verticalScrollBar(),SIGNAL(valueChanged(int)), |
489 | SLOT(setContentsPos(int))); | 489 | SLOT(setContentsPos(int))); |
490 | 490 | ||
491 | connect(mAgenda,SIGNAL(showDateView( int, QDate )),SIGNAL(showDateView( int, QDate ))); | 491 | connect(mAgenda,SIGNAL(showDateView( int, int)),SLOT(slotShowDateView( int, int ))); |
492 | connect(mAllDayAgenda,SIGNAL(showDateView( int, QDate )),SIGNAL(showDateView( int, QDate ))); | 492 | connect(mAllDayAgenda,SIGNAL(showDateView( int, int )), SLOT(slotShowDateView( int, int ) )); |
493 | 493 | ||
494 | // Create/Show/Edit/Delete Event | 494 | // Create/Show/Edit/Delete Event |
495 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), | 495 | connect(mAgenda,SIGNAL(newEventSignal(int,int)), |
496 | SLOT(newEvent(int,int))); | 496 | SLOT(newEvent(int,int))); |
497 | connect(mAgenda,SIGNAL(newTodoSignal(int,int)), | 497 | connect(mAgenda,SIGNAL(newTodoSignal(int,int)), |
498 | SLOT(newTodo(int,int))); | 498 | SLOT(newTodo(int,int))); |
499 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 499 | connect(mAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
500 | SLOT(newEvent(int,int,int,int))); | 500 | SLOT(newEvent(int,int,int,int))); |
501 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), | 501 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int)), |
502 | SLOT(newEventAllDay(int,int))); | 502 | SLOT(newEventAllDay(int,int))); |
503 | connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)), | 503 | connect(mAllDayAgenda,SIGNAL(newTodoSignal(int,int)), |
504 | SLOT(newTodoAllDay(int,int))); | 504 | SLOT(newTodoAllDay(int,int))); |
505 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), | 505 | connect(mAllDayAgenda,SIGNAL(newEventSignal(int,int,int,int)), |
506 | SLOT(newEventAllDay(int,int))); | 506 | SLOT(newEventAllDay(int,int))); |
507 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 507 | connect(mAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
508 | SLOT(newTimeSpanSelected(int,int,int,int))); | 508 | SLOT(newTimeSpanSelected(int,int,int,int))); |
509 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), | 509 | connect(mAllDayAgenda,SIGNAL(newTimeSpanSignal(int,int,int,int)), |
510 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); | 510 | SLOT(newTimeSpanSelectedAllDay(int,int,int,int))); |
511 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 511 | connect(mAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
512 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); | 512 | connect(mAllDayAgenda,SIGNAL(newStartSelectSignal()),SLOT(updateView())); |
513 | 513 | ||
514 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 514 | connect(mAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
515 | SIGNAL(editIncidenceSignal(Incidence *))); | 515 | SIGNAL(editIncidenceSignal(Incidence *))); |
516 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), | 516 | connect(mAllDayAgenda,SIGNAL(editIncidenceSignal(Incidence *)), |
517 | SIGNAL(editIncidenceSignal(Incidence *))); | 517 | SIGNAL(editIncidenceSignal(Incidence *))); |
518 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 518 | connect(mAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
519 | SIGNAL(showIncidenceSignal(Incidence *))); | 519 | SIGNAL(showIncidenceSignal(Incidence *))); |
520 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), | 520 | connect(mAllDayAgenda,SIGNAL(showIncidenceSignal(Incidence *)), |
521 | SIGNAL(showIncidenceSignal(Incidence *))); | 521 | SIGNAL(showIncidenceSignal(Incidence *))); |
522 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 522 | connect(mAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
523 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 523 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
524 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), | 524 | connect(mAllDayAgenda,SIGNAL(deleteIncidenceSignal(Incidence *)), |
525 | SIGNAL(deleteIncidenceSignal(Incidence *))); | 525 | SIGNAL(deleteIncidenceSignal(Incidence *))); |
526 | 526 | ||
527 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 527 | connect(mAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
528 | SLOT(updateEventDates(KOAgendaItem *, int ))); | 528 | SLOT(updateEventDates(KOAgendaItem *, int ))); |
529 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), | 529 | connect(mAllDayAgenda,SIGNAL(itemModified(KOAgendaItem *, int )), |
530 | SLOT(updateEventDates(KOAgendaItem *, int))); | 530 | SLOT(updateEventDates(KOAgendaItem *, int))); |
531 | 531 | ||
532 | // event indicator update | 532 | // event indicator update |
533 | connect(mAgenda,SIGNAL(lowerYChanged(int)), | 533 | connect(mAgenda,SIGNAL(lowerYChanged(int)), |
534 | SLOT(updateEventIndicatorTop(int))); | 534 | SLOT(updateEventIndicatorTop(int))); |
535 | connect(mAgenda,SIGNAL(upperYChanged(int)), | 535 | connect(mAgenda,SIGNAL(upperYChanged(int)), |
536 | SLOT(updateEventIndicatorBottom(int))); | 536 | SLOT(updateEventIndicatorBottom(int))); |
537 | // drag signals | 537 | // drag signals |
538 | /* | 538 | /* |
539 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), | 539 | connect(mAgenda,SIGNAL(startDragSignal(Event *)), |
540 | SLOT(startDrag(Event *))); | 540 | SLOT(startDrag(Event *))); |
541 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), | 541 | connect(mAllDayAgenda,SIGNAL(startDragSignal(Event *)), |
542 | SLOT(startDrag(Event *))); | 542 | SLOT(startDrag(Event *))); |
543 | */ | 543 | */ |
544 | // synchronize selections | 544 | // synchronize selections |
545 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 545 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
546 | mAllDayAgenda, SLOT( deselectItem() ) ); | 546 | mAllDayAgenda, SLOT( deselectItem() ) ); |
547 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 547 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
548 | mAgenda, SLOT( deselectItem() ) ); | 548 | mAgenda, SLOT( deselectItem() ) ); |
549 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 549 | connect( mAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
550 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 550 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
551 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), | 551 | connect( mAllDayAgenda, SIGNAL( incidenceSelected( Incidence * ) ), |
552 | SIGNAL( incidenceSelected( Incidence * ) ) ); | 552 | SIGNAL( incidenceSelected( Incidence * ) ) ); |
553 | connect( mAgenda, SIGNAL( resizedSignal() ), | 553 | connect( mAgenda, SIGNAL( resizedSignal() ), |
554 | SLOT( updateConfig( ) ) ); | 554 | SLOT( updateConfig( ) ) ); |
555 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), | 555 | connect( mAgenda, SIGNAL( addToCalSignal(Incidence *, Incidence *) ), |
556 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); | 556 | SLOT( addToCalSlot(Incidence *, Incidence * ) ) ); |
557 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), | 557 | connect( mAllDayAgenda, SIGNAL( addToCalSignal(Incidence * ,Incidence *) ), |
558 | SLOT( addToCalSlot(Incidence * , Incidence *) ) ); | 558 | SLOT( addToCalSlot(Incidence * , Incidence *) ) ); |
559 | // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); | 559 | // connect( mAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); |
560 | //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); | 560 | //connect( mAllDayAgenda, SIGNAL( cloneIncidenceSignal(Incidence *) ), SIGNAL( cloneIncidenceSignal(Incidence *) ) ); |
561 | 561 | ||
562 | 562 | ||
563 | } | 563 | } |
564 | 564 | ||
565 | void KOAgendaView::toggleAllDay() | 565 | void KOAgendaView::toggleAllDay() |
566 | { | 566 | { |
567 | if ( mSplitterAgenda->firstHandle() ) | 567 | if ( mSplitterAgenda->firstHandle() ) |
568 | mSplitterAgenda->firstHandle()->toggle(); | 568 | mSplitterAgenda->firstHandle()->toggle(); |
569 | } | 569 | } |
570 | void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) | 570 | void KOAgendaView::addToCalSlot(Incidence * inc, Incidence * incOld ) |
571 | { | 571 | { |
572 | calendar()->addIncidence( inc ); | 572 | calendar()->addIncidence( inc ); |
573 | 573 | ||
574 | if ( incOld ) { | 574 | if ( incOld ) { |
575 | if ( incOld->type() == "Todo" ) | 575 | if ( incOld->type() == "Todo" ) |
576 | emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED ); | 576 | emit todoMoved((Todo*)incOld, KOGlobals::EVENTEDITED ); |
577 | else | 577 | else |
578 | emit incidenceChanged(incOld, KOGlobals::EVENTEDITED); | 578 | emit incidenceChanged(incOld, KOGlobals::EVENTEDITED); |
579 | } | 579 | } |
580 | 580 | ||
581 | } | 581 | } |
582 | 582 | ||
583 | KOAgendaView::~KOAgendaView() | 583 | KOAgendaView::~KOAgendaView() |
584 | { | 584 | { |
585 | delete mAgendaPopup; | 585 | delete mAgendaPopup; |
586 | delete mAllDayAgendaPopup; | 586 | delete mAllDayAgendaPopup; |
587 | delete KOAgendaItem::paintPix(); | 587 | delete KOAgendaItem::paintPix(); |
588 | delete KOAgendaItem::paintPixSel(); | 588 | delete KOAgendaItem::paintPixSel(); |
589 | } | 589 | } |
590 | void KOAgendaView::resizeEvent( QResizeEvent* e ) | 590 | void KOAgendaView::resizeEvent( QResizeEvent* e ) |
591 | { | 591 | { |
592 | //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width()); | 592 | //qDebug("KOAgendaView::resizeEvent( QResizeEvent* e ) %d ", e->size().width()); |
593 | bool uc = false; | 593 | bool uc = false; |
594 | int ow = e->oldSize().width(); | 594 | int ow = e->oldSize().width(); |
595 | int oh = e->oldSize().height(); | 595 | int oh = e->oldSize().height(); |
596 | int w = e->size().width(); | 596 | int w = e->size().width(); |
597 | int h = e->size().height(); | 597 | int h = e->size().height(); |
598 | if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) { | 598 | if ( (ow > oh && w< h ) || (ow < oh && w > h ) ) { |
599 | if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda ) | 599 | if ( ! mBlockUpdating && !globalFlagBlockStartup && !globalFlagBlockAgenda ) |
600 | uc = true; | 600 | uc = true; |
601 | //qDebug("view changed %d %d %d %d ", ow, oh , w , h); | 601 | //qDebug("view changed %d %d %d %d ", ow, oh , w , h); |
602 | } | 602 | } |
603 | mUpcomingWidth = e->size().width() ; | 603 | mUpcomingWidth = e->size().width() ; |
604 | if ( mBlockUpdating || uc ) { | 604 | if ( mBlockUpdating || uc ) { |
605 | mBlockUpdating = false; | 605 | mBlockUpdating = false; |
606 | //mAgenda->setMinimumSize(800 , 600 ); | 606 | //mAgenda->setMinimumSize(800 , 600 ); |
607 | //qDebug("mAgenda->resize+++++++++++++++ "); | 607 | //qDebug("mAgenda->resize+++++++++++++++ "); |
608 | updateConfig(); | 608 | updateConfig(); |
609 | //qDebug("KOAgendaView::Updating now possible "); | 609 | //qDebug("KOAgendaView::Updating now possible "); |
610 | } else | 610 | } else |
611 | createDayLabels(); | 611 | createDayLabels(); |
612 | //qDebug("resizeEvent end "); | 612 | //qDebug("resizeEvent end "); |
613 | 613 | ||
614 | } | 614 | } |
615 | void KOAgendaView::slotDaylabelClicked( int num ) | 615 | void KOAgendaView::slotDaylabelClicked( int num ) |
616 | { | 616 | { |
617 | 617 | ||
618 | QDate firstDate = mSelectedDates.first(); | 618 | QDate firstDate = mSelectedDates.first(); |
619 | if ( num == -1 ) | 619 | if ( num == -1 ) |
620 | emit showDateView( 6, firstDate ); | 620 | emit showDateView( 6, firstDate ); |
@@ -1185,256 +1185,267 @@ void KOAgendaView::fillAgenda() | |||
1185 | } else { | 1185 | } else { |
1186 | int startY = mAgenda->timeToY(event->dtStart().time()); | 1186 | int startY = mAgenda->timeToY(event->dtStart().time()); |
1187 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; | 1187 | int endY = mAgenda->timeToY(event->dtEnd().time()) - 1; |
1188 | if (endY < startY) endY = startY; | 1188 | if (endY < startY) endY = startY; |
1189 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); | 1189 | mAgenda->insertItem(event,currentDate,curCol,startY,endY); |
1190 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1190 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1191 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1191 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1192 | } | 1192 | } |
1193 | } | 1193 | } |
1194 | // ---------- [display Todos -------------- | 1194 | // ---------- [display Todos -------------- |
1195 | unsigned int numTodo; | 1195 | unsigned int numTodo; |
1196 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { | 1196 | for (numTodo = 0; numTodo < todos.count(); ++numTodo) { |
1197 | Todo *todo = todos.at(numTodo); | 1197 | Todo *todo = todos.at(numTodo); |
1198 | 1198 | ||
1199 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date | 1199 | if ( ! todo->hasDueDate() && !todo->hasCompletedDate()) continue; // todo shall not be displayed if it has no date |
1200 | 1200 | ||
1201 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. | 1201 | // ToDo items shall be displayed for the day they are due, but only showed today if they are already overdue. |
1202 | // Already completed items can be displayed on their original due date | 1202 | // Already completed items can be displayed on their original due date |
1203 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda | 1203 | //if not KOPrefs::instance()->mShowTodoInAgenda, show overdue in agenda |
1204 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; | 1204 | bool overdue = (!todo->isCompleted()) && (todo->dtDue() < today) && KOPrefs::instance()->mShowTodoInAgenda; |
1205 | bool fillIn = false; | 1205 | bool fillIn = false; |
1206 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) | 1206 | if ( todo->hasCompletedDate() && todo->completed().date() == currentDate ) |
1207 | fillIn = true; | 1207 | fillIn = true; |
1208 | if ( ! fillIn && !todo->hasCompletedDate() ) | 1208 | if ( ! fillIn && !todo->hasCompletedDate() ) |
1209 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); | 1209 | fillIn = ((todo->dtDue().date() == currentDate) && !overdue) || ((currentDate == today) && overdue); |
1210 | if ( fillIn ) { | 1210 | if ( fillIn ) { |
1211 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue | 1211 | if ( (todo->doesFloat() || overdue ) && !todo->hasCompletedDate() ) { // Todo has no due-time set or is already overdue |
1212 | if ( KOPrefs::instance()->mShowTodoInAgenda ) | 1212 | if ( KOPrefs::instance()->mShowTodoInAgenda ) |
1213 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); | 1213 | mAllDayAgenda->insertAllDayItem(todo, currentDate, curCol, curCol); |
1214 | } | 1214 | } |
1215 | else { | 1215 | else { |
1216 | QDateTime dt; | 1216 | QDateTime dt; |
1217 | if ( todo->hasCompletedDate() ) | 1217 | if ( todo->hasCompletedDate() ) |
1218 | dt = todo->completed(); | 1218 | dt = todo->completed(); |
1219 | else | 1219 | else |
1220 | dt = todo->dtDue();; | 1220 | dt = todo->dtDue();; |
1221 | 1221 | ||
1222 | 1222 | ||
1223 | int endY = mAgenda->timeToY(dt.time()) - 1; | 1223 | int endY = mAgenda->timeToY(dt.time()) - 1; |
1224 | int hi = (18/KOPrefs::instance()->mHourSize); | 1224 | int hi = (18/KOPrefs::instance()->mHourSize); |
1225 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); | 1225 | //qDebug("hei %d ",KOPrefs::instance()->mHourSize); |
1226 | int startY = endY -hi; | 1226 | int startY = endY -hi; |
1227 | 1227 | ||
1228 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); | 1228 | mAgenda->insertItem(todo,currentDate,curCol,startY,endY); |
1229 | 1229 | ||
1230 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; | 1230 | if (startY < mMinY[curCol]) mMinY[curCol] = startY; |
1231 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; | 1231 | if (endY > mMaxY[curCol]) mMaxY[curCol] = endY; |
1232 | } | 1232 | } |
1233 | } | 1233 | } |
1234 | } | 1234 | } |
1235 | // ---------- display Todos] -------------- | 1235 | // ---------- display Todos] -------------- |
1236 | 1236 | ||
1237 | ++curCol; | 1237 | ++curCol; |
1238 | } | 1238 | } |
1239 | mAgenda->hideUnused(); | 1239 | mAgenda->hideUnused(); |
1240 | mAllDayAgenda->hideUnused(); | 1240 | mAllDayAgenda->hideUnused(); |
1241 | mAgenda->checkScrollBoundaries(); | 1241 | mAgenda->checkScrollBoundaries(); |
1242 | 1242 | ||
1243 | deleteSelectedDateTime(); | 1243 | deleteSelectedDateTime(); |
1244 | 1244 | ||
1245 | createDayLabels(); | 1245 | createDayLabels(); |
1246 | emit incidenceSelected( 0 ); | 1246 | emit incidenceSelected( 0 ); |
1247 | 1247 | ||
1248 | if ( globalFlagBlockAgenda == 2 ) { | 1248 | if ( globalFlagBlockAgenda == 2 ) { |
1249 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) | 1249 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) |
1250 | setStartHour( KOPrefs::instance()->mDayBegins ); | 1250 | setStartHour( KOPrefs::instance()->mDayBegins ); |
1251 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) | 1251 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) |
1252 | setStartHour( QTime::currentTime ().hour() ); | 1252 | setStartHour( QTime::currentTime ().hour() ); |
1253 | // qApp->processEvents(); | 1253 | // qApp->processEvents(); |
1254 | } | 1254 | } |
1255 | qApp->processEvents(); | 1255 | qApp->processEvents(); |
1256 | //qDebug("qApp->processEvents(); END "); | 1256 | //qDebug("qApp->processEvents(); END "); |
1257 | globalFlagBlockAgenda = 0; | 1257 | globalFlagBlockAgenda = 0; |
1258 | 1258 | ||
1259 | // mAgenda->hideUnused(); | 1259 | // mAgenda->hideUnused(); |
1260 | //mAllDayAgenda->hideUnused(); | 1260 | //mAllDayAgenda->hideUnused(); |
1261 | mAllDayAgenda->drawContentsToPainter(); | 1261 | mAllDayAgenda->drawContentsToPainter(); |
1262 | mAgenda->drawContentsToPainter(); | 1262 | mAgenda->drawContentsToPainter(); |
1263 | repaintAgenda(); | 1263 | repaintAgenda(); |
1264 | onlyOne = false; | 1264 | onlyOne = false; |
1265 | // mAgenda->finishUpdate(); | 1265 | // mAgenda->finishUpdate(); |
1266 | //mAllDayAgenda->finishUpdate(); | 1266 | //mAllDayAgenda->finishUpdate(); |
1267 | 1267 | ||
1268 | // repaintAgenda(); | 1268 | // repaintAgenda(); |
1269 | //qApp->processEvents(); | 1269 | //qApp->processEvents(); |
1270 | // globalFlagBlockAgenda = 0; | 1270 | // globalFlagBlockAgenda = 0; |
1271 | } | 1271 | } |
1272 | void KOAgendaView::repaintAgenda() | 1272 | void KOAgendaView::repaintAgenda() |
1273 | { | 1273 | { |
1274 | // mAllDayAgenda->drawContentsToPainter(); | 1274 | // mAllDayAgenda->drawContentsToPainter(); |
1275 | // mAllDayAgenda->viewport()->repaint( false ); | 1275 | // mAllDayAgenda->viewport()->repaint( false ); |
1276 | // mAgenda->drawContentsToPainter(); | 1276 | // mAgenda->drawContentsToPainter(); |
1277 | // mAgenda->viewport()->repaint( false ); | 1277 | // mAgenda->viewport()->repaint( false ); |
1278 | // qApp->processEvents(); | 1278 | // qApp->processEvents(); |
1279 | 1279 | ||
1280 | //qDebug("KOAgendaView::repaintAgenda() "); | 1280 | //qDebug("KOAgendaView::repaintAgenda() "); |
1281 | //qApp->processEvents(); | 1281 | //qApp->processEvents(); |
1282 | mAgenda->viewport()->repaint( false ); | 1282 | mAgenda->viewport()->repaint( false ); |
1283 | mAllDayAgenda->viewport()->repaint( false ); | 1283 | mAllDayAgenda->viewport()->repaint( false ); |
1284 | mAgenda->finishUpdate(); | 1284 | mAgenda->finishUpdate(); |
1285 | mAllDayAgenda->finishUpdate(); | 1285 | mAllDayAgenda->finishUpdate(); |
1286 | } | 1286 | } |
1287 | 1287 | ||
1288 | 1288 | ||
1289 | void KOAgendaView::clearView() | 1289 | void KOAgendaView::clearView() |
1290 | { | 1290 | { |
1291 | // kdDebug() << "ClearView" << endl; | 1291 | // kdDebug() << "ClearView" << endl; |
1292 | mAllDayAgenda->clear(); | 1292 | mAllDayAgenda->clear(); |
1293 | mAgenda->clear(); | 1293 | mAgenda->clear(); |
1294 | } | 1294 | } |
1295 | 1295 | ||
1296 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 1296 | void KOAgendaView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
1297 | const QDate &td) | 1297 | const QDate &td) |
1298 | { | 1298 | { |
1299 | #ifndef KORG_NOPRINTER | 1299 | #ifndef KORG_NOPRINTER |
1300 | if (fd == td) | 1300 | if (fd == td) |
1301 | calPrinter->preview(CalPrinter::Day, fd, td); | 1301 | calPrinter->preview(CalPrinter::Day, fd, td); |
1302 | else | 1302 | else |
1303 | calPrinter->preview(CalPrinter::Week, fd, td); | 1303 | calPrinter->preview(CalPrinter::Week, fd, td); |
1304 | #endif | 1304 | #endif |
1305 | } | 1305 | } |
1306 | 1306 | ||
1307 | // void KOAgendaView::updateMovedTodo() | 1307 | // void KOAgendaView::updateMovedTodo() |
1308 | // { | 1308 | // { |
1309 | // // updateConfig(); | 1309 | // // updateConfig(); |
1310 | // // emit updateTodoViews(); | 1310 | // // emit updateTodoViews(); |
1311 | // } | 1311 | // } |
1312 | 1312 | ||
1313 | void KOAgendaView::slotShowDateView( int mode , int d ) | ||
1314 | { | ||
1315 | if ( d >= mSelectedDates.count() ) { | ||
1316 | qDebug("KOAgendaView::slotShowDateView datecounterror %d d ", d, mSelectedDates.count() ); | ||
1317 | |||
1318 | } else { | ||
1319 | QDate day = mSelectedDates[d]; | ||
1320 | emit showDateView(mode , day ); | ||
1321 | } | ||
1322 | |||
1323 | } | ||
1313 | void KOAgendaView::newEvent(int gx, int gy) | 1324 | void KOAgendaView::newEvent(int gx, int gy) |
1314 | { | 1325 | { |
1315 | if (!mSelectedDates.count()) return; | 1326 | if (!mSelectedDates.count()) return; |
1316 | 1327 | ||
1317 | QDate day = mSelectedDates[gx]; | 1328 | QDate day = mSelectedDates[gx]; |
1318 | 1329 | ||
1319 | QTime time = mAgenda->gyToTime(gy); | 1330 | QTime time = mAgenda->gyToTime(gy); |
1320 | QDateTime dt(day,time); | 1331 | QDateTime dt(day,time); |
1321 | // if ( dt < QDateTime::currentDateTime () ) | 1332 | // if ( dt < QDateTime::currentDateTime () ) |
1322 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); | 1333 | // dt = QDateTime::currentDateTime ().addSecs( 3600 ); |
1323 | emit newEventSignal(dt); | 1334 | emit newEventSignal(dt); |
1324 | } | 1335 | } |
1325 | 1336 | ||
1326 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) | 1337 | void KOAgendaView::newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd) |
1327 | { | 1338 | { |
1328 | if (!mSelectedDates.count()) return; | 1339 | if (!mSelectedDates.count()) return; |
1329 | 1340 | ||
1330 | QDate dayStart = mSelectedDates[gxStart]; | 1341 | QDate dayStart = mSelectedDates[gxStart]; |
1331 | QDate dayEnd = mSelectedDates[gxEnd]; | 1342 | QDate dayEnd = mSelectedDates[gxEnd]; |
1332 | 1343 | ||
1333 | QTime timeStart = mAgenda->gyToTime(gyStart); | 1344 | QTime timeStart = mAgenda->gyToTime(gyStart); |
1334 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); | 1345 | QTime timeEnd = mAgenda->gyToTime( gyEnd + 1 ); |
1335 | 1346 | ||
1336 | QDateTime dtStart(dayStart,timeStart); | 1347 | QDateTime dtStart(dayStart,timeStart); |
1337 | QDateTime dtEnd(dayEnd,timeEnd); | 1348 | QDateTime dtEnd(dayEnd,timeEnd); |
1338 | 1349 | ||
1339 | emit newEventSignal(dtStart,dtEnd); | 1350 | emit newEventSignal(dtStart,dtEnd); |
1340 | } | 1351 | } |
1341 | 1352 | ||
1342 | void KOAgendaView::newEventAllDay(int gx, int ) | 1353 | void KOAgendaView::newEventAllDay(int gx, int ) |
1343 | { | 1354 | { |
1344 | if (!mSelectedDates.count()) return; | 1355 | if (!mSelectedDates.count()) return; |
1345 | 1356 | ||
1346 | QDate day = mSelectedDates[gx]; | 1357 | QDate day = mSelectedDates[gx]; |
1347 | 1358 | ||
1348 | emit newEventSignal(day); | 1359 | emit newEventSignal(day); |
1349 | } | 1360 | } |
1350 | void KOAgendaView::newTodoAllDay(int gx, int ) | 1361 | void KOAgendaView::newTodoAllDay(int gx, int ) |
1351 | { | 1362 | { |
1352 | if (!mSelectedDates.count()) return; | 1363 | if (!mSelectedDates.count()) return; |
1353 | 1364 | ||
1354 | QDateTime day (mSelectedDates[gx] ); | 1365 | QDateTime day (mSelectedDates[gx] ); |
1355 | emit newTodoSignal(day, true); | 1366 | emit newTodoSignal(day, true); |
1356 | } | 1367 | } |
1357 | void KOAgendaView::newTodo(int gx, int gy ) | 1368 | void KOAgendaView::newTodo(int gx, int gy ) |
1358 | { | 1369 | { |
1359 | if (!mSelectedDates.count()) return; | 1370 | if (!mSelectedDates.count()) return; |
1360 | QDate dayStart = mSelectedDates[gx]; | 1371 | QDate dayStart = mSelectedDates[gx]; |
1361 | QTime timeStart = mAgenda->gyToTime(gy); | 1372 | QTime timeStart = mAgenda->gyToTime(gy); |
1362 | QDateTime dt (dayStart,timeStart); | 1373 | QDateTime dt (dayStart,timeStart); |
1363 | emit newTodoSignal( dt, false ); | 1374 | emit newTodoSignal( dt, false ); |
1364 | } | 1375 | } |
1365 | 1376 | ||
1366 | void KOAgendaView::updateEventIndicatorTop(int newY) | 1377 | void KOAgendaView::updateEventIndicatorTop(int newY) |
1367 | { | 1378 | { |
1368 | uint i; | 1379 | uint i; |
1369 | for(i=0;i<mMinY.size();++i) { | 1380 | for(i=0;i<mMinY.size();++i) { |
1370 | if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true); | 1381 | if (newY >= mMinY.at(i)) mEventIndicatorTop->enableColumn(i,true); |
1371 | else mEventIndicatorTop->enableColumn(i,false); | 1382 | else mEventIndicatorTop->enableColumn(i,false); |
1372 | } | 1383 | } |
1373 | 1384 | ||
1374 | mEventIndicatorTop->update(); | 1385 | mEventIndicatorTop->update(); |
1375 | } | 1386 | } |
1376 | 1387 | ||
1377 | void KOAgendaView::updateEventIndicatorBottom(int newY) | 1388 | void KOAgendaView::updateEventIndicatorBottom(int newY) |
1378 | { | 1389 | { |
1379 | uint i; | 1390 | uint i; |
1380 | for(i=0;i<mMaxY.size();++i) { | 1391 | for(i=0;i<mMaxY.size();++i) { |
1381 | if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true); | 1392 | if (newY <= mMaxY.at(i)) mEventIndicatorBottom->enableColumn(i,true); |
1382 | else mEventIndicatorBottom->enableColumn(i,false); | 1393 | else mEventIndicatorBottom->enableColumn(i,false); |
1383 | } | 1394 | } |
1384 | 1395 | ||
1385 | mEventIndicatorBottom->update(); | 1396 | mEventIndicatorBottom->update(); |
1386 | } | 1397 | } |
1387 | 1398 | ||
1388 | void KOAgendaView::startDrag(Event *event) | 1399 | void KOAgendaView::startDrag(Event *event) |
1389 | { | 1400 | { |
1390 | #ifndef KORG_NODND | 1401 | #ifndef KORG_NODND |
1391 | DndFactory factory( calendar() ); | 1402 | DndFactory factory( calendar() ); |
1392 | ICalDrag *vd = factory.createDrag(event,this); | 1403 | ICalDrag *vd = factory.createDrag(event,this); |
1393 | if (vd->drag()) { | 1404 | if (vd->drag()) { |
1394 | kdDebug() << "KOAgendaView::startDrag(): Delete drag source" << endl; | 1405 | kdDebug() << "KOAgendaView::startDrag(): Delete drag source" << endl; |
1395 | } | 1406 | } |
1396 | #endif | 1407 | #endif |
1397 | } | 1408 | } |
1398 | 1409 | ||
1399 | void KOAgendaView::readSettings() | 1410 | void KOAgendaView::readSettings() |
1400 | { | 1411 | { |
1401 | readSettings(KOGlobals::config()); | 1412 | readSettings(KOGlobals::config()); |
1402 | } | 1413 | } |
1403 | 1414 | ||
1404 | void KOAgendaView::readSettings(KConfig *config) | 1415 | void KOAgendaView::readSettings(KConfig *config) |
1405 | { | 1416 | { |
1406 | // kdDebug() << "KOAgendaView::readSettings()" << endl; | 1417 | // kdDebug() << "KOAgendaView::readSettings()" << endl; |
1407 | 1418 | ||
1408 | config->setGroup("Views"); | 1419 | config->setGroup("Views"); |
1409 | 1420 | ||
1410 | //#ifndef KORG_NOSPLITTER | 1421 | //#ifndef KORG_NOSPLITTER |
1411 | QValueList<int> sizes = config->readIntListEntry("Separator AgendaView"); | 1422 | QValueList<int> sizes = config->readIntListEntry("Separator AgendaView"); |
1412 | if (sizes.count() == 2) { | 1423 | if (sizes.count() == 2) { |
1413 | if ( sizes[0] < 20 ) { | 1424 | if ( sizes[0] < 20 ) { |
1414 | sizes[1] = sizes[1] +20 - sizes[0]; | 1425 | sizes[1] = sizes[1] +20 - sizes[0]; |
1415 | sizes[0] = 20; | 1426 | sizes[0] = 20; |
1416 | } | 1427 | } |
1417 | mSplitterAgenda->setSizes(sizes); | 1428 | mSplitterAgenda->setSizes(sizes); |
1418 | // qDebug("read %d %d ",sizes[0],sizes[1] ); | 1429 | // qDebug("read %d %d ",sizes[0],sizes[1] ); |
1419 | } | 1430 | } |
1420 | //#endif | 1431 | //#endif |
1421 | 1432 | ||
1422 | // updateConfig(); | 1433 | // updateConfig(); |
1423 | } | 1434 | } |
1424 | 1435 | ||
1425 | void KOAgendaView::writeSettings(KConfig *config) | 1436 | void KOAgendaView::writeSettings(KConfig *config) |
1426 | { | 1437 | { |
1427 | // kdDebug() << "KOAgendaView::writeSettings()" << endl; | 1438 | // kdDebug() << "KOAgendaView::writeSettings()" << endl; |
1428 | 1439 | ||
1429 | config->setGroup("Views"); | 1440 | config->setGroup("Views"); |
1430 | 1441 | ||
1431 | //#ifndef KORG_NOSPLITTER | 1442 | //#ifndef KORG_NOSPLITTER |
1432 | QValueList<int> list = mSplitterAgenda->sizes(); | 1443 | QValueList<int> list = mSplitterAgenda->sizes(); |
1433 | config->writeEntry("Separator AgendaView",list); | 1444 | config->writeEntry("Separator AgendaView",list); |
1434 | //qDebug("write %d %d ", list[0],list[1] ); | 1445 | //qDebug("write %d %d ", list[0],list[1] ); |
1435 | //#endif | 1446 | //#endif |
1436 | } | 1447 | } |
1437 | 1448 | ||
1438 | void KOAgendaView::setHolidayMasks() | 1449 | void KOAgendaView::setHolidayMasks() |
1439 | { | 1450 | { |
1440 | mHolidayMask.resize(mSelectedDates.count()); | 1451 | mHolidayMask.resize(mSelectedDates.count()); |
diff --git a/korganizer/koagendaview.h b/korganizer/koagendaview.h index 57b4e46..6dc81c6 100644 --- a/korganizer/koagendaview.h +++ b/korganizer/koagendaview.h | |||
@@ -81,209 +81,210 @@ class TimeLabels : public QScrollView { | |||
81 | virtual int minimumWidth() const; | 81 | virtual int minimumWidth() const; |
82 | 82 | ||
83 | /** updates widget's internal state */ | 83 | /** updates widget's internal state */ |
84 | void updateConfig(); | 84 | void updateConfig(); |
85 | 85 | ||
86 | /** */ | 86 | /** */ |
87 | void setAgenda(KOAgenda* agenda); | 87 | void setAgenda(KOAgenda* agenda); |
88 | 88 | ||
89 | /** */ | 89 | /** */ |
90 | virtual void paintEvent(QPaintEvent* e); | 90 | virtual void paintEvent(QPaintEvent* e); |
91 | void contentsMousePressEvent ( QMouseEvent * ) ; | 91 | void contentsMousePressEvent ( QMouseEvent * ) ; |
92 | void contentsMouseReleaseEvent ( QMouseEvent * ); | 92 | void contentsMouseReleaseEvent ( QMouseEvent * ); |
93 | void contentsMouseMoveEvent ( QMouseEvent * ); | 93 | void contentsMouseMoveEvent ( QMouseEvent * ); |
94 | 94 | ||
95 | public slots: | 95 | public slots: |
96 | /** update time label positions */ | 96 | /** update time label positions */ |
97 | void positionChanged(); | 97 | void positionChanged(); |
98 | signals: | 98 | signals: |
99 | void scaleChanged(); | 99 | void scaleChanged(); |
100 | protected: | 100 | protected: |
101 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); | 101 | void drawContents(QPainter *p,int cx, int cy, int cw, int ch); |
102 | 102 | ||
103 | private: | 103 | private: |
104 | int mMiniWidth; | 104 | int mMiniWidth; |
105 | int mMouseDownY; | 105 | int mMouseDownY; |
106 | QString mOrgCap; | 106 | QString mOrgCap; |
107 | int mRows; | 107 | int mRows; |
108 | int mCellHeight; | 108 | int mCellHeight; |
109 | 109 | ||
110 | /** */ | 110 | /** */ |
111 | KOAgenda* mAgenda; | 111 | KOAgenda* mAgenda; |
112 | }; | 112 | }; |
113 | 113 | ||
114 | class EventIndicator : public QFrame { | 114 | class EventIndicator : public QFrame { |
115 | Q_OBJECT | 115 | Q_OBJECT |
116 | public: | 116 | public: |
117 | enum Location { Top, Bottom }; | 117 | enum Location { Top, Bottom }; |
118 | EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0); | 118 | EventIndicator(Location loc=Top,QWidget *parent=0,const char *name=0); |
119 | virtual ~EventIndicator(); | 119 | virtual ~EventIndicator(); |
120 | 120 | ||
121 | void changeColumns(int columns); | 121 | void changeColumns(int columns); |
122 | void setPaintWidget( KDGanttMinimizeSplitter* ); | 122 | void setPaintWidget( KDGanttMinimizeSplitter* ); |
123 | void setXOffset( int ); | 123 | void setXOffset( int ); |
124 | void enableColumn(int column, bool enable); | 124 | void enableColumn(int column, bool enable); |
125 | 125 | ||
126 | protected: | 126 | protected: |
127 | void drawContents(QPainter *); | 127 | void drawContents(QPainter *); |
128 | 128 | ||
129 | private: | 129 | private: |
130 | int mXOffset; | 130 | int mXOffset; |
131 | KDGanttMinimizeSplitter* mPaintWidget; | 131 | KDGanttMinimizeSplitter* mPaintWidget; |
132 | int mColumns; | 132 | int mColumns; |
133 | QHBox *mTopBox; | 133 | QHBox *mTopBox; |
134 | QBoxLayout *mTopLayout; | 134 | QBoxLayout *mTopLayout; |
135 | Location mLocation; | 135 | Location mLocation; |
136 | QPixmap mPixmap; | 136 | QPixmap mPixmap; |
137 | QMemArray<bool> mEnabled; | 137 | QMemArray<bool> mEnabled; |
138 | }; | 138 | }; |
139 | 139 | ||
140 | /** | 140 | /** |
141 | KOAgendaView is the agenda-like view used to display events in an one or | 141 | KOAgendaView is the agenda-like view used to display events in an one or |
142 | multi-day view. | 142 | multi-day view. |
143 | */ | 143 | */ |
144 | class KOAgendaView : public KOEventView { | 144 | class KOAgendaView : public KOEventView { |
145 | Q_OBJECT | 145 | Q_OBJECT |
146 | public: | 146 | public: |
147 | KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 ); | 147 | KOAgendaView(Calendar *cal,QWidget *parent = 0,const char *name = 0 ); |
148 | virtual ~KOAgendaView(); | 148 | virtual ~KOAgendaView(); |
149 | void setStartHour( int ); | 149 | void setStartHour( int ); |
150 | void toggleAllDay(); | 150 | void toggleAllDay(); |
151 | 151 | ||
152 | 152 | ||
153 | /** Returns maximum number of days supported by the koagendaview */ | 153 | /** Returns maximum number of days supported by the koagendaview */ |
154 | virtual int maxDatesHint(); | 154 | virtual int maxDatesHint(); |
155 | 155 | ||
156 | /** Returns number of currently shown dates. */ | 156 | /** Returns number of currently shown dates. */ |
157 | virtual int currentDateCount(); | 157 | virtual int currentDateCount(); |
158 | 158 | ||
159 | /** returns the currently selected events */ | 159 | /** returns the currently selected events */ |
160 | virtual QPtrList<Incidence> selectedIncidences(); | 160 | virtual QPtrList<Incidence> selectedIncidences(); |
161 | 161 | ||
162 | /** returns the currently selected events */ | 162 | /** returns the currently selected events */ |
163 | virtual DateList selectedDates(); | 163 | virtual DateList selectedDates(); |
164 | 164 | ||
165 | /** Remove all events from view */ | 165 | /** Remove all events from view */ |
166 | void clearView(); | 166 | void clearView(); |
167 | KOAgenda *agenda() { return mAgenda;} | 167 | KOAgenda *agenda() { return mAgenda;} |
168 | virtual void printPreview(CalPrinter *calPrinter, | 168 | virtual void printPreview(CalPrinter *calPrinter, |
169 | const QDate &, const QDate &); | 169 | const QDate &, const QDate &); |
170 | 170 | ||
171 | /** start-datetime of selection */ | 171 | /** start-datetime of selection */ |
172 | QDateTime selectionStart() {return mTimeSpanBegin;} | 172 | QDateTime selectionStart() {return mTimeSpanBegin;} |
173 | /** end-datetime of selection */ | 173 | /** end-datetime of selection */ |
174 | QDateTime selectionEnd() {return mTimeSpanEnd;} | 174 | QDateTime selectionEnd() {return mTimeSpanEnd;} |
175 | /** returns true if selection is for whole day */ | 175 | /** returns true if selection is for whole day */ |
176 | bool selectedIsAllDay() {return mTimeSpanInAllDay;} | 176 | bool selectedIsAllDay() {return mTimeSpanInAllDay;} |
177 | /** make selected start/end invalid */ | 177 | /** make selected start/end invalid */ |
178 | void deleteSelectedDateTime(); | 178 | void deleteSelectedDateTime(); |
179 | void repaintAgenda(); | 179 | void repaintAgenda(); |
180 | public slots: | 180 | public slots: |
181 | void setInitStartHour(); | 181 | void setInitStartHour(); |
182 | virtual void updateView(); | 182 | virtual void updateView(); |
183 | virtual void updateConfig(); | 183 | virtual void updateConfig(); |
184 | virtual void showDates(const QDate &start, const QDate &end); | 184 | virtual void showDates(const QDate &start, const QDate &end); |
185 | virtual void showEvents(QPtrList<Event> eventList); | 185 | virtual void showEvents(QPtrList<Event> eventList); |
186 | 186 | ||
187 | void updateTodo( Todo *, int ); | 187 | void updateTodo( Todo *, int ); |
188 | void changeEventDisplay(Event *, int); | 188 | void changeEventDisplay(Event *, int); |
189 | 189 | ||
190 | void clearSelection(); | 190 | void clearSelection(); |
191 | 191 | ||
192 | void newTodo(int gx,int gy); | 192 | void newTodo(int gx,int gy); |
193 | void newEvent(int gx,int gy); | 193 | void newEvent(int gx,int gy); |
194 | void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd); | 194 | void newEvent(int gxStart, int gyStart, int gxEnd, int gyEnd); |
195 | void newEventAllDay(int gx, int gy); | 195 | void newEventAllDay(int gx, int gy); |
196 | void newTodoAllDay(int gx, int gy); | 196 | void newTodoAllDay(int gx, int gy); |
197 | 197 | ||
198 | void startDrag(Event *); | 198 | void startDrag(Event *); |
199 | 199 | ||
200 | void readSettings(); | 200 | void readSettings(); |
201 | void readSettings(KConfig *); | 201 | void readSettings(KConfig *); |
202 | void writeSettings(KConfig *); | 202 | void writeSettings(KConfig *); |
203 | 203 | ||
204 | void setContentsPos(int y); | 204 | void setContentsPos(int y); |
205 | 205 | ||
206 | void scrollOneHourUp(); | 206 | void scrollOneHourUp(); |
207 | void scrollOneHourDown(); | 207 | void scrollOneHourDown(); |
208 | void addToCalSlot(Incidence *, Incidence *); | 208 | void addToCalSlot(Incidence *, Incidence *); |
209 | void slotShowDateView( int, int ); | ||
209 | 210 | ||
210 | signals: | 211 | signals: |
211 | void showDateView( int, QDate ); | 212 | void showDateView( int, QDate ); |
212 | void newTodoSignal( QDateTime ,bool ); | 213 | void newTodoSignal( QDateTime ,bool ); |
213 | void toggleExpand(); | 214 | void toggleExpand(); |
214 | void selectWeekNum( int ); | 215 | void selectWeekNum( int ); |
215 | void todoMoved( Todo *, int ); | 216 | void todoMoved( Todo *, int ); |
216 | void incidenceChanged(Incidence * , int ); | 217 | void incidenceChanged(Incidence * , int ); |
217 | // void cloneIncidenceSignal(Incidence *); | 218 | // void cloneIncidenceSignal(Incidence *); |
218 | 219 | ||
219 | protected: | 220 | protected: |
220 | KOAgendaButton* getNewDaylabel(); | 221 | KOAgendaButton* getNewDaylabel(); |
221 | bool mBlockUpdating; | 222 | bool mBlockUpdating; |
222 | int mUpcomingWidth; | 223 | int mUpcomingWidth; |
223 | /** Fill agenda beginning with date startDate */ | 224 | /** Fill agenda beginning with date startDate */ |
224 | void fillAgenda(const QDate &startDate); | 225 | void fillAgenda(const QDate &startDate); |
225 | void resizeEvent( QResizeEvent* e ); | 226 | void resizeEvent( QResizeEvent* e ); |
226 | /** Fill agenda using the current set value for the start date */ | 227 | /** Fill agenda using the current set value for the start date */ |
227 | void fillAgenda(); | 228 | void fillAgenda(); |
228 | 229 | ||
229 | /** Create labels for the selected dates. */ | 230 | /** Create labels for the selected dates. */ |
230 | void createDayLabels(); | 231 | void createDayLabels(); |
231 | 232 | ||
232 | /** | 233 | /** |
233 | Set the masks on the agenda widgets indicating, which days are holidays. | 234 | Set the masks on the agenda widgets indicating, which days are holidays. |
234 | */ | 235 | */ |
235 | void setHolidayMasks(); | 236 | void setHolidayMasks(); |
236 | 237 | ||
237 | protected slots: | 238 | protected slots: |
238 | void slotDaylabelClicked( int ); | 239 | void slotDaylabelClicked( int ); |
239 | /** Update event belonging to agenda item */ | 240 | /** Update event belonging to agenda item */ |
240 | void updateEventDates(KOAgendaItem *item, int mode = -1); | 241 | void updateEventDates(KOAgendaItem *item, int mode = -1); |
241 | //void updateMovedTodo(); | 242 | //void updateMovedTodo(); |
242 | 243 | ||
243 | void updateEventIndicatorTop(int newY); | 244 | void updateEventIndicatorTop(int newY); |
244 | void updateEventIndicatorBottom(int newY); | 245 | void updateEventIndicatorBottom(int newY); |
245 | 246 | ||
246 | /** Updates data for selected timespan */ | 247 | /** Updates data for selected timespan */ |
247 | void newTimeSpanSelected(int gxStart, int gyStart, int gxEnd, int gyEnd); | 248 | void newTimeSpanSelected(int gxStart, int gyStart, int gxEnd, int gyEnd); |
248 | /** Updates data for selected timespan for all day event*/ | 249 | /** Updates data for selected timespan for all day event*/ |
249 | void newTimeSpanSelectedAllDay(int gxStart, int gyStart, int gxEnd, int gyEnd); | 250 | void newTimeSpanSelectedAllDay(int gxStart, int gyStart, int gxEnd, int gyEnd); |
250 | 251 | ||
251 | private: | 252 | private: |
252 | // view widgets | 253 | // view widgets |
253 | QFrame *mDayLabels; | 254 | QFrame *mDayLabels; |
254 | QHBox *mDayLabelsFrame; | 255 | QHBox *mDayLabelsFrame; |
255 | QBoxLayout *mLayoutDayLabels; | 256 | QBoxLayout *mLayoutDayLabels; |
256 | QFrame *mAllDayFrame; | 257 | QFrame *mAllDayFrame; |
257 | KOAgenda *mAllDayAgenda; | 258 | KOAgenda *mAllDayAgenda; |
258 | KOAgenda *mAgenda; | 259 | KOAgenda *mAgenda; |
259 | TimeLabels *mTimeLabels; | 260 | TimeLabels *mTimeLabels; |
260 | QWidget *mDummyAllDayLeft; | 261 | QWidget *mDummyAllDayLeft; |
261 | 262 | ||
262 | KDGanttMinimizeSplitter* mSplitterAgenda; | 263 | KDGanttMinimizeSplitter* mSplitterAgenda; |
263 | QPushButton *mExpandButton; | 264 | QPushButton *mExpandButton; |
264 | 265 | ||
265 | DateList mSelectedDates; // List of dates to be displayed | 266 | DateList mSelectedDates; // List of dates to be displayed |
266 | int mViewType; | 267 | int mViewType; |
267 | 268 | ||
268 | bool mWeekStartsMonday; | 269 | bool mWeekStartsMonday; |
269 | int mStartHour; | 270 | int mStartHour; |
270 | 271 | ||
271 | KOEventPopupMenu *mAgendaPopup; | 272 | KOEventPopupMenu *mAgendaPopup; |
272 | KOEventPopupMenu *mAllDayAgendaPopup; | 273 | KOEventPopupMenu *mAllDayAgendaPopup; |
273 | 274 | ||
274 | EventIndicator *mEventIndicatorTop; | 275 | EventIndicator *mEventIndicatorTop; |
275 | EventIndicator *mEventIndicatorBottom; | 276 | EventIndicator *mEventIndicatorBottom; |
276 | 277 | ||
277 | QMemArray<int> mMinY; | 278 | QMemArray<int> mMinY; |
278 | QMemArray<int> mMaxY; | 279 | QMemArray<int> mMaxY; |
279 | 280 | ||
280 | QMemArray<bool> mHolidayMask; | 281 | QMemArray<bool> mHolidayMask; |
281 | 282 | ||
282 | QPtrList<KOAgendaButton> mDayLabelsList; | 283 | QPtrList<KOAgendaButton> mDayLabelsList; |
283 | QDateTime mTimeSpanBegin; | 284 | QDateTime mTimeSpanBegin; |
284 | QDateTime mTimeSpanEnd; | 285 | QDateTime mTimeSpanEnd; |
285 | bool mTimeSpanInAllDay; | 286 | bool mTimeSpanInAllDay; |
286 | void keyPressEvent ( QKeyEvent * e ); | 287 | void keyPressEvent ( QKeyEvent * e ); |
287 | }; | 288 | }; |
288 | 289 | ||
289 | #endif // KOAGENDAVIEW_H | 290 | #endif // KOAGENDAVIEW_H |
diff --git a/korganizer/komonthview.cpp b/korganizer/komonthview.cpp index b9ce4f4..ab9a4b6 100644 --- a/korganizer/komonthview.cpp +++ b/korganizer/komonthview.cpp | |||
@@ -812,257 +812,261 @@ void MonthViewCell::updateConfig( bool bigFont ) // = false | |||
812 | if ( ps < 18 ) | 812 | if ( ps < 18 ) |
813 | ps += 2; | 813 | ps += 2; |
814 | fo.setPointSize( ps ); | 814 | fo.setPointSize( ps ); |
815 | setFont( fo ); | 815 | setFont( fo ); |
816 | } else | 816 | } else |
817 | setFont( KOPrefs::instance()->mMonthViewFont ); | 817 | setFont( KOPrefs::instance()->mMonthViewFont ); |
818 | 818 | ||
819 | QFontMetrics fm( font() ); | 819 | QFontMetrics fm( font() ); |
820 | mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 ); | 820 | mLabelSize = fm.size( 0, "30" ) + QSize( 4, 2 ); |
821 | mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 ); | 821 | mLabelBigSize = fm.size( 0, "Mag 30" ) + QSize( 2, 2 ); |
822 | mHolidayPalette = mStandardPalette; | 822 | mHolidayPalette = mStandardPalette; |
823 | mPrimaryPalette = mStandardPalette; | 823 | mPrimaryPalette = mStandardPalette; |
824 | mNonPrimaryPalette = mStandardPalette; | 824 | mNonPrimaryPalette = mStandardPalette; |
825 | if ( KOPrefs::instance()->mMonthViewUsesDayColors ) { | 825 | if ( KOPrefs::instance()->mMonthViewUsesDayColors ) { |
826 | mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor ); | 826 | mHolidayPalette.setColor(QColorGroup::Base, KOPrefs::instance()->mMonthViewHolidayColor ); |
827 | mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor ); | 827 | mHolidayPalette.setColor(QColorGroup::Background, KOPrefs::instance()->mMonthViewHolidayColor ); |
828 | mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark()); | 828 | mHolidayPalette.setColor(QColorGroup::Foreground, KOPrefs::instance()->mMonthViewHolidayColor.dark()); |
829 | mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark()); | 829 | mPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewOddColor.dark()); |
830 | mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor); | 830 | mPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewOddColor); |
831 | mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor); | 831 | mPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewOddColor); |
832 | mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark()); | 832 | mNonPrimaryPalette.setColor(QColorGroup::Foreground,KOPrefs::instance()->mMonthViewEvenColor.dark()); |
833 | mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor); | 833 | mNonPrimaryPalette.setColor(QColorGroup::Base,KOPrefs::instance()->mMonthViewEvenColor); |
834 | mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor); | 834 | mNonPrimaryPalette.setColor(QColorGroup::Background,KOPrefs::instance()->mMonthViewEvenColor); |
835 | } | 835 | } |
836 | //updateCell(); | 836 | //updateCell(); |
837 | } | 837 | } |
838 | 838 | ||
839 | void MonthViewCell::enableScrollBars( bool enabled ) | 839 | void MonthViewCell::enableScrollBars( bool enabled ) |
840 | { | 840 | { |
841 | if ( enabled ) { | 841 | if ( enabled ) { |
842 | QListBoxItem *fi = firstItem (); | 842 | QListBoxItem *fi = firstItem (); |
843 | if (fi ) { | 843 | if (fi ) { |
844 | int ihei = fi->height( this ); | 844 | int ihei = fi->height( this ); |
845 | int hei = numRows () * ihei; | 845 | int hei = numRows () * ihei; |
846 | if ( hei < height() - horizontalScrollBar()->height () ) { | 846 | if ( hei < height() - horizontalScrollBar()->height () ) { |
847 | setVScrollBarMode(QScrollView::AlwaysOff); | 847 | setVScrollBarMode(QScrollView::AlwaysOff); |
848 | } | 848 | } |
849 | else | 849 | else |
850 | setVScrollBarMode(QScrollView::Auto); | 850 | setVScrollBarMode(QScrollView::Auto); |
851 | if ( ihei *3 > height() ) | 851 | if ( ihei *3 > height() ) |
852 | setHScrollBarMode(QScrollView::AlwaysOff); | 852 | setHScrollBarMode(QScrollView::AlwaysOff); |
853 | else | 853 | else |
854 | setHScrollBarMode(QScrollView::Auto); | 854 | setHScrollBarMode(QScrollView::Auto); |
855 | } else { | 855 | } else { |
856 | setVScrollBarMode(QScrollView::Auto); | 856 | setVScrollBarMode(QScrollView::Auto); |
857 | setHScrollBarMode(QScrollView::Auto); | 857 | setHScrollBarMode(QScrollView::Auto); |
858 | } | 858 | } |
859 | } else { | 859 | } else { |
860 | setVScrollBarMode(QScrollView::AlwaysOff); | 860 | setVScrollBarMode(QScrollView::AlwaysOff); |
861 | setHScrollBarMode(QScrollView::AlwaysOff); | 861 | setHScrollBarMode(QScrollView::AlwaysOff); |
862 | } | 862 | } |
863 | } | 863 | } |
864 | 864 | ||
865 | Incidence *MonthViewCell::selectedIncidence() | 865 | Incidence *MonthViewCell::selectedIncidence() |
866 | { | 866 | { |
867 | int index = currentItem(); | 867 | int index = currentItem(); |
868 | if ( index < 0 ) return 0; | 868 | if ( index < 0 ) return 0; |
869 | 869 | ||
870 | MonthViewItem *mitem = | 870 | MonthViewItem *mitem = |
871 | static_cast<MonthViewItem *>( item( index ) ); | 871 | static_cast<MonthViewItem *>( item( index ) ); |
872 | 872 | ||
873 | if ( !mitem ) return 0; | 873 | if ( !mitem ) return 0; |
874 | 874 | ||
875 | return mitem->incidence(); | 875 | return mitem->incidence(); |
876 | } | 876 | } |
877 | 877 | ||
878 | QDate MonthViewCell::selectedIncidenceDate() | 878 | QDate MonthViewCell::selectedIncidenceDate() |
879 | { | 879 | { |
880 | QDate qd; | 880 | QDate qd; |
881 | int index = currentItem(); | 881 | int index = currentItem(); |
882 | if ( index < 0 ) return qd; | 882 | if ( index < 0 ) return qd; |
883 | 883 | ||
884 | MonthViewItem *mitem = | 884 | MonthViewItem *mitem = |
885 | static_cast<MonthViewItem *>( item( index ) ); | 885 | static_cast<MonthViewItem *>( item( index ) ); |
886 | 886 | ||
887 | if ( !mitem ) return qd; | 887 | if ( !mitem ) return qd; |
888 | 888 | ||
889 | return mitem->incidenceDate(); | 889 | return mitem->incidenceDate(); |
890 | } | 890 | } |
891 | 891 | ||
892 | void MonthViewCell::deselect() | 892 | void MonthViewCell::deselect() |
893 | { | 893 | { |
894 | clearSelection(); | 894 | clearSelection(); |
895 | enableScrollBars( false ); | 895 | enableScrollBars( false ); |
896 | // updateCell(); | 896 | // updateCell(); |
897 | } | 897 | } |
898 | void MonthViewCell::select() | 898 | void MonthViewCell::select() |
899 | { | 899 | { |
900 | ;// updateCell(); | 900 | ;// updateCell(); |
901 | } | 901 | } |
902 | 902 | ||
903 | void MonthViewCell::resizeEvent ( QResizeEvent * e ) | 903 | void MonthViewCell::resizeEvent ( QResizeEvent * e ) |
904 | { | 904 | { |
905 | if ( !mMonthView->isUpdatePossible() ) | 905 | if ( !mMonthView->isUpdatePossible() ) |
906 | return; | 906 | return; |
907 | //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height()); | 907 | //qDebug("++++++++++++++MonthViewCell::resizeEvent %d %d ", width(), height()); |
908 | deselect(); | 908 | deselect(); |
909 | mLabel->setMaximumHeight( height() - lineWidth()*2 ); | 909 | mLabel->setMaximumHeight( height() - lineWidth()*2 ); |
910 | 910 | ||
911 | QString text; | 911 | QString text; |
912 | mLabel->setText( text ); | 912 | mLabel->setText( text ); |
913 | bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; | 913 | bool smallDisplay = QApplication::desktop()->width() < 320 && KOPrefs::instance()->mMonthViewSatSunTog; |
914 | if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) { | 914 | if ( KOPrefs::instance()->mMonthViewWeek || KOGlobals::self()->calendarSystem()->day( mDate ) == 1 || (mDate.dayOfWeek() == 7 && !smallDisplay ) || KOPrefs::instance()->mMonthShowShort) { |
915 | text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " "; | 915 | text = KOGlobals::self()->calendarSystem()->monthName( mDate, true ) + " "; |
916 | mLabel->resize( mLabelBigSize ); | 916 | mLabel->resize( mLabelBigSize ); |
917 | text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); | 917 | text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); |
918 | } else { | 918 | } else { |
919 | mLabel->resize( mLabelSize ); | 919 | mLabel->resize( mLabelSize ); |
920 | text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); | 920 | text += QString::number( KOGlobals::self()->calendarSystem()->day(mDate) ); |
921 | } | 921 | } |
922 | mLabel->setText( text ); | 922 | mLabel->setText( text ); |
923 | 923 | ||
924 | int size = height() - mLabel->height() - lineWidth()-1; | 924 | int size = height() - mLabel->height() - lineWidth()-1; |
925 | //qDebug("LW %d ", lineWidth()); | 925 | //qDebug("LW %d ", lineWidth()); |
926 | if ( size > 0 ) | 926 | if ( size > 0 ) |
927 | verticalScrollBar()->setMaximumHeight( size ); | 927 | verticalScrollBar()->setMaximumHeight( size ); |
928 | size = width() - mLabel->width() -lineWidth()-1; | 928 | size = width() - mLabel->width() -lineWidth()-1; |
929 | if ( size > 0 ) | 929 | if ( size > 0 ) |
930 | horizontalScrollBar()->setMaximumWidth( size ); | 930 | horizontalScrollBar()->setMaximumWidth( size ); |
931 | mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() ); | 931 | mLabel->move( width()-lineWidth() - mLabel->width(), height()-lineWidth() - mLabel->height() ); |
932 | //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); | 932 | //mLabel->setMaximumWidth( width() - mItemList->lineWidth()*2); |
933 | // mItemList->resize ( width(), height () ); | 933 | // mItemList->resize ( width(), height () ); |
934 | if ( e ) | 934 | if ( e ) |
935 | KNoScrollListBox::resizeEvent ( e ); | 935 | KNoScrollListBox::resizeEvent ( e ); |
936 | } | 936 | } |
937 | 937 | ||
938 | void MonthViewCell::defaultAction( QListBoxItem *item ) | 938 | void MonthViewCell::defaultAction( QListBoxItem *item ) |
939 | { | 939 | { |
940 | if ( !item ) return; | 940 | if ( !item ) { |
941 | QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); | ||
942 | emit newEventSignal( dt ); | ||
943 | return; | ||
944 | } | ||
941 | 945 | ||
942 | MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); | 946 | MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); |
943 | Incidence *incidence = eventItem->incidence(); | 947 | Incidence *incidence = eventItem->incidence(); |
944 | if ( incidence ) mMonthView->defaultAction( incidence ); | 948 | if ( incidence ) mMonthView->defaultAction( incidence ); |
945 | } | 949 | } |
946 | void MonthViewCell::showDay() | 950 | void MonthViewCell::showDay() |
947 | { | 951 | { |
948 | emit showDaySignal( date() ); | 952 | emit showDaySignal( date() ); |
949 | } | 953 | } |
950 | void MonthViewCell::newEvent() | 954 | void MonthViewCell::newEvent() |
951 | { | 955 | { |
952 | QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); | 956 | QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); |
953 | emit newEventSignal( dt ); | 957 | emit newEventSignal( dt ); |
954 | } | 958 | } |
955 | void MonthViewCell::cellClicked( QListBoxItem *item ) | 959 | void MonthViewCell::cellClicked( QListBoxItem *item ) |
956 | { | 960 | { |
957 | static QListBoxItem * lastClicked = 0; | 961 | static QListBoxItem * lastClicked = 0; |
958 | if ( item == 0 ) { | 962 | if ( item == 0 ) { |
959 | QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); | 963 | QDateTime dt( date(), QTime( KOPrefs::instance()->mStartTime, 0 ) ); |
960 | emit newEventSignal( dt ); | 964 | emit newEventSignal( dt ); |
961 | return; | 965 | return; |
962 | } | 966 | } |
963 | /* | 967 | /* |
964 | if ( lastClicked ) | 968 | if ( lastClicked ) |
965 | if ( ! item ) { | 969 | if ( ! item ) { |
966 | if ( lastClicked->listBox() != item->listBox() ) | 970 | if ( lastClicked->listBox() != item->listBox() ) |
967 | lastClicked->listBox()->clearSelection(); | 971 | lastClicked->listBox()->clearSelection(); |
968 | } | 972 | } |
969 | */ | 973 | */ |
970 | 974 | ||
971 | mMonthView->setSelectedCell( this ); | 975 | mMonthView->setSelectedCell( this ); |
972 | if( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) enableScrollBars( true ); | 976 | if( KOPrefs::instance()->mEnableMonthScroll || KOPrefs::instance()->mMonthViewWeek ) enableScrollBars( true ); |
973 | select(); | 977 | select(); |
974 | } | 978 | } |
975 | 979 | ||
976 | void MonthViewCell::contextMenu( QListBoxItem *item ) | 980 | void MonthViewCell::contextMenu( QListBoxItem *item ) |
977 | { | 981 | { |
978 | if ( !item ) return; | 982 | if ( !item ) return; |
979 | 983 | ||
980 | MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); | 984 | MonthViewItem *eventItem = static_cast<MonthViewItem *>( item ); |
981 | Incidence *incidence = eventItem->incidence(); | 985 | Incidence *incidence = eventItem->incidence(); |
982 | if ( incidence ) mMonthView->showContextMenu( incidence ); | 986 | if ( incidence ) mMonthView->showContextMenu( incidence ); |
983 | } | 987 | } |
984 | 988 | ||
985 | void MonthViewCell::selection( QListBoxItem *item ) | 989 | void MonthViewCell::selection( QListBoxItem *item ) |
986 | { | 990 | { |
987 | if ( !item ) return; | 991 | if ( !item ) return; |
988 | 992 | ||
989 | mMonthView->setSelectedCell( this ); | 993 | mMonthView->setSelectedCell( this ); |
990 | } | 994 | } |
991 | 995 | ||
992 | 996 | ||
993 | // ******************************************************************************* | 997 | // ******************************************************************************* |
994 | // ******************************************************************************* | 998 | // ******************************************************************************* |
995 | // ******************************************************************************* | 999 | // ******************************************************************************* |
996 | 1000 | ||
997 | 1001 | ||
998 | KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name) | 1002 | KOMonthView::KOMonthView(Calendar *calendar, QWidget *parent, const char *name) |
999 | : KOEventView( calendar, parent, name ), | 1003 | : KOEventView( calendar, parent, name ), |
1000 | mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ), | 1004 | mDaysPerWeek( 7 ), mNumWeeks( 6 ), mNumCells( mDaysPerWeek * mNumWeeks ), |
1001 | mWidthLongDayLabel( 0 ), mSelectedCell( 0 ) | 1005 | mWidthLongDayLabel( 0 ), mSelectedCell( 0 ) |
1002 | { | 1006 | { |
1003 | mFlagKeyPressed = false; | 1007 | mFlagKeyPressed = false; |
1004 | mShortDayLabelsM = false; | 1008 | mShortDayLabelsM = false; |
1005 | mShortDayLabelsW = false; | 1009 | mShortDayLabelsW = false; |
1006 | skipResize = false; | 1010 | skipResize = false; |
1007 | clPending = true; | 1011 | clPending = true; |
1008 | mNavigatorBar = new NavigatorBar( QDate::currentDate(), this, "useBigPixmaps" ); | 1012 | mNavigatorBar = new NavigatorBar( QDate::currentDate(), this, "useBigPixmaps" ); |
1009 | mWidStack = new QWidgetStack( this ); | 1013 | mWidStack = new QWidgetStack( this ); |
1010 | QVBoxLayout* hb = new QVBoxLayout( this ); | 1014 | QVBoxLayout* hb = new QVBoxLayout( this ); |
1011 | mMonthView = new QWidget( mWidStack ); | 1015 | mMonthView = new QWidget( mWidStack ); |
1012 | mWeekView = new QWidget( mWidStack ); | 1016 | mWeekView = new QWidget( mWidStack ); |
1013 | #if QT_VERSION >= 0x030000 | 1017 | #if QT_VERSION >= 0x030000 |
1014 | mWidStack->addWidget(mMonthView ); | 1018 | mWidStack->addWidget(mMonthView ); |
1015 | mWidStack->addWidget(mWeekView ); | 1019 | mWidStack->addWidget(mWeekView ); |
1016 | #else | 1020 | #else |
1017 | mWidStack->addWidget( mMonthView, 1 ); | 1021 | mWidStack->addWidget( mMonthView, 1 ); |
1018 | mWidStack->addWidget( mWeekView , 1 ); | 1022 | mWidStack->addWidget( mWeekView , 1 ); |
1019 | #endif | 1023 | #endif |
1020 | hb->addWidget( mNavigatorBar ); | 1024 | hb->addWidget( mNavigatorBar ); |
1021 | hb->addWidget( mWidStack ); | 1025 | hb->addWidget( mWidStack ); |
1022 | mShowWeekView = KOPrefs::instance()->mMonthViewWeek; | 1026 | mShowWeekView = KOPrefs::instance()->mMonthViewWeek; |
1023 | updatePossible = false; | 1027 | updatePossible = false; |
1024 | //updatePossible = true; | 1028 | //updatePossible = true; |
1025 | mCells.setAutoDelete( true ); | 1029 | mCells.setAutoDelete( true ); |
1026 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; | 1030 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; |
1027 | mDayLabels.resize( mDaysPerWeek ); | 1031 | mDayLabels.resize( mDaysPerWeek ); |
1028 | mDayLabelsW.resize( mDaysPerWeek ); | 1032 | mDayLabelsW.resize( mDaysPerWeek ); |
1029 | QFont bfont = font(); | 1033 | QFont bfont = font(); |
1030 | if ( QApplication::desktop()->width() < 650 ) { | 1034 | if ( QApplication::desktop()->width() < 650 ) { |
1031 | bfont.setPointSize( bfont.pointSize() - 2 ); | 1035 | bfont.setPointSize( bfont.pointSize() - 2 ); |
1032 | } | 1036 | } |
1033 | bfont.setBold( true ); | 1037 | bfont.setBold( true ); |
1034 | int i; | 1038 | int i; |
1035 | 1039 | ||
1036 | for( i = 0; i < mDaysPerWeek; i++ ) { | 1040 | for( i = 0; i < mDaysPerWeek; i++ ) { |
1037 | QLabel *label = new QLabel( mMonthView ); | 1041 | QLabel *label = new QLabel( mMonthView ); |
1038 | label->setFont(bfont); | 1042 | label->setFont(bfont); |
1039 | label->setFrameStyle(QFrame::Panel|QFrame::Raised); | 1043 | label->setFrameStyle(QFrame::Panel|QFrame::Raised); |
1040 | label->setLineWidth(1); | 1044 | label->setLineWidth(1); |
1041 | label->setAlignment(AlignCenter); | 1045 | label->setAlignment(AlignCenter); |
1042 | mDayLabels.insert( i, label ); | 1046 | mDayLabels.insert( i, label ); |
1043 | label = new QLabel( mWeekView ); | 1047 | label = new QLabel( mWeekView ); |
1044 | label->setFont(bfont); | 1048 | label->setFont(bfont); |
1045 | label->setFrameStyle(QFrame::Panel|QFrame::Raised); | 1049 | label->setFrameStyle(QFrame::Panel|QFrame::Raised); |
1046 | label->setLineWidth(1); | 1050 | label->setLineWidth(1); |
1047 | label->setAlignment(AlignCenter); | 1051 | label->setAlignment(AlignCenter); |
1048 | mDayLabelsW.insert( i, label ); | 1052 | mDayLabelsW.insert( i, label ); |
1049 | } | 1053 | } |
1050 | 1054 | ||
1051 | bfont.setBold( false ); | 1055 | bfont.setBold( false ); |
1052 | mWeekLabels.resize( mNumWeeks+1 ); | 1056 | mWeekLabels.resize( mNumWeeks+1 ); |
1053 | mWeekLabelsW.resize( 2 ); | 1057 | mWeekLabelsW.resize( 2 ); |
1054 | for( i = 0; i < mNumWeeks+1; i++ ) { | 1058 | for( i = 0; i < mNumWeeks+1; i++ ) { |
1055 | KOWeekButton *label = new KOWeekButton( mMonthView ); | 1059 | KOWeekButton *label = new KOWeekButton( mMonthView ); |
1056 | label->setFocusPolicy(NoFocus); | 1060 | label->setFocusPolicy(NoFocus); |
1057 | label->setFont(bfont); | 1061 | label->setFont(bfont); |
1058 | connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); | 1062 | connect( label, SIGNAL( selectWeekNum ( int )),this, SLOT( selectInternalWeekNum ( int )) ); |
1059 | label->setFlat(true); | 1063 | label->setFlat(true); |
1060 | QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); | 1064 | QWhatsThis::add(label,i18n("Click on the week number to\nshow week zoomed")); |
1061 | //label->setFrameStyle(QFrame::Panel|QFrame::Raised); | 1065 | //label->setFrameStyle(QFrame::Panel|QFrame::Raised); |
1062 | //label->setLineWidth(1); | 1066 | //label->setLineWidth(1); |
1063 | //label->setAlignment(AlignCenter); | 1067 | //label->setAlignment(AlignCenter); |
1064 | mWeekLabels.insert( i, label ); | 1068 | mWeekLabels.insert( i, label ); |
1065 | } | 1069 | } |
1066 | mWeekLabels[mNumWeeks]->setText( i18n("W")); | 1070 | mWeekLabels[mNumWeeks]->setText( i18n("W")); |
1067 | mWeekLabels[0]->setFocusPolicy(WheelFocus); | 1071 | mWeekLabels[0]->setFocusPolicy(WheelFocus); |
1068 | QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number")); | 1072 | QWhatsThis::add(mWeekLabels[mNumWeeks],i18n("Click on this to\nselect week number")); |
@@ -1246,256 +1250,257 @@ void KOMonthView::updateConfig() | |||
1246 | int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); | 1250 | int width = fontmetric.width(KOGlobals::self()->calendarSystem()->weekDayName(i+1)); |
1247 | if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; | 1251 | if ( width > mWidthLongDayLabel ) mWidthLongDayLabel = width; |
1248 | } | 1252 | } |
1249 | bool temp = mShowSatSunComp ; | 1253 | bool temp = mShowSatSunComp ; |
1250 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; | 1254 | mShowSatSunComp = KOPrefs::instance()->mMonthViewSatSunTog ; |
1251 | if ( ! mShowWeekView ) { | 1255 | if ( ! mShowWeekView ) { |
1252 | if ( temp != KOPrefs::instance()->mMonthViewSatSunTog ) | 1256 | if ( temp != KOPrefs::instance()->mMonthViewSatSunTog ) |
1253 | computeLayout(); | 1257 | computeLayout(); |
1254 | } | 1258 | } |
1255 | updateDayLabels(); | 1259 | updateDayLabels(); |
1256 | //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks); | 1260 | //qDebug("KOMonthView::updateConfig() %d %d %d ",height(), mDayLabels[0]->sizeHint().height() ,mNumWeeks); |
1257 | //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks; | 1261 | //int cellHeight = (height() - mDayLabels[0]->sizeHint().height()) /mNumWeeks; |
1258 | //resizeEvent( 0 ); | 1262 | //resizeEvent( 0 ); |
1259 | for (uint i = 0; i < mCells.count(); ++i) { | 1263 | for (uint i = 0; i < mCells.count(); ++i) { |
1260 | mCells[i]->updateConfig(); | 1264 | mCells[i]->updateConfig(); |
1261 | } | 1265 | } |
1262 | 1266 | ||
1263 | for (uint i = 0; i < mCellsW.count(); ++i) { | 1267 | for (uint i = 0; i < mCellsW.count(); ++i) { |
1264 | mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont); | 1268 | mCellsW[i]->updateConfig(KOPrefs::instance()->mMonthViewUsesBigFont); |
1265 | } | 1269 | } |
1266 | #ifdef DESKTOP_VERSION | 1270 | #ifdef DESKTOP_VERSION |
1267 | MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips); | 1271 | MonthViewCell::toolTipGroup()->setEnabled(KOPrefs::instance()->mEnableToolTips); |
1268 | #endif | 1272 | #endif |
1269 | updateView(); | 1273 | updateView(); |
1270 | } | 1274 | } |
1271 | 1275 | ||
1272 | void KOMonthView::updateDayLabels() | 1276 | void KOMonthView::updateDayLabels() |
1273 | { | 1277 | { |
1274 | 1278 | ||
1275 | QPtrVector<QLabel> *mDayLabelsT; | 1279 | QPtrVector<QLabel> *mDayLabelsT; |
1276 | 1280 | ||
1277 | mDayLabelsT = &mDayLabelsW; | 1281 | mDayLabelsT = &mDayLabelsW; |
1278 | for (int i = 0; i < 7; i++) { | 1282 | for (int i = 0; i < 7; i++) { |
1279 | { | 1283 | { |
1280 | bool show = mShortDayLabelsW; | 1284 | bool show = mShortDayLabelsW; |
1281 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) | 1285 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) |
1282 | show = true; | 1286 | show = true; |
1283 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); | 1287 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); |
1284 | } | 1288 | } |
1285 | } | 1289 | } |
1286 | mDayLabelsT = &mDayLabels; | 1290 | mDayLabelsT = &mDayLabels; |
1287 | for (int i = 0; i < 7; i++) { | 1291 | for (int i = 0; i < 7; i++) { |
1288 | if (KGlobal::locale()->weekStartsMonday() || KOPrefs::instance()->mMonthViewSatSunTog ) { | 1292 | if (KGlobal::locale()->weekStartsMonday() || KOPrefs::instance()->mMonthViewSatSunTog ) { |
1289 | bool show = mShortDayLabelsM; | 1293 | bool show = mShortDayLabelsM; |
1290 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) | 1294 | if ( i > 4 && mShowSatSunComp && mWidthLongDayLabel > (*mDayLabelsT)[i]->width() ) |
1291 | show = true; | 1295 | show = true; |
1292 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); | 1296 | (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i+1,show)); |
1293 | } else { | 1297 | } else { |
1294 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM)); | 1298 | if (i==0) (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(7,mShortDayLabelsM)); |
1295 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM)); | 1299 | else (*mDayLabelsT)[i]->setText(KOGlobals::self()->calendarSystem()->weekDayName(i,mShortDayLabelsM)); |
1296 | 1300 | ||
1297 | } | 1301 | } |
1298 | } | 1302 | } |
1299 | 1303 | ||
1300 | } | 1304 | } |
1301 | 1305 | ||
1302 | void KOMonthView::showDates(const QDate &start, const QDate &) | 1306 | void KOMonthView::showDates(const QDate &start, const QDate &) |
1303 | { | 1307 | { |
1304 | // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl; | 1308 | // kdDebug() << "KOMonthView::showDates(): " << start.toString() << endl; |
1305 | 1309 | ||
1306 | QPtrVector<MonthViewCell> *cells; | 1310 | QPtrVector<MonthViewCell> *cells; |
1307 | QPtrVector<QLabel> *dayLabels; | 1311 | QPtrVector<QLabel> *dayLabels; |
1308 | QPtrVector<KOWeekButton> *weekLabels; | 1312 | QPtrVector<KOWeekButton> *weekLabels; |
1309 | int weekNum = 6; | 1313 | int weekNum = 6; |
1310 | mStartDate = start; | 1314 | mStartDate = start; |
1311 | if ( mShowWeekView ) { | 1315 | if ( mShowWeekView ) { |
1312 | weekNum = 1; | 1316 | weekNum = 1; |
1313 | cells = &mCellsW; | 1317 | cells = &mCellsW; |
1314 | dayLabels = &mDayLabelsW; | 1318 | dayLabels = &mDayLabelsW; |
1315 | weekLabels = &mWeekLabelsW; | 1319 | weekLabels = &mWeekLabelsW; |
1316 | if ( !KGlobal::locale()->weekStartsMonday() ) { | 1320 | if ( !KGlobal::locale()->weekStartsMonday() ) { |
1317 | mStartDate = mStartDate.addDays( 1 ); | 1321 | mStartDate = mStartDate.addDays( 1 ); |
1318 | } | 1322 | } |
1319 | } else { | 1323 | } else { |
1320 | cells = &mCells; | 1324 | cells = &mCells; |
1321 | dayLabels = &mDayLabels; | 1325 | dayLabels = &mDayLabels; |
1322 | weekLabels = &mWeekLabels; | 1326 | weekLabels = &mWeekLabels; |
1323 | } | 1327 | } |
1324 | 1328 | ||
1325 | int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); | 1329 | int mWeekStartsMonday = KGlobal::locale()->weekStartsMonday(); |
1326 | 1330 | ||
1327 | if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) { | 1331 | if ( mShowWeekView || KOPrefs::instance()->mMonthViewSatSunTog ) { |
1328 | mWeekStartsMonday = true; | 1332 | mWeekStartsMonday = true; |
1329 | } | 1333 | } |
1330 | int startWeekDay = mWeekStartsMonday ? 1 : 7; | 1334 | int startWeekDay = mWeekStartsMonday ? 1 : 7; |
1331 | 1335 | ||
1332 | while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { | 1336 | while( KOGlobals::self()->calendarSystem()->dayOfWeek(mStartDate) != startWeekDay ) { |
1333 | mStartDate = mStartDate.addDays( -1 ); | 1337 | mStartDate = mStartDate.addDays( -1 ); |
1334 | } | 1338 | } |
1335 | bool primary = false; | 1339 | bool primary = false; |
1336 | uint i; | 1340 | uint i; |
1337 | for( i = 0; i < (*cells).size(); ++i ) { | 1341 | for( i = 0; i < (*cells).size(); ++i ) { |
1338 | QDate date = mStartDate.addDays( i ); | 1342 | QDate date = mStartDate.addDays( i ); |
1339 | (*cells)[i]->setDate( date ); | 1343 | (*cells)[i]->setDate( date ); |
1340 | 1344 | ||
1341 | #ifndef KORG_NOPLUGINS | 1345 | #ifndef KORG_NOPLUGINS |
1342 | // add holiday, if present | 1346 | // add holiday, if present |
1343 | QString hstring(KOCore::self()->holiday(date)); | 1347 | QString hstring(KOCore::self()->holiday(date)); |
1344 | (*cells)[i]->setHoliday( hstring ); | 1348 | (*cells)[i]->setHoliday( hstring ); |
1345 | #endif | 1349 | #endif |
1346 | 1350 | ||
1347 | } | 1351 | } |
1348 | QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); | 1352 | QDate date = mStartDate.addDays( mWeekStartsMonday ? 3 : 4 ); |
1349 | for( i = 0; i < weekNum; ++i ) { | 1353 | for( i = 0; i < weekNum; ++i ) { |
1350 | int wno; | 1354 | int wno; |
1351 | // remember, according to ISO 8601, the first week of the year is the | 1355 | // remember, according to ISO 8601, the first week of the year is the |
1352 | // first week that contains a thursday. Thus we must subtract off 4, | 1356 | // first week that contains a thursday. Thus we must subtract off 4, |
1353 | // not just 1. | 1357 | // not just 1. |
1354 | int dayOfYear = date.dayOfYear(); | 1358 | int dayOfYear = date.dayOfYear(); |
1355 | if (dayOfYear % 7 != 0) | 1359 | if (dayOfYear % 7 != 0) |
1356 | wno = dayOfYear / 7 + 1; | 1360 | wno = dayOfYear / 7 + 1; |
1357 | else | 1361 | else |
1358 | wno =dayOfYear / 7; | 1362 | wno =dayOfYear / 7; |
1359 | (*weekLabels)[i]->setWeekNum( wno ); | 1363 | (*weekLabels)[i]->setWeekNum( wno ); |
1360 | date = date.addDays( 7 ); | 1364 | date = date.addDays( 7 ); |
1361 | } | 1365 | } |
1362 | updateView(); | 1366 | updateView(); |
1363 | } | 1367 | } |
1364 | 1368 | ||
1365 | void KOMonthView::showEvents(QPtrList<Event>) | 1369 | void KOMonthView::showEvents(QPtrList<Event>) |
1366 | { | 1370 | { |
1367 | qDebug("KOMonthView::selectEvents is not implemented yet. "); | 1371 | qDebug("KOMonthView::selectEvents is not implemented yet. "); |
1368 | } | 1372 | } |
1369 | 1373 | ||
1370 | void KOMonthView::changeEventDisplay(Event *, int) | 1374 | void KOMonthView::changeEventDisplay(Event *, int) |
1371 | { | 1375 | { |
1372 | // this should be re-written to be much more efficient, but this | 1376 | // this should be re-written to be much more efficient, but this |
1373 | // quick-and-dirty-hack gets the job done for right now. | 1377 | // quick-and-dirty-hack gets the job done for right now. |
1378 | qDebug("KOMonthView::changeEventDisplay "); | ||
1374 | updateView(); | 1379 | updateView(); |
1375 | } | 1380 | } |
1376 | 1381 | ||
1377 | void KOMonthView::updateView() | 1382 | void KOMonthView::updateView() |
1378 | { | 1383 | { |
1379 | 1384 | ||
1380 | if ( !updatePossible ) | 1385 | if ( !updatePossible ) |
1381 | return; | 1386 | return; |
1382 | //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU "); | 1387 | //qDebug("UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU "); |
1383 | //QTime ti; | 1388 | //QTime ti; |
1384 | //ti.start(); | 1389 | //ti.start(); |
1385 | clearSelection(); | 1390 | clearSelection(); |
1386 | QPtrVector<MonthViewCell> *cells; | 1391 | QPtrVector<MonthViewCell> *cells; |
1387 | if ( mShowWeekView ) { | 1392 | if ( mShowWeekView ) { |
1388 | cells = &mCellsW; | 1393 | cells = &mCellsW; |
1389 | } else { | 1394 | } else { |
1390 | cells = &mCells; | 1395 | cells = &mCells; |
1391 | } | 1396 | } |
1392 | #if 1 | 1397 | #if 1 |
1393 | int i; | 1398 | int i; |
1394 | int timeSpan = (*cells).size()-1; | 1399 | int timeSpan = (*cells).size()-1; |
1395 | if ( KOPrefs::instance()->mMonthViewWeek ) | 1400 | if ( KOPrefs::instance()->mMonthViewWeek ) |
1396 | timeSpan = 6; | 1401 | timeSpan = 6; |
1397 | for( i = 0; i < timeSpan + 1; ++i ) { | 1402 | for( i = 0; i < timeSpan + 1; ++i ) { |
1398 | (*cells)[i]->startUpdateCell(); | 1403 | (*cells)[i]->startUpdateCell(); |
1399 | } | 1404 | } |
1400 | 1405 | ||
1401 | QPtrList<Event> events = calendar()->events(); | 1406 | QPtrList<Event> events = calendar()->events(); |
1402 | Event *event; | 1407 | Event *event; |
1403 | QDateTime dt; | 1408 | QDateTime dt; |
1404 | bool ok; | 1409 | bool ok; |
1405 | QDate endDate = mStartDate.addDays( timeSpan ); | 1410 | QDate endDate = mStartDate.addDays( timeSpan ); |
1406 | for( event = events.first(); event; event = events.next() ) { // for event | 1411 | for( event = events.first(); event; event = events.next() ) { // for event |
1407 | if ( event->doesRecur() ) { | 1412 | if ( event->doesRecur() ) { |
1408 | bool last; | 1413 | bool last; |
1409 | QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); | 1414 | QDateTime incidenceStart = event->recurrence()->getPreviousDateTime( QDateTime( mStartDate ) , &last ); |
1410 | QDateTime incidenceEnd; | 1415 | QDateTime incidenceEnd; |
1411 | int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); | 1416 | int eventlen = event->dtStart().date().daysTo ( event->dtEnd().date() ); |
1412 | bool invalid = false; | 1417 | bool invalid = false; |
1413 | while( true ) { | 1418 | while( true ) { |
1414 | if ( incidenceStart.isValid() ) { | 1419 | if ( incidenceStart.isValid() ) { |
1415 | incidenceEnd = incidenceStart.addDays( eventlen ); | 1420 | incidenceEnd = incidenceStart.addDays( eventlen ); |
1416 | int st = incidenceStart.date().daysTo( endDate ); | 1421 | int st = incidenceStart.date().daysTo( endDate ); |
1417 | if ( st >= 0 ) { // start before timeend | 1422 | if ( st >= 0 ) { // start before timeend |
1418 | int end = mStartDate.daysTo( incidenceEnd.date() ); | 1423 | int end = mStartDate.daysTo( incidenceEnd.date() ); |
1419 | if ( end >= 0 ) { // end after timestart --- got one! | 1424 | if ( end >= 0 ) { // end after timestart --- got one! |
1420 | //normalize | 1425 | //normalize |
1421 | st = timeSpan - st; | 1426 | st = timeSpan - st; |
1422 | if ( st < 0 ) st = 0; | 1427 | if ( st < 0 ) st = 0; |
1423 | if ( end > timeSpan ) end = timeSpan; | 1428 | if ( end > timeSpan ) end = timeSpan; |
1424 | int iii; | 1429 | int iii; |
1425 | //qDebug("found %s %d %d ",event->summary().latin1(), st, end ); | 1430 | //qDebug("found %s %d %d ",event->summary().latin1(), st, end ); |
1426 | for ( iii = st;iii<= end;++iii) | 1431 | for ( iii = st;iii<= end;++iii) |
1427 | (*cells)[iii]->insertEvent( event ); | 1432 | (*cells)[iii]->insertEvent( event ); |
1428 | } | 1433 | } |
1429 | } | 1434 | } |
1430 | } else { | 1435 | } else { |
1431 | if ( invalid ) | 1436 | if ( invalid ) |
1432 | break; | 1437 | break; |
1433 | invalid = true; | 1438 | invalid = true; |
1434 | //qDebug("invalid %s", event->summary().latin1()); | 1439 | //qDebug("invalid %s", event->summary().latin1()); |
1435 | incidenceStart = QDateTime( mStartDate ).addSecs( -2 );; | 1440 | incidenceStart = QDateTime( mStartDate ).addSecs( -2 );; |
1436 | } | 1441 | } |
1437 | if ( last ) | 1442 | if ( last ) |
1438 | break; | 1443 | break; |
1439 | bool ok; | 1444 | bool ok; |
1440 | incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok ); | 1445 | incidenceStart = event->getNextOccurence( incidenceStart.addSecs( 1 ) ,&ok ); |
1441 | if ( ! ok ) | 1446 | if ( ! ok ) |
1442 | break; | 1447 | break; |
1443 | if ( incidenceStart.date() > endDate ) | 1448 | if ( incidenceStart.date() > endDate ) |
1444 | break; | 1449 | break; |
1445 | } | 1450 | } |
1446 | } else { // no recur | 1451 | } else { // no recur |
1447 | int st = event->dtStart().date().daysTo( endDate ); | 1452 | int st = event->dtStart().date().daysTo( endDate ); |
1448 | if ( st >= 0 ) { // start before timeend | 1453 | if ( st >= 0 ) { // start before timeend |
1449 | int end = mStartDate.daysTo( event->dtEnd().date() ); | 1454 | int end = mStartDate.daysTo( event->dtEnd().date() ); |
1450 | if ( end >= 0 ) { // end after timestart --- got one! | 1455 | if ( end >= 0 ) { // end after timestart --- got one! |
1451 | //normalize | 1456 | //normalize |
1452 | st = timeSpan - st; | 1457 | st = timeSpan - st; |
1453 | if ( st < 0 ) st = 0; | 1458 | if ( st < 0 ) st = 0; |
1454 | if ( end > timeSpan ) end = timeSpan; | 1459 | if ( end > timeSpan ) end = timeSpan; |
1455 | int iii; | 1460 | int iii; |
1456 | for ( iii = st;iii<= end;++iii) | 1461 | for ( iii = st;iii<= end;++iii) |
1457 | (*cells)[iii]->insertEvent( event ); | 1462 | (*cells)[iii]->insertEvent( event ); |
1458 | } | 1463 | } |
1459 | } | 1464 | } |
1460 | } | 1465 | } |
1461 | } | 1466 | } |
1462 | // insert due todos | 1467 | // insert due todos |
1463 | QPtrList<Todo> todos = calendar()->todos( ); | 1468 | QPtrList<Todo> todos = calendar()->todos( ); |
1464 | Todo *todo; | 1469 | Todo *todo; |
1465 | for(todo = todos.first(); todo; todo = todos.next()) { | 1470 | for(todo = todos.first(); todo; todo = todos.next()) { |
1466 | //insertTodo( todo ); | 1471 | //insertTodo( todo ); |
1467 | if ( todo->hasDueDate() ) { | 1472 | if ( todo->hasDueDate() ) { |
1468 | int day = mStartDate.daysTo( todo->dtDue().date() ); | 1473 | int day = mStartDate.daysTo( todo->dtDue().date() ); |
1469 | if ( day >= 0 && day < timeSpan + 1) { | 1474 | if ( day >= 0 && day < timeSpan + 1) { |
1470 | (*cells)[day]->insertTodo( todo ); | 1475 | (*cells)[day]->insertTodo( todo ); |
1471 | } | 1476 | } |
1472 | } | 1477 | } |
1473 | } | 1478 | } |
1474 | 1479 | ||
1475 | for( i = 0; i < timeSpan+1; ++i ) { | 1480 | for( i = 0; i < timeSpan+1; ++i ) { |
1476 | (*cells)[i]->finishUpdateCell(); | 1481 | (*cells)[i]->finishUpdateCell(); |
1477 | } | 1482 | } |
1478 | processSelectionChange(); | 1483 | processSelectionChange(); |
1479 | //qApp->processEvents(); | 1484 | //qApp->processEvents(); |
1480 | for( i = 0; i < timeSpan+1; ++i ) { | 1485 | for( i = 0; i < timeSpan+1; ++i ) { |
1481 | (*cells)[i]->repaintfinishUpdateCell(); | 1486 | (*cells)[i]->repaintfinishUpdateCell(); |
1482 | } | 1487 | } |
1483 | setKeyBFocus(); | 1488 | setKeyBFocus(); |
1484 | #else | 1489 | #else |
1485 | // old code | 1490 | // old code |
1486 | //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); | 1491 | //qDebug("+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ "); |
1487 | int i; | 1492 | int i; |
1488 | for( i = 0; i < (*cells).count(); ++i ) { | 1493 | for( i = 0; i < (*cells).count(); ++i ) { |
1489 | (*cells)[i]->updateCell(); | 1494 | (*cells)[i]->updateCell(); |
1490 | } | 1495 | } |
1491 | 1496 | ||
1492 | //qDebug("KOMonthView::updateView() "); | 1497 | //qDebug("KOMonthView::updateView() "); |
1493 | processSelectionChange(); | 1498 | processSelectionChange(); |
1494 | // qDebug("---------------------------------------------------------------------+ "); | 1499 | // qDebug("---------------------------------------------------------------------+ "); |
1495 | (*cells)[0]->setFocus(); | 1500 | (*cells)[0]->setFocus(); |
1496 | #endif | 1501 | #endif |
1497 | 1502 | ||
1498 | //qDebug("update time %d ", ti.elapsed()); | 1503 | //qDebug("update time %d ", ti.elapsed()); |
1499 | } | 1504 | } |
1500 | 1505 | ||
1501 | void KOMonthView::setKeyBoardFocus() | 1506 | void KOMonthView::setKeyBoardFocus() |
diff --git a/korganizer/kotodoview.cpp b/korganizer/kotodoview.cpp index e008625..ccc4b01 100644 --- a/korganizer/kotodoview.cpp +++ b/korganizer/kotodoview.cpp | |||
@@ -139,282 +139,296 @@ void KOTodoListView::contentsDropEvent(QDropEvent *e) | |||
139 | 139 | ||
140 | if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) && | 140 | if ( !ICalDrag::canDecode( e ) && !VCalDrag::canDecode( e ) && |
141 | !QTextDrag::canDecode( e ) ) { | 141 | !QTextDrag::canDecode( e ) ) { |
142 | e->ignore(); | 142 | e->ignore(); |
143 | return; | 143 | return; |
144 | } | 144 | } |
145 | 145 | ||
146 | DndFactory factory( mCalendar ); | 146 | DndFactory factory( mCalendar ); |
147 | Todo *todo = factory.createDropTodo(e); | 147 | Todo *todo = factory.createDropTodo(e); |
148 | 148 | ||
149 | if (todo) { | 149 | if (todo) { |
150 | e->acceptAction(); | 150 | e->acceptAction(); |
151 | 151 | ||
152 | KOTodoViewItem *destination = | 152 | KOTodoViewItem *destination = |
153 | (KOTodoViewItem *)itemAt(contentsToViewport(e->pos())); | 153 | (KOTodoViewItem *)itemAt(contentsToViewport(e->pos())); |
154 | Todo *destinationEvent = 0; | 154 | Todo *destinationEvent = 0; |
155 | if (destination) destinationEvent = destination->todo(); | 155 | if (destination) destinationEvent = destination->todo(); |
156 | 156 | ||
157 | Todo *existingTodo = mCalendar->todo(todo->uid()); | 157 | Todo *existingTodo = mCalendar->todo(todo->uid()); |
158 | 158 | ||
159 | if(existingTodo) { | 159 | if(existingTodo) { |
160 | Incidence *to = destinationEvent; | 160 | Incidence *to = destinationEvent; |
161 | while(to) { | 161 | while(to) { |
162 | if (to->uid() == todo->uid()) { | 162 | if (to->uid() == todo->uid()) { |
163 | KMessageBox::sorry(this, | 163 | KMessageBox::sorry(this, |
164 | i18n("Cannot move To-Do to itself\nor a child of itself"), | 164 | i18n("Cannot move To-Do to itself\nor a child of itself"), |
165 | i18n("Drop To-Do")); | 165 | i18n("Drop To-Do")); |
166 | delete todo; | 166 | delete todo; |
167 | return; | 167 | return; |
168 | } | 168 | } |
169 | to = to->relatedTo(); | 169 | to = to->relatedTo(); |
170 | } | 170 | } |
171 | internalDrop = true; | 171 | internalDrop = true; |
172 | if ( destinationEvent ) | 172 | if ( destinationEvent ) |
173 | reparentTodoSignal( destinationEvent, existingTodo ); | 173 | reparentTodoSignal( destinationEvent, existingTodo ); |
174 | else | 174 | else |
175 | unparentTodoSignal(existingTodo); | 175 | unparentTodoSignal(existingTodo); |
176 | delete todo; | 176 | delete todo; |
177 | } else { | 177 | } else { |
178 | mCalendar->addTodo(todo); | 178 | mCalendar->addTodo(todo); |
179 | emit todoDropped(todo, KOGlobals::EVENTADDED); | 179 | emit todoDropped(todo, KOGlobals::EVENTADDED); |
180 | if ( destinationEvent ) | 180 | if ( destinationEvent ) |
181 | reparentTodoSignal( destinationEvent, todo ); | 181 | reparentTodoSignal( destinationEvent, todo ); |
182 | } | 182 | } |
183 | } | 183 | } |
184 | else { | 184 | else { |
185 | QString text; | 185 | QString text; |
186 | if (QTextDrag::decode(e,text)) { | 186 | if (QTextDrag::decode(e,text)) { |
187 | //QListViewItem *qlvi = itemAt( contentsToViewport(e->pos()) ); | 187 | //QListViewItem *qlvi = itemAt( contentsToViewport(e->pos()) ); |
188 | KOTodoViewItem *todoi = static_cast<KOTodoViewItem *>(itemAt( contentsToViewport(e->pos()) )); | 188 | KOTodoViewItem *todoi = static_cast<KOTodoViewItem *>(itemAt( contentsToViewport(e->pos()) )); |
189 | qDebug("Dropped : " + text); | 189 | qDebug("Dropped : " + text); |
190 | QStringList emails = QStringList::split(",",text); | 190 | QStringList emails = QStringList::split(",",text); |
191 | for(QStringList::ConstIterator it = emails.begin();it!=emails.end();++it) { | 191 | for(QStringList::ConstIterator it = emails.begin();it!=emails.end();++it) { |
192 | int pos = (*it).find("<"); | 192 | int pos = (*it).find("<"); |
193 | QString name = (*it).left(pos); | 193 | QString name = (*it).left(pos); |
194 | QString email = (*it).mid(pos); | 194 | QString email = (*it).mid(pos); |
195 | if (!email.isEmpty() && todoi) { | 195 | if (!email.isEmpty() && todoi) { |
196 | todoi->todo()->addAttendee(new Attendee(name,email)); | 196 | todoi->todo()->addAttendee(new Attendee(name,email)); |
197 | } | 197 | } |
198 | } | 198 | } |
199 | } | 199 | } |
200 | else { | 200 | else { |
201 | qDebug("KOTodoListView::contentsDropEvent(): Todo from drop not decodable "); | 201 | qDebug("KOTodoListView::contentsDropEvent(): Todo from drop not decodable "); |
202 | e->ignore(); | 202 | e->ignore(); |
203 | } | 203 | } |
204 | } | 204 | } |
205 | #endif | 205 | #endif |
206 | } | 206 | } |
207 | 207 | ||
208 | void KOTodoListView::contentsMousePressEvent(QMouseEvent* e) | 208 | void KOTodoListView::contentsMousePressEvent(QMouseEvent* e) |
209 | { | 209 | { |
210 | #ifndef KORG_NODND | 210 | #ifndef KORG_NODND |
211 | QPoint p(contentsToViewport(e->pos())); | 211 | QPoint p(contentsToViewport(e->pos())); |
212 | QListViewItem *i = itemAt(p); | 212 | QListViewItem *i = itemAt(p); |
213 | mMousePressed = false; | 213 | mMousePressed = false; |
214 | if (i) { | 214 | if (i) { |
215 | // if the user clicked into the root decoration of the item, don't | 215 | // if the user clicked into the root decoration of the item, don't |
216 | // try to start a drag! | 216 | // try to start a drag! |
217 | if (p.x() > header()->sectionPos(header()->mapToIndex(0)) + | 217 | if (p.x() > header()->sectionPos(header()->mapToIndex(0)) + |
218 | treeStepSize() * (i->depth() + (rootIsDecorated() ? 1 : 0)) + | 218 | treeStepSize() * (i->depth() + (rootIsDecorated() ? 1 : 0)) + |
219 | itemMargin() || | 219 | itemMargin() || |
220 | p.x() < header()->sectionPos(header()->mapToIndex(0))) { | 220 | p.x() < header()->sectionPos(header()->mapToIndex(0))) { |
221 | if (e->button()==Qt::LeftButton) { | 221 | if (e->button()==Qt::LeftButton) { |
222 | mPressPos = e->pos(); | 222 | mPressPos = e->pos(); |
223 | mMousePressed = true; | 223 | mMousePressed = true; |
224 | } | 224 | } |
225 | } | 225 | } |
226 | } | 226 | } |
227 | #endif | 227 | #endif |
228 | QListView::contentsMousePressEvent(e); | 228 | QListView::contentsMousePressEvent(e); |
229 | } | 229 | } |
230 | void KOTodoListView::paintEvent(QPaintEvent* e) | 230 | void KOTodoListView::paintEvent(QPaintEvent* e) |
231 | { | 231 | { |
232 | emit paintNeeded(); | 232 | emit paintNeeded(); |
233 | QListView::paintEvent( e); | 233 | QListView::paintEvent( e); |
234 | } | 234 | } |
235 | void KOTodoListView::contentsMouseMoveEvent(QMouseEvent* e) | 235 | void KOTodoListView::contentsMouseMoveEvent(QMouseEvent* e) |
236 | { | 236 | { |
237 | 237 | ||
238 | #ifndef KORG_NODND | 238 | #ifndef KORG_NODND |
239 | //QListView::contentsMouseMoveEvent(e); | 239 | //QListView::contentsMouseMoveEvent(e); |
240 | if (mMousePressed && (mPressPos - e->pos()).manhattanLength() > | 240 | if (mMousePressed && (mPressPos - e->pos()).manhattanLength() > |
241 | QApplication::startDragDistance()*3) { | 241 | QApplication::startDragDistance()*3) { |
242 | mMousePressed = false; | 242 | mMousePressed = false; |
243 | QListViewItem *item = itemAt(contentsToViewport(mPressPos)); | 243 | QListViewItem *item = itemAt(contentsToViewport(mPressPos)); |
244 | if (item) { | 244 | if (item) { |
245 | DndFactory factory( mCalendar ); | 245 | DndFactory factory( mCalendar ); |
246 | ICalDrag *vd = factory.createDrag( | 246 | ICalDrag *vd = factory.createDrag( |
247 | ((KOTodoViewItem *)item)->todo(),viewport()); | 247 | ((KOTodoViewItem *)item)->todo(),viewport()); |
248 | internalDrop = false; | 248 | internalDrop = false; |
249 | // we cannot do any senseful here, because the DnD is still broken in Qt | 249 | // we cannot do any senseful here, because the DnD is still broken in Qt |
250 | if (vd->drag()) { | 250 | if (vd->drag()) { |
251 | if ( !internalDrop ) { | 251 | if ( !internalDrop ) { |
252 | //emit deleteTodo( ((KOTodoViewItem *)item)->todo() ); | 252 | //emit deleteTodo( ((KOTodoViewItem *)item)->todo() ); |
253 | qDebug("Dnd: External move: Delete drag source "); | 253 | qDebug("Dnd: External move: Delete drag source "); |
254 | } else | 254 | } else |
255 | qDebug("Dnd: Internal move "); | 255 | qDebug("Dnd: Internal move "); |
256 | 256 | ||
257 | } else { | 257 | } else { |
258 | if ( !internalDrop ) { | 258 | if ( !internalDrop ) { |
259 | qDebug("Dnd: External Copy"); | 259 | qDebug("Dnd: External Copy"); |
260 | } else | 260 | } else |
261 | qDebug("DnD: Internal copy: Copy pending"); | 261 | qDebug("DnD: Internal copy: Copy pending"); |
262 | } | 262 | } |
263 | } | 263 | } |
264 | } | 264 | } |
265 | #endif | 265 | #endif |
266 | } | 266 | } |
267 | void KOTodoListView::keyReleaseEvent ( QKeyEvent *e ) | ||
268 | { | ||
269 | if ( !e->isAutoRepeat() ) { | ||
270 | mFlagKeyPressed = false; | ||
271 | } | ||
272 | } | ||
273 | |||
274 | |||
267 | void KOTodoListView::keyPressEvent ( QKeyEvent * e ) | 275 | void KOTodoListView::keyPressEvent ( QKeyEvent * e ) |
268 | { | 276 | { |
269 | 277 | qApp->processEvents(); | |
278 | if ( e->isAutoRepeat() && !mFlagKeyPressed ) { | ||
279 | e->ignore(); | ||
280 | // qDebug(" ignore %d",e->isAutoRepeat() ); | ||
281 | return; | ||
282 | } | ||
283 | if (! e->isAutoRepeat() ) | ||
284 | mFlagKeyPressed = true; | ||
270 | QListViewItem* cn; | 285 | QListViewItem* cn; |
271 | if ( e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter ) { | 286 | if ( e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter ) { |
272 | cn = currentItem(); | 287 | cn = currentItem(); |
273 | if ( cn ) { | 288 | if ( cn ) { |
274 | KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); | 289 | KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); |
275 | if ( ci ){ | 290 | if ( ci ){ |
276 | if ( e->state() == ShiftButton ) | 291 | if ( e->state() == ShiftButton ) |
277 | ci->setOn( false ); | 292 | ci->setOn( false ); |
278 | else | 293 | else |
279 | ci->setOn( true ); | 294 | ci->setOn( true ); |
280 | cn = cn->itemBelow(); | 295 | cn = cn->itemBelow(); |
281 | if ( cn ) { | 296 | if ( cn ) { |
282 | setCurrentItem ( cn ); | 297 | setCurrentItem ( cn ); |
283 | ensureItemVisible ( cn ); | 298 | ensureItemVisible ( cn ); |
284 | } | 299 | } |
285 | 300 | ||
286 | } | 301 | } |
287 | } | 302 | } |
288 | 303 | ||
289 | return; | 304 | return; |
290 | } | 305 | } |
291 | 306 | ||
292 | // qDebug("KOTodoListView::keyPressEvent "); | ||
293 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton || mName != "todolistsmall" ) { | 307 | if ( e->state() == Qt::ControlButton || e->state() == Qt::ShiftButton || mName != "todolistsmall" ) { |
294 | switch ( e->key() ) { | 308 | switch ( e->key() ) { |
295 | case Qt::Key_Down: | 309 | case Qt::Key_Down: |
296 | case Qt::Key_Up: | 310 | case Qt::Key_Up: |
297 | QListView::keyPressEvent ( e ); | 311 | QListView::keyPressEvent ( e ); |
298 | break; | 312 | break; |
299 | case Qt::Key_Left: | 313 | case Qt::Key_Left: |
300 | case Qt::Key_Right: | 314 | case Qt::Key_Right: |
301 | QListView::keyPressEvent ( e ); | 315 | QListView::keyPressEvent ( e ); |
302 | e->accept(); | 316 | e->accept(); |
303 | return; | 317 | return; |
304 | break; | 318 | break; |
305 | default: | 319 | default: |
306 | e->ignore(); | 320 | e->ignore(); |
307 | break; | 321 | break; |
308 | } | 322 | } |
309 | return; | 323 | return; |
310 | } | 324 | } |
311 | e->ignore(); | 325 | e->ignore(); |
312 | } | 326 | } |
313 | void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e) | 327 | void KOTodoListView::contentsMouseReleaseEvent(QMouseEvent *e) |
314 | { | 328 | { |
315 | QListView::contentsMouseReleaseEvent(e); | 329 | QListView::contentsMouseReleaseEvent(e); |
316 | mMousePressed = false; | 330 | mMousePressed = false; |
317 | } | 331 | } |
318 | 332 | ||
319 | void KOTodoListView::contentsMouseDoubleClickEvent(QMouseEvent *e) | 333 | void KOTodoListView::contentsMouseDoubleClickEvent(QMouseEvent *e) |
320 | { | 334 | { |
321 | if (!e) return; | 335 | if (!e) return; |
322 | 336 | ||
323 | QPoint vp = contentsToViewport(e->pos()); | 337 | QPoint vp = contentsToViewport(e->pos()); |
324 | 338 | ||
325 | QListViewItem *item = itemAt(vp); | 339 | QListViewItem *item = itemAt(vp); |
326 | 340 | ||
327 | emit double_Clicked(item); | 341 | emit double_Clicked(item); |
328 | if (!item) return; | 342 | if (!item) return; |
329 | 343 | ||
330 | emit doubleClicked(item,vp,0); | 344 | emit doubleClicked(item,vp,0); |
331 | } | 345 | } |
332 | 346 | ||
333 | ///////////////////////////////////////////////////////////////////////////// | 347 | ///////////////////////////////////////////////////////////////////////////// |
334 | 348 | ||
335 | KOQuickTodo::KOQuickTodo(QWidget *parent) : | 349 | KOQuickTodo::KOQuickTodo(QWidget *parent) : |
336 | QLineEdit(parent) | 350 | QLineEdit(parent) |
337 | { | 351 | { |
338 | setText(i18n("Click to add a new Todo")); | 352 | setText(i18n("Click to add a new Todo")); |
339 | } | 353 | } |
340 | 354 | ||
341 | void KOQuickTodo::focusInEvent(QFocusEvent *ev) | 355 | void KOQuickTodo::focusInEvent(QFocusEvent *ev) |
342 | { | 356 | { |
343 | if ( text()==i18n("Click to add a new Todo") ) | 357 | if ( text()==i18n("Click to add a new Todo") ) |
344 | setText(""); | 358 | setText(""); |
345 | QLineEdit::focusInEvent(ev); | 359 | QLineEdit::focusInEvent(ev); |
346 | } | 360 | } |
347 | 361 | ||
348 | void KOQuickTodo::focusOutEvent(QFocusEvent *ev) | 362 | void KOQuickTodo::focusOutEvent(QFocusEvent *ev) |
349 | { | 363 | { |
350 | setText(i18n("Click to add a new Todo")); | 364 | setText(i18n("Click to add a new Todo")); |
351 | QLineEdit::focusOutEvent(ev); | 365 | QLineEdit::focusOutEvent(ev); |
352 | } | 366 | } |
353 | 367 | ||
354 | ///////////////////////////////////////////////////////////////////////////// | 368 | ///////////////////////////////////////////////////////////////////////////// |
355 | 369 | ||
356 | KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : | 370 | KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : |
357 | KOrg::BaseView(calendar,parent,name) | 371 | KOrg::BaseView(calendar,parent,name) |
358 | { | 372 | { |
359 | mPendingUpdateBeforeRepaint = false; | 373 | mPendingUpdateBeforeRepaint = false; |
360 | isFlatDisplay = false; | 374 | isFlatDisplay = false; |
361 | mNavigator = 0; | 375 | mNavigator = 0; |
362 | QBoxLayout *topLayout = new QVBoxLayout(this); | 376 | QBoxLayout *topLayout = new QVBoxLayout(this); |
363 | mName = QString ( name ); | 377 | mName = QString ( name ); |
364 | mBlockUpdate = false; | 378 | mBlockUpdate = false; |
365 | mQuickAdd = new KOQuickTodo(this); | 379 | mQuickAdd = new KOQuickTodo(this); |
366 | topLayout->addWidget(mQuickAdd); | 380 | topLayout->addWidget(mQuickAdd); |
367 | 381 | ||
368 | if ( !KOPrefs::instance()->mEnableQuickTodo ) mQuickAdd->hide(); | 382 | if ( !KOPrefs::instance()->mEnableQuickTodo ) mQuickAdd->hide(); |
369 | 383 | ||
370 | mTodoListView = new KOTodoListView(calendar,this, name ); | 384 | mTodoListView = new KOTodoListView(calendar,this, name ); |
371 | topLayout->addWidget(mTodoListView); | 385 | topLayout->addWidget(mTodoListView); |
372 | //mTodoListView->header()->setMaximumHeight(30); | 386 | //mTodoListView->header()->setMaximumHeight(30); |
373 | mTodoListView->setRootIsDecorated(true); | 387 | mTodoListView->setRootIsDecorated(true); |
374 | mTodoListView->setAllColumnsShowFocus(true); | 388 | mTodoListView->setAllColumnsShowFocus(true); |
375 | 389 | ||
376 | mTodoListView->setShowSortIndicator(true); | 390 | mTodoListView->setShowSortIndicator(true); |
377 | 391 | ||
378 | mTodoListView->addColumn(i18n("Todo")); | 392 | mTodoListView->addColumn(i18n("Todo")); |
379 | mTodoListView->addColumn(i18n("Prio")); | 393 | mTodoListView->addColumn(i18n("Prio")); |
380 | mTodoListView->setColumnAlignment(1,AlignHCenter); | 394 | mTodoListView->setColumnAlignment(1,AlignHCenter); |
381 | mTodoListView->addColumn(i18n("Complete")); | 395 | mTodoListView->addColumn(i18n("Complete")); |
382 | mTodoListView->setColumnAlignment(2,AlignCenter); | 396 | mTodoListView->setColumnAlignment(2,AlignCenter); |
383 | 397 | ||
384 | mTodoListView->addColumn(i18n("Due Date")); | 398 | mTodoListView->addColumn(i18n("Due Date")); |
385 | mTodoListView->setColumnAlignment(3,AlignLeft); | 399 | mTodoListView->setColumnAlignment(3,AlignLeft); |
386 | mTodoListView->addColumn(i18n("Due Time")); | 400 | mTodoListView->addColumn(i18n("Due Time")); |
387 | mTodoListView->setColumnAlignment(4,AlignHCenter); | 401 | mTodoListView->setColumnAlignment(4,AlignHCenter); |
388 | 402 | ||
389 | mTodoListView->addColumn(i18n("Start Date")); | 403 | mTodoListView->addColumn(i18n("Start Date")); |
390 | mTodoListView->setColumnAlignment(5,AlignLeft); | 404 | mTodoListView->setColumnAlignment(5,AlignLeft); |
391 | mTodoListView->addColumn(i18n("Start Time")); | 405 | mTodoListView->addColumn(i18n("Start Time")); |
392 | mTodoListView->setColumnAlignment(6,AlignHCenter); | 406 | mTodoListView->setColumnAlignment(6,AlignHCenter); |
393 | 407 | ||
394 | mTodoListView->addColumn(i18n("Cancelled")); | 408 | mTodoListView->addColumn(i18n("Cancelled")); |
395 | mTodoListView->addColumn(i18n("Categories")); | 409 | mTodoListView->addColumn(i18n("Categories")); |
396 | #if 0 | 410 | #if 0 |
397 | mTodoListView->addColumn(i18n("Sort Id")); | 411 | mTodoListView->addColumn(i18n("Sort Id")); |
398 | mTodoListView->setColumnAlignment(4,AlignHCenter); | 412 | mTodoListView->setColumnAlignment(4,AlignHCenter); |
399 | #endif | 413 | #endif |
400 | 414 | ||
401 | mTodoListView->setMinimumHeight( 60 ); | 415 | mTodoListView->setMinimumHeight( 60 ); |
402 | mTodoListView->setItemsRenameable( true ); | 416 | mTodoListView->setItemsRenameable( true ); |
403 | mTodoListView->setRenameable( 0 ); | 417 | mTodoListView->setRenameable( 0 ); |
404 | mTodoListView->setColumnWidth( 0, 120 ); | 418 | mTodoListView->setColumnWidth( 0, 120 ); |
405 | mTodoListView->setColumnWidthMode(0, QListView::Manual); | 419 | mTodoListView->setColumnWidthMode(0, QListView::Manual); |
406 | mTodoListView->setColumnWidthMode(1, QListView::Manual); | 420 | mTodoListView->setColumnWidthMode(1, QListView::Manual); |
407 | mTodoListView->setColumnWidthMode(2, QListView::Manual); | 421 | mTodoListView->setColumnWidthMode(2, QListView::Manual); |
408 | mTodoListView->setColumnWidthMode(3, QListView::Manual); | 422 | mTodoListView->setColumnWidthMode(3, QListView::Manual); |
409 | mTodoListView->setColumnWidthMode(4, QListView::Manual); | 423 | mTodoListView->setColumnWidthMode(4, QListView::Manual); |
410 | mTodoListView->setColumnWidthMode(5, QListView::Manual); | 424 | mTodoListView->setColumnWidthMode(5, QListView::Manual); |
411 | mTodoListView->setColumnWidthMode(6, QListView::Manual); | 425 | mTodoListView->setColumnWidthMode(6, QListView::Manual); |
412 | mTodoListView->setColumnWidthMode(7, QListView::Manual); | 426 | mTodoListView->setColumnWidthMode(7, QListView::Manual); |
413 | mTodoListView->setColumnWidthMode(8, QListView::Manual); | 427 | mTodoListView->setColumnWidthMode(8, QListView::Manual); |
414 | 428 | ||
415 | 429 | ||
416 | mKOTodoViewWhatsThis = new KOTodoViewWhatsThis(mTodoListView->viewport(),this); | 430 | mKOTodoViewWhatsThis = new KOTodoViewWhatsThis(mTodoListView->viewport(),this); |
417 | 431 | ||
418 | mPriorityPopupMenu = new QPopupMenu(this); | 432 | mPriorityPopupMenu = new QPopupMenu(this); |
419 | for (int i = 1; i <= 5; i++) { | 433 | for (int i = 1; i <= 5; i++) { |
420 | QString label = QString ("%1").arg (i); | 434 | QString label = QString ("%1").arg (i); |
@@ -473,370 +487,408 @@ KOTodoView::KOTodoView(Calendar *calendar,QWidget* parent,const char* name) : | |||
473 | SLOT (newTodo()),0,1); | 487 | SLOT (newTodo()),0,1); |
474 | mPopupMenu->insertItem(i18n("delete completed To-Dos","Purge Completed"), | 488 | mPopupMenu->insertItem(i18n("delete completed To-Dos","Purge Completed"), |
475 | this, SLOT(purgeCompleted()),0,2); | 489 | this, SLOT(purgeCompleted()),0,2); |
476 | mPopupMenu->insertItem(i18n("Show Completed"), | 490 | mPopupMenu->insertItem(i18n("Show Completed"), |
477 | this, SLOT( toggleCompleted() ),0,3 ); | 491 | this, SLOT( toggleCompleted() ),0,3 ); |
478 | mPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"), | 492 | mPopupMenu->insertItem(i18n("toggle quick todo","Show Quick Todo"), |
479 | this, SLOT( toggleQuickTodo() ),0,4 ); | 493 | this, SLOT( toggleQuickTodo() ),0,4 ); |
480 | mPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"), | 494 | mPopupMenu->insertItem(i18n("toggle running todo","Hide not Running"), |
481 | this, SLOT( toggleRunning() ),0,5 ); | 495 | this, SLOT( toggleRunning() ),0,5 ); |
482 | mPopupMenu->insertItem(i18n(" set all open","Display all opened"), | 496 | mPopupMenu->insertItem(i18n(" set all open","Display all opened"), |
483 | this, SLOT( setAllOpen() ),0,6 ); | 497 | this, SLOT( setAllOpen() ),0,6 ); |
484 | mPopupMenu->insertItem(i18n(" set all close","Display all closed"), | 498 | mPopupMenu->insertItem(i18n(" set all close","Display all closed"), |
485 | this, SLOT( setAllClose() ),0,7 ); | 499 | this, SLOT( setAllClose() ),0,7 ); |
486 | mPopupMenu->insertItem(i18n(" set all flat","Display all flat"), | 500 | mPopupMenu->insertItem(i18n(" set all flat","Display all flat"), |
487 | this, SLOT( setAllFlat() ),0,8 ); | 501 | this, SLOT( setAllFlat() ),0,8 ); |
488 | mDocPrefs = new DocPrefs( name ); | 502 | mDocPrefs = new DocPrefs( name ); |
489 | 503 | ||
490 | mItemPopupMenu->insertItem(i18n("Todo View"),mPopupMenu ); | 504 | mItemPopupMenu->insertItem(i18n("Todo View"),mPopupMenu ); |
491 | mPopupMenu->setCheckable( true ); | 505 | mPopupMenu->setCheckable( true ); |
492 | mItemPopupMenu->setCheckable( true ); | 506 | mItemPopupMenu->setCheckable( true ); |
493 | 507 | ||
494 | 508 | ||
495 | mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); | 509 | mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); |
496 | mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); | 510 | mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); |
497 | 511 | ||
498 | mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); | 512 | mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); |
499 | mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); | 513 | mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); |
500 | 514 | ||
501 | mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); | 515 | mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); |
502 | mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); | 516 | mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); |
503 | 517 | ||
504 | 518 | ||
505 | // Double clicking conflicts with opening/closing the subtree | 519 | // Double clicking conflicts with opening/closing the subtree |
506 | connect( mTodoListView, SIGNAL( doubleClicked( QListViewItem *) ), | 520 | connect( mTodoListView, SIGNAL( doubleClicked( QListViewItem *) ), |
507 | SLOT( editItem( QListViewItem *) ) ); | 521 | SLOT( editItem( QListViewItem *) ) ); |
508 | /* | 522 | /* |
509 | connect( mTodoListView, SIGNAL( rightButtonClicked ( QListViewItem *, | 523 | connect( mTodoListView, SIGNAL( rightButtonClicked ( QListViewItem *, |
510 | const QPoint &,int ) ), | 524 | const QPoint &,int ) ), |
511 | SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); | 525 | SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); |
512 | */ | 526 | */ |
513 | connect( mTodoListView, SIGNAL( contextRequest ( QListViewItem *, | 527 | connect( mTodoListView, SIGNAL( contextRequest ( QListViewItem *, |
514 | const QPoint &,int ) ), | 528 | const QPoint &,int ) ), |
515 | SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); | 529 | SLOT( popupMenu( QListViewItem *, const QPoint & ,int) ) ); |
516 | connect( mTodoListView, SIGNAL( clicked( QListViewItem * ) ), | 530 | connect( mTodoListView, SIGNAL( clicked( QListViewItem * ) ), |
517 | SLOT( itemClicked( QListViewItem * ) ) ); | 531 | SLOT( itemClicked( QListViewItem * ) ) ); |
518 | connect( mTodoListView, SIGNAL( double_Clicked( QListViewItem * ) ), | 532 | connect( mTodoListView, SIGNAL( double_Clicked( QListViewItem * ) ), |
519 | SLOT( itemDoubleClicked( QListViewItem * ) ) ); | 533 | SLOT( itemDoubleClicked( QListViewItem * ) ) ); |
520 | connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), | 534 | connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), |
521 | SLOT( updateView() ) ); | 535 | SLOT( updateView() ) ); |
522 | connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), | 536 | connect( mTodoListView, SIGNAL( todoDropped( Todo *, int ) ), |
523 | SLOT( todoModified(Todo *, int) ) ); | 537 | SLOT( todoModified(Todo *, int) ) ); |
524 | connect( mTodoListView, SIGNAL( expanded( QListViewItem * ) ), | 538 | connect( mTodoListView, SIGNAL( expanded( QListViewItem * ) ), |
525 | SLOT( itemStateChanged( QListViewItem * ) ) ); | 539 | SLOT( itemStateChanged( QListViewItem * ) ) ); |
526 | connect( mTodoListView, SIGNAL( collapsed( QListViewItem * ) ), | 540 | connect( mTodoListView, SIGNAL( collapsed( QListViewItem * ) ), |
527 | SLOT( itemStateChanged( QListViewItem * ) ) ); | 541 | SLOT( itemStateChanged( QListViewItem * ) ) ); |
528 | connect( mTodoListView, SIGNAL( paintNeeded() ), | 542 | connect( mTodoListView, SIGNAL( paintNeeded() ), |
529 | SLOT( paintNeeded()) ); | 543 | SLOT( paintNeeded()) ); |
530 | 544 | ||
531 | #if 0 | 545 | #if 0 |
532 | connect(mTodoListView,SIGNAL(selectionChanged(QListViewItem *)), | 546 | connect(mTodoListView,SIGNAL(selectionChanged(QListViewItem *)), |
533 | SLOT(selectionChanged(QListViewItem *))); | 547 | SLOT(selectionChanged(QListViewItem *))); |
534 | connect(mTodoListView,SIGNAL(clicked(QListViewItem *)), | 548 | connect(mTodoListView,SIGNAL(clicked(QListViewItem *)), |
535 | SLOT(selectionChanged(QListViewItem *))); | 549 | SLOT(selectionChanged(QListViewItem *))); |
536 | connect(mTodoListView,SIGNAL(pressed(QListViewItem *)), | 550 | connect(mTodoListView,SIGNAL(pressed(QListViewItem *)), |
537 | SLOT(selectionChanged(QListViewItem *))); | 551 | SLOT(selectionChanged(QListViewItem *))); |
538 | #endif | 552 | #endif |
539 | 553 | ||
540 | connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) )); | 554 | connect( mTodoListView, SIGNAL(reparentTodoSignal( Todo *,Todo * ) ), SIGNAL(reparentTodoSignal( Todo *,Todo * ) )); |
541 | connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) )); | 555 | connect( mTodoListView, SIGNAL(unparentTodoSignal(Todo *) ), SIGNAL(unparentTodoSignal(Todo *) )); |
542 | connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) )); | 556 | connect( mTodoListView, SIGNAL( deleteTodo(Todo *) ), SIGNAL(deleteTodoSignal(Todo *) )); |
543 | 557 | ||
544 | connect( mTodoListView, SIGNAL(selectionChanged() ), | 558 | connect( mTodoListView, SIGNAL(selectionChanged() ), |
545 | SLOT( processSelectionChange() ) ); | 559 | SLOT( processSelectionChange() ) ); |
546 | connect( mQuickAdd, SIGNAL( returnPressed () ), | 560 | connect( mQuickAdd, SIGNAL( returnPressed () ), |
547 | SLOT( addQuickTodo() ) ); | 561 | SLOT( addQuickTodo() ) ); |
548 | 562 | ||
549 | } | 563 | } |
550 | 564 | ||
551 | KOTodoView::~KOTodoView() | 565 | KOTodoView::~KOTodoView() |
552 | { | 566 | { |
553 | // delete mKOTodoViewWhatsThis; | 567 | // delete mKOTodoViewWhatsThis; |
554 | delete mDocPrefs; | 568 | delete mDocPrefs; |
555 | } | 569 | } |
556 | QString KOTodoView::getWhatsThisText(QPoint p) | 570 | QString KOTodoView::getWhatsThisText(QPoint p) |
557 | { | 571 | { |
558 | KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p ); | 572 | KOTodoViewItem* item = ( KOTodoViewItem* ) mTodoListView->itemAt( p ); |
559 | if ( item ) | 573 | if ( item ) |
560 | return KIncidenceFormatter::instance()->getFormattedText( item->todo(), | 574 | return KIncidenceFormatter::instance()->getFormattedText( item->todo(), |
561 | KOPrefs::instance()->mWTshowDetails, | 575 | KOPrefs::instance()->mWTshowDetails, |
562 | KOPrefs::instance()->mWTshowCreated, | 576 | KOPrefs::instance()->mWTshowCreated, |
563 | KOPrefs::instance()->mWTshowChanged); | 577 | KOPrefs::instance()->mWTshowChanged); |
564 | return i18n("That is the todo view" ); | 578 | return i18n("That is the todo view" ); |
565 | 579 | ||
566 | } | 580 | } |
567 | 581 | ||
568 | void KOTodoView::jumpToDate () | 582 | void KOTodoView::jumpToDate () |
569 | { | 583 | { |
570 | // if (mActiveItem) { | 584 | // if (mActiveItem) { |
571 | // mActiveItem->todo()); | 585 | // mActiveItem->todo()); |
572 | // if ( mActiveItem->todo()->hasDueDate() ) | 586 | // if ( mActiveItem->todo()->hasDueDate() ) |
573 | // emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() ); | 587 | // emit mActiveItem->todo()jumpToTime( mTodo->dtDue().date() ); |
574 | } | 588 | } |
575 | void KOTodoView::paintNeeded() | 589 | void KOTodoView::paintNeeded() |
576 | { | 590 | { |
577 | if ( mPendingUpdateBeforeRepaint ) { | 591 | if ( mPendingUpdateBeforeRepaint ) { |
578 | updateView(); | 592 | updateView(); |
579 | mPendingUpdateBeforeRepaint = false; | 593 | mPendingUpdateBeforeRepaint = false; |
580 | } | 594 | } |
581 | } | 595 | } |
582 | void KOTodoView::paintEvent(QPaintEvent * pevent) | 596 | void KOTodoView::paintEvent(QPaintEvent * pevent) |
583 | { | 597 | { |
584 | if ( mPendingUpdateBeforeRepaint ) { | 598 | if ( mPendingUpdateBeforeRepaint ) { |
585 | updateView(); | 599 | updateView(); |
586 | mPendingUpdateBeforeRepaint = false; | 600 | mPendingUpdateBeforeRepaint = false; |
587 | } | 601 | } |
588 | KOrg::BaseView::paintEvent( pevent); | 602 | KOrg::BaseView::paintEvent( pevent); |
589 | } | 603 | } |
590 | 604 | ||
591 | void KOTodoView::updateView() | 605 | void KOTodoView::updateView() |
592 | { | 606 | { |
593 | pendingSubtodo = 0; | 607 | pendingSubtodo = 0; |
594 | if ( mBlockUpdate ) { | 608 | if ( mBlockUpdate ) { |
595 | return; | 609 | return; |
596 | } | 610 | } |
597 | if ( !isVisible() ) { | 611 | if ( !isVisible() ) { |
598 | mPendingUpdateBeforeRepaint = true; | 612 | mPendingUpdateBeforeRepaint = true; |
599 | return; | 613 | return; |
600 | } | 614 | } |
615 | storeCurrentItem(); | ||
601 | //qDebug("KOTodoView::updateView() %x", this); | 616 | //qDebug("KOTodoView::updateView() %x", this); |
602 | if ( isFlatDisplay ) { | 617 | if ( isFlatDisplay ) { |
603 | displayAllFlat(); | 618 | displayAllFlat(); |
619 | resetCurrentItem(); | ||
604 | return; | 620 | return; |
605 | } | 621 | } |
606 | //qDebug("update "); | 622 | //qDebug("update "); |
607 | // kdDebug() << "KOTodoView::updateView()" << endl; | 623 | // kdDebug() << "KOTodoView::updateView()" << endl; |
608 | QFont fo = KOPrefs::instance()->mTodoViewFont; | 624 | QFont fo = KOPrefs::instance()->mTodoViewFont; |
609 | Incidence* oldInc = 0; | 625 | |
610 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | ||
611 | if (mActiveItem) | ||
612 | oldInc = mActiveItem->todo(); | ||
613 | 626 | ||
614 | mTodoListView->clear(); | 627 | mTodoListView->clear(); |
615 | if ( mName == "todolistsmall" ) { | 628 | if ( mName == "todolistsmall" ) { |
616 | if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) { | 629 | if ( KOPrefs::instance()->mTodoViewUsesSmallFont ) { |
617 | int ps = fo.pointSize() -2; | 630 | int ps = fo.pointSize() -2; |
618 | if ( ps > 12 ) | 631 | if ( ps > 12 ) |
619 | ps -= 2; | 632 | ps -= 2; |
620 | fo.setPointSize( ps ); | 633 | fo.setPointSize( ps ); |
621 | } | 634 | } |
622 | } | 635 | } |
623 | 636 | ||
624 | mTodoListView->setFont( fo ); | 637 | mTodoListView->setFont( fo ); |
625 | // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont ); | 638 | // QFontMetrics fm ( KOPrefs::instance()->mTodoViewFont ); |
626 | //mTodoListView->header()->setMaximumHeight(fm.height()); | 639 | //mTodoListView->header()->setMaximumHeight(fm.height()); |
627 | QPtrList<Todo> todoList = calendar()->todos(); | 640 | QPtrList<Todo> todoList = calendar()->todos(); |
628 | 641 | ||
629 | /* | 642 | /* |
630 | kdDebug() << "KOTodoView::updateView(): Todo List:" << endl; | 643 | kdDebug() << "KOTodoView::updateView(): Todo List:" << endl; |
631 | Event *t; | 644 | Event *t; |
632 | for(t = todoList.first(); t; t = todoList.next()) { | 645 | for(t = todoList.first(); t; t = todoList.next()) { |
633 | kdDebug() << " " << t->getSummary() << endl; | 646 | kdDebug() << " " << t->getSummary() << endl; |
634 | 647 | ||
635 | if (t->getRelatedTo()) { | 648 | if (t->getRelatedTo()) { |
636 | kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl; | 649 | kdDebug() << " (related to " << t->getRelatedTo()->getSummary() << ")" << endl; |
637 | } | 650 | } |
638 | 651 | ||
639 | QPtrList<Event> l = t->getRelations(); | 652 | QPtrList<Event> l = t->getRelations(); |
640 | Event *c; | 653 | Event *c; |
641 | for(c=l.first();c;c=l.next()) { | 654 | for(c=l.first();c;c=l.next()) { |
642 | kdDebug() << " - relation: " << c->getSummary() << endl; | 655 | kdDebug() << " - relation: " << c->getSummary() << endl; |
643 | } | 656 | } |
644 | } | 657 | } |
645 | */ | 658 | */ |
646 | 659 | ||
647 | // Put for each Event a KOTodoViewItem in the list view. Don't rely on a | 660 | // Put for each Event a KOTodoViewItem in the list view. Don't rely on a |
648 | // specific order of events. That means that we have to generate parent items | 661 | // specific order of events. That means that we have to generate parent items |
649 | // recursively for proper hierarchical display of Todos. | 662 | // recursively for proper hierarchical display of Todos. |
650 | mTodoMap.clear(); | 663 | mTodoMap.clear(); |
651 | Todo *todo; | 664 | Todo *todo; |
652 | todo = todoList.first();// todo; todo = todoList.next()) { | 665 | todo = todoList.first();// todo; todo = todoList.next()) { |
653 | while ( todo ) { | 666 | while ( todo ) { |
654 | bool next = true; | 667 | bool next = true; |
655 | // qDebug("todo %s ", todo->summary().latin1()); | 668 | // qDebug("todo %s ", todo->summary().latin1()); |
656 | Incidence *incidence = todo->relatedTo(); | 669 | Incidence *incidence = todo->relatedTo(); |
657 | while ( incidence ) { | 670 | while ( incidence ) { |
658 | if ( incidence->type() == "Todo") { | 671 | if ( incidence->type() == "Todo") { |
659 | //qDebug("related %s ",incidence->summary().latin1() ); | 672 | //qDebug("related %s ",incidence->summary().latin1() ); |
660 | if ( !(todoList.contains ( ((Todo* )incidence ) ) )) { | 673 | if ( !(todoList.contains ( ((Todo* )incidence ) ) )) { |
661 | //qDebug("related not found "); | 674 | //qDebug("related not found "); |
662 | todoList.remove( ); | 675 | todoList.remove( ); |
663 | todo = todoList.current(); | 676 | todo = todoList.current(); |
664 | next = false; | 677 | next = false; |
665 | incidence = 0; | 678 | incidence = 0; |
666 | 679 | ||
667 | } else { | 680 | } else { |
668 | //qDebug("related found "); | 681 | //qDebug("related found "); |
669 | incidence = incidence->relatedTo(); | 682 | incidence = incidence->relatedTo(); |
670 | } | 683 | } |
671 | } else | 684 | } else |
672 | incidence = 0; | 685 | incidence = 0; |
673 | } | 686 | } |
674 | if ( next ) | 687 | if ( next ) |
675 | todo = todoList.next(); | 688 | todo = todoList.next(); |
676 | } | 689 | } |
677 | // qDebug("again .... "); | 690 | // qDebug("again .... "); |
678 | // for(todo = todoList.first(); todo; todo = todoList.next()) { | 691 | // for(todo = todoList.first(); todo; todo = todoList.next()) { |
679 | 692 | ||
680 | // qDebug("yytodo %s ", todo->summary().latin1()); | 693 | // qDebug("yytodo %s ", todo->summary().latin1()); |
681 | // } | 694 | // } |
682 | //qDebug("for "); | 695 | //qDebug("for "); |
683 | for(todo = todoList.first(); todo; todo = todoList.next()) { | 696 | for(todo = todoList.first(); todo; todo = todoList.next()) { |
684 | if (!mTodoMap.contains(todo) && checkTodo( todo ) ) | 697 | if (!mTodoMap.contains(todo) && checkTodo( todo ) ) |
685 | { | 698 | { |
686 | insertTodoItem(todo); | 699 | insertTodoItem(todo); |
687 | } | 700 | } |
688 | } | 701 | } |
689 | //qDebug("for end "); | 702 | //qDebug("for end "); |
690 | // Restore opened/closed state | 703 | // Restore opened/closed state |
691 | mTodoListView->blockSignals( true ); | 704 | mTodoListView->blockSignals( true ); |
692 | if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() ); | 705 | if( mDocPrefs ) restoreItemState( mTodoListView->firstChild() ); |
693 | mTodoListView->blockSignals( false ); | 706 | mTodoListView->blockSignals( false ); |
694 | mTodoListView->setFocus(); | 707 | resetCurrentItem(); |
695 | if ( mTodoListView->firstChild () ) { | ||
696 | if ( oldInc ) { | ||
697 | KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild (); | ||
698 | while ( item ) { | ||
699 | if ( item->todo() == oldInc ) { | ||
700 | mTodoListView->setCurrentItem( item ); | ||
701 | mTodoListView->ensureItemVisible( item ); | ||
702 | break; | ||
703 | } | ||
704 | item = (KOTodoViewItem*)item->itemBelow(); | ||
705 | } | ||
706 | if ( ! item ) | ||
707 | mTodoListView->setCurrentItem( mTodoListView->firstChild () ); | ||
708 | } else { | ||
709 | mTodoListView->setCurrentItem( mTodoListView->firstChild () ); | ||
710 | } | ||
711 | } | ||
712 | processSelectionChange(); | 708 | processSelectionChange(); |
713 | } | 709 | } |
714 | 710 | ||
711 | void KOTodoView::storeCurrentItem() | ||
712 | { | ||
713 | mCurItem = 0; | ||
714 | mCurItemRootParent = 0; | ||
715 | mCurItemAbove = 0; | ||
716 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | ||
717 | if (mActiveItem) { | ||
718 | mCurItem = mActiveItem->todo(); | ||
719 | KOTodoViewItem* activeItemAbove = (KOTodoViewItem*)mActiveItem->itemAbove (); | ||
720 | if ( activeItemAbove ) | ||
721 | mCurItemAbove = activeItemAbove->todo(); | ||
722 | while ( mActiveItem->parent() != 0 ) | ||
723 | mActiveItem = (KOTodoViewItem*)mActiveItem->parent(); | ||
724 | mCurItemRootParent = mActiveItem->todo(); | ||
725 | } | ||
726 | mActiveItem = 0; | ||
727 | } | ||
728 | |||
729 | void KOTodoView::resetCurrentItem() | ||
730 | { | ||
731 | mTodoListView->setFocus(); | ||
732 | KOTodoViewItem* foundItem = 0; | ||
733 | KOTodoViewItem* foundItemRoot = 0; | ||
734 | KOTodoViewItem* foundItemAbove = 0; | ||
735 | if ( mTodoListView->firstChild () ) { | ||
736 | if ( mCurItem ) { | ||
737 | KOTodoViewItem* item = (KOTodoViewItem*)mTodoListView->firstChild (); | ||
738 | while ( item ) { | ||
739 | if ( item->todo() == mCurItem ) { | ||
740 | foundItem = item; | ||
741 | break; | ||
742 | } else if ( item->todo() == mCurItemAbove ) { | ||
743 | foundItemAbove = item; | ||
744 | |||
745 | } else if ( item->todo() == mCurItemRootParent ) { | ||
746 | foundItemRoot = item; | ||
747 | } | ||
748 | item = (KOTodoViewItem*)item->itemBelow(); | ||
749 | } | ||
750 | if ( ! foundItem ) { | ||
751 | if ( foundItemAbove ) | ||
752 | foundItem = foundItemAbove; | ||
753 | else | ||
754 | foundItem = foundItemRoot; | ||
755 | } | ||
756 | } | ||
757 | if ( foundItem ) { | ||
758 | mTodoListView->setCurrentItem( foundItem ); | ||
759 | mTodoListView->ensureItemVisible( foundItem ); | ||
760 | } else { | ||
761 | mTodoListView->setCurrentItem( mTodoListView->firstChild () ); | ||
762 | } | ||
763 | } | ||
764 | mTodoListView->setFocus(); | ||
765 | } | ||
766 | //Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove; | ||
715 | bool KOTodoView::checkTodo( Todo * todo ) | 767 | bool KOTodoView::checkTodo( Todo * todo ) |
716 | { | 768 | { |
717 | 769 | ||
718 | if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() ) | 770 | if ( !KOPrefs::instance()->mShowCompletedTodo && todo->isCompleted() ) |
719 | return false; | 771 | return false; |
720 | if ( !todo->isCompleted() ) { | 772 | if ( !todo->isCompleted() ) { |
721 | if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() ) | 773 | if ( todo->hasDueDate() && todo->dtDue().date() <= QDate::currentDate() ) |
722 | return true; | 774 | return true; |
723 | } | 775 | } |
724 | if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) { | 776 | if ( KOPrefs::instance()->mHideNonStartedTodos && mNavigator ) { |
725 | if ( todo->hasStartDate() ) | 777 | if ( todo->hasStartDate() ) |
726 | if ( mNavigator->selectedDates().last() < todo->dtStart().date() ) | 778 | if ( mNavigator->selectedDates().last() < todo->dtStart().date() ) |
727 | return false; | 779 | return false; |
728 | if ( todo->hasDueDate() ) | 780 | if ( todo->hasDueDate() ) |
729 | if ( mNavigator->selectedDates().first() > todo->dtDue().date() ) | 781 | if ( mNavigator->selectedDates().first() > todo->dtDue().date() ) |
730 | return false; | 782 | return false; |
731 | } | 783 | } |
732 | return true; | 784 | return true; |
733 | } | 785 | } |
734 | 786 | ||
735 | void KOTodoView::restoreItemState( QListViewItem *item ) | 787 | void KOTodoView::restoreItemState( QListViewItem *item ) |
736 | { | 788 | { |
737 | pendingSubtodo = 0; | 789 | pendingSubtodo = 0; |
738 | while( item ) { | 790 | while( item ) { |
739 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; | 791 | KOTodoViewItem *todoItem = (KOTodoViewItem *)item; |
740 | todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) ); | 792 | todoItem->setOpen( mDocPrefs->readBoolEntry( todoItem->todo()->uid() ) ); |
741 | if( item->childCount() > 0 ) restoreItemState( item->firstChild() ); | 793 | if( item->childCount() > 0 ) restoreItemState( item->firstChild() ); |
742 | item = item->nextSibling(); | 794 | item = item->nextSibling(); |
743 | } | 795 | } |
744 | } | 796 | } |
745 | 797 | ||
746 | 798 | ||
747 | QMap<Todo *,KOTodoViewItem *>::ConstIterator | 799 | QMap<Todo *,KOTodoViewItem *>::ConstIterator |
748 | KOTodoView::insertTodoItem(Todo *todo) | 800 | KOTodoView::insertTodoItem(Todo *todo) |
749 | { | 801 | { |
750 | 802 | ||
751 | // kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl; | 803 | // kdDebug() << "KOTodoView::insertTodoItem(): " << todo->getSummary() << endl; |
752 | // TODO: Check, if dynmaic cast is necessary | 804 | // TODO: Check, if dynmaic cast is necessary |
753 | 805 | ||
754 | pendingSubtodo = 0; | 806 | pendingSubtodo = 0; |
755 | Incidence *incidence = todo->relatedTo(); | 807 | Incidence *incidence = todo->relatedTo(); |
756 | if (incidence && incidence->type() == "Todo") { | 808 | if (incidence && incidence->type() == "Todo") { |
757 | Todo *relatedTodo = static_cast<Todo *>(incidence); | 809 | Todo *relatedTodo = static_cast<Todo *>(incidence); |
758 | 810 | ||
759 | // kdDebug() << " has Related" << endl; | 811 | // kdDebug() << " has Related" << endl; |
760 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; | 812 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; |
761 | itemIterator = mTodoMap.find(relatedTodo); | 813 | itemIterator = mTodoMap.find(relatedTodo); |
762 | if (itemIterator == mTodoMap.end()) { | 814 | if (itemIterator == mTodoMap.end()) { |
763 | // kdDebug() << " related not yet in list" << endl; | 815 | // kdDebug() << " related not yet in list" << endl; |
764 | itemIterator = insertTodoItem (relatedTodo); | 816 | itemIterator = insertTodoItem (relatedTodo); |
765 | } | 817 | } |
766 | // isn't this pretty stupid? We give one Todo to the KOTodoViewItem | 818 | // isn't this pretty stupid? We give one Todo to the KOTodoViewItem |
767 | // and one into the map. Sure finding is more easy but why? -zecke | 819 | // and one into the map. Sure finding is more easy but why? -zecke |
768 | KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this); | 820 | KOTodoViewItem *todoItem = new KOTodoViewItem(*itemIterator,todo,this); |
769 | return mTodoMap.insert(todo,todoItem); | 821 | return mTodoMap.insert(todo,todoItem); |
770 | } else { | 822 | } else { |
771 | // kdDebug() << " no Related" << endl; | 823 | // kdDebug() << " no Related" << endl; |
772 | // see above -zecke | 824 | // see above -zecke |
773 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); | 825 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); |
774 | return mTodoMap.insert(todo,todoItem); | 826 | return mTodoMap.insert(todo,todoItem); |
775 | } | 827 | } |
776 | } | 828 | } |
777 | 829 | ||
778 | 830 | ||
779 | void KOTodoView::updateConfig() | 831 | void KOTodoView::updateConfig() |
780 | { | 832 | { |
781 | updateView(); | 833 | updateView(); |
782 | mTodoListView->repaintContents(); | 834 | mTodoListView->repaintContents(); |
783 | } | 835 | } |
784 | 836 | ||
785 | QPtrList<Incidence> KOTodoView::selectedIncidences() | 837 | QPtrList<Incidence> KOTodoView::selectedIncidences() |
786 | { | 838 | { |
787 | QPtrList<Incidence> selected; | 839 | QPtrList<Incidence> selected; |
788 | 840 | ||
789 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); | 841 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); |
790 | // if (!item) item = mActiveItem; | 842 | // if (!item) item = mActiveItem; |
791 | if (item) selected.append(item->todo()); | 843 | if (item) selected.append(item->todo()); |
792 | 844 | ||
793 | return selected; | 845 | return selected; |
794 | } | 846 | } |
795 | 847 | ||
796 | QPtrList<Todo> KOTodoView::selectedTodos() | 848 | QPtrList<Todo> KOTodoView::selectedTodos() |
797 | { | 849 | { |
798 | QPtrList<Todo> selected; | 850 | QPtrList<Todo> selected; |
799 | 851 | ||
800 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); | 852 | KOTodoViewItem *item = (KOTodoViewItem *)(mTodoListView->selectedItem()); |
801 | // if (!item) item = mActiveItem; | 853 | // if (!item) item = mActiveItem; |
802 | if (item) selected.append(item->todo()); | 854 | if (item) selected.append(item->todo()); |
803 | 855 | ||
804 | return selected; | 856 | return selected; |
805 | } | 857 | } |
806 | 858 | ||
807 | void KOTodoView::changeEventDisplay(Event *, int) | 859 | void KOTodoView::changeEventDisplay(Event *, int) |
808 | { | 860 | { |
809 | updateView(); | 861 | updateView(); |
810 | } | 862 | } |
811 | 863 | ||
812 | void KOTodoView::showDates(const QDate &, const QDate &) | 864 | void KOTodoView::showDates(const QDate &, const QDate &) |
813 | { | 865 | { |
814 | } | 866 | } |
815 | 867 | ||
816 | void KOTodoView::showEvents(QPtrList<Event>) | 868 | void KOTodoView::showEvents(QPtrList<Event>) |
817 | { | 869 | { |
818 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; | 870 | kdDebug() << "KOTodoView::selectEvents(): not yet implemented" << endl; |
819 | } | 871 | } |
820 | 872 | ||
821 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, | 873 | void KOTodoView::printPreview(CalPrinter *calPrinter, const QDate &fd, |
822 | const QDate &td) | 874 | const QDate &td) |
823 | { | 875 | { |
824 | #ifndef KORG_NOPRINTER | 876 | #ifndef KORG_NOPRINTER |
825 | calPrinter->preview(CalPrinter::Todolist, fd, td); | 877 | calPrinter->preview(CalPrinter::Todolist, fd, td); |
826 | #endif | 878 | #endif |
827 | } | 879 | } |
828 | 880 | ||
829 | void KOTodoView::editItem(QListViewItem *item ) | 881 | void KOTodoView::editItem(QListViewItem *item ) |
830 | { | 882 | { |
831 | // qDebug("editItem(QListViewItem *item ) "); | 883 | // qDebug("editItem(QListViewItem *item ) "); |
832 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); | 884 | emit editTodoSignal(((KOTodoViewItem *)item)->todo()); |
833 | } | 885 | } |
834 | 886 | ||
835 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) | 887 | void KOTodoView::showItem(QListViewItem *item,const QPoint &,int) |
836 | { | 888 | { |
837 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); | 889 | emit showTodoSignal(((KOTodoViewItem *)item)->todo()); |
838 | } | 890 | } |
839 | 891 | ||
840 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) | 892 | void KOTodoView::popupMenu(QListViewItem *item,const QPoint &p,int column) |
841 | { | 893 | { |
842 | pendingSubtodo = 0; | 894 | pendingSubtodo = 0; |
@@ -1114,228 +1166,229 @@ void KOTodoView::processSelectionChange() | |||
1114 | } else { | 1166 | } else { |
1115 | emit incidenceSelected( item->todo() ); | 1167 | emit incidenceSelected( item->todo() ); |
1116 | } | 1168 | } |
1117 | } | 1169 | } |
1118 | 1170 | ||
1119 | void KOTodoView::modified(bool b) | 1171 | void KOTodoView::modified(bool b) |
1120 | { | 1172 | { |
1121 | emit isModified(b); | 1173 | emit isModified(b); |
1122 | } | 1174 | } |
1123 | void KOTodoView::setTodoModified( Todo* todo ) | 1175 | void KOTodoView::setTodoModified( Todo* todo ) |
1124 | { | 1176 | { |
1125 | todoModified( todo, KOGlobals::UNKNOWN_MODIFIED ); | 1177 | todoModified( todo, KOGlobals::UNKNOWN_MODIFIED ); |
1126 | } | 1178 | } |
1127 | void KOTodoView::clearSelection() | 1179 | void KOTodoView::clearSelection() |
1128 | { | 1180 | { |
1129 | mTodoListView->selectAll( false ); | 1181 | mTodoListView->selectAll( false ); |
1130 | } | 1182 | } |
1131 | void KOTodoView::setAllOpen() | 1183 | void KOTodoView::setAllOpen() |
1132 | { | 1184 | { |
1133 | if ( isFlatDisplay ) { | 1185 | if ( isFlatDisplay ) { |
1134 | isFlatDisplay = false; | 1186 | isFlatDisplay = false; |
1135 | mPopupMenu->setItemChecked( 8,false ); | 1187 | mPopupMenu->setItemChecked( 8,false ); |
1136 | updateView(); | 1188 | updateView(); |
1137 | } | 1189 | } |
1138 | setOpen(mTodoListView->firstChild(), true); | 1190 | setOpen(mTodoListView->firstChild(), true); |
1139 | } | 1191 | } |
1140 | void KOTodoView::setAllClose() | 1192 | void KOTodoView::setAllClose() |
1141 | { | 1193 | { |
1142 | if ( isFlatDisplay ) { | 1194 | if ( isFlatDisplay ) { |
1143 | isFlatDisplay = false; | 1195 | isFlatDisplay = false; |
1144 | mPopupMenu->setItemChecked( 8,false ); | 1196 | mPopupMenu->setItemChecked( 8,false ); |
1145 | updateView(); | 1197 | updateView(); |
1146 | } | 1198 | } |
1147 | setOpen(mTodoListView->firstChild(), false); | 1199 | setOpen(mTodoListView->firstChild(), false); |
1148 | } | 1200 | } |
1149 | void KOTodoView::setOpen( QListViewItem* item, bool setOpenI) | 1201 | void KOTodoView::setOpen( QListViewItem* item, bool setOpenI) |
1150 | { | 1202 | { |
1151 | 1203 | ||
1152 | while ( item ) { | 1204 | while ( item ) { |
1153 | setOpen( item->firstChild(), setOpenI ); | 1205 | setOpen( item->firstChild(), setOpenI ); |
1154 | item->setOpen( setOpenI ); | 1206 | item->setOpen( setOpenI ); |
1155 | item = item->nextSibling(); | 1207 | item = item->nextSibling(); |
1156 | } | 1208 | } |
1157 | } | 1209 | } |
1158 | 1210 | ||
1159 | void KOTodoView::displayAllFlat() | 1211 | void KOTodoView::displayAllFlat() |
1160 | { | 1212 | { |
1161 | pendingSubtodo = 0; | 1213 | pendingSubtodo = 0; |
1162 | if ( mBlockUpdate ) { | 1214 | if ( mBlockUpdate ) { |
1163 | return; | 1215 | return; |
1164 | } | 1216 | } |
1165 | mPopupMenu->setItemChecked( 8,true ); | 1217 | mPopupMenu->setItemChecked( 8,true ); |
1166 | isFlatDisplay = true; | 1218 | isFlatDisplay = true; |
1167 | QPtrList<Todo> todoList = calendar()->todos(); | 1219 | QPtrList<Todo> todoList = calendar()->todos(); |
1168 | mTodoMap.clear(); | 1220 | mTodoMap.clear(); |
1169 | mTodoListView->clear(); | 1221 | mTodoListView->clear(); |
1170 | Todo *todo; | 1222 | Todo *todo; |
1171 | for(todo = todoList.first(); todo; todo = todoList.next()) { | 1223 | for(todo = todoList.first(); todo; todo = todoList.next()) { |
1172 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); | 1224 | KOTodoViewItem *todoItem = new KOTodoViewItem(mTodoListView,todo,this); |
1173 | mTodoMap.insert(todo,todoItem); | 1225 | mTodoMap.insert(todo,todoItem); |
1174 | } | 1226 | } |
1175 | mTodoListView->setFocus(); | 1227 | mTodoListView->setFocus(); |
1176 | processSelectionChange(); | 1228 | processSelectionChange(); |
1177 | } | 1229 | } |
1178 | 1230 | ||
1179 | void KOTodoView::setAllFlat() | 1231 | void KOTodoView::setAllFlat() |
1180 | { | 1232 | { |
1181 | if ( isFlatDisplay ) { | 1233 | if ( isFlatDisplay ) { |
1182 | isFlatDisplay = false; | 1234 | isFlatDisplay = false; |
1183 | mPopupMenu->setItemChecked( 8,false ); | 1235 | mPopupMenu->setItemChecked( 8,false ); |
1184 | updateView(); | 1236 | updateView(); |
1185 | return; | 1237 | return; |
1186 | } | 1238 | } |
1187 | displayAllFlat(); | 1239 | displayAllFlat(); |
1188 | } | 1240 | } |
1189 | 1241 | ||
1190 | void KOTodoView::purgeCompleted() | 1242 | void KOTodoView::purgeCompleted() |
1191 | { | 1243 | { |
1192 | emit purgeCompletedSignal(); | 1244 | emit purgeCompletedSignal(); |
1193 | } | 1245 | } |
1194 | void KOTodoView::toggleQuickTodo() | 1246 | void KOTodoView::toggleQuickTodo() |
1195 | { | 1247 | { |
1196 | if ( mQuickAdd->isVisible() ) { | 1248 | if ( mQuickAdd->isVisible() ) { |
1197 | mQuickAdd->hide(); | 1249 | mQuickAdd->hide(); |
1198 | KOPrefs::instance()->mEnableQuickTodo = false; | 1250 | KOPrefs::instance()->mEnableQuickTodo = false; |
1199 | } | 1251 | } |
1200 | else { | 1252 | else { |
1201 | mQuickAdd->show(); | 1253 | mQuickAdd->show(); |
1202 | KOPrefs::instance()->mEnableQuickTodo = true; | 1254 | KOPrefs::instance()->mEnableQuickTodo = true; |
1203 | } | 1255 | } |
1204 | mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); | 1256 | mPopupMenu->setItemChecked(4,KOPrefs::instance()->mEnableQuickTodo); |
1205 | mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); | 1257 | mItemPopupMenu->setItemChecked( 34 , KOPrefs::instance()->mEnableQuickTodo ); |
1206 | } | 1258 | } |
1207 | 1259 | ||
1208 | void KOTodoView::toggleRunning() | 1260 | void KOTodoView::toggleRunning() |
1209 | { | 1261 | { |
1210 | KOPrefs::instance()->mHideNonStartedTodos = !KOPrefs::instance()->mHideNonStartedTodos; | 1262 | KOPrefs::instance()->mHideNonStartedTodos = !KOPrefs::instance()->mHideNonStartedTodos; |
1211 | mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); | 1263 | mPopupMenu->setItemChecked(5,KOPrefs::instance()->mHideNonStartedTodos); |
1212 | mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); | 1264 | mItemPopupMenu->setItemChecked( 35 , KOPrefs::instance()->mHideNonStartedTodos ); |
1213 | updateView(); | 1265 | updateView(); |
1214 | } | 1266 | } |
1215 | 1267 | ||
1216 | void KOTodoView::toggleCompleted() | 1268 | void KOTodoView::toggleCompleted() |
1217 | { | 1269 | { |
1218 | KOPrefs::instance()->mShowCompletedTodo = !KOPrefs::instance()->mShowCompletedTodo; | 1270 | KOPrefs::instance()->mShowCompletedTodo = !KOPrefs::instance()->mShowCompletedTodo; |
1219 | mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); | 1271 | mPopupMenu->setItemChecked( 3,KOPrefs::instance()->mShowCompletedTodo ); |
1220 | mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); | 1272 | mItemPopupMenu->setItemChecked( 33 , KOPrefs::instance()->mShowCompletedTodo ); |
1221 | updateView(); | 1273 | updateView(); |
1222 | } | 1274 | } |
1223 | 1275 | ||
1224 | void KOTodoView::addQuickTodo() | 1276 | void KOTodoView::addQuickTodo() |
1225 | { | 1277 | { |
1226 | Todo *todo = new Todo(); | 1278 | Todo *todo = new Todo(); |
1227 | todo->setSummary(mQuickAdd->text()); | 1279 | todo->setSummary(mQuickAdd->text()); |
1228 | todo->setOrganizer(KOPrefs::instance()->email()); | 1280 | todo->setOrganizer(KOPrefs::instance()->email()); |
1229 | CalFilter * cf = mCalendar->filter(); | 1281 | CalFilter * cf = mCalendar->filter(); |
1230 | if ( cf ) { | 1282 | if ( cf ) { |
1231 | if ( cf->isEnabled()&& cf->showCategories()) { | 1283 | if ( cf->isEnabled()&& cf->showCategories()) { |
1232 | todo->setCategories(cf->categoryList()); | 1284 | todo->setCategories(cf->categoryList()); |
1233 | } | 1285 | } |
1234 | if ( cf->isEnabled() ) | 1286 | if ( cf->isEnabled() ) |
1235 | todo->setSecrecy( cf->getSecrecy()); | 1287 | todo->setSecrecy( cf->getSecrecy()); |
1236 | } | 1288 | } |
1237 | mCalendar->addTodo(todo); | 1289 | mCalendar->addTodo(todo); |
1238 | mQuickAdd->setText(""); | 1290 | mQuickAdd->setText(""); |
1239 | todoModified (todo, KOGlobals::EVENTADDED ); | 1291 | todoModified (todo, KOGlobals::EVENTADDED ); |
1240 | updateView(); | 1292 | updateView(); |
1241 | } | 1293 | } |
1294 | |||
1242 | void KOTodoView::keyPressEvent ( QKeyEvent * e ) | 1295 | void KOTodoView::keyPressEvent ( QKeyEvent * e ) |
1243 | { | 1296 | { |
1244 | // e->ignore(); | 1297 | // e->ignore(); |
1245 | //return; | 1298 | //return; |
1246 | //qDebug("KOTodoView::keyPressEvent "); | 1299 | //qDebug("KOTodoView::keyPressEvent "); |
1247 | switch ( e->key() ) { | 1300 | switch ( e->key() ) { |
1248 | case Qt::Key_Down: | 1301 | case Qt::Key_Down: |
1249 | case Qt::Key_Up: | 1302 | case Qt::Key_Up: |
1250 | QWidget::keyPressEvent ( e ); | 1303 | QWidget::keyPressEvent ( e ); |
1251 | break; | 1304 | break; |
1252 | 1305 | ||
1253 | case Qt::Key_Q: | 1306 | case Qt::Key_Q: |
1254 | toggleQuickTodo(); | 1307 | toggleQuickTodo(); |
1255 | break; | 1308 | break; |
1256 | case Qt::Key_U: | 1309 | case Qt::Key_U: |
1257 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { | 1310 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { |
1258 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | 1311 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); |
1259 | unparentTodo(); | 1312 | unparentTodo(); |
1260 | e->accept(); | 1313 | e->accept(); |
1261 | } else | 1314 | } else |
1262 | e->ignore(); | 1315 | e->ignore(); |
1263 | break; | 1316 | break; |
1264 | case Qt::Key_S: | 1317 | case Qt::Key_S: |
1265 | if ( e->state() == Qt::ControlButton ) { | 1318 | if ( e->state() == Qt::ControlButton ) { |
1266 | e->ignore(); | 1319 | e->ignore(); |
1267 | break; | 1320 | break; |
1268 | } | 1321 | } |
1269 | if ( e->state() == Qt::ShiftButton ) { | 1322 | if ( e->state() == Qt::ShiftButton ) { |
1270 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | 1323 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); |
1271 | reparentTodo(); | 1324 | reparentTodo(); |
1272 | e->accept(); | 1325 | e->accept(); |
1273 | } else | 1326 | } else |
1274 | e->ignore(); | 1327 | e->ignore(); |
1275 | break; | 1328 | break; |
1276 | case Qt::Key_P: | 1329 | case Qt::Key_P: |
1277 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { | 1330 | if ( e->state() == Qt::ControlButton|| e->state() == Qt::ShiftButton ) { |
1278 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); | 1331 | mActiveItem = (KOTodoViewItem*)mTodoListView->currentItem(); |
1279 | if ( pendingSubtodo ) | 1332 | if ( pendingSubtodo ) |
1280 | itemClicked(mActiveItem); | 1333 | itemClicked(mActiveItem); |
1281 | e->accept(); | 1334 | e->accept(); |
1282 | } else | 1335 | } else |
1283 | e->ignore(); | 1336 | e->ignore(); |
1284 | break; | 1337 | break; |
1285 | case Qt::Key_Escape: | 1338 | case Qt::Key_Escape: |
1286 | if ( pendingSubtodo ) { | 1339 | if ( pendingSubtodo ) { |
1287 | itemClicked(0); | 1340 | itemClicked(0); |
1288 | e->accept(); | 1341 | e->accept(); |
1289 | } else | 1342 | } else |
1290 | e->ignore(); | 1343 | e->ignore(); |
1291 | break; | 1344 | break; |
1292 | default: | 1345 | default: |
1293 | e->ignore(); | 1346 | e->ignore(); |
1294 | } | 1347 | } |
1295 | 1348 | ||
1296 | if ( true ) { | 1349 | if ( true ) { |
1297 | if ( e->key() == Qt::Key_I ) { | 1350 | if ( e->key() == Qt::Key_I ) { |
1298 | KOTodoViewItem*cn = (KOTodoViewItem*)mTodoListView->currentItem(); | 1351 | KOTodoViewItem*cn = (KOTodoViewItem*)mTodoListView->currentItem(); |
1299 | if ( cn ) { | 1352 | if ( cn ) { |
1300 | mActiveItem = cn; | 1353 | mActiveItem = cn; |
1301 | KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); | 1354 | KOTodoViewItem* ci = (KOTodoViewItem*)( cn ); |
1302 | if ( ci ){ | 1355 | if ( ci ){ |
1303 | showTodo(); | 1356 | showTodo(); |
1304 | cn = (KOTodoViewItem*)cn->itemBelow(); | 1357 | cn = (KOTodoViewItem*)cn->itemBelow(); |
1305 | if ( cn ) { | 1358 | if ( cn ) { |
1306 | mTodoListView->setCurrentItem ( cn ); | 1359 | mTodoListView->setCurrentItem ( cn ); |
1307 | mTodoListView->ensureItemVisible ( cn ); | 1360 | mTodoListView->ensureItemVisible ( cn ); |
1308 | } | 1361 | } |
1309 | 1362 | ||
1310 | } | 1363 | } |
1311 | } | 1364 | } |
1312 | e->accept(); | 1365 | e->accept(); |
1313 | 1366 | ||
1314 | } | 1367 | } |
1315 | 1368 | ||
1316 | } | 1369 | } |
1317 | 1370 | ||
1318 | } | 1371 | } |
1319 | void KOTodoView::updateTodo( Todo * t, int type ) | 1372 | void KOTodoView::updateTodo( Todo * t, int type ) |
1320 | { | 1373 | { |
1321 | if ( mBlockUpdate) | 1374 | if ( mBlockUpdate) |
1322 | return; | 1375 | return; |
1323 | 1376 | ||
1324 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; | 1377 | QMap<Todo *,KOTodoViewItem *>::ConstIterator itemIterator; |
1325 | itemIterator = mTodoMap.find(t); | 1378 | itemIterator = mTodoMap.find(t); |
1326 | if (itemIterator != mTodoMap.end()) { | 1379 | if (itemIterator != mTodoMap.end()) { |
1327 | (*itemIterator)->construct(); | 1380 | (*itemIterator)->construct(); |
1328 | } else { | 1381 | } else { |
1329 | if ( type == KOGlobals::EVENTADDED ) { | 1382 | if ( type == KOGlobals::EVENTADDED ) { |
1330 | insertTodoItem( t ); | 1383 | insertTodoItem( t ); |
1331 | } | 1384 | } |
1332 | } | 1385 | } |
1333 | 1386 | ||
1334 | } | 1387 | } |
1335 | 1388 | ||
1336 | void KOTodoView::todoModified(Todo * t , int p ) | 1389 | void KOTodoView::todoModified(Todo * t , int p ) |
1337 | { | 1390 | { |
1338 | mBlockUpdate = true; | 1391 | mBlockUpdate = true; |
1339 | emit todoModifiedSignal ( t, p ); | 1392 | emit todoModifiedSignal ( t, p ); |
1340 | mBlockUpdate = false; | 1393 | mBlockUpdate = false; |
1341 | } | 1394 | } |
diff --git a/korganizer/kotodoview.h b/korganizer/kotodoview.h index eab0754..e553d0e 100644 --- a/korganizer/kotodoview.h +++ b/korganizer/kotodoview.h | |||
@@ -1,257 +1,262 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of KOrganizer. | 2 | This file is part of KOrganizer. |
3 | Copyright (c) 2000, 2001 Cornelius Schumacher <schumacher@kde.org> | 3 | Copyright (c) 2000, 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 | #ifndef KOTODOVIEW_H | 23 | #ifndef KOTODOVIEW_H |
24 | #define KOTODOVIEW_H | 24 | #define KOTODOVIEW_H |
25 | 25 | ||
26 | #include <qfont.h> | 26 | #include <qfont.h> |
27 | #include <qfontmetrics.h> | 27 | #include <qfontmetrics.h> |
28 | #include <qlineedit.h> | 28 | #include <qlineedit.h> |
29 | #include <qptrlist.h> | 29 | #include <qptrlist.h> |
30 | #include <qstrlist.h> | 30 | #include <qstrlist.h> |
31 | #include <qlistbox.h> | 31 | #include <qlistbox.h> |
32 | #include <qpopupmenu.h> | 32 | #include <qpopupmenu.h> |
33 | #include <qlabel.h> | 33 | #include <qlabel.h> |
34 | #include <qmap.h> | 34 | #include <qmap.h> |
35 | #include <qlistview.h> | 35 | #include <qlistview.h> |
36 | #include <klistview.h> | 36 | #include <klistview.h> |
37 | 37 | ||
38 | #include <libkcal/calendar.h> | 38 | #include <libkcal/calendar.h> |
39 | #include <libkcal/todo.h> | 39 | #include <libkcal/todo.h> |
40 | 40 | ||
41 | #include <korganizer/baseview.h> | 41 | #include <korganizer/baseview.h> |
42 | 42 | ||
43 | #include "kotodoviewitem.h" | 43 | #include "kotodoviewitem.h" |
44 | #include "koprefs.h" | 44 | #include "koprefs.h" |
45 | #include "koglobals.h" | 45 | #include "koglobals.h" |
46 | #include "datenavigator.h" | 46 | #include "datenavigator.h" |
47 | 47 | ||
48 | class QDragEnterEvent; | 48 | class QDragEnterEvent; |
49 | class QDragMoveEvent; | 49 | class QDragMoveEvent; |
50 | class QDragLeaveEvent; | 50 | class QDragLeaveEvent; |
51 | class QDropEvent; | 51 | class QDropEvent; |
52 | class KOTodoViewWhatsThis; | 52 | class KOTodoViewWhatsThis; |
53 | 53 | ||
54 | class DocPrefs; | 54 | class DocPrefs; |
55 | 55 | ||
56 | class KOTodoListView : public KListView | 56 | class KOTodoListView : public KListView |
57 | { | 57 | { |
58 | Q_OBJECT | 58 | Q_OBJECT |
59 | public: | 59 | public: |
60 | KOTodoListView(Calendar *,QWidget *parent=0,const char *name=0); | 60 | KOTodoListView(Calendar *,QWidget *parent=0,const char *name=0); |
61 | virtual ~KOTodoListView() {} | 61 | virtual ~KOTodoListView() {} |
62 | 62 | ||
63 | signals: | 63 | signals: |
64 | void paintNeeded(); | 64 | void paintNeeded(); |
65 | void todoDropped(Todo *, int); | 65 | void todoDropped(Todo *, int); |
66 | void double_Clicked(QListViewItem *item); | 66 | void double_Clicked(QListViewItem *item); |
67 | void reparentTodoSignal( Todo *,Todo * ); | 67 | void reparentTodoSignal( Todo *,Todo * ); |
68 | void unparentTodoSignal(Todo *); | 68 | void unparentTodoSignal(Todo *); |
69 | void deleteTodo( Todo * ); | 69 | void deleteTodo( Todo * ); |
70 | protected: | 70 | protected: |
71 | void contentsDragEnterEvent(QDragEnterEvent *); | 71 | void contentsDragEnterEvent(QDragEnterEvent *); |
72 | void contentsDragMoveEvent(QDragMoveEvent *); | 72 | void contentsDragMoveEvent(QDragMoveEvent *); |
73 | void contentsDragLeaveEvent(QDragLeaveEvent *); | 73 | void contentsDragLeaveEvent(QDragLeaveEvent *); |
74 | void contentsDropEvent(QDropEvent *); | 74 | void contentsDropEvent(QDropEvent *); |
75 | 75 | ||
76 | void contentsMousePressEvent(QMouseEvent *); | 76 | void contentsMousePressEvent(QMouseEvent *); |
77 | void contentsMouseMoveEvent(QMouseEvent *); | 77 | void contentsMouseMoveEvent(QMouseEvent *); |
78 | void contentsMouseReleaseEvent(QMouseEvent *); | 78 | void contentsMouseReleaseEvent(QMouseEvent *); |
79 | void contentsMouseDoubleClickEvent(QMouseEvent *); | 79 | void contentsMouseDoubleClickEvent(QMouseEvent *); |
80 | 80 | ||
81 | private: | 81 | private: |
82 | void paintEvent(QPaintEvent * pevent); | 82 | void paintEvent(QPaintEvent * pevent); |
83 | bool internalDrop; | 83 | bool internalDrop; |
84 | QString mName; | 84 | QString mName; |
85 | Calendar *mCalendar; | 85 | Calendar *mCalendar; |
86 | QPoint mPressPos; | 86 | QPoint mPressPos; |
87 | bool mMousePressed; | 87 | bool mMousePressed; |
88 | QListViewItem *mOldCurrent; | 88 | QListViewItem *mOldCurrent; |
89 | bool mFlagKeyPressed; | ||
89 | void keyPressEvent ( QKeyEvent * ) ; | 90 | void keyPressEvent ( QKeyEvent * ) ; |
91 | void keyReleaseEvent ( QKeyEvent * ) ; | ||
90 | }; | 92 | }; |
91 | 93 | ||
92 | 94 | ||
93 | /** | 95 | /** |
94 | This is the line-edit on top of the todoview for fast addition of new todos | 96 | This is the line-edit on top of the todoview for fast addition of new todos |
95 | */ | 97 | */ |
96 | class KOQuickTodo : public QLineEdit | 98 | class KOQuickTodo : public QLineEdit |
97 | { | 99 | { |
98 | public: | 100 | public: |
99 | KOQuickTodo(QWidget *parent=0); | 101 | KOQuickTodo(QWidget *parent=0); |
100 | protected: | 102 | protected: |
101 | void focusInEvent(QFocusEvent *ev); | 103 | void focusInEvent(QFocusEvent *ev); |
102 | void focusOutEvent(QFocusEvent *ev); | 104 | void focusOutEvent(QFocusEvent *ev); |
103 | }; | 105 | }; |
104 | 106 | ||
105 | 107 | ||
106 | /** | 108 | /** |
107 | This class provides a multi-column list view of todo events. | 109 | This class provides a multi-column list view of todo events. |
108 | 110 | ||
109 | @short multi-column list view of todo events. | 111 | @short multi-column list view of todo events. |
110 | @author Cornelius Schumacher <schumacher@kde.org> | 112 | @author Cornelius Schumacher <schumacher@kde.org> |
111 | */ | 113 | */ |
112 | class KOTodoView : public KOrg::BaseView | 114 | class KOTodoView : public KOrg::BaseView |
113 | { | 115 | { |
114 | Q_OBJECT | 116 | Q_OBJECT |
115 | public: | 117 | public: |
116 | KOTodoView(Calendar *, QWidget* parent=0, const char* name=0 ); | 118 | KOTodoView(Calendar *, QWidget* parent=0, const char* name=0 ); |
117 | ~KOTodoView(); | 119 | ~KOTodoView(); |
118 | 120 | ||
119 | QPtrList<Incidence> selectedIncidences(); | 121 | QPtrList<Incidence> selectedIncidences(); |
120 | QPtrList<Todo> selectedTodos(); | 122 | QPtrList<Todo> selectedTodos(); |
121 | 123 | ||
122 | DateList selectedDates() | 124 | DateList selectedDates() |
123 | {DateList q; | 125 | {DateList q; |
124 | return q;} | 126 | return q;} |
125 | 127 | ||
126 | /** Return number of shown dates. TodoView does not show dates, */ | 128 | /** Return number of shown dates. TodoView does not show dates, */ |
127 | int currentDateCount() { return 0; } | 129 | int currentDateCount() { return 0; } |
128 | 130 | ||
129 | void printPreview(CalPrinter *calPrinter, const QDate &fd, const QDate &td); | 131 | void printPreview(CalPrinter *calPrinter, const QDate &fd, const QDate &td); |
130 | 132 | ||
131 | void setDocumentId( const QString & ); | 133 | void setDocumentId( const QString & ); |
132 | 134 | ||
133 | void saveLayout(KConfig *config, const QString &group) const; | 135 | void saveLayout(KConfig *config, const QString &group) const; |
134 | void restoreLayout(KConfig *config, const QString &group); | 136 | void restoreLayout(KConfig *config, const QString &group); |
135 | /** Create a popup menu to set categories */ | 137 | /** Create a popup menu to set categories */ |
136 | QPopupMenu *getCategoryPopupMenu (KOTodoViewItem *todoItem); | 138 | QPopupMenu *getCategoryPopupMenu (KOTodoViewItem *todoItem); |
137 | void setNavigator( DateNavigator* nav ) {mNavigator = nav;} | 139 | void setNavigator( DateNavigator* nav ) {mNavigator = nav;} |
138 | QString getWhatsThisText(QPoint p); | 140 | QString getWhatsThisText(QPoint p); |
139 | 141 | ||
140 | public slots: | 142 | public slots: |
141 | void updateView(); | 143 | void updateView(); |
142 | void updateConfig(); | 144 | void updateConfig(); |
143 | 145 | ||
144 | void changeEventDisplay(Event *, int); | 146 | void changeEventDisplay(Event *, int); |
145 | 147 | ||
146 | void showDates(const QDate &start, const QDate &end); | 148 | void showDates(const QDate &start, const QDate &end); |
147 | void showEvents(QPtrList<Event> eventList); | 149 | void showEvents(QPtrList<Event> eventList); |
148 | 150 | ||
149 | void clearSelection(); | 151 | void clearSelection(); |
150 | void jumpToDate (); | 152 | void jumpToDate (); |
151 | 153 | ||
152 | void editItem(QListViewItem *item); | 154 | void editItem(QListViewItem *item); |
153 | void showItem(QListViewItem *item,const QPoint &,int); | 155 | void showItem(QListViewItem *item,const QPoint &,int); |
154 | void popupMenu(QListViewItem *item,const QPoint &,int); | 156 | void popupMenu(QListViewItem *item,const QPoint &,int); |
155 | void newTodo(); | 157 | void newTodo(); |
156 | void newSubTodo(); | 158 | void newSubTodo(); |
157 | void unparentTodo(); | 159 | void unparentTodo(); |
158 | void reparentTodo(); | 160 | void reparentTodo(); |
159 | void showTodo(); | 161 | void showTodo(); |
160 | void editTodo(); | 162 | void editTodo(); |
161 | void cloneTodo(); | 163 | void cloneTodo(); |
162 | void cancelTodo(); | 164 | void cancelTodo(); |
163 | void moveTodo(); | 165 | void moveTodo(); |
164 | void beamTodo(); | 166 | void beamTodo(); |
165 | void deleteTodo(); | 167 | void deleteTodo(); |
166 | 168 | ||
167 | void setNewPriority(int); | 169 | void setNewPriority(int); |
168 | void setNewPercentage(int); | 170 | void setNewPercentage(int); |
169 | void changedCategories(int); | 171 | void changedCategories(int); |
170 | 172 | ||
171 | void setAllOpen(); | 173 | void setAllOpen(); |
172 | void setAllClose(); | 174 | void setAllClose(); |
173 | void setAllFlat(); | 175 | void setAllFlat(); |
174 | void displayAllFlat(); | 176 | void displayAllFlat(); |
175 | 177 | ||
176 | void purgeCompleted(); | 178 | void purgeCompleted(); |
177 | void toggleCompleted(); | 179 | void toggleCompleted(); |
178 | void toggleRunning(); | 180 | void toggleRunning(); |
179 | void toggleQuickTodo(); | 181 | void toggleQuickTodo(); |
180 | void updateTodo( Todo *, int ); | 182 | void updateTodo( Todo *, int ); |
181 | 183 | ||
182 | void itemClicked(QListViewItem *); | 184 | void itemClicked(QListViewItem *); |
183 | void itemStateChanged(QListViewItem *); | 185 | void itemStateChanged(QListViewItem *); |
184 | void modified(bool); | 186 | void modified(bool); |
185 | void itemDoubleClicked(QListViewItem *item); | 187 | void itemDoubleClicked(QListViewItem *item); |
186 | 188 | ||
187 | signals: | 189 | signals: |
188 | void newTodoSignal(); | 190 | void newTodoSignal(); |
189 | void newSubTodoSignal(Todo *); | 191 | void newSubTodoSignal(Todo *); |
190 | void unparentTodoSignal(Todo *); | 192 | void unparentTodoSignal(Todo *); |
191 | void reparentTodoSignal( Todo *,Todo * ); | 193 | void reparentTodoSignal( Todo *,Todo * ); |
192 | void showTodoSignal(Todo *); | 194 | void showTodoSignal(Todo *); |
193 | 195 | ||
194 | void editTodoSignal(Todo *); | 196 | void editTodoSignal(Todo *); |
195 | void deleteTodoSignal(Todo *); | 197 | void deleteTodoSignal(Todo *); |
196 | void todoModifiedSignal (Todo *, int); | 198 | void todoModifiedSignal (Todo *, int); |
197 | 199 | ||
198 | void isModified(bool); | 200 | void isModified(bool); |
199 | void cloneTodoSignal( Incidence * ); | 201 | void cloneTodoSignal( Incidence * ); |
200 | void cancelTodoSignal( Incidence * ); | 202 | void cancelTodoSignal( Incidence * ); |
201 | void moveTodoSignal( Incidence * ); | 203 | void moveTodoSignal( Incidence * ); |
202 | void beamTodoSignal( Incidence * ); | 204 | void beamTodoSignal( Incidence * ); |
203 | void purgeCompletedSignal(); | 205 | void purgeCompletedSignal(); |
204 | 206 | ||
205 | protected slots: | 207 | protected slots: |
206 | void paintNeeded(); | 208 | void paintNeeded(); |
207 | void processSelectionChange(); | 209 | void processSelectionChange(); |
208 | void addQuickTodo(); | 210 | void addQuickTodo(); |
209 | void setTodoModified( Todo* ); | 211 | void setTodoModified( Todo* ); |
210 | void todoModified(Todo *, int ); | 212 | void todoModified(Todo *, int ); |
211 | 213 | ||
212 | private: | 214 | private: |
213 | /* | 215 | /* |
214 | * the TodoEditor approach is rather unscaling in the long | 216 | * the TodoEditor approach is rather unscaling in the long |
215 | * run. | 217 | * run. |
216 | * Korganizer keeps it in memory and we need to update | 218 | * Korganizer keeps it in memory and we need to update |
217 | * 1. make KOTodoViewItem a QObject again? | 219 | * 1. make KOTodoViewItem a QObject again? |
218 | * 2. add a public method for setting one todo modified? | 220 | * 2. add a public method for setting one todo modified? |
219 | * 3. add a private method for setting a todo modified + friend here? | 221 | * 3. add a private method for setting a todo modified + friend here? |
220 | * -- zecke 2002-07-08 | 222 | * -- zecke 2002-07-08 |
221 | */ | 223 | */ |
222 | KOTodoViewWhatsThis* mKOTodoViewWhatsThis; | 224 | KOTodoViewWhatsThis* mKOTodoViewWhatsThis; |
223 | friend class KOTodoListView; | 225 | friend class KOTodoListView; |
224 | void paintEvent(QPaintEvent * pevent); | 226 | void paintEvent(QPaintEvent * pevent); |
225 | bool mPendingUpdateBeforeRepaint; | 227 | bool mPendingUpdateBeforeRepaint; |
226 | friend class KOTodoViewItem; | 228 | friend class KOTodoViewItem; |
227 | QMap<Todo *,KOTodoViewItem *>::ConstIterator insertTodoItem(Todo *todo); | 229 | QMap<Todo *,KOTodoViewItem *>::ConstIterator insertTodoItem(Todo *todo); |
228 | void restoreItemState( QListViewItem * ); | 230 | void restoreItemState( QListViewItem * ); |
229 | 231 | ||
230 | bool checkTodo( Todo * ); | 232 | bool checkTodo( Todo * ); |
231 | bool isFlatDisplay; | 233 | bool isFlatDisplay; |
232 | void setOpen( QListViewItem*, bool setOpen); | 234 | void setOpen( QListViewItem*, bool setOpen); |
233 | KOTodoListView *mTodoListView; | 235 | KOTodoListView *mTodoListView; |
234 | QPopupMenu *mItemPopupMenu; | 236 | QPopupMenu *mItemPopupMenu; |
235 | QPopupMenu *mPopupMenu; | 237 | QPopupMenu *mPopupMenu; |
236 | QPopupMenu *mPriorityPopupMenu; | 238 | QPopupMenu *mPriorityPopupMenu; |
237 | QPopupMenu *mPercentageCompletedPopupMenu; | 239 | QPopupMenu *mPercentageCompletedPopupMenu; |
238 | QPopupMenu *mCategoryPopupMenu; | 240 | QPopupMenu *mCategoryPopupMenu; |
239 | 241 | ||
240 | QMap<int, int> mPercentage; | 242 | QMap<int, int> mPercentage; |
241 | QMap<int, int> mPriority; | 243 | QMap<int, int> mPriority; |
242 | QMap<int, QString> mCategory; | 244 | QMap<int, QString> mCategory; |
243 | KOTodoViewItem *mActiveItem; | 245 | KOTodoViewItem *mActiveItem; |
244 | 246 | ||
245 | QMap<Todo *,KOTodoViewItem *> mTodoMap; | 247 | QMap<Todo *,KOTodoViewItem *> mTodoMap; |
246 | QString mName; | 248 | QString mName; |
247 | 249 | ||
248 | DocPrefs *mDocPrefs; | 250 | DocPrefs *mDocPrefs; |
249 | QString mCurrentDoc; | 251 | QString mCurrentDoc; |
250 | KOQuickTodo *mQuickAdd; | 252 | KOQuickTodo *mQuickAdd; |
251 | bool mBlockUpdate; | 253 | bool mBlockUpdate; |
252 | void keyPressEvent ( QKeyEvent * ) ; | 254 | void keyPressEvent ( QKeyEvent * ) ; |
253 | KOTodoViewItem * pendingSubtodo; | 255 | KOTodoViewItem * pendingSubtodo; |
254 | DateNavigator* mNavigator; | 256 | DateNavigator* mNavigator; |
257 | void storeCurrentItem(); | ||
258 | void resetCurrentItem(); | ||
259 | Incidence * mCurItem, *mCurItemRootParent,*mCurItemAbove; | ||
255 | }; | 260 | }; |
256 | 261 | ||
257 | #endif | 262 | #endif |
diff --git a/korganizer/koviewmanager.cpp b/korganizer/koviewmanager.cpp index f97aa98..c442d0b 100644 --- a/korganizer/koviewmanager.cpp +++ b/korganizer/koviewmanager.cpp | |||
@@ -13,507 +13,509 @@ | |||
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 13 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the | 14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the |
15 | GNU General Public License for more details. | 15 | GNU General Public License for more details. |
16 | 16 | ||
17 | You should have received a copy of the GNU General Public License | 17 | You should have received a copy of the GNU General Public License |
18 | along with this program; if not, write to the Free Software | 18 | along with this program; if not, write to the Free Software |
19 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 19 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
20 | 20 | ||
21 | As a special exception, permission is given to link this program | 21 | As a special exception, permission is given to link this program |
22 | with any edition of Qt, and distribute the resulting executable, | 22 | with any edition of Qt, and distribute the resulting executable, |
23 | without including the source code for Qt in the source distribution. | 23 | without including the source code for Qt in the source distribution. |
24 | */ | 24 | */ |
25 | 25 | ||
26 | #include <qwidgetstack.h> | 26 | #include <qwidgetstack.h> |
27 | 27 | ||
28 | #include <kconfig.h> | 28 | #include <kconfig.h> |
29 | #include <kglobal.h> | 29 | #include <kglobal.h> |
30 | #ifndef DESKTOP_VERSION | 30 | #ifndef DESKTOP_VERSION |
31 | #include <qpe/qpeapplication.h> | 31 | #include <qpe/qpeapplication.h> |
32 | #else | 32 | #else |
33 | #include <qapplication.h> | 33 | #include <qapplication.h> |
34 | #endif | 34 | #endif |
35 | #include <qdatetime.h> | 35 | #include <qdatetime.h> |
36 | #include "calendarview.h" | 36 | #include "calendarview.h" |
37 | #include "datenavigator.h" | 37 | #include "datenavigator.h" |
38 | #include "kotodoview.h" | 38 | #include "kotodoview.h" |
39 | #include "koagendaview.h" | 39 | #include "koagendaview.h" |
40 | #include "kodialogmanager.h" | 40 | #include "kodialogmanager.h" |
41 | #include "komonthview.h" | 41 | #include "komonthview.h" |
42 | #include "kolistview.h" | 42 | #include "kolistview.h" |
43 | #include "kowhatsnextview.h" | 43 | #include "kowhatsnextview.h" |
44 | #include "kojournalview.h" | 44 | #include "kojournalview.h" |
45 | #include "kotimespanview.h" | 45 | #include "kotimespanview.h" |
46 | #include "koprefs.h" | 46 | #include "koprefs.h" |
47 | #include "navigatorbar.h" | 47 | #include "navigatorbar.h" |
48 | #include "kdatenavigator.h" | 48 | #include "kdatenavigator.h" |
49 | 49 | ||
50 | #include "koviewmanager.h" | 50 | #include "koviewmanager.h" |
51 | //extern bool externFlagMonthviewBlockPainting; | 51 | //extern bool externFlagMonthviewBlockPainting; |
52 | 52 | ||
53 | //bool globalFlagBlockPainting = false; | 53 | //bool globalFlagBlockPainting = false; |
54 | int globalFlagBlockAgenda = 0; | 54 | int globalFlagBlockAgenda = 0; |
55 | int globalFlagBlockLabel = 0; | 55 | int globalFlagBlockLabel = 0; |
56 | int globalFlagBlockAgendaItemPaint = 1; | 56 | int globalFlagBlockAgendaItemPaint = 1; |
57 | int globalFlagBlockAgendaItemUpdate = 1; | 57 | int globalFlagBlockAgendaItemUpdate = 1; |
58 | 58 | ||
59 | 59 | ||
60 | KOViewManager::KOViewManager( CalendarView *mainView ) : | 60 | KOViewManager::KOViewManager( CalendarView *mainView ) : |
61 | QObject(), mMainView( mainView ) | 61 | QObject(), mMainView( mainView ) |
62 | { | 62 | { |
63 | mCurrentView = 0; | 63 | mCurrentView = 0; |
64 | flagResetViewChangeDate = 0; | 64 | flagResetViewChangeDate = 0; |
65 | mWhatsNextView = 0; | 65 | mWhatsNextView = 0; |
66 | mTodoView = 0; | 66 | mTodoView = 0; |
67 | mAgendaView = 0; | 67 | mAgendaView = 0; |
68 | mMonthView = 0; | 68 | mMonthView = 0; |
69 | mListView = 0; | 69 | mListView = 0; |
70 | mJournalView = 0; | 70 | mJournalView = 0; |
71 | mTimeSpanView = 0; | 71 | mTimeSpanView = 0; |
72 | mCurrentAgendaView = 0 ; | 72 | mCurrentAgendaView = 0 ; |
73 | mFlagShowNextxDays = false; | 73 | mFlagShowNextxDays = false; |
74 | } | 74 | } |
75 | 75 | ||
76 | KOViewManager::~KOViewManager() | 76 | KOViewManager::~KOViewManager() |
77 | { | 77 | { |
78 | } | 78 | } |
79 | 79 | ||
80 | 80 | ||
81 | KOrg::BaseView *KOViewManager::currentView() | 81 | KOrg::BaseView *KOViewManager::currentView() |
82 | { | 82 | { |
83 | return mCurrentView; | 83 | return mCurrentView; |
84 | } | 84 | } |
85 | 85 | ||
86 | void KOViewManager::readSettings(KConfig *config) | 86 | void KOViewManager::readSettings(KConfig *config) |
87 | { | 87 | { |
88 | config->setGroup("General"); | 88 | config->setGroup("General"); |
89 | QString view = config->readEntry("Current View"); | 89 | QString view = config->readEntry("Current View"); |
90 | if (view == "WhatsNext") showWhatsNextView(); | 90 | if (view == "WhatsNext") showWhatsNextView(); |
91 | else if (view == "Month") { | 91 | else if (view == "Month") { |
92 | if ( !KOPrefs::instance()->mMonthViewWeek ) | 92 | if ( !KOPrefs::instance()->mMonthViewWeek ) |
93 | showMonthView(); | 93 | showMonthView(); |
94 | else | 94 | else |
95 | showMonthViewWeek(); | 95 | showMonthViewWeek(); |
96 | } | 96 | } |
97 | else if (view == "List") showListView(); | 97 | else if (view == "List") showListView(); |
98 | else if (view == "Journal") showJournalView(); | 98 | else if (view == "Journal") showJournalView(); |
99 | else if (view == "TimeSpan") showTimeSpanView(); | 99 | else if (view == "TimeSpan") showTimeSpanView(); |
100 | else if (view == "Todo") showTodoView(); | 100 | else if (view == "Todo") showTodoView(); |
101 | else { | 101 | else { |
102 | config->setGroup( "Views" ); | 102 | config->setGroup( "Views" ); |
103 | int dateCount = config->readNumEntry( "ShownDatesCount", 7 ); | 103 | int dateCount = config->readNumEntry( "ShownDatesCount", 7 ); |
104 | mCurrentAgendaView = dateCount; | 104 | mCurrentAgendaView = dateCount; |
105 | showAgendaView(); | 105 | showAgendaView(); |
106 | mCurrentAgendaView = dateCount; | 106 | mCurrentAgendaView = dateCount; |
107 | #ifdef DESKTOP_VERSION | 107 | #ifdef DESKTOP_VERSION |
108 | QTimer::singleShot( 1000, mAgendaView, SLOT ( setInitStartHour() ) ); | 108 | QTimer::singleShot( 1000, mAgendaView, SLOT ( setInitStartHour() ) ); |
109 | #endif | 109 | #endif |
110 | } | 110 | } |
111 | } | 111 | } |
112 | 112 | ||
113 | void KOViewManager::showDateView( int view, QDate date) | 113 | void KOViewManager::showDateView( int view, QDate date) |
114 | { | 114 | { |
115 | static int lastMode = 0; | 115 | static int lastMode = 0; |
116 | static int lastCount = 0; | 116 | static int lastCount = 0; |
117 | static bool lastNDMode = false; | 117 | static bool lastNDMode = false; |
118 | static QDate lastDate; | 118 | static QDate lastDate; |
119 | //qDebug("date %d %s", view, date.toString().latin1()); | 119 | //qDebug("date %d %s", view, date.toString().latin1()); |
120 | 120 | ||
121 | if (view != 9) | 121 | if (view != 9) |
122 | lastMode = 0; | 122 | lastMode = 0; |
123 | //qDebug("%d %d ", lastNDMode, mFlagShowNextxDays ); | 123 | //qDebug("%d %d ", lastNDMode, mFlagShowNextxDays ); |
124 | bool savemFlagShowNextxDays = mFlagShowNextxDays; | 124 | bool savemFlagShowNextxDays = mFlagShowNextxDays; |
125 | mFlagShowNextxDays = false; | 125 | mFlagShowNextxDays = false; |
126 | if ( view == 3 ) { | 126 | if ( view == 3 ) { |
127 | //mCurrentAgendaView = 1 ; | 127 | //mCurrentAgendaView = 1 ; |
128 | lastDate = mMainView->dateNavigator()->selectedDates().first(); | 128 | lastDate = mMainView->dateNavigator()->selectedDates().first(); |
129 | lastCount = mMainView->dateNavigator()->selectedDates().count(); | 129 | lastCount = mMainView->dateNavigator()->selectedDates().count(); |
130 | lastNDMode = savemFlagShowNextxDays; | 130 | lastNDMode = savemFlagShowNextxDays; |
131 | mMainView->dateNavigator()->selectDate( date ); | 131 | mMainView->dateNavigator()->selectDate( date ); |
132 | lastMode = 1; | 132 | lastMode = 1; |
133 | mCurrentAgendaView = 1 ; | 133 | mCurrentAgendaView = 1 ; |
134 | } else if (view == 4 ) { | 134 | } else if (view == 4 ) { |
135 | mCurrentAgendaView = 7 ; | 135 | mCurrentAgendaView = 7 ; |
136 | mMainView->dateNavigator()->selectDates( date, 7 ); | 136 | mMainView->dateNavigator()->selectDates( date, 7 ); |
137 | } else if (view == 5 ) { | 137 | } else if (view == 5 ) { |
138 | mCurrentAgendaView = 14 ; | 138 | mCurrentAgendaView = 14 ; |
139 | mMainView->dateNavigator()->selectDates( date, 14); | 139 | mMainView->dateNavigator()->selectDates( date, 14); |
140 | } else if (view == 6 ) { | 140 | } else if (view == 6 ) { |
141 | //mMainView->dateNavigator()->selectDates( date, 7 ); | 141 | resetDateSilent( date,1); |
142 | showMonthView(); | 142 | showMonthView(); |
143 | } else if (view == 7 ) { | 143 | } else if (view == 7 ) { |
144 | mMainView->dateNavigator()->selectDate( date ); | 144 | mMainView->dateNavigator()->selectDate( date ); |
145 | showJournalView(); | 145 | showJournalView(); |
146 | } else if (view == 8 ) { | 146 | } else if (view == 8 ) { |
147 | globalFlagBlockAgenda = 1; | 147 | globalFlagBlockAgenda = 1; |
148 | if ( mCurrentAgendaView != 3 ) | 148 | if ( mCurrentAgendaView != 3 ) |
149 | mCurrentAgendaView = -1; | 149 | mCurrentAgendaView = -1; |
150 | showAgendaView(KOPrefs::instance()->mFullViewMonth); | 150 | showAgendaView(KOPrefs::instance()->mFullViewMonth); |
151 | globalFlagBlockAgenda = 2; | 151 | globalFlagBlockAgenda = 2; |
152 | mMainView->dateNavigator()->selectDates( date , | 152 | mMainView->dateNavigator()->selectDates( date , |
153 | KOPrefs::instance()->mNextXDays ); | 153 | KOPrefs::instance()->mNextXDays ); |
154 | mFlagShowNextxDays = true; | 154 | mFlagShowNextxDays = true; |
155 | mCurrentAgendaView = 3 ; | 155 | mCurrentAgendaView = 3 ; |
156 | } if (view == 9) { // return behaviour, for getting back from mode == 3 (single day mode ) | 156 | } if (view == 9) { // return behaviour, for getting back from mode == 3 (single day mode ) |
157 | if ( lastMode ) { | 157 | if ( lastMode ) { |
158 | mCurrentAgendaView = lastCount ; | 158 | mCurrentAgendaView = lastCount ; |
159 | mMainView->dateNavigator()->selectDates( lastDate, lastCount); | 159 | mMainView->dateNavigator()->selectDates( lastDate, lastCount); |
160 | mFlagShowNextxDays = lastNDMode; | 160 | mFlagShowNextxDays = lastNDMode; |
161 | if ( mFlagShowNextxDays ) { | 161 | if ( mFlagShowNextxDays ) { |
162 | mCurrentAgendaView = 3 ; | 162 | mCurrentAgendaView = 3 ; |
163 | } | 163 | } |
164 | } else | 164 | } else |
165 | showWeekView(); | 165 | showWeekView(); |
166 | } else if (view == 10) { | 166 | } else if (view == 10) { |
167 | mMainView->dateNavigator()->selectDates( date,mMainView->dateNavigator()->selectedDates().count() ); | 167 | mMainView->dateNavigator()->selectDates( date,mMainView->dateNavigator()->selectedDates().count() ); |
168 | } | 168 | } |
169 | } | 169 | } |
170 | 170 | ||
171 | 171 | ||
172 | 172 | ||
173 | void KOViewManager::writeSettings(KConfig *config) | 173 | void KOViewManager::writeSettings(KConfig *config) |
174 | { | 174 | { |
175 | config->setGroup("General"); | 175 | config->setGroup("General"); |
176 | 176 | ||
177 | QString view; | 177 | QString view; |
178 | if (mCurrentView == mWhatsNextView) view = "WhatsNext"; | 178 | if (mCurrentView == mWhatsNextView) view = "WhatsNext"; |
179 | else if (mCurrentView == mMonthView) view = "Month"; | 179 | else if (mCurrentView == mMonthView) view = "Month"; |
180 | else if (mCurrentView == mListView) view = "List"; | 180 | else if (mCurrentView == mListView) view = "List"; |
181 | else if (mCurrentView == mJournalView) view = "Journal"; | 181 | else if (mCurrentView == mJournalView) view = "Journal"; |
182 | else if (mCurrentView == mTimeSpanView) view = "TimeSpan"; | 182 | else if (mCurrentView == mTimeSpanView) view = "TimeSpan"; |
183 | else if (mCurrentView == mTodoView) view = "Todo"; | 183 | else if (mCurrentView == mTodoView) view = "Todo"; |
184 | else view = "Agenda"; | 184 | else view = "Agenda"; |
185 | 185 | ||
186 | config->writeEntry("Current View",view); | 186 | config->writeEntry("Current View",view); |
187 | 187 | ||
188 | if (mAgendaView) { | 188 | if (mAgendaView) { |
189 | mAgendaView->writeSettings(config); | 189 | mAgendaView->writeSettings(config); |
190 | } | 190 | } |
191 | if (mTimeSpanView) { | 191 | if (mTimeSpanView) { |
192 | mTimeSpanView->writeSettings(config); | 192 | mTimeSpanView->writeSettings(config); |
193 | } | 193 | } |
194 | if (mListView) { | 194 | if (mListView) { |
195 | mListView->writeSettings(config); | 195 | mListView->writeSettings(config); |
196 | } | 196 | } |
197 | if (mTodoView) { | 197 | if (mTodoView) { |
198 | mTodoView->saveLayout(config,"Todo View"); | 198 | mTodoView->saveLayout(config,"Todo View"); |
199 | } | 199 | } |
200 | } | 200 | } |
201 | void KOViewManager::showNextView() | 201 | void KOViewManager::showNextView() |
202 | { | 202 | { |
203 | static int selecteddatescount = 0; | 203 | static int selecteddatescount = 0; |
204 | static QDate selecteddate = QDate ( 2000, 1, 1 ); | 204 | static QDate selecteddate = QDate ( 2000, 1, 1 ); |
205 | static QDate baseCycleDate = QDate ( 2000, 1, 1 ); | 205 | static QDate baseCycleDate = QDate ( 2000, 1, 1 ); |
206 | int newCount = mMainView->dateNavigator()->selectedDates().count(); | 206 | int newCount = mMainView->dateNavigator()->selectedDates().count(); |
207 | if ( selecteddatescount != newCount && flagResetViewChangeDate == 0 ) { | 207 | if ( selecteddatescount != newCount && flagResetViewChangeDate == 0 ) { |
208 | flagResetViewChangeDate = 1; | 208 | flagResetViewChangeDate = 1; |
209 | } | 209 | } |
210 | if ( selecteddate != mMainView->dateNavigator()->selectedDates().first() ) | 210 | if ( selecteddate != mMainView->dateNavigator()->selectedDates().first() ) |
211 | flagResetViewChangeDate = 1; | 211 | flagResetViewChangeDate = 1; |
212 | if ( flagResetViewChangeDate > 0 ) { | 212 | if ( flagResetViewChangeDate > 0 ) { |
213 | baseCycleDate = mMainView->dateNavigator()->selectedDates().first(); | 213 | baseCycleDate = mMainView->dateNavigator()->selectedDates().first(); |
214 | //qDebug("newCycle "); | 214 | //qDebug("newCycle "); |
215 | } | 215 | } |
216 | if (mCurrentView == mWhatsNextView) goto NEXT_X; | 216 | if (mCurrentView == mWhatsNextView) goto NEXT_X; |
217 | if (mCurrentView == mAgendaView && mFlagShowNextxDays) goto JOURNAL; | 217 | if (mCurrentView == mAgendaView && mFlagShowNextxDays) goto JOURNAL; |
218 | if (mCurrentView == mJournalView ) goto DAY_1; | 218 | if (mCurrentView == mJournalView ) goto DAY_1; |
219 | if (mCurrentView == mAgendaView && mCurrentAgendaView == 1 ) goto DAY_5; | 219 | if (mCurrentView == mAgendaView && mCurrentAgendaView == 1 ) goto DAY_5; |
220 | if (mCurrentView == mAgendaView && mCurrentAgendaView == 5 ) goto DAY_7; | 220 | if (mCurrentView == mAgendaView && mCurrentAgendaView == 5 ) goto DAY_7; |
221 | if (mCurrentView == mAgendaView ) goto DAY_6; | 221 | if (mCurrentView == mAgendaView ) goto DAY_6; |
222 | if (mCurrentView == mMonthView && KOPrefs::instance()->mMonthViewWeek) goto MONTH; | 222 | if (mCurrentView == mMonthView && KOPrefs::instance()->mMonthViewWeek) goto MONTH; |
223 | if (mCurrentView == mMonthView ) goto LIST; | 223 | if (mCurrentView == mMonthView ) goto LIST; |
224 | if (mCurrentView == mListView ) goto TODO; | 224 | if (mCurrentView == mListView ) goto TODO; |
225 | // if (mCurrentView == mTodoView ) goto NEXT; | 225 | // if (mCurrentView == mTodoView ) goto NEXT; |
226 | NEXT: | 226 | NEXT: |
227 | if ( KOPrefs::instance()->mShowIconNext ) { showWhatsNextView();goto ENTE ;} | 227 | if ( KOPrefs::instance()->mShowIconNext ) { showWhatsNextView();goto ENTE ;} |
228 | NEXT_X: | 228 | NEXT_X: |
229 | if ( KOPrefs::instance()->mShowIconNextDays ) { | 229 | if ( KOPrefs::instance()->mShowIconNextDays ) { |
230 | globalFlagBlockAgenda = 1; | 230 | globalFlagBlockAgenda = 1; |
231 | if ( mCurrentAgendaView != 3 ) | 231 | if ( mCurrentAgendaView != 3 ) |
232 | mCurrentAgendaView = -1; | 232 | mCurrentAgendaView = -1; |
233 | showAgendaView(KOPrefs::instance()->mFullViewMonth); | 233 | showAgendaView(KOPrefs::instance()->mFullViewMonth); |
234 | globalFlagBlockAgenda = 2; | 234 | globalFlagBlockAgenda = 2; |
235 | mMainView->dateNavigator()->selectDates( baseCycleDate , | 235 | mMainView->dateNavigator()->selectDates( baseCycleDate , |
236 | KOPrefs::instance()->mNextXDays ); | 236 | KOPrefs::instance()->mNextXDays ); |
237 | mFlagShowNextxDays = true; | 237 | mFlagShowNextxDays = true; |
238 | mCurrentAgendaView = 3 ; | 238 | mCurrentAgendaView = 3 ; |
239 | goto ENTE ; | 239 | goto ENTE ; |
240 | } | 240 | } |
241 | JOURNAL: | 241 | JOURNAL: |
242 | if ( KOPrefs::instance()->mShowIconJournal ) { | 242 | if ( KOPrefs::instance()->mShowIconJournal ) { |
243 | resetDateSilent( baseCycleDate , 1 ); | 243 | resetDateSilent( baseCycleDate , 1 ); |
244 | showJournalView() ;goto ENTE ;} | 244 | showJournalView() ;goto ENTE ;} |
245 | DAY_1: | 245 | DAY_1: |
246 | if ( KOPrefs::instance()->mShowIconDay1 ) { | 246 | if ( KOPrefs::instance()->mShowIconDay1 ) { |
247 | resetDateSilent( baseCycleDate , 2 ); | 247 | resetDateSilent( baseCycleDate , 2 ); |
248 | showDayView() ;goto ENTE ;} | 248 | showDayView() ;goto ENTE ;} |
249 | DAY_5: | 249 | DAY_5: |
250 | if ( KOPrefs::instance()->mShowIconDay5 ) { | 250 | if ( KOPrefs::instance()->mShowIconDay5 ) { |
251 | resetDateSilent( baseCycleDate , 2 ); | 251 | resetDateSilent( baseCycleDate , 2 ); |
252 | showWorkWeekView() ;goto ENTE ;} | 252 | showWorkWeekView() ;goto ENTE ;} |
253 | DAY_7: | 253 | DAY_7: |
254 | if ( KOPrefs::instance()->mShowIconDay7 ) { | 254 | if ( KOPrefs::instance()->mShowIconDay7 ) { |
255 | resetDateSilent( baseCycleDate , 2 ); | 255 | resetDateSilent( baseCycleDate , 2 ); |
256 | showWeekView();goto ENTE ;} | 256 | showWeekView();goto ENTE ;} |
257 | DAY_6: | 257 | DAY_6: |
258 | if ( KOPrefs::instance()->mShowIconDay6 ) { | 258 | if ( KOPrefs::instance()->mShowIconDay6 ) { |
259 | resetDateSilent( baseCycleDate , 2 ); | 259 | resetDateSilent( baseCycleDate , 2 ); |
260 | showMonthViewWeek();goto ENTE ;} | 260 | showMonthViewWeek();goto ENTE ;} |
261 | MONTH: | 261 | MONTH: |
262 | if ( KOPrefs::instance()->mShowIconMonth ) { | 262 | if ( KOPrefs::instance()->mShowIconMonth ) { |
263 | resetDateSilent( baseCycleDate , 2 ); | 263 | resetDateSilent( baseCycleDate , 2 ); |
264 | showMonthView();goto ENTE ;} | 264 | showMonthView();goto ENTE ;} |
265 | LIST: | 265 | LIST: |
266 | if ( KOPrefs::instance()->mShowIconList ) { | 266 | if ( KOPrefs::instance()->mShowIconList ) { |
267 | resetDateSilent( baseCycleDate , 2 ); | 267 | resetDateSilent( baseCycleDate , 2 ); |
268 | showListView() ;goto ENTE ;} | 268 | showListView() ;goto ENTE ;} |
269 | TODO: | 269 | TODO: |
270 | if ( KOPrefs::instance()->mShowIconTodoview ) { showTodoView() ;goto ENTE ;} | 270 | if ( KOPrefs::instance()->mShowIconTodoview ) { showTodoView() ;goto ENTE ;} |
271 | if ( KOPrefs::instance()->mShowIconNext ) { goto NEXT ;} | 271 | if ( KOPrefs::instance()->mShowIconNext ) { goto NEXT ;} |
272 | if ( KOPrefs::instance()->mShowIconNextDays ) { goto NEXT_X ;} | 272 | if ( KOPrefs::instance()->mShowIconNextDays ) { goto NEXT_X ;} |
273 | if ( KOPrefs::instance()->mShowIconJournal ) { goto JOURNAL;} | 273 | if ( KOPrefs::instance()->mShowIconJournal ) { goto JOURNAL;} |
274 | if ( KOPrefs::instance()->mShowIconDay1 ) { goto DAY_1 ;} | 274 | if ( KOPrefs::instance()->mShowIconDay1 ) { goto DAY_1 ;} |
275 | if ( KOPrefs::instance()->mShowIconDay5 ) { goto DAY_5 ;} | 275 | if ( KOPrefs::instance()->mShowIconDay5 ) { goto DAY_5 ;} |
276 | if ( KOPrefs::instance()->mShowIconDay7 ) { goto DAY_7 ;} | 276 | if ( KOPrefs::instance()->mShowIconDay7 ) { goto DAY_7 ;} |
277 | if ( KOPrefs::instance()->mShowIconDay6 ) { goto DAY_6 ;} | 277 | if ( KOPrefs::instance()->mShowIconDay6 ) { goto DAY_6 ;} |
278 | if ( KOPrefs::instance()->mShowIconMonth ) {goto MONTH ;} | 278 | if ( KOPrefs::instance()->mShowIconMonth ) {goto MONTH ;} |
279 | if ( KOPrefs::instance()->mShowIconList ) { goto LIST ;} | 279 | if ( KOPrefs::instance()->mShowIconList ) { goto LIST ;} |
280 | //if ( KOPrefs::instance()->mShowIconTodoview ) { showTodoView() ;goto ENTE ;} | 280 | //if ( KOPrefs::instance()->mShowIconTodoview ) { showTodoView() ;goto ENTE ;} |
281 | ENTE: | 281 | ENTE: |
282 | flagResetViewChangeDate = 0; | 282 | flagResetViewChangeDate = 0; |
283 | selecteddatescount = mMainView->dateNavigator()->selectedDates().count(); | 283 | selecteddatescount = mMainView->dateNavigator()->selectedDates().count(); |
284 | selecteddate = mMainView->dateNavigator()->selectedDates().first(); | 284 | selecteddate = mMainView->dateNavigator()->selectedDates().first(); |
285 | 285 | ||
286 | } | 286 | } |
287 | void KOViewManager::resetDateSilent( QDate date , int days ) | 287 | void KOViewManager::resetDateSilent( QDate date , int days ) |
288 | { | 288 | { |
289 | mMainView->dateNavigator()->blockSignals( true ); | 289 | mMainView->dateNavigator()->blockSignals( true ); |
290 | mMainView->dateNavigator()->selectDates( date , days ); | 290 | mMainView->dateNavigator()->selectDates( date , days ); |
291 | mMainView->dateNavigator()->blockSignals( false ); | 291 | mMainView->dateNavigator()->blockSignals( false ); |
292 | } | 292 | } |
293 | void KOViewManager::showView(KOrg::BaseView *view, bool fullScreen ) | 293 | void KOViewManager::showView(KOrg::BaseView *view, bool fullScreen ) |
294 | { | 294 | { |
295 | if ( flagResetViewChangeDate < 10 ) | 295 | if ( flagResetViewChangeDate < 10 ) |
296 | ++flagResetViewChangeDate; | 296 | ++flagResetViewChangeDate; |
297 | //mFlagShowNextxDays = false; | 297 | //mFlagShowNextxDays = false; |
298 | //if(view == mCurrentView) return; | 298 | //if(view == mCurrentView) return; |
299 | if ( view == 0 ) { | 299 | if ( view == 0 ) { |
300 | view = mCurrentView; | 300 | view = mCurrentView; |
301 | if ( view == 0 ) | 301 | if ( view == 0 ) |
302 | return; | 302 | return; |
303 | } | 303 | } |
304 | bool callupdate = !(view == mCurrentView); | 304 | bool callupdate = !(view == mCurrentView); |
305 | bool full = fullScreen; | 305 | bool full = fullScreen; |
306 | if(view == mCurrentView && view != mWhatsNextView ) { | 306 | if(view == mCurrentView && view != mWhatsNextView ) { |
307 | if ( mCurrentAgendaView < 0 ) | 307 | if ( mCurrentAgendaView < 0 ) |
308 | return; | 308 | return; |
309 | if ( view != mMonthView ) | 309 | if ( view != mMonthView ) |
310 | full = mMainView->leftFrame()->isVisible(); | 310 | full = mMainView->leftFrame()->isVisible(); |
311 | } else { | 311 | } else { |
312 | if ( view == mMonthView && mMonthView) | 312 | if ( view == mMonthView && mMonthView) |
313 | ;//mMonthView->skipResize = true ; | 313 | ;//mMonthView->skipResize = true ; |
314 | mCurrentView = view; | 314 | mCurrentView = view; |
315 | // bool full = fullScreen; | 315 | // bool full = fullScreen; |
316 | bool isFull = !mMainView->leftFrame()->isVisible(); | 316 | bool isFull = !mMainView->leftFrame()->isVisible(); |
317 | if ( isFull && KOPrefs::instance()->mViewChangeHoldFullscreen ) | 317 | if ( isFull && KOPrefs::instance()->mViewChangeHoldFullscreen ) |
318 | full = true; | 318 | full = true; |
319 | if ( !isFull && KOPrefs::instance()->mViewChangeHoldNonFullscreen ) | 319 | if ( !isFull && KOPrefs::instance()->mViewChangeHoldNonFullscreen ) |
320 | full = false; | 320 | full = false; |
321 | } | 321 | } |
322 | if ( mAgendaView ) mAgendaView->deleteSelectedDateTime(); | 322 | if ( mAgendaView ) mAgendaView->deleteSelectedDateTime(); |
323 | //raiseCurrentView( full ); | 323 | //raiseCurrentView( full ); |
324 | mMainView->processIncidenceSelection( 0 ); | 324 | mMainView->processIncidenceSelection( 0 ); |
325 | //mMainView->updateView(); | 325 | //mMainView->updateView(); |
326 | raiseCurrentView( full, callupdate ); | 326 | raiseCurrentView( full, callupdate ); |
327 | mMainView->adaptNavigationUnits(); | 327 | mMainView->adaptNavigationUnits(); |
328 | } | 328 | } |
329 | 329 | ||
330 | void KOViewManager::raiseCurrentView( bool fullScreen, bool callUpdateView ) | 330 | void KOViewManager::raiseCurrentView( bool fullScreen, bool callUpdateView ) |
331 | { | 331 | { |
332 | mCurrentAgendaView = 0; | 332 | mCurrentAgendaView = 0; |
333 | if ( fullScreen ) { | 333 | if ( fullScreen ) { |
334 | mMainView->leftFrame()->hide(); | 334 | mMainView->leftFrame()->hide(); |
335 | } else { | 335 | } else { |
336 | mMainView->leftFrame()->show(); | 336 | mMainView->leftFrame()->show(); |
337 | } | 337 | } |
338 | //if ( mCurrentView == mMonthView ) qApp->processEvents(); | 338 | //if ( mCurrentView == mMonthView ) qApp->processEvents(); |
339 | emit signalFullScreen( !fullScreen ); | 339 | emit signalFullScreen( !fullScreen ); |
340 | if ( callUpdateView ) | 340 | if ( callUpdateView ) |
341 | mMainView->updateView(); | 341 | mMainView->updateView(); |
342 | 342 | ||
343 | if ( globalFlagBlockAgenda == 5 ) { | 343 | if ( globalFlagBlockAgenda == 5 ) { |
344 | globalFlagBlockAgenda = 4; | 344 | globalFlagBlockAgenda = 4; |
345 | globalFlagBlockAgendaItemPaint = 1; | 345 | globalFlagBlockAgendaItemPaint = 1; |
346 | } | 346 | } |
347 | mMainView->viewStack()->raiseWidget(mCurrentView); | 347 | mMainView->viewStack()->raiseWidget(mCurrentView); |
348 | if ( globalFlagBlockAgenda == 4 ) { | 348 | if ( globalFlagBlockAgenda == 4 ) { |
349 | if ( mCurrentView == mAgendaView ) { | 349 | if ( mCurrentView == mAgendaView ) { |
350 | //globalFlagBlockAgenda =1 ; | 350 | //globalFlagBlockAgenda =1 ; |
351 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) | 351 | if ( KOPrefs::instance()->mSetTimeToDayStartAt ) |
352 | mAgendaView->setStartHour( KOPrefs::instance()->mDayBegins ); | 352 | mAgendaView->setStartHour( KOPrefs::instance()->mDayBegins ); |
353 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) | 353 | else if ( KOPrefs::instance()->mCenterOnCurrentTime ) |
354 | mAgendaView->setStartHour( QTime::currentTime ().hour() ); | 354 | mAgendaView->setStartHour( QTime::currentTime ().hour() ); |
355 | qApp->processEvents(); | 355 | qApp->processEvents(); |
356 | //qDebug("qApp->processEvents() "); | 356 | //qDebug("qApp->processEvents() "); |
357 | globalFlagBlockAgenda = 0; | 357 | globalFlagBlockAgenda = 0; |
358 | mAgendaView->repaintAgenda(); | 358 | mAgendaView->repaintAgenda(); |
359 | 359 | ||
360 | } | 360 | } |
361 | globalFlagBlockAgenda = 0; | 361 | globalFlagBlockAgenda = 0; |
362 | } | 362 | } |
363 | emit signalAgendaView( mCurrentView == mAgendaView ); | 363 | emit signalAgendaView( mCurrentView == mAgendaView ); |
364 | //qDebug("raiseCurrentView ende "); | 364 | //qDebug("raiseCurrentView ende "); |
365 | 365 | ||
366 | } | 366 | } |
367 | 367 | ||
368 | void KOViewManager::updateView() | 368 | void KOViewManager::updateView() |
369 | { | 369 | { |
370 | // qDebug("KOViewManager::updateView() "); | 370 | // qDebug("KOViewManager::updateView() "); |
371 | // if we are updating mTodoView, we get endless recursion | 371 | // if we are updating mTodoView, we get endless recursion |
372 | if ( mTodoView == mCurrentView ) | 372 | if ( mTodoView == mCurrentView ) |
373 | return; | 373 | return; |
374 | if ( mCurrentView ) mCurrentView->updateView(); | 374 | if ( mCurrentView ) mCurrentView->updateView(); |
375 | 375 | ||
376 | } | 376 | } |
377 | 377 | ||
378 | void KOViewManager::updateView(const QDate &start, const QDate &end) | 378 | void KOViewManager::updateView(const QDate &start, const QDate &end) |
379 | { | 379 | { |
380 | // kdDebug() << "KOViewManager::updateView()" << endl; | 380 | // kdDebug() << "KOViewManager::updateView()" << endl; |
381 | 381 | ||
382 | if (mCurrentView) mCurrentView->showDates(start, end); | 382 | if (mCurrentView) mCurrentView->showDates(start, end); |
383 | 383 | ||
384 | if (mTodoView && mTodoView == mCurrentView ) mTodoView->updateView(); | 384 | if (mTodoView && mTodoView == mCurrentView ) mTodoView->updateView(); |
385 | } | 385 | } |
386 | 386 | ||
387 | 387 | ||
388 | void KOViewManager::updateWNview() | 388 | void KOViewManager::updateWNview() |
389 | { | 389 | { |
390 | if ( mCurrentView == mWhatsNextView && mWhatsNextView ) | 390 | if ( mCurrentView == mWhatsNextView && mWhatsNextView ) |
391 | mWhatsNextView->updateView(); | 391 | mWhatsNextView->updateView(); |
392 | if ( mCurrentView == mMonthView && mMonthView ) | ||
393 | mMonthView->updateView(); | ||
392 | 394 | ||
393 | } | 395 | } |
394 | void KOViewManager::showWhatsNextView() | 396 | void KOViewManager::showWhatsNextView() |
395 | { | 397 | { |
396 | if (!mWhatsNextView) { | 398 | if (!mWhatsNextView) { |
397 | mWhatsNextView = new KOWhatsNextView(mMainView->calendar(),mMainView->viewStack(), | 399 | mWhatsNextView = new KOWhatsNextView(mMainView->calendar(),mMainView->viewStack(), |
398 | "KOViewManager::WhatsNextView"); | 400 | "KOViewManager::WhatsNextView"); |
399 | mWhatsNextView->setEventViewer( mMainView->getEventViewerDialog()); | 401 | mWhatsNextView->setEventViewer( mMainView->getEventViewerDialog()); |
400 | connect(mMainView, SIGNAL(configChanged()), mWhatsNextView, SLOT(updateConfig())); | 402 | connect(mMainView, SIGNAL(configChanged()), mWhatsNextView, SLOT(updateConfig())); |
401 | addView(mWhatsNextView); | 403 | addView(mWhatsNextView); |
402 | connect(this, SIGNAL( printWNV() ), | 404 | connect(this, SIGNAL( printWNV() ), |
403 | mWhatsNextView, SLOT( printMe() ) ); | 405 | mWhatsNextView, SLOT( printMe() ) ); |
404 | } | 406 | } |
405 | globalFlagBlockAgenda = 1; | 407 | globalFlagBlockAgenda = 1; |
406 | showView(mWhatsNextView, true ); | 408 | showView(mWhatsNextView, true ); |
407 | //mWhatsNextView->updateView(); | 409 | //mWhatsNextView->updateView(); |
408 | 410 | ||
409 | } | 411 | } |
410 | 412 | ||
411 | void KOViewManager::slotprintWNV() | 413 | void KOViewManager::slotprintWNV() |
412 | { | 414 | { |
413 | if (!mWhatsNextView) | 415 | if (!mWhatsNextView) |
414 | showWhatsNextView(); | 416 | showWhatsNextView(); |
415 | emit printWNV(); | 417 | emit printWNV(); |
416 | 418 | ||
417 | } | 419 | } |
418 | void KOViewManager::showListView() | 420 | void KOViewManager::showListView() |
419 | { | 421 | { |
420 | if (!mListView) { | 422 | if (!mListView) { |
421 | mListView = new KOListView(mMainView->calendar(), mMainView->viewStack(), "KOViewManager::ListView"); | 423 | mListView = new KOListView(mMainView->calendar(), mMainView->viewStack(), "KOViewManager::ListView"); |
422 | addView(mListView); | 424 | addView(mListView); |
423 | 425 | ||
424 | connect(mListView, SIGNAL(showIncidenceSignal(Incidence *)), | 426 | connect(mListView, SIGNAL(showIncidenceSignal(Incidence *)), |
425 | mMainView, SLOT(showIncidence(Incidence *))); | 427 | mMainView, SLOT(showIncidence(Incidence *))); |
426 | connect(mListView, SIGNAL(editIncidenceSignal(Incidence *)), | 428 | connect(mListView, SIGNAL(editIncidenceSignal(Incidence *)), |
427 | mMainView, SLOT(editIncidence(Incidence *))); | 429 | mMainView, SLOT(editIncidence(Incidence *))); |
428 | connect(mListView, SIGNAL(deleteIncidenceSignal(Incidence *)), | 430 | connect(mListView, SIGNAL(deleteIncidenceSignal(Incidence *)), |
429 | mMainView, SLOT(deleteIncidence(Incidence *))); | 431 | mMainView, SLOT(deleteIncidence(Incidence *))); |
430 | connect( mListView, SIGNAL( incidenceSelected( Incidence * ) ), | 432 | connect( mListView, SIGNAL( incidenceSelected( Incidence * ) ), |
431 | mMainView, SLOT( processMainViewSelection( Incidence * ) ) ); | 433 | mMainView, SLOT( processMainViewSelection( Incidence * ) ) ); |
432 | connect( mListView, SIGNAL( signalNewEvent() ), | 434 | connect( mListView, SIGNAL( signalNewEvent() ), |
433 | mMainView, SLOT( newEvent() ) ); | 435 | mMainView, SLOT( newEvent() ) ); |
434 | connect(mMainView, SIGNAL(configChanged()), mListView, SLOT(updateConfig())); | 436 | connect(mMainView, SIGNAL(configChanged()), mListView, SLOT(updateConfig())); |
435 | connect( mListView, SIGNAL( cloneIncidenceSignal( Incidence * ) ), | 437 | connect( mListView, SIGNAL( cloneIncidenceSignal( Incidence * ) ), |
436 | mMainView, SLOT ( cloneIncidence( Incidence * ) ) ); | 438 | mMainView, SLOT ( cloneIncidence( Incidence * ) ) ); |
437 | connect( mListView, SIGNAL( cancelIncidenceSignal( Incidence * ) ), | 439 | connect( mListView, SIGNAL( cancelIncidenceSignal( Incidence * ) ), |
438 | mMainView, SLOT ( cancelIncidence( Incidence * ) ) ); | 440 | mMainView, SLOT ( cancelIncidence( Incidence * ) ) ); |
439 | connect( mListView, SIGNAL( moveIncidenceSignal( Incidence * ) ), | 441 | connect( mListView, SIGNAL( moveIncidenceSignal( Incidence * ) ), |
440 | mMainView, SLOT ( moveIncidence( Incidence * ) ) ); | 442 | mMainView, SLOT ( moveIncidence( Incidence * ) ) ); |
441 | connect( mListView, SIGNAL( beamIncidenceSignal( Incidence * ) ), | 443 | connect( mListView, SIGNAL( beamIncidenceSignal( Incidence * ) ), |
442 | mMainView, SLOT ( beamIncidence( Incidence * ) ) ); | 444 | mMainView, SLOT ( beamIncidence( Incidence * ) ) ); |
443 | } | 445 | } |
444 | // bool temp = mFlagShowNextxDays; | 446 | // bool temp = mFlagShowNextxDays; |
445 | //globalFlagBlockPainting = true; | 447 | //globalFlagBlockPainting = true; |
446 | globalFlagBlockAgenda = 1; | 448 | globalFlagBlockAgenda = 1; |
447 | if ( KOPrefs::instance()->mListViewMonthTimespan ) { | 449 | if ( KOPrefs::instance()->mListViewMonthTimespan ) { |
448 | mMainView->setBlockShowDates( true ); | 450 | mMainView->setBlockShowDates( true ); |
449 | mMainView->dateNavigator()->selectMonth(); | 451 | mMainView->dateNavigator()->selectMonth(); |
450 | mMainView->setBlockShowDates( false ); | 452 | mMainView->setBlockShowDates( false ); |
451 | } | 453 | } |
452 | showView(mListView, KOPrefs::instance()->mFullViewTodo); | 454 | showView(mListView, KOPrefs::instance()->mFullViewTodo); |
453 | //mFlagShowNextxDays = temp; | 455 | //mFlagShowNextxDays = temp; |
454 | } | 456 | } |
455 | 457 | ||
456 | void KOViewManager::showAgendaView( bool fullScreen ) | 458 | void KOViewManager::showAgendaView( bool fullScreen ) |
457 | { | 459 | { |
458 | 460 | ||
459 | mMainView->dialogManager()->hideSearchDialog(); | 461 | mMainView->dialogManager()->hideSearchDialog(); |
460 | // qDebug("KOViewManager::showAgendaView "); | 462 | // qDebug("KOViewManager::showAgendaView "); |
461 | bool full; | 463 | bool full; |
462 | full = fullScreen; | 464 | full = fullScreen; |
463 | if (!mAgendaView) { | 465 | if (!mAgendaView) { |
464 | full = false; | 466 | full = false; |
465 | mAgendaView = new KOAgendaView(mMainView->calendar(), mMainView->viewStack(), "KOViewManager::AgendaView"); | 467 | mAgendaView = new KOAgendaView(mMainView->calendar(), mMainView->viewStack(), "KOViewManager::AgendaView"); |
466 | addView(mAgendaView); | 468 | addView(mAgendaView); |
467 | #ifndef DESKTOP_VERSION | 469 | #ifndef DESKTOP_VERSION |
468 | QPEApplication::setStylusOperation( mAgendaView, QPEApplication::RightOnHold ); | 470 | QPEApplication::setStylusOperation( mAgendaView, QPEApplication::RightOnHold ); |
469 | #endif | 471 | #endif |
470 | connect( mAgendaView, SIGNAL( incidenceChanged(Incidence *, int )), | 472 | connect( mAgendaView, SIGNAL( incidenceChanged(Incidence *, int )), |
471 | mMainView, SLOT( changeIncidenceDisplay( Incidence *, int ) )); | 473 | mMainView, SLOT( changeIncidenceDisplay( Incidence *, int ) )); |
472 | 474 | ||
473 | // SIGNALS/SLOTS FOR DAY/WEEK VIEW | 475 | // SIGNALS/SLOTS FOR DAY/WEEK VIEW |
474 | 476 | ||
475 | connect(mAgendaView,SIGNAL(showDateView( int, QDate )),SLOT(showDateView( int, QDate ))); | 477 | connect(mAgendaView,SIGNAL(showDateView( int, QDate )),SLOT(showDateView( int, QDate ))); |
476 | 478 | ||
477 | connect(mAgendaView,SIGNAL(newTodoSignal(QDateTime,bool)), | 479 | connect(mAgendaView,SIGNAL(newTodoSignal(QDateTime,bool)), |
478 | mMainView, SLOT(newTodoDateTime(QDateTime,bool))); | 480 | mMainView, SLOT(newTodoDateTime(QDateTime,bool))); |
479 | connect(mAgendaView,SIGNAL(newEventSignal(QDateTime)), | 481 | connect(mAgendaView,SIGNAL(newEventSignal(QDateTime)), |
480 | mMainView, SLOT(newEvent(QDateTime))); | 482 | mMainView, SLOT(newEvent(QDateTime))); |
481 | connect(mAgendaView,SIGNAL(newEventSignal(QDateTime,QDateTime)), | 483 | connect(mAgendaView,SIGNAL(newEventSignal(QDateTime,QDateTime)), |
482 | mMainView, SLOT(newEvent(QDateTime,QDateTime))); | 484 | mMainView, SLOT(newEvent(QDateTime,QDateTime))); |
483 | connect(mAgendaView,SIGNAL(newEventSignal(QDate)), | 485 | connect(mAgendaView,SIGNAL(newEventSignal(QDate)), |
484 | mMainView, SLOT(newEvent(QDate))); | 486 | mMainView, SLOT(newEvent(QDate))); |
485 | 487 | ||
486 | connect(mAgendaView, SIGNAL(editIncidenceSignal(Incidence *)), | 488 | connect(mAgendaView, SIGNAL(editIncidenceSignal(Incidence *)), |
487 | mMainView, SLOT(editIncidence(Incidence *))); | 489 | mMainView, SLOT(editIncidence(Incidence *))); |
488 | connect(mAgendaView, SIGNAL(showIncidenceSignal(Incidence *)), | 490 | connect(mAgendaView, SIGNAL(showIncidenceSignal(Incidence *)), |
489 | mMainView, SLOT(showIncidence(Incidence *))); | 491 | mMainView, SLOT(showIncidence(Incidence *))); |
490 | connect(mAgendaView, SIGNAL(deleteIncidenceSignal(Incidence *)), | 492 | connect(mAgendaView, SIGNAL(deleteIncidenceSignal(Incidence *)), |
491 | mMainView, SLOT(deleteIncidence(Incidence *))); | 493 | mMainView, SLOT(deleteIncidence(Incidence *))); |
492 | 494 | ||
493 | connect( mAgendaView, SIGNAL( incidenceSelected( Incidence * ) ), | 495 | connect( mAgendaView, SIGNAL( incidenceSelected( Incidence * ) ), |
494 | mMainView, SLOT( processMainViewSelection( Incidence * ) ) ); | 496 | mMainView, SLOT( processMainViewSelection( Incidence * ) ) ); |
495 | 497 | ||
496 | connect(mAgendaView, SIGNAL( toggleExpand() ), | 498 | connect(mAgendaView, SIGNAL( toggleExpand() ), |
497 | mMainView, SLOT( toggleExpand() ) ); | 499 | mMainView, SLOT( toggleExpand() ) ); |
498 | 500 | ||
499 | connect( mAgendaView, SIGNAL( cloneIncidenceSignal(Incidence *) ), | 501 | connect( mAgendaView, SIGNAL( cloneIncidenceSignal(Incidence *) ), |
500 | mMainView, SLOT(cloneIncidence(Incidence *) ) ) ; | 502 | mMainView, SLOT(cloneIncidence(Incidence *) ) ) ; |
501 | connect( mAgendaView, SIGNAL( cancelIncidenceSignal(Incidence *) ), | 503 | connect( mAgendaView, SIGNAL( cancelIncidenceSignal(Incidence *) ), |
502 | mMainView, SLOT(cancelIncidence(Incidence *) ) ) ; | 504 | mMainView, SLOT(cancelIncidence(Incidence *) ) ) ; |
503 | connect(mMainView, SIGNAL(configChanged()), mAgendaView, SLOT(updateConfig())); | 505 | connect(mMainView, SIGNAL(configChanged()), mAgendaView, SLOT(updateConfig())); |
504 | connect( mMainView, SIGNAL( todoModified( Todo *, int )), mAgendaView, | 506 | connect( mMainView, SIGNAL( todoModified( Todo *, int )), mAgendaView, |
505 | SLOT( updateTodo( Todo *, int ) ) ); | 507 | SLOT( updateTodo( Todo *, int ) ) ); |
506 | connect( mAgendaView,SIGNAL( todoMoved( Todo *, int )), | 508 | connect( mAgendaView,SIGNAL( todoMoved( Todo *, int )), |
507 | mMainView, SIGNAL( todoModified( Todo *, int ))); | 509 | mMainView, SIGNAL( todoModified( Todo *, int ))); |
508 | connect( mAgendaView, SIGNAL( moveIncidenceSignal( Incidence * ) ), | 510 | connect( mAgendaView, SIGNAL( moveIncidenceSignal( Incidence * ) ), |
509 | mMainView, SLOT ( moveIncidence( Incidence * ) ) ); | 511 | mMainView, SLOT ( moveIncidence( Incidence * ) ) ); |
510 | connect( mAgendaView, SIGNAL( beamIncidenceSignal( Incidence * ) ), | 512 | connect( mAgendaView, SIGNAL( beamIncidenceSignal( Incidence * ) ), |
511 | mMainView, SLOT ( beamIncidence( Incidence * ) ) ); | 513 | mMainView, SLOT ( beamIncidence( Incidence * ) ) ); |
512 | connect( mAgendaView, SIGNAL( selectWeekNum( int ) ), | 514 | connect( mAgendaView, SIGNAL( selectWeekNum( int ) ), |
513 | mMainView->dateNavigator(), SLOT ( selectWeek( int ) ) ); | 515 | mMainView->dateNavigator(), SLOT ( selectWeek( int ) ) ); |
514 | mAgendaView->readSettings(); | 516 | mAgendaView->readSettings(); |
515 | mAgendaView->updateConfig(); | 517 | mAgendaView->updateConfig(); |
516 | } | 518 | } |
517 | 519 | ||
518 | showView( mAgendaView, full); | 520 | showView( mAgendaView, full); |
519 | 521 | ||